zhgdyun/public/js/bos3D/BOS3D.min.js
2022-06-08 14:51:11 +08:00

68 lines
4.8 MiB
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/*!!**
* @license
* BOS3D V5.0.0
* A WebGL-based 3D Viewer for threejs,it is modified for BosWinner
* http://bos3d.bimwinner.com
* Built on 2021/9/4 下午7:19:57
* commitHash 99809cde
* Copyright 2021, 盈嘉互联(北京)科技有限公司
***/
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).BOS3D={})}(this,(function(e){"use strict";console.log("BOS3D Version: 5.0.0");var t="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{};!function(e,t){e(t={exports:{}},t.exports)}((function(e){!function(t,i){var n=function(){function e(e){return"[object Array]"===Object.prototype.toString.call(e)}function t(e,t){for(var i in t)t.hasOwnProperty(i)&&(e[i]=t[i])}function i(e){if(!(this instanceof i))throw new TypeError(this+"is not a promise");if("function"!=typeof e)throw new TypeError("Promise resolver "+e+" is not a function");var t=new n;this._resolver=t;try{e((function(e){t.resolve(e)}),(function(e){t.reject(e)}))}catch(e){t.reject(e)}}function n(){this._callbacks=[],this._errbacks=[],this._status="pending",this._result=null}return t(i.prototype,{then:function(e,t){var n,r,o=new this.constructor((function(e,t){n=e,r=t}));return this._resolver._addCallbacks("function"==typeof e?i._makeCallback(o,n,r,e):n,"function"==typeof t?i._makeCallback(o,n,r,t):r),o},catch:function(e){return this.then(void 0,e)}}),i._makeCallback=function(e,t,i,n){return function(r){var o;try{o=n(r)}catch(e){return void i(e)}o!==e?t(o):i(new TypeError("Cannot resolve a promise with itself"))}},i.resolve=function(e){return e&&e.constructor===this?e:new this((function(t){t(e)}))},i.reject=function(e){var t=new this((function(){}));return t._resolver._result=e,t._resolver._status="rejected",t},i.all=function(t){var i=this;return new i((function(n,r){if(e(t)){var o=t.length,a=0,s=t.length,l=[];if(1>s)return n(l);for(;s>a;a++)i.resolve(t[a]).then(c(a),r)}else r(new TypeError("Promise.all expects an array of values or promises"));function c(e){return function(t){l[e]=t,--o||n(l)}}}))},i.race=function(t){var i=this;return new i((function(n,r){if(e(t))for(var o=0,a=t.length;a>o;o++)i.resolve(t[o]).then(n,r);else r(new TypeError("Promise.race expects an array of values or promises"))}))},i.async="undefined"!=typeof setImmediate?function(e){setImmediate(e)}:"undefined"!=typeof process&&process.nextTick?process.nextTick:function(e){setTimeout(e,0)},t(n.prototype,{fulfill:function(e){var t=this._status;"pending"!==t&&"accepted"!==t||(this._result=e,this._status="fulfilled"),"fulfilled"===this._status&&(this._notify(this._callbacks,this._result),this._callbacks=[],this._errbacks=null)},reject:function(e){var t=this._status;"pending"!==t&&"accepted"!==t||(this._result=e,this._status="rejected"),"rejected"===this._status&&(this._notify(this._errbacks,this._result),this._callbacks=null,this._errbacks=[])},resolve:function(e){"pending"===this._status&&(this._status="accepted",this._value=e,(this._callbacks&&this._callbacks.length||this._errbacks&&this._errbacks.length)&&this._unwrap(this._value))},_unwrap:function(e){var t,i=this,n=!1;if(!e||"object"!=typeof e&&"function"!=typeof e)i.fulfill(e);else try{"function"==typeof(t=e.then)?t.call(e,(function(e){n||(n=!0,i._unwrap(e))}),(function(e){n||(n=!0,i.reject(e))})):i.fulfill(e)}catch(e){n||i.reject(e)}},_addCallbacks:function(e,t){var i=this._callbacks,n=this._errbacks;switch(i&&i.push(e),n&&n.push(t),this._status){case"accepted":this._unwrap(this._value);break;case"fulfilled":this.fulfill(this._result);break;case"rejected":this.reject(this._result)}},_notify:function(e,t){e.length&&i.async((function(){var i,n;for(i=0,n=e.length;n>i;++i)e[i](t)}))}}),i.Resolver=n,i}();e&&(e.exports=n),(t=t||self).PromisePolyfill=n,t.Promise||(t.Promise=n)}(t)}));
/**
* @license
* Copyright 2010-2021 Three.js Authors
* SPDX-License-Identifier: MIT
*/
const i="129",n={LEFT:0,MIDDLE:1,RIGHT:2,ROTATE:0,DOLLY:1,PAN:2},r=100,o=200,a=201,s=300,l=301,c=302,h=303,d=304,u=306,p=307,g=1e3,f=1001,m=1002,A=1003,y=1004,v=1005,C=1006,I=1007,x=1008,w=1009,M=1012,E=1014,B=1015,S=1016,b=1020,k=1022,D=1023,T=1026,R=1027,U=33776,F=33777,Q=33778,L=33779,O=35840,N=35841,P=35842,G=35843,K=37492,V=37496,Y=2300,H=2301,j=2302,W=2400,J=2401,z=2402,q=2500,Z=2501,X=3e3,_=3001,$=3007,ee=3002,te=3004,ie=3005,ne=3006,re=3201,oe=7680,ae=7681,se=7682,le=7683,ce=34055,he=34056,de=515,ue=519,pe=35044,ge=35048,fe="300 es";class me{addEventListener(e,t){void 0===this._listeners&&(this._listeners={});const i=this._listeners;void 0===i[e]&&(i[e]=[]),-1===i[e].indexOf(t)&&i[e].push(t)}hasEventListener(e,t){if(void 0===this._listeners)return!1;const i=this._listeners;return void 0!==i[e]&&-1!==i[e].indexOf(t)}removeEventListener(e,t){if(void 0===this._listeners)return;const i=this._listeners[e];if(void 0!==i){const e=i.indexOf(t);-1!==e&&i.splice(e,1)}}dispatchEvent(e){if(void 0===this._listeners)return;const t=this._listeners[e.type];if(void 0!==t){e.target=this;const i=t.slice(0);for(let t=0,n=i.length;n>t;t++)i[t].call(this,e);e.target=null}}}const Ae=[];for(let e=0;256>e;e++)Ae[e]=(16>e?"0":"")+e.toString(16);let ye=1234567;const ve=Math.PI/180,Ce=180/Math.PI;function Ie(){const e=4294967295*Math.random()|0,t=4294967295*Math.random()|0,i=4294967295*Math.random()|0,n=4294967295*Math.random()|0;return(Ae[255&e]+Ae[e>>8&255]+Ae[e>>16&255]+Ae[e>>24&255]+"-"+Ae[255&t]+Ae[t>>8&255]+"-"+Ae[t>>16&15|64]+Ae[t>>24&255]+"-"+Ae[63&i|128]+Ae[i>>8&255]+"-"+Ae[i>>16&255]+Ae[i>>24&255]+Ae[255&n]+Ae[n>>8&255]+Ae[n>>16&255]+Ae[n>>24&255]).toUpperCase()}function xe(e,t,i){return Math.max(t,Math.min(i,e))}function we(e,t){return(e%t+t)%t}function Me(e,t,i){return(1-i)*e+i*t}function Ee(e){return 0==(e&e-1)&&0!==e}function Be(e){return Math.pow(2,Math.ceil(Math.log(e)/Math.LN2))}function Se(e){return Math.pow(2,Math.floor(Math.log(e)/Math.LN2))}var be=Object.freeze({__proto__:null,DEG2RAD:ve,RAD2DEG:Ce,generateUUID:Ie,clamp:xe,euclideanModulo:we,mapLinear:function(e,t,i,n,r){return n+(e-t)*(r-n)/(i-t)},inverseLerp:function(e,t,i){return e!==t?(i-e)/(t-e):0},lerp:Me,damp:function(e,t,i,n){return Me(e,t,1-Math.exp(-i*n))},pingpong:function(e,t=1){return t-Math.abs(we(e,2*t)-t)},smoothstep:function(e,t,i){return e>t?i>e?(e=(e-t)/(i-t))*e*(3-2*e):1:0},smootherstep:function(e,t,i){return e>t?i>e?(e=(e-t)/(i-t))*e*e*(e*(6*e-15)+10):1:0},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*(.5-Math.random())},seededRandom:function(e){return void 0!==e&&(ye=e%2147483647),ye=16807*ye%2147483647,(ye-1)/2147483646},degToRad:function(e){return e*ve},radToDeg:function(e){return e*Ce},isPowerOfTwo:Ee,ceilPowerOfTwo:Be,floorPowerOfTwo:Se,setQuaternionFromProperEuler:function(e,t,i,n,r){const o=Math.cos,a=Math.sin,s=o(i/2),l=a(i/2),c=o((t+n)/2),h=a((t+n)/2),d=o((t-n)/2),u=a((t-n)/2),p=o((n-t)/2),g=a((n-t)/2);switch(r){case"XYX":e.set(s*h,l*d,l*u,s*c);break;case"YZY":e.set(l*u,s*h,l*d,s*c);break;case"ZXZ":e.set(l*d,l*u,s*h,s*c);break;case"XZX":e.set(s*h,l*g,l*p,s*c);break;case"YXY":e.set(l*p,s*h,l*g,s*c);break;case"ZYZ":e.set(l*g,l*p,s*h,s*c);break;default:console.warn("THREE.MathUtils: .setQuaternionFromProperEuler() encountered an unknown order: "+r)}}});class ke{constructor(e=0,t=0){this.x=e,this.y=t}get width(){return this.x}set width(e){this.x=e}get height(){return this.y}set height(e){this.y=e}set(e,t){return this.x=e,this.y=t,this}setScalar(e){return this.x=e,this.y=e,this}setX(e){return this.x=e,this}setY(e){return this.y=e,this}setComponent(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}getComponent(e){switch(e){case 0:return this.x;case 1:return this.y;default:throw new Error("index is out of range: "+e)}}clone(){return new this.constructor(this.x,this.y)}copy(e){return this.x=e.x,this.y=e.y,this}add(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)}addScalar(e){return this.x+=e,this.y+=e,this}addVectors(e,t){return this.x=e.x+t.x,this.y=e.y+t.y,this}addScaledVector(e,t){return this.x+=e.x*t,this.y+=e.y*t,this}sub(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)}subScalar(e){return this.x-=e,this.y-=e,this}subVectors(e,t){return this.x=e.x-t.x,this.y=e.y-t.y,this}multiply(e){return this.x*=e.x,this.y*=e.y,this}multiplyScalar(e){return this.x*=e,this.y*=e,this}divide(e){return this.x/=e.x,this.y/=e.y,this}divideScalar(e){return this.multiplyScalar(1/e)}applyMatrix3(e){const t=this.x,i=this.y,n=e.elements;return this.x=n[0]*t+n[3]*i+n[6],this.y=n[1]*t+n[4]*i+n[7],this}min(e){return this.x=Math.min(this.x,e.x),this.y=Math.min(this.y,e.y),this}max(e){return this.x=Math.max(this.x,e.x),this.y=Math.max(this.y,e.y),this}clamp(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}clampScalar(e,t){return this.x=Math.max(e,Math.min(t,this.x)),this.y=Math.max(e,Math.min(t,this.y)),this}clampLength(e,t){const i=this.length();return this.divideScalar(i||1).multiplyScalar(Math.max(e,Math.min(t,i)))}floor(){return this.x=Math.floor(this.x),this.y=Math.floor(this.y),this}ceil(){return this.x=Math.ceil(this.x),this.y=Math.ceil(this.y),this}round(){return this.x=Math.round(this.x),this.y=Math.round(this.y),this}roundToZero(){return this.x=0>this.x?Math.ceil(this.x):Math.floor(this.x),this.y=0>this.y?Math.ceil(this.y):Math.floor(this.y),this}negate(){return this.x=-this.x,this.y=-this.y,this}dot(e){return this.x*e.x+this.y*e.y}cross(e){return this.x*e.y-this.y*e.x}lengthSq(){return this.x*this.x+this.y*this.y}length(){return Math.sqrt(this.x*this.x+this.y*this.y)}manhattanLength(){return Math.abs(this.x)+Math.abs(this.y)}normalize(){return this.divideScalar(this.length()||1)}angle(){return Math.atan2(-this.y,-this.x)+Math.PI}distanceTo(e){return Math.sqrt(this.distanceToSquared(e))}distanceToSquared(e){const t=this.x-e.x,i=this.y-e.y;return t*t+i*i}manhattanDistanceTo(e){return Math.abs(this.x-e.x)+Math.abs(this.y-e.y)}setLength(e){return this.normalize().multiplyScalar(e)}lerp(e,t){return this.x+=(e.x-this.x)*t,this.y+=(e.y-this.y)*t,this}lerpVectors(e,t,i){return this.x=e.x+(t.x-e.x)*i,this.y=e.y+(t.y-e.y)*i,this}equals(e){return e.x===this.x&&e.y===this.y}fromArray(e,t=0){return this.x=e[t],this.y=e[t+1],this}toArray(e=[],t=0){return e[t]=this.x,e[t+1]=this.y,e}fromBufferAttribute(e,t,i){return void 0!==i&&console.warn("THREE.Vector2: offset has been removed from .fromBufferAttribute()."),this.x=e.getX(t),this.y=e.getY(t),this}rotateAround(e,t){const i=Math.cos(t),n=Math.sin(t),r=this.x-e.x,o=this.y-e.y;return this.x=r*i-o*n+e.x,this.y=r*n+o*i+e.y,this}random(){return this.x=Math.random(),this.y=Math.random(),this}}ke.prototype.isVector2=!0;class De{constructor(){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.")}set(e,t,i,n,r,o,a,s,l){const c=this.elements;return c[0]=e,c[1]=n,c[2]=a,c[3]=t,c[4]=r,c[5]=s,c[6]=i,c[7]=o,c[8]=l,this}identity(){return this.set(1,0,0,0,1,0,0,0,1),this}copy(e){const t=this.elements,i=e.elements;return t[0]=i[0],t[1]=i[1],t[2]=i[2],t[3]=i[3],t[4]=i[4],t[5]=i[5],t[6]=i[6],t[7]=i[7],t[8]=i[8],this}extractBasis(e,t,i){return e.setFromMatrix3Column(this,0),t.setFromMatrix3Column(this,1),i.setFromMatrix3Column(this,2),this}setFromMatrix4(e){const 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}multiply(e){return this.multiplyMatrices(this,e)}premultiply(e){return this.multiplyMatrices(e,this)}multiplyMatrices(e,t){const i=e.elements,n=t.elements,r=this.elements,o=i[0],a=i[3],s=i[6],l=i[1],c=i[4],h=i[7],d=i[2],u=i[5],p=i[8],g=n[0],f=n[3],m=n[6],A=n[1],y=n[4],v=n[7],C=n[2],I=n[5],x=n[8];return r[0]=o*g+a*A+s*C,r[3]=o*f+a*y+s*I,r[6]=o*m+a*v+s*x,r[1]=l*g+c*A+h*C,r[4]=l*f+c*y+h*I,r[7]=l*m+c*v+h*x,r[2]=d*g+u*A+p*C,r[5]=d*f+u*y+p*I,r[8]=d*m+u*v+p*x,this}multiplyScalar(e){const 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}determinant(){const e=this.elements,t=e[0],i=e[1],n=e[2],r=e[3],o=e[4],a=e[5],s=e[6],l=e[7],c=e[8];return t*o*c-t*a*l-i*r*c+i*a*s+n*r*l-n*o*s}invert(){const e=this.elements,t=e[0],i=e[1],n=e[2],r=e[3],o=e[4],a=e[5],s=e[6],l=e[7],c=e[8],h=c*o-a*l,d=a*s-c*r,u=l*r-o*s,p=t*h+i*d+n*u;if(0===p)return this.set(0,0,0,0,0,0,0,0,0);const g=1/p;return e[0]=h*g,e[1]=(n*l-c*i)*g,e[2]=(a*i-n*o)*g,e[3]=d*g,e[4]=(c*t-n*s)*g,e[5]=(n*r-a*t)*g,e[6]=u*g,e[7]=(i*s-l*t)*g,e[8]=(o*t-i*r)*g,this}transpose(){let e;const 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}getNormalMatrix(e){return this.setFromMatrix4(e).invert().transpose()}transposeIntoArray(e){const 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}setUvTransform(e,t,i,n,r,o,a){const s=Math.cos(r),l=Math.sin(r);return this.set(i*s,i*l,-i*(s*o+l*a)+o+e,-n*l,n*s,-n*(-l*o+s*a)+a+t,0,0,1),this}scale(e,t){const i=this.elements;return i[0]*=e,i[3]*=e,i[6]*=e,i[1]*=t,i[4]*=t,i[7]*=t,this}rotate(e){const t=Math.cos(e),i=Math.sin(e),n=this.elements,r=n[0],o=n[3],a=n[6],s=n[1],l=n[4],c=n[7];return n[0]=t*r+i*s,n[3]=t*o+i*l,n[6]=t*a+i*c,n[1]=-i*r+t*s,n[4]=-i*o+t*l,n[7]=-i*a+t*c,this}translate(e,t){const i=this.elements;return i[0]+=e*i[2],i[3]+=e*i[5],i[6]+=e*i[8],i[1]+=t*i[2],i[4]+=t*i[5],i[7]+=t*i[8],this}equals(e){const t=this.elements,i=e.elements;for(let e=0;9>e;e++)if(t[e]!==i[e])return!1;return!0}fromArray(e,t=0){for(let i=0;9>i;i++)this.elements[i]=e[i+t];return this}toArray(e=[],t=0){const i=this.elements;return e[t]=i[0],e[t+1]=i[1],e[t+2]=i[2],e[t+3]=i[3],e[t+4]=i[4],e[t+5]=i[5],e[t+6]=i[6],e[t+7]=i[7],e[t+8]=i[8],e}clone(){return(new this.constructor).fromArray(this.elements)}}let Te;De.prototype.isMatrix3=!0;class Re{static getDataURL(e){if(/^data:/i.test(e.src))return e.src;if("undefined"==typeof HTMLCanvasElement)return e.src;let t;if(e instanceof HTMLCanvasElement)t=e;else{void 0===Te&&(Te=document.createElementNS("http://www.w3.org/1999/xhtml","canvas")),Te.width=e.width,Te.height=e.height;const i=Te.getContext("2d");e instanceof ImageData?i.putImageData(e,0,0):i.drawImage(e,0,0,e.width,e.height),t=Te}return t.width>2048||t.height>2048?(console.warn("THREE.ImageUtils.getDataURL: Image converted to jpg for performance reasons",e),t.toDataURL("image/jpeg",.6)):t.toDataURL("image/png")}}let Ue=0;class Fe extends me{constructor(e=Fe.DEFAULT_IMAGE,t=Fe.DEFAULT_MAPPING,i=1001,n=1001,r=1006,o=1008,a=1023,s=1009,l=1,c=3e3){super(),Object.defineProperty(this,"id",{value:Ue++}),this.uuid=Ie(),this.name="",this.image=e,this.mipmaps=[],this.mapping=t,this.wrapS=i,this.wrapT=n,this.magFilter=r,this.minFilter=o,this.anisotropy=l,this.format=a,this.internalFormat=null,this.type=s,this.offset=new ke(0,0),this.repeat=new ke(1,1),this.center=new ke(0,0),this.rotation=0,this.matrixAutoUpdate=!0,this.matrix=new De,this.generateMipmaps=!0,this.premultiplyAlpha=!1,this.flipY=!0,this.unpackAlignment=4,this.encoding=c,this.version=0,this.onUpdate=null}set needsUpdate(e){!0===e&&this.version++}updateMatrix(){this.matrix.setUvTransform(this.offset.x,this.offset.y,this.repeat.x,this.repeat.y,this.rotation,this.center.x,this.center.y)}clone(){return(new this.constructor).copy(this)}copy(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(e){const t=void 0===e||"string"==typeof e;if(!t&&void 0!==e.textures[this.uuid])return e.textures[this.uuid];const i={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){const n=this.image;if(void 0===n.uuid&&(n.uuid=Ie()),!t&&void 0===e.images[n.uuid]){let t;if(Array.isArray(n)){t=[];for(let e=0,i=n.length;i>e;e++)t.push(Qe(n[e].isDataTexture?n[e].image:n[e]))}else t=Qe(n);e.images[n.uuid]={uuid:n.uuid,url:t}}i.image=n.uuid}return t||(e.textures[this.uuid]=i),i}dispose(){this.dispatchEvent({type:"dispose"})}transformUv(e){if(this.mapping!==s)return e;if(e.applyMatrix3(this.matrix),0>e.x||e.x>1)switch(this.wrapS){case g:e.x=e.x-Math.floor(e.x);break;case f:e.x=0>e.x?0:1;break;case m:e.x=1===Math.abs(Math.floor(e.x)%2)?Math.ceil(e.x)-e.x:e.x-Math.floor(e.x)}if(0>e.y||e.y>1)switch(this.wrapT){case g:e.y=e.y-Math.floor(e.y);break;case f:e.y=0>e.y?0:1;break;case m:e.y=1===Math.abs(Math.floor(e.y)%2)?Math.ceil(e.y)-e.y:e.y-Math.floor(e.y)}return this.flipY&&(e.y=1-e.y),e}}function Qe(e){return"undefined"!=typeof HTMLImageElement&&e instanceof HTMLImageElement||"undefined"!=typeof HTMLCanvasElement&&e instanceof HTMLCanvasElement||"undefined"!=typeof ImageBitmap&&e instanceof ImageBitmap?Re.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."),{})}Fe.DEFAULT_IMAGE=void 0,Fe.DEFAULT_MAPPING=s,Fe.prototype.isTexture=!0;class Le{constructor(e=0,t=0,i=0,n=1){this.x=e,this.y=t,this.z=i,this.w=n}get width(){return this.z}set width(e){this.z=e}get height(){return this.w}set height(e){this.w=e}set(e,t,i,n){return this.x=e,this.y=t,this.z=i,this.w=n,this}setScalar(e){return this.x=e,this.y=e,this.z=e,this.w=e,this}setX(e){return this.x=e,this}setY(e){return this.y=e,this}setZ(e){return this.z=e,this}setW(e){return this.w=e,this}setComponent(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}getComponent(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)}}clone(){return new this.constructor(this.x,this.y,this.z,this.w)}copy(e){return this.x=e.x,this.y=e.y,this.z=e.z,this.w=void 0!==e.w?e.w:1,this}add(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)}addScalar(e){return this.x+=e,this.y+=e,this.z+=e,this.w+=e,this}addVectors(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}addScaledVector(e,t){return this.x+=e.x*t,this.y+=e.y*t,this.z+=e.z*t,this.w+=e.w*t,this}sub(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)}subScalar(e){return this.x-=e,this.y-=e,this.z-=e,this.w-=e,this}subVectors(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}multiply(e){return this.x*=e.x,this.y*=e.y,this.z*=e.z,this.w*=e.w,this}multiplyScalar(e){return this.x*=e,this.y*=e,this.z*=e,this.w*=e,this}applyMatrix4(e){const t=this.x,i=this.y,n=this.z,r=this.w,o=e.elements;return this.x=o[0]*t+o[4]*i+o[8]*n+o[12]*r,this.y=o[1]*t+o[5]*i+o[9]*n+o[13]*r,this.z=o[2]*t+o[6]*i+o[10]*n+o[14]*r,this.w=o[3]*t+o[7]*i+o[11]*n+o[15]*r,this}divideScalar(e){return this.multiplyScalar(1/e)}setAxisAngleFromQuaternion(e){this.w=2*Math.acos(e.w);const t=Math.sqrt(1-e.w*e.w);return 1e-4>t?(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}setAxisAngleFromRotationMatrix(e){let t,i,n,r;const o=.01,a=.1,s=e.elements,l=s[0],c=s[4],h=s[8],d=s[1],u=s[5],p=s[9],g=s[2],f=s[6],m=s[10];if(Math.abs(c-d)<o&&Math.abs(h-g)<o&&Math.abs(p-f)<o){if(Math.abs(c+d)<a&&Math.abs(h+g)<a&&Math.abs(p+f)<a&&Math.abs(l+u+m-3)<a)return this.set(1,0,0,0),this;t=Math.PI;const e=(l+1)/2,s=(u+1)/2,A=(m+1)/2,y=(c+d)/4,v=(h+g)/4,C=(p+f)/4;return e>s&&e>A?o>e?(i=0,n=.707106781,r=.707106781):(i=Math.sqrt(e),n=y/i,r=v/i):s>A?o>s?(i=.707106781,n=0,r=.707106781):(n=Math.sqrt(s),i=y/n,r=C/n):o>A?(i=.707106781,n=.707106781,r=0):(r=Math.sqrt(A),i=v/r,n=C/r),this.set(i,n,r,t),this}let A=Math.sqrt((f-p)*(f-p)+(h-g)*(h-g)+(d-c)*(d-c));return.001>Math.abs(A)&&(A=1),this.x=(f-p)/A,this.y=(h-g)/A,this.z=(d-c)/A,this.w=Math.acos((l+u+m-1)/2),this}min(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}max(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}clamp(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}clampScalar(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}clampLength(e,t){const i=this.length();return this.divideScalar(i||1).multiplyScalar(Math.max(e,Math.min(t,i)))}floor(){return this.x=Math.floor(this.x),this.y=Math.floor(this.y),this.z=Math.floor(this.z),this.w=Math.floor(this.w),this}ceil(){return this.x=Math.ceil(this.x),this.y=Math.ceil(this.y),this.z=Math.ceil(this.z),this.w=Math.ceil(this.w),this}round(){return this.x=Math.round(this.x),this.y=Math.round(this.y),this.z=Math.round(this.z),this.w=Math.round(this.w),this}roundToZero(){return this.x=0>this.x?Math.ceil(this.x):Math.floor(this.x),this.y=0>this.y?Math.ceil(this.y):Math.floor(this.y),this.z=0>this.z?Math.ceil(this.z):Math.floor(this.z),this.w=0>this.w?Math.ceil(this.w):Math.floor(this.w),this}negate(){return this.x=-this.x,this.y=-this.y,this.z=-this.z,this.w=-this.w,this}dot(e){return this.x*e.x+this.y*e.y+this.z*e.z+this.w*e.w}lengthSq(){return this.x*this.x+this.y*this.y+this.z*this.z+this.w*this.w}length(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z+this.w*this.w)}manhattanLength(){return Math.abs(this.x)+Math.abs(this.y)+Math.abs(this.z)+Math.abs(this.w)}normalize(){return this.divideScalar(this.length()||1)}setLength(e){return this.normalize().multiplyScalar(e)}lerp(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}lerpVectors(e,t,i){return this.x=e.x+(t.x-e.x)*i,this.y=e.y+(t.y-e.y)*i,this.z=e.z+(t.z-e.z)*i,this.w=e.w+(t.w-e.w)*i,this}equals(e){return e.x===this.x&&e.y===this.y&&e.z===this.z&&e.w===this.w}fromArray(e,t=0){return this.x=e[t],this.y=e[t+1],this.z=e[t+2],this.w=e[t+3],this}toArray(e=[],t=0){return e[t]=this.x,e[t+1]=this.y,e[t+2]=this.z,e[t+3]=this.w,e}fromBufferAttribute(e,t,i){return void 0!==i&&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}random(){return this.x=Math.random(),this.y=Math.random(),this.z=Math.random(),this.w=Math.random(),this}}Le.prototype.isVector4=!0;class Oe extends me{constructor(e,t,i){super(),this.width=e,this.height=t,this.depth=1,this.scissor=new Le(0,0,e,t),this.scissorTest=!1,this.viewport=new Le(0,0,e,t),this.texture=new Fe(void 0,(i=i||{}).mapping,i.wrapS,i.wrapT,i.magFilter,i.minFilter,i.format,i.type,i.anisotropy,i.encoding),this.texture.image={},this.texture.image.width=e,this.texture.image.height=t,this.texture.image.depth=1,this.texture.generateMipmaps=void 0!==i.generateMipmaps&&i.generateMipmaps,this.texture.minFilter=void 0!==i.minFilter?i.minFilter:C,this.depthBuffer=void 0===i.depthBuffer||i.depthBuffer,this.stencilBuffer=void 0!==i.stencilBuffer&&i.stencilBuffer,this.depthTexture=void 0!==i.depthTexture?i.depthTexture:null}setTexture(e){e.image={width:this.width,height:this.height,depth:this.depth},this.texture=e}setSize(e,t,i=1){this.width===e&&this.height===t&&this.depth===i||(this.width=e,this.height=t,this.depth=i,this.texture.image.width=e,this.texture.image.height=t,this.texture.image.depth=i,this.dispose()),this.viewport.set(0,0,e,t),this.scissor.set(0,0,e,t)}clone(){return(new this.constructor).copy(this)}copy(e){return this.width=e.width,this.height=e.height,this.depth=e.depth,this.viewport.copy(e.viewport),this.texture=e.texture.clone(),this.texture.image={...this.texture.image},this.depthBuffer=e.depthBuffer,this.stencilBuffer=e.stencilBuffer,this.depthTexture=e.depthTexture,this}dispose(){this.dispatchEvent({type:"dispose"})}}Oe.prototype.isWebGLRenderTarget=!0;class Ne extends Oe{constructor(e,t,i){super(e,t);const n=this.texture;this.texture=[];for(let e=0;i>e;e++)this.texture[e]=n.clone()}setSize(e,t,i=1){if(this.width!==e||this.height!==t||this.depth!==i){this.width=e,this.height=t,this.depth=i;for(let n=0,r=this.texture.length;r>n;n++)this.texture[n].image.width=e,this.texture[n].image.height=t,this.texture[n].image.depth=i;this.dispose()}return this.viewport.set(0,0,e,t),this.scissor.set(0,0,e,t),this}copy(e){this.dispose(),this.width=e.width,this.height=e.height,this.depth=e.depth,this.viewport.set(0,0,this.width,this.height),this.scissor.set(0,0,this.width,this.height),this.depthBuffer=e.depthBuffer,this.stencilBuffer=e.stencilBuffer,this.depthTexture=e.depthTexture,this.texture.length=0;for(let t=0,i=e.texture.length;i>t;t++)this.texture[t]=e.texture[t].clone();return this}}Ne.prototype.isWebGLMultipleRenderTargets=!0;class Pe extends Oe{constructor(e,t,i){super(e,t,i),this.samples=4}copy(e){return super.copy.call(this,e),this.samples=e.samples,this}}Pe.prototype.isWebGLMultisampleRenderTarget=!0;class Ge{constructor(e=0,t=0,i=0,n=1){this._x=e,this._y=t,this._z=i,this._w=n}get x(){return this._x}set x(e){this._x=e,this._onChangeCallback()}get y(){return this._y}set y(e){this._y=e,this._onChangeCallback()}get z(){return this._z}set z(e){this._z=e,this._onChangeCallback()}get w(){return this._w}set w(e){this._w=e,this._onChangeCallback()}static slerp(e,t,i,n){return console.warn("THREE.Quaternion: Static .slerp() has been deprecated. Use qm.slerpQuaternions( qa, qb, t ) instead."),i.slerpQuaternions(e,t,n)}static slerpFlat(e,t,i,n,r,o,a){let s=i[n+0],l=i[n+1],c=i[n+2],h=i[n+3];const d=r[o+0],u=r[o+1],p=r[o+2],g=r[o+3];if(0===a)return e[t+0]=s,e[t+1]=l,e[t+2]=c,void(e[t+3]=h);if(1===a)return e[t+0]=d,e[t+1]=u,e[t+2]=p,void(e[t+3]=g);if(h!==g||s!==d||l!==u||c!==p){let e=1-a;const t=s*d+l*u+c*p+h*g,i=0>t?-1:1,n=1-t*t;if(n>Number.EPSILON){const r=Math.sqrt(n),o=Math.atan2(r,t*i);e=Math.sin(e*o)/r,a=Math.sin(a*o)/r}const r=a*i;if(s=s*e+d*r,l=l*e+u*r,c=c*e+p*r,h=h*e+g*r,e===1-a){const e=1/Math.sqrt(s*s+l*l+c*c+h*h);s*=e,l*=e,c*=e,h*=e}}e[t]=s,e[t+1]=l,e[t+2]=c,e[t+3]=h}static multiplyQuaternionsFlat(e,t,i,n,r,o){const a=i[n],s=i[n+1],l=i[n+2],c=i[n+3],h=r[o],d=r[o+1],u=r[o+2],p=r[o+3];return e[t]=a*p+c*h+s*u-l*d,e[t+1]=s*p+c*d+l*h-a*u,e[t+2]=l*p+c*u+a*d-s*h,e[t+3]=c*p-a*h-s*d-l*u,e}set(e,t,i,n){return this._x=e,this._y=t,this._z=i,this._w=n,this._onChangeCallback(),this}clone(){return new this.constructor(this._x,this._y,this._z,this._w)}copy(e){return this._x=e.x,this._y=e.y,this._z=e.z,this._w=e.w,this._onChangeCallback(),this}setFromEuler(e,t){if(!e||!e.isEuler)throw new Error("THREE.Quaternion: .setFromEuler() now expects an Euler rotation rather than a Vector3 and order.");const i=e._x,n=e._y,r=e._z,o=e._order,a=Math.cos,s=Math.sin,l=a(i/2),c=a(n/2),h=a(r/2),d=s(i/2),u=s(n/2),p=s(r/2);switch(o){case"XYZ":this._x=d*c*h+l*u*p,this._y=l*u*h-d*c*p,this._z=l*c*p+d*u*h,this._w=l*c*h-d*u*p;break;case"YXZ":this._x=d*c*h+l*u*p,this._y=l*u*h-d*c*p,this._z=l*c*p-d*u*h,this._w=l*c*h+d*u*p;break;case"ZXY":this._x=d*c*h-l*u*p,this._y=l*u*h+d*c*p,this._z=l*c*p+d*u*h,this._w=l*c*h-d*u*p;break;case"ZYX":this._x=d*c*h-l*u*p,this._y=l*u*h+d*c*p,this._z=l*c*p-d*u*h,this._w=l*c*h+d*u*p;break;case"YZX":this._x=d*c*h+l*u*p,this._y=l*u*h+d*c*p,this._z=l*c*p-d*u*h,this._w=l*c*h-d*u*p;break;case"XZY":this._x=d*c*h-l*u*p,this._y=l*u*h-d*c*p,this._z=l*c*p+d*u*h,this._w=l*c*h+d*u*p;break;default:console.warn("THREE.Quaternion: .setFromEuler() encountered an unknown order: "+o)}return!1!==t&&this._onChangeCallback(),this}setFromAxisAngle(e,t){const i=t/2,n=Math.sin(i);return this._x=e.x*n,this._y=e.y*n,this._z=e.z*n,this._w=Math.cos(i),this._onChangeCallback(),this}setFromRotationMatrix(e){const t=e.elements,i=t[0],n=t[4],r=t[8],o=t[1],a=t[5],s=t[9],l=t[2],c=t[6],h=t[10],d=i+a+h;if(d>0){const e=.5/Math.sqrt(d+1);this._w=.25/e,this._x=(c-s)*e,this._y=(r-l)*e,this._z=(o-n)*e}else if(i>a&&i>h){const e=2*Math.sqrt(1+i-a-h);this._w=(c-s)/e,this._x=.25*e,this._y=(n+o)/e,this._z=(r+l)/e}else if(a>h){const e=2*Math.sqrt(1+a-i-h);this._w=(r-l)/e,this._x=(n+o)/e,this._y=.25*e,this._z=(s+c)/e}else{const e=2*Math.sqrt(1+h-i-a);this._w=(o-n)/e,this._x=(r+l)/e,this._y=(s+c)/e,this._z=.25*e}return this._onChangeCallback(),this}setFromUnitVectors(e,t){let i=e.dot(t)+1;return Number.EPSILON>i?(i=0,Math.abs(e.x)>Math.abs(e.z)?(this._x=-e.y,this._y=e.x,this._z=0,this._w=i):(this._x=0,this._y=-e.z,this._z=e.y,this._w=i)):(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=i),this.normalize()}angleTo(e){return 2*Math.acos(Math.abs(xe(this.dot(e),-1,1)))}rotateTowards(e,t){const i=this.angleTo(e);if(0===i)return this;const n=Math.min(1,t/i);return this.slerp(e,n),this}identity(){return this.set(0,0,0,1)}invert(){return this.conjugate()}conjugate(){return this._x*=-1,this._y*=-1,this._z*=-1,this._onChangeCallback(),this}dot(e){return this._x*e._x+this._y*e._y+this._z*e._z+this._w*e._w}lengthSq(){return this._x*this._x+this._y*this._y+this._z*this._z+this._w*this._w}length(){return Math.sqrt(this._x*this._x+this._y*this._y+this._z*this._z+this._w*this._w)}normalize(){let 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}multiply(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)}premultiply(e){return this.multiplyQuaternions(e,this)}multiplyQuaternions(e,t){const i=e._x,n=e._y,r=e._z,o=e._w,a=t._x,s=t._y,l=t._z,c=t._w;return this._x=i*c+o*a+n*l-r*s,this._y=n*c+o*s+r*a-i*l,this._z=r*c+o*l+i*s-n*a,this._w=o*c-i*a-n*s-r*l,this._onChangeCallback(),this}slerp(e,t){if(0===t)return this;if(1===t)return this.copy(e);const i=this._x,n=this._y,r=this._z,o=this._w;let a=o*e._w+i*e._x+n*e._y+r*e._z;if(0>a?(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=i,this._y=n,this._z=r,this;const s=1-a*a;if(Number.EPSILON>=s){const e=1-t;return this._w=e*o+t*this._w,this._x=e*i+t*this._x,this._y=e*n+t*this._y,this._z=e*r+t*this._z,this.normalize(),this._onChangeCallback(),this}const l=Math.sqrt(s),c=Math.atan2(l,a),h=Math.sin((1-t)*c)/l,d=Math.sin(t*c)/l;return this._w=o*h+this._w*d,this._x=i*h+this._x*d,this._y=n*h+this._y*d,this._z=r*h+this._z*d,this._onChangeCallback(),this}slerpQuaternions(e,t,i){this.copy(e).slerp(t,i)}equals(e){return e._x===this._x&&e._y===this._y&&e._z===this._z&&e._w===this._w}fromArray(e,t=0){return this._x=e[t],this._y=e[t+1],this._z=e[t+2],this._w=e[t+3],this._onChangeCallback(),this}toArray(e=[],t=0){return e[t]=this._x,e[t+1]=this._y,e[t+2]=this._z,e[t+3]=this._w,e}fromBufferAttribute(e,t){return this._x=e.getX(t),this._y=e.getY(t),this._z=e.getZ(t),this._w=e.getW(t),this}_onChange(e){return this._onChangeCallback=e,this}_onChangeCallback(){}}Ge.prototype.isQuaternion=!0;class Ke{constructor(e=0,t=0,i=0){this.x=e,this.y=t,this.z=i}set(e,t,i){return void 0===i&&(i=this.z),this.x=e,this.y=t,this.z=i,this}setScalar(e){return this.x=e,this.y=e,this.z=e,this}setX(e){return this.x=e,this}setY(e){return this.y=e,this}setZ(e){return this.z=e,this}setComponent(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}getComponent(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)}}clone(){return new this.constructor(this.x,this.y,this.z)}copy(e){return this.x=e.x,this.y=e.y,this.z=e.z,this}add(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)}addScalar(e){return this.x+=e,this.y+=e,this.z+=e,this}addVectors(e,t){return this.x=e.x+t.x,this.y=e.y+t.y,this.z=e.z+t.z,this}addScaledVector(e,t){return this.x+=e.x*t,this.y+=e.y*t,this.z+=e.z*t,this}sub(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)}subScalar(e){return this.x-=e,this.y-=e,this.z-=e,this}subVectors(e,t){return this.x=e.x-t.x,this.y=e.y-t.y,this.z=e.z-t.z,this}multiply(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)}multiplyScalar(e){return this.x*=e,this.y*=e,this.z*=e,this}multiplyVectors(e,t){return this.x=e.x*t.x,this.y=e.y*t.y,this.z=e.z*t.z,this}applyEuler(e){return e&&e.isEuler||console.error("THREE.Vector3: .applyEuler() now expects an Euler rotation rather than a Vector3 and order."),this.applyQuaternion(Ye.setFromEuler(e))}applyAxisAngle(e,t){return this.applyQuaternion(Ye.setFromAxisAngle(e,t))}applyMatrix3(e){const t=this.x,i=this.y,n=this.z,r=e.elements;return this.x=r[0]*t+r[3]*i+r[6]*n,this.y=r[1]*t+r[4]*i+r[7]*n,this.z=r[2]*t+r[5]*i+r[8]*n,this}applyNormalMatrix(e){return this.applyMatrix3(e).normalize()}applyMatrix4(e){const t=this.x,i=this.y,n=this.z,r=e.elements,o=1/(r[3]*t+r[7]*i+r[11]*n+r[15]);return this.x=(r[0]*t+r[4]*i+r[8]*n+r[12])*o,this.y=(r[1]*t+r[5]*i+r[9]*n+r[13])*o,this.z=(r[2]*t+r[6]*i+r[10]*n+r[14])*o,this}applyQuaternion(e){const t=this.x,i=this.y,n=this.z,r=e.x,o=e.y,a=e.z,s=e.w,l=s*t+o*n-a*i,c=s*i+a*t-r*n,h=s*n+r*i-o*t,d=-r*t-o*i-a*n;return this.x=l*s+d*-r+c*-a-h*-o,this.y=c*s+d*-o+h*-r-l*-a,this.z=h*s+d*-a+l*-o-c*-r,this}project(e){return this.applyMatrix4(e.matrixWorldInverse).applyMatrix4(e.projectionMatrix)}unproject(e){return this.applyMatrix4(e.projectionMatrixInverse).applyMatrix4(e.matrixWorld)}transformDirection(e){const t=this.x,i=this.y,n=this.z,r=e.elements;return this.x=r[0]*t+r[4]*i+r[8]*n,this.y=r[1]*t+r[5]*i+r[9]*n,this.z=r[2]*t+r[6]*i+r[10]*n,this.normalize()}divide(e){return this.x/=e.x,this.y/=e.y,this.z/=e.z,this}divideScalar(e){return this.multiplyScalar(1/e)}min(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}max(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}clamp(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}clampScalar(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}clampLength(e,t){const i=this.length();return this.divideScalar(i||1).multiplyScalar(Math.max(e,Math.min(t,i)))}floor(){return this.x=Math.floor(this.x),this.y=Math.floor(this.y),this.z=Math.floor(this.z),this}ceil(){return this.x=Math.ceil(this.x),this.y=Math.ceil(this.y),this.z=Math.ceil(this.z),this}round(){return this.x=Math.round(this.x),this.y=Math.round(this.y),this.z=Math.round(this.z),this}roundToZero(){return this.x=0>this.x?Math.ceil(this.x):Math.floor(this.x),this.y=0>this.y?Math.ceil(this.y):Math.floor(this.y),this.z=0>this.z?Math.ceil(this.z):Math.floor(this.z),this}negate(){return this.x=-this.x,this.y=-this.y,this.z=-this.z,this}dot(e){return this.x*e.x+this.y*e.y+this.z*e.z}lengthSq(){return this.x*this.x+this.y*this.y+this.z*this.z}length(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z)}manhattanLength(){return Math.abs(this.x)+Math.abs(this.y)+Math.abs(this.z)}normalize(){return this.divideScalar(this.length()||1)}setLength(e){return this.normalize().multiplyScalar(e)}lerp(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}lerpVectors(e,t,i){return this.x=e.x+(t.x-e.x)*i,this.y=e.y+(t.y-e.y)*i,this.z=e.z+(t.z-e.z)*i,this}cross(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)}crossVectors(e,t){const i=e.x,n=e.y,r=e.z,o=t.x,a=t.y,s=t.z;return this.x=n*s-r*a,this.y=r*o-i*s,this.z=i*a-n*o,this}projectOnVector(e){const t=e.lengthSq();if(0===t)return this.set(0,0,0);const i=e.dot(this)/t;return this.copy(e).multiplyScalar(i)}projectOnPlane(e){return Ve.copy(this).projectOnVector(e),this.sub(Ve)}reflect(e){return this.sub(Ve.copy(e).multiplyScalar(2*this.dot(e)))}angleTo(e){const t=Math.sqrt(this.lengthSq()*e.lengthSq());if(0===t)return Math.PI/2;const i=this.dot(e)/t;return Math.acos(xe(i,-1,1))}distanceTo(e){return Math.sqrt(this.distanceToSquared(e))}distanceToSquared(e){const t=this.x-e.x,i=this.y-e.y,n=this.z-e.z;return t*t+i*i+n*n}manhattanDistanceTo(e){return Math.abs(this.x-e.x)+Math.abs(this.y-e.y)+Math.abs(this.z-e.z)}setFromSpherical(e){return this.setFromSphericalCoords(e.radius,e.phi,e.theta)}setFromSphericalCoords(e,t,i){const n=Math.sin(t)*e;return this.x=n*Math.sin(i),this.y=Math.cos(t)*e,this.z=n*Math.cos(i),this}setFromCylindrical(e){return this.setFromCylindricalCoords(e.radius,e.theta,e.y)}setFromCylindricalCoords(e,t,i){return this.x=e*Math.sin(t),this.y=i,this.z=e*Math.cos(t),this}setFromMatrixPosition(e){const t=e.elements;return this.x=t[12],this.y=t[13],this.z=t[14],this}setFromMatrixScale(e){const t=this.setFromMatrixColumn(e,0).length(),i=this.setFromMatrixColumn(e,1).length(),n=this.setFromMatrixColumn(e,2).length();return this.x=t,this.y=i,this.z=n,this}setFromMatrixColumn(e,t){return this.fromArray(e.elements,4*t)}setFromMatrix3Column(e,t){return this.fromArray(e.elements,3*t)}equals(e){return e.x===this.x&&e.y===this.y&&e.z===this.z}fromArray(e,t=0){return this.x=e[t],this.y=e[t+1],this.z=e[t+2],this}toArray(e=[],t=0){return e[t]=this.x,e[t+1]=this.y,e[t+2]=this.z,e}fromBufferAttribute(e,t,i){return void 0!==i&&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}random(){return this.x=Math.random(),this.y=Math.random(),this.z=Math.random(),this}}Ke.prototype.isVector3=!0;const Ve=new Ke,Ye=new Ge;class He{constructor(e=new Ke(1/0,1/0,1/0),t=new Ke(-1/0,-1/0,-1/0)){this.min=e,this.max=t}set(e,t){return this.min.copy(e),this.max.copy(t),this}setFromArray(e){let t=1/0,i=1/0,n=1/0,r=-1/0,o=-1/0,a=-1/0;for(let s=0,l=e.length;l>s;s+=3){const l=e[s],c=e[s+1],h=e[s+2];t>l&&(t=l),i>c&&(i=c),n>h&&(n=h),l>r&&(r=l),c>o&&(o=c),h>a&&(a=h)}return this.min.set(t,i,n),this.max.set(r,o,a),this}setFromBufferAttribute(e){let t=1/0,i=1/0,n=1/0,r=-1/0,o=-1/0,a=-1/0;for(let s=0,l=e.count;l>s;s++){const l=e.getX(s),c=e.getY(s),h=e.getZ(s);t>l&&(t=l),i>c&&(i=c),n>h&&(n=h),l>r&&(r=l),c>o&&(o=c),h>a&&(a=h)}return this.min.set(t,i,n),this.max.set(r,o,a),this}setFromPoints(e){this.makeEmpty();for(let t=0,i=e.length;i>t;t++)this.expandByPoint(e[t]);return this}setFromCenterAndSize(e,t){const i=We.copy(t).multiplyScalar(.5);return this.min.copy(e).sub(i),this.max.copy(e).add(i),this}setFromObject(e){return this.makeEmpty(),this.expandByObject(e)}clone(){return(new this.constructor).copy(this)}copy(e){return this.min.copy(e.min),this.max.copy(e.max),this}makeEmpty(){return this.min.x=this.min.y=this.min.z=1/0,this.max.x=this.max.y=this.max.z=-1/0,this}isEmpty(){return this.min.x>this.max.x||this.min.y>this.max.y||this.min.z>this.max.z}getCenter(e){return void 0===e&&(console.warn("THREE.Box3: .getCenter() target is now required"),e=new Ke),this.isEmpty()?e.set(0,0,0):e.addVectors(this.min,this.max).multiplyScalar(.5)}getSize(e){return void 0===e&&(console.warn("THREE.Box3: .getSize() target is now required"),e=new Ke),this.isEmpty()?e.set(0,0,0):e.subVectors(this.max,this.min)}expandByPoint(e){return this.min.min(e),this.max.max(e),this}expandByVector(e){return this.min.sub(e),this.max.add(e),this}expandByScalar(e){return this.min.addScalar(-e),this.max.addScalar(e),this}expandByObject(e){e.updateWorldMatrix(!1,!1);const t=e.geometry;void 0!==t&&(null===t.boundingBox&&t.computeBoundingBox(),Je.copy(t.boundingBox),Je.applyMatrix4(e.matrixWorld),this.union(Je));const i=e.children;for(let e=0,t=i.length;t>e;e++)this.expandByObject(i[e]);return this}containsPoint(e){return!(this.min.x>e.x||e.x>this.max.x||this.min.y>e.y||e.y>this.max.y||this.min.z>e.z||e.z>this.max.z)}containsBox(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)}getParameter(e,t){return void 0===t&&(console.warn("THREE.Box3: .getParameter() target is now required"),t=new Ke),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))}intersectsBox(e){return!(this.min.x>e.max.x||e.min.x>this.max.x||this.min.y>e.max.y||e.min.y>this.max.y||this.min.z>e.max.z||e.min.z>this.max.z)}intersectsSphere(e){return this.clampPoint(e.center,We),We.distanceToSquared(e.center)<=e.radius*e.radius}intersectsPlane(e){let t,i;return e.normal.x>0?(t=e.normal.x*this.min.x,i=e.normal.x*this.max.x):(t=e.normal.x*this.max.x,i=e.normal.x*this.min.x),e.normal.y>0?(t+=e.normal.y*this.min.y,i+=e.normal.y*this.max.y):(t+=e.normal.y*this.max.y,i+=e.normal.y*this.min.y),e.normal.z>0?(t+=e.normal.z*this.min.z,i+=e.normal.z*this.max.z):(t+=e.normal.z*this.max.z,i+=e.normal.z*this.min.z),-e.constant>=t&&i>=-e.constant}intersectsTriangle(e){if(this.isEmpty())return!1;this.getCenter(et),tt.subVectors(this.max,et),ze.subVectors(e.a,et),qe.subVectors(e.b,et),Ze.subVectors(e.c,et),Xe.subVectors(qe,ze),_e.subVectors(Ze,qe),$e.subVectors(ze,Ze);let t=[0,-Xe.z,Xe.y,0,-_e.z,_e.y,0,-$e.z,$e.y,Xe.z,0,-Xe.x,_e.z,0,-_e.x,$e.z,0,-$e.x,-Xe.y,Xe.x,0,-_e.y,_e.x,0,-$e.y,$e.x,0];return!!rt(t,ze,qe,Ze,tt)&&(t=[1,0,0,0,1,0,0,0,1],!!rt(t,ze,qe,Ze,tt)&&(it.crossVectors(Xe,_e),t=[it.x,it.y,it.z],rt(t,ze,qe,Ze,tt)))}clampPoint(e,t){return void 0===t&&(console.warn("THREE.Box3: .clampPoint() target is now required"),t=new Ke),t.copy(e).clamp(this.min,this.max)}distanceToPoint(e){return We.copy(e).clamp(this.min,this.max).sub(e).length()}getBoundingSphere(e){return void 0===e&&console.error("THREE.Box3: .getBoundingSphere() target is now required"),this.getCenter(e.center),e.radius=.5*this.getSize(We).length(),e}intersect(e){return this.min.max(e.min),this.max.min(e.max),this.isEmpty()&&this.makeEmpty(),this}union(e){return this.min.min(e.min),this.max.max(e.max),this}applyMatrix4(e){return this.isEmpty()||(je[0].set(this.min.x,this.min.y,this.min.z).applyMatrix4(e),je[1].set(this.min.x,this.min.y,this.max.z).applyMatrix4(e),je[2].set(this.min.x,this.max.y,this.min.z).applyMatrix4(e),je[3].set(this.min.x,this.max.y,this.max.z).applyMatrix4(e),je[4].set(this.max.x,this.min.y,this.min.z).applyMatrix4(e),je[5].set(this.max.x,this.min.y,this.max.z).applyMatrix4(e),je[6].set(this.max.x,this.max.y,this.min.z).applyMatrix4(e),je[7].set(this.max.x,this.max.y,this.max.z).applyMatrix4(e),this.setFromPoints(je)),this}translate(e){return this.min.add(e),this.max.add(e),this}equals(e){return e.min.equals(this.min)&&e.max.equals(this.max)}}He.prototype.isBox3=!0;const je=[new Ke,new Ke,new Ke,new Ke,new Ke,new Ke,new Ke,new Ke],We=new Ke,Je=new He,ze=new Ke,qe=new Ke,Ze=new Ke,Xe=new Ke,_e=new Ke,$e=new Ke,et=new Ke,tt=new Ke,it=new Ke,nt=new Ke;function rt(e,t,i,n,r){for(let o=0,a=e.length-3;a>=o;o+=3){nt.fromArray(e,o);const a=r.x*Math.abs(nt.x)+r.y*Math.abs(nt.y)+r.z*Math.abs(nt.z),s=t.dot(nt),l=i.dot(nt),c=n.dot(nt);if(Math.max(-Math.max(s,l,c),Math.min(s,l,c))>a)return!1}return!0}const ot=new He,at=new Ke,st=new Ke,lt=new Ke;class ct{constructor(e=new Ke,t=-1){this.center=e,this.radius=t}set(e,t){return this.center.copy(e),this.radius=t,this}setFromPoints(e,t){const i=this.center;void 0!==t?i.copy(t):ot.setFromPoints(e).getCenter(i);let n=0;for(let t=0,r=e.length;r>t;t++)n=Math.max(n,i.distanceToSquared(e[t]));return this.radius=Math.sqrt(n),this}copy(e){return this.center.copy(e.center),this.radius=e.radius,this}isEmpty(){return 0>this.radius}makeEmpty(){return this.center.set(0,0,0),this.radius=-1,this}containsPoint(e){return e.distanceToSquared(this.center)<=this.radius*this.radius}distanceToPoint(e){return e.distanceTo(this.center)-this.radius}intersectsSphere(e){const t=this.radius+e.radius;return e.center.distanceToSquared(this.center)<=t*t}intersectsBox(e){return e.intersectsSphere(this)}intersectsPlane(e){return Math.abs(e.distanceToPoint(this.center))<=this.radius}clampPoint(e,t){const i=this.center.distanceToSquared(e);return void 0===t&&(console.warn("THREE.Sphere: .clampPoint() target is now required"),t=new Ke),t.copy(e),i>this.radius*this.radius&&(t.sub(this.center).normalize(),t.multiplyScalar(this.radius).add(this.center)),t}getBoundingBox(e){return void 0===e&&(console.warn("THREE.Sphere: .getBoundingBox() target is now required"),e=new He),this.isEmpty()?(e.makeEmpty(),e):(e.set(this.center,this.center),e.expandByScalar(this.radius),e)}applyMatrix4(e){return this.center.applyMatrix4(e),this.radius=this.radius*e.getMaxScaleOnAxis(),this}translate(e){return this.center.add(e),this}expandByPoint(e){lt.subVectors(e,this.center);const t=lt.lengthSq();if(t>this.radius*this.radius){const e=Math.sqrt(t),i=.5*(e-this.radius);this.center.add(lt.multiplyScalar(i/e)),this.radius+=i}return this}union(e){return st.subVectors(e.center,this.center).normalize().multiplyScalar(e.radius),this.expandByPoint(at.copy(e.center).add(st)),this.expandByPoint(at.copy(e.center).sub(st)),this}equals(e){return e.center.equals(this.center)&&e.radius===this.radius}clone(){return(new this.constructor).copy(this)}}const ht=new Ke,dt=new Ke,ut=new Ke,pt=new Ke,gt=new Ke,ft=new Ke,mt=new Ke;class At{constructor(e=new Ke,t=new Ke(0,0,-1)){this.origin=e,this.direction=t}set(e,t){return this.origin.copy(e),this.direction.copy(t),this}copy(e){return this.origin.copy(e.origin),this.direction.copy(e.direction),this}at(e,t){return void 0===t&&(console.warn("THREE.Ray: .at() target is now required"),t=new Ke),t.copy(this.direction).multiplyScalar(e).add(this.origin)}lookAt(e){return this.direction.copy(e).sub(this.origin).normalize(),this}recast(e){return this.origin.copy(this.at(e,ht)),this}closestPointToPoint(e,t){void 0===t&&(console.warn("THREE.Ray: .closestPointToPoint() target is now required"),t=new Ke),t.subVectors(e,this.origin);const i=t.dot(this.direction);return 0>i?t.copy(this.origin):t.copy(this.direction).multiplyScalar(i).add(this.origin)}distanceToPoint(e){return Math.sqrt(this.distanceSqToPoint(e))}distanceSqToPoint(e){const t=ht.subVectors(e,this.origin).dot(this.direction);return 0>t?this.origin.distanceToSquared(e):(ht.copy(this.direction).multiplyScalar(t).add(this.origin),ht.distanceToSquared(e))}distanceSqToSegment(e,t,i,n){dt.copy(e).add(t).multiplyScalar(.5),ut.copy(t).sub(e).normalize(),pt.copy(this.origin).sub(dt);const r=.5*e.distanceTo(t),o=-this.direction.dot(ut),a=pt.dot(this.direction),s=-pt.dot(ut),l=pt.lengthSq(),c=Math.abs(1-o*o);let h,d,u,p;if(c>0)if(h=o*s-a,d=o*a-s,p=r*c,0>h)d>-p?d>p?(h=Math.max(0,-(o*r+a)),d=h>0?r:Math.min(Math.max(-r,-s),r),u=-h*h+d*(d+2*s)+l):(h=0,d=Math.min(Math.max(-r,-s),r),u=d*(d+2*s)+l):(h=Math.max(0,-(-o*r+a)),d=h>0?-r:Math.min(Math.max(-r,-s),r),u=-h*h+d*(d+2*s)+l);else if(d<-p)d=-r,h=Math.max(0,-(o*d+a)),u=-h*h+d*(d+2*s)+l;else if(p<d)d=r,h=Math.max(0,-(o*d+a)),u=-h*h+d*(d+2*s)+l;else{const e=1/c;h*=e,d*=e,u=h*(h+o*d+2*a)+d*(o*h+d+2*s)+l}else d=o>0?-r:r,h=Math.max(0,-(o*d+a)),u=-h*h+d*(d+2*s)+l;return i&&i.copy(this.direction).multiplyScalar(h).add(this.origin),n&&n.copy(ut).multiplyScalar(d).add(dt),u}intersectSphere(e,t){ht.subVectors(e.center,this.origin);const i=ht.dot(this.direction),n=ht.dot(ht)-i*i,r=e.radius*e.radius;if(n>r)return null;const o=Math.sqrt(r-n),a=i-o,s=i+o;return 0>a&&0>s?null:this.at(0>a?s:a,t)}intersectsSphere(e){return this.distanceSqToPoint(e.center)<=e.radius*e.radius}distanceToPlane(e){const t=e.normal.dot(this.direction);if(0===t)return 0===e.distanceToPoint(this.origin)?0:null;const i=-(this.origin.dot(e.normal)+e.constant)/t;return 0>i?null:i}intersectPlane(e,t){const i=this.distanceToPlane(e);return null===i?null:this.at(i,t)}intersectsPlane(e){const t=e.distanceToPoint(this.origin);if(0===t)return!0;return 0>e.normal.dot(this.direction)*t}intersectBox(e,t){let i,n,r,o,a,s;const l=1/this.direction.x,c=1/this.direction.y,h=1/this.direction.z,d=this.origin;return 0>l?(i=(e.max.x-d.x)*l,n=(e.min.x-d.x)*l):(i=(e.min.x-d.x)*l,n=(e.max.x-d.x)*l),0>c?(r=(e.max.y-d.y)*c,o=(e.min.y-d.y)*c):(r=(e.min.y-d.y)*c,o=(e.max.y-d.y)*c),i>o||r>n?null:((r>i||i!=i)&&(i=r),(n>o||n!=n)&&(n=o),0>h?(a=(e.max.z-d.z)*h,s=(e.min.z-d.z)*h):(a=(e.min.z-d.z)*h,s=(e.max.z-d.z)*h),i>s||a>n?null:((a>i||i!=i)&&(i=a),(n>s||n!=n)&&(n=s),0>n?null:this.at(0>i?n:i,t)))}intersectsBox(e){return null!==this.intersectBox(e,ht)}intersectTriangle(e,t,i,n,r){gt.subVectors(t,e),ft.subVectors(i,e),mt.crossVectors(gt,ft);let o,a=this.direction.dot(mt);if(a>0){if(n)return null;o=1}else{if(a>=0)return null;o=-1,a=-a}pt.subVectors(this.origin,e);const s=o*this.direction.dot(ft.crossVectors(pt,ft));if(0>s)return null;const l=o*this.direction.dot(gt.cross(pt));if(0>l)return null;if(s+l>a)return null;const c=-o*pt.dot(mt);return 0>c?null:this.at(c/a,r)}applyMatrix4(e){return this.origin.applyMatrix4(e),this.direction.transformDirection(e),this}equals(e){return e.origin.equals(this.origin)&&e.direction.equals(this.direction)}clone(){return(new this.constructor).copy(this)}}class yt{constructor(){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.")}set(e,t,i,n,r,o,a,s,l,c,h,d,u,p,g,f){const m=this.elements;return m[0]=e,m[4]=t,m[8]=i,m[12]=n,m[1]=r,m[5]=o,m[9]=a,m[13]=s,m[2]=l,m[6]=c,m[10]=h,m[14]=d,m[3]=u,m[7]=p,m[11]=g,m[15]=f,this}identity(){return this.set(1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1),this}clone(){return(new yt).fromArray(this.elements)}copy(e){const t=this.elements,i=e.elements;return t[0]=i[0],t[1]=i[1],t[2]=i[2],t[3]=i[3],t[4]=i[4],t[5]=i[5],t[6]=i[6],t[7]=i[7],t[8]=i[8],t[9]=i[9],t[10]=i[10],t[11]=i[11],t[12]=i[12],t[13]=i[13],t[14]=i[14],t[15]=i[15],this}copyPosition(e){const t=this.elements,i=e.elements;return t[12]=i[12],t[13]=i[13],t[14]=i[14],this}setFromMatrix3(e){const 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}extractBasis(e,t,i){return e.setFromMatrixColumn(this,0),t.setFromMatrixColumn(this,1),i.setFromMatrixColumn(this,2),this}makeBasis(e,t,i){return this.set(e.x,t.x,i.x,0,e.y,t.y,i.y,0,e.z,t.z,i.z,0,0,0,0,1),this}extractRotation(e){const t=this.elements,i=e.elements,n=1/vt.setFromMatrixColumn(e,0).length(),r=1/vt.setFromMatrixColumn(e,1).length(),o=1/vt.setFromMatrixColumn(e,2).length();return t[0]=i[0]*n,t[1]=i[1]*n,t[2]=i[2]*n,t[3]=0,t[4]=i[4]*r,t[5]=i[5]*r,t[6]=i[6]*r,t[7]=0,t[8]=i[8]*o,t[9]=i[9]*o,t[10]=i[10]*o,t[11]=0,t[12]=0,t[13]=0,t[14]=0,t[15]=1,this}makeRotationFromEuler(e){e&&e.isEuler||console.error("THREE.Matrix4: .makeRotationFromEuler() now expects a Euler rotation rather than a Vector3 and order.");const t=this.elements,i=e.x,n=e.y,r=e.z,o=Math.cos(i),a=Math.sin(i),s=Math.cos(n),l=Math.sin(n),c=Math.cos(r),h=Math.sin(r);if("XYZ"===e.order){const e=o*c,i=o*h,n=a*c,r=a*h;t[0]=s*c,t[4]=-s*h,t[8]=l,t[1]=i+n*l,t[5]=e-r*l,t[9]=-a*s,t[2]=r-e*l,t[6]=n+i*l,t[10]=o*s}else if("YXZ"===e.order){const e=s*c,i=s*h,n=l*c,r=l*h;t[0]=e+r*a,t[4]=n*a-i,t[8]=o*l,t[1]=o*h,t[5]=o*c,t[9]=-a,t[2]=i*a-n,t[6]=r+e*a,t[10]=o*s}else if("ZXY"===e.order){const e=s*c,i=s*h,n=l*c,r=l*h;t[0]=e-r*a,t[4]=-o*h,t[8]=n+i*a,t[1]=i+n*a,t[5]=o*c,t[9]=r-e*a,t[2]=-o*l,t[6]=a,t[10]=o*s}else if("ZYX"===e.order){const e=o*c,i=o*h,n=a*c,r=a*h;t[0]=s*c,t[4]=n*l-i,t[8]=e*l+r,t[1]=s*h,t[5]=r*l+e,t[9]=i*l-n,t[2]=-l,t[6]=a*s,t[10]=o*s}else if("YZX"===e.order){const e=o*s,i=o*l,n=a*s,r=a*l;t[0]=s*c,t[4]=r-e*h,t[8]=n*h+i,t[1]=h,t[5]=o*c,t[9]=-a*c,t[2]=-l*c,t[6]=i*h+n,t[10]=e-r*h}else if("XZY"===e.order){const e=o*s,i=o*l,n=a*s,r=a*l;t[0]=s*c,t[4]=-h,t[8]=l*c,t[1]=e*h+r,t[5]=o*c,t[9]=i*h-n,t[2]=n*h-i,t[6]=a*c,t[10]=r*h+e}return t[3]=0,t[7]=0,t[11]=0,t[12]=0,t[13]=0,t[14]=0,t[15]=1,this}makeRotationFromQuaternion(e){return this.compose(It,e,xt)}lookAt(e,t,i){const n=this.elements;return Et.subVectors(e,t),0===Et.lengthSq()&&(Et.z=1),Et.normalize(),wt.crossVectors(i,Et),0===wt.lengthSq()&&(1===Math.abs(i.z)?Et.x+=1e-4:Et.z+=1e-4,Et.normalize(),wt.crossVectors(i,Et)),wt.normalize(),Mt.crossVectors(Et,wt),n[0]=wt.x,n[4]=Mt.x,n[8]=Et.x,n[1]=wt.y,n[5]=Mt.y,n[9]=Et.y,n[2]=wt.z,n[6]=Mt.z,n[10]=Et.z,this}multiply(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)}premultiply(e){return this.multiplyMatrices(e,this)}multiplyMatrices(e,t){const i=e.elements,n=t.elements,r=this.elements,o=i[0],a=i[4],s=i[8],l=i[12],c=i[1],h=i[5],d=i[9],u=i[13],p=i[2],g=i[6],f=i[10],m=i[14],A=i[3],y=i[7],v=i[11],C=i[15],I=n[0],x=n[4],w=n[8],M=n[12],E=n[1],B=n[5],S=n[9],b=n[13],k=n[2],D=n[6],T=n[10],R=n[14],U=n[3],F=n[7],Q=n[11],L=n[15];return r[0]=o*I+a*E+s*k+l*U,r[4]=o*x+a*B+s*D+l*F,r[8]=o*w+a*S+s*T+l*Q,r[12]=o*M+a*b+s*R+l*L,r[1]=c*I+h*E+d*k+u*U,r[5]=c*x+h*B+d*D+u*F,r[9]=c*w+h*S+d*T+u*Q,r[13]=c*M+h*b+d*R+u*L,r[2]=p*I+g*E+f*k+m*U,r[6]=p*x+g*B+f*D+m*F,r[10]=p*w+g*S+f*T+m*Q,r[14]=p*M+g*b+f*R+m*L,r[3]=A*I+y*E+v*k+C*U,r[7]=A*x+y*B+v*D+C*F,r[11]=A*w+y*S+v*T+C*Q,r[15]=A*M+y*b+v*R+C*L,this}multiplyScalar(e){const 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}determinant(){const e=this.elements,t=e[0],i=e[4],n=e[8],r=e[12],o=e[1],a=e[5],s=e[9],l=e[13],c=e[2],h=e[6],d=e[10],u=e[14];return e[3]*(+r*s*h-n*l*h-r*a*d+i*l*d+n*a*u-i*s*u)+e[7]*(+t*s*u-t*l*d+r*o*d-n*o*u+n*l*c-r*s*c)+e[11]*(+t*l*h-t*a*u-r*o*h+i*o*u+r*a*c-i*l*c)+e[15]*(-n*a*c-t*s*h+t*a*d+n*o*h-i*o*d+i*s*c)}transpose(){const e=this.elements;let t;return t=e[1],e[1]=e[4],e[4]=t,t=e[2],e[2]=e[8],e[8]=t,t=e[6],e[6]=e[9],e[9]=t,t=e[3],e[3]=e[12],e[12]=t,t=e[7],e[7]=e[13],e[13]=t,t=e[11],e[11]=e[14],e[14]=t,this}setPosition(e,t,i){const n=this.elements;return e.isVector3?(n[12]=e.x,n[13]=e.y,n[14]=e.z):(n[12]=e,n[13]=t,n[14]=i),this}invert(){const e=this.elements,t=e[0],i=e[1],n=e[2],r=e[3],o=e[4],a=e[5],s=e[6],l=e[7],c=e[8],h=e[9],d=e[10],u=e[11],p=e[12],g=e[13],f=e[14],m=e[15],A=h*f*l-g*d*l+g*s*u-a*f*u-h*s*m+a*d*m,y=p*d*l-c*f*l-p*s*u+o*f*u+c*s*m-o*d*m,v=c*g*l-p*h*l+p*a*u-o*g*u-c*a*m+o*h*m,C=p*h*s-c*g*s-p*a*d+o*g*d+c*a*f-o*h*f,I=t*A+i*y+n*v+r*C;if(0===I)return this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0);const x=1/I;return e[0]=A*x,e[1]=(g*d*r-h*f*r-g*n*u+i*f*u+h*n*m-i*d*m)*x,e[2]=(a*f*r-g*s*r+g*n*l-i*f*l-a*n*m+i*s*m)*x,e[3]=(h*s*r-a*d*r-h*n*l+i*d*l+a*n*u-i*s*u)*x,e[4]=y*x,e[5]=(c*f*r-p*d*r+p*n*u-t*f*u-c*n*m+t*d*m)*x,e[6]=(p*s*r-o*f*r-p*n*l+t*f*l+o*n*m-t*s*m)*x,e[7]=(o*d*r-c*s*r+c*n*l-t*d*l-o*n*u+t*s*u)*x,e[8]=v*x,e[9]=(p*h*r-c*g*r-p*i*u+t*g*u+c*i*m-t*h*m)*x,e[10]=(o*g*r-p*a*r+p*i*l-t*g*l-o*i*m+t*a*m)*x,e[11]=(c*a*r-o*h*r-c*i*l+t*h*l+o*i*u-t*a*u)*x,e[12]=C*x,e[13]=(c*g*n-p*h*n+p*i*d-t*g*d-c*i*f+t*h*f)*x,e[14]=(p*a*n-o*g*n-p*i*s+t*g*s+o*i*f-t*a*f)*x,e[15]=(o*h*n-c*a*n+c*i*s-t*h*s-o*i*d+t*a*d)*x,this}scale(e){const t=this.elements,i=e.x,n=e.y,r=e.z;return t[0]*=i,t[4]*=n,t[8]*=r,t[1]*=i,t[5]*=n,t[9]*=r,t[2]*=i,t[6]*=n,t[10]*=r,t[3]*=i,t[7]*=n,t[11]*=r,this}getMaxScaleOnAxis(){const e=this.elements;return Math.sqrt(Math.max(e[0]*e[0]+e[1]*e[1]+e[2]*e[2],e[4]*e[4]+e[5]*e[5]+e[6]*e[6],e[8]*e[8]+e[9]*e[9]+e[10]*e[10]))}makeTranslation(e,t,i){return this.set(1,0,0,e,0,1,0,t,0,0,1,i,0,0,0,1),this}makeRotationX(e){const t=Math.cos(e),i=Math.sin(e);return this.set(1,0,0,0,0,t,-i,0,0,i,t,0,0,0,0,1),this}makeRotationY(e){const t=Math.cos(e),i=Math.sin(e);return this.set(t,0,i,0,0,1,0,0,-i,0,t,0,0,0,0,1),this}makeRotationZ(e){const t=Math.cos(e),i=Math.sin(e);return this.set(t,-i,0,0,i,t,0,0,0,0,1,0,0,0,0,1),this}makeRotationAxis(e,t){const i=Math.cos(t),n=Math.sin(t),r=1-i,o=e.x,a=e.y,s=e.z,l=r*o,c=r*a;return this.set(l*o+i,l*a-n*s,l*s+n*a,0,l*a+n*s,c*a+i,c*s-n*o,0,l*s-n*a,c*s+n*o,r*s*s+i,0,0,0,0,1),this}makeScale(e,t,i){return this.set(e,0,0,0,0,t,0,0,0,0,i,0,0,0,0,1),this}makeShear(e,t,i,n,r,o){return this.set(1,i,r,0,e,1,o,0,t,n,1,0,0,0,0,1),this}compose(e,t,i){const n=this.elements,r=t._x,o=t._y,a=t._z,s=t._w,l=r+r,c=o+o,h=a+a,d=r*l,u=r*c,p=r*h,g=o*c,f=o*h,m=a*h,A=s*l,y=s*c,v=s*h,C=i.x,I=i.y,x=i.z;return n[0]=(1-(g+m))*C,n[1]=(u+v)*C,n[2]=(p-y)*C,n[3]=0,n[4]=(u-v)*I,n[5]=(1-(d+m))*I,n[6]=(f+A)*I,n[7]=0,n[8]=(p+y)*x,n[9]=(f-A)*x,n[10]=(1-(d+g))*x,n[11]=0,n[12]=e.x,n[13]=e.y,n[14]=e.z,n[15]=1,this}decompose(e,t,i){const n=this.elements;let r=vt.set(n[0],n[1],n[2]).length();const o=vt.set(n[4],n[5],n[6]).length(),a=vt.set(n[8],n[9],n[10]).length();0>this.determinant()&&(r=-r),e.x=n[12],e.y=n[13],e.z=n[14],Ct.copy(this);const s=1/r,l=1/o,c=1/a;return Ct.elements[0]*=s,Ct.elements[1]*=s,Ct.elements[2]*=s,Ct.elements[4]*=l,Ct.elements[5]*=l,Ct.elements[6]*=l,Ct.elements[8]*=c,Ct.elements[9]*=c,Ct.elements[10]*=c,t.setFromRotationMatrix(Ct),i.x=r,i.y=o,i.z=a,this}makePerspective(e,t,i,n,r,o){void 0===o&&console.warn("THREE.Matrix4: .makePerspective() has been redefined and has a new signature. Please check the docs.");const a=this.elements,s=2*r/(i-n),l=(t+e)/(t-e),c=(i+n)/(i-n),h=-(o+r)/(o-r),d=-2*o*r/(o-r);return a[0]=2*r/(t-e),a[4]=0,a[8]=l,a[12]=0,a[1]=0,a[5]=s,a[9]=c,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}makeOrthographic(e,t,i,n,r,o){const a=this.elements,s=1/(t-e),l=1/(i-n),c=1/(o-r),h=(t+e)*s,d=(i+n)*l,u=(o+r)*c;return a[0]=2*s,a[4]=0,a[8]=0,a[12]=-h,a[1]=0,a[5]=2*l,a[9]=0,a[13]=-d,a[2]=0,a[6]=0,a[10]=-2*c,a[14]=-u,a[3]=0,a[7]=0,a[11]=0,a[15]=1,this}equals(e){const t=this.elements,i=e.elements;for(let e=0;16>e;e++)if(t[e]!==i[e])return!1;return!0}fromArray(e,t=0){for(let i=0;16>i;i++)this.elements[i]=e[i+t];return this}toArray(e=[],t=0){const i=this.elements;return e[t]=i[0],e[t+1]=i[1],e[t+2]=i[2],e[t+3]=i[3],e[t+4]=i[4],e[t+5]=i[5],e[t+6]=i[6],e[t+7]=i[7],e[t+8]=i[8],e[t+9]=i[9],e[t+10]=i[10],e[t+11]=i[11],e[t+12]=i[12],e[t+13]=i[13],e[t+14]=i[14],e[t+15]=i[15],e}}yt.prototype.isMatrix4=!0;const vt=new Ke,Ct=new yt,It=new Ke(0,0,0),xt=new Ke(1,1,1),wt=new Ke,Mt=new Ke,Et=new Ke,Bt=new yt,St=new Ge;class bt{constructor(e=0,t=0,i=0,n=bt.DefaultOrder){this._x=e,this._y=t,this._z=i,this._order=n}get x(){return this._x}set x(e){this._x=e,this._onChangeCallback()}get y(){return this._y}set y(e){this._y=e,this._onChangeCallback()}get z(){return this._z}set z(e){this._z=e,this._onChangeCallback()}get order(){return this._order}set order(e){this._order=e,this._onChangeCallback()}set(e,t,i,n){return this._x=e,this._y=t,this._z=i,this._order=n||this._order,this._onChangeCallback(),this}clone(){return new this.constructor(this._x,this._y,this._z,this._order)}copy(e){return this._x=e._x,this._y=e._y,this._z=e._z,this._order=e._order,this._onChangeCallback(),this}setFromRotationMatrix(e,t,i){const n=e.elements,r=n[0],o=n[4],a=n[8],s=n[1],l=n[5],c=n[9],h=n[2],d=n[6],u=n[10];switch(t=t||this._order){case"XYZ":this._y=Math.asin(xe(a,-1,1)),.9999999>Math.abs(a)?(this._x=Math.atan2(-c,u),this._z=Math.atan2(-o,r)):(this._x=Math.atan2(d,l),this._z=0);break;case"YXZ":this._x=Math.asin(-xe(c,-1,1)),.9999999>Math.abs(c)?(this._y=Math.atan2(a,u),this._z=Math.atan2(s,l)):(this._y=Math.atan2(-h,r),this._z=0);break;case"ZXY":this._x=Math.asin(xe(d,-1,1)),.9999999>Math.abs(d)?(this._y=Math.atan2(-h,u),this._z=Math.atan2(-o,l)):(this._y=0,this._z=Math.atan2(s,r));break;case"ZYX":this._y=Math.asin(-xe(h,-1,1)),.9999999>Math.abs(h)?(this._x=Math.atan2(d,u),this._z=Math.atan2(s,r)):(this._x=0,this._z=Math.atan2(-o,l));break;case"YZX":this._z=Math.asin(xe(s,-1,1)),.9999999>Math.abs(s)?(this._x=Math.atan2(-c,l),this._y=Math.atan2(-h,r)):(this._x=0,this._y=Math.atan2(a,u));break;case"XZY":this._z=Math.asin(-xe(o,-1,1)),.9999999>Math.abs(o)?(this._x=Math.atan2(d,l),this._y=Math.atan2(a,r)):(this._x=Math.atan2(-c,u),this._y=0);break;default:console.warn("THREE.Euler: .setFromRotationMatrix() encountered an unknown order: "+t)}return this._order=t,!1!==i&&this._onChangeCallback(),this}setFromQuaternion(e,t,i){return Bt.makeRotationFromQuaternion(e),this.setFromRotationMatrix(Bt,t,i)}setFromVector3(e,t){return this.set(e.x,e.y,e.z,t||this._order)}reorder(e){return St.setFromEuler(this),this.setFromQuaternion(St,e)}equals(e){return e._x===this._x&&e._y===this._y&&e._z===this._z&&e._order===this._order}fromArray(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}toArray(e=[],t=0){return e[t]=this._x,e[t+1]=this._y,e[t+2]=this._z,e[t+3]=this._order,e}toVector3(e){return e?e.set(this._x,this._y,this._z):new Ke(this._x,this._y,this._z)}_onChange(e){return this._onChangeCallback=e,this}_onChangeCallback(){}}bt.prototype.isEuler=!0,bt.DefaultOrder="XYZ",bt.RotationOrders=["XYZ","YZX","ZXY","XZY","YXZ","ZYX"];class kt{constructor(){this.mask=1}set(e){this.mask=1<<e|0}enable(e){this.mask|=1<<e|0}enableAll(){this.mask=-1}toggle(e){this.mask^=1<<e|0}disable(e){this.mask&=~(1<<e|0)}disableAll(){this.mask=0}test(e){return 0!=(this.mask&e.mask)}}let Dt=0;const Tt=new Ke,Rt=new Ge,Ut=new yt,Ft=new Ke,Qt=new Ke,Lt=new Ke,Ot=new Ge,Nt=new Ke(1,0,0),Pt=new Ke(0,1,0),Gt=new Ke(0,0,1),Kt={type:"added"},Vt={type:"removed"};class Yt extends me{constructor(){super(),Object.defineProperty(this,"id",{value:Dt++}),this.uuid=Ie(),this.name="",this.type="Object3D",this.parent=null,this.children=[],this.up=Yt.DefaultUp.clone();const e=new Ke,t=new bt,i=new Ge,n=new Ke(1,1,1);t._onChange((function(){i.setFromEuler(t,!1)})),i._onChange((function(){t.setFromQuaternion(i,void 0,!1)})),Object.defineProperties(this,{position:{configurable:!0,enumerable:!0,value:e},rotation:{configurable:!0,enumerable:!0,value:t},quaternion:{configurable:!0,enumerable:!0,value:i},scale:{configurable:!0,enumerable:!0,value:n},modelViewMatrix:{value:new yt},normalMatrix:{value:new De}}),this.matrix=new yt,this.matrixWorld=new yt,this.matrixAutoUpdate=Yt.DefaultMatrixAutoUpdate,this.matrixWorldNeedsUpdate=!1,this.layers=new kt,this.visible=!0,this.castShadow=!1,this.receiveShadow=!1,this.frustumCulled=!0,this.renderOrder=0,this.animations=[],this.userData={}}onBeforeRender(){}onAfterRender(){}applyMatrix4(e){this.matrixAutoUpdate&&this.updateMatrix(),this.matrix.premultiply(e),this.matrix.decompose(this.position,this.quaternion,this.scale)}applyQuaternion(e){return this.quaternion.premultiply(e),this}setRotationFromAxisAngle(e,t){this.quaternion.setFromAxisAngle(e,t)}setRotationFromEuler(e){this.quaternion.setFromEuler(e,!0)}setRotationFromMatrix(e){this.quaternion.setFromRotationMatrix(e)}setRotationFromQuaternion(e){this.quaternion.copy(e)}rotateOnAxis(e,t){return Rt.setFromAxisAngle(e,t),this.quaternion.multiply(Rt),this}rotateOnWorldAxis(e,t){return Rt.setFromAxisAngle(e,t),this.quaternion.premultiply(Rt),this}rotateX(e){return this.rotateOnAxis(Nt,e)}rotateY(e){return this.rotateOnAxis(Pt,e)}rotateZ(e){return this.rotateOnAxis(Gt,e)}translateOnAxis(e,t){return Tt.copy(e).applyQuaternion(this.quaternion),this.position.add(Tt.multiplyScalar(t)),this}translateX(e){return this.translateOnAxis(Nt,e)}translateY(e){return this.translateOnAxis(Pt,e)}translateZ(e){return this.translateOnAxis(Gt,e)}localToWorld(e){return e.applyMatrix4(this.matrixWorld)}worldToLocal(e){return e.applyMatrix4(Ut.copy(this.matrixWorld).invert())}lookAt(e,t,i){e.isVector3?Ft.copy(e):Ft.set(e,t,i);const n=this.parent;this.updateWorldMatrix(!0,!1),Qt.setFromMatrixPosition(this.matrixWorld),this.isCamera||this.isLight?Ut.lookAt(Qt,Ft,this.up):Ut.lookAt(Ft,Qt,this.up),this.quaternion.setFromRotationMatrix(Ut),n&&(Ut.extractRotation(n.matrixWorld),Rt.setFromRotationMatrix(Ut),this.quaternion.premultiply(Rt.invert()))}add(e){if(arguments.length>1){for(let e=0;arguments.length>e;e++)this.add(arguments[e]);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(Kt)):console.error("THREE.Object3D.add: object not an instance of THREE.Object3D.",e),this)}remove(e){if(arguments.length>1){for(let e=0;arguments.length>e;e++)this.remove(arguments[e]);return this}const t=this.children.indexOf(e);return-1!==t&&(e.parent=null,this.children.splice(t,1),e.dispatchEvent(Vt)),this}removeFromParent(){const e=this.parent;return null!==e&&e.remove(this),this}clear(){for(let e=0;this.children.length>e;e++){const t=this.children[e];t.parent=null,t.dispatchEvent(Vt)}return this.children.length=0,this}attach(e){return this.updateWorldMatrix(!0,!1),Ut.copy(this.matrixWorld).invert(),null!==e.parent&&(e.parent.updateWorldMatrix(!0,!1),Ut.multiply(e.parent.matrixWorld)),e.applyMatrix4(Ut),this.add(e),e.updateWorldMatrix(!1,!0),this}getObjectById(e){return this.getObjectByProperty("id",e)}getObjectByName(e){return this.getObjectByProperty("name",e)}getObjectByProperty(e,t){if(this[e]===t)return this;for(let i=0,n=this.children.length;n>i;i++){const n=this.children[i].getObjectByProperty(e,t);if(void 0!==n)return n}}getWorldPosition(e){return void 0===e&&(console.warn("THREE.Object3D: .getWorldPosition() target is now required"),e=new Ke),this.updateWorldMatrix(!0,!1),e.setFromMatrixPosition(this.matrixWorld)}getWorldQuaternion(e){return void 0===e&&(console.warn("THREE.Object3D: .getWorldQuaternion() target is now required"),e=new Ge),this.updateWorldMatrix(!0,!1),this.matrixWorld.decompose(Qt,e,Lt),e}getWorldScale(e){return void 0===e&&(console.warn("THREE.Object3D: .getWorldScale() target is now required"),e=new Ke),this.updateWorldMatrix(!0,!1),this.matrixWorld.decompose(Qt,Ot,e),e}getWorldDirection(e){void 0===e&&(console.warn("THREE.Object3D: .getWorldDirection() target is now required"),e=new Ke),this.updateWorldMatrix(!0,!1);const t=this.matrixWorld.elements;return e.set(t[8],t[9],t[10]).normalize()}raycast(){}traverse(e){e(this);const t=this.children;for(let i=0,n=t.length;n>i;i++)t[i].traverse(e)}traverseVisible(e){if(!1===this.visible)return;e(this);const t=this.children;for(let i=0,n=t.length;n>i;i++)t[i].traverseVisible(e)}traverseAncestors(e){const t=this.parent;null!==t&&(e(t),t.traverseAncestors(e))}updateMatrix(){this.matrix.compose(this.position,this.quaternion,this.scale),this.matrixWorldNeedsUpdate=!0}updateMatrixWorld(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);const t=this.children;for(let i=0,n=t.length;n>i;i++)t[i].updateMatrixWorld(e)}updateWorldMatrix(e,t){const i=this.parent;if(!0===e&&null!==i&&i.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){const e=this.children;for(let t=0,i=e.length;i>t;t++)e[t].updateWorldMatrix(!1,!0)}}toJSON(e){const t=void 0===e||"string"==typeof e,i={};t&&(e={geometries:{},materials:{},textures:{},images:{},shapes:{},skeletons:{},animations:{}},i.metadata={version:4.5,type:"Object",generator:"Object3D.toJSON"});const n={};function r(t,i){return void 0===t[i.uuid]&&(t[i.uuid]=i.toJSON(e)),i.uuid}if(n.uuid=this.uuid,n.type=this.type,""!==this.name&&(n.name=this.name),!0===this.castShadow&&(n.castShadow=!0),!0===this.receiveShadow&&(n.receiveShadow=!0),!1===this.visible&&(n.visible=!1),!1===this.frustumCulled&&(n.frustumCulled=!1),0!==this.renderOrder&&(n.renderOrder=this.renderOrder),"{}"!==JSON.stringify(this.userData)&&(n.userData=this.userData),n.layers=this.layers.mask,n.matrix=this.matrix.toArray(),!1===this.matrixAutoUpdate&&(n.matrixAutoUpdate=!1),this.isInstancedMesh&&(n.type="InstancedMesh",n.count=this.count,n.instanceMatrix=this.instanceMatrix.toJSON(),null!==this.instanceColor&&(n.instanceColor=this.instanceColor.toJSON())),this.isMesh||this.isLine||this.isPoints){n.geometry=r(e.geometries,this.geometry);const t=this.geometry.parameters;if(void 0!==t&&void 0!==t.shapes){const i=t.shapes;if(Array.isArray(i))for(let t=0,n=i.length;n>t;t++){r(e.shapes,i[t])}else r(e.shapes,i)}}if(this.isSkinnedMesh&&(n.bindMode=this.bindMode,n.bindMatrix=this.bindMatrix.toArray(),void 0!==this.skeleton&&(r(e.skeletons,this.skeleton),n.skeleton=this.skeleton.uuid)),void 0!==this.material)if(Array.isArray(this.material)){const t=[];for(let i=0,n=this.material.length;n>i;i++)t.push(r(e.materials,this.material[i]));n.material=t}else n.material=r(e.materials,this.material);if(this.children.length>0){n.children=[];for(let t=0;this.children.length>t;t++)n.children.push(this.children[t].toJSON(e).object)}if(this.animations.length>0){n.animations=[];for(let t=0;this.animations.length>t;t++){n.animations.push(r(e.animations,this.animations[t]))}}if(t){const t=o(e.geometries),n=o(e.materials),r=o(e.textures),a=o(e.images),s=o(e.shapes),l=o(e.skeletons),c=o(e.animations);t.length>0&&(i.geometries=t),n.length>0&&(i.materials=n),r.length>0&&(i.textures=r),a.length>0&&(i.images=a),s.length>0&&(i.shapes=s),l.length>0&&(i.skeletons=l),c.length>0&&(i.animations=c)}return i.object=n,i;function o(e){const t=[];for(const i in e){const n=e[i];delete n.metadata,t.push(n)}return t}}clone(e){return(new this.constructor).copy(this,e)}copy(e,t=!0){if(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(let t=0;e.children.length>t;t++){this.add(e.children[t].clone())}return this}}Yt.DefaultUp=new Ke(0,1,0),Yt.DefaultMatrixAutoUpdate=!0,Yt.prototype.isObject3D=!0;const Ht=new Ke,jt=new Ke,Wt=new De;class Jt{constructor(e=new Ke(1,0,0),t=0){this.normal=e,this.constant=t}set(e,t){return this.normal.copy(e),this.constant=t,this}setComponents(e,t,i,n){return this.normal.set(e,t,i),this.constant=n,this}setFromNormalAndCoplanarPoint(e,t){return this.normal.copy(e),this.constant=-t.dot(this.normal),this}setFromCoplanarPoints(e,t,i){const n=Ht.subVectors(i,t).cross(jt.subVectors(e,t)).normalize();return this.setFromNormalAndCoplanarPoint(n,e),this}copy(e){return this.normal.copy(e.normal),this.constant=e.constant,this}normalize(){const e=1/this.normal.length();return this.normal.multiplyScalar(e),this.constant*=e,this}negate(){return this.constant*=-1,this.normal.negate(),this}distanceToPoint(e){return this.normal.dot(e)+this.constant}distanceToSphere(e){return this.distanceToPoint(e.center)-e.radius}projectPoint(e,t){return void 0===t&&(console.warn("THREE.Plane: .projectPoint() target is now required"),t=new Ke),t.copy(this.normal).multiplyScalar(-this.distanceToPoint(e)).add(e)}intersectLine(e,t){void 0===t&&(console.warn("THREE.Plane: .intersectLine() target is now required"),t=new Ke);const i=e.delta(Ht),n=this.normal.dot(i);if(0===n)return 0===this.distanceToPoint(e.start)?t.copy(e.start):null;const r=-(e.start.dot(this.normal)+this.constant)/n;return 0>r||r>1?null:t.copy(i).multiplyScalar(r).add(e.start)}intersectsLine(e){const t=this.distanceToPoint(e.start),i=this.distanceToPoint(e.end);return 0>t&&i>0||0>i&&t>0}intersectsBox(e){return e.intersectsPlane(this)}intersectsSphere(e){return e.intersectsPlane(this)}coplanarPoint(e){return void 0===e&&(console.warn("THREE.Plane: .coplanarPoint() target is now required"),e=new Ke),e.copy(this.normal).multiplyScalar(-this.constant)}applyMatrix4(e,t){const i=t||Wt.getNormalMatrix(e),n=this.coplanarPoint(Ht).applyMatrix4(e),r=this.normal.applyMatrix3(i).normalize();return this.constant=-n.dot(r),this}translate(e){return this.constant-=e.dot(this.normal),this}equals(e){return e.normal.equals(this.normal)&&e.constant===this.constant}clone(){return(new this.constructor).copy(this)}}Jt.prototype.isPlane=!0;const zt=new Ke,qt=new Ke,Zt=new Ke,Xt=new Ke,_t=new Ke,$t=new Ke,ei=new Ke,ti=new Ke,ii=new Ke,ni=new Ke;class ri{constructor(e=new Ke,t=new Ke,i=new Ke){this.a=e,this.b=t,this.c=i}static getNormal(e,t,i,n){void 0===n&&(console.warn("THREE.Triangle: .getNormal() target is now required"),n=new Ke),n.subVectors(i,t),zt.subVectors(e,t),n.cross(zt);const r=n.lengthSq();return r>0?n.multiplyScalar(1/Math.sqrt(r)):n.set(0,0,0)}static getBarycoord(e,t,i,n,r){zt.subVectors(n,t),qt.subVectors(i,t),Zt.subVectors(e,t);const o=zt.dot(zt),a=zt.dot(qt),s=zt.dot(Zt),l=qt.dot(qt),c=qt.dot(Zt),h=o*l-a*a;if(void 0===r&&(console.warn("THREE.Triangle: .getBarycoord() target is now required"),r=new Ke),0===h)return r.set(-2,-1,-1);const d=1/h,u=(l*s-a*c)*d,p=(o*c-a*s)*d;return r.set(1-u-p,p,u)}static containsPoint(e,t,i,n){return this.getBarycoord(e,t,i,n,Xt),Xt.x>=0&&Xt.y>=0&&1>=Xt.x+Xt.y}static getUV(e,t,i,n,r,o,a,s){return this.getBarycoord(e,t,i,n,Xt),s.set(0,0),s.addScaledVector(r,Xt.x),s.addScaledVector(o,Xt.y),s.addScaledVector(a,Xt.z),s}static isFrontFacing(e,t,i,n){return zt.subVectors(i,t),qt.subVectors(e,t),0>zt.cross(qt).dot(n)}set(e,t,i){return this.a.copy(e),this.b.copy(t),this.c.copy(i),this}setFromPointsAndIndices(e,t,i,n){return this.a.copy(e[t]),this.b.copy(e[i]),this.c.copy(e[n]),this}clone(){return(new this.constructor).copy(this)}copy(e){return this.a.copy(e.a),this.b.copy(e.b),this.c.copy(e.c),this}getArea(){return zt.subVectors(this.c,this.b),qt.subVectors(this.a,this.b),.5*zt.cross(qt).length()}getMidpoint(e){return void 0===e&&(console.warn("THREE.Triangle: .getMidpoint() target is now required"),e=new Ke),e.addVectors(this.a,this.b).add(this.c).multiplyScalar(1/3)}getNormal(e){return ri.getNormal(this.a,this.b,this.c,e)}getPlane(e){return void 0===e&&(console.warn("THREE.Triangle: .getPlane() target is now required"),e=new Jt),e.setFromCoplanarPoints(this.a,this.b,this.c)}getBarycoord(e,t){return ri.getBarycoord(e,this.a,this.b,this.c,t)}getUV(e,t,i,n,r){return ri.getUV(e,this.a,this.b,this.c,t,i,n,r)}containsPoint(e){return ri.containsPoint(e,this.a,this.b,this.c)}isFrontFacing(e){return ri.isFrontFacing(this.a,this.b,this.c,e)}intersectsBox(e){return e.intersectsTriangle(this)}closestPointToPoint(e,t){void 0===t&&(console.warn("THREE.Triangle: .closestPointToPoint() target is now required"),t=new Ke);const i=this.a,n=this.b,r=this.c;let o,a;_t.subVectors(n,i),$t.subVectors(r,i),ti.subVectors(e,i);const s=_t.dot(ti),l=$t.dot(ti);if(0>=s&&0>=l)return t.copy(i);ii.subVectors(e,n);const c=_t.dot(ii),h=$t.dot(ii);if(c>=0&&c>=h)return t.copy(n);const d=s*h-c*l;if(0>=d&&s>=0&&0>=c)return o=s/(s-c),t.copy(i).addScaledVector(_t,o);ni.subVectors(e,r);const u=_t.dot(ni),p=$t.dot(ni);if(p>=0&&p>=u)return t.copy(r);const g=u*l-s*p;if(0>=g&&l>=0&&0>=p)return a=l/(l-p),t.copy(i).addScaledVector($t,a);const f=c*p-u*h;if(0>=f&&h-c>=0&&u-p>=0)return ei.subVectors(r,n),a=(h-c)/(h-c+(u-p)),t.copy(n).addScaledVector(ei,a);const m=1/(f+g+d);return o=g*m,a=d*m,t.copy(i).addScaledVector(_t,o).addScaledVector($t,a)}equals(e){return e.a.equals(this.a)&&e.b.equals(this.b)&&e.c.equals(this.c)}}let oi=0;class ai extends me{constructor(){super(),Object.defineProperty(this,"id",{value:oi++}),this.uuid=Ie(),this.name="",this.type="Material",this.fog=!0,this.blending=1,this.side=0,this.vertexColors=!1,this.opacity=1,this.transparent=!1,this.blendSrc=204,this.blendDst=205,this.blendEquation=r,this.blendSrcAlpha=null,this.blendDstAlpha=null,this.blendEquationAlpha=null,this.depthFunc=3,this.depthTest=!0,this.depthWrite=!0,this.stencilWriteMask=255,this.stencilFunc=ue,this.stencilRef=0,this.stencilFuncMask=255,this.stencilFail=oe,this.stencilZFail=oe,this.stencilZPass=oe,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.alphaToCoverage=!1,this.premultipliedAlpha=!1,this.visible=!0,this.toneMapped=!0,this.userData={},this.version=0}set needsUpdate(e){!0===e&&this.version++}onBuild(){}onBeforeCompile(){}customProgramCacheKey(){return this.onBeforeCompile.toString()}setValues(e){if(void 0!==e)for(const t in e){const i=e[t];if(void 0===i){console.warn("THREE.Material: '"+t+"' parameter is undefined.");continue}if("shading"===t){console.warn("THREE."+this.type+": .shading has been removed. Use the boolean .flatShading instead."),this.flatShading=1===i;continue}const n=this[t];void 0!==n?n&&n.isColor?n.set(i):n&&n.isVector3&&i&&i.isVector3?n.copy(i):this[t]=i:console.warn("THREE."+this.type+": '"+t+"' is not a property of this material.")}}toJSON(e){const t=void 0===e||"string"==typeof e;t&&(e={textures:{},images:{}});const i={metadata:{version:4.5,type:"Material",generator:"Material.toJSON"}};function n(e){const t=[];for(const i in e){const n=e[i];delete n.metadata,t.push(n)}return t}if(i.uuid=this.uuid,i.type=this.type,""!==this.name&&(i.name=this.name),this.color&&this.color.isColor&&(i.color=this.color.getHex()),void 0!==this.roughness&&(i.roughness=this.roughness),void 0!==this.metalness&&(i.metalness=this.metalness),this.sheen&&this.sheen.isColor&&(i.sheen=this.sheen.getHex()),this.emissive&&this.emissive.isColor&&(i.emissive=this.emissive.getHex()),this.emissiveIntensity&&1!==this.emissiveIntensity&&(i.emissiveIntensity=this.emissiveIntensity),this.specular&&this.specular.isColor&&(i.specular=this.specular.getHex()),void 0!==this.shininess&&(i.shininess=this.shininess),void 0!==this.clearcoat&&(i.clearcoat=this.clearcoat),void 0!==this.clearcoatRoughness&&(i.clearcoatRoughness=this.clearcoatRoughness),this.clearcoatMap&&this.clearcoatMap.isTexture&&(i.clearcoatMap=this.clearcoatMap.toJSON(e).uuid),this.clearcoatRoughnessMap&&this.clearcoatRoughnessMap.isTexture&&(i.clearcoatRoughnessMap=this.clearcoatRoughnessMap.toJSON(e).uuid),this.clearcoatNormalMap&&this.clearcoatNormalMap.isTexture&&(i.clearcoatNormalMap=this.clearcoatNormalMap.toJSON(e).uuid,i.clearcoatNormalScale=this.clearcoatNormalScale.toArray()),this.map&&this.map.isTexture&&(i.map=this.map.toJSON(e).uuid),this.matcap&&this.matcap.isTexture&&(i.matcap=this.matcap.toJSON(e).uuid),this.alphaMap&&this.alphaMap.isTexture&&(i.alphaMap=this.alphaMap.toJSON(e).uuid),this.lightMap&&this.lightMap.isTexture&&(i.lightMap=this.lightMap.toJSON(e).uuid,i.lightMapIntensity=this.lightMapIntensity),this.aoMap&&this.aoMap.isTexture&&(i.aoMap=this.aoMap.toJSON(e).uuid,i.aoMapIntensity=this.aoMapIntensity),this.bumpMap&&this.bumpMap.isTexture&&(i.bumpMap=this.bumpMap.toJSON(e).uuid,i.bumpScale=this.bumpScale),this.normalMap&&this.normalMap.isTexture&&(i.normalMap=this.normalMap.toJSON(e).uuid,i.normalMapType=this.normalMapType,i.normalScale=this.normalScale.toArray()),this.displacementMap&&this.displacementMap.isTexture&&(i.displacementMap=this.displacementMap.toJSON(e).uuid,i.displacementScale=this.displacementScale,i.displacementBias=this.displacementBias),this.roughnessMap&&this.roughnessMap.isTexture&&(i.roughnessMap=this.roughnessMap.toJSON(e).uuid),this.metalnessMap&&this.metalnessMap.isTexture&&(i.metalnessMap=this.metalnessMap.toJSON(e).uuid),this.emissiveMap&&this.emissiveMap.isTexture&&(i.emissiveMap=this.emissiveMap.toJSON(e).uuid),this.specularMap&&this.specularMap.isTexture&&(i.specularMap=this.specularMap.toJSON(e).uuid),this.envMap&&this.envMap.isTexture&&(i.envMap=this.envMap.toJSON(e).uuid,void 0!==this.combine&&(i.combine=this.combine)),void 0!==this.envMapIntensity&&(i.envMapIntensity=this.envMapIntensity),void 0!==this.reflectivity&&(i.reflectivity=this.reflectivity),void 0!==this.refractionRatio&&(i.refractionRatio=this.refractionRatio),this.gradientMap&&this.gradientMap.isTexture&&(i.gradientMap=this.gradientMap.toJSON(e).uuid),void 0!==this.transmission&&(i.transmission=this.transmission),this.transmissionMap&&this.transmissionMap.isTexture&&(i.transmissionMap=this.transmissionMap.toJSON(e).uuid),void 0!==this.thickness&&(i.thickness=this.thickness),this.thicknessMap&&this.thicknessMap.isTexture&&(i.thicknessMap=this.thicknessMap.toJSON(e).uuid),void 0!==this.attenuationDistance&&(i.attenuationDistance=this.attenuationDistance),void 0!==this.attenuationColor&&(i.attenuationColor=this.attenuationColor.getHex()),void 0!==this.size&&(i.size=this.size),null!==this.shadowSide&&(i.shadowSide=this.shadowSide),void 0!==this.sizeAttenuation&&(i.sizeAttenuation=this.sizeAttenuation),1!==this.blending&&(i.blending=this.blending),0!==this.side&&(i.side=this.side),this.vertexColors&&(i.vertexColors=!0),1>this.opacity&&(i.opacity=this.opacity),!0===this.transparent&&(i.transparent=this.transparent),i.depthFunc=this.depthFunc,i.depthTest=this.depthTest,i.depthWrite=this.depthWrite,i.colorWrite=this.colorWrite,i.stencilWrite=this.stencilWrite,i.stencilWriteMask=this.stencilWriteMask,i.stencilFunc=this.stencilFunc,i.stencilRef=this.stencilRef,i.stencilFuncMask=this.stencilFuncMask,i.stencilFail=this.stencilFail,i.stencilZFail=this.stencilZFail,i.stencilZPass=this.stencilZPass,this.rotation&&0!==this.rotation&&(i.rotation=this.rotation),!0===this.polygonOffset&&(i.polygonOffset=!0),0!==this.polygonOffsetFactor&&(i.polygonOffsetFactor=this.polygonOffsetFactor),0!==this.polygonOffsetUnits&&(i.polygonOffsetUnits=this.polygonOffsetUnits),this.linewidth&&1!==this.linewidth&&(i.linewidth=this.linewidth),void 0!==this.dashSize&&(i.dashSize=this.dashSize),void 0!==this.gapSize&&(i.gapSize=this.gapSize),void 0!==this.scale&&(i.scale=this.scale),!0===this.dithering&&(i.dithering=!0),this.alphaTest>0&&(i.alphaTest=this.alphaTest),!0===this.alphaToCoverage&&(i.alphaToCoverage=this.alphaToCoverage),!0===this.premultipliedAlpha&&(i.premultipliedAlpha=this.premultipliedAlpha),!0===this.wireframe&&(i.wireframe=this.wireframe),this.wireframeLinewidth>1&&(i.wireframeLinewidth=this.wireframeLinewidth),"round"!==this.wireframeLinecap&&(i.wireframeLinecap=this.wireframeLinecap),"round"!==this.wireframeLinejoin&&(i.wireframeLinejoin=this.wireframeLinejoin),!0===this.morphTargets&&(i.morphTargets=!0),!0===this.morphNormals&&(i.morphNormals=!0),!0===this.flatShading&&(i.flatShading=this.flatShading),!1===this.visible&&(i.visible=!1),!1===this.toneMapped&&(i.toneMapped=!1),"{}"!==JSON.stringify(this.userData)&&(i.userData=this.userData),t){const t=n(e.textures),r=n(e.images);t.length>0&&(i.textures=t),r.length>0&&(i.images=r)}return i}clone(){return(new this.constructor).copy(this)}copy(e){this.name=e.name,this.fog=e.fog,this.blending=e.blending,this.side=e.side,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;const t=e.clippingPlanes;let i=null;if(null!==t){const e=t.length;i=new Array(e);for(let n=0;n!==e;++n)i[n]=t[n].clone()}return this.clippingPlanes=i,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.alphaToCoverage=e.alphaToCoverage,this.premultipliedAlpha=e.premultipliedAlpha,this.visible=e.visible,this.toneMapped=e.toneMapped,this.userData=JSON.parse(JSON.stringify(e.userData)),this}dispose(){this.dispatchEvent({type:"dispose"})}}ai.prototype.isMaterial=!0;const si={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},li={h:0,s:0,l:0},ci={h:0,s:0,l:0};function hi(e,t,i){return 0>i&&(i+=1),i>1&&(i-=1),1/6>i?e+6*(t-e)*i:.5>i?t:2/3>i?e+6*(t-e)*(2/3-i):e}function di(e){return.04045>e?.0773993808*e:Math.pow(.9478672986*e+.0521327014,2.4)}function ui(e){return.0031308>e?12.92*e:1.055*Math.pow(e,.41666)-.055}class pi{constructor(e,t,i){return void 0===t&&void 0===i?this.set(e):this.setRGB(e,t,i)}set(e){return e&&e.isColor?this.copy(e):"number"==typeof e?this.setHex(e):"string"==typeof e&&this.setStyle(e),this}setScalar(e){return this.r=e,this.g=e,this.b=e,this}setHex(e){return e=Math.floor(e),this.r=(e>>16&255)/255,this.g=(e>>8&255)/255,this.b=(255&e)/255,this}setRGB(e,t,i){return this.r=e,this.g=t,this.b=i,this}setHSL(e,t,i){if(e=we(e,1),t=xe(t,0,1),i=xe(i,0,1),0===t)this.r=this.g=this.b=i;else{const n=i>.5?i+t-i*t:i*(1+t),r=2*i-n;this.r=hi(r,n,e+1/3),this.g=hi(r,n,e),this.b=hi(r,n,e-1/3)}return this}setStyle(e){function t(t){void 0!==t&&1>parseFloat(t)&&console.warn("THREE.Color: Alpha component of "+e+" will be ignored.")}let i;if(i=/^((?:rgb|hsl)a?)\(([^\)]*)\)/.exec(e)){let e;const n=i[2];switch(i[1]){case"rgb":case"rgba":if(e=/^\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*(?:,\s*(\d*\.?\d+)\s*)?$/.exec(n))return this.r=Math.min(255,parseInt(e[1],10))/255,this.g=Math.min(255,parseInt(e[2],10))/255,this.b=Math.min(255,parseInt(e[3],10))/255,t(e[4]),this;if(e=/^\s*(\d+)\%\s*,\s*(\d+)\%\s*,\s*(\d+)\%\s*(?:,\s*(\d*\.?\d+)\s*)?$/.exec(n))return this.r=Math.min(100,parseInt(e[1],10))/100,this.g=Math.min(100,parseInt(e[2],10))/100,this.b=Math.min(100,parseInt(e[3],10))/100,t(e[4]),this;break;case"hsl":case"hsla":if(e=/^\s*(\d*\.?\d+)\s*,\s*(\d+)\%\s*,\s*(\d+)\%\s*(?:,\s*(\d*\.?\d+)\s*)?$/.exec(n)){const i=parseFloat(e[1])/360,n=parseInt(e[2],10)/100,r=parseInt(e[3],10)/100;return t(e[4]),this.setHSL(i,n,r)}}}else if(i=/^\#([A-Fa-f\d]+)$/.exec(e)){const e=i[1],t=e.length;if(3===t)return this.r=parseInt(e.charAt(0)+e.charAt(0),16)/255,this.g=parseInt(e.charAt(1)+e.charAt(1),16)/255,this.b=parseInt(e.charAt(2)+e.charAt(2),16)/255,this;if(6===t)return this.r=parseInt(e.charAt(0)+e.charAt(1),16)/255,this.g=parseInt(e.charAt(2)+e.charAt(3),16)/255,this.b=parseInt(e.charAt(4)+e.charAt(5),16)/255,this}return e&&e.length>0?this.setColorName(e):this}setColorName(e){const t=si[e.toLowerCase()];return void 0!==t?this.setHex(t):console.warn("THREE.Color: Unknown color "+e),this}clone(){return new this.constructor(this.r,this.g,this.b)}copy(e){return this.r=e.r,this.g=e.g,this.b=e.b,this}copyGammaToLinear(e,t=2){return this.r=Math.pow(e.r,t),this.g=Math.pow(e.g,t),this.b=Math.pow(e.b,t),this}copyLinearToGamma(e,t=2){const i=t>0?1/t:1;return this.r=Math.pow(e.r,i),this.g=Math.pow(e.g,i),this.b=Math.pow(e.b,i),this}convertGammaToLinear(e){return this.copyGammaToLinear(this,e),this}convertLinearToGamma(e){return this.copyLinearToGamma(this,e),this}copySRGBToLinear(e){return this.r=di(e.r),this.g=di(e.g),this.b=di(e.b),this}copyLinearToSRGB(e){return this.r=ui(e.r),this.g=ui(e.g),this.b=ui(e.b),this}convertSRGBToLinear(){return this.copySRGBToLinear(this),this}convertLinearToSRGB(){return this.copyLinearToSRGB(this),this}getHex(){return 255*this.r<<16^255*this.g<<8^255*this.b<<0}getHexString(){return("000000"+this.getHex().toString(16)).slice(-6)}getHSL(e){void 0===e&&(console.warn("THREE.Color: .getHSL() target is now required"),e={h:0,s:0,l:0});const t=this.r,i=this.g,n=this.b,r=Math.max(t,i,n),o=Math.min(t,i,n);let a,s;const l=(o+r)/2;if(o===r)a=0,s=0;else{const e=r-o;switch(s=l>.5?e/(2-r-o):e/(r+o),r){case t:a=(i-n)/e+(n>i?6:0);break;case i:a=(n-t)/e+2;break;case n:a=(t-i)/e+4}a/=6}return e.h=a,e.s=s,e.l=l,e}getStyle(){return"rgb("+(255*this.r|0)+","+(255*this.g|0)+","+(255*this.b|0)+")"}offsetHSL(e,t,i){return this.getHSL(li),li.h+=e,li.s+=t,li.l+=i,this.setHSL(li.h,li.s,li.l),this}add(e){return this.r+=e.r,this.g+=e.g,this.b+=e.b,this}addColors(e,t){return this.r=e.r+t.r,this.g=e.g+t.g,this.b=e.b+t.b,this}addScalar(e){return this.r+=e,this.g+=e,this.b+=e,this}sub(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}multiply(e){return this.r*=e.r,this.g*=e.g,this.b*=e.b,this}multiplyScalar(e){return this.r*=e,this.g*=e,this.b*=e,this}lerp(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}lerpColors(e,t,i){return this.r=e.r+(t.r-e.r)*i,this.g=e.g+(t.g-e.g)*i,this.b=e.b+(t.b-e.b)*i,this}lerpHSL(e,t){this.getHSL(li),e.getHSL(ci);const i=Me(li.h,ci.h,t),n=Me(li.s,ci.s,t),r=Me(li.l,ci.l,t);return this.setHSL(i,n,r),this}equals(e){return e.r===this.r&&e.g===this.g&&e.b===this.b}fromArray(e,t=0){return this.r=e[t],this.g=e[t+1],this.b=e[t+2],this}toArray(e=[],t=0){return e[t]=this.r,e[t+1]=this.g,e[t+2]=this.b,e}fromBufferAttribute(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}toJSON(){return this.getHex()}}pi.NAMES=si,pi.prototype.isColor=!0,pi.prototype.r=1,pi.prototype.g=1,pi.prototype.b=1;class gi extends ai{constructor(e){super(),this.type="MeshBasicMaterial",this.color=new pi(16777215),this.map=null,this.lightMap=null,this.lightMapIntensity=1,this.aoMap=null,this.aoMapIntensity=1,this.specularMap=null,this.alphaMap=null,this.envMap=null,this.combine=0,this.reflectivity=1,this.refractionRatio=.98,this.wireframe=!1,this.wireframeLinewidth=1,this.wireframeLinecap="round",this.wireframeLinejoin="round",this.morphTargets=!1,this.setValues(e)}copy(e){return super.copy(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.morphTargets=e.morphTargets,this}}gi.prototype.isMeshBasicMaterial=!0;const fi=new Ke,mi=new ke;class Ai{constructor(e,t,i){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===i,this.usage=pe,this.updateRange={offset:0,count:-1},this.version=0}set needsUpdate(e){!0===e&&this.version++}onUploadCallback(){}setUsage(e){return this.usage=e,this}copy(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(e,t,i){e*=this.itemSize,i*=t.itemSize;for(let n=0,r=this.itemSize;r>n;n++)this.array[e+n]=t.array[i+n];return this}copyArray(e){return this.array.set(e),this}copyColorsArray(e){const t=this.array;let i=0;for(let n=0,r=e.length;r>n;n++){let r=e[n];void 0===r&&(console.warn("THREE.BufferAttribute.copyColorsArray(): color is undefined",n),r=new pi),t[i++]=r.r,t[i++]=r.g,t[i++]=r.b}return this}copyVector2sArray(e){const t=this.array;let i=0;for(let n=0,r=e.length;r>n;n++){let r=e[n];void 0===r&&(console.warn("THREE.BufferAttribute.copyVector2sArray(): vector is undefined",n),r=new ke),t[i++]=r.x,t[i++]=r.y}return this}copyVector3sArray(e){const t=this.array;let i=0;for(let n=0,r=e.length;r>n;n++){let r=e[n];void 0===r&&(console.warn("THREE.BufferAttribute.copyVector3sArray(): vector is undefined",n),r=new Ke),t[i++]=r.x,t[i++]=r.y,t[i++]=r.z}return this}copyVector4sArray(e){const t=this.array;let i=0;for(let n=0,r=e.length;r>n;n++){let r=e[n];void 0===r&&(console.warn("THREE.BufferAttribute.copyVector4sArray(): vector is undefined",n),r=new Le),t[i++]=r.x,t[i++]=r.y,t[i++]=r.z,t[i++]=r.w}return this}applyMatrix3(e){if(2===this.itemSize)for(let t=0,i=this.count;i>t;t++)mi.fromBufferAttribute(this,t),mi.applyMatrix3(e),this.setXY(t,mi.x,mi.y);else if(3===this.itemSize)for(let t=0,i=this.count;i>t;t++)fi.fromBufferAttribute(this,t),fi.applyMatrix3(e),this.setXYZ(t,fi.x,fi.y,fi.z);return this}applyMatrix4(e){for(let t=0,i=this.count;i>t;t++)fi.x=this.getX(t),fi.y=this.getY(t),fi.z=this.getZ(t),fi.applyMatrix4(e),this.setXYZ(t,fi.x,fi.y,fi.z);return this}applyNormalMatrix(e){for(let t=0,i=this.count;i>t;t++)fi.x=this.getX(t),fi.y=this.getY(t),fi.z=this.getZ(t),fi.applyNormalMatrix(e),this.setXYZ(t,fi.x,fi.y,fi.z);return this}transformDirection(e){for(let t=0,i=this.count;i>t;t++)fi.x=this.getX(t),fi.y=this.getY(t),fi.z=this.getZ(t),fi.transformDirection(e),this.setXYZ(t,fi.x,fi.y,fi.z);return this}set(e,t=0){return this.array.set(e,t),this}getX(e){return this.array[e*this.itemSize]}setX(e,t){return this.array[e*this.itemSize]=t,this}getY(e){return this.array[e*this.itemSize+1]}setY(e,t){return this.array[e*this.itemSize+1]=t,this}getZ(e){return this.array[e*this.itemSize+2]}setZ(e,t){return this.array[e*this.itemSize+2]=t,this}getW(e){return this.array[e*this.itemSize+3]}setW(e,t){return this.array[e*this.itemSize+3]=t,this}setXY(e,t,i){return this.array[(e*=this.itemSize)+0]=t,this.array[e+1]=i,this}setXYZ(e,t,i,n){return this.array[(e*=this.itemSize)+0]=t,this.array[e+1]=i,this.array[e+2]=n,this}setXYZW(e,t,i,n,r){return this.array[(e*=this.itemSize)+0]=t,this.array[e+1]=i,this.array[e+2]=n,this.array[e+3]=r,this}onUpload(e){return this.onUploadCallback=e,this}clone(){return new this.constructor(this.array,this.itemSize).copy(this)}toJSON(){const e={itemSize:this.itemSize,type:this.array.constructor.name,array:Array.prototype.slice.call(this.array),normalized:this.normalized};return""!==this.name&&(e.name=this.name),this.usage!==pe&&(e.usage=this.usage),0===this.updateRange.offset&&-1===this.updateRange.count||(e.updateRange=this.updateRange),e}}Ai.prototype.isBufferAttribute=!0;class yi extends Ai{constructor(e,t,i){super(new Int8Array(e),t,i)}}class vi extends Ai{constructor(e,t,i){super(new Uint8Array(e),t,i)}}class Ci extends Ai{constructor(e,t,i){super(new Uint8ClampedArray(e),t,i)}}class Ii extends Ai{constructor(e,t,i){super(new Int16Array(e),t,i)}}class xi extends Ai{constructor(e,t,i){super(new Uint16Array(e),t,i)}}class wi extends Ai{constructor(e,t,i){super(new Int32Array(e),t,i)}}class Mi extends Ai{constructor(e,t,i){super(new Uint32Array(e),t,i)}}class Ei extends Ai{constructor(e,t,i){super(new Uint16Array(e),t,i)}}Ei.prototype.isFloat16BufferAttribute=!0;class Bi extends Ai{constructor(e,t,i){super(new Float32Array(e),t,i)}}class Si extends Ai{constructor(e,t,i){super(new Float64Array(e),t,i)}}function bi(e){if(0===e.length)return-1/0;let t=e[0];for(let i=1,n=e.length;n>i;++i)e[i]>t&&(t=e[i]);return t}const ki={Int8Array:Int8Array,Uint8Array:Uint8Array,Uint8ClampedArray:Uint8ClampedArray,Int16Array:Int16Array,Uint16Array:Uint16Array,Int32Array:Int32Array,Uint32Array:Uint32Array,Float32Array:Float32Array,Float64Array:Float64Array};function Di(e,t){return new ki[e](t)}let Ti=0;const Ri=new yt,Ui=new Yt,Fi=new Ke,Qi=new He,Li=new He,Oi=new Ke;class Ni extends me{constructor(){super(),Object.defineProperty(this,"id",{value:Ti++}),this.uuid=Ie(),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={}}getIndex(){return this.index}setIndex(e){return this.index=Array.isArray(e)?new(bi(e)>65535?Mi:xi)(e,1):e,this}getAttribute(e){return this.attributes[e]}setAttribute(e,t){return this.attributes[e]=t,this}deleteAttribute(e){return delete this.attributes[e],this}hasAttribute(e){return void 0!==this.attributes[e]}addGroup(e,t,i=0){this.groups.push({start:e,count:t,materialIndex:i})}clearGroups(){this.groups=[]}setDrawRange(e,t){this.drawRange.start=e,this.drawRange.count=t}applyMatrix4(e){const t=this.attributes.position;void 0!==t&&(t.applyMatrix4(e),t.needsUpdate=!0);const i=this.attributes.normal;if(void 0!==i){const t=(new De).getNormalMatrix(e);i.applyNormalMatrix(t),i.needsUpdate=!0}const n=this.attributes.tangent;return void 0!==n&&(n.transformDirection(e),n.needsUpdate=!0),null!==this.boundingBox&&this.computeBoundingBox(),null!==this.boundingSphere&&this.computeBoundingSphere(),this}applyQuaternion(e){return Ri.makeRotationFromQuaternion(e),this.applyMatrix4(Ri),this}rotateX(e){return Ri.makeRotationX(e),this.applyMatrix4(Ri),this}rotateY(e){return Ri.makeRotationY(e),this.applyMatrix4(Ri),this}rotateZ(e){return Ri.makeRotationZ(e),this.applyMatrix4(Ri),this}translate(e,t,i){return Ri.makeTranslation(e,t,i),this.applyMatrix4(Ri),this}scale(e,t,i){return Ri.makeScale(e,t,i),this.applyMatrix4(Ri),this}lookAt(e){return Ui.lookAt(e),Ui.updateMatrix(),this.applyMatrix4(Ui.matrix),this}center(){return this.computeBoundingBox(),this.boundingBox.getCenter(Fi).negate(),this.translate(Fi.x,Fi.y,Fi.z),this}setFromPoints(e){const t=[];for(let i=0,n=e.length;n>i;i++){const n=e[i];t.push(n.x,n.y,n.z||0)}return this.setAttribute("position",new Bi(t,3)),this}computeBoundingBox(){null===this.boundingBox&&(this.boundingBox=new He);const 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 Ke(-1/0,-1/0,-1/0),new Ke(1/0,1/0,1/0));if(void 0!==e){if(this.boundingBox.setFromBufferAttribute(e),t)for(let e=0,i=t.length;i>e;e++){Qi.setFromBufferAttribute(t[e]),this.morphTargetsRelative?(Oi.addVectors(this.boundingBox.min,Qi.min),this.boundingBox.expandByPoint(Oi),Oi.addVectors(this.boundingBox.max,Qi.max),this.boundingBox.expandByPoint(Oi)):(this.boundingBox.expandByPoint(Qi.min),this.boundingBox.expandByPoint(Qi.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(){null===this.boundingSphere&&(this.boundingSphere=new ct);const 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 Ke,1/0);if(e){const i=this.boundingSphere.center;if(Qi.setFromBufferAttribute(e),t)for(let e=0,i=t.length;i>e;e++){Li.setFromBufferAttribute(t[e]),this.morphTargetsRelative?(Oi.addVectors(Qi.min,Li.min),Qi.expandByPoint(Oi),Oi.addVectors(Qi.max,Li.max),Qi.expandByPoint(Oi)):(Qi.expandByPoint(Li.min),Qi.expandByPoint(Li.max))}Qi.getCenter(i);let n=0;for(let t=0,r=e.count;r>t;t++)Oi.fromBufferAttribute(e,t),n=Math.max(n,i.distanceToSquared(Oi));if(t)for(let r=0,o=t.length;o>r;r++){const o=t[r],a=this.morphTargetsRelative;for(let t=0,r=o.count;r>t;t++)Oi.fromBufferAttribute(o,t),a&&(Fi.fromBufferAttribute(e,t),Oi.add(Fi)),n=Math.max(n,i.distanceToSquared(Oi))}this.boundingSphere.radius=Math.sqrt(n),isNaN(this.boundingSphere.radius)&&console.error('THREE.BufferGeometry.computeBoundingSphere(): Computed radius is NaN. The "position" attribute is likely to have NaN values.',this)}}computeFaceNormals(){}computeTangents(){const e=this.index,t=this.attributes;if(null===e||void 0===t.position||void 0===t.normal||void 0===t.uv)return void console.error("THREE.BufferGeometry: .computeTangents() failed. Missing required attributes (index, position, normal or uv)");const i=e.array,n=t.position.array,r=t.normal.array,o=t.uv.array,a=n.length/3;void 0===t.tangent&&this.setAttribute("tangent",new Ai(new Float32Array(4*a),4));const s=t.tangent.array,l=[],c=[];for(let e=0;a>e;e++)l[e]=new Ke,c[e]=new Ke;const h=new Ke,d=new Ke,u=new Ke,p=new ke,g=new ke,f=new ke,m=new Ke,A=new Ke;function y(e,t,i){h.fromArray(n,3*e),d.fromArray(n,3*t),u.fromArray(n,3*i),p.fromArray(o,2*e),g.fromArray(o,2*t),f.fromArray(o,2*i),d.sub(h),u.sub(h),g.sub(p),f.sub(p);const r=1/(g.x*f.y-f.x*g.y);isFinite(r)&&(m.copy(d).multiplyScalar(f.y).addScaledVector(u,-g.y).multiplyScalar(r),A.copy(u).multiplyScalar(g.x).addScaledVector(d,-f.x).multiplyScalar(r),l[e].add(m),l[t].add(m),l[i].add(m),c[e].add(A),c[t].add(A),c[i].add(A))}let v=this.groups;0===v.length&&(v=[{start:0,count:i.length}]);for(let e=0,t=v.length;t>e;++e){const t=v[e],n=t.start;for(let e=n,r=n+t.count;r>e;e+=3)y(i[e+0],i[e+1],i[e+2])}const C=new Ke,I=new Ke,x=new Ke,w=new Ke;function M(e){x.fromArray(r,3*e),w.copy(x);const t=l[e];C.copy(t),C.sub(x.multiplyScalar(x.dot(t))).normalize(),I.crossVectors(w,t);const i=0>I.dot(c[e])?-1:1;s[4*e]=C.x,s[4*e+1]=C.y,s[4*e+2]=C.z,s[4*e+3]=i}for(let e=0,t=v.length;t>e;++e){const t=v[e],n=t.start;for(let e=n,r=n+t.count;r>e;e+=3)M(i[e+0]),M(i[e+1]),M(i[e+2])}}computeVertexNormals(){const e=this.index,t=this.getAttribute("position");if(void 0!==t){let i=this.getAttribute("normal");if(void 0===i)i=new Ai(new Float32Array(3*t.count),3),this.setAttribute("normal",i);else for(let e=0,t=i.count;t>e;e++)i.setXYZ(e,0,0,0);const n=new Ke,r=new Ke,o=new Ke,a=new Ke,s=new Ke,l=new Ke,c=new Ke,h=new Ke;if(e)for(let d=0,u=e.count;u>d;d+=3){const u=e.getX(d+0),p=e.getX(d+1),g=e.getX(d+2);n.fromBufferAttribute(t,u),r.fromBufferAttribute(t,p),o.fromBufferAttribute(t,g),c.subVectors(o,r),h.subVectors(n,r),c.cross(h),a.fromBufferAttribute(i,u),s.fromBufferAttribute(i,p),l.fromBufferAttribute(i,g),a.add(c),s.add(c),l.add(c),i.setXYZ(u,a.x,a.y,a.z),i.setXYZ(p,s.x,s.y,s.z),i.setXYZ(g,l.x,l.y,l.z)}else for(let e=0,a=t.count;a>e;e+=3)n.fromBufferAttribute(t,e+0),r.fromBufferAttribute(t,e+1),o.fromBufferAttribute(t,e+2),c.subVectors(o,r),h.subVectors(n,r),c.cross(h),i.setXYZ(e+0,c.x,c.y,c.z),i.setXYZ(e+1,c.x,c.y,c.z),i.setXYZ(e+2,c.x,c.y,c.z);this.normalizeNormals(),i.needsUpdate=!0}}merge(e,t){if(!e||!e.isBufferGeometry)return void console.error("THREE.BufferGeometry.merge(): geometry not an instance of THREE.BufferGeometry.",e);void 0===t&&(t=0,console.warn("THREE.BufferGeometry.merge(): Overwriting original geometry, starting at offset=0. Use BufferGeometryUtils.mergeBufferGeometries() for lossless merge."));const i=this.attributes;for(const n in i){if(void 0===e.attributes[n])continue;const r=i[n].array,o=e.attributes[n],a=o.array,s=o.itemSize*t,l=Math.min(a.length,r.length-s);for(let e=0,t=s;l>e;e++,t++)r[t]=a[e]}return this}normalizeNormals(){const e=this.attributes.normal;for(let t=0,i=e.count;i>t;t++)Oi.fromBufferAttribute(e,t),Oi.normalize(),e.setXYZ(t,Oi.x,Oi.y,Oi.z)}toNonIndexed(){function e(e,t){const i=e.array,n=e.itemSize,r=e.normalized,o=new i.constructor(t.length*n);let a=0,s=0;for(let e=0,r=t.length;r>e;e++){a=t[e]*n;for(let e=0;n>e;e++)o[s++]=i[a++]}return new Ai(o,n,r)}if(null===this.index)return console.warn("THREE.BufferGeometry.toNonIndexed(): BufferGeometry is already non-indexed."),this;const t=new Ni,i=this.index.array,n=this.attributes;for(const r in n){const o=e(n[r],i);t.setAttribute(r,o)}const r=this.morphAttributes;for(const n in r){const o=[],a=r[n];for(let t=0,n=a.length;n>t;t++){const n=e(a[t],i);o.push(n)}t.morphAttributes[n]=o}t.morphTargetsRelative=this.morphTargetsRelative;const o=this.groups;for(let e=0,i=o.length;i>e;e++){const i=o[e];t.addGroup(i.start,i.count,i.materialIndex)}return t}toJSON(){const 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){const t=this.parameters;for(const i in t)void 0!==t[i]&&(e[i]=t[i]);return e}e.data={attributes:{}};const t=this.index;null!==t&&(e.data.index={type:t.array.constructor.name,array:Array.prototype.slice.call(t.array)});const i=this.attributes;for(const t in i){e.data.attributes[t]=i[t].toJSON(e.data)}const n={};let r=!1;for(const t in this.morphAttributes){const i=this.morphAttributes[t],o=[];for(let t=0,n=i.length;n>t;t++){o.push(i[t].toJSON(e.data))}o.length>0&&(n[t]=o,r=!0)}r&&(e.data.morphAttributes=n,e.data.morphTargetsRelative=this.morphTargetsRelative);const o=this.groups;o.length>0&&(e.data.groups=JSON.parse(JSON.stringify(o)));const a=this.boundingSphere;return null!==a&&(e.data.boundingSphere={center:a.center.toArray(),radius:a.radius}),e}clone(){return(new Ni).copy(this)}copy(e){this.index=null,this.attributes={},this.morphAttributes={},this.groups=[],this.boundingBox=null,this.boundingSphere=null;const t={};this.name=e.name;const i=e.index;null!==i&&this.setIndex(i.clone(t));const n=e.attributes;for(const e in n){this.setAttribute(e,n[e].clone(t))}const r=e.morphAttributes;for(const e in r){const i=[],n=r[e];for(let e=0,r=n.length;r>e;e++)i.push(n[e].clone(t));this.morphAttributes[e]=i}this.morphTargetsRelative=e.morphTargetsRelative;const o=e.groups;for(let e=0,t=o.length;t>e;e++){const t=o[e];this.addGroup(t.start,t.count,t.materialIndex)}const a=e.boundingBox;null!==a&&(this.boundingBox=a.clone());const s=e.boundingSphere;return null!==s&&(this.boundingSphere=s.clone()),this.drawRange.start=e.drawRange.start,this.drawRange.count=e.drawRange.count,this.userData=e.userData,this}dispose(){this.dispatchEvent({type:"dispose"})}}Ni.prototype.isBufferGeometry=!0;const Pi=new yt,Gi=new At,Ki=new ct,Vi=new Ke,Yi=new Ke,Hi=new Ke,ji=new Ke,Wi=new Ke,Ji=new Ke,zi=new Ke,qi=new Ke,Zi=new Ke,Xi=new ke,_i=new ke,$i=new ke,en=new Ke,tn=new Ke;class nn extends Yt{constructor(e=new Ni,t=new gi){super(),this.type="Mesh",this.geometry=e,this.material=t,this.updateMorphTargets()}copy(e){return super.copy(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(){const e=this.geometry;if(e.isBufferGeometry){const t=e.morphAttributes,i=Object.keys(t);if(i.length>0){const e=t[i[0]];if(void 0!==e){this.morphTargetInfluences=[],this.morphTargetDictionary={};for(let t=0,i=e.length;i>t;t++){const i=e[t].name||String(t);this.morphTargetInfluences.push(0),this.morphTargetDictionary[i]=t}}}}else{const t=e.morphTargets;void 0!==t&&t.length>0&&console.error("THREE.Mesh.updateMorphTargets() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.")}}raycast(e,t){const i=this.geometry,n=this.material,r=this.matrixWorld;if(void 0===n)return;if(null===i.boundingSphere&&i.computeBoundingSphere(),Ki.copy(i.boundingSphere),Ki.applyMatrix4(r),!1===e.ray.intersectsSphere(Ki))return;if(Pi.copy(r).invert(),Gi.copy(e.ray).applyMatrix4(Pi),null!==i.boundingBox&&!1===Gi.intersectsBox(i.boundingBox))return;let o;if(i.isBufferGeometry){const r=i.index,a=i.attributes.position,s=i.morphAttributes.position,l=i.morphTargetsRelative,c=i.attributes.uv,h=i.attributes.uv2,d=i.groups,u=i.drawRange;if(null!==r)if(Array.isArray(n))for(let i=0,p=d.length;p>i;i++){const p=d[i],g=n[p.materialIndex];for(let i=Math.max(p.start,u.start),n=Math.min(p.start+p.count,u.start+u.count);n>i;i+=3){const n=r.getX(i),d=r.getX(i+1),u=r.getX(i+2);o=rn(this,g,e,Gi,a,s,l,c,h,n,d,u),o&&(o.faceIndex=Math.floor(i/3),o.face.materialIndex=p.materialIndex,t.push(o))}}else{for(let i=Math.max(0,u.start),d=Math.min(r.count,u.start+u.count);d>i;i+=3){const d=r.getX(i),u=r.getX(i+1),p=r.getX(i+2);o=rn(this,n,e,Gi,a,s,l,c,h,d,u,p),o&&(o.faceIndex=Math.floor(i/3),t.push(o))}}else if(void 0!==a)if(Array.isArray(n))for(let i=0,r=d.length;r>i;i++){const r=d[i],p=n[r.materialIndex];for(let i=Math.max(r.start,u.start),n=Math.min(r.start+r.count,u.start+u.count);n>i;i+=3){o=rn(this,p,e,Gi,a,s,l,c,h,i,i+1,i+2),o&&(o.faceIndex=Math.floor(i/3),o.face.materialIndex=r.materialIndex,t.push(o))}}else{for(let i=Math.max(0,u.start),r=Math.min(a.count,u.start+u.count);r>i;i+=3){o=rn(this,n,e,Gi,a,s,l,c,h,i,i+1,i+2),o&&(o.faceIndex=Math.floor(i/3),t.push(o))}}}else i.isGeometry&&console.error("THREE.Mesh.raycast() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.")}}function rn(e,t,i,n,r,o,a,s,l,c,h,d){Vi.fromBufferAttribute(r,c),Yi.fromBufferAttribute(r,h),Hi.fromBufferAttribute(r,d);const u=e.morphTargetInfluences;if(t.morphTargets&&o&&u){zi.set(0,0,0),qi.set(0,0,0),Zi.set(0,0,0);for(let e=0,t=o.length;t>e;e++){const t=u[e],i=o[e];0!==t&&(ji.fromBufferAttribute(i,c),Wi.fromBufferAttribute(i,h),Ji.fromBufferAttribute(i,d),a?(zi.addScaledVector(ji,t),qi.addScaledVector(Wi,t),Zi.addScaledVector(Ji,t)):(zi.addScaledVector(ji.sub(Vi),t),qi.addScaledVector(Wi.sub(Yi),t),Zi.addScaledVector(Ji.sub(Hi),t)))}Vi.add(zi),Yi.add(qi),Hi.add(Zi)}e.isSkinnedMesh&&(e.boneTransform(c,Vi),e.boneTransform(h,Yi),e.boneTransform(d,Hi));const p=function(e,t,i,n,r,o,a,s){let l;if(l=1===t.side?n.intersectTriangle(a,o,r,!0,s):n.intersectTriangle(r,o,a,2!==t.side,s),null===l)return null;tn.copy(s),tn.applyMatrix4(e.matrixWorld);const c=i.ray.origin.distanceTo(tn);return i.near>c||c>i.far?null:{distance:c,point:tn.clone(),object:e}}(e,t,i,n,Vi,Yi,Hi,en);if(p){s&&(Xi.fromBufferAttribute(s,c),_i.fromBufferAttribute(s,h),$i.fromBufferAttribute(s,d),p.uv=ri.getUV(en,Vi,Yi,Hi,Xi,_i,$i,new ke)),l&&(Xi.fromBufferAttribute(l,c),_i.fromBufferAttribute(l,h),$i.fromBufferAttribute(l,d),p.uv2=ri.getUV(en,Vi,Yi,Hi,Xi,_i,$i,new ke));const e={a:c,b:h,c:d,normal:new Ke,materialIndex:0};ri.getNormal(Vi,Yi,Hi,e.normal),p.face=e}return p}nn.prototype.isMesh=!0;class on extends Ni{constructor(e=1,t=1,i=1,n=1,r=1,o=1){super(),this.type="BoxGeometry",this.parameters={width:e,height:t,depth:i,widthSegments:n,heightSegments:r,depthSegments:o};const a=this;n=Math.floor(n),r=Math.floor(r),o=Math.floor(o);const s=[],l=[],c=[],h=[];let d=0,u=0;function p(e,t,i,n,r,o,p,g,f,m,A){const y=o/f,v=p/m,C=o/2,I=p/2,x=g/2,w=f+1,M=m+1;let E=0,B=0;const S=new Ke;for(let o=0;M>o;o++){const a=o*v-I;for(let s=0;w>s;s++){S[e]=(s*y-C)*n,S[t]=a*r,S[i]=x,l.push(S.x,S.y,S.z),S[e]=0,S[t]=0,S[i]=g>0?1:-1,c.push(S.x,S.y,S.z),h.push(s/f),h.push(1-o/m),E+=1}}for(let e=0;m>e;e++)for(let t=0;f>t;t++){const i=d+t+w*(e+1),n=d+(t+1)+w*(e+1),r=d+(t+1)+w*e;s.push(d+t+w*e,i,r),s.push(i,n,r),B+=6}a.addGroup(u,B,A),u+=B,d+=E}p("z","y","x",-1,-1,i,t,e,o,r,0),p("z","y","x",1,-1,i,t,-e,o,r,1),p("x","z","y",1,1,e,i,t,n,o,2),p("x","z","y",1,-1,e,i,-t,n,o,3),p("x","y","z",1,-1,e,t,i,n,r,4),p("x","y","z",-1,-1,e,t,-i,n,r,5),this.setIndex(s),this.setAttribute("position",new Bi(l,3)),this.setAttribute("normal",new Bi(c,3)),this.setAttribute("uv",new Bi(h,2))}}function an(e){const t={};for(const i in e){t[i]={};for(const n in e[i]){const r=e[i][n];t[i][n]=r&&(r.isColor||r.isMatrix3||r.isMatrix4||r.isVector2||r.isVector3||r.isVector4||r.isTexture||r.isQuaternion)?r.clone():Array.isArray(r)?r.slice():r}}return t}function sn(e){const t={};for(let i=0;e.length>i;i++){const n=an(e[i]);for(const e in n)t[e]=n[e]}return t}const ln={clone:an,merge:sn};class cn extends ai{constructor(e){super(),this.type="ShaderMaterial",this.defines={},this.uniforms={},this.vertexShader="void main() {\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );\n}",this.fragmentShader="void main() {\n\tgl_FragColor = vec4( 1.0, 0.0, 0.0, 1.0 );\n}",this.linewidth=1,this.wireframe=!1,this.wireframeLinewidth=1,this.fog=!1,this.lights=!1,this.clipping=!1,this.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))}copy(e){return super.copy(e),this.fragmentShader=e.fragmentShader,this.vertexShader=e.vertexShader,this.uniforms=an(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.morphTargets=e.morphTargets,this.morphNormals=e.morphNormals,this.extensions=Object.assign({},e.extensions),this.glslVersion=e.glslVersion,this}toJSON(e){const t=super.toJSON(e);t.glslVersion=this.glslVersion,t.uniforms={};for(const i in this.uniforms){const n=this.uniforms[i].value;t.uniforms[i]=n&&n.isTexture?{type:"t",value:n.toJSON(e).uuid}:n&&n.isColor?{type:"c",value:n.getHex()}:n&&n.isVector2?{type:"v2",value:n.toArray()}:n&&n.isVector3?{type:"v3",value:n.toArray()}:n&&n.isVector4?{type:"v4",value:n.toArray()}:n&&n.isMatrix3?{type:"m3",value:n.toArray()}:n&&n.isMatrix4?{type:"m4",value:n.toArray()}:{value:n}}Object.keys(this.defines).length>0&&(t.defines=this.defines),t.vertexShader=this.vertexShader,t.fragmentShader=this.fragmentShader;const i={};for(const e in this.extensions)!0===this.extensions[e]&&(i[e]=!0);return Object.keys(i).length>0&&(t.extensions=i),t}}cn.prototype.isShaderMaterial=!0;class hn extends Yt{constructor(){super(),this.type="Camera",this.matrixWorldInverse=new yt,this.projectionMatrix=new yt,this.projectionMatrixInverse=new yt}copy(e,t){return super.copy(e,t),this.matrixWorldInverse.copy(e.matrixWorldInverse),this.projectionMatrix.copy(e.projectionMatrix),this.projectionMatrixInverse.copy(e.projectionMatrixInverse),this}getWorldDirection(e){void 0===e&&(console.warn("THREE.Camera: .getWorldDirection() target is now required"),e=new Ke),this.updateWorldMatrix(!0,!1);const t=this.matrixWorld.elements;return e.set(-t[8],-t[9],-t[10]).normalize()}updateMatrixWorld(e){super.updateMatrixWorld(e),this.matrixWorldInverse.copy(this.matrixWorld).invert()}updateWorldMatrix(e,t){super.updateWorldMatrix(e,t),this.matrixWorldInverse.copy(this.matrixWorld).invert()}clone(){return(new this.constructor).copy(this)}}hn.prototype.isCamera=!0;class dn extends hn{constructor(e=50,t=1,i=.1,n=2e3){super(),this.type="PerspectiveCamera",this.fov=e,this.zoom=1,this.near=i,this.far=n,this.focus=10,this.aspect=t,this.view=null,this.filmGauge=35,this.filmOffset=0,this.updateProjectionMatrix()}copy(e,t){return super.copy(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(e){const t=.5*this.getFilmHeight()/e;this.fov=2*Ce*Math.atan(t),this.updateProjectionMatrix()}getFocalLength(){const e=Math.tan(.5*ve*this.fov);return.5*this.getFilmHeight()/e}getEffectiveFOV(){return 2*Ce*Math.atan(Math.tan(.5*ve*this.fov)/this.zoom)}getFilmWidth(){return this.filmGauge*Math.min(this.aspect,1)}getFilmHeight(){return this.filmGauge/Math.max(this.aspect,1)}setViewOffset(e,t,i,n,r,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=i,this.view.offsetY=n,this.view.width=r,this.view.height=o,this.updateProjectionMatrix()}clearViewOffset(){null!==this.view&&(this.view.enabled=!1),this.updateProjectionMatrix()}updateProjectionMatrix(){const e=this.near;let t=e*Math.tan(.5*ve*this.fov)/this.zoom,i=2*t,n=this.aspect*i,r=-.5*n;const o=this.view;if(null!==this.view&&this.view.enabled){const e=o.fullWidth,a=o.fullHeight;r+=o.offsetX*n/e,t-=o.offsetY*i/a,n*=o.width/e,i*=o.height/a}const a=this.filmOffset;0!==a&&(r+=e*a/this.getFilmWidth()),this.projectionMatrix.makePerspective(r,r+n,t,t-i,e,this.far),this.projectionMatrixInverse.copy(this.projectionMatrix).invert()}toJSON(e){const t=super.toJSON(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}}dn.prototype.isPerspectiveCamera=!0;const un=90;class pn extends Yt{constructor(e,t,i){if(super(),this.type="CubeCamera",!0!==i.isWebGLCubeRenderTarget)return void console.error("THREE.CubeCamera: The constructor now expects an instance of WebGLCubeRenderTarget as third parameter.");this.renderTarget=i;const n=new dn(un,1,e,t);n.layers=this.layers,n.up.set(0,-1,0),n.lookAt(new Ke(1,0,0)),this.add(n);const r=new dn(un,1,e,t);r.layers=this.layers,r.up.set(0,-1,0),r.lookAt(new Ke(-1,0,0)),this.add(r);const o=new dn(un,1,e,t);o.layers=this.layers,o.up.set(0,0,1),o.lookAt(new Ke(0,1,0)),this.add(o);const a=new dn(un,1,e,t);a.layers=this.layers,a.up.set(0,0,-1),a.lookAt(new Ke(0,-1,0)),this.add(a);const s=new dn(un,1,e,t);s.layers=this.layers,s.up.set(0,-1,0),s.lookAt(new Ke(0,0,1)),this.add(s);const l=new dn(un,1,e,t);l.layers=this.layers,l.up.set(0,-1,0),l.lookAt(new Ke(0,0,-1)),this.add(l)}update(e,t){null===this.parent&&this.updateMatrixWorld();const i=this.renderTarget,[n,r,o,a,s,l]=this.children,c=e.xr.enabled,h=e.getRenderTarget();e.xr.enabled=!1;const d=i.texture.generateMipmaps;i.texture.generateMipmaps=!1,e.setRenderTarget(i,0),e.render(t,n),e.setRenderTarget(i,1),e.render(t,r),e.setRenderTarget(i,2),e.render(t,o),e.setRenderTarget(i,3),e.render(t,a),e.setRenderTarget(i,4),e.render(t,s),i.texture.generateMipmaps=d,e.setRenderTarget(i,5),e.render(t,l),e.setRenderTarget(h),e.xr.enabled=c}}class gn extends Fe{constructor(e,t,i,n,r,o,a,s,c,h){super(e=void 0!==e?e:[],t=void 0!==t?t:l,i,n,r,o,a=void 0!==a?a:k,s,c,h),this._needsFlipEnvMap=!0,this.flipY=!1}get images(){return this.image}set images(e){this.image=e}}gn.prototype.isCubeTexture=!0;class fn extends Oe{constructor(e,t,i){Number.isInteger(t)&&(console.warn("THREE.WebGLCubeRenderTarget: constructor signature is now WebGLCubeRenderTarget( size, options )"),t=i),super(e,e,t),this.texture=new gn(void 0,(t=t||{}).mapping,t.wrapS,t.wrapT,t.magFilter,t.minFilter,t.format,t.type,t.anisotropy,t.encoding),this.texture.generateMipmaps=void 0!==t.generateMipmaps&&t.generateMipmaps,this.texture.minFilter=void 0!==t.minFilter?t.minFilter:C,this.texture._needsFlipEnvMap=!1}fromEquirectangularTexture(e,t){this.texture.type=t.type,this.texture.format=D,this.texture.encoding=t.encoding,this.texture.generateMipmaps=t.generateMipmaps,this.texture.minFilter=t.minFilter,this.texture.magFilter=t.magFilter;const i={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 <begin_vertex>\n\t\t\t\t\t#include <project_vertex>\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 <common>\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"},n=new on(5,5,5),r=new cn({name:"CubemapFromEquirect",uniforms:an(i.uniforms),vertexShader:i.vertexShader,fragmentShader:i.fragmentShader,side:1,blending:0});r.uniforms.tEquirect.value=t;const o=new nn(n,r),a=t.minFilter;t.minFilter===x&&(t.minFilter=C);return new pn(1,10,this).update(e,o),t.minFilter=a,o.geometry.dispose(),o.material.dispose(),this}clear(e,t,i,n){const r=e.getRenderTarget();for(let r=0;6>r;r++)e.setRenderTarget(this,r),e.clear(t,i,n);e.setRenderTarget(r)}}fn.prototype.isWebGLCubeRenderTarget=!0;const mn=new ct,An=new Ke;class yn{constructor(e=new Jt,t=new Jt,i=new Jt,n=new Jt,r=new Jt,o=new Jt){this.planes=[e,t,i,n,r,o]}set(e,t,i,n,r,o){const a=this.planes;return a[0].copy(e),a[1].copy(t),a[2].copy(i),a[3].copy(n),a[4].copy(r),a[5].copy(o),this}copy(e){const t=this.planes;for(let i=0;6>i;i++)t[i].copy(e.planes[i]);return this}setFromProjectionMatrix(e){const t=this.planes,i=e.elements,n=i[0],r=i[1],o=i[2],a=i[3],s=i[4],l=i[5],c=i[6],h=i[7],d=i[8],u=i[9],p=i[10],g=i[11],f=i[12],m=i[13],A=i[14],y=i[15];return t[0].setComponents(a-n,h-s,g-d,y-f).normalize(),t[1].setComponents(a+n,h+s,g+d,y+f).normalize(),t[2].setComponents(a+r,h+l,g+u,y+m).normalize(),t[3].setComponents(a-r,h-l,g-u,y-m).normalize(),t[4].setComponents(a-o,h-c,g-p,y-A).normalize(),t[5].setComponents(a+o,h+c,g+p,y+A).normalize(),this}intersectsObject(e){const t=e.geometry;return null===t.boundingSphere&&t.computeBoundingSphere(),mn.copy(t.boundingSphere).applyMatrix4(e.matrixWorld),this.intersectsSphere(mn)}intersectsSprite(e){return mn.center.set(0,0,0),mn.radius=.7071067811865476,mn.applyMatrix4(e.matrixWorld),this.intersectsSphere(mn)}intersectsSphere(e){const t=this.planes,i=e.center,n=-e.radius;for(let e=0;6>e;e++){if(n>t[e].distanceToPoint(i))return!1}return!0}intersectsBox(e){const t=this.planes;for(let i=0;6>i;i++){const n=t[i];if(An.x=n.normal.x>0?e.max.x:e.min.x,An.y=n.normal.y>0?e.max.y:e.min.y,An.z=n.normal.z>0?e.max.z:e.min.z,0>n.distanceToPoint(An))return!1}return!0}containsPoint(e){const t=this.planes;for(let i=0;6>i;i++)if(0>t[i].distanceToPoint(e))return!1;return!0}clone(){return(new this.constructor).copy(this)}}function vn(){let e=null,t=!1,i=null,n=null;function r(t,o){i(t,o),n=e.requestAnimationFrame(r)}return{start:function(){!0!==t&&null!==i&&(n=e.requestAnimationFrame(r),t=!0)},stop:function(){e.cancelAnimationFrame(n),t=!1},setAnimationLoop:function(e){i=e},setContext:function(t){e=t}}}function Cn(e,t){const i=t.isWebGL2,n=new WeakMap;return{get:function(e){if(e)return e.isInterleavedBufferAttribute&&(e=e.data),n.get(e)},remove:function(t){t.isInterleavedBufferAttribute&&(t=t.data);const i=n.get(t);i&&(e.deleteBuffer(i.buffer),n.delete(t))},update:function(t,r){if(t.isGLBufferAttribute){const e=n.get(t);return void(e&&e.version>=t.version||n.set(t,{buffer:t.buffer,type:t.type,bytesPerElement:t.elementSize,version:t.version}))}t.isInterleavedBufferAttribute&&(t=t.data);const o=n.get(t);void 0===o?n.set(t,function(t,n){const r=t.array,o=t.usage,a=e.createBuffer();e.bindBuffer(n,a),e.bufferData(n,r,o),t.onUploadCallback();let s=5126;return r instanceof Float32Array?s=5126:r instanceof Float64Array?console.warn("THREE.WebGLAttributes: Unsupported data buffer format: Float64Array."):r instanceof Uint16Array?t.isFloat16BufferAttribute?i?s=5131:console.warn("THREE.WebGLAttributes: Usage of Float16BufferAttribute requires WebGL2."):s=5123:r instanceof Int16Array?s=5122:r instanceof Uint32Array?s=5125:r instanceof Int32Array?s=5124:r instanceof Int8Array?s=5120:(r instanceof Uint8Array||r instanceof Uint8ClampedArray)&&(s=5121),{buffer:a,type:s,bytesPerElement:r.BYTES_PER_ELEMENT,version:t.version}}(t,r)):t.version>o.version&&(!function(t,n,r){const o=n.array,a=n.updateRange;e.bindBuffer(r,t),-1===a.count?e.bufferSubData(r,0,o):(i?e.bufferSubData(r,a.offset*o.BYTES_PER_ELEMENT,o,a.offset,a.count):e.bufferSubData(r,a.offset*o.BYTES_PER_ELEMENT,o.subarray(a.offset,a.offset+a.count)),a.count=-1)}(o.buffer,t,r),o.version=t.version)}}}class In extends Ni{constructor(e=1,t=1,i=1,n=1){super(),this.type="PlaneGeometry",this.parameters={width:e,height:t,widthSegments:i,heightSegments:n};const r=e/2,o=t/2,a=Math.floor(i),s=Math.floor(n),l=a+1,c=s+1,h=e/a,d=t/s,u=[],p=[],g=[],f=[];for(let e=0;c>e;e++){const t=e*d-o;for(let i=0;l>i;i++){p.push(i*h-r,-t,0),g.push(0,0,1),f.push(i/a),f.push(1-e/s)}}for(let e=0;s>e;e++)for(let t=0;a>t;t++){const i=t+l*(e+1),n=t+1+l*(e+1),r=t+1+l*e;u.push(t+l*e,i,r),u.push(i,n,r)}this.setIndex(u),this.setAttribute("position",new Bi(p,3)),this.setAttribute("normal",new Bi(g,3)),this.setAttribute("uv",new Bi(f,2))}}const xn={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, float faceDirection ) {\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 ) * faceDirection;\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:"#if defined( USE_COLOR_ALPHA )\n\tdiffuseColor *= vColor;\n#elif defined( USE_COLOR )\n\tdiffuseColor.rgb *= vColor;\n#endif",color_pars_fragment:"#if defined( USE_COLOR_ALPHA )\n\tvarying vec4 vColor;\n#elif defined( USE_COLOR )\n\tvarying vec3 vColor;\n#endif",color_pars_vertex:"#if defined( USE_COLOR_ALPHA )\n\tvarying vec4 vColor;\n#elif defined( USE_COLOR ) || defined( USE_INSTANCING_COLOR )\n\tvarying vec3 vColor;\n#endif",color_vertex:"#if defined( USE_COLOR_ALPHA )\n\tvColor = vec4( 1.0 );\n#elif defined( USE_COLOR ) || defined( USE_INSTANCING_COLOR )\n\tvColor = vec3( 1.0 );\n#endif\n#ifdef USE_COLOR\n\tvColor *= color;\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 ) ), rawDiffuseColor, metalnessFactor );\n#else\n\tmaterial.specularColor = mix( vec3( DEFAULT_SPECULAR_COEFFICIENT ), rawDiffuseColor, 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( 0, 1, 0 ),\n\t\t\tvec3( t1.z, 0, t1.w )\n\t\t);\n\t\tvec3 fresnel = ( material.specularColor * t2.x + ( vec3( 1.0 ) - material.specularColor ) * t2.y );\n\t\treflectedLight.directSpecular += lightColor * fresnel * LTC_Evaluate( normal, viewDir, position, mInv, rectCoords );\n\t\treflectedLight.directDiffuse += lightColor * material.diffuseColor * LTC_Evaluate( normal, viewDir, position, mat3( 1.0 ), rectCoords );\n\t}\n#endif\nvoid RE_Direct_Physical( const in IncidentLight directLight, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) {\n\tfloat dotNL = saturate( dot( geometry.normal, directLight.direction ) );\n\tvec3 irradiance = dotNL * directLight.color;\n\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\tirradiance *= PI;\n\t#endif\n\t#ifdef CLEARCOAT\n\t\tfloat ccDotNL = saturate( dot( geometry.clearcoatNormal, directLight.direction ) );\n\t\tvec3 ccIrradiance = ccDotNL * directLight.color;\n\t\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\t\tccIrradiance *= PI;\n\t\t#endif\n\t\tfloat clearcoatDHR = material.clearcoat * clearcoatDHRApprox( material.clearcoatRoughness, ccDotNL );\n\t\treflectedLight.directSpecular += ccIrradiance * material.clearcoat * BRDF_Specular_GGX( directLight, geometry.viewDir, geometry.clearcoatNormal, vec3( DEFAULT_SPECULAR_COEFFICIENT ), material.clearcoatRoughness );\n\t#else\n\t\tfloat clearcoatDHR = 0.0;\n\t#endif\n\t#ifdef USE_SHEEN\n\t\treflectedLight.directSpecular += ( 1.0 - clearcoatDHR ) * irradiance * BRDF_Specular_Sheen(\n\t\t\tmaterial.specularRoughness,\n\t\t\tdirectLight.direction,\n\t\t\tgeometry,\n\t\t\tmaterial.sheenColor\n\t\t);\n\t#else\n\t\treflectedLight.directSpecular += ( 1.0 - clearcoatDHR ) * irradiance * BRDF_Specular_GGX( directLight, geometry.viewDir, geometry.normal, material.specularColor, material.specularRoughness);\n\t#endif\n\treflectedLight.directDiffuse += ( 1.0 - clearcoatDHR ) * irradiance * BRDF_Diffuse_Lambert( material.diffuseColor );\n}\nvoid RE_IndirectDiffuse_Physical( const in vec3 irradiance, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) {\n\treflectedLight.indirectDiffuse += irradiance * BRDF_Diffuse_Lambert( material.diffuseColor );\n}\nvoid RE_IndirectSpecular_Physical( const in vec3 radiance, const in vec3 irradiance, const in vec3 clearcoatRadiance, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight) {\n\t#ifdef CLEARCOAT\n\t\tfloat ccDotNV = saturate( dot( geometry.clearcoatNormal, geometry.viewDir ) );\n\t\treflectedLight.indirectSpecular += clearcoatRadiance * material.clearcoat * BRDF_Specular_GGX_Environment( geometry.viewDir, geometry.clearcoatNormal, vec3( DEFAULT_SPECULAR_COEFFICIENT ), material.clearcoatRoughness );\n\t\tfloat ccDotNL = ccDotNV;\n\t\tfloat clearcoatDHR = material.clearcoat * clearcoatDHRApprox( material.clearcoatRoughness, ccDotNL );\n\t#else\n\t\tfloat clearcoatDHR = 0.0;\n\t#endif\n\tfloat clearcoatInv = 1.0 - clearcoatDHR;\n\tvec3 singleScattering = vec3( 0.0 );\n\tvec3 multiScattering = vec3( 0.0 );\n\tvec3 cosineWeightedIrradiance = irradiance * RECIPROCAL_PI;\n\tBRDF_Specular_Multiscattering_Environment( geometry, material.specularColor, material.specularRoughness, singleScattering, multiScattering );\n\tvec3 diffuse = material.diffuseColor * ( 1.0 - ( singleScattering + multiScattering ) );\n\treflectedLight.indirectSpecular += clearcoatInv * radiance * singleScattering;\n\treflectedLight.indirectSpecular += multiScattering * cosineWeightedIrradiance;\n\treflectedLight.indirectDiffuse += diffuse * cosineWeightedIrradiance;\n}\n#define RE_Direct\t\t\t\tRE_Direct_Physical\n#define RE_Direct_RectArea\t\tRE_Direct_RectArea_Physical\n#define RE_IndirectDiffuse\t\tRE_IndirectDiffuse_Physical\n#define RE_IndirectSpecular\t\tRE_IndirectSpecular_Physical\nfloat computeSpecularOcclusion( const in float dotNV, const in float ambientOcclusion, const in float roughness ) {\n\treturn saturate( pow( dotNV + ambientOcclusion, exp2( - 16.0 * roughness - 1.0 ) ) - 1.0 + ambientOcclusion );\n}",lights_fragment_begin:"\nGeometricContext geometry;\ngeometry.position = - vViewPosition;\ngeometry.normal = normal;\ngeometry.viewDir = ( isOrthographic ) ? vec3( 0, 0, 1 ) : normalize( vViewPosition );\n#ifdef CLEARCOAT\n\tgeometry.clearcoatNormal = clearcoatNormal;\n#endif\nIncidentLight directLight;\n#if ( NUM_POINT_LIGHTS > 0 ) && defined( RE_Direct )\n\tPointLight pointLight;\n\t#if defined( USE_SHADOWMAP ) && NUM_POINT_LIGHT_SHADOWS > 0\n\tPointLightShadow pointLightShadow;\n\t#endif\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_POINT_LIGHTS; i ++ ) {\n\t\tpointLight = pointLights[ i ];\n\t\tgetPointDirectLightIrradiance( pointLight, geometry, directLight );\n\t\t#if defined( USE_SHADOWMAP ) && ( UNROLLED_LOOP_INDEX < NUM_POINT_LIGHT_SHADOWS )\n\t\tpointLightShadow = pointLightShadows[ i ];\n\t\tdirectLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getPointShadow( pointShadowMap[ i ], pointLightShadow.shadowMapSize, pointLightShadow.shadowBias, pointLightShadow.shadowRadius, vPointShadowCoord[ i ], pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraFar ) : 1.0;\n\t\t#endif\n\t\tRE_Direct( directLight, geometry, material, reflectedLight );\n\t}\n\t#pragma unroll_loop_end\n#endif\n#if ( NUM_SPOT_LIGHTS > 0 ) && defined( RE_Direct )\n\tSpotLight spotLight;\n\t#if defined( USE_SHADOWMAP ) && NUM_SPOT_LIGHT_SHADOWS > 0\n\tSpotLightShadow spotLightShadow;\n\t#endif\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_SPOT_LIGHTS; i ++ ) {\n\t\tspotLight = spotLights[ i ];\n\t\tgetSpotDirectLightIrradiance( spotLight, geometry, directLight );\n\t\t#if defined( USE_SHADOWMAP ) && ( UNROLLED_LOOP_INDEX < NUM_SPOT_LIGHT_SHADOWS )\n\t\tspotLightShadow = spotLightShadows[ i ];\n\t\tdirectLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getShadow( spotShadowMap[ i ], spotLightShadow.shadowMapSize, spotLightShadow.shadowBias, spotLightShadow.shadowRadius, vSpotShadowCoord[ i ] ) : 1.0;\n\t\t#endif\n\t\tRE_Direct( directLight, geometry, material, reflectedLight );\n\t}\n\t#pragma unroll_loop_end\n#endif\n#if ( NUM_DIR_LIGHTS > 0 ) && defined( RE_Direct )\n\tDirectionalLight directionalLight;\n\t#if defined( USE_SHADOWMAP ) && NUM_DIR_LIGHT_SHADOWS > 0\n\tDirectionalLightShadow directionalLightShadow;\n\t#endif\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) {\n\t\tdirectionalLight = directionalLights[ i ];\n\t\tgetDirectionalDirectLightIrradiance( directionalLight, geometry, directLight );\n\t\t#if defined( USE_SHADOWMAP ) && ( UNROLLED_LOOP_INDEX < NUM_DIR_LIGHT_SHADOWS )\n\t\tdirectionalLightShadow = directionalLightShadows[ i ];\n\t\tdirectLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getShadow( directionalShadowMap[ i ], directionalLightShadow.shadowMapSize, directionalLightShadow.shadowBias, directionalLightShadow.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0;\n\t\t#endif\n\t\tRE_Direct( directLight, geometry, material, reflectedLight );\n\t}\n\t#pragma unroll_loop_end\n#endif\n#if ( NUM_RECT_AREA_LIGHTS > 0 ) && defined( RE_Direct_RectArea )\n\tRectAreaLight rectAreaLight;\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_RECT_AREA_LIGHTS; i ++ ) {\n\t\trectAreaLight = rectAreaLights[ i ];\n\t\tRE_Direct_RectArea( rectAreaLight, geometry, material, reflectedLight );\n\t}\n\t#pragma unroll_loop_end\n#endif\n#if defined( RE_IndirectDiffuse )\n\tvec3 iblIrradiance = vec3( 0.0 );\n\tvec3 irradiance = getAmbientLightIrradiance( ambientLightColor );\n\tirradiance += getLightProbeIrradiance( lightProbe, geometry );\n\t#if ( NUM_HEMI_LIGHTS > 0 )\n\t\t#pragma unroll_loop_start\n\t\tfor ( int i = 0; i < NUM_HEMI_LIGHTS; i ++ ) {\n\t\t\tirradiance += getHemisphereLightIrradiance( hemisphereLights[ i ], geometry );\n\t\t}\n\t\t#pragma unroll_loop_end\n\t#endif\n#endif\n#if defined( RE_IndirectSpecular )\n\tvec3 radiance = vec3( 0.0 );\n\tvec3 clearcoatRadiance = vec3( 0.0 );\n#endif",lights_fragment_maps:"#if defined( RE_IndirectDiffuse )\n\t#ifdef USE_LIGHTMAP\n\t\tvec4 lightMapTexel= texture2D( lightMap, vUv2 );\n\t\tvec3 lightMapIrradiance = lightMapTexelToLinear( lightMapTexel ).rgb * lightMapIntensity;\n\t\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\t\tlightMapIrradiance *= PI;\n\t\t#endif\n\t\tirradiance += lightMapIrradiance;\n\t#endif\n\t#if defined( USE_ENVMAP ) && defined( STANDARD ) && defined( ENVMAP_TYPE_CUBE_UV )\n\t\tiblIrradiance += getLightProbeIndirectIrradiance( geometry, maxMipLevel );\n\t#endif\n#endif\n#if defined( USE_ENVMAP ) && defined( RE_IndirectSpecular )\n\tradiance += getLightProbeIndirectRadiance( geometry.viewDir, geometry.normal, material.specularRoughness, maxMipLevel );\n\t#ifdef CLEARCOAT\n\t\tclearcoatRadiance += getLightProbeIndirectRadiance( geometry.viewDir, geometry.clearcoatNormal, material.clearcoatRoughness, maxMipLevel );\n\t#endif\n#endif",lights_fragment_end:"#if defined( RE_IndirectDiffuse )\n\tRE_IndirectDiffuse( irradiance, geometry, material, reflectedLight );\n#endif\n#if defined( RE_IndirectSpecular )\n\tRE_IndirectSpecular( radiance, iblIrradiance, clearcoatRadiance, geometry, material, reflectedLight );\n#endif",logdepthbuf_fragment:"#if defined( USE_LOGDEPTHBUF ) && defined( USE_LOGDEPTHBUF_EXT )\n\tgl_FragDepthEXT = vIsPerspective == 0.0 ? gl_FragCoord.z : log2( vFragDepth ) * logDepthBufFC * 0.5;\n#endif",logdepthbuf_pars_fragment:"#if defined( USE_LOGDEPTHBUF ) && defined( USE_LOGDEPTHBUF_EXT )\n\tuniform float logDepthBufFC;\n\tvarying float vFragDepth;\n\tvarying float vIsPerspective;\n#endif",logdepthbuf_pars_vertex:"#ifdef USE_LOGDEPTHBUF\n\t#ifdef USE_LOGDEPTHBUF_EXT\n\t\tvarying float vFragDepth;\n\t\tvarying float vIsPerspective;\n\t#else\n\t\tuniform float logDepthBufFC;\n\t#endif\n#endif",logdepthbuf_vertex:"#ifdef USE_LOGDEPTHBUF\n\t#ifdef USE_LOGDEPTHBUF_EXT\n\t\tvFragDepth = 1.0 + gl_Position.w;\n\t\tvIsPerspective = float( isPerspectiveMatrix( projectionMatrix ) );\n\t#else\n\t\tif ( isPerspectiveMatrix( projectionMatrix ) ) {\n\t\t\tgl_Position.z = log2( max( EPSILON, gl_Position.w + 1.0 ) ) * logDepthBufFC - 1.0;\n\t\t\tgl_Position.z *= gl_Position.w;\n\t\t}\n\t#endif\n#endif",map_fragment:"#ifdef USE_MAP\n\tvec4 texelColor = texture2D( map, vUv );\n\ttexelColor = mapTexelToLinear( texelColor );\n\tdiffuseColor *= texelColor;\n#endif",map_pars_fragment:"#ifdef USE_MAP\n\tuniform sampler2D map;\n#endif",map_particle_fragment:"#if defined( USE_MAP ) || defined( USE_ALPHAMAP )\n\tvec2 uv = ( uvTransform * vec3( gl_PointCoord.x, 1.0 - gl_PointCoord.y, 1 ) ).xy;\n#endif\n#ifdef USE_MAP\n\tvec4 mapTexel = texture2D( map, uv );\n\tdiffuseColor *= mapTexelToLinear( mapTexel );\n#endif\n#ifdef USE_ALPHAMAP\n\tdiffuseColor.a *= texture2D( alphaMap, uv ).g;\n#endif",map_particle_pars_fragment:"#if defined( USE_MAP ) || defined( USE_ALPHAMAP )\n\tuniform mat3 uvTransform;\n#endif\n#ifdef USE_MAP\n\tuniform sampler2D map;\n#endif\n#ifdef USE_ALPHAMAP\n\tuniform sampler2D alphaMap;\n#endif",metalnessmap_fragment:"float metalnessFactor = metalness;\n#ifdef USE_METALNESSMAP\n\tvec4 texelMetalness = texture2D( metalnessMap, vUv );\n\tmetalnessFactor *= texelMetalness.b;\n#endif",metalnessmap_pars_fragment:"#ifdef USE_METALNESSMAP\n\tuniform sampler2D metalnessMap;\n#endif",morphnormal_vertex:"#ifdef USE_MORPHNORMALS\n\tobjectNormal *= morphTargetBaseInfluence;\n\tobjectNormal += morphNormal0 * morphTargetInfluences[ 0 ];\n\tobjectNormal += morphNormal1 * morphTargetInfluences[ 1 ];\n\tobjectNormal += morphNormal2 * morphTargetInfluences[ 2 ];\n\tobjectNormal += morphNormal3 * morphTargetInfluences[ 3 ];\n#endif",morphtarget_pars_vertex:"#ifdef USE_MORPHTARGETS\n\tuniform float morphTargetBaseInfluence;\n\t#ifndef USE_MORPHNORMALS\n\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:"float faceDirection = gl_FrontFacing ? 1.0 : - 1.0;\n#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 * faceDirection;\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 * faceDirection;\n\t\t\tbitangent = bitangent * faceDirection;\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 * faceDirection;\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, faceDirection );\n\t#endif\n#elif defined( USE_BUMPMAP )\n\tnormal = perturbNormalArb( -vViewPosition, normal, dHdxy_fwd(), faceDirection );\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, float faceDirection ) {\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\tvec3 N = surf_norm;\n\t\tvec3 q1perp = cross( q1, N );\n\t\tvec3 q0perp = cross( N, q0 );\n\t\tvec3 T = q1perp * st0.x + q0perp * st1.x;\n\t\tvec3 B = q1perp * st0.y + q0perp * st1.y;\n\t\tfloat det = max( dot( T, T ), dot( B, B ) );\n\t\tfloat scale = ( det == 0.0 ) ? 0.0 : faceDirection * inversesqrt( det );\n\t\treturn normalize( T * ( mapN.x * scale ) + B * ( mapN.y * scale ) + N * mapN.z );\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, faceDirection );\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 texture2DCompare( shadowMap, uv + vec2( 2.0 * dx, -dy ), shadowCoord.z ),\n\t\t\t\t\t\t f.x ),\n\t\t\t\t\t mix( texture2DCompare( shadowMap, uv + vec2( -dx, 2.0 * dy ), shadowCoord.z ), \n\t\t\t\t\t\t texture2DCompare( shadowMap, uv + vec2( 2.0 * dx, 2.0 * dy ), shadowCoord.z ),\n\t\t\t\t\t\t f.x ),\n\t\t\t\t\t f.y )\n\t\t\t) * ( 1.0 / 9.0 );\n\t\t#elif defined( SHADOWMAP_TYPE_VSM )\n\t\t\tshadow = VSMShadow( shadowMap, shadowCoord.xy, shadowCoord.z );\n\t\t#else\n\t\t\tshadow = texture2DCompare( shadowMap, shadowCoord.xy, shadowCoord.z );\n\t\t#endif\n\t\t}\n\t\treturn shadow;\n\t}\n\tvec2 cubeToUV( vec3 v, float texelSizeY ) {\n\t\tvec3 absV = abs( v );\n\t\tfloat scaleToCube = 1.0 / max( absV.x, max( absV.y, absV.z ) );\n\t\tabsV *= scaleToCube;\n\t\tv *= scaleToCube * ( 1.0 - 2.0 * texelSizeY );\n\t\tvec2 planar = v.xy;\n\t\tfloat almostATexel = 1.5 * texelSizeY;\n\t\tfloat almostOne = 1.0 - almostATexel;\n\t\tif ( absV.z >= almostOne ) {\n\t\t\tif ( v.z > 0.0 )\n\t\t\t\tplanar.x = 4.0 - v.x;\n\t\t} else if ( absV.x >= almostOne ) {\n\t\t\tfloat signX = sign( v.x );\n\t\t\tplanar.x = v.z * signX + 2.0 * signX;\n\t\t} else if ( absV.y >= almostOne ) {\n\t\t\tfloat signY = sign( v.y );\n\t\t\tplanar.x = v.x + 2.0 * signY + 2.0;\n\t\t\tplanar.y = v.z * signY - 2.0;\n\t\t}\n\t\treturn vec2( 0.125, 0.25 ) * planar + vec2( 0.375, 0.75 );\n\t}\n\tfloat getPointShadow( sampler2D shadowMap, vec2 shadowMapSize, float shadowBias, float shadowRadius, vec4 shadowCoord, float shadowCameraNear, float shadowCameraFar ) {\n\t\tvec2 texelSize = vec2( 1.0 ) / ( shadowMapSize * vec2( 4.0, 2.0 ) );\n\t\tvec3 lightToPosition = shadowCoord.xyz;\n\t\tfloat dp = ( length( lightToPosition ) - shadowCameraNear ) / ( shadowCameraFar - shadowCameraNear );\t\tdp += shadowBias;\n\t\tvec3 bd3D = normalize( lightToPosition );\n\t\t#if defined( SHADOWMAP_TYPE_PCF ) || defined( SHADOWMAP_TYPE_PCF_SOFT ) || defined( SHADOWMAP_TYPE_VSM )\n\t\t\tvec2 offset = vec2( - 1, 1 ) * shadowRadius * texelSize.y;\n\t\t\treturn (\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xyy, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yyy, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xyx, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yyx, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xxy, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yxy, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xxx, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yxx, texelSize.y ), dp )\n\t\t\t) * ( 1.0 / 9.0 );\n\t\t#else\n\t\t\treturn texture2DCompare( shadowMap, cubeToUV( bd3D, texelSize.y ), dp );\n\t\t#endif\n\t}\n#endif",shadowmap_pars_vertex:"#ifdef USE_SHADOWMAP\n\t#if NUM_DIR_LIGHT_SHADOWS > 0\n\t\tuniform mat4 directionalShadowMatrix[ NUM_DIR_LIGHT_SHADOWS ];\n\t\tvarying vec4 vDirectionalShadowCoord[ NUM_DIR_LIGHT_SHADOWS ];\n\t\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( 1.60475, -0.10208, -0.00327 ),\t\tvec3( -0.53108, 1.10813, -0.07276 ),\n\t\tvec3( -0.07367, -0.00605, 1.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; }",transmission_fragment:"#ifdef USE_TRANSMISSION\n\t#ifdef USE_TRANSMISSIONMAP\n\t\ttotalTransmission *= texture2D( transmissionMap, vUv ).r;\n\t#endif\n\t#ifdef USE_THICKNESSNMAP\n\t\tthicknessFactor *= texture2D( thicknessMap, vUv ).g;\n\t#endif\n\tvec3 pos = vWorldPosition.xyz / vWorldPosition.w;\n\tvec3 v = normalize( cameraPosition - pos );\n\tvec3 viewDir = ( isOrthographic ) ? vec3( 0, 0, 1 ) : normalize( vViewPosition );\n\tfloat ior = ( 1.0 + 0.4 * reflectivity ) / ( 1.0 - 0.4 * reflectivity );\n\tvec3 f0 = vec3( pow( ior - 1.0, 2.0 ) / pow( ior + 1.0, 2.0 ) );\n\tvec3 f90 = vec3( 1.0 );\n\tvec3 f_transmission = totalTransmission * getIBLVolumeRefraction(\n\t\tnormal, v, viewDir, roughnessFactor, diffuseColor.rgb, f0, f90,\n\t\tpos, modelMatrix, viewMatrix, projectionMatrix, ior, thicknessFactor,\n\t\tattenuationColor, attenuationDistance);\n\tdiffuseColor.rgb = mix( diffuseColor.rgb, f_transmission, totalTransmission );\n#endif",transmission_pars_fragment:"#ifdef USE_TRANSMISSION\n\t#ifdef USE_TRANSMISSIONMAP\n\t\tuniform sampler2D transmissionMap;\n\t#endif\n\t#ifdef USE_THICKNESSMAP\n\t\tuniform sampler2D thicknessMap;\n\t#endif\n\tuniform vec2 transmissionSamplerSize;\n\tuniform sampler2D transmissionSamplerMap;\n\tuniform mat4 modelMatrix;\n\tuniform mat4 projectionMatrix;\n\tvarying vec4 vWorldPosition;\n\tvec3 getVolumeTransmissionRay(vec3 n, vec3 v, float thickness, float ior, mat4 modelMatrix) {\n\t\tvec3 refractionVector = refract(-v, normalize(n), 1.0 / ior);\n\t\tvec3 modelScale;\n\t\tmodelScale.x = length(vec3(modelMatrix[0].xyz));\n\t\tmodelScale.y = length(vec3(modelMatrix[1].xyz));\n\t\tmodelScale.z = length(vec3(modelMatrix[2].xyz));\n\t\treturn normalize(refractionVector) * thickness * modelScale;\n\t}\n\tfloat applyIorToRoughness(float roughness, float ior) {\n\t\treturn roughness * clamp(ior * 2.0 - 2.0, 0.0, 1.0);\n\t}\n\tvec3 getTransmissionSample(vec2 fragCoord, float roughness, float ior) {\n\t\tfloat framebufferLod = log2(transmissionSamplerSize.x) * applyIorToRoughness(roughness, ior);\n\t\treturn texture2DLodEXT(transmissionSamplerMap, fragCoord.xy, framebufferLod).rgb;\n\t}\n\tvec3 applyVolumeAttenuation(vec3 radiance, float transmissionDistance, vec3 attenuationColor, float attenuationDistance) {\n\t\tif (attenuationDistance == 0.0) {\n\t\t\treturn radiance;\n\t\t} else {\n\t\t\tvec3 attenuationCoefficient = -log(attenuationColor) / attenuationDistance;\n\t\t\tvec3 transmittance = exp(-attenuationCoefficient * transmissionDistance);\t\t\treturn transmittance * radiance;\n\t\t}\n\t}\n\tvec3 getIBLVolumeRefraction(vec3 n, vec3 v, vec3 viewDir, float perceptualRoughness, vec3 baseColor, vec3 f0, vec3 f90,\n\t\tvec3 position, mat4 modelMatrix, mat4 viewMatrix, mat4 projMatrix, float ior, float thickness, vec3 attenuationColor, float attenuationDistance) {\n\t\tvec3 transmissionRay = getVolumeTransmissionRay(n, v, thickness, ior, modelMatrix);\n\t\tvec3 refractedRayExit = position + transmissionRay;\n\t\tvec4 ndcPos = projMatrix * viewMatrix * vec4(refractedRayExit, 1.0);\n\t\tvec2 refractionCoords = ndcPos.xy / ndcPos.w;\n\t\trefractionCoords += 1.0;\n\t\trefractionCoords /= 2.0;\n\t\tvec3 transmittedLight = getTransmissionSample(refractionCoords, perceptualRoughness, ior);\n\t\tvec3 attenuatedColor = applyVolumeAttenuation(transmittedLight, length(transmissionRay), attenuationColor, attenuationDistance);\n\t\tfloat NdotV = saturate(dot(n, viewDir));\n\t\tvec2 brdf = integrateSpecularBRDF(NdotV, perceptualRoughness);\n\t\tvec3 specularColor = f0 * brdf.x + f90 * brdf.y;\n\t\treturn (1.0 - specularColor) * attenuatedColor * baseColor;\n\t}\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 ) || defined ( USE_TRANSMISSION )\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 <tonemapping_fragment>\n\t#include <encodings_fragment>\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 <envmap_common_pars_fragment>\nuniform float opacity;\nvarying vec3 vWorldDirection;\n#include <cube_uv_reflection_fragment>\nvoid main() {\n\tvec3 vReflect = vWorldDirection;\n\t#include <envmap_fragment>\n\tgl_FragColor = envColor;\n\tgl_FragColor.a *= opacity;\n\t#include <tonemapping_fragment>\n\t#include <encodings_fragment>\n}",cube_vert:"varying vec3 vWorldDirection;\n#include <common>\nvoid main() {\n\tvWorldDirection = transformDirection( position, modelMatrix );\n\t#include <begin_vertex>\n\t#include <project_vertex>\n\tgl_Position.z = gl_Position.w;\n}",depth_frag:"#if DEPTH_PACKING == 3200\n\tuniform float opacity;\n#endif\n#include <common>\n#include <packing>\n#include <uv_pars_fragment>\n#include <map_pars_fragment>\n#include <alphamap_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvarying vec2 vHighPrecisionZW;\nvoid main() {\n\t#include <clipping_planes_fragment>\n\tvec4 diffuseColor = vec4( 1.0 );\n\t#if DEPTH_PACKING == 3200\n\t\tdiffuseColor.a = opacity;\n\t#endif\n\t#include <map_fragment>\n\t#include <alphamap_fragment>\n\t#include <alphatest_fragment>\n\t#include <logdepthbuf_fragment>\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 <common>\n#include <uv_pars_vertex>\n#include <displacementmap_pars_vertex>\n#include <morphtarget_pars_vertex>\n#include <skinning_pars_vertex>\n#include <logdepthbuf_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvarying vec2 vHighPrecisionZW;\nvoid main() {\n\t#include <uv_vertex>\n\t#include <skinbase_vertex>\n\t#ifdef USE_DISPLACEMENTMAP\n\t\t#include <beginnormal_vertex>\n\t\t#include <morphnormal_vertex>\n\t\t#include <skinnormal_vertex>\n\t#endif\n\t#include <begin_vertex>\n\t#include <morphtarget_vertex>\n\t#include <skinning_vertex>\n\t#include <displacementmap_vertex>\n\t#include <project_vertex>\n\t#include <logdepthbuf_vertex>\n\t#include <clipping_planes_vertex>\n\tvHighPrecisionZW = gl_Position.zw;\n}",distanceRGBA_frag:"#define DISTANCE\nuniform vec3 referencePosition;\nuniform float nearDistance;\nuniform float farDistance;\nvarying vec3 vWorldPosition;\n#include <common>\n#include <packing>\n#include <uv_pars_fragment>\n#include <map_pars_fragment>\n#include <alphamap_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main () {\n\t#include <clipping_planes_fragment>\n\tvec4 diffuseColor = vec4( 1.0 );\n\t#include <map_fragment>\n\t#include <alphamap_fragment>\n\t#include <alphatest_fragment>\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 <common>\n#include <uv_pars_vertex>\n#include <displacementmap_pars_vertex>\n#include <morphtarget_pars_vertex>\n#include <skinning_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\t#include <uv_vertex>\n\t#include <skinbase_vertex>\n\t#ifdef USE_DISPLACEMENTMAP\n\t\t#include <beginnormal_vertex>\n\t\t#include <morphnormal_vertex>\n\t\t#include <skinnormal_vertex>\n\t#endif\n\t#include <begin_vertex>\n\t#include <morphtarget_vertex>\n\t#include <skinning_vertex>\n\t#include <displacementmap_vertex>\n\t#include <project_vertex>\n\t#include <worldpos_vertex>\n\t#include <clipping_planes_vertex>\n\tvWorldPosition = worldPosition.xyz;\n}",equirect_frag:"uniform sampler2D tEquirect;\nvarying vec3 vWorldDirection;\n#include <common>\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 <tonemapping_fragment>\n\t#include <encodings_fragment>\n}",equirect_vert:"varying vec3 vWorldDirection;\n#include <common>\nvoid main() {\n\tvWorldDirection = transformDirection( position, modelMatrix );\n\t#include <begin_vertex>\n\t#include <project_vertex>\n}",linedashed_frag:"uniform vec3 diffuse;\nuniform float opacity;\nuniform float dashSize;\nuniform float totalSize;\nvarying float vLineDistance;\n#include <common>\n#include <color_pars_fragment>\n#include <fog_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main() {\n\t#include <clipping_planes_fragment>\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 <logdepthbuf_fragment>\n\t#include <color_fragment>\n\toutgoingLight = diffuseColor.rgb;\n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include <tonemapping_fragment>\n\t#include <encodings_fragment>\n\t#include <fog_fragment>\n\t#include <premultiplied_alpha_fragment>\n}",linedashed_vert:"uniform float scale;\nattribute float lineDistance;\nvarying float vLineDistance;\n#include <common>\n#include <color_pars_vertex>\n#include <fog_pars_vertex>\n#include <morphtarget_pars_vertex>\n#include <logdepthbuf_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\tvLineDistance = scale * lineDistance;\n\t#include <color_vertex>\n\t#include <begin_vertex>\n\t#include <morphtarget_vertex>\n\t#include <project_vertex>\n\t#include <logdepthbuf_vertex>\n\t#include <clipping_planes_vertex>\n\t#include <fog_vertex>\n}",meshbasic_frag:"uniform vec3 diffuse;\nuniform float opacity;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\n#include <common>\n#include <dithering_pars_fragment>\n#include <color_pars_fragment>\n#include <uv_pars_fragment>\n#include <uv2_pars_fragment>\n#include <map_pars_fragment>\n#include <alphamap_pars_fragment>\n#include <aomap_pars_fragment>\n#include <lightmap_pars_fragment>\n#include <envmap_common_pars_fragment>\n#include <envmap_pars_fragment>\n#include <cube_uv_reflection_fragment>\n#include <fog_pars_fragment>\n#include <specularmap_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main() {\n\t#include <clipping_planes_fragment>\n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\t#include <logdepthbuf_fragment>\n\t#include <map_fragment>\n\t#include <color_fragment>\n\t#include <alphamap_fragment>\n\t#include <alphatest_fragment>\n\t#include <specularmap_fragment>\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 <aomap_fragment>\n\treflectedLight.indirectDiffuse *= diffuseColor.rgb;\n\tvec3 outgoingLight = reflectedLight.indirectDiffuse;\n\t#include <envmap_fragment>\n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include <tonemapping_fragment>\n\t#include <encodings_fragment>\n\t#include <fog_fragment>\n\t#include <premultiplied_alpha_fragment>\n\t#include <dithering_fragment>\n}",meshbasic_vert:"#include <common>\n#include <uv_pars_vertex>\n#include <uv2_pars_vertex>\n#include <envmap_pars_vertex>\n#include <color_pars_vertex>\n#include <fog_pars_vertex>\n#include <morphtarget_pars_vertex>\n#include <skinning_pars_vertex>\n#include <logdepthbuf_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\t#include <uv_vertex>\n\t#include <uv2_vertex>\n\t#include <color_vertex>\n\t#include <skinbase_vertex>\n\t#ifdef USE_ENVMAP\n\t#include <beginnormal_vertex>\n\t#include <morphnormal_vertex>\n\t#include <skinnormal_vertex>\n\t#include <defaultnormal_vertex>\n\t#endif\n\t#include <begin_vertex>\n\t#include <morphtarget_vertex>\n\t#include <skinning_vertex>\n\t#include <project_vertex>\n\t#include <logdepthbuf_vertex>\n\t#include <worldpos_vertex>\n\t#include <clipping_planes_vertex>\n\t#include <envmap_vertex>\n\t#include <fog_vertex>\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 <common>\n#include <packing>\n#include <dithering_pars_fragment>\n#include <color_pars_fragment>\n#include <uv_pars_fragment>\n#include <uv2_pars_fragment>\n#include <map_pars_fragment>\n#include <alphamap_pars_fragment>\n#include <aomap_pars_fragment>\n#include <lightmap_pars_fragment>\n#include <emissivemap_pars_fragment>\n#include <envmap_common_pars_fragment>\n#include <envmap_pars_fragment>\n#include <cube_uv_reflection_fragment>\n#include <bsdfs>\n#include <lights_pars_begin>\n#include <fog_pars_fragment>\n#include <shadowmap_pars_fragment>\n#include <shadowmask_pars_fragment>\n#include <specularmap_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main() {\n\t#include <clipping_planes_fragment>\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 <logdepthbuf_fragment>\n\t#include <map_fragment>\n\t#include <color_fragment>\n\t#include <alphamap_fragment>\n\t#include <alphatest_fragment>\n\t#include <specularmap_fragment>\n\t#include <emissivemap_fragment>\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 <lightmap_fragment>\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 <aomap_fragment>\n\tvec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + totalEmissiveRadiance;\n\t#include <envmap_fragment>\n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include <tonemapping_fragment>\n\t#include <encodings_fragment>\n\t#include <fog_fragment>\n\t#include <premultiplied_alpha_fragment>\n\t#include <dithering_fragment>\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 <common>\n#include <uv_pars_vertex>\n#include <uv2_pars_vertex>\n#include <envmap_pars_vertex>\n#include <bsdfs>\n#include <lights_pars_begin>\n#include <color_pars_vertex>\n#include <fog_pars_vertex>\n#include <morphtarget_pars_vertex>\n#include <skinning_pars_vertex>\n#include <shadowmap_pars_vertex>\n#include <logdepthbuf_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\t#include <uv_vertex>\n\t#include <uv2_vertex>\n\t#include <color_vertex>\n\t#include <beginnormal_vertex>\n\t#include <morphnormal_vertex>\n\t#include <skinbase_vertex>\n\t#include <skinnormal_vertex>\n\t#include <defaultnormal_vertex>\n\t#include <begin_vertex>\n\t#include <morphtarget_vertex>\n\t#include <skinning_vertex>\n\t#include <project_vertex>\n\t#include <logdepthbuf_vertex>\n\t#include <clipping_planes_vertex>\n\t#include <worldpos_vertex>\n\t#include <envmap_vertex>\n\t#include <lights_lambert_vertex>\n\t#include <shadowmap_vertex>\n\t#include <fog_vertex>\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 <common>\n#include <dithering_pars_fragment>\n#include <color_pars_fragment>\n#include <uv_pars_fragment>\n#include <map_pars_fragment>\n#include <alphamap_pars_fragment>\n#include <fog_pars_fragment>\n#include <bumpmap_pars_fragment>\n#include <normalmap_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main() {\n\t#include <clipping_planes_fragment>\n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\t#include <logdepthbuf_fragment>\n\t#include <map_fragment>\n\t#include <color_fragment>\n\t#include <alphamap_fragment>\n\t#include <alphatest_fragment>\n\t#include <normal_fragment_begin>\n\t#include <normal_fragment_maps>\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 <tonemapping_fragment>\n\t#include <encodings_fragment>\n\t#include <fog_fragment>\n\t#include <premultiplied_alpha_fragment>\n\t#include <dithering_fragment>\n}",meshmatcap_vert:"#define MATCAP\nvarying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\n#include <common>\n#include <uv_pars_vertex>\n#include <color_pars_vertex>\n#include <displacementmap_pars_vertex>\n#include <fog_pars_vertex>\n#include <morphtarget_pars_vertex>\n#include <skinning_pars_vertex>\n#include <logdepthbuf_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\t#include <uv_vertex>\n\t#include <color_vertex>\n\t#include <beginnormal_vertex>\n\t#include <morphnormal_vertex>\n\t#include <skinbase_vertex>\n\t#include <skinnormal_vertex>\n\t#include <defaultnormal_vertex>\n\t#ifndef FLAT_SHADED\n\t\tvNormal = normalize( transformedNormal );\n\t#endif\n\t#include <begin_vertex>\n\t#include <morphtarget_vertex>\n\t#include <skinning_vertex>\n\t#include <displacementmap_vertex>\n\t#include <project_vertex>\n\t#include <logdepthbuf_vertex>\n\t#include <clipping_planes_vertex>\n\t#include <fog_vertex>\n\tvViewPosition = - mvPosition.xyz;\n}",meshtoon_frag:"#define TOON\nuniform vec3 diffuse;\nuniform vec3 emissive;\nuniform float opacity;\n#include <common>\n#include <packing>\n#include <dithering_pars_fragment>\n#include <color_pars_fragment>\n#include <uv_pars_fragment>\n#include <uv2_pars_fragment>\n#include <map_pars_fragment>\n#include <alphamap_pars_fragment>\n#include <aomap_pars_fragment>\n#include <lightmap_pars_fragment>\n#include <emissivemap_pars_fragment>\n#include <gradientmap_pars_fragment>\n#include <fog_pars_fragment>\n#include <bsdfs>\n#include <lights_pars_begin>\n#include <lights_toon_pars_fragment>\n#include <shadowmap_pars_fragment>\n#include <bumpmap_pars_fragment>\n#include <normalmap_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main() {\n\t#include <clipping_planes_fragment>\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 <logdepthbuf_fragment>\n\t#include <map_fragment>\n\t#include <color_fragment>\n\t#include <alphamap_fragment>\n\t#include <alphatest_fragment>\n\t#include <normal_fragment_begin>\n\t#include <normal_fragment_maps>\n\t#include <emissivemap_fragment>\n\t#include <lights_toon_fragment>\n\t#include <lights_fragment_begin>\n\t#include <lights_fragment_maps>\n\t#include <lights_fragment_end>\n\t#include <aomap_fragment>\n\tvec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + totalEmissiveRadiance;\n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include <tonemapping_fragment>\n\t#include <encodings_fragment>\n\t#include <fog_fragment>\n\t#include <premultiplied_alpha_fragment>\n\t#include <dithering_fragment>\n}",meshtoon_vert:"#define TOON\nvarying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\n#include <common>\n#include <uv_pars_vertex>\n#include <uv2_pars_vertex>\n#include <displacementmap_pars_vertex>\n#include <color_pars_vertex>\n#include <fog_pars_vertex>\n#include <morphtarget_pars_vertex>\n#include <skinning_pars_vertex>\n#include <shadowmap_pars_vertex>\n#include <logdepthbuf_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\t#include <uv_vertex>\n\t#include <uv2_vertex>\n\t#include <color_vertex>\n\t#include <beginnormal_vertex>\n\t#include <morphnormal_vertex>\n\t#include <skinbase_vertex>\n\t#include <skinnormal_vertex>\n\t#include <defaultnormal_vertex>\n#ifndef FLAT_SHADED\n\tvNormal = normalize( transformedNormal );\n#endif\n\t#include <begin_vertex>\n\t#include <morphtarget_vertex>\n\t#include <skinning_vertex>\n\t#include <displacementmap_vertex>\n\t#include <project_vertex>\n\t#include <logdepthbuf_vertex>\n\t#include <clipping_planes_vertex>\n\tvViewPosition = - mvPosition.xyz;\n\t#include <worldpos_vertex>\n\t#include <shadowmap_vertex>\n\t#include <fog_vertex>\n}",meshphong_frag:"#define PHONG\nuniform vec3 diffuse;\nuniform vec3 emissive;\nuniform vec3 specular;\nuniform float shininess;\nuniform float opacity;\n#include <common>\n#include <packing>\n#include <dithering_pars_fragment>\n#include <color_pars_fragment>\n#include <uv_pars_fragment>\n#include <uv2_pars_fragment>\n#include <map_pars_fragment>\n#include <alphamap_pars_fragment>\n#include <aomap_pars_fragment>\n#include <lightmap_pars_fragment>\n#include <emissivemap_pars_fragment>\n#include <envmap_common_pars_fragment>\n#include <envmap_pars_fragment>\n#include <cube_uv_reflection_fragment>\n#include <fog_pars_fragment>\n#include <bsdfs>\n#include <lights_pars_begin>\n#include <lights_phong_pars_fragment>\n#include <shadowmap_pars_fragment>\n#include <bumpmap_pars_fragment>\n#include <normalmap_pars_fragment>\n#include <specularmap_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main() {\n\t#include <clipping_planes_fragment>\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 <logdepthbuf_fragment>\n\t#include <map_fragment>\n\t#include <color_fragment>\n\t#include <alphamap_fragment>\n\t#include <alphatest_fragment>\n\t#include <specularmap_fragment>\n\t#include <normal_fragment_begin>\n\t#include <normal_fragment_maps>\n\t#include <emissivemap_fragment>\n\t#include <lights_phong_fragment>\n\t#include <lights_fragment_begin>\n\t#include <lights_fragment_maps>\n\t#include <lights_fragment_end>\n\t#include <aomap_fragment>\n\tvec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + reflectedLight.directSpecular + reflectedLight.indirectSpecular + totalEmissiveRadiance;\n\t#include <envmap_fragment>\n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include <tonemapping_fragment>\n\t#include <encodings_fragment>\n\t#include <fog_fragment>\n\t#include <premultiplied_alpha_fragment>\n\t#include <dithering_fragment>\n}",meshphong_vert:"#define PHONG\nvarying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\n#include <common>\n#include <uv_pars_vertex>\n#include <uv2_pars_vertex>\n#include <displacementmap_pars_vertex>\n#include <envmap_pars_vertex>\n#include <color_pars_vertex>\n#include <fog_pars_vertex>\n#include <morphtarget_pars_vertex>\n#include <skinning_pars_vertex>\n#include <shadowmap_pars_vertex>\n#include <logdepthbuf_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\t#include <uv_vertex>\n\t#include <uv2_vertex>\n\t#include <color_vertex>\n\t#include <beginnormal_vertex>\n\t#include <morphnormal_vertex>\n\t#include <skinbase_vertex>\n\t#include <skinnormal_vertex>\n\t#include <defaultnormal_vertex>\n#ifndef FLAT_SHADED\n\tvNormal = normalize( transformedNormal );\n#endif\n\t#include <begin_vertex>\n\t#include <morphtarget_vertex>\n\t#include <skinning_vertex>\n\t#include <displacementmap_vertex>\n\t#include <project_vertex>\n\t#include <logdepthbuf_vertex>\n\t#include <clipping_planes_vertex>\n\tvViewPosition = - mvPosition.xyz;\n\t#include <worldpos_vertex>\n\t#include <envmap_vertex>\n\t#include <shadowmap_vertex>\n\t#include <fog_vertex>\n}",meshphysical_frag:"#define STANDARD\n#ifdef PHYSICAL\n\t#define REFLECTIVITY\n\t#define CLEARCOAT\n#endif\nuniform vec3 diffuse;\nuniform vec3 emissive;\nuniform float roughness;\nuniform float metalness;\nuniform float opacity;\n#ifdef USE_TRANSMISSION\n\tuniform float transmission;\n\tuniform float thickness;\n\tuniform vec3 attenuationColor;\n\tuniform float attenuationDistance;\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 <common>\n#include <packing>\n#include <dithering_pars_fragment>\n#include <color_pars_fragment>\n#include <uv_pars_fragment>\n#include <uv2_pars_fragment>\n#include <map_pars_fragment>\n#include <alphamap_pars_fragment>\n#include <aomap_pars_fragment>\n#include <lightmap_pars_fragment>\n#include <emissivemap_pars_fragment>\n#include <bsdfs>\n#include <transmission_pars_fragment>\n#include <cube_uv_reflection_fragment>\n#include <envmap_common_pars_fragment>\n#include <envmap_physical_pars_fragment>\n#include <fog_pars_fragment>\n#include <lights_pars_begin>\n#include <lights_physical_pars_fragment>\n#include <shadowmap_pars_fragment>\n#include <bumpmap_pars_fragment>\n#include <normalmap_pars_fragment>\n#include <clearcoat_pars_fragment>\n#include <roughnessmap_pars_fragment>\n#include <metalnessmap_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main() {\n\t#include <clipping_planes_fragment>\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 USE_TRANSMISSION\n\t\tfloat totalTransmission = transmission;\n\t\tfloat thicknessFactor = thickness;\n\t#endif\n\t#include <logdepthbuf_fragment>\n\t#include <map_fragment>\n\t#include <color_fragment>\n\t#include <alphamap_fragment>\n\t#include <alphatest_fragment>\n\t#include <roughnessmap_fragment>\n\t#include <metalnessmap_fragment>\n\t#include <normal_fragment_begin>\n\t#include <normal_fragment_maps>\n\t#include <clearcoat_normal_fragment_begin>\n\t#include <clearcoat_normal_fragment_maps>\n\t#include <emissivemap_fragment>\n\tvec3 rawDiffuseColor = diffuseColor.rgb;\n\t#include <transmission_fragment>\n\t#include <lights_physical_fragment>\n\t#include <lights_fragment_begin>\n\t#include <lights_fragment_maps>\n\t#include <lights_fragment_end>\n\t#include <aomap_fragment>\n\tvec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + reflectedLight.directSpecular + reflectedLight.indirectSpecular + totalEmissiveRadiance;\n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include <tonemapping_fragment>\n\t#include <encodings_fragment>\n\t#include <fog_fragment>\n\t#include <premultiplied_alpha_fragment>\n\t#include <dithering_fragment>\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#ifdef USE_TRANSMISSION\n\tvarying vec4 vWorldPosition;\n#endif\n#include <common>\n#include <uv_pars_vertex>\n#include <uv2_pars_vertex>\n#include <displacementmap_pars_vertex>\n#include <color_pars_vertex>\n#include <fog_pars_vertex>\n#include <morphtarget_pars_vertex>\n#include <skinning_pars_vertex>\n#include <shadowmap_pars_vertex>\n#include <logdepthbuf_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\t#include <uv_vertex>\n\t#include <uv2_vertex>\n\t#include <color_vertex>\n\t#include <beginnormal_vertex>\n\t#include <morphnormal_vertex>\n\t#include <skinbase_vertex>\n\t#include <skinnormal_vertex>\n\t#include <defaultnormal_vertex>\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 <begin_vertex>\n\t#include <morphtarget_vertex>\n\t#include <skinning_vertex>\n\t#include <displacementmap_vertex>\n\t#include <project_vertex>\n\t#include <logdepthbuf_vertex>\n\t#include <clipping_planes_vertex>\n\tvViewPosition = - mvPosition.xyz;\n\t#include <worldpos_vertex>\n\t#include <shadowmap_vertex>\n\t#include <fog_vertex>\n#ifdef USE_TRANSMISSION\n\tvWorldPosition = worldPosition;\n#endif\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 <packing>\n#include <uv_pars_fragment>\n#include <bumpmap_pars_fragment>\n#include <normalmap_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main() {\n\t#include <clipping_planes_fragment>\n\t#include <logdepthbuf_fragment>\n\t#include <normal_fragment_begin>\n\t#include <normal_fragment_maps>\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 <common>\n#include <uv_pars_vertex>\n#include <displacementmap_pars_vertex>\n#include <morphtarget_pars_vertex>\n#include <skinning_pars_vertex>\n#include <logdepthbuf_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\t#include <uv_vertex>\n\t#include <beginnormal_vertex>\n\t#include <morphnormal_vertex>\n\t#include <skinbase_vertex>\n\t#include <skinnormal_vertex>\n\t#include <defaultnormal_vertex>\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 <begin_vertex>\n\t#include <morphtarget_vertex>\n\t#include <skinning_vertex>\n\t#include <displacementmap_vertex>\n\t#include <project_vertex>\n\t#include <logdepthbuf_vertex>\n\t#include <clipping_planes_vertex>\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 <common>\n#include <color_pars_fragment>\n#include <map_particle_pars_fragment>\n#include <fog_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main() {\n\t#include <clipping_planes_fragment>\n\tvec3 outgoingLight = vec3( 0.0 );\n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\t#include <logdepthbuf_fragment>\n\t#include <map_particle_fragment>\n\t#include <color_fragment>\n\t#include <alphatest_fragment>\n\toutgoingLight = diffuseColor.rgb;\n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include <tonemapping_fragment>\n\t#include <encodings_fragment>\n\t#include <fog_fragment>\n\t#include <premultiplied_alpha_fragment>\n}",points_vert:"uniform float size;\nuniform float scale;\n#include <common>\n#include <color_pars_vertex>\n#include <fog_pars_vertex>\n#include <morphtarget_pars_vertex>\n#include <logdepthbuf_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\t#include <color_vertex>\n\t#include <begin_vertex>\n\t#include <morphtarget_vertex>\n\t#include <project_vertex>\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 <logdepthbuf_vertex>\n\t#include <clipping_planes_vertex>\n\t#include <worldpos_vertex>\n\t#include <fog_vertex>\n}",shadow_frag:"uniform vec3 color;\nuniform float opacity;\n#include <common>\n#include <packing>\n#include <fog_pars_fragment>\n#include <bsdfs>\n#include <lights_pars_begin>\n#include <shadowmap_pars_fragment>\n#include <shadowmask_pars_fragment>\nvoid main() {\n\tgl_FragColor = vec4( color, opacity * ( 1.0 - getShadowMask() ) );\n\t#include <tonemapping_fragment>\n\t#include <encodings_fragment>\n\t#include <fog_fragment>\n}",shadow_vert:"#include <common>\n#include <fog_pars_vertex>\n#include <shadowmap_pars_vertex>\nvoid main() {\n\t#include <begin_vertex>\n\t#include <project_vertex>\n\t#include <worldpos_vertex>\n\t#include <beginnormal_vertex>\n\t#include <morphnormal_vertex>\n\t#include <skinbase_vertex>\n\t#include <skinnormal_vertex>\n\t#include <defaultnormal_vertex>\n\t#include <shadowmap_vertex>\n\t#include <fog_vertex>\n}",sprite_frag:"uniform vec3 diffuse;\nuniform float opacity;\n#include <common>\n#include <uv_pars_fragment>\n#include <map_pars_fragment>\n#include <alphamap_pars_fragment>\n#include <fog_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main() {\n\t#include <clipping_planes_fragment>\n\tvec3 outgoingLight = vec3( 0.0 );\n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\t#include <logdepthbuf_fragment>\n\t#include <map_fragment>\n\t#include <alphamap_fragment>\n\t#include <alphatest_fragment>\n\toutgoingLight = diffuseColor.rgb;\n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include <tonemapping_fragment>\n\t#include <encodings_fragment>\n\t#include <fog_fragment>\n}",sprite_vert:"uniform float rotation;\nuniform vec2 center;\n#include <common>\n#include <uv_pars_vertex>\n#include <fog_pars_vertex>\n#include <logdepthbuf_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\t#include <uv_vertex>\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 <logdepthbuf_vertex>\n\t#include <clipping_planes_vertex>\n\t#include <fog_vertex>\n}"},wn={common:{diffuse:{value:new pi(16777215)},opacity:{value:1},map:{value:null},uvTransform:{value:new De},uv2Transform:{value:new De},alphaMap:{value:null}},specularmap:{specularMap:{value:null}},envmap:{envMap:{value:null},flipEnvMap:{value:-1},reflectivity:{value:1},refractionRatio:{value:.98},maxMipLevel:{value:0}},aomap:{aoMap:{value:null},aoMapIntensity:{value:1}},lightmap:{lightMap:{value:null},lightMapIntensity:{value:1}},emissivemap:{emissiveMap:{value:null}},bumpmap:{bumpMap:{value:null},bumpScale:{value:1}},normalmap:{normalMap:{value:null},normalScale:{value:new ke(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 pi(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 pi(16777215)},opacity:{value:1},size:{value:1},scale:{value:1},map:{value:null},alphaMap:{value:null},uvTransform:{value:new De}},sprite:{diffuse:{value:new pi(16777215)},opacity:{value:1},center:{value:new ke(.5,.5)},rotation:{value:0},map:{value:null},alphaMap:{value:null},uvTransform:{value:new De}}},Mn={basic:{uniforms:sn([wn.common,wn.specularmap,wn.envmap,wn.aomap,wn.lightmap,wn.fog]),vertexShader:xn.meshbasic_vert,fragmentShader:xn.meshbasic_frag},lambert:{uniforms:sn([wn.common,wn.specularmap,wn.envmap,wn.aomap,wn.lightmap,wn.emissivemap,wn.fog,wn.lights,{emissive:{value:new pi(0)}}]),vertexShader:xn.meshlambert_vert,fragmentShader:xn.meshlambert_frag},phong:{uniforms:sn([wn.common,wn.specularmap,wn.envmap,wn.aomap,wn.lightmap,wn.emissivemap,wn.bumpmap,wn.normalmap,wn.displacementmap,wn.fog,wn.lights,{emissive:{value:new pi(0)},specular:{value:new pi(1118481)},shininess:{value:30}}]),vertexShader:xn.meshphong_vert,fragmentShader:xn.meshphong_frag},standard:{uniforms:sn([wn.common,wn.envmap,wn.aomap,wn.lightmap,wn.emissivemap,wn.bumpmap,wn.normalmap,wn.displacementmap,wn.roughnessmap,wn.metalnessmap,wn.fog,wn.lights,{emissive:{value:new pi(0)},roughness:{value:1},metalness:{value:0},envMapIntensity:{value:1}}]),vertexShader:xn.meshphysical_vert,fragmentShader:xn.meshphysical_frag},toon:{uniforms:sn([wn.common,wn.aomap,wn.lightmap,wn.emissivemap,wn.bumpmap,wn.normalmap,wn.displacementmap,wn.gradientmap,wn.fog,wn.lights,{emissive:{value:new pi(0)}}]),vertexShader:xn.meshtoon_vert,fragmentShader:xn.meshtoon_frag},matcap:{uniforms:sn([wn.common,wn.bumpmap,wn.normalmap,wn.displacementmap,wn.fog,{matcap:{value:null}}]),vertexShader:xn.meshmatcap_vert,fragmentShader:xn.meshmatcap_frag},points:{uniforms:sn([wn.points,wn.fog]),vertexShader:xn.points_vert,fragmentShader:xn.points_frag},dashed:{uniforms:sn([wn.common,wn.fog,{scale:{value:1},dashSize:{value:1},totalSize:{value:2}}]),vertexShader:xn.linedashed_vert,fragmentShader:xn.linedashed_frag},depth:{uniforms:sn([wn.common,wn.displacementmap]),vertexShader:xn.depth_vert,fragmentShader:xn.depth_frag},normal:{uniforms:sn([wn.common,wn.bumpmap,wn.normalmap,wn.displacementmap,{opacity:{value:1}}]),vertexShader:xn.normal_vert,fragmentShader:xn.normal_frag},sprite:{uniforms:sn([wn.sprite,wn.fog]),vertexShader:xn.sprite_vert,fragmentShader:xn.sprite_frag},background:{uniforms:{uvTransform:{value:new De},t2D:{value:null}},vertexShader:xn.background_vert,fragmentShader:xn.background_frag},cube:{uniforms:sn([wn.envmap,{opacity:{value:1}}]),vertexShader:xn.cube_vert,fragmentShader:xn.cube_frag},equirect:{uniforms:{tEquirect:{value:null}},vertexShader:xn.equirect_vert,fragmentShader:xn.equirect_frag},distanceRGBA:{uniforms:sn([wn.common,wn.displacementmap,{referencePosition:{value:new Ke},nearDistance:{value:1},farDistance:{value:1e3}}]),vertexShader:xn.distanceRGBA_vert,fragmentShader:xn.distanceRGBA_frag},shadow:{uniforms:sn([wn.lights,wn.fog,{color:{value:new pi(0)},opacity:{value:1}}]),vertexShader:xn.shadow_vert,fragmentShader:xn.shadow_frag}};function En(e,t,i,n,r){const o=new pi(0);let a,s,l=0,c=null,h=0,d=null;function p(e,t){i.buffers.color.setClear(e.r,e.g,e.b,t,r)}return{getClearColor:function(){return o},setClearColor:function(e,t=1){o.set(e),l=t,p(o,l)},getClearAlpha:function(){return l},setClearAlpha:function(e){l=e,p(o,l)},render:function(i,r){let g=!1,f=!0===r.isScene?r.background:null;f&&f.isTexture&&(f=t.get(f));const m=e.xr,A=m.getSession&&m.getSession();A&&"additive"===A.environmentBlendMode&&(f=null),null===f?p(o,l):f&&f.isColor&&(p(f,1),g=!0),(e.autoClear||g)&&e.clear(e.autoClearColor,e.autoClearDepth,e.autoClearStencil),f&&(f.isCubeTexture||f.mapping===u)?(void 0===s&&(s=new nn(new on(1,1,1),new cn({name:"BackgroundCubeMaterial",uniforms:an(Mn.cube.uniforms),vertexShader:Mn.cube.vertexShader,fragmentShader:Mn.cube.fragmentShader,side:1,depthTest:!1,depthWrite:!1,fog:!1})),s.geometry.deleteAttribute("normal"),s.geometry.deleteAttribute("uv"),s.onBeforeRender=function(e,t,i){this.matrixWorld.copyPosition(i.matrixWorld)},Object.defineProperty(s.material,"envMap",{get:function(){return this.uniforms.envMap.value}}),n.update(s)),s.material.uniforms.envMap.value=f,s.material.uniforms.flipEnvMap.value=f.isCubeTexture&&f._needsFlipEnvMap?-1:1,c===f&&h===f.version&&d===e.toneMapping||(s.material.needsUpdate=!0,c=f,h=f.version,d=e.toneMapping),i.unshift(s,s.geometry,s.material,0,0,null)):f&&f.isTexture&&(void 0===a&&(a=new nn(new In(2,2),new cn({name:"BackgroundMaterial",uniforms:an(Mn.background.uniforms),vertexShader:Mn.background.vertexShader,fragmentShader:Mn.background.fragmentShader,side:0,depthTest:!1,depthWrite:!1,fog:!1})),a.geometry.deleteAttribute("normal"),Object.defineProperty(a.material,"map",{get:function(){return this.uniforms.t2D.value}}),n.update(a)),a.material.uniforms.t2D.value=f,!0===f.matrixAutoUpdate&&f.updateMatrix(),a.material.uniforms.uvTransform.value.copy(f.matrix),c===f&&h===f.version&&d===e.toneMapping||(a.material.needsUpdate=!0,c=f,h=f.version,d=e.toneMapping),i.unshift(a,a.geometry,a.material,0,0,null))}}}function Bn(e,t,i,n){const r=e.getParameter(34921),o=n.isWebGL2?null:t.get("OES_vertex_array_object"),a=n.isWebGL2||null!==o,s={},l=u(null);let c=l;function h(t){return n.isWebGL2?e.bindVertexArray(t):o.bindVertexArrayOES(t)}function d(t){return n.isWebGL2?e.deleteVertexArray(t):o.deleteVertexArrayOES(t)}function u(e){const t=[],i=[],n=[];for(let e=0;r>e;e++)t[e]=0,i[e]=0,n[e]=0;return{geometry:null,program:null,wireframe:!1,newAttributes:t,enabledAttributes:i,attributeDivisors:n,object:e,attributes:{},index:null}}function p(){const e=c.newAttributes;for(let t=0,i=e.length;i>t;t++)e[t]=0}function g(e){f(e,0)}function f(i,r){const o=c.enabledAttributes,a=c.attributeDivisors;if(c.newAttributes[i]=1,0===o[i]&&(e.enableVertexAttribArray(i),o[i]=1),a[i]!==r){(n.isWebGL2?e:t.get("ANGLE_instanced_arrays"))[n.isWebGL2?"vertexAttribDivisor":"vertexAttribDivisorANGLE"](i,r),a[i]=r}}function m(){const t=c.newAttributes,i=c.enabledAttributes;for(let n=0,r=i.length;r>n;n++)i[n]!==t[n]&&(e.disableVertexAttribArray(n),i[n]=0)}function A(t,i,r,o,a,s){!0!==n.isWebGL2||5124!==r&&5125!==r?e.vertexAttribPointer(t,i,r,o,a,s):e.vertexAttribIPointer(t,i,r,a,s)}function y(){v(),c!==l&&(c=l,h(c.object))}function v(){l.geometry=null,l.program=null,l.wireframe=!1}return{setup:function(r,l,d,y,v){let C=!1;if(a){const t=function(t,i,r){const a=!0===r.wireframe;let l=s[t.id];void 0===l&&(l={},s[t.id]=l);let c=l[i.id];void 0===c&&(c={},l[i.id]=c);let h=c[a];void 0===h&&(h=u(function(){if(n.isWebGL2)return e.createVertexArray();return o.createVertexArrayOES()}()),c[a]=h);return h}(y,d,l);c!==t&&(c=t,h(c.object)),C=function(e,t){const i=c.attributes,n=e.attributes;let r=0;for(const e in n){const t=i[e],o=n[e];if(void 0===t)return!0;if(t.attribute!==o)return!0;if(t.data!==o.data)return!0;r++}if(c.attributesNum!==r)return!0;if(c.index!==t)return!0;return!1}(y,v),C&&function(e,t){const i={},n=e.attributes;let r=0;for(const e in n){const t=n[e],o={};o.attribute=t,t.data&&(o.data=t.data),i[e]=o,r++}c.attributes=i,c.attributesNum=r,c.index=t}(y,v)}else{const e=!0===l.wireframe;c.geometry===y.id&&c.program===d.id&&c.wireframe===e||(c.geometry=y.id,c.program=d.id,c.wireframe=e,C=!0)}!0===r.isInstancedMesh&&(C=!0),null!==v&&i.update(v,34963),C&&(!function(r,o,a,s){if(!1===n.isWebGL2&&(r.isInstancedMesh||s.isInstancedBufferGeometry)&&null===t.get("ANGLE_instanced_arrays"))return;p();const l=s.attributes,c=a.getAttributes(),h=o.defaultAttributeValues;for(const t in c){const n=c[t];if(n>=0){const o=l[t];if(void 0!==o){const t=o.normalized,r=o.itemSize,a=i.get(o);if(void 0===a)continue;const l=a.buffer,c=a.type,h=a.bytesPerElement;if(o.isInterleavedBufferAttribute){const i=o.data,a=i.stride,d=o.offset;i&&i.isInstancedInterleavedBuffer?(f(n,i.meshPerAttribute),void 0===s._maxInstanceCount&&(s._maxInstanceCount=i.meshPerAttribute*i.count)):g(n),e.bindBuffer(34962,l),A(n,r,c,t,a*h,d*h)}else o.isInstancedBufferAttribute?(f(n,o.meshPerAttribute),void 0===s._maxInstanceCount&&(s._maxInstanceCount=o.meshPerAttribute*o.count)):g(n),e.bindBuffer(34962,l),A(n,r,c,t,0,0)}else if("instanceMatrix"===t){const t=i.get(r.instanceMatrix);if(void 0===t)continue;const o=t.buffer,a=t.type;f(n+0,1),f(n+1,1),f(n+2,1),f(n+3,1),e.bindBuffer(34962,o),e.vertexAttribPointer(n+0,4,a,!1,64,0),e.vertexAttribPointer(n+1,4,a,!1,64,16),e.vertexAttribPointer(n+2,4,a,!1,64,32),e.vertexAttribPointer(n+3,4,a,!1,64,48)}else if("instanceColor"===t){const t=i.get(r.instanceColor);if(void 0===t)continue;const o=t.buffer,a=t.type;f(n,1),e.bindBuffer(34962,o),e.vertexAttribPointer(n,3,a,!1,12,0)}else if(void 0!==h){const i=h[t];if(void 0!==i)switch(i.length){case 2:e.vertexAttrib2fv(n,i);break;case 3:e.vertexAttrib3fv(n,i);break;case 4:e.vertexAttrib4fv(n,i);break;default:e.vertexAttrib1fv(n,i)}}}}m()}(r,l,d,y),null!==v&&e.bindBuffer(34963,i.get(v).buffer))},reset:y,resetDefaultState:v,dispose:function(){y();for(const e in s){const t=s[e];for(const e in t){const i=t[e];for(const e in i)d(i[e].object),delete i[e];delete t[e]}delete s[e]}},releaseStatesOfGeometry:function(e){if(void 0===s[e.id])return;const t=s[e.id];for(const e in t){const i=t[e];for(const e in i)d(i[e].object),delete i[e];delete t[e]}delete s[e.id]},releaseStatesOfProgram:function(e){for(const t in s){const i=s[t];if(void 0===i[e.id])continue;const n=i[e.id];for(const e in n)d(n[e].object),delete n[e];delete i[e.id]}},initAttributes:p,enableAttribute:g,disableUnusedAttributes:m}}function Sn(e,t,i,n){const r=e.getParameter(34921),o=n.isWebGL2?null:t.get("OES_vertex_array_object"),a=n.isWebGL2||null!==o,s={},l=u(null);let c=l;function h(t){return n.isWebGL2?e.bindVertexArray(t):o.bindVertexArrayOES(t)}function d(t){return n.isWebGL2?e.deleteVertexArray(t):o.deleteVertexArrayOES(t)}function u(e){const t=[],i=[],n=[];for(let e=0;r>e;e++)t[e]=0,i[e]=0,n[e]=0;return{geometry:null,program:null,wireframe:!1,newAttributes:t,enabledAttributes:i,attributeDivisors:n,object:e,attributes:{},index:null}}function p(){const e=c.newAttributes;for(let t=0,i=e.length;i>t;t++)e[t]=0}function g(e){f(e,0)}function f(i,r){const o=c.enabledAttributes,a=c.attributeDivisors;if(c.newAttributes[i]=1,0===o[i]&&(e.enableVertexAttribArray(i),o[i]=1),a[i]!==r){(n.isWebGL2?e:t.get("ANGLE_instanced_arrays"))[n.isWebGL2?"vertexAttribDivisor":"vertexAttribDivisorANGLE"](i,r),a[i]=r}}function m(){const t=c.newAttributes,i=c.enabledAttributes;for(let n=0,r=i.length;r>n;n++)i[n]!==t[n]&&(e.disableVertexAttribArray(n),i[n]=0)}function A(t,i,r,o,a,s){!0!==n.isWebGL2||5124!==r&&5125!==r?e.vertexAttribPointer(t,i,r,o,a,s):e.vertexAttribIPointer(t,i,r,a,s)}function y(){v(),c!==l&&(c=l,h(c.object))}function v(){l.geometry=null,l.program=null,l.wireframe=!1}return{setup:function(r,l,d,y,v,C){let I=!1;if(a){const t=function(t,i,r){const a=!0===r.wireframe;let l=s[t.id];void 0===l&&(l={},s[t.id]=l);let c=l[i.id];void 0===c&&(c={},l[i.id]=c);let h=c[a];void 0===h&&(h=u(function(){if(n.isWebGL2)return e.createVertexArray();return o.createVertexArrayOES()}()),c[a]=h);return h}(y,d,l);c!==t&&(c=t,h(c.object)),I=function(e,t){const i=c.attributes,n=e.attributes;let r=0;for(const e in n){const t=i[e],o=n[e];if(void 0===t)return!0;if(t.attribute!==o)return!0;if(t.data!==o.data)return!0;r++}if(c.attributesNum!==r)return!0;if(c.index!==t)return!0;return!1}(y,v),I&&function(e,t){const i={},n=e.attributes;let r=0;for(const e in n){const t=n[e],o={};o.attribute=t,t.data&&(o.data=t.data),i[e]=o,r++}c.attributes=i,c.attributesNum=r,c.index=t}(y,v)}else{const e=!0===l.wireframe;c.geometry===y.id&&c.program===d.id&&c.wireframe===e||(c.geometry=y.id,c.program=d.id,c.wireframe=e,I=!0)}!0===r.isInstancedMesh&&(I=!0),null!==v&&i.update(v,34963),I&&(!function(r,o,a,s,l){if(!1===n.isWebGL2&&(r.isInstancedMesh||s.isInstancedBufferGeometry)&&null===t.get("ANGLE_instanced_arrays"))return;p();const c=s.attributes,h=a.getAttributes(),d=o.defaultAttributeValues;for(const t in h){const n=h[t];if(n>=0){const o=c[t];if(void 0!==o){const t=o.normalized,r=o.itemSize,a=i.get(o);if(void 0===a)continue;const l=a.buffer,c=a.type,h=a.bytesPerElement;if(o.isInterleavedBufferAttribute){const i=o.data,a=i.stride,d=o.offset;i&&i.isInstancedInterleavedBuffer?(f(n,i.meshPerAttribute),void 0===s._maxInstanceCount&&(s._maxInstanceCount=i.meshPerAttribute*i.count)):g(n),e.bindBuffer(34962,l),A(n,r,c,t,a*h,d*h)}else o.isInstancedBufferAttribute?(f(n,o.meshPerAttribute),void 0===s._maxInstanceCount&&(s._maxInstanceCount=o.meshPerAttribute*o.count)):g(n),e.bindBuffer(34962,l),A(n,r,c,t,0,0)}else if("instanceMatrix"===t){if(void 0===(u=i.get(null!=l?r.instanceMatrices[l]:r.instanceMatrix)))continue;const t=u.buffer,o=u.type;f(n+0,1),f(n+1,1),f(n+2,1),f(n+3,1),e.bindBuffer(34962,t),e.vertexAttribPointer(n+0,4,o,!1,64,0),e.vertexAttribPointer(n+1,4,o,!1,64,16),e.vertexAttribPointer(n+2,4,o,!1,64,32),e.vertexAttribPointer(n+3,4,o,!1,64,48)}else if("instanceColor"===t){if(void 0===(u=i.get(null!=l?r.instanceColors[l]:r.instanceColor)))continue;const t=u.buffer,o=u.type;f(n,1),e.bindBuffer(34962,t),e.vertexAttribPointer(n,4,o,!1,16,0)}else if("instanceShows"===t||"instanceDiffuses"===t){var u;if(void 0===(u=i.get(null!=l?r[t][l]:r[t])))continue;const o=u.buffer,a=u.type;f(n,1),e.bindBuffer(34962,o),e.vertexAttribPointer(n,4,a,!1,16,0)}else if(void 0!==d){const i=d[t];if(void 0!==i)switch(i.length){case 2:e.vertexAttrib2fv(n,i);break;case 3:e.vertexAttrib3fv(n,i);break;case 4:e.vertexAttrib4fv(n,i);break;default:e.vertexAttrib1fv(n,i)}}}}m()}(r,l,d,y,null!==C?C.instanceIndex:null),null!==v&&e.bindBuffer(34963,i.get(v).buffer))},reset:y,resetDefaultState:v,dispose:function(){y();for(const e in s){const t=s[e];for(const e in t){const i=t[e];for(const e in i)d(i[e].object),delete i[e];delete t[e]}delete s[e]}},releaseStatesOfGeometry:function(e){if(void 0===s[e.id])return;const t=s[e.id];for(const e in t){const i=t[e];for(const e in i)d(i[e].object),delete i[e];delete t[e]}delete s[e.id]},releaseStatesOfProgram:function(e){for(const t in s){const i=s[t];if(void 0===i[e.id])continue;const n=i[e.id];for(const e in n)d(n[e].object),delete n[e];delete i[e.id]}},initAttributes:p,enableAttribute:g,disableUnusedAttributes:m}}function bn(e,t,i,n){const r=n.isWebGL2;let o;this.setMode=function(e){o=e},this.render=function(t,n){e.drawArrays(o,t,n),i.update(n,o,1)},this.renderInstances=function(n,a,s){if(0===s)return;let l,c;if(r)l=e,c="drawArraysInstanced";else if(l=t.get("ANGLE_instanced_arrays"),c="drawArraysInstancedANGLE",null===l)return void console.error("THREE.WebGLBufferRenderer: using THREE.InstancedBufferGeometry but hardware does not support extension ANGLE_instanced_arrays.");l[c](o,n,a,s),i.update(a,o,s)}}function kn(e,t,i){let n;function r(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"}const o="undefined"!=typeof WebGL2RenderingContext&&e instanceof WebGL2RenderingContext||"undefined"!=typeof WebGL2ComputeRenderingContext&&e instanceof WebGL2ComputeRenderingContext;let a=void 0!==i.precision?i.precision:"highp";const s=r(a);s!==a&&(console.warn("THREE.WebGLRenderer:",a,"not supported, using",s,"instead."),a=s);const l=o||t.has("WEBGL_draw_buffers"),c=!0===i.logarithmicDepthBuffer,h=e.getParameter(34930),d=e.getParameter(35660),u=e.getParameter(3379),p=e.getParameter(34076),g=e.getParameter(34921),f=e.getParameter(36347),m=e.getParameter(36348),A=e.getParameter(36349),y=d>0,v=o||t.has("OES_texture_float");return{isWebGL2:o,drawBuffers:l,getMaxAnisotropy:function(){if(void 0!==n)return n;if(!0===t.has("EXT_texture_filter_anisotropic")){const i=t.get("EXT_texture_filter_anisotropic");n=e.getParameter(i.MAX_TEXTURE_MAX_ANISOTROPY_EXT)}else n=0;return n},getMaxPrecision:r,precision:a,logarithmicDepthBuffer:c,maxTextures:h,maxVertexTextures:d,maxTextureSize:u,maxCubemapSize:p,maxAttributes:g,maxVertexUniforms:f,maxVaryings:m,maxFragmentUniforms:A,vertexTextures:y,floatFragmentTextures:v,floatVertexTextures:y&&v,maxSamples:o?e.getParameter(36183):0}}function Dn(e){const t=this;let i=null,n=0,r=!1,o=!1;const a=new Jt,s=new De,l={value:null,needsUpdate:!1};function c(){l.value!==i&&(l.value=i,l.needsUpdate=n>0),t.numPlanes=n,t.numIntersection=0}function h(e,i,n,r){const o=null!==e?e.length:0;let c=null;if(0!==o){if(c=l.value,!0!==r||null===c){const t=n+4*o,r=i.matrixWorldInverse;s.getNormalMatrix(r),(null===c||t>c.length)&&(c=new Float32Array(t));for(let t=0,i=n;t!==o;++t,i+=4)a.copy(e[t]).applyMatrix4(r,s),a.normal.toArray(c,i),c[i+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){const a=0!==e.length||t||0!==n||r;return r=t,i=h(e,o,0),n=e.length,a},this.beginShadows=function(){o=!0,h(null)},this.endShadows=function(){o=!1,c()},this.setState=function(t,a,s){const d=t.clippingPlanes,u=t.clipIntersection,p=t.clipShadows,g=e.get(t);if(!r||null===d||0===d.length||o&&!p)o?h(null):c();else{const e=o?0:n,t=4*e;let r=g.clippingState||null;l.value=r,r=h(d,a,t,s);for(let e=0;e!==t;++e)r[e]=i[e];g.clippingState=r,this.numIntersection=u?this.numPlanes:0,this.numPlanes+=e}}}function Tn(e){let t=new WeakMap;function i(e,t){return t===h?e.mapping=l:t===d&&(e.mapping=c),e}function n(e){const i=e.target;i.removeEventListener("dispose",n);const r=t.get(i);void 0!==r&&(t.delete(i),r.dispose())}return{get:function(r){if(r&&r.isTexture){const o=r.mapping;if(o===h||o===d){if(t.has(r)){return i(t.get(r).texture,r.mapping)}{const o=r.image;if(o&&o.height>0){const a=e.getRenderTarget(),s=new fn(o.height/2);return s.fromEquirectangularTexture(e,r),t.set(r,s),e.setRenderTarget(a),r.addEventListener("dispose",n),i(s.texture,r.mapping)}return null}}}return r},dispose:function(){t=new WeakMap}}}function Rn(e){const t={};function i(i){if(void 0!==t[i])return t[i];let n;switch(i){case"WEBGL_depth_texture":n=e.getExtension("WEBGL_depth_texture")||e.getExtension("MOZ_WEBGL_depth_texture")||e.getExtension("WEBKIT_WEBGL_depth_texture");break;case"EXT_texture_filter_anisotropic":n=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":n=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":n=e.getExtension("WEBGL_compressed_texture_pvrtc")||e.getExtension("WEBKIT_WEBGL_compressed_texture_pvrtc");break;default:n=e.getExtension(i)}return t[i]=n,n}return{has:function(e){return null!==i(e)},init:function(e){e.isWebGL2?i("EXT_color_buffer_float"):(i("WEBGL_depth_texture"),i("OES_texture_float"),i("OES_texture_half_float"),i("OES_texture_half_float_linear"),i("OES_standard_derivatives"),i("OES_element_index_uint"),i("OES_vertex_array_object"),i("ANGLE_instanced_arrays")),i("OES_texture_float_linear"),i("EXT_color_buffer_half_float")},get:function(e){const t=i(e);return null===t&&console.warn("THREE.WebGLRenderer: "+e+" extension not supported."),t}}}function Un(e,t,i,n){const r={},o=new WeakMap;function a(e){const s=e.target;null!==s.index&&t.remove(s.index);for(const e in s.attributes)t.remove(s.attributes[e]);s.removeEventListener("dispose",a),delete r[s.id];const l=o.get(s);l&&(t.remove(l),o.delete(s)),n.releaseStatesOfGeometry(s),!0===s.isInstancedBufferGeometry&&delete s._maxInstanceCount,i.memory.geometries--}function s(e){const i=[],n=e.index,r=e.attributes.position;let a=0;if(null!==n){const e=n.array;a=n.version;for(let t=0,n=e.length;n>t;t+=3){const n=e[t+0],r=e[t+1],o=e[t+2];i.push(n,r,r,o,o,n)}}else{a=r.version;for(let e=0,t=r.array.length/3-1;t>e;e+=3){const t=e+0,n=e+1,r=e+2;i.push(t,n,n,r,r,t)}}const s=new(bi(i)>65535?Mi:xi)(i,1);s.version=a;const l=o.get(e);l&&t.remove(l),o.set(e,s)}return{get:function(e,t){return!0===r[t.id]||(t.addEventListener("dispose",a),r[t.id]=!0,i.memory.geometries++),t},update:function(e){const i=e.attributes;for(const e in i)t.update(i[e],34962);const n=e.morphAttributes;for(const e in n){const i=n[e];for(let e=0,n=i.length;n>e;e++)t.update(i[e],34962)}},getWireframeAttribute:function(e){const t=o.get(e);if(t){const i=e.index;null!==i&&i.version>t.version&&s(e)}else s(e);return o.get(e)}}}function Fn(e,t,i,n){const r=n.isWebGL2;let o,a,s;this.setMode=function(e){o=e},this.setIndex=function(e){a=e.type,s=e.bytesPerElement},this.render=function(t,n){e.drawElements(o,n,a,t*s),i.update(n,o,1)},this.renderInstances=function(n,l,c){if(0===c)return;let h,d;if(r)h=e,d="drawElementsInstanced";else if(h=t.get("ANGLE_instanced_arrays"),d="drawElementsInstancedANGLE",null===h)return void console.error("THREE.WebGLIndexedBufferRenderer: using THREE.InstancedBufferGeometry but hardware does not support extension ANGLE_instanced_arrays.");h[d](o,l,a,n*s,c),i.update(l,o,c)}}function Qn(e){const t={frame:0,calls:0,triangles:0,points:0,lines:0};return{memory:{geometries:0,textures:0},render:t,programs:null,autoReset:!0,reset:function(){t.frame++,t.calls=0,t.triangles=0,t.points=0,t.lines=0},update:function(e,i,n){switch(t.calls++,i){case 4:t.triangles+=n*(e/3);break;case 1:t.lines+=n*(e/2);break;case 3:t.lines+=n*(e-1);break;case 2:t.lines+=n*e;break;case 0:t.points+=n*e;break;default:console.error("THREE.WebGLInfo: Unknown draw mode:",i)}}}}function Ln(e,t){return e[0]-t[0]}function On(e,t){return Math.abs(t[1])-Math.abs(e[1])}function Nn(e){const t={},i=new Float32Array(8),n=[];for(let e=0;8>e;e++)n[e]=[e,0];return{update:function(r,o,a,s){const l=r.morphTargetInfluences,c=void 0===l?0:l.length;let h=t[o.id];if(void 0===h){h=[];for(let e=0;c>e;e++)h[e]=[e,0];t[o.id]=h}for(let e=0;c>e;e++){const t=h[e];t[0]=e,t[1]=l[e]}h.sort(On);for(let e=0;8>e;e++)c>e&&h[e][1]?(n[e][0]=h[e][0],n[e][1]=h[e][1]):(n[e][0]=Number.MAX_SAFE_INTEGER,n[e][1]=0);n.sort(Ln);const d=a.morphTargets&&o.morphAttributes.position,u=a.morphNormals&&o.morphAttributes.normal;let p=0;for(let e=0;8>e;e++){const t=n[e],r=t[0],a=t[1];r!==Number.MAX_SAFE_INTEGER&&a?(d&&o.getAttribute("morphTarget"+e)!==d[r]&&o.setAttribute("morphTarget"+e,d[r]),u&&o.getAttribute("morphNormal"+e)!==u[r]&&o.setAttribute("morphNormal"+e,u[r]),i[e]=a,p+=a):(d&&!0===o.hasAttribute("morphTarget"+e)&&o.deleteAttribute("morphTarget"+e),u&&!0===o.hasAttribute("morphNormal"+e)&&o.deleteAttribute("morphNormal"+e),i[e]=0)}const g=o.morphTargetsRelative?1:1-p;s.getUniforms().setValue(e,"morphTargetBaseInfluence",g),s.getUniforms().setValue(e,"morphTargetInfluences",i)}}}function Pn(e,t,i,n){let r=new WeakMap;function o(e){const t=e.target;t.removeEventListener("dispose",o),i.remove(t.instanceMatrix),null!==t.instanceColor&&i.remove(t.instanceColor)}return{update:function(e){const a=n.render.frame,s=t.get(e,e.geometry);return r.get(s)!==a&&(t.update(s),r.set(s,a)),e.isInstancedMesh&&(!1===e.hasEventListener("dispose",o)&&e.addEventListener("dispose",o),i.update(e.instanceMatrix,34962),null!==e.instanceColor&&i.update(e.instanceColor,34962)),s},dispose:function(){r=new WeakMap}}}function Gn(e,t,i,n){let r=new WeakMap;function o(e){const t=e.target;t.removeEventListener("dispose",o),i.remove(t.instanceMatrix),null!==t.instanceColor&&i.remove(t.instanceColor)}return{update:function(e){const a=n.render.frame,s=t.get(e,e.geometry);if(r.get(s)!==a&&(t.update(s),r.set(s,a)),e.isInstancedMesh){if(!1===e.hasEventListener("dispose",o)&&e.addEventListener("dispose",o),i.update(e.instanceMatrix,34962),null!==e.instanceColor&&i.update(e.instanceColor,34962),e.instanceMatrices)for(var l=0;e.instanceMatrices.length>l;++l)i.update(e.instanceMatrices[l],34962);if(e.instanceColors)for(l=0;e.instanceColors.length>l;++l)i.update(e.instanceColors[l],34962);if(e.instanceShows)for(l=0;e.instanceShows.length>l;++l)i.update(e.instanceShows[l],34962);if(e.instanceDiffuses)for(l=0;e.instanceDiffuses.length>l;++l)i.update(e.instanceDiffuses[l],34962)}return s},dispose:function(){r=new WeakMap}}}Mn.physical={uniforms:sn([Mn.standard.uniforms,{clearcoat:{value:0},clearcoatMap:{value:null},clearcoatRoughness:{value:0},clearcoatRoughnessMap:{value:null},clearcoatNormalScale:{value:new ke(1,1)},clearcoatNormalMap:{value:null},sheen:{value:new pi(0)},transmission:{value:0},transmissionMap:{value:null},transmissionSamplerSize:{value:new ke},transmissionSamplerMap:{value:null},thickness:{value:0},thicknessMap:{value:null},attenuationDistance:{value:0},attenuationColor:{value:new pi(0)}}]),vertexShader:xn.meshphysical_vert,fragmentShader:xn.meshphysical_frag};class Kn extends Fe{constructor(e=null,t=1,i=1,n=1){super(null),this.image={data:e,width:t,height:i,depth:n},this.magFilter=A,this.minFilter=A,this.wrapR=f,this.generateMipmaps=!1,this.flipY=!1,this.unpackAlignment=1,this.needsUpdate=!0}}Kn.prototype.isDataTexture2DArray=!0;class Vn extends Fe{constructor(e=null,t=1,i=1,n=1){super(null),this.image={data:e,width:t,height:i,depth:n},this.magFilter=A,this.minFilter=A,this.wrapR=f,this.generateMipmaps=!1,this.flipY=!1,this.unpackAlignment=1,this.needsUpdate=!0}}Vn.prototype.isDataTexture3D=!0;const Yn=new Fe,Hn=new Kn,jn=new Vn,Wn=new gn,Jn=[],zn=[],qn=new Float32Array(16),Zn=new Float32Array(9),Xn=new Float32Array(4);function _n(e,t,i){const n=e[0];if(0>=n||n>0)return e;const r=t*i;let o=Jn[r];if(void 0===o&&(o=new Float32Array(r),Jn[r]=o),0!==t){n.toArray(o,0);for(let n=1,r=0;n!==t;++n)r+=i,e[n].toArray(o,r)}return o}function $n(e,t){if(e.length!==t.length)return!1;for(let i=0,n=e.length;n>i;i++)if(e[i]!==t[i])return!1;return!0}function er(e,t){for(let i=0,n=t.length;n>i;i++)e[i]=t[i]}function tr(e,t){let i=zn[t];void 0===i&&(i=new Int32Array(t),zn[t]=i);for(let n=0;n!==t;++n)i[n]=e.allocateTextureUnit();return i}function ir(e,t){const i=this.cache;i[0]!==t&&(e.uniform1f(this.addr,t),i[0]=t)}function nr(e,t){const i=this.cache;if(void 0!==t.x)i[0]===t.x&&i[1]===t.y||(e.uniform2f(this.addr,t.x,t.y),i[0]=t.x,i[1]=t.y);else{if($n(i,t))return;e.uniform2fv(this.addr,t),er(i,t)}}function rr(e,t){const i=this.cache;if(void 0!==t.x)i[0]===t.x&&i[1]===t.y&&i[2]===t.z||(e.uniform3f(this.addr,t.x,t.y,t.z),i[0]=t.x,i[1]=t.y,i[2]=t.z);else if(void 0!==t.r)i[0]===t.r&&i[1]===t.g&&i[2]===t.b||(e.uniform3f(this.addr,t.r,t.g,t.b),i[0]=t.r,i[1]=t.g,i[2]=t.b);else{if($n(i,t))return;e.uniform3fv(this.addr,t),er(i,t)}}function or(e,t){const i=this.cache;if(void 0!==t.x)i[0]===t.x&&i[1]===t.y&&i[2]===t.z&&i[3]===t.w||(e.uniform4f(this.addr,t.x,t.y,t.z,t.w),i[0]=t.x,i[1]=t.y,i[2]=t.z,i[3]=t.w);else{if($n(i,t))return;e.uniform4fv(this.addr,t),er(i,t)}}function ar(e,t){const i=this.cache,n=t.elements;if(void 0===n){if($n(i,t))return;e.uniformMatrix2fv(this.addr,!1,t),er(i,t)}else{if($n(i,n))return;Xn.set(n),e.uniformMatrix2fv(this.addr,!1,Xn),er(i,n)}}function sr(e,t){const i=this.cache,n=t.elements;if(void 0===n){if($n(i,t))return;e.uniformMatrix3fv(this.addr,!1,t),er(i,t)}else{if($n(i,n))return;Zn.set(n),e.uniformMatrix3fv(this.addr,!1,Zn),er(i,n)}}function lr(e,t){const i=this.cache,n=t.elements;if(void 0===n){if($n(i,t))return;e.uniformMatrix4fv(this.addr,!1,t),er(i,t)}else{if($n(i,n))return;qn.set(n),e.uniformMatrix4fv(this.addr,!1,qn),er(i,n)}}function cr(e,t){const i=this.cache;i[0]!==t&&(e.uniform1i(this.addr,t),i[0]=t)}function hr(e,t){const i=this.cache;$n(i,t)||(e.uniform2iv(this.addr,t),er(i,t))}function dr(e,t){const i=this.cache;$n(i,t)||(e.uniform3iv(this.addr,t),er(i,t))}function ur(e,t){const i=this.cache;$n(i,t)||(e.uniform4iv(this.addr,t),er(i,t))}function pr(e,t){const i=this.cache;i[0]!==t&&(e.uniform1ui(this.addr,t),i[0]=t)}function gr(e,t){const i=this.cache;$n(i,t)||(e.uniform2uiv(this.addr,t),er(i,t))}function fr(e,t){const i=this.cache;$n(i,t)||(e.uniform3uiv(this.addr,t),er(i,t))}function mr(e,t){const i=this.cache;$n(i,t)||(e.uniform4uiv(this.addr,t),er(i,t))}function Ar(e,t,i){const n=this.cache,r=i.allocateTextureUnit();n[0]!==r&&(e.uniform1i(this.addr,r),n[0]=r),i.safeSetTexture2D(t||Yn,r)}function yr(e,t,i){const n=this.cache,r=i.allocateTextureUnit();n[0]!==r&&(e.uniform1i(this.addr,r),n[0]=r),i.setTexture3D(t||jn,r)}function vr(e,t,i){const n=this.cache,r=i.allocateTextureUnit();n[0]!==r&&(e.uniform1i(this.addr,r),n[0]=r),i.safeSetTextureCube(t||Wn,r)}function Cr(e,t,i){const n=this.cache,r=i.allocateTextureUnit();n[0]!==r&&(e.uniform1i(this.addr,r),n[0]=r),i.setTexture2DArray(t||Hn,r)}function Ir(e,t){e.uniform1fv(this.addr,t)}function xr(e,t){const i=_n(t,this.size,2);e.uniform2fv(this.addr,i)}function wr(e,t){const i=_n(t,this.size,3);e.uniform3fv(this.addr,i)}function Mr(e,t){const i=_n(t,this.size,4);e.uniform4fv(this.addr,i)}function Er(e,t){const i=_n(t,this.size,4);e.uniformMatrix2fv(this.addr,!1,i)}function Br(e,t){const i=_n(t,this.size,9);e.uniformMatrix3fv(this.addr,!1,i)}function Sr(e,t){const i=_n(t,this.size,16);e.uniformMatrix4fv(this.addr,!1,i)}function br(e,t){e.uniform1iv(this.addr,t)}function kr(e,t){e.uniform2iv(this.addr,t)}function Dr(e,t){e.uniform3iv(this.addr,t)}function Tr(e,t){e.uniform4iv(this.addr,t)}function Rr(e,t){e.uniform1uiv(this.addr,t)}function Ur(e,t){e.uniform2uiv(this.addr,t)}function Fr(e,t){e.uniform3uiv(this.addr,t)}function Qr(e,t){e.uniform4uiv(this.addr,t)}function Lr(e,t,i){const n=t.length,r=tr(i,n);e.uniform1iv(this.addr,r);for(let e=0;e!==n;++e)i.safeSetTexture2D(t[e]||Yn,r[e])}function Or(e,t,i){const n=t.length,r=tr(i,n);e.uniform1iv(this.addr,r);for(let e=0;e!==n;++e)i.safeSetTextureCube(t[e]||Wn,r[e])}function Nr(e,t,i){this.id=e,this.addr=i,this.cache=[],this.setValue=function(e){switch(e){case 5126:return ir;case 35664:return nr;case 35665:return rr;case 35666:return or;case 35674:return ar;case 35675:return sr;case 35676:return lr;case 5124:case 35670:return cr;case 35667:case 35671:return hr;case 35668:case 35672:return dr;case 35669:case 35673:return ur;case 5125:return pr;case 36294:return gr;case 36295:return fr;case 36296:return mr;case 35678:case 36198:case 36298:case 36306:case 35682:return Ar;case 35679:case 36299:case 36307:return yr;case 35680:case 36300:case 36308:case 36293:return vr;case 36289:case 36303:case 36311:case 36292:return Cr}}(t.type)}function Pr(e,t,i){this.id=e,this.addr=i,this.cache=[],this.size=t.size,this.setValue=function(e){switch(e){case 5126:return Ir;case 35664:return xr;case 35665:return wr;case 35666:return Mr;case 35674:return Er;case 35675:return Br;case 35676:return Sr;case 5124:case 35670:return br;case 35667:case 35671:return kr;case 35668:case 35672:return Dr;case 35669:case 35673:return Tr;case 5125:return Rr;case 36294:return Ur;case 36295:return Fr;case 36296:return Qr;case 35678:case 36198:case 36298:case 36306:case 35682:return Lr;case 35680:case 36300:case 36308:case 36293:return Or}}(t.type)}function Gr(e){this.id=e,this.seq=[],this.map={}}Pr.prototype.updateCache=function(e){const t=this.cache;e instanceof Float32Array&&t.length!==e.length&&(this.cache=new Float32Array(e.length)),er(t,e)},Gr.prototype.setValue=function(e,t,i){const n=this.seq;for(let r=0,o=n.length;r!==o;++r){const o=n[r];o.setValue(e,t[o.id],i)}};const Kr=/(\w+)(\])?(\[|\.)?/g;function Vr(e,t){e.seq.push(t),e.map[t.id]=t}function Yr(e,t,i){const n=e.name,r=n.length;for(Kr.lastIndex=0;;){const o=Kr.exec(n),a=Kr.lastIndex;let s=o[1];const l=o[3];if("]"===o[2]&&(s|=0),void 0===l||"["===l&&a+2===r){Vr(i,void 0===l?new Nr(s,e,t):new Pr(s,e,t));break}{let e=i.map[s];void 0===e&&(e=new Gr(s),Vr(i,e)),i=e}}}function Hr(e,t){this.seq=[],this.map={};const i=e.getProgramParameter(t,35718);for(let n=0;i>n;++n){const i=e.getActiveUniform(t,n);Yr(i,e.getUniformLocation(t,i.name),this)}}function jr(e,t,i){const n=e.createShader(t);return e.shaderSource(n,i),e.compileShader(n),n}Hr.prototype.setValue=function(e,t,i,n){const r=this.map[t];void 0!==r&&r.setValue(e,i,n)},Hr.prototype.setOptional=function(e,t,i){const n=t[i];void 0!==n&&this.setValue(e,i,n)},Hr.upload=function(e,t,i,n){for(let r=0,o=t.length;r!==o;++r){const o=t[r],a=i[o.id];!1!==a.needsUpdate&&o.setValue(e,a.value,n)}},Hr.seqWithValue=function(e,t){const i=[];for(let n=0,r=e.length;n!==r;++n){const r=e[n];r.id in t&&i.push(r)}return i};let Wr=0;function Jr(e){switch(e){case X:return["Linear","( value )"];case _:return["sRGB","( value )"];case ee:return["RGBE","( value )"];case te:return["RGBM","( value, 7.0 )"];case ie:return["RGBM","( value, 16.0 )"];case ne:return["RGBD","( value, 256.0 )"];case $:return["Gamma","( value, float( GAMMA_FACTOR ) )"];case 3003:return["LogLuv","( value )"];default:return console.warn("THREE.WebGLProgram: Unsupported encoding:",e),["Linear","( value )"]}}function zr(e,t,i){const n=e.getShaderParameter(t,35713),r=e.getShaderInfoLog(t).trim();if(n&&""===r)return"";return"THREE.WebGLShader: gl.getShaderInfoLog() "+i+"\n"+r+function(e){const t=e.split("\n");for(let e=0;t.length>e;e++)t[e]=e+1+": "+t[e];return t.join("\n")}(e.getShaderSource(t))}function qr(e,t){const i=Jr(t);return"vec4 "+e+"( vec4 value ) { return "+i[0]+"ToLinear"+i[1]+"; }"}function Zr(e,t){const i=Jr(t);return"vec4 "+e+"( vec4 value ) { return LinearTo"+i[0]+i[1]+"; }"}function Xr(e,t){let i;switch(t){case 1:i="Linear";break;case 2:i="Reinhard";break;case 3:i="OptimizedCineon";break;case 4:i="ACESFilmic";break;case 5:i="Custom";break;default:console.warn("THREE.WebGLProgram: Unsupported toneMapping:",t),i="Linear"}return"vec3 "+e+"( vec3 color ) { return "+i+"ToneMapping( color ); }"}function _r(e){return""!==e}function $r(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 eo(e,t){return e.replace(/NUM_CLIPPING_PLANES/g,t.numClippingPlanes).replace(/UNION_CLIPPING_PLANES/g,t.numClippingPlanes-t.numClipIntersection)}const to=/^[ \t]*#include +<([\w\d./]+)>/gm;function io(e){return e.replace(to,no)}function no(e,t){const i=xn[t];if(void 0===i)throw new Error("Can not resolve #include <"+t+">");return io(i)}const ro=/#pragma unroll_loop[\s]+?for \( int i \= (\d+)\; i < (\d+)\; i \+\+ \) \{([\s\S]+?)(?=\})\}/g,oo=/#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 ao(e){return e.replace(oo,lo).replace(ro,so)}function so(e,t,i,n){return console.warn("WebGLProgram: #pragma unroll_loop shader syntax is deprecated. Please use #pragma unroll_loop_start syntax instead."),lo(e,t,i,n)}function lo(e,t,i,n){let r="";for(let e=parseInt(t);e<parseInt(i);e++)r+=n.replace(/\[\s*i\s*\]/g,"[ "+e+" ]").replace(/UNROLLED_LOOP_INDEX/g,e);return r}function co(e){let 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 ho(e,t,i,n){const r=e.getContext(),o=i.defines;let a=i.vertexShader,s=i.fragmentShader;const h=function(e){let t="SHADOWMAP_TYPE_BASIC";return 1===e.shadowMapType?t="SHADOWMAP_TYPE_PCF":2===e.shadowMapType?t="SHADOWMAP_TYPE_PCF_SOFT":3===e.shadowMapType&&(t="SHADOWMAP_TYPE_VSM"),t}(i),d=function(e){let t="ENVMAP_TYPE_CUBE";if(e.envMap)switch(e.envMapMode){case l:case c:t="ENVMAP_TYPE_CUBE";break;case u:case p:t="ENVMAP_TYPE_CUBE_UV"}return t}(i),g=function(e){let t="ENVMAP_MODE_REFLECTION";if(e.envMap)switch(e.envMapMode){case c:case p:t="ENVMAP_MODE_REFRACTION"}return t}(i),f=function(e){let t="ENVMAP_BLENDING_NONE";if(e.envMap)switch(e.combine){case 0:t="ENVMAP_BLENDING_MULTIPLY";break;case 1:t="ENVMAP_BLENDING_MIX";break;case 2:t="ENVMAP_BLENDING_ADD"}return t}(i),m=e.gammaFactor>0?e.gammaFactor:1,A=i.isWebGL2?"":function(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.transmission>0)&&e.rendererExtensionShaderTextureLod?"#extension GL_EXT_shader_texture_lod : enable":""].filter(_r).join("\n")}(i),y=function(e){const t=[];for(const i in e){const n=e[i];!1!==n&&t.push("#define "+i+" "+n)}return t.join("\n")}(o),v=r.createProgram();let C,I,x=i.glslVersion?"#version "+i.glslVersion+"\n":"";i.isRawShaderMaterial?(C=[y].filter(_r).join("\n"),C.length>0&&(C+="\n"),I=[A,y].filter(_r).join("\n"),I.length>0&&(I+="\n")):(C=[co(i),"#define SHADER_NAME "+i.shaderName,y,i.instancing?"#define USE_INSTANCING":"",i.instancingColor?"#define USE_INSTANCING_COLOR":"",i.supportsVertexTextures?"#define VERTEX_TEXTURES":"","#define GAMMA_FACTOR "+m,"#define MAX_BONES "+i.maxBones,i.useFog&&i.fog?"#define USE_FOG":"",i.useFog&&i.fogExp2?"#define FOG_EXP2":"",i.map?"#define USE_MAP":"",i.envMap?"#define USE_ENVMAP":"",i.envMap?"#define "+g:"",i.lightMap?"#define USE_LIGHTMAP":"",i.aoMap?"#define USE_AOMAP":"",i.emissiveMap?"#define USE_EMISSIVEMAP":"",i.bumpMap?"#define USE_BUMPMAP":"",i.normalMap?"#define USE_NORMALMAP":"",i.normalMap&&i.objectSpaceNormalMap?"#define OBJECTSPACE_NORMALMAP":"",i.normalMap&&i.tangentSpaceNormalMap?"#define TANGENTSPACE_NORMALMAP":"",i.clearcoatMap?"#define USE_CLEARCOATMAP":"",i.clearcoatRoughnessMap?"#define USE_CLEARCOAT_ROUGHNESSMAP":"",i.clearcoatNormalMap?"#define USE_CLEARCOAT_NORMALMAP":"",i.displacementMap&&i.supportsVertexTextures?"#define USE_DISPLACEMENTMAP":"",i.specularMap?"#define USE_SPECULARMAP":"",i.roughnessMap?"#define USE_ROUGHNESSMAP":"",i.metalnessMap?"#define USE_METALNESSMAP":"",i.alphaMap?"#define USE_ALPHAMAP":"",i.transmission?"#define USE_TRANSMISSION":"",i.transmissionMap?"#define USE_TRANSMISSIONMAP":"",i.thicknessMap?"#define USE_THICKNESSMAP":"",i.vertexTangents?"#define USE_TANGENT":"",i.vertexColors?"#define USE_COLOR":"",i.vertexAlphas?"#define USE_COLOR_ALPHA":"",i.vertexUvs?"#define USE_UV":"",i.uvsVertexOnly?"#define UVS_VERTEX_ONLY":"",i.flatShading?"#define FLAT_SHADED":"",i.skinning?"#define USE_SKINNING":"",i.useVertexTexture?"#define BONE_TEXTURE":"",i.morphTargets?"#define USE_MORPHTARGETS":"",i.morphNormals&&!1===i.flatShading?"#define USE_MORPHNORMALS":"",i.doubleSided?"#define DOUBLE_SIDED":"",i.flipSided?"#define FLIP_SIDED":"",i.shadowMapEnabled?"#define USE_SHADOWMAP":"",i.shadowMapEnabled?"#define "+h:"",i.sizeAttenuation?"#define USE_SIZEATTENUATION":"",i.logarithmicDepthBuffer?"#define USE_LOGDEPTHBUF":"",i.logarithmicDepthBuffer&&i.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","#if defined( USE_COLOR_ALPHA )","\tattribute vec4 color;","#elif defined( 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(_r).join("\n"),I=[A,co(i),"#define SHADER_NAME "+i.shaderName,y,i.alphaTest?"#define ALPHATEST "+i.alphaTest+(i.alphaTest%1?"":".0"):"","#define GAMMA_FACTOR "+m,i.useFog&&i.fog?"#define USE_FOG":"",i.useFog&&i.fogExp2?"#define FOG_EXP2":"",i.map?"#define USE_MAP":"",i.matcap?"#define USE_MATCAP":"",i.envMap?"#define USE_ENVMAP":"",i.envMap?"#define "+d:"",i.envMap?"#define "+g:"",i.envMap?"#define "+f:"",i.lightMap?"#define USE_LIGHTMAP":"",i.aoMap?"#define USE_AOMAP":"",i.emissiveMap?"#define USE_EMISSIVEMAP":"",i.bumpMap?"#define USE_BUMPMAP":"",i.normalMap?"#define USE_NORMALMAP":"",i.normalMap&&i.objectSpaceNormalMap?"#define OBJECTSPACE_NORMALMAP":"",i.normalMap&&i.tangentSpaceNormalMap?"#define TANGENTSPACE_NORMALMAP":"",i.clearcoatMap?"#define USE_CLEARCOATMAP":"",i.clearcoatRoughnessMap?"#define USE_CLEARCOAT_ROUGHNESSMAP":"",i.clearcoatNormalMap?"#define USE_CLEARCOAT_NORMALMAP":"",i.specularMap?"#define USE_SPECULARMAP":"",i.roughnessMap?"#define USE_ROUGHNESSMAP":"",i.metalnessMap?"#define USE_METALNESSMAP":"",i.alphaMap?"#define USE_ALPHAMAP":"",i.sheen?"#define USE_SHEEN":"",i.transmission?"#define USE_TRANSMISSION":"",i.transmissionMap?"#define USE_TRANSMISSIONMAP":"",i.thicknessMap?"#define USE_THICKNESSMAP":"",i.vertexTangents?"#define USE_TANGENT":"",i.vertexColors||i.instancingColor?"#define USE_COLOR":"",i.vertexAlphas?"#define USE_COLOR_ALPHA":"",i.vertexUvs?"#define USE_UV":"",i.uvsVertexOnly?"#define UVS_VERTEX_ONLY":"",i.gradientMap?"#define USE_GRADIENTMAP":"",i.flatShading?"#define FLAT_SHADED":"",i.doubleSided?"#define DOUBLE_SIDED":"",i.flipSided?"#define FLIP_SIDED":"",i.shadowMapEnabled?"#define USE_SHADOWMAP":"",i.shadowMapEnabled?"#define "+h:"",i.premultipliedAlpha?"#define PREMULTIPLIED_ALPHA":"",i.physicallyCorrectLights?"#define PHYSICALLY_CORRECT_LIGHTS":"",i.logarithmicDepthBuffer?"#define USE_LOGDEPTHBUF":"",i.logarithmicDepthBuffer&&i.rendererExtensionFragDepth?"#define USE_LOGDEPTHBUF_EXT":"",(i.extensionShaderTextureLOD||i.envMap)&&i.rendererExtensionShaderTextureLod?"#define TEXTURE_LOD_EXT":"","uniform mat4 viewMatrix;","uniform vec3 cameraPosition;","uniform bool isOrthographic;",0!==i.toneMapping?"#define TONE_MAPPING":"",0!==i.toneMapping?xn.tonemapping_pars_fragment:"",0!==i.toneMapping?Xr("toneMapping",i.toneMapping):"",i.dithering?"#define DITHERING":"",xn.encodings_pars_fragment,i.map?qr("mapTexelToLinear",i.mapEncoding):"",i.matcap?qr("matcapTexelToLinear",i.matcapEncoding):"",i.envMap?qr("envMapTexelToLinear",i.envMapEncoding):"",i.emissiveMap?qr("emissiveMapTexelToLinear",i.emissiveMapEncoding):"",i.lightMap?qr("lightMapTexelToLinear",i.lightMapEncoding):"",Zr("linearToOutputTexel",i.outputEncoding),i.depthPacking?"#define DEPTH_PACKING "+i.depthPacking:"","\n"].filter(_r).join("\n")),a=io(a),a=$r(a,i),a=eo(a,i),s=io(s),s=$r(s,i),s=eo(s,i),a=ao(a),s=ao(s),i.isWebGL2&&!0!==i.isRawShaderMaterial&&(x="#version 300 es\n",C=["#define attribute in","#define varying out","#define texture2D texture"].join("\n")+"\n"+C,I=["#define varying in",i.glslVersion===fe?"":"out highp vec4 pc_fragColor;",i.glslVersion===fe?"":"#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"+I);const w=x+I+s,M=jr(r,35633,x+C+a),E=jr(r,35632,w);if(r.attachShader(v,M),r.attachShader(v,E),void 0!==i.index0AttributeName?r.bindAttribLocation(v,0,i.index0AttributeName):!0===i.morphTargets&&r.bindAttribLocation(v,0,"position"),r.linkProgram(v),e.debug.checkShaderErrors){const e=r.getProgramInfoLog(v).trim(),t=r.getShaderInfoLog(M).trim(),i=r.getShaderInfoLog(E).trim();let n=!0,o=!0;if(!1===r.getProgramParameter(v,35714)){n=!1;const t=zr(r,M,"vertex"),i=zr(r,E,"fragment");console.error("THREE.WebGLProgram: shader error: ",r.getError(),"35715",r.getProgramParameter(v,35715),"gl.getProgramInfoLog",e,t,i)}else""!==e?console.warn("THREE.WebGLProgram: gl.getProgramInfoLog()",e):""!==t&&""!==i||(o=!1);o&&(this.diagnostics={runnable:n,programLog:e,vertexShader:{log:t,prefix:C},fragmentShader:{log:i,prefix:I}})}let B,S;return r.deleteShader(M),r.deleteShader(E),this.getUniforms=function(){return void 0===B&&(B=new Hr(r,v)),B},this.getAttributes=function(){return void 0===S&&(S=function(e,t){const i={},n=e.getProgramParameter(t,35721);for(let r=0;n>r;r++){const n=e.getActiveAttrib(t,r).name;i[n]=e.getAttribLocation(t,n)}return i}(r,v)),S},this.destroy=function(){n.releaseStatesOfProgram(this),r.deleteProgram(v),this.program=void 0},this.name=i.shaderName,this.id=Wr++,this.cacheKey=t,this.usedTimes=1,this.program=v,this.vertexShader=M,this.fragmentShader=E,this}function uo(e,t,i,n,r,o){const a=[],s=n.isWebGL2,l=n.logarithmicDepthBuffer,c=n.floatVertexTextures,h=n.maxVertexUniforms,d=n.vertexTextures;let g=n.precision;const f={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"},m=["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","vertexAlphas","vertexTangents","vertexUvs","uvsVertexOnly","fog","useFog","fogExp2","flatShading","sizeAttenuation","logarithmicDepthBuffer","skinning","maxBones","useVertexTexture","morphTargets","morphNormals","premultipliedAlpha","numDirLights","numPointLights","numSpotLights","numHemiLights","numRectAreaLights","numDirLightShadows","numPointLightShadows","numSpotLightShadows","shadowMapEnabled","shadowMapType","toneMapping","physicallyCorrectLights","alphaTest","doubleSided","flipSided","numClippingPlanes","numClipIntersection","depthPacking","dithering","sheen","transmission","transmissionMap","thicknessMap"];function A(e){let 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=X,t}return{getParameters:function(r,a,m,y,v){const C=y.fog,I=t.get(r.envMap||(r.isMeshStandardMaterial?y.environment:null)),x=f[r.type],w=v.isSkinnedMesh?function(e){const t=e.skeleton.bones;if(c)return 1024;{const e=Math.floor((h-20)/4),i=Math.min(e,t.length);return t.length>i?(console.warn("THREE.WebGLRenderer: Skeleton has "+t.length+" bones. This GPU supports "+i+"."),0):i}}(v):0;let M,E;if(null!==r.precision&&(g=n.getMaxPrecision(r.precision),g!==r.precision&&console.warn("THREE.WebGLProgram.getParameters:",r.precision,"not supported, using",g,"instead.")),x){const e=Mn[x];M=e.vertexShader,E=e.fragmentShader}else M=r.vertexShader,E=r.fragmentShader;const B=e.getRenderTarget();return{isWebGL2:s,shaderID:x,shaderName:r.type,vertexShader:M,fragmentShader:E,defines:r.defines,isRawShaderMaterial:!0===r.isRawShaderMaterial,glslVersion:r.glslVersion,precision:g,instancing:!0===v.isInstancedMesh,instancingColor:!0===v.isInstancedMesh&&null!==v.instanceColor,supportsVertexTextures:d,outputEncoding:null!==B?A(B.texture):e.outputEncoding,map:!!r.map,mapEncoding:A(r.map),matcap:!!r.matcap,matcapEncoding:A(r.matcap),envMap:!!I,envMapMode:I&&I.mapping,envMapEncoding:A(I),envMapCubeUV:!!I&&(I.mapping===u||I.mapping===p),lightMap:!!r.lightMap,lightMapEncoding:A(r.lightMap),aoMap:!!r.aoMap,emissiveMap:!!r.emissiveMap,emissiveMapEncoding:A(r.emissiveMap),bumpMap:!!r.bumpMap,normalMap:!!r.normalMap,objectSpaceNormalMap:1===r.normalMapType,tangentSpaceNormalMap:0===r.normalMapType,clearcoatMap:!!r.clearcoatMap,clearcoatRoughnessMap:!!r.clearcoatRoughnessMap,clearcoatNormalMap:!!r.clearcoatNormalMap,displacementMap:!!r.displacementMap,roughnessMap:!!r.roughnessMap,metalnessMap:!!r.metalnessMap,specularMap:!!r.specularMap,alphaMap:!!r.alphaMap,gradientMap:!!r.gradientMap,sheen:!!r.sheen,transmission:!!r.transmission,transmissionMap:!!r.transmissionMap,thicknessMap:!!r.thicknessMap,combine:r.combine,vertexTangents:r.normalMap&&r.vertexTangents,vertexColors:r.vertexColors,vertexAlphas:!0===r.vertexColors&&v.geometry&&v.geometry.attributes.color&&4===v.geometry.attributes.color.itemSize,vertexUvs:!!(r.map||r.bumpMap||r.normalMap||r.specularMap||r.alphaMap||r.emissiveMap||r.roughnessMap||r.metalnessMap||r.clearcoatMap||r.clearcoatRoughnessMap||r.clearcoatNormalMap||r.displacementMap||r.transmission||r.transmissionMap||r.thicknessMap),uvsVertexOnly:!(r.map||r.bumpMap||r.normalMap||r.specularMap||r.alphaMap||r.emissiveMap||r.roughnessMap||r.metalnessMap||r.clearcoatNormalMap||r.transmission||r.transmissionMap||r.thicknessMap||!r.displacementMap),fog:!!C,useFog:r.fog,fogExp2:C&&C.isFogExp2,flatShading:!!r.flatShading,sizeAttenuation:r.sizeAttenuation,logarithmicDepthBuffer:l,skinning:!0===v.isSkinnedMesh&&w>0,maxBones:w,useVertexTexture:c,morphTargets:r.morphTargets,morphNormals:r.morphNormals,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:r.dithering,shadowMapEnabled:e.shadowMap.enabled&&m.length>0,shadowMapType:e.shadowMap.type,toneMapping:r.toneMapped?e.toneMapping:0,physicallyCorrectLights:e.physicallyCorrectLights,premultipliedAlpha:r.premultipliedAlpha,alphaTest:r.alphaTest,doubleSided:2===r.side,flipSided:1===r.side,depthPacking:void 0!==r.depthPacking&&r.depthPacking,index0AttributeName:r.index0AttributeName,extensionDerivatives:r.extensions&&r.extensions.derivatives,extensionFragDepth:r.extensions&&r.extensions.fragDepth,extensionDrawBuffers:r.extensions&&r.extensions.drawBuffers,extensionShaderTextureLOD:r.extensions&&r.extensions.shaderTextureLOD,rendererExtensionFragDepth:s||i.has("EXT_frag_depth"),rendererExtensionDrawBuffers:s||i.has("WEBGL_draw_buffers"),rendererExtensionShaderTextureLod:s||i.has("EXT_shader_texture_lod"),customProgramCacheKey:r.customProgramCacheKey()}},getProgramCacheKey:function(t){const i=[];if(t.shaderID?i.push(t.shaderID):(i.push(t.fragmentShader),i.push(t.vertexShader)),void 0!==t.defines)for(const e in t.defines)i.push(e),i.push(t.defines[e]);if(!1===t.isRawShaderMaterial){for(let e=0;m.length>e;e++)i.push(t[m[e]]);i.push(e.outputEncoding),i.push(e.gammaFactor)}return i.push(t.customProgramCacheKey),i.join()},getUniforms:function(e){const t=f[e.type];let i;if(t){i=ln.clone(Mn[t].uniforms)}else i=e.uniforms;return i},acquireProgram:function(t,i){let n;for(let e=0,t=a.length;t>e;e++){const t=a[e];if(t.cacheKey===i){n=t,++n.usedTimes;break}}return void 0===n&&(n=new ho(e,i,t,r),a.push(n)),n},releaseProgram:function(e){if(0==--e.usedTimes){const t=a.indexOf(e);a[t]=a[a.length-1],a.pop(),e.destroy()}},programs:a}}function po(){let e=new WeakMap;return{get:function(t){let i=e.get(t);return void 0===i&&(i={},e.set(t,i)),i},remove:function(t){e.delete(t)},update:function(t,i,n){e.get(t)[i]=n},dispose:function(){e=new WeakMap}}}function go(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 fo(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 mo(e){const t=[];let i=0;const n=[],r=[],o=[],a={id:-1};function s(n,r,o,s,l,c){let h=t[i];const d=e.get(o);return void 0===h?(h={id:n.id,object:n,geometry:r,material:o,program:d.program||a,groupOrder:s,renderOrder:n.renderOrder,z:l,group:c},t[i]=h):(h.id=n.id,h.object=n,h.geometry=r,h.material=o,h.program=d.program||a,h.groupOrder=s,h.renderOrder=n.renderOrder,h.z=l,h.group=c),i++,h}return{opaque:n,transmissive:r,transparent:o,init:function(){i=0,n.length=0,r.length=0,o.length=0},push:function(e,t,i,a,l,c){const h=s(e,t,i,a,l,c);i.transmission>0?r.push(h):!0===i.transparent?o.push(h):n.push(h)},unshift:function(e,t,i,a,l,c){const h=s(e,t,i,a,l,c);i.transmission>0?r.unshift(h):!0===i.transparent?o.unshift(h):n.unshift(h)},finish:function(){for(let e=i,n=t.length;n>e;e++){const 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}},sort:function(e,t){n.length>1&&n.sort(e||go),r.length>1&&r.sort(t||fo),o.length>1&&o.sort(t||fo)}}}function Ao(e){let t=new WeakMap;return{get:function(i,n){let r;return!1===t.has(i)?(r=new mo(e),t.set(i,[r])):n<t.get(i).length?r=t.get(i)[n]:(r=new mo(e),t.get(i).push(r)),r},dispose:function(){t=new WeakMap}}}function yo(){const e={};return{get:function(t){if(void 0!==e[t.id])return e[t.id];let i;switch(t.type){case"DirectionalLight":i={direction:new Ke,color:new pi};break;case"SpotLight":i={position:new Ke,direction:new Ke,color:new pi,distance:0,coneCos:0,penumbraCos:0,decay:0};break;case"PointLight":i={position:new Ke,color:new pi,distance:0,decay:0};break;case"HemisphereLight":i={direction:new Ke,skyColor:new pi,groundColor:new pi};break;case"RectAreaLight":i={color:new pi,position:new Ke,halfWidth:new Ke,halfHeight:new Ke}}return e[t.id]=i,i}}}let vo=0;function Co(e,t){return(t.castShadow?1:0)-(e.castShadow?1:0)}function Io(e,t){const i=new yo,n=function(){const e={};return{get:function(t){if(void 0!==e[t.id])return e[t.id];let i;switch(t.type){case"DirectionalLight":case"SpotLight":i={shadowBias:0,shadowNormalBias:0,shadowRadius:1,shadowMapSize:new ke};break;case"PointLight":i={shadowBias:0,shadowNormalBias:0,shadowRadius:1,shadowMapSize:new ke,shadowCameraNear:1,shadowCameraFar:1e3}}return e[t.id]=i,i}}}(),r={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:[]};for(let e=0;9>e;e++)r.probe.push(new Ke);const o=new Ke,a=new yt,s=new yt;return{setup:function(o){let a=0,s=0,l=0;for(let e=0;9>e;e++)r.probe[e].set(0,0,0);let c=0,h=0,d=0,u=0,p=0,g=0,f=0,m=0;o.sort(Co);for(let e=0,t=o.length;t>e;e++){const t=o[e],A=t.color,y=t.intensity,v=t.distance,C=t.shadow&&t.shadow.map?t.shadow.map.texture:null;if(t.isAmbientLight)a+=A.r*y,s+=A.g*y,l+=A.b*y;else if(t.isLightProbe)for(let e=0;9>e;e++)r.probe[e].addScaledVector(t.sh.coefficients[e],y);else if(t.isDirectionalLight){const e=i.get(t);if(e.color.copy(t.color).multiplyScalar(t.intensity),t.castShadow){const e=t.shadow,i=n.get(t);i.shadowBias=e.bias,i.shadowNormalBias=e.normalBias,i.shadowRadius=e.radius,i.shadowMapSize=e.mapSize,r.directionalShadow[c]=i,r.directionalShadowMap[c]=C,r.directionalShadowMatrix[c]=t.shadow.matrix,g++}r.directional[c]=e,c++}else if(t.isSpotLight){const e=i.get(t);if(e.position.setFromMatrixPosition(t.matrixWorld),e.color.copy(A).multiplyScalar(y),e.distance=v,e.coneCos=Math.cos(t.angle),e.penumbraCos=Math.cos(t.angle*(1-t.penumbra)),e.decay=t.decay,t.castShadow){const e=t.shadow,i=n.get(t);i.shadowBias=e.bias,i.shadowNormalBias=e.normalBias,i.shadowRadius=e.radius,i.shadowMapSize=e.mapSize,r.spotShadow[d]=i,r.spotShadowMap[d]=C,r.spotShadowMatrix[d]=t.shadow.matrix,m++}r.spot[d]=e,d++}else if(t.isRectAreaLight){const e=i.get(t);e.color.copy(A).multiplyScalar(y),e.halfWidth.set(.5*t.width,0,0),e.halfHeight.set(0,.5*t.height,0),r.rectArea[u]=e,u++}else if(t.isPointLight){const e=i.get(t);if(e.color.copy(t.color).multiplyScalar(t.intensity),e.distance=t.distance,e.decay=t.decay,t.castShadow){const e=t.shadow,i=n.get(t);i.shadowBias=e.bias,i.shadowNormalBias=e.normalBias,i.shadowRadius=e.radius,i.shadowMapSize=e.mapSize,i.shadowCameraNear=e.camera.near,i.shadowCameraFar=e.camera.far,r.pointShadow[h]=i,r.pointShadowMap[h]=C,r.pointShadowMatrix[h]=t.shadow.matrix,f++}r.point[h]=e,h++}else if(t.isHemisphereLight){const e=i.get(t);e.skyColor.copy(t.color).multiplyScalar(y),e.groundColor.copy(t.groundColor).multiplyScalar(y),r.hemi[p]=e,p++}}u>0&&(t.isWebGL2||!0===e.has("OES_texture_float_linear")?(r.rectAreaLTC1=wn.LTC_FLOAT_1,r.rectAreaLTC2=wn.LTC_FLOAT_2):!0===e.has("OES_texture_half_float_linear")?(r.rectAreaLTC1=wn.LTC_HALF_1,r.rectAreaLTC2=wn.LTC_HALF_2):console.error("THREE.WebGLRenderer: Unable to use RectAreaLight. Missing WebGL extensions.")),r.ambient[0]=a,r.ambient[1]=s,r.ambient[2]=l;const A=r.hash;A.directionalLength===c&&A.pointLength===h&&A.spotLength===d&&A.rectAreaLength===u&&A.hemiLength===p&&A.numDirectionalShadows===g&&A.numPointShadows===f&&A.numSpotShadows===m||(r.directional.length=c,r.spot.length=d,r.rectArea.length=u,r.point.length=h,r.hemi.length=p,r.directionalShadow.length=g,r.directionalShadowMap.length=g,r.pointShadow.length=f,r.pointShadowMap.length=f,r.spotShadow.length=m,r.spotShadowMap.length=m,r.directionalShadowMatrix.length=g,r.pointShadowMatrix.length=f,r.spotShadowMatrix.length=m,A.directionalLength=c,A.pointLength=h,A.spotLength=d,A.rectAreaLength=u,A.hemiLength=p,A.numDirectionalShadows=g,A.numPointShadows=f,A.numSpotShadows=m,r.version=vo++)},setupView:function(e,t){let i=0,n=0,l=0,c=0,h=0;const d=t.matrixWorldInverse;for(let t=0,u=e.length;u>t;t++){const u=e[t];if(u.isDirectionalLight){const e=r.directional[i];e.direction.setFromMatrixPosition(u.matrixWorld),o.setFromMatrixPosition(u.target.matrixWorld),e.direction.sub(o),e.direction.transformDirection(d),i++}else if(u.isSpotLight){const e=r.spot[l];e.position.setFromMatrixPosition(u.matrixWorld),e.position.applyMatrix4(d),e.direction.setFromMatrixPosition(u.matrixWorld),o.setFromMatrixPosition(u.target.matrixWorld),e.direction.sub(o),e.direction.transformDirection(d),l++}else if(u.isRectAreaLight){const e=r.rectArea[c];e.position.setFromMatrixPosition(u.matrixWorld),e.position.applyMatrix4(d),s.identity(),a.copy(u.matrixWorld),a.premultiply(d),s.extractRotation(a),e.halfWidth.set(.5*u.width,0,0),e.halfHeight.set(0,.5*u.height,0),e.halfWidth.applyMatrix4(s),e.halfHeight.applyMatrix4(s),c++}else if(u.isPointLight){const e=r.point[n];e.position.setFromMatrixPosition(u.matrixWorld),e.position.applyMatrix4(d),n++}else if(u.isHemisphereLight){const e=r.hemi[h];e.direction.setFromMatrixPosition(u.matrixWorld),e.direction.transformDirection(d),e.direction.normalize(),h++}}},state:r}}function xo(e,t){const i=new Io(e,t),n=[],r=[];return{init:function(){n.length=0,r.length=0},state:{lightsArray:n,shadowsArray:r,lights:i},setupLights:function(){i.setup(n)},setupLightsView:function(e){i.setupView(n,e)},pushLight:function(e){n.push(e)},pushShadow:function(e){r.push(e)}}}function wo(e,t){let i=new WeakMap;return{get:function(n,r=0){let o;return!1===i.has(n)?(o=new xo(e,t),i.set(n,[o])):r<i.get(n).length?o=i.get(n)[r]:(o=new xo(e,t),i.get(n).push(o)),o},dispose:function(){i=new WeakMap}}}class Mo extends ai{constructor(e){super(),this.type="MeshDepthMaterial",this.depthPacking=3200,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)}copy(e){return super.copy(e),this.depthPacking=e.depthPacking,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}}Mo.prototype.isMeshDepthMaterial=!0;class Eo extends ai{constructor(e){super(),this.type="MeshDistanceMaterial",this.referencePosition=new Ke,this.nearDistance=1,this.farDistance=1e3,this.morphTargets=!1,this.map=null,this.alphaMap=null,this.displacementMap=null,this.displacementScale=1,this.displacementBias=0,this.fog=!1,this.setValues(e)}copy(e){return super.copy(e),this.referencePosition.copy(e.referencePosition),this.nearDistance=e.nearDistance,this.farDistance=e.farDistance,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}}Eo.prototype.isMeshDistanceMaterial=!0;function Bo(e,t,i){let n=new yn;const r=new ke,o=new ke,a=new Le,s=[],l=[],c={},h=i.maxTextureSize,d={0:1,1:0,2:2},u=new cn({defines:{SAMPLE_RATE:2/8,HALF_SAMPLE_RATE:1/8},uniforms:{shadow_pass:{value:null},resolution:{value:new ke},radius:{value:4}},vertexShader:"void main() {\n\tgl_Position = vec4( position, 1.0 );\n}",fragmentShader:"uniform sampler2D shadow_pass;\nuniform vec2 resolution;\nuniform float radius;\n#include <packing>\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}"}),p=u.clone();p.defines.HORIZONTAL_PASS=1;const g=new Ni;g.setAttribute("position",new Ai(new Float32Array([-1,-1,.5,3,-1,.5,-1,3,.5]),3));const f=new nn(g,u),m=this;function y(i,n){const r=t.update(f);u.uniforms.shadow_pass.value=i.map.texture,u.uniforms.resolution.value=i.mapSize,u.uniforms.radius.value=i.radius,e.setRenderTarget(i.mapPass),e.clear(),e.renderBufferDirect(n,null,r,u,f,null),p.uniforms.shadow_pass.value=i.mapPass.texture,p.uniforms.resolution.value=i.mapSize,p.uniforms.radius.value=i.radius,e.setRenderTarget(i.map),e.clear(),e.renderBufferDirect(n,null,r,p,f,null)}function v(e){const t=e<<0;let i=s[t];return void 0===i&&(i=new Mo({depthPacking:re,morphTargets:e}),s[t]=i),i}function I(e){const t=e<<0;let i=l[t];return void 0===i&&(i=new Eo({morphTargets:e}),l[t]=i),i}function x(t,i,n,r,o,a,s){let l=null,h=v,u=t.customDepthMaterial;if(!0===r.isPointLight&&(h=I,u=t.customDistanceMaterial),void 0===u){let e=!1;!0===n.morphTargets&&(e=i.morphAttributes&&i.morphAttributes.position&&i.morphAttributes.position.length>0),l=h(e)}else l=u;if(e.localClippingEnabled&&!0===n.clipShadows&&0!==n.clippingPlanes.length){const e=l.uuid,t=n.uuid;let i=c[e];void 0===i&&(i={},c[e]=i);let r=i[t];void 0===r&&(r=l.clone(),i[t]=r),l=r}return l.visible=n.visible,l.wireframe=n.wireframe,l.side=3===s?null!==n.shadowSide?n.shadowSide:n.side:null!==n.shadowSide?n.shadowSide:d[n.side],l.clipShadows=n.clipShadows,l.clippingPlanes=n.clippingPlanes,l.clipIntersection=n.clipIntersection,l.wireframeLinewidth=n.wireframeLinewidth,l.linewidth=n.linewidth,!0===r.isPointLight&&!0===l.isMeshDistanceMaterial&&(l.referencePosition.setFromMatrixPosition(r.matrixWorld),l.nearDistance=o,l.farDistance=a),l}function w(i,r,o,a,s){if(!1===i.visible)return;if(i.layers.test(r.layers)&&(i.isMesh||i.isLine||i.isPoints)&&(i.castShadow||i.receiveShadow&&3===s)&&(!i.frustumCulled||n.intersectsObject(i))){i.modelViewMatrix.multiplyMatrices(o.matrixWorldInverse,i.matrixWorld);const n=t.update(i),r=i.material;if(Array.isArray(r)){const t=n.groups;for(let l=0,c=t.length;c>l;l++){const c=t[l],h=r[c.materialIndex];if(h&&h.visible){const t=x(i,n,h,a,o.near,o.far,s);e.renderBufferDirect(o,null,n,t,i,c)}}}else if(r.visible){const t=x(i,n,r,a,o.near,o.far,s);e.renderBufferDirect(o,null,n,t,i,null)}}const l=i.children;for(let e=0,t=l.length;t>e;e++)w(l[e],r,o,a,s)}this.enabled=!1,this.autoUpdate=!0,this.needsUpdate=!1,this.type=1,this.render=function(t,i,s){if(!1===m.enabled)return;if(!1===m.autoUpdate&&!1===m.needsUpdate)return;if(0===t.length)return;const l=e.getRenderTarget(),c=e.getActiveCubeFace(),d=e.getActiveMipmapLevel(),u=e.state;u.setBlending(0),u.buffers.color.setClear(1,1,1,1),u.buffers.depth.setTest(!0),u.setScissorTest(!1);for(let l=0,c=t.length;c>l;l++){const c=t[l],d=c.shadow;if(void 0===d){console.warn("THREE.WebGLShadowMap:",c,"has no shadow.");continue}if(!1===d.autoUpdate&&!1===d.needsUpdate)continue;r.copy(d.mapSize);const p=d.getFrameExtents();if(r.multiply(p),o.copy(d.mapSize),(r.x>h||r.y>h)&&(r.x>h&&(o.x=Math.floor(h/p.x),r.x=o.x*p.x,d.mapSize.x=o.x),r.y>h&&(o.y=Math.floor(h/p.y),r.y=o.y*p.y,d.mapSize.y=o.y)),null===d.map&&!d.isPointLightShadow&&3===this.type){const e={minFilter:C,magFilter:C,format:D};d.map=new Oe(r.x,r.y,e),d.map.texture.name=c.name+".shadowMap",d.mapPass=new Oe(r.x,r.y,e),d.camera.updateProjectionMatrix()}if(null===d.map){d.map=new Oe(r.x,r.y,{minFilter:A,magFilter:A,format:D}),d.map.texture.name=c.name+".shadowMap",d.camera.updateProjectionMatrix()}e.setRenderTarget(d.map),e.clear();const g=d.getViewportCount();for(let e=0;g>e;e++){const t=d.getViewport(e);a.set(o.x*t.x,o.y*t.y,o.x*t.z,o.y*t.w),u.viewport(a),d.updateMatrices(c,e),n=d.getFrustum(),w(i,s,d.camera,c,this.type)}d.isPointLightShadow||3!==this.type||y(d,s),d.needsUpdate=!1}m.needsUpdate=!1,e.setRenderTarget(l,c,d)}}function So(e,t,i){const n=i.isWebGL2;const s=new function(){let t=!1;const i=new Le;let n=null;const r=new Le(0,0,0,0);return{setMask:function(i){n===i||t||(e.colorMask(i,i,i,i),n=i)},setLocked:function(e){t=e},setClear:function(t,n,o,a,s){!0===s&&(t*=a,n*=a,o*=a),i.set(t,n,o,a),!1===r.equals(i)&&(e.clearColor(t,n,o,a),r.copy(i))},reset:function(){t=!1,n=null,r.set(-1,0,0,0)}}},l=new function(){let t=!1,i=null,n=null,r=null;return{setTest:function(e){e?G(2929):K(2929)},setMask:function(n){i===n||t||(e.depthMask(n),i=n)},setFunc:function(t){if(n!==t){if(t)switch(t){case 0:e.depthFunc(512);break;case 1:e.depthFunc(519);break;case 2:e.depthFunc(513);break;case 3:e.depthFunc(515);break;case 4:e.depthFunc(514);break;case 5:e.depthFunc(518);break;case 6:e.depthFunc(516);break;case 7:e.depthFunc(517);break;default:e.depthFunc(515)}else e.depthFunc(515);n=t}},setLocked:function(e){t=e},setClear:function(t){r!==t&&(e.clearDepth(t),r=t)},reset:function(){t=!1,i=null,n=null,r=null}}},c=new function(){let t=!1,i=null,n=null,r=null,o=null,a=null,s=null,l=null,c=null;return{setTest:function(e){t||(e?G(2960):K(2960))},setMask:function(n){i===n||t||(e.stencilMask(n),i=n)},setFunc:function(t,i,a){n===t&&r===i&&o===a||(e.stencilFunc(t,i,a),n=t,r=i,o=a)},setOp:function(t,i,n){a===t&&s===i&&l===n||(e.stencilOp(t,i,n),a=t,s=i,l=n)},setLocked:function(e){t=e},setClear:function(t){c!==t&&(e.clearStencil(t),c=t)},reset:function(){t=!1,i=null,n=null,r=null,o=null,a=null,s=null,l=null,c=null}}};let h={},d=null,u={},p=null,g=!1,f=null,m=null,A=null,y=null,v=null,C=null,I=null,x=!1,w=null,M=null,E=null,B=null,S=null;const b=e.getParameter(35661);let k=!1,D=0;const T=e.getParameter(7938);-1!==T.indexOf("WebGL")?(D=parseFloat(/^WebGL (\d)/.exec(T)[1]),k=D>=1):-1!==T.indexOf("OpenGL ES")&&(D=parseFloat(/^OpenGL ES (\d)/.exec(T)[1]),k=D>=2);let R=null,U={};const F=e.getParameter(3088),Q=e.getParameter(2978),L=(new Le).fromArray(F),O=(new Le).fromArray(Q);function N(t,i,n){const r=new Uint8Array(4),o=e.createTexture();e.bindTexture(t,o),e.texParameteri(t,10241,9728),e.texParameteri(t,10240,9728);for(let t=0;n>t;t++)e.texImage2D(i+t,0,6408,1,1,0,6408,5121,r);return o}const P={};function G(t){!0!==h[t]&&(e.enable(t),h[t]=!0)}function K(t){!1!==h[t]&&(e.disable(t),h[t]=!1)}P[3553]=N(3553,3553,1),P[34067]=N(34067,34069,6),s.setClear(0,0,0,1),l.setClear(1),c.setClear(0),G(2929),l.setFunc(3),j(!1),W(1),G(2884),H(0);const V={[r]:32774,101:32778,102:32779};if(n)V[103]=32775,V[104]=32776;else{const e=t.get("EXT_blend_minmax");null!==e&&(V[103]=e.MIN_EXT,V[104]=e.MAX_EXT)}const Y={[o]:0,[a]:1,202:768,204:770,210:776,208:774,206:772,203:769,205:771,209:775,207:773};function H(t,i,n,o,a,s,l,c){if(0!==t){if(!1===g&&(G(3042),g=!0),5===t)a=a||i,s=s||n,l=l||o,i===m&&a===v||(e.blendEquationSeparate(V[i],V[a]),m=i,v=a),n===A&&o===y&&s===C&&l===I||(e.blendFuncSeparate(Y[n],Y[o],Y[s],Y[l]),A=n,y=o,C=s,I=l),f=t,x=null;else if(t!==f||c!==x){if(m===r&&v===r||(e.blendEquation(32774),m=r,v=r),c)switch(t){case 1:e.blendFuncSeparate(1,771,1,771);break;case 2:e.blendFunc(1,1);break;case 3:e.blendFuncSeparate(0,0,769,771);break;case 4:e.blendFuncSeparate(0,768,0,770);break;default:console.error("THREE.WebGLState: Invalid blending: ",t)}else switch(t){case 1:e.blendFuncSeparate(770,771,1,771);break;case 2:e.blendFunc(770,1);break;case 3:e.blendFunc(0,769);break;case 4:e.blendFunc(0,768);break;default:console.error("THREE.WebGLState: Invalid blending: ",t)}A=null,y=null,C=null,I=null,f=t,x=c}}else!0===g&&(K(3042),g=!1)}function j(t){w!==t&&(e.frontFace(t?2304:2305),w=t)}function W(t){0!==t?(G(2884),t!==M&&e.cullFace(1===t?1029:2===t?1028:1032)):K(2884),M=t}function J(t,i,n){t?(G(32823),B===i&&S===n||(e.polygonOffset(i,n),B=i,S=n)):K(32823)}function z(t){void 0===t&&(t=33984+b-1),R!==t&&(e.activeTexture(t),R=t)}return{buffers:{color:s,depth:l,stencil:c},enable:G,disable:K,bindFramebuffer:function(t,i){return null===i&&null!==d&&(i=d),u[t]!==i&&(e.bindFramebuffer(t,i),u[t]=i,n&&(36009===t&&(u[36160]=i),36160===t&&(u[36009]=i)),!0)},bindXRFramebuffer:function(t){t!==d&&(e.bindFramebuffer(36160,t),d=t)},useProgram:function(t){return p!==t&&(e.useProgram(t),p=t,!0)},setBlending:H,setMaterial:function(e,t){2===e.side?K(2884):G(2884);let i=1===e.side;t&&(i=!i),j(i),1===e.blending&&!1===e.transparent?H(0):H(e.blending,e.blendEquation,e.blendSrc,e.blendDst,e.blendEquationAlpha,e.blendSrcAlpha,e.blendDstAlpha,e.premultipliedAlpha),l.setFunc(e.depthFunc),l.setTest(e.depthTest),l.setMask(e.depthWrite),s.setMask(e.colorWrite);const n=e.stencilWrite;c.setTest(n),n&&(c.setMask(e.stencilWriteMask),c.setFunc(e.stencilFunc,e.stencilRef,e.stencilFuncMask),c.setOp(e.stencilFail,e.stencilZFail,e.stencilZPass)),J(e.polygonOffset,e.polygonOffsetFactor,e.polygonOffsetUnits),!0===e.alphaToCoverage?G(32926):K(32926)},setFlipSided:j,setCullFace:W,setLineWidth:function(t){t!==E&&(k&&e.lineWidth(t),E=t)},setPolygonOffset:J,setScissorTest:function(e){e?G(3089):K(3089)},activeTexture:z,bindTexture:function(t,i){null===R&&z();let n=U[R];void 0===n&&(n={type:void 0,texture:void 0},U[R]=n),n.type===t&&n.texture===i||(e.bindTexture(t,i||P[t]),n.type=t,n.texture=i)},unbindTexture:function(){const t=U[R];void 0!==t&&void 0!==t.type&&(e.bindTexture(t.type,null),t.type=void 0,t.texture=void 0)},compressedTexImage2D:function(){try{e.compressedTexImage2D.apply(e,arguments)}catch(e){console.error("THREE.WebGLState:",e)}},texImage2D:function(){try{e.texImage2D.apply(e,arguments)}catch(e){console.error("THREE.WebGLState:",e)}},texImage3D:function(){try{e.texImage3D.apply(e,arguments)}catch(e){console.error("THREE.WebGLState:",e)}},scissor:function(t){!1===L.equals(t)&&(e.scissor(t.x,t.y,t.z,t.w),L.copy(t))},viewport:function(t){!1===O.equals(t)&&(e.viewport(t.x,t.y,t.z,t.w),O.copy(t))},reset:function(){e.disable(3042),e.disable(2884),e.disable(2929),e.disable(32823),e.disable(3089),e.disable(2960),e.disable(32926),e.blendEquation(32774),e.blendFunc(1,0),e.blendFuncSeparate(1,0,1,0),e.colorMask(!0,!0,!0,!0),e.clearColor(0,0,0,0),e.depthMask(!0),e.depthFunc(513),e.clearDepth(1),e.stencilMask(4294967295),e.stencilFunc(519,0,4294967295),e.stencilOp(7680,7680,7680),e.clearStencil(0),e.cullFace(1029),e.frontFace(2305),e.polygonOffset(0,0),e.activeTexture(33984),e.bindFramebuffer(36160,null),!0===n&&(e.bindFramebuffer(36009,null),e.bindFramebuffer(36008,null)),e.useProgram(null),e.lineWidth(1),e.scissor(0,0,e.canvas.width,e.canvas.height),e.viewport(0,0,e.canvas.width,e.canvas.height),h={},R=null,U={},d=null,u={},p=null,g=!1,f=null,m=null,A=null,y=null,v=null,C=null,I=null,x=!1,w=null,M=null,E=null,B=null,S=null,L.set(0,0,e.canvas.width,e.canvas.height),O.set(0,0,e.canvas.width,e.canvas.height),s.reset(),l.reset(),c.reset()}}}function bo(e,t,i,n,r,o,a){const s=r.isWebGL2,l=r.maxTextures,c=r.maxCubemapSize,h=r.maxTextureSize,d=r.maxSamples,u=new WeakMap;let p,w=!1;try{w="undefined"!=typeof OffscreenCanvas&&null!==new OffscreenCanvas(1,1).getContext("2d")}catch(e){}function U(e,t){return w?new OffscreenCanvas(e,t):document.createElementNS("http://www.w3.org/1999/xhtml","canvas")}function F(e,t,i,n){let r=1;if((e.width>n||e.height>n)&&(r=n/Math.max(e.width,e.height)),1>r||!0===t){if("undefined"!=typeof HTMLImageElement&&e instanceof HTMLImageElement||"undefined"!=typeof HTMLCanvasElement&&e instanceof HTMLCanvasElement||"undefined"!=typeof ImageBitmap&&e instanceof ImageBitmap){const n=t?Se:Math.floor,o=n(r*e.width),a=n(r*e.height);void 0===p&&(p=U(o,a));const s=i?U(o,a):p;s.width=o,s.height=a;return s.getContext("2d").drawImage(e,0,0,o,a),console.warn("THREE.WebGLRenderer: Texture has been resized from ("+e.width+"x"+e.height+") to ("+o+"x"+a+")."),s}return"data"in e&&console.warn("THREE.WebGLRenderer: Image in DataTexture is too big ("+e.width+"x"+e.height+")."),e}return e}function Q(e){return Ee(e.width)&&Ee(e.height)}function L(e,t){return e.generateMipmaps&&t&&e.minFilter!==A&&e.minFilter!==C}function O(t,i,r,o){e.generateMipmap(t);n.get(i).__maxMipLevel=Math.log2(Math.max(r,o))}function N(i,n,r){if(!1===s)return n;if(null!==i){if(void 0!==e[i])return e[i];console.warn("THREE.WebGLRenderer: Attempt to use non-existing WebGL internal format '"+i+"'")}let o=n;return 6403===n&&(5126===r&&(o=33326),5131===r&&(o=33325),5121===r&&(o=33321)),6407===n&&(5126===r&&(o=34837),5131===r&&(o=34843),5121===r&&(o=32849)),6408===n&&(5126===r&&(o=34836),5131===r&&(o=34842),5121===r&&(o=32856)),33325!==o&&33326!==o&&34842!==o&&34836!==o||t.get("EXT_color_buffer_float"),o}function P(e){return e===A||e===y||e===v?9728:9729}function G(t){const i=t.target;i.removeEventListener("dispose",G),function(t){const i=n.get(t);if(void 0===i.__webglInit)return;e.deleteTexture(i.__webglTexture),n.remove(t)}(i),i.isVideoTexture&&u.delete(i),a.memory.textures--}function K(t){const i=t.target;i.removeEventListener("dispose",K),function(t){const i=t.texture,r=n.get(t),o=n.get(i);if(!t)return;void 0!==o.__webglTexture&&(e.deleteTexture(o.__webglTexture),a.memory.textures--);t.depthTexture&&t.depthTexture.dispose();if(t.isWebGLCubeRenderTarget)for(let t=0;6>t;t++)e.deleteFramebuffer(r.__webglFramebuffer[t]),r.__webglDepthbuffer&&e.deleteRenderbuffer(r.__webglDepthbuffer[t]);else e.deleteFramebuffer(r.__webglFramebuffer),r.__webglDepthbuffer&&e.deleteRenderbuffer(r.__webglDepthbuffer),r.__webglMultisampledFramebuffer&&e.deleteFramebuffer(r.__webglMultisampledFramebuffer),r.__webglColorRenderbuffer&&e.deleteRenderbuffer(r.__webglColorRenderbuffer),r.__webglDepthRenderbuffer&&e.deleteRenderbuffer(r.__webglDepthRenderbuffer);if(t.isWebGLMultipleRenderTargets)for(let t=0,r=i.length;r>t;t++){const r=n.get(i[t]);r.__webglTexture&&(e.deleteTexture(r.__webglTexture),a.memory.textures--),n.remove(i[t])}n.remove(i),n.remove(t)}(i)}let V=0;function Y(e,t){const r=n.get(e);if(e.isVideoTexture&&function(e){const t=a.render.frame;u.get(e)!==t&&(u.set(e,t),e.update())}(e),e.version>0&&r.__version!==e.version){const i=e.image;if(void 0===i)console.warn("THREE.WebGLRenderer: Texture marked for update but image is undefined");else{if(!1!==i.complete)return void q(r,e,t);console.warn("THREE.WebGLRenderer: Texture marked for update but image is incomplete")}}i.activeTexture(33984+t),i.bindTexture(3553,r.__webglTexture)}function H(t,r){const a=n.get(t);t.version>0&&a.__version!==t.version?function(t,n,r){if(6!==n.image.length)return;z(t,n),i.activeTexture(33984+r),i.bindTexture(34067,t.__webglTexture),e.pixelStorei(37440,n.flipY),e.pixelStorei(37441,n.premultiplyAlpha),e.pixelStorei(3317,n.unpackAlignment),e.pixelStorei(37443,0);const a=n&&(n.isCompressedTexture||n.image[0].isCompressedTexture),l=n.image[0]&&n.image[0].isDataTexture,h=[];for(let e=0;6>e;e++)h[e]=a||l?l?n.image[e].image:n.image[e]:F(n.image[e],!1,!0,c);const d=h[0],u=Q(d)||s,p=o.convert(n.format),g=o.convert(n.type),f=N(n.internalFormat,p,g);let m;if(J(34067,n,u),a){for(let e=0;6>e;e++){m=h[e].mipmaps;for(let t=0;m.length>t;t++){const r=m[t];n.format!==D&&n.format!==k?null!==p?i.compressedTexImage2D(34069+e,t,f,r.width,r.height,0,r.data):console.warn("THREE.WebGLRenderer: Attempt to load unsupported compressed texture format in .setTextureCube()"):i.texImage2D(34069+e,t,f,r.width,r.height,0,p,g,r.data)}}t.__maxMipLevel=m.length-1}else{m=n.mipmaps;for(let e=0;6>e;e++)if(l){i.texImage2D(34069+e,0,f,h[e].width,h[e].height,0,p,g,h[e].data);for(let t=0;m.length>t;t++){const n=m[t].image[e].image;i.texImage2D(34069+e,t+1,f,n.width,n.height,0,p,g,n.data)}}else{i.texImage2D(34069+e,0,f,p,g,h[e]);for(let t=0;m.length>t;t++){i.texImage2D(34069+e,t+1,f,p,g,m[t].image[e])}}t.__maxMipLevel=m.length}L(n,u)&&O(34067,n,d.width,d.height);t.__version=n.version,n.onUpdate&&n.onUpdate(n)}(a,t,r):(i.activeTexture(33984+r),i.bindTexture(34067,a.__webglTexture))}const j={[g]:10497,[f]:33071,[m]:33648},W={[A]:9728,[y]:9984,[v]:9986,[C]:9729,[I]:9985,[x]:9987};function J(i,o,a){if(a?(e.texParameteri(i,10242,j[o.wrapS]),e.texParameteri(i,10243,j[o.wrapT]),32879!==i&&35866!==i||e.texParameteri(i,32882,j[o.wrapR]),e.texParameteri(i,10240,W[o.magFilter]),e.texParameteri(i,10241,W[o.minFilter])):(e.texParameteri(i,10242,33071),e.texParameteri(i,10243,33071),32879!==i&&35866!==i||e.texParameteri(i,32882,33071),o.wrapS===f&&o.wrapT===f||console.warn("THREE.WebGLRenderer: Texture is not power of two. Texture.wrapS and Texture.wrapT should be set to THREE.ClampToEdgeWrapping."),e.texParameteri(i,10240,P(o.magFilter)),e.texParameteri(i,10241,P(o.minFilter)),o.minFilter!==A&&o.minFilter!==C&&console.warn("THREE.WebGLRenderer: Texture is not power of two. Texture.minFilter should be set to THREE.NearestFilter or THREE.LinearFilter.")),!0===t.has("EXT_texture_filter_anisotropic")){const a=t.get("EXT_texture_filter_anisotropic");if(o.type===B&&!1===t.has("OES_texture_float_linear"))return;if(!1===s&&o.type===S&&!1===t.has("OES_texture_half_float_linear"))return;(o.anisotropy>1||n.get(o).__currentAnisotropy)&&(e.texParameterf(i,a.TEXTURE_MAX_ANISOTROPY_EXT,Math.min(o.anisotropy,r.getMaxAnisotropy())),n.get(o).__currentAnisotropy=o.anisotropy)}}function z(t,i){void 0===t.__webglInit&&(t.__webglInit=!0,i.addEventListener("dispose",G),t.__webglTexture=e.createTexture(),a.memory.textures++)}function q(t,n,r){let a=3553;n.isDataTexture2DArray&&(a=35866),n.isDataTexture3D&&(a=32879),z(t,n),i.activeTexture(33984+r),i.bindTexture(a,t.__webglTexture),e.pixelStorei(37440,n.flipY),e.pixelStorei(37441,n.premultiplyAlpha),e.pixelStorei(3317,n.unpackAlignment),e.pixelStorei(37443,0);const l=function(e){return!s&&(e.wrapS!==f||e.wrapT!==f||e.minFilter!==A&&e.minFilter!==C)}(n)&&!1===Q(n.image),c=F(n.image,l,!1,h),d=Q(c)||s,u=o.convert(n.format);let p,g=o.convert(n.type),m=N(n.internalFormat,u,g);J(a,n,d);const y=n.mipmaps;if(n.isDepthTexture)m=6402,s?m=n.type===B?36012:n.type===E?33190:n.type===b?35056:33189:n.type===B&&console.error("WebGLRenderer: Floating point depth texture requires WebGL2."),n.format===T&&6402===m&&n.type!==M&&n.type!==E&&(console.warn("THREE.WebGLRenderer: Use UnsignedShortType or UnsignedIntType for DepthFormat DepthTexture."),n.type=M,g=o.convert(n.type)),n.format===R&&6402===m&&(m=34041,n.type!==b&&(console.warn("THREE.WebGLRenderer: Use UnsignedInt248Type for DepthStencilFormat DepthTexture."),n.type=b,g=o.convert(n.type))),i.texImage2D(3553,0,m,c.width,c.height,0,u,g,null);else if(n.isDataTexture)if(y.length>0&&d){for(let e=0,t=y.length;t>e;e++)p=y[e],i.texImage2D(3553,e,m,p.width,p.height,0,u,g,p.data);n.generateMipmaps=!1,t.__maxMipLevel=y.length-1}else i.texImage2D(3553,0,m,c.width,c.height,0,u,g,c.data),t.__maxMipLevel=0;else if(n.isCompressedTexture){for(let e=0,t=y.length;t>e;e++)p=y[e],n.format!==D&&n.format!==k?null!==u?i.compressedTexImage2D(3553,e,m,p.width,p.height,0,p.data):console.warn("THREE.WebGLRenderer: Attempt to load unsupported compressed texture format in .uploadTexture()"):i.texImage2D(3553,e,m,p.width,p.height,0,u,g,p.data);t.__maxMipLevel=y.length-1}else if(n.isDataTexture2DArray)i.texImage3D(35866,0,m,c.width,c.height,c.depth,0,u,g,c.data),t.__maxMipLevel=0;else if(n.isDataTexture3D)i.texImage3D(32879,0,m,c.width,c.height,c.depth,0,u,g,c.data),t.__maxMipLevel=0;else if(y.length>0&&d){for(let e=0,t=y.length;t>e;e++)p=y[e],i.texImage2D(3553,e,m,u,g,p);n.generateMipmaps=!1,t.__maxMipLevel=y.length-1}else i.texImage2D(3553,0,m,u,g,c),t.__maxMipLevel=0;L(n,d)&&O(a,n,c.width,c.height),t.__version=n.version,n.onUpdate&&n.onUpdate(n)}function Z(t,r,a,s,l){const c=o.convert(a.format),h=o.convert(a.type),d=N(a.internalFormat,c,h);32879===l||35866===l?i.texImage3D(l,0,d,r.width,r.height,r.depth,0,c,h,null):i.texImage2D(l,0,d,r.width,r.height,0,c,h,null),i.bindFramebuffer(36160,t),e.framebufferTexture2D(36160,s,l,n.get(a).__webglTexture,0),i.bindFramebuffer(36160,null)}function X(t,i,n){if(e.bindRenderbuffer(36161,t),i.depthBuffer&&!i.stencilBuffer){let r=33189;if(n){const t=i.depthTexture;t&&t.isDepthTexture&&(t.type===B?r=36012:t.type===E&&(r=33190));const n=$(i);e.renderbufferStorageMultisample(36161,n,r,i.width,i.height)}else e.renderbufferStorage(36161,r,i.width,i.height);e.framebufferRenderbuffer(36160,36096,36161,t)}else if(i.depthBuffer&&i.stencilBuffer){if(n){const t=$(i);e.renderbufferStorageMultisample(36161,t,35056,i.width,i.height)}else e.renderbufferStorage(36161,34041,i.width,i.height);e.framebufferRenderbuffer(36160,33306,36161,t)}else{const t=!0===i.isWebGLMultipleRenderTargets?i.texture[0]:i.texture,r=o.convert(t.format),a=o.convert(t.type),s=N(t.internalFormat,r,a);if(n){const t=$(i);e.renderbufferStorageMultisample(36161,t,s,i.width,i.height)}else e.renderbufferStorage(36161,s,i.width,i.height)}e.bindRenderbuffer(36161,null)}function _(t){const r=n.get(t),o=!0===t.isWebGLCubeRenderTarget;if(t.depthTexture){if(o)throw new Error("target.depthTexture not supported in Cube render targets");!function(t,r){if(r&&r.isWebGLCubeRenderTarget)throw new Error("Depth Texture with cube render targets is not supported");if(i.bindFramebuffer(36160,t),!r.depthTexture||!r.depthTexture.isDepthTexture)throw new Error("renderTarget.depthTexture must be an instance of THREE.DepthTexture");n.get(r.depthTexture).__webglTexture&&r.depthTexture.image.width===r.width&&r.depthTexture.image.height===r.height||(r.depthTexture.image.width=r.width,r.depthTexture.image.height=r.height,r.depthTexture.needsUpdate=!0),Y(r.depthTexture,0);const o=n.get(r.depthTexture).__webglTexture;if(r.depthTexture.format===T)e.framebufferTexture2D(36160,36096,3553,o,0);else{if(r.depthTexture.format!==R)throw new Error("Unknown depthTexture format");e.framebufferTexture2D(36160,33306,3553,o,0)}}(r.__webglFramebuffer,t)}else if(o){r.__webglDepthbuffer=[];for(let n=0;6>n;n++)i.bindFramebuffer(36160,r.__webglFramebuffer[n]),r.__webglDepthbuffer[n]=e.createRenderbuffer(),X(r.__webglDepthbuffer[n],t,!1)}else i.bindFramebuffer(36160,r.__webglFramebuffer),r.__webglDepthbuffer=e.createRenderbuffer(),X(r.__webglDepthbuffer,t,!1);i.bindFramebuffer(36160,null)}function $(e){return s&&e.isWebGLMultisampleRenderTarget?Math.min(d,e.samples):0}let ee=!1,te=!1;this.allocateTextureUnit=function(){const e=V;return l>e||console.warn("THREE.WebGLTextures: Trying to use "+e+" texture units while this GPU supports only "+l),V+=1,e},this.resetTextureUnits=function(){V=0},this.setTexture2D=Y,this.setTexture2DArray=function(e,t){const r=n.get(e);e.version>0&&r.__version!==e.version?q(r,e,t):(i.activeTexture(33984+t),i.bindTexture(35866,r.__webglTexture))},this.setTexture3D=function(e,t){const r=n.get(e);e.version>0&&r.__version!==e.version?q(r,e,t):(i.activeTexture(33984+t),i.bindTexture(32879,r.__webglTexture))},this.setTextureCube=H,this.setupRenderTarget=function(t){const l=t.texture,c=n.get(t),h=n.get(l);t.addEventListener("dispose",K),!0!==t.isWebGLMultipleRenderTargets&&(h.__webglTexture=e.createTexture(),h.__version=l.version,a.memory.textures++);const d=!0===t.isWebGLCubeRenderTarget,u=!0===t.isWebGLMultipleRenderTargets,p=!0===t.isWebGLMultisampleRenderTarget,g=l.isDataTexture3D||l.isDataTexture2DArray,f=Q(t)||s;if(!s||l.format!==k||l.type!==B&&l.type!==S||(l.format=D,console.warn("THREE.WebGLRenderer: Rendering to textures with RGB format is not supported. Using RGBA format instead.")),d){c.__webglFramebuffer=[];for(let t=0;6>t;t++)c.__webglFramebuffer[t]=e.createFramebuffer()}else if(c.__webglFramebuffer=e.createFramebuffer(),u)if(r.drawBuffers){const i=t.texture;for(let t=0,r=i.length;r>t;t++){const r=n.get(i[t]);void 0===r.__webglTexture&&(r.__webglTexture=e.createTexture(),a.memory.textures++)}}else console.warn("THREE.WebGLRenderer: WebGLMultipleRenderTargets can only be used with WebGL2 or WEBGL_draw_buffers extension.");else if(p)if(s){c.__webglMultisampledFramebuffer=e.createFramebuffer(),c.__webglColorRenderbuffer=e.createRenderbuffer(),e.bindRenderbuffer(36161,c.__webglColorRenderbuffer);const n=o.convert(l.format),r=o.convert(l.type),a=N(l.internalFormat,n,r),s=$(t);e.renderbufferStorageMultisample(36161,s,a,t.width,t.height),i.bindFramebuffer(36160,c.__webglMultisampledFramebuffer),e.framebufferRenderbuffer(36160,36064,36161,c.__webglColorRenderbuffer),e.bindRenderbuffer(36161,null),t.depthBuffer&&(c.__webglDepthRenderbuffer=e.createRenderbuffer(),X(c.__webglDepthRenderbuffer,t,!0)),i.bindFramebuffer(36160,null)}else console.warn("THREE.WebGLRenderer: WebGLMultisampleRenderTarget can only be used with WebGL2.");if(d){i.bindTexture(34067,h.__webglTexture),J(34067,l,f);for(let e=0;6>e;e++)Z(c.__webglFramebuffer[e],t,l,36064,34069+e);L(l,f)&&O(34067,l,t.width,t.height),i.bindTexture(34067,null)}else if(u){const e=t.texture;for(let r=0,o=e.length;o>r;r++){const o=e[r],a=n.get(o);i.bindTexture(3553,a.__webglTexture),J(3553,o,f),Z(c.__webglFramebuffer,t,o,36064+r,3553),L(o,f)&&O(3553,o,t.width,t.height)}i.bindTexture(3553,null)}else{let e=3553;if(g)if(s){e=l.isDataTexture3D?32879:35866}else console.warn("THREE.DataTexture3D and THREE.DataTexture2DArray only supported with WebGL2.");i.bindTexture(e,h.__webglTexture),J(e,l,f),Z(c.__webglFramebuffer,t,l,36064,e),L(l,f)&&O(3553,l,t.width,t.height),i.bindTexture(3553,null)}t.depthBuffer&&_(t)},this.updateRenderTargetMipmap=function(e){const t=Q(e)||s,r=!0===e.isWebGLMultipleRenderTargets?e.texture:[e.texture];for(let o=0,a=r.length;a>o;o++){const a=r[o];if(L(a,t)){const t=e.isWebGLCubeRenderTarget?34067:3553,r=n.get(a).__webglTexture;i.bindTexture(t,r),O(t,a,e.width,e.height),i.bindTexture(t,null)}}},this.updateMultisampleRenderTarget=function(t){if(t.isWebGLMultisampleRenderTarget)if(s){const r=t.width,o=t.height;let a=16384;t.depthBuffer&&(a|=256),t.stencilBuffer&&(a|=1024);const s=n.get(t);i.bindFramebuffer(36008,s.__webglMultisampledFramebuffer),i.bindFramebuffer(36009,s.__webglFramebuffer),e.blitFramebuffer(0,0,r,o,0,0,r,o,a,9728),i.bindFramebuffer(36008,null),i.bindFramebuffer(36009,s.__webglMultisampledFramebuffer)}else console.warn("THREE.WebGLRenderer: WebGLMultisampleRenderTarget can only be used with WebGL2.")},this.safeSetTexture2D=function(e,t){e&&e.isWebGLRenderTarget&&(!1===ee&&(console.warn("THREE.WebGLTextures.safeSetTexture2D: don't use render targets as textures. Use their .texture property instead."),ee=!0),e=e.texture),Y(e,t)},this.safeSetTextureCube=function(e,t){e&&e.isWebGLCubeRenderTarget&&(!1===te&&(console.warn("THREE.WebGLTextures.safeSetTextureCube: don't use cube render targets as textures. Use their .texture property instead."),te=!0),e=e.texture),H(e,t)}}function ko(e,t,i){const n=i.isWebGL2;return{convert:function(e){let i;if(e===w)return 5121;if(1017===e)return 32819;if(1018===e)return 32820;if(1019===e)return 33635;if(1010===e)return 5120;if(1011===e)return 5122;if(e===M)return 5123;if(1013===e)return 5124;if(e===E)return 5125;if(e===B)return 5126;if(e===S)return n?5131:(i=t.get("OES_texture_half_float"),null!==i?i.HALF_FLOAT_OES:null);if(1021===e)return 6406;if(e===k)return 6407;if(e===D)return 6408;if(1024===e)return 6409;if(1025===e)return 6410;if(e===T)return 6402;if(e===R)return 34041;if(1028===e)return 6403;if(1029===e)return 36244;if(1030===e)return 33319;if(1031===e)return 33320;if(1032===e)return 36248;if(1033===e)return 36249;if(e===U||e===F||e===Q||e===L){if(i=t.get("WEBGL_compressed_texture_s3tc"),null===i)return null;if(e===U)return i.COMPRESSED_RGB_S3TC_DXT1_EXT;if(e===F)return i.COMPRESSED_RGBA_S3TC_DXT1_EXT;if(e===Q)return i.COMPRESSED_RGBA_S3TC_DXT3_EXT;if(e===L)return i.COMPRESSED_RGBA_S3TC_DXT5_EXT}if(e===O||e===N||e===P||e===G){if(i=t.get("WEBGL_compressed_texture_pvrtc"),null===i)return null;if(e===O)return i.COMPRESSED_RGB_PVRTC_4BPPV1_IMG;if(e===N)return i.COMPRESSED_RGB_PVRTC_2BPPV1_IMG;if(e===P)return i.COMPRESSED_RGBA_PVRTC_4BPPV1_IMG;if(e===G)return i.COMPRESSED_RGBA_PVRTC_2BPPV1_IMG}if(36196===e)return i=t.get("WEBGL_compressed_texture_etc1"),null!==i?i.COMPRESSED_RGB_ETC1_WEBGL:null;if((e===K||e===V)&&(i=t.get("WEBGL_compressed_texture_etc"),null!==i)){if(e===K)return i.COMPRESSED_RGB8_ETC2;if(e===V)return i.COMPRESSED_RGBA8_ETC2_EAC}return 37808===e||37809===e||37810===e||37811===e||37812===e||37813===e||37814===e||37815===e||37816===e||37817===e||37818===e||37819===e||37820===e||37821===e||37840===e||37841===e||37842===e||37843===e||37844===e||37845===e||37846===e||37847===e||37848===e||37849===e||37850===e||37851===e||37852===e||37853===e?(i=t.get("WEBGL_compressed_texture_astc"),null!==i?e:null):36492===e?(i=t.get("EXT_texture_compression_bptc"),null!==i?e:null):e===b?n?34042:(i=t.get("WEBGL_depth_texture"),null!==i?i.UNSIGNED_INT_24_8_WEBGL:null):void 0}}}class Do extends dn{constructor(e=[]){super(),this.cameras=e}}Do.prototype.isArrayCamera=!0;class To extends Yt{constructor(){super(),this.type="Group"}}To.prototype.isGroup=!0;const Ro={type:"move"};class Uo{constructor(){this._targetRay=null,this._grip=null,this._hand=null}getHandSpace(){return null===this._hand&&(this._hand=new To,this._hand.matrixAutoUpdate=!1,this._hand.visible=!1,this._hand.joints={},this._hand.inputState={pinching:!1}),this._hand}getTargetRaySpace(){return null===this._targetRay&&(this._targetRay=new To,this._targetRay.matrixAutoUpdate=!1,this._targetRay.visible=!1,this._targetRay.hasLinearVelocity=!1,this._targetRay.linearVelocity=new Ke,this._targetRay.hasAngularVelocity=!1,this._targetRay.angularVelocity=new Ke),this._targetRay}getGripSpace(){return null===this._grip&&(this._grip=new To,this._grip.matrixAutoUpdate=!1,this._grip.visible=!1,this._grip.hasLinearVelocity=!1,this._grip.linearVelocity=new Ke,this._grip.hasAngularVelocity=!1,this._grip.angularVelocity=new Ke),this._grip}dispatchEvent(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(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(e,t,i){let n=null,r=null,o=null;const a=this._targetRay,s=this._grip,l=this._hand;if(e&&"visible-blurred"!==t.session.visibilityState)if(null!==a&&(n=t.getPose(e.targetRaySpace,i),null!==n&&(a.matrix.fromArray(n.transform.matrix),a.matrix.decompose(a.position,a.rotation,a.scale),n.linearVelocity?(a.hasLinearVelocity=!0,a.linearVelocity.copy(n.linearVelocity)):a.hasLinearVelocity=!1,n.angularVelocity?(a.hasAngularVelocity=!0,a.angularVelocity.copy(n.angularVelocity)):a.hasAngularVelocity=!1,this.dispatchEvent(Ro))),l&&e.hand){o=!0;for(const n of e.hand.values()){const e=t.getJointPose(n,i);if(void 0===l.joints[n.jointName]){const e=new To;e.matrixAutoUpdate=!1,e.visible=!1,l.joints[n.jointName]=e,l.add(e)}const r=l.joints[n.jointName];null!==e&&(r.matrix.fromArray(e.transform.matrix),r.matrix.decompose(r.position,r.rotation,r.scale),r.jointRadius=e.radius),r.visible=null!==e}const n=l.joints["index-finger-tip"].position.distanceTo(l.joints["thumb-tip"].position),r=.02,a=.005;l.inputState.pinching&&n>r+a?(l.inputState.pinching=!1,this.dispatchEvent({type:"pinchend",handedness:e.handedness,target:this})):l.inputState.pinching||n>r-a||(l.inputState.pinching=!0,this.dispatchEvent({type:"pinchstart",handedness:e.handedness,target:this}))}else null!==s&&e.gripSpace&&(r=t.getPose(e.gripSpace,i),null!==r&&(s.matrix.fromArray(r.transform.matrix),s.matrix.decompose(s.position,s.rotation,s.scale),r.linearVelocity?(s.hasLinearVelocity=!0,s.linearVelocity.copy(r.linearVelocity)):s.hasLinearVelocity=!1,r.angularVelocity?(s.hasAngularVelocity=!0,s.angularVelocity.copy(r.angularVelocity)):s.hasAngularVelocity=!1));return null!==a&&(a.visible=null!==n),null!==s&&(s.visible=null!==r),null!==l&&(l.visible=null!==o),this}}class Fo extends me{constructor(e,t){super();const i=this,n=e.state;let r=null,o=1,a=null,s="local-floor",l=null;const c=[],h=new Map,d=new dn;d.layers.enable(1),d.viewport=new Le;const u=new dn;u.layers.enable(2),u.viewport=new Le;const p=[d,u],g=new Do;g.layers.enable(1),g.layers.enable(2);let f=null,m=null;function A(e){const t=h.get(e.inputSource);t&&t.dispatchEvent({type:e.type,data:e.inputSource})}function y(){h.forEach((function(e,t){e.disconnect(t)})),h.clear(),f=null,m=null,n.bindXRFramebuffer(null),e.setRenderTarget(e.getRenderTarget()),M.stop(),i.isPresenting=!1,i.dispatchEvent({type:"sessionend"})}function v(e){const t=r.inputSources;for(let e=0;c.length>e;e++)h.set(t[e],c[e]);for(let t=0;e.removed.length>t;t++){const i=e.removed[t],n=h.get(i);n&&(n.dispatchEvent({type:"disconnected",data:i}),h.delete(i))}for(let t=0;e.added.length>t;t++){const i=e.added[t],n=h.get(i);n&&n.dispatchEvent({type:"connected",data:i})}}this.cameraAutoUpdate=!0,this.enabled=!1,this.isPresenting=!1,this.getController=function(e){let t=c[e];return void 0===t&&(t=new Uo,c[e]=t),t.getTargetRaySpace()},this.getControllerGrip=function(e){let t=c[e];return void 0===t&&(t=new Uo,c[e]=t),t.getGripSpace()},this.getHand=function(e){let t=c[e];return void 0===t&&(t=new Uo,c[e]=t),t.getHandSpace()},this.setFramebufferScaleFactor=function(e){o=e,!0===i.isPresenting&&console.warn("THREE.WebXRManager: Cannot change framebuffer scale while presenting.")},this.setReferenceSpaceType=function(e){s=e,!0===i.isPresenting&&console.warn("THREE.WebXRManager: Cannot change reference space type while presenting.")},this.getReferenceSpace=function(){return a},this.getSession=function(){return r},this.setSession=async function(e){if(r=e,null!==r){r.addEventListener("select",A),r.addEventListener("selectstart",A),r.addEventListener("selectend",A),r.addEventListener("squeeze",A),r.addEventListener("squeezestart",A),r.addEventListener("squeezeend",A),r.addEventListener("end",y),r.addEventListener("inputsourceschange",v);const e=t.getContextAttributes();!0!==e.xrCompatible&&await t.makeXRCompatible();const n=new XRWebGLLayer(r,t,{antialias:e.antialias,alpha:e.alpha,depth:e.depth,stencil:e.stencil,framebufferScaleFactor:o});r.updateRenderState({baseLayer:n}),a=await r.requestReferenceSpace(s),M.setContext(r),M.start(),i.isPresenting=!0,i.dispatchEvent({type:"sessionstart"})}};const C=new Ke,I=new Ke;function x(e,t){null===t?e.matrixWorld.copy(e.matrix):e.matrixWorld.multiplyMatrices(t.matrixWorld,e.matrix),e.matrixWorldInverse.copy(e.matrixWorld).invert()}this.updateCamera=function(e){if(null===r)return;g.near=u.near=d.near=e.near,g.far=u.far=d.far=e.far,f===g.near&&m===g.far||(r.updateRenderState({depthNear:g.near,depthFar:g.far}),f=g.near,m=g.far);const t=e.parent,i=g.cameras;x(g,t);for(let e=0;i.length>e;e++)x(i[e],t);e.matrixWorld.copy(g.matrixWorld),e.matrix.copy(g.matrix),e.matrix.decompose(e.position,e.quaternion,e.scale);const n=e.children;for(let e=0,t=n.length;t>e;e++)n[e].updateMatrixWorld(!0);2===i.length?function(e,t,i){C.setFromMatrixPosition(t.matrixWorld),I.setFromMatrixPosition(i.matrixWorld);const n=C.distanceTo(I),r=t.projectionMatrix.elements,o=i.projectionMatrix.elements,a=r[14]/(r[10]-1),s=r[14]/(r[10]+1),l=(r[9]+1)/r[5],c=(r[9]-1)/r[5],h=(r[8]-1)/r[0],d=(o[8]+1)/o[0],u=a*h,p=a*d,g=n/(-h+d),f=g*-h;t.matrixWorld.decompose(e.position,e.quaternion,e.scale),e.translateX(f),e.translateZ(g),e.matrixWorld.compose(e.position,e.quaternion,e.scale),e.matrixWorldInverse.copy(e.matrixWorld).invert();const m=a+g,A=s+g;e.projectionMatrix.makePerspective(u-f,p+(n-f),l*s/A*m,c*s/A*m,m,A)}(g,d,u):g.projectionMatrix.copy(d.projectionMatrix)},this.getCamera=function(){return g};let w=null;const M=new vn;M.setAnimationLoop((function(e,t){if(l=t.getViewerPose(a),null!==l){const e=l.views,t=r.renderState.baseLayer;n.bindXRFramebuffer(t.framebuffer);let i=!1;e.length!==g.cameras.length&&(g.cameras.length=0,i=!0);for(let n=0;e.length>n;n++){const r=e[n],o=t.getViewport(r),a=p[n];a.matrix.fromArray(r.transform.matrix),a.projectionMatrix.fromArray(r.projectionMatrix),a.viewport.set(o.x,o.y,o.width,o.height),0===n&&g.matrix.copy(a.matrix),!0===i&&g.cameras.push(a)}}const i=r.inputSources;for(let e=0;c.length>e;e++){c[e].update(i[e],t,a)}w&&w(e,t)})),this.setAnimationLoop=function(e){w=e},this.dispose=function(){}}}function Qo(e){function t(t,i){t.opacity.value=i.opacity,i.color&&t.diffuse.value.copy(i.color),i.emissive&&t.emissive.value.copy(i.emissive).multiplyScalar(i.emissiveIntensity),i.map&&(t.map.value=i.map),i.alphaMap&&(t.alphaMap.value=i.alphaMap),i.specularMap&&(t.specularMap.value=i.specularMap);const n=e.get(i).envMap;if(n){t.envMap.value=n,t.flipEnvMap.value=n.isCubeTexture&&n._needsFlipEnvMap?-1:1,t.reflectivity.value=i.reflectivity,t.refractionRatio.value=i.refractionRatio;const r=e.get(n).__maxMipLevel;void 0!==r&&(t.maxMipLevel.value=r)}let r,o;i.lightMap&&(t.lightMap.value=i.lightMap,t.lightMapIntensity.value=i.lightMapIntensity),i.aoMap&&(t.aoMap.value=i.aoMap,t.aoMapIntensity.value=i.aoMapIntensity),i.map?r=i.map:i.specularMap?r=i.specularMap:i.displacementMap?r=i.displacementMap:i.normalMap?r=i.normalMap:i.bumpMap?r=i.bumpMap:i.roughnessMap?r=i.roughnessMap:i.metalnessMap?r=i.metalnessMap:i.alphaMap?r=i.alphaMap:i.emissiveMap?r=i.emissiveMap:i.clearcoatMap?r=i.clearcoatMap:i.clearcoatNormalMap?r=i.clearcoatNormalMap:i.clearcoatRoughnessMap&&(r=i.clearcoatRoughnessMap),void 0!==r&&(r.isWebGLRenderTarget&&(r=r.texture),!0===r.matrixAutoUpdate&&r.updateMatrix(),t.uvTransform.value.copy(r.matrix)),i.aoMap?o=i.aoMap:i.lightMap&&(o=i.lightMap),void 0!==o&&(o.isWebGLRenderTarget&&(o=o.texture),!0===o.matrixAutoUpdate&&o.updateMatrix(),t.uv2Transform.value.copy(o.matrix))}function i(t,i){t.roughness.value=i.roughness,t.metalness.value=i.metalness,i.roughnessMap&&(t.roughnessMap.value=i.roughnessMap),i.metalnessMap&&(t.metalnessMap.value=i.metalnessMap),i.emissiveMap&&(t.emissiveMap.value=i.emissiveMap),i.bumpMap&&(t.bumpMap.value=i.bumpMap,t.bumpScale.value=i.bumpScale,1===i.side&&(t.bumpScale.value*=-1)),i.normalMap&&(t.normalMap.value=i.normalMap,t.normalScale.value.copy(i.normalScale),1===i.side&&t.normalScale.value.negate()),i.displacementMap&&(t.displacementMap.value=i.displacementMap,t.displacementScale.value=i.displacementScale,t.displacementBias.value=i.displacementBias);e.get(i).envMap&&(t.envMapIntensity.value=i.envMapIntensity)}return{refreshFogUniforms:function(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)},refreshMaterialUniforms:function(e,n,r,o,a){n.isMeshBasicMaterial?t(e,n):n.isMeshLambertMaterial?(t(e,n),function(e,t){t.emissiveMap&&(e.emissiveMap.value=t.emissiveMap)}(e,n)):n.isMeshToonMaterial?(t(e,n),function(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,1===t.side&&(e.bumpScale.value*=-1));t.normalMap&&(e.normalMap.value=t.normalMap,e.normalScale.value.copy(t.normalScale),1===t.side&&e.normalScale.value.negate());t.displacementMap&&(e.displacementMap.value=t.displacementMap,e.displacementScale.value=t.displacementScale,e.displacementBias.value=t.displacementBias)}(e,n)):n.isMeshPhongMaterial?(t(e,n),function(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,1===t.side&&(e.bumpScale.value*=-1));t.normalMap&&(e.normalMap.value=t.normalMap,e.normalScale.value.copy(t.normalScale),1===t.side&&e.normalScale.value.negate());t.displacementMap&&(e.displacementMap.value=t.displacementMap,e.displacementScale.value=t.displacementScale,e.displacementBias.value=t.displacementBias)}(e,n)):n.isMeshStandardMaterial?(t(e,n),n.isMeshPhysicalMaterial?function(e,t,n){i(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,1===t.side&&e.clearcoatNormalScale.value.negate());e.transmission.value=t.transmission,t.transmissionMap&&(e.transmissionMap.value=t.transmissionMap);t.transmission>0&&(e.transmissionSamplerMap.value=n.texture,e.transmissionSamplerSize.value.set(n.width,n.height));e.thickness.value=t.thickness,t.thicknessMap&&(e.thicknessMap.value=t.thicknessMap);e.attenuationDistance.value=t.attenuationDistance,e.attenuationColor.value.copy(t.attenuationColor)}(e,n,a):i(e,n)):n.isMeshMatcapMaterial?(t(e,n),function(e,t){t.matcap&&(e.matcap.value=t.matcap);t.bumpMap&&(e.bumpMap.value=t.bumpMap,e.bumpScale.value=t.bumpScale,1===t.side&&(e.bumpScale.value*=-1));t.normalMap&&(e.normalMap.value=t.normalMap,e.normalScale.value.copy(t.normalScale),1===t.side&&e.normalScale.value.negate());t.displacementMap&&(e.displacementMap.value=t.displacementMap,e.displacementScale.value=t.displacementScale,e.displacementBias.value=t.displacementBias)}(e,n)):n.isMeshDepthMaterial?(t(e,n),function(e,t){t.displacementMap&&(e.displacementMap.value=t.displacementMap,e.displacementScale.value=t.displacementScale,e.displacementBias.value=t.displacementBias)}(e,n)):n.isMeshDistanceMaterial?(t(e,n),function(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}(e,n)):n.isMeshNormalMaterial?(t(e,n),function(e,t){t.bumpMap&&(e.bumpMap.value=t.bumpMap,e.bumpScale.value=t.bumpScale,1===t.side&&(e.bumpScale.value*=-1));t.normalMap&&(e.normalMap.value=t.normalMap,e.normalScale.value.copy(t.normalScale),1===t.side&&e.normalScale.value.negate());t.displacementMap&&(e.displacementMap.value=t.displacementMap,e.displacementScale.value=t.displacementScale,e.displacementBias.value=t.displacementBias)}(e,n)):n.isLineBasicMaterial?(function(e,t){e.diffuse.value.copy(t.color),e.opacity.value=t.opacity}(e,n),n.isLineDashedMaterial&&function(e,t){e.dashSize.value=t.dashSize,e.totalSize.value=t.dashSize+t.gapSize,e.scale.value=t.scale}(e,n)):n.isPointsMaterial?function(e,t,i,n){e.diffuse.value.copy(t.color),e.opacity.value=t.opacity,e.size.value=t.size*i,e.scale.value=.5*n,t.map&&(e.map.value=t.map);t.alphaMap&&(e.alphaMap.value=t.alphaMap);let r;t.map?r=t.map:t.alphaMap&&(r=t.alphaMap);void 0!==r&&(!0===r.matrixAutoUpdate&&r.updateMatrix(),e.uvTransform.value.copy(r.matrix))}(e,n,r,o):n.isSpriteMaterial?function(e,t){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);let i;t.map?i=t.map:t.alphaMap&&(i=t.alphaMap);void 0!==i&&(!0===i.matrixAutoUpdate&&i.updateMatrix(),e.uvTransform.value.copy(i.matrix))}(e,n):n.isShadowMaterial?(e.color.value.copy(n.color),e.opacity.value=n.opacity):n.isShaderMaterial&&(n.uniformsNeedUpdate=!1)}}}function Lo(){const e=document.createElementNS("http://www.w3.org/1999/xhtml","canvas");return e.style.display="block",e}function Oo(e){const t=void 0!==(e=e||{}).canvas?e.canvas:Lo(),i=void 0!==e.context?e.context:null,n=void 0!==e.alpha&&e.alpha,r=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",h=void 0!==e.failIfMajorPerformanceCaveat&&e.failIfMajorPerformanceCaveat;let d=null,u=null;const p=[],g=[];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=X,this.physicallyCorrectLights=!1,this.toneMapping=0,this.toneMappingExposure=1;const m=this;let y=!1,v=0,C=0,I=null,M=-1,E=null;const b=new Le,k=new Le;let T=null,R=t.width,U=t.height,F=1,Q=null,L=null;const O=new Le(0,0,R,U),N=new Le(0,0,R,U);let P=!1;const G=[],K=new yn;let V=!1,Y=!1,H=null;const j=new yt,W=new Ke,J={background:null,fog:null,environment:null,overrideMaterial:null,isScene:!0};function z(){return null===I?F:1}let q,Z,_,$,ee,te,ie,ne,re,oe,ae,se,le,ce,he,de,ue,pe,ge,fe,me,Ae,ye=i;function ve(e,i){for(let n=0;e.length>n;n++){const r=t.getContext(e[n],i);if(null!==r)return r}return null}try{const e={alpha:n,depth:r,stencil:o,antialias:a,premultipliedAlpha:s,preserveDrawingBuffer:l,powerPreference:c,failIfMajorPerformanceCaveat:h};if(t.addEventListener("webglcontextlost",xe,!1),t.addEventListener("webglcontextrestored",we,!1),null===ye){const t=["webgl2","webgl","experimental-webgl"];if(!0===m.isWebGL1Renderer&&t.shift(),ye=ve(t,e),null===ye)throw ve(t)?new Error("Error creating WebGL context with your selected attributes."):new Error("Error creating WebGL context.")}void 0===ye.getShaderPrecisionFormat&&(ye.getShaderPrecisionFormat=function(){return{rangeMin:1,rangeMax:1,precision:1}})}catch(e){throw console.error("THREE.WebGLRenderer: "+e.message),e}function Ce(){q=new Rn(ye),Z=new kn(ye,q,e),q.init(Z),me=new ko(ye,q,Z),_=new So(ye,q,Z),G[0]=1029,$=new Qn(ye),ee=new po,te=new bo(ye,q,_,ee,Z,me,$),ie=new Tn(m),ne=new Cn(ye,Z),Ae=new Bn(ye,q,ne,Z),re=new Un(ye,ne,$,Ae),oe=new Pn(ye,re,ne,$),pe=new Nn(ye),he=new Dn(ee),ae=new uo(m,ie,q,Z,Ae,he),se=new Qo(ee),le=new Ao(ee),ce=new wo(q,Z),ue=new En(m,ie,_,oe,s),de=new Bo(m,oe,Z),ge=new bn(ye,q,$,Z),fe=new Fn(ye,q,$,Z),$.programs=ae.programs,m.capabilities=Z,m.extensions=q,m.properties=ee,m.renderLists=le,m.shadowMap=de,m.state=_,m.info=$}Ce();const Ie=new Fo(m,ye);function xe(e){e.preventDefault(),console.log("THREE.WebGLRenderer: Context Lost."),y=!0}function we(){console.log("THREE.WebGLRenderer: Context Restored."),y=!1;const e=$.autoReset,t=de.enabled,i=de.autoUpdate,n=de.needsUpdate,r=de.type;Ce(),$.autoReset=e,de.enabled=t,de.autoUpdate=i,de.needsUpdate=n,de.type=r}function Me(e){const t=e.target;t.removeEventListener("dispose",Me),function(e){(function(e){const t=ee.get(e).programs;void 0!==t&&t.forEach((function(e){ae.releaseProgram(e)}))})(e),ee.remove(e)}(t)}this.xr=Ie,this.getContext=function(){return ye},this.getContextAttributes=function(){return ye.getContextAttributes()},this.forceContextLoss=function(){const e=q.get("WEBGL_lose_context");e&&e.loseContext()},this.forceContextRestore=function(){const e=q.get("WEBGL_lose_context");e&&e.restoreContext()},this.getPixelRatio=function(){return F},this.setPixelRatio=function(e){void 0!==e&&(F=e,this.setSize(R,U,!1))},this.getSize=function(e){return void 0===e&&(console.warn("WebGLRenderer: .getsize() now requires a Vector2 as an argument"),e=new ke),e.set(R,U)},this.setSize=function(e,i,n){Ie.isPresenting?console.warn("THREE.WebGLRenderer: Can't change size while VR device is presenting."):(R=e,U=i,t.width=Math.floor(e*F),t.height=Math.floor(i*F),!1!==n&&(t.style.width=e+"px",t.style.height=i+"px"),this.setViewport(0,0,e,i))},this.getDrawingBufferSize=function(e){return void 0===e&&(console.warn("WebGLRenderer: .getdrawingBufferSize() now requires a Vector2 as an argument"),e=new ke),e.set(R*F,U*F).floor()},this.setDrawingBufferSize=function(e,i,n){R=e,U=i,F=n,t.width=Math.floor(e*n),t.height=Math.floor(i*n),this.setViewport(0,0,e,i)},this.getCurrentViewport=function(e){return void 0===e&&(console.warn("WebGLRenderer: .getCurrentViewport() now requires a Vector4 as an argument"),e=new Le),e.copy(b)},this.getViewport=function(e){return e.copy(O)},this.setViewport=function(e,t,i,n){e.isVector4?O.set(e.x,e.y,e.z,e.w):O.set(e,t,i,n),_.viewport(b.copy(O).multiplyScalar(F).floor())},this.getScissor=function(e){return e.copy(N)},this.setScissor=function(e,t,i,n){e.isVector4?N.set(e.x,e.y,e.z,e.w):N.set(e,t,i,n),_.scissor(k.copy(N).multiplyScalar(F).floor())},this.getScissorTest=function(){return P},this.setScissorTest=function(e){_.setScissorTest(P=e)},this.setOpaqueSort=function(e){Q=e},this.setTransparentSort=function(e){L=e},this.getOpaqueSort=function(){return Q},this.getTransparentSort=function(){return L},this.getClearColor=function(e){return void 0===e&&(console.warn("WebGLRenderer: .getClearColor() now requires a Color as an argument"),e=new pi),e.copy(ue.getClearColor())},this.setClearColor=function(){ue.setClearColor.apply(ue,arguments)},this.getClearAlpha=function(){return ue.getClearAlpha()},this.setClearAlpha=function(){ue.setClearAlpha.apply(ue,arguments)},this.clear=function(e,t,i){let n=0;(void 0===e||e)&&(n|=16384),(void 0===t||t)&&(n|=256),(void 0===i||i)&&(n|=1024),ye.clear(n)},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",xe,!1),t.removeEventListener("webglcontextrestored",we,!1),le.dispose(),ce.dispose(),ee.dispose(),ie.dispose(),oe.dispose(),Ae.dispose(),Ie.dispose(),Ie.removeEventListener("sessionstart",Be),Ie.removeEventListener("sessionend",Se),H&&(H.dispose(),H=null),be.stop()},this.renderBufferImmediate=function(e,t){Ae.initAttributes();const i=ee.get(e);e.hasPositions&&!i.position&&(i.position=ye.createBuffer()),e.hasNormals&&!i.normal&&(i.normal=ye.createBuffer()),e.hasUvs&&!i.uv&&(i.uv=ye.createBuffer()),e.hasColors&&!i.color&&(i.color=ye.createBuffer());const n=t.getAttributes();e.hasPositions&&(ye.bindBuffer(34962,i.position),ye.bufferData(34962,e.positionArray,35048),Ae.enableAttribute(n.position),ye.vertexAttribPointer(n.position,3,5126,!1,0,0)),e.hasNormals&&(ye.bindBuffer(34962,i.normal),ye.bufferData(34962,e.normalArray,35048),Ae.enableAttribute(n.normal),ye.vertexAttribPointer(n.normal,3,5126,!1,0,0)),e.hasUvs&&(ye.bindBuffer(34962,i.uv),ye.bufferData(34962,e.uvArray,35048),Ae.enableAttribute(n.uv),ye.vertexAttribPointer(n.uv,2,5126,!1,0,0)),e.hasColors&&(ye.bindBuffer(34962,i.color),ye.bufferData(34962,e.colorArray,35048),Ae.enableAttribute(n.color),ye.vertexAttribPointer(n.color,3,5126,!1,0,0)),Ae.disableUnusedAttributes(),ye.drawArrays(4,0,e.count),e.count=0},this.renderBufferDirect=function(e,t,i,n,r,o){null===t&&(t=J);const a=r.isMesh&&0>r.matrixWorld.determinant(),s=Qe(e,t,n,r);_.setMaterial(n,a);let l=i.index;const c=i.attributes.position;if(null===l){if(void 0===c||0===c.count)return}else if(0===l.count)return;let h,d=1;!0===n.wireframe&&(l=re.getWireframeAttribute(i),d=2),(n.morphTargets||n.morphNormals)&&pe.update(r,i,n,s),Ae.setup(r,n,s,i,l);let u=ge;null!==l&&(h=ne.get(l),u=fe,u.setIndex(h));const p=null!==l?l.count:c.count,g=i.drawRange.start*d,f=i.drawRange.count*d,m=null!==o?o.start*d:0,A=null!==o?o.count*d:1/0,y=Math.max(g,m),v=Math.min(p,g+f,m+A)-1,C=Math.max(0,v-y+1);if(0!==C){if(r.isMesh)!0===n.wireframe?(_.setLineWidth(n.wireframeLinewidth*z()),u.setMode(1)):u.setMode(4);else if(r.isLine){let e=n.linewidth;void 0===e&&(e=1),_.setLineWidth(e*z()),u.setMode(r.isLineSegments?1:r.isLineLoop?2:3)}else r.isPoints?u.setMode(0):r.isSprite&&u.setMode(4);if(r.isInstancedMesh)u.renderInstances(y,C,r.count);else if(i.isInstancedBufferGeometry){const e=Math.min(i.instanceCount,i._maxInstanceCount);u.renderInstances(y,C,e)}else u.render(y,C)}},this.compile=function(e,t){u=ce.get(e),u.init(),e.traverseVisible((function(e){e.isLight&&e.layers.test(t.layers)&&(u.pushLight(e),e.castShadow&&u.pushShadow(e))})),u.setupLights(),e.traverse((function(t){const i=t.material;if(i)if(Array.isArray(i))for(let n=0;i.length>n;n++){Ue(i[n],e,t)}else Ue(i,e,t)}))};let Ee=null;function Be(){be.stop()}function Se(){be.start()}const be=new vn;function De(e,t,i,n){if(!1===e.visible)return;if(e.layers.test(t.layers))if(e.isGroup)i=e.renderOrder;else if(e.isLOD)!0===e.autoUpdate&&e.update(t);else if(e.isLight)u.pushLight(e),e.castShadow&&u.pushShadow(e);else if(e.isSprite){if(!e.frustumCulled||K.intersectsSprite(e)){n&&W.setFromMatrixPosition(e.matrixWorld).applyMatrix4(j);const t=oe.update(e),r=e.material;r.visible&&d.push(e,t,r,i,W.z,null)}}else if(e.isImmediateRenderObject)n&&W.setFromMatrixPosition(e.matrixWorld).applyMatrix4(j),d.push(e,null,e.material,i,W.z,null);else if((e.isMesh||e.isLine||e.isPoints)&&(e.isSkinnedMesh&&e.skeleton.frame!==$.render.frame&&(e.skeleton.update(),e.skeleton.frame=$.render.frame),!e.frustumCulled||K.intersectsObject(e))){n&&W.setFromMatrixPosition(e.matrixWorld).applyMatrix4(j);const t=oe.update(e),r=e.material;if(Array.isArray(r)){const n=t.groups;for(let o=0,a=n.length;a>o;o++){const a=n[o],s=r[a.materialIndex];s&&s.visible&&d.push(e,t,s,i,W.z,a)}}else r.visible&&d.push(e,t,r,i,W.z,null)}const r=e.children;for(let e=0,o=r.length;o>e;e++)De(r[e],t,i,n)}function Te(e,t,i){const n=!0===t.isScene?t.overrideMaterial:null;for(let r=0,o=e.length;o>r;r++){const o=e[r],a=o.object,s=o.geometry,l=null===n?o.material:n,c=o.group;if(i.isArrayCamera){const e=i.cameras;for(let i=0,n=e.length;n>i;i++){const n=e[i];a.layers.test(n.layers)&&(_.viewport(b.copy(n.viewport)),u.setupLightsView(n),Re(a,t,n,s,l,c))}}else Re(a,t,i,s,l,c)}}function Re(e,t,i,n,r,o){if(e.onBeforeRender(m,t,i,n,r,o),e.modelViewMatrix.multiplyMatrices(i.matrixWorldInverse,e.matrixWorld),e.normalMatrix.getNormalMatrix(e.modelViewMatrix),e.isImmediateRenderObject){const n=Qe(i,t,r,e);_.setMaterial(r),Ae.reset(),function(e,t){e.render((function(e){m.renderBufferImmediate(e,t)}))}(e,n)}else m.renderBufferDirect(i,t,n,r,e,o);e.onAfterRender(m,t,i,n,r,o)}function Ue(e,t,i){!0!==t.isScene&&(t=J);const n=ee.get(e),r=u.state.lights,o=r.state.version,a=ae.getParameters(e,r.state,u.state.shadowsArray,t,i),s=ae.getProgramCacheKey(a);let l=n.programs;n.environment=e.isMeshStandardMaterial?t.environment:null,n.fog=t.fog,n.envMap=ie.get(e.envMap||n.environment),void 0===l&&(e.addEventListener("dispose",Me),l=new Map,n.programs=l);let c=l.get(s);if(void 0!==c){if(n.currentProgram===c&&n.lightsStateVersion===o)return Fe(e,a),c}else a.uniforms=ae.getUniforms(e),e.onBuild(a,m),e.onBeforeCompile(a,m),c=ae.acquireProgram(a,s),l.set(s,c),n.uniforms=a.uniforms;const h=n.uniforms;(e.isShaderMaterial||e.isRawShaderMaterial)&&!0!==e.clipping||(h.clippingPlanes=he.uniform),Fe(e,a),n.needsLights=function(e){return e.isMeshLambertMaterial||e.isMeshToonMaterial||e.isMeshPhongMaterial||e.isMeshStandardMaterial||e.isShadowMaterial||e.isShaderMaterial&&!0===e.lights}(e),n.lightsStateVersion=o,n.needsLights&&(h.ambientLightColor.value=r.state.ambient,h.lightProbe.value=r.state.probe,h.directionalLights.value=r.state.directional,h.directionalLightShadows.value=r.state.directionalShadow,h.spotLights.value=r.state.spot,h.spotLightShadows.value=r.state.spotShadow,h.rectAreaLights.value=r.state.rectArea,h.ltc_1.value=r.state.rectAreaLTC1,h.ltc_2.value=r.state.rectAreaLTC2,h.pointLights.value=r.state.point,h.pointLightShadows.value=r.state.pointShadow,h.hemisphereLights.value=r.state.hemi,h.directionalShadowMap.value=r.state.directionalShadowMap,h.directionalShadowMatrix.value=r.state.directionalShadowMatrix,h.spotShadowMap.value=r.state.spotShadowMap,h.spotShadowMatrix.value=r.state.spotShadowMatrix,h.pointShadowMap.value=r.state.pointShadowMap,h.pointShadowMatrix.value=r.state.pointShadowMatrix);const d=c.getUniforms(),p=Hr.seqWithValue(d.seq,h);return n.currentProgram=c,n.uniformsList=p,c}function Fe(e,t){const i=ee.get(e);i.outputEncoding=t.outputEncoding,i.instancing=t.instancing,i.skinning=t.skinning,i.numClippingPlanes=t.numClippingPlanes,i.numIntersection=t.numClipIntersection,i.vertexAlphas=t.vertexAlphas}function Qe(e,t,i,n){!0!==t.isScene&&(t=J),te.resetTextureUnits();const r=t.fog,o=null===I?m.outputEncoding:I.texture.encoding,a=ie.get(i.envMap||(i.isMeshStandardMaterial?t.environment:null)),s=!0===i.vertexColors&&n.geometry&&n.geometry.attributes.color&&4===n.geometry.attributes.color.itemSize,l=ee.get(i),c=u.state.lights;if(!0===V&&(!0===Y||e!==E)){he.setState(i,e,e===E&&i.id===M)}let h=!1;i.version===l.__version?l.needsLights&&l.lightsStateVersion!==c.state.version||l.outputEncoding!==o||n.isInstancedMesh&&!1===l.instancing?h=!0:n.isInstancedMesh||!0!==l.instancing?n.isSkinnedMesh&&!1===l.skinning?h=!0:n.isSkinnedMesh||!0!==l.skinning?l.envMap!==a||i.fog&&l.fog!==r?h=!0:void 0===l.numClippingPlanes||l.numClippingPlanes===he.numPlanes&&l.numIntersection===he.numIntersection?l.vertexAlphas!==s&&(h=!0):h=!0:h=!0:h=!0:(h=!0,l.__version=i.version);let d=l.currentProgram;!0===h&&(d=Ue(i,t,n));let p=!1,g=!1,f=!1;const A=d.getUniforms(),y=l.uniforms;if(_.useProgram(d.program)&&(p=!0,g=!0,f=!0),i.id!==M&&(M=i.id,g=!0),p||E!==e){if(A.setValue(ye,"projectionMatrix",e.projectionMatrix),Z.logarithmicDepthBuffer&&A.setValue(ye,"logDepthBufFC",2/(Math.log(e.far+1)/Math.LN2)),E!==e&&(E=e,g=!0,f=!0),i.isShaderMaterial||i.isMeshPhongMaterial||i.isMeshToonMaterial||i.isMeshStandardMaterial||i.envMap){const t=A.map.cameraPosition;void 0!==t&&t.setValue(ye,W.setFromMatrixPosition(e.matrixWorld))}(i.isMeshPhongMaterial||i.isMeshToonMaterial||i.isMeshLambertMaterial||i.isMeshBasicMaterial||i.isMeshStandardMaterial||i.isShaderMaterial)&&A.setValue(ye,"isOrthographic",!0===e.isOrthographicCamera),(i.isMeshPhongMaterial||i.isMeshToonMaterial||i.isMeshLambertMaterial||i.isMeshBasicMaterial||i.isMeshStandardMaterial||i.isShaderMaterial||i.isShadowMaterial||n.isSkinnedMesh)&&A.setValue(ye,"viewMatrix",e.matrixWorldInverse)}if(n.isSkinnedMesh){A.setOptional(ye,n,"bindMatrix"),A.setOptional(ye,n,"bindMatrixInverse");const e=n.skeleton;e&&(Z.floatVertexTextures?(null===e.boneTexture&&e.computeBoneTexture(),A.setValue(ye,"boneTexture",e.boneTexture,te),A.setValue(ye,"boneTextureSize",e.boneTextureSize)):A.setOptional(ye,e,"boneMatrices"))}return(g||l.receiveShadow!==n.receiveShadow)&&(l.receiveShadow=n.receiveShadow,A.setValue(ye,"receiveShadow",n.receiveShadow)),g&&(A.setValue(ye,"toneMappingExposure",m.toneMappingExposure),l.needsLights&&function(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}(y,f),r&&i.fog&&se.refreshFogUniforms(y,r),se.refreshMaterialUniforms(y,i,F,U,H),Hr.upload(ye,l.uniformsList,y,te)),i.isShaderMaterial&&!0===i.uniformsNeedUpdate&&(Hr.upload(ye,l.uniformsList,y,te),i.uniformsNeedUpdate=!1),i.isSpriteMaterial&&A.setValue(ye,"center",n.center),A.setValue(ye,"modelViewMatrix",n.modelViewMatrix),A.setValue(ye,"normalMatrix",n.normalMatrix),A.setValue(ye,"modelMatrix",n.matrixWorld),d}be.setAnimationLoop((function(e){Ee&&Ee(e)})),"undefined"!=typeof window&&be.setContext(window),this.setAnimationLoop=function(e){Ee=e,Ie.setAnimationLoop(e),null===e?be.stop():be.start()},Ie.addEventListener("sessionstart",Be),Ie.addEventListener("sessionend",Se),this.render=function(e,t){if(void 0!==t&&!0!==t.isCamera)return void console.error("THREE.WebGLRenderer.render: camera is not an instance of THREE.Camera.");if(!0===y)return;!0===e.autoUpdate&&e.updateMatrixWorld(),null===t.parent&&t.updateMatrixWorld(),!0===Ie.enabled&&!0===Ie.isPresenting&&(!0===Ie.cameraAutoUpdate&&Ie.updateCamera(t),t=Ie.getCamera()),!0===e.isScene&&e.onBeforeRender(m,e,t,I),u=ce.get(e,g.length),u.init(),g.push(u),j.multiplyMatrices(t.projectionMatrix,t.matrixWorldInverse),K.setFromProjectionMatrix(j),Y=this.localClippingEnabled,V=he.init(this.clippingPlanes,Y,t),d=le.get(e,p.length),d.init(),p.push(d),De(e,t,0,m.sortObjects),d.finish(),!0===m.sortObjects&&d.sort(Q,L),!0===V&&he.beginShadows();de.render(u.state.shadowsArray,e,t),u.setupLights(),u.setupLightsView(t),!0===V&&he.endShadows(),!0===this.info.autoReset&&this.info.reset(),ue.render(d,e);const i=d.opaque,n=d.transmissive,r=d.transparent;i.length>0&&Te(i,e,t),n.length>0&&function(e,t,i,n){null===H&&(H=new Oe(1024,1024,{generateMipmaps:!0,minFilter:x,magFilter:A,wrapS:f,wrapT:f}));const r=m.getRenderTarget();m.setRenderTarget(H),m.clear(),Te(e,i,n),te.updateRenderTargetMipmap(H),m.setRenderTarget(r),Te(t,i,n)}(i,n,e,t),r.length>0&&Te(r,e,t),null!==I&&(te.updateRenderTargetMipmap(I),te.updateMultisampleRenderTarget(I)),!0===e.isScene&&e.onAfterRender(m,e,t),_.buffers.depth.setTest(!0),_.buffers.depth.setMask(!0),_.buffers.color.setMask(!0),_.setPolygonOffset(!1),Ae.resetDefaultState(),M=-1,E=null,g.pop(),u=g.length>0?g[g.length-1]:null,p.pop(),d=p.length>0?p[p.length-1]:null},this.getActiveCubeFace=function(){return v},this.getActiveMipmapLevel=function(){return C},this.getRenderTarget=function(){return I},this.setRenderTarget=function(e,t=0,i=0){I=e,v=t,C=i,e&&void 0===ee.get(e).__webglFramebuffer&&te.setupRenderTarget(e);let n=null,r=!1,o=!1;if(e){const i=e.texture;(i.isDataTexture3D||i.isDataTexture2DArray)&&(o=!0);const a=ee.get(e).__webglFramebuffer;e.isWebGLCubeRenderTarget?(n=a[t],r=!0):n=e.isWebGLMultisampleRenderTarget?ee.get(e).__webglMultisampledFramebuffer:a,b.copy(e.viewport),k.copy(e.scissor),T=e.scissorTest}else b.copy(O).multiplyScalar(F).floor(),k.copy(N).multiplyScalar(F).floor(),T=P;if(_.bindFramebuffer(36160,n)&&Z.drawBuffers){let t=!1;if(e)if(e.isWebGLMultipleRenderTargets){const i=e.texture;if(G.length!==i.length||36064!==G[0]){for(let e=0,t=i.length;t>e;e++)G[e]=36064+e;G.length=i.length,t=!0}}else 1===G.length&&36064===G[0]||(G[0]=36064,G.length=1,t=!0);else 1===G.length&&1029===G[0]||(G[0]=1029,G.length=1,t=!0);t&&(Z.isWebGL2?ye.drawBuffers(G):q.get("WEBGL_draw_buffers").drawBuffersWEBGL(G))}if(_.viewport(b),_.scissor(k),_.setScissorTest(T),r){const n=ee.get(e.texture);ye.framebufferTexture2D(36160,36064,34069+t,n.__webglTexture,i)}else if(o){const n=ee.get(e.texture);ye.framebufferTextureLayer(36160,36064,n.__webglTexture,i||0,t||0)}},this.readRenderTargetPixels=function(e,t,i,n,r,o,a){if(!e||!e.isWebGLRenderTarget)return void console.error("THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not THREE.WebGLRenderTarget.");let s=ee.get(e).__webglFramebuffer;if(e.isWebGLCubeRenderTarget&&void 0!==a&&(s=s[a]),s){_.bindFramebuffer(36160,s);try{const a=e.texture,s=a.format,l=a.type;if(s!==D&&me.convert(s)!==ye.getParameter(35739))return void console.error("THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not in RGBA or implementation defined format.");const c=l===S&&(q.has("EXT_color_buffer_half_float")||Z.isWebGL2&&q.has("EXT_color_buffer_float"));if(!(l===w||me.convert(l)===ye.getParameter(35738)||l===B&&(Z.isWebGL2||q.has("OES_texture_float")||q.has("WEBGL_color_buffer_float"))||c))return void console.error("THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not in UnsignedByteType or implementation defined type.");36053===ye.checkFramebufferStatus(36160)?0>t||t>e.width-n||0>i||i>e.height-r||ye.readPixels(t,i,n,r,me.convert(s),me.convert(l),o):console.error("THREE.WebGLRenderer.readRenderTargetPixels: readPixels from renderTarget failed. Framebuffer not complete.")}finally{const e=null!==I?ee.get(I).__webglFramebuffer:null;_.bindFramebuffer(36160,e)}}},this.copyFramebufferToTexture=function(e,t,i=0){const n=Math.pow(2,-i),r=Math.floor(t.image.width*n),o=Math.floor(t.image.height*n);let a=me.convert(t.format);Z.isWebGL2&&(6407===a&&(a=32849),6408===a&&(a=32856)),te.setTexture2D(t,0),ye.copyTexImage2D(3553,i,a,e.x,e.y,r,o,0),_.unbindTexture()},this.copyTextureToTexture=function(e,t,i,n=0){const r=t.image.width,o=t.image.height,a=me.convert(i.format),s=me.convert(i.type);te.setTexture2D(i,0),ye.pixelStorei(37440,i.flipY),ye.pixelStorei(37441,i.premultiplyAlpha),ye.pixelStorei(3317,i.unpackAlignment),t.isDataTexture?ye.texSubImage2D(3553,n,e.x,e.y,r,o,a,s,t.image.data):t.isCompressedTexture?ye.compressedTexSubImage2D(3553,n,e.x,e.y,t.mipmaps[0].width,t.mipmaps[0].height,a,t.mipmaps[0].data):ye.texSubImage2D(3553,n,e.x,e.y,a,s,t.image),0===n&&i.generateMipmaps&&ye.generateMipmap(3553),_.unbindTexture()},this.copyTextureToTexture3D=function(e,t,i,n,r=0){if(m.isWebGL1Renderer)return void console.warn("THREE.WebGLRenderer.copyTextureToTexture3D: can only be used with WebGL2.");const{width:o,height:a,data:s}=i.image,l=me.convert(n.format),c=me.convert(n.type);let h;if(n.isDataTexture3D)te.setTexture3D(n,0),h=32879;else{if(!n.isDataTexture2DArray)return void console.warn("THREE.WebGLRenderer.copyTextureToTexture3D: only supports THREE.DataTexture3D and THREE.DataTexture2DArray.");te.setTexture2DArray(n,0),h=35866}ye.pixelStorei(37440,n.flipY),ye.pixelStorei(37441,n.premultiplyAlpha),ye.pixelStorei(3317,n.unpackAlignment);const d=ye.getParameter(3314),u=ye.getParameter(32878),p=ye.getParameter(3316),g=ye.getParameter(3315),f=ye.getParameter(32877);ye.pixelStorei(3314,o),ye.pixelStorei(32878,a),ye.pixelStorei(3316,e.min.x),ye.pixelStorei(3315,e.min.y),ye.pixelStorei(32877,e.min.z),ye.texSubImage3D(h,r,t.x,t.y,t.z,e.max.x-e.min.x+1,e.max.y-e.min.y+1,e.max.z-e.min.z+1,l,c,s),ye.pixelStorei(3314,d),ye.pixelStorei(32878,u),ye.pixelStorei(3316,p),ye.pixelStorei(3315,g),ye.pixelStorei(32877,f),0===r&&n.generateMipmaps&&ye.generateMipmap(h),_.unbindTexture()},this.initTexture=function(e){te.setTexture2D(e,0),_.unbindTexture()},this.resetState=function(){v=0,C=0,I=null,_.reset(),Ae.reset()},"undefined"!=typeof __THREE_DEVTOOLS__&&__THREE_DEVTOOLS__.dispatchEvent(new CustomEvent("observe",{detail:this}))}class No extends Oo{}function Po(e){const t=void 0!==(e=e||{}).canvas?e.canvas:Lo(),i=void 0!==e.context?e.context:null,n=void 0!==e.alpha&&e.alpha,r=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",h=void 0!==e.failIfMajorPerformanceCaveat&&e.failIfMajorPerformanceCaveat;let d=null,u=null;const p=[],g=[];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=X,this.physicallyCorrectLights=!1,this.toneMapping=0,this.toneMappingExposure=1;const m=this;let y=!1,v=0,C=0,I=null,M=-1,E=null;const b=new Le,k=new Le;let T=null,R=t.width,U=t.height,F=1,Q=null,L=null;const O=new Le(0,0,R,U),N=new Le(0,0,R,U);let P=!1;const G=[],K=new yn;let V=!1,Y=!1,H=null;const j=new yt,W=new Ke,J={background:null,fog:null,environment:null,overrideMaterial:null,isScene:!0};function z(){return null===I?F:1}let q,Z,_,$,ee,te,ie,ne,re,oe,ae,se,le,ce,he,de,ue,pe,ge,fe,me,Ae,ye=i;function ve(e,i){for(let n=0;e.length>n;n++){const r=t.getContext(e[n],i);if(null!==r)return r}return null}try{const e={alpha:n,depth:r,stencil:o,antialias:a,premultipliedAlpha:s,preserveDrawingBuffer:l,powerPreference:c,failIfMajorPerformanceCaveat:h};if(t.addEventListener("webglcontextlost",xe,!1),t.addEventListener("webglcontextrestored",we,!1),null===ye){const t=["webgl2","webgl","experimental-webgl"];if(!0===m.isWebGL1Renderer&&t.shift(),ye=ve(t,e),null===ye)throw ve(t)?new Error("Error creating WebGL context with your selected attributes."):new Error("Error creating WebGL context.")}void 0===ye.getShaderPrecisionFormat&&(ye.getShaderPrecisionFormat=function(){return{rangeMin:1,rangeMax:1,precision:1}})}catch(e){throw console.error("THREE.WebGLRenderer: "+e.message),e}function Ce(){q=new Rn(ye),Z=new kn(ye,q,e),q.init(Z),me=new ko(ye,q,Z),_=new So(ye,q,Z),G[0]=1029,$=new Qn(ye),ee=new po,te=new bo(ye,q,_,ee,Z,me,$),ie=new Tn(m),ne=new Cn(ye,Z),Ae=new Sn(ye,q,ne,Z),re=new Un(ye,ne,$,Ae),oe=new Gn(ye,re,ne,$),pe=new Nn(ye),he=new Dn(ee),ae=new uo(m,ie,q,Z,Ae,he),se=new Qo(ee),le=new Ao(ee),ce=new wo(q,Z),ue=new En(m,ie,_,oe,s),de=new Bo(m,oe,Z),ge=new bn(ye,q,$,Z),fe=new Fn(ye,q,$,Z),$.programs=ae.programs,m.capabilities=Z,m.extensions=q,m.properties=ee,m.renderLists=le,m.shadowMap=de,m.state=_,m.info=$}Ce();const Ie=new Fo(m,ye);function xe(e){e.preventDefault(),console.log("THREE.WebGLRenderer: Context Lost."),y=!0}function we(){console.log("THREE.WebGLRenderer: Context Restored."),y=!1;const e=$.autoReset,t=de.enabled,i=de.autoUpdate,n=de.needsUpdate,r=de.type;Ce(),$.autoReset=e,de.enabled=t,de.autoUpdate=i,de.needsUpdate=n,de.type=r}function Me(e){const t=e.target;t.removeEventListener("dispose",Me),function(e){(function(e){const t=ee.get(e).programs;void 0!==t&&t.forEach((function(e){ae.releaseProgram(e)}))})(e),ee.remove(e)}(t)}this.xr=Ie,this.getContext=function(){return ye},this.getContextAttributes=function(){return ye.getContextAttributes()},this.forceContextLoss=function(){const e=q.get("WEBGL_lose_context");e&&e.loseContext()},this.forceContextRestore=function(){const e=q.get("WEBGL_lose_context");e&&e.restoreContext()},this.getPixelRatio=function(){return F},this.setPixelRatio=function(e){void 0!==e&&(F=e,this.setSize(R,U,!1))},this.getSize=function(e){return void 0===e&&(console.warn("WebGLRenderer: .getsize() now requires a Vector2 as an argument"),e=new ke),e.set(R,U)},this.setSize=function(e,i,n){Ie.isPresenting?console.warn("THREE.WebGLRenderer: Can't change size while VR device is presenting."):(R=e,U=i,t.width=Math.floor(e*F),t.height=Math.floor(i*F),!1!==n&&(t.style.width=e+"px",t.style.height=i+"px"),this.setViewport(0,0,e,i))},this.getDrawingBufferSize=function(e){return void 0===e&&(console.warn("WebGLRenderer: .getdrawingBufferSize() now requires a Vector2 as an argument"),e=new ke),e.set(R*F,U*F).floor()},this.setDrawingBufferSize=function(e,i,n){R=e,U=i,F=n,t.width=Math.floor(e*n),t.height=Math.floor(i*n),this.setViewport(0,0,e,i)},this.getCurrentViewport=function(e){return void 0===e&&(console.warn("WebGLRenderer: .getCurrentViewport() now requires a Vector4 as an argument"),e=new Le),e.copy(b)},this.getViewport=function(e){return e.copy(O)},this.setViewport=function(e,t,i,n){e.isVector4?O.set(e.x,e.y,e.z,e.w):O.set(e,t,i,n),_.viewport(b.copy(O).multiplyScalar(F).floor())},this.getScissor=function(e){return e.copy(N)},this.setScissor=function(e,t,i,n){e.isVector4?N.set(e.x,e.y,e.z,e.w):N.set(e,t,i,n),_.scissor(k.copy(N).multiplyScalar(F).floor())},this.getScissorTest=function(){return P},this.setScissorTest=function(e){_.setScissorTest(P=e)},this.setOpaqueSort=function(e){Q=e},this.setTransparentSort=function(e){L=e},this.getOpaqueSort=function(){return Q},this.getTransparentSort=function(){return L},this.getClearColor=function(e){return void 0===e&&(console.warn("WebGLRenderer: .getClearColor() now requires a Color as an argument"),e=new pi),e.copy(ue.getClearColor())},this.setClearColor=function(){ue.setClearColor.apply(ue,arguments)},this.getClearAlpha=function(){return ue.getClearAlpha()},this.setClearAlpha=function(){ue.setClearAlpha.apply(ue,arguments)},this.clear=function(e,t,i){let n=0;(void 0===e||e)&&(n|=16384),(void 0===t||t)&&(n|=256),(void 0===i||i)&&(n|=1024),ye.clear(n)},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",xe,!1),t.removeEventListener("webglcontextrestored",we,!1),le.dispose(),ce.dispose(),ee.dispose(),ie.dispose(),oe.dispose(),Ae.dispose(),Ie.dispose(),Ie.removeEventListener("sessionstart",Be),Ie.removeEventListener("sessionend",Se),H&&(H.dispose(),H=null),be.stop()},this.renderBufferImmediate=function(e,t){Ae.initAttributes();const i=ee.get(e);e.hasPositions&&!i.position&&(i.position=ye.createBuffer()),e.hasNormals&&!i.normal&&(i.normal=ye.createBuffer()),e.hasUvs&&!i.uv&&(i.uv=ye.createBuffer()),e.hasColors&&!i.color&&(i.color=ye.createBuffer());const n=t.getAttributes();e.hasPositions&&(ye.bindBuffer(34962,i.position),ye.bufferData(34962,e.positionArray,35048),Ae.enableAttribute(n.position),ye.vertexAttribPointer(n.position,3,5126,!1,0,0)),e.hasNormals&&(ye.bindBuffer(34962,i.normal),ye.bufferData(34962,e.normalArray,35048),Ae.enableAttribute(n.normal),ye.vertexAttribPointer(n.normal,3,5126,!1,0,0)),e.hasUvs&&(ye.bindBuffer(34962,i.uv),ye.bufferData(34962,e.uvArray,35048),Ae.enableAttribute(n.uv),ye.vertexAttribPointer(n.uv,2,5126,!1,0,0)),e.hasColors&&(ye.bindBuffer(34962,i.color),ye.bufferData(34962,e.colorArray,35048),Ae.enableAttribute(n.color),ye.vertexAttribPointer(n.color,3,5126,!1,0,0)),Ae.disableUnusedAttributes(),ye.drawArrays(4,0,e.count),e.count=0},this.renderBufferDirect=function(e,t,i,n,r,o){null===t&&(t=J);const a=r.isMesh&&0>r.matrixWorld.determinant(),s=Qe(e,t,n,r);_.setMaterial(n,a);let l=i.index;const c=i.attributes.position;if(null===l){if(void 0===c||0===c.count)return}else if(0===l.count)return;let h,d=1;!0===n.wireframe&&(l=re.getWireframeAttribute(i),d=2),(n.morphTargets||n.morphNormals)&&pe.update(r,i,n,s),Ae.setup(r,n,s,i,l,o);let u=ge;null!==l&&(h=ne.get(l),u=fe,u.setIndex(h));const p=null!==l?l.count:c.count,g=i.drawRange.start*d,f=i.drawRange.count*d,m=null!==o?o.start*d:0,A=null!==o?o.count*d:1/0,y=Math.max(g,m),v=Math.min(p,g+f,m+A)-1,C=Math.max(0,v-y+1);if(0!==C){if(r.isMesh)!0===n.wireframe?(_.setLineWidth(n.wireframeLinewidth*z()),u.setMode(1)):u.setMode(4);else if(r.isLine){let e=n.linewidth;void 0===e&&(e=1),_.setLineWidth(e*z()),u.setMode(r.isLineSegments?1:r.isLineLoop?2:3)}else r.isPoints?u.setMode(0):r.isSprite&&u.setMode(4);if(r.isInstancedMesh)u.renderInstances(y,C,r.multiCounts&&null!==o&&null!==o.instanceIndex?r.multiCounts[o.instanceIndex]:r.count);else if(i.isInstancedBufferGeometry){const e=Math.min(i.instanceCount,i._maxInstanceCount);u.renderInstances(y,C,e)}else u.render(y,C)}},this.compile=function(e,t){u=ce.get(e),u.init(),e.traverseVisible((function(e){e.isLight&&e.layers.test(t.layers)&&(u.pushLight(e),e.castShadow&&u.pushShadow(e))})),u.setupLights(),e.traverse((function(t){const i=t.material;if(i)if(Array.isArray(i))for(let n=0;i.length>n;n++){Ue(i[n],e,t)}else Ue(i,e,t)}))};let Ee=null;function Be(){be.stop()}function Se(){be.start()}const be=new vn;function De(e,t,i,n){if(!1===e.visible)return;if(e.layers.test(t.layers))if(e.isGroup)i=e.renderOrder;else if(e.isLOD)!0===e.autoUpdate&&e.update(t);else if(e.isLight)u.pushLight(e),e.castShadow&&u.pushShadow(e);else if(e.isSprite){if(!e.frustumCulled||K.intersectsSprite(e)){n&&W.setFromMatrixPosition(e.matrixWorld).applyMatrix4(j);const t=oe.update(e),r=e.material;r.visible&&d.push(e,t,r,i,W.z,null)}}else if(e.isImmediateRenderObject)n&&W.setFromMatrixPosition(e.matrixWorld).applyMatrix4(j),d.push(e,null,e.material,i,W.z,null);else if((e.isMesh||e.isLine||e.isPoints)&&(e.isSkinnedMesh&&e.skeleton.frame!==$.render.frame&&(e.skeleton.update(),e.skeleton.frame=$.render.frame),!e.frustumCulled||K.intersectsObject(e))){n&&W.setFromMatrixPosition(e.matrixWorld).applyMatrix4(j);const t=oe.update(e),r=e.material;if(Array.isArray(r)){const n=t.groups;for(let o=0,a=n.length;a>o;o++){const a=n[o],s=r[a.materialIndex];s&&s.visible&&d.push(e,t,s,i,W.z,a)}}else r.visible&&d.push(e,t,r,i,W.z,null)}const r=e.children;for(let e=0,o=r.length;o>e;e++)De(r[e],t,i,n)}function Te(e,t,i){const n=!0===t.isScene?t.overrideMaterial:null;for(let r=0,o=e.length;o>r;r++){const o=e[r],a=o.object,s=o.geometry,l=null===n?o.material:n,c=o.group;if(i.isArrayCamera){const e=i.cameras;for(let i=0,n=e.length;n>i;i++){const n=e[i];a.layers.test(n.layers)&&(_.viewport(b.copy(n.viewport)),u.setupLightsView(n),Re(a,t,n,s,l,c))}}else Re(a,t,i,s,l,c)}}function Re(e,t,i,n,r,o){if(e.onBeforeRender(m,t,i,n,r,o),e.modelViewMatrix.multiplyMatrices(i.matrixWorldInverse,e.matrixWorld),e.normalMatrix.getNormalMatrix(e.modelViewMatrix),e.isImmediateRenderObject){const n=Qe(i,t,r,e);_.setMaterial(r),Ae.reset(),function(e,t){e.render((function(e){m.renderBufferImmediate(e,t)}))}(e,n)}else m.renderBufferDirect(i,t,n,r,e,o);e.onAfterRender(m,t,i,n,r,o)}function Ue(e,t,i){!0!==t.isScene&&(t=J);const n=ee.get(e),r=u.state.lights,o=r.state.version,a=ae.getParameters(e,r.state,u.state.shadowsArray,t,i),s=ae.getProgramCacheKey(a);let l=n.programs;n.environment=e.isMeshStandardMaterial?t.environment:null,n.fog=t.fog,n.envMap=ie.get(e.envMap||n.environment),void 0===l&&(e.addEventListener("dispose",Me),l=new Map,n.programs=l);let c=l.get(s);if(void 0!==c){if(n.currentProgram===c&&n.lightsStateVersion===o)return Fe(e,a),c}else a.uniforms=ae.getUniforms(e),e.onBuild(a,m),e.onBeforeCompile(a,m),c=ae.acquireProgram(a,s),l.set(s,c),n.uniforms=a.uniforms;const h=n.uniforms;(e.isShaderMaterial||e.isRawShaderMaterial)&&!0!==e.clipping||(h.clippingPlanes=he.uniform),Fe(e,a),n.needsLights=function(e){return e.isMeshLambertMaterial||e.isMeshToonMaterial||e.isMeshPhongMaterial||e.isMeshStandardMaterial||e.isShadowMaterial||e.isShaderMaterial&&!0===e.lights}(e),n.lightsStateVersion=o,n.needsLights&&(h.ambientLightColor.value=r.state.ambient,h.lightProbe.value=r.state.probe,h.directionalLights.value=r.state.directional,h.directionalLightShadows.value=r.state.directionalShadow,h.spotLights.value=r.state.spot,h.spotLightShadows.value=r.state.spotShadow,h.rectAreaLights.value=r.state.rectArea,h.ltc_1.value=r.state.rectAreaLTC1,h.ltc_2.value=r.state.rectAreaLTC2,h.pointLights.value=r.state.point,h.pointLightShadows.value=r.state.pointShadow,h.hemisphereLights.value=r.state.hemi,h.directionalShadowMap.value=r.state.directionalShadowMap,h.directionalShadowMatrix.value=r.state.directionalShadowMatrix,h.spotShadowMap.value=r.state.spotShadowMap,h.spotShadowMatrix.value=r.state.spotShadowMatrix,h.pointShadowMap.value=r.state.pointShadowMap,h.pointShadowMatrix.value=r.state.pointShadowMatrix);const d=c.getUniforms(),p=Hr.seqWithValue(d.seq,h);return n.currentProgram=c,n.uniformsList=p,c}function Fe(e,t){const i=ee.get(e);i.outputEncoding=t.outputEncoding,i.instancing=t.instancing,i.skinning=t.skinning,i.numClippingPlanes=t.numClippingPlanes,i.numIntersection=t.numClipIntersection,i.vertexAlphas=t.vertexAlphas}function Qe(e,t,i,n){!0!==t.isScene&&(t=J),te.resetTextureUnits();const r=t.fog,o=null===I?m.outputEncoding:I.texture.encoding,a=ie.get(i.envMap||(i.isMeshStandardMaterial?t.environment:null)),s=!0===i.vertexColors&&n.geometry&&n.geometry.attributes.color&&4===n.geometry.attributes.color.itemSize,l=ee.get(i),c=u.state.lights;if(!0===V&&(!0===Y||e!==E)){he.setState(i,e,e===E&&i.id===M)}let h=!1;i.version===l.__version?l.needsLights&&l.lightsStateVersion!==c.state.version||l.outputEncoding!==o||n.isInstancedMesh&&!1===l.instancing?h=!0:n.isInstancedMesh||!0!==l.instancing?n.isSkinnedMesh&&!1===l.skinning?h=!0:n.isSkinnedMesh||!0!==l.skinning?l.envMap!==a||i.fog&&l.fog!==r?h=!0:void 0===l.numClippingPlanes||l.numClippingPlanes===he.numPlanes&&l.numIntersection===he.numIntersection?l.vertexAlphas!==s&&(h=!0):h=!0:h=!0:h=!0:(h=!0,l.__version=i.version);let d=l.currentProgram;!0===h&&(d=Ue(i,t,n));let p=!1,g=!1,f=!1;const A=d.getUniforms(),y=l.uniforms;if(_.useProgram(d.program)&&(p=!0,g=!0,f=!0),i.id!==M&&(M=i.id,g=!0),p||E!==e){if(A.setValue(ye,"projectionMatrix",e.projectionMatrix),Z.logarithmicDepthBuffer&&A.setValue(ye,"logDepthBufFC",2/(Math.log(e.far+1)/Math.LN2)),E!==e&&(E=e,g=!0,f=!0),i.isShaderMaterial||i.isMeshPhongMaterial||i.isMeshToonMaterial||i.isMeshStandardMaterial||i.envMap){const t=A.map.cameraPosition;void 0!==t&&t.setValue(ye,W.setFromMatrixPosition(e.matrixWorld))}(i.isMeshPhongMaterial||i.isMeshToonMaterial||i.isMeshLambertMaterial||i.isMeshBasicMaterial||i.isMeshStandardMaterial||i.isShaderMaterial)&&A.setValue(ye,"isOrthographic",!0===e.isOrthographicCamera),(i.isMeshPhongMaterial||i.isMeshToonMaterial||i.isMeshLambertMaterial||i.isMeshBasicMaterial||i.isMeshStandardMaterial||i.isShaderMaterial||i.isShadowMaterial||n.isSkinnedMesh)&&A.setValue(ye,"viewMatrix",e.matrixWorldInverse)}if(n.isSkinnedMesh){A.setOptional(ye,n,"bindMatrix"),A.setOptional(ye,n,"bindMatrixInverse");const e=n.skeleton;e&&(Z.floatVertexTextures?(null===e.boneTexture&&e.computeBoneTexture(),A.setValue(ye,"boneTexture",e.boneTexture,te),A.setValue(ye,"boneTextureSize",e.boneTextureSize)):A.setOptional(ye,e,"boneMatrices"))}return(g||l.receiveShadow!==n.receiveShadow)&&(l.receiveShadow=n.receiveShadow,A.setValue(ye,"receiveShadow",n.receiveShadow)),g&&(A.setValue(ye,"toneMappingExposure",m.toneMappingExposure),l.needsLights&&function(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}(y,f),r&&i.fog&&se.refreshFogUniforms(y,r),se.refreshMaterialUniforms(y,i,F,U,H),Hr.upload(ye,l.uniformsList,y,te)),i.isShaderMaterial&&!0===i.uniformsNeedUpdate&&(Hr.upload(ye,l.uniformsList,y,te),i.uniformsNeedUpdate=!1),i.isSpriteMaterial&&A.setValue(ye,"center",n.center),A.setValue(ye,"modelViewMatrix",n.modelViewMatrix),A.setValue(ye,"normalMatrix",n.normalMatrix),A.setValue(ye,"modelMatrix",n.matrixWorld),d}be.setAnimationLoop((function(e){Ee&&Ee(e)})),"undefined"!=typeof window&&be.setContext(window),this.setAnimationLoop=function(e){Ee=e,Ie.setAnimationLoop(e),null===e?be.stop():be.start()},Ie.addEventListener("sessionstart",Be),Ie.addEventListener("sessionend",Se),this.render=function(e,t){if(void 0!==t&&!0!==t.isCamera)return void console.error("THREE.WebGLRenderer.render: camera is not an instance of THREE.Camera.");if(!0===y)return;!0===e.autoUpdate&&e.updateMatrixWorld(),null===t.parent&&t.updateMatrixWorld(),!0===Ie.enabled&&!0===Ie.isPresenting&&(!0===Ie.cameraAutoUpdate&&Ie.updateCamera(t),t=Ie.getCamera()),!0===e.isScene&&e.onBeforeRender(m,e,t,I),u=ce.get(e,g.length),u.init(),g.push(u),j.multiplyMatrices(t.projectionMatrix,t.matrixWorldInverse),K.setFromProjectionMatrix(j),Y=this.localClippingEnabled,V=he.init(this.clippingPlanes,Y,t),d=le.get(e,p.length),d.init(),p.push(d),De(e,t,0,m.sortObjects),d.finish(),!0===m.sortObjects&&d.sort(Q,L),!0===V&&he.beginShadows();de.render(u.state.shadowsArray,e,t),u.setupLights(),u.setupLightsView(t),!0===V&&he.endShadows(),!0===this.info.autoReset&&this.info.reset(),ue.render(d,e);const i=d.opaque,n=d.transmissive,r=d.transparent;i.length>0&&Te(i,e,t),n.length>0&&function(e,t,i,n){null===H&&(H=new Oe(1024,1024,{generateMipmaps:!0,minFilter:x,magFilter:A,wrapS:f,wrapT:f}));const r=m.getRenderTarget();m.setRenderTarget(H),m.clear(),Te(e,i,n),te.updateRenderTargetMipmap(H),m.setRenderTarget(r),Te(t,i,n)}(i,n,e,t),r.length>0&&Te(r,e,t),null!==I&&(te.updateRenderTargetMipmap(I),te.updateMultisampleRenderTarget(I)),!0===e.isScene&&e.onAfterRender(m,e,t),_.buffers.depth.setTest(!0),_.buffers.depth.setMask(!0),_.buffers.color.setMask(!0),_.setPolygonOffset(!1),Ae.resetDefaultState(),M=-1,E=null,g.pop(),u=g.length>0?g[g.length-1]:null,p.pop(),d=p.length>0?p[p.length-1]:null},this.getActiveCubeFace=function(){return v},this.getActiveMipmapLevel=function(){return C},this.getRenderTarget=function(){return I},this.setRenderTarget=function(e,t=0,i=0){I=e,v=t,C=i,e&&void 0===ee.get(e).__webglFramebuffer&&te.setupRenderTarget(e);let n=null,r=!1,o=!1;if(e){const i=e.texture;(i.isDataTexture3D||i.isDataTexture2DArray)&&(o=!0);const a=ee.get(e).__webglFramebuffer;e.isWebGLCubeRenderTarget?(n=a[t],r=!0):n=e.isWebGLMultisampleRenderTarget?ee.get(e).__webglMultisampledFramebuffer:a,b.copy(e.viewport),k.copy(e.scissor),T=e.scissorTest}else b.copy(O).multiplyScalar(F).floor(),k.copy(N).multiplyScalar(F).floor(),T=P;if(_.bindFramebuffer(36160,n)&&Z.drawBuffers){let t=!1;if(e)if(e.isWebGLMultipleRenderTargets){const i=e.texture;if(G.length!==i.length||36064!==G[0]){for(let e=0,t=i.length;t>e;e++)G[e]=36064+e;G.length=i.length,t=!0}}else 1===G.length&&36064===G[0]||(G[0]=36064,G.length=1,t=!0);else 1===G.length&&1029===G[0]||(G[0]=1029,G.length=1,t=!0);t&&(Z.isWebGL2?ye.drawBuffers(G):q.get("WEBGL_draw_buffers").drawBuffersWEBGL(G))}if(_.viewport(b),_.scissor(k),_.setScissorTest(T),r){const n=ee.get(e.texture);ye.framebufferTexture2D(36160,36064,34069+t,n.__webglTexture,i)}else if(o){const n=ee.get(e.texture);ye.framebufferTextureLayer(36160,36064,n.__webglTexture,i||0,t||0)}},this.readRenderTargetPixels=function(e,t,i,n,r,o,a){if(!e||!e.isWebGLRenderTarget)return void console.error("THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not THREE.WebGLRenderTarget.");let s=ee.get(e).__webglFramebuffer;if(e.isWebGLCubeRenderTarget&&void 0!==a&&(s=s[a]),s){_.bindFramebuffer(36160,s);try{const a=e.texture,s=a.format,l=a.type;if(s!==D&&me.convert(s)!==ye.getParameter(35739))return void console.error("THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not in RGBA or implementation defined format.");const c=l===S&&(q.has("EXT_color_buffer_half_float")||Z.isWebGL2&&q.has("EXT_color_buffer_float"));if(!(l===w||me.convert(l)===ye.getParameter(35738)||l===B&&(Z.isWebGL2||q.has("OES_texture_float")||q.has("WEBGL_color_buffer_float"))||c))return void console.error("THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not in UnsignedByteType or implementation defined type.");36053===ye.checkFramebufferStatus(36160)?0>t||t>e.width-n||0>i||i>e.height-r||ye.readPixels(t,i,n,r,me.convert(s),me.convert(l),o):console.error("THREE.WebGLRenderer.readRenderTargetPixels: readPixels from renderTarget failed. Framebuffer not complete.")}finally{const e=null!==I?ee.get(I).__webglFramebuffer:null;_.bindFramebuffer(36160,e)}}},this.copyFramebufferToTexture=function(e,t,i=0){const n=Math.pow(2,-i),r=Math.floor(t.image.width*n),o=Math.floor(t.image.height*n);let a=me.convert(t.format);Z.isWebGL2&&(6407===a&&(a=32849),6408===a&&(a=32856)),te.setTexture2D(t,0),ye.copyTexImage2D(3553,i,a,e.x,e.y,r,o,0),_.unbindTexture()},this.copyTextureToTexture=function(e,t,i,n=0){const r=t.image.width,o=t.image.height,a=me.convert(i.format),s=me.convert(i.type);te.setTexture2D(i,0),ye.pixelStorei(37440,i.flipY),ye.pixelStorei(37441,i.premultiplyAlpha),ye.pixelStorei(3317,i.unpackAlignment),t.isDataTexture?ye.texSubImage2D(3553,n,e.x,e.y,r,o,a,s,t.image.data):t.isCompressedTexture?ye.compressedTexSubImage2D(3553,n,e.x,e.y,t.mipmaps[0].width,t.mipmaps[0].height,a,t.mipmaps[0].data):ye.texSubImage2D(3553,n,e.x,e.y,a,s,t.image),0===n&&i.generateMipmaps&&ye.generateMipmap(3553),_.unbindTexture()},this.copyTextureToTexture3D=function(e,t,i,n,r=0){if(m.isWebGL1Renderer)return void console.warn("THREE.WebGLRenderer.copyTextureToTexture3D: can only be used with WebGL2.");const{width:o,height:a,data:s}=i.image,l=me.convert(n.format),c=me.convert(n.type);let h;if(n.isDataTexture3D)te.setTexture3D(n,0),h=32879;else{if(!n.isDataTexture2DArray)return void console.warn("THREE.WebGLRenderer.copyTextureToTexture3D: only supports THREE.DataTexture3D and THREE.DataTexture2DArray.");te.setTexture2DArray(n,0),h=35866}ye.pixelStorei(37440,n.flipY),ye.pixelStorei(37441,n.premultiplyAlpha),ye.pixelStorei(3317,n.unpackAlignment);const d=ye.getParameter(3314),u=ye.getParameter(32878),p=ye.getParameter(3316),g=ye.getParameter(3315),f=ye.getParameter(32877);ye.pixelStorei(3314,o),ye.pixelStorei(32878,a),ye.pixelStorei(3316,e.min.x),ye.pixelStorei(3315,e.min.y),ye.pixelStorei(32877,e.min.z),ye.texSubImage3D(h,r,t.x,t.y,t.z,e.max.x-e.min.x+1,e.max.y-e.min.y+1,e.max.z-e.min.z+1,l,c,s),ye.pixelStorei(3314,d),ye.pixelStorei(32878,u),ye.pixelStorei(3316,p),ye.pixelStorei(3315,g),ye.pixelStorei(32877,f),0===r&&n.generateMipmaps&&ye.generateMipmap(h),_.unbindTexture()},this.initTexture=function(e){te.setTexture2D(e,0),_.unbindTexture()},this.resetState=function(){v=0,C=0,I=null,_.reset(),Ae.reset()},"undefined"!=typeof __THREE_DEVTOOLS__&&__THREE_DEVTOOLS__.dispatchEvent(new CustomEvent("observe",{detail:this}))}No.prototype.isWebGL1Renderer=!0;class Go{constructor(e,t=25e-5){this.name="",this.color=new pi(e),this.density=t}clone(){return new Go(this.color,this.density)}toJSON(){return{type:"FogExp2",color:this.color.getHex(),density:this.density}}}Go.prototype.isFogExp2=!0;class Ko{constructor(e,t=1,i=1e3){this.name="",this.color=new pi(e),this.near=t,this.far=i}clone(){return new Ko(this.color,this.near,this.far)}toJSON(){return{type:"Fog",color:this.color.getHex(),near:this.near,far:this.far}}}Ko.prototype.isFog=!0;class Vo extends Yt{constructor(){super(),this.type="Scene",this.background=null,this.environment=null,this.fog=null,this.overrideMaterial=null,this.autoUpdate=!0,"undefined"!=typeof __THREE_DEVTOOLS__&&__THREE_DEVTOOLS__.dispatchEvent(new CustomEvent("observe",{detail:this}))}copy(e,t){return super.copy(e,t),null!==e.background&&(this.background=e.background.clone()),null!==e.environment&&(this.environment=e.environment.clone()),null!==e.fog&&(this.fog=e.fog.clone()),null!==e.overrideMaterial&&(this.overrideMaterial=e.overrideMaterial.clone()),this.autoUpdate=e.autoUpdate,this.matrixAutoUpdate=e.matrixAutoUpdate,this}toJSON(e){const t=super.toJSON(e);return null!==this.background&&(t.object.background=this.background.toJSON(e)),null!==this.environment&&(t.object.environment=this.environment.toJSON(e)),null!==this.fog&&(t.object.fog=this.fog.toJSON()),t}}Vo.prototype.isScene=!0;class Yo{constructor(e,t){this.array=e,this.stride=t,this.count=void 0!==e?e.length/t:0,this.usage=pe,this.updateRange={offset:0,count:-1},this.version=0,this.uuid=Ie()}set needsUpdate(e){!0===e&&this.version++}onUploadCallback(){}setUsage(e){return this.usage=e,this}copy(e){return this.array=new e.array.constructor(e.array),this.count=e.count,this.stride=e.stride,this.usage=e.usage,this}copyAt(e,t,i){e*=this.stride,i*=t.stride;for(let n=0,r=this.stride;r>n;n++)this.array[e+n]=t.array[i+n];return this}set(e,t=0){return this.array.set(e,t),this}clone(e){void 0===e.arrayBuffers&&(e.arrayBuffers={}),void 0===this.array.buffer._uuid&&(this.array.buffer._uuid=Ie()),void 0===e.arrayBuffers[this.array.buffer._uuid]&&(e.arrayBuffers[this.array.buffer._uuid]=this.array.slice(0).buffer);const t=new this.array.constructor(e.arrayBuffers[this.array.buffer._uuid]),i=new this.constructor(t,this.stride);return i.setUsage(this.usage),i}onUpload(e){return this.onUploadCallback=e,this}toJSON(e){return void 0===e.arrayBuffers&&(e.arrayBuffers={}),void 0===this.array.buffer._uuid&&(this.array.buffer._uuid=Ie()),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}}}Yo.prototype.isInterleavedBuffer=!0;const Ho=new Ke;class jo{constructor(e,t,i,n){this.name="",this.data=e,this.itemSize=t,this.offset=i,this.normalized=!0===n}get count(){return this.data.count}get array(){return this.data.array}set needsUpdate(e){this.data.needsUpdate=e}applyMatrix4(e){for(let t=0,i=this.data.count;i>t;t++)Ho.x=this.getX(t),Ho.y=this.getY(t),Ho.z=this.getZ(t),Ho.applyMatrix4(e),this.setXYZ(t,Ho.x,Ho.y,Ho.z);return this}applyNormalMatrix(e){for(let t=0,i=this.count;i>t;t++)Ho.x=this.getX(t),Ho.y=this.getY(t),Ho.z=this.getZ(t),Ho.applyNormalMatrix(e),this.setXYZ(t,Ho.x,Ho.y,Ho.z);return this}transformDirection(e){for(let t=0,i=this.count;i>t;t++)Ho.x=this.getX(t),Ho.y=this.getY(t),Ho.z=this.getZ(t),Ho.transformDirection(e),this.setXYZ(t,Ho.x,Ho.y,Ho.z);return this}setX(e,t){return this.data.array[e*this.data.stride+this.offset]=t,this}setY(e,t){return this.data.array[e*this.data.stride+this.offset+1]=t,this}setZ(e,t){return this.data.array[e*this.data.stride+this.offset+2]=t,this}setW(e,t){return this.data.array[e*this.data.stride+this.offset+3]=t,this}getX(e){return this.data.array[e*this.data.stride+this.offset]}getY(e){return this.data.array[e*this.data.stride+this.offset+1]}getZ(e){return this.data.array[e*this.data.stride+this.offset+2]}getW(e){return this.data.array[e*this.data.stride+this.offset+3]}setXY(e,t,i){return this.data.array[(e=e*this.data.stride+this.offset)+0]=t,this.data.array[e+1]=i,this}setXYZ(e,t,i,n){return this.data.array[(e=e*this.data.stride+this.offset)+0]=t,this.data.array[e+1]=i,this.data.array[e+2]=n,this}setXYZW(e,t,i,n,r){return this.data.array[(e=e*this.data.stride+this.offset)+0]=t,this.data.array[e+1]=i,this.data.array[e+2]=n,this.data.array[e+3]=r,this}clone(e){if(void 0===e){console.log("THREE.InterleavedBufferAttribute.clone(): Cloning an interlaved buffer attribute will deinterleave buffer data.");const e=[];for(let t=0;this.count>t;t++){const i=t*this.data.stride+this.offset;for(let t=0;this.itemSize>t;t++)e.push(this.data.array[i+t])}return new Ai(new this.array.constructor(e),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 jo(e.interleavedBuffers[this.data.uuid],this.itemSize,this.offset,this.normalized)}toJSON(e){if(void 0===e){console.log("THREE.InterleavedBufferAttribute.toJSON(): Serializing an interlaved buffer attribute will deinterleave buffer data.");const e=[];for(let t=0;this.count>t;t++){const i=t*this.data.stride+this.offset;for(let t=0;this.itemSize>t;t++)e.push(this.data.array[i+t])}return{itemSize:this.itemSize,type:this.array.constructor.name,array:e,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}}}jo.prototype.isInterleavedBufferAttribute=!0;class Wo extends ai{constructor(e){super(),this.type="SpriteMaterial",this.color=new pi(16777215),this.map=null,this.alphaMap=null,this.rotation=0,this.sizeAttenuation=!0,this.transparent=!0,this.setValues(e)}copy(e){return super.copy(e),this.color.copy(e.color),this.map=e.map,this.alphaMap=e.alphaMap,this.rotation=e.rotation,this.sizeAttenuation=e.sizeAttenuation,this}}let Jo;Wo.prototype.isSpriteMaterial=!0;const zo=new Ke,qo=new Ke,Zo=new Ke,Xo=new ke,_o=new ke,$o=new yt,ea=new Ke,ta=new Ke,ia=new Ke,na=new ke,ra=new ke,oa=new ke;class aa extends Yt{constructor(e){if(super(),this.type="Sprite",void 0===Jo){Jo=new Ni;const e=new Float32Array([-.5,-.5,0,0,0,.5,-.5,0,1,0,.5,.5,0,1,1,-.5,.5,0,0,1]),t=new Yo(e,5);Jo.setIndex([0,1,2,0,2,3]),Jo.setAttribute("position",new jo(t,3,0,!1)),Jo.setAttribute("uv",new jo(t,2,3,!1))}this.geometry=Jo,this.material=void 0!==e?e:new Wo,this.center=new ke(.5,.5)}raycast(e,t){null===e.camera&&console.error('THREE.Sprite: "Raycaster.camera" needs to be set in order to raycast against sprites.'),qo.setFromMatrixScale(this.matrixWorld),$o.copy(e.camera.matrixWorld),this.modelViewMatrix.multiplyMatrices(e.camera.matrixWorldInverse,this.matrixWorld),Zo.setFromMatrixPosition(this.modelViewMatrix),e.camera.isPerspectiveCamera&&!1===this.material.sizeAttenuation&&qo.multiplyScalar(-Zo.z);const i=this.material.rotation;let n,r;0!==i&&(r=Math.cos(i),n=Math.sin(i));const o=this.center;sa(ea.set(-.5,-.5,0),Zo,o,qo,n,r),sa(ta.set(.5,-.5,0),Zo,o,qo,n,r),sa(ia.set(.5,.5,0),Zo,o,qo,n,r),na.set(0,0),ra.set(1,0),oa.set(1,1);let a=e.ray.intersectTriangle(ea,ta,ia,!1,zo);if(null===a&&(sa(ta.set(-.5,.5,0),Zo,o,qo,n,r),ra.set(0,1),a=e.ray.intersectTriangle(ea,ia,ta,!1,zo),null===a))return;const s=e.ray.origin.distanceTo(zo);e.near>s||s>e.far||t.push({distance:s,point:zo.clone(),uv:ri.getUV(zo,ea,ta,ia,na,ra,oa,new ke),face:null,object:this})}copy(e){return super.copy(e),void 0!==e.center&&this.center.copy(e.center),this.material=e.material,this}}function sa(e,t,i,n,r,o){Xo.subVectors(e,i).addScalar(.5).multiply(n),void 0!==r?(_o.x=o*Xo.x-r*Xo.y,_o.y=r*Xo.x+o*Xo.y):_o.copy(Xo),e.copy(t),e.x+=_o.x,e.y+=_o.y,e.applyMatrix4($o)}aa.prototype.isSprite=!0;const la=new Ke,ca=new Ke;class ha extends Yt{constructor(){super(),this._currentLevel=0,this.type="LOD",Object.defineProperties(this,{levels:{enumerable:!0,value:[]},isLOD:{value:!0}}),this.autoUpdate=!0}copy(e){super.copy(e,!1);const t=e.levels;for(let e=0,i=t.length;i>e;e++){const i=t[e];this.addLevel(i.object.clone(),i.distance)}return this.autoUpdate=e.autoUpdate,this}addLevel(e,t=0){t=Math.abs(t);const i=this.levels;let n;for(n=0;i.length>n&&i[n].distance<=t;n++);return i.splice(n,0,{distance:t,object:e}),this.add(e),this}getCurrentLevel(){return this._currentLevel}getObjectForDistance(e){const t=this.levels;if(t.length>0){let i,n;for(i=1,n=t.length;n>i&&t[i].distance<=e;i++);return t[i-1].object}return null}raycast(e,t){if(this.levels.length>0){la.setFromMatrixPosition(this.matrixWorld);const i=e.ray.origin.distanceTo(la);this.getObjectForDistance(i).raycast(e,t)}}update(e){const t=this.levels;if(t.length>1){la.setFromMatrixPosition(e.matrixWorld),ca.setFromMatrixPosition(this.matrixWorld);const i=la.distanceTo(ca)/e.zoom;let n,r;for(t[0].object.visible=!0,n=1,r=t.length;r>n&&t[n].distance<=i;n++)t[n-1].object.visible=!1,t[n].object.visible=!0;for(this._currentLevel=n-1;r>n;n++)t[n].object.visible=!1}}toJSON(e){const t=super.toJSON(e);!1===this.autoUpdate&&(t.object.autoUpdate=!1),t.object.levels=[];const i=this.levels;for(let e=0,n=i.length;n>e;e++){const n=i[e];t.object.levels.push({object:n.object.uuid,distance:n.distance})}return t}}const da=new Ke,ua=new Le,pa=new Le,ga=new Ke,fa=new yt;class ma extends nn{constructor(e,t){super(e,t),this.type="SkinnedMesh",this.bindMode="attached",this.bindMatrix=new yt,this.bindMatrixInverse=new yt}copy(e){return super.copy(e),this.bindMode=e.bindMode,this.bindMatrix.copy(e.bindMatrix),this.bindMatrixInverse.copy(e.bindMatrixInverse),this.skeleton=e.skeleton,this}bind(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(){this.skeleton.pose()}normalizeSkinWeights(){const e=new Le,t=this.geometry.attributes.skinWeight;for(let i=0,n=t.count;n>i;i++){e.x=t.getX(i),e.y=t.getY(i),e.z=t.getZ(i),e.w=t.getW(i);const n=1/e.manhattanLength();n!==1/0?e.multiplyScalar(n):e.set(1,0,0,0),t.setXYZW(i,e.x,e.y,e.z,e.w)}}updateMatrixWorld(e){super.updateMatrixWorld(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(e,t){const i=this.skeleton,n=this.geometry;ua.fromBufferAttribute(n.attributes.skinIndex,e),pa.fromBufferAttribute(n.attributes.skinWeight,e),da.fromBufferAttribute(n.attributes.position,e).applyMatrix4(this.bindMatrix),t.set(0,0,0);for(let e=0;4>e;e++){const n=pa.getComponent(e);if(0!==n){const r=ua.getComponent(e);fa.multiplyMatrices(i.bones[r].matrixWorld,i.boneInverses[r]),t.addScaledVector(ga.copy(da).applyMatrix4(fa),n)}}return t.applyMatrix4(this.bindMatrixInverse)}}ma.prototype.isSkinnedMesh=!0;class Aa extends Yt{constructor(){super(),this.type="Bone"}}Aa.prototype.isBone=!0;class ya extends Fe{constructor(e,t,i,n,r,o,a,s,l,c,h,d){super(null,o,a,s,l,c,n,r,h,d),this.image={data:e||null,width:t||1,height:i||1},this.magFilter=void 0!==l?l:A,this.minFilter=void 0!==c?c:A,this.generateMipmaps=!1,this.flipY=!1,this.unpackAlignment=1,this.needsUpdate=!0}}ya.prototype.isDataTexture=!0;const va=new yt,Ca=new yt;class Ia{constructor(e=[],t=[]){this.uuid=Ie(),this.bones=e.slice(0),this.boneInverses=t,this.boneMatrices=null,this.boneTexture=null,this.boneTextureSize=0,this.frame=-1,this.init()}init(){const 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(let e=0,t=this.bones.length;t>e;e++)this.boneInverses.push(new yt)}}calculateInverses(){this.boneInverses.length=0;for(let e=0,t=this.bones.length;t>e;e++){const t=new yt;this.bones[e]&&t.copy(this.bones[e].matrixWorld).invert(),this.boneInverses.push(t)}}pose(){for(let e=0,t=this.bones.length;t>e;e++){const t=this.bones[e];t&&t.matrixWorld.copy(this.boneInverses[e]).invert()}for(let e=0,t=this.bones.length;t>e;e++){const t=this.bones[e];t&&(t.parent&&t.parent.isBone?(t.matrix.copy(t.parent.matrixWorld).invert(),t.matrix.multiply(t.matrixWorld)):t.matrix.copy(t.matrixWorld),t.matrix.decompose(t.position,t.quaternion,t.scale))}}update(){const e=this.bones,t=this.boneInverses,i=this.boneMatrices,n=this.boneTexture;for(let n=0,r=e.length;r>n;n++){va.multiplyMatrices(e[n]?e[n].matrixWorld:Ca,t[n]),va.toArray(i,16*n)}null!==n&&(n.needsUpdate=!0)}clone(){return new Ia(this.bones,this.boneInverses)}computeBoneTexture(){let e=Math.sqrt(4*this.bones.length);e=Be(e),e=Math.max(e,4);const t=new Float32Array(e*e*4);t.set(this.boneMatrices);const i=new ya(t,e,e,D,B);return this.boneMatrices=t,this.boneTexture=i,this.boneTextureSize=e,this}getBoneByName(e){for(let t=0,i=this.bones.length;i>t;t++){const i=this.bones[t];if(i.name===e)return i}}dispose(){null!==this.boneTexture&&(this.boneTexture.dispose(),this.boneTexture=null)}fromJSON(e,t){this.uuid=e.uuid;for(let i=0,n=e.bones.length;n>i;i++){const n=e.bones[i];let r=t[n];void 0===r&&(console.warn("THREE.Skeleton: No bone found with UUID:",n),r=new Aa),this.bones.push(r),this.boneInverses.push((new yt).fromArray(e.boneInverses[i]))}return this.init(),this}toJSON(){const e={metadata:{version:4.5,type:"Skeleton",generator:"Skeleton.toJSON"},bones:[],boneInverses:[]};e.uuid=this.uuid;const t=this.bones,i=this.boneInverses;for(let n=0,r=t.length;r>n;n++){e.bones.push(t[n].uuid);e.boneInverses.push(i[n].toArray())}return e}}const xa=new yt,wa=new yt,Ma=[],Ea=new nn;class Ba extends nn{constructor(e,t,i){super(e,t),this.instanceMatrix=new Ai(new Float32Array(16*i),16),this.instanceColor=null,this.count=i,this.frustumCulled=!1}copy(e){return super.copy(e),this.instanceMatrix.copy(e.instanceMatrix),null!==e.instanceColor&&(this.instanceColor=e.instanceColor.clone()),this.count=e.count,this}getColorAt(e,t){t.fromArray(this.instanceColor.array,3*e)}getMatrixAt(e,t){t.fromArray(this.instanceMatrix.array,16*e)}raycast(e,t){const i=this.matrixWorld,n=this.count;if(Ea.geometry=this.geometry,Ea.material=this.material,void 0!==Ea.material)for(let r=0;n>r;r++){this.getMatrixAt(r,xa),wa.multiplyMatrices(i,xa),Ea.matrixWorld=wa,Ea.raycast(e,Ma);for(let e=0,i=Ma.length;i>e;e++){const i=Ma[e];i.instanceId=r,i.object=this,t.push(i)}Ma.length=0}}setColorAt(e,t){null===this.instanceColor&&(this.instanceColor=new Ai(new Float32Array(3*this.count),3)),t.toArray(this.instanceColor.array,3*e)}setMatrixAt(e,t){t.toArray(this.instanceMatrix.array,16*e)}updateMorphTargets(){}dispose(){this.dispatchEvent({type:"dispose"})}}Ba.prototype.isInstancedMesh=!0;class Sa extends ai{constructor(e){super(),this.type="LineBasicMaterial",this.color=new pi(16777215),this.linewidth=1,this.linecap="round",this.linejoin="round",this.morphTargets=!1,this.setValues(e)}copy(e){return super.copy(e),this.color.copy(e.color),this.linewidth=e.linewidth,this.linecap=e.linecap,this.linejoin=e.linejoin,this.morphTargets=e.morphTargets,this}}Sa.prototype.isLineBasicMaterial=!0;const ba=new Ke,ka=new Ke,Da=new yt,Ta=new At,Ra=new ct;class Ua extends Yt{constructor(e=new Ni,t=new Sa){super(),this.type="Line",this.geometry=e,this.material=t,this.updateMorphTargets()}copy(e){return super.copy(e),this.material=e.material,this.geometry=e.geometry,this}computeLineDistances(){const e=this.geometry;if(e.isBufferGeometry)if(null===e.index){const t=e.attributes.position,i=[0];for(let e=1,n=t.count;n>e;e++)ba.fromBufferAttribute(t,e-1),ka.fromBufferAttribute(t,e),i[e]=i[e-1],i[e]+=ba.distanceTo(ka);e.setAttribute("lineDistance",new Bi(i,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(e,t){const i=this.geometry,n=this.matrixWorld,r=e.params.Line.threshold,o=i.drawRange;if(null===i.boundingSphere&&i.computeBoundingSphere(),Ra.copy(i.boundingSphere),Ra.applyMatrix4(n),Ra.radius+=r,!1===e.ray.intersectsSphere(Ra))return;Da.copy(n).invert(),Ta.copy(e.ray).applyMatrix4(Da);const a=r/((this.scale.x+this.scale.y+this.scale.z)/3),s=a*a,l=new Ke,c=new Ke,h=new Ke,d=new Ke,u=this.isLineSegments?2:1;if(i.isBufferGeometry){const n=i.index,r=i.attributes.position;if(null!==n){for(let i=Math.max(0,o.start),a=Math.min(n.count,o.start+o.count)-1;a>i;i+=u){const o=n.getX(i),a=n.getX(i+1);l.fromBufferAttribute(r,o),c.fromBufferAttribute(r,a);if(Ta.distanceSqToSegment(l,c,d,h)>s)continue;d.applyMatrix4(this.matrixWorld);const u=e.ray.origin.distanceTo(d);u<e.near||e.far<u||t.push({distance:u,point:h.clone().applyMatrix4(this.matrixWorld),index:i,face:null,faceIndex:null,object:this})}}else{for(let i=Math.max(0,o.start),n=Math.min(r.count,o.start+o.count)-1;n>i;i+=u){l.fromBufferAttribute(r,i),c.fromBufferAttribute(r,i+1);if(Ta.distanceSqToSegment(l,c,d,h)>s)continue;d.applyMatrix4(this.matrixWorld);const n=e.ray.origin.distanceTo(d);n<e.near||e.far<n||t.push({distance:n,point:h.clone().applyMatrix4(this.matrixWorld),index:i,face:null,faceIndex:null,object:this})}}}else i.isGeometry&&console.error("THREE.Line.raycast() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.")}updateMorphTargets(){const e=this.geometry;if(e.isBufferGeometry){const t=e.morphAttributes,i=Object.keys(t);if(i.length>0){const e=t[i[0]];if(void 0!==e){this.morphTargetInfluences=[],this.morphTargetDictionary={};for(let t=0,i=e.length;i>t;t++){const i=e[t].name||String(t);this.morphTargetInfluences.push(0),this.morphTargetDictionary[i]=t}}}}else{const t=e.morphTargets;void 0!==t&&t.length>0&&console.error("THREE.Line.updateMorphTargets() does not support THREE.Geometry. Use THREE.BufferGeometry instead.")}}}Ua.prototype.isLine=!0;const Fa=new Ke,Qa=new Ke;class La extends Ua{constructor(e,t){super(e,t),this.type="LineSegments"}computeLineDistances(){const e=this.geometry;if(e.isBufferGeometry)if(null===e.index){const t=e.attributes.position,i=[];for(let e=0,n=t.count;n>e;e+=2)Fa.fromBufferAttribute(t,e),Qa.fromBufferAttribute(t,e+1),i[e]=0===e?0:i[e-1],i[e+1]=i[e]+Fa.distanceTo(Qa);e.setAttribute("lineDistance",new Bi(i,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}}La.prototype.isLineSegments=!0;class Oa extends Ua{constructor(e,t){super(e,t),this.type="LineLoop"}}Oa.prototype.isLineLoop=!0;class Na extends ai{constructor(e){super(),this.type="PointsMaterial",this.color=new pi(16777215),this.map=null,this.alphaMap=null,this.size=1,this.sizeAttenuation=!0,this.morphTargets=!1,this.setValues(e)}copy(e){return super.copy(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}}Na.prototype.isPointsMaterial=!0;const Pa=new yt,Ga=new At,Ka=new ct,Va=new Ke;class Ya extends Yt{constructor(e=new Ni,t=new Na){super(),this.type="Points",this.geometry=e,this.material=t,this.updateMorphTargets()}copy(e){return super.copy(e),this.material=e.material,this.geometry=e.geometry,this}raycast(e,t){const i=this.geometry,n=this.matrixWorld,r=e.params.Points.threshold,o=i.drawRange;if(null===i.boundingSphere&&i.computeBoundingSphere(),Ka.copy(i.boundingSphere),Ka.applyMatrix4(n),Ka.radius+=r,!1===e.ray.intersectsSphere(Ka))return;Pa.copy(n).invert(),Ga.copy(e.ray).applyMatrix4(Pa);const a=r/((this.scale.x+this.scale.y+this.scale.z)/3),s=a*a;if(i.isBufferGeometry){const r=i.index,a=i.attributes.position;if(null!==r){for(let i=Math.max(0,o.start),l=Math.min(r.count,o.start+o.count);l>i;i++){const o=r.getX(i);Va.fromBufferAttribute(a,o),Ha(Va,o,s,n,e,t,this)}}else{for(let i=Math.max(0,o.start),r=Math.min(a.count,o.start+o.count);r>i;i++)Va.fromBufferAttribute(a,i),Ha(Va,i,s,n,e,t,this)}}else console.error("THREE.Points.raycast() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.")}updateMorphTargets(){const e=this.geometry;if(e.isBufferGeometry){const t=e.morphAttributes,i=Object.keys(t);if(i.length>0){const e=t[i[0]];if(void 0!==e){this.morphTargetInfluences=[],this.morphTargetDictionary={};for(let t=0,i=e.length;i>t;t++){const i=e[t].name||String(t);this.morphTargetInfluences.push(0),this.morphTargetDictionary[i]=t}}}}else{const t=e.morphTargets;void 0!==t&&t.length>0&&console.error("THREE.Points.updateMorphTargets() does not support THREE.Geometry. Use THREE.BufferGeometry instead.")}}}function Ha(e,t,i,n,r,o,a){const s=Ga.distanceSqToPoint(e);if(i>s){const i=new Ke;Ga.closestPointToPoint(e,i),i.applyMatrix4(n);const l=r.ray.origin.distanceTo(i);if(r.near>l||l>r.far)return;o.push({distance:l,distanceToRay:Math.sqrt(s),point:i,index:t,face:null,object:a})}}Ya.prototype.isPoints=!0;class ja extends Fe{constructor(e,t,i,n,r,o,a,s,l){super(e,t,i,n,r,o,a,s,l),this.format=void 0!==a?a:k,this.minFilter=void 0!==o?o:C,this.magFilter=void 0!==r?r:C,this.generateMipmaps=!1;const c=this;"requestVideoFrameCallback"in e&&e.requestVideoFrameCallback((function t(){c.needsUpdate=!0,e.requestVideoFrameCallback(t)}))}clone(){return new this.constructor(this.image).copy(this)}update(){const e=this.image;!1!=="requestVideoFrameCallback"in e||e.HAVE_CURRENT_DATA>e.readyState||(this.needsUpdate=!0)}}ja.prototype.isVideoTexture=!0;class Wa extends Fe{constructor(e,t,i,n,r,o,a,s,l,c,h,d){super(null,o,a,s,l,c,n,r,h,d),this.image={width:t,height:i},this.mipmaps=e,this.flipY=!1,this.generateMipmaps=!1}}Wa.prototype.isCompressedTexture=!0;class Ja extends Fe{constructor(e,t,i,n,r,o,a,s,l){super(e,t,i,n,r,o,a,s,l),this.needsUpdate=!0}}Ja.prototype.isCanvasTexture=!0;class za extends Fe{constructor(e,t,i,n,r,o,a,s,l,c){if((c=void 0!==c?c:T)!==T&&c!==R)throw new Error("DepthTexture format must be either THREE.DepthFormat or THREE.DepthStencilFormat");void 0===i&&c===T&&(i=M),void 0===i&&c===R&&(i=b),super(null,n,r,o,a,s,c,i,l),this.image={width:e,height:t},this.magFilter=void 0!==a?a:A,this.minFilter=void 0!==s?s:A,this.flipY=!1,this.generateMipmaps=!1}}za.prototype.isDepthTexture=!0;class qa extends Ni{constructor(e=1,t=8,i=0,n=2*Math.PI){super(),this.type="CircleGeometry",this.parameters={radius:e,segments:t,thetaStart:i,thetaLength:n},t=Math.max(3,t);const r=[],o=[],a=[],s=[],l=new Ke,c=new ke;o.push(0,0,0),a.push(0,0,1),s.push(.5,.5);for(let r=0,h=3;t>=r;r++,h+=3){const d=i+r/t*n;l.x=e*Math.cos(d),l.y=e*Math.sin(d),o.push(l.x,l.y,l.z),a.push(0,0,1),c.x=(o[h]/e+1)/2,c.y=(o[h+1]/e+1)/2,s.push(c.x,c.y)}for(let e=1;t>=e;e++)r.push(e,e+1,0);this.setIndex(r),this.setAttribute("position",new Bi(o,3)),this.setAttribute("normal",new Bi(a,3)),this.setAttribute("uv",new Bi(s,2))}}class Za extends Ni{constructor(e=1,t=1,i=1,n=8,r=1,o=!1,a=0,s=2*Math.PI){super(),this.type="CylinderGeometry",this.parameters={radiusTop:e,radiusBottom:t,height:i,radialSegments:n,heightSegments:r,openEnded:o,thetaStart:a,thetaLength:s};const l=this;n=Math.floor(n),r=Math.floor(r);const c=[],h=[],d=[],u=[];let p=0;const g=[],f=i/2;let m=0;function A(i){const r=p,o=new ke,g=new Ke;let A=0;const y=!0===i?e:t,v=!0===i?1:-1;for(let e=1;n>=e;e++)h.push(0,f*v,0),d.push(0,v,0),u.push(.5,.5),p++;const C=p;for(let e=0;n>=e;e++){const t=e/n*s+a,i=Math.cos(t),r=Math.sin(t);g.x=y*r,g.y=f*v,g.z=y*i,h.push(g.x,g.y,g.z),d.push(0,v,0),o.x=.5*i+.5,o.y=.5*r*v+.5,u.push(o.x,o.y),p++}for(let e=0;n>e;e++){const t=r+e,n=C+e;!0===i?c.push(n,n+1,t):c.push(n+1,n,t),A+=3}l.addGroup(m,A,!0===i?1:2),m+=A}!function(){const o=new Ke,A=new Ke;let y=0;const v=(t-e)/i;for(let l=0;r>=l;l++){const c=[],m=l/r,y=m*(t-e)+e;for(let e=0;n>=e;e++){const t=e/n,r=t*s+a,l=Math.sin(r),g=Math.cos(r);A.x=y*l,A.y=-m*i+f,A.z=y*g,h.push(A.x,A.y,A.z),o.set(l,v,g).normalize(),d.push(o.x,o.y,o.z),u.push(t,1-m),c.push(p++)}g.push(c)}for(let e=0;n>e;e++)for(let t=0;r>t;t++){const i=g[t+1][e],n=g[t+1][e+1],r=g[t][e+1];c.push(g[t][e],i,r),c.push(i,n,r),y+=6}l.addGroup(m,y,0),m+=y}(),!1===o&&(e>0&&A(!0),t>0&&A(!1)),this.setIndex(c),this.setAttribute("position",new Bi(h,3)),this.setAttribute("normal",new Bi(d,3)),this.setAttribute("uv",new Bi(u,2))}}class Xa extends Za{constructor(e=1,t=1,i=8,n=1,r=!1,o=0,a=2*Math.PI){super(0,e,t,i,n,r,o,a),this.type="ConeGeometry",this.parameters={radius:e,height:t,radialSegments:i,heightSegments:n,openEnded:r,thetaStart:o,thetaLength:a}}}class _a extends Ni{constructor(e,t,i=1,n=0){super(),this.type="PolyhedronGeometry",this.parameters={vertices:e,indices:t,radius:i,detail:n};const r=[],o=[];function a(e,t,i,n){const r=n+1,o=[];for(let n=0;r>=n;n++){o[n]=[];const a=e.clone().lerp(i,n/r),s=t.clone().lerp(i,n/r),l=r-n;for(let e=0;l>=e;e++)o[n][e]=0===e&&n===r?a:a.clone().lerp(s,e/l)}for(let e=0;r>e;e++)for(let t=0;2*(r-e)-1>t;t++){const i=Math.floor(t/2);t%2==0?(s(o[e][i+1]),s(o[e+1][i]),s(o[e][i])):(s(o[e][i+1]),s(o[e+1][i+1]),s(o[e+1][i]))}}function s(e){r.push(e.x,e.y,e.z)}function l(t,i){const n=3*t;i.x=e[n+0],i.y=e[n+1],i.z=e[n+2]}function c(e,t,i,n){0>n&&1===e.x&&(o[t]=e.x-1),0===i.x&&0===i.z&&(o[t]=n/2/Math.PI+.5)}function h(e){return Math.atan2(e.z,-e.x)}!function(e){const i=new Ke,n=new Ke,r=new Ke;for(let o=0;t.length>o;o+=3)l(t[o+0],i),l(t[o+1],n),l(t[o+2],r),a(i,n,r,e)}(n),function(e){const t=new Ke;for(let i=0;r.length>i;i+=3)t.x=r[i+0],t.y=r[i+1],t.z=r[i+2],t.normalize().multiplyScalar(e),r[i+0]=t.x,r[i+1]=t.y,r[i+2]=t.z}(i),function(){const e=new Ke;for(let i=0;r.length>i;i+=3){e.x=r[i+0],e.y=r[i+1],e.z=r[i+2];const n=h(e)/2/Math.PI+.5,a=(t=e,Math.atan2(-t.y,Math.sqrt(t.x*t.x+t.z*t.z))/Math.PI+.5);o.push(n,1-a)}var t;(function(){const e=new Ke,t=new Ke,i=new Ke,n=new Ke,a=new ke,s=new ke,l=new ke;for(let d=0,u=0;r.length>d;d+=9,u+=6){e.set(r[d+0],r[d+1],r[d+2]),t.set(r[d+3],r[d+4],r[d+5]),i.set(r[d+6],r[d+7],r[d+8]),a.set(o[u+0],o[u+1]),s.set(o[u+2],o[u+3]),l.set(o[u+4],o[u+5]),n.copy(e).add(t).add(i).divideScalar(3);const p=h(n);c(a,u+0,e,p),c(s,u+2,t,p),c(l,u+4,i,p)}})(),function(){for(let e=0;o.length>e;e+=6){const t=o[e+0],i=o[e+2],n=o[e+4],r=Math.max(t,i,n),a=Math.min(t,i,n);r>.9&&.1>a&&(.2>t&&(o[e+0]+=1),.2>i&&(o[e+2]+=1),.2>n&&(o[e+4]+=1))}}()}(),this.setAttribute("position",new Bi(r,3)),this.setAttribute("normal",new Bi(r.slice(),3)),this.setAttribute("uv",new Bi(o,2)),0===n?this.computeVertexNormals():this.normalizeNormals()}}class $a extends _a{constructor(e=1,t=0){const i=(1+Math.sqrt(5))/2,n=1/i;super([-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,-n,-i,0,-n,i,0,n,-i,0,n,i,-n,-i,0,-n,i,0,n,-i,0,n,i,0,-i,0,-n,i,0,-n,-i,0,n,i,0,n],[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],e,t),this.type="DodecahedronGeometry",this.parameters={radius:e,detail:t}}}const es=new Ke,ts=new Ke,is=new Ke,ns=new ri;class rs extends Ni{constructor(e,t){if(super(),this.type="EdgesGeometry",this.parameters={thresholdAngle:t},t=void 0!==t?t:1,!0===e.isGeometry)return void console.error("THREE.EdgesGeometry no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.");const i=Math.pow(10,4),n=Math.cos(ve*t),r=e.getIndex(),o=e.getAttribute("position"),a=r?r.count:o.count,s=[0,0,0],l=["a","b","c"],c=new Array(3),h={},d=[];for(let e=0;a>e;e+=3){r?(s[0]=r.getX(e),s[1]=r.getX(e+1),s[2]=r.getX(e+2)):(s[0]=e,s[1]=e+1,s[2]=e+2);const{a:t,b:a,c:u}=ns;if(t.fromBufferAttribute(o,s[0]),a.fromBufferAttribute(o,s[1]),u.fromBufferAttribute(o,s[2]),ns.getNormal(is),c[0]=`${Math.round(t.x*i)},${Math.round(t.y*i)},${Math.round(t.z*i)}`,c[1]=`${Math.round(a.x*i)},${Math.round(a.y*i)},${Math.round(a.z*i)}`,c[2]=`${Math.round(u.x*i)},${Math.round(u.y*i)},${Math.round(u.z*i)}`,c[0]!==c[1]&&c[1]!==c[2]&&c[2]!==c[0])for(let e=0;3>e;e++){const t=(e+1)%3,i=c[e],r=c[t],o=ns[l[e]],a=ns[l[t]],u=`${i}_${r}`,p=`${r}_${i}`;p in h&&h[p]?(is.dot(h[p].normal)>n||(d.push(o.x,o.y,o.z),d.push(a.x,a.y,a.z)),h[p]=null):u in h||(h[u]={index0:s[e],index1:s[t],normal:is.clone()})}}for(const e in h)if(h[e]){const{index0:t,index1:i}=h[e];es.fromBufferAttribute(o,t),ts.fromBufferAttribute(o,i),d.push(es.x,es.y,es.z),d.push(ts.x,ts.y,ts.z)}this.setAttribute("position",new Bi(d,3))}}const os=function(e,t,i){i=i||2;const n=t&&t.length,r=n?t[0]*i:e.length;let o=as(e,0,r,i,!0);const a=[];if(!o||o.next===o.prev)return a;let s,l,c,h,d,u,p;if(n&&(o=function(e,t,i,n){const r=[];let o,a,s,l,c;for(o=0,a=t.length;a>o;o++)s=t[o]*n,l=a-1>o?t[o+1]*n:e.length,c=as(e,s,l,n,!1),c===c.next&&(c.steiner=!0),r.push(As(c));for(r.sort(ps),o=0;r.length>o;o++)gs(r[o],i),i=ss(i,i.next);return i}(e,t,o,i)),e.length>80*i){s=c=e[0],l=h=e[1];for(let t=i;r>t;t+=i)d=e[t],u=e[t+1],s>d&&(s=d),l>u&&(l=u),d>c&&(c=d),u>h&&(h=u);p=Math.max(c-s,h-l),p=0!==p?1/p:0}return ls(o,a,i,s,l,p),a};function as(e,t,i,n,r){let o,a;if(r===function(e,t,i,n){let r=0;for(let o=t,a=i-n;i>o;o+=n)r+=(e[a]-e[o])*(e[o+1]+e[a+1]),a=o;return r}(e,t,i,n)>0)for(o=t;i>o;o+=n)a=Ss(o,e[o],e[o+1],a);else for(o=i-n;o>=t;o-=n)a=Ss(o,e[o],e[o+1],a);return a&&Is(a,a.next)&&(bs(a),a=a.next),a}function ss(e,t){if(!e)return e;t||(t=e);let i,n=e;do{if(i=!1,n.steiner||!Is(n,n.next)&&0!==Cs(n.prev,n,n.next))n=n.next;else{if(bs(n),n=t=n.prev,n===n.next)break;i=!0}}while(i||n!==t);return t}function ls(e,t,i,n,r,o,a){if(!e)return;!a&&o&&function(e,t,i,n){let r=e;do{null===r.z&&(r.z=ms(r.x,r.y,t,i,n)),r.prevZ=r.prev,r.nextZ=r.next,r=r.next}while(r!==e);r.prevZ.nextZ=null,r.prevZ=null,function(e){let t,i,n,r,o,a,s,l,c=1;do{for(i=e,e=null,o=null,a=0;i;){for(a++,n=i,s=0,t=0;c>t&&(s++,n=n.nextZ,n);t++);for(l=c;s>0||l>0&&n;)0===s||0!==l&&n&&i.z>n.z?(r=n,n=n.nextZ,l--):(r=i,i=i.nextZ,s--),o?o.nextZ=r:e=r,r.prevZ=o,o=r;i=n}o.nextZ=null,c*=2}while(a>1)}(r)}(e,n,r,o);let s,l,c=e;for(;e.prev!==e.next;)if(s=e.prev,l=e.next,o?hs(e,n,r,o):cs(e))t.push(s.i/i),t.push(e.i/i),t.push(l.i/i),bs(e),e=l.next,c=l.next;else if((e=l)===c){a?1===a?ls(e=ds(ss(e),t,i),t,i,n,r,o,2):2===a&&us(e,t,i,n,r,o):ls(ss(e),t,i,n,r,o,1);break}}function cs(e){const t=e.prev,i=e,n=e.next;if(Cs(t,i,n)>=0)return!1;let r=e.next.next;for(;r!==e.prev;){if(ys(t.x,t.y,i.x,i.y,n.x,n.y,r.x,r.y)&&Cs(r.prev,r,r.next)>=0)return!1;r=r.next}return!0}function hs(e,t,i,n){const r=e.prev,o=e,a=e.next;if(Cs(r,o,a)>=0)return!1;const s=r.x>o.x?r.x>a.x?r.x:a.x:o.x>a.x?o.x:a.x,l=r.y>o.y?r.y>a.y?r.y:a.y:o.y>a.y?o.y:a.y,c=ms(o.x>r.x?a.x>r.x?r.x:a.x:a.x>o.x?o.x:a.x,o.y>r.y?a.y>r.y?r.y:a.y:a.y>o.y?o.y:a.y,t,i,n),h=ms(s,l,t,i,n);let d=e.prevZ,u=e.nextZ;for(;d&&d.z>=c&&u&&h>=u.z;){if(d!==e.prev&&d!==e.next&&ys(r.x,r.y,o.x,o.y,a.x,a.y,d.x,d.y)&&Cs(d.prev,d,d.next)>=0)return!1;if(d=d.prevZ,u!==e.prev&&u!==e.next&&ys(r.x,r.y,o.x,o.y,a.x,a.y,u.x,u.y)&&Cs(u.prev,u,u.next)>=0)return!1;u=u.nextZ}for(;d&&d.z>=c;){if(d!==e.prev&&d!==e.next&&ys(r.x,r.y,o.x,o.y,a.x,a.y,d.x,d.y)&&Cs(d.prev,d,d.next)>=0)return!1;d=d.prevZ}for(;u&&h>=u.z;){if(u!==e.prev&&u!==e.next&&ys(r.x,r.y,o.x,o.y,a.x,a.y,u.x,u.y)&&Cs(u.prev,u,u.next)>=0)return!1;u=u.nextZ}return!0}function ds(e,t,i){let n=e;do{const r=n.prev,o=n.next.next;!Is(r,o)&&xs(r,n,n.next,o)&&Es(r,o)&&Es(o,r)&&(t.push(r.i/i),t.push(n.i/i),t.push(o.i/i),bs(n),bs(n.next),n=e=o),n=n.next}while(n!==e);return ss(n)}function us(e,t,i,n,r,o){let a=e;do{let e=a.next.next;for(;e!==a.prev;){if(a.i!==e.i&&vs(a,e)){let s=Bs(a,e);return a=ss(a,a.next),s=ss(s,s.next),ls(a,t,i,n,r,o),void ls(s,t,i,n,r,o)}e=e.next}a=a.next}while(a!==e)}function ps(e,t){return e.x-t.x}function gs(e,t){if(t=function(e,t){let i=t;const n=e.x,r=e.y;let o,a=-1/0;do{if(i.y>=r&&r>=i.next.y&&i.next.y!==i.y){const e=i.x+(r-i.y)*(i.next.x-i.x)/(i.next.y-i.y);if(n>=e&&e>a){if(a=e,e===n){if(r===i.y)return i;if(r===i.next.y)return i.next}o=i.next.x>i.x?i:i.next}}i=i.next}while(i!==t);if(!o)return null;if(n===a)return o;const s=o,l=o.x,c=o.y;let h,d=1/0;i=o;do{i.x>n||l>i.x||n===i.x||!ys(c>r?n:a,r,l,c,c>r?a:n,r,i.x,i.y)||(h=Math.abs(r-i.y)/(n-i.x),Es(i,e)&&(d>h||h===d&&(i.x>o.x||i.x===o.x&&fs(o,i)))&&(o=i,d=h)),i=i.next}while(i!==s);return o}(e,t)){const i=Bs(t,e);ss(t,t.next),ss(i,i.next)}}function fs(e,t){return 0>Cs(e.prev,e,t.prev)&&0>Cs(t.next,e,e.next)}function ms(e,t,i,n,r){return(e=1431655765&((e=858993459&((e=252645135&((e=16711935&((e=32767*(e-i)*r)|e<<8))|e<<4))|e<<2))|e<<1))|(t=1431655765&((t=858993459&((t=252645135&((t=16711935&((t=32767*(t-n)*r)|t<<8))|t<<4))|t<<2))|t<<1))<<1}function As(e){let t=e,i=e;do{(i.x>t.x||t.x===i.x&&i.y>t.y)&&(i=t),t=t.next}while(t!==e);return i}function ys(e,t,i,n,r,o,a,s){return(r-a)*(t-s)-(e-a)*(o-s)>=0&&(e-a)*(n-s)-(i-a)*(t-s)>=0&&(i-a)*(o-s)-(r-a)*(n-s)>=0}function vs(e,t){return e.next.i!==t.i&&e.prev.i!==t.i&&!function(e,t){let i=e;do{if(i.i!==e.i&&i.next.i!==e.i&&i.i!==t.i&&i.next.i!==t.i&&xs(i,i.next,e,t))return!0;i=i.next}while(i!==e);return!1}(e,t)&&(Es(e,t)&&Es(t,e)&&function(e,t){let i=e,n=!1;const r=(e.x+t.x)/2,o=(e.y+t.y)/2;do{i.y>o!=i.next.y>o&&i.next.y!==i.y&&(i.next.x-i.x)*(o-i.y)/(i.next.y-i.y)+i.x>r&&(n=!n),i=i.next}while(i!==e);return n}(e,t)&&(Cs(e.prev,e,t.prev)||Cs(e,t.prev,t))||Is(e,t)&&Cs(e.prev,e,e.next)>0&&Cs(t.prev,t,t.next)>0)}function Cs(e,t,i){return(t.y-e.y)*(i.x-t.x)-(t.x-e.x)*(i.y-t.y)}function Is(e,t){return e.x===t.x&&e.y===t.y}function xs(e,t,i,n){const r=Ms(Cs(e,t,i)),o=Ms(Cs(e,t,n)),a=Ms(Cs(i,n,e)),s=Ms(Cs(i,n,t));return r!==o&&a!==s||(!(0!==r||!ws(e,i,t))||(!(0!==o||!ws(e,n,t))||(!(0!==a||!ws(i,e,n))||!(0!==s||!ws(i,t,n)))))}function ws(e,t,i){return!(t.x>Math.max(e.x,i.x)||t.x<Math.min(e.x,i.x)||t.y>Math.max(e.y,i.y)||t.y<Math.min(e.y,i.y))}function Ms(e){return e>0?1:0>e?-1:0}function Es(e,t){return 0>Cs(e.prev,e,e.next)?Cs(e,t,e.next)>=0&&Cs(e,e.prev,t)>=0:0>Cs(e,t,e.prev)||0>Cs(e,e.next,t)}function Bs(e,t){const i=new ks(e.i,e.x,e.y),n=new ks(t.i,t.x,t.y),r=e.next,o=t.prev;return e.next=t,t.prev=e,i.next=r,r.prev=i,n.next=i,i.prev=n,o.next=n,n.prev=o,n}function Ss(e,t,i,n){const r=new ks(e,t,i);return n?(r.next=n.next,r.prev=n,n.next.prev=r,n.next=r):(r.prev=r,r.next=r),r}function bs(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 ks(e,t,i){this.i=e,this.x=t,this.y=i,this.prev=null,this.next=null,this.z=null,this.prevZ=null,this.nextZ=null,this.steiner=!1}class Ds{static area(e){const t=e.length;let i=0;for(let n=t-1,r=0;t>r;n=r++)i+=e[n].x*e[r].y-e[r].x*e[n].y;return.5*i}static isClockWise(e){return 0>Ds.area(e)}static triangulateShape(e,t){const i=[],n=[],r=[];Ts(e),Rs(i,e);let o=e.length;t.forEach(Ts);for(let e=0;t.length>e;e++)n.push(o),o+=t[e].length,Rs(i,t[e]);const a=os(i,n);for(let e=0;a.length>e;e+=3)r.push(a.slice(e,e+3));return r}}function Ts(e){const t=e.length;t>2&&e[t-1].equals(e[0])&&e.pop()}function Rs(e,t){for(let i=0;t.length>i;i++)e.push(t[i].x),e.push(t[i].y)}class Us extends Ni{constructor(e,t){super(),this.type="ExtrudeGeometry",this.parameters={shapes:e,options:t},e=Array.isArray(e)?e:[e];const i=this,n=[],r=[];for(let t=0,i=e.length;i>t;t++){o(e[t])}function o(e){const o=[],a=void 0!==t.curveSegments?t.curveSegments:12,s=void 0!==t.steps?t.steps:1;let l=void 0!==t.depth?t.depth:100,c=void 0===t.bevelEnabled||t.bevelEnabled,h=void 0!==t.bevelThickness?t.bevelThickness:6,d=void 0!==t.bevelSize?t.bevelSize:h-2,u=void 0!==t.bevelOffset?t.bevelOffset:0,p=void 0!==t.bevelSegments?t.bevelSegments:3;const g=t.extrudePath,f=void 0!==t.UVGenerator?t.UVGenerator:Fs;void 0!==t.amount&&(console.warn("THREE.ExtrudeBufferGeometry: amount has been renamed to depth."),l=t.amount);let m,A,y,v,C,I=!1;g&&(m=g.getSpacedPoints(s),I=!0,c=!1,A=g.computeFrenetFrames(s,!1),y=new Ke,v=new Ke,C=new Ke),c||(p=0,h=0,d=0,u=0);const x=e.extractPoints(a);let w=x.shape;const M=x.holes;if(!Ds.isClockWise(w)){w=w.reverse();for(let e=0,t=M.length;t>e;e++){const t=M[e];Ds.isClockWise(t)&&(M[e]=t.reverse())}}const E=Ds.triangulateShape(w,M),B=w;for(let e=0,t=M.length;t>e;e++){w=w.concat(M[e])}function S(e,t,i){return t||console.error("THREE.ExtrudeGeometry: vec does not exist"),t.clone().multiplyScalar(i).add(e)}const b=w.length,k=E.length;function D(e,t,i){let n,r,o;const a=e.x-t.x,s=e.y-t.y,l=i.x-e.x,c=i.y-e.y,h=a*a+s*s;if(Math.abs(a*c-s*l)>Number.EPSILON){const d=Math.sqrt(h),u=Math.sqrt(l*l+c*c),p=t.x-s/d,g=t.y+a/d,f=((i.x-c/u-p)*c-(i.y+l/u-g)*l)/(a*c-s*l);n=p+a*f-e.x,r=g+s*f-e.y;const m=n*n+r*r;if(2>=m)return new ke(n,r);o=Math.sqrt(m/2)}else{let e=!1;a>Number.EPSILON?l>Number.EPSILON&&(e=!0):-Number.EPSILON>a?-Number.EPSILON>l&&(e=!0):Math.sign(s)===Math.sign(c)&&(e=!0),e?(n=-s,r=a,o=Math.sqrt(h)):(n=a,r=s,o=Math.sqrt(h/2))}return new ke(n/o,r/o)}const T=[];for(let e=0,t=B.length,i=t-1,n=e+1;t>e;e++,i++,n++)i===t&&(i=0),n===t&&(n=0),T[e]=D(B[e],B[i],B[n]);const R=[];let U,F=T.concat();for(let e=0,t=M.length;t>e;e++){const t=M[e];U=[];for(let e=0,i=t.length,n=i-1,r=e+1;i>e;e++,n++,r++)n===i&&(n=0),r===i&&(r=0),U[e]=D(t[e],t[n],t[r]);R.push(U),F=F.concat(U)}for(let e=0;p>e;e++){const t=e/p,i=h*Math.cos(t*Math.PI/2),n=d*Math.sin(t*Math.PI/2)+u;for(let e=0,t=B.length;t>e;e++){const t=S(B[e],T[e],n);O(t.x,t.y,-i)}for(let e=0,t=M.length;t>e;e++){const t=M[e];U=R[e];for(let e=0,r=t.length;r>e;e++){const r=S(t[e],U[e],n);O(r.x,r.y,-i)}}}const Q=d+u;for(let e=0;b>e;e++){const t=c?S(w[e],F[e],Q):w[e];I?(v.copy(A.normals[0]).multiplyScalar(t.x),y.copy(A.binormals[0]).multiplyScalar(t.y),C.copy(m[0]).add(v).add(y),O(C.x,C.y,C.z)):O(t.x,t.y,0)}for(let e=1;s>=e;e++)for(let t=0;b>t;t++){const i=c?S(w[t],F[t],Q):w[t];I?(v.copy(A.normals[e]).multiplyScalar(i.x),y.copy(A.binormals[e]).multiplyScalar(i.y),C.copy(m[e]).add(v).add(y),O(C.x,C.y,C.z)):O(i.x,i.y,l/s*e)}for(let e=p-1;e>=0;e--){const t=e/p,i=h*Math.cos(t*Math.PI/2),n=d*Math.sin(t*Math.PI/2)+u;for(let e=0,t=B.length;t>e;e++){const t=S(B[e],T[e],n);O(t.x,t.y,l+i)}for(let e=0,t=M.length;t>e;e++){const t=M[e];U=R[e];for(let e=0,r=t.length;r>e;e++){const r=S(t[e],U[e],n);I?O(r.x,r.y+m[s-1].y,m[s-1].x+i):O(r.x,r.y,l+i)}}}function L(e,t){let i=e.length;for(;--i>=0;){const n=i;let r=i-1;0>r&&(r=e.length-1);for(let e=0,i=s+2*p;i>e;e++){const i=b*e,o=b*(e+1);P(t+n+i,t+r+i,t+r+o,t+n+o)}}}function O(e,t,i){o.push(e),o.push(t),o.push(i)}function N(e,t,r){G(e),G(t),G(r);const o=n.length/3,a=f.generateTopUV(i,n,o-3,o-2,o-1);K(a[0]),K(a[1]),K(a[2])}function P(e,t,r,o){G(e),G(t),G(o),G(t),G(r),G(o);const a=n.length/3,s=f.generateSideWallUV(i,n,a-6,a-3,a-2,a-1);K(s[0]),K(s[1]),K(s[3]),K(s[1]),K(s[2]),K(s[3])}function G(e){n.push(o[3*e+0]),n.push(o[3*e+1]),n.push(o[3*e+2])}function K(e){r.push(e.x),r.push(e.y)}!function(){const e=n.length/3;if(c){let e=0,t=b*e;for(let e=0;k>e;e++){const i=E[e];N(i[2]+t,i[1]+t,i[0]+t)}e=s+2*p,t=b*e;for(let e=0;k>e;e++){const i=E[e];N(i[0]+t,i[1]+t,i[2]+t)}}else{for(let e=0;k>e;e++){const t=E[e];N(t[2],t[1],t[0])}for(let e=0;k>e;e++){const t=E[e];N(t[0]+b*s,t[1]+b*s,t[2]+b*s)}}i.addGroup(e,n.length/3-e,0)}(),function(){const e=n.length/3;let t=0;L(B,t),t+=B.length;for(let e=0,i=M.length;i>e;e++){const i=M[e];L(i,t),t+=i.length}i.addGroup(e,n.length/3-e,1)}()}this.setAttribute("position",new Bi(n,3)),this.setAttribute("uv",new Bi(r,2)),this.computeVertexNormals()}toJSON(){const e=super.toJSON();return function(e,t,i){if(i.shapes=[],Array.isArray(e))for(let t=0,n=e.length;n>t;t++){i.shapes.push(e[t].uuid)}else i.shapes.push(e.uuid);void 0!==t.extrudePath&&(i.options.extrudePath=t.extrudePath.toJSON());return i}(this.parameters.shapes,this.parameters.options,e)}}const Fs={generateTopUV:function(e,t,i,n,r){const o=t[3*n],a=t[3*n+1],s=t[3*r],l=t[3*r+1];return[new ke(t[3*i],t[3*i+1]),new ke(o,a),new ke(s,l)]},generateSideWallUV:function(e,t,i,n,r,o){const a=t[3*i],s=t[3*i+1],l=t[3*i+2],c=t[3*n],h=t[3*n+1],d=t[3*n+2],u=t[3*r],p=t[3*r+1],g=t[3*r+2],f=t[3*o],m=t[3*o+1],A=t[3*o+2];return Math.abs(s-h)<Math.abs(a-c)?[new ke(a,1-l),new ke(c,1-d),new ke(u,1-g),new ke(f,1-A)]:[new ke(s,1-l),new ke(h,1-d),new ke(p,1-g),new ke(m,1-A)]}};class Qs extends _a{constructor(e=1,t=0){const i=(1+Math.sqrt(5))/2;super([-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],[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],e,t),this.type="IcosahedronGeometry",this.parameters={radius:e,detail:t}}}class Ls extends Ni{constructor(e,t=12,i=0,n=2*Math.PI){super(),this.type="LatheGeometry",this.parameters={points:e,segments:t,phiStart:i,phiLength:n},t=Math.floor(t),n=xe(n,0,2*Math.PI);const r=[],o=[],a=[],s=1/t,l=new Ke,c=new ke;for(let r=0;t>=r;r++){const h=i+r*s*n,d=Math.sin(h),u=Math.cos(h);for(let i=0;e.length-1>=i;i++)l.x=e[i].x*d,l.y=e[i].y,l.z=e[i].x*u,o.push(l.x,l.y,l.z),c.x=r/t,c.y=i/(e.length-1),a.push(c.x,c.y)}for(let i=0;t>i;i++)for(let t=0;e.length-1>t;t++){const n=t+i*e.length,o=n+e.length,a=n+e.length+1,s=n+1;r.push(n,o,s),r.push(o,a,s)}if(this.setIndex(r),this.setAttribute("position",new Bi(o,3)),this.setAttribute("uv",new Bi(a,2)),this.computeVertexNormals(),n===2*Math.PI){const i=this.attributes.normal.array,n=new Ke,r=new Ke,o=new Ke,a=t*e.length*3;for(let t=0,s=0;e.length>t;t++,s+=3)n.x=i[s+0],n.y=i[s+1],n.z=i[s+2],r.x=i[a+s+0],r.y=i[a+s+1],r.z=i[a+s+2],o.addVectors(n,r).normalize(),i[s+0]=i[a+s+0]=o.x,i[s+1]=i[a+s+1]=o.y,i[s+2]=i[a+s+2]=o.z}}}class Os extends _a{constructor(e=1,t=0){super([1,0,0,-1,0,0,0,1,0,0,-1,0,0,0,1,0,0,-1],[0,2,4,0,4,3,0,3,5,0,5,2,1,2,5,1,5,3,1,3,4,1,4,2],e,t),this.type="OctahedronGeometry",this.parameters={radius:e,detail:t}}}class Ns extends Ni{constructor(e,t,i){super(),this.type="ParametricGeometry",this.parameters={func:e,slices:t,stacks:i};const n=[],r=[],o=[],a=[],s=1e-5,l=new Ke,c=new Ke,h=new Ke,d=new Ke,u=new Ke;3>e.length&&console.error("THREE.ParametricGeometry: Function must now modify a Vector3 as third parameter.");const p=t+1;for(let n=0;i>=n;n++){const p=n/i;for(let i=0;t>=i;i++){const n=i/t;e(n,p,c),r.push(c.x,c.y,c.z),0>n-s?(e(n+s,p,h),d.subVectors(h,c)):(e(n-s,p,h),d.subVectors(c,h)),0>p-s?(e(n,p+s,h),u.subVectors(h,c)):(e(n,p-s,h),u.subVectors(c,h)),l.crossVectors(d,u).normalize(),o.push(l.x,l.y,l.z),a.push(n,p)}}for(let e=0;i>e;e++)for(let i=0;t>i;i++){const t=e*p+i+1,r=(e+1)*p+i+1,o=(e+1)*p+i;n.push(e*p+i,t,o),n.push(t,r,o)}this.setIndex(n),this.setAttribute("position",new Bi(r,3)),this.setAttribute("normal",new Bi(o,3)),this.setAttribute("uv",new Bi(a,2))}}class Ps extends Ni{constructor(e=.5,t=1,i=8,n=1,r=0,o=2*Math.PI){super(),this.type="RingGeometry",this.parameters={innerRadius:e,outerRadius:t,thetaSegments:i,phiSegments:n,thetaStart:r,thetaLength:o},i=Math.max(3,i);const a=[],s=[],l=[],c=[];let h=e;const d=(t-e)/(n=Math.max(1,n)),u=new Ke,p=new ke;for(let e=0;n>=e;e++){for(let e=0;i>=e;e++){const n=r+e/i*o;u.x=h*Math.cos(n),u.y=h*Math.sin(n),s.push(u.x,u.y,u.z),l.push(0,0,1),p.x=(u.x/t+1)/2,p.y=(u.y/t+1)/2,c.push(p.x,p.y)}h+=d}for(let e=0;n>e;e++){const t=e*(i+1);for(let e=0;i>e;e++){const n=e+t,r=n+i+1,o=n+i+2,s=n+1;a.push(n,r,s),a.push(r,o,s)}}this.setIndex(a),this.setAttribute("position",new Bi(s,3)),this.setAttribute("normal",new Bi(l,3)),this.setAttribute("uv",new Bi(c,2))}}class Gs extends Ni{constructor(e,t=12){super(),this.type="ShapeGeometry",this.parameters={shapes:e,curveSegments:t};const i=[],n=[],r=[],o=[];let a=0,s=0;if(!1===Array.isArray(e))l(e);else for(let t=0;e.length>t;t++)l(e[t]),this.addGroup(a,s,t),a+=s,s=0;function l(e){const a=n.length/3,l=e.extractPoints(t);let c=l.shape;const h=l.holes;!1===Ds.isClockWise(c)&&(c=c.reverse());for(let e=0,t=h.length;t>e;e++){const t=h[e];!0===Ds.isClockWise(t)&&(h[e]=t.reverse())}const d=Ds.triangulateShape(c,h);for(let e=0,t=h.length;t>e;e++){c=c.concat(h[e])}for(let e=0,t=c.length;t>e;e++){const t=c[e];n.push(t.x,t.y,0),r.push(0,0,1),o.push(t.x,t.y)}for(let e=0,t=d.length;t>e;e++){const t=d[e];i.push(t[0]+a,t[1]+a,t[2]+a),s+=3}}this.setIndex(i),this.setAttribute("position",new Bi(n,3)),this.setAttribute("normal",new Bi(r,3)),this.setAttribute("uv",new Bi(o,2))}toJSON(){const e=super.toJSON();return function(e,t){if(t.shapes=[],Array.isArray(e))for(let i=0,n=e.length;n>i;i++){t.shapes.push(e[i].uuid)}else t.shapes.push(e.uuid);return t}(this.parameters.shapes,e)}}class Ks extends Ni{constructor(e=1,t=8,i=6,n=0,r=2*Math.PI,o=0,a=Math.PI){super(),this.type="SphereGeometry",this.parameters={radius:e,widthSegments:t,heightSegments:i,phiStart:n,phiLength:r,thetaStart:o,thetaLength:a},t=Math.max(3,Math.floor(t)),i=Math.max(2,Math.floor(i));const s=Math.min(o+a,Math.PI);let l=0;const c=[],h=new Ke,d=new Ke,u=[],p=[],g=[],f=[];for(let u=0;i>=u;u++){const m=[],A=u/i;let y=0;0==u&&0==o?y=.5/t:u==i&&s==Math.PI&&(y=-.5/t);for(let i=0;t>=i;i++){const s=i/t;h.x=-e*Math.cos(n+s*r)*Math.sin(o+A*a),h.y=e*Math.cos(o+A*a),h.z=e*Math.sin(n+s*r)*Math.sin(o+A*a),p.push(h.x,h.y,h.z),d.copy(h).normalize(),g.push(d.x,d.y,d.z),f.push(s+y,1-A),m.push(l++)}c.push(m)}for(let e=0;i>e;e++)for(let n=0;t>n;n++){const t=c[e][n+1],r=c[e][n],a=c[e+1][n],l=c[e+1][n+1];(0!==e||o>0)&&u.push(t,r,l),(e!==i-1||s<Math.PI)&&u.push(r,a,l)}this.setIndex(u),this.setAttribute("position",new Bi(p,3)),this.setAttribute("normal",new Bi(g,3)),this.setAttribute("uv",new Bi(f,2))}}class Vs extends _a{constructor(e=1,t=0){super([1,1,1,-1,-1,1,-1,1,-1,1,-1,-1],[2,1,0,0,3,2,1,3,0,2,3,1],e,t),this.type="TetrahedronGeometry",this.parameters={radius:e,detail:t}}}class Ys extends Us{constructor(e,t={}){const i=t.font;if(!i||!i.isFont)return console.error("THREE.TextGeometry: font parameter is not an instance of THREE.Font."),new Ni;const n=i.generateShapes(e,t.size);t.depth=void 0!==t.height?t.height:50,void 0===t.bevelThickness&&(t.bevelThickness=10),void 0===t.bevelSize&&(t.bevelSize=8),void 0===t.bevelEnabled&&(t.bevelEnabled=!1),super(n,t),this.type="TextGeometry"}}class Hs extends Ni{constructor(e=1,t=.4,i=8,n=6,r=2*Math.PI){super(),this.type="TorusGeometry",this.parameters={radius:e,tube:t,radialSegments:i,tubularSegments:n,arc:r},i=Math.floor(i),n=Math.floor(n);const o=[],a=[],s=[],l=[],c=new Ke,h=new Ke,d=new Ke;for(let o=0;i>=o;o++)for(let u=0;n>=u;u++){const p=u/n*r,g=o/i*Math.PI*2;h.x=(e+t*Math.cos(g))*Math.cos(p),h.y=(e+t*Math.cos(g))*Math.sin(p),h.z=t*Math.sin(g),a.push(h.x,h.y,h.z),c.x=e*Math.cos(p),c.y=e*Math.sin(p),d.subVectors(h,c).normalize(),s.push(d.x,d.y,d.z),l.push(u/n),l.push(o/i)}for(let e=1;i>=e;e++)for(let t=1;n>=t;t++){const i=(n+1)*(e-1)+t-1,r=(n+1)*(e-1)+t,a=(n+1)*e+t;o.push((n+1)*e+t-1,i,a),o.push(i,r,a)}this.setIndex(o),this.setAttribute("position",new Bi(a,3)),this.setAttribute("normal",new Bi(s,3)),this.setAttribute("uv",new Bi(l,2))}}class js extends Ni{constructor(e=1,t=.4,i=64,n=8,r=2,o=3){super(),this.type="TorusKnotGeometry",this.parameters={radius:e,tube:t,tubularSegments:i,radialSegments:n,p:r,q:o},i=Math.floor(i),n=Math.floor(n);const a=[],s=[],l=[],c=[],h=new Ke,d=new Ke,u=new Ke,p=new Ke,g=new Ke,f=new Ke,m=new Ke;for(let a=0;i>=a;++a){const y=a/i*r*Math.PI*2;A(y,r,o,e,u),A(y+.01,r,o,e,p),f.subVectors(p,u),m.addVectors(p,u),g.crossVectors(f,m),m.crossVectors(g,f),g.normalize(),m.normalize();for(let e=0;n>=e;++e){const r=e/n*Math.PI*2,o=-t*Math.cos(r),p=t*Math.sin(r);h.x=u.x+(o*m.x+p*g.x),h.y=u.y+(o*m.y+p*g.y),h.z=u.z+(o*m.z+p*g.z),s.push(h.x,h.y,h.z),d.subVectors(h,u).normalize(),l.push(d.x,d.y,d.z),c.push(a/i),c.push(e/n)}}for(let e=1;i>=e;e++)for(let t=1;n>=t;t++){const i=(n+1)*e+(t-1),r=(n+1)*e+t,o=(n+1)*(e-1)+t;a.push((n+1)*(e-1)+(t-1),i,o),a.push(i,r,o)}function A(e,t,i,n,r){const o=Math.cos(e),a=Math.sin(e),s=i/t*e,l=Math.cos(s);r.x=n*(2+l)*.5*o,r.y=n*(2+l)*a*.5,r.z=n*Math.sin(s)*.5}this.setIndex(a),this.setAttribute("position",new Bi(s,3)),this.setAttribute("normal",new Bi(l,3)),this.setAttribute("uv",new Bi(c,2))}}class Ws extends Ni{constructor(e,t=64,i=1,n=8,r=!1){super(),this.type="TubeGeometry",this.parameters={path:e,tubularSegments:t,radius:i,radialSegments:n,closed:r};const o=e.computeFrenetFrames(t,r);this.tangents=o.tangents,this.normals=o.normals,this.binormals=o.binormals;const a=new Ke,s=new Ke,l=new ke;let c=new Ke;const h=[],d=[],u=[],p=[];function g(r){c=e.getPointAt(r/t,c);const l=o.normals[r],u=o.binormals[r];for(let e=0;n>=e;e++){const t=e/n*Math.PI*2,r=Math.sin(t),o=-Math.cos(t);s.x=o*l.x+r*u.x,s.y=o*l.y+r*u.y,s.z=o*l.z+r*u.z,s.normalize(),d.push(s.x,s.y,s.z),a.x=c.x+i*s.x,a.y=c.y+i*s.y,a.z=c.z+i*s.z,h.push(a.x,a.y,a.z)}}!function(){for(let e=0;t>e;e++)g(e);g(!1===r?t:0),function(){for(let e=0;t>=e;e++)for(let i=0;n>=i;i++)l.x=e/t,l.y=i/n,u.push(l.x,l.y)}(),function(){for(let e=1;t>=e;e++)for(let t=1;n>=t;t++){const i=(n+1)*e+(t-1),r=(n+1)*e+t,o=(n+1)*(e-1)+t;p.push((n+1)*(e-1)+(t-1),i,o),p.push(i,r,o)}}()}(),this.setIndex(p),this.setAttribute("position",new Bi(h,3)),this.setAttribute("normal",new Bi(d,3)),this.setAttribute("uv",new Bi(u,2))}toJSON(){const e=super.toJSON();return e.path=this.parameters.path.toJSON(),e}}class Js extends Ni{constructor(e){if(super(),this.type="WireframeGeometry",!0===e.isGeometry)return void console.error("THREE.WireframeGeometry no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.");const t=[],i=[0,0],n={},r=new Ke;if(null!==e.index){const o=e.attributes.position,a=e.index;let s=e.groups;0===s.length&&(s=[{start:0,count:a.count,materialIndex:0}]);for(let e=0,t=s.length;t>e;++e){const t=s[e],r=t.start;for(let e=r,o=r+t.count;o>e;e+=3)for(let t=0;3>t;t++){const r=a.getX(e+t),o=a.getX(e+(t+1)%3);i[0]=Math.min(r,o),i[1]=Math.max(r,o);const s=i[0]+","+i[1];void 0===n[s]&&(n[s]={index1:i[0],index2:i[1]})}}for(const e in n){const i=n[e];r.fromBufferAttribute(o,i.index1),t.push(r.x,r.y,r.z),r.fromBufferAttribute(o,i.index2),t.push(r.x,r.y,r.z)}}else{const i=e.attributes.position;for(let e=0,n=i.count/3;n>e;e++)for(let n=0;3>n;n++){r.fromBufferAttribute(i,3*e+n),t.push(r.x,r.y,r.z);r.fromBufferAttribute(i,3*e+(n+1)%3),t.push(r.x,r.y,r.z)}}this.setAttribute("position",new Bi(t,3))}}var zs=Object.freeze({__proto__:null,BoxGeometry:on,BoxBufferGeometry:on,CircleGeometry:qa,CircleBufferGeometry:qa,ConeGeometry:Xa,ConeBufferGeometry:Xa,CylinderGeometry:Za,CylinderBufferGeometry:Za,DodecahedronGeometry:$a,DodecahedronBufferGeometry:$a,EdgesGeometry:rs,ExtrudeGeometry:Us,ExtrudeBufferGeometry:Us,IcosahedronGeometry:Qs,IcosahedronBufferGeometry:Qs,LatheGeometry:Ls,LatheBufferGeometry:Ls,OctahedronGeometry:Os,OctahedronBufferGeometry:Os,ParametricGeometry:Ns,ParametricBufferGeometry:Ns,PlaneGeometry:In,PlaneBufferGeometry:In,PolyhedronGeometry:_a,PolyhedronBufferGeometry:_a,RingGeometry:Ps,RingBufferGeometry:Ps,ShapeGeometry:Gs,ShapeBufferGeometry:Gs,SphereGeometry:Ks,SphereBufferGeometry:Ks,TetrahedronGeometry:Vs,TetrahedronBufferGeometry:Vs,TextGeometry:Ys,TextBufferGeometry:Ys,TorusGeometry:Hs,TorusBufferGeometry:Hs,TorusKnotGeometry:js,TorusKnotBufferGeometry:js,TubeGeometry:Ws,TubeBufferGeometry:Ws,WireframeGeometry:Js});class qs extends ai{constructor(e){super(),this.type="ShadowMaterial",this.color=new pi(0),this.transparent=!0,this.setValues(e)}copy(e){return super.copy(e),this.color.copy(e.color),this}}qs.prototype.isShadowMaterial=!0;class Zs extends cn{constructor(e){super(e),this.type="RawShaderMaterial"}}Zs.prototype.isRawShaderMaterial=!0;class Xs extends ai{constructor(e){super(),this.defines={STANDARD:""},this.type="MeshStandardMaterial",this.color=new pi(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 pi(0),this.emissiveIntensity=1,this.emissiveMap=null,this.bumpMap=null,this.bumpScale=1,this.normalMap=null,this.normalMapType=0,this.normalScale=new ke(1,1),this.displacementMap=null,this.displacementScale=1,this.displacementBias=0,this.roughnessMap=null,this.metalnessMap=null,this.alphaMap=null,this.envMap=null,this.envMapIntensity=1,this.refractionRatio=.98,this.wireframe=!1,this.wireframeLinewidth=1,this.wireframeLinecap="round",this.wireframeLinejoin="round",this.morphTargets=!1,this.morphNormals=!1,this.flatShading=!1,this.vertexTangents=!1,this.setValues(e)}copy(e){return super.copy(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.morphTargets=e.morphTargets,this.morphNormals=e.morphNormals,this.flatShading=e.flatShading,this.vertexTangents=e.vertexTangents,this}}Xs.prototype.isMeshStandardMaterial=!0;class _s extends Xs{constructor(e){super(),this.defines={STANDARD:"",PHYSICAL:""},this.type="MeshPhysicalMaterial",this.clearcoat=0,this.clearcoatMap=null,this.clearcoatRoughness=0,this.clearcoatRoughnessMap=null,this.clearcoatNormalScale=new ke(1,1),this.clearcoatNormalMap=null,this.reflectivity=.5,Object.defineProperty(this,"ior",{get:function(){return(1+.4*this.reflectivity)/(1-.4*this.reflectivity)},set:function(e){this.reflectivity=xe(2.5*(e-1)/(e+1),0,1)}}),this.sheen=null,this.transmission=0,this.transmissionMap=null,this.thickness=.01,this.thicknessMap=null,this.attenuationDistance=0,this.attenuationColor=new pi(1,1,1),this.setValues(e)}copy(e){return super.copy(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,this.sheen=e.sheen?(this.sheen||new pi).copy(e.sheen):null,this.transmission=e.transmission,this.transmissionMap=e.transmissionMap,this.thickness=e.thickness,this.thicknessMap=e.thicknessMap,this.attenuationDistance=e.attenuationDistance,this.attenuationColor.copy(e.attenuationColor),this}}_s.prototype.isMeshPhysicalMaterial=!0;class $s extends ai{constructor(e){super(),this.type="MeshPhongMaterial",this.color=new pi(16777215),this.specular=new pi(1118481),this.shininess=30,this.map=null,this.lightMap=null,this.lightMapIntensity=1,this.aoMap=null,this.aoMapIntensity=1,this.emissive=new pi(0),this.emissiveIntensity=1,this.emissiveMap=null,this.bumpMap=null,this.bumpScale=1,this.normalMap=null,this.normalMapType=0,this.normalScale=new ke(1,1),this.displacementMap=null,this.displacementScale=1,this.displacementBias=0,this.specularMap=null,this.alphaMap=null,this.envMap=null,this.combine=0,this.reflectivity=1,this.refractionRatio=.98,this.wireframe=!1,this.wireframeLinewidth=1,this.wireframeLinecap="round",this.wireframeLinejoin="round",this.morphTargets=!1,this.morphNormals=!1,this.flatShading=!1,this.setValues(e)}copy(e){return super.copy(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.morphTargets=e.morphTargets,this.morphNormals=e.morphNormals,this.flatShading=e.flatShading,this}}$s.prototype.isMeshPhongMaterial=!0;class el extends ai{constructor(e){super(),this.defines={TOON:""},this.type="MeshToonMaterial",this.color=new pi(16777215),this.map=null,this.gradientMap=null,this.lightMap=null,this.lightMapIntensity=1,this.aoMap=null,this.aoMapIntensity=1,this.emissive=new pi(0),this.emissiveIntensity=1,this.emissiveMap=null,this.bumpMap=null,this.bumpScale=1,this.normalMap=null,this.normalMapType=0,this.normalScale=new ke(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.morphTargets=!1,this.morphNormals=!1,this.setValues(e)}copy(e){return super.copy(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.morphTargets=e.morphTargets,this.morphNormals=e.morphNormals,this}}el.prototype.isMeshToonMaterial=!0;class tl extends ai{constructor(e){super(),this.type="MeshNormalMaterial",this.bumpMap=null,this.bumpScale=1,this.normalMap=null,this.normalMapType=0,this.normalScale=new ke(1,1),this.displacementMap=null,this.displacementScale=1,this.displacementBias=0,this.wireframe=!1,this.wireframeLinewidth=1,this.fog=!1,this.morphTargets=!1,this.morphNormals=!1,this.flatShading=!1,this.setValues(e)}copy(e){return super.copy(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.morphTargets=e.morphTargets,this.morphNormals=e.morphNormals,this.flatShading=e.flatShading,this}}tl.prototype.isMeshNormalMaterial=!0;class il extends ai{constructor(e){super(),this.type="MeshLambertMaterial",this.color=new pi(16777215),this.map=null,this.lightMap=null,this.lightMapIntensity=1,this.aoMap=null,this.aoMapIntensity=1,this.emissive=new pi(0),this.emissiveIntensity=1,this.emissiveMap=null,this.specularMap=null,this.alphaMap=null,this.envMap=null,this.combine=0,this.reflectivity=1,this.refractionRatio=.98,this.wireframe=!1,this.wireframeLinewidth=1,this.wireframeLinecap="round",this.wireframeLinejoin="round",this.morphTargets=!1,this.morphNormals=!1,this.setValues(e)}copy(e){return super.copy(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.morphTargets=e.morphTargets,this.morphNormals=e.morphNormals,this}}il.prototype.isMeshLambertMaterial=!0;class nl extends ai{constructor(e){super(),this.defines={MATCAP:""},this.type="MeshMatcapMaterial",this.color=new pi(16777215),this.matcap=null,this.map=null,this.bumpMap=null,this.bumpScale=1,this.normalMap=null,this.normalMapType=0,this.normalScale=new ke(1,1),this.displacementMap=null,this.displacementScale=1,this.displacementBias=0,this.alphaMap=null,this.morphTargets=!1,this.morphNormals=!1,this.flatShading=!1,this.setValues(e)}copy(e){return super.copy(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.morphTargets=e.morphTargets,this.morphNormals=e.morphNormals,this.flatShading=e.flatShading,this}}nl.prototype.isMeshMatcapMaterial=!0;class rl extends Sa{constructor(e){super(),this.type="LineDashedMaterial",this.scale=1,this.dashSize=3,this.gapSize=1,this.setValues(e)}copy(e){return super.copy(e),this.scale=e.scale,this.dashSize=e.dashSize,this.gapSize=e.gapSize,this}}rl.prototype.isLineDashedMaterial=!0;var ol=Object.freeze({__proto__:null,ShadowMaterial:qs,SpriteMaterial:Wo,RawShaderMaterial:Zs,ShaderMaterial:cn,PointsMaterial:Na,MeshPhysicalMaterial:_s,MeshStandardMaterial:Xs,MeshPhongMaterial:$s,MeshToonMaterial:el,MeshNormalMaterial:tl,MeshLambertMaterial:il,MeshDepthMaterial:Mo,MeshDistanceMaterial:Eo,MeshBasicMaterial:gi,MeshMatcapMaterial:nl,LineDashedMaterial:rl,LineBasicMaterial:Sa,Material:ai});const al={arraySlice:function(e,t,i){return al.isTypedArray(e)?new e.constructor(e.subarray(t,void 0!==i?i:e.length)):e.slice(t,i)},convertArray:function(e,t,i){return!e||!i&&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){const t=e.length,i=new Array(t);for(let e=0;e!==t;++e)i[e]=e;return i.sort((function(t,i){return e[t]-e[i]})),i},sortedArray:function(e,t,i){const n=e.length,r=new e.constructor(n);for(let o=0,a=0;a!==n;++o){const n=i[o]*t;for(let i=0;i!==t;++i)r[a++]=e[n+i]}return r},flattenJSON:function(e,t,i,n){let r=1,o=e[0];for(;void 0!==o&&void 0===o[n];)o=e[r++];if(void 0===o)return;let a=o[n];if(void 0!==a)if(Array.isArray(a))do{a=o[n],void 0!==a&&(t.push(o.time),i.push.apply(i,a)),o=e[r++]}while(void 0!==o);else if(void 0!==a.toArray)do{a=o[n],void 0!==a&&(t.push(o.time),a.toArray(i,i.length)),o=e[r++]}while(void 0!==o);else do{a=o[n],void 0!==a&&(t.push(o.time),i.push(a)),o=e[r++]}while(void 0!==o)},subclip:function(e,t,i,n,r=30){const o=e.clone();o.name=t;const a=[];for(let e=0;o.tracks.length>e;++e){const t=o.tracks[e],s=t.getValueSize(),l=[],c=[];for(let e=0;t.times.length>e;++e){const o=t.times[e]*r;if(o>=i&&n>o){l.push(t.times[e]);for(let i=0;s>i;++i)c.push(t.values[e*s+i])}}0!==l.length&&(t.times=al.convertArray(l,t.times.constructor),t.values=al.convertArray(c,t.values.constructor),a.push(t))}o.tracks=a;let s=1/0;for(let e=0;o.tracks.length>e;++e)s>o.tracks[e].times[0]&&(s=o.tracks[e].times[0]);for(let e=0;o.tracks.length>e;++e)o.tracks[e].shift(-1*s);return o.resetDuration(),o},makeClipAdditive:function(e,t=0,i=e,n=30){n>0||(n=30);const r=i.tracks.length,o=t/n;for(let t=0;r>t;++t){const n=i.tracks[t],r=n.ValueTypeName;if("bool"===r||"string"===r)continue;const a=e.tracks.find((function(e){return e.name===n.name&&e.ValueTypeName===r}));if(void 0===a)continue;let s=0;const l=n.getValueSize();n.createInterpolant.isInterpolantFactoryMethodGLTFCubicSpline&&(s=l/3);let c=0;const h=a.getValueSize();a.createInterpolant.isInterpolantFactoryMethodGLTFCubicSpline&&(c=h/3);const d=n.times.length-1;let u;if(n.times[0]<o)if(o<n.times[d]){const e=n.createInterpolant(),t=s,i=l-s;e.evaluate(o),u=al.arraySlice(e.resultBuffer,t,i)}else{const e=d*l+s;u=al.arraySlice(n.values,e,e+l-s)}else{u=al.arraySlice(n.values,s,l-s)}if("quaternion"===r){(new Ge).fromArray(u).normalize().conjugate().toArray(u)}const p=a.times.length;for(let e=0;p>e;++e){const t=e*h+c;if("quaternion"===r)Ge.multiplyQuaternionsFlat(a.values,t,u,0,a.values,t);else{const e=h-2*c;for(let i=0;e>i;++i)a.values[t+i]-=u[i]}}}return e.blendMode=Z,e}};class sl{constructor(e,t,i,n){this.parameterPositions=e,this._cachedIndex=0,this.resultBuffer=void 0!==n?n:new t.constructor(i),this.sampleValues=t,this.valueSize=i,this.settings=null,this.DefaultSettings_={}}evaluate(e){const t=this.parameterPositions;let i=this._cachedIndex,n=t[i],r=t[i-1];e:{t:{let o;i:{n:if(n<=e){for(let o=i+2;;){if(void 0===n){if(r>e)break n;return i=t.length,this._cachedIndex=i,this.afterEnd_(i-1,e,r)}if(i===o)break;if(r=n,n=t[++i],n>e)break t}o=t.length;break i}if(e>=r)break e;{const a=t[1];a>e&&(i=2,r=a);for(let o=i-2;;){if(void 0===r)return this._cachedIndex=0,this.beforeStart_(0,e,n);if(i===o)break;if(n=r,r=t[--i-1],e>=r)break t}o=i,i=0}}for(;o>i;){const n=i+o>>>1;t[n]>e?o=n:i=n+1}if(n=t[i],r=t[i-1],void 0===r)return this._cachedIndex=0,this.beforeStart_(0,e,n);if(void 0===n)return i=t.length,this._cachedIndex=i,this.afterEnd_(i-1,r,e)}this._cachedIndex=i,this.intervalChanged_(i,r,n)}return this.interpolate_(i,r,e,n)}getSettings_(){return this.settings||this.DefaultSettings_}copySampleValue_(e){const t=this.resultBuffer,i=this.sampleValues,n=this.valueSize,r=e*n;for(let e=0;e!==n;++e)t[e]=i[r+e];return t}interpolate_(){throw new Error("call to abstract method")}intervalChanged_(){}}sl.prototype.beforeStart_=sl.prototype.copySampleValue_,sl.prototype.afterEnd_=sl.prototype.copySampleValue_;class ll extends sl{constructor(e,t,i,n){super(e,t,i,n),this._weightPrev=-0,this._offsetPrev=-0,this._weightNext=-0,this._offsetNext=-0,this.DefaultSettings_={endingStart:W,endingEnd:W}}intervalChanged_(e,t,i){const n=this.parameterPositions;let r=e-2,o=e+1,a=n[r],s=n[o];if(void 0===a)switch(this.getSettings_().endingStart){case J:r=e,a=2*t-i;break;case z:r=n.length-2,a=t+n[r]-n[r+1];break;default:r=e,a=i}if(void 0===s)switch(this.getSettings_().endingEnd){case J:o=e,s=2*i-t;break;case z:o=1,s=i+n[1]-n[0];break;default:o=e-1,s=t}const l=.5*(i-t),c=this.valueSize;this._weightPrev=l/(t-a),this._weightNext=l/(s-i),this._offsetPrev=r*c,this._offsetNext=o*c}interpolate_(e,t,i,n){const r=this.resultBuffer,o=this.sampleValues,a=this.valueSize,s=e*a,l=s-a,c=this._offsetPrev,h=this._offsetNext,d=this._weightPrev,u=this._weightNext,p=(i-t)/(n-t),g=p*p,f=g*p,m=-d*f+2*d*g-d*p,A=(1+d)*f+(-1.5-2*d)*g+(-.5+d)*p+1,y=(-1-u)*f+(1.5+u)*g+.5*p,v=u*f-u*g;for(let e=0;e!==a;++e)r[e]=m*o[c+e]+A*o[l+e]+y*o[s+e]+v*o[h+e];return r}}class cl extends sl{constructor(e,t,i,n){super(e,t,i,n)}interpolate_(e,t,i,n){const r=this.resultBuffer,o=this.sampleValues,a=this.valueSize,s=e*a,l=s-a,c=(i-t)/(n-t),h=1-c;for(let e=0;e!==a;++e)r[e]=o[l+e]*h+o[s+e]*c;return r}}class hl extends sl{constructor(e,t,i,n){super(e,t,i,n)}interpolate_(e){return this.copySampleValue_(e-1)}}class dl{constructor(e,t,i,n){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=al.convertArray(t,this.TimeBufferType),this.values=al.convertArray(i,this.ValueBufferType),this.setInterpolation(n||this.DefaultInterpolation)}static toJSON(e){const t=e.constructor;let i;if(t.toJSON!==this.toJSON)i=t.toJSON(e);else{i={name:e.name,times:al.convertArray(e.times,Array),values:al.convertArray(e.values,Array)};const t=e.getInterpolation();t!==e.DefaultInterpolation&&(i.interpolation=t)}return i.type=e.ValueTypeName,i}InterpolantFactoryMethodDiscrete(e){return new hl(this.times,this.values,this.getValueSize(),e)}InterpolantFactoryMethodLinear(e){return new cl(this.times,this.values,this.getValueSize(),e)}InterpolantFactoryMethodSmooth(e){return new ll(this.times,this.values,this.getValueSize(),e)}setInterpolation(e){let t;switch(e){case Y:t=this.InterpolantFactoryMethodDiscrete;break;case H:t=this.InterpolantFactoryMethodLinear;break;case j:t=this.InterpolantFactoryMethodSmooth}if(void 0===t){const t="unsupported interpolation for "+this.ValueTypeName+" keyframe track named "+this.name;if(void 0===this.createInterpolant){if(e===this.DefaultInterpolation)throw new Error(t);this.setInterpolation(this.DefaultInterpolation)}return console.warn("THREE.KeyframeTrack:",t),this}return this.createInterpolant=t,this}getInterpolation(){switch(this.createInterpolant){case this.InterpolantFactoryMethodDiscrete:return Y;case this.InterpolantFactoryMethodLinear:return H;case this.InterpolantFactoryMethodSmooth:return j}}getValueSize(){return this.values.length/this.times.length}shift(e){if(0!==e){const t=this.times;for(let i=0,n=t.length;i!==n;++i)t[i]+=e}return this}scale(e){if(1!==e){const t=this.times;for(let i=0,n=t.length;i!==n;++i)t[i]*=e}return this}trim(e,t){const i=this.times,n=i.length;let r=0,o=n-1;for(;r!==n&&e>i[r];)++r;for(;-1!==o&&i[o]>t;)--o;if(++o,0!==r||o!==n){o>r||(o=Math.max(o,1),r=o-1);const e=this.getValueSize();this.times=al.arraySlice(i,r,o),this.values=al.arraySlice(this.values,r*e,o*e)}return this}validate(){let e=!0;const t=this.getValueSize();t-Math.floor(t)!=0&&(console.error("THREE.KeyframeTrack: Invalid value size in track.",this),e=!1);const i=this.times,n=this.values,r=i.length;0===r&&(console.error("THREE.KeyframeTrack: Track is empty.",this),e=!1);let o=null;for(let t=0;t!==r;t++){const n=i[t];if("number"==typeof n&&isNaN(n)){console.error("THREE.KeyframeTrack: Time is not a valid number.",this,t,n),e=!1;break}if(null!==o&&o>n){console.error("THREE.KeyframeTrack: Out of order keys.",this,t,n,o),e=!1;break}o=n}if(void 0!==n&&al.isTypedArray(n))for(let t=0,i=n.length;t!==i;++t){const i=n[t];if(isNaN(i)){console.error("THREE.KeyframeTrack: Value is not a valid number.",this,t,i),e=!1;break}}return e}optimize(){const e=al.arraySlice(this.times),t=al.arraySlice(this.values),i=this.getValueSize(),n=this.getInterpolation()===j,r=e.length-1;let o=1;for(let a=1;r>a;++a){let r=!1;const s=e[a];if(s!==e[a+1]&&(1!==a||s!==e[0]))if(n)r=!0;else{const e=a*i,n=e-i,o=e+i;for(let a=0;a!==i;++a){const i=t[e+a];if(i!==t[n+a]||i!==t[o+a]){r=!0;break}}}if(r){if(a!==o){e[o]=e[a];const n=a*i,r=o*i;for(let e=0;e!==i;++e)t[r+e]=t[n+e]}++o}}if(r>0){e[o]=e[r];for(let e=r*i,n=o*i,a=0;a!==i;++a)t[n+a]=t[e+a];++o}return o!==e.length?(this.times=al.arraySlice(e,0,o),this.values=al.arraySlice(t,0,o*i)):(this.times=e,this.values=t),this}clone(){const e=al.arraySlice(this.times,0),t=al.arraySlice(this.values,0),i=new(0,this.constructor)(this.name,e,t);return i.createInterpolant=this.createInterpolant,i}}dl.prototype.TimeBufferType=Float32Array,dl.prototype.ValueBufferType=Float32Array,dl.prototype.DefaultInterpolation=H;class ul extends dl{}ul.prototype.ValueTypeName="bool",ul.prototype.ValueBufferType=Array,ul.prototype.DefaultInterpolation=Y,ul.prototype.InterpolantFactoryMethodLinear=void 0,ul.prototype.InterpolantFactoryMethodSmooth=void 0;class pl extends dl{}pl.prototype.ValueTypeName="color";class gl extends dl{}gl.prototype.ValueTypeName="number";class fl extends sl{constructor(e,t,i,n){super(e,t,i,n)}interpolate_(e,t,i,n){const r=this.resultBuffer,o=this.sampleValues,a=this.valueSize,s=(i-t)/(n-t);let l=e*a;for(let e=l+a;l!==e;l+=4)Ge.slerpFlat(r,0,o,l-a,o,l,s);return r}}class ml extends dl{InterpolantFactoryMethodLinear(e){return new fl(this.times,this.values,this.getValueSize(),e)}}ml.prototype.ValueTypeName="quaternion",ml.prototype.DefaultInterpolation=H,ml.prototype.InterpolantFactoryMethodSmooth=void 0;class Al extends dl{}Al.prototype.ValueTypeName="string",Al.prototype.ValueBufferType=Array,Al.prototype.DefaultInterpolation=Y,Al.prototype.InterpolantFactoryMethodLinear=void 0,Al.prototype.InterpolantFactoryMethodSmooth=void 0;class yl extends dl{}yl.prototype.ValueTypeName="vector";class vl{constructor(e,t=-1,i,n=2500){this.name=e,this.tracks=i,this.duration=t,this.blendMode=n,this.uuid=Ie(),0>this.duration&&this.resetDuration()}static parse(e){const t=[],i=e.tracks,n=1/(e.fps||1);for(let e=0,r=i.length;e!==r;++e)t.push(Cl(i[e]).scale(n));const r=new this(e.name,e.duration,t,e.blendMode);return r.uuid=e.uuid,r}static toJSON(e){const t=[],i=e.tracks,n={name:e.name,duration:e.duration,tracks:t,uuid:e.uuid,blendMode:e.blendMode};for(let e=0,n=i.length;e!==n;++e)t.push(dl.toJSON(i[e]));return n}static CreateFromMorphTargetSequence(e,t,i,n){const r=t.length,o=[];for(let e=0;r>e;e++){let a=[],s=[];a.push((e+r-1)%r,e,(e+1)%r),s.push(0,1,0);const l=al.getKeyframeOrder(a);a=al.sortedArray(a,1,l),s=al.sortedArray(s,1,l),n||0!==a[0]||(a.push(r),s.push(s[0])),o.push(new gl(".morphTargetInfluences["+t[e].name+"]",a,s).scale(1/i))}return new this(e,-1,o)}static findByName(e,t){let i=e;if(!Array.isArray(e)){const t=e;i=t.geometry&&t.geometry.animations||t.animations}for(let e=0;i.length>e;e++)if(i[e].name===t)return i[e];return null}static CreateClipsFromMorphTargetSequences(e,t,i){const n={},r=/^([\w-]*?)([\d]+)$/;for(let t=0,i=e.length;i>t;t++){const i=e[t],o=i.name.match(r);if(o&&o.length>1){const e=o[1];let t=n[e];t||(n[e]=t=[]),t.push(i)}}const o=[];for(const e in n)o.push(this.CreateFromMorphTargetSequence(e,n[e],t,i));return o}static parseAnimation(e,t){if(!e)return console.error("THREE.AnimationClip: No animation in JSONLoader data."),null;const i=function(e,t,i,n,r){if(0!==i.length){const o=[],a=[];al.flattenJSON(i,o,a,n),0!==o.length&&r.push(new e(t,o,a))}},n=[],r=e.name||"default",o=e.fps||30,a=e.blendMode;let s=e.length||-1;const l=e.hierarchy||[];for(let e=0;l.length>e;e++){const r=l[e].keys;if(r&&0!==r.length)if(r[0].morphTargets){const e={};let t;for(t=0;r.length>t;t++)if(r[t].morphTargets)for(let i=0;r[t].morphTargets.length>i;i++)e[r[t].morphTargets[i]]=-1;for(const i in e){const e=[],o=[];for(let n=0;n!==r[t].morphTargets.length;++n){const n=r[t];e.push(n.time),o.push(n.morphTarget===i?1:0)}n.push(new gl(".morphTargetInfluence["+i+"]",e,o))}s=e.length*(o||1)}else{const o=".bones["+t[e].name+"]";i(yl,o+".position",r,"pos",n),i(ml,o+".quaternion",r,"rot",n),i(yl,o+".scale",r,"scl",n)}}if(0===n.length)return null;return new this(r,s,n,a)}resetDuration(){let e=0;for(let t=0,i=this.tracks.length;t!==i;++t){const i=this.tracks[t];e=Math.max(e,i.times[i.times.length-1])}return this.duration=e,this}trim(){for(let e=0;this.tracks.length>e;e++)this.tracks[e].trim(0,this.duration);return this}validate(){let e=!0;for(let t=0;this.tracks.length>t;t++)e=e&&this.tracks[t].validate();return e}optimize(){for(let e=0;this.tracks.length>e;e++)this.tracks[e].optimize();return this}clone(){const e=[];for(let t=0;this.tracks.length>t;t++)e.push(this.tracks[t].clone());return new this.constructor(this.name,this.duration,e,this.blendMode)}toJSON(){return this.constructor.toJSON(this)}}function Cl(e){if(void 0===e.type)throw new Error("THREE.KeyframeTrack: track type undefined, can not parse");const t=function(e){switch(e.toLowerCase()){case"scalar":case"double":case"float":case"number":case"integer":return gl;case"vector":case"vector2":case"vector3":case"vector4":return yl;case"color":return pl;case"quaternion":return ml;case"bool":case"boolean":return ul;case"string":return Al}throw new Error("THREE.KeyframeTrack: Unsupported typeName: "+e)}(e.type);if(void 0===e.times){const t=[],i=[];al.flattenJSON(e.keys,t,i,"value"),e.times=t,e.values=i}return void 0!==t.parse?t.parse(e):new t(e.name,e.times,e.values,e.interpolation)}const Il={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={}}};class xl{constructor(e,t,i){const n=this;let r,o=!1,a=0,s=0;const l=[];this.onStart=void 0,this.onLoad=e,this.onProgress=t,this.onError=i,this.itemStart=function(e){s++,!1===o&&void 0!==n.onStart&&n.onStart(e,a,s),o=!0},this.itemEnd=function(e){a++,void 0!==n.onProgress&&n.onProgress(e,a,s),a===s&&(o=!1,void 0!==n.onLoad&&n.onLoad())},this.itemError=function(e){void 0!==n.onError&&n.onError(e)},this.resolveURL=function(e){return r?r(e):e},this.setURLModifier=function(e){return r=e,this},this.addHandler=function(e,t){return l.push(e,t),this},this.removeHandler=function(e){const t=l.indexOf(e);return-1!==t&&l.splice(t,2),this},this.getHandler=function(e){for(let t=0,i=l.length;i>t;t+=2){const i=l[t],n=l[t+1];if(i.global&&(i.lastIndex=0),i.test(e))return n}return null}}}const wl=new xl;class Ml{constructor(e){this.manager=void 0!==e?e:wl,this.crossOrigin="anonymous",this.withCredentials=!1,this.path="",this.resourcePath="",this.requestHeader={}}load(){}loadAsync(e,t){const i=this;return new Promise((function(n,r){i.load(e,n,t,r)}))}parse(){}setCrossOrigin(e){return this.crossOrigin=e,this}setWithCredentials(e){return this.withCredentials=e,this}setPath(e){return this.path=e,this}setResourcePath(e){return this.resourcePath=e,this}setRequestHeader(e){return this.requestHeader=e,this}}const El={};class Bl extends Ml{constructor(e){super(e)}load(e,t,i,n){void 0===e&&(e=""),void 0!==this.path&&(e=this.path+e),e=this.manager.resolveURL(e);const r=this,o=Il.get(e);if(void 0!==o)return r.manager.itemStart(e),setTimeout((function(){t&&t(o),r.manager.itemEnd(e)}),0),o;if(void 0!==El[e])return void El[e].push({onLoad:t,onProgress:i,onError:n});const a=e.match(/^data:(.*?)(;base64)?,(.*)$/);let s;if(a){const i=a[1],o=!!a[2];let s=a[3];s=decodeURIComponent(s),o&&(s=atob(s));try{let n;const o=(this.responseType||"").toLowerCase();switch(o){case"arraybuffer":case"blob":const e=new Uint8Array(s.length);for(let t=0;s.length>t;t++)e[t]=s.charCodeAt(t);n="blob"===o?new Blob([e.buffer],{type:i}):e.buffer;break;case"document":const t=new DOMParser;n=t.parseFromString(s,i);break;case"json":n=JSON.parse(s);break;default:n=s}setTimeout((function(){t&&t(n),r.manager.itemEnd(e)}),0)}catch(t){setTimeout((function(){n&&n(t),r.manager.itemError(e),r.manager.itemEnd(e)}),0)}}else{El[e]=[],El[e].push({onLoad:t,onProgress:i,onError:n}),s=new XMLHttpRequest,s.open("GET",e,!0),s.addEventListener("load",(function(t){const i=this.response,n=El[e];if(delete El[e],200===this.status||0===this.status){0===this.status&&console.warn("THREE.FileLoader: HTTP Status 0 received."),Il.add(e,i);for(let e=0,t=n.length;t>e;e++){const t=n[e];t.onLoad&&t.onLoad(i)}r.manager.itemEnd(e)}else{for(let e=0,i=n.length;i>e;e++){const i=n[e];i.onError&&i.onError(t)}r.manager.itemError(e),r.manager.itemEnd(e)}}),!1),s.addEventListener("progress",(function(t){const i=El[e];for(let e=0,n=i.length;n>e;e++){const n=i[e];n.onProgress&&n.onProgress(t)}}),!1),s.addEventListener("error",(function(t){const i=El[e];delete El[e];for(let e=0,n=i.length;n>e;e++){const n=i[e];n.onError&&n.onError(t)}r.manager.itemError(e),r.manager.itemEnd(e)}),!1),s.addEventListener("abort",(function(t){const i=El[e];delete El[e];for(let e=0,n=i.length;n>e;e++){const n=i[e];n.onError&&n.onError(t)}r.manager.itemError(e),r.manager.itemEnd(e)}),!1),void 0!==this.responseType&&(s.responseType=this.responseType),void 0!==this.withCredentials&&(s.withCredentials=this.withCredentials),s.overrideMimeType&&s.overrideMimeType(void 0!==this.mimeType?this.mimeType:"text/plain");for(const e in this.requestHeader)s.setRequestHeader(e,this.requestHeader[e]);s.send(null)}return r.manager.itemStart(e),s}setResponseType(e){return this.responseType=e,this}setMimeType(e){return this.mimeType=e,this}}class Sl extends Ml{constructor(e){super(e)}load(e,t,i,n){void 0!==this.path&&(e=this.path+e),e=this.manager.resolveURL(e);const r=this,o=Il.get(e);if(void 0!==o)return r.manager.itemStart(e),setTimeout((function(){t&&t(o),r.manager.itemEnd(e)}),0),o;const a=document.createElementNS("http://www.w3.org/1999/xhtml","img");function s(){a.removeEventListener("load",s,!1),a.removeEventListener("error",l,!1),Il.add(e,this),t&&t(this),r.manager.itemEnd(e)}function l(t){a.removeEventListener("load",s,!1),a.removeEventListener("error",l,!1),n&&n(t),r.manager.itemError(e),r.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),r.manager.itemStart(e),a.src=e,a}}class bl extends Ml{constructor(e){super(e)}load(e,t,i,n){const r=new gn,o=new Sl(this.manager);o.setCrossOrigin(this.crossOrigin),o.setPath(this.path);let a=0;function s(i){o.load(e[i],(function(e){r.images[i]=e,a++,6===a&&(r.needsUpdate=!0,t&&t(r))}),void 0,n)}for(let t=0;e.length>t;++t)s(t);return r}}class kl extends Ml{constructor(e){super(e)}load(e,t,i,n){const r=this,o=new ya,a=new Bl(this.manager);return a.setResponseType("arraybuffer"),a.setRequestHeader(this.requestHeader),a.setPath(this.path),a.setWithCredentials(r.withCredentials),a.load(e,(function(e){const i=r.parse(e);i&&(void 0!==i.image?o.image=i.image:void 0!==i.data&&(o.image.width=i.width,o.image.height=i.height,o.image.data=i.data),o.wrapS=void 0!==i.wrapS?i.wrapS:f,o.wrapT=void 0!==i.wrapT?i.wrapT:f,o.magFilter=void 0!==i.magFilter?i.magFilter:C,o.minFilter=void 0!==i.minFilter?i.minFilter:C,o.anisotropy=void 0!==i.anisotropy?i.anisotropy:1,void 0!==i.encoding&&(o.encoding=i.encoding),void 0!==i.flipY&&(o.flipY=i.flipY),void 0!==i.format&&(o.format=i.format),void 0!==i.type&&(o.type=i.type),void 0!==i.mipmaps&&(o.mipmaps=i.mipmaps,o.minFilter=x),1===i.mipmapCount&&(o.minFilter=C),void 0!==i.generateMipmaps&&(o.generateMipmaps=i.generateMipmaps),o.needsUpdate=!0,t&&t(o,i))}),i,n),o}}class Dl extends Ml{constructor(e){super(e)}load(e,t,i,n){const r=new Fe,o=new Sl(this.manager);return o.setCrossOrigin(this.crossOrigin),o.setPath(this.path),o.load(e,(function(i){r.image=i;const n=e.search(/\.jpe?g($|\?)/i)>0||0===e.search(/^data\:image\/jpeg/);r.format=n?k:D,r.needsUpdate=!0,void 0!==t&&t(r)}),i,n),r}}class Tl{constructor(){this.type="Curve",this.arcLengthDivisions=200}getPoint(){return console.warn("THREE.Curve: .getPoint() not implemented."),null}getPointAt(e,t){const i=this.getUtoTmapping(e);return this.getPoint(i,t)}getPoints(e=5){const t=[];for(let i=0;e>=i;i++)t.push(this.getPoint(i/e));return t}getSpacedPoints(e=5){const t=[];for(let i=0;e>=i;i++)t.push(this.getPointAt(i/e));return t}getLength(){const e=this.getLengths();return e[e.length-1]}getLengths(e=this.arcLengthDivisions){if(this.cacheArcLengths&&this.cacheArcLengths.length===e+1&&!this.needsUpdate)return this.cacheArcLengths;this.needsUpdate=!1;const t=[];let i,n=this.getPoint(0),r=0;t.push(0);for(let o=1;e>=o;o++)i=this.getPoint(o/e),r+=i.distanceTo(n),t.push(r),n=i;return this.cacheArcLengths=t,t}updateArcLengths(){this.needsUpdate=!0,this.getLengths()}getUtoTmapping(e,t){const i=this.getLengths();let n=0;const r=i.length;let o;o=t||e*i[r-1];let a,s=0,l=r-1;for(;l>=s;)if(n=Math.floor(s+(l-s)/2),a=i[n]-o,0>a)s=n+1;else{if(0>=a){l=n;break}l=n-1}if(n=l,i[n]===o)return n/(r-1);const c=i[n];return(n+(o-c)/(i[n+1]-c))/(r-1)}getTangent(e,t){const i=1e-4;let n=e-i,r=e+i;0>n&&(n=0),r>1&&(r=1);const o=this.getPoint(n),a=this.getPoint(r),s=t||(o.isVector2?new ke:new Ke);return s.copy(a).sub(o).normalize(),s}getTangentAt(e,t){const i=this.getUtoTmapping(e);return this.getTangent(i,t)}computeFrenetFrames(e,t){const i=new Ke,n=[],r=[],o=[],a=new Ke,s=new yt;for(let t=0;e>=t;t++){n[t]=this.getTangentAt(t/e,new Ke),n[t].normalize()}r[0]=new Ke,o[0]=new Ke;let l=Number.MAX_VALUE;const c=Math.abs(n[0].x),h=Math.abs(n[0].y),d=Math.abs(n[0].z);c>l||(l=c,i.set(1,0,0)),h>l||(l=h,i.set(0,1,0)),d>l||i.set(0,0,1),a.crossVectors(n[0],i).normalize(),r[0].crossVectors(n[0],a),o[0].crossVectors(n[0],r[0]);for(let t=1;e>=t;t++){if(r[t]=r[t-1].clone(),o[t]=o[t-1].clone(),a.crossVectors(n[t-1],n[t]),a.length()>Number.EPSILON){a.normalize();const e=Math.acos(xe(n[t-1].dot(n[t]),-1,1));r[t].applyMatrix4(s.makeRotationAxis(a,e))}o[t].crossVectors(n[t],r[t])}if(!0===t){let t=Math.acos(xe(r[0].dot(r[e]),-1,1));t/=e,n[0].dot(a.crossVectors(r[0],r[e]))>0&&(t=-t);for(let i=1;e>=i;i++)r[i].applyMatrix4(s.makeRotationAxis(n[i],t*i)),o[i].crossVectors(n[i],r[i])}return{tangents:n,normals:r,binormals:o}}clone(){return(new this.constructor).copy(this)}copy(e){return this.arcLengthDivisions=e.arcLengthDivisions,this}toJSON(){const e={metadata:{version:4.5,type:"Curve",generator:"Curve.toJSON"}};return e.arcLengthDivisions=this.arcLengthDivisions,e.type=this.type,e}fromJSON(e){return this.arcLengthDivisions=e.arcLengthDivisions,this}}class Rl extends Tl{constructor(e=0,t=0,i=1,n=1,r=0,o=2*Math.PI,a=!1,s=0){super(),this.type="EllipseCurve",this.aX=e,this.aY=t,this.xRadius=i,this.yRadius=n,this.aStartAngle=r,this.aEndAngle=o,this.aClockwise=a,this.aRotation=s}getPoint(e,t){const i=t||new ke,n=2*Math.PI;let r=this.aEndAngle-this.aStartAngle;const o=Math.abs(r)<Number.EPSILON;for(;0>r;)r+=n;for(;r>n;)r-=n;Number.EPSILON>r&&(r=o?0:n),!0!==this.aClockwise||o||(r===n?r=-n:r-=n);const a=this.aStartAngle+e*r;let s=this.aX+this.xRadius*Math.cos(a),l=this.aY+this.yRadius*Math.sin(a);if(0!==this.aRotation){const e=Math.cos(this.aRotation),t=Math.sin(this.aRotation),i=s-this.aX,n=l-this.aY;s=i*e-n*t+this.aX,l=i*t+n*e+this.aY}return i.set(s,l)}copy(e){return super.copy(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}toJSON(){const e=super.toJSON();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}fromJSON(e){return super.fromJSON(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}}Rl.prototype.isEllipseCurve=!0;class Ul extends Rl{constructor(e,t,i,n,r,o){super(e,t,i,i,n,r,o),this.type="ArcCurve"}}function Fl(){let e=0,t=0,i=0,n=0;function r(r,o,a,s){e=r,t=a,i=-3*r+3*o-2*a-s,n=2*r-2*o+a+s}return{initCatmullRom:function(e,t,i,n,o){r(t,i,o*(i-e),o*(n-t))},initNonuniformCatmullRom:function(e,t,i,n,o,a,s){let l=(t-e)/o-(i-e)/(o+a)+(i-t)/a,c=(i-t)/a-(n-t)/(a+s)+(n-i)/s;l*=a,c*=a,r(t,i,l,c)},calc:function(r){const o=r*r;return e+t*r+i*o+n*(o*r)}}}Ul.prototype.isArcCurve=!0;const Ql=new Ke,Ll=new Fl,Ol=new Fl,Nl=new Fl;class Pl extends Tl{constructor(e=[],t=!1,i="centripetal",n=.5){super(),this.type="CatmullRomCurve3",this.points=e,this.closed=t,this.curveType=i,this.tension=n}getPoint(e,t=new Ke){const i=t,n=this.points,r=n.length,o=(r-(this.closed?0:1))*e;let a,s,l=Math.floor(o),c=o-l;this.closed?l+=l>0?0:(Math.floor(Math.abs(l)/r)+1)*r:0===c&&l===r-1&&(l=r-2,c=1),this.closed||l>0?a=n[(l-1)%r]:(Ql.subVectors(n[0],n[1]).add(n[0]),a=Ql);const h=n[l%r],d=n[(l+1)%r];if(this.closed||r>l+2?s=n[(l+2)%r]:(Ql.subVectors(n[r-1],n[r-2]).add(n[r-1]),s=Ql),"centripetal"===this.curveType||"chordal"===this.curveType){const e="chordal"===this.curveType?.5:.25;let t=Math.pow(a.distanceToSquared(h),e),i=Math.pow(h.distanceToSquared(d),e),n=Math.pow(d.distanceToSquared(s),e);1e-4>i&&(i=1),1e-4>t&&(t=i),1e-4>n&&(n=i),Ll.initNonuniformCatmullRom(a.x,h.x,d.x,s.x,t,i,n),Ol.initNonuniformCatmullRom(a.y,h.y,d.y,s.y,t,i,n),Nl.initNonuniformCatmullRom(a.z,h.z,d.z,s.z,t,i,n)}else"catmullrom"===this.curveType&&(Ll.initCatmullRom(a.x,h.x,d.x,s.x,this.tension),Ol.initCatmullRom(a.y,h.y,d.y,s.y,this.tension),Nl.initCatmullRom(a.z,h.z,d.z,s.z,this.tension));return i.set(Ll.calc(c),Ol.calc(c),Nl.calc(c)),i}copy(e){super.copy(e),this.points=[];for(let t=0,i=e.points.length;i>t;t++){this.points.push(e.points[t].clone())}return this.closed=e.closed,this.curveType=e.curveType,this.tension=e.tension,this}toJSON(){const e=super.toJSON();e.points=[];for(let t=0,i=this.points.length;i>t;t++){e.points.push(this.points[t].toArray())}return e.closed=this.closed,e.curveType=this.curveType,e.tension=this.tension,e}fromJSON(e){super.fromJSON(e),this.points=[];for(let t=0,i=e.points.length;i>t;t++){const i=e.points[t];this.points.push((new Ke).fromArray(i))}return this.closed=e.closed,this.curveType=e.curveType,this.tension=e.tension,this}}function Gl(e,t,i,n,r){const o=.5*(n-t),a=.5*(r-i),s=e*e;return(2*i-2*n+o+a)*(e*s)+(-3*i+3*n-2*o-a)*s+o*e+i}function Kl(e,t,i,n){return function(e,t){const i=1-e;return i*i*t}(e,t)+function(e,t){return 2*(1-e)*e*t}(e,i)+function(e,t){return e*e*t}(e,n)}function Vl(e,t,i,n,r){return function(e,t){const i=1-e;return i*i*i*t}(e,t)+function(e,t){const i=1-e;return 3*i*i*e*t}(e,i)+function(e,t){return 3*(1-e)*e*e*t}(e,n)+function(e,t){return e*e*e*t}(e,r)}Pl.prototype.isCatmullRomCurve3=!0;class Yl extends Tl{constructor(e=new ke,t=new ke,i=new ke,n=new ke){super(),this.type="CubicBezierCurve",this.v0=e,this.v1=t,this.v2=i,this.v3=n}getPoint(e,t=new ke){const i=t,n=this.v0,r=this.v1,o=this.v2,a=this.v3;return i.set(Vl(e,n.x,r.x,o.x,a.x),Vl(e,n.y,r.y,o.y,a.y)),i}copy(e){return super.copy(e),this.v0.copy(e.v0),this.v1.copy(e.v1),this.v2.copy(e.v2),this.v3.copy(e.v3),this}toJSON(){const e=super.toJSON();return e.v0=this.v0.toArray(),e.v1=this.v1.toArray(),e.v2=this.v2.toArray(),e.v3=this.v3.toArray(),e}fromJSON(e){return super.fromJSON(e),this.v0.fromArray(e.v0),this.v1.fromArray(e.v1),this.v2.fromArray(e.v2),this.v3.fromArray(e.v3),this}}Yl.prototype.isCubicBezierCurve=!0;class Hl extends Tl{constructor(e=new Ke,t=new Ke,i=new Ke,n=new Ke){super(),this.type="CubicBezierCurve3",this.v0=e,this.v1=t,this.v2=i,this.v3=n}getPoint(e,t=new Ke){const i=t,n=this.v0,r=this.v1,o=this.v2,a=this.v3;return i.set(Vl(e,n.x,r.x,o.x,a.x),Vl(e,n.y,r.y,o.y,a.y),Vl(e,n.z,r.z,o.z,a.z)),i}copy(e){return super.copy(e),this.v0.copy(e.v0),this.v1.copy(e.v1),this.v2.copy(e.v2),this.v3.copy(e.v3),this}toJSON(){const e=super.toJSON();return e.v0=this.v0.toArray(),e.v1=this.v1.toArray(),e.v2=this.v2.toArray(),e.v3=this.v3.toArray(),e}fromJSON(e){return super.fromJSON(e),this.v0.fromArray(e.v0),this.v1.fromArray(e.v1),this.v2.fromArray(e.v2),this.v3.fromArray(e.v3),this}}Hl.prototype.isCubicBezierCurve3=!0;class jl extends Tl{constructor(e=new ke,t=new ke){super(),this.type="LineCurve",this.v1=e,this.v2=t}getPoint(e,t=new ke){const i=t;return 1===e?i.copy(this.v2):(i.copy(this.v2).sub(this.v1),i.multiplyScalar(e).add(this.v1)),i}getPointAt(e,t){return this.getPoint(e,t)}getTangent(e,t){const i=t||new ke;return i.copy(this.v2).sub(this.v1).normalize(),i}copy(e){return super.copy(e),this.v1.copy(e.v1),this.v2.copy(e.v2),this}toJSON(){const e=super.toJSON();return e.v1=this.v1.toArray(),e.v2=this.v2.toArray(),e}fromJSON(e){return super.fromJSON(e),this.v1.fromArray(e.v1),this.v2.fromArray(e.v2),this}}jl.prototype.isLineCurve=!0;class Wl extends Tl{constructor(e=new Ke,t=new Ke){super(),this.type="LineCurve3",this.isLineCurve3=!0,this.v1=e,this.v2=t}getPoint(e,t=new Ke){const i=t;return 1===e?i.copy(this.v2):(i.copy(this.v2).sub(this.v1),i.multiplyScalar(e).add(this.v1)),i}getPointAt(e,t){return this.getPoint(e,t)}copy(e){return super.copy(e),this.v1.copy(e.v1),this.v2.copy(e.v2),this}toJSON(){const e=super.toJSON();return e.v1=this.v1.toArray(),e.v2=this.v2.toArray(),e}fromJSON(e){return super.fromJSON(e),this.v1.fromArray(e.v1),this.v2.fromArray(e.v2),this}}class Jl extends Tl{constructor(e=new ke,t=new ke,i=new ke){super(),this.type="QuadraticBezierCurve",this.v0=e,this.v1=t,this.v2=i}getPoint(e,t=new ke){const i=t,n=this.v0,r=this.v1,o=this.v2;return i.set(Kl(e,n.x,r.x,o.x),Kl(e,n.y,r.y,o.y)),i}copy(e){return super.copy(e),this.v0.copy(e.v0),this.v1.copy(e.v1),this.v2.copy(e.v2),this}toJSON(){const e=super.toJSON();return e.v0=this.v0.toArray(),e.v1=this.v1.toArray(),e.v2=this.v2.toArray(),e}fromJSON(e){return super.fromJSON(e),this.v0.fromArray(e.v0),this.v1.fromArray(e.v1),this.v2.fromArray(e.v2),this}}Jl.prototype.isQuadraticBezierCurve=!0;class zl extends Tl{constructor(e=new Ke,t=new Ke,i=new Ke){super(),this.type="QuadraticBezierCurve3",this.v0=e,this.v1=t,this.v2=i}getPoint(e,t=new Ke){const i=t,n=this.v0,r=this.v1,o=this.v2;return i.set(Kl(e,n.x,r.x,o.x),Kl(e,n.y,r.y,o.y),Kl(e,n.z,r.z,o.z)),i}copy(e){return super.copy(e),this.v0.copy(e.v0),this.v1.copy(e.v1),this.v2.copy(e.v2),this}toJSON(){const e=super.toJSON();return e.v0=this.v0.toArray(),e.v1=this.v1.toArray(),e.v2=this.v2.toArray(),e}fromJSON(e){return super.fromJSON(e),this.v0.fromArray(e.v0),this.v1.fromArray(e.v1),this.v2.fromArray(e.v2),this}}zl.prototype.isQuadraticBezierCurve3=!0;class ql extends Tl{constructor(e=[]){super(),this.type="SplineCurve",this.points=e}getPoint(e,t=new ke){const i=t,n=this.points,r=(n.length-1)*e,o=Math.floor(r),a=r-o,s=n[0===o?o:o-1],l=n[o],c=n[o>n.length-2?n.length-1:o+1],h=n[o>n.length-3?n.length-1:o+2];return i.set(Gl(a,s.x,l.x,c.x,h.x),Gl(a,s.y,l.y,c.y,h.y)),i}copy(e){super.copy(e),this.points=[];for(let t=0,i=e.points.length;i>t;t++){this.points.push(e.points[t].clone())}return this}toJSON(){const e=super.toJSON();e.points=[];for(let t=0,i=this.points.length;i>t;t++){e.points.push(this.points[t].toArray())}return e}fromJSON(e){super.fromJSON(e),this.points=[];for(let t=0,i=e.points.length;i>t;t++){const i=e.points[t];this.points.push((new ke).fromArray(i))}return this}}ql.prototype.isSplineCurve=!0;var Zl=Object.freeze({__proto__:null,ArcCurve:Ul,CatmullRomCurve3:Pl,CubicBezierCurve:Yl,CubicBezierCurve3:Hl,EllipseCurve:Rl,LineCurve:jl,LineCurve3:Wl,QuadraticBezierCurve:Jl,QuadraticBezierCurve3:zl,SplineCurve:ql});class Xl extends Tl{constructor(){super(),this.type="CurvePath",this.curves=[],this.autoClose=!1}add(e){this.curves.push(e)}closePath(){const e=this.curves[0].getPoint(0),t=this.curves[this.curves.length-1].getPoint(1);e.equals(t)||this.curves.push(new jl(t,e))}getPoint(e){const t=e*this.getLength(),i=this.getCurveLengths();let n=0;for(;i.length>n;){if(i[n]>=t){const e=i[n]-t,r=this.curves[n],o=r.getLength();return r.getPointAt(0===o?0:1-e/o)}n++}return null}getLength(){const e=this.getCurveLengths();return e[e.length-1]}updateArcLengths(){this.needsUpdate=!0,this.cacheLengths=null,this.getCurveLengths()}getCurveLengths(){if(this.cacheLengths&&this.cacheLengths.length===this.curves.length)return this.cacheLengths;const e=[];let t=0;for(let i=0,n=this.curves.length;n>i;i++)t+=this.curves[i].getLength(),e.push(t);return this.cacheLengths=e,e}getSpacedPoints(e=40){const t=[];for(let i=0;e>=i;i++)t.push(this.getPoint(i/e));return this.autoClose&&t.push(t[0]),t}getPoints(e=12){const t=[];let i;for(let n=0,r=this.curves;r.length>n;n++){const o=r[n],a=o.getPoints(o&&o.isEllipseCurve?2*e:o&&(o.isLineCurve||o.isLineCurve3)?1:o&&o.isSplineCurve?e*o.points.length:e);for(let e=0;a.length>e;e++){const n=a[e];i&&i.equals(n)||(t.push(n),i=n)}}return this.autoClose&&t.length>1&&!t[t.length-1].equals(t[0])&&t.push(t[0]),t}copy(e){super.copy(e),this.curves=[];for(let t=0,i=e.curves.length;i>t;t++){this.curves.push(e.curves[t].clone())}return this.autoClose=e.autoClose,this}toJSON(){const e=super.toJSON();e.autoClose=this.autoClose,e.curves=[];for(let t=0,i=this.curves.length;i>t;t++){e.curves.push(this.curves[t].toJSON())}return e}fromJSON(e){super.fromJSON(e),this.autoClose=e.autoClose,this.curves=[];for(let t=0,i=e.curves.length;i>t;t++){const i=e.curves[t];this.curves.push((new Zl[i.type]).fromJSON(i))}return this}}class _l extends Xl{constructor(e){super(),this.type="Path",this.currentPoint=new ke,e&&this.setFromPoints(e)}setFromPoints(e){this.moveTo(e[0].x,e[0].y);for(let t=1,i=e.length;i>t;t++)this.lineTo(e[t].x,e[t].y);return this}moveTo(e,t){return this.currentPoint.set(e,t),this}lineTo(e,t){const i=new jl(this.currentPoint.clone(),new ke(e,t));return this.curves.push(i),this.currentPoint.set(e,t),this}quadraticCurveTo(e,t,i,n){const r=new Jl(this.currentPoint.clone(),new ke(e,t),new ke(i,n));return this.curves.push(r),this.currentPoint.set(i,n),this}bezierCurveTo(e,t,i,n,r,o){const a=new Yl(this.currentPoint.clone(),new ke(e,t),new ke(i,n),new ke(r,o));return this.curves.push(a),this.currentPoint.set(r,o),this}splineThru(e){const t=[this.currentPoint.clone()].concat(e),i=new ql(t);return this.curves.push(i),this.currentPoint.copy(e[e.length-1]),this}arc(e,t,i,n,r,o){return this.absarc(e+this.currentPoint.x,t+this.currentPoint.y,i,n,r,o),this}absarc(e,t,i,n,r,o){return this.absellipse(e,t,i,i,n,r,o),this}ellipse(e,t,i,n,r,o,a,s){return this.absellipse(e+this.currentPoint.x,t+this.currentPoint.y,i,n,r,o,a,s),this}absellipse(e,t,i,n,r,o,a,s){const l=new Rl(e,t,i,n,r,o,a,s);if(this.curves.length>0){const e=l.getPoint(0);e.equals(this.currentPoint)||this.lineTo(e.x,e.y)}this.curves.push(l);const c=l.getPoint(1);return this.currentPoint.copy(c),this}copy(e){return super.copy(e),this.currentPoint.copy(e.currentPoint),this}toJSON(){const e=super.toJSON();return e.currentPoint=this.currentPoint.toArray(),e}fromJSON(e){return super.fromJSON(e),this.currentPoint.fromArray(e.currentPoint),this}}class $l extends _l{constructor(e){super(e),this.uuid=Ie(),this.type="Shape",this.holes=[]}getPointsHoles(e){const t=[];for(let i=0,n=this.holes.length;n>i;i++)t[i]=this.holes[i].getPoints(e);return t}extractPoints(e){return{shape:this.getPoints(e),holes:this.getPointsHoles(e)}}copy(e){super.copy(e),this.holes=[];for(let t=0,i=e.holes.length;i>t;t++){this.holes.push(e.holes[t].clone())}return this}toJSON(){const e=super.toJSON();e.uuid=this.uuid,e.holes=[];for(let t=0,i=this.holes.length;i>t;t++){e.holes.push(this.holes[t].toJSON())}return e}fromJSON(e){super.fromJSON(e),this.uuid=e.uuid,this.holes=[];for(let t=0,i=e.holes.length;i>t;t++){const i=e.holes[t];this.holes.push((new _l).fromJSON(i))}return this}}class ec extends Yt{constructor(e,t=1){super(),this.type="Light",this.color=new pi(e),this.intensity=t}dispose(){}copy(e){return super.copy(e),this.color.copy(e.color),this.intensity=e.intensity,this}toJSON(e){const t=super.toJSON(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}}ec.prototype.isLight=!0;class tc extends ec{constructor(e,t,i){super(e,i),this.type="HemisphereLight",this.position.copy(Yt.DefaultUp),this.updateMatrix(),this.groundColor=new pi(t)}copy(e){return ec.prototype.copy.call(this,e),this.groundColor.copy(e.groundColor),this}}tc.prototype.isHemisphereLight=!0;const ic=new yt,nc=new Ke,rc=new Ke;class oc{constructor(e){this.camera=e,this.bias=0,this.normalBias=0,this.radius=1,this.mapSize=new ke(512,512),this.map=null,this.mapPass=null,this.matrix=new yt,this.autoUpdate=!0,this.needsUpdate=!1,this._frustum=new yn,this._frameExtents=new ke(1,1),this._viewportCount=1,this._viewports=[new Le(0,0,1,1)]}getViewportCount(){return this._viewportCount}getFrustum(){return this._frustum}updateMatrices(e){const t=this.camera,i=this.matrix;nc.setFromMatrixPosition(e.matrixWorld),t.position.copy(nc),rc.setFromMatrixPosition(e.target.matrixWorld),t.lookAt(rc),t.updateMatrixWorld(),ic.multiplyMatrices(t.projectionMatrix,t.matrixWorldInverse),this._frustum.setFromProjectionMatrix(ic),i.set(.5,0,0,.5,0,.5,0,.5,0,0,.5,.5,0,0,0,1),i.multiply(t.projectionMatrix),i.multiply(t.matrixWorldInverse)}getViewport(e){return this._viewports[e]}getFrameExtents(){return this._frameExtents}dispose(){this.map&&this.map.dispose(),this.mapPass&&this.mapPass.dispose()}copy(e){return this.camera=e.camera.clone(),this.bias=e.bias,this.radius=e.radius,this.mapSize.copy(e.mapSize),this}clone(){return(new this.constructor).copy(this)}toJSON(){const 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}}class ac extends oc{constructor(){super(new dn(50,1,.5,500)),this.focus=1}updateMatrices(e){const t=this.camera,i=2*Ce*e.angle*this.focus,n=this.mapSize.width/this.mapSize.height,r=e.distance||t.far;i===t.fov&&n===t.aspect&&r===t.far||(t.fov=i,t.aspect=n,t.far=r,t.updateProjectionMatrix()),super.updateMatrices(e)}copy(e){return super.copy(e),this.focus=e.focus,this}}ac.prototype.isSpotLightShadow=!0;class sc extends ec{constructor(e,t,i=0,n=Math.PI/3,r=0,o=1){super(e,t),this.type="SpotLight",this.position.copy(Yt.DefaultUp),this.updateMatrix(),this.target=new Yt,this.distance=i,this.angle=n,this.penumbra=r,this.decay=o,this.shadow=new ac}get power(){return this.intensity*Math.PI}set power(e){this.intensity=e/Math.PI}dispose(){this.shadow.dispose()}copy(e){return super.copy(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}}sc.prototype.isSpotLight=!0;const lc=new yt,cc=new Ke,hc=new Ke;class dc extends oc{constructor(){super(new dn(90,1,.5,500)),this._frameExtents=new ke(4,2),this._viewportCount=6,this._viewports=[new Le(2,1,1,1),new Le(0,1,1,1),new Le(3,1,1,1),new Le(1,1,1,1),new Le(3,0,1,1),new Le(1,0,1,1)],this._cubeDirections=[new Ke(1,0,0),new Ke(-1,0,0),new Ke(0,0,1),new Ke(0,0,-1),new Ke(0,1,0),new Ke(0,-1,0)],this._cubeUps=[new Ke(0,1,0),new Ke(0,1,0),new Ke(0,1,0),new Ke(0,1,0),new Ke(0,0,1),new Ke(0,0,-1)]}updateMatrices(e,t=0){const i=this.camera,n=this.matrix,r=e.distance||i.far;r!==i.far&&(i.far=r,i.updateProjectionMatrix()),cc.setFromMatrixPosition(e.matrixWorld),i.position.copy(cc),hc.copy(i.position),hc.add(this._cubeDirections[t]),i.up.copy(this._cubeUps[t]),i.lookAt(hc),i.updateMatrixWorld(),n.makeTranslation(-cc.x,-cc.y,-cc.z),lc.multiplyMatrices(i.projectionMatrix,i.matrixWorldInverse),this._frustum.setFromProjectionMatrix(lc)}}dc.prototype.isPointLightShadow=!0;class uc extends ec{constructor(e,t,i=0,n=1){super(e,t),this.type="PointLight",this.distance=i,this.decay=n,this.shadow=new dc}get power(){return 4*this.intensity*Math.PI}set power(e){this.intensity=e/(4*Math.PI)}dispose(){this.shadow.dispose()}copy(e){return super.copy(e),this.distance=e.distance,this.decay=e.decay,this.shadow=e.shadow.clone(),this}}uc.prototype.isPointLight=!0;class pc extends hn{constructor(e=-1,t=1,i=1,n=-1,r=.1,o=2e3){super(),this.type="OrthographicCamera",this.zoom=1,this.view=null,this.left=e,this.right=t,this.top=i,this.bottom=n,this.near=r,this.far=o,this.updateProjectionMatrix()}copy(e,t){return super.copy(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(e,t,i,n,r,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=i,this.view.offsetY=n,this.view.width=r,this.view.height=o,this.updateProjectionMatrix()}clearViewOffset(){null!==this.view&&(this.view.enabled=!1),this.updateProjectionMatrix()}updateProjectionMatrix(){const e=(this.right-this.left)/(2*this.zoom),t=(this.top-this.bottom)/(2*this.zoom),i=(this.right+this.left)/2,n=(this.top+this.bottom)/2;let r=i-e,o=i+e,a=n+t,s=n-t;if(null!==this.view&&this.view.enabled){const e=(this.right-this.left)/this.view.fullWidth/this.zoom,t=(this.top-this.bottom)/this.view.fullHeight/this.zoom;r+=e*this.view.offsetX,o=r+e*this.view.width,a-=t*this.view.offsetY,s=a-t*this.view.height}this.projectionMatrix.makeOrthographic(r,o,a,s,this.near,this.far),this.projectionMatrixInverse.copy(this.projectionMatrix).invert()}toJSON(e){const t=super.toJSON(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}}pc.prototype.isOrthographicCamera=!0;class gc extends oc{constructor(){super(new pc(-5,5,5,-5,.5,500))}}gc.prototype.isDirectionalLightShadow=!0;class fc extends ec{constructor(e,t){super(e,t),this.type="DirectionalLight",this.position.copy(Yt.DefaultUp),this.updateMatrix(),this.target=new Yt,this.shadow=new gc}dispose(){this.shadow.dispose()}copy(e){return super.copy(e),this.target=e.target.clone(),this.shadow=e.shadow.clone(),this}}fc.prototype.isDirectionalLight=!0;class mc extends ec{constructor(e,t){super(e,t),this.type="AmbientLight"}}mc.prototype.isAmbientLight=!0;class Ac extends ec{constructor(e,t,i=10,n=10){super(e,t),this.type="RectAreaLight",this.width=i,this.height=n}copy(e){return super.copy(e),this.width=e.width,this.height=e.height,this}toJSON(e){const t=super.toJSON(e);return t.object.width=this.width,t.object.height=this.height,t}}Ac.prototype.isRectAreaLight=!0;class yc{constructor(){this.coefficients=[];for(let e=0;9>e;e++)this.coefficients.push(new Ke)}static getBasisAt(e,t){const i=e.x,n=e.y,r=e.z;t[0]=.282095,t[1]=.488603*n,t[2]=.488603*r,t[3]=.488603*i,t[4]=1.092548*i*n,t[5]=1.092548*n*r,t[6]=.315392*(3*r*r-1),t[7]=1.092548*i*r,t[8]=.546274*(i*i-n*n)}set(e){for(let t=0;9>t;t++)this.coefficients[t].copy(e[t]);return this}zero(){for(let e=0;9>e;e++)this.coefficients[e].set(0,0,0);return this}getAt(e,t){const i=e.x,n=e.y,r=e.z,o=this.coefficients;return t.copy(o[0]).multiplyScalar(.282095),t.addScaledVector(o[1],.488603*n),t.addScaledVector(o[2],.488603*r),t.addScaledVector(o[3],.488603*i),t.addScaledVector(o[4],i*n*1.092548),t.addScaledVector(o[5],n*r*1.092548),t.addScaledVector(o[6],.315392*(3*r*r-1)),t.addScaledVector(o[7],i*r*1.092548),t.addScaledVector(o[8],.546274*(i*i-n*n)),t}getIrradianceAt(e,t){const i=e.x,n=e.y,r=e.z,o=this.coefficients;return t.copy(o[0]).multiplyScalar(.886227),t.addScaledVector(o[1],1.023328*n),t.addScaledVector(o[2],1.023328*r),t.addScaledVector(o[3],1.023328*i),t.addScaledVector(o[4],.858086*i*n),t.addScaledVector(o[5],.858086*n*r),t.addScaledVector(o[6],.743125*r*r-.247708),t.addScaledVector(o[7],.858086*i*r),t.addScaledVector(o[8],.429043*(i*i-n*n)),t}add(e){for(let t=0;9>t;t++)this.coefficients[t].add(e.coefficients[t]);return this}addScaledSH(e,t){for(let i=0;9>i;i++)this.coefficients[i].addScaledVector(e.coefficients[i],t);return this}scale(e){for(let t=0;9>t;t++)this.coefficients[t].multiplyScalar(e);return this}lerp(e,t){for(let i=0;9>i;i++)this.coefficients[i].lerp(e.coefficients[i],t);return this}equals(e){for(let t=0;9>t;t++)if(!this.coefficients[t].equals(e.coefficients[t]))return!1;return!0}copy(e){return this.set(e.coefficients)}clone(){return(new this.constructor).copy(this)}fromArray(e,t=0){const i=this.coefficients;for(let n=0;9>n;n++)i[n].fromArray(e,t+3*n);return this}toArray(e=[],t=0){const i=this.coefficients;for(let n=0;9>n;n++)i[n].toArray(e,t+3*n);return e}}yc.prototype.isSphericalHarmonics3=!0;class vc extends ec{constructor(e=new yc,t=1){super(void 0,t),this.sh=e}copy(e){return super.copy(e),this.sh.copy(e.sh),this}fromJSON(e){return this.intensity=e.intensity,this.sh.fromArray(e.sh),this}toJSON(e){const t=super.toJSON(e);return t.object.sh=this.sh.toArray(),t}}vc.prototype.isLightProbe=!0;class Cc extends Ml{constructor(e){super(e),this.textures={}}load(e,t,i,n){const r=this,o=new Bl(r.manager);o.setPath(r.path),o.setRequestHeader(r.requestHeader),o.setWithCredentials(r.withCredentials),o.load(e,(function(i){try{t(r.parse(JSON.parse(i)))}catch(t){n?n(t):console.error(t),r.manager.itemError(e)}}),i,n)}parse(e){const t=this.textures;function i(e){return void 0===t[e]&&console.warn("THREE.MaterialLoader: Undefined texture",e),t[e]}const n=new ol[e.type];if(void 0!==e.uuid&&(n.uuid=e.uuid),void 0!==e.name&&(n.name=e.name),void 0!==e.color&&void 0!==n.color&&n.color.setHex(e.color),void 0!==e.roughness&&(n.roughness=e.roughness),void 0!==e.metalness&&(n.metalness=e.metalness),void 0!==e.sheen&&(n.sheen=(new pi).setHex(e.sheen)),void 0!==e.emissive&&void 0!==n.emissive&&n.emissive.setHex(e.emissive),void 0!==e.specular&&void 0!==n.specular&&n.specular.setHex(e.specular),void 0!==e.shininess&&(n.shininess=e.shininess),void 0!==e.clearcoat&&(n.clearcoat=e.clearcoat),void 0!==e.clearcoatRoughness&&(n.clearcoatRoughness=e.clearcoatRoughness),void 0!==e.transmission&&(n.transmission=e.transmission),void 0!==e.thickness&&(n.thickness=e.thickness),void 0!==e.attenuationDistance&&(n.attenuationDistance=e.attenuationDistance),void 0!==e.attenuationColor&&void 0!==n.attenuationColor&&n.attenuationColor.setHex(e.attenuationColor),void 0!==e.fog&&(n.fog=e.fog),void 0!==e.flatShading&&(n.flatShading=e.flatShading),void 0!==e.blending&&(n.blending=e.blending),void 0!==e.combine&&(n.combine=e.combine),void 0!==e.side&&(n.side=e.side),void 0!==e.shadowSide&&(n.shadowSide=e.shadowSide),void 0!==e.opacity&&(n.opacity=e.opacity),void 0!==e.transparent&&(n.transparent=e.transparent),void 0!==e.alphaTest&&(n.alphaTest=e.alphaTest),void 0!==e.depthTest&&(n.depthTest=e.depthTest),void 0!==e.depthWrite&&(n.depthWrite=e.depthWrite),void 0!==e.colorWrite&&(n.colorWrite=e.colorWrite),void 0!==e.stencilWrite&&(n.stencilWrite=e.stencilWrite),void 0!==e.stencilWriteMask&&(n.stencilWriteMask=e.stencilWriteMask),void 0!==e.stencilFunc&&(n.stencilFunc=e.stencilFunc),void 0!==e.stencilRef&&(n.stencilRef=e.stencilRef),void 0!==e.stencilFuncMask&&(n.stencilFuncMask=e.stencilFuncMask),void 0!==e.stencilFail&&(n.stencilFail=e.stencilFail),void 0!==e.stencilZFail&&(n.stencilZFail=e.stencilZFail),void 0!==e.stencilZPass&&(n.stencilZPass=e.stencilZPass),void 0!==e.wireframe&&(n.wireframe=e.wireframe),void 0!==e.wireframeLinewidth&&(n.wireframeLinewidth=e.wireframeLinewidth),void 0!==e.wireframeLinecap&&(n.wireframeLinecap=e.wireframeLinecap),void 0!==e.wireframeLinejoin&&(n.wireframeLinejoin=e.wireframeLinejoin),void 0!==e.rotation&&(n.rotation=e.rotation),1!==e.linewidth&&(n.linewidth=e.linewidth),void 0!==e.dashSize&&(n.dashSize=e.dashSize),void 0!==e.gapSize&&(n.gapSize=e.gapSize),void 0!==e.scale&&(n.scale=e.scale),void 0!==e.polygonOffset&&(n.polygonOffset=e.polygonOffset),void 0!==e.polygonOffsetFactor&&(n.polygonOffsetFactor=e.polygonOffsetFactor),void 0!==e.polygonOffsetUnits&&(n.polygonOffsetUnits=e.polygonOffsetUnits),void 0!==e.morphTargets&&(n.morphTargets=e.morphTargets),void 0!==e.morphNormals&&(n.morphNormals=e.morphNormals),void 0!==e.dithering&&(n.dithering=e.dithering),void 0!==e.alphaToCoverage&&(n.alphaToCoverage=e.alphaToCoverage),void 0!==e.premultipliedAlpha&&(n.premultipliedAlpha=e.premultipliedAlpha),void 0!==e.vertexTangents&&(n.vertexTangents=e.vertexTangents),void 0!==e.visible&&(n.visible=e.visible),void 0!==e.toneMapped&&(n.toneMapped=e.toneMapped),void 0!==e.userData&&(n.userData=e.userData),void 0!==e.vertexColors&&(n.vertexColors="number"==typeof e.vertexColors?e.vertexColors>0:e.vertexColors),void 0!==e.uniforms)for(const t in e.uniforms){const r=e.uniforms[t];switch(n.uniforms[t]={},r.type){case"t":n.uniforms[t].value=i(r.value);break;case"c":n.uniforms[t].value=(new pi).setHex(r.value);break;case"v2":n.uniforms[t].value=(new ke).fromArray(r.value);break;case"v3":n.uniforms[t].value=(new Ke).fromArray(r.value);break;case"v4":n.uniforms[t].value=(new Le).fromArray(r.value);break;case"m3":n.uniforms[t].value=(new De).fromArray(r.value);break;case"m4":n.uniforms[t].value=(new yt).fromArray(r.value);break;default:n.uniforms[t].value=r.value}}if(void 0!==e.defines&&(n.defines=e.defines),void 0!==e.vertexShader&&(n.vertexShader=e.vertexShader),void 0!==e.fragmentShader&&(n.fragmentShader=e.fragmentShader),void 0!==e.extensions)for(const t in e.extensions)n.extensions[t]=e.extensions[t];if(void 0!==e.shading&&(n.flatShading=1===e.shading),void 0!==e.size&&(n.size=e.size),void 0!==e.sizeAttenuation&&(n.sizeAttenuation=e.sizeAttenuation),void 0!==e.map&&(n.map=i(e.map)),void 0!==e.matcap&&(n.matcap=i(e.matcap)),void 0!==e.alphaMap&&(n.alphaMap=i(e.alphaMap)),void 0!==e.bumpMap&&(n.bumpMap=i(e.bumpMap)),void 0!==e.bumpScale&&(n.bumpScale=e.bumpScale),void 0!==e.normalMap&&(n.normalMap=i(e.normalMap)),void 0!==e.normalMapType&&(n.normalMapType=e.normalMapType),void 0!==e.normalScale){let t=e.normalScale;!1===Array.isArray(t)&&(t=[t,t]),n.normalScale=(new ke).fromArray(t)}return void 0!==e.displacementMap&&(n.displacementMap=i(e.displacementMap)),void 0!==e.displacementScale&&(n.displacementScale=e.displacementScale),void 0!==e.displacementBias&&(n.displacementBias=e.displacementBias),void 0!==e.roughnessMap&&(n.roughnessMap=i(e.roughnessMap)),void 0!==e.metalnessMap&&(n.metalnessMap=i(e.metalnessMap)),void 0!==e.emissiveMap&&(n.emissiveMap=i(e.emissiveMap)),void 0!==e.emissiveIntensity&&(n.emissiveIntensity=e.emissiveIntensity),void 0!==e.specularMap&&(n.specularMap=i(e.specularMap)),void 0!==e.envMap&&(n.envMap=i(e.envMap)),void 0!==e.envMapIntensity&&(n.envMapIntensity=e.envMapIntensity),void 0!==e.reflectivity&&(n.reflectivity=e.reflectivity),void 0!==e.refractionRatio&&(n.refractionRatio=e.refractionRatio),void 0!==e.lightMap&&(n.lightMap=i(e.lightMap)),void 0!==e.lightMapIntensity&&(n.lightMapIntensity=e.lightMapIntensity),void 0!==e.aoMap&&(n.aoMap=i(e.aoMap)),void 0!==e.aoMapIntensity&&(n.aoMapIntensity=e.aoMapIntensity),void 0!==e.gradientMap&&(n.gradientMap=i(e.gradientMap)),void 0!==e.clearcoatMap&&(n.clearcoatMap=i(e.clearcoatMap)),void 0!==e.clearcoatRoughnessMap&&(n.clearcoatRoughnessMap=i(e.clearcoatRoughnessMap)),void 0!==e.clearcoatNormalMap&&(n.clearcoatNormalMap=i(e.clearcoatNormalMap)),void 0!==e.clearcoatNormalScale&&(n.clearcoatNormalScale=(new ke).fromArray(e.clearcoatNormalScale)),void 0!==e.transmissionMap&&(n.transmissionMap=i(e.transmissionMap)),void 0!==e.thicknessMap&&(n.thicknessMap=i(e.thicknessMap)),n}setTextures(e){return this.textures=e,this}}class Ic{static decodeText(e){if("undefined"!=typeof TextDecoder)return(new TextDecoder).decode(e);let t="";for(let i=0,n=e.length;n>i;i++)t+=String.fromCharCode(e[i]);try{return decodeURIComponent(escape(t))}catch(e){return t}}static extractUrlBase(e){const t=e.lastIndexOf("/");return-1===t?"./":e.substr(0,t+1)}}class xc extends Ni{constructor(){super(),this.type="InstancedBufferGeometry",this.instanceCount=1/0}copy(e){return super.copy(e),this.instanceCount=e.instanceCount,this}clone(){return(new this.constructor).copy(this)}toJSON(){const e=super.toJSON(this);return e.instanceCount=this.instanceCount,e.isInstancedBufferGeometry=!0,e}}xc.prototype.isInstancedBufferGeometry=!0;class wc extends Ai{constructor(e,t,i,n){"number"==typeof i&&(n=i,i=!1,console.error("THREE.InstancedBufferAttribute: The constructor now expects normalized as the third argument.")),super(e,t,i),this.meshPerAttribute=n||1}copy(e){return super.copy(e),this.meshPerAttribute=e.meshPerAttribute,this}toJSON(){const e=super.toJSON();return e.meshPerAttribute=this.meshPerAttribute,e.isInstancedBufferAttribute=!0,e}}wc.prototype.isInstancedBufferAttribute=!0;class Mc extends Ml{constructor(e){super(e)}load(e,t,i,n){const r=this,o=new Bl(r.manager);o.setPath(r.path),o.setRequestHeader(r.requestHeader),o.setWithCredentials(r.withCredentials),o.load(e,(function(i){try{t(r.parse(JSON.parse(i)))}catch(t){n?n(t):console.error(t),r.manager.itemError(e)}}),i,n)}parse(e){const t={},i={};function n(e,n){if(void 0!==t[n])return t[n];const r=e.interleavedBuffers[n],o=function(e,t){if(void 0!==i[t])return i[t];const n=new Uint32Array(e.arrayBuffers[t]).buffer;return i[t]=n,n}(e,r.buffer),a=Di(r.type,o),s=new Yo(a,r.stride);return s.uuid=r.uuid,t[n]=s,s}const r=e.isInstancedBufferGeometry?new xc:new Ni,o=e.data.index;if(void 0!==o){const e=Di(o.type,o.array);r.setIndex(new Ai(e,1))}const a=e.data.attributes;for(const t in a){const i=a[t];let o;if(i.isInterleavedBufferAttribute){const t=n(e.data,i.data);o=new jo(t,i.itemSize,i.offset,i.normalized)}else{const e=Di(i.type,i.array);o=new(i.isInstancedBufferAttribute?wc:Ai)(e,i.itemSize,i.normalized)}void 0!==i.name&&(o.name=i.name),void 0!==i.usage&&o.setUsage(i.usage),void 0!==i.updateRange&&(o.updateRange.offset=i.updateRange.offset,o.updateRange.count=i.updateRange.count),r.setAttribute(t,o)}const s=e.data.morphAttributes;if(s)for(const t in s){const i=s[t],o=[];for(let t=0,r=i.length;r>t;t++){const r=i[t];let a;if(r.isInterleavedBufferAttribute){const t=n(e.data,r.data);a=new jo(t,r.itemSize,r.offset,r.normalized)}else{const e=Di(r.type,r.array);a=new Ai(e,r.itemSize,r.normalized)}void 0!==r.name&&(a.name=r.name),o.push(a)}r.morphAttributes[t]=o}e.data.morphTargetsRelative&&(r.morphTargetsRelative=!0);const l=e.data.groups||e.data.drawcalls||e.data.offsets;if(void 0!==l)for(let e=0,t=l.length;e!==t;++e){const t=l[e];r.addGroup(t.start,t.count,t.materialIndex)}const c=e.data.boundingSphere;if(void 0!==c){const e=new Ke;void 0!==c.center&&e.fromArray(c.center),r.boundingSphere=new ct(e,c.radius)}return e.name&&(r.name=e.name),e.userData&&(r.userData=e.userData),r}}const Ec={UVMapping:s,CubeReflectionMapping:l,CubeRefractionMapping:c,EquirectangularReflectionMapping:h,EquirectangularRefractionMapping:d,CubeUVReflectionMapping:u,CubeUVRefractionMapping:p},Bc={RepeatWrapping:g,ClampToEdgeWrapping:f,MirroredRepeatWrapping:m},Sc={NearestFilter:A,NearestMipmapNearestFilter:y,NearestMipmapLinearFilter:v,LinearFilter:C,LinearMipmapNearestFilter:I,LinearMipmapLinearFilter:x};class bc extends Ml{constructor(e){super(e),"undefined"==typeof createImageBitmap&&console.warn("THREE.ImageBitmapLoader: createImageBitmap() not supported."),"undefined"==typeof fetch&&console.warn("THREE.ImageBitmapLoader: fetch() not supported."),this.options={premultiplyAlpha:"none"}}setOptions(e){return this.options=e,this}load(e,t,i,n){void 0===e&&(e=""),void 0!==this.path&&(e=this.path+e),e=this.manager.resolveURL(e);const r=this,o=Il.get(e);if(void 0!==o)return r.manager.itemStart(e),setTimeout((function(){t&&t(o),r.manager.itemEnd(e)}),0),o;const a={};a.credentials="anonymous"===this.crossOrigin?"same-origin":"include",a.headers=this.requestHeader,fetch(e,a).then((function(e){return e.blob()})).then((function(e){return createImageBitmap(e,Object.assign(r.options,{colorSpaceConversion:"none"}))})).then((function(i){Il.add(e,i),t&&t(i),r.manager.itemEnd(e)})).catch((function(t){n&&n(t),r.manager.itemError(e),r.manager.itemEnd(e)})),r.manager.itemStart(e)}}bc.prototype.isImageBitmapLoader=!0;class kc{constructor(){this.type="ShapePath",this.color=new pi,this.subPaths=[],this.currentPath=null}moveTo(e,t){return this.currentPath=new _l,this.subPaths.push(this.currentPath),this.currentPath.moveTo(e,t),this}lineTo(e,t){return this.currentPath.lineTo(e,t),this}quadraticCurveTo(e,t,i,n){return this.currentPath.quadraticCurveTo(e,t,i,n),this}bezierCurveTo(e,t,i,n,r,o){return this.currentPath.bezierCurveTo(e,t,i,n,r,o),this}splineThru(e){return this.currentPath.splineThru(e),this}toShapes(e,t){function i(e){const t=[];for(let i=0,n=e.length;n>i;i++){const n=e[i],r=new $l;r.curves=n.curves,t.push(r)}return t}function n(e,t){const i=t.length;let n=!1;for(let r=i-1,o=0;i>o;r=o++){let i=t[r],a=t[o],s=a.x-i.x,l=a.y-i.y;if(Math.abs(l)>Number.EPSILON){if(0>l&&(i=t[o],s=-s,a=t[r],l=-l),i.y>e.y||e.y>a.y)continue;if(e.y===i.y){if(e.x===i.x)return!0}else{const t=l*(e.x-i.x)-s*(e.y-i.y);if(0===t)return!0;if(0>t)continue;n=!n}}else{if(e.y!==i.y)continue;if(e.x>=a.x&&i.x>=e.x||e.x>=i.x&&a.x>=e.x)return!0}}return n}const r=Ds.isClockWise,o=this.subPaths;if(0===o.length)return[];if(!0===t)return i(o);let a,s,l;const c=[];if(1===o.length)return s=o[0],l=new $l,l.curves=s.curves,c.push(l),c;let h=!r(o[0].getPoints());h=e?!h:h;const d=[],u=[];let p,g,f=[],m=0;u[m]=void 0,f[m]=[];for(let t=0,i=o.length;i>t;t++)s=o[t],p=s.getPoints(),a=r(p),a=e?!a:a,a?(!h&&u[m]&&m++,u[m]={s:new $l,p:p},u[m].s.curves=s.curves,h&&m++,f[m]=[]):f[m].push({h:s,p:p[0]});if(!u[0])return i(o);if(u.length>1){let e=!1;const t=[];for(let e=0,t=u.length;t>e;e++)d[e]=[];for(let i=0,r=u.length;r>i;i++){const r=f[i];for(let o=0;r.length>o;o++){const a=r[o];let s=!0;for(let r=0;u.length>r;r++)n(a.p,u[r].p)&&(i!==r&&t.push({froms:i,tos:r,hole:o}),s?(s=!1,d[r].push(a)):e=!0);s&&d[i].push(a)}}t.length>0&&(e||(f=d))}for(let e=0,t=u.length;t>e;e++){l=u[e].s,c.push(l),g=f[e];for(let e=0,t=g.length;t>e;e++)l.holes.push(g[e].h)}return c}}class Dc{constructor(e){this.type="Font",this.data=e}generateShapes(e,t=100){const i=[],n=function(e,t,i){const n=Array.from(e),r=t/i.resolution,o=(i.boundingBox.yMax-i.boundingBox.yMin+i.underlineThickness)*r,a=[];let s=0,l=0;for(let e=0;n.length>e;e++){const t=n[e];if("\n"===t)s=0,l-=o;else{const e=Tc(t,r,s,l,i);s+=e.offsetX,a.push(e.path)}}return a}(e,t,this.data);for(let e=0,t=n.length;t>e;e++)Array.prototype.push.apply(i,n[e].toShapes());return i}}function Tc(e,t,i,n,r){const o=r.glyphs[e]||r.glyphs["?"];if(!o)return void console.error('THREE.Font: character "'+e+'" does not exists in font family '+r.familyName+".");const a=new kc;let s,l,c,h,d,u,p,g;if(o.o){const e=o._cachedOutline||(o._cachedOutline=o.o.split(" "));for(let r=0,o=e.length;o>r;){switch(e[r++]){case"m":s=e[r++]*t+i,l=e[r++]*t+n,a.moveTo(s,l);break;case"l":s=e[r++]*t+i,l=e[r++]*t+n,a.lineTo(s,l);break;case"q":c=e[r++]*t+i,h=e[r++]*t+n,d=e[r++]*t+i,u=e[r++]*t+n,a.quadraticCurveTo(d,u,c,h);break;case"b":c=e[r++]*t+i,h=e[r++]*t+n,d=e[r++]*t+i,u=e[r++]*t+n,p=e[r++]*t+i,g=e[r++]*t+n,a.bezierCurveTo(d,u,p,g,c,h)}}}return{offsetX:o.ha*t,path:a}}Dc.prototype.isFont=!0;let Rc;const Uc={getContext:function(){return void 0===Rc&&(Rc=new(window.AudioContext||window.webkitAudioContext)),Rc},setContext:function(e){Rc=e}};class Fc extends Ml{constructor(e){super(e)}load(e,t,i,n){const r=this,o=new Bl(this.manager);o.setResponseType("arraybuffer"),o.setPath(this.path),o.setRequestHeader(this.requestHeader),o.setWithCredentials(this.withCredentials),o.load(e,(function(i){try{const e=i.slice(0);Uc.getContext().decodeAudioData(e,(function(e){t(e)}))}catch(t){n?n(t):console.error(t),r.manager.itemError(e)}}),i,n)}}class Qc extends vc{constructor(e,t,i=1){super(void 0,i);const n=(new pi).set(e),r=(new pi).set(t),o=new Ke(n.r,n.g,n.b),a=new Ke(r.r,r.g,r.b),s=Math.sqrt(Math.PI),l=s*Math.sqrt(.75);this.sh.coefficients[0].copy(o).add(a).multiplyScalar(s),this.sh.coefficients[1].copy(o).sub(a).multiplyScalar(l)}}Qc.prototype.isHemisphereLightProbe=!0;class Lc extends vc{constructor(e,t=1){super(void 0,t);const i=(new pi).set(e);this.sh.coefficients[0].set(i.r,i.g,i.b).multiplyScalar(2*Math.sqrt(Math.PI))}}Lc.prototype.isAmbientLightProbe=!0;const Oc=new yt,Nc=new yt;class Pc{constructor(e=!0){this.autoStart=e,this.startTime=0,this.oldTime=0,this.elapsedTime=0,this.running=!1}start(){this.startTime=Gc(),this.oldTime=this.startTime,this.elapsedTime=0,this.running=!0}stop(){this.getElapsedTime(),this.running=!1,this.autoStart=!1}getElapsedTime(){return this.getDelta(),this.elapsedTime}getDelta(){let e=0;if(this.autoStart&&!this.running)return this.start(),0;if(this.running){const t=Gc();e=(t-this.oldTime)/1e3,this.oldTime=t,this.elapsedTime+=e}return e}}function Gc(){return("undefined"==typeof performance?Date:performance).now()}const Kc=new Ke,Vc=new Ge,Yc=new Ke,Hc=new Ke;class jc extends Yt{constructor(e){super(),this.type="Audio",this.listener=e,this.context=e.context,this.gain=this.context.createGain(),this.gain.connect(e.getInput()),this.autoplay=!1,this.buffer=null,this.detune=0,this.loop=!1,this.loopStart=0,this.loopEnd=0,this.offset=0,this.duration=void 0,this.playbackRate=1,this.isPlaying=!1,this.hasPlaybackControl=!0,this.source=null,this.sourceType="empty",this._startedAt=0,this._progress=0,this._connected=!1,this.filters=[]}getOutput(){return this.gain}setNodeSource(e){return this.hasPlaybackControl=!1,this.sourceType="audioNode",this.source=e,this.connect(),this}setMediaElementSource(e){return this.hasPlaybackControl=!1,this.sourceType="mediaNode",this.source=this.context.createMediaElementSource(e),this.connect(),this}setMediaStreamSource(e){return this.hasPlaybackControl=!1,this.sourceType="mediaStreamNode",this.source=this.context.createMediaStreamSource(e),this.connect(),this}setBuffer(e){return this.buffer=e,this.sourceType="buffer",this.autoplay&&this.play(),this}play(e=0){if(!0===this.isPlaying)return void console.warn("THREE.Audio: Audio is already playing.");if(!1===this.hasPlaybackControl)return void console.warn("THREE.Audio: this Audio has no playback control.");this._startedAt=this.context.currentTime+e;const 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()}pause(){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.")}stop(){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.")}connect(){if(this.filters.length>0){this.source.connect(this.filters[0]);for(let e=1,t=this.filters.length;t>e;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}disconnect(){if(this.filters.length>0){this.source.disconnect(this.filters[0]);for(let e=1,t=this.filters.length;t>e;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}getFilters(){return this.filters}setFilters(e){return e||(e=[]),!0===this._connected?(this.disconnect(),this.filters=e.slice(),this.connect()):this.filters=e.slice(),this}setDetune(e){if(this.detune=e,void 0!==this.source.detune)return!0===this.isPlaying&&this.source.detune.setTargetAtTime(this.detune,this.context.currentTime,.01),this}getDetune(){return this.detune}getFilter(){return this.getFilters()[0]}setFilter(e){return this.setFilters(e?[e]:[])}setPlaybackRate(e){if(!1!==this.hasPlaybackControl)return this.playbackRate=e,!0===this.isPlaying&&this.source.playbackRate.setTargetAtTime(this.playbackRate,this.context.currentTime,.01),this;console.warn("THREE.Audio: this Audio has no playback control.")}getPlaybackRate(){return this.playbackRate}onEnded(){this.isPlaying=!1}getLoop(){return!1===this.hasPlaybackControl?(console.warn("THREE.Audio: this Audio has no playback control."),!1):this.loop}setLoop(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.")}setLoopStart(e){return this.loopStart=e,this}setLoopEnd(e){return this.loopEnd=e,this}getVolume(){return this.gain.gain.value}setVolume(e){return this.gain.gain.setTargetAtTime(e,this.context.currentTime,.01),this}}const Wc=new Ke,Jc=new Ge,zc=new Ke,qc=new Ke;class Zc{constructor(e,t=2048){this.analyser=e.context.createAnalyser(),this.analyser.fftSize=t,this.data=new Uint8Array(this.analyser.frequencyBinCount),e.getOutput().connect(this.analyser)}getFrequencyData(){return this.analyser.getByteFrequencyData(this.data),this.data}getAverageFrequency(){let e=0;const t=this.getFrequencyData();for(let i=0;t.length>i;i++)e+=t[i];return e/t.length}}class Xc{constructor(e,t,i){let n,r,o;switch(this.binding=e,this.valueSize=i,t){case"quaternion":n=this._slerp,r=this._slerpAdditive,o=this._setAdditiveIdentityQuaternion,this.buffer=new Float64Array(6*i),this._workIndex=5;break;case"string":case"bool":n=this._select,r=this._select,o=this._setAdditiveIdentityOther,this.buffer=new Array(5*i);break;default:n=this._lerp,r=this._lerpAdditive,o=this._setAdditiveIdentityNumeric,this.buffer=new Float64Array(5*i)}this._mixBufferRegion=n,this._mixBufferRegionAdditive=r,this._setIdentity=o,this._origIndex=3,this._addIndex=4,this.cumulativeWeight=0,this.cumulativeWeightAdditive=0,this.useCount=0,this.referenceCount=0}accumulate(e,t){const i=this.buffer,n=this.valueSize,r=e*n+n;let o=this.cumulativeWeight;if(0===o){for(let e=0;e!==n;++e)i[r+e]=i[e];o=t}else{o+=t;this._mixBufferRegion(i,r,0,t/o,n)}this.cumulativeWeight=o}accumulateAdditive(e){const t=this.buffer,i=this.valueSize,n=i*this._addIndex;0===this.cumulativeWeightAdditive&&this._setIdentity(),this._mixBufferRegionAdditive(t,n,0,e,i),this.cumulativeWeightAdditive+=e}apply(e){const t=this.valueSize,i=this.buffer,n=e*t+t,r=this.cumulativeWeight,o=this.cumulativeWeightAdditive,a=this.binding;if(this.cumulativeWeight=0,this.cumulativeWeightAdditive=0,1>r){this._mixBufferRegion(i,n,t*this._origIndex,1-r,t)}o>0&&this._mixBufferRegionAdditive(i,n,this._addIndex*t,1,t);for(let e=t,r=t+t;e!==r;++e)if(i[e]!==i[e+t]){a.setValue(i,n);break}}saveOriginalState(){const e=this.buffer,t=this.valueSize,i=t*this._origIndex;this.binding.getValue(e,i);for(let n=t,r=i;n!==r;++n)e[n]=e[i+n%t];this._setIdentity(),this.cumulativeWeight=0,this.cumulativeWeightAdditive=0}restoreOriginalState(){this.binding.setValue(this.buffer,3*this.valueSize)}_setAdditiveIdentityNumeric(){const e=this._addIndex*this.valueSize,t=e+this.valueSize;for(let i=e;t>i;i++)this.buffer[i]=0}_setAdditiveIdentityQuaternion(){this._setAdditiveIdentityNumeric(),this.buffer[this._addIndex*this.valueSize+3]=1}_setAdditiveIdentityOther(){const e=this._origIndex*this.valueSize,t=this._addIndex*this.valueSize;for(let i=0;this.valueSize>i;i++)this.buffer[t+i]=this.buffer[e+i]}_select(e,t,i,n,r){if(n>=.5)for(let n=0;n!==r;++n)e[t+n]=e[i+n]}_slerp(e,t,i,n){Ge.slerpFlat(e,t,e,t,e,i,n)}_slerpAdditive(e,t,i,n,r){const o=this._workIndex*r;Ge.multiplyQuaternionsFlat(e,o,e,t,e,i),Ge.slerpFlat(e,t,e,t,e,o,n)}_lerp(e,t,i,n,r){const o=1-n;for(let a=0;a!==r;++a){const r=t+a;e[r]=e[r]*o+e[i+a]*n}}_lerpAdditive(e,t,i,n,r){for(let o=0;o!==r;++o){const r=t+o;e[r]=e[r]+e[i+o]*n}}}const _c="\\[\\]\\.:\\/",$c=new RegExp("[\\[\\]\\.:\\/]","g"),eh="[^\\[\\]\\.:\\/]",th="[^"+_c.replace("\\.","")+"]",ih=/((?:WC+[\/:])*)/.source.replace("WC",eh),nh=/(WCOD+)?/.source.replace("WCOD",th),rh=/(?:\.(WC+)(?:\[(.+)\])?)?/.source.replace("WC",eh),oh=/\.(WC+)(?:\[(.+)\])?/.source.replace("WC",eh),ah=new RegExp("^"+ih+nh+rh+oh+"$"),sh=["material","materials","bones"];class lh{constructor(e,t,i){this.path=t,this.parsedPath=i||lh.parseTrackName(t),this.node=lh.findNode(e,this.parsedPath.nodeName)||e,this.rootNode=e,this.getValue=this._getValue_unbound,this.setValue=this._setValue_unbound}static create(e,t,i){return e&&e.isAnimationObjectGroup?new lh.Composite(e,t,i):new lh(e,t,i)}static sanitizeNodeName(e){return e.replace(/\s/g,"_").replace($c,"")}static parseTrackName(e){const t=ah.exec(e);if(!t)throw new Error("PropertyBinding: Cannot parse trackName: "+e);const i={nodeName:t[2],objectName:t[3],objectIndex:t[4],propertyName:t[5],propertyIndex:t[6]},n=i.nodeName&&i.nodeName.lastIndexOf(".");if(void 0!==n&&-1!==n){const e=i.nodeName.substring(n+1);-1!==sh.indexOf(e)&&(i.nodeName=i.nodeName.substring(0,n),i.objectName=e)}if(null===i.propertyName||0===i.propertyName.length)throw new Error("PropertyBinding: can not parse propertyName from trackName: "+e);return i}static findNode(e,t){if(!t||""===t||"."===t||-1===t||t===e.name||t===e.uuid)return e;if(e.skeleton){const i=e.skeleton.getBoneByName(t);if(void 0!==i)return i}if(e.children){const i=function(e){for(let n=0;e.length>n;n++){const r=e[n];if(r.name===t||r.uuid===t)return r;const o=i(r.children);if(o)return o}return null},n=i(e.children);if(n)return n}return null}_getValue_unavailable(){}_setValue_unavailable(){}_getValue_direct(e,t){e[t]=this.node[this.propertyName]}_getValue_array(e,t){const i=this.resolvedProperty;for(let n=0,r=i.length;n!==r;++n)e[t++]=i[n]}_getValue_arrayElement(e,t){e[t]=this.resolvedProperty[this.propertyIndex]}_getValue_toArray(e,t){this.resolvedProperty.toArray(e,t)}_setValue_direct(e,t){this.targetObject[this.propertyName]=e[t]}_setValue_direct_setNeedsUpdate(e,t){this.targetObject[this.propertyName]=e[t],this.targetObject.needsUpdate=!0}_setValue_direct_setMatrixWorldNeedsUpdate(e,t){this.targetObject[this.propertyName]=e[t],this.targetObject.matrixWorldNeedsUpdate=!0}_setValue_array(e,t){const i=this.resolvedProperty;for(let n=0,r=i.length;n!==r;++n)i[n]=e[t++]}_setValue_array_setNeedsUpdate(e,t){const i=this.resolvedProperty;for(let n=0,r=i.length;n!==r;++n)i[n]=e[t++];this.targetObject.needsUpdate=!0}_setValue_array_setMatrixWorldNeedsUpdate(e,t){const i=this.resolvedProperty;for(let n=0,r=i.length;n!==r;++n)i[n]=e[t++];this.targetObject.matrixWorldNeedsUpdate=!0}_setValue_arrayElement(e,t){this.resolvedProperty[this.propertyIndex]=e[t]}_setValue_arrayElement_setNeedsUpdate(e,t){this.resolvedProperty[this.propertyIndex]=e[t],this.targetObject.needsUpdate=!0}_setValue_arrayElement_setMatrixWorldNeedsUpdate(e,t){this.resolvedProperty[this.propertyIndex]=e[t],this.targetObject.matrixWorldNeedsUpdate=!0}_setValue_fromArray(e,t){this.resolvedProperty.fromArray(e,t)}_setValue_fromArray_setNeedsUpdate(e,t){this.resolvedProperty.fromArray(e,t),this.targetObject.needsUpdate=!0}_setValue_fromArray_setMatrixWorldNeedsUpdate(e,t){this.resolvedProperty.fromArray(e,t),this.targetObject.matrixWorldNeedsUpdate=!0}_getValue_unbound(e,t){this.bind(),this.getValue(e,t)}_setValue_unbound(e,t){this.bind(),this.setValue(e,t)}bind(){let e=this.node;const t=this.parsedPath,i=t.objectName,n=t.propertyName;let r=t.propertyIndex;if(e||(e=lh.findNode(this.rootNode,t.nodeName)||this.rootNode,this.node=e),this.getValue=this._getValue_unavailable,this.setValue=this._setValue_unavailable,!e)return void console.error("THREE.PropertyBinding: Trying to update node for track: "+this.path+" but it wasn't found.");if(i){let n=t.objectIndex;switch(i){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(let t=0;e.length>t;t++)if(e[t].name===n){n=t;break}break;default:if(void 0===e[i])return void console.error("THREE.PropertyBinding: Can not bind to objectName of node undefined.",this);e=e[i]}if(void 0!==n){if(void 0===e[n])return void console.error("THREE.PropertyBinding: Trying to bind to objectIndex of objectName, but is undefined.",this,e);e=e[n]}}const o=e[n];if(void 0===o){return void console.error("THREE.PropertyBinding: Trying to update property for track: "+t.nodeName+"."+n+" but it wasn't found.",e)}let a=this.Versioning.None;this.targetObject=e,void 0!==e.needsUpdate?a=this.Versioning.NeedsUpdate:void 0!==e.matrixWorldNeedsUpdate&&(a=this.Versioning.MatrixWorldNeedsUpdate);let s=this.BindingType.Direct;if(void 0!==r){if("morphTargetInfluences"===n){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[r]&&(r=e.morphTargetDictionary[r])}s=this.BindingType.ArrayElement,this.resolvedProperty=o,this.propertyIndex=r}else void 0!==o.fromArray&&void 0!==o.toArray?(s=this.BindingType.HasFromToArray,this.resolvedProperty=o):Array.isArray(o)?(s=this.BindingType.EntireArray,this.resolvedProperty=o):this.propertyName=n;this.getValue=this.GetterByBindingType[s],this.setValue=this.SetterByBindingTypeAndVersioning[s][a]}unbind(){this.node=null,this.getValue=this._getValue_unbound,this.setValue=this._setValue_unbound}}lh.Composite=class{constructor(e,t,i){const n=i||lh.parseTrackName(t);this._targetGroup=e,this._bindings=e.subscribe_(t,n)}getValue(e,t){this.bind();const i=this._bindings[this._targetGroup.nCachedObjects_];void 0!==i&&i.getValue(e,t)}setValue(e,t){const i=this._bindings;for(let n=this._targetGroup.nCachedObjects_,r=i.length;n!==r;++n)i[n].setValue(e,t)}bind(){const e=this._bindings;for(let t=this._targetGroup.nCachedObjects_,i=e.length;t!==i;++t)e[t].bind()}unbind(){const e=this._bindings;for(let t=this._targetGroup.nCachedObjects_,i=e.length;t!==i;++t)e[t].unbind()}},lh.prototype.BindingType={Direct:0,EntireArray:1,ArrayElement:2,HasFromToArray:3},lh.prototype.Versioning={None:0,NeedsUpdate:1,MatrixWorldNeedsUpdate:2},lh.prototype.GetterByBindingType=[lh.prototype._getValue_direct,lh.prototype._getValue_array,lh.prototype._getValue_arrayElement,lh.prototype._getValue_toArray],lh.prototype.SetterByBindingTypeAndVersioning=[[lh.prototype._setValue_direct,lh.prototype._setValue_direct_setNeedsUpdate,lh.prototype._setValue_direct_setMatrixWorldNeedsUpdate],[lh.prototype._setValue_array,lh.prototype._setValue_array_setNeedsUpdate,lh.prototype._setValue_array_setMatrixWorldNeedsUpdate],[lh.prototype._setValue_arrayElement,lh.prototype._setValue_arrayElement_setNeedsUpdate,lh.prototype._setValue_arrayElement_setMatrixWorldNeedsUpdate],[lh.prototype._setValue_fromArray,lh.prototype._setValue_fromArray_setNeedsUpdate,lh.prototype._setValue_fromArray_setMatrixWorldNeedsUpdate]];class ch{constructor(){this.uuid=Ie(),this._objects=Array.prototype.slice.call(arguments),this.nCachedObjects_=0;const e={};this._indicesByUUID=e;for(let t=0,i=arguments.length;t!==i;++t)e[arguments[t].uuid]=t;this._paths=[],this._parsedPaths=[],this._bindings=[],this._bindingsIndicesByPath={};const t=this;this.stats={objects:{get total(){return t._objects.length},get inUse(){return this.total-t.nCachedObjects_}},get bindingsPerObject(){return t._bindings.length}}}add(){const e=this._objects,t=this._indicesByUUID,i=this._paths,n=this._parsedPaths,r=this._bindings,o=r.length;let a,s=e.length,l=this.nCachedObjects_;for(let c=0,h=arguments.length;c!==h;++c){const h=arguments[c],d=h.uuid;let u=t[d];if(void 0===u){u=s++,t[d]=u,e.push(h);for(let e=0,t=o;e!==t;++e)r[e].push(new lh(h,i[e],n[e]))}else if(l>u){a=e[u];const s=--l,c=e[s];t[c.uuid]=u,e[u]=c,t[d]=s,e[s]=h;for(let e=0,t=o;e!==t;++e){const t=r[e];let o=t[u];t[u]=t[s],void 0===o&&(o=new lh(h,i[e],n[e])),t[s]=o}}else e[u]!==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(){const e=this._objects,t=this._indicesByUUID,i=this._bindings,n=i.length;let r=this.nCachedObjects_;for(let o=0,a=arguments.length;o!==a;++o){const a=arguments[o],s=a.uuid,l=t[s];if(void 0!==l&&l>=r){const o=r++,c=e[o];t[c.uuid]=l,e[l]=c,t[s]=o,e[o]=a;for(let e=0,t=n;e!==t;++e){const t=i[e],n=t[l];t[l]=t[o],t[o]=n}}}this.nCachedObjects_=r}uncache(){const e=this._objects,t=this._indicesByUUID,i=this._bindings,n=i.length;let r=this.nCachedObjects_,o=e.length;for(let a=0,s=arguments.length;a!==s;++a){const s=arguments[a].uuid,l=t[s];if(void 0!==l)if(delete t[s],r>l){const a=--r,s=e[a],c=--o,h=e[c];t[s.uuid]=l,e[l]=s,t[h.uuid]=a,e[a]=h,e.pop();for(let e=0,t=n;e!==t;++e){const t=i[e],n=t[c];t[l]=t[a],t[a]=n,t.pop()}}else{const r=--o,a=e[r];r>0&&(t[a.uuid]=l),e[l]=a,e.pop();for(let e=0,t=n;e!==t;++e){const t=i[e];t[l]=t[r],t.pop()}}}this.nCachedObjects_=r}subscribe_(e,t){const i=this._bindingsIndicesByPath;let n=i[e];const r=this._bindings;if(void 0!==n)return r[n];const o=this._paths,a=this._parsedPaths,s=this._objects,l=this.nCachedObjects_,c=new Array(s.length);n=r.length,i[e]=n,o.push(e),a.push(t),r.push(c);for(let i=l,n=s.length;i!==n;++i){c[i]=new lh(s[i],e,t)}return c}unsubscribe_(e){const t=this._bindingsIndicesByPath,i=t[e];if(void 0!==i){const n=this._paths,r=this._parsedPaths,o=this._bindings,a=o.length-1,s=o[a];t[e[a]]=i,o[i]=s,o.pop(),r[i]=r[a],r.pop(),n[i]=n[a],n.pop()}}}ch.prototype.isAnimationObjectGroup=!0;class hh{constructor(e,t,i=null,n=t.blendMode){this._mixer=e,this._clip=t,this._localRoot=i,this.blendMode=n;const r=t.tracks,o=r.length,a=new Array(o),s={endingStart:W,endingEnd:W};for(let e=0;e!==o;++e){const t=r[e].createInterpolant(null);a[e]=t,t.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=2201,this._loopCount=-1,this._startTime=null,this.time=0,this.timeScale=1,this._effectiveTimeScale=1,this.weight=1,this._effectiveWeight=1,this.repetitions=1/0,this.paused=!1,this.enabled=!0,this.clampWhenFinished=!1,this.zeroSlopeAtStart=!0,this.zeroSlopeAtEnd=!0}play(){return this._mixer._activateAction(this),this}stop(){return this._mixer._deactivateAction(this),this.reset()}reset(){return this.paused=!1,this.enabled=!0,this.time=0,this._loopCount=-1,this._startTime=null,this.stopFading().stopWarping()}isRunning(){return this.enabled&&!this.paused&&0!==this.timeScale&&null===this._startTime&&this._mixer._isActiveAction(this)}isScheduled(){return this._mixer._isActiveAction(this)}startAt(e){return this._startTime=e,this}setLoop(e,t){return this.loop=e,this.repetitions=t,this}setEffectiveWeight(e){return this.weight=e,this._effectiveWeight=this.enabled?e:0,this.stopFading()}getEffectiveWeight(){return this._effectiveWeight}fadeIn(e){return this._scheduleFading(e,0,1)}fadeOut(e){return this._scheduleFading(e,1,0)}crossFadeFrom(e,t,i){if(e.fadeOut(t),this.fadeIn(t),i){const i=this._clip.duration,n=e._clip.duration,r=i/n;e.warp(1,n/i,t),this.warp(r,1,t)}return this}crossFadeTo(e,t,i){return e.crossFadeFrom(this,t,i)}stopFading(){const e=this._weightInterpolant;return null!==e&&(this._weightInterpolant=null,this._mixer._takeBackControlInterpolant(e)),this}setEffectiveTimeScale(e){return this.timeScale=e,this._effectiveTimeScale=this.paused?0:e,this.stopWarping()}getEffectiveTimeScale(){return this._effectiveTimeScale}setDuration(e){return this.timeScale=this._clip.duration/e,this.stopWarping()}syncWith(e){return this.time=e.time,this.timeScale=e.timeScale,this.stopWarping()}halt(e){return this.warp(this._effectiveTimeScale,0,e)}warp(e,t,i){const n=this._mixer,r=n.time,o=this.timeScale;let a=this._timeScaleInterpolant;null===a&&(a=n._lendControlInterpolant(),this._timeScaleInterpolant=a);const s=a.parameterPositions,l=a.sampleValues;return s[0]=r,s[1]=r+i,l[0]=e/o,l[1]=t/o,this}stopWarping(){const e=this._timeScaleInterpolant;return null!==e&&(this._timeScaleInterpolant=null,this._mixer._takeBackControlInterpolant(e)),this}getMixer(){return this._mixer}getClip(){return this._clip}getRoot(){return this._localRoot||this._mixer._root}_update(e,t,i,n){if(!this.enabled)return void this._updateWeight(e);const r=this._startTime;if(null!==r){const n=(e-r)*i;if(0>n||0===i)return;this._startTime=null,t=i*n}t*=this._updateTimeScale(e);const o=this._updateTime(t),a=this._updateWeight(e);if(a>0){const e=this._interpolants,t=this._propertyBindings;switch(this.blendMode){case Z:for(let i=0,n=e.length;i!==n;++i)e[i].evaluate(o),t[i].accumulateAdditive(a);break;case q:default:for(let i=0,r=e.length;i!==r;++i)e[i].evaluate(o),t[i].accumulate(n,a)}}}_updateWeight(e){let t=0;if(this.enabled){t=this.weight;const i=this._weightInterpolant;if(null!==i){const n=i.evaluate(e)[0];t*=n,e>i.parameterPositions[1]&&(this.stopFading(),0===n&&(this.enabled=!1))}}return this._effectiveWeight=t,t}_updateTimeScale(e){let t=0;if(!this.paused){t=this.timeScale;const i=this._timeScaleInterpolant;if(null!==i){t*=i.evaluate(e)[0],e>i.parameterPositions[1]&&(this.stopWarping(),0===t?this.paused=!0:this.timeScale=t)}}return this._effectiveTimeScale=t,t}_updateTime(e){const t=this._clip.duration,i=this.loop;let n=this.time+e,r=this._loopCount;const o=2202===i;if(0===e)return-1===r?n:o&&1==(1&r)?t-n:n;if(2200===i){-1===r&&(this._loopCount=0,this._setEndings(!0,!0,!1));e:{if(n<t){if(n>=0){this.time=n;break e}n=0}else n=t;this.clampWhenFinished?this.paused=!0:this.enabled=!1,this.time=n,this._mixer.dispatchEvent({type:"finished",action:this,direction:0>e?-1:1})}}else{if(-1===r&&(0>e?this._setEndings(0===this.repetitions,!0,o):(r=0,this._setEndings(!0,0===this.repetitions,o))),n>=t||0>n){const i=Math.floor(n/t);n-=t*i,r+=Math.abs(i);const a=this.repetitions-r;if(0<a){if(1===a){const t=0>e;this._setEndings(t,!t,o)}else this._setEndings(!1,!1,o);this._loopCount=r,this.time=n,this._mixer.dispatchEvent({type:"loop",action:this,loopDelta:i})}else this.clampWhenFinished?this.paused=!0:this.enabled=!1,n=e>0?t:0,this.time=n,this._mixer.dispatchEvent({type:"finished",action:this,direction:e>0?1:-1})}else this.time=n;if(o&&1==(1&r))return t-n}return n}_setEndings(e,t,i){const n=this._interpolantSettings;i?(n.endingStart=J,n.endingEnd=J):(n.endingStart=e?this.zeroSlopeAtStart?J:W:z,n.endingEnd=t?this.zeroSlopeAtEnd?J:W:z)}_scheduleFading(e,t,i){const n=this._mixer,r=n.time;let o=this._weightInterpolant;null===o&&(o=n._lendControlInterpolant(),this._weightInterpolant=o);const a=o.parameterPositions,s=o.sampleValues;return a[0]=r,s[0]=t,a[1]=r+e,s[1]=i,this}}class dh extends me{constructor(e){super(),this._root=e,this._initMemoryManager(),this._accuIndex=0,this.time=0,this.timeScale=1}_bindAction(e,t){const i=e._localRoot||this._root,n=e._clip.tracks,r=n.length,o=e._propertyBindings,a=e._interpolants,s=i.uuid,l=this._bindingsByRootAndName;let c=l[s];void 0===c&&(c={},l[s]=c);for(let e=0;e!==r;++e){const r=n[e],l=r.name;let h=c[l];if(void 0!==h)o[e]=h;else{if(h=o[e],void 0!==h){null===h._cacheIndex&&(++h.referenceCount,this._addInactiveBinding(h,s,l));continue}h=new Xc(lh.create(i,l,t&&t._propertyBindings[e].binding.parsedPath),r.ValueTypeName,r.getValueSize()),++h.referenceCount,this._addInactiveBinding(h,s,l),o[e]=h}a[e].resultBuffer=h.buffer}}_activateAction(e){if(!this._isActiveAction(e)){if(null===e._cacheIndex){const t=(e._localRoot||this._root).uuid,i=e._clip.uuid,n=this._actionsByClip[i];this._bindAction(e,n&&n.knownActions[0]),this._addInactiveAction(e,i,t)}const t=e._propertyBindings;for(let e=0,i=t.length;e!==i;++e){const i=t[e];0==i.useCount++&&(this._lendBinding(i),i.saveOriginalState())}this._lendAction(e)}}_deactivateAction(e){if(this._isActiveAction(e)){const t=e._propertyBindings;for(let e=0,i=t.length;e!==i;++e){const i=t[e];0==--i.useCount&&(i.restoreOriginalState(),this._takeBackBinding(i))}this._takeBackAction(e)}}_initMemoryManager(){this._actions=[],this._nActiveActions=0,this._actionsByClip={},this._bindings=[],this._nActiveBindings=0,this._bindingsByRootAndName={},this._controlInterpolants=[],this._nActiveControlInterpolants=0;const 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(e){const t=e._cacheIndex;return null!==t&&this._nActiveActions>t}_addInactiveAction(e,t,i){const n=this._actions,r=this._actionsByClip;let o=r[t];if(void 0===o)o={knownActions:[e],actionByRoot:{}},e._byClipCacheIndex=0,r[t]=o;else{const t=o.knownActions;e._byClipCacheIndex=t.length,t.push(e)}e._cacheIndex=n.length,n.push(e),o.actionByRoot[i]=e}_removeInactiveAction(e){const t=this._actions,i=t[t.length-1],n=e._cacheIndex;i._cacheIndex=n,t[n]=i,t.pop(),e._cacheIndex=null;const r=e._clip.uuid,o=this._actionsByClip,a=o[r],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[r],this._removeInactiveBindingsForAction(e)}_removeInactiveBindingsForAction(e){const t=e._propertyBindings;for(let e=0,i=t.length;e!==i;++e){const i=t[e];0==--i.referenceCount&&this._removeInactiveBinding(i)}}_lendAction(e){const t=this._actions,i=e._cacheIndex,n=this._nActiveActions++,r=t[n];e._cacheIndex=n,t[n]=e,r._cacheIndex=i,t[i]=r}_takeBackAction(e){const t=this._actions,i=e._cacheIndex,n=--this._nActiveActions,r=t[n];e._cacheIndex=n,t[n]=e,r._cacheIndex=i,t[i]=r}_addInactiveBinding(e,t,i){const n=this._bindingsByRootAndName,r=this._bindings;let o=n[t];void 0===o&&(o={},n[t]=o),o[i]=e,e._cacheIndex=r.length,r.push(e)}_removeInactiveBinding(e){const t=this._bindings,i=e.binding,n=i.rootNode.uuid,r=i.path,o=this._bindingsByRootAndName,a=o[n],s=t[t.length-1],l=e._cacheIndex;s._cacheIndex=l,t[l]=s,t.pop(),delete a[r],0===Object.keys(a).length&&delete o[n]}_lendBinding(e){const t=this._bindings,i=e._cacheIndex,n=this._nActiveBindings++,r=t[n];e._cacheIndex=n,t[n]=e,r._cacheIndex=i,t[i]=r}_takeBackBinding(e){const t=this._bindings,i=e._cacheIndex,n=--this._nActiveBindings,r=t[n];e._cacheIndex=n,t[n]=e,r._cacheIndex=i,t[i]=r}_lendControlInterpolant(){const e=this._controlInterpolants,t=this._nActiveControlInterpolants++;let i=e[t];return void 0===i&&(i=new cl(new Float32Array(2),new Float32Array(2),1,this._controlInterpolantsResultBuffer),i.__cacheIndex=t,e[t]=i),i}_takeBackControlInterpolant(e){const t=this._controlInterpolants,i=e.__cacheIndex,n=--this._nActiveControlInterpolants,r=t[n];e.__cacheIndex=n,t[n]=e,r.__cacheIndex=i,t[i]=r}clipAction(e,t,i){const n=t||this._root,r=n.uuid;let o="string"==typeof e?vl.findByName(n,e):e;const a=null!==o?o.uuid:e,s=this._actionsByClip[a];let l=null;if(void 0===i&&(i=null!==o?o.blendMode:q),void 0!==s){const e=s.actionByRoot[r];if(void 0!==e&&e.blendMode===i)return e;l=s.knownActions[0],null===o&&(o=l._clip)}if(null===o)return null;const c=new hh(this,o,t,i);return this._bindAction(c,l),this._addInactiveAction(c,a,r),c}existingAction(e,t){const i=t||this._root,n=i.uuid,r="string"==typeof e?vl.findByName(i,e):e,o=this._actionsByClip[r?r.uuid:e];return void 0!==o&&o.actionByRoot[n]||null}stopAllAction(){const e=this._actions;for(let t=this._nActiveActions-1;t>=0;--t)e[t].stop();return this}update(e){const t=this._actions,i=this._nActiveActions,n=this.time+=e*=this.timeScale,r=Math.sign(e),o=this._accuIndex^=1;for(let a=0;a!==i;++a){t[a]._update(n,e,r,o)}const a=this._bindings,s=this._nActiveBindings;for(let e=0;e!==s;++e)a[e].apply(o);return this}setTime(e){this.time=0;for(let e=0;this._actions.length>e;e++)this._actions[e].time=0;return this.update(e)}getRoot(){return this._root}uncacheClip(e){const t=this._actions,i=e.uuid,n=this._actionsByClip,r=n[i];if(void 0!==r){const e=r.knownActions;for(let i=0,n=e.length;i!==n;++i){const n=e[i];this._deactivateAction(n);const r=n._cacheIndex,o=t[t.length-1];n._cacheIndex=null,n._byClipCacheIndex=null,o._cacheIndex=r,t[r]=o,t.pop(),this._removeInactiveBindingsForAction(n)}delete n[i]}}uncacheRoot(e){const t=e.uuid,i=this._actionsByClip;for(const e in i){const n=i[e].actionByRoot[t];void 0!==n&&(this._deactivateAction(n),this._removeInactiveAction(n))}const n=this._bindingsByRootAndName[t];if(void 0!==n)for(const e in n){const t=n[e];t.restoreOriginalState(),this._removeInactiveBinding(t)}}uncacheAction(e,t){const i=this.existingAction(e,t);null!==i&&(this._deactivateAction(i),this._removeInactiveAction(i))}}dh.prototype._controlInterpolantsResultBuffer=new Float32Array(1);class uh{constructor(e){"string"==typeof e&&(console.warn("THREE.Uniform: Type parameter is no longer needed."),e=arguments[1]),this.value=e}clone(){return new uh(void 0===this.value.clone?this.value:this.value.clone())}}class ph extends Yo{constructor(e,t,i=1){super(e,t),this.meshPerAttribute=i||1}copy(e){return super.copy(e),this.meshPerAttribute=e.meshPerAttribute,this}clone(e){const t=super.clone(e);return t.meshPerAttribute=this.meshPerAttribute,t}toJSON(e){const t=super.toJSON(e);return t.isInstancedInterleavedBuffer=!0,t.meshPerAttribute=this.meshPerAttribute,t}}ph.prototype.isInstancedInterleavedBuffer=!0;class gh{constructor(e,t,i,n,r){this.buffer=e,this.type=t,this.itemSize=i,this.elementSize=n,this.count=r,this.version=0}set needsUpdate(e){!0===e&&this.version++}setBuffer(e){return this.buffer=e,this}setType(e,t){return this.type=e,this.elementSize=t,this}setItemSize(e){return this.itemSize=e,this}setCount(e){return this.count=e,this}}gh.prototype.isGLBufferAttribute=!0;function fh(e,t){return e.distance-t.distance}function mh(e,t,i,n){if(e.layers.test(t.layers)&&e.raycast(t,i),!0===n){const n=e.children;for(let e=0,r=n.length;r>e;e++)mh(n[e],t,i,!0)}}class Ah{constructor(e=1,t=0,i=0){return this.radius=e,this.phi=t,this.theta=i,this}set(e,t,i){return this.radius=e,this.phi=t,this.theta=i,this}copy(e){return this.radius=e.radius,this.phi=e.phi,this.theta=e.theta,this}makeSafe(){const e=1e-6;return this.phi=Math.max(e,Math.min(Math.PI-e,this.phi)),this}setFromVector3(e){return this.setFromCartesianCoords(e.x,e.y,e.z)}setFromCartesianCoords(e,t,i){return this.radius=Math.sqrt(e*e+t*t+i*i),0===this.radius?(this.theta=0,this.phi=0):(this.theta=Math.atan2(e,i),this.phi=Math.acos(xe(t/this.radius,-1,1))),this}clone(){return(new this.constructor).copy(this)}}const yh=new ke;class vh{constructor(e=new ke(1/0,1/0),t=new ke(-1/0,-1/0)){this.min=e,this.max=t}set(e,t){return this.min.copy(e),this.max.copy(t),this}setFromPoints(e){this.makeEmpty();for(let t=0,i=e.length;i>t;t++)this.expandByPoint(e[t]);return this}setFromCenterAndSize(e,t){const i=yh.copy(t).multiplyScalar(.5);return this.min.copy(e).sub(i),this.max.copy(e).add(i),this}clone(){return(new this.constructor).copy(this)}copy(e){return this.min.copy(e.min),this.max.copy(e.max),this}makeEmpty(){return this.min.x=this.min.y=1/0,this.max.x=this.max.y=-1/0,this}isEmpty(){return this.min.x>this.max.x||this.min.y>this.max.y}getCenter(e){return void 0===e&&(console.warn("THREE.Box2: .getCenter() target is now required"),e=new ke),this.isEmpty()?e.set(0,0):e.addVectors(this.min,this.max).multiplyScalar(.5)}getSize(e){return void 0===e&&(console.warn("THREE.Box2: .getSize() target is now required"),e=new ke),this.isEmpty()?e.set(0,0):e.subVectors(this.max,this.min)}expandByPoint(e){return this.min.min(e),this.max.max(e),this}expandByVector(e){return this.min.sub(e),this.max.add(e),this}expandByScalar(e){return this.min.addScalar(-e),this.max.addScalar(e),this}containsPoint(e){return!(this.min.x>e.x||e.x>this.max.x||this.min.y>e.y||e.y>this.max.y)}containsBox(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)}getParameter(e,t){return void 0===t&&(console.warn("THREE.Box2: .getParameter() target is now required"),t=new ke),t.set((e.x-this.min.x)/(this.max.x-this.min.x),(e.y-this.min.y)/(this.max.y-this.min.y))}intersectsBox(e){return!(this.min.x>e.max.x||e.min.x>this.max.x||this.min.y>e.max.y||e.min.y>this.max.y)}clampPoint(e,t){return void 0===t&&(console.warn("THREE.Box2: .clampPoint() target is now required"),t=new ke),t.copy(e).clamp(this.min,this.max)}distanceToPoint(e){return yh.copy(e).clamp(this.min,this.max).sub(e).length()}intersect(e){return this.min.max(e.min),this.max.min(e.max),this}union(e){return this.min.min(e.min),this.max.max(e.max),this}translate(e){return this.min.add(e),this.max.add(e),this}equals(e){return e.min.equals(this.min)&&e.max.equals(this.max)}}vh.prototype.isBox2=!0;const Ch=new Ke,Ih=new Ke;class xh{constructor(e=new Ke,t=new Ke){this.start=e,this.end=t}set(e,t){return this.start.copy(e),this.end.copy(t),this}copy(e){return this.start.copy(e.start),this.end.copy(e.end),this}getCenter(e){return void 0===e&&(console.warn("THREE.Line3: .getCenter() target is now required"),e=new Ke),e.addVectors(this.start,this.end).multiplyScalar(.5)}delta(e){return void 0===e&&(console.warn("THREE.Line3: .delta() target is now required"),e=new Ke),e.subVectors(this.end,this.start)}distanceSq(){return this.start.distanceToSquared(this.end)}distance(){return this.start.distanceTo(this.end)}at(e,t){return void 0===t&&(console.warn("THREE.Line3: .at() target is now required"),t=new Ke),this.delta(t).multiplyScalar(e).add(this.start)}closestPointToPointParameter(e,t){Ch.subVectors(e,this.start),Ih.subVectors(this.end,this.start);const i=Ih.dot(Ih);let n=Ih.dot(Ch)/i;return t&&(n=xe(n,0,1)),n}closestPointToPoint(e,t,i){const n=this.closestPointToPointParameter(e,t);return void 0===i&&(console.warn("THREE.Line3: .closestPointToPoint() target is now required"),i=new Ke),this.delta(i).multiplyScalar(n).add(this.start)}applyMatrix4(e){return this.start.applyMatrix4(e),this.end.applyMatrix4(e),this}equals(e){return e.start.equals(this.start)&&e.end.equals(this.end)}clone(){return(new this.constructor).copy(this)}}class wh extends Yt{constructor(e){super(),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}}wh.prototype.isImmediateRenderObject=!0;const Mh=new Ke;const Eh=new Ke,Bh=new yt,Sh=new yt;class bh extends La{constructor(e){const t=kh(e),i=new Ni,n=[],r=[],o=new pi(0,0,1),a=new pi(0,1,0);for(let e=0;t.length>e;e++){const i=t[e];i.parent&&i.parent.isBone&&(n.push(0,0,0),n.push(0,0,0),r.push(o.r,o.g,o.b),r.push(a.r,a.g,a.b))}i.setAttribute("position",new Bi(n,3)),i.setAttribute("color",new Bi(r,3));super(i,new Sa({vertexColors:!0,depthTest:!1,depthWrite:!1,toneMapped:!1,transparent:!0})),this.type="SkeletonHelper",this.isSkeletonHelper=!0,this.root=e,this.bones=t,this.matrix=e.matrixWorld,this.matrixAutoUpdate=!1}updateMatrixWorld(e){const t=this.bones,i=this.geometry,n=i.getAttribute("position");Sh.copy(this.root.matrixWorld).invert();for(let e=0,i=0;t.length>e;e++){const r=t[e];r.parent&&r.parent.isBone&&(Bh.multiplyMatrices(Sh,r.matrixWorld),Eh.setFromMatrixPosition(Bh),n.setXYZ(i,Eh.x,Eh.y,Eh.z),Bh.multiplyMatrices(Sh,r.parent.matrixWorld),Eh.setFromMatrixPosition(Bh),n.setXYZ(i+1,Eh.x,Eh.y,Eh.z),i+=2)}i.getAttribute("position").needsUpdate=!0,super.updateMatrixWorld(e)}}function kh(e){const t=[];e&&e.isBone&&t.push(e);for(let i=0;e.children.length>i;i++)t.push.apply(t,kh(e.children[i]));return t}const Dh=new Ke,Th=new pi,Rh=new pi;class Uh extends La{constructor(e=10,t=10,i=4473924,n=8947848){i=new pi(i),n=new pi(n);const r=t/2,o=e/t,a=e/2,s=[],l=[];for(let e=0,c=0,h=-a;t>=e;e++,h+=o){s.push(-a,0,h,a,0,h),s.push(h,0,-a,h,0,a);const t=e===r?i:n;t.toArray(l,c),c+=3,t.toArray(l,c),c+=3,t.toArray(l,c),c+=3,t.toArray(l,c),c+=3}const c=new Ni;c.setAttribute("position",new Bi(s,3)),c.setAttribute("color",new Bi(l,3));super(c,new Sa({vertexColors:!0,toneMapped:!1})),this.type="GridHelper"}}const Fh=new Ke,Qh=new Ke,Lh=new Ke;class Oh extends Yt{constructor(e,t,i){super(),this.light=e,this.light.updateMatrixWorld(),this.matrix=e.matrixWorld,this.matrixAutoUpdate=!1,this.color=i,void 0===t&&(t=1);let n=new Ni;n.setAttribute("position",new Bi([-t,t,0,t,t,0,t,-t,0,-t,-t,0,-t,t,0],3));const r=new Sa({fog:!1,toneMapped:!1});this.lightPlane=new Ua(n,r),this.add(this.lightPlane),n=new Ni,n.setAttribute("position",new Bi([0,0,0,0,0,1],3)),this.targetLine=new Ua(n,r),this.add(this.targetLine),this.update()}dispose(){this.lightPlane.geometry.dispose(),this.lightPlane.material.dispose(),this.targetLine.geometry.dispose(),this.targetLine.material.dispose()}update(){Fh.setFromMatrixPosition(this.light.matrixWorld),Qh.setFromMatrixPosition(this.light.target.matrixWorld),Lh.subVectors(Qh,Fh),this.lightPlane.lookAt(Qh),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(Qh),this.targetLine.scale.z=Lh.length()}}const Nh=new Ke,Ph=new hn;function Gh(e,t,i,n,r,o,a){Nh.set(r,o,a).unproject(n);const s=t[e];if(void 0!==s){const e=i.getAttribute("position");for(let t=0,i=s.length;i>t;t++)e.setXYZ(s[t],Nh.x,Nh.y,Nh.z)}}const Kh=new He;class Vh extends La{constructor(e,t=16776960){const 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]),n=new Float32Array(24),r=new Ni;r.setIndex(new Ai(i,1)),r.setAttribute("position",new Ai(n,3)),super(r,new Sa({color:t,toneMapped:!1})),this.object=e,this.type="BoxHelper",this.matrixAutoUpdate=!1,this.update()}update(e){if(void 0!==e&&console.warn("THREE.BoxHelper: .update() has no longer arguments."),void 0!==this.object&&Kh.setFromObject(this.object),Kh.isEmpty())return;const t=Kh.min,i=Kh.max,n=this.geometry.attributes.position,r=n.array;r[0]=i.x,r[1]=i.y,r[2]=i.z,r[3]=t.x,r[4]=i.y,r[5]=i.z,r[6]=t.x,r[7]=t.y,r[8]=i.z,r[9]=i.x,r[10]=t.y,r[11]=i.z,r[12]=i.x,r[13]=i.y,r[14]=t.z,r[15]=t.x,r[16]=i.y,r[17]=t.z,r[18]=t.x,r[19]=t.y,r[20]=t.z,r[21]=i.x,r[22]=t.y,r[23]=t.z,n.needsUpdate=!0,this.geometry.computeBoundingSphere()}setFromObject(e){return this.object=e,this.update(),this}copy(e){return La.prototype.copy.call(this,e),this.object=e.object,this}}const Yh=new Ke;let Hh,jh;class Wh extends La{constructor(e=1){const t=[0,0,0,e,0,0,0,0,0,0,e,0,0,0,0,0,0,e],i=new Ni;i.setAttribute("position",new Bi(t,3)),i.setAttribute("color",new Bi([1,0,0,1,.6,0,0,1,0,.6,1,0,0,0,1,0,.6,1],3));super(i,new Sa({vertexColors:!0,toneMapped:!1})),this.type="AxesHelper"}dispose(){this.geometry.dispose(),this.material.dispose()}}const Jh=new Float32Array(1),zh=new Int32Array(Jh.buffer);const qh=Math.pow(2,8),Zh=[.125,.215,.35,.446,.526,.582],Xh=5+Zh.length,_h=20,$h={[X]:0,[_]:1,[ee]:2,[te]:3,[ie]:4,[ne]:5,[$]:6},ed=new gi({side:1,depthWrite:!1,depthTest:!1}),td=new nn(new on,ed),id=new pc,{_lodPlanes:nd,_sizeLods:rd,_sigmas:od}=pd(),ad=new pi;let sd=null;const ld=(1+Math.sqrt(5))/2,cd=1/ld,hd=[new Ke(1,1,1),new Ke(-1,1,1),new Ke(1,1,-1),new Ke(-1,1,-1),new Ke(0,ld,cd),new Ke(0,ld,-cd),new Ke(cd,0,ld),new Ke(-cd,0,ld),new Ke(ld,cd,0),new Ke(-ld,cd,0)];function dd(e){const t=Math.max(e.r,e.g,e.b),i=Math.min(Math.max(Math.ceil(Math.log2(t)),-128),127);e.multiplyScalar(Math.pow(2,-i));return(i+128)/255}function ud(e){return void 0!==e&&e.type===w&&(e.encoding===X||e.encoding===_||e.encoding===$)}function pd(){const e=[],t=[],i=[];let n=8;for(let r=0;Xh>r;r++){const o=Math.pow(2,n);t.push(o);let a=1/o;r>4?a=Zh[r-8+4-1]:0==r&&(a=0),i.push(a);const s=1/(o-1),l=-s/2,c=1+s/2,h=[l,l,c,l,c,c,l,l,c,c,l,c],d=6,u=6,p=3,g=2,f=1,m=new Float32Array(p*u*d),A=new Float32Array(g*u*d),y=new Float32Array(f*u*d);for(let e=0;d>e;e++){const t=e%3*2/3-1,i=e>2?0:-1;m.set([t,i,0,t+2/3,i,0,t+2/3,i+1,0,t,i,0,t+2/3,i+1,0,t,i+1,0],p*u*e),A.set(h,g*u*e);y.set([e,e,e,e,e,e],f*u*e)}const v=new Ni;v.setAttribute("position",new Ai(m,p)),v.setAttribute("uv",new Ai(A,g)),v.setAttribute("faceIndex",new Ai(y,f)),e.push(v),n>4&&n--}return{_lodPlanes:e,_sizeLods:t,_sigmas:i}}function gd(e){const t=new Oe(3*qh,3*qh,e);return t.texture.mapping=u,t.texture.name="PMREM.cubeUv",t.scissorTest=!0,t}function fd(e,t,i,n,r){e.viewport.set(t,i,n,r),e.scissor.set(t,i,n,r)}function md(){const e=new ke(1,1);return new Zs({name:"EquirectangularToCubeUV",uniforms:{envMap:{value:null},texelSize:{value:e},inputEncoding:{value:$h[3e3]},outputEncoding:{value:$h[3e3]}},vertexShader:yd(),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${vd()}\n\n\t\t\t#include <common>\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:0,depthTest:!1,depthWrite:!1})}function Ad(){return new Zs({name:"CubemapToCubeUV",uniforms:{envMap:{value:null},inputEncoding:{value:$h[3e3]},outputEncoding:{value:$h[3e3]}},vertexShader:yd(),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${vd()}\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:0,depthTest:!1,depthWrite:!1})}function yd(){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 vd(){return"\n\n\t\tuniform int inputEncoding;\n\t\tuniform int outputEncoding;\n\n\t\t#include <encodings_pars_fragment>\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"}Tl.create=function(e,t){return console.log("THREE.Curve.create() has been deprecated"),e.prototype=Object.create(Tl.prototype),e.prototype.constructor=e,e.prototype.getPoint=t,e},_l.prototype.fromPoints=function(e){return console.warn("THREE.Path: .fromPoints() has been renamed to .setFromPoints()."),this.setFromPoints(e)},Uh.prototype.setColors=function(){console.error("THREE.GridHelper: setColors() has been deprecated, pass them in the constructor instead.")},bh.prototype.update=function(){console.error("THREE.SkeletonHelper: update() no longer needs to be called.")},Ml.prototype.extractUrlBase=function(e){return console.warn("THREE.Loader: .extractUrlBase() has been deprecated. Use THREE.LoaderUtils.extractUrlBase() instead."),Ic.extractUrlBase(e)},Ml.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.")}},vh.prototype.center=function(e){return console.warn("THREE.Box2: .center() has been renamed to .getCenter()."),this.getCenter(e)},vh.prototype.empty=function(){return console.warn("THREE.Box2: .empty() has been renamed to .isEmpty()."),this.isEmpty()},vh.prototype.isIntersectionBox=function(e){return console.warn("THREE.Box2: .isIntersectionBox() has been renamed to .intersectsBox()."),this.intersectsBox(e)},vh.prototype.size=function(e){return console.warn("THREE.Box2: .size() has been renamed to .getSize()."),this.getSize(e)},He.prototype.center=function(e){return console.warn("THREE.Box3: .center() has been renamed to .getCenter()."),this.getCenter(e)},He.prototype.empty=function(){return console.warn("THREE.Box3: .empty() has been renamed to .isEmpty()."),this.isEmpty()},He.prototype.isIntersectionBox=function(e){return console.warn("THREE.Box3: .isIntersectionBox() has been renamed to .intersectsBox()."),this.intersectsBox(e)},He.prototype.isIntersectionSphere=function(e){return console.warn("THREE.Box3: .isIntersectionSphere() has been renamed to .intersectsSphere()."),this.intersectsSphere(e)},He.prototype.size=function(e){return console.warn("THREE.Box3: .size() has been renamed to .getSize()."),this.getSize(e)},ct.prototype.empty=function(){return console.warn("THREE.Sphere: .empty() has been renamed to .isEmpty()."),this.isEmpty()},yn.prototype.setFromMatrix=function(e){return console.warn("THREE.Frustum: .setFromMatrix() has been renamed to .setFromProjectionMatrix()."),this.setFromProjectionMatrix(e)},xh.prototype.center=function(e){return console.warn("THREE.Line3: .center() has been renamed to .getCenter()."),this.getCenter(e)},De.prototype.flattenToArrayOffset=function(e,t){return console.warn("THREE.Matrix3: .flattenToArrayOffset() has been deprecated. Use .toArray() instead."),this.toArray(e,t)},De.prototype.multiplyVector3=function(e){return console.warn("THREE.Matrix3: .multiplyVector3() has been removed. Use vector.applyMatrix3( matrix ) instead."),e.applyMatrix3(this)},De.prototype.multiplyVector3Array=function(){console.error("THREE.Matrix3: .multiplyVector3Array() has been removed.")},De.prototype.applyToBufferAttribute=function(e){return console.warn("THREE.Matrix3: .applyToBufferAttribute() has been removed. Use attribute.applyMatrix3( matrix ) instead."),e.applyMatrix3(this)},De.prototype.applyToVector3Array=function(){console.error("THREE.Matrix3: .applyToVector3Array() has been removed.")},De.prototype.getInverse=function(e){return console.warn("THREE.Matrix3: .getInverse() has been removed. Use matrixInv.copy( matrix ).invert(); instead."),this.copy(e).invert()},yt.prototype.extractPosition=function(e){return console.warn("THREE.Matrix4: .extractPosition() has been renamed to .copyPosition()."),this.copyPosition(e)},yt.prototype.flattenToArrayOffset=function(e,t){return console.warn("THREE.Matrix4: .flattenToArrayOffset() has been deprecated. Use .toArray() instead."),this.toArray(e,t)},yt.prototype.getPosition=function(){return console.warn("THREE.Matrix4: .getPosition() has been removed. Use Vector3.setFromMatrixPosition( matrix ) instead."),(new Ke).setFromMatrixColumn(this,3)},yt.prototype.setRotationFromQuaternion=function(e){return console.warn("THREE.Matrix4: .setRotationFromQuaternion() has been renamed to .makeRotationFromQuaternion()."),this.makeRotationFromQuaternion(e)},yt.prototype.multiplyToArray=function(){console.warn("THREE.Matrix4: .multiplyToArray() has been removed.")},yt.prototype.multiplyVector3=function(e){return console.warn("THREE.Matrix4: .multiplyVector3() has been removed. Use vector.applyMatrix4( matrix ) instead."),e.applyMatrix4(this)},yt.prototype.multiplyVector4=function(e){return console.warn("THREE.Matrix4: .multiplyVector4() has been removed. Use vector.applyMatrix4( matrix ) instead."),e.applyMatrix4(this)},yt.prototype.multiplyVector3Array=function(){console.error("THREE.Matrix4: .multiplyVector3Array() has been removed.")},yt.prototype.rotateAxis=function(e){console.warn("THREE.Matrix4: .rotateAxis() has been removed. Use Vector3.transformDirection( matrix ) instead."),e.transformDirection(this)},yt.prototype.crossVector=function(e){return console.warn("THREE.Matrix4: .crossVector() has been removed. Use vector.applyMatrix4( matrix ) instead."),e.applyMatrix4(this)},yt.prototype.translate=function(){console.error("THREE.Matrix4: .translate() has been removed.")},yt.prototype.rotateX=function(){console.error("THREE.Matrix4: .rotateX() has been removed.")},yt.prototype.rotateY=function(){console.error("THREE.Matrix4: .rotateY() has been removed.")},yt.prototype.rotateZ=function(){console.error("THREE.Matrix4: .rotateZ() has been removed.")},yt.prototype.rotateByAxis=function(){console.error("THREE.Matrix4: .rotateByAxis() has been removed.")},yt.prototype.applyToBufferAttribute=function(e){return console.warn("THREE.Matrix4: .applyToBufferAttribute() has been removed. Use attribute.applyMatrix4( matrix ) instead."),e.applyMatrix4(this)},yt.prototype.applyToVector3Array=function(){console.error("THREE.Matrix4: .applyToVector3Array() has been removed.")},yt.prototype.makeFrustum=function(e,t,i,n,r,o){return console.warn("THREE.Matrix4: .makeFrustum() has been removed. Use .makePerspective( left, right, top, bottom, near, far ) instead."),this.makePerspective(e,t,n,i,r,o)},yt.prototype.getInverse=function(e){return console.warn("THREE.Matrix4: .getInverse() has been removed. Use matrixInv.copy( matrix ).invert(); instead."),this.copy(e).invert()},Jt.prototype.isIntersectionLine=function(e){return console.warn("THREE.Plane: .isIntersectionLine() has been renamed to .intersectsLine()."),this.intersectsLine(e)},Ge.prototype.multiplyVector3=function(e){return console.warn("THREE.Quaternion: .multiplyVector3() has been removed. Use is now vector.applyQuaternion( quaternion ) instead."),e.applyQuaternion(this)},Ge.prototype.inverse=function(){return console.warn("THREE.Quaternion: .inverse() has been renamed to invert()."),this.invert()},At.prototype.isIntersectionBox=function(e){return console.warn("THREE.Ray: .isIntersectionBox() has been renamed to .intersectsBox()."),this.intersectsBox(e)},At.prototype.isIntersectionPlane=function(e){return console.warn("THREE.Ray: .isIntersectionPlane() has been renamed to .intersectsPlane()."),this.intersectsPlane(e)},At.prototype.isIntersectionSphere=function(e){return console.warn("THREE.Ray: .isIntersectionSphere() has been renamed to .intersectsSphere()."),this.intersectsSphere(e)},ri.prototype.area=function(){return console.warn("THREE.Triangle: .area() has been renamed to .getArea()."),this.getArea()},ri.prototype.barycoordFromPoint=function(e,t){return console.warn("THREE.Triangle: .barycoordFromPoint() has been renamed to .getBarycoord()."),this.getBarycoord(e,t)},ri.prototype.midpoint=function(e){return console.warn("THREE.Triangle: .midpoint() has been renamed to .getMidpoint()."),this.getMidpoint(e)},ri.prototypenormal=function(e){return console.warn("THREE.Triangle: .normal() has been renamed to .getNormal()."),this.getNormal(e)},ri.prototype.plane=function(e){return console.warn("THREE.Triangle: .plane() has been renamed to .getPlane()."),this.getPlane(e)},ri.barycoordFromPoint=function(e,t,i,n,r){return console.warn("THREE.Triangle: .barycoordFromPoint() has been renamed to .getBarycoord()."),ri.getBarycoord(e,t,i,n,r)},ri.normal=function(e,t,i,n){return console.warn("THREE.Triangle: .normal() has been renamed to .getNormal()."),ri.getNormal(e,t,i,n)},$l.prototype.extractAllPoints=function(e){return console.warn("THREE.Shape: .extractAllPoints() has been removed. Use .extractPoints() instead."),this.extractPoints(e)},$l.prototype.extrude=function(e){return console.warn("THREE.Shape: .extrude() has been removed. Use ExtrudeGeometry() instead."),new Us(this,e)},$l.prototype.makeGeometry=function(e){return console.warn("THREE.Shape: .makeGeometry() has been removed. Use ShapeGeometry() instead."),new Gs(this,e)},ke.prototype.fromAttribute=function(e,t,i){return console.warn("THREE.Vector2: .fromAttribute() has been renamed to .fromBufferAttribute()."),this.fromBufferAttribute(e,t,i)},ke.prototype.distanceToManhattan=function(e){return console.warn("THREE.Vector2: .distanceToManhattan() has been renamed to .manhattanDistanceTo()."),this.manhattanDistanceTo(e)},ke.prototype.lengthManhattan=function(){return console.warn("THREE.Vector2: .lengthManhattan() has been renamed to .manhattanLength()."),this.manhattanLength()},Ke.prototype.setEulerFromRotationMatrix=function(){console.error("THREE.Vector3: .setEulerFromRotationMatrix() has been removed. Use Euler.setFromRotationMatrix() instead.")},Ke.prototype.setEulerFromQuaternion=function(){console.error("THREE.Vector3: .setEulerFromQuaternion() has been removed. Use Euler.setFromQuaternion() instead.")},Ke.prototype.getPositionFromMatrix=function(e){return console.warn("THREE.Vector3: .getPositionFromMatrix() has been renamed to .setFromMatrixPosition()."),this.setFromMatrixPosition(e)},Ke.prototype.getScaleFromMatrix=function(e){return console.warn("THREE.Vector3: .getScaleFromMatrix() has been renamed to .setFromMatrixScale()."),this.setFromMatrixScale(e)},Ke.prototype.getColumnFromMatrix=function(e,t){return console.warn("THREE.Vector3: .getColumnFromMatrix() has been renamed to .setFromMatrixColumn()."),this.setFromMatrixColumn(t,e)},Ke.prototype.applyProjection=function(e){return console.warn("THREE.Vector3: .applyProjection() has been removed. Use .applyMatrix4( m ) instead."),this.applyMatrix4(e)},Ke.prototype.fromAttribute=function(e,t,i){return console.warn("THREE.Vector3: .fromAttribute() has been renamed to .fromBufferAttribute()."),this.fromBufferAttribute(e,t,i)},Ke.prototype.distanceToManhattan=function(e){return console.warn("THREE.Vector3: .distanceToManhattan() has been renamed to .manhattanDistanceTo()."),this.manhattanDistanceTo(e)},Ke.prototype.lengthManhattan=function(){return console.warn("THREE.Vector3: .lengthManhattan() has been renamed to .manhattanLength()."),this.manhattanLength()},Le.prototype.fromAttribute=function(e,t,i){return console.warn("THREE.Vector4: .fromAttribute() has been renamed to .fromBufferAttribute()."),this.fromBufferAttribute(e,t,i)},Le.prototype.lengthManhattan=function(){return console.warn("THREE.Vector4: .lengthManhattan() has been renamed to .manhattanLength()."),this.manhattanLength()},Yt.prototype.getChildByName=function(e){return console.warn("THREE.Object3D: .getChildByName() has been renamed to .getObjectByName()."),this.getObjectByName(e)},Yt.prototype.renderDepth=function(){console.warn("THREE.Object3D: .renderDepth has been removed. Use .renderOrder, instead.")},Yt.prototype.translate=function(e,t){return console.warn("THREE.Object3D: .translate() has been removed. Use .translateOnAxis( axis, distance ) instead."),this.translateOnAxis(t,e)},Yt.prototype.getWorldRotation=function(){console.error("THREE.Object3D: .getWorldRotation() has been removed. Use THREE.Object3D.getWorldQuaternion( target ) instead.")},Yt.prototype.applyMatrix=function(e){return console.warn("THREE.Object3D: .applyMatrix() has been renamed to .applyMatrix4()."),this.applyMatrix4(e)},Object.defineProperties(Yt.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.")}}}),nn.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(nn.prototype,{drawMode:{get:function(){return console.error("THREE.Mesh: .drawMode has been removed. The renderer now always assumes THREE.TrianglesDrawMode."),0},set:function(){console.error("THREE.Mesh: .drawMode has been removed. The renderer now always assumes THREE.TrianglesDrawMode. Transform your geometry via BufferGeometryUtils.toTrianglesDrawMode() if necessary.")}}}),ma.prototype.initBones=function(){console.error("THREE.SkinnedMesh: initBones() has been removed.")},dn.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(ec.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(Ai.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===ge},set:function(){console.warn("THREE.BufferAttribute: .dynamic has been deprecated. Use .usage instead."),this.setUsage(ge)}}}),Ai.prototype.setDynamic=function(e){return console.warn("THREE.BufferAttribute: .setDynamic() has been deprecated. Use .setUsage() instead."),this.setUsage(!0===e?ge:pe),this},Ai.prototype.copyIndicesArray=function(){console.error("THREE.BufferAttribute: .copyIndicesArray() has been removed.")},Ai.prototype.setArray=function(){console.error("THREE.BufferAttribute: .setArray has been removed. Use BufferGeometry .setAttribute to replace/resize attribute buffers")},Ni.prototype.addIndex=function(e){console.warn("THREE.BufferGeometry: .addIndex() has been renamed to .setIndex()."),this.setIndex(e)},Ni.prototype.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 Ai(arguments[1],arguments[2])))},Ni.prototype.addDrawCall=function(e,t,i){void 0!==i&&console.warn("THREE.BufferGeometry: .addDrawCall() no longer supports indexOffset."),console.warn("THREE.BufferGeometry: .addDrawCall() is now .addGroup()."),this.addGroup(e,t)},Ni.prototype.clearDrawCalls=function(){console.warn("THREE.BufferGeometry: .clearDrawCalls() is now .clearGroups()."),this.clearGroups()},Ni.prototype.computeOffsets=function(){console.warn("THREE.BufferGeometry: .computeOffsets() has been removed.")},Ni.prototype.removeAttribute=function(e){return console.warn("THREE.BufferGeometry: .removeAttribute() has been renamed to .deleteAttribute()."),this.deleteAttribute(e)},Ni.prototype.applyMatrix=function(e){return console.warn("THREE.BufferGeometry: .applyMatrix() has been renamed to .applyMatrix4()."),this.applyMatrix4(e)},Object.defineProperties(Ni.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}}}),Yo.prototype.setDynamic=function(e){return console.warn("THREE.InterleavedBuffer: .setDynamic() has been deprecated. Use .setUsage() instead."),this.setUsage(!0===e?ge:pe),this},Yo.prototype.setArray=function(){console.error("THREE.InterleavedBuffer: .setArray has been removed. Use BufferGeometry .setAttribute to replace/resize attribute buffers")},Us.prototype.getArrays=function(){console.error("THREE.ExtrudeGeometry: .getArrays() has been removed.")},Us.prototype.addShapeList=function(){console.error("THREE.ExtrudeGeometry: .addShapeList() has been removed.")},Us.prototype.addShape=function(){console.error("THREE.ExtrudeGeometry: .addShape() has been removed.")},Vo.prototype.dispose=function(){console.error("THREE.Scene: .dispose() has been removed.")},uh.prototype.onUpdate=function(){return console.warn("THREE.Uniform: .onUpdate() has been removed. Use object.onBeforeRender() instead."),this},Object.defineProperties(ai.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 pi}},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=1===e}},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(cn.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}}}),Oo.prototype.clearTarget=function(e,t,i,n){console.warn("THREE.WebGLRenderer: .clearTarget() has been deprecated. Use .setRenderTarget() and .clear() instead."),this.setRenderTarget(e),this.clear(t,i,n)},Oo.prototype.animate=function(e){console.warn("THREE.WebGLRenderer: .animate() is now .setAnimationLoop()."),this.setAnimationLoop(e)},Oo.prototype.getCurrentRenderTarget=function(){return console.warn("THREE.WebGLRenderer: .getCurrentRenderTarget() is now .getRenderTarget()."),this.getRenderTarget()},Oo.prototype.getMaxAnisotropy=function(){return console.warn("THREE.WebGLRenderer: .getMaxAnisotropy() is now .capabilities.getMaxAnisotropy()."),this.capabilities.getMaxAnisotropy()},Oo.prototype.getPrecision=function(){return console.warn("THREE.WebGLRenderer: .getPrecision() is now .capabilities.precision."),this.capabilities.precision},Oo.prototype.resetGLState=function(){return console.warn("THREE.WebGLRenderer: .resetGLState() is now .state.reset()."),this.state.reset()},Oo.prototype.supportsFloatTextures=function(){return console.warn("THREE.WebGLRenderer: .supportsFloatTextures() is now .extensions.get( 'OES_texture_float' )."),this.extensions.get("OES_texture_float")},Oo.prototype.supportsHalfFloatTextures=function(){return console.warn("THREE.WebGLRenderer: .supportsHalfFloatTextures() is now .extensions.get( 'OES_texture_half_float' )."),this.extensions.get("OES_texture_half_float")},Oo.prototype.supportsStandardDerivatives=function(){return console.warn("THREE.WebGLRenderer: .supportsStandardDerivatives() is now .extensions.get( 'OES_standard_derivatives' )."),this.extensions.get("OES_standard_derivatives")},Oo.prototype.supportsCompressedTextureS3TC=function(){return console.warn("THREE.WebGLRenderer: .supportsCompressedTextureS3TC() is now .extensions.get( 'WEBGL_compressed_texture_s3tc' )."),this.extensions.get("WEBGL_compressed_texture_s3tc")},Oo.prototype.supportsCompressedTexturePVRTC=function(){return console.warn("THREE.WebGLRenderer: .supportsCompressedTexturePVRTC() is now .extensions.get( 'WEBGL_compressed_texture_pvrtc' )."),this.extensions.get("WEBGL_compressed_texture_pvrtc")},Oo.prototype.supportsBlendMinMax=function(){return console.warn("THREE.WebGLRenderer: .supportsBlendMinMax() is now .extensions.get( 'EXT_blend_minmax' )."),this.extensions.get("EXT_blend_minmax")},Oo.prototype.supportsVertexTextures=function(){return console.warn("THREE.WebGLRenderer: .supportsVertexTextures() is now .capabilities.vertexTextures."),this.capabilities.vertexTextures},Oo.prototype.supportsInstancedArrays=function(){return console.warn("THREE.WebGLRenderer: .supportsInstancedArrays() is now .extensions.get( 'ANGLE_instanced_arrays' )."),this.extensions.get("ANGLE_instanced_arrays")},Oo.prototype.enableScissorTest=function(e){console.warn("THREE.WebGLRenderer: .enableScissorTest() is now .setScissorTest()."),this.setScissorTest(e)},Oo.prototype.initMaterial=function(){console.warn("THREE.WebGLRenderer: .initMaterial() has been removed.")},Oo.prototype.addPrePlugin=function(){console.warn("THREE.WebGLRenderer: .addPrePlugin() has been removed.")},Oo.prototype.addPostPlugin=function(){console.warn("THREE.WebGLRenderer: .addPostPlugin() has been removed.")},Oo.prototype.updateShadowMap=function(){console.warn("THREE.WebGLRenderer: .updateShadowMap() has been removed.")},Oo.prototype.setFaceCulling=function(){console.warn("THREE.WebGLRenderer: .setFaceCulling() has been removed.")},Oo.prototype.allocTextureUnit=function(){console.warn("THREE.WebGLRenderer: .allocTextureUnit() has been removed.")},Oo.prototype.setTexture=function(){console.warn("THREE.WebGLRenderer: .setTexture() has been removed.")},Oo.prototype.setTexture2D=function(){console.warn("THREE.WebGLRenderer: .setTexture2D() has been removed.")},Oo.prototype.setTextureCube=function(){console.warn("THREE.WebGLRenderer: .setTextureCube() has been removed.")},Oo.prototype.getActiveMipMapLevel=function(){return console.warn("THREE.WebGLRenderer: .getActiveMipMapLevel() is now .getActiveMipmapLevel()."),this.getActiveMipmapLevel()},Object.defineProperties(Oo.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?_:X}},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(Bo.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(Oe.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}}}),jc.prototype.load=function(e){console.warn("THREE.Audio: .load has been deprecated. Use THREE.AudioLoader instead.");const t=this;return(new Fc).load(e,(function(e){t.setBuffer(e)})),this},Zc.prototype.getData=function(){return console.warn("THREE.AudioAnalyser: .getData() is now .getFrequencyData()."),this.getFrequencyData()},pn.prototype.updateCubeMap=function(e,t){return console.warn("THREE.CubeCamera: .updateCubeMap() is now .update()."),this.update(e,t)},pn.prototype.clear=function(e,t,i,n){return console.warn("THREE.CubeCamera: .clear() is now .renderTarget.clear()."),this.renderTarget.clear(e,t,i,n)},Re.crossOrigin=void 0,Re.loadTexture=function(e,t,i,n){console.warn("THREE.ImageUtils.loadTexture has been deprecated. Use THREE.TextureLoader() instead.");const r=new Dl;r.setCrossOrigin(this.crossOrigin);const o=r.load(e,i,void 0,n);return t&&(o.mapping=t),o},Re.loadTextureCube=function(e,t,i,n){console.warn("THREE.ImageUtils.loadTextureCube has been deprecated. Use THREE.CubeTextureLoader() instead.");const r=new bl;r.setCrossOrigin(this.crossOrigin);const o=r.load(e,i,void 0,n);return t&&(o.mapping=t),o},Re.loadCompressedTexture=function(){console.error("THREE.ImageUtils.loadCompressedTexture has been removed. Use THREE.DDSLoader instead.")},Re.loadCompressedTextureCube=function(){console.error("THREE.ImageUtils.loadCompressedTextureCube has been removed. Use THREE.DDSLoader instead.")};const Cd={createMultiMaterialObject:function(){console.error("THREE.SceneUtils has been moved to /examples/jsm/utils/SceneUtils.js")},detach:function(){console.error("THREE.SceneUtils has been moved to /examples/jsm/utils/SceneUtils.js")},attach:function(){console.error("THREE.SceneUtils has been moved to /examples/jsm/utils/SceneUtils.js")}};"undefined"!=typeof __THREE_DEVTOOLS__&&__THREE_DEVTOOLS__.dispatchEvent(new CustomEvent("register",{detail:{revision:i}})),"undefined"!=typeof window&&(window.__THREE__?console.warn("WARNING: Multiple instances of Three.js being imported."):window.__THREE__=i);var Id=Object.freeze({__proto__:null,ACESFilmicToneMapping:4,AddEquation:r,AddOperation:2,AdditiveAnimationBlendMode:Z,AdditiveBlending:2,AlphaFormat:1021,AlwaysDepth:1,AlwaysStencilFunc:ue,AmbientLight:mc,AmbientLightProbe:Lc,AnimationClip:vl,AnimationLoader:class extends Ml{constructor(e){super(e)}load(e,t,i,n){const r=this,o=new Bl(this.manager);o.setPath(this.path),o.setRequestHeader(this.requestHeader),o.setWithCredentials(this.withCredentials),o.load(e,(function(i){try{t(r.parse(JSON.parse(i)))}catch(t){n?n(t):console.error(t),r.manager.itemError(e)}}),i,n)}parse(e){const t=[];for(let i=0;e.length>i;i++){const n=vl.parse(e[i]);t.push(n)}return t}},AnimationMixer:dh,AnimationObjectGroup:ch,AnimationUtils:al,ArcCurve:Ul,ArrayCamera:Do,ArrowHelper:class extends Yt{constructor(e=new Ke(0,0,1),t=new Ke(0,0,0),i=1,n=16776960,r=.2*i,o=.2*r){super(),this.type="ArrowHelper",void 0===Hh&&(Hh=new Ni,Hh.setAttribute("position",new Bi([0,0,0,0,1,0],3)),jh=new Za(0,.5,1,5,1),jh.translate(0,-.5,0)),this.position.copy(t),this.line=new Ua(Hh,new Sa({color:n,toneMapped:!1})),this.line.matrixAutoUpdate=!1,this.add(this.line),this.cone=new nn(jh,new gi({color:n,toneMapped:!1})),this.cone.matrixAutoUpdate=!1,this.add(this.cone),this.setDirection(e),this.setLength(i,r,o)}setDirection(e){if(e.y>.99999)this.quaternion.set(0,0,0,1);else if(-.99999>e.y)this.quaternion.set(1,0,0,0);else{Yh.set(e.z,0,-e.x).normalize();const t=Math.acos(e.y);this.quaternion.setFromAxisAngle(Yh,t)}}setLength(e,t=.2*e,i=.2*t){this.line.scale.set(1,Math.max(1e-4,e-t),1),this.line.updateMatrix(),this.cone.scale.set(i,t,i),this.cone.position.y=e,this.cone.updateMatrix()}setColor(e){this.line.material.color.set(e),this.cone.material.color.set(e)}copy(e){return super.copy(e,!1),this.line.copy(e.line),this.cone.copy(e.cone),this}},Audio:jc,AudioAnalyser:Zc,AudioContext:Uc,AudioListener:class extends Yt{constructor(){super(),this.type="AudioListener",this.context=Uc.getContext(),this.gain=this.context.createGain(),this.gain.connect(this.context.destination),this.filter=null,this.timeDelta=0,this._clock=new Pc}getInput(){return this.gain}removeFilter(){return null!==this.filter&&(this.gain.disconnect(this.filter),this.filter.disconnect(this.context.destination),this.gain.connect(this.context.destination),this.filter=null),this}getFilter(){return this.filter}setFilter(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}getMasterVolume(){return this.gain.gain.value}setMasterVolume(e){return this.gain.gain.setTargetAtTime(e,this.context.currentTime,.01),this}updateMatrixWorld(e){super.updateMatrixWorld(e);const t=this.context.listener,i=this.up;if(this.timeDelta=this._clock.getDelta(),this.matrixWorld.decompose(Kc,Vc,Yc),Hc.set(0,0,-1).applyQuaternion(Vc),t.positionX){const e=this.context.currentTime+this.timeDelta;t.positionX.linearRampToValueAtTime(Kc.x,e),t.positionY.linearRampToValueAtTime(Kc.y,e),t.positionZ.linearRampToValueAtTime(Kc.z,e),t.forwardX.linearRampToValueAtTime(Hc.x,e),t.forwardY.linearRampToValueAtTime(Hc.y,e),t.forwardZ.linearRampToValueAtTime(Hc.z,e),t.upX.linearRampToValueAtTime(i.x,e),t.upY.linearRampToValueAtTime(i.y,e),t.upZ.linearRampToValueAtTime(i.z,e)}else t.setPosition(Kc.x,Kc.y,Kc.z),t.setOrientation(Hc.x,Hc.y,Hc.z,i.x,i.y,i.z)}},AudioLoader:Fc,AxesHelper:Wh,AxisHelper:function(e){return console.warn("THREE.AxisHelper has been renamed to THREE.AxesHelper."),new Wh(e)},BackSide:1,BasicDepthPacking:3200,BasicShadowMap:0,BinaryTextureLoader:function(e){return console.warn("THREE.BinaryTextureLoader has been renamed to THREE.DataTextureLoader."),new kl(e)},Bone:Aa,BooleanKeyframeTrack:ul,BoundingBoxHelper:function(e,t){return console.warn("THREE.BoundingBoxHelper has been deprecated. Creating a THREE.BoxHelper instead."),new Vh(e,t)},Box2:vh,Box3:He,Box3Helper:class extends La{constructor(e,t=16776960){const 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]),n=new Ni;n.setIndex(new Ai(i,1)),n.setAttribute("position",new Bi([1,1,1,-1,1,1,-1,-1,1,1,-1,1,1,1,-1,-1,1,-1,-1,-1,-1,1,-1,-1],3)),super(n,new Sa({color:t,toneMapped:!1})),this.box=e,this.type="Box3Helper",this.geometry.computeBoundingSphere()}updateMatrixWorld(e){const t=this.box;t.isEmpty()||(t.getCenter(this.position),t.getSize(this.scale),this.scale.multiplyScalar(.5),super.updateMatrixWorld(e))}},BoxBufferGeometry:on,BoxGeometry:on,BoxHelper:Vh,BufferAttribute:Ai,BufferGeometry:Ni,BufferGeometryLoader:Mc,ByteType:1010,Cache:Il,Camera:hn,CameraHelper:class extends La{constructor(e){const t=new Ni,i=new Sa({color:16777215,vertexColors:!0,toneMapped:!1}),n=[],r=[],o={},a=new pi(16755200),s=new pi(16711680),l=new pi(43775),c=new pi(16777215),h=new pi(3355443);function d(e,t,i){u(e,i),u(t,i)}function u(e,t){n.push(0,0,0),r.push(t.r,t.g,t.b),void 0===o[e]&&(o[e]=[]),o[e].push(n.length/3-1)}d("n1","n2",a),d("n2","n4",a),d("n4","n3",a),d("n3","n1",a),d("f1","f2",a),d("f2","f4",a),d("f4","f3",a),d("f3","f1",a),d("n1","f1",a),d("n2","f2",a),d("n3","f3",a),d("n4","f4",a),d("p","n1",s),d("p","n2",s),d("p","n3",s),d("p","n4",s),d("u1","u2",l),d("u2","u3",l),d("u3","u1",l),d("c","t",c),d("p","c",h),d("cn1","cn2",h),d("cn3","cn4",h),d("cf1","cf2",h),d("cf3","cf4",h),t.setAttribute("position",new Bi(n,3)),t.setAttribute("color",new Bi(r,3)),super(t,i),this.type="CameraHelper",this.camera=e,this.camera.updateProjectionMatrix&&this.camera.updateProjectionMatrix(),this.matrix=e.matrixWorld,this.matrixAutoUpdate=!1,this.pointMap=o,this.update()}update(){const e=this.geometry,t=this.pointMap;Ph.projectionMatrixInverse.copy(this.camera.projectionMatrixInverse),Gh("c",t,e,Ph,0,0,-1),Gh("t",t,e,Ph,0,0,1),Gh("n1",t,e,Ph,-1,-1,-1),Gh("n2",t,e,Ph,1,-1,-1),Gh("n3",t,e,Ph,-1,1,-1),Gh("n4",t,e,Ph,1,1,-1),Gh("f1",t,e,Ph,-1,-1,1),Gh("f2",t,e,Ph,1,-1,1),Gh("f3",t,e,Ph,-1,1,1),Gh("f4",t,e,Ph,1,1,1),Gh("u1",t,e,Ph,.7,1.1,-1),Gh("u2",t,e,Ph,-.7,1.1,-1),Gh("u3",t,e,Ph,0,2,-1),Gh("cf1",t,e,Ph,-1,0,1),Gh("cf2",t,e,Ph,1,0,1),Gh("cf3",t,e,Ph,0,-1,1),Gh("cf4",t,e,Ph,0,1,1),Gh("cn1",t,e,Ph,-1,0,-1),Gh("cn2",t,e,Ph,1,0,-1),Gh("cn3",t,e,Ph,0,-1,-1),Gh("cn4",t,e,Ph,0,1,-1),e.getAttribute("position").needsUpdate=!0}dispose(){this.geometry.dispose(),this.material.dispose()}},CanvasRenderer:function(){console.error("THREE.CanvasRenderer has been removed")},CanvasTexture:Ja,CatmullRomCurve3:Pl,CineonToneMapping:3,CircleBufferGeometry:qa,CircleGeometry:qa,ClampToEdgeWrapping:f,Clock:Pc,Color:pi,ColorKeyframeTrack:pl,CompressedTexture:Wa,CompressedTextureLoader:class extends Ml{constructor(e){super(e)}load(e,t,i,n){const r=this,o=[],a=new Wa,s=new Bl(this.manager);s.setPath(this.path),s.setResponseType("arraybuffer"),s.setRequestHeader(this.requestHeader),s.setWithCredentials(r.withCredentials);let l=0;function c(c){s.load(e[c],(function(e){const i=r.parse(e,!0);o[c]={width:i.width,height:i.height,format:i.format,mipmaps:i.mipmaps},l+=1,6===l&&(1===i.mipmapCount&&(a.minFilter=C),a.image=o,a.format=i.format,a.needsUpdate=!0,t&&t(a))}),i,n)}if(Array.isArray(e))for(let t=0,i=e.length;i>t;++t)c(t);else s.load(e,(function(e){const i=r.parse(e,!0);if(i.isCubemap){const e=i.mipmaps.length/i.mipmapCount;for(let t=0;e>t;t++){o[t]={mipmaps:[]};for(let e=0;i.mipmapCount>e;e++)o[t].mipmaps.push(i.mipmaps[t*i.mipmapCount+e]),o[t].format=i.format,o[t].width=i.width,o[t].height=i.height}a.image=o}else a.image.width=i.width,a.image.height=i.height,a.mipmaps=i.mipmaps;1===i.mipmapCount&&(a.minFilter=C),a.format=i.format,a.needsUpdate=!0,t&&t(a)}),i,n);return a}},ConeBufferGeometry:Xa,ConeGeometry:Xa,CubeCamera:pn,CubeReflectionMapping:l,CubeRefractionMapping:c,CubeTexture:gn,CubeTextureLoader:bl,CubeUVReflectionMapping:u,CubeUVRefractionMapping:p,CubicBezierCurve:Yl,CubicBezierCurve3:Hl,CubicInterpolant:ll,CullFaceBack:1,CullFaceFront:2,CullFaceFrontBack:3,CullFaceNone:0,Curve:Tl,CurvePath:Xl,CustomBlending:5,CustomToneMapping:5,CylinderBufferGeometry:Za,CylinderGeometry:Za,Cylindrical:class{constructor(e=1,t=0,i=0){return this.radius=e,this.theta=t,this.y=i,this}set(e,t,i){return this.radius=e,this.theta=t,this.y=i,this}copy(e){return this.radius=e.radius,this.theta=e.theta,this.y=e.y,this}setFromVector3(e){return this.setFromCartesianCoords(e.x,e.y,e.z)}setFromCartesianCoords(e,t,i){return this.radius=Math.sqrt(e*e+i*i),this.theta=Math.atan2(e,i),this.y=t,this}clone(){return(new this.constructor).copy(this)}},DataTexture:ya,DataTexture2DArray:Kn,DataTexture3D:Vn,DataTextureLoader:kl,DataUtils:class{static toHalfFloat(e){Jh[0]=e;const t=zh[0];let i=t>>16&32768,n=t>>12&2047;const r=t>>23&255;return 103>r?i:r>142?(i|=31744,i|=(255==r?0:1)&&8388607&t,i):113>r?(n|=2048,i|=(n>>114-r)+(n>>113-r&1),i):(i|=r-112<<10|n>>1,i+=1&n,i)}},DecrementStencilOp:le,DecrementWrapStencilOp:he,DefaultLoadingManager:wl,DepthFormat:T,DepthStencilFormat:R,DepthTexture:za,DirectionalLight:fc,DirectionalLightHelper:Oh,DiscreteInterpolant:hl,DodecahedronBufferGeometry:$a,DodecahedronGeometry:$a,DoubleSide:2,DstAlphaFactor:206,DstColorFactor:208,DynamicBufferAttribute:function(e,t){return console.warn("THREE.DynamicBufferAttribute has been removed. Use new THREE.BufferAttribute().setUsage( THREE.DynamicDrawUsage ) instead."),new Ai(e,t).setUsage(ge)},DynamicCopyUsage:35050,DynamicDrawUsage:ge,DynamicReadUsage:35049,EdgesGeometry:rs,EdgesHelper:function(e,t){return console.warn("THREE.EdgesHelper has been removed. Use THREE.EdgesGeometry instead."),new La(new rs(e.geometry),new Sa({color:void 0!==t?t:16777215}))},EllipseCurve:Rl,EqualDepth:4,EqualStencilFunc:514,EquirectangularReflectionMapping:h,EquirectangularRefractionMapping:d,Euler:bt,EventDispatcher:me,ExtrudeBufferGeometry:Us,ExtrudeGeometry:Us,FaceColors:1,FileLoader:Bl,FlatShading:1,Float16BufferAttribute:Ei,Float32Attribute:function(e,t){return console.warn("THREE.Float32Attribute has been removed. Use new THREE.Float32BufferAttribute() instead."),new Bi(e,t)},Float32BufferAttribute:Bi,Float64Attribute:function(e,t){return console.warn("THREE.Float64Attribute has been removed. Use new THREE.Float64BufferAttribute() instead."),new Si(e,t)},Float64BufferAttribute:Si,FloatType:B,Fog:Ko,FogExp2:Go,Font:Dc,FontLoader:class extends Ml{constructor(e){super(e)}load(e,t,i,n){const r=this,o=new Bl(this.manager);o.setPath(this.path),o.setRequestHeader(this.requestHeader),o.setWithCredentials(r.withCredentials),o.load(e,(function(e){let i;try{i=JSON.parse(e)}catch(t){console.warn("THREE.FontLoader: typeface.js support is being deprecated. Use typeface.json instead."),i=JSON.parse(e.substring(65,e.length-2))}const n=r.parse(i);t&&t(n)}),i,n)}parse(e){return new Dc(e)}},FrontSide:0,Frustum:yn,GLBufferAttribute:gh,GLSL1:"100",GLSL3:fe,GammaEncoding:$,GreaterDepth:6,GreaterEqualDepth:5,GreaterEqualStencilFunc:518,GreaterStencilFunc:516,GridHelper:Uh,Group:To,HalfFloatType:S,HemisphereLight:tc,HemisphereLightHelper:class extends Yt{constructor(e,t,i){super(),this.light=e,this.light.updateMatrixWorld(),this.matrix=e.matrixWorld,this.matrixAutoUpdate=!1,this.color=i;const n=new Os(t);n.rotateY(.5*Math.PI),this.material=new gi({wireframe:!0,fog:!1,toneMapped:!1}),void 0===this.color&&(this.material.vertexColors=!0);const r=n.getAttribute("position"),o=new Float32Array(3*r.count);n.setAttribute("color",new Ai(o,3)),this.add(new nn(n,this.material)),this.update()}dispose(){this.children[0].geometry.dispose(),this.children[0].material.dispose()}update(){const e=this.children[0];if(void 0!==this.color)this.material.color.set(this.color);else{const t=e.geometry.getAttribute("color");Th.copy(this.light.color),Rh.copy(this.light.groundColor);for(let e=0,i=t.count;i>e;e++){const n=i/2>e?Th:Rh;t.setXYZ(e,n.r,n.g,n.b)}t.needsUpdate=!0}e.lookAt(Dh.setFromMatrixPosition(this.light.matrixWorld).negate())}},HemisphereLightProbe:Qc,IcosahedronBufferGeometry:Qs,IcosahedronGeometry:Qs,ImageBitmapLoader:bc,ImageLoader:Sl,ImageUtils:Re,ImmediateRenderObject:wh,IncrementStencilOp:se,IncrementWrapStencilOp:ce,InstancedBufferAttribute:wc,InstancedBufferGeometry:xc,InstancedInterleavedBuffer:ph,InstancedMesh:Ba,Int16Attribute:function(e,t){return console.warn("THREE.Int16Attribute has been removed. Use new THREE.Int16BufferAttribute() instead."),new Ii(e,t)},Int16BufferAttribute:Ii,Int32Attribute:function(e,t){return console.warn("THREE.Int32Attribute has been removed. Use new THREE.Int32BufferAttribute() instead."),new wi(e,t)},Int32BufferAttribute:wi,Int8Attribute:function(e,t){return console.warn("THREE.Int8Attribute has been removed. Use new THREE.Int8BufferAttribute() instead."),new yi(e,t)},Int8BufferAttribute:yi,IntType:1013,InterleavedBuffer:Yo,InterleavedBufferAttribute:jo,Interpolant:sl,InterpolateDiscrete:Y,InterpolateLinear:H,InterpolateSmooth:j,InvertStencilOp:5386,JSONLoader:function(){console.error("THREE.JSONLoader has been removed.")},KeepStencilOp:oe,KeyframeTrack:dl,LOD:ha,LatheBufferGeometry:Ls,LatheGeometry:Ls,Layers:kt,LensFlare:function(){console.error("THREE.LensFlare has been moved to /examples/jsm/objects/Lensflare.js")},LessDepth:2,LessEqualDepth:3,LessEqualStencilFunc:de,LessStencilFunc:513,Light:ec,LightProbe:vc,Line:Ua,Line3:xh,LineBasicMaterial:Sa,LineCurve:jl,LineCurve3:Wl,LineDashedMaterial:rl,LineLoop:Oa,LinePieces:1,LineSegments:La,LineStrip:0,LinearEncoding:X,LinearFilter:C,LinearInterpolant:cl,LinearMipMapLinearFilter:1008,LinearMipMapNearestFilter:1007,LinearMipmapLinearFilter:x,LinearMipmapNearestFilter:I,LinearToneMapping:1,Loader:Ml,LoaderUtils:Ic,LoadingManager:xl,LogLuvEncoding:3003,LoopOnce:2200,LoopPingPong:2202,LoopRepeat:2201,LuminanceAlphaFormat:1025,LuminanceFormat:1024,MOUSE:n,Material:ai,MaterialLoader:Cc,Math:be,MathUtils:be,Matrix3:De,Matrix4:yt,MaxEquation:104,Mesh:nn,MeshBasicMaterial:gi,MeshDepthMaterial:Mo,MeshDistanceMaterial:Eo,MeshFaceMaterial:function(e){return console.warn("THREE.MeshFaceMaterial has been removed. Use an Array instead."),e},MeshLambertMaterial:il,MeshMatcapMaterial:nl,MeshNormalMaterial:tl,MeshPhongMaterial:$s,MeshPhysicalMaterial:_s,MeshStandardMaterial:Xs,MeshToonMaterial:el,MinEquation:103,MirroredRepeatWrapping:m,MixOperation:1,MultiMaterial:function(e=[]){return console.warn("THREE.MultiMaterial has been removed. Use an Array instead."),e.isMultiMaterial=!0,e.materials=e,e.clone=function(){return e.slice()},e},MultiplyBlending:4,MultiplyOperation:0,NearestFilter:A,NearestMipMapLinearFilter:1005,NearestMipMapNearestFilter:1004,NearestMipmapLinearFilter:v,NearestMipmapNearestFilter:y,NeverDepth:0,NeverStencilFunc:512,NoBlending:0,NoColors:0,NoToneMapping:0,NormalAnimationBlendMode:q,NormalBlending:1,NotEqualDepth:7,NotEqualStencilFunc:517,NumberKeyframeTrack:gl,Object3D:Yt,ObjectLoader:class extends Ml{constructor(e){super(e)}load(e,t,i,n){const r=this,o=""===this.path?Ic.extractUrlBase(e):this.path;this.resourcePath=this.resourcePath||o;const a=new Bl(this.manager);a.setPath(this.path),a.setRequestHeader(this.requestHeader),a.setWithCredentials(this.withCredentials),a.load(e,(function(i){let o=null;try{o=JSON.parse(i)}catch(t){return void 0!==n&&n(t),void console.error("THREE:ObjectLoader: Can't parse "+e+".",t.message)}const a=o.metadata;void 0!==a&&void 0!==a.type&&"geometry"!==a.type.toLowerCase()?r.parse(o,t):console.error("THREE.ObjectLoader: Can't load "+e)}),i,n)}parse(e,t){const i=this.parseAnimations(e.animations),n=this.parseShapes(e.shapes),r=this.parseGeometries(e.geometries,n),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,r,s,i),c=this.parseSkeletons(e.skeletons,l);if(this.bindSkeletons(l,c),void 0!==t){let e=!1;for(const t in o)if(o[t]instanceof HTMLImageElement){e=!0;break}!1===e&&t(l)}return l}parseShapes(e){const t={};if(void 0!==e)for(let i=0,n=e.length;n>i;i++){const n=(new $l).fromJSON(e[i]);t[n.uuid]=n}return t}parseSkeletons(e,t){const i={},n={};if(t.traverse((function(e){e.isBone&&(n[e.uuid]=e)})),void 0!==e)for(let t=0,r=e.length;r>t;t++){const r=(new Ia).fromJSON(e[t],n);i[r.uuid]=r}return i}parseGeometries(e,t){const i={};let n;if(void 0!==e){const r=new Mc;for(let o=0,a=e.length;a>o;o++){let a;const s=e[o];switch(s.type){case"PlaneGeometry":case"PlaneBufferGeometry":a=new zs[s.type](s.width,s.height,s.widthSegments,s.heightSegments);break;case"BoxGeometry":case"BoxBufferGeometry":a=new zs[s.type](s.width,s.height,s.depth,s.widthSegments,s.heightSegments,s.depthSegments);break;case"CircleGeometry":case"CircleBufferGeometry":a=new zs[s.type](s.radius,s.segments,s.thetaStart,s.thetaLength);break;case"CylinderGeometry":case"CylinderBufferGeometry":a=new zs[s.type](s.radiusTop,s.radiusBottom,s.height,s.radialSegments,s.heightSegments,s.openEnded,s.thetaStart,s.thetaLength);break;case"ConeGeometry":case"ConeBufferGeometry":a=new zs[s.type](s.radius,s.height,s.radialSegments,s.heightSegments,s.openEnded,s.thetaStart,s.thetaLength);break;case"SphereGeometry":case"SphereBufferGeometry":a=new zs[s.type](s.radius,s.widthSegments,s.heightSegments,s.phiStart,s.phiLength,s.thetaStart,s.thetaLength);break;case"DodecahedronGeometry":case"DodecahedronBufferGeometry":case"IcosahedronGeometry":case"IcosahedronBufferGeometry":case"OctahedronGeometry":case"OctahedronBufferGeometry":case"TetrahedronGeometry":case"TetrahedronBufferGeometry":a=new zs[s.type](s.radius,s.detail);break;case"RingGeometry":case"RingBufferGeometry":a=new zs[s.type](s.innerRadius,s.outerRadius,s.thetaSegments,s.phiSegments,s.thetaStart,s.thetaLength);break;case"TorusGeometry":case"TorusBufferGeometry":a=new zs[s.type](s.radius,s.tube,s.radialSegments,s.tubularSegments,s.arc);break;case"TorusKnotGeometry":case"TorusKnotBufferGeometry":a=new zs[s.type](s.radius,s.tube,s.tubularSegments,s.radialSegments,s.p,s.q);break;case"TubeGeometry":case"TubeBufferGeometry":a=new zs[s.type]((new Zl[s.path.type]).fromJSON(s.path),s.tubularSegments,s.radius,s.radialSegments,s.closed);break;case"LatheGeometry":case"LatheBufferGeometry":a=new zs[s.type](s.points,s.segments,s.phiStart,s.phiLength);break;case"PolyhedronGeometry":case"PolyhedronBufferGeometry":a=new zs[s.type](s.vertices,s.indices,s.radius,s.details);break;case"ShapeGeometry":case"ShapeBufferGeometry":n=[];for(let e=0,i=s.shapes.length;i>e;e++){n.push(t[s.shapes[e]])}a=new zs[s.type](n,s.curveSegments);break;case"ExtrudeGeometry":case"ExtrudeBufferGeometry":n=[];for(let e=0,i=s.shapes.length;i>e;e++){n.push(t[s.shapes[e]])}const e=s.options.extrudePath;void 0!==e&&(s.options.extrudePath=(new Zl[e.type]).fromJSON(e)),a=new zs[s.type](n,s.options);break;case"BufferGeometry":case"InstancedBufferGeometry":a=r.parse(s);break;case"Geometry":console.error('THREE.ObjectLoader: Loading "Geometry" is not supported anymore.');break;default:console.warn('THREE.ObjectLoader: Unsupported geometry type "'+s.type+'"');continue}a.uuid=s.uuid,void 0!==s.name&&(a.name=s.name),!0===a.isBufferGeometry&&void 0!==s.userData&&(a.userData=s.userData),i[s.uuid]=a}}return i}parseMaterials(e,t){const i={},n={};if(void 0!==e){const r=new Cc;r.setTextures(t);for(let t=0,o=e.length;o>t;t++){const o=e[t];if("MultiMaterial"===o.type){const e=[];for(let t=0;o.materials.length>t;t++){const n=o.materials[t];void 0===i[n.uuid]&&(i[n.uuid]=r.parse(n)),e.push(i[n.uuid])}n[o.uuid]=e}else void 0===i[o.uuid]&&(i[o.uuid]=r.parse(o)),n[o.uuid]=i[o.uuid]}}return n}parseAnimations(e){const t={};if(void 0!==e)for(let i=0;e.length>i;i++){const n=vl.parse(e[i]);t[n.uuid]=n}return t}parseImages(e,t){const i=this,n={};let r;function o(e){if("string"==typeof e){const t=e;return function(e){return i.manager.itemStart(e),r.load(e,(function(){i.manager.itemEnd(e)}),void 0,(function(){i.manager.itemError(e),i.manager.itemEnd(e)}))}(/^(\/\/)|([a-z]+:(\/\/)?)/i.test(t)?t:i.resourcePath+t)}return e.data?{data:Di(e.type,e.data),width:e.width,height:e.height}:null}if(void 0!==e&&e.length>0){const i=new xl(t);r=new Sl(i),r.setCrossOrigin(this.crossOrigin);for(let t=0,i=e.length;i>t;t++){const i=e[t],r=i.url;if(Array.isArray(r)){n[i.uuid]=[];for(let e=0,t=r.length;t>e;e++){const t=o(r[e]);null!==t&&(t instanceof HTMLImageElement?n[i.uuid].push(t):n[i.uuid].push(new ya(t.data,t.width,t.height)))}}else{const e=o(i.url);null!==e&&(n[i.uuid]=e)}}}return n}parseTextures(e,t){function i(e,t){return"number"==typeof e?e:(console.warn("THREE.ObjectLoader.parseTexture: Constant should be in numeric form.",e),t[e])}const n={};if(void 0!==e)for(let r=0,o=e.length;o>r;r++){const o=e[r];let a;void 0===o.image&&console.warn('THREE.ObjectLoader: No "image" specified for',o.uuid),void 0===t[o.image]&&console.warn("THREE.ObjectLoader: Undefined image",o.image);const s=t[o.image];Array.isArray(s)?(a=new gn(s),6===s.length&&(a.needsUpdate=!0)):(a=s&&s.data?new ya(s.data,s.width,s.height):new Fe(s),s&&(a.needsUpdate=!0)),a.uuid=o.uuid,void 0!==o.name&&(a.name=o.name),void 0!==o.mapping&&(a.mapping=i(o.mapping,Ec)),void 0!==o.offset&&a.offset.fromArray(o.offset),void 0!==o.repeat&&a.repeat.fromArray(o.repeat),void 0!==o.center&&a.center.fromArray(o.center),void 0!==o.rotation&&(a.rotation=o.rotation),void 0!==o.wrap&&(a.wrapS=i(o.wrap[0],Bc),a.wrapT=i(o.wrap[1],Bc)),void 0!==o.format&&(a.format=o.format),void 0!==o.type&&(a.type=o.type),void 0!==o.encoding&&(a.encoding=o.encoding),void 0!==o.minFilter&&(a.minFilter=i(o.minFilter,Sc)),void 0!==o.magFilter&&(a.magFilter=i(o.magFilter,Sc)),void 0!==o.anisotropy&&(a.anisotropy=o.anisotropy),void 0!==o.flipY&&(a.flipY=o.flipY),void 0!==o.premultiplyAlpha&&(a.premultiplyAlpha=o.premultiplyAlpha),void 0!==o.unpackAlignment&&(a.unpackAlignment=o.unpackAlignment),n[o.uuid]=a}return n}parseObject(e,t,i,n){let r,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)){const t=[];for(let n=0,r=e.length;r>n;n++){const r=e[n];void 0===i[r]&&console.warn("THREE.ObjectLoader: Undefined material",r),t.push(i[r])}return t}return void 0===i[e]&&console.warn("THREE.ObjectLoader: Undefined material",e),i[e]}}switch(e.type){case"Scene":r=new Vo,void 0!==e.background&&Number.isInteger(e.background)&&(r.background=new pi(e.background)),void 0!==e.fog&&("Fog"===e.fog.type?r.fog=new Ko(e.fog.color,e.fog.near,e.fog.far):"FogExp2"===e.fog.type&&(r.fog=new Go(e.fog.color,e.fog.density)));break;case"PerspectiveCamera":r=new dn(e.fov,e.aspect,e.near,e.far),void 0!==e.focus&&(r.focus=e.focus),void 0!==e.zoom&&(r.zoom=e.zoom),void 0!==e.filmGauge&&(r.filmGauge=e.filmGauge),void 0!==e.filmOffset&&(r.filmOffset=e.filmOffset),void 0!==e.view&&(r.view=Object.assign({},e.view));break;case"OrthographicCamera":r=new pc(e.left,e.right,e.top,e.bottom,e.near,e.far),void 0!==e.zoom&&(r.zoom=e.zoom),void 0!==e.view&&(r.view=Object.assign({},e.view));break;case"AmbientLight":r=new mc(e.color,e.intensity);break;case"DirectionalLight":r=new fc(e.color,e.intensity);break;case"PointLight":r=new uc(e.color,e.intensity,e.distance,e.decay);break;case"RectAreaLight":r=new Ac(e.color,e.intensity,e.width,e.height);break;case"SpotLight":r=new sc(e.color,e.intensity,e.distance,e.angle,e.penumbra,e.decay);break;case"HemisphereLight":r=new tc(e.color,e.groundColor,e.intensity);break;case"LightProbe":r=(new vc).fromJSON(e);break;case"SkinnedMesh":o=s(e.geometry),a=l(e.material),r=new ma(o,a),void 0!==e.bindMode&&(r.bindMode=e.bindMode),void 0!==e.bindMatrix&&r.bindMatrix.fromArray(e.bindMatrix),void 0!==e.skeleton&&(r.skeleton=e.skeleton);break;case"Mesh":o=s(e.geometry),a=l(e.material),r=new nn(o,a);break;case"InstancedMesh":o=s(e.geometry),a=l(e.material);const t=e.instanceMatrix,i=e.instanceColor;r=new Ba(o,a,e.count),r.instanceMatrix=new Ai(new Float32Array(t.array),16),void 0!==i&&(r.instanceColor=new Ai(new Float32Array(i.array),i.itemSize));break;case"LOD":r=new ha;break;case"Line":r=new Ua(s(e.geometry),l(e.material));break;case"LineLoop":r=new Oa(s(e.geometry),l(e.material));break;case"LineSegments":r=new La(s(e.geometry),l(e.material));break;case"PointCloud":case"Points":r=new Ya(s(e.geometry),l(e.material));break;case"Sprite":r=new aa(l(e.material));break;case"Group":r=new To;break;case"Bone":r=new Aa;break;default:r=new Yt}if(r.uuid=e.uuid,void 0!==e.name&&(r.name=e.name),void 0!==e.matrix?(r.matrix.fromArray(e.matrix),void 0!==e.matrixAutoUpdate&&(r.matrixAutoUpdate=e.matrixAutoUpdate),r.matrixAutoUpdate&&r.matrix.decompose(r.position,r.quaternion,r.scale)):(void 0!==e.position&&r.position.fromArray(e.position),void 0!==e.rotation&&r.rotation.fromArray(e.rotation),void 0!==e.quaternion&&r.quaternion.fromArray(e.quaternion),void 0!==e.scale&&r.scale.fromArray(e.scale)),void 0!==e.castShadow&&(r.castShadow=e.castShadow),void 0!==e.receiveShadow&&(r.receiveShadow=e.receiveShadow),e.shadow&&(void 0!==e.shadow.bias&&(r.shadow.bias=e.shadow.bias),void 0!==e.shadow.normalBias&&(r.shadow.normalBias=e.shadow.normalBias),void 0!==e.shadow.radius&&(r.shadow.radius=e.shadow.radius),void 0!==e.shadow.mapSize&&r.shadow.mapSize.fromArray(e.shadow.mapSize),void 0!==e.shadow.camera&&(r.shadow.camera=this.parseObject(e.shadow.camera))),void 0!==e.visible&&(r.visible=e.visible),void 0!==e.frustumCulled&&(r.frustumCulled=e.frustumCulled),void 0!==e.renderOrder&&(r.renderOrder=e.renderOrder),void 0!==e.userData&&(r.userData=e.userData),void 0!==e.layers&&(r.layers.mask=e.layers),void 0!==e.children){const o=e.children;for(let e=0;o.length>e;e++)r.add(this.parseObject(o[e],t,i,n))}if(void 0!==e.animations){const t=e.animations;for(let e=0;t.length>e;e++){r.animations.push(n[t[e]])}}if("LOD"===e.type){void 0!==e.autoUpdate&&(r.autoUpdate=e.autoUpdate);const t=e.levels;for(let e=0;t.length>e;e++){const i=t[e],n=r.getObjectByProperty("uuid",i.object);void 0!==n&&r.addLevel(n,i.distance)}}return r}bindSkeletons(e,t){0!==Object.keys(t).length&&e.traverse((function(e){if(!0===e.isSkinnedMesh&&void 0!==e.skeleton){const i=t[e.skeleton];void 0===i?console.warn("THREE.ObjectLoader: No skeleton found with UUID:",e.skeleton):e.bind(i,e.bindMatrix)}}))}setTexturePath(e){return console.warn("THREE.ObjectLoader: .setTexturePath() has been renamed to .setResourcePath()."),this.setResourcePath(e)}},ObjectSpaceNormalMap:1,OctahedronBufferGeometry:Os,OctahedronGeometry:Os,OneFactor:a,OneMinusDstAlphaFactor:207,OneMinusDstColorFactor:209,OneMinusSrcAlphaFactor:205,OneMinusSrcColorFactor:203,OrthographicCamera:pc,PCFShadowMap:1,PCFSoftShadowMap:2,PMREMGenerator:class{constructor(e){this._renderer=e,this._pingPongRenderTarget=null,this._blurMaterial=function(e){const t=new Float32Array(e),i=new Ke(0,1,0);return new Zs({name:"SphericalGaussianBlur",defines:{n:e},uniforms:{envMap:{value:null},samples:{value:1},weights:{value:t},latitudinal:{value:!1},dTheta:{value:0},mipInt:{value:0},poleAxis:{value:i},inputEncoding:{value:$h[3e3]},outputEncoding:{value:$h[3e3]}},vertexShader:yd(),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${vd()}\n\n\t\t\t#define ENVMAP_TYPE_CUBE_UV\n\t\t\t#include <cube_uv_reflection_fragment>\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:0,depthTest:!1,depthWrite:!1})}(_h),this._equirectShader=null,this._cubemapShader=null,this._compileMaterial(this._blurMaterial)}fromScene(e,t=0,i=.1,n=100){sd=this._renderer.getRenderTarget();const r=this._allocateTargets();return this._sceneToCubeUV(e,i,n,r),t>0&&this._blur(r,0,0,t),this._applyPMREM(r),this._cleanup(r),r}fromEquirectangular(e){return this._fromTexture(e)}fromCubemap(e){return this._fromTexture(e)}compileCubemapShader(){null===this._cubemapShader&&(this._cubemapShader=Ad(),this._compileMaterial(this._cubemapShader))}compileEquirectangularShader(){null===this._equirectShader&&(this._equirectShader=md(),this._compileMaterial(this._equirectShader))}dispose(){this._blurMaterial.dispose(),null!==this._cubemapShader&&this._cubemapShader.dispose(),null!==this._equirectShader&&this._equirectShader.dispose();for(let e=0;nd.length>e;e++)nd[e].dispose()}_cleanup(e){this._pingPongRenderTarget.dispose(),this._renderer.setRenderTarget(sd),e.scissorTest=!1,fd(e,0,0,e.width,e.height)}_fromTexture(e){sd=this._renderer.getRenderTarget();const t=this._allocateTargets(e);return this._textureToCubeUV(e,t),this._applyPMREM(t),this._cleanup(t),t}_allocateTargets(e){const t={magFilter:A,minFilter:A,generateMipmaps:!1,type:w,format:1023,encoding:ud(e)?e.encoding:ee,depthBuffer:!1},i=gd(t);return i.depthBuffer=!e,this._pingPongRenderTarget=gd(t),i}_compileMaterial(e){const t=new nn(nd[0],e);this._renderer.compile(t,id)}_sceneToCubeUV(e,t,i,n){const r=new dn(90,1,t,i),o=[1,-1,1,1,1,1],a=[1,1,1,-1,-1,-1],s=this._renderer,l=s.autoClear,c=s.outputEncoding,h=s.toneMapping;s.getClearColor(ad),s.toneMapping=0,s.outputEncoding=X,s.autoClear=!1;let d=!1;const u=e.background;if(u){if(u.isColor){ed.color.copy(u).convertSRGBToLinear(),e.background=null;const t=dd(ed.color);ed.opacity=t,d=!0}}else{ed.color.copy(ad).convertSRGBToLinear();const e=dd(ed.color);ed.opacity=e,d=!0}for(let t=0;6>t;t++){const i=t%3;0==i?(r.up.set(0,o[t],0),r.lookAt(a[t],0,0)):1==i?(r.up.set(0,0,o[t]),r.lookAt(0,a[t],0)):(r.up.set(0,o[t],0),r.lookAt(0,0,a[t])),fd(n,i*qh,t>2?qh:0,qh,qh),s.setRenderTarget(n),d&&s.render(td,r),s.render(e,r)}s.toneMapping=h,s.outputEncoding=c,s.autoClear=l}_textureToCubeUV(e,t){const i=this._renderer;e.isCubeTexture?null==this._cubemapShader&&(this._cubemapShader=Ad()):null==this._equirectShader&&(this._equirectShader=md());const n=e.isCubeTexture?this._cubemapShader:this._equirectShader,r=new nn(nd[0],n),o=n.uniforms;o.envMap.value=e,e.isCubeTexture||o.texelSize.value.set(1/e.image.width,1/e.image.height),o.inputEncoding.value=$h[e.encoding],o.outputEncoding.value=$h[t.texture.encoding],fd(t,0,0,3*qh,2*qh),i.setRenderTarget(t),i.render(r,id)}_applyPMREM(e){const t=this._renderer,i=t.autoClear;t.autoClear=!1;for(let t=1;Xh>t;t++){const i=Math.sqrt(od[t]*od[t]-od[t-1]*od[t-1]);this._blur(e,t-1,t,i,hd[(t-1)%hd.length])}t.autoClear=i}_blur(e,t,i,n,r){const o=this._pingPongRenderTarget;this._halfBlur(e,o,t,i,n,"latitudinal",r),this._halfBlur(o,e,i,i,n,"longitudinal",r)}_halfBlur(e,t,i,n,r,o,a){const s=this._renderer,l=this._blurMaterial;"latitudinal"!==o&&"longitudinal"!==o&&console.error("blur direction must be either latitudinal or longitudinal!");const c=new nn(nd[n],l),h=l.uniforms,d=rd[i]-1,u=isFinite(r)?Math.PI/(2*d):2*Math.PI/39,p=r/u,g=isFinite(r)?1+Math.floor(3*p):_h;g>_h&&console.warn(`sigmaRadians, ${r}, is too large and will clip, as it requested ${g} samples when the maximum is set to 20`);const f=[];let m=0;for(let e=0;_h>e;++e){const t=e/p,i=Math.exp(-t*t/2);f.push(i),0==e?m+=i:g>e&&(m+=2*i)}for(let e=0;f.length>e;e++)f[e]=f[e]/m;h.envMap.value=e.texture,h.samples.value=g,h.weights.value=f,h.latitudinal.value="latitudinal"===o,a&&(h.poleAxis.value=a),h.dTheta.value=u,h.mipInt.value=8-i,h.inputEncoding.value=$h[e.texture.encoding],h.outputEncoding.value=$h[e.texture.encoding];const A=rd[n];fd(t,3*Math.max(0,qh-2*A),(0===n?0:2*qh)+2*A*(n>4?n-8+4:0),3*A,2*A),s.setRenderTarget(t),s.render(c,id)}},ParametricBufferGeometry:Ns,ParametricGeometry:Ns,Particle:function(e){return console.warn("THREE.Particle has been renamed to THREE.Sprite."),new aa(e)},ParticleBasicMaterial:function(e){return console.warn("THREE.ParticleBasicMaterial has been renamed to THREE.PointsMaterial."),new Na(e)},ParticleSystem:function(e,t){return console.warn("THREE.ParticleSystem has been renamed to THREE.Points."),new Ya(e,t)},ParticleSystemMaterial:function(e){return console.warn("THREE.ParticleSystemMaterial has been renamed to THREE.PointsMaterial."),new Na(e)},Path:_l,PerspectiveCamera:dn,Plane:Jt,PlaneBufferGeometry:In,PlaneGeometry:In,PlaneHelper:class extends Ua{constructor(e,t=1,i=16776960){const n=i,r=new Ni;r.setAttribute("position",new Bi([1,-1,1,-1,1,1,-1,-1,1,1,1,1,-1,1,1,-1,-1,1,1,-1,1,1,1,1,0,0,1,0,0,0],3)),r.computeBoundingSphere(),super(r,new Sa({color:n,toneMapped:!1})),this.type="PlaneHelper",this.plane=e,this.size=t;const o=new Ni;o.setAttribute("position",new Bi([1,1,1,-1,1,1,-1,-1,1,1,1,1,-1,-1,1,1,-1,1],3)),o.computeBoundingSphere(),this.add(new nn(o,new gi({color:n,opacity:.2,transparent:!0,depthWrite:!1,toneMapped:!1})))}updateMatrixWorld(e){let t=-this.plane.constant;1e-8>Math.abs(t)&&(t=1e-8),this.scale.set(.5*this.size,.5*this.size,t),this.children[0].material.side=0>t?1:0,this.lookAt(this.plane.normal),super.updateMatrixWorld(e)}},PointCloud:function(e,t){return console.warn("THREE.PointCloud has been renamed to THREE.Points."),new Ya(e,t)},PointCloudMaterial:function(e){return console.warn("THREE.PointCloudMaterial has been renamed to THREE.PointsMaterial."),new Na(e)},PointLight:uc,PointLightHelper:class extends nn{constructor(e,t,i){super(new Ks(t,4,2),new gi({wireframe:!0,fog:!1,toneMapped:!1})),this.light=e,this.light.updateMatrixWorld(),this.color=i,this.type="PointLightHelper",this.matrix=this.light.matrixWorld,this.matrixAutoUpdate=!1,this.update()}dispose(){this.geometry.dispose(),this.material.dispose()}update(){void 0!==this.color?this.material.color.set(this.color):this.material.color.copy(this.light.color)}},Points:Ya,PointsMaterial:Na,PolarGridHelper:class extends La{constructor(e=10,t=16,i=8,n=64,r=4473924,o=8947848){r=new pi(r),o=new pi(o);const a=[],s=[];for(let i=0;t>=i;i++){const n=i/t*(2*Math.PI),l=Math.sin(n)*e,c=Math.cos(n)*e;a.push(0,0,0),a.push(l,0,c);const h=1&i?r:o;s.push(h.r,h.g,h.b),s.push(h.r,h.g,h.b)}for(let t=0;i>=t;t++){const l=1&t?r:o,c=e-e/i*t;for(let e=0;n>e;e++){let t=e/n*(2*Math.PI),i=Math.sin(t)*c,r=Math.cos(t)*c;a.push(i,0,r),s.push(l.r,l.g,l.b),t=(e+1)/n*(2*Math.PI),i=Math.sin(t)*c,r=Math.cos(t)*c,a.push(i,0,r),s.push(l.r,l.g,l.b)}}const l=new Ni;l.setAttribute("position",new Bi(a,3)),l.setAttribute("color",new Bi(s,3));super(l,new Sa({vertexColors:!0,toneMapped:!1})),this.type="PolarGridHelper"}},PolyhedronBufferGeometry:_a,PolyhedronGeometry:_a,PositionalAudio:class extends jc{constructor(e){super(e),this.panner=this.context.createPanner(),this.panner.panningModel="HRTF",this.panner.connect(this.gain)}getOutput(){return this.panner}getRefDistance(){return this.panner.refDistance}setRefDistance(e){return this.panner.refDistance=e,this}getRolloffFactor(){return this.panner.rolloffFactor}setRolloffFactor(e){return this.panner.rolloffFactor=e,this}getDistanceModel(){return this.panner.distanceModel}setDistanceModel(e){return this.panner.distanceModel=e,this}getMaxDistance(){return this.panner.maxDistance}setMaxDistance(e){return this.panner.maxDistance=e,this}setDirectionalCone(e,t,i){return this.panner.coneInnerAngle=e,this.panner.coneOuterAngle=t,this.panner.coneOuterGain=i,this}updateMatrixWorld(e){if(super.updateMatrixWorld(e),!0===this.hasPlaybackControl&&!1===this.isPlaying)return;this.matrixWorld.decompose(Wc,Jc,zc),qc.set(0,0,1).applyQuaternion(Jc);const t=this.panner;if(t.positionX){const e=this.context.currentTime+this.listener.timeDelta;t.positionX.linearRampToValueAtTime(Wc.x,e),t.positionY.linearRampToValueAtTime(Wc.y,e),t.positionZ.linearRampToValueAtTime(Wc.z,e),t.orientationX.linearRampToValueAtTime(qc.x,e),t.orientationY.linearRampToValueAtTime(qc.y,e),t.orientationZ.linearRampToValueAtTime(qc.z,e)}else t.setPosition(Wc.x,Wc.y,Wc.z),t.setOrientation(qc.x,qc.y,qc.z)}},PropertyBinding:lh,PropertyMixer:Xc,QuadraticBezierCurve:Jl,QuadraticBezierCurve3:zl,Quaternion:Ge,QuaternionKeyframeTrack:ml,QuaternionLinearInterpolant:fl,REVISION:i,RGBADepthPacking:re,RGBAFormat:D,RGBAIntegerFormat:1033,RGBA_ASTC_10x10_Format:37819,RGBA_ASTC_10x5_Format:37816,RGBA_ASTC_10x6_Format:37817,RGBA_ASTC_10x8_Format:37818,RGBA_ASTC_12x10_Format:37820,RGBA_ASTC_12x12_Format:37821,RGBA_ASTC_4x4_Format:37808,RGBA_ASTC_5x4_Format:37809,RGBA_ASTC_5x5_Format:37810,RGBA_ASTC_6x5_Format:37811,RGBA_ASTC_6x6_Format:37812,RGBA_ASTC_8x5_Format:37813,RGBA_ASTC_8x6_Format:37814,RGBA_ASTC_8x8_Format:37815,RGBA_BPTC_Format:36492,RGBA_ETC2_EAC_Format:V,RGBA_PVRTC_2BPPV1_Format:G,RGBA_PVRTC_4BPPV1_Format:P,RGBA_S3TC_DXT1_Format:F,RGBA_S3TC_DXT3_Format:Q,RGBA_S3TC_DXT5_Format:L,RGBDEncoding:ne,RGBEEncoding:ee,RGBEFormat:1023,RGBFormat:k,RGBIntegerFormat:1032,RGBM16Encoding:ie,RGBM7Encoding:te,RGB_ETC1_Format:36196,RGB_ETC2_Format:K,RGB_PVRTC_2BPPV1_Format:N,RGB_PVRTC_4BPPV1_Format:O,RGB_S3TC_DXT1_Format:U,RGFormat:1030,RGIntegerFormat:1031,RawShaderMaterial:Zs,Ray:At,Raycaster:class{constructor(e,t,i=0,n=1/0){this.ray=new At(e,t),this.near=i,this.far=n,this.camera=null,this.layers=new kt,this.params={Mesh:{},Line:{threshold:1},LOD:{},Points:{threshold:1},Sprite:{}}}set(e,t){this.ray.set(e,t)}setFromCamera(e,t){t&&t.isPerspectiveCamera?(this.ray.origin.setFromMatrixPosition(t.matrixWorld),this.ray.direction.set(e.x,e.y,.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(e,t=!1,i=[]){return mh(e,this,i,t),i.sort(fh),i}intersectObjects(e,t=!1,i=[]){for(let n=0,r=e.length;r>n;n++)mh(e[n],this,i,t);return i.sort(fh),i}},RectAreaLight:Ac,RedFormat:1028,RedIntegerFormat:1029,ReinhardToneMapping:2,RepeatWrapping:g,ReplaceStencilOp:ae,ReverseSubtractEquation:102,RingBufferGeometry:Ps,RingGeometry:Ps,SRGB8_ALPHA8_ASTC_10x10_Format:37851,SRGB8_ALPHA8_ASTC_10x5_Format:37848,SRGB8_ALPHA8_ASTC_10x6_Format:37849,SRGB8_ALPHA8_ASTC_10x8_Format:37850,SRGB8_ALPHA8_ASTC_12x10_Format:37852,SRGB8_ALPHA8_ASTC_12x12_Format:37853,SRGB8_ALPHA8_ASTC_4x4_Format:37840,SRGB8_ALPHA8_ASTC_5x4_Format:37841,SRGB8_ALPHA8_ASTC_5x5_Format:37842,SRGB8_ALPHA8_ASTC_6x5_Format:37843,SRGB8_ALPHA8_ASTC_6x6_Format:37844,SRGB8_ALPHA8_ASTC_8x5_Format:37845,SRGB8_ALPHA8_ASTC_8x6_Format:37846,SRGB8_ALPHA8_ASTC_8x8_Format:37847,Scene:Vo,SceneUtils:Cd,ShaderChunk:xn,ShaderLib:Mn,ShaderMaterial:cn,ShadowMaterial:qs,Shape:$l,ShapeBufferGeometry:Gs,ShapeGeometry:Gs,ShapePath:kc,ShapeUtils:Ds,ShortType:1011,Skeleton:Ia,SkeletonHelper:bh,SkinnedMesh:ma,SmoothShading:2,Sphere:ct,SphereBufferGeometry:Ks,SphereGeometry:Ks,Spherical:Ah,SphericalHarmonics3:yc,SplineCurve:ql,SpotLight:sc,SpotLightHelper:class extends Yt{constructor(e,t){super(),this.light=e,this.light.updateMatrixWorld(),this.matrix=e.matrixWorld,this.matrixAutoUpdate=!1,this.color=t;const i=new Ni,n=[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];for(let e=0,t=1,i=32;i>e;e++,t++){const r=e/i*Math.PI*2,o=t/i*Math.PI*2;n.push(Math.cos(r),Math.sin(r),1,Math.cos(o),Math.sin(o),1)}i.setAttribute("position",new Bi(n,3));const r=new Sa({fog:!1,toneMapped:!1});this.cone=new La(i,r),this.add(this.cone),this.update()}dispose(){this.cone.geometry.dispose(),this.cone.material.dispose()}update(){this.light.updateMatrixWorld();const e=this.light.distance?this.light.distance:1e3,t=e*Math.tan(this.light.angle);this.cone.scale.set(t,t,e),Mh.setFromMatrixPosition(this.light.target.matrixWorld),this.cone.lookAt(Mh),void 0!==this.color?this.cone.material.color.set(this.color):this.cone.material.color.copy(this.light.color)}},Sprite:aa,SpriteMaterial:Wo,SrcAlphaFactor:204,SrcAlphaSaturateFactor:210,SrcColorFactor:202,StaticCopyUsage:35046,StaticDrawUsage:pe,StaticReadUsage:35045,StereoCamera:class{constructor(){this.type="StereoCamera",this.aspect=1,this.eyeSep=.064,this.cameraL=new dn,this.cameraL.layers.enable(1),this.cameraL.matrixAutoUpdate=!1,this.cameraR=new dn,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}}update(e){const 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;const i=e.projectionMatrix.clone(),n=t.eyeSep/2,r=n*t.near/t.focus,o=t.near*Math.tan(ve*t.fov*.5)/t.zoom;let a,s;Nc.elements[12]=-n,Oc.elements[12]=n,a=-o*t.aspect+r,s=o*t.aspect+r,i.elements[0]=2*t.near/(s-a),i.elements[8]=(s+a)/(s-a),this.cameraL.projectionMatrix.copy(i),a=-o*t.aspect-r,s=o*t.aspect-r,i.elements[0]=2*t.near/(s-a),i.elements[8]=(s+a)/(s-a),this.cameraR.projectionMatrix.copy(i)}this.cameraL.matrixWorld.copy(e.matrixWorld).multiply(Nc),this.cameraR.matrixWorld.copy(e.matrixWorld).multiply(Oc)}},StreamCopyUsage:35042,StreamDrawUsage:35040,StreamReadUsage:35041,StringKeyframeTrack:Al,SubtractEquation:101,SubtractiveBlending:3,TOUCH:{ROTATE:0,PAN:1,DOLLY_PAN:2,DOLLY_ROTATE:3},TangentSpaceNormalMap:0,TetrahedronBufferGeometry:Vs,TetrahedronGeometry:Vs,TextBufferGeometry:Ys,TextGeometry:Ys,Texture:Fe,TextureLoader:Dl,TorusBufferGeometry:Hs,TorusGeometry:Hs,TorusKnotBufferGeometry:js,TorusKnotGeometry:js,Triangle:ri,TriangleFanDrawMode:2,TriangleStripDrawMode:1,TrianglesDrawMode:0,TubeBufferGeometry:Ws,TubeGeometry:Ws,UVMapping:s,Uint16Attribute:function(e,t){return console.warn("THREE.Uint16Attribute has been removed. Use new THREE.Uint16BufferAttribute() instead."),new xi(e,t)},Uint16BufferAttribute:xi,Uint32Attribute:function(e,t){return console.warn("THREE.Uint32Attribute has been removed. Use new THREE.Uint32BufferAttribute() instead."),new Mi(e,t)},Uint32BufferAttribute:Mi,Uint8Attribute:function(e,t){return console.warn("THREE.Uint8Attribute has been removed. Use new THREE.Uint8BufferAttribute() instead."),new vi(e,t)},Uint8BufferAttribute:vi,Uint8ClampedAttribute:function(e,t){return console.warn("THREE.Uint8ClampedAttribute has been removed. Use new THREE.Uint8ClampedBufferAttribute() instead."),new Ci(e,t)},Uint8ClampedBufferAttribute:Ci,Uniform:uh,UniformsLib:wn,UniformsUtils:ln,UnsignedByteType:w,UnsignedInt248Type:b,UnsignedIntType:E,UnsignedShort4444Type:1017,UnsignedShort5551Type:1018,UnsignedShort565Type:1019,UnsignedShortType:M,VSMShadowMap:3,Vector2:ke,Vector3:Ke,Vector4:Le,VectorKeyframeTrack:yl,Vertex:function(e,t,i){return console.warn("THREE.Vertex has been removed. Use THREE.Vector3 instead."),new Ke(e,t,i)},VertexColors:2,VideoTexture:ja,WebGL1Renderer:No,WebGLCubeRenderTarget:fn,WebGLMultipleRenderTargets:Ne,WebGLMultisampleRenderTarget:Pe,WebGLRenderTarget:Oe,WebGLRenderTargetCube:function(e,t,i){return console.warn("THREE.WebGLRenderTargetCube( width, height, options ) is now WebGLCubeRenderTarget( size, options )."),new fn(e,i)},WebGLRenderer:Oo,WebGLRendererEx:Po,WebGLUtils:ko,WireframeGeometry:Js,WireframeHelper:function(e,t){return console.warn("THREE.WireframeHelper has been removed. Use THREE.WireframeGeometry instead."),new La(new Js(e.geometry),new Sa({color:void 0!==t?t:16777215}))},WrapAroundEnding:z,XHRLoader:function(e){return console.warn("THREE.XHRLoader has been renamed to THREE.FileLoader."),new Bl(e)},ZeroCurvatureEnding:W,ZeroFactor:o,ZeroSlopeEnding:J,ZeroStencilOp:0,sRGBEncoding:_}),xd={SceneSize:1e3,getDataFromIndexedDB:!0,TextureResRoot:"images/",UserControlView:!1,FillCavity:!1,EnableClippingCaps:!0,EnableBoxClippingCaps:!1,EnableTextureMapping:!0,EnableTextureLoading:!0,EnableLightmap:!1,EnableTransformAoMap:!0,LightmapIntensity:1,ClippingCaps:!1,SelectionColor:{color:2205669,side:2,opacity:.8,transparent:!0},DisableAntialias:!1,EnableZoomToComponentByDClick:!0,IsMobile:!1,UseWorker:!1,ZipResourcePostfix:"",HasLayerData:!1,Renderer:1,Instance:!0,MergeComponent:!1,AutoMergeComponent:!0,AutoMergeComponentCount:1e4,MaxMergeCount:1e3,MergedTriangleNumberThreshold:2e7,MaxMergedTriangleNumber:2e7,IncrementRender:!1,EnableRenderPass:!1,LimitFrameTime:250,maxObjectNumInPool:1e3,maxDrawCacheNum:4e4,OctantDepth:15,MaximumDepth:0,TargetDistance:1e4,ConcurrencyRequestCount:16,ShowOctant:!1,EnableOctant:!1,EnableViewController:!0,DirectionalLight:!0,LightPreset:2,IBL:!1,ToneMapping:4,LightIntensityFactor:1,Hover:!1,OcclusionTranslucentEnabled:!1,OcclusionOpacity:.5,OcclusionDistanceToCamera:1e3,LineSelectRange:30,DrawingStyle:0,DrawingBoardlineEnabled:!0,InitWireframeData:!1,EnableHitDetection:!1,TranslucentDepthDisabled:!1,SharedMeshInstanceEnable:!1,DataProvider:0,EnableSelectionOutline:!0,EnableSelectionByTranslucent:!1,EnableSelectionBoundingBox:!1,EnableShadow:!1,EnableAnimation:!0,UseLods:!1,AutoPrepare:!0,DEBUG:!1,WalkingWithGravity:!1,WalkingWithViewLock:!1,RendererWhenLoad:!1,language:"zh-cn",LoadComponentOnDemand:!1,EnableLogarithmicDepthBuffer:!1,InfluencedByLight:!0,geometricErrorThresholdValue:80,MaximumAvailableMemory:500,DataReduction:!1,ConstraintZoom:!1,stepLoad:!1,useGzip:!1,notDepthWriteByTransparent:!1,PickingEffect:!0,PickingLineWidthEnabled:!0,loadBatch:!0,MiniMapSize:1024,alphaTest:.5,EnableCreateMiniMap:!1,MultipleSelectComponents:!0,UseReaderWorker:!1,ContinueRender:!1,KeepViewState:!1,usePack:!1};Object.defineProperties(xd,{logarithmicDepthBuffer:{set:function(e){this.EnableLogarithmicDepthBuffer=e},get:function(){return this.EnableLogarithmicDepthBuffer}}});var wd=bt.RotationOrders,Md={ORTHOGRAPHIC:"orth",PERSPECTIVE:"persp"},Ed={elements:[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1]},Bd={elements:[1,0,0,0,1,0,0,0,1]},Sd={IfcOpeningElement:!0,IfcSpace:!0,OST_Rooms:!0,"房间":!0};Object.defineProperties(Sd,{"房间":{get:function(){return Sd.OST_Rooms},set:function(e){Sd.OST_Rooms=e}}});var bd=new(Proxy||function(e){return e})(Sd,{deleteProperty:function(e,t){t in e&&("房间"===t&&delete e.OST_Rooms,delete e[t])}}),kd={Keep:0,Home:135,Top:1,Bottom:2,Front:3,Back:4,Right:5,Left:6,TopFrontRight:135,TopFrontLeft:136,TopBackRight:145,TopBackLeft:146,BottomFrontRight:235,BottomFrontLeft:236,BottomBackRight:245,BottomBackLeft:246,TopFront:13,TopBack:14,TopRight:15,TopLeft:16,BottomFront:23,BottomBack:24,BottomRight:25,BottomLeft:26,FrontRight:35,FrontLeft:36,BackRight:45,BackLeft:46,TopToRight:105,TopToLeft:106,TopToFront:103,TopToBack:104,BottomToRight:205,BottomToLeft:206,BottomToFront:203,BottomToBack:204,FrontToTop:301,FrontToBottom:302,FrontToRight:305,FrontToLeft:306,BackToTop:401,BackToBottom:402,BackToRight:405,BackToLeft:406,RightToTop:501,RightToBottom:502,RightToFront:503,RightToBack:504,LeftToTop:601,LeftTopBottom:602,LeftTopFront:603,LeftTopBack:604},Dd={DirectionalLight:"directional",AmbientLight:"ambient",PointLight:"point",SpotLight:"spot"},Td={Clear:0,Add:1,Remove:2},Rd={Geometry:1,Marker3d:2,Room:3,ExternalComponent:4,UnPickable:0},Ud=0,Fd={ON_LOAD_START:Ud+=1,ON_LOAD_PROGRESS:Ud+=1,ON_LOAD_COMPLETE:Ud+=1,ON_DEMAND_LOAD_COMPLETE:Ud+=1,ON_LOAD_EMPTY_SCENE:Ud+=1,ON_LOAD_CONFIG_FINISH:Ud+=1,ON_LOAD_INVALID_SCENE:Ud+=1,ON_LOAD_INVALID_DATA:Ud+=1,ON_NETWORK_ERROR:Ud+=1,ACCOUNT_NO_EXIST:Ud+=1,NO_PERMISSION:Ud+=1,ON_LOAD_ERROR:Ud+=1,ON_SELECTION_CHANGED:Ud+=1,ON_RECTPICK_ADD:Ud+=1,ON_RECTPICK_REMOVE:Ud+=1,ON_CLICK_PICK:Ud+=1,ON_AXIS_GRID_HOVER:Ud+=1,ON_HOVER_PICK:Ud+=1,ON_MEASURE_PICK:Ud+=1,ON_SELECTION_FAILED:Ud+=1,ON_CLIP_HOVER:Ud+=1,ON_HOVER_SNAP:Ud+=1,ON_CLIP_MOUSE_MOVE:Ud+=1,ON_CLIP_MOUSE_DOWN:Ud+=1,ON_TOOL_END:Ud+=1,ON_VERSION_NO_MATCH:Ud+=1,ON_VIEWER_RESTORED:Ud+=1,ON_CAMERA_HEIGHT_CHANGED:Ud+=1,ON_CAMERA_CHANGED_AND_RENDERED:Ud+=1,ON_DATABASE_OPEN:Ud+=1,ON_DATABASE_CLOSE:Ud+=1,ON_DATABASE_ADD:Ud+=1,ON_DATABASE_DELETE:Ud+=1,ON_DATABASE_CLERA:Ud+=1,ON_DATABASE_EEEOR:Ud+=1,BEFORE_RESETSCENE:Ud+=1,AFTER_RESETSCENE:Ud+=1,ON_CAMERA_CHANGE:Ud+=1,ON_CONTROL_ENTER:Ud+=1,ON_CONTROL_EXIST:Ud+=1,ON_POINTERLOCK_EXIST:Ud+=1,ON_CONTROL_BEGIN:Ud+=1,ON_CONTROL_END:Ud+=1,ON_CONTROL_MOUSEMOVE:Ud+=1,ON_CONTROL_ZOOM:Ud+=1,ON_CONTROL_UPDATEUI:Ud+=1,ON_CONTROL_KEYDOWN:Ud+=1,ON_CONTROL_KEYUP:Ud+=1,ON_CONTROL_PANING:Ud+=1,ON_CONTROL_ROTATING:Ud+=1,ON_CONTROL_WALKING:Ud+=1,ON_CAMERA_ANIMATION_UPDATE:Ud+=1,ON_MOUSE_DRAGGED:Ud+=1,ON_EARTH_ANIMATION_COMPLETE:Ud+=1},Qd={LOAD_COMPONENT_ERROR:Ud+=1,LOAD_MATERIAL_ERROR:Ud+=1,LOAD_GEOMETRY_ERROR:Ud+=1,LOAD_COMPONENTNODE_ERROR:Ud+=1,LOAD_TEXTURE_ERROR:Ud+=1,LOAD_AXISNET_ERROR:Ud+=1,LOAD_FLOORINFO_ERROR:Ud+=1,PARSEFAILE:Ud+=1,PARSING:Ud+=1,IS2D:Ud+=1,LOAD_ERROR:Ud+=1,SCENE_NOT_CLOSE:Ud+=1,SCENE_NOTHING_TO_LOAD:Ud+=1,LOAD_SCENE_ERROR:Ud+=1,LOAD_SYMBOL_ERROR:Ud+=1,LOAD_OCTREEINNER_ERROR:Ud+=1,LOAD_OCTREEOUTER_ERROR:Ud+=1,LOAD_USERID_ERROR:Ud+=1,LOAD_USERDATA_ERROR:Ud+=1,LOAD_CAMERA_ERROR:Ud+=1,LOAD_MPK_ERROR:Ud+=1,LOAD_IBLCONFIG_ERROR:Ud+=1},Ld={MOUSEPOINT:0,SELECTION:1,CENTER:2,CAMERA:3},Od={FILE_VISIBLE:0,FILE_HIDDEN:1,SELECTED:2,VISIBLE:3,HIDDEN:4,TRANSLUCENT:5,TRANSLUCENT_OTHERS:6,WIREFRAME:7,COLORFUL:8},Nd={Visible:1,HideByIsolate:2,Transparent:4,TransparentByIsolate:8},Pd={HIDDEN:0,HIDDEN_OTHERS:1,TRANSLUCENT:2,TRANSLUCENT_OTHERS:3},Gd={TRANSLUCENT:"TRANSLUCENT",OPAQUE:"OPAQUE"},Kd={DISABLED:0,TRANSLUCENT:1,HIDDEN:2},Vd={ORBIT:"orbit",PICK:"pick",PAN:"pan",ZOOM:"zoom",FLY:"fly",WALK:"walk",THIRDPERSONWALK:"thirdpersonwalk"},Yd={PICK_BY_RECT:"pickByRect",ZOOM_BY_RECT:"zoomByRect",CLIP_BY_BOX:"clipByBox",CLIP_FILL:"fillClip",PICK_BY_MEASURE:"pickByMeasure",COMPONENT_TRANSFORM:"componentTransform"},Hd={NONE:0,UP:1,DOWN:2,LEFT:4,RIGHT:8,FORWARD:16,BACK:32},jd={SHADING:0,BOARDLINE:1,SHADINGWITHLINE:2},Wd={HIDDEN:-1,NONE:0,HOVER:1,SELECTED:2,OVERRIDED:3,TRANSPARENT:4,BLINK:5},Jd={NONE:0,BLINK:1,SELECT:2},zd={AUTO:0,DEFAULT:1,MERGED:2,LAYER:3,LAYER_SCENE:4},qd={MATCH_RETURN_TRUE:0,MATCH_RETURN_FALSE:1,NOMATCH_RETURN_TRUE:2,NOMATCH_RETURN_FALSE:3},Zd={CLIPPING:-2,HIDDEN:-1,NONE:0,SELECTED:1,BLINK:2,HOVER:3,TRANSPARENT:4,OVERRIDED:5,NEWBLINK:6},Xd={RVT:"RVT",IFC:"IFC",I_MODEL:"I-MODEL",THREE_DS:"3DS",MERGE:"MERGE",DAE:"DAE",DWG:"DWG",OBJ:"OBJ",FBX:"FBX",SCENE:"SCENE",ARRAY:"ARRAY"},_d=Object.freeze({Meter:"Meter",Millimeter:"Millimeter"}),$d="ON_VIEWER3D_CAMERA_CHANGE",eu=function(e,t){this.viewer2D=t,this.viewer3D=e,this.enableFocus(),this.show3DCameraOn2DViewer()};function tu(e,t){var i=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),i.push.apply(i,n)}return i}function iu(e){for(var t=1;arguments.length>t;t++){var i=null!=arguments[t]?arguments[t]:{};t%2?tu(Object(i),!0).forEach((function(t){su(e,t,i[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(i)):tu(Object(i)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(i,t))}))}return e}function nu(e){return(nu="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e})(e)}function ru(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function ou(e,t){for(var i=0;t.length>i;i++){var n=t[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(e,n.key,n)}}function au(e,t,i){return t&&ou(e.prototype,t),i&&ou(e,i),e}function su(e,t,i){return t in e?Object.defineProperty(e,t,{value:i,enumerable:!0,configurable:!0,writable:!0}):e[t]=i,e}function lu(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function");e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,writable:!0,configurable:!0}}),t&&hu(e,t)}function cu(e){return(cu=Object.setPrototypeOf?Object.getPrototypeOf:function(e){return e.__proto__||Object.getPrototypeOf(e)})(e)}function hu(e,t){return(hu=Object.setPrototypeOf||function(e,t){return e.__proto__=t,e})(e,t)}function du(e){if(void 0===e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return e}function uu(e,t){if(t&&("object"==typeof t||"function"==typeof t))return t;if(void 0!==t)throw new TypeError("Derived constructors may only return object or undefined");return du(e)}function pu(e){var t=function(){if("undefined"==typeof Reflect||!Reflect.construct)return!1;if(Reflect.construct.sham)return!1;if("function"==typeof Proxy)return!0;try{return Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],(function(){}))),!0}catch(e){return!1}}();return function(){var i,n=cu(e);if(t){var r=cu(this).constructor;i=Reflect.construct(n,arguments,r)}else i=n.apply(this,arguments);return uu(this,i)}}function gu(e,t,i){return(gu="undefined"!=typeof Reflect&&Reflect.get?Reflect.get:function(e,t,i){var n=function(e,t){for(;!Object.prototype.hasOwnProperty.call(e,t)&&null!==(e=cu(e)););return e}(e,t);if(n){var r=Object.getOwnPropertyDescriptor(n,t);return r.get?r.get.call(i):r.value}})(e,t,i||e)}function fu(e,t){return function(e){if(Array.isArray(e))return e}(e)||function(e,t){var i=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null==i)return;var n,r,o=[],a=!0,s=!1;try{for(i=i.call(e);!(a=(n=i.next()).done)&&(o.push(n.value),!t||o.length!==t);a=!0);}catch(e){s=!0,r=e}finally{try{a||null==i.return||i.return()}finally{if(s)throw r}}return o}(e,t)||Au(e,t)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function mu(e){return function(e){if(Array.isArray(e))return yu(e)}(e)||function(e){if("undefined"!=typeof Symbol&&null!=e[Symbol.iterator]||null!=e["@@iterator"])return Array.from(e)}(e)||Au(e)||function(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function Au(e,t){if(e){if("string"==typeof e)return yu(e,t);var i=Object.prototype.toString.call(e).slice(8,-1);return"Object"===i&&e.constructor&&(i=e.constructor.name),"Map"===i||"Set"===i?Array.from(e):"Arguments"===i||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(i)?yu(e,t):void 0}}function yu(e,t){(null==t||t>e.length)&&(t=e.length);for(var i=0,n=new Array(t);t>i;i++)n[i]=e[i];return n}function vu(e,t){var i="undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(!i){if(Array.isArray(e)||(i=Au(e))||t&&e&&"number"==typeof e.length){i&&(e=i);var n=0,r=function(){};return{s:r,n:function(){return e.length>n?{done:!1,value:e[n++]}:{done:!0}},e:function(e){throw e},f: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.")}var o,a=!0,s=!1;return{s:function(){i=i.call(e)},n:function(){var e=i.next();return a=e.done,e},e:function(e){s=!0,o=e},f:function(){try{a||null==i.return||i.return()}finally{if(s)throw o}}}}eu.prototype.enableFocus=function(){var e=this.viewer2D,t=this.viewer3D;t&&e&&(e.setOnSelectComponentCallback((function(e){e&&e.length>0?(t.highlightComponentsByKey(e),t.adaptiveSizeByKey(e)):t.clearHighlightList()})),t.registerModelEventListener(Fd.ON_CLICK_PICK,(function(t){t.intersectInfo&&t.intersectInfo.selectedObjectId&&e.focusOnComponentByKey(t.intersectInfo.selectedObjectId,!0)})))},eu.prototype.enableMove2DCamera=function(){this.viewer2D.getViewerImpl().controlManager.enableTool(this.viewer2D.getViewerImpl(),"viewer3DCameraControl")},eu.prototype.disableMove2DCamera=function(){this.viewer2D.getViewerImpl().controlManager.disableTool("viewer3DCameraControl")},eu.prototype.show3DCameraOn2DViewer=function(){var e=this.viewer2D,t=this.viewer3D;if(t&&e){var i=t.getViewerImpl();t.registerCameraEventListener(Fd.ON_CAMERA_CHANGE,(function(t){var i=t.camera,n=i.getWorldPosition(new Ke),r=i.getWorldDirection(new Ke);e.show3DCamera([n.x,n.y],[r.x,r.y])})),e.getViewerImpl().cameraControl.addEventListener($d,(function(e){var t=e.position;i.locateToPoint({x:t[0],y:t[1],z:i.camera.position.z})}))}};var Cu={clamp:function(e,t,i){return Math.max(t,Math.min(i,e))},euclideanModulo:function(e,t){return(e%t+t)%t}},Iu={DEBUG:6,PERFORMANCE:5,LOG:4,INFO:3,WARNING:2,ERROR:1,NONE:0},xu={},wu=function(e){xu[e]?console.warn("[BOS3D Time]:","Timer '"+e+"' already exists"):xu[e]=Date.now()},Mu=function(e){xu[e]?(console.warn("[BOS3D Time]:",e+":",Date.now()-xu[e],"ms"),delete xu[e]):console.warn("[BOS3D Time]:","Timer '"+e+"' does not exist")};function Eu(){this.level=-1,this.setLevel(Iu.LOG)}Eu.prototype.setLevel=function(e){if(this.level!==e){this.level=e;var t=function(){},i=Iu,n=this;this.debug=i.DEBUG>e?t:function(){var e=["[BOS3D Debug]:"].concat(Array.prototype.slice.call(arguments));console.debug.apply(console,e)},this.trace=i.DEBUG>e?t:function(){var e=["[BOS3D Trace]:"].concat(Array.prototype.slice.call(arguments));console.trace.apply(console,e)},this.assert=i.DEBUG>e?t:function(){var e=["[BOS3D Assert]:"].concat(Array.prototype.slice.call(arguments));console.assert.apply(console,e)},this.count=i.DEBUG>e?t:function(){var e=["[BOS3D Count]:"].concat(Array.prototype.slice.call(arguments));console.count.apply(console,e)},this.dir=i.DEBUG>e?t:function(){var e=["[BOS3D Dir]:"].concat(Array.prototype.slice.call(arguments));console.dir.apply(console,e)},this.time=i.PERFORMANCE>e?t:wu,this.timeEnd=i.PERFORMANCE>e?t:Mu,this.log=i.LOG>e?t:function(){var e=["[BOS3D Log]:"].concat(Array.prototype.slice.call(arguments));console.log.apply(console,e)},this.info=i.INFO>e?t:console.info.bind(console),this.warn=i.WARNING>e?t:function(){var e=["[BOS3D Warn]:"].concat(Array.prototype.slice.call(arguments));console.warn.apply(console,e)},this.error=i.ERROR>e?t:function(){if(n.callback){var e=Array.prototype.slice.call(arguments).join(" ");n.callback({category:"error",message:e},{adp:!1})}var t=["[BOS3D Error]:"].concat(Array.prototype.slice.call(arguments));console.error.apply(console,t)}}};var Bu=new Eu,Su={aliceblue:15792383,antiquewhite:16444375,aqua:65535,aquamarine:8388564,azure:15794175,beige:16119260,bisque:16770244,black:0,blanchedalmond:16772045,blue:255,blueviolet:9055202,brown:10824234,burlywood:14596231,cadetblue:6266528,chartreuse:8388352,chocolate:13789470,coral:16744272,cornflowerblue:6591981,cornsilk:16775388,crimson:14423100,cyan:65535,darkblue:139,darkcyan:35723,darkgoldenrod:12092939,darkgray:11119017,darkgreen:25600,darkgrey:11119017,darkkhaki:12433259,darkmagenta:9109643,darkolivegreen:5597999,darkorange:16747520,darkorchid:10040012,darkred:9109504,darksalmon:15308410,darkseagreen:9419919,darkslateblue:4734347,darkslategray:3100495,darkslategrey:3100495,darkturquoise:52945,darkviolet:9699539,deeppink:16716947,deepskyblue:49151,dimgray:6908265,dimgrey:6908265,dodgerblue:2003199,firebrick:11674146,floralwhite:16775920,forestgreen:2263842,fuchsia:16711935,gainsboro:14474460,ghostwhite:16316671,gold:16766720,goldenrod:14329120,gray:8421504,green:32768,greenyellow:11403055,grey:8421504,honeydew:15794160,hotpink:16738740,indianred:13458524,indigo:4915330,ivory:16777200,khaki:15787660,lavender:15132410,lavenderblush:16773365,lawngreen:8190976,lemonchiffon:16775885,lightblue:11393254,lightcoral:15761536,lightcyan:14745599,lightgoldenrodyellow:16448210,lightgray:13882323,lightgreen:9498256,lightgrey:13882323,lightpink:16758465,lightsalmon:16752762,lightseagreen:2142890,lightskyblue:8900346,lightslategray:7833753,lightslategrey:7833753,lightsteelblue:11584734,lightyellow:16777184,lime:65280,limegreen:3329330,linen:16445670,magenta:16711935,maroon:8388608,mediumaquamarine:6737322,mediumblue:205,mediumorchid:12211667,mediumpurple:9662683,mediumseagreen:3978097,mediumslateblue:8087790,mediumspringgreen:64154,mediumturquoise:4772300,mediumvioletred:13047173,midnightblue:1644912,mintcream:16121850,mistyrose:16770273,moccasin:16770229,navajowhite:16768685,navy:128,oldlace:16643558,olive:8421376,olivedrab:7048739,orange:16753920,orangered:16729344,orchid:14315734,palegoldenrod:15657130,palegreen:10025880,paleturquoise:11529966,palevioletred:14381203,papayawhip:16773077,peachpuff:16767673,peru:13468991,pink:16761035,plum:14524637,powderblue:11591910,purple:8388736,rebeccapurple:6697881,red:16711680,rosybrown:12357519,royalblue:4286945,saddlebrown:9127187,salmon:16416882,sandybrown:16032864,seagreen:3050327,seashell:16774638,sienna:10506797,silver:12632256,skyblue:8900331,slateblue:6970061,slategray:7372944,slategrey:7372944,snow:16775930,springgreen:65407,steelblue:4620980,tan:13808780,teal:32896,thistle:14204888,tomato:16737095,turquoise:4251856,violet:15631086,wheat:16113331,white:16777215,whitesmoke:16119285,yellow:16776960,yellowgreen:10145074};function bu(e,t,i){return 0>i&&(i+=1),i>1&&(i-=1),1/6>i?e+6*(t-e)*i:.5>i?t:2/3>i?e+6*(t-e)*(2/3-i):e}var ku,Du=function(e,t,i,n){return void 0===n&&void 0===i?this.set(e,t):this.setRGB(e,t,i,n)};Object.assign(Du.prototype,{isColor:!0,r:1,g:1,b:1,a:1,set:function(e,t){return"number"==typeof e?this.setHex(e):"string"==typeof e&&this.setStyle(e),void 0!==t&&this.setAlpha(t),this},setHex:function(e,t){return e=Math.floor(e),this.r=(e>>16&255)/255,this.g=(e>>8&255)/255,this.b=(255&e)/255,this.setAlpha(t),this},setAlpha:function(e){return"number"==typeof e?(e>1&&(e=1),0>e&&(e=0),this.a=e):isNaN(parseFloat(e))?this.a=1:((e=parseFloat(e))>1&&(e=1),0>e&&(e=0),this.a=e),this},setRGB:function(e,t,i,n){return this.r=e>1?Math.min(255,parseInt(e,10))/255:e,this.g=t>1?Math.min(255,parseInt(t,10))/255:t,this.b=i>1?Math.min(255,parseInt(i,10))/255:i,this.setAlpha(n),this},setHSL:function(e,t,i,n){if(e=Cu.euclideanModulo(e,1),t=Cu.clamp(t,0,1),i=Cu.clamp(i,0,1),0===t)this.r=this.g=this.b=i;else{var r=i>.5?i+t-i*t:i*(1+t),o=2*i-r;this.r=bu(o,r,e+1/3),this.g=bu(o,r,e),this.b=bu(o,r,e-1/3)}return this.a=n,this},setStyle:function(e){var t=null;if(t=/^((?:rgb|hsl)a?)\(\s*([^\)]*)\)/.exec(e)){var i=null,n=t[2];switch(t[1]){case"rgb":case"rgba":if(i=/^(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*(,\s*([0-9]*\.?[0-9]+)\s*)?$/.exec(n))return this.r=Math.min(255,parseInt(i[1],10))/255,this.g=Math.min(255,parseInt(i[2],10))/255,this.b=Math.min(255,parseInt(i[3],10))/255,this.setAlpha(i[5]),this;if(i=/^(\d+)\%\s*,\s*(\d+)\%\s*,\s*(\d+)\%\s*(,\s*([0-9]*\.?[0-9]+)\s*)?$/.exec(n))return this.r=Math.min(100,parseInt(i[1],10))/100,this.g=Math.min(100,parseInt(i[2],10))/100,this.b=Math.min(100,parseInt(i[3],10))/100,this.setAlpha(i[5]),this;break;case"hsl":case"hsla":if(i=/^([0-9]*\.?[0-9]+)\s*,\s*(\d+)\%\s*,\s*(\d+)\%\s*(,\s*([0-9]*\.?[0-9]+)\s*)?$/.exec(n)){var r=parseFloat(i[1])/360,o=parseInt(i[2],10)/100,a=parseInt(i[3],10)/100;return this.setAlpha(i[5]),this.setHSL(r,o,a)}}}else if(t=/^\#([A-Fa-f0-9]+)$/.exec(e)){var s,l=(s=t[1]).length;if(3===l)return this.r=parseInt(s.charAt(0)+s.charAt(0),16)/255,this.g=parseInt(s.charAt(1)+s.charAt(1),16)/255,this.b=parseInt(s.charAt(2)+s.charAt(2),16)/255,this;if(6===l)return this.r=parseInt(s.charAt(0)+s.charAt(1),16)/255,this.g=parseInt(s.charAt(2)+s.charAt(3),16)/255,this.b=parseInt(s.charAt(4)+s.charAt(5),16)/255,this}e&&e.length>0&&(void 0!==(s=Su[e])?this.setHex(s):Bu.warn("Color: Unknown color "+e));return this},getHex:function(){return 255*this.r<<16^255*this.g<<8^255*this.b<<0},getHexString:function(){return("000000"+this.getHex().toString(16)).slice(-6)},getHSL:function(){var e={h:0,s:0,l:0,a:1},t=this.r,i=this.g,n=this.b,r=Math.max(t,i,n),o=Math.min(t,i,n),a=0,s=0,l=(o+r)/2;if(o===r)a=0,s=0;else{var c=r-o;switch(s=l>.5?c/(2-r-o):c/(r+o),r){case t:a=(i-n)/c+(n>i?6:0);break;case i:a=(n-t)/c+2;break;case n:a=(t-i)/c+4}a/=6}return e.h=a,e.s=s,e.l=l,e.a=this.a,e},getRGB:function(){return"rgb("+(255*this.r|0)+","+(255*this.g|0)+","+(255*this.b|0)+")"},getRGBA:function(){return"rgba("+(255*this.r|0)+","+(255*this.g|0)+","+(255*this.b|0)+","+this.a+")"},getAlpha:function(){return this.a},getStyle:function(){return"rgb("+(255*this.r|0)+","+(255*this.g|0)+","+(255*this.b|0)+")"},offsetHSL:(ku={},function(e,t,i){return this.getHSL(ku),ku.h+=e,ku.s+=t,ku.l+=i,this.setHSL(ku.h,ku.s,ku.l),this}),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.a=e[t+3]||1,this},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+3]=this.a,e},toRGBArray:function(e,t){return void 0===e&&(e=[]),void 0===t&&(t=0),e[t]=255*this.r,e[t+1]=255*this.g,e[t+2]=255*this.b,e[t+3]=255*this.a,e},toJSON:function(){return this.getHex()}}),Object.defineProperties(Du.prototype,{red:{get:function(){return this.r},set:function(e){this.r=e}},green:{get:function(){return this.g},set:function(e){this.g=e}},blue:{get:function(){return this.b},set:function(e){this.b=e}},alpha:{get:function(){return this.a},set:function(e){this.a=e}},opacity:{get:function(){return this.a},set:function(e){this.a=e}}});var Tu=function(e){lu(i,e);var t=pu(i);function i(e,n){var r;ru(this,i),(r=t.call(this,e)).type="Reflector";var o=du(r),a=new pi(void 0!==(n=n||{}).color?n.color:16777215),s=n.textureWidth||512,l=n.textureHeight||512,c=n.clipBias||0,h=n.shader||i.ReflectorShader,d=void 0!==n.recursion?n.recursion:0,u=new Jt,p=new Ke,g=new Ke,f=new Ke,m=new yt,A=new Ke(0,0,-1),y=new Le,v=new Ke,I=new Ke,x=new Le,w=new yt,M=new dn,E=new Oe(s,l,{minFilter:C,magFilter:C,format:k,stencilBuffer:!1});be.isPowerOfTwo(s)&&be.isPowerOfTwo(l)||(E.texture.generateMipmaps=!1);var B=new cn({uniforms:ln.clone(h.uniforms),fragmentShader:h.fragmentShader,vertexShader:h.vertexShader});return B.uniforms.tDiffuse.value=E.texture,B.uniforms.color.value=a,B.uniforms.textureMatrix.value=w,r.material=B,r.onBeforeRender=function(e,t,i){if("recursion"in i.userData){if(i.userData.recursion===d)return;i.userData.recursion+=1}if(g.setFromMatrixPosition(o.matrixWorld),f.setFromMatrixPosition(i.matrixWorld),m.extractRotation(o.matrixWorld),p.set(0,0,1),p.applyMatrix4(m),v.subVectors(g,f),0>=v.dot(p)){v.reflect(p).negate(),v.add(g),m.extractRotation(i.matrixWorld),A.set(0,0,-1),A.applyMatrix4(m),A.add(f),I.subVectors(g,A),I.reflect(p).negate(),I.add(g),M.position.copy(v),M.up.set(0,1,0),M.up.applyMatrix4(m),M.up.reflect(p),M.lookAt(I),M.far=i.far,M.updateMatrixWorld(),M.matrixWorldInverse.copy(M.matrixWorld).invert(),M.projectionMatrix.copy(i.projectionMatrix),M.userData.recursion=0,w.set(.5,0,0,.5,0,.5,0,.5,0,0,.5,.5,0,0,0,1),w.multiply(M.projectionMatrix),w.multiply(M.matrixWorldInverse),w.multiply(o.matrixWorld),u.setFromNormalAndCoplanarPoint(p,g),u.applyMatrix4(M.matrixWorldInverse),y.set(u.normal.x,u.normal.y,u.normal.z,u.constant);var n=M.projectionMatrix;x.x=(Math.sign(y.x)+n.elements[8])/n.elements[0],x.y=(Math.sign(y.y)+n.elements[9])/n.elements[5],x.z=-1,x.w=(1+n.elements[10])/n.elements[14],y.multiplyScalar(2/y.dot(x)),n.elements[2]=y.x,n.elements[6]=y.y,n.elements[10]=y.z+1-c,n.elements[14]=y.w,E.texture.encoding=e.outputEncoding,o.visible=!1;var r=e.getRenderTarget(),a=e.xr.enabled,s=e.shadowMap.autoUpdate;e.xr.enabled=!1,e.shadowMap.autoUpdate=!1,e.setRenderTarget(E),e.state.buffers.depth.setMask(!0),!1===e.autoClear&&e.clear(),e.render(t,M),e.xr.enabled=a,e.shadowMap.autoUpdate=s,e.setRenderTarget(r);var l=i.viewport;void 0!==l&&e.state.viewport(l),o.visible=!0}},r.getRenderTarget=function(){return E},r}return i}(nn);Tu.ReflectorShader={uniforms:{color:{value:null},tDiffuse:{value:null},textureMatrix:{value:null}},vertexShader:["uniform mat4 textureMatrix;","varying vec4 vUv;","void main() {"," vUv = textureMatrix * vec4( position, 1.0 );"," gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );","}"].join("\n"),fragmentShader:["uniform vec3 color;","uniform sampler2D tDiffuse;","varying vec4 vUv;","float blendOverlay( float base, float blend ) {"," return( base < 0.5 ? ( 2.0 * base * blend ) : ( 1.0 - 2.0 * ( 1.0 - base ) * ( 1.0 - blend ) ) );","}","vec3 blendOverlay( vec3 base, vec3 blend ) {"," return vec3( blendOverlay( base.r, blend.r ), blendOverlay( base.g, blend.g ), blendOverlay( base.b, blend.b ) );","}","void main() {"," vec4 base = texture2DProj( tDiffuse, vUv );"," gl_FragColor = vec4( blendOverlay( base.rgb, color ), 1.0 );","}"].join("\n")};var Ru=function(e){lu(i,e);var t=pu(i);function i(e,n){var r;ru(this,i),(r=t.call(this,e)).type="Refractor";var o=du(r),a=new pi(void 0!==(n=n||{}).color?n.color:8355711),s=n.textureWidth||512,l=n.textureHeight||512,c=n.clipBias||0,h=n.shader||i.RefractorShader,d=new dn;d.matrixAutoUpdate=!1,d.userData.refractor=!0;var u=new Jt,p=new yt,g=new Oe(s,l,{minFilter:C,magFilter:C,format:k,stencilBuffer:!1});be.isPowerOfTwo(s)&&be.isPowerOfTwo(l)||(g.texture.generateMipmaps=!1),r.material=new cn({uniforms:ln.clone(h.uniforms),vertexShader:h.vertexShader,fragmentShader:h.fragmentShader,transparent:!0}),r.material.uniforms.color.value=a,r.material.uniforms.tDiffuse.value=g.texture,r.material.uniforms.textureMatrix.value=p;var f,m,A,y,v,I=(f=new Ke,m=new Ke,A=new yt,y=new Ke,v=new Ke,function(e){return f.setFromMatrixPosition(o.matrixWorld),m.setFromMatrixPosition(e.matrixWorld),y.subVectors(f,m),A.extractRotation(o.matrixWorld),v.set(0,0,1),v.applyMatrix4(A),0>y.dot(v)}),x=function(){var e=new Ke,t=new Ke,i=new Ge,n=new Ke;return function(){o.matrixWorld.decompose(t,i,n),e.set(0,0,1).applyQuaternion(i).normalize(),e.negate(),u.setFromNormalAndCoplanarPoint(e,t)}}(),w=function(){var e=new Jt,t=new Le,i=new Le;return function(n){d.matrixWorld.copy(n.matrixWorld),d.matrixWorldInverse.copy(d.matrixWorld).invert(),d.projectionMatrix.copy(n.projectionMatrix),d.far=n.far,e.copy(u),e.applyMatrix4(d.matrixWorldInverse),t.set(e.normal.x,e.normal.y,e.normal.z,e.constant);var r=d.projectionMatrix;i.x=(Math.sign(t.x)+r.elements[8])/r.elements[0],i.y=(Math.sign(t.y)+r.elements[9])/r.elements[5],i.z=-1,i.w=(1+r.elements[10])/r.elements[14],t.multiplyScalar(2/t.dot(i)),r.elements[2]=t.x,r.elements[6]=t.y,r.elements[10]=t.z+1-c,r.elements[14]=t.w}}();return r.onBeforeRender=function(e,t,i){g.texture.encoding=e.outputEncoding,!0!==i.userData.refractor&&!0!=!I(i)&&(x(),function(e){p.set(.5,0,0,.5,0,.5,0,.5,0,0,.5,.5,0,0,0,1),p.multiply(e.projectionMatrix),p.multiply(e.matrixWorldInverse),p.multiply(o.matrixWorld)}(i),w(i),function(e,t,i){o.visible=!1;var n=e.getRenderTarget(),r=e.xr.enabled,a=e.shadowMap.autoUpdate;e.xr.enabled=!1,e.shadowMap.autoUpdate=!1,e.setRenderTarget(g),!1===e.autoClear&&e.clear(),e.render(t,d),e.xr.enabled=r,e.shadowMap.autoUpdate=a,e.setRenderTarget(n);var s=i.viewport;void 0!==s&&e.state.viewport(s),o.visible=!0}(e,t,i))},r.getRenderTarget=function(){return g},r}return i}(nn);Ru.RefractorShader={uniforms:{color:{value:null},tDiffuse:{value:null},textureMatrix:{value:null}},vertexShader:["uniform mat4 textureMatrix;","varying vec4 vUv;","void main() {"," vUv = textureMatrix * vec4( position, 1.0 );"," gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );","}"].join("\n"),fragmentShader:["uniform vec3 color;","uniform sampler2D tDiffuse;","varying vec4 vUv;","float blendOverlay( float base, float blend ) {"," return( base < 0.5 ? ( 2.0 * base * blend ) : ( 1.0 - 2.0 * ( 1.0 - base ) * ( 1.0 - blend ) ) );","}","vec3 blendOverlay( vec3 base, vec3 blend ) {"," return vec3( blendOverlay( base.r, blend.r ), blendOverlay( base.g, blend.g ), blendOverlay( base.b, blend.b ) );","}","void main() {"," vec4 base = texture2DProj( tDiffuse, vUv );"," gl_FragColor = vec4( blendOverlay( base.rgb, color ), 1.0 );","}"].join("\n")};var Uu=function(e){lu(i,e);var t=pu(i);function i(e){var n;return ru(this,i),(n=t.call(this)).points=e,n.handlePoints=[],n.minX=0,n.minY=0,n.maxX=0,n.maxY=0,n.invalid=!1,n._createPlaneGeometry(),n}return i}(Ni);Uu.prototype._createPlaneGeometry=function(){var e=this;if(e._RemoveDuplicatePoints(e.points))this.invalid=!0;else{if(3>e.handlePoints.length)return Bu.warn("Failed to create plane, the number of the points must be more than three."),void(this.invalid=!0);if(3===e.handlePoints.length&&0===e._area(e.handlePoints[0],e.handlePoints[1],e.handlePoints[2]))return Bu.warn("Failed to create plane, points are collinear."),void(this.invalid=!0);if(e._checkIntersect())return Bu.warn("Failed to create plane, the plane border is self-intersecting."),void(this.invalid=!0);e.handlePoints.push(new ke(e.points[0].x,e.points[0].y));var t=new $l(e.handlePoints),i=new Gs(t),n=new Float32Array(e._updateUv(i));i.setAttribute("uv",new Ai(n,2)),this.attributes=i.attributes,this.groups=i.groups,this.index=i.index}},Uu.prototype._updateUv=function(e){for(var t=this,i=[],n=e.attributes.position.array,r=0;n.length>r;r+=3){var o=(n[r+1]-t.minY)/(t.maxY-t.minY);i.push((n[r]-t.minX)/(t.maxX-t.minX)),i.push(o)}return i},Uu.prototype._RemoveDuplicatePoints=function(e){var t=this,i=new ke(e[0].x,e[0].y);t.handlePoints.push(i),t.minX=i.x,t.maxX=i.x,t.minY=i.y,t.maxY=i.y;for(var n=1;e.length>n;n+=1){var r=!1;if(void 0===e[n].x||void 0===e[n].y)return Bu.log("Failed to create plane, the format of plane is not right, please follow [{x:,y:},...]"),!0;for(var o=0;t.handlePoints.length>o;o+=1)if(e[n].x===t.handlePoints[o].x&&e[n].y===t.handlePoints[o].y){r=!0;break}if(!1===r){i=new ke(e[n].x,e[n].y);t.handlePoints.push(i),t.minX>i.x&&(t.minX=i.x),t.minY>i.y&&(t.minY=i.y),i.x>t.maxX&&(t.maxX=i.x),i.y>t.maxY&&(t.maxY=i.y)}}return!1},Uu.prototype._checkIntersect=function(){for(var e=this,t=null,i=null,n=e.handlePoints.length,r=0;n>r;r+=1){t=e.handlePoints[r],i=e.handlePoints[r===n-1?0:r+1];for(var o=r+2;n>o;o+=1)if((0!==r||o!==n-1)&&e._intersectSegments(t,i,e.handlePoints[o],e.handlePoints[o===n-1?0:o+1]))return!0}return!1},Uu.prototype._area=function(e,t,i){return(t.x-e.x)*(i.y-e.y)-(i.x-e.x)*(t.y-e.y)},Uu.prototype._collinearIntersectCheck=function(e,t,i,n){return(Math.min(e.x,t.x)>i.x||i.x>Math.max(e.x,t.x)||Math.min(e.y,t.y)>i.y||i.y>Math.max(e.y,t.y))&&(Math.min(e.x,t.x)>n.x||n.x>Math.max(e.x,t.x)||Math.min(e.y,t.y)>n.y||n.y>Math.max(e.y,t.y))},Uu.prototype._intersectSegments=function(e,t,i,n){var r=this._area(e,t,i)*this._area(e,t,n),o=this._area(i,n,e)*this._area(i,n,t);return 0>=r&&(0>=o&&(0!==r||0!==o||!this._collinearIntersectCheck(e,t,i,n)))};var Fu=function(){function e(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,i=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:0,r=arguments.length>3&&void 0!==arguments[3]?arguments[3]:1;ru(this,e),this._x=t,this._y=i,this._z=n,this._w=r}return au(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()}},{key:"set",value:function(e,t,i,n){return this._x=e,this._y=t,this._z=i,this._w=n,this._onChangeCallback(),this}},{key:"clone",value:function(){return new this.constructor(this._x,this._y,this._z,this._w)}},{key:"copy",value:function(e){return this._x=e.x,this._y=e.y,this._z=e.z,this._w=e.w,this._onChangeCallback(),this}},{key:"setFromEuler",value: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 i=e._x,n=e._y,r=e._z,o=e._order,a=Math.cos,s=Math.sin,l=a(i/2),c=a(n/2),h=a(r/2),d=s(i/2),u=s(n/2),p=s(r/2);switch(o){case"XYZ":this._x=d*c*h+l*u*p,this._y=l*u*h-d*c*p,this._z=l*c*p+d*u*h,this._w=l*c*h-d*u*p;break;case"YXZ":this._x=d*c*h+l*u*p,this._y=l*u*h-d*c*p,this._z=l*c*p-d*u*h,this._w=l*c*h+d*u*p;break;case"ZXY":this._x=d*c*h-l*u*p,this._y=l*u*h+d*c*p,this._z=l*c*p+d*u*h,this._w=l*c*h-d*u*p;break;case"ZYX":this._x=d*c*h-l*u*p,this._y=l*u*h+d*c*p,this._z=l*c*p-d*u*h,this._w=l*c*h+d*u*p;break;case"YZX":this._x=d*c*h+l*u*p,this._y=l*u*h+d*c*p,this._z=l*c*p-d*u*h,this._w=l*c*h-d*u*p;break;case"XZY":this._x=d*c*h-l*u*p,this._y=l*u*h-d*c*p,this._z=l*c*p+d*u*h,this._w=l*c*h+d*u*p;break;default:console.warn("THREE.Quaternion: .setFromEuler() encountered an unknown order: "+o)}return!1!==t&&this._onChangeCallback(),this}},{key:"setFromAxisAngle",value:function(e,t){var i=t/2,n=Math.sin(i);return this._x=e.x*n,this._y=e.y*n,this._z=e.z*n,this._w=Math.cos(i),this._onChangeCallback(),this}},{key:"setFromRotationMatrix",value:function(e){var t=e.elements,i=t[0],n=t[4],r=t[8],o=t[1],a=t[5],s=t[9],l=t[2],c=t[6],h=t[10],d=i+a+h;if(d>0){var u=.5/Math.sqrt(d+1);this._w=.25/u,this._x=(c-s)*u,this._y=(r-l)*u,this._z=(o-n)*u}else if(i>a&&i>h){var p=2*Math.sqrt(1+i-a-h);this._w=(c-s)/p,this._x=.25*p,this._y=(n+o)/p,this._z=(r+l)/p}else if(a>h){var g=2*Math.sqrt(1+a-i-h);this._w=(r-l)/g,this._x=(n+o)/g,this._y=.25*g,this._z=(s+c)/g}else{var f=2*Math.sqrt(1+h-i-a);this._w=(o-n)/f,this._x=(r+l)/f,this._y=(s+c)/f,this._z=.25*f}return this._onChangeCallback(),this}},{key:"setFromUnitVectors",value:function(e,t){var i=e.dot(t)+1;return Number.EPSILON>i?(i=0,Math.abs(e.x)>Math.abs(e.z)?(this._x=-e.y,this._y=e.x,this._z=0,this._w=i):(this._x=0,this._y=-e.z,this._z=e.y,this._w=i)):(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=i),this.normalize()}},{key:"angleTo",value:function(e){return 2*Math.acos(Math.abs(Cu.clamp(this.dot(e),-1,1)))}},{key:"rotateTowards",value:function(e,t){var i=this.angleTo(e);if(0===i)return this;var n=Math.min(1,t/i);return this.slerp(e,n),this}},{key:"identity",value:function(){return this.set(0,0,0,1)}},{key:"invert",value:function(){return this.conjugate()}},{key:"conjugate",value:function(){return this._x*=-1,this._y*=-1,this._z*=-1,this._onChangeCallback(),this}},{key:"dot",value:function(e){return this._x*e._x+this._y*e._y+this._z*e._z+this._w*e._w}},{key:"lengthSq",value:function(){return this._x*this._x+this._y*this._y+this._z*this._z+this._w*this._w}},{key:"length",value:function(){return Math.sqrt(this._x*this._x+this._y*this._y+this._z*this._z+this._w*this._w)}},{key:"normalize",value:function(){var e=this.length();return 0===e?(this._x=0,this._y=0,this._z=0,this._w=1):(this._x=this._x*(e=1/e),this._y=this._y*e,this._z=this._z*e,this._w=this._w*e),this._onChangeCallback(),this}},{key:"multiply",value: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)}},{key:"premultiply",value:function(e){return this.multiplyQuaternions(e,this)}},{key:"multiplyQuaternions",value:function(e,t){var i=e._x,n=e._y,r=e._z,o=e._w,a=t._x,s=t._y,l=t._z,c=t._w;return this._x=i*c+o*a+n*l-r*s,this._y=n*c+o*s+r*a-i*l,this._z=r*c+o*l+i*s-n*a,this._w=o*c-i*a-n*s-r*l,this._onChangeCallback(),this}},{key:"slerp",value:function(e,t){if(0===t)return this;if(1===t)return this.copy(e);var i=this._x,n=this._y,r=this._z,o=this._w,a=o*e._w+i*e._x+n*e._y+r*e._z;if(0>a?(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=i,this._y=n,this._z=r,this;var s=1-a*a;if(Number.EPSILON>=s){var l=1-t;return this._w=l*o+t*this._w,this._x=l*i+t*this._x,this._y=l*n+t*this._y,this._z=l*r+t*this._z,this.normalize(),this._onChangeCallback(),this}var c=Math.sqrt(s),h=Math.atan2(c,a),d=Math.sin((1-t)*h)/c,u=Math.sin(t*h)/c;return this._w=o*d+this._w*u,this._x=i*d+this._x*u,this._y=n*d+this._y*u,this._z=r*d+this._z*u,this._onChangeCallback(),this}},{key:"slerpQuaternions",value:function(e,t,i){this.copy(e).slerp(t,i)}},{key:"equals",value:function(e){return e._x===this._x&&e._y===this._y&&e._z===this._z&&e._w===this._w}},{key:"fromArray",value:function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0;return this._x=e[t],this._y=e[t+1],this._z=e[t+2],this._w=e[t+3],this._onChangeCallback(),this}},{key:"toArray",value:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:[],t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0;return e[t]=this._x,e[t+1]=this._y,e[t+2]=this._z,e[t+3]=this._w,e}},{key:"fromBufferAttribute",value: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}},{key:"_onChange",value:function(e){return this._onChangeCallback=e,this}},{key:"_onChangeCallback",value:function(){}}],[{key:"slerp",value:function(e,t,i,n){return console.warn("THREE.Quaternion: Static .slerp() has been deprecated. Use qm.slerpQuaternions( qa, qb, t ) instead."),i.slerpQuaternions(e,t,n)}},{key:"slerpFlat",value:function(e,t,i,n,r,o,a){var s=i[n+0],l=i[n+1],c=i[n+2],h=i[n+3],d=r[o+0],u=r[o+1],p=r[o+2],g=r[o+3];if(0===a)return e[t+0]=s,e[t+1]=l,e[t+2]=c,void(e[t+3]=h);if(1===a)return e[t+0]=d,e[t+1]=u,e[t+2]=p,void(e[t+3]=g);if(h!==g||s!==d||l!==u||c!==p){var f=1-a,m=s*d+l*u+c*p+h*g,A=0>m?-1:1,y=1-m*m;if(y>Number.EPSILON){var v=Math.sqrt(y),C=Math.atan2(v,m*A);f=Math.sin(f*C)/v,a=Math.sin(a*C)/v}var I=a*A;if(s=s*f+d*I,l=l*f+u*I,c=c*f+p*I,h=h*f+g*I,f===1-a){var x=1/Math.sqrt(s*s+l*l+c*c+h*h);s*=x,l*=x,c*=x,h*=x}}e[t]=s,e[t+1]=l,e[t+2]=c,e[t+3]=h}},{key:"multiplyQuaternionsFlat",value:function(e,t,i,n,r,o){var a=i[n],s=i[n+1],l=i[n+2],c=i[n+3],h=r[o],d=r[o+1],u=r[o+2],p=r[o+3];return e[t]=a*p+c*h+s*u-l*d,e[t+1]=s*p+c*d+l*h-a*u,e[t+2]=l*p+c*u+a*d-s*h,e[t+3]=c*p-a*h-s*d-l*u,e}}]),e}();Fu.prototype.isQuaternion=!0;var Qu=function(){function e(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,i=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:0;ru(this,e),this.x=t,this.y=i,this.z=n}return au(e,[{key:"set",value:function(e,t,i){return void 0===i&&(i=this.z),this.x=e,this.y=t,this.z=i,this}},{key:"setScalar",value:function(e){return this.x=e,this.y=e,this.z=e,this}},{key:"setX",value:function(e){return this.x=e,this}},{key:"setY",value:function(e){return this.y=e,this}},{key:"setZ",value:function(e){return this.z=e,this}},{key:"setComponent",value: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}},{key:"getComponent",value: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)}}},{key:"clone",value:function(){return new this.constructor(this.x,this.y,this.z)}},{key:"copy",value:function(e){return this.x=e.x,this.y=e.y,this.z=e.z,this}},{key:"add",value: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)}},{key:"addScalar",value:function(e){return this.x+=e,this.y+=e,this.z+=e,this}},{key:"addVectors",value:function(e,t){return this.x=e.x+t.x,this.y=e.y+t.y,this.z=e.z+t.z,this}},{key:"addScaledVector",value:function(e,t){return this.x+=e.x*t,this.y+=e.y*t,this.z+=e.z*t,this}},{key:"sub",value: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)}},{key:"subScalar",value:function(e){return this.x-=e,this.y-=e,this.z-=e,this}},{key:"subVectors",value:function(e,t){return this.x=e.x-t.x,this.y=e.y-t.y,this.z=e.z-t.z,this}},{key:"multiply",value: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)}},{key:"multiplyScalar",value:function(e){return this.x*=e,this.y*=e,this.z*=e,this}},{key:"multiplyVectors",value:function(e,t){return this.x=e.x*t.x,this.y=e.y*t.y,this.z=e.z*t.z,this}},{key:"applyEuler",value:function(e){return e&&e.isEuler||console.error("THREE.Vector3: .applyEuler() now expects an Euler rotation rather than a Vector3 and order."),this.applyQuaternion(Ou.setFromEuler(e))}},{key:"applyAxisAngle",value:function(e,t){return this.applyQuaternion(Ou.setFromAxisAngle(e,t))}},{key:"applyMatrix3",value:function(e){var t=this.x,i=this.y,n=this.z,r=e.elements;return this.x=r[0]*t+r[3]*i+r[6]*n,this.y=r[1]*t+r[4]*i+r[7]*n,this.z=r[2]*t+r[5]*i+r[8]*n,this}},{key:"applyNormalMatrix",value:function(e){return this.applyMatrix3(e).normalize()}},{key:"applyMatrix4",value:function(e){var t=this.x,i=this.y,n=this.z,r=e.elements,o=1/(r[3]*t+r[7]*i+r[11]*n+r[15]);return this.x=(r[0]*t+r[4]*i+r[8]*n+r[12])*o,this.y=(r[1]*t+r[5]*i+r[9]*n+r[13])*o,this.z=(r[2]*t+r[6]*i+r[10]*n+r[14])*o,this}},{key:"applyQuaternion",value:function(e){var t=this.x,i=this.y,n=this.z,r=e.x,o=e.y,a=e.z,s=e.w,l=s*t+o*n-a*i,c=s*i+a*t-r*n,h=s*n+r*i-o*t,d=-r*t-o*i-a*n;return this.x=l*s+d*-r+c*-a-h*-o,this.y=c*s+d*-o+h*-r-l*-a,this.z=h*s+d*-a+l*-o-c*-r,this}},{key:"project",value:function(e){return this.applyMatrix4(e.matrixWorldInverse).applyMatrix4(e.projectionMatrix)}},{key:"unproject",value:function(e){return this.applyMatrix4(e.projectionMatrixInverse).applyMatrix4(e.matrixWorld)}},{key:"transformDirection",value:function(e){var t=this.x,i=this.y,n=this.z,r=e.elements;return this.x=r[0]*t+r[4]*i+r[8]*n,this.y=r[1]*t+r[5]*i+r[9]*n,this.z=r[2]*t+r[6]*i+r[10]*n,this.normalize()}},{key:"divide",value:function(e){return this.x/=e.x,this.y/=e.y,this.z/=e.z,this}},{key:"divideScalar",value:function(e){return this.multiplyScalar(1/e)}},{key:"min",value: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}},{key:"max",value: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}},{key:"clamp",value: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}},{key:"clampScalar",value: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}},{key:"clampLength",value:function(e,t){var i=this.length();return this.divideScalar(i||1).multiplyScalar(Math.max(e,Math.min(t,i)))}},{key:"floor",value:function(){return this.x=Math.floor(this.x),this.y=Math.floor(this.y),this.z=Math.floor(this.z),this}},{key:"ceil",value:function(){return this.x=Math.ceil(this.x),this.y=Math.ceil(this.y),this.z=Math.ceil(this.z),this}},{key:"round",value:function(){return this.x=Math.round(this.x),this.y=Math.round(this.y),this.z=Math.round(this.z),this}},{key:"roundToZero",value:function(){return this.x=0>this.x?Math.ceil(this.x):Math.floor(this.x),this.y=0>this.y?Math.ceil(this.y):Math.floor(this.y),this.z=0>this.z?Math.ceil(this.z):Math.floor(this.z),this}},{key:"negate",value:function(){return this.x=-this.x,this.y=-this.y,this.z=-this.z,this}},{key:"dot",value:function(e){return this.x*e.x+this.y*e.y+this.z*e.z}},{key:"lengthSq",value:function(){return this.x*this.x+this.y*this.y+this.z*this.z}},{key:"length",value:function(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z)}},{key:"manhattanLength",value:function(){return Math.abs(this.x)+Math.abs(this.y)+Math.abs(this.z)}},{key:"normalize",value:function(){return this.divideScalar(this.length()||1)}},{key:"setLength",value:function(e){return this.normalize().multiplyScalar(e)}},{key:"lerp",value: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}},{key:"lerpVectors",value:function(e,t,i){return this.x=e.x+(t.x-e.x)*i,this.y=e.y+(t.y-e.y)*i,this.z=e.z+(t.z-e.z)*i,this}},{key:"cross",value: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)}},{key:"crossVectors",value:function(e,t){var i=e.x,n=e.y,r=e.z,o=t.x,a=t.y,s=t.z;return this.x=n*s-r*a,this.y=r*o-i*s,this.z=i*a-n*o,this}},{key:"projectOnVector",value:function(e){var t=e.lengthSq();if(0===t)return this.set(0,0,0);var i=e.dot(this)/t;return this.copy(e).multiplyScalar(i)}},{key:"projectOnPlane",value:function(e){return Lu.copy(this).projectOnVector(e),this.sub(Lu)}},{key:"reflect",value:function(e){return this.sub(Lu.copy(e).multiplyScalar(2*this.dot(e)))}},{key:"angleTo",value:function(e){var t=Math.sqrt(this.lengthSq()*e.lengthSq());if(0===t)return Math.PI/2;var i=this.dot(e)/t;return Math.acos(Cu.clamp(i,-1,1))}},{key:"distanceTo",value:function(e){return Math.sqrt(this.distanceToSquared(e))}},{key:"distanceToSquared",value:function(e){var t=this.x-e.x,i=this.y-e.y,n=this.z-e.z;return t*t+i*i+n*n}},{key:"manhattanDistanceTo",value:function(e){return Math.abs(this.x-e.x)+Math.abs(this.y-e.y)+Math.abs(this.z-e.z)}},{key:"setFromSpherical",value:function(e){return this.setFromSphericalCoords(e.radius,e.phi,e.theta)}},{key:"setFromSphericalCoords",value:function(e,t,i){var n=Math.sin(t)*e;return this.x=n*Math.sin(i),this.y=Math.cos(t)*e,this.z=n*Math.cos(i),this}},{key:"setFromCylindrical",value:function(e){return this.setFromCylindricalCoords(e.radius,e.theta,e.y)}},{key:"setFromCylindricalCoords",value:function(e,t,i){return this.x=e*Math.sin(t),this.y=i,this.z=e*Math.cos(t),this}},{key:"setFromMatrixPosition",value:function(e){var t=e.elements;return this.x=t[12],this.y=t[13],this.z=t[14],this}},{key:"setFromMatrixScale",value:function(e){var t=this.setFromMatrixColumn(e,0).length(),i=this.setFromMatrixColumn(e,1).length(),n=this.setFromMatrixColumn(e,2).length();return this.x=t,this.y=i,this.z=n,this}},{key:"setFromMatrixColumn",value:function(e,t){return this.fromArray(e.elements,4*t)}},{key:"setFromMatrix3Column",value:function(e,t){return this.fromArray(e.elements,3*t)}},{key:"equals",value:function(e){return e.x===this.x&&e.y===this.y&&e.z===this.z}},{key:"fromArray",value:function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0;return this.x=e[t],this.y=e[t+1],this.z=e[t+2],this}},{key:"toArray",value:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:[],t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0;return e[t]=this.x,e[t+1]=this.y,e[t+2]=this.z,e}},{key:"fromBufferAttribute",value:function(e,t,i){return void 0!==i&&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}},{key:"random",value:function(){return this.x=Math.random(),this.y=Math.random(),this.z=Math.random(),this}}]),e}();Qu.prototype.isVector3=!0;var Lu=new Qu,Ou=new Fu,Nu=function(){function e(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:new Qu(1/0,1/0,1/0),i=arguments.length>1&&void 0!==arguments[1]?arguments[1]:new Qu(-1/0,-1/0,-1/0);ru(this,e),this.min=t,this.max=i}return au(e,[{key:"set",value:function(e,t){return this.min.copy(e),this.max.copy(t),this}},{key:"setFromArray",value:function(e){for(var t=1/0,i=1/0,n=1/0,r=-1/0,o=-1/0,a=-1/0,s=0,l=e.length;l>s;s+=3){var c=e[s],h=e[s+1],d=e[s+2];t>c&&(t=c),i>h&&(i=h),n>d&&(n=d),c>r&&(r=c),h>o&&(o=h),d>a&&(a=d)}return this.min.set(t,i,n),this.max.set(r,o,a),this}},{key:"setFromBufferAttribute",value:function(e){for(var t=1/0,i=1/0,n=1/0,r=-1/0,o=-1/0,a=-1/0,s=0,l=e.count;l>s;s++){var c=e.getX(s),h=e.getY(s),d=e.getZ(s);t>c&&(t=c),i>h&&(i=h),n>d&&(n=d),c>r&&(r=c),h>o&&(o=h),d>a&&(a=d)}return this.min.set(t,i,n),this.max.set(r,o,a),this}},{key:"setFromPoints",value:function(e){this.makeEmpty();for(var t=0,i=e.length;i>t;t++)this.expandByPoint(e[t]);return this}},{key:"setFromCenterAndSize",value:function(e,t){var i=Gu.copy(t).multiplyScalar(.5);return this.min.copy(e).sub(i),this.max.copy(e).add(i),this}},{key:"setFromObject",value:function(e){return this.makeEmpty(),this.expandByObject(e)}},{key:"clone",value:function(){return(new this.constructor).copy(this)}},{key:"copy",value:function(e){return this.min.copy(e.min),this.max.copy(e.max),this}},{key:"makeEmpty",value: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}},{key:"isEmpty",value:function(){return this.min.x>this.max.x||this.min.y>this.max.y||this.min.z>this.max.z}},{key:"getCenter",value:function(e){return void 0===e&&(console.warn("THREE.Box3: .getCenter() target is now required"),e=new Qu),this.isEmpty()?e.set(0,0,0):e.addVectors(this.min,this.max).multiplyScalar(.5)}},{key:"getSize",value:function(e){return void 0===e&&(console.warn("THREE.Box3: .getSize() target is now required"),e=new Qu),this.isEmpty()?e.set(0,0,0):e.subVectors(this.max,this.min)}},{key:"expandByPoint",value:function(e){return this.min.min(e),this.max.max(e),this}},{key:"expandByVector",value:function(e){return this.min.sub(e),this.max.add(e),this}},{key:"expandByScalar",value:function(e){return this.min.addScalar(-e),this.max.addScalar(e),this}},{key:"expandByObject",value:function(e){e.updateWorldMatrix(!1,!1);var t=e.geometry;void 0!==t&&(null===t.boundingBox&&t.computeBoundingBox(),Ku.copy(t.boundingBox),Ku.applyMatrix4(e.matrixWorld),this.union(Ku));for(var i=e.children,n=0,r=i.length;r>n;n++)this.expandByObject(i[n]);return this}},{key:"containsPoint",value:function(e){return!(this.min.x>e.x||e.x>this.max.x||this.min.y>e.y||e.y>this.max.y||this.min.z>e.z||e.z>this.max.z)}},{key:"containsBox",value: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)}},{key:"getParameter",value:function(e,t){return void 0===t&&(console.warn("THREE.Box3: .getParameter() target is now required"),t=new Qu),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))}},{key:"intersectsBox",value:function(e){return!(this.min.x>e.max.x||e.min.x>this.max.x||this.min.y>e.max.y||e.min.y>this.max.y||this.min.z>e.max.z||e.min.z>this.max.z)}},{key:"intersectsSphere",value:function(e){return this.clampPoint(e.center,Gu),Gu.distanceToSquared(e.center)<=e.radius*e.radius}},{key:"intersectsPlane",value:function(e){var t,i;return e.normal.x>0?(t=e.normal.x*this.min.x,i=e.normal.x*this.max.x):(t=e.normal.x*this.max.x,i=e.normal.x*this.min.x),e.normal.y>0?(t+=e.normal.y*this.min.y,i+=e.normal.y*this.max.y):(t+=e.normal.y*this.max.y,i+=e.normal.y*this.min.y),e.normal.z>0?(t+=e.normal.z*this.min.z,i+=e.normal.z*this.max.z):(t+=e.normal.z*this.max.z,i+=e.normal.z*this.min.z),-e.constant>=t&&i>=-e.constant}},{key:"intersectsTriangle",value:function(e){if(this.isEmpty())return!1;this.getCenter(zu),qu.subVectors(this.max,zu),Vu.subVectors(e.a,zu),Yu.subVectors(e.b,zu),Hu.subVectors(e.c,zu),ju.subVectors(Yu,Vu),Wu.subVectors(Hu,Yu),Ju.subVectors(Vu,Hu);var t=[0,-ju.z,ju.y,0,-Wu.z,Wu.y,0,-Ju.z,Ju.y,ju.z,0,-ju.x,Wu.z,0,-Wu.x,Ju.z,0,-Ju.x,-ju.y,ju.x,0,-Wu.y,Wu.x,0,-Ju.y,Ju.x,0];return!!_u(t,Vu,Yu,Hu,qu)&&(!!_u(t=[1,0,0,0,1,0,0,0,1],Vu,Yu,Hu,qu)&&(Zu.crossVectors(ju,Wu),_u(t=[Zu.x,Zu.y,Zu.z],Vu,Yu,Hu,qu)))}},{key:"clampPoint",value:function(e,t){return void 0===t&&(console.warn("THREE.Box3: .clampPoint() target is now required"),t=new Qu),t.copy(e).clamp(this.min,this.max)}},{key:"distanceToPoint",value:function(e){return Gu.copy(e).clamp(this.min,this.max).sub(e).length()}},{key:"getBoundingSphere",value:function(e){return void 0===e&&console.error("THREE.Box3: .getBoundingSphere() target is now required"),this.getCenter(e.center),e.radius=.5*this.getSize(Gu).length(),e}},{key:"intersect",value:function(e){return this.min.max(e.min),this.max.min(e.max),this.isEmpty()&&this.makeEmpty(),this}},{key:"union",value:function(e){return this.min.min(e.min),this.max.max(e.max),this}},{key:"applyMatrix4",value:function(e){return this.isEmpty()||(Pu[0].set(this.min.x,this.min.y,this.min.z).applyMatrix4(e),Pu[1].set(this.min.x,this.min.y,this.max.z).applyMatrix4(e),Pu[2].set(this.min.x,this.max.y,this.min.z).applyMatrix4(e),Pu[3].set(this.min.x,this.max.y,this.max.z).applyMatrix4(e),Pu[4].set(this.max.x,this.min.y,this.min.z).applyMatrix4(e),Pu[5].set(this.max.x,this.min.y,this.max.z).applyMatrix4(e),Pu[6].set(this.max.x,this.max.y,this.min.z).applyMatrix4(e),Pu[7].set(this.max.x,this.max.y,this.max.z).applyMatrix4(e),this.setFromPoints(Pu)),this}},{key:"translate",value:function(e){return this.min.add(e),this.max.add(e),this}},{key:"equals",value:function(e){return e.min.equals(this.min)&&e.max.equals(this.max)}}]),e}();Nu.prototype.isBox3=!0;var Pu=[new Qu,new Qu,new Qu,new Qu,new Qu,new Qu,new Qu,new Qu],Gu=new Qu,Ku=new Nu,Vu=new Qu,Yu=new Qu,Hu=new Qu,ju=new Qu,Wu=new Qu,Ju=new Qu,zu=new Qu,qu=new Qu,Zu=new Qu,Xu=new Qu;function _u(e,t,i,n,r){for(var o=0,a=e.length-3;a>=o;o+=3){Xu.fromArray(e,o);var s=r.x*Math.abs(Xu.x)+r.y*Math.abs(Xu.y)+r.z*Math.abs(Xu.z),l=t.dot(Xu),c=i.dot(Xu),h=n.dot(Xu);if(Math.max(-Math.max(l,c,h),Math.min(l,c,h))>s)return!1}return!0}var $u=function(){function e(){ru(this,e),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.")}return au(e,[{key:"set",value:function(e,t,i,n,r,o,a,s,l,c,h,d,u,p,g,f){var m=this.elements;return m[0]=e,m[4]=t,m[8]=i,m[12]=n,m[1]=r,m[5]=o,m[9]=a,m[13]=s,m[2]=l,m[6]=c,m[10]=h,m[14]=d,m[3]=u,m[7]=p,m[11]=g,m[15]=f,this}},{key:"identity",value:function(){return this.set(1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1),this}},{key:"clone",value:function(){return(new e).fromArray(this.elements)}},{key:"copy",value:function(e){var t=this.elements,i=e.elements;return t[0]=i[0],t[1]=i[1],t[2]=i[2],t[3]=i[3],t[4]=i[4],t[5]=i[5],t[6]=i[6],t[7]=i[7],t[8]=i[8],t[9]=i[9],t[10]=i[10],t[11]=i[11],t[12]=i[12],t[13]=i[13],t[14]=i[14],t[15]=i[15],this}},{key:"copyPosition",value:function(e){var t=this.elements,i=e.elements;return t[12]=i[12],t[13]=i[13],t[14]=i[14],this}},{key:"setFromMatrix3",value: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}},{key:"extractBasis",value:function(e,t,i){return e.setFromMatrixColumn(this,0),t.setFromMatrixColumn(this,1),i.setFromMatrixColumn(this,2),this}},{key:"makeBasis",value:function(e,t,i){return this.set(e.x,t.x,i.x,0,e.y,t.y,i.y,0,e.z,t.z,i.z,0,0,0,0,1),this}},{key:"extractRotation",value:function(e){var t=this.elements,i=e.elements,n=1/ep.setFromMatrixColumn(e,0).length(),r=1/ep.setFromMatrixColumn(e,1).length(),o=1/ep.setFromMatrixColumn(e,2).length();return t[0]=i[0]*n,t[1]=i[1]*n,t[2]=i[2]*n,t[3]=0,t[4]=i[4]*r,t[5]=i[5]*r,t[6]=i[6]*r,t[7]=0,t[8]=i[8]*o,t[9]=i[9]*o,t[10]=i[10]*o,t[11]=0,t[12]=0,t[13]=0,t[14]=0,t[15]=1,this}},{key:"makeRotationFromEuler",value: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,i=e.x,n=e.y,r=e.z,o=Math.cos(i),a=Math.sin(i),s=Math.cos(n),l=Math.sin(n),c=Math.cos(r),h=Math.sin(r);if("XYZ"===e.order){var d=o*c,u=o*h,p=a*c,g=a*h;t[0]=s*c,t[4]=-s*h,t[8]=l,t[1]=u+p*l,t[5]=d-g*l,t[9]=-a*s,t[2]=g-d*l,t[6]=p+u*l,t[10]=o*s}else if("YXZ"===e.order){var f=s*c,m=s*h,A=l*c,y=l*h;t[0]=f+y*a,t[4]=A*a-m,t[8]=o*l,t[1]=o*h,t[5]=o*c,t[9]=-a,t[2]=m*a-A,t[6]=y+f*a,t[10]=o*s}else if("ZXY"===e.order){var v=s*c,C=s*h,I=l*c,x=l*h;t[0]=v-x*a,t[4]=-o*h,t[8]=I+C*a,t[1]=C+I*a,t[5]=o*c,t[9]=x-v*a,t[2]=-o*l,t[6]=a,t[10]=o*s}else if("ZYX"===e.order){var w=o*c,M=o*h,E=a*c,B=a*h;t[0]=s*c,t[4]=E*l-M,t[8]=w*l+B,t[1]=s*h,t[5]=B*l+w,t[9]=M*l-E,t[2]=-l,t[6]=a*s,t[10]=o*s}else if("YZX"===e.order){var S=o*s,b=o*l,k=a*s,D=a*l;t[0]=s*c,t[4]=D-S*h,t[8]=k*h+b,t[1]=h,t[5]=o*c,t[9]=-a*c,t[2]=-l*c,t[6]=b*h+k,t[10]=S-D*h}else if("XZY"===e.order){var T=o*s,R=o*l,U=a*s,F=a*l;t[0]=s*c,t[4]=-h,t[8]=l*c,t[1]=T*h+F,t[5]=o*c,t[9]=R*h-U,t[2]=U*h-R,t[6]=a*c,t[10]=F*h+T}return t[3]=0,t[7]=0,t[11]=0,t[12]=0,t[13]=0,t[14]=0,t[15]=1,this}},{key:"makeRotationFromQuaternion",value:function(e){return this.compose(ip,e,np)}},{key:"lookAt",value:function(e,t,i){var n=this.elements;return ap.subVectors(e,t),0===ap.lengthSq()&&(ap.z=1),ap.normalize(),rp.crossVectors(i,ap),0===rp.lengthSq()&&(1===Math.abs(i.z)?ap.x+=1e-4:ap.z+=1e-4,ap.normalize(),rp.crossVectors(i,ap)),rp.normalize(),op.crossVectors(ap,rp),n[0]=rp.x,n[4]=op.x,n[8]=ap.x,n[1]=rp.y,n[5]=op.y,n[9]=ap.y,n[2]=rp.z,n[6]=op.z,n[10]=ap.z,this}},{key:"multiply",value: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)}},{key:"premultiply",value:function(e){return this.multiplyMatrices(e,this)}},{key:"multiplyMatrices",value:function(e,t){var i=e.elements,n=t.elements,r=this.elements,o=i[0],a=i[4],s=i[8],l=i[12],c=i[1],h=i[5],d=i[9],u=i[13],p=i[2],g=i[6],f=i[10],m=i[14],A=i[3],y=i[7],v=i[11],C=i[15],I=n[0],x=n[4],w=n[8],M=n[12],E=n[1],B=n[5],S=n[9],b=n[13],k=n[2],D=n[6],T=n[10],R=n[14],U=n[3],F=n[7],Q=n[11],L=n[15];return r[0]=o*I+a*E+s*k+l*U,r[4]=o*x+a*B+s*D+l*F,r[8]=o*w+a*S+s*T+l*Q,r[12]=o*M+a*b+s*R+l*L,r[1]=c*I+h*E+d*k+u*U,r[5]=c*x+h*B+d*D+u*F,r[9]=c*w+h*S+d*T+u*Q,r[13]=c*M+h*b+d*R+u*L,r[2]=p*I+g*E+f*k+m*U,r[6]=p*x+g*B+f*D+m*F,r[10]=p*w+g*S+f*T+m*Q,r[14]=p*M+g*b+f*R+m*L,r[3]=A*I+y*E+v*k+C*U,r[7]=A*x+y*B+v*D+C*F,r[11]=A*w+y*S+v*T+C*Q,r[15]=A*M+y*b+v*R+C*L,this}},{key:"multiplyScalar",value: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}},{key:"determinant",value:function(){var e=this.elements,t=e[0],i=e[4],n=e[8],r=e[12],o=e[1],a=e[5],s=e[9],l=e[13],c=e[2],h=e[6],d=e[10],u=e[14];return e[3]*(+r*s*h-n*l*h-r*a*d+i*l*d+n*a*u-i*s*u)+e[7]*(+t*s*u-t*l*d+r*o*d-n*o*u+n*l*c-r*s*c)+e[11]*(+t*l*h-t*a*u-r*o*h+i*o*u+r*a*c-i*l*c)+e[15]*(-n*a*c-t*s*h+t*a*d+n*o*h-i*o*d+i*s*c)}},{key:"transpose",value: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}},{key:"setPosition",value:function(e,t,i){var n=this.elements;return e.isVector3?(n[12]=e.x,n[13]=e.y,n[14]=e.z):(n[12]=e,n[13]=t,n[14]=i),this}},{key:"invert",value:function(){var e=this.elements,t=e[0],i=e[1],n=e[2],r=e[3],o=e[4],a=e[5],s=e[6],l=e[7],c=e[8],h=e[9],d=e[10],u=e[11],p=e[12],g=e[13],f=e[14],m=e[15],A=h*f*l-g*d*l+g*s*u-a*f*u-h*s*m+a*d*m,y=p*d*l-c*f*l-p*s*u+o*f*u+c*s*m-o*d*m,v=c*g*l-p*h*l+p*a*u-o*g*u-c*a*m+o*h*m,C=p*h*s-c*g*s-p*a*d+o*g*d+c*a*f-o*h*f,I=t*A+i*y+n*v+r*C;if(0===I)return this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0);var x=1/I;return e[0]=A*x,e[1]=(g*d*r-h*f*r-g*n*u+i*f*u+h*n*m-i*d*m)*x,e[2]=(a*f*r-g*s*r+g*n*l-i*f*l-a*n*m+i*s*m)*x,e[3]=(h*s*r-a*d*r-h*n*l+i*d*l+a*n*u-i*s*u)*x,e[4]=y*x,e[5]=(c*f*r-p*d*r+p*n*u-t*f*u-c*n*m+t*d*m)*x,e[6]=(p*s*r-o*f*r-p*n*l+t*f*l+o*n*m-t*s*m)*x,e[7]=(o*d*r-c*s*r+c*n*l-t*d*l-o*n*u+t*s*u)*x,e[8]=v*x,e[9]=(p*h*r-c*g*r-p*i*u+t*g*u+c*i*m-t*h*m)*x,e[10]=(o*g*r-p*a*r+p*i*l-t*g*l-o*i*m+t*a*m)*x,e[11]=(c*a*r-o*h*r-c*i*l+t*h*l+o*i*u-t*a*u)*x,e[12]=C*x,e[13]=(c*g*n-p*h*n+p*i*d-t*g*d-c*i*f+t*h*f)*x,e[14]=(p*a*n-o*g*n-p*i*s+t*g*s+o*i*f-t*a*f)*x,e[15]=(o*h*n-c*a*n+c*i*s-t*h*s-o*i*d+t*a*d)*x,this}},{key:"scale",value:function(e){var t=this.elements,i=e.x,n=e.y,r=e.z;return t[0]*=i,t[4]*=n,t[8]*=r,t[1]*=i,t[5]*=n,t[9]*=r,t[2]*=i,t[6]*=n,t[10]*=r,t[3]*=i,t[7]*=n,t[11]*=r,this}},{key:"getMaxScaleOnAxis",value:function(){var e=this.elements;return Math.sqrt(Math.max(e[0]*e[0]+e[1]*e[1]+e[2]*e[2],e[4]*e[4]+e[5]*e[5]+e[6]*e[6],e[8]*e[8]+e[9]*e[9]+e[10]*e[10]))}},{key:"makeTranslation",value:function(e,t,i){return this.set(1,0,0,e,0,1,0,t,0,0,1,i,0,0,0,1),this}},{key:"makeRotationX",value:function(e){var t=Math.cos(e),i=Math.sin(e);return this.set(1,0,0,0,0,t,-i,0,0,i,t,0,0,0,0,1),this}},{key:"makeRotationY",value:function(e){var t=Math.cos(e),i=Math.sin(e);return this.set(t,0,i,0,0,1,0,0,-i,0,t,0,0,0,0,1),this}},{key:"makeRotationZ",value:function(e){var t=Math.cos(e),i=Math.sin(e);return this.set(t,-i,0,0,i,t,0,0,0,0,1,0,0,0,0,1),this}},{key:"makeRotationAxis",value:function(e,t){var i=Math.cos(t),n=Math.sin(t),r=1-i,o=e.x,a=e.y,s=e.z,l=r*o,c=r*a;return this.set(l*o+i,l*a-n*s,l*s+n*a,0,l*a+n*s,c*a+i,c*s-n*o,0,l*s-n*a,c*s+n*o,r*s*s+i,0,0,0,0,1),this}},{key:"makeScale",value:function(e,t,i){return this.set(e,0,0,0,0,t,0,0,0,0,i,0,0,0,0,1),this}},{key:"makeShear",value:function(e,t,i,n,r,o){return this.set(1,i,r,0,e,1,o,0,t,n,1,0,0,0,0,1),this}},{key:"compose",value:function(e,t,i){var n=this.elements,r=t._x,o=t._y,a=t._z,s=t._w,l=r+r,c=o+o,h=a+a,d=r*l,u=r*c,p=r*h,g=o*c,f=o*h,m=a*h,A=s*l,y=s*c,v=s*h,C=i.x,I=i.y,x=i.z;return n[0]=(1-(g+m))*C,n[1]=(u+v)*C,n[2]=(p-y)*C,n[3]=0,n[4]=(u-v)*I,n[5]=(1-(d+m))*I,n[6]=(f+A)*I,n[7]=0,n[8]=(p+y)*x,n[9]=(f-A)*x,n[10]=(1-(d+g))*x,n[11]=0,n[12]=e.x,n[13]=e.y,n[14]=e.z,n[15]=1,this}},{key:"decompose",value:function(e,t,i){var n=this.elements,r=ep.set(n[0],n[1],n[2]).length(),o=ep.set(n[4],n[5],n[6]).length(),a=ep.set(n[8],n[9],n[10]).length();0>this.determinant()&&(r=-r),e.x=n[12],e.y=n[13],e.z=n[14],tp.copy(this);var s=1/r,l=1/o,c=1/a;return tp.elements[0]*=s,tp.elements[1]*=s,tp.elements[2]*=s,tp.elements[4]*=l,tp.elements[5]*=l,tp.elements[6]*=l,tp.elements[8]*=c,tp.elements[9]*=c,tp.elements[10]*=c,t.setFromRotationMatrix(tp),i.x=r,i.y=o,i.z=a,this}},{key:"makePerspective",value:function(e,t,i,n,r,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*r/(i-n),l=(t+e)/(t-e),c=(i+n)/(i-n),h=-(o+r)/(o-r),d=-2*o*r/(o-r);return a[0]=2*r/(t-e),a[4]=0,a[8]=l,a[12]=0,a[1]=0,a[5]=s,a[9]=c,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}},{key:"makeOrthographic",value:function(e,t,i,n,r,o){var a=this.elements,s=1/(t-e),l=1/(i-n),c=1/(o-r),h=(t+e)*s,d=(i+n)*l,u=(o+r)*c;return a[0]=2*s,a[4]=0,a[8]=0,a[12]=-h,a[1]=0,a[5]=2*l,a[9]=0,a[13]=-d,a[2]=0,a[6]=0,a[10]=-2*c,a[14]=-u,a[3]=0,a[7]=0,a[11]=0,a[15]=1,this}},{key:"equals",value:function(e){for(var t=this.elements,i=e.elements,n=0;16>n;n++)if(t[n]!==i[n])return!1;return!0}},{key:"fromArray",value:function(e){for(var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,i=0;16>i;i++)this.elements[i]=e[i+t];return this}},{key:"toArray",value:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:[],t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,i=this.elements;return e[t]=i[0],e[t+1]=i[1],e[t+2]=i[2],e[t+3]=i[3],e[t+4]=i[4],e[t+5]=i[5],e[t+6]=i[6],e[t+7]=i[7],e[t+8]=i[8],e[t+9]=i[9],e[t+10]=i[10],e[t+11]=i[11],e[t+12]=i[12],e[t+13]=i[13],e[t+14]=i[14],e[t+15]=i[15],e}}]),e}();$u.prototype.isMatrix4=!0;var ep=new Qu,tp=new $u,ip=new Qu(0,0,0),np=new Qu(1,1,1),rp=new Qu,op=new Qu,ap=new Qu,sp=function(){function e(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,i=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0;ru(this,e),this.x=t,this.y=i}return au(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}},{key:"set",value:function(e,t){return this.x=e,this.y=t,this}},{key:"setScalar",value:function(e){return this.x=e,this.y=e,this}},{key:"setX",value:function(e){return this.x=e,this}},{key:"setY",value:function(e){return this.y=e,this}},{key:"setComponent",value: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}},{key:"getComponent",value:function(e){switch(e){case 0:return this.x;case 1:return this.y;default:throw new Error("index is out of range: "+e)}}},{key:"clone",value:function(){return new this.constructor(this.x,this.y)}},{key:"copy",value:function(e){return this.x=e.x,this.y=e.y,this}},{key:"add",value: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)}},{key:"addScalar",value:function(e){return this.x+=e,this.y+=e,this}},{key:"addVectors",value:function(e,t){return this.x=e.x+t.x,this.y=e.y+t.y,this}},{key:"addScaledVector",value:function(e,t){return this.x+=e.x*t,this.y+=e.y*t,this}},{key:"sub",value: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)}},{key:"subScalar",value:function(e){return this.x-=e,this.y-=e,this}},{key:"subVectors",value:function(e,t){return this.x=e.x-t.x,this.y=e.y-t.y,this}},{key:"multiply",value:function(e){return this.x*=e.x,this.y*=e.y,this}},{key:"multiplyScalar",value:function(e){return this.x*=e,this.y*=e,this}},{key:"divide",value:function(e){return this.x/=e.x,this.y/=e.y,this}},{key:"divideScalar",value:function(e){return this.multiplyScalar(1/e)}},{key:"applyMatrix3",value:function(e){var t=this.x,i=this.y,n=e.elements;return this.x=n[0]*t+n[3]*i+n[6],this.y=n[1]*t+n[4]*i+n[7],this}},{key:"min",value:function(e){return this.x=Math.min(this.x,e.x),this.y=Math.min(this.y,e.y),this}},{key:"max",value:function(e){return this.x=Math.max(this.x,e.x),this.y=Math.max(this.y,e.y),this}},{key:"clamp",value: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}},{key:"clampScalar",value: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}},{key:"clampLength",value:function(e,t){var i=this.length();return this.divideScalar(i||1).multiplyScalar(Math.max(e,Math.min(t,i)))}},{key:"floor",value:function(){return this.x=Math.floor(this.x),this.y=Math.floor(this.y),this}},{key:"ceil",value:function(){return this.x=Math.ceil(this.x),this.y=Math.ceil(this.y),this}},{key:"round",value:function(){return this.x=Math.round(this.x),this.y=Math.round(this.y),this}},{key:"roundToZero",value:function(){return this.x=0>this.x?Math.ceil(this.x):Math.floor(this.x),this.y=0>this.y?Math.ceil(this.y):Math.floor(this.y),this}},{key:"negate",value:function(){return this.x=-this.x,this.y=-this.y,this}},{key:"dot",value:function(e){return this.x*e.x+this.y*e.y}},{key:"cross",value:function(e){return this.x*e.y-this.y*e.x}},{key:"lengthSq",value:function(){return this.x*this.x+this.y*this.y}},{key:"length",value:function(){return Math.sqrt(this.x*this.x+this.y*this.y)}},{key:"manhattanLength",value:function(){return Math.abs(this.x)+Math.abs(this.y)}},{key:"normalize",value:function(){return this.divideScalar(this.length()||1)}},{key:"angle",value:function(){var e=Math.atan2(-this.y,-this.x)+Math.PI;return e}},{key:"distanceTo",value:function(e){return Math.sqrt(this.distanceToSquared(e))}},{key:"distanceToSquared",value:function(e){var t=this.x-e.x,i=this.y-e.y;return t*t+i*i}},{key:"manhattanDistanceTo",value:function(e){return Math.abs(this.x-e.x)+Math.abs(this.y-e.y)}},{key:"setLength",value:function(e){return this.normalize().multiplyScalar(e)}},{key:"lerp",value:function(e,t){return this.x+=(e.x-this.x)*t,this.y+=(e.y-this.y)*t,this}},{key:"lerpVectors",value:function(e,t,i){return this.x=e.x+(t.x-e.x)*i,this.y=e.y+(t.y-e.y)*i,this}},{key:"equals",value:function(e){return e.x===this.x&&e.y===this.y}},{key:"fromArray",value:function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0;return this.x=e[t],this.y=e[t+1],this}},{key:"toArray",value:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:[],t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0;return e[t]=this.x,e[t+1]=this.y,e}},{key:"fromBufferAttribute",value:function(e,t,i){return void 0!==i&&console.warn("THREE.Vector2: offset has been removed from .fromBufferAttribute()."),this.x=e.getX(t),this.y=e.getY(t),this}},{key:"rotateAround",value:function(e,t){var i=Math.cos(t),n=Math.sin(t),r=this.x-e.x,o=this.y-e.y;return this.x=r*i-o*n+e.x,this.y=r*n+o*i+e.y,this}},{key:"random",value:function(){return this.x=Math.random(),this.y=Math.random(),this}}]),e}();sp.prototype.isVector2=!0;var lp=function(){function e(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,i=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:0,r=arguments.length>3&&void 0!==arguments[3]?arguments[3]:1;ru(this,e),this.x=t,this.y=i,this.z=n,this.w=r}return au(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}},{key:"set",value:function(e,t,i,n){return this.x=e,this.y=t,this.z=i,this.w=n,this}},{key:"setScalar",value:function(e){return this.x=e,this.y=e,this.z=e,this.w=e,this}},{key:"setX",value:function(e){return this.x=e,this}},{key:"setY",value:function(e){return this.y=e,this}},{key:"setZ",value:function(e){return this.z=e,this}},{key:"setW",value:function(e){return this.w=e,this}},{key:"setComponent",value: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}},{key:"getComponent",value: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)}}},{key:"clone",value:function(){return new this.constructor(this.x,this.y,this.z,this.w)}},{key:"copy",value: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}},{key:"add",value: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)}},{key:"addScalar",value:function(e){return this.x+=e,this.y+=e,this.z+=e,this.w+=e,this}},{key:"addVectors",value: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}},{key:"addScaledVector",value: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}},{key:"sub",value: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)}},{key:"subScalar",value:function(e){return this.x-=e,this.y-=e,this.z-=e,this.w-=e,this}},{key:"subVectors",value: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}},{key:"multiply",value:function(e){return this.x*=e.x,this.y*=e.y,this.z*=e.z,this.w*=e.w,this}},{key:"multiplyScalar",value:function(e){return this.x*=e,this.y*=e,this.z*=e,this.w*=e,this}},{key:"applyMatrix4",value:function(e){var t=this.x,i=this.y,n=this.z,r=this.w,o=e.elements;return this.x=o[0]*t+o[4]*i+o[8]*n+o[12]*r,this.y=o[1]*t+o[5]*i+o[9]*n+o[13]*r,this.z=o[2]*t+o[6]*i+o[10]*n+o[14]*r,this.w=o[3]*t+o[7]*i+o[11]*n+o[15]*r,this}},{key:"divideScalar",value:function(e){return this.multiplyScalar(1/e)}},{key:"setAxisAngleFromQuaternion",value:function(e){this.w=2*Math.acos(e.w);var t=Math.sqrt(1-e.w*e.w);return 1e-4>t?(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}},{key:"setAxisAngleFromRotationMatrix",value:function(e){var t,i,n,r,o=.01,a=.1,s=e.elements,l=s[0],c=s[4],h=s[8],d=s[1],u=s[5],p=s[9],g=s[2],f=s[6],m=s[10];if(Math.abs(c-d)<o&&Math.abs(h-g)<o&&Math.abs(p-f)<o){if(Math.abs(c+d)<a&&Math.abs(h+g)<a&&Math.abs(p+f)<a&&Math.abs(l+u+m-3)<a)return this.set(1,0,0,0),this;t=Math.PI;var A=(l+1)/2,y=(u+1)/2,v=(m+1)/2,C=(c+d)/4,I=(h+g)/4,x=(p+f)/4;return A>y&&A>v?o>A?(i=0,n=.707106781,r=.707106781):(n=C/(i=Math.sqrt(A)),r=I/i):y>v?o>y?(i=.707106781,n=0,r=.707106781):(i=C/(n=Math.sqrt(y)),r=x/n):o>v?(i=.707106781,n=.707106781,r=0):(i=I/(r=Math.sqrt(v)),n=x/r),this.set(i,n,r,t),this}var w=Math.sqrt((f-p)*(f-p)+(h-g)*(h-g)+(d-c)*(d-c));return.001>Math.abs(w)&&(w=1),this.x=(f-p)/w,this.y=(h-g)/w,this.z=(d-c)/w,this.w=Math.acos((l+u+m-1)/2),this}},{key:"min",value: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}},{key:"max",value: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}},{key:"clamp",value: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}},{key:"clampScalar",value: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}},{key:"clampLength",value:function(e,t){var i=this.length();return this.divideScalar(i||1).multiplyScalar(Math.max(e,Math.min(t,i)))}},{key:"floor",value: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}},{key:"ceil",value: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}},{key:"round",value: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}},{key:"roundToZero",value:function(){return this.x=0>this.x?Math.ceil(this.x):Math.floor(this.x),this.y=0>this.y?Math.ceil(this.y):Math.floor(this.y),this.z=0>this.z?Math.ceil(this.z):Math.floor(this.z),this.w=0>this.w?Math.ceil(this.w):Math.floor(this.w),this}},{key:"negate",value:function(){return this.x=-this.x,this.y=-this.y,this.z=-this.z,this.w=-this.w,this}},{key:"dot",value:function(e){return this.x*e.x+this.y*e.y+this.z*e.z+this.w*e.w}},{key:"lengthSq",value:function(){return this.x*this.x+this.y*this.y+this.z*this.z+this.w*this.w}},{key:"length",value:function(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z+this.w*this.w)}},{key:"manhattanLength",value:function(){return Math.abs(this.x)+Math.abs(this.y)+Math.abs(this.z)+Math.abs(this.w)}},{key:"normalize",value:function(){return this.divideScalar(this.length()||1)}},{key:"setLength",value:function(e){return this.normalize().multiplyScalar(e)}},{key:"lerp",value: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}},{key:"lerpVectors",value:function(e,t,i){return this.x=e.x+(t.x-e.x)*i,this.y=e.y+(t.y-e.y)*i,this.z=e.z+(t.z-e.z)*i,this.w=e.w+(t.w-e.w)*i,this}},{key:"equals",value:function(e){return e.x===this.x&&e.y===this.y&&e.z===this.z&&e.w===this.w}},{key:"fromArray",value:function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0;return this.x=e[t],this.y=e[t+1],this.z=e[t+2],this.w=e[t+3],this}},{key:"toArray",value:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:[],t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0;return e[t]=this.x,e[t+1]=this.y,e[t+2]=this.z,e[t+3]=this.w,e}},{key:"fromBufferAttribute",value:function(e,t,i){return void 0!==i&&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}},{key:"random",value:function(){return this.x=Math.random(),this.y=Math.random(),this.z=Math.random(),this.w=Math.random(),this}}]),e}();function cp(e,t){var i=(65535&e)+(65535&t);return(e>>16)+(t>>16)+(i>>16)<<16|65535&i}function hp(e,t,i,n,r,o){return cp((a=cp(cp(t,e),cp(n,o)))<<(s=r)|a>>>32-s,i);var a,s}function dp(e,t,i,n,r,o,a){return hp(t&i|~t&n,e,t,r,o,a)}function up(e,t,i,n,r,o,a){return hp(t&n|i&~n,e,t,r,o,a)}function pp(e,t,i,n,r,o,a){return hp(t^i^n,e,t,r,o,a)}function gp(e,t,i,n,r,o,a){return hp(i^(t|~n),e,t,r,o,a)}function fp(e,t){var i,n,r,o,a;e[t>>5]|=128<<t%32,e[14+(t+64>>>9<<4)]=t;var s=1732584193,l=-271733879,c=-1732584194,h=271733878;for(i=0;e.length>i;i+=16)n=s,r=l,o=c,a=h,s=dp(s,l,c,h,e[i],7,-680876936),h=dp(h,s,l,c,e[i+1],12,-389564586),c=dp(c,h,s,l,e[i+2],17,606105819),l=dp(l,c,h,s,e[i+3],22,-1044525330),s=dp(s,l,c,h,e[i+4],7,-176418897),h=dp(h,s,l,c,e[i+5],12,1200080426),c=dp(c,h,s,l,e[i+6],17,-1473231341),l=dp(l,c,h,s,e[i+7],22,-45705983),s=dp(s,l,c,h,e[i+8],7,1770035416),h=dp(h,s,l,c,e[i+9],12,-1958414417),c=dp(c,h,s,l,e[i+10],17,-42063),l=dp(l,c,h,s,e[i+11],22,-1990404162),s=dp(s,l,c,h,e[i+12],7,1804603682),h=dp(h,s,l,c,e[i+13],12,-40341101),c=dp(c,h,s,l,e[i+14],17,-1502002290),s=up(s,l=dp(l,c,h,s,e[i+15],22,1236535329),c,h,e[i+1],5,-165796510),h=up(h,s,l,c,e[i+6],9,-1069501632),c=up(c,h,s,l,e[i+11],14,643717713),l=up(l,c,h,s,e[i],20,-373897302),s=up(s,l,c,h,e[i+5],5,-701558691),h=up(h,s,l,c,e[i+10],9,38016083),c=up(c,h,s,l,e[i+15],14,-660478335),l=up(l,c,h,s,e[i+4],20,-405537848),s=up(s,l,c,h,e[i+9],5,568446438),h=up(h,s,l,c,e[i+14],9,-1019803690),c=up(c,h,s,l,e[i+3],14,-187363961),l=up(l,c,h,s,e[i+8],20,1163531501),s=up(s,l,c,h,e[i+13],5,-1444681467),h=up(h,s,l,c,e[i+2],9,-51403784),c=up(c,h,s,l,e[i+7],14,1735328473),s=pp(s,l=up(l,c,h,s,e[i+12],20,-1926607734),c,h,e[i+5],4,-378558),h=pp(h,s,l,c,e[i+8],11,-2022574463),c=pp(c,h,s,l,e[i+11],16,1839030562),l=pp(l,c,h,s,e[i+14],23,-35309556),s=pp(s,l,c,h,e[i+1],4,-1530992060),h=pp(h,s,l,c,e[i+4],11,1272893353),c=pp(c,h,s,l,e[i+7],16,-155497632),l=pp(l,c,h,s,e[i+10],23,-1094730640),s=pp(s,l,c,h,e[i+13],4,681279174),h=pp(h,s,l,c,e[i],11,-358537222),c=pp(c,h,s,l,e[i+3],16,-722521979),l=pp(l,c,h,s,e[i+6],23,76029189),s=pp(s,l,c,h,e[i+9],4,-640364487),h=pp(h,s,l,c,e[i+12],11,-421815835),c=pp(c,h,s,l,e[i+15],16,530742520),s=gp(s,l=pp(l,c,h,s,e[i+2],23,-995338651),c,h,e[i],6,-198630844),h=gp(h,s,l,c,e[i+7],10,1126891415),c=gp(c,h,s,l,e[i+14],15,-1416354905),l=gp(l,c,h,s,e[i+5],21,-57434055),s=gp(s,l,c,h,e[i+12],6,1700485571),h=gp(h,s,l,c,e[i+3],10,-1894986606),c=gp(c,h,s,l,e[i+10],15,-1051523),l=gp(l,c,h,s,e[i+1],21,-2054922799),s=gp(s,l,c,h,e[i+8],6,1873313359),h=gp(h,s,l,c,e[i+15],10,-30611744),c=gp(c,h,s,l,e[i+6],15,-1560198380),l=gp(l,c,h,s,e[i+13],21,1309151649),s=gp(s,l,c,h,e[i+4],6,-145523070),h=gp(h,s,l,c,e[i+11],10,-1120210379),c=gp(c,h,s,l,e[i+2],15,718787259),l=gp(l,c,h,s,e[i+9],21,-343485551),s=cp(s,n),l=cp(l,r),c=cp(c,o),h=cp(h,a);return[s,l,c,h]}function mp(e){var t,i="",n=32*e.length;for(t=0;n>t;t+=8)i+=String.fromCharCode(e[t>>5]>>>t%32&255);return i}function Ap(e){var t,i=[];for(i[(e.length>>2)-1]=void 0,t=0;i.length>t;t+=1)i[t]=0;var n=8*e.length;for(t=0;n>t;t+=8)i[t>>5]|=(255&e.charCodeAt(t/8))<<t%32;return i}function yp(e){var t,i,n="0123456789abcdef",r="";for(i=0;e.length>i;i+=1)t=e.charCodeAt(i),r+=n.charAt(t>>>4&15)+n.charAt(15&t);return r}function vp(e){return unescape(encodeURIComponent(e))}function Cp(e){return function(e){return mp(fp(Ap(e),8*e.length))}(vp(e))}function Ip(e,t){return function(e,t){var i,n,r=Ap(e),o=[],a=[];for(o[15]=a[15]=void 0,r.length>16&&(r=fp(r,8*e.length)),i=0;16>i;i+=1)o[i]=909522486^r[i],a[i]=1549556828^r[i];return n=fp(o.concat(Ap(t)),512+8*t.length),mp(fp(a.concat(n),640))}(vp(e),vp(t))}function xp(e,t,i){return t?i?Ip(t,e):function(e,t){return yp(Ip(e,t))}(t,e):i?Cp(e):yp(Cp(e))}lp.prototype.isVector4=!0;var wp={scratchVector_1:new Qu,scratchVector_2:new Qu,scratchVector_3:new Qu,scratchMatrix4_1:new $u,scratchMatrix4_2:new $u,scratchQuaternion_1:new Fu,TemporaryMatrix:new $u,MinusEpsilon:-1e-6,MatrixFromMillimeterToMeter:(new $u).makeScale(.001,.001,.001),MatrixFromMeterToMillimeter:(new $u).makeScale(1e3,1e3,1e3),isDefined:function(e){return null!=e},supportWorker:function(){return"undefined"!=typeof Worker||(console.log("Web Worker is not supported."),!1)},box3FromArray:function(e,t){if(Array.isArray(e)){var i=t||new Nu;return i.min.fromArray(e,0),i.max.fromArray(e,3),i}return null},box3FromSize:function(e,t,i){return wp.isDefined(i)||(i=new Nu),i.min.set(-t.x/2,-t.y/2,-t.z/2),i.max.set(t.x/2,t.y/2,t.z/2),i.translate(e),i},box3FromArrayRange:function(e,t,i){for(var n=new Nu,r=Number(1/0),o=Number(1/0),a=Number(1/0),s=-1/0,l=-1/0,c=-1/0,h=t,d=i;d>h;h+=3){var u=e[h],p=e[h+1],g=e[h+2];r>u&&(r=u),o>p&&(o=p),a>g&&(a=g),u>s&&(s=u),p>l&&(l=p),g>c&&(c=g)}return n.min.set(r,o,a),n.max.set(s,l,c),n},box3FromObject:function(e,t,i){if(void 0!==e&&void 0!==t&&void 0!==e.x&&void 0!==e.y&&void 0!==e.z&&void 0!==t.x&&void 0!==t.y&&void 0!==t.z){var n=i||new Nu;return n.min.set(e.x,e.y,e.z),n.max.set(t.x,t.y,t.z),n}return null},computeBBox:function(e){for(var t=new Nu,i=new Qu,n=0,r=e.length;r>n;n+=1)i.fromArray(e[n],0),t.expandByPoint(i);return t},mergeBBox:function(e){if(1>e.length)return null;for(var t=new Nu,i=new Qu,n=new Qu,r=new Nu,o=0,a=e.length;a>o;o+=1)i.set(e[o].max.x,e[o].max.y,e[o].max.z),n.set(e[o].min.x,e[o].min.y,e[o].min.z),r.set(n,i),t.union(r);return t},parseTransform:function(e,t,i){var n=!1;if(t.rotation&&(e.rotation.fromArray(t.rotation),n=!0),t.position&&(e.position.fromArray(t.position),n=!0),t.scale&&(e.scale.fromArray(t.scale),n=!0),t.quaternion&&(e.quaternion.fromArray(t.quaternion),n=!0),n&&e.updateMatrix(),t.matrix&&e.matrix.fromArray(t.matrix),i){var r=e.matrix.clone();r.multiplyMatrices(i,e.matrix),e.matrix=r}e.matrixAutoUpdate=!1,void 0!==e.boundingBox&&(e.boundingBox=wp.box3FromArray(t.bbox))},isEmptyObject:function(e){if(!e)return!0;if(e.length>0)return!1;if(0===e.length)return!0;for(var t in e)if(e.hasOwnProperty(t))return!1;return!0},isEmptyObjectSimple:function(e){for(var t in e)return!1;return!0},isOwnEmptyObject:function(e){for(var t in e)if(e.hasOwnProperty(t))return!1;return!0},hexStrToRgb:function(e){var t=e.replace("#",""),i=/^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(t);return i?{r:parseInt(i[1],16)/255,g:parseInt(i[2],16)/255,b:parseInt(i[3],16)/255}:null},hexToRgb:function(e){var t={};return t.r=(e>>16&255)/255,t.g=(e>>8&255)/255,t.b=(255&e)/255,t},getMin:function(e){for(var t=e.length,i=1/0;(t-=1)>=0;)i=i>e[t]?e[t]:i;return i},getMax:function(e){for(var t=e.length,i=-1/0;(t-=1)>=0;)i=e[t]>i?e[t]:i;return i},findRange:function(e,t){if(t<Math.min.apply(null,e))return 0;if(t>Math.max.apply(null,e))return e.length-1;for(var i=0,n=0,r=e.length;r>n;n+=1)if(e[n]>t){i=n-1;break}return i},stringToByte:function(e){for(var t=[],i=e.length,n=null,r=0;i>r;r+=1)65536>(n=e.charCodeAt(r))||n>1114111?2048>n||n>65535?128>n||n>2047?t.push(255&n):(t.push(n>>6&31|192),t.push(63&n|128)):(t.push(n>>12&15|224),t.push(n>>6&63|128),t.push(63&n|128)):(t.push(n>>18&7|240),t.push(n>>12&63|128),t.push(n>>6&63|128),t.push(63&n|128));return t},byteToString:function(e){if("string"==typeof e)return e;for(var t="",i=e,n=0;i.length>n;n+=1){var r=i[n].toString(2),o=r.match(/^1+?(?=0)/);if(o&&8===r.length){for(var a=o[0].length,s=i[n].toString(2).slice(7-a),l=1;a>l;l+=1)s+=i[l+n].toString(2).slice(2);t+=String.fromCharCode(parseInt(s,2)),n+=a-1}else t+=String.fromCharCode(i[n])}return t},strToBinary:function(e){for(var t=[],i=e.split(""),n=0;i.length>n;n+=1){0!==n&&t.push(" ");var r=i[n].charCodeAt().toString(2);t.push(r)}return t.join("")},binaryToStr:function(e){for(var t=[],i=e.split(" "),n=0;i.length>n;n+=1){var r=parseInt(i[n],2),o=String.fromCharCode(r);t.push(o)}return t.join("")},byteArr2Int:function(e){return(255&e[0])<<24|(255&e[1])<<16|(255&e[2])<<8|(255&e[3])<<0},int2ByteArr:function(e){var t=[];return t[0]=e>>24,t[1]=e>>16,t[2]=e>>8,t[3]=e>>0,t},isPlainObject:function(e){var t,i;return!(!e||"[object Object]"!==Object.prototype.toString.call(e))&&(!(t=Object.getPrototypeOf(e))||"function"==typeof(i=Object.hasOwnProperty.call(t,"constructor")&&t.constructor)&&Object.hasOwnProperty.toString.call(i)===Object.hasOwnProperty.toString.call(Object))},extend:function(){var e=null,t=null,i=null,n=null,r=null,o=null,a=arguments[0]||{},s=1,l=arguments.length,c=!1;for("boolean"==typeof a&&(c=a,a=arguments[s]||{},s+=1),"object"!==nu(a)&&"function"===!nu(a)&&(a={}),s===l&&(a=this,s-=1);l>s;s+=1)if(null!==(e=arguments[s])&&void 0!==(e=arguments[s]))for(t in e)i=a[t],a!==(n=e[t])&&(c&&n&&(wp.isPlainObject(n)||(r=Array.isArray(n)))?(r?(r=!1,o=i&&Array.isArray(i)?i:[]):o=i&&wp.isPlainObject(i)?i:{},a[t]=wp.extend(c,o,n)):null!=n&&(a[t]=n));return a},isMirror:function(e){var t=new Qu(e[0],e[1],e[2]),i=new Qu(e[4],e[5],e[6]),n=new Qu(e[8],e[9],e[10]);return 0>(new Qu).crossVectors(t,i).dot(n)},decodeUTF8:function(e){for(var t="",i=0;e.length>i;i+=1)t+=String.fromCharCode(e[i]);return decodeURIComponent(escape(t))},unique:function(e){for(var t,i=[],n={},r=0;null!==(t=e[r])&&void 0!==(t=e[r]);r+=1)n[t]||(i.push(t),n[t]=!0);return n=null,i},getValue:function(e,t){var i=t.split("."),n=e;return i.map((function(e,t){n=n[e]})),n},sortByName:function(e,t,i){i=i||"asc";var n=!1;t?t.indexOf(".")>-1&&(n=!0):t="name",e=e.sort((function(e,r){if(n){var o=wp.getValue(e,t),a=wp.getValue(r,t);return"asc"===i?o.localeCompare(a):a.localeCompare(o)}return"asc"===i?e[t].localeCompare(r[t]):r[t].localeCompare(e[t])}));var r=[],o=[],a=[],s=[];return e.map((function(e,i){var l=null;l=n?wp.getValue(e,t):e[t],/^[a-zA-Z]*$/.test(l.slice(0,1))?r.push(e):/^[\u4e00-\u9fa5]*$/.test(l.slice(0,1))?o.push(e):/^\d+(\.\d+)?$/.test(l.slice(0,1))?a.push(e):s.push(e)})),s.concat(a,r,o)},PointToLineDistance:function(e,t,i,n,r,o){var a=void 0,s=void 0,l=void 0,c=void 0,h=Math.sqrt((i-e)*(i-e)+(n-t)*(n-t));if(0===h)return[0,{x:i,y:n}];var d=Math.sqrt((r-e)*(r-e)+(o-t)*(o-t));if(0===d)return[0,{x:r,y:o}];var u=Math.sqrt((i-r)*(i-r)+(n-o)*(n-o));if(0===u)return[h,{x:i,y:n}];if(d>h){if(n===o?a=r>i?0:Math.PI:((c=(r-i)/u)-1>1e-5&&(c=1),a=Math.acos(c),n>o&&(a=2*Math.PI-a)),(c=(e-i)/h)-1>1e-5&&(c=1),s=Math.acos(c),n>t&&(s=2*Math.PI-s),0>(l=s-a)&&(l=-l),l>Math.PI&&(l=2*Math.PI-l),l>Math.PI/2)return[h,{x:i,y:n}];if(i===r)return[d*Math.sin(l),{x:i,y:t}];if(n===o)return[d*Math.sin(l),{x:e,y:n}];var p,g,f=(o-n)/r-i,m=-1/f,A=t-e*m;return g=m*(p=(o-r*f-A)/(m-f))+A,[h*Math.sin(l),{x:p,y:g}]}if(n===o?a=r>i?Math.PI:0:((c=(i-r)/u)-1>1e-5&&(c=1),a=Math.acos(c),o>n&&(a=2*Math.PI-a)),(c=(e-r)/d)-1>1e-5&&(c=1),s=Math.acos(c),o>t&&(s=2*Math.PI-s),0>(l=s-a)&&(l=-l),l>Math.PI&&(l=2*Math.PI-l),l>Math.PI/2)return[d,{x:r,y:o}];if(i===r)return[d*Math.sin(l),{x:i,y:t}];if(n===o)return[d*Math.sin(l),{x:e,y:n}];var y,v,C=(o-n)/r-i,I=-1/C,x=t-e*I;return v=I*(y=(o-r*C-x)/(I-C))+x,[d*Math.sin(l),{x:y,y:v}]},freezeObject:function(e){return Object.freeze?Object.freeze(e):e},getEncodedId:function(e){return xp(e)},arrayToMap:function(e,t){t=t||{};for(var i=0,n=e.length;n>i;i+=1)t[e[i]]=!0;return t},getDifferentialIdxs:function(e,t){var i=null,n={},r={},o={};if(t)if(this.isEmptyObject(e))r=t;else{for(i in t)e[i]&&(o[i]=!0);if(this.isEmptyObject(o))n=e,r=t;else{for(i in t)o[i]||(r[i]=!0);for(i in e)o[i]||(n[i]=!0)}}else this.isEmptyObject(e)||(n=e);return{objCurrUsedIdxs:e,addIdxs:Object.keys(n),removeIdxs:Object.keys(r)}},getCombinedKeyString:function(e,t){return e.join(t=t||"&")},splitCombinedKeyString:function(e,t){return e.split(t=t||"&")},getModelKeyFromComponentKey:function(e){return e.split("_")[0]},isGroupObject:function(e){return!(!e.children||!e.children.length)},isMeshObject:function(e){return!!(e.isMesh||e.isLine||e.isPoints)},extendObject:function(e,t,i){if(i)for(var n in t)"object"===nu(t[n])?wp.extendObject(e[n],t[n],!0):e[n]=t[n];else for(var n in t)null!=e[n]?"object"===nu(t[n])&&wp.extendObject(e[n],t[n],!1):e[n]=t[n];return e},computeExplodeTranslation:function(e,t,i){var n=new Qu,r=t.getCenter(n),o=i*e.distanceTo(r),a=new Qu;return a.subVectors(r,e),0!=a.length()&&a.normalize(),a.multiplyScalar(o),a},minDistanceBetweenTriToMesh:function(e,t,i,n){function r(e,t){return new Qu(e.x-t.x,e.y-t.y,e.z-t.z)}function o(e,t){return new Qu(e.x+t.x,e.y+t.y,e.z+t.z)}function a(e,t,i){return new Qu(e.x+t.x*i,e.y+t.y*i,e.z+t.z*i)}function s(e,t){return e.x*t.x+e.y*t.y+e.z*t.z}function l(e,t){return new Qu(e.y*t.z-e.z*t.y,e.z*t.x-e.x*t.z,e.x*t.y-e.y*t.x)}function c(e,t,i,n){var c,h,d,u,p,g,f=s(t,n),m=s(t,t),A=s(n,n),y=r(i,e),v=s(t,y),C=s(n,y);return 0>(c=(v*A-C*f)/(m*A-f*f))||isNaN(c)?c=0:c>1&&(c=1),0>=(h=(c*f-C)/A)||isNaN(h)?(u=i,0>=(c=v/m)||isNaN(c)?(d=e,p=r(i,e)):1>c?(d=a(e,t,c),g=l(y,t),p=l(t,g)):p=r(i,d=o(e,t))):1>h?(u=a(i,n,h),0>=c||isNaN(c)?(d=e,g=l(y,n),p=l(n,g)):1>c?(d=a(e,t,c),0>s(p=l(t,n),y)&&p.multiplyScalar(-1)):(g=l(y=r(i,d=o(e,t)),n),p=l(n,g))):(u=o(i,n),0>=(c=(f+v)/m)||isNaN(c)?(d=e,p=r(u,e)):1>c?(d=a(e,t,c),g=l(y=r(u,e),t),p=l(t,g)):p=r(u,d=o(e,t))),{vec:p,closestP:d,closestQ:u}}function h(e,t){var i,n,o,h,d,u,p=[],g=[];p[0]=r(e[1],e[0]),p[1]=r(e[2],e[1]),p[2]=r(e[0],e[2]),g[0]=r(t[1],t[0]),g[1]=r(t[2],t[1]),g[2]=r(t[0],t[2]);for(var f=0,m=e[0].distanceToSquared(t[0])+1,A=0;3>A;A+=1)for(var y=0;3>y;y+=1){var v=c(e[A],p[A],t[y],g[y]);o=v.vec;var C=s(h=r(n=v.closestQ,i=v.closestP),h);if(m>=C){d=i.clone(),u=n.clone(),m=C;var I=s(r(e[(A+2)%3],i),o),x=s(r(t[(y+2)%3],n),o);if(0>=I&&x>=0)return{start:i.clone(),end:n.clone(),minDistance:Math.sqrt(C)};0>I&&(I=0),x>0&&(x=0),s(h,o)-I+x>0&&(f=1)}}var w=l(p[0],p[1]),M=s(w,w);if(M>1e-15){var E=[];h=r(e[0],t[0]),E[0]=s(h,w),h=r(e[0],t[1]),E[1]=s(h,w),h=r(e[0],t[2]),E[2]=s(h,w);var B=-1;if(E[0]>0&&E[1]>0&&E[2]>0?E[B=E[1]>E[0]?0:1]>E[2]&&(B=2):0>E[0]&&0>E[1]&&0>E[2]&&E[2]>E[B=E[0]>E[1]?0:1]&&(B=2),B>=0&&(f=1,s(h=r(t[B],e[0]),l(w,p[0]))>0&&s(h=r(t[B],e[1]),l(w,p[1]))>0&&s(h=r(t[B],e[2]),l(w,p[2]))>0))return i=a(t[B],w,E[B]/M),n=t[B].clone(),{start:i.clone(),end:n,minDistance:i.distanceTo(n)}}var S=l(g[0],g[1]),b=s(S,S);if(b>1e-15){var k=[];h=r(t[0],e[0]),k[0]=s(h,S),h=r(t[0],e[1]),k[1]=s(h,S),h=r(t[0],e[2]),k[2]=s(h,S);B=-1;if(k[0]>0&&k[1]>0&&k[2]>0?k[B=k[1]>k[0]?0:1]>k[2]&&(B=2):0>k[0]&&0>k[1]&&0>k[2]&&k[2]>k[B=k[0]>k[1]?0:1]&&(B=2),B>=0&&(f=1,s(h=r(e[B],t[0]),l(S,g[0]))>0&&s(h=r(e[B],t[1]),l(S,g[1]))>0&&s(h=r(e[B],t[2]),l(S,g[2]))>0))return{start:i=e[B].clone(),end:(n=a(e[B],S,k[B]/b)).clone(),minDistance:i.distanceTo(n)}}return f?(i=d,n=u,{start:d.clone(),end:u.clone(),minDistance:Math.sqrt(m)}):{start:d.clone(),end:u.clone(),minDistance:0}}var d=new Qu,u=new Qu,p=new Qu;function g(e,t,i,n,r,o){d.fromBufferAttribute(t,i),u.fromBufferAttribute(t,n),p.fromBufferAttribute(t,r),o&&(d.applyMatrix4(o),u.applyMatrix4(o),p.applyMatrix4(o)),e.push(d),e.push(u),e.push(p)}for(var f={start:null,end:null,minDistance:Number.POSITIVE_INFINITY},m=t.geometry,A=m.attributes.position,y=i?i.indexStart:0,v=m.getIndex().array,C=y,I=i?i.indexStart+i.indexCount:v.length;I>C;C+=3){var x=[];g(x,A,v[C],v[C+1],v[C+2],n);var w=h(e,x);if(f.minDistance>w.minDistance&&(f.minDistance=w.minDistance,f.start=w.start.clone(),f.end=w.end.clone()),0>=w.minDistance)return f}return f},asyncProcess:function(e,t,i,n,r){requestAnimationFrame(function o(a){var s=a;return function(){var a=null,l=null;for(l=s+i>t?t:s+i,a=s;l>a;a+=1){n&&n(e,a),a===l-1&&(l!==t?requestAnimationFrame(o(a+1)):r&&r(e))}}}(0))},hasSimilarProperty:function(e,t){if(!(e instanceof Object&&t instanceof Object))return!1;for(var i in e)if(e.hasOwnProperty(i)&&!t.hasOwnProperty(i))return!1;return!0},equalsWithEpsilon:function(e,t){var i=1e-7,n=Math.abs(e.x-t.x),r=Math.abs(e.y-t.y),o=Math.abs(e.z-t.z);return i>=n&&i>=r&&i>=o},arrayMax:function(e){if(0===e.length)return-1/0;for(var t=e[0],i=1,n=e.length;n>i;i+=1)e[i]>t&&(t=e[i]);return t},arrayMin:function(e){if(0===e.length)return 1/0;for(var t=e[0],i=1,n=e.length;n>i;i+=1)t>e[i]&&(t=e[i]);return t},ab2str:function(e){return(new TextDecoder).decode(new Uint8Array(e))},str2ab:function(e){return(new TextEncoder).encode(e).buffer},getEncodedString:function(e){return xp(e)},toMemoryString:function(e){var t=e/1048576;return 1>t?t.toLocaleString(void 0,{maximumFractionDigits:3}):Math.round(t).toLocaleString()},defined:function(e){return null!=e},defaultValue:function(e,t){return null!=e?e:t},clone:function(e,t){if(null===e||"object"!==nu(e))return e;t=wp.defaultValue(t,!1);var i=new e.constructor;for(var n in e)if(e.hasOwnProperty(n)){var r=e[n];t&&(r=wp.clone(r,t)),i[n]=r}return i},binarySearch:function(e,t,i){for(var n,r,o=0,a=e.length-1;a>=o;)if(0>(r=i(e[n=~~((o+a)/2)],t)))o=n+1;else{if(0>=r)return n;a=n-1}return~(a+1)},unpackRGBAToDepth:function(e){if(!wp.UnpackFactors){var t=255/256,i=new Qu(16777216,65536,256);wp.UnpackFactors=new lp(t/i.x,t/i.y,t/i.z,t)}return e.dot(wp.UnpackFactors)},computeViewportTransformation:function(e,t,i,n){var r=wp.defaultValue(e.x,0),o=wp.defaultValue(e.y,0),a=wp.defaultValue(e.width,0),s=wp.defaultValue(e.height,0);t=wp.defaultValue(t,0);var l=.5*a,c=.5*s,h=.5*((i=wp.defaultValue(i,1))-t),d=l,u=c,p=h,g=r+l,f=o+c,m=t+h;return wp.defined(n)||(n=new $u),n.elements[0]=d,n.elements[1]=0,n.elements[2]=0,n.elements[3]=0,n.elements[4]=0,n.elements[5]=u,n.elements[6]=0,n.elements[7]=0,n.elements[8]=0,n.elements[9]=0,n.elements[10]=p,n.elements[11]=0,n.elements[12]=g,n.elements[13]=f,n.elements[14]=m,n.elements[15]=1,n},computeView:function(e,t,i,n,r){return wp.defined(r)||(r=new $u),r.elements[0]=n.x,r.elements[1]=i.x,r.elements[2]=-t.x,r.elements[3]=0,r.elements[4]=n.y,r.elements[5]=i.y,r.elements[6]=-t.y,r.elements[7]=0,r.elements[8]=n.z,r.elements[9]=i.z,r.elements[10]=-t.z,r.elements[11]=0,r.elements[12]=-n.dot(e),r.elements[13]=-i.dot(e),r.elements[14]=t.dot(e),r.elements[15]=1,r},getTranslationFromMatrix4:function(e,t){return wp.defined(t)||(t=new Qu),t.x=e.elements[12],t.y=e.elements[13],t.z=e.elements[14],t},pointInPolygon:function(e,t){for(var i=e.x,n=e.y,r=!1,o=0,a=t.length-1;t.length>o;a=o+=1){var s=t[o].x,l=t[o].y,c=t[a].y;l>n!=c>n&&(t[a].x-s)*(n-l)/(c-l)+s>i&&(r=!r)}return r},area:function(e){for(var t=e.length,i=0,n=t-1,r=0;t>r;n=r+=1)i+=e[n].x*e[r].y-e[r].x*e[n].y;return.5*i},isClockWise:function(e){return 0>wp.area(e)},lineLineIntersection:function(e,t,i,n){var r=(n.y-i.y)*(t.x-e.x)-(n.x-i.x)*(t.y-e.y),o=(n.x-i.x)*(e.y-i.y)-(n.y-i.y)*(e.x-i.x),a=(t.x-e.x)*(e.y-i.y)-(t.y-e.y)*(e.x-i.x);if(0!=r){var s=o/r,l=a/r;return 0>s||s>1||0>l||l>1?void 0:new sp(e.x+s*(t.x-e.x),e.y+s*(t.y-e.y))}},lineStartScratch:new sp,lineEndScratch:new sp,linePolygonIntersection:function(e,t,i){for(var n,r=0;i.length>r;r+=1)if(wp.lineStartScratch.set(i[r].x,i[r].y),wp.lineEndScratch.set(i[(r+1)%i.length].x,i[(r+1)%i.length].y),n=wp.lineLineIntersection(e,t,wp.lineStartScratch,wp.lineEndScratch))return n},linePolygonIntersection2:function(e,t,i){for(var n,r=0;i.length>r;r+=1)if(wp.lineStartScratch.set(i[r].x,i[r].y),wp.lineEndScratch.set(i[(r+1)%i.length].x,i[(r+1)%i.length].y),n=wp.lineLineIntersection(e,t,wp.lineStartScratch,wp.lineEndScratch))return n.index=r,n}};wp.createUUID=function(){for(var e=[],t="0123456789abcdef",i=0;36>i;i+=1)e[i]=t.substr(Math.floor(16*Math.random()),1);return e[14]="4",e[19]=t.substr(3&e[19]|8,1),e[8]=e[13]=e[18]=e[23]="-",e.join("")};var Mp=function(e){lu(i,e);var t=pu(i);function i(e,n,r,o){var a;return ru(this,i),(a=t.call(this,e,n,r,o)).projectOnWidth=!1,a}return au(i,[{key:"updateProjectionMatrixByFrustum",value:function(e,t){var i=this.near,n=null,r=null,o=null,a=null;this.projectOnWidth?(r=-.5*(o=e),n=.5*(a=this.aspect*o)):(n=.5*(a=t),r=-.5*(o=this.aspect*a));var s=this.view;if(null!==s){var l=s.fullWidth,c=s.fullHeight;r+=s.offsetX*o/l,n-=s.offsetY*a/c,o*=s.width/l,a*=s.height/c}var h=this.filmOffset;0!==h&&(r+=i*h/this.getFilmWidth()),this.projectionMatrix.makePerspective(r,r+o,n,n-a,i,this.far)}},{key:"setProjectOnWidth",value:function(e){this.projectOnWidth=e}}]),i}(dn),Ep=function(e){lu(i,e);var t=pu(i);function i(e){var n,r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return ru(this,i),(n=t.call(this)).cameraType=e||Md.PERSPECTIVE,n.target=new Ke,n.name=r.name||"",n.near=r.near||.1,n.far=r.far||2e3,n.fov=r.fov||45,n.cameraType===Md.PERSPECTIVE?(r.width&&r.height&&(n.aspect=r.width/r.height,n.left=-r.width/2,n.right=r.width/2,n.top=r.height/2,n.bottom=-r.height/2),n.perspectiveCamera=new Mp(n.fov,n.aspect,n.near,n.far),n.orthoCamera=null,n.toPerspective()):(n.left=r.left,n.right=r.right,n.top=r.top,n.bottom=r.bottom,void 0!==r.left&&void 0!==r.right&&void 0!==r.top&&void 0!==r.bottom&&(n.aspect=(n.right-n.left)/(n.top-n.bottom)),n.orthoCamera=new pc(n.left,n.right,n.top,n.bottom,n.near,n.far),n.perspectiveCamera=null,n.orthoCamera.updateProjectionMatrix(),n.projectionMatrix=n.orthoCamera.projectionMatrix,n.isPerspective=!1),n.zoom=r.zoom||1,n.updateProjectionMatrixByFrustum=!1,n}return au(i,[{key:"toPerspective",value:function(){null!==this.perspectiveCamera?this.updateProjectionMatrixByFrustum||(this.perspectiveCamera.aspect=this.aspect,this.perspectiveCamera.near=this.near,this.perspectiveCamera.far=this.far,this.perspectiveCamera.fov=this.fov,this.perspectiveCamera.updateProjectionMatrix(),this.projectionMatrix=this.perspectiveCamera.projectionMatrix,this.projectionMatrixInverse=this.perspectiveCamera.projectionMatrixInverse,this.isPerspective=!0,this.dirty=!0):Bu.log("Can not convert to perspective camera because the camera original type is orthographic.")}},{key:"toOrthographic",value:function(){null===this.orthoCamera&&(this.orthoCamera=new pc(this.left,this.right,this.top,this.bottom,this.near,this.far));var e=this.fov,t=this.target.clone().sub(this.position).length(),i=Math.tan(e*Math.PI/180/2)*t,n=i*this.aspect;i/=this.zoom,this.left=this.orthoCamera.left=-(n/=this.zoom),this.right=this.orthoCamera.right=n,this.top=this.orthoCamera.top=i,this.bottom=this.orthoCamera.bottom=-i,this.orthoCamera.near=this.near,this.orthoCamera.far=this.far,this.orthoCamera.updateProjectionMatrix(),this.projectionMatrix=this.orthoCamera.projectionMatrix,this.projectionMatrixInverse=this.orthoCamera.projectionMatrixInverse,this.isPerspective=!1,this.dirty=!0}},{key:"setSize",value:function(e,t){this.perspectiveCamera.aspect=e/t,this.left=-e/2,this.right=e/2,this.top=t/2,this.bottom=-t/2,this.aspect=e/t,this.dirty=!0}},{key:"setSizeByFrustum",value:function(e,t){var i,n=2*this.right,r=2*this.top;this.aspect=n/r,e/t>n/r?(i=r/n,this.perspectiveCamera.setProjectOnWidth(!0)):(i=n/r,this.perspectiveCamera.setProjectOnWidth(!1)),this.dirty=!0,this.isPerspective&&(this.perspectiveCamera.aspect=i,this.perspectiveCamera.near=this.near,this.perspectiveCamera.far=this.far,this.perspectiveCamera.fov=this.fov,this.perspectiveCamera.updateProjectionMatrixByFrustum(e,t),this.projectionMatrix=this.perspectiveCamera.projectionMatrix,this.isPerspective=!0,this.dirty=!0)}},{key:"setFov",value:function(e){this.fov=e,this.dirty=!0,this.updateProjectionMatrix()}},{key:"setNearFar",value:function(e,t){this.near=e,this.far=t,this.dirty=!0,this.updateProjectionMatrix()}},{key:"updateProjectionMatrix",value:function(){this.isPerspective?this.toPerspective():this.toOrthographic()}},{key:"setLens",value:function(e,t){void 0===t&&(t=24);var i=2*be.radToDeg(Math.atan(t/(2*e)));return this.setFov(i),this.dirty=!0,i}},{key:"setZoom",value:function(e){this.zoom=e,this.dirty=!0,this.updateProjectionMatrix()}},{key:"copy",value:function(e){return gu(cu(i.prototype),"copy",this).call(this,e),this.cameraType=e.cameraType,this.target.copy(e.target),this.aspect=e.aspect,this.fov=e.fov,this.near=e.near,this.far=e.far,this.left=e.left,this.right=e.right,this.top=e.top,this.bottom=e.bottom,this.zoom=e.zoom,this.isPerspective=e.isPerspective,this.updateProjectionMatrixByFrustum=e.updateProjectionMatrixByFrustum,this.orthoCamera&&e.orthoCamera&&this.orthoCamera.copy(e.orthoCamera),this.perspectiveCamera&&e.perspectiveCamera&&this.perspectiveCamera.copy(e.perspectiveCamera),this}},{key:"clone",value:function(){return new this.constructor(this.cameraType).copy(this)}},{key:"isDirty",value:function(){return this.dirty}},{key:"toFrontView",value:function(){this.rotation.x=0,this.rotation.y=0,this.rotation.z=0}},{key:"toBackView",value:function(){this.rotation.x=0,this.rotation.y=Math.PI,this.rotation.z=0}},{key:"toLeftView",value:function(){this.rotation.x=0,this.rotation.y=-Math.PI/2,this.rotation.z=0}},{key:"toRightView",value:function(){this.rotation.x=0,this.rotation.y=Math.PI/2,this.rotation.z=0}},{key:"toTopView",value:function(){this.rotation.x=-Math.PI/2,this.rotation.y=0,this.rotation.z=0}},{key:"toBottomView",value:function(){this.rotation.x=Math.PI/2,this.rotation.y=0,this.rotation.z=0}}]),i}(hn),Bp=new yt,Sp=new Ke,bp=new Ke,kp=new Ke,Dp=function(e){lu(i,e);var t=pu(i);function i(e,n){var r;return ru(this,i),(r=t.call(this,e,n)).realUp=r.up.clone(),r.target=new Ke,r.dirty=!1,r.orthoScale=1,r.positionPlane=new Jt,r.projScreenMatrix=new yt,r.viewProjInverse=new yt,r.frustum=new yn,r.frustumHeightFactor=r.computeFrustumHeightFactor(),r.minimumElevation=null,r._statusInitialized=!1,r._direction=null,r.statusChange=!1,r}return au(i,[{key:"statusInitialized",get:function(){return this._statusInitialized}},{key:"direction",value:function(e){return this._direction||(this._direction=new Ke),this._direction.subVectors(this.target,this.position),wp.isDefined(e)||(e=new Ke),e.copy(this._direction)}},{key:"_updatePositionPlane",value:function(){this.positionPlane.setFromNormalAndCoplanarPoint(this.getWorldDirection(Sp),this.position)}},{key:"_updateFrustum",value:function(){this.frustum.setFromProjectionMatrix(this.projScreenMatrix)}},{key:"updateMVP",value:function(){this.dirty&&(this._statusInitialized||(this._statusInitialized=!0),null===this.parent&&this.updateMatrixWorld(),this.matrixWorldInverse.copy(this.matrixWorld).invert(),this.projScreenMatrix.multiplyMatrices(this.projectionMatrix,this.matrixWorldInverse),this.viewProjInverse.copy(this.projScreenMatrix).invert(),this._updateFrustum(),this._updatePositionPlane(),this.frustumHeightFactor=this.computeFrustumHeightFactor(),this.dirty=!1)}},{key:"computeFrustumHeightFactor",value:function(){return 2*Math.tan(.5*be.degToRad(this.fov))}},{key:"getFrustum",value:function(){return this.dirty&&this.updateMVP(),this.frustum}},{key:"lookAtEx",value:function(e,t,i,n){var r=new Ke;r.copy(t),void 0!==n&&"number"==typeof n&&r.setLength(n),this.position.subVectors(e,r),this.up.copy(i),this.lookAt(e),this.realUp.copy(i),this.target.copy(e),this.dirty=!0}},{key:"lookAtEXForTargetPositionUp",value:function(e,t,i){this.position.copy(t),this.up=i,this.lookAt(e),this.realUp=i.clone(),this.target=e.clone(),this.dirty=!0}},{key:"copy",value:function(e){return gu(cu(i.prototype),"copy",this).call(this,e),this.realUp.copy(e.realUp),this.orthoScale=e.orthoScale,this.dirty=e.dirty,this.positionPlane.copy(e.positionPlane),this.projScreenMatrix.copy(e.projScreenMatrix),this.viewProjInverse.copy(e.viewProjInverse),this.frustum.copy(e.frustum),this}},{key:"setStandardView",value:function(e,t){var i=null,n=null;t?(i=t.getCenter(Sp),n=t.getSize(Sp)):i=new Ke(0,0,0);var r=xd.SceneSize,o=r/2;switch(n||(n=o),e){case kd.ISO:var a=new Ke(-r,r,r),s=new Ke,l=new Ke(0,0,0);s.subVectors(l,a),this.lookAtEx(i,s,Yt.DefaultUp);break;case kd.Top:this.lookAtEx(i,new Ke(0,0,-1),new Ke(0,1,0),n?n.x:o);break;case kd.Bottom:this.lookAtEx(i,new Ke(0,0,1),new Ke(0,1,0),n?n.x:o);break;case kd.Front:this.lookAtEx(i,new Ke(0,1,0),new Ke(0,0,1),n?n.z:o);break;case kd.Back:this.lookAtEx(i,new Ke(0,-1,0),new Ke(0,0,1),n?n.z:o);break;case kd.Right:this.lookAtEx(i,new Ke(-1,0,0),new Ke(0,0,1),n?n.y:o);break;case kd.Left:this.lookAtEx(i,new Ke(1,0,0),new Ke(0,0,1),n?n.y:o);break;case kd.FrontRight:this.lookAtEx(i,new Ke(-1,1,0),new Ke(0,0,1),n?n.x+n.y:o);break;case kd.FrontLeft:this.lookAtEx(i,new Ke(1,1,0),new Ke(0,0,1),n?n.x+n.y:o);break;case kd.BackLeft:this.lookAtEx(i,new Ke(1,-1,0),new Ke(0,0,1),n?n.x+n.y:o);break;case kd.BackRight:this.lookAtEx(i,new Ke(-1,-1,0),new Ke(0,0,1),n?n.x+n.y:o);break;case kd.BottomFront:this.lookAtEx(i,new Ke(0,1,1),new Ke(0,0,1),n?n.x+n.z:o);break;case kd.BottomBack:this.lookAtEx(i,new Ke(0,-1,1),new Ke(0,0,1),n?n.x+n.z:o);break;case kd.BottomRight:this.lookAtEx(i,new Ke(-1,0,1),new Ke(0,0,1),n?n.y+n.z:o);break;case kd.BottomLeft:this.lookAtEx(i,new Ke(1,0,1),new Ke(0,0,1),n?n.y+n.z:o);break;case kd.BottomFrontRight:this.lookAtEx(i,new Ke(-1,1,1),new Ke(0,0,1),n?n.x+n.y+n.z:o);break;case kd.BottomFrontLeft:this.lookAtEx(i,new Ke(1,1,1),new Ke(0,0,1),n?n.x+n.y+n.z:o);break;case kd.BottomBackLeft:this.lookAtEx(i,new Ke(1,-1,1),new Ke(0,0,1),n?n.x+n.y+n.z:o);break;case kd.BottomBackRight:this.lookAtEx(i,new Ke(-1,-1,1),new Ke(0,0,1),n?n.x+n.y+n.z:o);break;case kd.TopFront:this.lookAtEx(i,new Ke(0,1,-1),new Ke(0,0,1),n?n.x+n.z:o);break;case kd.TopBack:this.lookAtEx(i,new Ke(0,-1,-1),new Ke(0,0,1),n?n.x+n.z:o);break;case kd.TopRight:this.lookAtEx(i,new Ke(-1,0,-1),new Ke(0,0,1),n?n.y+n.z:o);break;case kd.TopLeft:this.lookAtEx(i,new Ke(1,0,-1),new Ke(0,0,1),n?n.y+n.z:o);break;case kd.TopFrontRight:this.lookAtEx(i,new Ke(-1,1,-1),new Ke(0,0,1),n?n.x+n.y+n.z:o);break;case kd.TopFrontLeft:this.lookAtEx(i,new Ke(1,1,-1),new Ke(0,0,1),n?n.x+n.y+n.z:o);break;case kd.TopBackLeft:this.lookAtEx(i,new Ke(1,-1,-1),new Ke(0,0,1),n?n.x+n.y+n.z:o);break;case kd.TopBackRight:this.lookAtEx(i,new Ke(-1,-1,-1),new Ke(0,0,1),n?n.x+n.y+n.z:o);break;case kd.TopToRight:this.lookAtEx(i,new Ke(0,1,0),new Ke(-1,0,0),o);break;case kd.TopToBack:this.lookAtEx(i,new Ke(0,1,0),new Ke(0,0,1),o);break;case kd.TopToLeft:this.lookAtEx(i,new Ke(0,1,0),new Ke(1,0,0),o);break;case kd.TopToFront:this.lookAtEx(i,new Ke(0,1,0),new Ke(0,0,-1),o);break;case kd.BottomToRight:this.lookAtEx(i,new Ke(0,-1,0),new Ke(-1,0,0),o);break;case kd.BottomToBack:this.lookAtEx(i,new Ke(0,-1,0),new Ke(0,0,-1),o);break;case kd.BottomToFront:this.lookAtEx(i,new Ke(0,-1,0),new Ke(0,0,1),o);break;case kd.BottomToLeft:this.lookAtEx(i,new Ke(0,-1,0),new Ke(1,0,0),o);break;case kd.FrontToTop:this.lookAtEx(i,new Ke(0,0,-1),new Ke(0,-1,0),o);break;case kd.FrontToBottom:this.lookAtEx(i,new Ke(0,0,-1),new Ke(0,1,0),o);break;case kd.FrontToLeft:this.lookAtEx(i,new Ke(0,0,-1),new Ke(1,0,0),o);break;case kd.FrontToRight:this.lookAtEx(i,new Ke(0,0,-1),new Ke(-1,0,0),o);break;case kd.RightToTop:this.lookAtEx(i,new Ke(-1,0,0),new Ke(0,-1,0),o);break;case kd.RightToBottom:this.lookAtEx(i,new Ke(-1,0,0),new Ke(0,1,0),o);break;case kd.RightToFront:this.lookAtEx(i,new Ke(-1,0,0),new Ke(0,0,-1),o);break;case kd.RightToBack:this.lookAtEx(i,new Ke(-1,0,0),new Ke(0,0,1),o);break;case kd.BackToTop:this.lookAtEx(i,new Ke(0,0,1),new Ke(0,-1,0),o);break;case kd.BackToBottom:this.lookAtEx(i,new Ke(0,0,1),new Ke(0,1,0),o);break;case kd.BackToLeft:this.lookAtEx(i,new Ke(0,0,1),new Ke(-1,0,0),o);break;case kd.BackToRight:this.lookAtEx(i,new Ke(0,0,1),new Ke(1,0,0),o);break;case kd.LeftToTop:this.lookAtEx(i,new Ke(1,0,0),new Ke(0,0,-1),o);break;case kd.LeftTopBottom:this.lookAtEx(i,new Ke(1,0,0),new Ke(0,1,0),o);break;case kd.LeftTopBack:this.lookAtEx(i,new Ke(1,0,0),new Ke(0,0,1),o);break;case kd.LeftTopFront:this.lookAtEx(i,new Ke(1,0,0),new Ke(0,0,-1),o);break;case kd.Keep:break;default:this.lookAtEx(i,new Ke(-1,-1,-1),new Ke(0,0,1),o)}return this.updateProjectionMatrix(),i}},{key:"zoomToBox",value:function(e,t,i,n){i=i||1,t=-1>(t=t||0)?-1:t;var r=new He;if(r.copy(e),0!==t){var o=.5*e.getSize(Sp).length(),a=new Ke;a.subVectors(r.max,r.min).normalize(),a.multiplyScalar(o*t),r.expandByVector(a)}var s=n||this.getWorldDirection(Sp),l=this.up,c=this.aspect,h=be.degToRad(.5*this.fov),d=r.getSize(bp),u=r.getCenter(kp),p=.5*d.length()/Math.sin(h)*i,g=new Ke;g.copy(s),g.setLength(p);var f=new Ke;f.subVectors(u,g);var m=new Ke;m.crossVectors(s,l),m.normalize();var A=new Ke;A.crossVectors(s,m),A.normalize();var y=new Jt;y.setFromNormalAndCoplanarPoint(m,f);var v=new Jt;v.setFromNormalAndCoplanarPoint(A,f);var C=0,I=0,x=0,w=0,M=0,E=[new Ke,new Ke,new Ke,new Ke,new Ke,new Ke,new Ke,new Ke];E[0].set(r.min.x,r.min.y,r.min.z),E[1].set(r.min.x,r.min.y,r.max.z),E[2].set(r.min.x,r.max.y,r.min.z),E[3].set(r.min.x,r.max.y,r.max.z),E[4].set(r.max.x,r.min.y,r.min.z),E[5].set(r.max.x,r.min.y,r.max.z),E[6].set(r.max.x,r.max.y,r.min.z),E[7].set(r.max.x,r.max.y,r.max.z);for(var B=0;8>B;B+=1){var S=new Ke;S.subVectors(E[B],f);var b=Math.abs(S.dot(s)),k=Math.abs(v.distanceToPoint(E[B])),D=k*c,T=Math.abs(y.distanceToPoint(E[B])),R=Math.max(k,T/c),U=Math.max(D,T);R>C&&(C=R),I&&x&&I*b/x>=R||(I=R,x=b),w&&M&&w*b/M>=U||(w=U,M=b)}var F=w/Math.tan(h)+(p-M),Q=I/Math.tan(h)+(p-x),L=0;if(L=1>c?Math.max(F,Q):Math.min(F,Q),this.near>L){this.near=(L*L+.001*L)/16777.216}if(g.copy(s).normalize().setLength(L),f.subVectors(u,g),this.position.copy(f),this.lookAt(u),this.target.copy(u),!this.isPerspective){var O=Math.tan(this.fov*Math.PI/180/2)*L;this.orthoScale=O/C,this.zoom=this.orthoScale}return this.updateProjectionMatrix(),this.dirty=!0,u}},{key:"calculateNearFar",value:function(e,t){var i=e,n=[new Ke(i.min.x,i.min.y,i.min.z),new Ke(i.min.x,i.min.y,i.max.z),new Ke(i.min.x,i.max.y,i.min.z),new Ke(i.min.x,i.max.y,i.max.z),new Ke(i.max.x,i.min.y,i.min.z),new Ke(i.max.x,i.min.y,i.max.z),new Ke(i.max.x,i.max.y,i.min.z),new Ke(i.max.x,i.max.y,i.max.z)],r=this.getWorldDirection(Sp),o=(new Jt).setFromNormalAndCoplanarPoint(r,this.position),a=-1/0,s=1/0;n.forEach((function(e){var t=o.distanceToPoint(e);s>t-10&&(s=t-10),t+10>a&&(a=t+10)}));var l=s>0?s:.1,c=a>0?a:2e3;this.isPerspective?void 0!==t&&(l=t):l=-c,this.setNearFar(l,c)}},{key:"calculateNearFar2",value:function(e,t,i){var n,r,o=e,a=o.getCenter(Sp),s=this.position.clone().sub(a).length(),l=o.getSize(bp).length();if(t){var c=.5*l;if(r=s+c,this.isPerspective){n=(s*s+.001*s)/16777.216,c>s||i?n=.1:n+c>s&&(n=s-c)}else n=-r}else r=s,n=this.isPerspective?.1:-r;this.setNearFar(n,r)}},{key:"computeRay",value:function(e,t,i){var n=new ke;if(void 0===i)n.x=window.innerWidth,n.y=window.innerHeight;else{var r=i===document?i.body:i;n.x=r.offsetWidth,n.y=r.offsetHeight}var o=new ke;o.x=e/n.x*2-1,o.y=-t/n.y*2+1;var a=new At;return this.isPerspective?(a.origin.copy(this.position),a.direction.set(o.x,o.y,.5).unproject(this).sub(this.position).normalize()):(a.origin.set(o.x,o.y,-1).unproject(this),a.direction.set(0,0,-1).transformDirection(this.matrixWorld)),a}},{key:"screenToWorld",value:function(e,t,i,n){var r=this.computeRay(e,t,i),o=this.getWorldDirection(Sp).normalize(),a=new Jt(o);return a.setFromNormalAndCoplanarPoint(o,n),r.intersectPlane(a,n)}},{key:"getWorldFrustum",value:function(e){var t=new yn,i=this.clone(),n=this.target,r=n.clone().sub(this.position).length();Bp.copy(e).invert();var o=new yt;o.extractRotation(e);var a=new Ge;a.setFromRotationMatrix(o),a.invert(),i.position.applyMatrix4(Bp);var s=n.clone();s.applyMatrix4(Bp);var l=s.clone().sub(i.position),c=l.length();return l.normalize(),i.far=this.far*(c/r),i.up.applyQuaternion(a).normalize(),i.realUp.applyQuaternion(a).normalize(),i.updateProjectionMatrix(),i.updateMatrixWorld(),Bp.copy(i.matrixWorld).invert(),t.setFromProjectionMatrix((new yt).multiplyMatrices(i.projectionMatrix,Bp)),i=null,t}},{key:"distanceFromWorldToDrawing",value:function(e,t){var i=this.position.clone(),n=this.target.clone();return n.subVectors(this.target,this.position),n.normalize(),Bp.copy(e).invert(),n.add(i).applyMatrix4(Bp),i.applyMatrix4(Bp),n.sub(i),n.normalize().multiplyScalar(t),n.add(i).applyMatrix4(e),n.sub(this.position),n.length()}},{key:"getPositionByDis",value:function(e,t,i,n){var r=i||this.position,o=n||this.target;r=r.clone(),o=o.clone(),(Bp=new yt).copy(t).invert(),r.applyMatrix4(Bp),o.applyMatrix4(Bp);var a=e/r.distanceTo(o),s=new Ke;return s.subVectors(r,o),s.multiplyScalar(a),s.subVectors(r,s),s}},{key:"getDistanceByPos",value:function(e,t){var i=this.position.clone();return(Bp=new yt).copy(t).invert(),i.applyMatrix4(Bp),i.distanceTo(e)}},{key:"flyTo",value:function(){}}],[{key:"nearFarDrawingToWorld",value:function(e,t){var i=e.position.clone(),n=e.target.clone().sub(i);n.normalize(),(Bp=new yt).copy(t).invert();var r=function(e,t,i,n){var r=i.clone().multiplyScalar(e);r.add(t).applyMatrix4(n);var o=t.clone().applyMatrix4(n);return r.sub(o),e>0?r.length():-r.length()};return e.near&&e.far&&(e.near=r(e.near,i,n,Bp),e.far=r(e.far,i,n,Bp)),e.left&&e.right&&e.top&&e.bottom&&(e.left=r(e.left,i,n,Bp),e.right=r(e.right,i,n,Bp),e.top=r(e.top,i,n,Bp),e.bottom=r(e.bottom,i,n,Bp)),e}},{key:"drawingToWorld",value:function(e,t){var i=e.position.clone(),n=e.target.clone(),r=e.up.clone();return(Bp=new yt).copy(t).invert(),r.add(i),r.applyMatrix4(Bp),i.applyMatrix4(Bp),n.applyMatrix4(Bp),r.sub(i),r.normalize(),{position:i,target:n,up:r}}},{key:"worldToDrawing",value:function(e,t){var i=e.position.clone(),n=e.target.clone(),r=e.up.clone();return r.add(i),r.applyMatrix4(t),i.applyMatrix4(t),n.applyMatrix4(t),r.sub(i),r.normalize(),{position:i,target:n,up:r}}}]),i}(Ep),Tp=function(){var e=this,t=null,i={},n={},r=1e3,o=null,a=null,s=.9995,l=null,c=!1,h=null,d=null,u=null;this.from=function(e){for(var n in t=e)t.hasOwnProperty(n)&&(i[n]=t[n]);return this},this.to=function(e,t){return void 0!==t&&(r=t),n=e,this},this.onStart=function(e){return h=e,this},this.onUpdate=function(e){return d=e,this},this.onComplete=function(e){return u=e,this},this.start=function(e,s){c=!1,a&&cancelAnimationFrame(a),o=Date.now(),l=s?this.linearInterpolateForTargetPostionUp:this.interpolate,a=requestAnimationFrame((function s(){var p=i,g=n,f=Date.now();!1===c&&(null!==h&&h.call(t),c=!0);var m=(f-o)/r;t=l(p,g,m=m>1?1:m),1===m?(cancelAnimationFrame(a),null!==u&&u.call(t)):(requestAnimationFrame(s,e),null!==d&&d.call(t,m))}),e)},this.isAngleGreaterThanPi=function(e,t,i){var n=new Ke;return n.crossVectors(e,t),0>n.dot(i)},this.conicInterpolate=function(e,t,i,n){var r=-t.angleTo(e)*n,o=new Ke;o.crossVectors(t,e).normalize();var a=new Ge;a.setFromAxisAngle(o,r),i.copy(e),i.applyQuaternion(a)},this.quaternionInterpolate=function(e,t,i,n,r){var o=new Ge(e.x,e.y,e.z,1).normalize(),a=new Ge(t.x,t.y,t.z,1).normalize(),s=new Ge(0,0,0,1),l=new Ge(0,0,0,1),c=new Ke;c.crossVectors(e,i).normalize(),s.set(c.x,c.y,c.z,1).normalize();.5>r?(Ge.slerp(o,s,l,2*r),n.set(l.x,l.y,l.z)):(Ge.slerp(s,a,l,2*(r-.5)),n.set(l.x,l.y,l.z))},this.slerpInterpolate=function(e,t,i,n,r,o){var a=e.dot(t);a>o?n.copy(t):o<Math.abs(a)?this.quaternionInterpolate(e,t,i,n,r):this.conicInterpolate(e,t,n,r),n.normalize()},this.linearInterpolate=function(e,t,i,n,r){if(e.equals(t))i.copy(t);else{var o=new Ke(1,0,0),a=new Ke(0,0,1),s=new Ke,l=e.dot(t);l>r?i.copy(t):-l>r?(r>Math.abs(e.dot(a))?s.crossVectors(e,a).normalize():s.crossVectors(e,o).normalize(),.5>n?i.lerpVectors(e,s,2*n):i.lerpVectors(s,t,2*(n-.5))):i.lerpVectors(e,t,n),i.normalize()}},this.linearInterpolatePosition=function(e,t,i,n){i.lerpVectors(e,t,n)},this.sphericalInterpolate=function(e,t,i,n,r,o){var a=e.clone().sub(t),s=i.clone().sub(n),l=new Ah;l.setFromVector3(a);var c=new Ah;c.setFromVector3(s);var h=c.theta-l.theta;Math.abs(h)>Math.PI&&(h=h>0?-(2*Math.PI-Math.abs(h)):2*Math.PI-Math.abs(h));var d=l.theta+h*o,u=l.phi+(c.phi-l.phi)*o,p=a.length(),g=new Ah;g.set(p,u,d);var f=new Ke;f.setFromSpherical(g),r.copy(f).multiplyScalar(-1)},this.interpolate=function(t,i,n){var r=new Ke,o=new Ke,a=new Ke,l=new Ke,c=new Ke,h=t.animTarget,d=t.animUp,u=t.animFocal,p=t.zoom,g=i.animTarget,f=i.animUp,m=i.animFocal,A=i.zoom;return e.sphericalInterpolate(t.animPos,h,i.animPos,g,r,n),e.linearInterpolate(d,f,o,n,s),e.linearInterpolatePosition(h,g,a,n),e.linearInterpolatePosition(u,m,l,n),e.linearInterpolatePosition(p,A,c,n),{animDir:r,animUp:o,animTarget:a,animFocal:l,zoomScale:c}},this.linearInterpolateForTargetPostionUp=function(t,i,n){var r=new Ke,o=new Ke,a=new Ke,l=t.animTarget,c=t.animPos,h=i.animTarget,d=i.animPos;return e.linearInterpolate(t.animUp,i.animUp,o,n,s),e.linearInterpolatePosition(l,h,a,n),e.linearInterpolatePosition(c,d,r,n),{animPos:r,animUp:o,animTarget:a}}},Rp=800,Up=13,Fp=new Tp,Qp=new Ke,Lp=new Ke,Op=function(){function e(){ru(this,e),this.flyTo=this.slerpFlyTo}return au(e,[{key:"setDuration",value:function(e){Rp=e}},{key:"getDuration",value:function(){return Rp}},{key:"setFrameTime",value:function(e){Up=e}},{key:"setStandardView",value:function(e,t,i,n,r,o){var a=t.camera,s=a.position.clone(),l=a.target.clone(),c=a.getWorldDirection(Qp);c.normalize();var h=new Ke;h.copy(a.realUp||a.up),h.normalize();var d=new Ke(a.position.clone().sub(l).length(),0,0),u=t.camera.clone();u.setStandardView(e,i);var p=u.zoomToBox(i,n),g=u.position.clone(),f=u.getWorldDirection(Lp);f.normalize();var m=new Ke;m.copy(u.realUp||u.up),m.normalize();var A=new Ke(u.position.clone().sub(p).length(),0,0);c.equals(f)&&h.equals(m)&&l.equals(p)&&d.equals(A)?o&&o():(t.getControlManager().setInteractiveState(!1),Fp.from({animPos:s,animDir:c,animUp:h,animTarget:l,animFocal:d,zoom:1}).to({animPos:g,animDir:f,animUp:m,animTarget:p,animFocal:A,zoom:1},Rp).onUpdate((function(){t.camera.lookAtEx(this.animTarget,this.animDir,this.animUp,this.animFocal.x),t.cameraControl.update(!0,!0),t.controlManager.dispatchEvent({type:Fd.ON_CAMERA_ANIMATION_UPDATE}),r&&r()})).onComplete((function(){t.camera.lookAtEx(p,f,m,A.x),t.cameraControl.update(!0,!0),o&&o(),t.getControlManager().setInteractiveState(!0)})).start(Up))}},{key:"active",value:function(e,t,i,n,r){var o=i.camera,a=new Ke(e.position.x,e.position.y,e.position.z),s=new Ke(e.target.x,e.target.y,e.target.z),l=new Ke(s.distanceTo(a),0,0),c=s.clone().sub(a).normalize(),h=new Ke(e.up.x,e.up.y,e.up.z);h.normalize();var d=new Ke(e.zoom),u=new Ke(t.position.x,t.position.y,t.position.z),p=new Ke(t.target.x,t.target.y,t.target.z),g=new Ke(p.distanceTo(u),0,0),f=p.clone().sub(u).normalize(),m=new Ke(t.up.x,t.up.y,t.up.z);m.normalize();var A,y,v,C,I=new Ke(t.zoom,0,0);if(0==(A=.01,y=u.clone().sub(a).length()<A,v=f.clone().sub(c).length()<A,C=m.clone().sub(h).length()<A,!(y&&v&&C)))return Bu.log("Current camera status is equal with before."),void(r&&r());i.getControlManager().setInteractiveState(!1),Fp.from({animPos:a,animDir:c,animUp:h,animTarget:s,animFocal:l,zoom:d}).to({animPos:u,animDir:f,animUp:m,animTarget:p,animFocal:g,zoom:I},Rp).onUpdate((function(){var e=this.animTarget,t=this.animDir,r=this.animUp,a=this.animFocal.x;o.setZoom(this.zoomScale.x),o.lookAtEx(e,t,r,a),i.controlManager.dispatchEvent({type:Fd.ON_CAMERA_ANIMATION_UPDATE}),n&&n(e)})).onComplete((function(){o.setZoom(I.x),o.lookAtEx(p,f,m,g.x),n&&n(p),r&&r(),i.getControlManager().setInteractiveState(!0)})).start(Up)}},{key:"slerpFlyTo",value:function(e,t,i,n){var r=t.camera,o=r.position.clone(),a=r.getWorldDirection(new Ke),s=new Ke;s.copy(r.realUp||r.up),s.normalize();var l=r.target.clone(),c=new Ke(r.position.clone().sub(l).length(),0,0),h=new Ke(r.zoom),d=new Ke(e.position.x,e.position.y,e.position.z),u=new Ke(e.target.x,e.target.y,e.target.z),p=new Ke(u.distanceTo(d),0,0),g=u.clone().sub(d).normalize(),f=new Ke(e.up.x,e.up.y,e.up.z);f.normalize();var m,A,y,v,C=new Ke(e.zoom,0,0);if(0==(m=.01,A=d.clone().sub(o).length()<m,y=g.clone().sub(a).length()<m,v=f.clone().sub(s).length()<m,!(A&&y&&v)))return Bu.log("Current camera status is equal with before."),void(n&&n());t.getControlManager().setInteractiveState(!1),Fp.from({animPos:o,animDir:a,animUp:s,animTarget:l,animFocal:c,zoom:h}).to({animPos:d,animDir:g,animUp:f,animTarget:u,animFocal:p,zoom:C},Rp).onUpdate((function(){var e=this.animTarget,n=this.animDir,o=this.animUp,a=this.animFocal.x;r.setZoom(this.zoomScale.x),r.lookAtEx(e,n,o,a),t.controlManager.dispatchEvent({type:Fd.ON_CAMERA_ANIMATION_UPDATE}),i&&i(e)})).onComplete((function(){r.setZoom(C.x),r.lookAtEx(u,g,f,p.x),i&&i(u),n&&n(),t.getControlManager().setInteractiveState(!0)})).start(Up)}},{key:"linearFlyTo",value:function(e,t,i,n){var r=t.camera,o=r.getWorldDirection(new Ke),a=new Ke(r.zoom),s=new Ke;s.copy(r.realUp||r.up),s.normalize();var l=r.target.clone(),c=r.position.clone(),h=new Ke(r.position.clone().sub(l).length(),0,0),d=(new Ke).set(e.position.x,e.position.y,e.position.z),u=(new Ke).set(e.target.x,e.target.y,e.target.z),p=new Ke(u.distanceTo(d),0,0),g=u.clone().sub(d).normalize(),f=new Ke(e.up.x,e.up.y,e.up.z);f.normalize();var m,A,y,v,C=new Ke(e.zoom,0,0);if(0==(m=.01,A=d.clone().sub(c).length()<m,y=g.clone().sub(o).length()<m,v=f.clone().sub(s).length()<m,!(A&&y&&v)))return Bu.log("Current camera status is equal with before."),void(n&&n());t.getControlManager().setInteractiveState(!1),Fp.from({animPos:c,animDir:o,animUp:s,animTarget:l,animFocal:h,zoom:a}).to({animPos:d,animDir:g,animUp:f,animTarget:u,animFocal:p,zoom:C},Rp).onUpdate((function(e){var n=this.animTarget;r.lookAtEXForTargetPositionUp(n,this.animPos,this.animUp),t.controlManager.dispatchEvent({type:Fd.ON_CAMERA_ANIMATION_UPDATE}),i&&i(n)})).onComplete((function(){r.lookAtEXForTargetPositionUp(u,d,f),i&&i(u),n&&n(),t.getControlManager().setInteractiveState(!0)})).start(Up,!0)}},{key:"linearActive",value:function(e,t,i,n,r){var o=i.camera,a=(new Ke).set(e.position.x,e.position.y,e.position.z),s=(new Ke).set(e.target.x,e.target.y,e.target.z),l=(new Ke).set(e.up.x,e.up.y,e.up.z);l.normalize();var c=(new Ke).set(t.position.x,t.position.y,t.position.z),h=(new Ke).set(t.target.x,t.target.y,t.target.z),d=(new Ke).set(t.up.x,t.up.y,t.up.z).normalize();a.equals(c)&&l.equals(d)&&s.equals(h)?r&&r():Fp.from({animPosition:a,animUp:l,animTarget:s}).to({animPosition:c,animUp:d,animTarget:h},Rp).onUpdate((function(e){var t=this.animTarget;o.lookAtEXForTargetPositionUp(t,this.animPosition,this.animUp),n&&n(t)})).onComplete((function(){o.lookAtEXForTargetPositionUp(h,c,d),n&&n(h),r&&r(),i.getControlManager().setInteractiveState(!0)})).start(Up,!0)}}]),e}(),Np=function(){this.condition=[{type:"IfcWall"},{type:"IfcRoof"},{type:"IfcWallStandardCase"},{type:"IfcDoor"},{type:"墙"},{type:"门"}],this.distance=150,this.factor=1};Np.prototype.setCondition=function(e){Array.isArray(e)&&(this.condition=e)},Np.prototype.getCondition=function(){return this.condition},Np.prototype.getDistance=function(){return this.distance},Np.prototype.getFactor=function(){return this.factor},Np.prototype.setDistance=function(e){"number"==typeof e&&(this.distance=e)},Np.prototype.setFactor=function(e){"number"==typeof e&&(this.factor=e)},Np.prototype.matchConditions=function(e){var t=this.condition;if(0===t.length)return!1;for(var i=!0,n=0,r=t.length;r>n;n+=1){var o=t[n];for(var a in o)if(!e.hasOwnProperty(a)||e[a]!==o[a]){i=!1;break}if(!0===i)break;t.length-1>n&&(i=!0)}return i},Np.prototype.hasCollision=function(e,t){return!!e&&(this.matchConditions(e)&&this.distance*this.factor>=t)};var Pp,Gp={ALT:18,CTRL:17,SHIFTLEFT:16,BACKSPACE:8,LEFT:37,UP:38,RIGHT:39,DOWN:40,A:65,D:68,E:69,Q:81,S:83,W:87,Z:90,PLUS:187,SUB:189,ZERO:48,ESC:27,TAB:9,NUMPADADD:107,NUMPADSUBTRACT:109,NUMPAD0:96},Kp={ReverseWheelDirection:!1,MovementSpeedRate:1,WalkSpeedRate:1,RotatePivotMode:Ld.SELECTION,NoPan:!1,NoRotate:!1,NoZoom:!1,NoKey:!1,LockAxisZ:!1,LockAxisZRange:null},Vp={MODEL:"Model",GEOMETRY:"Geometry",SLM:"SLM",LINESEGMENTS:"LineSegments",INSTANCEGEOMETRY:"InstanceGeometry",INSTANCEWIREFRAMEGEOMETRY:"InstanceWireframeGeometry",WIREFRAME:"Wireframe",MARKER3D:"Marker3D",CLIPPLANE:"ClipPlane",FILLCLIPPLANE:"FillClipPlane",CLIPREGION:"ClipRegion",CAPSWIREFRAME:"CapsWireframe",IBLCUBE:"IBLCube",CUSTOMPLANE:"CustomPlane",PIVOTBALL:"PivotBall",MEASUREPICKPOINT:"MeasurePickPoint",MEASUREPICKLINE:"MeasurePickLine",MEASUREPLANE:"MeasurePlane",MEASURELINE:"MeasureLine",OCTREENODE:"OctreeNode",BOUNDARYEDGEMANAGER:"BoundaryEdgeManager",AREANODE:"AreaNode",AXISNET:"AxisNet",AXISGRIDMANAGER:"AxisGridManager",EXTRUDEBODYMANAGER:"ExtrudeBodyManager",EXTRUDEBODYMANAGERTEST:"EXTRUDEBODYMANAGERTEST",EXTERNALSCENEMANAGER:"ExternalSceneManager",EXTERNALCOMPONENTMANAGER:"ExternalComponentManager",BIMTILESGROUP:"BimTilesGroup",TILEGROUP:"TileGroup",ROADNETWORK:"RoadNetworkGroup",GEOJSONGROUP:"GEOJSONGROUP",TRANSFORM:"TRANSFORM",RECEIVESHADOWPLANE:"ReceiveShadowPlane",VIEWSHED:"Viewshed",DEFAULTLIGHTS:"DefaultLights",EXTERNALSPOTLIGHTS:"ExternalSpotLights",EXTERNALDIRLIGHTS:"ExternalDirLights",LIGHTHELPER:"LightHelper",GLOBALEARTH:"GlobelEarth"},Yp={EPSILON1:.1,EPSILON2:.01,EPSILON3:.001,EPSILON4:1e-4,EPSILON5:1e-5,EPSILON6:1e-6,EPSILON7:1e-7,EPSILON8:1e-8,EPSILON9:1e-9,EPSILON10:1e-10,EPSILON11:1e-11,EPSILON12:1e-12,EPSILON13:1e-13,EPSILON14:1e-14,EPSILON15:1e-15,EPSILON16:1e-16,EPSILON17:1e-17,EPSILON18:1e-18,EPSILON19:1e-19,EPSILON20:1e-20,EPSILON21:1e-21,ONE_Megabytes:1048576,ONE_GIGABYTES:1073741824,TWO_PI:2*Math.PI,PI_OVER_TWO:Math.PI/2,RADIANS_PER_DEGREE:Math.PI/180,RADIANS_PER_ARCSECOND:Math.PI/180/3600,mod:function(e,t){return(e%t+t)%t},clamp:function(e,t,i){return t>e?t:e>i?i:e},normalize:function(e,t,i){return 0===(i=Math.max(i-t,0))?0:Math.clamp((e-t)/i,0,1)},isolateDigits:function(e,t,i){return parseInt(e*Math.pow(10,t),0)*Math.pow(10,i)},lessThan:function(e,t,i){return-i>e-t},lessThanOrEquals:function(e,t,i){return i>e-t},greaterThan:function(e,t,i){return e-t>i},greaterThanOrEquals:function(e,t,i){return e-t>-i},equalsEpsilonVec3:function(e,t,i){return Math.equalsEpsilon(e.x,t.x,i)&&Math.equalsEpsilon(e.y,t.y,i)&&Math.equalsEpsilon(e.z,t.z,i)},equalsEpsilonMatrix4:function(e,t,i){i=i||0;for(var n=e.elements,r=t.elements,o=0;16>o;o+=1)if(!Yp.equalsEpsilon(n[o],r[o],i))return!1;return!0},equalsEpsilonQuaternion:function(e,t,i){return Yp.equalsEpsilon(e._x,t._x,i=i||0)&&Yp.equalsEpsilon(e._y,t._y,i)&&Yp.equalsEpsilon(e._z,t._z,i)&&Yp.equalsEpsilon(e._w,t._w,i)},equalsEpsilonFrustum:function(e,t,i){i=i||0;for(var n=e.planes,r=t.planes,o=0;6>o;o+=1)if(!Yp.equalsEpsilonVec3(n[o].normal,r[o].normal,i)||!Yp.equalsEpsilon(n[o].constant,r[o].constant,i))return!1;return!0},incrementWrap:function(e,t,i){return i=void 0!==i?i:0,++e>t&&(e=i),e},isPowerOfTwo:function(e){return 0!==e&&0==(e&e-1)},nextPowerOfTwo:function(e){return--e,e|=e>>1,e|=e>>2,e|=e>>4,e|=e>>8,e|=e>>16,++e},maxComponent:function(e,t){var i=Math.max(Math.abs(e.x),Math.abs(t.x)),n=Math.max(Math.abs(e.y),Math.abs(t.y)),r=Math.max(Math.abs(e.z),Math.abs(t.z));return Math.max(Math.max(i,n),r)},getMatrix3:function(e){var t=e.elements,i=new De;return i.elements[0]=t[0],i.elements[1]=t[1],i.elements[2]=t[2],i.elements[3]=t[4],i.elements[4]=t[5],i.elements[5]=t[6],i.elements[6]=t[8],i.elements[7]=t[9],i.elements[8]=t[10],i},bezierCurveFn:function(e,t,i,n){return n>1&&(n=1),(1-n)*(1-n)*e+2*n*(1-n)*t+n*n*i},tweens:function(e,t,i,n){var r=i%n/n;return 0>r&&(r*=-1),r>1&&(r=1),Yp.linear([e,t],r)},breatheTweens:function(e,t,i,n){var r=i%n/(.5*n)-1;return 0>r&&(r*=-1),r>1&&(r=1),Yp.linear([e,t],r)},linear:function(e,t){var i=Yp,n=e.length-1,r=n*t,o=Math.floor(r);return 0>t?i.linearFn(e[0],e[1],r):t>1?i.linearFn(e[n],e[n-1],n-r):i.linearFn(e[o],e[o+1>n?n:o+1],r-o)},linearFn:function(e,t,i){return(t-e)*i+e},negativePiToPi:function(e){if(!wp.defined(e))throw new Error("angle is required.");return Yp.zeroToTwoPi(e+Math.PI)-Math.PI},zeroToTwoPi:function(e){if(!wp.defined(e))throw new Error("angle is required.");var t=Yp.mod(e,Yp.TWO_PI);return Math.abs(t)<this.EPSILON14&&Math.abs(e)>this.EPSILON14?Yp.TWO_PI:t},equalsEpsilon:function(e,t,i,n){if(!wp.defined(e))throw new Error("left is required.");if(!wp.defined(t))throw new Error("right is required.");i=wp.defaultValue(i,0),n=wp.defaultValue(n,i);var r=Math.abs(e-t);return n>=r||r<=i*Math.max(Math.abs(e),Math.abs(t))},equalsEpsilonVector3:function(e,t,i,n){return e===t||wp.defined(e)&&wp.defined(t)&&this.equalsEpsilon(e.x,t.x,i,n)&&this.equalsEpsilon(e.y,t.y,i,n)&&this.equalsEpsilon(e.z,t.z,i,n)},isMirror:function(e){var t=wp.scratchVector_2,i=wp.scratchVector_3,n=e.elements,r=wp.scratchVector_1.set(n[0],n[1],n[2]),o=t.set(n[4],n[5],n[6]),a=i.set(n[8],n[9],n[10]);return 0>r.cross(o).dot(a)}},Hp=function(e,t,i,n,r,o,a,s,l,c){this.name=e,this.position=t,this.target=i,this.up=n,this.near=r,this.far=o,this.zoom=a,this.frustumWidth=l,this.frustumHeight=c,this.version=void 0===s?1:s},jp=function(e,t,i,n,r,o,a,s,l,c,h){Hp.call(this,Md.PERSPECTIVE,e,t,i,o,a,s,l,c,h),this.fov=n,this.aspect=r},Wp=function(e,t,i,n,r,o,a,s,l,c,h,d,u){Hp.call(this,Md.ORTHOGRAPHIC,e,t,i,s,l,c,h,d,u),this.left=n,this.right=r,this.top=o,this.bottom=a},Jp=new Ke,zp=new Ke,qp=new yt,Zp={createCameraInfo:function(e){var t=e.camera,i=new Hp(e.getCameraName(),t.position,t.target,t.up);return JSON.stringify(i)},transformCamera:function(e,t){var i=new Ke,n=function(e){return[parseFloat(e[0]),parseFloat(e[1]),parseFloat(e[2])]};i.fromArray(n(e.position.split(",")));var r=new Ke;r.fromArray(n(e.direction.split(",")));var o=new Ke;o.fromArray(n(e.up.split(",")));var a=new Ke;a.addVectors(i,r),i.applyMatrix4(t.rootNode.matrix),a.applyMatrix4(t.rootNode.matrix);var s=new yt;return s.makeRotationFromEuler(t.rootNode.rotation),o.applyMatrix4(s),o.normalize(),new Hp(e.name,i,a,o)},parseCameraInfo:function(e){if(!e)return null;var t=JSON.parse(e);if(!t.hasOwnProperty("position")||!t.hasOwnProperty("target")||!t.hasOwnProperty("up"))return null;var i=t.name||Md.PERSPECTIVE,n=new Ke;n.x=t.position.x,n.y=t.position.y,n.z=t.position.z;var r=new Ke;r.x=t.target.x,r.y=t.target.y,r.z=t.target.z;var o=new Ke;o.x=t.up.x,o.y=t.up.y,o.z=t.up.z;var a=void 0===t.version?0:t.version,s=t.frustumWidth,l=t.frustumHeight;return i===Md.PERSPECTIVE?new jp(n,r,o,t.fov,t.aspect,t.near,t.far,t.zoom,a,s,l):new Wp(n,r,o,t.left,t.right,t.top,t.bottom,t.near,t.far,t.zoom,a,s,l)},canvasToNormalized:function(e,t,i){var n={x:0,y:0,z:0};return n.x=e.x/t*2-1,n.y=-e.y/i*2+1,n.z=e.z||0,n},normalizedToCanvas:function(e,t,i){var n={x:0,y:0,z:0};return n.x=Math.floor(.5*(e.x+1)*t+.5),n.y=Math.floor(-.5*(e.y-1)*i+.5),n.z=e.z||0,n},drawingToCanvas:function(e,t,i,n){var r=new Ke(t.x,t.y,t.z);return r.project(e),this.normalizedToCanvas(r,i,n)},drawingPointsToCanvas:function(e,t,i,n,r){var o={};qp.copy(e.matrixWorld).invert();var a=new Ke(t.x,t.y,t.z);a.applyMatrix4(qp);var s=new Ke(i.x,i.y,i.z);if(s.applyMatrix4(qp),a.z>0&&s.z>0)return null;var l=a.clone().sub(s);if(l.normalize(),a.z>0)a.sub(l.multiplyScalar((a.z+e.near)/l.z));else if(s.z>0){s.sub(l.multiplyScalar((s.z+e.near)/l.z))}return a.applyMatrix4(e.projectionMatrix),s.applyMatrix4(e.projectionMatrix),o.start=this.normalizedToCanvas(a,n,r),o.end=this.normalizedToCanvas(s,n,r),o},lineIntersectWithRect:function(e,t){if(e&&e.start.x===e.end.x&&e.start.y===e.end.y)return Bu.log("Invalid line."),null;var i,n=0;e.start.x!==e.end.x&&(n=(e.start.y-e.end.y)/(e.start.x-e.end.x));var r=[],o=t.min,a=t.max;return o.y>n*o.x+(i=e.start.y-n*e.start.x)||n*o.x+i>a.y||r.push(new ke(o.x,n*o.x+i)),o.y>n*a.x+i||n*a.x+i>a.y||r.push(new ke(a.x,n*a.x+i)),0===n&&(r.push(new ke(o.x,i)),r.push(new ke(a.x,i))),(o.y-i)/n>o.x&&a.x>(o.y-i)/n&&r.push(new ke((o.y-i)/n,o.y)),(a.y-i)/n>o.x&&a.x>(a.y-i)/n&&r.push(new ke((a.y-i)/n,a.y)),r},canvasToDrawing:function(e,t,i,n){var r=this.canvasToNormalized(t,i,n),o=new Ke(r.x,r.y,r.z);return o.unproject(e),{x:o.x,y:o.y,z:o.z}},intersectBoxByRay:function(e,t){var i=0,n=0,r=0,o=0,a=0,s=0,l=1/e.direction.x,c=1/e.direction.y,h=1/e.direction.z,d=e.origin;return 0>l?(i=(t.max.x-d.x)*l,n=(t.min.x-d.x)*l):(i=(t.min.x-d.x)*l,n=(t.max.x-d.x)*l),0>c?(r=(t.max.y-d.y)*c,o=(t.min.y-d.y)*c):(r=(t.min.y-d.y)*c,o=(t.max.y-d.y)*c),i>o||r>n?null:((r>i||isNaN(i))&&(i=r),(n>o||isNaN(n))&&(n=o),0>h?(a=(t.max.z-d.z)*h,s=(t.min.z-d.z)*h):(a=(t.min.z-d.z)*h,s=(t.max.z-d.z)*h),i>s||a>n?null:((a>i||isNaN(i))&&(i=a),(n>s||isNaN(n))&&(n=s),0>n?null:0>i?n:i))},intersectObject:function(e,t,i,n,r){if((!r||e.visible)&&(e.raycast(t,i),!0===n&&e.children))for(var o=e.children,a=0,s=o.length;s>a;a+=1)Zp.intersectObject(o[a],t,i,!0,r)},intersectObjectWithFrustum:(Pp=new He,function(e,t){if(!e.boundingBox||e instanceof nn){var i=e.geometry;null===i.boundingBox&&i.computeBoundingBox(),Pp.copy(i.boundingBox)}else Pp.copy(e.boundingBox);return Pp.applyMatrix4(e.matrixWorld),t.intersectsBox(Pp)}),equalsCamera:function(e,t){var i=Yp.EPSILON15;return Yp.equalsEpsilonVec3(e.position,t.position,i)&&Yp.equalsEpsilonVec3(e.up,t.up,i)&&Yp.equalsEpsilonVec3(e.realUp,t.realUp,i)&&Yp.equalsEpsilonVec3(e.getWorldDirection(Jp),t.getWorldDirection(zp),i)&&Yp.equalsEpsilonFrustum(e.frustum,t.frustum,i)}},Xp=function(e,t,i,n){this.ray=new At(e,t),this.near=i||0,this.far=n||1/0,this.params={Sprite:{},Mesh:{},Points:{threshold:1},LOD:{},Line:{}}};Xp.prototype={constructor:Xp,precision:1e-4,linePrecision:1,descSort:function(e,t){return e.distance-t.distance},set:function(e,t){this.ray.set(e,t)},setFromCamera:function(e,t){t instanceof Ep?t.isPerspective?(this.ray.origin.copy(t.position),this.ray.direction.set(e.x,e.y,.5).unproject(t).sub(t.position).normalize()):(this.ray.origin.set(e.x,e.y,-1).unproject(t),this.ray.direction.set(0,0,-1).transformDirection(t.matrixWorld)):t instanceof dn?(this.ray.origin.copy(t.position),this.ray.direction.set(e.x,e.y,.5).unproject(t).sub(t.position).normalize()):t instanceof pc?(this.ray.origin.set(e.x,e.y,-1).unproject(t),this.ray.direction.set(0,0,-1).transformDirection(t.matrixWorld)):Bu.error("Raycaster: Unsupported camera type.")},intersectObject:function(e,t){var i=[];return Zp.intersectObject(e,this,i,t),i.sort(this.descSort),i.length>0?i[0]:null},intersectObjects:function(e){for(var t=arguments.length>1&&void 0!==arguments[1]&&arguments[1],i=2>=arguments.length||void 0===arguments[2]||arguments[2],n=[],r=0,o=e.length;o>r;r+=1)Zp.intersectObject(e[r],this,n,t,i);return n.sort(this.descSort),n.length>0?n[0]:null},intersectOctantForNode:function(e,t){var i=this,n=new He;!function e(r){var o=null,a=null;if(n.set(r.min,r.max),i.ray.intersectBox(n)&&(t.push(r),r.childOctants))for(o=0,a=r.childOctants.length;a>o;o+=1)e(r.childOctants[o])}(e)}},At.prototype.intersectBoxWithDistance=function(e){var t=null,i=null,n=null,r=null,o=null,a=null,s=1/this.direction.x,l=1/this.direction.y,c=1/this.direction.z,h=this.origin;if(0>s?(i=(e.max.x-h.x)*s,t=(e.min.x-h.x)*s):(i=(e.min.x-h.x)*s,t=(e.max.x-h.x)*s),0>l?(r=(e.max.y-h.y)*l,n=(e.min.y-h.y)*l):(r=(e.min.y-h.y)*l,n=(e.max.y-h.y)*l),i>n||r>t)return-1;if((r>i||isNaN(i))&&(i=r),(t>n||isNaN(t))&&(t=n),0>c?(a=(e.max.z-h.z)*c,o=(e.min.z-h.z)*c):(a=(e.min.z-h.z)*c,o=(e.max.z-h.z)*c),i>o||a>t)return-1;if((a>i||isNaN(i))&&(i=a),(t>o||isNaN(t))&&(t=o),0>t)return-1;if(0>i)return 0;var d=new Ke;this.at(0>i?t:i,d);var u=d.x-h.x,p=d.y-h.y,g=d.z-h.z;return Math.sqrt(u*u+p*p+g*g)};var _p=function(){function e(){ru(this,e)}return au(e,null,[{key:"getBox",value:function(e,t){var i=new He;if(Array.isArray(e)&&6===e.length&&i.setFromArray(e),e.region){var n=e.region;i.set(be.radToDeg(n[0]),be.radToDeg(n[2]),be.radToDeg(n[1]),be.radToDeg(n[3]))}if(e.box){var r=e.box,o=new Ke(r[0],r[1],r[2]),a=o.x-Math.abs(r[3]),s=o.x+Math.abs(r[3]),l=o.y-Math.abs(r[7]),c=o.y+Math.abs(r[7]),h=o.z-Math.abs(r[11]),d=o.z+Math.abs(r[11]);i.set(new Ke(a,l,h),new Ke(s,c,d))}if(e.sphere){var u=new ct(new Ke(e.sphere[0],e.sphere[1],e.sphere[2]),e.sphere[3]);i.copy(u.getBoundingBox())}return t&&i.applyMatrix4(t),i}},{key:"getDracoLibUrl",value:function(){return xd.DracoLibUrl?xd.DracoLibUrl:window.LoaderConfig&&window.LoaderConfig.fullStaticHost?(xd.DracoLibUrl=window.LoaderConfig.fullStaticHost+"/lib/draco/",xd.DracoLibUrl):(xd.DracoLibUrl="../../lib/draco/",xd.DracoLibUrl)}},{key:"getDracoLoader",value:function(){return void 0===this.dracoLoader&&(this.dracoLoader=new(void 0),this.dracoLoader.setDecoderPath(e.getDracoLibUrl())),this.dracoLoader}},{key:"praseUserData",value:function(e){if(void 0!==e){var t={};return e.map((function(e){t[e[0]]=e[1]})),t}}},{key:"getDebugColor",value:function(e,t){if(-1===e)return Debug.DebugColor.BLACK;if(!t)return Debug.DebugColor.GRAY;var i=Debug.DebugColorArray;return i[e%i.length]}},{key:"nodeIndexGroupsSort",value:function(e){var t=[];for(var i in e)for(var n=e[i],r=0,o=n.length;o>r;++r)t.push({userId:i,indexGroup:n[r]});return t.sort((function(e,t){return e.indexGroup.indexStart-t.indexGroup.indexStart})),t}},{key:"matchLineCategory",value:function(e,t){if(!(t instanceof Object))return!0;var i=t.key;return e[i]&&!0===t.value[e[i]]}},{key:"isNodeInVisible",value:function(e){return!(e&&!1!==e.visible&&(!e.parent||!1!==e.parent.visible))}},{key:"isInstanceNodeInVisible",value:function(e){return!e||!1===e.visible}}]),e}();_p.max_uncompressed_blob_size=8388608,_p.TILE_DATA_INDEX="INDEX",_p.TILE_DATA_USERDATA="USERDATA",_p.TILE_DATA_MATERIAL="MATERIAL",_p.TILE_TEXTURE_NONE="TEXTURENONE",_p.TILE_TEXTURE_LOADING="TEXTURE_LOADING",_p.TILE_TEXTURE_LOADED="TEXTURELOADED",_p.TWO_ACCURACY=.01,_p.SIX_ACCURACY=1e-7,_p.BMD_GEOMETRIC_ERROR_COEFFICIENT=1,_p.OP_GEOMETRIC_ERROR_COEFFICIENT=.25,_p.Minimum_Setting_SSEHold=.001,_p.MODEL_SSE_Threshold_MAP={"3dtiles":_p.OP_GEOMETRIC_ERROR_COEFFICIENT,osgb:_p.OP_GEOMETRIC_ERROR_COEFFICIENT,shp:_p.OP_GEOMETRIC_ERROR_COEFFICIENT,bim:_p.BMD_GEOMETRIC_ERROR_COEFFICIENT},_p.PICK_EFFECT_MODEL_TYPE={bim:!0,shp:!0,kml:!0,citygml:!0};var $p=new yt,eg=function e(){ru(this,e),this.scene=null,this.camera=null,this.octreeRoots=null,this.octantMap=null,this.mouse=new ke,this.canvasMouse=new ke},tg=function(){function e(t){ru(this,e),this.viewer=t,this.filter=t.getFilter(),this.raycaster=new Xp,this.recursive=!0,this.lastIntersect=null,this.highPriorities=[Vp.EXTRUDEBODYMANAGER],this._ground=null,this._pickedLocalPos=null,this._pickedWorldPos=null}return au(e,[{key:"destroy",value:function(){this.viewer=null,this.filter=null,this.raycaster=null,this.lastIntersect=null,this.highPriorities=null,this._ground=null,this._pickedLocalPos=null,this._pickedWorldPos=null}},{key:"defaultIntersect",value:function(e,t,i,n,r){if(e.visible||r){var o=[];e.raycast(this.raycaster,o);var a=[];if(o.length>0)for(var s=0;o.length>s;s++)o[s].distance>i.far||i.near>o[s].distance||e.name!=xd.TilePlaneGroupName&&this.viewer.clipPoint(o[s].point)||null==o[s]||a.push(o[s]);return n?a:(a.sort((function(e,t){return e.distance-t.distance})),a.length>0?a[0]:null)}}},{key:"intersectMeshesWithDistance",value:function(e,t,i,n,r,o,a,s){if(!t||!t.mesh)return null;var l=0,c=wp.MinusEpsilon,h=this.raycaster,d=[],u=this.filter,p=u._hasVisibleFilter(),g=u._hasPickableFilter(),f=this.viewer.modelManager,m=function(e,t){var i=f.isHiddenSourceObjectUserId(e.userId);if(t){if(p&&!u._isVisible(e)||g&&!u._isPickable(e)||i)return!0}else if(p&&!u._isVisible(e)||i)return!0;return!1};!0===this.byGravity?n.near=0:n.near+=c;var A=t.info,y=t.mesh,v=[];if(Bu.time("kdNode Pick"),r&&o&&!o.explosioning){var C=[],I=new yt;I.copy(o.getModelMatrix()).invert();var x=h.ray.clone().applyMatrix4(I);if(Array.isArray(r))for(var w=new yt,M=0;r.length>M;M+=1){var E=r[M],B=E.modelKey,S=x;if(B)w.copy(o.subModel[B]).invert(),S=x.clone().applyMatrix4(w);E.intersect(S,C)}else r.intersect(x,C);v=wp.unique(C)}else v=o.getComponentlist();Bu.timeEnd("kdNode Pick");var b=Object.keys(o.manager.explosionList);if(o&&o.manager&&b.length>0&&(v=v.concat(b),v=wp.unique(v)),Object.keys(f.transformComponent).length>0){for(var k in f.transformComponent)v.push(k);v=wp.unique(v)}var D=this.viewer.modelManager.getMatrixWorldGlobal();Bu.time("Box Pick");for(var T=0,R=v.length;R>T;T+=1){var U=A[v[T]];if(U){var F=U[0];if(F){var Q=F.boundingBox.clone();if(Q.applyMatrix4(o.getModelMatrix()).applyMatrix4(D),(l=h.ray.intersectBoxWithDistance(Q))>=n.near&&n.far>=l)for(var L=0,O=U.length;O>L;L+=1){var N=U[L];if(!m(N,i)){var P=y[this.viewer.modelManager.getMeshIdFromOctantMap(N)];if(P)for(var G=0,K=P.length;K>G;G+=1)d.push({object:P[G],distance:l,nodeInfo:N})}}}}}Bu.timeEnd("Box Pick"),Bu.time("Ending Pick"),d.sort((function(e,t){return e.distance-t.distance}));for(var V=[],Y=0;d.length>Y;Y+=1)d[Y].distance>n.far||n.near>d[Y].distance||d[Y].object.raycast(h,d[Y].nodeInfo,n,this.viewer,V,s);return V.sort((function(e,t){return e.distance-t.distance})),s?V:(Bu.timeEnd("Ending Pick"),V.length>0?V[0]:null)}},{key:"intersectMeshesWithRender",value:function(e,t,i,n,r,o,a,s){if(!t||!t.mesh)return null;var l=wp.MinusEpsilon,c=this.raycaster,h=this.filter;h._hasVisibleFilter(),h._hasPickableFilter(),!0===this.byGravity?n.near=0:n.near+=l;var d=t.mesh;this.viewer.modelManager.getMatrixWorldGlobal();var u=[],p=o.picker.getPickedIdByMouseEx(this.raycaster.canvasMouse.x,this.raycaster.canvasMouse.y,null,i),g=o.getModelDescriptor().getNodeInfosByElementId(p.pickedId);if(g)if(i){var f={indexStart:3*g.group.start,indexCount:3*g.group.count,matrix:(new yt).multiplyMatrices(g.matrix,o.getModelDescriptor().rootGroupNodeMatrix),userId:g.componentKey,nodeId:g.nodeId,isMixNode:!0},m=d[g.mesh.uuid];if(!m)return null;for(var A=0,y=m.length;y>A;A+=1)m[A].raycast(c,f,n,this.viewer,u,s)}else u.push({userId:g.componentKey,object:g.mesh,point:p.point,distance:p.distance,modelKey:o.modelKey,nodeInfo:g});return u.sort((function(e,t){return e.distance-t.distance})),s?u:(Bu.timeEnd("Ending Pick"),u.length>0?u[0]:null)}},{key:"intersect",value:function(e,t,i,n){var r=this.raycaster;null===t?r.setFromCamera(e.mouse,e.camera):r.set(t.origin,t.direction);Bu.time("intersect time"),r.camera=e.camera,r._camera=e.camera,r.viewportSize=e.viewportSize,r.canvasMouse=e.canvasMouse;var o=new Ke;e.camera.getWorldDirection(o);var a=o.dot(r.ray.direction),s={near:e.camera.near/Math.abs(a),far:e.camera.far/Math.abs(a)},l=[],c=e.scene.getGroups(),h=this.viewer.terrainOperationManager,d=new ke;this.viewer.cameraControl.mapViewportToWindow(e.mouse.x,e.mouse.y,d);for(var u=0;c.length>u;u+=1)if(c[u].isPickable()&&0!==c[u].children.length&&(c[u].name!=xd.TilePlaneGroupName||!h.pickExcavation(d))){var p=null,g=e.scene.getGroupType(c[u].name),f=g.modelKey;if(-1<this.highPriorities.indexOf(g.groupType))p=this.defaultIntersect(c[u],i,s,void 0,!0),p&&(p.objectType=c[u].pickableType,p.hoverEnabled=c[u].hoverEnabled,l.push(p));else{var m=this.viewer.modelManager.getModel(g.modelKey),A=m?m.getTransformMatrix():new yt;if(this.filter._isModelPickable(f))switch(g.groupType){case Vp.MODEL:m&&m.isDataReady()&&m.isVisible()&&(p=m.picker&&e.canvasMouse?this.intersectMeshesWithRender([],e.octantMap[f],i,s,m.kdTreeNode,m):this.intersectMeshesWithDistance([],e.octantMap[f],!1,s,m.kdTreeNode,m),p&&(p.modelKey=m.modelKey,p.objectType=c[u].pickableType,p.hoverEnabled=c[u].hoverEnabled,l.push(p)));break;case Vp.GEOMETRY:for(var f in e.octreeRoots)p=this.intersectMeshesWithDistance([],e.octantMap[f],i,s,false,!1,A,f),p&&(p.objectType=c[u].pickableType,p.hoverEnabled=c[u].hoverEnabled,l.push(p));break;case Vp.EXTERNALCOMPONENTMANAGER:p=this.intersectExternalComponent(c[u],i,s),p&&(p.objectType=c[u].pickableType,p.hoverEnabled=c[u].hoverEnabled,l.push(p));break;case Vp.BIMTILESGROUP:if(m)if(p=!0===_p.PICK_EFFECT_MODEL_TYPE[m.config.metadata.content]||m.config.metadata.enableSelect?this.intersectBimTile(m,i,s,false,!1,A):this.defaultIntersect(c[u],i,s),p){var y=m.tilesLoader.tileReader.getUserIdByIndex(p.userId);p.userId=y,p.objectType=c[u].pickableType,p.hoverEnabled=c[u].hoverEnabled,l.push(p)}break;default:p=this.defaultIntersect(c[u],i,s),p&&(p.objectType=c[u].pickableType,p.hoverEnabled=c[u].hoverEnabled,l.push(p))}}}l.sort((function(e,t){return e.distance-t.distance})),Bu.timeEnd("intersect time");var v=l.length;if(v>0)for(var C=null,I=0;v>I;I+=1){p=l[I];var x=p.object;if(x.geometry){if(p.objectType===Rd.Marker3d?p.userId=p.id:void 0===p.userId&&(p.userId=x.userId||x.key||x.name),p.modelKey=x.modelKey,p.fileId=x.fileId,C)return C.intersectWithoutMap=p,C;if(this.lastIntersect={intersect:p,pickable:i},p.objectType!==Rd.Map||I>=v-1)return p;C=p}}return this.lastIntersect=null,null}},{key:"_intersectOctantForNodeByBox",value:function(e,t,i){var n=new He;!function t(r){var o,a;if(n.set(r.min,r.max),e.intersectsBox(n)&&(i.push(r),r.childOctants))for(o=0,a=r.childOctants.length;a>o;o++)t(r.childOctants[o])}(t)}},{key:"intersectMeshByBox",value:function(e,t,i,n,r){if(!t||!t.mesh)return null;var o=[],a=this.filter,s=a._hasVisibleFilter();a._hasPickableFilter();var l=this.viewer.modelManager,c=function(e){var t=l.isHiddenSourceObjectUserId(e.userId);return!!(s&&!a._isVisible(e)||t)},h=t.info,d=t.mesh,u=[],p=this.viewer.modelManager.getMatrixWorldGlobal();if(i)for(var g=function e(t,i){if(i.push(t),t.childOctants)for(var n=0,r=t.childOctants.length;r>n;n++)e(t.childOctants[n],i)},f=0,m=e.length;m>f;f++)g(e[f],u);else for(var A=r.clone().applyMatrix4(p),y=0,v=e.length;v>y;y++)this._intersectOctantForNodeByBox(A,e[y],u);for(var C=0,I=u.length;I>C;C++){var x=h[u[C].octantId];if(x)for(var w=0,M=x.length;M>w;w++){var E=x[w];if(!c(E)){var B=E.boundingBox.clone();if(B.applyMatrix4(n),r.intersectsBox(B)){var S=d[this.viewer.modelManager.getMeshIdFromOctantMap(E)];if(S)for(var b=0,k=S.length;k>b;b++)S[b].intersectByBox(r,o,E)&&(o[o.length-1].userId=E.userId)}}}}return o}},{key:"intersectByBox",value:function(e,t){var i=this,n={},r=e.scene.getObjectGroups(),o=this.viewer.terrainOperationManager,a=new ke;this.viewer.cameraControl.mapViewportToWindow(e.mouse.x,e.mouse.y,a);for(var s=0;r.length>s;s++)if(r[s].isPickable()&&0!==r[s].children.length&&(r[s].name!=xd.TilePlaneGroupName||!o.pickExcavation(a))){var l=null,c=e.scene.getGroupType(r[s].name),h=this.viewer.modelManager,d=h.getModel(c.modelKey),u=d?d.getTransformMatrix():new yt,p=!1;switch(p=!!(d&&d.id&&h.explosionManager.isExploded(d.id)),c.groupType){case Vp.MODEL:e.octreeRoots[g=c.modelKey]&&e.octantMap[g]&&(l=this.intersectMeshByBox(e.octreeRoots[g],e.octantMap[g],p,u,t)).forEach((function(e){n[e.userId]=!0}));break;case Vp.GEOMETRY:for(var g in e.octreeRoots)(l=this.intersectMeshByBox(e.octreeRoots[g],e.octantMap[g],p,u,t)).forEach((function(e){n[e.userId]=!0}));break;case Vp.BIMTILESGROUP:d&&function(){(!0===_p.PICK_EFFECT_MODEL_TYPE[d.config.metadata.content]||d.config.metadata.enableSelect)&&(l=i.intersectBimTile(d,!1,{near:0,far:1/0},p,!0,u,t));var e=d.tilesLoader.tileReader;l.forEach((function(t){var i=e.getUserIdByIndex(t.userId);n[i]=!0}))}()}}return Object.keys(n)}},{key:"getObjectsByClientCoordinates",value:function(e){var t=this.viewer.cameraControl.getIntersectContext(e),i=this.raycaster;return i.setFromCamera(t.mouse,t.camera),i.camera=t.camera,i.viewportSize=t.viewportSize,this.getObjectsByRaycaster(t,i)}},{key:"getObjectsByRaycaster",value:function(e,t,i){var n=this;this.raycaster=t;for(var r={near:i?0:e.camera.near,far:Infinity},o=[],a=e.scene.getGroups(),s=function(){if(!a[l].isPickable()||0===a[l].children.length)return"continue";c=[],h=e.scene.getGroupType(a[l].name);var t=n.viewer.modelManager.getModel(d=h.modelKey),i=t?t.getTransformMatrix():new yt;switch(h.groupType){case Vp.MODEL:if(d=h.modelKey,t&&t.isDataReady()&&t.isVisible()){var s=n.intersectMeshesWithDistance([],e.octantMap[d],!1,r,t.kdTreeNode,t);s&&(s.objectType=a[l].pickableType,s.hoverEnabled=a[l].hoverEnabled,c.push(s))}break;case Vp.GEOMETRY:for(d in e.octreeRoots)null!=(c=n.intersectMeshesWithDistance(e.octreeRoots[d],e.octantMap[d],!1,r,false,!0,i,d))&&(o=o.concat(c));break;case Vp.BIMTILESGROUP:if(!0===_p.PICK_EFFECT_MODEL_TYPE[t.config.metadata.content])for(var u=(c=n.intersectBimTile(t,!0,r,false,!0,i)).length,p=0;u>p;++p){var g=c[p],f=t.tilesLoader.tileReader.getUserIdByIndex(g.userId);g.userId=f}else c=n.defaultIntersect(a[l],!1,r,!0);null!=c&&(c.forEach((function(e){return e.modelKey=t.id})),o=o.concat(c));break;default:null!=(c=n.defaultIntersect(a[l],!1,r,!0))&&(o=o.concat(c))}},l=0;a.length>l;l++){var c,h,d;s()}o.sort((function(e,t){return e.distance-t.distance}));var u,p=new Map,g=vu(o);try{for(g.s();!(u=g.n()).done;){var f=u.value;p.has(f.userId)||p.set(f.userId,f)}}catch(e){g.e(e)}finally{g.f()}return o=mu(p.values())}},{key:"hitTest",value:function(e){var t=this.intersect(e,null,!1);return null!==t?t.point:null}},{key:"pick",value:function(e,t){var i=this.intersect(e,null,!0);return t&&t(i),i}},{key:"pickGlobe",value:function(e,t){var i=this.raycaster,n=e.scene.getObjectGroup(xd.TilePlaneGroupName);if(!n||!n.visible)return null;i.setFromCamera(e.mouse,e.camera),i.camera=e.camera,i.viewportSize=e.viewportSize,e.scene.shrinkScopeByClipPlane(i,{near:0,far:1/0});var r=[];n.raycast(this.raycaster,r),r.sort((function(e,t){return e.distance-t.distance}));var o=r.length>0?r[0]:null;return o&&(o.objectType=n.pickableType,o.hoverEnabled=n.hoverEnabled),o}},{key:"pickGround",value:function(e,t){var i=e.viewer.ground;if(!i)return console.log("there is no ground in current viewer"),null;if(!e.camera)return console.log("camera have not been initialized"),null;var n,r=this.raycaster;r.setFromCamera(e.mouse,e.camera),r.camera=e.camera,r.viewportSize=e.viewportSize;var o=i.intersect(r.ray);if(o){var a=e.scene.getMatrixGlobal();this._pickedWorldPos||(this._pickedWorldPos=new Ke),$p.copy(a).invert(),this._pickedWorldPos.setX(o.x),this._pickedWorldPos.setY(o.y),this._pickedWorldPos.setZ(o.z),this._pickedWorldPos.applyMatrix4($p),n={point:o,worldPosition:this._pickedWorldPos.setZ(i.elevation),pickFromReferencePlane:!0}}return t&&t(n),n}},{key:"getIntersectByRay",value:function(e,t){return this.intersect(e,t,!0)}},{key:"intersectBimTile",value:function(e,t,i,n,r,o,a){var s=this.raycaster,l=e.getAllNodeInfos(),c=this.viewer.modelManager.getMatrixWorldGlobal(),h=e.tilesLoader.tileReader.getSearchTreeBuffer(),d=this.viewer.modelManager,u=e.getFilter(),p=u._hasVisibleFilter(),g=u._hasPickableFilter(),f=a?function(e,t,i){var n=e.clone();return n.applyMatrix4(t),a.intersectsBox(n)?1:-1}:function(e,t,i){var n=e.clone();return n.applyMatrix4(t),n.applyMatrix4(i),s.ray.intersectBoxWithDistance(n)},m=function(e){return!e||!e.parent||!1===e.visible||!1===e.parent.visible};function A(e,t){var i=d.isHiddenSourceObjectUserId(e.userId);if(t){if(p&&!u._isVisible(e)||g&&!u._isPickable(e)||i)return!0}else if(p&&!u._isVisible(e)||i)return!0;return!1}for(var y in h){var v=h[y].searchTreeBlob,C=f(h[y].box,o,c);!n&&C<0||(v.getNodeIdsList(),v.getOctreeList(),v.getOctreeList())}var I=[];for(var x in{}){var w=l[x];if(w)for(var M=0,E=w.length;E>M;M++){var B=w[M];if(!A(B,t)){var S=f(B.boundingBox,o,c);if(S>=i.near&&i.far>=S){var b=B.parent||B.nodeId;if(B.instanceOrNot){var k=e.tilesLoader.getInstanceMeshNodeById(b);if(!k)continue;if(void 0===B.matrix)continue;for(var D in k){var T=k[D].matrix,R=k[D].mesh;if(!m(R)){var U=Object.create(B),F=U.matrix.clone();F=F.multiply(T),U.matrix=F,I.push({meshNode:R,distance:S,nodeInfo:U,meshId:b})}}}else{var Q=e.tilesLoader.getMeshNodeById(b);if(!m(Q)){var L=Q.indexGroups;for(var O in L)for(var N=L[O],P=0,G=N.length;G>P;++P){var K=N[P];K.meshId===B.nodeId&&(K.userId=O,I.push({meshNode:Q,distance:S,nodeInfo:K,meshId:b}))}}}}}}}I.sort((function(e,t){return e.distance-t.distance}));for(var V=[],Y=this,H=a?function(e,t,i,n){e.intersectByBox(a,t,i,n)}:function(e,t,i,n){e.raycastByIndices(s,t,i,n),(t=t.filter((function(e){return!Y.viewer.clipPoint(e.point)&&e}))).sort((function(e,t){return e.distance-t.distance}))},j=0;I.length>j;j++){var W=[],J=I[j].nodeInfo,z=null;J.instanceOrNot&&(z=J.matrix),H(I[j].meshNode,W,J,z),0!==W.length&&(W[0].userId=J.userId,W[0].indexInfo=J,W[0].meshId=I[j].meshId,V.push(W[0]))}return V.sort((function(e,t){return e.distance-t.distance})),r?V:V[0]}},{key:"intersectExternalComponent",value:function(e,t,i,n,r){if(e.visible||r){for(var o=this.raycaster,a=this.filter,s=function e(t){var i=t,n=[];if(i.isGroup)for(var r=0,s=i.children.length;s>r;r+=1){var l=e(i.children[r]);n=n.concat(l)}else a._isPickable({userId:i.key})&&i.raycast(o,n);return n},l={},c=0,h=e.children.length;h>c;c+=1){var d=e.children[c],u=s(d);if(u.length>0){u.sort((function(e,t){return e.distance-t.distance})),u[0].userId=d.key;var p=l[d.key];p?p.distance>u[0].distance&&(l[d.key]=u[0]):l[d.key]=u[0]}}var g=[],f=Object.values(l);if(f.length>0)for(var m=0;f.length>m;m+=1)f[m].distance>i.far||i.near>f[m].distance||this.viewer.clipPoint(f[m].point)||g.push(f[m]);return n?g:(g.sort((function(e,t){return e.distance-t.distance})),g.length>0?g[0]:null)}}}]),e}(),ig=function(e){lu(i,e);var t=pu(i);function i(e){var n;return ru(this,i),(n=t.call(this)).type="PhongLightingMaterial",n.color=new pi(16777215),n.specular=new pi(1118481),n.shininess=30,n.emissive=new pi(0),n.isShaderMaterial=!0,n.map=null,n.shadowMapEnabled=!1,n.defines={},n.uniforms=ln.merge([wn.common,wn.lights,{diffuse:{value:new pi(16711680)},opacity:{value:1},specular:{value:new pi(1118481)},shininess:{value:30},emissive:{value:new pi(0)}}]),n.vertexShader=["varying vec3 vViewPosition;","varying vec3 vNormal;","#include <uv_pars_vertex>","#include <common>","#include <logdepthbuf_pars_vertex>","#include <shadowmap_pars_vertex>","void main() {"," #include <uv_vertex>"," #include <begin_vertex>"," #include <project_vertex>"," #include <logdepthbuf_vertex>"," #include <beginnormal_vertex>"," #include <defaultnormal_vertex>"," vNormal = normalize( transformedNormal );"," vViewPosition = - mvPosition.xyz;","}"].join("\n"),n.fragmentShader=["uniform vec3 diffuse;","uniform float opacity;","uniform vec3 specular;","uniform float shininess;","uniform vec3 emissive;","#include <common>","#include <uv_pars_fragment>","#include <map_pars_fragment>","#include <packing>","#include <bsdfs>","#include <lights_pars_begin>","#include <lights_phong_pars_fragment>","#include <specularmap_pars_fragment>","#include <shadowmap_pars_fragment>","#include <logdepthbuf_pars_fragment>","void main() {"," #include <logdepthbuf_fragment>"," vec4 diffuseColor = vec4( diffuse, opacity );","#ifdef USE_MAP"," vec4 texelColor = texture2D( map, vUv );"," texelColor = mapTexelToLinear( texelColor );"," diffuseColor = vec4(texelColor.rgb, opacity);","#endif"," ReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );"," vec3 totalEmissiveRadiance = emissive;"," float specularStrength = 1.0;"," #include <normal_fragment_begin>"," #include <normal_fragment_maps>"," #include <lights_phong_fragment>"," #include <lights_template>"," vec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + reflectedLight.directSpecular + reflectedLight.indirectSpecular + totalEmissiveRadiance;"," gl_FragColor = vec4( outgoingLight, diffuseColor.a );"," #if defined( TONE_MAPPING )"," gl_FragColor.rgb = toneMapping( gl_FragColor.rgb );"," #endif"," gl_FragColor = linearToOutputTexel( gl_FragColor );","}"].join("\n"),n.lights=!0,n.defaultAttributeValues={color:[1,1,1],uv:[0,0],uv2:[0,0]},void 0!==e&&(void 0!==e.attributes&&console.error("PhongLightingMaterial: attributes should now be defined in THREE.BufferGeometry instead."),n.setValues(e)),n.refreshUniforms(),n}return au(i,[{key:"copy",value:function(e){return gu(cu(i.prototype),"copy",this).call(this,e),this.color.copy(e.color),this.specular.copy(e.specular),this.shininess=e.shininess,this.emissive.copy(e.emissive),this}},{key:"refreshUniforms",value:function(){this.uniforms.diffuse.value.set(this.color),this.uniforms.opacity.value=this.opacity,this.uniforms.specular.value.set(this.specular),this.uniforms.shininess.value=this.shininess,this.uniforms.emissive.value.set(this.emissive),this.uniforms.map.value=this.map}}]),i}(cn),ng=function(){function e(t){ru(this,e),t=wp.defaultValue(t,{}),this._referencePlane=new Jt,this._elevation=wp.defaultValue(t.elevation,0);var i=wp.defaultValue(t.position,new Ke(0,0,0));i.y=this._elevation,this._position=i,this._direction=wp.defaultValue(t.direction,new Ke(0,1,0)),this._referencePlane.setFromNormalAndCoplanarPoint(this._direction,this._position),this._scratchInsertPoint=null}return au(e,[{key:"elevation",get:function(){return this._elevation}},{key:"show",value:function(){}},{key:"hide",value:function(){}},{key:"remove",value:function(){this._referencePlane=null}},{key:"update",value:function(){}},{key:"setColor",value:function(){}},{key:"setElevation",value:function(e){this._position.y=e,this._elevation=e,this._referencePlane.setFromNormalAndCoplanarPoint(this._direction,this._position)}},{key:"getElevation",value:function(){return this._elevation}},{key:"intersect",value:function(e){return this._scratchInsertPoint||(this._scratchInsertPoint=new Ke),e.intersectPlane(this._referencePlane,this._scratchInsertPoint)}}]),e}(),rg={"zh-cn":{YourGraphicsCardDoesNotSeemToSupportWebGL:"您的显卡似乎不支持WebGL",YourBrowserDoesNotSeemToSupportWebGL:"您的浏览器似乎不支持WebGL",YourBrowserDoesNotSeemToSupportPath2D:"您的浏览器或者浏览器内核似乎不支持Path2D",YourBrowserDoesNotSeemToSupportPath2DMethod:"您的浏览器或者浏览器内核不支持Path2D的一些方法您仍然可以查看图纸但是性能会下降",FindOutHowToGetItHere:"您可以在这里查看相关信息",SectionBoxLockHint:"请在使用此方法之前调用enableSectionBox。",APIAxisLockHint:"The API supports AxisOption.Z only for now.",Close:"关闭提示"},en:{YourGraphicsCardDoesNotSeemToSupportWebGL:"Your graphics card does not seem to support WebGL",YourBrowserDoesNotSeemToSupportWebGL:"Your browser does not seem to support WebGL",YourBrowserDoesNotSeemToSupportPath2D:"Your browser or Rendering Engine does not seem to support Path2D",YourBrowserDoesNotSeemToSupportPath2DMethod:"Your browser does not support some of Paht2D's methods, and you can still view the drawings, but the performance will degrade",FindOutHowToGetItHere:"Find out how to get it here",SectionBoxLockHint:"Please call enableSectionBox before using this method.",APIAxisLockHint:"The API supports AxisOption.Z only for now.",Close:"Close the tip"}},og={getAndroidVersion:function(e){var t=(e=e||navigator.userAgent).match(/Android\s([0-9.]*)/);return!!t&&t[1]},isTouchDevice:function(){return"undefined"!=typeof window&&"ontouchstart"in window},isBrowser:function(){return"undefined"!=typeof navigator},isIE11:function(){return og.isBrowser()&&Boolean(navigator.userAgent.match(/Edge|Trident\/7\./))},isIOSDevice:function(){return!!og.isBrowser()&&/ip(ad|hone|od)/.test(navigator.userAgent.toLowerCase())},isAndroidDevice:function(){return!!og.isBrowser()&&-1!==navigator.userAgent.toLowerCase().indexOf("android")},isMobileDevice:function(){return!!og.isBrowser()&&(og.isIOSDevice()||og.isAndroidDevice())},isSafari:function(){if(!og.isBrowser())return!1;var e=navigator.userAgent.toLowerCase();return-1!==e.indexOf("safari")&&-1===e.indexOf("chrome")},isFirefox:function(){return!!og.isBrowser()&&-1!==navigator.userAgent.toLowerCase().indexOf("firefox")},isChrome:function(){return!!og.isBrowser()&&-1!==navigator.userAgent.toLowerCase().indexOf("chrome")},isMac:function(){return!!og.isBrowser()&&-1!==navigator.userAgent.toLowerCase().indexOf("mac os")},isLinux:function(){return!!og.isBrowser()&&-1!==navigator.userAgent.toLowerCase().indexOf("linux x86_64")},isWindows:function(){if(!og.isBrowser())return!1;var e=navigator.userAgent.toLowerCase();return-1!==e.indexOf("win32")||-1!==e.indexOf("windows")},isWindowsPhone:function(){var e=navigator.userAgent.toLowerCase();return/(?:Windows Phone)/.test(e)},isSymbian:function(){var e=navigator.userAgent.toLowerCase();return/(?:SymbianOS)/.test(e)||og.isWindowsPhone()},isTablet:function(){var e=navigator.userAgent.toLowerCase();return/(?:iPad|PlayBook)/.test(e)||og.isAndroidDevice()&&!/(?:Mobile)/.test(e)||og.isFirefox()&&/(?:Tablet)/.test(e)},isPc:function(){return!og.isMobileDevice()&&!og.isTablet()&&!og.isSymbian()},isOpera:function(){return navigator.userAgent.indexOf("Opera")>-1}};og.isSafari(),og.detectWebGL=function(){if(window.WebGLRenderingContext){for(var e=document.createElement("canvas"),t=["webgl","experimental-webgl"],i=!1,n=0;t.length>n;n+=1)try{if((i=e.getContext(t[n]))&&"function"==typeof i.getParameter)return 1}catch(e){}return 0}return-1},og.detectWebGL2=function(){if(window.WebGL2RenderingContext){for(var e=document.createElement("canvas"),t=["webgl2"],i=!1,n=0;t.length>n;n+=1)try{if((i=e.getContext(t[n]))&&"function"==typeof i.getParameter)return 1}catch(e){}return 0}return-1},og.detectPath2D=function(){if(window.Path2D){var e;try{e=new Path2D("M100,100 L200,200")}catch(e){return-1}return e&&e.addPath?1:0}return-1},og.showWebGLMessage=function(e,t,i){var n,r=null,o=null;r=void 0!==(i=i||{}).parent?i.parent:document.body,n=void 0!==i.id?i.id:"oldie",(o=og.getWebGLErrorMessage(e,t)).id=n,r.appendChild(o)},og.showPath2DMessage=function(e,t,i){var n,r=null,o=null;r=void 0!==(i=i||{}).parent?i.parent:document.body,n=void 0!==i.id?i.id:"oldie",(o=og.getPath2DErrorMessage(e,t)).id=n,r.appendChild(o)},og.language=function(){return(navigator.browserLanguage||navigator.language).toLowerCase()},og.getWebGLErrorMessage=function(e,t){var i=document.createElement("div");i.id="webgl-error-message",i.style.fontSize="16px",i.style.fontWeight="normal",i.style.textAlign="center",i.style.background="#f4c8c8",i.style.color="#000",i.style.padding="1.5em",i.style.width="400px",i.style.position="absolute",i.style.left=document.body.clientWidth/2-224+"px";var n=document.body.clientHeight/2-45;return 0>n&&(n=0),i.style.top=n+"px",t||(t="zh-cn"),0===e?i.innerHTML=[' <a href="http://khronos.org/webgl/wiki/Getting_a_WebGL_Implementation" style="color:#000">'+rg[t].YourGraphicsCardDoesNotSeemToSupportWebGL+"</a>.<br />",' <a href="http://get.webgl.org/" style="color:#000">'+rg[t].FindOutHowToGetItHere+"</a>."].join("\n"):-1===e&&(i.innerHTML=['<a href="http://khronos.org/webgl/wiki/Getting_a_WebGL_Implementation" style="color:#000">'+rg[t].YourBrowserDoesNotSeemToSupportWebGL+"</a>.<br/>",'<a href="http://get.webgl.org/" style="color:#000">'+rg[t].FindOutHowToGetItHere+"</a>."].join("\n")),i},og.getPath2DErrorMessage=function(e,t){var i=document.createElement("div");i.id="webgl-error-message",i.style.fontSize="16px",i.style.fontWeight="normal",i.style.textAlign="center",i.style.background="#f4c8c8",i.style.color="#000",i.style.padding="1.5em",i.style.width="400px",i.style.position="absolute",i.style.left=document.body.clientWidth/2-224+"px";var n=document.body.clientHeight/2-45;if(0>n&&(n=0),i.style.top=n+"px",t||(t="zh-cn"),-1===e)i.innerHTML='<a href="https://developer.mozilla.org/zh-CN/docs/Web/API/Path2D" style="color:#000">'+rg[t].YourBrowserDoesNotSeemToSupportPath2D+"</a>.<br/>";else{var r=document.createElement("button");r.innerText=rg[t].Close,r.onclick=function(){i.style.display="none"},i.innerHTML='<a href="https://developer.mozilla.org/zh-CN/docs/Web/API/Path2D" style="color:#000">'+rg[t].YourBrowserDoesNotSeemToSupportPath2DMethod+"</a>.<br/>",i.appendChild(r)}return i},og.isSupportIndexedDB=function(){return window.indexedDB||window.mozIndexedDB||window.webkitIndexedDB||window.msIndexedDB},og.isSupportWorker=function(){return window.Worker};var ag={splitStr:function(e){return e.trim().split(/\s+/g)},getClientHeight:function(){return document.body.clientHeight&&document.documentElement.clientHeight?document.body.clientHeight<document.documentElement.clientHeight?document.documentElement.clientHeight:document.body.clientHeight:document.body.clientHeight>document.documentElement.clientHeight?document.body.clientHeight:document.documentElement.clientHeight},getClientWidth:function(){return document.body.clientWidth&&document.documentElement.clientWidth?document.body.clientWidth<document.documentElement.clientWidth?document.body.clientWidth:document.documentElement.clientWidth:document.body.clientWidth>document.documentElement.clientWidth?document.body.clientWidth:document.documentElement.clientWidth},getDomOffsetToClient:function(e){var t,i=null;if(e!==document){var n=(t=e).getBoundingClientRect?function(e){var t=e.getBoundingClientRect(),i=document.body,n=document.documentElement,r=t.left-(n.clientLeft||i.clientLeft);return{top:Math.round(t.top-(n.clientTop||i.clientTop)),left:Math.round(r)}}(t):function(e){for(var t=0,i=0;e;)t+=e.offsetTop,i+=e.offsetLeft,e=e.offsetParent;var n=document.body,r=document.documentElement;return{top:t-=window.pageYOffset||r.scrollTop||n.scrollTop,left:i-=window.pageXOffset||r.scrollLeft||n.scrollLeft}}(t);i={width:e.offsetWidth,height:e.offsetHeight,left:n.left,top:n.top}}else i={width:window.innerWidth,height:window.innerHeight,left:0,top:0};return i},getContainerOffsetToClient:function(e){return ag.getDomOffsetToClient(e)},setClassName:function(e,t){var i=document.getElementById(e);i&&(i.className=t)},addClassName:function(e,t){var i=null,n=null,r=null,o=null,a=null,s=document.getElementById(e);if(s&&(n=s,t&&"string"==typeof t&&(i=t.split(/\s+/),1===n.nodeType)))if(n.className||1!==i.length){for(r=" "+n.className+" ",o=0,a=i.length;a>o;o+=1)0>r.indexOf(" "+i[o]+" ")&&(r+=i[0]+" ");n.className=String.trim(r)}else n.className=t},removeClassName:function(e,t){var i=null,n=null,r=null,o=null,a=null,s=document.getElementById(e);if(s&&(r=s,t&&"string"==typeof t&&(i=(t||"").split(/\s+/),1===r.nodeType&&r.className))){for(n=(" "+r.className+" ").replace(0," "),o=0,a=i.length;a>o;o+=1)for(;n.indexOf(" "+i[o]+" ")>=0;)n=n.replace(" "+i[o]+" "," ");r.className=t?String.trim(n):""}},showOrHideElement:function(e,t){var i=document.getElementById(e);i&&(i.style.display=t?"":"none")},getStyleString:function(e){var t=[];for(var i in e){var n=e[i];t.push(i),t.push(":"),t.push(n),t.push("; ")}return t.join("")},cloneStyle:function(e){var t={};for(var i in e)t[i]=e[i];return t},removeStyleAttribute:function(e,t){Array.isArray(t)||(t=[t]),t.forEach((function(t){t in e&&delete e[t]}))},trimRight:function(e){if(0===e.length)return"";for(var t=e.length-1,i=t;i>=0;i-=1)if(" "!==e.charAt(i)){t=i;break}return e.substr(0,t+1)},trimLeft:function(e){if(0===e.length)return"";for(var t=0,i=0;e.length>i;i+=1)if(" "!==e.charAt(i)){t=i;break}return e.substr(t)},trim:function(e){return e.replace(/(^\s*)|(\s*$)/g,"")},matchesSelector:function(e,t){if(e.matches)return e.matches(t);if(e.matchesSelector)return e.matchesSelector(t);if(e.webkitMatchesSelector)return e.webkitMatchesSelector(t);if(e.msMatchesSelector)return e.msMatchesSelector(t);if(e.mozMatchesSelector)return e.mozMatchesSelector(t);if(e.oMatchesSelector)return e.oMatchesSelector(t);if(e.querySelectorAll){for(var i=(e.document||e.ownerDocument).querySelectorAll(t),n=0;i[n]&&void 0!==i[n];)n+=1;return!!i[n]}return!1},toTranslate3d:function(e,t){return"translate3d("+e+"px,"+t+"px,0)"},setCursorStyle:function(e,t){var i=null;switch(t){case"n":case"s":i="ns-resize";break;case"w":case"e":i="ew-resize";break;case"ne":case"sw":i="nesw-resize";break;case"nw":case"se":i="nwse-resize"}e.style.cursor=i},css:function(e,t){for(var i=e.getAttribute("style")||"",n=Object.keys(t),r=i.split(";"),o=[],a=0,s=r.length;s>a;a+=1){""!==(l=r[a])?o.push(l.replace(/:.+/,"")):r.splice(a,1)}for(a=0,s=n.length;s>a;a+=1){var l=n[a],c=-1;r.map((function(e,t){return e.indexOf(l)>-1&&(c=t),null})),c>-1?r[c]=l+":"+t[l]:r.push(l+":"+t[l])}var h=r.join(";");e.setAttribute("style",h+";")},append:function(e,t){if("string"==typeof t){var i=document.createElement("div");i.innerHTML=t;for(var n=document.createDocumentFragment();i.firstChild;)n.appendChild(i.firstChild);e.appendChild(n)}else e.appendChild(t)},scrollTop:function(e,t){var i=e.scrollTop;if(i>t)var n=setInterval((function(){var i=e.scrollTop,r=Math.floor(-i/6);e.scrollTop=i=r+i,e.scrollTop>t||(e.scrollTop=e.scrollTop=t,clearTimeout(n))}),20);else if(0===i)var r=setInterval((function(){var n=e.scrollTop,o=Math.floor(70);e.scrollTop=n=o+n,i>e.scrollTop&&(e.scrollTop=t,clearTimeout(r))}),20);else if(t>i)var o=setInterval((function(){var n=e.scrollTop,r=Math.floor(n/6);e.scrollTop=n=r+n,i>e.scrollTop&&(e.scrollTop=t,clearTimeout(o))}),20);else if(t===i)return!1},closest:function(e,t){if(!e)return null;for(var i=e.matches||e.webkitMatchesSelector||e.mozMatchesSelector||e.msMatchesSelector;e&&!i.call(e,t);)e=e.parentElement;return e},addEventListener:function(e,t,i){if(e)if(e.length)for(var n=0;e.length>n;n+=1)e[n].addEventListener(t,(function(e){i&&"function"==typeof i&&i(e)}));else e.addEventListener(t,(function(e){i&&"function"==typeof i&&i(e)}))},remove:function(e){if(e)if(e.removeNode=[],void 0!==e.length){for(var t=e.length,i=0;t>i;i+=1)e.removeNode.push({parent:e[i].parentNode,inner:e[i].outerHTML,next:e[i].nextSibling});for(i=0;t>i;i+=1)e[0].parentNode.removeChild(e[0])}else e.removeNode.push({parent:e.parentNode,inner:e.outerHTML,next:e.nextSibling}),e.parentNode.removeChild(e)},getStyleValue:function(e,t){var i=e.ownerDocument.defaultView;return i&&i.opener||(i=window),e.currentStyle?e.currentStyle[t]:i.getComputedStyle(e)[t]},isShow:function(e){return"none"!==this.getStyleValue(e,"display")},getHeight:function(e){if(null!=e){if(this.isShow(e)){if(null!=e.style.height&&e.style.height.length>0)return parseFloat(e.style.height);if(parseFloat(this.getStyleValue(e,"height"))>0)return parseFloat(this.getStyleValue(e,"height"));if(e.offsetHeight>0){var t=this.getStyleValue(e,"borderTopWidth"),i=this.getStyleValue(e,"borderBottomWidth"),n=this.getStyleValue(e,"paddingTop"),r=this.getStyleValue(e,"paddingBottom"),o=parseFloat(e.offsetHeight)-parseFloat(t)-parseFloat(i)-parseFloat(n)-parseFloat(r);return parseFloat(o)}return 0}var a=e.getAttribute("style")||"";e.setAttribute("style",a+"visibility:hidden;display:block !important;");var s=this.getHeight(e);return e.setAttribute("style",a),Math.ceil(s)}},getWidth:function(e){if(null!=e){if(this.isShow(e)){if(null!=e.style.width&&e.style.width.length>0)return parseFloat(e.style.width);if(parseFloat(this.getStyleValue(e,"width"))>0)return parseFloat(this.getStyleValue(e,"width"));if(e.offsetWidth>0){var t=this.getStyleValue(e,"borderLeftWidth"),i=this.getStyleValue(e,"borderRightWidth"),n=this.getStyleValue(e,"paddingLeft"),r=this.getStyleValue(e,"paddingRight"),o=parseFloat(e.offsetWidth)-parseFloat(t)-parseFloat(i)-parseFloat(n)-parseFloat(r);return parseFloat(o)}return 0}var a=e.getAttribute("style")||"";e.setAttribute("style",a+"visibility:hidden;display:inline-block !important;");var s=this.getWidth(e);return e.setAttribute("style",a),Math.ceil(s)}},outerHeight:function(e,t){var i=e.offsetHeight;if(t){var n=e.currentStyle||getComputedStyle(e);i+=parseInt(n.marginTop,0)+parseInt(n.marginBottom,0)}return i},outerWidth:function(e,t){var i=e.offsetWidth;if(t){var n=e.currentStyle||getComputedStyle(e);i+=parseInt(n.marginLeft,0)+parseInt(n.marginRight,0)}return i},isEmptyObject:function(e){var t=null;for(t in e)return!1;return!0},hasClass:function(e,t){if(e){var i=e.className.match&&e.className.match(new RegExp("(\\s|^)"+t+"(\\s|$)"));return Boolean(i)}return!1},addClass:function(e,t){e&&(this.hasClass(e,t)||(e.className+=" "+t))},removeClass:function(e,t){if(this.hasClass(e,t)){var i=new RegExp("(\\s|^)"+t+"(\\s|$)");e.className=e.className.replace(i," ")}},toggleClass:function(e,t){this.hasClass(e,t)?this.removeClass(e,t):this.addClass(e,t)},simulateEvent:function(e,t){var i=document.createEvent("Event");i.initEvent(t,!0,!0),e.dispatchEvent(i)},bind:function(e,t,i){e&&(e.addEventListener?e.addEventListener(t,i,!1):e.attachEvent?e.attachEvent("on"+t,i):e["on"+t]=i)},delegate:function(e,t,i,n){if(e)if(e.length)for(var r=0;e.length>r;r+=1)this.delegateFn(e[r],t,i,n);else this.delegateFn(e,t,i,n)},delegateFn:function(e,t,i,n){var r=this;function o(e){var o=(e=e||window.event).target||e.srcElement;r.matchSelector(o,t)&&n&&("mouseenter"===i||"mouseleave"===i?r.fixedMouse(e,o)&&n.call(o,e):n.call(o,e))}i=i.toLowerCase(),e.addEventListener?e.addEventListener("mouseenter"===i?"mouseover":"mouseleave"===i?"mouseout":i,o):e.attachEvent("mouseenter"===i?"onmouseover":"mouseleave"===i?"onmouseout":"on"+i,o)},matchSelector:function(e,t){return"#"===t.charAt(0)?e.id===t.slice(1):"."===t.charAt(0)?-1!==(" "+e.className+" ").indexOf(" "+t.slice(1)+" "):e.tagName.toLowerCase()===t.toLowerCase()},contains:function(e,t){return e.contains?e!==t&&e.contains(t):Boolean(16&e.compareDocumentPosition(t))},fixedMouse:function(e,t){var i=null,n=e.type.toLowerCase();if("mouseover"===n)i=e.relatedTarget||e.fromElement;else{if("mouseout"!==n)return!0;i=e.relatedTarget||e.toElement}return i&&"xul"!==i.prefix&&!this.contains(t,i)&&i!==t},fireEvent:function(e,t){var i=null;if(e.ownerDocument)i=e.ownerDocument;else{if(9!==e.nodeType)throw new Error("Invalid node passed to fireEvent: "+e.id);i=e}if(e.dispatchEvent){var n="";switch(t){case"click":case"mousedown":case"mouseup":n="MouseEvents";break;case"focus":case"change":case"blur":case"select":n="HTMLEvents";break;default:Bu.error("fireEvent: Couldn't find an event class for event '"+t+"'.")}(r=i.createEvent(n)).initEvent(t,"change"!==t,!0),r.synthetic=!0,e.dispatchEvent(r,!0)}else if(e.fireEvent){var r;(r=i.createEventObject()).synthetic=!0,e.fireEvent("on"+t,r)}}};ag.create=function(e,t){var i=document.createElement(e);return i.setAttribute("class",t),i};ag.createNS=function(e,t){var i=document.createElementNS("http://www.w3.org/2000/svg",e);return i.setAttribute("class",t),i};ag.select=function(e){return e.indexof("#")?document.getElementById(e.replace("#","")):e.indexof(".")?document.getElementsByClassName(e.replace(".","")):document.getElementsByTagName(e)};var sg=function(e){if(""===e)return 0;if("string"==typeof e){if(-1===e.indexOf("px")){var t=Number(e);return isNaN(t)?0:t}var i=e.split("px"),n=Number(i[0]);return isNaN(n)?0:n}return 0};ag.drag=function(e){var t=og.isPc(),i=Object.assign({element:null,handle:null,axis:"all",cursor:"move",distance:0,start:null,move:null,stop:null},e),n=i.element;if(!n)return!1;var r=i.handle||n,o=void 0,a=!1,s=function(e){if(t)var r={x:e.clientX,y:e.clientY};else r={x:e.touches[0].clientX,y:e.touches[0].clientY};var s={x:r.x-o.x,y:r.y-o.y};a?(i.move&&i.move(o,r,s),o=r,function(e){var t=n.offsetLeft,r=n.offsetTop,o=sg(getComputedStyle(n).marginLeft),a=sg(getComputedStyle(n).marginTop),s=0>(t-=o)+e.x?0:t+e.x,l=0>(r-=a)+e.y?0:r+e.y;switch(i.axis){case"x":n.style.left=s+"px";break;case"y":n.style.top=l+"px";break;case"all":default:n.style.left=s+"px",n.style.top=l+"px"}}(s)):a=function(e){return Math.pow(e.x,2)+Math.pow(e.y,2)>Math.pow(i.distance,2)&&(i.start&&i.start(o),!0)}(s)},l=function(e){var n,a,l=e;if(t){if(n=l.button,!((a=navigator.userAgent).indexOf("compatible")>-1&&a.indexOf("MSIE")>-1&&!og.isOpera()?1===n:0===n))return;o={x:l.clientX,y:l.clientY},document.addEventListener("mousemove",s)}else o={x:l.touches[0].clientX,y:l.touches[0].clientY},r.addEventListener("touchmove",s);i.start&&i.start(o)},c=function(){a&&i.end&&i.end(o),a=!1,document.removeEventListener("mousemove",s),r.removeEventListener("touchmove",s)};t?(r.style.cursor=i.cursor,r.style.userSelect="none",r.addEventListener("mousedown",l),document.addEventListener("mouseup",c)):(r.addEventListener("touchend",c),r.addEventListener("touchstart",l))};ag.sizable=function(e){var t=Object.assign({element:null,axis:"all",minWidth:100,minHeight:100,distance:0,start:null,sizable:null,stop:null},e),i=t.element;if(!i)return!1;var n=void 0,r=!1,o=ag.create("div","yj-resize"),a=void 0,s=void 0,l=function(e){var o={x:e.clientX,y:e.clientY},l={x:o.x-n.x,y:o.y-n.y};r?(t.sizable&&t.sizable(n,o,l),function(e){var n=i.offsetLeft,r=i.offsetTop,o=t.minWidth>a+e.x?t.minWidth:a+e.x,l=t.minHeight>s+e.y?t.minHeight:s+e.y;switch(t.resize&&t.resize(o,l),i.style.left=n+"px",i.style.top=r+"px",t.axis){case"x":i.style.width=o+"px";break;case"y":i.style.height=l+"px";break;case"all":default:i.style.width=o+"px",i.style.height=l+"px"}}(l)):r=function(e){return Math.pow(e.x,2)+Math.pow(e.y,2)>Math.pow(t.distance,2)&&(t.start&&t.start(n),!0)}(l)},c=function(e){a=i.clientWidth,s=i.clientHeight;var t,r,o=e;(t=o.button,(r=navigator.userAgent).indexOf("compatible")>-1&&r.indexOf("MSIE")>-1&&!og.isOpera()?1===t:0===t)&&(n={x:o.clientX,y:o.clientY},document.addEventListener("mousemove",l),document.addEventListener("touchmove",l))},h=function(){r&&t.end&&t.end(n),r=!1,document.removeEventListener("mousemove",l),document.removeEventListener("touchmove",l)};ag.addClass(i,"yj-sizable"),i.appendChild(o),o.addEventListener("mousedown",c),o.addEventListener("touchstart",c),document.addEventListener("mouseup",h),document.addEventListener("touchend",h)};var lg=function(e){var t=this,i=Object.assign({element:null,min:0,max:100,cur:50,step:1,isShowProgress:!0,input:null,change:null,currentColor:"#11dab7",defaultColor:"#999"},e);this._opt=i;var n=ag.create("div","yj-range"),r=ag.create("input","yj-input-range");t.input=r,r.setAttribute("type","range"),r.setAttribute("step",i.step),r.setAttribute("min",i.min),r.setAttribute("max",i.max),r.setAttribute("value",i.cur);var o=ag.create("span","yj-range-min");o.innerText=i.min;var a=ag.create("span","yj-range-cur");t.cur=a,a.innerText=i.cur;var s=ag.create("span","yj-range-max");s.innerText=i.max;var l=ag.create("span","yj-range-progress");n.appendChild(r),i.isShowProgress&&(n.appendChild(o),n.appendChild(a),n.appendChild(s)),n.appendChild(l),i.element.appendChild(n),t.setProgress(i.cur),r.addEventListener("input",(function(){t.setProgress(this.value),i.input&&i.input(this.value)})),r.addEventListener("change",(function(){t.setProgress(this.value),i.change&&i.change(this.value)}))};lg.prototype.setProgress=function(e){var t=this._opt,i=this.input,n=this.cur,r=(e-t.min)/(t.max-t.min)*100;i.value=e,i.style.background="linear-gradient(to right,"+t.currentColor+" 0%,"+t.currentColor+" "+r+"%,"+t.defaultColor+" "+r+"%, "+t.defaultColor+" 100%)",n.innerText=e},lg.prototype.reset=function(){this.setProgress(this._opt.cur)},ag.range=lg;var cg=function(e){this._opt=Object.assign({element:null,min:0,max:100,from:null,to:null,step:1,currentColor:"#11dab7",defaultColor:"#999",change:null},e),this._opt.from=this._opt.from||this._opt.min,this._opt.to=this._opt.to||this._opt.max,this.init()};cg.prototype={init:function(){var e=ag.create("div","yj-multiple-range"),t=ag.create("div","yj-range-track"),i=ag.create("span","yj-slider yj-slider-min");i.id="minSlider",i.type="minimum";var n=ag.create("span","yj-slider yj-slider-max");n.id="maxSlider",n.type="maximum",this._state={from:this._opt.from,to:this._opt.to},t.style.backgroundColor=this._opt.currentColor,e.style.backgroundColor=this._opt.defaultColor,e.appendChild(t),e.appendChild(i),e.appendChild(n),this._opt.element.appendChild(e),this._track=t,this._sliders={min:i,max:n},this._element=e,this.bindEvent(),this.update(!1)},bindEvent:function(){var e=this,t=!1,i=null,n=null,r=function(e){e=e||event;n=e.screenX,i=this,t=!0};this._sliders.min.addEventListener("mousedown",r),this._sliders.max.addEventListener("mousedown",r),document.addEventListener("mousemove",(function(r){if(t){r=r||event;var o=Math.round((r.screenX-n)/e._pix/e._opt.step)*e._opt.step;0!==o&&(n=o*e._pix+n,"minimum"===i.type?e._state.from+=o:e._state.to+=o,e.recalculate(i),e.update(!0))}})),document.addEventListener("mouseup",(function(){i=null,t=!1}))},update:function(e){var t=this._sliders.min.offsetWidth,i=this._sliders.max.offsetWidth;this._pix||(this._pix=(this._element.offsetWidth-t-i)/(this._opt.max-this._opt.min));var n=(this._state.from-this._opt.min)*this._pix,r=(this._state.to-this._opt.min)*this._pix+t+i;this._track.style.left=n+t/2+"px",this._track.style.width=r-n-t/2-i/2+"px",this._sliders.min.style.left=n+"px",this._sliders.max.style.left=r+"px",this._opt.change&&e&&this._opt.change(this._state)},recalculate:function(e){this._opt.max>this._state.to||(this._state.to=this._opt.max),this._state.from>this._opt.min||(this._state.from=this._opt.min),e&&("maximum"===e.type&&(this._state.to>this._state.from||(this._state.to=this._state.from)),"minimum"===e.type&&(this._state.to>this._state.from||(this._state.from=this._state.to)))},getProgress:function(){return this._state},setProgress:function(e){this._state=e,this.recalculate(),this.update(!1)}},ag.multipleRange=cg;var hg=function(){};hg.prototype={constructor:hg,apply:function(e){e.addEventListener=hg.prototype.addEventListener,e.hasEventListener=hg.prototype.hasEventListener,e.removeEventListener=hg.prototype.removeEventListener,e.fireEvent=hg.prototype.dispatchEvent,e.dispatchEvent=hg.prototype.dispatchEvent},addEventListener:function(e,t){e&&(void 0===this._listeners&&(this._listeners={}),void 0===this._listeners[e]&&(this._listeners[e]=[]),this._listeners[e].push(t))},hasEventListener:function(e,t){if(!e)return!1;if(void 0===this._listeners)return!1;var i=this._listeners;return void 0!==i[e]&&-1!==i[e].indexOf(t)},removeEventListener:function(e,t){if(e&&(void 0===this._listeners&&(this._listeners={}),Array.isArray(this._listeners[e])))for(var i=this._listeners[e],n=0,r=i.length;r>n;n+=1)if(i[n]===t){i.splice(n,1);break}},removeAllEventListenerByType:function(e){e&&(void 0===this._listeners&&(this._listeners={}),Array.isArray(this._listeners[e])&&this._listeners[e]&&(this._listeners[e]=void 0))},removeAllEventListener:function(){for(var e in void 0===this._listeners&&(this._listeners={}),this._listeners)if(this._listeners.hasOwnProperty(e))for(var t=this._listeners[e],i=0,n=t.length;n>i;i+=1)t.splice(i,1);this._listeners={}},dispatchEvent:function(e){if(void 0===this._listeners&&(this._listeners={}),"string"!=typeof e&&"number"!=typeof e||(e={type:e}),!e.target)try{e.target=this}catch(e){}if(null==e.type)throw Bu.trace("事件类型未知."),new Error("事件类型未知.");if(Array.isArray(this._listeners[e.type]))for(var t=this._listeners[e.type].slice(),i=0;t.length>i;i+=1)t[i].call(this,e)},fireEvent:function(e){this.dispatchEvent(e)}};var dg=new Ke,ug=new Ke,pg=new ke,gg=new Ke,fg=new Ke,mg=new Jt,Ag=new Ke,yg=new Ke,vg=new Ke,Cg=new Ke,Ig=new yt,xg=function(){function e(t,i){ru(this,e),this.camera=t.camera,this.cameraControl=t,this.domElement=i,this.intersectContext=new eg,this.rayCaster=new Xp,this._lastTrackingPoint=new Ke,this.viewer=t.viewer,this._rotatePivot=new Ke,this.pivot=null,this._assistGroundPlane=new ng,this.boundaryLimitFactor=2,this._planIntersect=new Ke,this.intersectHelper=t.intersector,this._minObjectOffset=.5}return au(e,[{key:"getWorldDimension",value:function(e,t,i){var n=this.camera.position,r=this.camera.direction(fg).normalize(),o=this.getTrackingPoint(e,t),a=dg.subVectors(o,n),s=Math.abs(r.dot(a)),l=ag.getContainerOffsetToClient(this.domElement),c=l.width/l.height,h=2*s*Math.tan(be.degToRad(.5*this.camera.fov)),d=h*c;return wp.isDefined(i)||(console.warn("result is needed for function getWorldDimension()"),i=new ke),i.set(d,h),i}},{key:"getWorldPointFromNearPlane",value:function(e,t){var i=new Ke(e,t,0);return i.unproject(this.camera),i}},{key:"getTrackingPoint",value:function(e,t){dg.set(e,t),this.getIntersectContext(dg);var i=this.intersectHelper.hitTest(this.intersectContext),n=this.camera.position;if(i)n.equals(i)&&(i=null),i&&(this._lastTrackingPoint.copy(i),!0);else{var r=this.intersectContext.mouse,o=this.getWorldPointFromNearPlane(r.x,r.y),a=this.getRayCaster(e,t).ray,s=this.camera.direction(fg).normalize();if(mg.setFromNormalAndCoplanarPoint(s,this._lastTrackingPoint),i=a.intersectPlane(mg,this._planIntersect)){var l=i.distanceTo(n);Yp.EPSILON1>l&&(i=this._getTrackingPointFromScene(a),!1)}else i=this._getTrackingPointFromScene(a),!1;i||(Bu.log("tracking point is default!"),i=o)}return i}},{key:"getRotatePivot",value:function(e,t){var i=null,n=this.viewer.getRotationCenter();if(wp.isDefined(n))return n;switch(e){case Ld.SELECTION:i=this._getRotatePivotFromSelection(t,this._rotatePivot);break;case Ld.CENTER:i=this.viewer.getScene().getBoundingBox().getCenter(dg);break;case Ld.CAMERA:i=null;break;default:i=this._getRotatePivotFromIntersect(t)}return this.cameraControl.dirtyCamera(!0),this.cameraControl.setCameraChanging(!0),this.pivot=i,i}},{key:"getPanOffset",value:function(e,t,i,n){var r=ag.getContainerOffsetToClient(this.domElement),o=e.x-r.left,a=e.y-r.top;Ag.x=o/r.width,Ag.y=a/r.height,a=t.y-r.top,yg.x=(o=t.x-r.left)/r.width,yg.y=a/r.height,vg.subVectors(yg,Ag);var s=-vg.x*i.x,l=vg.y*i.y,c=this.cameraControl.getWorldRight().multiplyScalar(s),h=this.cameraControl.getWorldUp().multiplyScalar(l);return this.cameraControl.dirtyCamera(!0),this.cameraControl.setCameraChanging(!0),n.addVectors(c,h),n}},{key:"adjustCameraForPan",value:function(e){if(!this.lockPan){var t=this.camera;if(dg.copy(t.position),dg.add(e),null==t.minimumElevation||e.y>=0||dg.y>=t.minimumElevation){if(this._limitWorldScalar&&this.cameraControl._checkZoomNearBoundary(dg,-1)){if(0>dg.x&&0>e.x||0>dg.z&&0>e.z)return;if(dg.x>0&&e.x>0||dg.z>0&&e.z>0)return}this.cameraControl.dirtyCamera(!0),this.cameraControl.setCameraChanging(!0),t.target.add(e),t.position.add(e)}}}},{key:"adjustCameraForZoom",value:function(e,t){if(Math.abs(e)<Yp.EPSILON6)return!1;var i=this.camera;e*=this.cameraControl.zoomSpeed;var n=i.position,r=i.direction(fg);if(t?ug.subVectors(t,n):ug.copy(r),dg.copy(ug),ug.multiplyScalar(e),i.isPerspective){var o=dg.length()*(1-e),a=this.cameraControl.sceneLengthUnitFactor,s=this.viewer.getScene().getMatrixGlobal();Ig.copy(s).invert(),dg.applyMatrix4(Ig);var l=dg.length()*(1-e)*a;this._minObjectOffset>l&&ug.normalize().multiplyScalar(o+.1)}else i.orthoScale*=e+1,i.setZoom(i.orthoScale);ug.add(n),wp.isDefined(i.minimumElevation)&&i.minimumElevation>ug.y||(this._checkCameraLimitBoundary(i,ug,e)?this.cameraControl.resetCameraToMaximumRange():(i.position.copy(ug),i.target.copy(r.add(ug)),this.cameraControl.dirtyCamera(!0),this.cameraControl.setCameraChanging(!0)))}},{key:"clientToViewport",value:function(e,t,i){var n=ag.getContainerOffsetToClient(this.domElement),r=i||new ke;return r.x=(e-n.left)/n.width*2-1,r.y=-(t-n.top)/n.height*2+1,r}},{key:"clientToCanvas",value:function(e,t,i){var n=ag.getContainerOffsetToClient(this.domElement),r=i||new ke;return r.x=(e-n.left)/n.width,r.y=(t-n.top)/n.height,r}},{key:"viewportToClient",value:function(e,t,i){var n=ag.getContainerOffsetToClient(this.domElement),r=i||new ke;return r.x=(e+1)/2*n.width+n.left,r.y=(1-t)/2*n.height+n.top,r}},{key:"getIntersectContext",value:function(e){return this.intersectContext.scene=this.viewer.getScene(),this.intersectContext.camera=this.camera,wp.isDefined(e)&&(this.clientToViewport(e.x,e.y,this.intersectContext.mouse),this.clientToCanvas(e.x,e.y,this.intersectContext.canvasMouse)),this.intersectContext.viewportSize=this.viewer.getRenderer().getSize(new ke),this.intersectContext.octantMap=this.viewer.modelManager.octantToObjectMap,this.intersectContext}},{key:"getRayCaster",value:function(e,t){return this.clientToViewport(e,t,pg),this.rayCaster.setFromCamera(pg,this.camera),this.rayCaster}},{key:"_getTrackingPointFromScene",value:function(e){var t=1/0,i=e.origin,n=this.viewer.getScene().getBoundingBox();dg.set(0,0,-1),mg.setFromNormalAndCoplanarPoint(dg,n.max);var r=0;return e.intersectPlane(mg,this._planIntersect)&&t>(r=i.distanceTo(this._planIntersect))&&(t=r,gg.copy(this._planIntersect)),dg.set(0,-1,0),mg.setFromNormalAndCoplanarPoint(dg,n.max),e.intersectPlane(mg,this._planIntersect)&&t>(r=i.distanceTo(this._planIntersect))&&(t=r,gg.copy(this._planIntersect)),dg.set(-1,0,0),mg.setFromNormalAndCoplanarPoint(dg,n.max),e.intersectPlane(mg,this._planIntersect)&&t>(r=i.distanceTo(this._planIntersect))&&(t=r,gg.copy(this._planIntersect)),dg.set(0,0,-1),mg.setFromNormalAndCoplanarPoint(dg,n.min),e.intersectPlane(mg,this._planIntersect)&&t>(r=i.distanceTo(this._planIntersect))&&(t=r,gg.copy(this._planIntersect)),dg.set(0,-1,0),mg.setFromNormalAndCoplanarPoint(dg,n.min),e.intersectPlane(mg,this._planIntersect)&&t>(r=i.distanceTo(this._planIntersect))&&(t=r,gg.copy(this._planIntersect)),dg.set(0,0,-1),mg.setFromNormalAndCoplanarPoint(dg,n.min),e.intersectPlane(mg,this._planIntersect)&&t>(r=i.distanceTo(this._planIntersect))&&(t=r,gg.copy(this._planIntersect)),gg}},{key:"_getRotatePivotFromIntersect",value:function(e){var t=this.getIntersectContext(e),i=this.intersectHelper.hitTest(t);return e&&i?i:this.viewer.getScene().getBoundingBox().getCenter(Cg)}},{key:"_getRotatePivotFromSelection",value:function(e,t){var i,n=this.viewer,r=n.getScene();if(r.hasClipPlanes()){var o=r.getClipPlanes();if(o.isEnabled()&&(i=o.getClipBoundingBox(),wp.isDefined(i)&&!i.isEmpty()&&o.isVisible()))return t.copy(i.getCenter(Cg)),t}var a=n.getFilter().getVisibleComponentSet(n.modelManager.sceneState.getSelectionSet()),s=n.getBoundingBoxByIds(a);if(!s||s.isEmpty())t.copy(this._getRotatePivotFromIntersect(e));else{if(wp.isDefined(i))s.intersect(i);else if(r.hasFillClipPlanes()){var l=r.getFillClipPlane();if(l.isEnabled()){var c=l.getFillClipBoundingBox();wp.isDefined(c)&&s.intersect(c)}}t.copy(s.getCenter(dg))}return t}},{key:"_checkCameraLimitBoundary",value:function(e,t,i){if(!e.isPerspective||!xd.ConstraintZoom)return!1;var n=this.viewer.getScene().getBoundingBox();if(wp.isDefined(i)&&i>0)return!e.getFrustum().intersectsBox(n);var r=.5*n.getSize(dg).length()/Math.tan(be.degToRad(.5*e.fov))*this.boundaryLimitFactor,o=n.getCenter(dg);return t.distanceTo(o)>=r}}]),e}(),wg=new Ke(0,0,1),Mg=new Ke(0,1,0),Eg=new Ke,Bg=new Ge,Sg=!1,bg=new yt,kg=new Ke,Dg=new Ge,Tg=new Ke,Rg=new Ke,Ug=new Ke,Fg=new yt,Qg=new yt,Lg=new He,Og=new Ke;function Ng(e){if(e.viewer.getRotationCenter())return e.viewer.getRotationCenter();var t=e.viewer.modelManager.sceneState;if(t.hasSelection()){var i=e.viewer.getFilter().getVisibleComponentSet(t.getSelectionSet()),n=e.viewer.getBoundingBoxByIds(i);if(n&&!n.isEmpty())return n.getCenter(Rg)}return e.pivot?e.pivot:e.scene.getBoundingBox().getCenter(Rg)}function Pg(e,t,i,n){if(null==n||void 0===n)return!0;var r=n[0],o=n[1];if(r>=o)return!1;var a=e.position;e.getWorldDirection(Tg);var s=e.realUp||e.up;i||(i=a.clone());var l=Tg.clone().cross(s).normalize(),c=(new Ge).setFromAxisAngle(l,t);a.clone().sub(i).normalize();var h=Tg.clone().negate(),d=Math.PI-h.angleTo(wg.clone()),u=h.clone().projectOnPlane(wg.clone()),p=u.angleTo(wg.clone());0>u.x&&(p=2*Math.PI-p),Tg.applyQuaternion(c).normalize();var g=Tg.clone().negate(),f=Math.PI-g.angleTo(wg.clone()),m=g.clone().projectOnPlane(wg.clone()),A=m.angleTo(wg.clone());if(0>m.x&&(A=2*Math.PI-A),Math.abs(A-p)>.001)return!1;if(d>r&&o>d){if(f>o||r>f)return!1}else if((d>o?f-d:d-f)>0)return!1;return!0}function Gg(e,t,i,n){bg.copy(t).invert();var r=new Ke(e.position.x,e.position.y,e.position.z),o=r.clone();o.applyMatrix4(bg);var a=new Ke(i.x,i.y,i.z);a.add(r),a.applyMatrix4(bg),a.sub(o).normalize().multiplyScalar(n);var s=a.clone();return a.add(o),a.applyMatrix4(t),a.sub(r),{stepDiffWorld:s,stepDiffDrawing:a}}var Kg=function(e){lu(i,e);var t=pu(i);function i(e,n,r,o,a,s){var l;return ru(this,i),(l=t.call(this)).viewer=e,l.camera=r,l.domElement=o,l.scene=n,l.intersector=new tg(e),l._ground=new ng,l.collisionManager=new Np,l.pivotBallGroup=null,l.minDollyDistance=5,l.gravity=0,l.zoomSpeed=1,l.farFactor=2,l.maxPitch=void 0,l.minPitch=void 0,s=wp.defaultValue(s,{}),l._enableDamping=wp.defaultValue(s.enableDamping,!1),l._dynamicDampingFactor=wp.defaultValue(s.dynamicDampingFactor,.1),l._limitWorldScalar=!0,l.lockPan=!1,l.userInputWorking=!1,l._changeCallBack=a,l._planIntersect=new Ke,l.userInputHelper=new xg(du(l),o),l._realManHeight=1650,l.sceneLengthUnitFactor=1,l}return au(i,[{key:"destroy",value:function(){this.viewer=null,this.camera=null,this.domElement=null,this.scene=null,this.intersector.destroy(),this.intersector=null,this.collisionManager=null,this.pivotBallGroup=null}},{key:"enableDamping",value:function(){this._enableDamping=!0;var e=this.viewer.controlManager.userInputControl;wp.isDefined(e)&&e.resetDynamicMoving()}},{key:"disableDamping",value:function(){this._enableDamping=!1;var e=this.viewer.controlManager.userInputControl;wp.isDefined(e)&&e.resetDynamicMoving()}},{key:"isEnableDamping",value:function(){return this._enableDamping}},{key:"dynamicDampingFactor",value:function(e){return wp.isDefined(e)&&(this._dynamicDampingFactor=e),this._dynamicDampingFactor}},{key:"enableLimitWorldScalar",value:function(e){this._limitWorldScalar=e}},{key:"isCameraChanging",value:function(){return Sg}},{key:"setCameraChanging",value:function(e){Sg=e,this.camera.dirty=e}},{key:"setCamera",value:function(e){this.camera=e}},{key:"getCamera",value:function(){return this.camera.updateMVP(),this.camera}},{key:"dirtyCamera",value:function(e){this.camera.dirty=e}},{key:"getFrustum",value:function(){return this.camera.getFrustum()}},{key:"lockAxisZ",value:function(e){Kp.LockAxisZ=e}},{key:"isLockedAxisZ",value:function(){return Kp.LockAxisZ}},{key:"setLockAxisZRange",value:function(e){Kp.LockAxisZRange=e}},{key:"getLockAxisZRange",value:function(){return Kp.LockAxisZRange}},{key:"getClientSize",value:function(){var e=this.domElement===document?this.domElement.body:this.domElement;return new ke(e.clientWidth,e.clientHeight)}},{key:"delayHandle",value:function(){var e=this;this.timeoutId&&clearTimeout(this.timeoutId),this.timeoutId=setTimeout((function(){e.update(!0,!0)}),200),this.needUpdateRenderList(!1)}},{key:"updateMaxPitch",value:function(e){this.maxPitch=e}},{key:"updateMinPitch",value:function(e){this.minPitch=e}},{key:"enabledPolar",value:function(e){Kp.LockAxisZ=e}},{key:"setMinPolarAngle",value:function(e){"number"==typeof e&&(Array.isArray(Kp.LockAxisZRange)||(Kp.LockAxisZRange=[]),Kp.LockAxisZRange[0]=e)}},{key:"setMaxPolarAngle",value:function(e){"number"==typeof e&&(Array.isArray(Kp.LockAxisZRange)||(Kp.LockAxisZRange=[]),Kp.LockAxisZRange[1]=e)}},{key:"getMinPolarAngle",value:function(){return Kp.LockAxisZRange?Kp.LockAxisZRange[0]:null}},{key:"getMaxPolarAngle",value:function(){return Kp.LockAxisZRange?Kp.LockAxisZRange[1]:null}},{key:"processRotate",value:function(e,t){var i=this.viewer.getClientSize(),n=-2*Math.PI*e.x/i.x,r=-2*Math.PI*e.y/i.y;this.handleRotation(n,r,t)}},{key:"getRotatePivot",value:function(e,t){return this.userInputHelper.getRotatePivot(e,t)}},{key:"handleRotation",value:function(e,t,i){var n=this.camera,r=n.position,o=n.target.clone(),a=n.getWorldDirection(o),s=o.clone().sub(r).length(),l=null,c=function(e){var t=arguments.length>1&&void 0!==arguments[1]&&arguments[1],o=null,l=null,c=null,h=new Ke;if(i){if(l=(o=r.clone().sub(i)).length(),o.normalize(),c=o.clone().applyQuaternion(e).normalize(),t&&null!=n.minimumElevation){var d=r.clone();if(d.copy(i).add(c.clone().multiplyScalar(l)),n.minimumElevation>d.z)return!1}n.position.copy(i).add(c.multiplyScalar(l)),a.applyQuaternion(e).normalize(),h.copy(r).add(a.multiplyScalar(s)),n.target.copy(h)}else a.applyQuaternion(e).normalize(),h.copy(r).add(a.multiplyScalar(s)),n.target.copy(h);return!0},h=n.realUp||n.up,d=a.clone().cross(h).normalize().clone().cross(a).normalize();n.realUp.copy(d);var u=null;if(Kp.LockAxisZ){if(Math.abs(e)>Math.abs(t))u=wg,c(l=(new Ge).setFromAxisAngle(u,e)),n.realUp.applyQuaternion(l).normalize(),this.adjustCameraUp();else if(null!=Kp.LockAxisZRange&&Math.abs(t)>1e-4){Pg(n,t,i,Kp.LockAxisZRange)&&(u=a.clone().cross(h).normalize(),c(l=(new Ge).setFromAxisAngle(u,t)),n.realUp.applyQuaternion(l).normalize(),this.adjustCameraUp())}}else if(Math.abs(e)<Math.abs(t)){if(Math.abs(t)>1e-4){if(null!=this.maxPitch&&null!=this.minPitch){var p=n.target.clone().sub(n.position),g=new ke(Math.sqrt(p.x*p.x+p.y*p.y)*(n.realUp.z>0?1:-1),p.z).angle();if(g-Math.PI>0&&(g-=2*Math.PI),g=-g,0>t){if(g+t*(n.realUp.z>0?1:-1)>=this.maxPitch)return}else if(null!=n.minimumElevation&&n.minimumElevation>n.position.z||this.minPitch>=g-t)return}if(u=a.clone().cross(n.realUp).normalize(),!c(l=(new Ge).setFromAxisAngle(u,t),t>0))return;n.realUp.applyQuaternion(l).normalize(),this.adjustCameraUp()}}else(1e-4>Math.abs(a.z+1)||1e-4>Math.abs(a.z-1))&&(u=a.clone().cross(n.realUp).normalize(),c(l=(new Ge).setFromAxisAngle(u,.1)),n.realUp.applyQuaternion(l).normalize(),this.adjustCameraUp()),u=new Ke(0,0,a.z>0&&0>n.realUp.z?-1:1),c(l=(new Ge).setFromAxisAngle(u,e)),n.realUp.applyQuaternion(l).normalize();this.dirtyCamera(!0),this.setCameraChanging(!0)}},{key:"updateCamera",value:function(){var e=this.camera;e.dirty&&(e.lookAt(e.target),e.updateMVP(),this.adjustCameraUp(),this.dispatchEvent({type:Fd.ON_CAMERA_CHANGE,camera:this.camera}))}},{key:"update",value:function(e,t){this.updateCamera(),this.dispatchEvent({type:Fd.ON_CAMERA_CHANGE,camera:this.camera});var i=this.camera;e?(void 0!==t&&this.needUpdateRenderList(t),this._changeCallBack(),Eg.copy(i.position),Bg.copy(i.quaternion)):(Eg.distanceToSquared(i.position)>Yp.EPSILON6||8*(1-Bg.dot(i.quaternion))>Yp.EPSILON6)&&(this._changeCallBack(),Eg.copy(i.position),Bg.copy(i.quaternion))}},{key:"updateView",value:function(e){this.dispatchEvent({type:Fd.ON_CAMERA_CHANGE,camera:this.camera}),this._changeCallBack()}},{key:"updateHighlight",value:function(){this.dispatchEvent({type:Fd.ON_CAMERA_CHANGE,camera:this.camera}),this._changeCallBack(!0)}},{key:"needUpdateRenderList",value:function(e){this.viewer.controlManager.isUpdateRenderList=e}},{key:"pan",value:function(e,t){var i=this.domElement===document?this.domElement.body:this.domElement,n=new Ke,r=this;function o(e){var t=r.camera.matrix.elements;n.set(t[0],t[1],t[2]),n.multiplyScalar(-e),r.camera.target.add(n),r.camera.position.add(n)}function a(e){var t=r.camera.matrix.elements;n.set(t[4],t[5],t[6]),n.multiplyScalar(e),r.camera.target.add(n),r.camera.position.add(n)}if(this.camera.isPerspective){var s=this.camera.position.clone().sub(this.camera.target).length();o(2*e*(s*=Math.tan(this.camera.fov/2*Math.PI/180))/i.clientHeight),a(2*t*s/i.clientHeight)}else void 0!==this.camera.top?(o(e*(this.camera.right-this.camera.left)/i.clientWidth),a(t*(this.camera.top-this.camera.bottom)/i.clientHeight)):Bu.warn("WARNING: CloudPickControl.js encountered an unknown camera type - pan disabled.");this.dirtyCamera(!0),this.setCameraChanging(!0)}},{key:"_checkZoomNearBoundary",value:function(e,t){if(0>t){Rg.copy(e);var i=this.scene.getOriginalBoundingBoxWorld(),n=.5*i.getSize(Rg).length()/Math.tan(be.degToRad(.5*this.camera.fov)),r=this.scene.getMatrixWorldGlobal();bg.copy(r).invert(),Rg.applyMatrix4(bg);var o=20*n,a=i.getCenter(Rg);if(Rg.distanceTo(a)>o)return!0}return!1}},{key:"endOperation",value:function(){this.intersector.lastIntersect=null}},{key:"onUserInputFinished",value:function(){this.userInputWorking=!1,this.viewer.modelManager.setRenderStateChanged(!0),this.viewer.render()}},{key:"zoom",value:function(e,t,i){var n=null;wp.isDefined(t)&&wp.isDefined(i)&&(n=this.userInputHelper.getTrackingPoint(t,i)),this.userInputHelper.adjustCameraForZoom(e,n),this.update()}},{key:"touchDolly",value:function(e,t,i){var n=.5*i,r=new ke(e,t),o=this.getIntersectContext(r),a=this.intersector.hitTest(o);this.userInputHelper.adjustCameraForZoom(n,null!=a?a:null)}},{key:"zoomWithCenter",value:function(e,t){this.userInputHelper.adjustCameraForZoom(e>0?e/(1-e):e,this.scene.worldToDrawing(t)),this.update()}},{key:"getContainerDimensions",value:function(){return ag.getDomOffsetToClient(this.domElement)}},{key:"screenToCanvas",value:function(e,t){var i=this.getContainerDimensions();return{x:e-i.left,y:t-i.top}}},{key:"calculatePivot",value:function(e,t){return this.userInputHelper.getRotatePivot(e,t)}},{key:"mapWindowToViewport",value:function(e,t,i){var n=this.getContainerDimensions(),r=i||new ke;return r.x=(e-n.left)/n.width*2-1,r.y=-(t-n.top)/n.height*2+1,r}},{key:"mapViewportToWindow",value:function(e,t,i){var n=this.getContainerDimensions(),r=i||new ke;return r.x=(e+1)/2*n.width+n.left,r.y=(1-t)/2*n.height+n.top,r}},{key:"computeFrustum",value:function(e,t,i,n,r,o){var a=this,s=this.camera,l=s.near*Math.tan(be.degToRad(.5*s.fov)),c=l*s.aspect,h=(e-o.left)/o.width*2-1,d=(t-o.left)/o.width*2-1,u=-(i-o.top)/o.height*2+1,p=-(n-o.top)/o.height*2+1;if(s.isPerspective?Fg.makePerspective(h*c,d*c,u*l,p*l,s.near,s.far):Fg.makeOrthographic(h*c,d*c,u*l,p*l,s.near,s.far),s.updateMatrixWorld(),s.matrixWorldInverse.copy(s.matrixWorld).invert(),Qg.multiplyMatrices(Fg,s.matrixWorldInverse),r.setFromProjectionMatrix(Qg),!s.isPerspective){var g=function(e,t,i,n,o){var s,l=[a.viewer.worldToDrawing(a.viewer.clientToWorld({x:t,y:i,z:0})),a.viewer.worldToDrawing(a.viewer.clientToWorld({x:n,y:o,z:0})),a.viewer.worldToDrawing(a.viewer.clientToWorld({x:n,y:o,z:1}))];(s=r.planes[e]).setFromCoplanarPoints.apply(s,l)};g(0,e,i,e,n),g(1,t,n,t,i),g(2,e,n,t,n),g(3,t,i,e,i)}}},{key:"getCameraName",value:function(){return this.camera===this.viewer.defaultCamera?this.camera.isPerspective?Md.PERSPECTIVE:Md.ORTHOGRAPHIC:this.camera.name}},{key:"getCameraInfo",value:function(){var e=new Hp(this.getCameraName(),this.camera.position,this.camera.target,this.camera.up);return JSON.stringify(e)}},{key:"adjustCameraUp",value:function(){this.camera.realUp.z>0?this.camera.up.set(0,0,1):0>this.camera.realUp.z?this.camera.up.set(0,0,-1):this.camera.realUp.x>0?this.camera.up.set(1,0,0):0>this.camera.realUp.x?this.camera.up.set(-1,0,0):this.camera.realUp.y>0?this.camera.up.set(0,1,0):0>this.camera.realUp.y&&this.camera.up.set(0,-1,0)}},{key:"getWorldRight",value:function(){var e=new Ke,t=this.camera.up,i=this.camera.direction(Ug);return e.crossVectors(i,t),0===e.lengthSq()&&(t.y>t.z?i.z-=1e-4:i.y+=1e-4,e.crossVectors(i,t)),e.normalize()}},{key:"getWorldEye",value:function(){return this.camera.direction(Ug)}},{key:"getWorldRightByRealUp",value:function(){var e=new Ke,t=this.camera.realUp,i=this.camera.direction(Ug);return e.crossVectors(i,t),0===e.lengthSq()&&(t.y>t.z?i.z-=1e-4:i.y+=1e-4,e.crossVectors(i,t)),e.normalize()}},{key:"getWorldUp",value:function(){var e=this.getWorldRight(),t=this.camera.direction(Ug);return e.cross(t).normalize()}},{key:"getWorldPointFromNearPlane",value:function(e,t){var i=new Ke(e,t,0);return i.unproject(this.camera),i}},{key:"setCameraPosition",value:function(e){var t=this.camera,i=this.camera.direction(),n=i.length(),r=i.clone();r.normalize(),r.setLength(n),t.position.copy(e),t.target.addVectors(t.position,r),this.dirtyCamera(!0),this.setCameraChanging(!0)}},{key:"moveStraight",value:function(e,t){var i=this.camera.position,n=this.camera.target;if(t){var r=new Ke(n.x-i.x,0,n.z-i.z),o=e/r.length(),a=new Ke(r.x*o,0,r.z*o);i.add(a),n.add(a)}else{var s=n.clone().sub(i);this.camera.translateZ(-e),n.addVectors(i,s)}this.dirtyCamera(!0),this.setCameraChanging(!0)}},{key:"getIntersectContext",value:function(e){return this.userInputHelper.getIntersectContext(e)}},{key:"getLastIntersect",value:function(){return this.intersector.lastIntersect}},{key:"touchUpdateRotationInPersonView",value:function(e,t){this.dirtyCamera(!0),this.setCameraChanging(!0);var i=this,n=this.camera.position,r=this.camera.target.clone().sub(n).length();this.camera.getWorldDirection(Tg);var o=this.camera.realUp||this.camera.up,a=Tg.clone().cross(o).normalize(),s=a.clone().cross(Tg).normalize();this.camera.realUp.copy(s);var l=Kp.LockAxisZRange,c=null,h=null;if(Math.abs(e)>Math.abs(t))c=wg,h=e;else{if(Kp.LockAxisZ&&!Pg(this.camera,t,this.camera.target,l))return;c=a;var d=new Ke(0,0,1).clone().cross(o),u=d.dot(a),p=Math.asin(d.length());0>u&&(p=-p),p+t>Math.PI/4-Yp.EPSILON6?t=Math.PI/4-Yp.EPSILON6-p:p+t<-Math.PI/4+Yp.EPSILON6&&(t=-Math.PI/4+Yp.EPSILON6-p),h=t}var g,f,m=(new Ge).setFromAxisAngle(c,h);g=m,f=new Ke,Tg.applyQuaternion(g).normalize(),f.copy(n).add(Tg.multiplyScalar(r)),i.camera.target.copy(f),this.camera.realUp.applyQuaternion(m).normalize()}},{key:"touchUpdateRotationInModelView",value:function(e,t,i){this.dirtyCamera(!0),this.setCameraChanging(!0);var n=i||this.scene.getBoundingBox().getCenter(Rg),r=this.camera.position,o=this.camera.target.clone().sub(r).length(),a=r.clone().sub(n),s=a.length(),l=null;this.camera.getWorldDirection(Tg),a.normalize();var c=this,h=function(e){var t=new Ke,i=a.clone().applyQuaternion(e).normalize();r.copy(n).add(i.multiplyScalar(s)),Tg.applyQuaternion(e).normalize(),t.copy(r).add(Tg.multiplyScalar(o)),c.camera.target.copy(t)},d=this.camera.up,u=Tg.clone().cross(d).normalize(),p=u.clone().cross(Tg).normalize();this.camera.realUp.copy(p);var g=null;if(Kp.LockAxisZ){if(Math.abs(e)>Math.abs(t))g=wg,h(l=(new Ge).setFromAxisAngle(g,e)),this.camera.realUp.applyQuaternion(l).normalize();else if(null!=Kp.LockAxisZRange&&Math.abs(t)>1e-4){Pg(this.camera,t,n,Kp.LockAxisZRange)&&(g=Tg.clone().cross(d).normalize(),h(l=(new Ge).setFromAxisAngle(g,t)),this.camera.realUp.applyQuaternion(l).normalize(),this.adjustCameraUp())}}else if(Math.abs(e)>Math.abs(t))(1e-4>Math.abs(Tg.z+1)||1e-4>Math.abs(Tg.z-1))&&(g=Tg.clone().cross(this.camera.realUp).normalize(),h(l=(new Ge).setFromAxisAngle(g,.1)),this.camera.realUp.applyQuaternion(l).normalize(),this.adjustCameraUp()),g=new Ke(0,0,Tg.z>0&&0>this.camera.realUp.z?-1:1),h(l=(new Ge).setFromAxisAngle(g,e)),this.camera.realUp.applyQuaternion(l).normalize();else if(Math.abs(t)>.01){g=Tg.clone().cross(this.camera.realUp).normalize();var f=new Ke(0,0,1).clone().cross(d),m=f.dot(u),A=Math.asin(f.length());0>m&&(A=-A),A+t>Math.PI/2-Yp.EPSILON6?t=Math.PI/2-Yp.EPSILON6-A:A+t<-Math.PI/2+Yp.EPSILON6&&(t=-Math.PI/2+Yp.EPSILON6-A),h(l=(new Ge).setFromAxisAngle(g,t)),this.camera.realUp.applyQuaternion(l).normalize(),this.adjustCameraUp()}this.pivotBallGroup||function(e){e.pivotBallGroup=e.scene.getOrCreateGroup(Vp.PIVOTBALL,{priority:10,globalSpace:!1});var t=new Ks(15,64,64),i=new nn(t,new ig({color:16777215,depthTest:!1,opacity:.5,transparent:!0,side:2}));t=new Ks(1,64,64);var n=new nn(t,new ig({color:16711680,depthTest:!1,opacity:.5,transparent:!0,side:2}));e.pivotBallGroup.add(i),e.pivotBallGroup.add(n)}(this),this.pivotBallGroup.visible=!0;for(var y=function(e){var t=e.camera,i=t.position,n=e.camera.target.clone().sub(i);n.normalize();var r=new Jt;r.setFromNormalAndCoplanarPoint(n.clone().negate(),Ng(e)),r.normalize();var o=r.distanceToPoint(i)*Math.tan(.5*t.fov),a=e.getContainerDimensions();return 2*o/(a.height-a.top)}(this),v=Ng(this),C=0;this.pivotBallGroup.children.length>C;C+=1){var I=this.pivotBallGroup.children[C];I.position.copy(v),I.scale.set(y,y,y),I.updateMatrixWorld()}}},{key:"touchUpdateRotation",value:function(e,t){var i=this.camera.position;this.scene.getBoundingBox().containsPoint(i)?this.touchUpdateRotationInPersonView(e,t):this.touchUpdateRotationInModelView(e,t,Ng(this))}},{key:"clearTouchRotateState",value:function(){this.pivotBallGroup&&(this.pivotBallGroup.visible=!1)}},{key:"touchEndHandler",value:function(){this.viewer.controlManager.cameraChange=!1,this.clearTouchRotateState(),this.touchUpdate()}},{key:"touchUpdate",value:function(){var e=new Ke;e.copy(this.camera.up),this.camera.up.copy(this.camera.realUp),this.camera.lookAt(this.camera.target),this.camera.up.copy(e),this.camera.updateMVP(),(kg.distanceToSquared(this.camera.position)>Yp.EPSILON6||8*(1-Dg.dot(this.camera.quaternion))>Yp.EPSILON6)&&(this.dispatchEvent({type:Fd.ON_CAMERA_CHANGE,camera:this.camera}),this._changeCallBack(),this.dirtyCamera(!1),kg.copy(this.camera.position),Dg.copy(this.camera.quaternion))}},{key:"goTurnForWalk",value:function(e){var t=this.getCamera(),i=t.position,n=t.target,r=new Ke(n.x-i.x,n.y-i.y,0),o=Math.cos(e),a=Math.sin(e),s=new Ke(r.x*o-r.y*a,r.x*a+r.y*o,0);n.x=i.x+s.x,n.y=i.y+s.y,this.dirtyCamera(!0),this.setCameraChanging(!0)}},{key:"goPitchForWalk",value:function(e){var t=this.getCamera(),i=t.position,n=t.target,r=n.x-i.x,o=n.y-i.y,a=Math.sqrt(r*r+o*o),s=new Ke(a,0,n.z-i.z),l=Math.cos(e),c=Math.sin(e),h=new Ke(s.x*l-s.z*c,0,s.x*c+s.z*l);n.z=i.z+h.z,this.dirtyCamera(!0),this.setCameraChanging(!0)}},{key:"goUpDownForWalk",value:function(e,t){var i=this.getCamera(),n=i.position,r=i.target,o=new Ke(0,0,1),a=Gg(i,this.scene.getMatrixGlobal(),o,e);t&&(t.position.y+=a.stepDiffWorld.y),n.z+=a.stepDiffDrawing.z,r.z+=a.stepDiffDrawing.z,this.dirtyCamera(!0),this.setCameraChanging(!0)}},{key:"stepCameraForWalk",value:function(e,t,i){var n,r=this.getCamera(),o=r.position,a=r.target,s=new Ke(a.x-o.x,a.y-o.y,0).normalize(),l=new Ke(0,0,1),c=s.clone().cross(l),h=this.scene.getMatrixGlobal();switch(e){case Hd.FORWARD:n=Gg(r,h,s,t);break;case Hd.BACK:s.multiplyScalar(-1),n=Gg(r,h,s,t);break;case Hd.LEFT:c.multiplyScalar(-1),n=Gg(r,h,c,t);break;case Hd.RIGHT:n=Gg(r,h,c,t)}if(n.stepDiffDrawing.z=0,n.stepDiffWorld.y=0,i)return n;o.add(n.stepDiffDrawing),a.add(n.stepDiffDrawing),this.dirtyCamera(!0),this.setCameraChanging(!0)}},{key:"hitTestWithGround",value:function(e){var t=this.getCamera(),i=t.up.clone().multiplyScalar(-1);e&&(e.box.getCenter(Rg),Rg.z=e.box.max.z);var n=e?this.scene.worldToDrawing(Rg):t.position.clone(),r=new At(n,i),o=this.getIntersectContext(null),a=this.intersector.byGravity;this.intersector.byGravity=!0;var s=this.intersector.intersect(o,r,!1);return this.intersector.byGravity=a,s}},{key:"hitTestForward",value:function(e,t){var i=this.getCamera(),n=this.camera.direction();n.normalize(),n=n.multiplyScalar(e);var r,o=[],a=this.getIntersectContext(null);if(a.camera.near=-1,t)o=this.intersector.intersectByBox(a,t);else{r=i.position.clone();var s=new At(r,n),l=this.intersector.intersect(a,s,!1);l&&o.push(l)}return o}},{key:"hitTestRight",value:function(e,t){var i=this.getCamera(),n=this.camera.direction();n.normalize();var r,o=n.cross(i.up).normalize();o=o.multiplyScalar(e);var a=[],s=this.getIntersectContext(null);if(s.camera.near=-1,t)a=this.intersector.intersectByBox(s,t);else{r=i.position.clone();var l=new At(r,o),c=this.intersector.intersect(s,l,!1);c&&a.push(c)}return a}},{key:"setRealManHeight",value:function(e){e!==this._realManHeight&&(this._realManHeight=e,this.manHeight=void 0)}},{key:"getRealManHeight",value:function(){return this._realManHeight}},{key:"computeGravity",value:function(e){this.gravity=0;var t=this.hitTestWithGround(e);if(null==t){var i=this.scene.getMatrixGlobal();bg.copy(i).invert();var n=this.camera.position.clone();n.applyMatrix4(bg),n.z=this.scene.getBoundingBoxWorld().min.z||0,n.applyMatrix4(i),this.distanceToGround=Math.abs(this.camera.position.z-n.z)}if(void 0===this.manHeight)this.computeManHeight(e);else{var r=t?t.distance-this.manHeight:this.distanceToGround-this.manHeight;if(r/=this.scene.getGlobalScaleFactor(),.1>Math.abs(r))return 0;this.gravity=r}}},{key:"computeManHeight",value:function(e){var t;if(t=this.sceneLengthUnitFactor,!this.manHeight){var i=this.hitTestWithGround(e),n=e?.94*e.box.getSize(Rg).z:this._realManHeight*t,r=this.scene.getMatrixGlobal();if(bg.copy(r).invert(),null!=i){var o=i.point.clone();o.applyMatrix4(bg),o.z+=n,o.applyMatrix4(r),this.manHeight=Math.abs(i.point.z-o.z)}else{var a=e?e.box.min.clone():this.camera.position.clone();a.applyMatrix4(bg),a.z=0;var s=a.clone();s.z+=n,a.applyMatrix4(r),s.applyMatrix4(r),this.manHeight=Math.abs(s.z-a.z)}}}},{key:"walkWithParallelEye",value:function(){var e=this.camera,t=this.camera.direction().length(),i=this.scene.getBoundingBox().getCenter(Rg),n=new Ke;n.subVectors(i,e.position);var r=n.length();n.y=0,n.normalize(),n.multiplyScalar(r),e.position.subVectors(i,n),e.target.addVectors(e.position,n.normalize().multiplyScalar(t));var o=new Ke(0,0,1);e.up.copy(o),e.realUp.copy(o),this.dirtyCamera(!0),this.setCameraChanging(!0),this.update(!0)}},{key:"updateFlyMove",value:function(e,t){var i=this.camera;this.dirtyCamera(!0),this.setCameraChanging(!0);var n=Hd;e&n.FORWARD&&i.translateY(-t),e&n.BACK&&i.translateY(t),e&n.LEFT&&i.translateX(-t),e&n.RIGHT&&i.translateX(t),e&n.UP&&i.translateZ(t),e&n.DOWN&&i.translateZ(-t),this.flyOnWorld()}},{key:"flyOnWorld",value:function(e){var t=this.camera,i=t.up.clone();(e=!1!==e)&&t.realUp&&(t.up.copy(t.realUp),t.lookAt(t.target),t.up.copy(i)),this.updateCamera(),this._changeCallBack(),this.dirtyCamera(!1),Eg.copy(t.position),Bg.copy(t.quaternion)}},{key:"rotateForFly",value:function(e,t,i,n){var r=this.camera,o=r.position,a=r.target,s=a.clone().sub(o),l=new Ke(0,0,1),c=r.realUp||r.up,h=s.clone().cross(c).normalize();if(this.dirtyCamera(!0),this.setCameraChanging(!0),Kp.LockAxisZ&&(t=0),0!=t){var d=(new Ge).setFromAxisAngle(h,-t),u=s.clone();u.applyQuaternion(d);var p=u.angleTo(l);i>(p-=.5*Math.PI)||p>n||s.applyQuaternion(d)}if(0!=e){var g=(new Ge).setFromAxisAngle(l,-e);s.applyQuaternion(g)}a.addVectors(o,s),this.flyOnWorld()}},{key:"fitAndRotateBySelection",value:function(){this.viewer.zoomToSelection()}},{key:"flyToPointWithParallelEye",value:function(e){var t=this.camera.direction(),i=t.length(),n=t.clone();n.z=0,n.normalize(),n.setLength(i);var r=new Ke(0,0,1);this.camera.up=r,this.camera.realUp=r.clone(),this.camera.position.copy(e),this.camera.target.addVectors(this.camera.position,n),this.update(!0)}},{key:"flyToPoint",value:function(e){var t=this.camera.direction();this.camera.position.copy(e),this.camera.target.addVectors(this.camera.position,t),this.update(!0)}},{key:"setCameraHeight",value:function(e,t){this.cameraAbsoluteHeightEnabled=!1,this.cameraRelativeHeight=t,void 0===this.cameraConstraintHeights?this.cameraConstraintHeights=[]:this.cameraConstraintHeights.length=0;for(var i=0,n=e.length;n>i;i+=1)this.cameraConstraintHeights[i]=e[i]}},{key:"updateCameraHeight",value:function(){var e=this.scene,t=this.getCamera(),i=e.drawingToWorld(t.position),n=i.z,r=null,o=null;if(this.cameraAbsoluteHeightEnabled)void 0===this.cameraAbsoluteHeight&&(this.cameraAbsoluteHeight=n),r=this.cameraAbsoluteHeight;else if(void 0===this.cameraConstraintHeights)r=n;else{var a=wp.findRange(this.cameraConstraintHeights,n);if(r=this.cameraConstraintHeights[a],r+=this.cameraRelativeHeight,this.cameraConstraintHeights.length-1>a){var s=this.cameraConstraintHeights[a+1];r>s&&(r=s)}}r!==n&&(o=e.worldToDrawing({x:i.x,y:i.y,z:r}),this.setCameraPosition(o))}},{key:"getRaycaster",value:function(e,t){var i=new Xp,n=new ke;return this.userInputHelper.clientToViewport(e,t,n),i.setFromCamera(n,this.camera),i}},{key:"translateCameraForWalk",value:function(e,t){var i=this.collisionManager;if(0!==e.x){if(!1===xd.EnableHitDetection)return void this.stepCameraForWalk(Hd.RIGHT,e.x*t);var n=1;0>e.x&&(n=-1);var r=this.hitTestRight(n)[0];if(r){var o=this.viewer.modelManager.getNodeInfosByUserId(r.userId);if(!i.hasCollision({type:o?o[0].type:null},r.distance)){var a=t;Math.abs(t)>r.distance&&(a=t>0?r.distance-i.distance*i.factor-.1*this.sceneLengthUnitFactor:i.distance*i.factor-r.distance+.1*this.sceneLengthUnitFactor),this.stepCameraForWalk(Hd.RIGHT,e.x*a)}}else this.stepCameraForWalk(Hd.RIGHT,e.x*t)}if(0!==e.z)this.goUpDownForWalk(e.z*t*.5);else if(xd.WalkingWithGravity){var s=t;if(0!=this.gravity){var l=Math.abs(this.gravity);s=l>s?.2*l:l}this.gravity>0?this.goUpDownForWalk(-s):0>this.gravity&&this.goUpDownForWalk(s)}if(0!==e.y){if(!1===xd.EnableHitDetection)return void this.stepCameraForWalk(Hd.BACK,e.y*t);n=1;e.y>0&&(n=-1);var c=this.hitTestForward(n)[0];if(c){var h=this.viewer.modelManager.getNodeInfosByUserId(c.userId);if(!i.hasCollision({type:h?h[0].type:null},c.distance)){var d=t;Math.abs(t)>c.distance&&(d=t>0?c.distance-i.distance*i.factor-.1*this.sceneLengthUnitFactor:i.distance*i.factor-c.distance+.1*this.sceneLengthUnitFactor),this.stepCameraForWalk(Hd.BACK,e.y*d)}}else this.stepCameraForWalk(Hd.BACK,e.y*t)}}},{key:"translateCameraForThirdpersonWalk",value:function(e,t,i){var n=this.collisionManager;if(i.box.getSize(Og),Lg.set(i.box.min,i.box.max),Lg.min.z+=.5*Og.z,Lg.max.z-=.2*Og.z,0!==e.x){var r=this.stepCameraForWalk(Hd.RIGHT,e.x*t,i);if(Lg.min.add(r.stepDiffWorld),Lg.max.add(r.stepDiffWorld),!1===xd.EnableHitDetection)return void this.stepObjectForWalk(r,i,Lg);var o=1;0>e.x&&(o=-1);for(var a=this.hitTestRight(o,Lg),s=!1,l=0;a.length>l;l++){var c=this.viewer.modelManager.getNodeInfosByUserId(a[l]);if(s=n.hasCollision(c?c[0].userData:null,0))break}s||this.stepObjectForWalk(r,i,Lg)}if(0!==e.z)this.goUpDownForWalk(e.z*t*.5,i);else if(xd.WalkingWithGravity){var h=t;if(0!=this.gravity){var d=Math.abs(this.gravity);h=d>h?.2*d:d}this.gravity>0?this.goUpDownForWalk(-h,i):0>this.gravity&&this.goUpDownForWalk(h,i)}if(0!==e.y){var u=this.stepCameraForWalk(Hd.BACK,e.y*t,i);if(Lg.min.add(u.stepDiffWorld),Lg.max.add(u.stepDiffWorld),!1===xd.EnableHitDetection)return void this.stepObjectForWalk(u,i,Lg);o=1;e.y>0&&(o=-1);for(var p=this.hitTestForward(o,Lg),g=!1,f=0;p.length>f;f+=1){c=this.viewer.modelManager.getNodeInfosByUserId(p[f]);if(g=n.hasCollision(c?c[0].userData:null,0))break}g||this.stepObjectForWalk(u,i,Lg)}}},{key:"stepObjectForWalk",value:function(e,t,i){function n(e,t){return!(e.min.x>t.x||t.x>e.max.x||e.min.y>t.y||t.y>e.max.y)}var r=this.scene.getBoundingBoxWorld();if(n(r,i.min)&&n(r,i.max)){t.box.min.add(e.stepDiffWorld),t.box.max.add(e.stepDiffWorld),t.position.add(e.stepDiffWorld);var o=this.getCamera(),a=o.target;o.position.add(e.stepDiffDrawing),a.add(e.stepDiffDrawing),this.dirtyCamera(!0),this.setCameraChanging(!0)}}},{key:"rotateCameraForWalk",value:function(e,t){0!==e.y&&(this.goTurnForWalk(e.y*Math.PI*t),e.y=0),0!==e.x&&(this.goPitchForWalk(e.x*Math.PI),e.x=0)}},{key:"movePlane",value:function(e,t,i,n,r){if(null==r){var o=new Jt;o.setComponents(e.x,e.y,e.z,e.w),r=new Ke,o.coplanarPoint(r)}var a=new Ke(e.x,e.y,e.z),s=this.camera.getWorldDirection(Rg),l=new Jt;l.setFromNormalAndCoplanarPoint(s,r);var c=this.getRaycaster(t.clientX,t.clientY),h=new Ke,d=this.getRaycaster(i.x,i.y),u=new Ke;if(c.ray.intersectPlane(l,h)&&d.ray.intersectPlane(l,u)){h.subVectors(h,u),h.projectOnVector(a);var p=h.length();if(0>h.dot(a)&&(p=-p),0!=p)return n&&(a.multiplyScalar(p),p=a.x+a.y+a.z),p}return null}},{key:"getZenith",value:function(){var e=this.camera.position,t=this.viewer.getBoundingBox().getCenter(Rg);return e.clone().sub(t.clone()).clone().angleTo(wg.clone())}},{key:"getAzimuth",value:function(){var e=this.camera.position,t=this.viewer.getBoundingBox().getCenter(Rg),i=e.clone().sub(t.clone()).clone().projectOnPlane(Mg.clone()),n=i.angleTo(wg.clone());return 0>i.x&&(n=360-n),n}},{key:"getCurrentRangeofCamera",value:function(){var e=this.camera,t=this.viewer.getBoundingBox(),i=e.position,n=.5*t.getSize(Rg).length()/Math.tan(be.degToRad(.5*e.fov));return t.getCenter(Rg).distanceTo(i)/n}},{key:"setMaximalRangeofCamera",value:function(e){this.farFactor=e||2}},{key:"getMaximalRangeofCamera",value:function(){return this.farFactor}},{key:"cameraWithinMaximumRange",value:function(e){var t=e||this.farFactor;return this.getCurrentRangeofCamera()<=t}},{key:"resetCameraToMaximumRange",value:function(e){var t=this.camera,i=this.viewer.getBoundingBox(),n=t.position,r=e||this.farFactor,o=.5*i.getSize(Rg).length()/Math.tan(be.degToRad(.5*t.fov)),a=i.getCenter(Rg),s=(new Ke).subVectors(a,n);s.setLength(r*o);var l=a.clone().sub(s),c=this.camera.direction();this.camera.position.copy(l),this.camera.target.copy(c.add(l)),this.updateView(!0)}},{key:"setSceneUnit",value:function(e){var t=1;switch(e){case"m":t=.001;break;case"mm":t=1;break;case"km":t=1e-6;break;default:t=1}this.collisionManager.setFactor(t),this.sceneLengthUnitFactor=t}},{key:"projectPositionToBottom",value:function(e){var t=void 0;if(e instanceof Array)t=new Ke(e[0],e[1],e[2]);else{if(!(e instanceof Ke))return;t=e}this.getCamera();var i=new Ke(0,0,-t.z).normalize(),n=new At(t,i),r=this.getIntersectContext(null),o=this.intersector.byGravity;this.intersector.byGravity=!0;var a=this.intersector.intersect(r,n,!1);if(this.intersector.byGravity=o,a)return a.point}},{key:"setZoomSpeed",value:function(e){"number"==typeof e&&e>0&&(this.zoomSpeed=e)}},{key:"getZoomSpeed",value:function(){return this.zoomSpeed}},{key:"setZoomOutLimitRate",value:function(e){"number"==typeof e&&e>0&&(this.farFactor=e)}},{key:"getZoomOutLimitRate",value:function(){return this.farFactor}},{key:"zoomCameraForWalk",value:function(e){this.this.userInputHelper.adjustCameraForZoom(e,null)}},{key:"computeRotation",value:function(){var e=new yt;e.lookAt(this.camera.position,this.camera.target,this.camera.up);var t=new Ge;t.setFromRotationMatrix(e);var i=new bt;return i.setFromQuaternion(t,void 0,!1),i}},{key:"isKeepZoom",value:function(e,t,i){this.dirtyCamera(!0),this.setCameraChanging(!0),void 0===t&&(t=this.minDistance),void 0===i&&(i=this.maxDistance);var n=this.camera.position,r=this.camera.target,o=new Ke;o.copy(n).sub(r);var a=o.length()*(2-e);return!(t>a||a>i)}}]),i}(hg),Vg=function(){this.duration=500,this._state=null};Vg.prototype.rotateCameraByViewCubeSide=function(e,t,i,n){var r=e.target.clone(),o=t.getCenter(new Ke),a=e.quaternion.clone(),s=e.position.clone(),l=this._calculateDistanceAndEuler(i,t),c=(new Ge).setFromEuler(l.euler).invert(),h=new yt;h.makeRotationFromQuaternion(c);var d=h.elements,u=new Ke(-d[8],-d[9],-d[10]).normalize();u.setLength(l.distance);var p=o.clone().sub(u);if(!s.equals(p)||!a.equals(c)){var g=this._calculatePositionRotateInfo(a,c,s,p);this._state&&this._state.timerID&&(cancelAnimationFrame(this._state.timerID),this._state.timerID=void 0),this._state={startTime:Date.now(),startQuaternion:a,endQuaternion:c,startPosition:s,endPosition:p,startTarget:r,endTarget:o,positionRotateInfo:g,onUpdate:n},this._state.timerID=requestAnimationFrame(this._animate.bind(this))}},Vg.prototype.cancelAnimation=function(){this._state&&this._state.timerID&&(cancelAnimationFrame(this._state.timerID),this._state=void 0)},Vg.prototype._animate=function(){if(this._state){var e=Date.now(),t=this._state,i=t.startTarget,n=t.endTarget,r=t.startQuaternion,o=t.endQuaternion,a=t.startPosition,s=t.endPosition,l=t.positionRotateInfo,c=Math.min((e-t.startTime)/this.duration,1);c=this._easyOut(c);var h=o.clone();r.equals(o)||Ge.slerp(r,o,h,c);var d=s;a.equals(s)||(d=l?this._rotatePositionAroundCenter(l,a,s,c):a.clone().lerp(s,c));var u=n.clone();i.equals(n)||(u=u.lerpVectors(i,n,c)),"function"==typeof this._state.onUpdate&&this._state.onUpdate(c,h,d,u),1===c?(cancelAnimationFrame(this._state.timerID),this._state=null):this._state.timerID=requestAnimationFrame(this._animate.bind(this))}},Vg.prototype._calculateDistanceAndEuler=function(e,t){var i=-45,n=0,r=-135,o=0,a=t?t.getSize(new Ke):{x:0,y:0,z:0};switch(e){case kd.Home:break;case kd.Front:i=-90,n=0,r=0;break;case kd.Right:i=-90,n=0,r=-90;break;case kd.Back:i=-90,n=0,r=-180;break;case kd.Left:i=-90,n=0,r=-270;break;case kd.Top:i=0,n=0,r=0;break;case kd.Bottom:i=-180,n=0,r=-180;break;case kd.TopFront:i=-45,n=0,r=-90;break;case kd.TopRight:i=-45,n=0,r=-180;break;case kd.TopBack:i=-45,n=0,r=90;break;case kd.TopLeft:i=-45,n=0,r=0;break;case kd.BottomFront:i=-135,n=0,r=270;break;case kd.BottomRight:i=-135,n=0,r=-180;break;case kd.BottomBack:i=-135,n=0,r=90;break;case kd.BottomLeft:i=-135,n=0,r=0;break;case kd.FrontRight:i=-90,n=0,r=-135;break;case kd.BackRight:i=-90,n=0,r=-225;break;case kd.BackLeft:i=-90,n=0,r=45;break;case kd.FrontLeft:i=-90,n=0,r=-45;break;case kd.TopFrontRight:i=-45,n=-0,r=-135;break;case kd.TopBackRight:i=-45,n=0,r=-225;break;case kd.TopBackLeft:i=-45,n=0,r=-315;break;case kd.TopFrontLeft:i=-45,n=0,r=-45;break;case kd.BottomFrontRight:i=-135,n=0,r=-135;break;case kd.BottomBackRight:i=-135,n=0,r=-225;break;case kd.BottomBackLeft:i=-135,n=0,r=45;break;case kd.BottomFrontLeft:i=-135,n=0,r=-45}var s=Math.PI/180,l=new bt(i*s,n*s,r*s);return 0===(o=a.x+a.y+a.z)&&(o=xd.SceneSize/2),{euler:l,distance:o}},Vg.prototype._easyOut=function(e){return e*(2-e)},Vg.prototype._calculatePositionRotateInfo=function(e,t,i,n){var r=(new Ge).multiplyQuaternions(t,e.clone().invert());r.normalize();var o=new Ke(r.x,r.y,r.z).normalize(),a=2*Math.acos(r.w);if(0!==a){var s=null;if(a===Math.PI)s=(new Ke).addVectors(i,n).divideScalar(2);else{var l=(new Ke).addVectors(i,n),c=(new Ke).subVectors(n,i),h=o.clone().cross(c).normalize(),d=.5*c.length()/Math.tan(a/2);h.setLength(d),s=(new Ke).addVectors(l.multiplyScalar(.5),h)}var u=null,p=null,g=(new Ke).subVectors(i,s),f=g.length(),m=(new Ke).subVectors(n,i);if(a===Math.PI)p=-1,u=(new Ke).crossVectors(m,o);else{var A=(new Ke).subVectors(n,s);p=Math.cos(a),p=Math.max(-1,Math.min(1,p)),u=A.clone().sub(g.clone().multiplyScalar(p))}return{center:s,dot:p,vec:u,start:g,radiusLength:f}}},Vg.prototype._rotatePositionAroundCenter=function(e,t,i,n){if(0===n)return t;if(n>=1)return i;var r=Math.acos(e.dot)*n,o=e.start.clone(),a=e.vec.clone().normalize(),s=o.multiplyScalar(Math.cos(r)),l=a.multiplyScalar(Math.sin(r)*e.radiusLength),c=s.add(l);return c.add(e.center),c};var Yg=function(e){this.name=e,this._mousePressed=!1};Yg.prototype.getName=function(){return this.name},Yg.prototype.onExit=function(){},Yg.prototype.destroy=function(){},Yg.prototype.processMouseDown=function(e){return!1},Yg.prototype.processMouseMove=function(e){return!1},Yg.prototype.processMouseUp=function(e){return!1},Yg.prototype.processMouseWheel=function(e){return!1},Yg.prototype.processMouseDoubleClick=function(e){return!1},Yg.prototype.processKeyDown=function(e){return!1},Yg.prototype.processKeyUp=function(e){switch(e.keyCode){case Gp.ESC:this._mousePressed=!1}return!1},Yg.prototype.processTouchstart=function(e){return!1},Yg.prototype.processTouchmove=function(e){return!1},Yg.prototype.processTouchend=function(e){return!1},Yg.prototype.processHover=function(e){return!1},Yg.prototype.onEvent=function(e){var t=!1;switch(e.type){case"touchmove":t=this.processTouchmove(e);break;case"touchstart":t=this.processTouchstart(e);break;case"touchend":t=this.processTouchend(e);break;case"keydown":t=this.processKeyDown(e);break;case"keyup":t=this.processKeyUp(e);break;case"mousewheel":case"DOMMouseScroll":t=this.processMouseWheel(e);break;case"mousedown":this._mousePressed=!0,t=this.processMouseDown(e);break;case"mousemove":t=this._mousePressed?this.processMouseMove(e):this.processHover(e);break;case"mouseup":this._mousePressed=!1,t=this.processMouseUp(e);break;case"dblclick":t=this.processMouseDoubleClick(e)}return t};var Hg=function(e){Yg.call(this,Yd.CLIP_BY_BOX),this.viewer=e,this.scene=e.getScene(),this.enablePick=!1,this.cameraControl=e.cameraControl,this.clipStartPoint=new Ke,this.startPt=new ke,this.onClipBox=!1,this.mapLockedBoxFaces={},this.mapBoxFaceIndex={0:"right",1:"left",2:"top",3:"bottom",4:"front",5:"back"};for(var t=[],i=0;6>i;i+=1)t.push(new Jt);var n=this.scene.getClipPlanes(!0);n.updateClippingParams=function(i){if(0===i.iClipPlane.value)e.getRenderer().clippingPlanes=Object.freeze([]);else{for(var n=0,r=i.iClipPlane.value;r>n;n+=1){var o=i.vClipPlane.value[n],a=t[n];a.setComponents(-o.x,-o.y,-o.z,-o.w),a.normalize()}e.getRenderer().clippingPlanes=t,this.calculateClipBoundingBox(t)}},n.init(),this.selectIndex=null,this.planeDistance=0,this.offsetSpeed=.02,this.toggle=function(e,t){n.enable(e,t)},this.visible=function(e){n.visible=e},this.rotatable=function(e){n.rotatable=e},this.store=function(){return n.store()},this.restore=function(e){n.restore(e)},this.reset=function(){n.reset()},this.pointToScreen=function(e){var t=this.cameraControl.camera,i=new yt;i.multiplyMatrices(t.projectionMatrix,t.matrixWorldInverse);var n=new Le(e.x,e.y,e.z,1);n.applyMatrix4(i);var r=new ke;r.x=(n.x/n.w+1)/2,r.y=1-(n.y/n.w+1)/2;var o=this.cameraControl.getContainerDimensions();return r.x=r.x*o.width+o.left,r.y=r.y*o.height+o.top,r},this.getPlaneDistanceInScreen=function(){if(null===this.selectIndex)return null;if(2>this.selectIndex){var e=n.center.clone(),t=n.center.clone();e.x-=n.cubeSize.x,t.x+=n.cubeSize.x;var i=this.pointToScreen(e),r=this.pointToScreen(t);return i.x-r.x}var o=n.center.clone(),a=n.center.clone();a.y-=n.cubeSize.y,o.y+=n.cubeSize.y;var s=this.pointToScreen(a),l=this.pointToScreen(o);return s.y-l.y},this.getPickPoint=function(e,t){var i=this.cameraControl.camera,n=this.cameraControl.getContainerDimensions(),r=(e-n.left)/n.width*2-1,o=(n.height-(t-n.top))/n.height*2-1,a=new Xp;return a.setFromCamera(new ke(r,o),i),a.ray.intersectPlane(this.plane)},this.getSelectIndex=function(){return n.selectIndex},this._isVisible=function(){return n.visible},this.isRotate=function(){return n.rotatable},this.offset=function(e){var t=Math.floor(this.selectIndex/2);n.offset(this.selectIndex,this.selectIndex>3?this.selectIndex%2==1?-e*n.cubeSize.getComponent(t)*2:e*n.cubeSize.getComponent(t)*2:-e*n.cubeSize.getComponent(t)*2)},this.setSectionBox=function(e,t){var i=new He(new Ke(e.x,e.y,e.z),new Ke(t.x,t.y,t.z));i.applyMatrix4(this.scene.getMatrixGlobal()),n.setSectionBox(i.min,i.max)},this.calculateOffsetByBox=function(e,t){var i=new He(new Ke(e.x,e.y,e.z),new Ke(t.x,t.y,t.z));i.applyMatrix4(this.scene.getMatrixGlobal()),i.setFromCenterAndSize(i.getCenter(),i.getSize().multiplyScalar(this.scene.getExpandScalar())),n.calculateOffsetByBox(i.min,i.max)},this.moveSectionPlane=function(e,t){n.moveSectionPlane(e,t)},this.rotateSectionBox=function(e,t){n.rotateSectionBox(e,t)},this.rotate=function(e,t){2===this.selectIndex||3===this.selectIndex?n.rotX(t/180*Math.PI*.1):n.rotY(e/180*Math.PI*.1)},this.update=function(e){n.update(e)},this.cancelHighLight=function(){n.cancelHighLight()},this.highLight=function(){n.highLight()},this.lockBoxFaces=function(e){var t=!0;try{for(var i,n=e[Symbol.iterator]();!(t=(i=n.next()).done);t=!0){this.mapLockedBoxFaces[i.value]=!0}}catch(e){}finally{try{!t&&n.return&&n.return()}catch(e){}}},this.unlockBox=function(){this.mapLockedBoxFaces={}},this.setProcess=function(e,t){this.mapLockedBoxFaces[e]||n.setProcess(e,t)},this.getProcess=function(e){return n.getProcess(e)}};function jg(e){return null!=e}function Wg(e,t){return null!=e?e:t}(Hg.prototype=Object.create(Yg.prototype)).constructor=Hg,Hg.prototype.destroy=function(){this.cameraControl=null,this.intersectPoint=null,this.selectIndex=null,this.normal=null,this.plane=null,this.pickHelper=null,this.scene=null,this.viewer=null},Hg.prototype.onExit=function(){this.toggle(!1,!1)},Hg.prototype.processMouseDown=function(e){if(this.startPt.set(e.clientX,e.clientY),!this.enablePick&&e.button===n.LEFT){var t=this.cameraControl.getRaycaster(e.clientX,e.clientY),i=this.scene.getClipPlanes().hitTest(t),r=this.cameraControl.getIntersectContext(new ke(e.clientX,e.clientY)),o=this.cameraControl.intersector.intersect(r,null,!0);if(null!==o&&i.distance>=o.distance)return Yg.prototype.processMouseDown(this,e);if(this.selectIndex=this.getSelectIndex(),this.planeDistance=this.getPlaneDistanceInScreen(),null!==this.selectIndex)return this.highLight(),this.cameraControl.needUpdateRenderList(!0),this.cameraControl.update(!0),this.enablePick=!0,this.clipStartPoint=t.ray.at(i.distance,this.clipStartPoint),!0}return Yg.prototype.processMouseDown(this,e)},Hg.prototype.processHover=function(e){if(!this.enablePick){var t=!1,i=this.cameraControl.getRaycaster(e.clientX,e.clientY),n=this.scene.getClipPlanes(),r=this.getSelectIndex();if(null!==r&&this.cancelHighLight(),n.hitTest(i),this.selectIndex=this.getSelectIndex(),null!==this.selectIndex){if(this.highLight(),!this.onClipBox)this.onClipBox=!0,this.cameraControl.viewer.modelManager.dispatchEvent({type:Fd.ON_CLIP_HOVER,onClipBox:!0,event:e});t=!0}else if(this.onClipBox){this.onClipBox=!1,this.cameraControl.viewer.modelManager.dispatchEvent({type:Fd.ON_CLIP_HOVER,onClipBox:!1,event:e})}return this.selectIndex!==r&&(this.cameraControl.needUpdateRenderList(!0),this.cameraControl.update(!0)),t}return Yg.prototype.processHover(this,e)},Hg.prototype.processMouseUp=function(e){if(e.button===n.LEFT){var t=this.cameraControl.getRaycaster(e.clientX,e.clientY),i=this.scene.getClipPlanes();if(null!==this.getSelectIndex()&&(this.cancelHighLight(),this.cameraControl.needUpdateRenderList(!0),this.cameraControl.update(!0)),i.hitTest(t),this.selectIndex=this.getSelectIndex(),xd.ClippingCaps=!0,null!==this.selectIndex){if(this.highLight(),this.cameraControl.needUpdateRenderList(!0),this.cameraControl.update(!0),!this.onClipBox)this.onClipBox=!0,this.cameraControl.viewer.modelManager.dispatchEvent({type:Fd.ON_CLIP_HOVER,onClipBox:!0,event:e})}else if(this.onClipBox){this.onClipBox=!1,this.cameraControl.viewer.modelManager.dispatchEvent({type:Fd.ON_CLIP_HOVER,onClipBox:!1,event:e})}if(this.enablePick)return this.planeDistance=0,this.enablePick=!1,!0}return Yg.prototype.processMouseUp(this,e)},Hg.prototype.processMouseMove=function(e){if(this.enablePick){if(this.isRotate())this.rotate(e.clientX-this.startPt.x,e.clientY-this.startPt.y),this.startPt.set(e.clientX,e.clientY);else{var t=this.mapBoxFaceIndex[this.selectIndex];if(this.mapLockedBoxFaces[t])return!0;if(!(e.clientX===this.startPt.x&&e.clientY===this.startPt.y)){xd.ClippingCaps=!1;var i=this.scene.getClipPlanes(),n=this.cameraControl.movePlane(i.clipplanes[this.selectIndex],e,this.startPt,!0,this.clipStartPoint);null!==n&&i.offset(this.selectIndex,n),this.startPt.set(e.clientX,e.clientY)}this.cameraControl.viewer.modelManager.dispatchEvent({type:Fd.ON_CLIP_MOUSE_MOVE,draggedFaceName:t})}return this.cameraControl.update(!0),!0}return Yg.prototype.processMouseMove(this,e)},Hg.prototype.processTouchstart=function(e){if(this.startPt.set(e.touches[0].clientX,e.touches[0].clientY),this.enablePick)return Yg.prototype.processTouchstart(this,e);var t=this.cameraControl.getRaycaster(e.touches[0].clientX,e.touches[0].clientY);return this.scene.getClipPlanes().hitTest(t),this.selectIndex=this.getSelectIndex(),this.planeDistance=this.getPlaneDistanceInScreen(),null!==this.selectIndex?(this.highLight(),this.cameraControl.needUpdateRenderList(!0),this.cameraControl.update(!0),this.update(),!0):void 0},Hg.prototype.processTouchmove=function(e){if(null!==this.selectIndex){if(this.isRotate())this.rotate(e.touches[0].clientX-this.startPt.x,e.touches[0].clientY-this.startPt.y),this.startPt.set(e.touches[0].clientX,e.touches[0].clientY);else{this.offset((2>this.selectIndex?e.touches[0].clientX-this.startPt.x:e.touches[0].clientY-this.startPt.y)/this.planeDistance),this.startPt.set(e.touches[0].clientX,e.touches[0].clientY)}return this.cameraControl.update(!0),this.update(),!0}return Yg.prototype.processTouchmove(this,e)},Hg.prototype.processTouchend=function(e){return this.selectIndex=null,this.planeDistance=0,this.enablePick&&(this.onUpdateUI({visible:!1}),this.startPt.x===e.touches[0].clientX&&this.startPt.y===e.touches[0].clientY&&this.pickHelper.click(e)),this.cameraControl.needUpdateRenderList(!0),this.cancelHighLight(),this.cameraControl.update(!0),this.update(),Yg.prototype.processTouchend(this,e)},Wg.EMPTY_OBJECT=Object.freeze({}),new Ke;var Jg=function(e){lu(i,e);var t=pu(i);function i(){var e,n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return ru(this,i),(e=t.call(this)).destroyMeshs=Wg(n.destroyMeshs,!0),e.boundingBox=new He,e}return au(i,[{key:"getBoundingBoxCenter",value:function(e){return jg(e)||(e=new Ke),this.boundingBox.getCenter(e)}}]),i}(Yt),zg={LOCAL:0,WORLD:1},qg=function(e,t,i){Yg.call(this,Yd.COMPONENT_TRANSFORM),this._callbackWrapper=void 0,this._objectCallbackWrapper=void 0,this._cancelCallback=void 0,this.transformControl=new Zg(e,t,i),this.bindingComponentKey=void 0,this.transformObject=new Jg};(qg.prototype=Object.create(Yg.prototype)).constructor=qg,qg.prototype.destroy=function(){this.transformControl.destory()},qg.prototype.update=function(){this.transformControl.updateMatrixWorld()},qg.prototype.transformComponent=function(e,t,i,n,r){if(e){e instanceof Jg&&(e=this.transformObject);var o=this.transformControl;if(o.object&&e!==o.object&&this.cancelTransformComponent(!1),this._callbackWrapper&&(this.transformControl.removeEventListener("change",this._callbackWrapper),this._callbackWrapper=void 0),this._objectCallbackWrapper&&(this.transformControl.removeEventListener("objectChange",this._objectCallbackWrapper),this._objectCallbackWrapper=void 0),this._cancelCallback&&(this._cancelCallback=void 0),this._pauseCallbackWrapper&&(this.transformControl.removeEventListener("mouseUp",this._pauseCallbackWrapper),this._pauseCallbackWrapper=void 0),t&&(this._callbackWrapper=function(e){t(e)},this.transformControl.addEventListener("change",this._callbackWrapper)),i){this._objectCallbackWrapper=function(e){i(e)},this.transformControl.addEventListener("objectChange",this._objectCallbackWrapper);var a=this.transformControl._listeners.objectChange,s=a.splice(a.length-1,1)[0];a.unshift(s)}n&&(this._cancelCallback=n),r&&(this._pauseCallbackWrapper=function(e){r(e)},this.transformControl.addEventListener("mouseUp",this._pauseCallbackWrapper)),this._saveComponentOriginalTransformState(e),!0!==o.showX&&(o.showX=!0),!0!==o.showY&&(o.showY=!0),!0!==o.showZ&&(o.showZ=!0),!0!==o.enabled&&(o.enabled=!0),o.attach(e)}},qg.prototype.cancelTransformComponent=function(){var e=this.transformControl.object;if(e)return this.transformControl.detach(),this._callbackWrapper&&(this.transformControl.removeEventListener("change",this._callbackWrapper),this._callbackWrapper=void 0),this._objectCallbackWrapper&&(this.transformControl.removeEventListener("objectChange",this._objectCallbackWrapper),this._objectCallbackWrapper=void 0),this._cancelCallback&&(this._cancelCallback(),this._cancelCallback=void 0),this.bindingComponentKey=void 0,e},qg.prototype.switchToTranslateMode=function(){this.transformControl.setMode("translate")},qg.prototype.switchToRotateMode=function(){this.transformControl.setMode("rotate")},qg.prototype.switchToScaleMode=function(){this.transformControl.setMode("scale")},qg.prototype._saveComponentOriginalTransformState=function(e){var t;if(e instanceof Array)t=e;else{if(!(e instanceof Yt))return;t=[e]}for(var i=0,n=t.length;n>i;i+=1){var r=t[i];if(!r.userData._originalTransformState){var o=r.position.clone(),a=r.quaternion.clone(),s=r.scale.clone(),l=r.matrix.clone(),c=r.matrixWorld.clone();r.userData._originalTransformState={position:o,quaternion:a,scale:s,matrix:l,matrixWorld:c}}}},qg.prototype.restoreComponentOriginalTransformState=function(){if(!this.transformControl.object)return!1;var e,t=this.transformControl.object;if(t instanceof Array)e=t;else{if(!(t instanceof Yt))return!1;e=[t]}for(var i=!1,n=0,r=e.length;r>n;n+=1){var o=e[n],a=o.userData._originalTransformState;a&&(o.position.copy(a.position),o.quaternion.copy(a.quaternion),o.scale.copy(a.scale),o.matrix.copy(a.matrix),o.matrixWorld.copy(a.matrixWorld),this.transformControl.updateMatrixWorld(),this.transformControl.dispatchEvent({type:"objectChange"}),i=!0)}return i},qg.prototype.increaseTransformControlSize=function(){var e=this.transformControl;if(e.object&&e.visible){var t=e.size;if(3>t)return e.setSize(t+.1),!0}return!1},qg.prototype.decreaseTransformControlSize=function(){var e=this.transformControl;if(e.object&&e.visible){var t=e.size;if(t>.5)return e.setSize(t-.1),!0}return!1},qg.prototype.setTransformControlSize=function(e){var t=this.transformControl;return!(!t.object||!t.visible)&&(t.setSize(e),!0)},qg.prototype.getTransformControlSize=function(){return this.transformControl.size},qg.prototype.setTransformSpaceToLocalSpace=function(){console.log("不再支持")},qg.prototype.setTransformSpaceToWorldSpace=function(){console.log("不再支持")},qg.prototype.switchTransformSpace=function(){console.log("不再支持")},qg.prototype.showTransformOnAxis=function(e){var t=this.transformControl;if(t.object&&t.visible){var i=!1;switch(e){case"x":case"X":!0!==t.showX&&(i=!0,t.showX=!0);break;case"y":case"Y":!0!==t.showY&&(i=!0,t.showY=!0);break;case"z":case"Z":!0!==t.showZ&&(i=!0,t.showZ=!0)}return i}return!1},qg.prototype.hideTransformOnAxis=function(e){var t=this.transformControl;if(t.object&&t.visible){var i=!1;switch(e){case"x":case"X":!1!==t.showX&&(i=!0,t.showX=!1);break;case"y":case"Y":!1!==t.showY&&(i=!0,t.showY=!1);break;case"z":case"Z":!1!==t.showZ&&(i=!0,t.showZ=!1)}return i}return!1},qg.prototype.disableTransform=function(){var e=this.transformControl;return!(!e.object||!e.visible||!1===e.enabled)&&(e.enabled=!1,!0)},qg.prototype.enableTransform=function(){var e=this.transformControl;return!(!e.object||!e.visible||!0===e.enabled)&&(e.enabled=!0,!0)},qg.prototype.processMouseDown=function(e){return!!this.transformControl.enabled&&(!!this.transformControl.mouseHover(e)&&this.transformControl.mouseDown(e))},qg.prototype.processMouseMove=function(e){return!!this.transformControl.enabled&&this.transformControl.mouseMove(e)},qg.prototype.processMouseUp=function(e){return!!this.transformControl.enabled&&this.transformControl.mouseUp(e)},qg.prototype.processHover=function(e){return!!this.transformControl.enabled&&this.transformControl.mouseHover(e)},qg.onExit=function(){this.destroy()};var Zg=function(e){lu(i,e);var t=pu(i);function i(e,n,r){var o;ru(this,i),(o=t.call(this)).isTransformControls=!0,r=void 0!==r?r:document,o.scene=e,o.visible=!1;var a=new Xg;o.add(a);var s=new _g;o.add(s);var l=du(o);N("camera",n),N("object",void 0),N("enabled",!0),N("axis",null),N("mode","translate"),N("translationSnap",null),N("rotationSnap",null),N("space","world"),N("size",1),N("dragging",!1),N("showX",!0),N("showY",!0),N("showZ",!0);var c={type:"change"},h={type:"mouseDown"},d={type:"mouseUp",mode:l.mode},u={type:"objectChange"};o.objectChangeEvent=u,o.rotateSpace=zg.WORLD;var p=new Xp,g=new Ke,f=new Ke,m=new Ge,A={X:new Ke(1,0,0),Y:new Ke(0,1,0),Z:new Ke(0,0,1)};new Ge,new Ke;var y=new Ke,v=new Ke,C=new Ke,I=new Ke,x=new Ke,w=new Ke,M=0,E=new Ke,B=new Ge,S=new Ke,b=new Ke,k=new Ge,D=new Ge,T=new Ke(1,1,1),R=new Ke,U=new Ke;new Ke;var F=new Ge,Q=new Ge,L=new Ke,O=new Ke;function N(e,t){var i=t;Object.defineProperty(l,e,{get:function(){return void 0!==i?i:t},set:function(t){i!==t&&(i=t,s[e]=t,a[e]=t,l.dispatchEvent({type:e+"-changed",value:t}),l.dispatchEvent(c))}}),l[e]=t,s[e]=t,a[e]=t}function P(e){var t=e.changedTouches?e.changedTouches[0]:e,i=r.getBoundingClientRect();return{x:(t.clientX-i.left)/i.width*2-1,y:-(t.clientY-i.top)/i.height*2+1,button:e.button}}return N("worldPosition",U),N("worldPositionStart",R),N("worldQuaternion",F),N("cameraPosition",E),N("cameraQuaternion",B),N("pointStart",y),N("pointEnd",v),N("rotationAxis",I),N("rotationAngle",M),N("eye",O),o.attach=function(t){t&&(this.object!==t&&(this.scene.add(this),e.componentTransformControl=this,this.object=t,c.object=t,u.object=t,this.updateMatrixWorld()),this.visible=!0)},o.detach=function(){this.object&&(this.object=void 0,c.object=void 0),this.parent&&this.parent.remove(this),this.scene.componentTransformControl=void 0},o.destory=function(){this.scene.componentTransformControl=void 0,this.scene=void 0,this.axis=void 0,this.camera=void 0},o.updateMatrixWorld=function(){if(void 0!==this.object){var e,t=new He;if(this.object instanceof Array)e=this.object;else{if(!(this.object instanceof Yt))return;e=[this.object]}for(var i=0,n=e.length;n>i;i+=1){var r=e[i];if(r.geometry)t.expandByObject(e[i]);else{var o=new Ke;r.getWorldPosition(o),t.expandByPoint(o)}}e[0].parent&&e[0].parent.matrixWorld.decompose(b,k,T),e[0].matrixWorld.decompose(U,F,L),t.getCenter(U),D.copy(k).invert(),Q.copy(F).invert()}this.camera.updateMatrixWorld(),this.camera.matrixWorld.decompose(E,B,S),this.camera instanceof dn?O.copy(E).sub(U).normalize():this.camera instanceof pc?O.copy(E).normalize():this.camera instanceof Ep&&(this.camera.isPerspective?O.copy(E).sub(U).normalize():O.copy(E).normalize()),Yt.prototype.updateMatrixWorld.call(this)},o.mouseHover=function(e){var t=P(e);if(void 0===this.object||!0===this.dragging||void 0!==t.button&&0!==t.button)return!1;p.setFromCamera(t,this.camera);var i,n=p.intersectObjects(a.picker[this.mode].children,!0)||!1;return n?(this.axis=n.object.name,i=!0):(this.axis=null,i=!1),this.updateMatrixWorld(),i},o.mouseDown=function(e){var t=P(e);if(void 0===this.object||!0===this.dragging||void 0!==t.button&&0!==t.button)return!1;if((0===t.button||void 0===t.button)&&null!==this.axis){p.setFromCamera(t,this.camera);var i=p.intersectObjects([s],!0)||!1;return!1!==i&&(i&&(R.copy(U),y.copy(i.point).sub(R)),this.dragging=!0,h.mode=this.mode,this.dispatchEvent(h),!0)}},o.mouseMove=function(e){var t=P(e),i=this.axis,n=this.mode,r=void 0;if(void 0===this.object||null===i||!1===this.dragging||void 0!==t.button&&0!==t.button)return!1;p.setFromCamera(t,this.camera);var o=p.intersectObjects([s],!0)||!1;if(!1===o)return!1;if(v.copy(o.point).sub(R),"translate"===n)C.copy(v).sub(y),-1===i.indexOf("X")&&(C.x=0),-1===i.indexOf("Y")&&(C.y=0),-1===i.indexOf("Z")&&(C.z=0),C.applyQuaternion(D).divide(T),0===C.x&&0===C.y&&0===C.z||(r=this._translateCurrentObject(C));else if("scale"===n){if(-1!==i.search("XYZ")){var a=v.length()/y.length();0>v.dot(y)&&(a*=-1),f.set(a,a,a)}else g.copy(y),f.copy(v),g.applyQuaternion(Q),f.applyQuaternion(Q),f.divide(g),-1===i.search("X")&&(f.x=1),-1===i.search("Y")&&(f.y=1),-1===i.search("Z")&&(f.z=1);1===f.x&&1===f.y&&1===f.z||(r=this._scaleCurrentObject(f))}else if("rotate"===n){C.copy(v).sub(y);var l=20/U.distanceTo(g.setFromMatrixPosition(this.camera.matrixWorld));if("E"===i?(I.copy(O),M=v.angleTo(y),x.copy(y).normalize(),w.copy(v).normalize(),M*=0>w.cross(x).dot(O)?1:-1):"XYZE"===i?(I.copy(C).cross(O).normalize(),M=C.dot(g.copy(I).cross(this.eye))*l):"X"!==i&&"Y"!==i&&"Z"!==i||(I.copy(A[i]),g.copy(A[i]),M=C.dot(g.cross(O).normalize())*l),this.rotationAngle=M,0!==M){var h=new Ge;I.applyQuaternion(D),h.copy(m.setFromAxisAngle(I,M)),h.normalize(),r=this._rotateCurrentObject(h)}}return r?(this.updateMatrixWorld(),this.dispatchEvent(c),u.matrix=r.clone(),u.mode=n,u.rotateSpace=this.rotateSpace,this.dispatchEvent(u),y.copy(v),!0):void 0},o.mouseUp=function(e){var t=P(e);return(void 0===t.button||0===t.button)&&(this.dragging&&null!==this.axis&&(d.mode=this.mode,this.dispatchEvent(d)),this.dragging=!1,void 0===t.button&&(this.axis=null),!0)},o.getMode=function(){return l.mode},o.setMode=function(e){l.mode=e,this.updateMatrixWorld()},o.setTranslationSnap=function(e){l.translationSnap=e},o.setRotationSnap=function(e){l.rotationSnap=e},o.setSize=function(e){l.size=e},o.setSpace=function(e){l.space=e},o.getBoundingBox=function(){return a.getBoundingBox()},o._scaleCurrentObject=function(){var e=new yt,t=new yt,i=new yt,n=new yt,r=new Ke;return function(o){var a;if(this.object instanceof Array)a=this.object;else{if(!(this.object instanceof Yt))return;a=[this.object]}for(var s=0,l=a.length;l>s;s+=1){var c=a[s];c.geometry?(c.geometry.boundingBox||c.geometry.computeBoundingBox(),c.geometry.boundingBox.getCenter(r),r.applyMatrix4(c.matrix)):r.copy(c.position),t.makeTranslation(-r.x,-r.y,-r.z),i.makeScale(o.x,o.y,o.z),n.makeTranslation(r.x,r.y,r.z),e.identity(),e.multiply(n),e.multiply(i),e.multiply(t);var h=c.matrixAutoUpdate;c.matrixAutoUpdate=!1,c.applyMatrix4(e),c.updateMatrixWorld(!0),c.matrixAutoUpdate=h}return e}}(),o._rotateCurrentObject=function(){var e=new yt,t=new yt,i=new yt,n=new yt,r=new Ke;return function(o){var a;if(this.object instanceof Array)a=this.object;else{if(!(this.object instanceof Yt))return;a=[this.object]}for(var s=0,l=a.length;l>s;s+=1){var c=a[s];c.geometry?(c.geometry.boundingBox||c.geometry.computeBoundingBox(),c.geometry.boundingBox.getCenter(r),r.applyMatrix4(c.matrix)):r.copy(c.position),e.makeTranslation(-r.x,-r.y,-r.z),t.makeRotationFromQuaternion(o),i.makeTranslation(r.x,r.y,r.z),n.identity(),n.multiply(i),n.multiply(t),n.multiply(e);var h=c.matrixAutoUpdate;c.matrixAutoUpdate=!1,c.applyMatrix4(n),c.matrixAutoUpdate=h,c.updateMatrixWorld(!0)}return n}}(),o._translateCurrentObject=function(){var e=new yt;return function(t){var i;if(this.object instanceof Array)i=this.object;else{if(!(this.object instanceof Yt))return;i=[this.object]}e.makeTranslation(t.x,t.y,t.z);for(var n=0,r=i.length;r>n;n+=1){var o=i[n],a=o.matrixAutoUpdate;o.matrixAutoUpdate=!1,o.applyMatrix4(e),o.matrixAutoUpdate=a,o.updateMatrixWorld(!0)}return e}}(),o.removeTranslateXYZ=function(){var e=a.gizmo.translate.getObjectByName("XYZ"),t=a.picker.translate.getObjectByName("XYZ");jg(e)&&e.parent.remove(e),jg(t)&&t.parent.remove(t)},o}return i}(Yt),Xg=function(e){lu(i,e);var t=pu(i);function i(){var e;ru(this,i),(e=t.call(this)).type="TransformControlsGizmo",e.isTransformControlsGizmo=!0;var n=new gi({depthTest:!1,depthWrite:!1,transparent:!0,side:2,fog:!1}),r=new Sa({depthTest:!1,depthWrite:!1,transparent:!0,linewidth:1,fog:!1}),o=n.clone();o.opacity=.15;var a=n.clone();a.opacity=.33;var s=n.clone();s.color.set(16711680);var l=n.clone();l.color.set(65280);var c=n.clone();c.color.set(255);var h=n.clone();h.opacity=.25;var d=h.clone();d.color.set(16776960);var u=h.clone();u.color.set(65535);var p=h.clone();p.color.set(16711935),n.clone().color.set(16776960);var g=r.clone();g.color.set(16711680);var f=r.clone();f.color.set(65280);var m=r.clone();m.color.set(255);var A=r.clone();A.color.set(65535);var y=r.clone();y.color.set(16711935);var v=r.clone();v.color.set(16776960);var C=r.clone();C.color.set(7895160);var I=v.clone();I.opacity=.25;var x=new Za(0,.05,.2,12,1,!1),w=new on(.125,.125,.125),M=new Ni;M.setAttribute("position",new Bi([0,0,0,1,0,0],3));var E,B=function(e,t){for(var i=new Ni,n=[],r=0;64*t>=r;++r)n.push(0,Math.cos(r/32*Math.PI)*e,Math.sin(r/32*Math.PI)*e);return i.setAttribute("position",new Bi(n,3)),i},S={X:[[new nn(x,s),[1,0,0],[0,0,-Math.PI/2],null,"fwd"],[new nn(x,s),[1,0,0],[0,0,Math.PI/2],null,"bwd"],[new Ua(M,g)]],Y:[[new nn(x,l),[0,1,0],null,null,"fwd"],[new nn(x,l),[0,1,0],[Math.PI,0,0],null,"bwd"],[new Ua(M,f),null,[0,0,Math.PI/2]]],Z:[[new nn(x,c),[0,0,1],[Math.PI/2,0,0],null,"fwd"],[new nn(x,c),[0,0,1],[-Math.PI/2,0,0],null,"bwd"],[new Ua(M,m),null,[0,-Math.PI/2,0]]],XYZ:[[new nn(new Os(.1,0),h),[0,0,0],[0,0,0]]],XY:[[new nn(new In(.295,.295),d),[.15,.15,0]],[new Ua(M,v),[.18,.3,0],null,[.125,1,1]],[new Ua(M,v),[.3,.18,0],[0,0,Math.PI/2],[.125,1,1]]],YZ:[[new nn(new In(.295,.295),u),[0,.15,.15],[0,Math.PI/2,0]],[new Ua(M,A),[0,.18,.3],[0,0,Math.PI/2],[.125,1,1]],[new Ua(M,A),[0,.3,.18],[0,-Math.PI/2,0],[.125,1,1]]],XZ:[[new nn(new In(.295,.295),p),[.15,0,.15],[-Math.PI/2,0,0]],[new Ua(M,y),[.18,0,.3],null,[.125,1,1]],[new Ua(M,y),[.3,0,.18],[0,-Math.PI/2,0],[.125,1,1]]]},b={X:[[new nn(new Za(.2,0,1,4,1,!1),o),[.6,0,0],[0,0,-Math.PI/2]]],Y:[[new nn(new Za(.2,0,1,4,1,!1),o),[0,.6,0]]],Z:[[new nn(new Za(.2,0,1,4,1,!1),o),[0,0,.6],[Math.PI/2,0,0]]],XYZ:[[new nn(new Os(.2,0),o)]],XY:[[new nn(new In(.4,.4),o),[.2,.2,0]]],YZ:[[new nn(new In(.4,.4),o),[0,.2,.2],[0,Math.PI/2,0]]],XZ:[[new nn(new In(.4,.4),o),[.2,0,.2],[-Math.PI/2,0,0]]]},k={START:[[new nn(new Os(.01,2),a),null,null,null,"helper"]],END:[[new nn(new Os(.01,2),a),null,null,null,"helper"]],DELTA:[[new Ua((E=new Ni,E.setAttribute("position",new Bi([0,0,0,1,1,1],3)),E),a),null,null,null,"helper"]],X:[[new Ua(M,a.clone()),[-1e3,0,0],null,[1e6,1,1],"helper"]],Y:[[new Ua(M,a.clone()),[0,-1e3,0],[0,0,Math.PI/2],[1e6,1,1],"helper"]],Z:[[new Ua(M,a.clone()),[0,0,-1e3],[0,-Math.PI/2,0],[1e6,1,1],"helper"]]},D={X:[[new Ua(B(1,.5),g)],[new nn(new Os(.04,0),s),[0,0,.99],null,[1,3,1]]],Y:[[new Ua(B(1,.5),f),null,[0,0,-Math.PI/2]],[new nn(new Os(.04,0),l),[0,0,.99],null,[3,1,1]]],Z:[[new Ua(B(1,.5),m),null,[0,Math.PI/2,0]],[new nn(new Os(.04,0),c),[.99,0,0],null,[1,3,1]]],E:[[new Ua(B(1.25,1),I),null,[0,Math.PI/2,0]],[new nn(new Za(.03,0,.15,4,1,!1),I),[1.17,0,0],[0,0,-Math.PI/2],[1,1,.001]],[new nn(new Za(.03,0,.15,4,1,!1),I),[-1.17,0,0],[0,0,Math.PI/2],[1,1,.001]],[new nn(new Za(.03,0,.15,4,1,!1),I),[0,-1.17,0],[Math.PI,0,0],[1,1,.001]],[new nn(new Za(.03,0,.15,4,1,!1),I),[0,1.17,0],[0,0,0],[1,1,.001]]],XYZE:[[new Ua(B(1,1),C),null,[0,Math.PI/2,0]]]},T={AXIS:[[new Ua(M,a.clone()),[-1e3,0,0],null,[1e6,1,1],"helper"]]},R={X:[[new nn(new Hs(1,.1,4,24),o),[0,0,0],[0,-Math.PI/2,-Math.PI/2]]],Y:[[new nn(new Hs(1,.1,4,24),o),[0,0,0],[Math.PI/2,0,0]]],Z:[[new nn(new Hs(1,.1,4,24),o),[0,0,0],[0,0,-Math.PI/2]]],E:[[new nn(new Hs(1.25,.1,2,24),o)]],XYZE:[[new nn(new Ks(.7,10,8),o)]]},U={X:[[new nn(w,s),[.8,0,0],[0,0,-Math.PI/2]],[new Ua(M,g),null,null,[.8,1,1]]],Y:[[new nn(w,l),[0,.8,0]],[new Ua(M,f),null,[0,0,Math.PI/2],[.8,1,1]]],Z:[[new nn(w,c),[0,0,.8],[Math.PI/2,0,0]],[new Ua(M,m),null,[0,-Math.PI/2,0],[.8,1,1]]],XY:[[new nn(w,d),[.85,.85,0],null,[2,2,.2]],[new Ua(M,v),[.855,.98,0],null,[.125,1,1]],[new Ua(M,v),[.98,.855,0],[0,0,Math.PI/2],[.125,1,1]]],YZ:[[new nn(w,u),[0,.85,.85],null,[.2,2,2]],[new Ua(M,A),[0,.855,.98],[0,0,Math.PI/2],[.125,1,1]],[new Ua(M,A),[0,.98,.855],[0,-Math.PI/2,0],[.125,1,1]]],XZ:[[new nn(w,p),[.85,0,.85],null,[2,.2,2]],[new Ua(M,y),[.855,0,.98],null,[.125,1,1]],[new Ua(M,y),[.98,0,.855],[0,-Math.PI/2,0],[.125,1,1]]],XYZX:[[new nn(new on(.125,.125,.125),h),[1.1,0,0]]],XYZY:[[new nn(new on(.125,.125,.125),h),[0,1.1,0]]],XYZZ:[[new nn(new on(.125,.125,.125),h),[0,0,1.1]]]},F={X:[[new nn(new Za(.2,0,.8,4,1,!1),o),[.5,0,0],[0,0,-Math.PI/2]]],Y:[[new nn(new Za(.2,0,.8,4,1,!1),o),[0,.5,0]]],Z:[[new nn(new Za(.2,0,.8,4,1,!1),o),[0,0,.5],[Math.PI/2,0,0]]],XY:[[new nn(w,o),[.85,.85,0],null,[3,3,.2]]],YZ:[[new nn(w,o),[0,.85,.85],null,[.2,3,3]]],XZ:[[new nn(w,o),[.85,0,.85],null,[3,.2,3]]],XYZX:[[new nn(new on(.2,.2,.2),o),[1.1,0,0]]],XYZY:[[new nn(new on(.2,.2,.2),o),[0,1.1,0]]],XYZZ:[[new nn(new on(.2,.2,.2),o),[0,0,1.1]]]},Q={X:[[new Ua(M,a.clone()),[-1e3,0,0],null,[1e6,1,1],"helper"]],Y:[[new Ua(M,a.clone()),[0,-1e3,0],[0,0,Math.PI/2],[1e6,1,1],"helper"]],Z:[[new Ua(M,a.clone()),[0,0,-1e3],[0,-Math.PI/2,0],[1e6,1,1],"helper"]]},L=function(e){var t=new Yt;for(var i in e)for(var n=e[i].length;n--;){var r=e[i][n][0].clone(),o=e[i][n][1],a=e[i][n][2],s=e[i][n][3],l=e[i][n][4];r.name=i,r.tag=l,o&&r.position.set(o[0],o[1],o[2]),a&&r.rotation.set(a[0],a[1],a[2]),s&&r.scale.set(s[0],s[1],s[2]),r.updateMatrix();var c=r.geometry.clone();c.applyMatrix4(r.matrix),r.geometry=c,r.renderOrder=1/0,r.position.set(0,0,0),r.rotation.set(0,0,0),r.scale.set(1,1,1),t.add(r)}return t};new Ke(0,0,0);var O=new bt,N=new Ke(0,1,0),P=new Ke(0,0,0),G=new yt,K=new Ge,V=new Ge,Y=new Ge,H=new Ke(1,0,0),j=new Ke(0,1,0),W=new Ke(0,0,1);return e.gizmo={},e.picker={},e.helper={},e.add(e.gizmo.translate=L(S)),e.add(e.gizmo.rotate=L(D)),e.add(e.gizmo.scale=L(U)),e.add(e.picker.translate=L(b)),e.add(e.picker.rotate=L(R)),e.add(e.picker.scale=L(F)),e.add(e.helper.translate=L(k)),e.add(e.helper.rotate=L(T)),e.add(e.helper.scale=L(Q)),e.picker.translate.visible=!1,e.picker.rotate.visible=!1,e.picker.scale.visible=!1,e.updateMatrixWorld=function(){var e=this.space;"scale"===this.mode&&(e="local");var t="local"===e?this.worldQuaternion:Y;this.gizmo.translate.visible="translate"===this.mode,this.gizmo.rotate.visible="rotate"===this.mode,this.gizmo.scale.visible="scale"===this.mode,this.helper.translate.visible="translate"===this.mode,this.helper.rotate.visible="rotate"===this.mode,this.helper.scale.visible="scale"===this.mode;var i=[];i=(i=(i=i.concat(this.picker[this.mode].children)).concat(this.gizmo[this.mode].children)).concat(this.helper[this.mode].children);for(var n=this.boundingBox?this.boundingBox.makeEmpty():new He,r=0;i.length>r;r++){var o=i[r];o.visible=!0,o.rotation.set(0,0,0),o.position.copy(this.worldPosition);var a=this.worldPosition.distanceTo(this.cameraPosition);if(o.scale.set(1,1,1).multiplyScalar(a*this.size/7),"helper"!==o.tag){if(o.quaternion.copy(t),"translate"===this.mode||"scale"===this.mode){var s=.99;"X"!==o.name&&"XYZX"!==o.name||Math.abs(N.copy(H).applyQuaternion(t).dot(this.eye))>s&&(o.scale.set(1e-10,1e-10,1e-10),o.visible=!1),"Y"!==o.name&&"XYZY"!==o.name||Math.abs(N.copy(j).applyQuaternion(t).dot(this.eye))>s&&(o.scale.set(1e-10,1e-10,1e-10),o.visible=!1),"Z"!==o.name&&"XYZZ"!==o.name||Math.abs(N.copy(W).applyQuaternion(t).dot(this.eye))>s&&(o.scale.set(1e-10,1e-10,1e-10),o.visible=!1),"XY"===o.name&&.2>Math.abs(N.copy(W).applyQuaternion(t).dot(this.eye))&&(o.scale.set(1e-10,1e-10,1e-10),o.visible=!1),"YZ"===o.name&&.2>Math.abs(N.copy(H).applyQuaternion(t).dot(this.eye))&&(o.scale.set(1e-10,1e-10,1e-10),o.visible=!1),"XZ"===o.name&&.2>Math.abs(N.copy(j).applyQuaternion(t).dot(this.eye))&&(o.scale.set(1e-10,1e-10,1e-10),o.visible=!1),-1!==o.name.search("X")&&(0>N.copy(H).applyQuaternion(t).dot(this.eye)?"fwd"===o.tag?o.visible=!1:o.scale.x*=-1:"bwd"===o.tag&&(o.visible=!1)),-1!==o.name.search("Y")&&(0>N.copy(j).applyQuaternion(t).dot(this.eye)?"fwd"===o.tag?o.visible=!1:o.scale.y*=-1:"bwd"===o.tag&&(o.visible=!1)),-1!==o.name.search("Z")&&(0>N.copy(W).applyQuaternion(t).dot(this.eye)?"fwd"===o.tag?o.visible=!1:o.scale.z*=-1:"bwd"===o.tag&&(o.visible=!1))}else"rotate"===this.mode&&(V.copy(t),N.copy(this.eye).applyQuaternion(K.copy(t).invert()),-1!==o.name.search("E")&&o.quaternion.setFromRotationMatrix(G.lookAt(this.eye,P,j)),"X"===o.name&&(K.setFromAxisAngle(H,Math.atan2(-N.y,N.z)),K.multiplyQuaternions(V,K),o.quaternion.copy(K)),"Y"===o.name&&(K.setFromAxisAngle(j,Math.atan2(N.x,N.z)),K.multiplyQuaternions(V,K),o.quaternion.copy(K)),"Z"===o.name&&(K.setFromAxisAngle(W,Math.atan2(N.y,N.x)),K.multiplyQuaternions(V,K),o.quaternion.copy(K)));o.visible=o.visible&&(-1===o.name.indexOf("X")||this.showX),o.visible=o.visible&&(-1===o.name.indexOf("Y")||this.showY),o.visible=o.visible&&(-1===o.name.indexOf("Z")||this.showZ),o.visible=o.visible&&(-1===o.name.indexOf("E")||this.showX&&this.showY&&this.showZ),o.material._opacity=o.material._opacity||o.material.opacity,o.material._color=o.material._color||o.material.color.clone(),o.material.color.copy(o.material._color),o.material.opacity=o.material._opacity,this.enabled?this.axis&&(o.name===this.axis||this.axis.split("").some((function(e){return o.name===e}))?(o.material.opacity=1,o.material.color.lerp(new pi(1,1,1),.5)):(o.material.opacity*=.25,o.material.color.lerp(new pi(1,1,1),.5))):(o.material.opacity*=.5,o.material.color.lerp(new pi(1,1,1),.5)),n.expandByObject(o)}else if(o.visible=!1,"AXIS"===o.name)o.position.copy(this.worldPositionStart),o.visible=!!this.axis,"X"===this.axis&&(K.setFromEuler(O.set(0,0,0)),o.quaternion.copy(t).multiply(K),Math.abs(N.copy(H).applyQuaternion(t).dot(this.eye))>.9&&(o.visible=!1)),"Y"===this.axis&&(K.setFromEuler(O.set(0,0,Math.PI/2)),o.quaternion.copy(t).multiply(K),Math.abs(N.copy(j).applyQuaternion(t).dot(this.eye))>.9&&(o.visible=!1)),"Z"===this.axis&&(K.setFromEuler(O.set(0,Math.PI/2,0)),o.quaternion.copy(t).multiply(K),Math.abs(N.copy(W).applyQuaternion(t).dot(this.eye))>.9&&(o.visible=!1)),"XYZE"===this.axis&&(K.setFromEuler(O.set(0,Math.PI/2,0)),N.copy(this.rotationAxis),o.quaternion.setFromRotationMatrix(G.lookAt(P,N,j)),o.quaternion.multiply(K),o.visible=this.dragging),"E"===this.axis&&(o.visible=!1);else if("START"===o.name)o.position.copy(this.worldPositionStart),o.visible=this.dragging;else if("END"===o.name)o.position.copy(this.worldPosition),o.visible=this.dragging;else if("DELTA"===o.name){o.position.set(0,0,0),o.scale.set(1,1,1);var l=o.geometry.getAttribute("position");l.setXYZ(0,this.worldPositionStart.x,this.worldPositionStart.y,this.worldPositionStart.z),l.setXYZ(1,this.worldPosition.x,this.worldPosition.y,this.worldPosition.z),l.needsUpdate=!0,o.visible=this.dragging}else o.quaternion.copy(t),o.position.copy(this.dragging?this.worldPositionStart:this.worldPosition),this.axis&&(o.visible=-1!==this.axis.search(o.name))}this.boundingBox=n,Yt.prototype.updateMatrixWorld.call(this)},e.getBoundingBox=function(){return this.boundingBox||this.updateMatrixWorld(),this.boundingBox},e}return i}(Yt),_g=function(e){lu(i,e);var t=pu(i);function i(){var e;ru(this,i),(e=t.call(this,new In(4,4,2,2),new gi({visible:!1,wireframe:!0,side:2,transparent:!0,opacity:.1}))).type="TransformControlsPlane",e.isTransformControlsPlane=!0;var n=new Ke(1,0,0),r=new Ke(0,1,0),o=new Ke(0,0,1),a=new Ke,s=new Ke,l=new Ke,c=new yt,h=new Ge;return e.updateMatrixWorld=function(){var e=this.space;switch(this.position.copy(this.worldPosition),"scale"===this.mode&&(e="local"),n.set(1,0,0).applyQuaternion("local"===e?this.worldQuaternion:h),r.set(0,1,0).applyQuaternion("local"===e?this.worldQuaternion:h),o.set(0,0,1).applyQuaternion("local"===e?this.worldQuaternion:h),l.copy(r),this.mode){case"translate":case"scale":switch(this.axis){case"X":l.copy(this.eye).cross(n),s.copy(n).cross(l);break;case"Y":l.copy(this.eye).cross(r),s.copy(r).cross(l);break;case"Z":l.copy(this.eye).cross(o),s.copy(o).cross(l);break;case"XY":s.copy(o);break;case"YZ":s.copy(n);break;case"XZ":l.copy(o),s.copy(r);break;case"XYZ":case"E":s.set(0,0,0)}break;case"rotate":default:s.set(0,0,0)}0===s.length()?this.quaternion.copy(this.cameraQuaternion):(c.lookAt(a.set(0,0,0),s,l),this.quaternion.setFromRotationMatrix(c));var t=this.worldPosition.distanceTo(this.cameraPosition);this.scale.set(1,1,1).multiplyScalar(t*this.size/7),Yt.prototype.updateMatrixWorld.call(this)},e}return i}(nn),$g=[new Jt],ef=new Ke,tf=function(e){lu(i,e);var t=pu(i);function i(e){var n;return ru(this,i),(n=t.call(this,Yd.CLIP_FILL)).viewer=e,n.scene=e.getScene(),n.enablePick=!1,n.rotX=!0,n.onClipPlane=!1,n.cameraControl=e.cameraControl,n.startPt=new ke,n.endPt=new ke,n.frustum=new yn,n.modelManager=n.cameraControl.viewer.modelManager,n.planeDistance=0,n.offsetSpeed=.02,du(n),n._planIntersect=new Ke,n.fillClipPlane=n.scene.getFillClipPlane(),n.fillClipPlane.updateClippingParams=function(t){if(0===t.iClipPlane.value)e.getRenderer().localClippingEnabled=!1,e.getRenderer().clippingPlanes=Object.freeze([]);else{var i=t.vClipPlane.value[0],n=$g[0];n.setComponents(-i.x,-i.y,-i.z,-i.w),n.normalize(),e.getRenderer().clippingPlanes=$g,this.renderClipPlane=new Jt,this.renderClipPlane.setComponents(i.x,i.y,i.z,i.w),this.renderClipPlane.normalize(),this.calculateFillClipBoundingBox(n.coplanarPoint(ef)),e.updateShadowMap()}},n.fillClipPlane.calculateClippingIds=function(){e.modelManager.calculateClippingIds()},n.fillClipPlane.init(),n}return au(i,[{key:"toggle",value:function(e,t){this.fillClipPlane.enable(e,t),this.fillClipPlane.update(),this.viewer.updateShadowMap()}},{key:"visible",value:function(e){this.fillClipPlane.visible=e,this.fillClipPlane.update()}},{key:"rotatable",value:function(e){this.fillClipPlane.rotatable=e,this.fillClipPlane.update()}},{key:"hit",value:function(){return this.fillClipPlane.hit}},{key:"pointToScreen",value:function(e){var t=this.cameraControl.camera,i=new yt;i.multiplyMatrices(t.projectionMatrix,t.matrixWorldInverse);var n=new Le(e.x,e.y,e.z,1);n.applyMatrix4(i);var r=new ke;r.x=(n.x/n.w+1)/2,r.y=1-(n.y/n.w+1)/2;var o=this.cameraControl.getContainerDimensions();return r.x=r.x*o.width+o.left,r.y=r.y*o.height+o.top,r}},{key:"getPlaneDistanceInScreen",value:function(){if(null===this.selectIndex)return null;if(2>this.selectIndex){var e=this.fillClipPlane.clipPlanes.center.clone(),t=this.fillClipPlane.clipPlanes.center.clone();e.x-=this.fillClipPlane.clipPlanes.cubeSize.x,t.x+=this.fillClipPlane.clipPlanes.cubeSize.x;var i=this.pointToScreen(e),n=this.pointToScreen(t);return i.x-n.x}var r=this.fillClipPlane.clipPlanes.center.clone(),o=this.fillClipPlane.clipPlanes.center.clone();o.y-=this.fillClipPlane.clipPlanes.cubeSize.y,r.y+=this.fillClipPlane.clipPlanes.cubeSize.y;var a=this.pointToScreen(o),s=this.pointToScreen(r);return a.y-s.y}},{key:"getPickPoint",value:function(e,t){var i=this.cameraControl.camera,n=this.cameraControl.getContainerDimensions(),r=(e-n.left)/n.width*2-1,o=(n.height-(t-n.top))/n.height*2-1,a=new Xp;return a.setFromCamera(new ke(r,o),i),a.ray.intersectPlane(this.plane,this._planIntersect)}},{key:"_isVisible",value:function(){return this.fillClipPlane.visible}},{key:"isRotate",value:function(){return this.fillClipPlane.rotatable}},{key:"offset",value:function(e){this.fillClipPlane.offset(e)}},{key:"setOffset",value:function(e){this.fillClipPlane.setOffset(e)}},{key:"rotate",value:function(e,t){this.rotX?this.fillClipPlane.rotX(t/180*Math.PI*.1):this.fillClipPlane.rotY(e/180*Math.PI*.1)}},{key:"rotateAngleOffset",value:function(e,t){this.fillClipPlane.rotateAngleOffset(e,t)}},{key:"setRotateAngle",value:function(e,t){this.fillClipPlane.setRotateAngle(e,t)}},{key:"getRotateAngle",value:function(){return this.fillClipPlane.getRotateAngle()}},{key:"changeNormal",value:function(e){this.fillClipPlane.changeNormal(e)}},{key:"update",value:function(e){this.fillClipPlane.update(e)}},{key:"cancelHighLight",value:function(){this.fillClipPlane.cancelHighLight()}},{key:"highLight",value:function(){this.fillClipPlane.highLight()}},{key:"store",value:function(){return this.fillClipPlane.store()}},{key:"restore",value:function(e){this.fillClipPlane.restore(e)}},{key:"setProcess",value:function(e){isNaN(e)?Bu.error("非法参数"):this.fillClipPlane.setProcess(e)}},{key:"getProcess",value:function(){return this.fillClipPlane.getProcess()}},{key:"destroy",value:function(){this.cameraControl=null,this.normal=null,this.plane=null,this.pickHelper=null,this.scene=null,this.viewer=null}},{key:"onExit",value:function(){this.toggle(!1,!1)}},{key:"processMouseDown",value:function(e){if(this.startPt.set(e.clientX,e.clientY),!this.enablePick&&e.button===n.LEFT){var t=this.cameraControl.getRaycaster(e.clientX,e.clientY);if(this.scene.getFillClipPlane().hitTest(t),this.hit())return this.highLight(),this.cameraControl.needUpdateRenderList(!0),this.cameraControl.update(!0),!0}return Yg.prototype.processMouseDown(this,e)}},{key:"processMouseUp",value:function(e){this.planeDistance=0;var t=!1;if(this.enablePick&&e.button===n.LEFT)if(this.startPt.x==e.clientX&&this.startPt.y==e.clientY)this.pickHelper.click(e);else if(e.shiftKey||e.ctrlKey||e.altKey){this.endPt.set(e.clientX,e.clientY);var i=Td.Clear;e.ctrlKey?i=Td.Add:e.altKey&&(i=Td.Remove);var r=this;this.scene.pickByRect(this.frustum,i,(function(){r.pickHelper.notifySelectionChanged(null,0,e)})),this.cameraControl.updateView(!0),t=!0}var o=this.cameraControl.getRaycaster(e.clientX,e.clientY);return this.scene.getFillClipPlane().hitTest(o),this.hit()?(this.highLight(),this.cameraControl.needUpdateRenderList(!0),this.cameraControl.update(!0),this.onClipPlane||(this.onClipPlane=!0,this.modelManager.dispatchEvent({type:Fd.ON_CLIP_HOVER,onClipPlane:!0,event:e})),t=!0):(this.cancelHighLight(),this.cameraControl.needUpdateRenderList(!0),this.cameraControl.update(!0),this.onClipPlane&&(this.onClipPlane=!1,this.modelManager.dispatchEvent({type:Fd.ON_CLIP_HOVER,onClipPlane:!1,event:e}))),this.modelManager.dispatchEvent({type:Fd.ON_TOOL_END}),t}},{key:"processMouseMove",value:function(e){return this.modelManager.dispatchEvent({type:Fd.ON_CLIP_MOUSE_MOVE,event:e}),Yg.prototype.processMouseMove(this,e)}},{key:"processTouchstart",value:function(e){if(this.startPt.set(e.touches[0].clientX,e.touches[0].clientY),!this.enablePick){var t=this.cameraControl.getRaycaster(e.touches[0].clientX,e.touches[0].clientY);this.scene.getFillClipPlane().hitTest(t)}return this.hit()?(this.highLight(),this.cameraControl.needUpdateRenderList(!0),this.cameraControl.update(!0),!0):Yg.prototype.processTouchstart(this,e)}},{key:"processTouchmove",value:function(e){if(this.hit()){if(this.isRotate())this.rotate(e.touches[0].clientX-this.startPt.x,e.touches[0].clientY-this.startPt.y),this.startPt.set(e.touches[0].clientX,e.touches[0].clientY);else{this.offset(Number(e.touches[0].clientX-this.startPt.x)),this.startPt.set(e.touches[0].clientX,e.touches[0].clientY)}return this.cameraControl.update(!0),!0}return Yg.prototype.processTouchmove(this,e)}},{key:"processTouchend",value:function(e){return this.enablePick&&(this.onUpdateUI({visible:!1}),this.startPt.x===e.touches[0].clientX&&this.startPt.y===e.touches[0].clientY&&this.pickHelper.click(e)),this.cameraControl.needUpdateRenderList(!0),this.cancelHighLight(),this.cameraControl.update(!0),Yg.prototype.processTouchmove(this,e)}},{key:"processHover",value:function(e){if(!this.enablePick){var t=!1,i=this.cameraControl.getRaycaster(e.clientX,e.clientY);return this.scene.getFillClipPlane().hitTest(i),this.hit()?(this.onClipPlane||(this.highLight(),this.cameraControl.needUpdateRenderList(!0),this.cameraControl.update(!0),this.onClipPlane=!0,this.modelManager.dispatchEvent({type:Fd.ON_CLIP_HOVER,onClipPlane:!0,event:e})),t=!0):this.onClipPlane?(this.cancelHighLight(),this.cameraControl.needUpdateRenderList(!0),this.cameraControl.update(!0),this.onClipPlane=!1,this.modelManager.dispatchEvent({type:Fd.ON_CLIP_HOVER,onClipPlane:!1,event:e})):this.modelManager.dispatchEvent({type:Fd.ON_CLIP_HOVER,onClipPlane:!1,event:e}),t}return Yg.prototype.processHover(this,e)}}]),i}(Yg),nf=function(){this.vertexIndex=new Array(2),this.faceIndex=new Array(2)},rf=function(e,t){var i=e.length/3,n=new Array(i),r=new Array(i);function o(e,t){var i=n[e],r=n[t];return i.x!==r.x?i.x-r.x:i.y!==r.y?i.y-r.y:i.z-r.z}for(var a=0;i>a;a+=1)n[a]=new Ke(e[3*a],e[3*a+1],e[3*a+2]),r[a]=a;r.sort((function(e,t){var i=o(e,t);return 0===i?e-t:i}));var s={},l=r[0];for(a=1;i>a;a+=1)0===o(l,r[a])?s[r[a]]=l:l=r[a];var c=new Array(t.length);for(a=0;t.length>a;a+=1)c[a]=s.hasOwnProperty(t[a])?s[t[a]]:t[a];return c},of=function(e,t){function i(e,t){return e-t}var n=rf(e,t);n.sort(i);var r=[],o=n[0];r.push(o);for(var a=1;n.length>a;a+=1)n[a]!==o&&r.push(o=n[a]);return r.sort(i)},af=function(e,t,i){i=void 0===i?Math.PI/4:i;var n=rf(e,t),r=n.length,o=e.length/3,a=new Array(o+r),s=o,l=n.length/3;parseInt(l,0)!==l&&(Bu.error("triangleCount 不是整数"),l=parseInt(l,0));for(var c=0;o>c;c+=1)a[c]=-1;var h=new Array(r),d=0;for(c=0;l>c;c+=1)for(var u=n[3*c+2],p=0;3>p;p+=1){var g=!1,f=n[3*c+p];if(u>f){g=!0;var m=u;u=f,f=m}var A=new nf;A.vertexIndex[0]=u,A.vertexIndex[1]=f,A.faceIndex[0]=c,A.faceIndex[1]=c;var y=a[u];if(-1===y)a[u]=d,h[d]=A,a[s+d]=-1,d+=1;else for(;;){if((I=h[y]).vertexIndex[1]===f){I.faceIndex[1]=c;break}var v=a[s+y];if(-1===v){a[s+y]=d,h[d]=A,a[s+d]=-1,d+=1;break}y=v}g||(u=f)}var C=[];for(c=0;d>c;c+=1){var I;if((I=h[c]).faceIndex[0]===I.faceIndex[1])C.push(I.vertexIndex[0]),C.push(I.vertexIndex[1]);else{var x=I.faceIndex[0],w=n[3*x],M=n[3*x+1],E=n[3*x+2],B=new Ke(e[3*w],e[3*w+1],e[3*w+2]),S=new Ke(e[3*M],e[3*M+1],e[3*M+2]),b=new Ke(e[3*E],e[3*E+1],e[3*E+2]),k=B.sub(S),D=S.sub(b),T=k.cross(D);T.normalize();var R=I.faceIndex[1];M=n[3*R+1],E=n[3*R+2],B=new Ke(e[3*(w=n[3*R])],e[3*w+1],e[3*w+2]),S=new Ke(e[3*M],e[3*M+1],e[3*M+2]),b=new Ke(e[3*E],e[3*E+1],e[3*E+2]),k=B.sub(S),D=S.sub(b);var U=k.cross(D);U.normalize(),Math.abs(T.dot(U))<i&&(C.push(I.vertexIndex[0]),C.push(I.vertexIndex[1]))}}return C},sf=function(e,t,i,n,r){for(var o=i.length/3,a=[],s=0;o>s;s+=1){var l=i[3*s],c=new Ke(t[3*l],t[3*l+1],t[3*l+2]),h=c.dot(r);if(.001>Math.abs(h-1)){var d=-new Ke(e[3*l],e[3*l+1],e[3*l+2]).dot(c),u=Math.abs(n.dot(c)+d);3>Math.abs(u)&&a.push(i[3*s],i[3*s+1],i[3*s+2])}}return a},lf=new yt,cf=new Ke,hf=new Ke,df=new Ke,uf=new Ke,pf=function(){function e(t){ru(this,e),this.cameraControl=t,this.scene=t.scene,this.timerId=null,this.lastIntersected=null,this._pickObjectByHover=!1}return au(e,[{key:"destroy",value:function(){this.cameraControl=null,this.scene=null,this.lastIntersected=null,this.timerId&&(clearTimeout(this.timerId),this.timerId=null)}},{key:"click",value:function(e,t){var i=this;function r(){t&&!1===t.pickable&&(t=null),i.handleMousePick(e,!1,t)}e.button!==n.RIGHT?(this.timerId&&clearTimeout(this.timerId),this.timerId=setTimeout(r,500)):r()}},{key:"doubleClick",value:function(e){e.preventDefault(),this.timerId&&clearTimeout(this.timerId),this.handleMousePick(e,!0,null)}},{key:"handleMousePick",value:function(e,t,i){var r=this,o=this.cameraControl,a=o.viewer.modelManager.sceneState,s=new ke(e.clientX,e.clientY),l=o.screenToCanvas(e.clientX,e.clientY),c=o.viewer.modelManager;function h(i,n){var r=null;if(i&&i.objectType==Rd.Room){var o=i.face.contourIndex,a=i.object.geometry.contour;r=o?{startPoint:a[o.st],endPoint:a[o.ed]}:null}var s=function(e){return e?{selectedObjectId:wp.isDefined(i.userId)?i.userId:null,objectType:wp.isDefined(i.objectType)?i.objectType:null,selectable:wp.isDefined(i.selectable)?n:null,modelKey:wp.isDefined(i.modelKey)?i.modelKey:null,fileId:wp.isDefined(i.fileId)?i.fileId:null,unit:wp.isDefined(i.unit)?i.unit:null,worldPosition:wp.isDefined(i.worldPosition)?i.worldPosition:null,worldBoundingBox:wp.isDefined(i.worldBoundingBox)?i.worldBoundingBox:null,point:wp.isDefined(i.point)?i.point:null,index:wp.isDefined(i.index)?i.index:null,innnerDebugging:wp.isDefined(i.innnerDebugging)?i.innnerDebugging:null,object:wp.isDefined(i.object)?i.object:null,normal:wp.isDefined(i.face)&&wp.isDefined(i.face.normal)?i.face.normal:null,boundaryPoints:wp.isDefined(i.boundaryPoints)?r:null}:null};c.dispatchEvent({type:i&&i.objectType===Rd.Marker3d?Fd.ON_CLICK_MARKER3D_PICK:Fd.ON_CLICK_PICK,event:e,doubleClick:t,canvasPos:{x:l.x,y:l.y},intersectInfo:s(i),intersectInfoWithoutMap:i&&s(i.intersectWithoutMap)})}var d=null;if(e.button!==n.RIGHT){if(i)i.pickable&&(d=i.intersect);else{var u=o.getIntersectContext(s);d=o.intersector.pick(u,null)}if(d){var p=d.userId;if(og.isMobileDevice()&&(o.pivot=d.point),r.scene.intersectToWorld(d,o.viewer),d.intersectWithoutMap&&r.scene.intersectToWorld(d.intersectWithoutMap,o.viewer),d.innnerDebugging=e.altKey,d.cx=s.x,d.cy=s.y,r.lastPickedUserId=p,d.face&&d.face.normal){var g=d.face.normal;for(var f in g)g[f]=g[f]==-g[f]?Math.abs(g[f]):g[f]}if(e.button!==n.RIGHT)if(t)xd.EnableZoomToComponentByDClick?(a.setSelection([p],d.modelKey),o.fitAndRotateBySelection(),h(d,!0)):(a.setSelection([p],d.modelKey),h(d,!0),o.updateView(!0));else{var m=a.getSelection();if(!!xd.MultipleSelectComponents&&e.ctrlKey){var A=m.indexOf(p);-1===A?a.addSelection([p]):(m.splice(A,1),a.setSelection(m))}else-1===m.indexOf(p)?a.setSelection([p]):a.clearSelection();r.setSelectedIdsForOutline(a.getSelection()),h(d,!0),o.updateView(!0)}else h(d,!1)}else{var y=a.getSelection();if(e.ctrlKey)return;if(e.button!=n.RIGHT&&y.length>0&&(a.clearSelection(),o.updateView(!0)),i&&!i.pickable)(d=i.intersect).cx=s.x,d.cy=s.y,h(d,!1);else{var v=o.getIntersectContext(s);o.viewer.ground?(v.viewer=o.viewer,h(d=o.intersector.pickGround(v))):h(null)}}}else h(d,!1)}},{key:"handleMouseMeasure",value:function(e,t,i,n){var r=null,o=this.cameraControl,a=o.scene,s=n||Fd.ON_MEASURE_PICK,l=this.pickToPoint({x:e.clientX,y:e.clientY},5);function c(i,n,a,l,c,h,d,u){var p=o.viewer.modelManager;if(null!=i){var g=o.scene.drawingToWorld(i);i.copy(g)}if(null!=a){var f=o.scene.drawingToWorld(a[0]),m=o.scene.drawingToWorld(a[1]);a[0].copy(f),a[1].copy(m)}(l||t||a||i)&&p.dispatchEvent(r={type:s,event:e,pick:t,pickPoint:i,isAbsorbPoint:n,pickLine:a,pickPlane:l,normal:c,userId:h,measureUnit:u,modelKey:d})}return null!=l?(t&&i.copy(l.pickPoint),c(l.pickPoint,l.isAbsorbPoint,l.pickLine,l.pickPlane,l.face.normal,l.userId,l.modelKey,l.measureUnit)):(a.hasGroup(Vp.MEASUREPICKPLANE)&&a.removeGroupByName(Vp.MEASUREPICKPLANE),c(null,!1,null,!1)),r}},{key:"handleMouseMovePick",value:function(e){if(xd.MouseMovePick&&this._canPick()){var t=this.cameraControl,i=t.screenToCanvas(e.clientX,e.clientY),n=this,r=new ke(e.clientX,e.clientY),o=t.getIntersectContext(r);if(o.viewer=t.viewer,this._pickObjectByHover)if(this.lastIntersected)a(this.lastIntersected,!0,!1);else a(t.intersector.pickGround(o),!1,!0);else t.intersector.pick(o,(function(e){e?(n.scene.intersectToWorld(e,t.viewer),a(e,!0,!1)):a(t.intersector.pickGround(o),!1,!0)}));this._pickObjectByHover=!1}function a(n,r,o){if(null!=n){var a=t.viewer.modelManager,s={type:Fd.ON_MOUSE_MOVE_PICK,event:e,selectable:r,canvasPos:{x:i.x,y:i.y},intersectInfo:{}};s.intersectInfo.pickFromReferencePlane=o,void 0!==n.userId&&(s.intersectInfo.selectedObjectId=n.userId),void 0!==n.objectType&&(s.intersectInfo.objectType=n.objectType),void 0!==n.modelKey&&(s.intersectInfo.modelKey=n.modelKey),void 0!==n.worldPosition&&(s.intersectInfo.worldPosition=n.worldPosition),void 0!==n.worldBoundingBox&&(s.intersectInfo.worldBoundingBox=n.worldBoundingBox),void 0!==n.point&&(s.intersectInfo.point=n.point),void 0!==n.innnerDebugging&&(s.intersectInfo.innnerDebugging=n.innnerDebugging),s.intersectInfo.fileId=wp.isDefined(n.fileId)?n.fileId:null,s.intersectInfo.unit=wp.isDefined(n.unit)?n.unit:null,a.dispatchEvent(s)}}}},{key:"handleMouseHover",value:function(e){var t=this.cameraControl,i=t.viewer.modelManager.sceneState,n=this;if(function(){if(!1===n.scene.hasGroup(Vp.AXISGRIDMANAGER))return!1;var e=0,t=n.scene.axisGridEnableHover;if(t){for(var i in n.scene.axisGridManagerMap){e+=AxisGridManager.getInstance(n.scene,i).getElements().length}0===e&&(t=!1)}return t}()){var r=this.scene.getMatrixGlobal(),o=new ke(e.clientX,e.clientY),a=t.getRaycaster(o.x,o.y),s=[];for(var l in this.scene.axisGridManagerMap){var c=AxisGridManager.getInstance(this.scene,l),h=c.getIntersectPoints(a,r);c.snapOnFloors(h).forEach((function(e){e.modelKey=l,s.push(e)}))}t.viewer.modelManager.dispatchEvent({type:Fd.ON_AXIS_GRID_HOVER,snaps:s})}if(xd.Hover||(d=!1,n.scene.children[0].children.some((function(e){if(e.name&&e.name.indexOf(Vp.MARKER3D)>=0&&e.children.length>0)return d=!0})),d)){var d,u=t.screenToCanvas(e.clientX,e.clientY),p=new ke(e.clientX,e.clientY),g=t.getIntersectContext(p);t.intersector.pick(g,(function(e){function r(e){switch(e.objectType){case Rd.Marker3d:e.object.setAttributeSize(e.index,e.currentSize);break;default:i.clearHover()}}if(n._pickObjectByHover=!0,e){var o=xd.Hover||e.hoverEnabled;n.lastIntersected&&(n.lastIntersected.userId!=e.userId&&r(n.lastIntersected),n.lastIntersected.hoverEnabled&&f(null)),o?(n.lastIntersected&&n.lastIntersected.userId==e.userId||(!function(t){switch(t.objectType){case Rd.Marker3d:var n=t.object;t.currentSize=n.getAttributeSize(t.index),n.initSize=n.initSize||t.currentSize,n.getAttributeHoverAnimation(t.index)&&t.currentSize===n.initSize&&n.setAttributeSize(e.index,Math.floor(1.5*t.currentSize));break;default:i.setHoverId(t.userId)}}(e),n.lastIntersected=e),f(e,!0)):n.lastIntersected=e,t.updateHighlight()}else n.lastIntersected&&(r(n.lastIntersected),n.lastIntersected=null,f(null),t.updateHighlight())}))}function f(i,r){var o=t.viewer.modelManager;null!==i&&n.scene.intersectToWorld(i,t.viewer),o.dispatchEvent({type:Fd.ON_HOVER_PICK,event:e,canvasPos:{x:u.x,y:u.y},intersectInfo:i?{selectedObjectId:i.userId,objectType:i.objectType,selectable:r,modelKey:i.modelKey,fileId:i.fileId,unit:i.unit,worldPosition:i.worldPosition,worldBoundingBox:i.worldBoundingBox,point:i.point,innnerDebugging:i.innnerDebugging,object:i.object}:null})}}},{key:"_canPick",value:function(){return!!this.cameraControl.viewer.modelManager.hasModelDataReady()}},{key:"setSelectedIdsForOutline",value:function(e){this.cameraControl.viewer.rendererManager.composer&&this.cameraControl.viewer.rendererManager.composer.setSelectedIds(e)}},{key:"pickToPoint",value:function(e,t){wp.defaultValue(t,5);var i=t*t,n=this.cameraControl,r=n.scene,o=new ke(e.x,e.y),a=n.getIntersectContext(o),s=n.intersector.pick(a);if(s){var l="",c=s.modelKey,h=null;c&&(h=n.viewer.modelManager.getModel(c))&&h.originalLengthUnit&&(l=h.originalLengthUnit);var d=s.point,u=s.object.geometry,p=(new yt).extractRotation(s.object.matrix.clone()),g=s.object.matrixWorld.clone(),f=n.camera.projScreenMatrix,m=a.mouse,A=a.viewportSize,y=null;if(null!=s.indexInfo&&(y=s.indexInfo),!u.attributes&&!u._bufferGeometry)return null;s.unit=l;var v=u.attributes?u:u._bufferGeometry;if("MeshLineGeometry"===v.type){var C={};return lf.copy(p).invert(),(H=new Ke(d.x,d.y,d.z)).applyMatrix4(lf),C.pickPoint=H,C.pickLine=s.object,C.pickPlane=null,C.type="Line",C.face=s.face,C.userId=s.userId,C.modelKey=s.modelKey,C.fileId=s.fileId,C.unit=s.unit,C}var I,x=d.clone(),w=!1,M=null,E=!1,B=[],S=0,b=0;if(!v.index)return null;if(s.indexInfo&&s.indexInfo.isMixNode)I=v.attributes.position,B=v.index.array,S=y.indexStart,b=y.indexStart+y.indexCount,g.multiply(y.matrix);else{if(!v.index||void 0===v.attributes.normal)return null;I=v.attributes.position,y?(B=v.index.array,S=y.indexStart,b=y.indexStart+y.indexCount):h&&h.merged&&g.multiply(s.matrix)}var k=1/0,D=(e=new Ke,[]),T=new Ke,R=new Ke;wp.getMin(B.slice(S,b));var U=T.fromBufferAttribute(I,s.face.a);U.applyMatrix4(g);var F=R.copy(U);F.applyMatrix4(f);var Q=.5*(F.x-m.x)*A.width,L=.5*(F.y-m.y)*A.height,O=Q*Q+L*L;if(k>O&&(k=O,e.copy(U)),(U=T.fromBufferAttribute(I,s.face.b)).applyMatrix4(g),(F=R.copy(U)).applyMatrix4(f),k>(O=(Q=.5*(F.x-m.x)*A.width)*Q+(L=.5*(F.y-m.y)*A.height)*L)&&(k=O,e.copy(U)),(U=T.fromBufferAttribute(I,s.face.c)).applyMatrix4(g),(F=R.copy(U)).applyMatrix4(f),k>(O=(Q=.5*(F.x-m.x)*A.width)*Q+(L=.5*(F.y-m.y)*A.height)*L)&&(k=O,e.copy(U)),i>k)r.hasGroup(Vp.MEASUREPICKPLANE)&&r.removeGroupByName(Vp.MEASUREPICKPLANE),x=e.clone(),w=!0;else{k=1/0;var N=new Ke,P=new Ke;e=new Ke;var G,K=this._getEegeData(s);if(!K)return Bu.error("no edge data"),null;D=K.positionsArray,G=K.edgeIndex;for(var V=0;G.length>V;V+=2){df.set(D[3*G[V]],D[3*G[V]+1],D[3*G[V]+2]),df.applyMatrix4(g),uf.set(D[3*G[V+1]],D[3*G[V+1]+1],D[3*G[V+1]+2]),uf.applyMatrix4(g);var Y=this._pointToLine(df,uf,d);(F=Y.clone()).applyMatrix4(f),k>(O=(Q=.5*(F.x-m.x)*A.width)*Q+(L=.5*(F.y-m.y)*A.height)*L)&&(k=O,N.copy(df),P.copy(uf),e.copy(Y))}if(D=null,i>k)r.hasGroup(Vp.MEASUREPICKPLANE)&&r.removeGroupByName(Vp.MEASUREPICKPLANE),(M=[]).push(N),M.push(P),x=e.clone();else{if(xd.MeasureHighlightPlane){var H;B=v.index.array,lf.copy(p).invert(),(H=new Ke(d.x,d.y,d.z)).applyMatrix4(lf);var j=sf(I,normals,B,H,s.face.normal),W=new Ni;W.setIndex(j),W.setAttribute("position",v.attributes.position,3),W.setAttribute("normal",v.attributes.normal,3);var J=af(I,j),z=new Ni;z.setIndex(J),z.setAttribute("position",v.attributes.position,3),r.hasGroup(Vp.MEASUREPICKPLANE)&&r.removeGroupByName(Vp.MEASUREPICKPLANE);var q=r.getOrCreateGroup(Vp.MEASUREPICKPLANE,{priority:1,globalSpace:!0}),Z=new nn(W,new gi({color:1170103,opacity:.1,transparent:!0}));Z.applyMatrix4(s.object.matrix),q.add(Z);var X=new La(z,new Sa({color:1170103}));X.applyMatrix4(s.object.matrix),q.add(X),q.updateMatrixWorld(!0),n.updateHighlight()}E=!0}}var _=null;return E?_="Plane":M?_="Line":x&&(_="Point"),(C={}).pickPoint=x,C.isAbsorbPoint=w,C.measureUnit=l,C.pickLine=M,C.pickPlane=E,C.type=_,C.face=s.face,C.userId=s.userId,C.modelKey=s.modelKey,C.fileId=s.fileId,C.unit=s.unit,C}return null}},{key:"handleTabs",value:function(e){null!=e&&null!=e.userId&&this.cameraControl.viewer.modelManager.sceneState.setSelection([e.userId],e.modelKey)}},{key:"pickAllObjectsByPosition",value:function(e){var t=new ke(e.clientX,e.clientY);return this.cameraControl.intersector.getObjectsByClientCoordinates(t)}},{key:"_getEegeData",value:function(e){var t=e.object.geometry;this.edgeDataMap||(this.edgeDataMap={});var i=null;null!=e.indexInfo&&(i=e.indexInfo);var n=t.attributes?t:t._bufferGeometry,r=n.attributes.position.data||n.attributes.position.array,o=e.nodeId||e.userId;return this.edgeDataMap[n.id]?this.edgeDataMap[n.id].version!==r.version?(delete this.edgeDataMap[n.id].data,this.edgeDataMap[n.id].data[o]=this._getPositionArrayAndEdgeIndex(n,i)):this.edgeDataMap[n.id].data[o]||(this.edgeDataMap[n.id].data[o]=this._getPositionArrayAndEdgeIndex(n,i)):(this.edgeDataMap[n.id]={},this.edgeDataMap[n.id].version=r.version,this.edgeDataMap[n.id].data={},this.edgeDataMap[n.id].data[o]=this._getPositionArrayAndEdgeIndex(n,i)),this.edgeDataMap[n.id].data[o]}},{key:"_getPositionArrayAndEdgeIndex",value:function(e,t){var i=[],n=0,r=0,o=[],a=[],s=e.attributes.position.data||e.attributes.position,l=[];if(t)if(t.isMixNode){i=e.index.array,n=t.indexStart,r=t.indexStart+t.indexCount;for(var c=[],h=0;t.indexCount/3>h;++h){var d=i[n+3*h+0],u=i[n+3*h+1],p=i[n+3*h+2];c.push(3*h),c.push(3*h+1),c.push(3*h+2);var g=s.stride;o.push(s.array[d*g+0]),o.push(s.array[d*g+1]),o.push(s.array[d*g+2]),o.push(s.array[u*g+0]),o.push(s.array[u*g+1]),o.push(s.array[u*g+2]),o.push(s.array[p*g+0]),o.push(s.array[p*g+1]),o.push(s.array[p*g+2])}l=af(o,c)}else{for(var f=wp.getMin((i=e.index.array).slice(n=t.indexStart,r=t.indexStart+t.indexCount)),m=n;r>m;m+=1)a.push(i[m]-f);o=s.array.slice(t.positionStart,t.positionStart+t.positionCount),l=af(o,a)}else r=(i=of(e.attributes.position.array,e.index.array)).length,o=s.array,l=af(e.attributes.position.array,e.index.array);return{positionsArray:o,edgeIndex:l}}},{key:"_pointToLine",value:function(e,t,i){cf.subVectors(t,e),hf.subVectors(i,e);var n=cf.dot(hf);if(0>n)return e;var r=cf.dot(cf);if(n>r)return t;n/=r;var o=e.clone();return o.addScaledVector(cf,n),o}}]),e}(),gf="http://www.w3.org/2000/svg",ff=function(){var e=document.createElementNS(gf,"svg"),t=function(e,t,i,n){var r=document.createElementNS(gf,"defs"),o=document.createElementNS(gf,"filter");o.id=e,o.setAttributeNS(null,"x","-30%"),o.setAttributeNS(null,"y","-30%"),o.setAttributeNS(null,"width","200%"),o.setAttributeNS(null,"height","200%");var a=document.createElementNS(gf,"feGaussianBlur");a.setAttributeNS(null,"in","SourceAlpha"),a.setAttributeNS(null,"stdDeviation","4");var s=document.createElementNS(gf,"feOffset");s.setAttributeNS(null,"result","offsetblur");var l=document.createElementNS(gf,"feMerge"),c=document.createElementNS(gf,"feMergeNode"),h=document.createElementNS(gf,"feMergeNode");return h.setAttributeNS(null,"in","SourceGraphic"),l.appendChild(c),l.appendChild(h),o.appendChild(a),o.appendChild(s),o.appendChild(l),r.appendChild(o),r}("drop-shadow");return e.appendChild(t),e},mf=function(){return document.createElementNS(gf,"line")},Af=function(){return document.createElementNS(gf,"path")},yf=function(e){var t=document.createElementNS(gf,"circle");return t.setAttributeNS(null,"r",e||0),t.setAttributeNS(null,"fill","none"),t},vf=function(){return document.createElementNS(gf,"text")},Cf=function(){return document.createElementNS(gf,"g")},If=function(e,t){var i=Math.pow(e[0]-t[0],2),n=Math.pow(e[1]-t[1],2),r=0;return 3===e.length&&3===t.length&&(r=Math.pow(e[2]-t[2],2)),Math.sqrt(i+n+r)},xf=function(e){var t=Math.pow(e[0],2),i=Math.pow(e[1],2),n=0;e.length>2&&(n=Math.pow(e[2],2));var r=Math.sqrt(t+i+n),o=[e[0]/r,e[1]/r];return e.length>2&&o.push(e[2]/r),o},wf=function(e,t){var i=0;return e.length>2&&t.length>2&&(i=e[2]*t[2]),e[0]*t[0]+e[1]*t[1]+i},Mf=function(e,t){var i=e[0],n=e[1],r=e[2],o=t[0],a=t[1],s=t[2];return[n*s-r*a,r*o-i*s,i*a-n*o]},Ef=function(e){return"mm"===e?1:"cm"===e?10:"m"===e?1e3:1},Bf=function(e,t,i,n){var r=Ef(e);2===n?r*=r:3===n&&(r*=r*r);var o=Ef(t);return 2===n?o*=o:3===n&&(o*=o*o),i*r/o},Sf=function(e,t){return!(t.x>e.x+e.width||e.x>t.x+t.width||t.y>e.y+e.height||e.y>t.y+t.height)},bf=function(){return"undefined"!=typeof window&&"ontouchstart"in window},kf=function(e){this.svg=e,this.maxPointsNeed=0,this.pickedPoints=[],this.svgGroup=Cf(),this.svg.appendChild(this.svgGroup),this.unitOfModel=void 0,this.unitOnUI=void 0,this.precision=3,this.adjustOption=void 0,this.is3DMode=!1,this.isSelected=!1,this.onclickCallback=void 0};kf.prototype.addPickedPoint=function(e,t,i){return!this.isDone()&&(!!e&&(this.pickedPoints.push(e),t&&(this.unitOfModel=this.unitOfModel&&this.unitOfModel!==t?void 0:t),!0))},kf.prototype.getAllPickedPoint=function(){return this.pickedPoints},kf.prototype.draw=function(e,t){},kf.prototype.adjustWithOption=function(e){this.adjustOption=e,e&&this.updateTexts()},kf.prototype.unAdjustWithOption=function(e){this.adjustOption=void 0,this.updateTexts()},kf.prototype.changeUnit=function(e){e&&(this.unitOnUI=e,this.updateTexts())},kf.prototype.changePrecision=function(e){this.precision=e,e&&this.updateTexts()},kf.prototype.updateTexts=function(){},kf.prototype.isVisible=function(){return!!(this.svg&&this.svgGroup&&this.svgGroup.parentNode)},kf.prototype.remove=function(){this.svg&&this.svgGroup&&this.svgGroup.parentNode&&(this.svg.removeChild(this.svgGroup),this.onclickCallback=void 0)},kf.prototype.add=function(){this.svg&&this.svgGroup&&this.svg.appendChild(this.svgGroup)},kf.prototype.isDone=function(){return this.pickedPoints.length===this.maxPointsNeed},kf.prototype.setClickCallback=function(e){this.onclickCallback=e},kf.prototype.measureResult=function(){},kf.prototype.createCircle=function(){var e=yf(5);return e.setAttributeNS(null,"fill","#ff9800"),e.setAttributeNS(null,"stroke","#ffffff"),e.setAttributeNS(null,"stroke-width",2),e.style.display="none",e},kf.prototype.createLine=function(){var e=mf();return e.setAttributeNS(null,"stroke-width",2),e.setAttributeNS(null,"stroke","#ffff00"),e.style.display="none",e},kf.prototype.createText=function(){var e=vf();return e.style.fontSize="14",e.style.display="none",e.style.textAnchor="middle",e.setAttributeNS(null,"fill","#ffffff"),e},kf.prototype.createPath=function(){var e=Af();return e.style.display="none",e.setAttributeNS(null,"fill","none"),e.setAttributeNS(null,"stroke","#0aea06"),e},kf.prototype.resultToDisplayOfLength=function(e){var t=e,i=this.unitOfModel;return this.adjustOption&&(t=this.adjustOption.adjustLength(e),i=this.adjustOption.unit),this.unitOnUI&&(i&&(t=Bf(i,this.unitOnUI,t,0)),i=this.unitOnUI),i||(i=""),t=t.toFixed(this.precision),{value:Number(t),unit:i,text:t+i}},kf.prototype.setSelected=function(e){return this.isSelected!==e&&(this.isSelected=e,!0)};var Df=function(){this.group=Cf(),this.group.style.display="none";var e=Af();this.textBackground=e,this.group.appendChild(e),e=Af(),this.prefixTextBackground=e,this.prefixTextBackground.style.display="none",this.group.appendChild(e);var t=vf();t.style.fontSize="12",t.style.textAnchor="middle",t.style.dominantBaseline="central",t.style.cursor="default",t.setAttributeNS(null,"fill","#ffffff"),this.group.appendChild(t),this.text=t,(t=vf()).style.fontSize="12",t.style.textAnchor="middle",t.style.dominantBaseline="central",t.style.display="none",t.setAttributeNS(null,"fill","#ffffff"),this.group.appendChild(t),this.prefixText=t,this.textColor="#ffffff",this.prefixTextColor="#ffffff",this.textBackgroundColor="#ffffff",this.prefixTextBackgroundColor="blue",this.textContent=void 0,this.prefixTextContent=void 0,this.textPosition={x:0,y:0},this.isShowShadow=!1,this.onclickCallback=void 0,this._onMouseDown=this._onMouseDown.bind(this),this._onMouseMove=this._onMouseMove.bind(this),this._onMouseUp=this._onMouseUp.bind(this)};Df.prototype.draw=function(e){if(this.textContent&&this.textContent.length){this.group.style.display="",this.text.textContent=this.textContent;var t=null;this.prefixTextContent?(this.prefixText.textContent=this.prefixTextContent,this.prefixText.style.display="",t=this.prefixText.getBBox()):(this.prefixText.style.display="none",t={width:0,height:0});var i=this.text.getBBox(),n=5+i.width+5;this.prefixTextContent&&this.prefixTextContent.length>0&&(n=n+5+t.width+5),e&&(n=Math.max(e,n));var r=this.textPosition.x-n/2,o=this.textPosition.y-(5+i.height+5)/2,a=function(e,t,i,n,r){return"M"+e+","+(t+r)+"a"+r+","+r+" 0 0 1 "+r+","+-r+"h"+(i-2*r)+"a"+r+","+r+" 0 0 1 "+r+","+r+"v"+(n-2*r)+"a"+r+","+r+" 0 0 1 "+-r+","+r+"h"+(2*r-i)+"a"+r+","+r+" 0 0 1 "+-r+","+-r+"v"+(2*r-n)+"z"}(r,o,n,i.height+10,5);this.textBackground.setAttributeNS(null,"d",a),this.textBackground.setAttributeNS(null,"fill",this.textBackgroundColor),this.isShowShadow?this.group.setAttributeNS(null,"filter","url(#drop-shadow)"):this.group.removeAttributeNS(null,"filter"),this.prefixTextContent&&this.prefixTextContent.length>0?(a=function(e,t,i,n,r){return"M"+e+","+(t+r)+"a"+r+","+r+" 0 0 1 "+r+","+-r+"h"+(i-r)+"v"+n+"h"+(r-i)+"a"+r+","+r+" 0 0 1 "+-r+","+-r+"v"+(2*r-n)+"z"}(r,o,t.width+10,t.height+10,5),this.prefixTextBackground.setAttributeNS(null,"d",a),this.prefixTextBackground.setAttributeNS(null,"fill",this.prefixTextBackgroundColor),this.prefixTextBackground.style.display="",this.prefixText.setAttributeNS(null,"x",r+5+t.width/2),this.prefixText.setAttributeNS(null,"y",o+5+t.height/2),r=r+(10+t.width)/2+n/2):r+=n/2,this.text.setAttributeNS(null,"x",r),this.text.setAttributeNS(null,"y",o+5+i.height/2),this.text.setAttributeNS(null,"fill",this.textColor),this.prefixText.setAttributeNS(null,"fill",this.prefixTextColor)}},Df.prototype.setText=function(e,t){this.textContent=e,this.prefixTextContent=t},Df.prototype.setPosition=function(e,t){this.textPosition={x:e,y:t}},Df.prototype.hide=function(){this.group.style.display="none"},Df.prototype.show=function(){this.group.style.display=""},Df.prototype.setClickCallback=function(e){this.onclickCallback=e,e?(this.group.style.cursor="pointer",this.text.style.cursor="pointer",bf()?(this.group.addEventListener("touchstart",this._onMouseDown),this.group.addEventListener("touchend",this._onMouseUp),this.group.addEventListener("touchmove",this._onMouseMove)):(this.group.addEventListener("mousedown",this._onMouseDown),this.group.addEventListener("mouseup",this._onMouseUp),this.group.addEventListener("mousemove",this._onMouseMove))):(this.group.style.cursor="default",this.text.style.cursor="default",bf()?(this.group.removeEventListener("touchstart",this._onMouseDown),this.group.removeEventListener("touchend",this._onMouseUp),this.group.removeEventListener("touchmove",this._onMouseMove)):(this.group.removeEventListener("mousedown",this._onMouseDown),this.group.removeEventListener("mouseup",this._onMouseUp),this.group.removeEventListener("mousemove",this._onMouseMove)))},Df.prototype._onMouseMove=function(e){e.stopPropagation(),e.preventDefault()},Df.prototype._onMouseDown=function(e){e.stopPropagation(),e.preventDefault()},Df.prototype._onMouseUp=function(e){e.stopPropagation(),e.preventDefault(),this.onclickCallback&&this.onclickCallback()};var Tf=function(e){kf.call(this,e),this.maxPointsNeed=2,this.startCircle=this.createCircle(),this.startCircle.setAttributeNS(null,"fill","#ffffff"),this.endCircle=this.createCircle(),this.endCircle.setAttributeNS(null,"fill","#ffffff"),this.svgGroup.appendChild(this.startCircle),this.svgGroup.appendChild(this.endCircle),this.line=this.createLine(),this.line.setAttributeNS(null,"stroke","#ffffff"),this.line.setAttributeNS(null,"strokd-width",2),this.svgGroup.appendChild(this.line),this.text=new Df,this.text.textBackgroundColor="#ffffff",this.text.textColor="#000000",this.svgGroup.appendChild(this.text.group),this._distance=void 0};(Tf.prototype=Object.assign(Object.create(kf.prototype),{constructor:Tf})).addPickedPoint=function(e,t,i){kf.prototype.addPickedPoint.call(this,e,t,i)&&this.isDone()&&(this._enableSelect(),this._distance=If(this.pickedPoints[0],this.pickedPoints[1]))},Tf.prototype.draw=function(e,t){if(this.svgGroup.parentNode){var i=this.pickedPoints;if(i.length>0){e&&!this.isDone()&&(i=i.concat([e]));var n=i;if(t){for(var r=[],o=0,a=i.length;a>o;o+=1)r[o]=t(i[o]);n=r}var s=n[0],l=n.length>1?n[1]:s;if(this.startCircle.setAttributeNS(null,"cx",s[0]),this.startCircle.setAttributeNS(null,"cy",s[1]),this.startCircle.style.display="",this.line.setAttributeNS(null,"x1",s[0]),this.line.setAttributeNS(null,"y1",s[1]),this.line.setAttributeNS(null,"x2",l[0]),this.line.setAttributeNS(null,"y2",l[1]),this.line.style.display="",this.text.setPosition((s[0]+l[0])/2,(s[1]+l[1])/2),i.length>1){var c=If(i[0],i[1]);this._distance=c}2===this.pickedPoints.length?(this.endCircle.setAttributeNS(null,"cx",l[0]),this.endCircle.setAttributeNS(null,"cy",l[1]),this.endCircle.style.display=""):this.endCircle.style.display="none",this._updateText()}}},Tf.prototype.measureResult=function(){if(this.isDone()){var e={};if(e.distance=this._distance,this.adjustOption){var t=this.resultToDisplayOfLength(this._distance);e.unit=t.unit,e.value=t.value}return e}},Tf.prototype.adjustWithOption=function(e){kf.prototype.adjustWithOption.call(this,e),this._updateText(),this._disableSelect()},Tf.prototype.changeUnit=function(e){kf.prototype.changeUnit.call(this,e),e&&this._updateText()},Tf.prototype.changePrecision=function(e){kf.prototype.changePrecision.call(this,e),e&&this._updateText()},Tf.prototype._enableSelect=function(){var e=this;this.startCircle.onmousedown=function(t){e.isDone()&&(e.pickedPoints=e.pickedPoints.slice(1),t.stopPropagation(),e._disableSelect())},this.endCircle.onmousedown=function(t){e.isDone()&&(e.pickedPoints=e.pickedPoints.slice(0,1),t.stopPropagation(),e._disableSelect())}},Tf.prototype._disableSelect=function(){this.startCircle.onmousedown=void 0,this.endCircle.onmousedown=void 0},Tf.prototype._updateText=function(){this.isDone()&&this._distance&&this.adjustOption&&(this.text.setText(this.resultToDisplayOfLength(this._distance).text),this.text.draw())};var Rf=function(){this.unit=void 0,this.valueBeforeAdjust=void 0,this.valueAfterAdjust=void 0};Rf.prototype.adjustLength=function(e){return this.valueAfterAdjust&&this.valueBeforeAdjust?e*this.valueAfterAdjust/this.valueBeforeAdjust:e},Rf.prototype.adjustArea=function(e){return this.valueAfterAdjust&&this.valueBeforeAdjust?e*Math.pow(this.valueAfterAdjust/this.valueBeforeAdjust,2):e},Rf.prototype.adjustVolume=function(e){return this.valueAfterAdjust&&this.valueBeforeAdjust?e*Math.pow(this.valueAfterAdjust/this.valueBeforeAdjust,3):e};var Uf=function(e){kf.call(this,e),this.maxPointsNeed=3,this._angle=void 0,this.circle1=this.createCircle(),this.circle2=this.createCircle(),this.circle3=this.createCircle(),this.svgGroup.appendChild(this.circle1),this.svgGroup.appendChild(this.circle2),this.svgGroup.appendChild(this.circle3),this.line1=this.createLine(),this.line1.setAttributeNS(null,"stroke-width",2),this.svgGroup.appendChild(this.line1),this.line2=this.createLine(),this.line2.setAttributeNS(null,"stroke-width",2),this.svgGroup.appendChild(this.line2),this.arc=this.createPath(),this.svgGroup.appendChild(this.arc),this.angleText=new Df,this.angleText.textBackgroundColor="#009bff",this.svgGroup.appendChild(this.angleText.group);var t=this;this.angleText.setClickCallback((function(){t.onclickCallback&&t.onclickCallback(t)}))};(Uf.prototype=Object.assign(Object.create(kf.prototype),{constructor:Uf})).addPickedPoint=function(e,t,i){if(kf.prototype.addPickedPoint.call(this,e,t,i)&&this.isDone()){var n=this.pickedPoints[0],r=this.pickedPoints[1],o=this.pickedPoints[2],a=function(e,t){var i=xf(e),n=xf(t),r=wf(i,n);return Math.acos(r)/Math.PI*180}([n[0]-r[0],n[1]-r[1],n[2]-r[2]],[o[0]-r[0],o[1]-r[1],o[2]-r[2]]);this._angle=a}},Uf.prototype.draw=function(e,t){if(this.svgGroup.parentNode){var i=this.pickedPoints;if(i.length>0){e&&!this.isDone()&&(i=i.concat([e]));var n=i,r=!0;if(t){for(var o=!0,a=[],s=0,l=i.length;l>s;s+=1)a[s]=t(i[s]),r&&a[s][0]>0&&a[s][0]<parseInt(this.svg.style.width,10)&&a[s][1]>0&&a[s][1]<parseInt(this.svg.style.height,10)&&(r=!1),void 0!==a[s][2]&&0!==a[s][2]||(o=!1);n=a,o&&(r=!0)}if(this.pickedPoints.length>=1){var c=n[0],h=n[1];this.circle1.setAttributeNS(null,"cx",c[0]),this.circle1.setAttributeNS(null,"cy",c[1]),this.circle1.style.display="",(e||this.pickedPoints.length>1)&&(this.line1.setAttributeNS(null,"x1",c[0]),this.line1.setAttributeNS(null,"y1",c[1]),this.line1.setAttributeNS(null,"x2",h[0]),this.line1.setAttributeNS(null,"y2",h[1]),this.line1.style.display="")}if(this.pickedPoints.length>=2){var d=n[1],u=n[2];this.circle2.setAttributeNS(null,"cx",d[0]),this.circle2.setAttributeNS(null,"cy",d[1]),this.circle2.style.display="",(e||this.pickedPoints.length>2)&&(this.line2.setAttributeNS(null,"x1",d[0]),this.line2.setAttributeNS(null,"y1",d[1]),this.line2.setAttributeNS(null,"x2",u[0]),this.line2.setAttributeNS(null,"y2",u[1]),this.line2.style.display="")}if(3===this.pickedPoints.length){if(r)return void(this.svgGroup.style.display="none");this.svgGroup.style.display="";var p=n[2];this.circle3.setAttributeNS(null,"cx",p[0]),this.circle3.setAttributeNS(null,"cy",p[1]),this.circle3.style.display="";var g=n[0].slice(0,2),f=n[1].slice(0,2),m=n[2].slice(0,2),A=If(g,f),y=If(f,m),v=Math.min(Math.min(A,y),30),C=xf([g[0]-f[0],g[1]-f[1]]),I=[f[0]+C[0]*v,f[1]+C[1]*v],x=xf([m[0]-f[0],m[1]-f[1]]),w=[f[0]+x[0]*v,f[1]+x[1]*v],M=[(I[0]+w[0])/2,(I[1]+w[1])/2],E=[M[0]-f[0],M[1]-f[1]],B=[f[0]+(E=[1.5*E[0],1.5*E[1]])[0],f[1]+E[1]],S="M"+I[0]+","+I[1];S+="Q"+B[0]+","+B[1],this.arc.setAttributeNS(null,"d",S+=" "+w[0]+","+w[1]),this.arc.style.display="",this.angleText.setText(this._angle.toFixed(this.precision)+"°"),this.angleText.setPosition(B[0],B[1]),this.angleText.draw()}}}},Uf.prototype.setSelected=function(e){kf.prototype.setSelected.call(this,e)&&(e?(this.angleText.isShowShadow=!0,this.angleText.textBackgroundColor="#ffffff",this.angleText.textColor="#009bff",this.angleText.draw()):(this.angleText.isShowShadow=!1,this.angleText.textBackgroundColor="#009bff",this.angleText.textColor="#ffffff",this.angleText.draw()))},Uf.prototype.measureResult=function(){return this._angle},Uf.prototype.updateTexts=function(){this.isDone()&&(this.angleText.setText(this._angle.toFixed(this.precision)+"°"),this.angleText.draw())};var Ff=function(e){kf.call(this,e),this.path=Af(),this.path.setAttributeNS(null,"fill","none"),this.path.setAttributeNS(null,"stroke","rgb(69,195,69)"),this.svgGroup.appendChild(this.path),this._isDone=!1,this._circles=[],this._area=-1,this.resultText=new Df,this.resultText.textBackgroundColor="#009bff",this.svgGroup.appendChild(this.resultText.group);var t=this;this.resultText.setClickCallback((function(){t.onclickCallback&&t.onclickCallback(t)}))};(Ff.prototype=Object.assign(Object.create(kf.prototype),{constructor:Ff})).addPickedPoint=function(e,t,i){if(this._pointCanClosePath(e,i))this._isDone=!0,this._area=this.is3DMode?this._calculateArea3D():this._calculateArea2D();else if(kf.prototype.addPickedPoint.call(this,e,t,i)){var n=this.createCircle();this.svgGroup.appendChild(n),this._circles.push(n)}},Ff.prototype.isDone=function(){return this._isDone},Ff.prototype.draw=function(e,t){if(this.svgGroup.parentNode){var i=this.pickedPoints;if(i.length>0){if(e&&!this.isDone()){if(this._pointCanClosePath(e,t)){var n=this.pickedPoints[0];e=[n[0],n[1],n[2]]}i=i.concat([e])}var r=i,o=!0;if(t){for(var a=!0,s=[],l=0,c=i.length;c>l;l+=1)s[l]=t(i[l]),o&&s[l][0]>0&&s[l][0]<parseInt(this.svg.style.width,10)&&s[l][1]>0&&s[l][1]<parseInt(this.svg.style.height,10)&&(o=!1),void 0!==s[l][2]&&0!==s[l][2]||(a=!1);r=s,a&&(o=!0)}var h=this._pathString(r);if(this.path.setAttributeNS(null,"d",h),this.isDone()){if(o)return void(this.svgGroup.style.display="none");this.svgGroup.style.display="",this.path.setAttributeNS(null,"fill","rgba(69,195,69,0.5)");var d=this._getPointsCenter(this.pickedPoints);t&&(d=t(d)),this.resultText.setPosition(d[0],d[1]),this.updateTexts()}for(var u=0,p=this._circles.length;p>u;u+=1){var g=this._circles[u],f=r[u];g.setAttributeNS(null,"cx",f[0]),g.setAttributeNS(null,"cy",f[1]),g.style.display=""}}}},Ff.prototype.measureResult=function(){return this._area},Ff.prototype.updateTexts=function(){this.isDone()&&(this.resultText.setText(this.resultToDisplayOfArea(this._area).text),this.resultText.draw())},Ff.prototype.setSelected=function(e){kf.prototype.setSelected.call(this,e)&&(e?(this.resultText.isShowShadow=!0,this.resultText.textBackgroundColor="#ffffff",this.resultText.textColor="#009bff",this.resultText.draw()):(this.resultText.isShowShadow=!1,this.resultText.textBackgroundColor="#009bff",this.resultText.textColor="#ffffff",this.resultText.draw()))},Ff.prototype.resultToDisplayOfArea=function(e){var t=e,i=this.unitOfModel;return this.adjustOption&&(t=this.adjustOption.adjustArea(e),i=this.adjustOption.unit),this.unitOnUI&&(i&&(t=Bf(i,this.unitOnUI,t,2)),i=this.unitOnUI),i||(i=""),t=t.toFixed(this.precision),"mm"===i?i="mm²":"m"===i?i="m²":"cm"===i&&(i="cm²"),{value:Number(t),unit:i,text:t+i}},Ff.prototype._pointCanClosePath=function(e,t){if(this.pickedPoints.length>0){var i=this.pickedPoints[0];t&&(i=t(i),e=t(e));var n=e[0]-i[0],r=e[1]-i[1];if(200>=n*n+r*r+0)return!0}return!1},Ff.prototype._pathString=function(e){if(!e||0===e.length)return"";for(var t="M"+e[0][0]+" "+e[0][1],i=1,n=e.length;n>i;i+=1)t=t+"L"+e[i][0]+" "+e[i][1];return this.isDone()&&(t+="Z"),t},Ff.prototype._calculateArea2D=function(){if(this.isDone()&&this.pickedPoints.length>=3){for(var e=this.pickedPoints,t=this.pickedPoints[0],i=[],n=1,r=e.length;r>n;n+=1)i.push([e[n][0]-t[0],e[n][1]-t[1]]);for(var o=0,a=0,s=i.length;s-1>a;a+=1){var l=i[a],c=i[a+1];o+=l[0]*c[1]-l[1]*c[0]}return Math.abs(o/2)}return 0},Ff.prototype._calculateArea3D=function(){if(this.isDone()&&this.pickedPoints.length>=3){for(var e=this.pickedPoints,t=this.pickedPoints[0],i=xf(Mf([this.pickedPoints[1][0]-t[0],this.pickedPoints[1][1]-t[1],this.pickedPoints[1][2]-t[2]],[this.pickedPoints[2][0]-t[0],this.pickedPoints[2][1]-t[1],this.pickedPoints[2][2]-t[2]])),n=0,r=1,o=e.length;o>r;r+=1){n+=wf(Mf([this.pickedPoints[r-1][0]-t[0],this.pickedPoints[r-1][1]-t[1],this.pickedPoints[r-1][2]-t[2]],[this.pickedPoints[r][0]-t[0],this.pickedPoints[r][1]-t[1],this.pickedPoints[r][2]-t[2]]),i)}return Math.abs(n/2)}return 0},Ff.prototype._getPointsCenter=function(e){var t=e.length;return[e.reduce((function(e,t){return e+t[0]}),0)/t,e.reduce((function(e,t){return e+t[1]}),0)/t,e.reduce((function(e,t){return e+t[2]}),0)/t]},Ff.prototype._crossProduct=function(e,t){var i=e[0],n=e[1],r=e[2],o=t[0],a=t[1],s=t[2];return[n*s-r*a,r*o-i*s,i*a-n*o]};var Qf=function(e,t,i){kf.call(this,e),this.maxPointsNeed=2,this.isMobile=t,this.number=i,this._drawPoints=[],this.startCircle=this.createCircle(),this.endCircle=this.createCircle(),this.svgGroup.appendChild(this.startCircle),this.svgGroup.appendChild(this.endCircle),this.distanceLine=this.createLine(),this.svgGroup.appendChild(this.distanceLine),this.deltaXLine=this.createLine(),this.deltaXLine.setAttributeNS(null,"stroke","#ec4545"),this.deltaXLine.setAttributeNS(null,"stroke-dasharray","6,4"),this.isMobile||this.svgGroup.appendChild(this.deltaXLine),this.deltaYLine=this.createLine(),this.deltaYLine.setAttributeNS(null,"stroke","#45c345"),this.deltaYLine.setAttributeNS(null,"stroke-dasharray","6,4"),this.isMobile||this.svgGroup.appendChild(this.deltaYLine),this.deltaZLine=this.createLine(),this.deltaZLine.setAttributeNS(null,"stroke","#5757da"),this.deltaZLine.setAttributeNS(null,"stroke-dasharray","6,4"),this.isMobile||this.svgGroup.appendChild(this.deltaZLine),this.deltaXText=new Df,this.deltaXText.textColor="#ec4545",this.deltaXText.prefixTextBackgroundColor="#ec4545",this.svgGroup.appendChild(this.deltaXText.group),this.deltaYText=new Df,this.deltaYText.textColor="#45c345",this.deltaYText.prefixTextBackgroundColor="#45c345",this.svgGroup.appendChild(this.deltaYText.group),this.deltaZText=new Df,this.deltaZText.textColor="#5757da",this.deltaZText.prefixTextBackgroundColor="#5757da",this.svgGroup.appendChild(this.deltaZText.group),this.distanceText=new Df,this.distanceText.textBackgroundColor="#009bff";var n=this;this.distanceText.setClickCallback((function(){n.onclickCallback&&n.onclickCallback(n)})),this.svgGroup.appendChild(this.distanceText.group),this._distance=void 0,this._deltaXDistance=void 0,this._deltaYDistance=void 0,this._deltaZDistance=void 0};(Qf.prototype=Object.assign(Object.create(kf.prototype),{constructor:Qf})).addPickedPoint=function(e,t,i){if(kf.prototype.addPickedPoint.call(this,e,t,i)&&(this._drawPoints.push(e),this.isDone())){if(3===e.length){var n=[];n[0]=this.pickedPoints[1][0],n[1]=this.pickedPoints[0][1],n[2]=this.pickedPoints[1][2];var r=[];r[0]=this.pickedPoints[1][0],r[1]=this.pickedPoints[0][1],r[2]=this.pickedPoints[0][2],this._drawPoints.push(n),this._drawPoints.push(r)}this._distance=If(this._drawPoints[0],this._drawPoints[1]),this._deltaYDistance=If(this._drawPoints[1],this._drawPoints[2]),this._deltaZDistance=If(this._drawPoints[2],this._drawPoints[3]),this._deltaXDistance=If(this._drawPoints[3],this._drawPoints[0]),this.updateTexts()}},Qf.prototype.draw=function(e,t){if(this.svgGroup.parentNode){var i=this._drawPoints;if(i.length>0){e&&!this.isDone()&&(i=i.concat([e]));var n=i,r=!0;if(t){for(var o=!0,a=[],s=0,l=i.length;l>s;s+=1)a[s]=t(i[s]),r&&a[s][0]>0&&a[s][0]<parseInt(this.svg.style.width,10)&&a[s][1]>0&&a[s][1]<parseInt(this.svg.style.height,10)&&(r=!1),void 0!==a[s][2]&&0!==a[s][2]||(o=!1);n=a,o&&(r=!0)}var c=n[0],h=n.length>1?n[1]:c;if(this.startCircle.setAttributeNS(null,"cx",c[0]),this.startCircle.setAttributeNS(null,"cy",c[1]),this.startCircle.style.display="",this.distanceLine.setAttributeNS(null,"x1",c[0]),this.distanceLine.setAttributeNS(null,"y1",c[1]),this.distanceLine.setAttributeNS(null,"x2",h[0]),this.distanceLine.setAttributeNS(null,"y2",h[1]),this.distanceLine.style.display="",2>i.length)return;if(this.distanceText.setPosition((c[0]+h[0])/2,(c[1]+h[1])/2),!this.isDone()){var d=If(i[0],i[1]);this._distance=d}if(4===i.length){if(r)return void(this.svgGroup.style.display="none");this.svgGroup.style.display="",this.isSelected?(this.distanceText.isShowShadow=!0,this.distanceText.textBackgroundColor="#ffffff",this.distanceText.textColor="#009bff"):(this.distanceText.isShowShadow=!1,this.distanceText.textBackgroundColor="#009bff",this.distanceText.textColor="#ffffff"),this.distanceText.draw(),this.endCircle.style.display="",this.deltaYLine.style.display="",this.deltaXLine.style.display="",this.deltaZLine.style.display="",this.endCircle.setAttributeNS(null,"cx",h[0]),this.endCircle.setAttributeNS(null,"cy",h[1]);var u=n[2],p=n[3];this.deltaYLine.setAttributeNS(null,"x1",h[0]),this.deltaYLine.setAttributeNS(null,"y1",h[1]),this.deltaYLine.setAttributeNS(null,"x2",u[0]),this.deltaYLine.setAttributeNS(null,"y2",u[1]),this.deltaYText.setPosition((u[0]+h[0])/2,(u[1]+h[1])/2),this.deltaZLine.setAttributeNS(null,"x1",u[0]),this.deltaZLine.setAttributeNS(null,"y1",u[1]),this.deltaZLine.setAttributeNS(null,"x2",p[0]),this.deltaZLine.setAttributeNS(null,"y2",p[1]),this.deltaZText.setPosition((u[0]+p[0])/2,(u[1]+p[1])/2),this.deltaXLine.setAttributeNS(null,"x1",p[0]),this.deltaXLine.setAttributeNS(null,"y1",p[1]),this.deltaXLine.setAttributeNS(null,"x2",c[0]),this.deltaXLine.setAttributeNS(null,"y2",c[1]),this.deltaXText.setPosition((p[0]+c[0])/2,(p[1]+c[1])/2),this.isSelected&&(this.isMobile||(this.deltaXText.draw(),this.deltaYText.draw(),this.deltaZText.draw()),this.layoutResultText())}}}},Qf.prototype.layoutResultText=function(){for(var e=this.distanceText.group.getBBox(),t=this.deltaXText.group.getBBox(),i=this.deltaYText.group.getBBox(),n=this.deltaZText.group.getBBox(),r=[t,i,n],o=!1,a=0;r.length>a;a+=1)if(Sf(e,r[a])){o=!0;break}if(o||(o=Sf(t,i)),o||(o=Sf(t,n)),o||(o=Sf(i,n)),o){var s=Math.max(e.width,t.width,i.width,n.width),l=e.x+e.width/2,c=e.y+e.height+8;return this.deltaXText.setPosition(l,c+t.height/2),this.deltaYText.setPosition(l,(c+=t.height)+i.height/2),this.deltaZText.setPosition(l,(c+=i.height)+n.height/2),this.isMobile||(this.deltaXText.draw(s),this.deltaYText.draw(s),this.deltaZText.draw(s)),this.distanceText.draw(s),o}},Qf.prototype.measureResult=function(){if(this._distance)return[this._distance,this._deltaXDistance,this._deltaYDistance,this._deltaZDistance]},Qf.prototype.updateTexts=function(){this._distance&&(this.distanceText.setText(this.isMobile?"线段"+this.number+": "+this.resultToDisplayOfLength(this._distance).text:this.resultToDisplayOfLength(this._distance).text,void 0),this.distanceText.draw(),this.isDone()&&(0!==this._deltaXDistance&&this.deltaXText.setText(this.resultToDisplayOfLength(this._deltaXDistance).text,"X"),0!==this._deltaYDistance&&this.deltaYText.setText(this.resultToDisplayOfLength(this._deltaYDistance).text,"Y"),0!==this._deltaZDistance&&this.deltaZText.setText(this.resultToDisplayOfLength(this._deltaZDistance).text,"Z"),this.isSelected&&!this.isMobile&&(this.deltaXText.draw(),this.deltaYText.draw(),this.deltaZText.draw())))},Qf.prototype.setSelected=function(e){kf.prototype.setSelected.call(this,e)&&(e?(this.distanceText.isShowShadow=!0,this.distanceText.textBackgroundColor="#ffffff",this.distanceText.textColor="#009bff",this.isMobile||(this.deltaXText.draw(),this.deltaYText.draw(),this.deltaZText.draw()),this.distanceText.draw(),this.layoutResultText()):(this.deltaXText.hide(),this.deltaYText.hide(),this.deltaZText.hide(),this.distanceText.isShowShadow=!1,this.distanceText.textBackgroundColor="#009bff",this.distanceText.textColor="#ffffff",this.distanceText.draw()))};var Lf=function(e){kf.call(this,e),this.maxPointsNeed=2,this.startCircle=this.createCircle(),this.endCircle=this.createCircle(),this.svgGroup.appendChild(this.startCircle),this.svgGroup.appendChild(this.endCircle),this.distanceLine=this.createLine(),this.svgGroup.appendChild(this.distanceLine),this.distanceText=new Df,this.distanceText.textBackgroundColor="#009bff",this.svgGroup.appendChild(this.distanceText.group);var t=this;this.distanceText.setClickCallback((function(){t.onclickCallback&&t.onclickCallback(t)})),this.pickedComponentKeys=[],this._distance=void 0};(Lf.prototype=Object.assign(Object.create(kf.prototype),{constructor:Lf})).setData=function(e,t,i){this.pickedPoints=e,this._distance=t,i&&(this.unitOfModel=this.unitOfModel&&this.unitOfModel!==i?void 0:i)},Lf.prototype.draw=function(e,t){if(this.svgGroup.parentNode&&this.isDone()){var i=this.pickedPoints;if(t){for(var n=[],r=0,o=i.length;o>r;r+=1)n[r]=t(i[r]);i=n}var a=i[0],s=i[1];this.startCircle.setAttributeNS(null,"cx",a[0]),this.startCircle.setAttributeNS(null,"cy",a[1]),this.startCircle.style.display="",this.endCircle.setAttributeNS(null,"cx",s[0]),this.endCircle.setAttributeNS(null,"cy",s[1]),this.endCircle.style.display="",this.distanceLine.setAttributeNS(null,"x1",a[0]),this.distanceLine.setAttributeNS(null,"y1",a[1]),this.distanceLine.setAttributeNS(null,"x2",s[0]),this.distanceLine.setAttributeNS(null,"y2",s[1]),this.distanceLine.style.display="",this.distanceText.setPosition((a[0]+s[0])/2,(a[1]+s[1])/2),this.updateTexts()}},Lf.prototype.measureResult=function(){if(void 0!==this._distance)return this._distance},Lf.prototype.updateTexts=function(){void 0!==this._distance&&(this.distanceText.setText(this.resultToDisplayOfLength(this._distance).text,void 0),this.distanceText.draw())},Lf.prototype.setSelected=function(e){kf.prototype.setSelected.call(this,e)&&(e?(this.distanceText.isShowShadow=!0,this.distanceText.textBackgroundColor="#ffffff",this.distanceText.textColor="#009bff",this.distanceText.draw()):(this.distanceText.isShowShadow=!1,this.distanceText.textBackgroundColor="#009bff",this.distanceText.textColor="#ffffff",this.distanceText.draw()))};var Of=function(e){kf.call(this,e),this.maxPointsNeed=2;var t=mf();t.setAttributeNS(null,"stroke-width","2"),t.setAttributeNS(null,"stroke","#0aea06"),this.svgGroup.appendChild(t),this._line=t,this.distanceText=new Df,this.distanceText.textBackgroundColor="#009bff",this.svgGroup.appendChild(this.distanceText.group)};(Of.prototype=Object.assign(Object.create(kf.prototype),{constructor:Of})).setData=function(e,t){e&&t&&(this._points=[e,t])},Of.prototype.draw=function(e,t){if(2===this._points.length){var i=t(this._points[0]),n=t(this._points[1]);this._line.setAttributeNS(null,"x1",i[0]),this._line.setAttributeNS(null,"y1",i[1]),this._line.setAttributeNS(null,"x2",n[0]),this._line.setAttributeNS(null,"y2",n[1]),this.distanceText.setPosition((i[0]+n[0])/2,(i[1]+n[1])/2);var r=If(this._points[0],this._points[1]);this.distanceText.setText(this.resultToDisplayOfLength(r).text,void 0),this.distanceText.draw()}};var Nf,Pf,Gf=function(e,t){this.x=e||0,this.y=t||0};Object.defineProperties(Gf.prototype,{width:{get:function(){return this.x},set:function(e){this.x=e}},height:{get:function(){return this.y},set:function(e){this.y=e}}}),Object.assign(Gf.prototype,{isVector2:!0,set:function(e,t){return this.x=e,this.y=t,this},setScalar:function(e){return this.x=e,this.y=e,this},setX:function(e){return this.x=e,this},setY:function(e){return this.y=e,this},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},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)}},clone:function(){return new this.constructor(this.x,this.y)},copy:function(e){return this.x=e.x,this.y=e.y,this},add:function(e,t){return void 0!==t?(console.warn("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)},addScalar:function(e){return this.x+=e,this.y+=e,this},addVectors:function(e,t){return this.x=e.x+t.x,this.y=e.y+t.y,this},addScaledVector:function(e,t){return this.x+=e.x*t,this.y+=e.y*t,this},sub:function(e,t){return void 0!==t?(console.warn("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)},subScalar:function(e){return this.x-=e,this.y-=e,this},subVectors:function(e,t){return this.x=e.x-t.x,this.y=e.y-t.y,this},multiply:function(e){return this.x*=e.x,this.y*=e.y,this},multiplyScalar:function(e){return this.x*=e,this.y*=e,this},divide:function(e){return this.x/=e.x,this.y/=e.y,this},divideScalar:function(e){return this.multiplyScalar(1/e)},applyMatrix3:function(e){var t=this.x,i=this.y,n=e.elements;return this.x=n[0]*t+n[3]*i+n[6],this.y=n[1]*t+n[4]*i+n[7],this},min:function(e){return this.x>e.x&&(this.x=e.x),this.y>e.y&&(this.y=e.y),this},max:function(e){return e.x>this.x&&(this.x=e.x),e.y>this.y&&(this.y=e.y),this},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},clampScalar:(Nf=new Gf,Pf=new Gf,function(e,t){return Nf.set(e,e),Pf.set(t,t),this.clamp(Nf,Pf)}),clampLength:function(e,t){var i=this.length();return this.divideScalar(i||1).multiplyScalar(Math.max(e,Math.min(t,i)))},floor:function(){return this.x=Math.floor(this.x),this.y=Math.floor(this.y),this},ceil:function(){return this.x=Math.ceil(this.x),this.y=Math.ceil(this.y),this},round:function(){return this.x=Math.round(this.x),this.y=Math.round(this.y),this},roundToZero:function(){return this.x=0>this.x?Math.ceil(this.x):Math.floor(this.x),this.y=0>this.y?Math.ceil(this.y):Math.floor(this.y),this},negate:function(){return this.x=-this.x,this.y=-this.y,this},dot:function(e){return this.x*e.x+this.y*e.y},cross:function(e){return this.x*e.y-this.y*e.x},lengthSq:function(){return this.x*this.x+this.y*this.y},length:function(){return Math.sqrt(this.x*this.x+this.y*this.y)},manhattanLength:function(){return Math.abs(this.x)+Math.abs(this.y)},normalize:function(){return this.divideScalar(this.length()||1)},angle:function(){var e=Math.atan2(this.y,this.x);return 0>e&&(e+=2*Math.PI),e},distanceTo:function(e){return Math.sqrt(this.distanceToSquared(e))},distanceToSquared:function(e){var t=this.x-e.x,i=this.y-e.y;return t*t+i*i},manhattanDistanceTo:function(e){return Math.abs(this.x-e.x)+Math.abs(this.y-e.y)},setLength:function(e){return this.normalize().multiplyScalar(e)},lerp:function(e,t){return this.x+=(e.x-this.x)*t,this.y+=(e.y-this.y)*t,this},lerpVectors:function(e,t,i){return this.subVectors(t,e).multiplyScalar(i).add(e)},equals:function(e){return e.x===this.x&&e.y===this.y},fromArray:function(e,t){return void 0===t&&(t=0),this.x=e[t],this.y=e[t+1],this},toArray:function(e,t){return void 0===e&&(e=[]),void 0===t&&(t=0),e[t]=this.x,e[t+1]=this.y,e},rotateAround:function(e,t){var i=Math.cos(t),n=Math.sin(t),r=this.x-e.x,o=this.y-e.y;return this.x=r*i-o*n+e.x,this.y=r*n+o*i+e.y,this}});var Kf=function(){this.elements=[1,0,0,0,1,0,0,0,1]};function Vf(e,t){this.normal=void 0!==e?e:new Qu(1,0,0),this.constant=void 0!==t?t:0}Kf.prototype.clear=function(){return this.elements=[1,0,0,0,1,0,0,0,1],this},Kf.prototype.set=function(e,t,i,n,r,o,a,s,l){var c=this.elements;return c[0]=e,c[1]=n,c[2]=a,c[3]=t,c[4]=r,c[5]=s,c[6]=i,c[7]=o,c[8]=l,this},Kf.prototype.clone=function(){return(new this.constructor).fromArray(this.elements)},Kf.prototype.fromArray=function(e,t){void 0===t&&(t=0);for(var i=0;9>i;i+=1)this.elements[i]=e[i+t];return this},Kf.prototype.multiply=function(e){return this.multiplyMatrices(this,e)},Kf.prototype.multiplyMatrices=function(e,t){var i=e.elements,n=t.elements,r=this.elements,o=i[0],a=i[3],s=i[6],l=i[1],c=i[4],h=i[7],d=i[2],u=i[5],p=i[8],g=n[0],f=n[3],m=n[6],A=n[1],y=n[4],v=n[7],C=n[2],I=n[5],x=n[8];return r[0]=o*g+a*A+s*C,r[3]=o*f+a*y+s*I,r[6]=o*m+a*v+s*x,r[1]=l*g+c*A+h*C,r[4]=l*f+c*y+h*I,r[7]=l*m+c*v+h*x,r[2]=d*g+u*A+p*C,r[5]=d*f+u*y+p*I,r[8]=d*m+u*v+p*x,this},Kf.prototype.scale=function(e,t){var i=this.elements;return i[0]*=e,i[3]*=e,i[6]*=e,i[1]*=t,i[4]*=t,i[7]*=t,this},Kf.prototype.rotate=function(e){var t=Math.cos(e),i=Math.sin(e),n=this.elements,r=n[0],o=n[3],a=n[6],s=n[1],l=n[4],c=n[7];return n[0]=t*r+i*s,n[3]=t*o+i*l,n[6]=t*a+i*c,n[1]=-i*r+t*s,n[4]=-i*o+t*l,n[7]=-i*a+t*c,this},Kf.prototype.makeRotate=function(e){var t=Math.cos(e),i=Math.sin(e);return this.set(t,-i,0,i,t,0,0,0,1),this},Kf.prototype.translate=function(e,t){var i=this.elements;return i[0]+=e*i[2],i[3]+=e*i[5],i[6]+=e*i[8],i[1]+=t*i[2],i[4]+=t*i[5],i[7]+=t*i[8],this},Kf.prototype.makeShear=function(e,t){return this.set(1,t,0,e,1,0,0,0,1),this},Kf.prototype.fromCanvasTransform=function(e,t,i,n,r,o){return this.set(e,i,r,t,n,o,0,0,1),this},Kf.prototype.toCanvasTransform=function(){var e=this.elements;return[e[0],e[3],e[1],e[4],e[6],e[7]]},Kf.prototype.getInverse=function(e,t){e&&e.isMatrix4&&console.error("THREE.Matrix3: .getInverse() no longer takes a Matrix4 argument.");var i=e.elements,n=this.elements,r=i[0],o=i[1],a=i[2],s=i[3],l=i[4],c=i[5],h=i[6],d=i[7],u=i[8],p=u*l-c*d,g=c*h-u*s,f=d*s-l*h,m=r*p+o*g+a*f;if(0===m){var A="THREE.Matrix3: .getInverse() can't invert matrix, determinant is 0";if(!0===t)throw new Error(A);return console.warn(A),this.identity()}var y=1/m;return n[0]=p*y,n[1]=(a*d-u*o)*y,n[2]=(c*o-a*l)*y,n[3]=g*y,n[4]=(u*r-a*h)*y,n[5]=(a*s-c*r)*y,n[6]=f*y,n[7]=(o*h-d*r)*y,n[8]=(l*r-o*s)*y,this},Object.assign(Vf.prototype,{isPlane:!0,set:function(e,t){return this.normal.copy(e),this.constant=t,this},setComponents:function(e,t,i,n){return this.normal.set(e,t,i),this.constant=n,this},setFromNormalAndCoplanarPoint:function(e,t){return this.normal.copy(e),this.constant=-t.dot(this.normal),this},setFromCoplanarPoints:function(){var e=new Qu,t=new Qu;return function(i,n,r){var o=e.subVectors(r,n).cross(t.subVectors(i,n)).normalize();return this.setFromNormalAndCoplanarPoint(o,i),this}}(),clone:function(){return(new this.constructor).copy(this)},copy:function(e){return this.normal.copy(e.normal),this.constant=e.constant,this},normalize:function(){var e=1/this.normal.length();return this.normal.multiplyScalar(e),this.constant*=e,this},negate:function(){return this.constant*=-1,this.normal.negate(),this},distanceToPoint:function(e){return this.normal.dot(e)+this.constant},distanceToSphere:function(e){return this.distanceToPoint(e.center)-e.radius},projectPoint:function(e,t){return void 0===t&&(console.warn("THREE.Plane: .projectPoint() target is now required"),t=new Qu),t.copy(this.normal).multiplyScalar(-this.distanceToPoint(e)).add(e)},intersectLine:function(){var e=new Qu;return function(t,i){void 0===i&&(console.warn("THREE.Plane: .intersectLine() target is now required"),i=new Qu);var n=t.delta(e),r=this.normal.dot(n);if(0===r)return 0===this.distanceToPoint(t.start)?i.copy(t.start):void 0;var o=-(t.start.dot(this.normal)+this.constant)/r;return 0>o||o>1?void 0:i.copy(n).multiplyScalar(o).add(t.start)}}(),intersectsLine:function(e){var t=this.distanceToPoint(e.start),i=this.distanceToPoint(e.end);return 0>t&&i>0||0>i&&t>0},intersectsBox:function(e){return e.intersectsPlane(this)},intersectsSphere:function(e){return e.intersectsPlane(this)},coplanarPoint:function(e){return void 0===e&&(console.warn("THREE.Plane: .coplanarPoint() target is now required"),e=new Qu),e.copy(this.normal).multiplyScalar(-this.constant)},applyMatrix4:function(){var e=new Qu,t=new Kf;return function(i,n){var r=n||t.getNormalMatrix(i),o=this.coplanarPoint(e).applyMatrix4(i),a=this.normal.applyMatrix3(r).normalize();return this.constant=-o.dot(a),this}}(),translate:function(e){return this.constant-=e.dot(this.normal),this},equals:function(e){return e.normal.equals(this.normal)&&e.constant===this.constant}});var Yf=function(e,t){this._point=void 0,this._normal=void 0,this.viewer=t,this.svg=e;var i=document.createElementNS(gf,"polygon");i.setAttribute("fill","rgba(10,234,6,0.2)"),i.setAttribute("stroke","#0aea06"),i.setAttribute("stroke-width",1),i.style.pointerEvents="none",this._panel=i,this.hoverPanelSize={width:20,height:20}};Yf.prototype.setupWithPoint=function(e,t){this._point=e,this._normal=t},Yf.prototype.remove=function(){this.svg&&this._panel.parentNode&&this.svg.removeChild(this._panel)},Yf.prototype.add=function(){this.svg&&this._panel&&this.svg.appendChild(this._panel)},Yf.prototype.isVisible=function(){return!!this._panel.parentNode},Yf.prototype.stretchOnDirection=function(e,t,i){var n=e.clone().add(t).multiplyScalar(.5),r=t.clone().sub(e).normalize();return[n.clone().sub(r.clone().multiplyScalar(i/2)),n.clone().add(r.clone().multiplyScalar(i/2))]},Yf.prototype.draw=function(){var e=this.viewer.getScene().worldToDrawing(this._normal);e.normalize();var t=this.viewer.worldToClient(this._point),i=this.viewer.getScene().worldToDrawing(this._point),n=this.viewer.cameraControl,r=new Vf;r.setFromNormalAndCoplanarPoint(e,i);var o=new Gf(t.x-10,t.y-10),a=new Gf(t.x+10,t.y-10),s=i,l=n.getRaycaster(o.x,o.y),c=new Qu,h=new Qu;if(l.ray.intersectPlane(r,c),(l=n.getRaycaster(a.x,a.y)).ray.intersectPlane(r,h),null!==c&&null!==h){var d=new Qu(1,0,0),u=new Qu(0,0,1),p=new Qu(0,1,0),g=.0025>=Math.abs(e.clone().dot(d)),f=.0025>=Math.abs(e.clone().dot(p));if(g&&f)var m=d.clone(),A=p.clone();else m=u.clone().cross(e).normalize(),A=e.clone().cross(m).normalize();var y=c.distanceTo(h)/2,v=m.clone().multiplyScalar(y),C=A.clone().multiplyScalar(y),I=s.clone().sub(v).add(C),x=s.clone().add(v).add(C),w=s.clone().sub(v).sub(C),M=s.clone().add(v).sub(C),E=[];E.push(I,x,M,w);for(var B=[],S=n.getContainerDimensions(),b=0;E.length>b;b+=1){var k=new Qu(E[b].x,E[b].y,E[b].z);k.project(n.camera);var D={x:0,y:0,z:0};D.x=Math.floor(.5*(k.x+1)*S.width+.5),D.y=Math.floor(-.5*(k.y-1)*S.height+.5),D.z=k.z||0,B.push(new Qu(D.x,D.y,0))}var T=this.hoverPanelSize,R=B[0].distanceTo(B[1]),U=B[0].distanceTo(B[3])/T.height;if(1!==R/T.width){var F=this.stretchOnDirection(B[0],B[1],T.width),Q=this.stretchOnDirection(B[2],B[3],T.width);B=F.concat(Q)}if(1!==U){F=this.stretchOnDirection(B[0],B[3],T.height),Q=this.stretchOnDirection(B[1],B[2],T.height);B=[F[0],Q[0],Q[1],F[1]]}for(var L="",O=0;B.length>O;O+=1)L+=B[O].x+",",L+=B[O].y+" ";this._panel.setAttribute("points",L)}};var Hf=function(e){this._point=void 0,this.svg=e;var t=yf(5);t.setAttributeNS(null,"fill","#00ff00"),this._circle=t};Hf.prototype.setupWithPoint=function(e){e&&(this._point=e)},Hf.prototype.remove=function(){this.svg&&this._circle.parentNode&&this.svg.removeChild(this._circle)},Hf.prototype.add=function(){this.svg&&this._circle&&this.svg.appendChild(this._circle)},Hf.prototype.isVisible=function(){return!!this._circle.parentNode},Hf.prototype.draw=function(e){if(this._point){var t=e(this._point);this._circle.setAttributeNS(null,"cx",t[0]),this._circle.setAttributeNS(null,"cy",t[1])}};var jf=function(e){kf.call(this,e),this.volumeText=new Df,this.volumeText.textBackgroundColor="#009bff",this.svgGroup.appendChild(this.volumeText.group);var t=this;this.volumeText.setClickCallback((function(){t.onclickCallback&&t.onclickCallback(t)})),this.pickedComponentKeys=[],this._position=void 0,this._volume=void 0};(jf.prototype=Object.assign(Object.create(kf.prototype),{constructor:jf})).setData=function(e,t,i){this._position=e,this._volume=t,i&&(this.unitOfModel=this.unitOfModel&&this.unitOfModel!==i?void 0:i)},jf.prototype.isDone=function(){return this.pickedComponentKeys[0]&&this._position},jf.prototype.draw=function(e,t){if(this.svgGroup.parentNode&&this.isDone()){var i=this._position;t&&(i=t(i)),this.volumeText.setPosition(i[0],i[1]),this.updateTexts()}},jf.prototype.measureResult=function(){if(this._volume)return this._volume},jf.prototype.resultToDisplayOfVolume=function(e){var t=e,i=this.unitOfModel;return this.adjustOption&&(t=this.adjustOption.adjustVolume(e),i=this.adjustOption.unit),this.unitOnUI&&(i&&(t=Bf(i,this.unitOnUI,t,3)),i=this.unitOnUI),i||(i=""),t=t.toFixed(this.precision),"mm"===i?i="mm³":"m"===i?i="m³":"cm"===i&&(i="cm³"),{value:Number(t),unit:i,text:t+i}},jf.prototype.updateTexts=function(){this._volume&&(this.volumeText.setText(this.resultToDisplayOfVolume(this._volume).text,void 0),this.volumeText.draw())},jf.prototype.setSelected=function(e){kf.prototype.setSelected.call(this,e)&&(e?(this.volumeText.isShowShadow=!0,this.volumeText.textBackgroundColor="#ffffff",this.volumeText.textColor="#009bff",this.volumeText.draw()):(this.volumeText.isShowShadow=!1,this.volumeText.textBackgroundColor="#009bff",this.volumeText.textColor="#ffffff",this.volumeText.draw()))};var Wf=function(){this.pointTransformer=void 0,this.parentDom=void 0,this.viewer=void 0,this.is3DMode=!1,this.isMobile=!1},Jf="Distance",zf="Angle",qf="Adjust",Zf="Area",Xf="MinDistance",_f="Volume",$f=function(e){this.config=e,this.config.viewer.measure=this,this.svg=this._createSVG(e.parentDom.clientWidth,e.parentDom.clientHeight),e.parentDom.appendChild(this.svg),this._resize=this._resize.bind(this),this.config.viewer.addEventListener("resize",this._resize),this.setCurrentMode(Jf),this.isOpen=!1,this.didEndMeasureCallback=void 0,this._items=[],this._adjustItem=void 0,this._adjustOption=void 0,this._precision=3,this._unitSetByUser="mm",this._pickedLine=void 0,this._pickedPoint=void 0,this._pickedPanel=void 0,this._selectedItem=void 0,this.open()};$f.prototype.supportUnits=function(){return[{unit:"mm",title:"毫米"},{unit:"cm",title:"厘米"},{unit:"m",title:"米"}]},$f.prototype.open=function(){this.isOpen||(this.isOpen=!0,this._handleKeyUp=this._handleKeyUp.bind(this),document.addEventListener("keyup",this._handleKeyUp))},$f.prototype.close=function(){this.svg.parentNode.removeChild(this.svg),this.isOpen=!1,this.config.is3DMode&&(this.config.viewer.clearSelection(),this.config.viewer.render()),this.config.viewer.measure=void 0,document.removeEventListener("keyup",this._handleKeyUp),this.config.viewer.removeEventListener("resize",this._resize)},$f.prototype.setCurrentMode=function(e){if(this.config.is3DMode||e!==_f&&e!==Xf)if(this._currentMode!==e&&(this._currentMode=e,this._currentMeasureItem&&(this._currentMeasureItem instanceof Lf&&this.config.is3DMode&&(this.config.viewer.clearSelection(),this.config.viewer.render()),this._currentMeasureItem.remove(),this._currentMeasureItem=void 0)),this._currentMode===qf){var t=this._adjustItem?this._adjustItem:this._currentMeasureItem;(t||t instanceof Tf)&&t.isDone()&&(t.add(),t.draw(void 0,this.config.pointTransformer),this.didEndMeasureCallback&&this.didEndMeasureCallback(t.measureResult()))}else this._adjustItem&&this._adjustItem.remove()},$f.prototype.getCurrentMode=function(){return this._currentMode},$f.prototype.getCurrentUnit=function(){return this._unitSetByUser},$f.prototype.setUnit=function(e){if(e&&this._unitSetByUser!==e){this._unitSetByUser=e;for(var t=0,i=this._items.length;i>t;t+=1){this._items[t].changeUnit(e)}this._adjustOption&&(this._adjustOption.valueAfterAdjust=Bf(this._adjustOption.unit,e,this._adjustOption.valueAfterAdjust,0),this._adjustOption.unit=e)}},$f.prototype.getCurrentPrecision=function(){return this._precision},$f.prototype.setPrecision=function(e){if(e&&this._precision!==e){this._precision=e;for(var t=0,i=this._items.length;i>t;t+=1){this._items[t].changePrecision(e)}this._adjustItem&&this._adjustItem.changePrecision(e)}},$f.prototype.clearAllMeasure=function(){for(var e=0,t=this._items.length;t>e;e+=1){this._items[e].remove()}this._items=[],this._selectedItem=void 0},$f.prototype.removeSelectedMeasure=function(){if(this._selectedItem){for(var e=0,t=this._items.length;t>e;e+=1)if(this._items[e]===this._selectedItem){this._selectedItem.remove(),this._items.splice(e,1);break}(this._selectedItem instanceof jf||this._selectedItem instanceof Lf)&&this.config.is3DMode&&(this.config.viewer.removeFromSelection(this._selectedItem.pickedComponentKeys||[]),this.config.viewer.render()),this._selectedItem=void 0,this._items.length>0&&(this._selectedItem=this._items[this._items.length-1],this._selectedItem.setSelected(!0))}},$f.prototype.setAdjustForCurrentAdjustItem=function(e,t){if(e&&t&&this._currentMode===qf&&(this._currentMeasureItem&&this._currentMeasureItem instanceof Tf&&this._currentMeasureItem.isDone()&&(this._adjustItem&&this._adjustItem.remove(),this._adjustItem=this._currentMeasureItem,this._currentMeasureItem=void 0),this._adjustItem&&this._adjustItem.isDone())){var i=new Rf;i.unit=e,i.valueBeforeAdjust=this._adjustItem.measureResult().distance,i.valueAfterAdjust=t,this._adjustOption=i;for(var n=0,r=this._items.length;r>n;n+=1){this._items[n].adjustWithOption(this._adjustOption)}this._adjustItem.adjustWithOption(this._adjustOption)}},$f.prototype.cancelCurrentAdjust=function(){if(this._adjustItem&&(this._adjustItem.remove(),this._adjustItem=void 0),this._currentMeasureItem instanceof Tf&&(this._currentMeasureItem.remove(),this._currentMeasureItem=void 0),this._adjustOption){for(var e=0,t=this._items.length;t>e;e+=1){this._items[e].unAdjustWithOption(this._adjustOption)}this._adjustOption=void 0}},$f.prototype.cancelCurrentMeasure=function(){!this._currentMeasureItem||this._currentMeasureItem instanceof Tf||(this._currentMeasureItem.remove(),this._currentMeasureItem=void 0)},$f.prototype.processIntersect=function(e){if(this.isOpen){if(!e)return this._hidePickedLine(),void this._hidePickedPoint();if(e.pickPoint){var t=[e.pickPoint.x,e.pickPoint.y,void 0===e.pickPoint.z?0:e.pickPoint.z],i=t;if(e.pick){if(this._currentMode===qf&&this._currentMeasureItem&&this._currentMeasureItem.isDone()&&(this._currentMeasureItem.remove(),this._currentMeasureItem=void 0),this._currentMeasureItem||this._createNewItem(),!this._currentMeasureItem)return;if(this._currentMeasureItem instanceof Lf){var n=this._currentMeasureItem.pickedComponentKeys;if(n.push(e.userId),2===n.length){var r=this.config.viewer.calculateMinDistance(n[0],n[1]);if(r&&r.start&&r.end)this._currentMeasureItem.setData([[r.start.x,r.start.y,r.start.z],[r.end.x,r.end.y,r.end.z]],r.minDistance,e.measureUnit),this._currentMeasureItem.draw(void 0,this.config.pointTransformer);else this._currentMeasureItem=void 0}this.config.viewer.addToSelection(n),this.config.viewer.render()}else if(this._currentMeasureItem instanceof jf){var o=this._currentMeasureItem.pickedComponentKeys;if(0===o.length){o.push(e.userId);var a=this.config.viewer.calculateComponentVolume(o[0]);a&&(this._currentMeasureItem.setData(a.position,a.volume,e.measureUnit),this._currentMeasureItem.draw(void 0,this.config.pointTransformer)),this.config.viewer.addToSelection(o),this.config.viewer.render()}}else i=void 0,this._currentMeasureItem.addPickedPoint(t,e.measureUnit,this.config.pointTransformer),this._currentMeasureItem.draw(i,this.config.pointTransformer);if(this._currentMeasureItem&&this._currentMeasureItem.isDone()){this._currentMeasureItem instanceof Tf||!this._adjustOption||this._currentMeasureItem.adjustWithOption(this._adjustOption);var s=this._currentMeasureItem.measureResult();this._currentMeasureItem instanceof Tf||(this._items.push(this._currentMeasureItem),this._selectedItem&&(this._selectedItem.setSelected(!1),this._selectedItem=void 0),this._selectedItem=this._currentMeasureItem,this._selectedItem.setSelected(!0),this._currentMeasureItem=void 0),this.didEndMeasureCallback&&this.didEndMeasureCallback(s)}}else this._currentMeasureItem&&this._currentMeasureItem.draw(i,this.config.pointTransformer)}this._currentMode!==Xf&&this._currentMode!==_f&&(e.pickPoint&&e.isAbsorbPoint?this._showPickedPoint(e.pickPoint):this._hidePickedPoint(),e.pickPlane?this._showPickedPanel(e.pickPoint,e.normal):this._hidePickedPanel(),e.pickLine?this._showPickedLine(e.pickLine[0],e.pickLine[1],e.measureUnit):this._hidePickedLine())}},$f.prototype.update=function(){if(this.isOpen){for(var e=0,t=this._items.length;t>e;e+=1){this._items[e].draw(void 0,this.config.pointTransformer)}this._currentMeasureItem&&this._currentMeasureItem.draw(void 0,this.config.pointTransformer),this._adjustItem&&this._adjustItem.draw(void 0,this.config.pointTransformer),this._pickedLine&&this._pickedLine.isVisible()&&this._pickedLine.draw(void 0,this.config.pointTransformer),this._pickedPanel&&this._pickedPanel.isVisible()&&this._pickedPanel.draw(this.config.pointTransformer)}},$f.prototype.changeSelect=function(){for(var e=0,t=this._items.length;t>e;e+=1){var i=this._items[e];i.setSelected(this._selectedItem===i)}},$f.prototype._resize=function(){this.svg.style.width=this.config.parentDom.clientWidth,this.svg.style.height=this.config.parentDom.clientHeight},$f.prototype._createNewItem=function(){switch(this._currentMode){case Jf:this._currentMeasureItem=new Qf(this.svg,this.config.isMobile,this._items.length+1);break;case zf:this._currentMeasureItem=new Uf(this.svg);break;case qf:this._currentMeasureItem=new Tf(this.svg);break;case Zf:this._currentMeasureItem=new Ff(this.svg);break;case Xf:this._currentMeasureItem=new Lf(this.svg);break;case _f:this._currentMeasureItem=new jf(this.svg)}if(this._currentMeasureItem){this._currentMeasureItem.is3DMode=this.config.is3DMode,this._currentMeasureItem instanceof Tf||(this._adjustOption&&this._currentMeasureItem.adjustWithOption(this._adjustOption),this._unitSetByUser&&this._currentMeasureItem.changeUnit(this._unitSetByUser)),this._currentMeasureItem.changePrecision(this._precision);var e=this;this._currentMeasureItem.setClickCallback((function(t){t.isDone()&&(e._selectedItem=t,e.changeSelect())}))}},$f.prototype._showPickedLine=function(e,t,i){var n=[e.x,e.y,void 0===e.z?0:e.z],r=[t.x,t.y,void 0===t.z?0:t.z];this._pickedLine||(this._pickedLine=new Of(this.svg),this._pickedLine.unitOfModel=i),this._adjustOption&&this._pickedLine.adjustWithOption(this._adjustOption),this._pickedLine.changeUnit(this._unitSetByUser?this._unitSetByUser:i),this._pickedLine.changePrecision(this._precision),this._pickedLine.add(),this._pickedLine.setData(n,r),this._pickedLine.draw(void 0,this.config.pointTransformer)},$f.prototype._hidePickedLine=function(){this._pickedLine&&this._pickedLine.remove()},$f.prototype._showPickedPoint=function(e){this._pickedPoint||(this._pickedPoint=new Hf(this.svg)),this._pickedPoint.add(),this._pickedPoint.setupWithPoint(e),this._pickedPoint.draw(this.config.pointTransformer)},$f.prototype._hidePickedPoint=function(){this._pickedPoint&&this._pickedPoint.remove()},$f.prototype._showPickedPanel=function(e,t){this._pickedPanel||(this._pickedPanel=new Yf(this.svg,this.config.viewer)),this._pickedPanel.add(),this._pickedPanel.setupWithPoint(e,t),this._pickedPanel.draw(this.config.pointTransformer)},$f.prototype._hidePickedPanel=function(){this._pickedPanel&&this._pickedPanel.remove()},$f.prototype._createSVG=function(e,t){var i=ff();return i.style.width=e+"px",i.style.height=t+"px",i.style.position="absolute",i.style.left="0",i.style.top="0",i},$f.prototype._handleKeyUp=function(e){var t=e.keyCode;27===t?this.cancelCurrentMeasure():46===t&&this.removeSelectedMeasure()};var em=function(e){Yg.call(this,Yd.PICK_BY_MEASURE),this.controlManager=e.controlManager,this.pickHelper=new pf(e.cameraControl),this.mouseDown=new ke,this.lastEvent=null,this.pick=!1,this.pickPoint=new Ke;var t=e.getRenderer().domElement.parentElement,i=new Wf;i.parentDom=t,i.pointTransformer=e.getScreenCoordFromSceneCoord.bind(e),i.viewer=e,i.is3DMode=!0,this.measure=new $f(i);var n=this;e.cameraControl.addEventListener(Fd.ON_CAMERA_CHANGE,(function(){n.measure.update()})),e.clearSelection()};(em.prototype=Object.create(Yg.prototype)).constructor=em,em.prototype.destroy=function(){Yg.prototype.destroy.call(this),this.controlManager=null,this.mouseDown=null,this.lastEvent=null,this.pickPoint=null,this.pickHelper.destroy(),this.pickHelper=null},em.prototype.processMouseDown=function(e){return!!og.isMobileDevice()||(e.button===n.LEFT?(this.mouseDown.x=e.clientX,this.mouseDown.y=e.clientY,!1):Yg.prototype.processMouseDown.call(this,e))},em.prototype.processMouseMove=function(e){return!1},em.prototype.processMouseUp=function(e){if(og.isMobileDevice())return!0;if(e.button===n.LEFT){if(2>=new ke(e.clientX,e.clientY).distanceTo(this.mouseDown)){var t=this.pickPoint.clone(),i=void 0;return i=e.shiftKey?this.pickHelper.handleShiftMeasure(e,!0,t):this.pickHelper.handleMouseMeasure(e,!0,t),this.measure.processIntersect(i),t.equals(this.pickPoint)||(this.pick=!this.pick,this.pickPoint.copy(t)),this.controlManager.isUpdateRenderList=!0,!0}return!0}return Yg.prototype.processMouseUp.call(this,e)},em.prototype.processKeyDown=function(e){return 16===e.keyCode||Yg.prototype.processKeyDown.call(this,e)},em.prototype.processHover=function(e){if(og.isMobileDevice())return!0;var t=void 0;return t=e.shiftKey?this.pickHelper.handleShiftMeasure(e,!1,this.pickPoint):this.pickHelper.handleMouseMeasure(e,!1,this.pickPoint),this.measure.processIntersect(t),!0},em.prototype.processTouchstart=function(e){return this.mouseDown.x=e.touches[0].clientX,this.mouseDown.y=e.touches[0].clientY,e.clientX=e.touches[0].clientX,e.clientY=e.touches[0].clientY,this.lastEvent=e,Yg.prototype.processTouchstart.call(this,e)},em.prototype.processTouchmove=function(e){return this.lastEvent=null,Yg.prototype.processTouchmove.call(this,e)},em.prototype.processTouchend=function(e){if(null!==this.lastEvent){var t=this.pickHelper.handleMouseMeasure(this.lastEvent,!0,this.pickPoint);this.measure.processIntersect(t),this.controlManager.isUpdateRenderList=!0}return Yg.prototype.processTouchend.call(this,e)},em.prototype.touchPointMove=function(e){this.measure.processIntersect(this.pickHelper.handleMouseMeasure(e,!1,this.pickPoint))},em.prototype.touchPointEnd=function(e){var t=this.pickPoint.clone(),i=this.pickHelper.handleMouseMeasure(e,!0,t);return this.measure.processIntersect(i),t.equals(this.pickPoint)||(this.pick=!this.pick,this.pickPoint.copy(t)),this.controlManager.isUpdateRenderList=!0,!0},em.prototype.onExit=function(e){this.measure.close();var t=this.pickHelper.scene;t.hasGroup(Vp.MEASUREPICKPLANE)&&t.removeGroupByName(Vp.MEASUREPICKPLANE)};var tm,im,nm,rm={pickByRect:function(e,t,i,n,r,o){var a=[],s=n.octantToObjectMap;e.getMatrixGlobal();var l=n.sceneState,c=new He;function h(e,i,n){e&&e.frustumIntersect(t,i,n)}var d=n.filter,u=d._hasVisibleFilter(),p=d._hasPickableFilter();if(i!==Td.Clear){var g,f,m=null,A=[];for(var y in s)if(s.hasOwnProperty(y)){var v=n.getModel(y);m=s[y];var C=v&&v.kdTreeNode,I=[];if(Array.isArray(C))for(var x=0,w=C.length;w>x;x+=1){var M=C[x],E=M.modelKey,B=(new yt).copy(v.getModelMatrix());E&&B.multiply(v.subModel[E]),h(M,I,B)}else C?h(C,I,v.getModelMatrix()):I=Object.keys(m.info);var S=Object.keys(v.manager.explosionList);v&&v.manager&&S.length>0&&(I=I.concat(S));for(var b=0,k=(A=wp.unique(I)).length;k>b;b+=1){var D=m.info[A[b]];if(D)for(var T=0,R=D.length;R>T;T+=1){var U=D[T];(f=void 0,f=n.isHiddenSourceObjectUserId((g=U).userId),u&&!d._isVisible(g)||p&&!d._isPickable(g)||f)||(c.copy(U.boundingBox),c.applyMatrix4(v.getModelMatrix()),this._intersectBox(t,c,o)&&!this._clipBox(r,c)&&a.push(U.userId))}}}return(a=a.concat(this.pickNonModelObjectsByRect(r,n,t,o))).length>0&&(Td.Remove===i?(l.removeSelection(a),n.dispatchEvent({type:Fd.ON_RECTPICK_REMOVE,list:a})):Td.Add===i&&(l.addSelection(a),n.dispatchEvent({type:Fd.ON_RECTPICK_ADD,list:a}))),a}l.clearSelection()},getObjectsInBox:function(e,t,i,n,r){var o={},a=i.octantToObjectMap;e.getMatrixGlobal();var s=new He;function l(e){for(var t=new Ke,i=0;8>i;i+=1)if(t.x=4>i?e.min.x:e.max.x,t.y=2>i/2?e.min.y:e.max.y,t.z=i%2==0?e.min.z:e.max.z,!n.clipPoint(t))return!1;return!0}function c(e){return r?!(t.min.x>e.min.x||e.max.x>t.max.x||t.min.y>e.min.y||e.max.y>t.max.y||t.min.z>e.min.z||e.max.z>t.max.z):!(t.min.x>e.max.x||e.min.x>t.max.x||t.min.y>e.max.y||e.min.y>t.max.y||t.min.z>e.max.z||e.min.z>t.max.z)}function h(e){return Boolean(!(t.max.x>e.max.x||e.min.x>t.min.x||t.max.y>e.max.y||e.min.y>t.min.y||t.max.z>e.max.z||e.min.z>t.min.z))}var d=i.filter,u=d._hasVisibleFilter(),p=d._hasPickableFilter();var g,f,m=null;for(var A in a)if(a.hasOwnProperty(A)){var y=i.getModel(A);for(var v in(m=a[A]).info)if(m.info.hasOwnProperty(v)){var C=m.info[v];if(!C)continue;for(var I=0,x=C.length;x>I;I+=1){var w=C[I];(f=void 0,f=i.isHiddenSourceObjectUserId((g=w).userId),u&&!d._isVisible(g)||p&&!d._isPickable(g)||f)||(s.copy(w.boundingBox),s.applyMatrix4(y.getModelMatrix()),!c(s)||h(s)||l(s)||(o[w.userId]=!0))}}}var M=[];for(var E in o)M.push(E);return M},pickNonModelObjectsByRect:function(e,t,i,n){var r=[],o=t.getNodeInfosInPlugins(),a=new He;for(var s in o)if(o.hasOwnProperty(s)){var l=o[s];for(var s in l)if(l.hasOwnProperty(s)){var c=l[s][0].mesh;if(c){c instanceof Array||(c=[c]),a.empty();for(var h=0,d=c.length;d>h;h+=1){var u=c[h];u instanceof Yt&&a.expandByObject(u)}this._intersectBox(i,a,n)&&!this._clipBox(e,a)&&r.push(s)}}}return r},_intersectBox:(im=new Ke,nm=new Ke,function(e,t,i){for(var n=0,r=e.planes,o=0;6>o;o+=1){var a=r[o];im.x=a.normal.x>0?t.min.x:t.max.x,nm.x=a.normal.x>0?t.max.x:t.min.x,im.y=a.normal.y>0?t.min.y:t.max.y,nm.y=a.normal.y>0?t.max.y:t.min.y,im.z=a.normal.z>0?t.min.z:t.max.z,nm.z=a.normal.z>0?t.max.z:t.min.z;var s=a.distanceToPoint(im),l=a.distanceToPoint(nm);if(0>s&&0>l)return!1;0>s*l||(n+=1)}return i?n>=2:6===n}),_clipBox:(tm=new Ke,function(e,t){for(var i=0;8>i;i+=1)if(tm.x=4>i?t.min.x:t.max.x,tm.y=2>i/2?t.min.y:t.max.y,tm.z=i%2==0?t.min.z:t.max.z,!e.clipPoint(tm))return!1;return!0})},om=function(e,t,i){Yg.call(this,e),this.cameraControl=t,this.frustum=new yn,this.startPt=new ke,this.endPt=new ke,this.eventDispatcher=i};(om.prototype=Object.create(Yg.prototype)).constructor=om,om.prototype.destroy=function(e){Yg.prototype.destroy.call(this),this.cameraControl=null,this.frustum=null,this.startPt=null,this.endPt=null,this.eventDispatcher=null},om.prototype.onUpdateUI=function(e){this.eventDispatcher.dispatchEvent({type:Fd.ON_CONTROL_UPDATEUI,data:e,control:this.name})},om.prototype.updateFrustum=function(e,t){var i=this.startPt.x,n=this.endPt.x,r=this.startPt.y,o=this.endPt.y;if(i>n){var a=i;i=n,n=a}if(r>o){var s=r;r=o,o=s}if(n-i==0||o-r==0)return!1;var l=this.cameraControl,c=l.getContainerDimensions();return e&&l.computeFrustum(i,n,r,o,this.frustum,c),t&&this.onUpdateUI({visible:!0,dir:this.endPt.x>this.startPt.x,left:i-c.left,top:r-c.top,width:n-i,height:o-r}),!0};var am=function(e){om.call(this,Yd.PICK_BY_RECT,e.cameraControl,e.modelManager),this.viewer=e,this.scene=e.getScene(),this.pickHelper=new pf(this.cameraControl),this.activatePick=!1,this.pressKey="",this.pickPoint=new Ke,this.snapIsEnabled=!1};(am.prototype=Object.create(om.prototype)).constructor=am,am.prototype.destroy=function(){om.prototype.destroy.call(this),this.pickHelper.destroy(),this.pickHelper=null,this.viewer=null,this.scene=null,this.pickPoint=null},am.prototype.setPressKey=function(e){this.pressKey=e},am.prototype.processMouseDown=function(e){return e.preventDefault(),this.activatePick=e.ctrlKey||e.altKey,this.activatePick&&e.button===n.LEFT?(this.startPt.set(e.clientX,e.clientY),!0):om.prototype.processMouseDown(this,e)},am.prototype.processMouseMove=function(e){return this.activatePick&&e.button===n.LEFT?(this.endPt.set(e.clientX,e.clientY),this.updateFrustum(!1,!0),!0):om.prototype.processMouseMove(this,e)},am.prototype.processMouseUp=function(e){if(this.onUpdateUI({visible:!1}),this.activatePick&&e.button===n.LEFT){if(this.activatePick=!1,2>Math.abs(this.startPt.x-e.clientX)&&2>Math.abs(this.startPt.y-e.clientY))return this.pickHelper.click(e,null),!0;if(this.endPt.set(e.clientX,e.clientY),!this.updateFrustum(!0,!1))return this.pickHelper.click(e),!0;var t=Td.Clear,i=this.pressKey||e.ctrlKey&&"ctrl"||e.altKey&&"alt"||"";return"ctrl"===i?t=Td.Add:"alt"===i&&(t=Td.Remove),rm.pickByRect(this.scene,this.frustum,t,this.cameraControl.viewer.modelManager,this.viewer,this.startPt.x>this.endPt.x),this.pickHelper.lastPickedUserId="",this.cameraControl.updateView(!0),!0}return om.prototype.processMouseUp(this,e)},am.prototype.processTouchstart=function(e){return e.preventDefault(),this.pressKey?(this.startPt.set(e.changedTouches[0].pageX,e.changedTouches[0].pageY),!0):om.prototype.processTouchstart(this,e)},am.prototype.processTouchmove=function(e){return this.pressKey?(this.endPt.set(e.changedTouches[0].pageX,e.changedTouches[0].pageY),this.updateFrustum(!1,!0),!0):om.prototype.processMouseMove(this,e)},am.prototype.processTouchend=function(e){this.onUpdateUI({visible:!1});var t=e.changedTouches[0].pageX,i=e.changedTouches[0].pageY;if(this.pressKey){if(2>Math.abs(this.startPt.x-t)&&2>Math.abs(this.startPt.y-i))return this.pickHelper.click(e,null),!0;if(this.endPt.set(t,i),!this.updateFrustum(!0,!1))return this.pickHelper.click(e),!0;var n=Td.Clear,r=this.pressKey;return"ctrl"===r?n=Td.Add:"alt"===r&&(n=Td.Remove),rm.pickByRect(this.scene,this.frustum,n,this.cameraControl.viewer.modelManager,this.viewer,this.startPt.x>this.endPt.x),this.pickHelper.lastPickedUserId="",this.cameraControl.updateView(!0),!0}return om.prototype.processTouchend(this,e)},am.prototype.processHover=function(e){if(this.snapIsEnabled)return xd.IsMobile||this.pickHelper.handleMouseMeasure(e,!1,this.pickPoint,Fd.ON_HOVER_SNAP),!0},am.prototype.enableSnap=function(e){this.snapIsEnabled=e};var sm=function(e){om.call(this,Yd.ZOOM_BY_RECT,e.cameraControl,e.modelManager),this.scene=e.getScene(),this.activateZoom=!1};function lm(e,t){var i,n=vu(Reflect.ownKeys(t));try{for(n.s();!(i=n.n()).done;){var r=i.value;if("constructor"!==r&&"prototype"!==r&&"name"!==r){var o=Object.getOwnPropertyDescriptor(t,r);Object.defineProperty(e,r,o)}}}catch(e){n.e(e)}finally{n.f()}}(sm.prototype=Object.create(om.prototype)).constructor=sm,sm.prototype.destroy=function(){om.prototype.destroy.call(this),this.scene=null},sm.prototype.processMouseDown=function(e){return e.button===n.LEFT?(this.startPt.set(e.clientX,e.clientY),this.activateZoom=!0,!0):om.prototype.processMouseDown.call(this,e)},sm.prototype.processMouseMove=function(e){return this.activateZoom?(this.endPt.set(e.clientX,e.clientY),this.updateFrustum(!1,!0),!0):om.prototype.processMouseMove.call(this,e)},sm.prototype.processMouseUp=function(e){return this.activateZoom?(this.activateZoom=!1,this.onUpdateUI({visible:!1}),this.endPt.set(e.clientX,e.clientY),this.updateFrustum(!0,!1)&&this.zoomToRectangle(),!0):om.prototype.processMouseUp.call(this,e)},sm.prototype.zoomToRectangle=function(){var e=this.cameraControl.camera,t=this.cameraControl.camera.target,i=this.cameraControl.getContainerDimensions(),n=this.startPt.x,r=this.startPt.y,o=this.endPt.x,a=this.endPt.y,s=Math.abs(o-n),l=Math.abs(r-a);if(0!==s&&0!==l){var c=new ke((n+o)/2,(r+a)/2),h=e.position.clone(),d=t.clone().sub(h),u=d.length(),p=0,g=this.cameraControl.getIntersectContext(c),f=this.cameraControl.intersector.hitTest(g);if(f){var m=s/l>i.width/i.height?s/i.width:l/i.height,A=f.distanceTo(h)*m;d.normalize(),p=d.clone().negate().multiplyScalar(A)}else{var y={};y.left=Math.min(n,o),y.top=Math.min(r,a),y.right=Math.max(n,o),y.bottom=Math.max(r,a);var v=this.scene.getNearDepthByRect(this.frustum,e);if(v===1/0)return;var C=new Ke((n+o)/2,(r+a)/2,v),I=new Ke(y.left,y.top,v),x=this.clientToWorld(C),w=this.clientToWorld(I),M=x.clone().sub(w).length();f=x.clone(),d.normalize(),p=d.clone().negate().multiplyScalar(M)}h=f.clone().add(p),e.position.copy(h),t.copy(h).sub(p.clone().normalize().multiplyScalar(u)),this.cameraControl.updateView(!0)}},sm.prototype.worldToClient=function(e){var t=this.cameraControl.camera,i=new Ke(e.x,e.y,e.z);return i.project(t),i},sm.prototype.clientToWorld=function(e){var t=this.cameraControl.getContainerDimensions(),i=this.cameraControl.camera,n=new Ke;return n.x=e.x/t.width*2-1,n.y=-e.y/t.height*2+1,n.z=e.z,n.unproject(i),n};var cm=function(e){lu(i,e);var t=pu(i);function i(e,n){var r;ru(this,i),r=t.call(this);var o={priority:5,pickableType:Rd.UnPickable,globalSpace:!1,hoverEnabled:!1};r.name=e;var a=wp.extend({},o,n);return r.priority=a.priority,r.pickableType=a.pickableType,r.globalSpace=a.globalSpace,r.boundingBox=null,r.hoverEnabled=a.hoverEnabled,r}return au(i,[{key:"removeByName",value:function(e){for(var t=this.children,i=0,n=t.length;n>i;i+=1)if(t[i].name===e){t.splice(i,1);break}}},{key:"clear",value:function(){this.children.length=0}},{key:"isGlobalSpace",value:function(){return this.globalSpace}},{key:"hasChild",value:function(e){for(var t=0,i=this.children.length;i>t;t+=1)if(this.children[t].name===e)return!0;return!1}},{key:"isPickable",value:function(){return this.pickableType!==Rd.UnPickable}}]),i}(function(){for(var e=arguments.length,t=new Array(e),i=0;e>i;i++)t[i]=arguments[i];for(var n=function(){function e(){ru(this,e);for(var i=arguments.length,n=new Array(i),r=0;i>r;r++)n[r]=arguments[r];var o,a=vu(t);try{for(a.s();!(o=a.n()).done;){var s=o.value;lm(this,new s(n))}}catch(e){a.e(e)}finally{a.f()}}return au(e,[{key:"updateFixedFrame",value:function(e,t){for(var i=this.children,n=i.length,r=0;n>r;r+=1){var o=i[r];jg(o.updateFixedFrame)&&o.updateFixedFrame(e,t)}}}]),e}(),r=0,o=t;o.length>r;r++){var a=o[r];lm(n,a),lm(n.prototype,a.prototype)}return n}(Yt,hg)),hm=function(e){lu(i,e);var t=pu(i);function i(e){var n;ru(this,i),e=e||{},(n=t.call(this,Vp.VIEWSHED,{priority:20}))._position=new Ke(0,0,0),n._direction=new Ke(0,0,-1),n._visibleAreaColor=new Le(0,255,0,.8),n._hiddenAreaColor=new Le(255,0,0,.8),n._distance=null!=e.distance?e.distance:200,n._horizontalFov=null!=e.horizontalFov?e.horizontalFov:2*Math.PI/3,n._verticalFov=null!=e.verticalFov?e.verticalFov:Math.PI/2,n._up=new Ke(0,1,0),n._right=new Ke(1,0,0),n._unitAngle=5,n._cornerLeftTop=new Ke,n._cornerRightTop=new Ke,n._cornerLeftBottom=new Ke,n._cornerRightBottom=new Ke,n._viewer=null,n._lineGeometry=new Ni,n._lineMaterial=new Sa({color:16777215}),n._lineMesh=new La(n._lineGeometry,n._lineMaterial),n.camera=new dn,n.viewMatrix=new yt,n.viewProjMatrix=new yt,n.depthRenderTarget=new Oe(1024,1024,{minFilter:C,magFilter:C});var r=new Ke;n.updateViewMatrix=function(){r.copy(this._position),r.add(this._direction),this.camera.position.copy(this._position),this.camera.lookAt(r),this.camera.updateMatrixWorld(!0),this.viewMatrix.copy(this.camera.matrixWorld).invert()};var o=new Ke;n.updateProjMatrix=function(){var e=Math.cos(this._horizontalFov/2),t=Math.tan(this._verticalFov/2),i=Math.atan(e*t),n=this._distance*Math.cos(i)*Math.cos(this._horizontalFov/2);o.copy(this._position),o.addScaledVector(this._direction,n);var r=n*Math.tan(this._horizontalFov/2),a=n*Math.tan(this._verticalFov/2);this._cornerLeftTop.copy(o),this._cornerLeftTop.addScaledVector(this._right,-r),this._cornerLeftTop.addScaledVector(this._up,a),this._cornerRightTop.copy(o),this._cornerRightTop.addScaledVector(this._right,r),this._cornerRightTop.addScaledVector(this._up,a),this._cornerLeftBottom.copy(o),this._cornerLeftBottom.addScaledVector(this._right,-r),this._cornerLeftBottom.addScaledVector(this._up,-a),this._cornerRightBottom.copy(o),this._cornerRightBottom.addScaledVector(this._right,r),this._cornerRightBottom.addScaledVector(this._up,-a);var s=Math.tan(.5*this._horizontalFov)/Math.tan(.5*this._verticalFov);this.camera.fov=be.radToDeg(this._verticalFov),this.camera.aspect=s,this.camera.near=.01,this.camera.far=this._distance,this.camera.updateProjectionMatrix()},n.getViewProjMatrix=function(){return this.viewProjMatrix.multiplyMatrices(this.camera.projectionMatrix,this.viewMatrix),this.viewProjMatrix},n.createSideLines=function(){for(var e=[],t=[this._cornerLeftBottom,this._cornerRightBottom,this._cornerRightTop,this._cornerLeftTop],i=0;t.length>i;i+=1)e.push(this._position.x,this._position.y,this._position.z),e.push(t[i].x,t[i].y,t[i].z);return e};var a=new Ke,s=new Ke,l=new Ke,c=new Ke,h=[],d=du(n);n.createTopSideLines=function(){var e=[];function t(e,t,i){var n=[];if(i){for(var r=e;t>r;)if(n.push(r),(r+=d._unitAngle)>=t){n.push(t);break}}else for(r=t;r>e;)if(n.push(r),e>=(r-=d._unitAngle)){n.push(e);break}return n}a.copy(this._cornerLeftTop),a.sub(this._position),s.copy(this._cornerRightTop),s.sub(this._position),l.copy(this._cornerRightBottom),l.sub(this._position);var i,n,r=be.radToDeg(s.angleTo(l)),o=be.radToDeg(a.angleTo(s)),u=[{axis:"up",outerAngle:-this._horizontalFov/2,innerAngles:t(-r/2,r/2,!0)},{axis:"right",outerAngle:this._verticalFov/2,innerAngles:t(-o/2,o/2,!0)},{axis:"up",outerAngle:this._horizontalFov/2,innerAngles:t(-r/2,r/2,!1)},{axis:"right",outerAngle:-this._verticalFov/2,innerAngles:t(-o/2,o/2,!1)}];h=[];for(var p=0;u.length>p;p+=1){"up"==u[p].axis?(i=this._up,n=this._right):"right"==u[p].axis&&(i=this._right,n=this._up);for(var g=[],f=0;u[p].innerAngles.length>f;f+=1){c.copy(this._direction),c.applyAxisAngle(n,be.degToRad(u[p].innerAngles[f])),c.applyAxisAngle(i,u[p].outerAngle),c.multiplyScalar(this._distance);var m=new Ke;m.copy(this._position),m.add(c),g.push(m),h.push(m)}for(f=0;g.length-1>f;f+=1)e.push(g[f].x,g[f].y,g[f].z),e.push(g[f+1].x,g[f+1].y,g[f+1].z)}return e};var u=new Ke,p=new Ke,g=new Ke,f=new Ke,m=new Ge;n.createTopLines=function(){var e=[];u.copy(this._position),u.addScaledVector(this._direction,this._distance),p.copy(u),p.sub(this._position),p.normalize();for(var t=[],i=0,n=0;h.length>n;n+=1){f.copy(h[n]),f.sub(this._position),f.normalize(),g.copy(p),g.cross(f),g.normalize();for(var r=be.radToDeg(p.angleTo(f)),o=[],a=0;;a+=this._unitAngle){r>a||(a=r),m.setFromAxisAngle(g,be.degToRad(a)),c.copy(p),c.applyQuaternion(m);var s=new Ke;if(s.copy(this._position),s.addScaledVector(c,this._distance),o.push(s),a>=r)break}i=Math.max(i,o.length),t.push(o)}for(n=0;t.length>n;n+=1)for(a=0;t[n].length-1>a;a+=1)e.push(t[n][a].x,t[n][a].y,t[n][a].z),e.push(t[n][a+1].x,t[n][a+1].y,t[n][a+1].z);for(n=1;i>n;n+=1)for(a=0;t.length-1>a;a+=1)t[a][n]&&t[a+1][n]&&(e.push(t[a][n].x,t[a][n].y,t[a][n].z),e.push(t[a+1][n].x,t[a+1][n].y,t[a+1][n].z));return e},n.updateMeshGeometry=function(){this.updateViewMatrix(),this.updateProjMatrix();var e=[];return e=(e=(e=e.concat(this.createSideLines())).concat(this.createTopSideLines())).concat(this.createTopLines()),this._lineGeometry.deleteAttribute("position"),this._lineGeometry.setAttribute("position",new Ai(new Float32Array(e),3)),this._lineGeometry},n.initPrimitive=function(){this.updateMeshGeometry(),this._lineMesh.geometry=this._lineGeometry,this.add(this._lineMesh)},n.updatePrimitive=function(){this.updateMeshGeometry(),this._lineMesh.geometry=this._lineGeometry},i.prototype.getId=function(){return this.uuid};var A={x:0,y:0,z:0};i.prototype.getPositon=function(){return A.x=this._position.x,A.y=this._position.y,A.z=this._position.z,A};var y=new Ke;i.prototype.setPosition=function(e){y.x=e.x,y.y=e.y,y.z=e.z,this._position!=y&&(this._position.copy(y),this.updatePrimitive())};var v={x:0,y:0,z:0};i.prototype.getDirection=function(){return v.x=this._direction.x,v.y=this._direction.y,v.z=this._direction.z,v};var I=new Ke(0,1,0),x=new Ke;i.prototype.setDirection=function(e){x.x=e.x,x.y=e.y,x.z=e.z,x.normalize(),this._direction!==x&&(0!==x.lengthSq()?(this._direction.copy(x),this._right.crossVectors(I,x),0===this._right.lengthSq()&&(1===Math.abs(I.z)?x.x+=1e-4:x.z+=1e-4,x.normalize(),this._right.crossVectors(I,x)),this._right.normalize(),this._up.crossVectors(x,this._right),this.updatePrimitive()):Bu.warn("WARNING: Invalid direction when Viewshed.prototype.setDirection()"))};var w={x:0,y:0,z:0,w:0};i.prototype.getVisibleAreaColor=function(){return w.x=this._visibleAreaColor.x,w.y=this._visibleAreaColor.y,w.z=this._visibleAreaColor.z,w.w=this._visibleAreaColor.w,w};var M=new Le;i.prototype.setVisibleAreaColor=function(e){M.x=e.red||e.x?e.red||e.x:0,M.y=e.green||e.y?e.green||e.y:0,M.z=e.blue||e.z?e.blue||e.z:0,M.w=e.alpha||e.w?e.alpha||e.w:0,this._visibleAreaColor!=M&&(this._visibleAreaColor.copy(M),this.updatePrimitive())};var E={x:0,y:0,z:0,w:0};i.prototype.getHiddenAreaColor=function(){return E.x=this._hiddenAreaColor.x,E.y=this._hiddenAreaColor.y,E.z=this._hiddenAreaColor.z,E.w=this._hiddenAreaColor.w,E};var B=new Le;return i.prototype.setHiddenAreaColor=function(e){B.x=e.red||e.x?e.red||e.x:0,B.y=e.green||e.y?e.green||e.y:0,B.z=e.blue||e.z?e.blue||e.z:0,B.w=e.alpha||e.w?e.alpha||e.w:0,this._hiddenAreaColor!=B&&(this._hiddenAreaColor.copy(B),this.updatePrimitive())},i.prototype.getDistance=function(){return this._distance},i.prototype.setDistance=function(e){this._distance!=e&&(this._distance=e,this.updatePrimitive())},i.prototype.getHorizontalFov=function(){return this._horizontalFov},i.prototype.setHorizontalFov=function(e){this._horizontalFov!=e&&(this._horizontalFov=e,this.updatePrimitive())},i.prototype.getVerticalFov=function(){return this._verticalFov},i.prototype.setVerticalFov=function(e){this._verticalFov!=e&&(this._verticalFov=e,this.updatePrimitive())},i.prototype.show=function(){this.visible=!0,this._viewer&&this._viewer.viewshedManager.update()},i.prototype.hide=function(){this.visible=!1,this._viewer&&this._viewer.viewshedManager.update()},n.setPosition(null!=e.position?e.position:n._position),n.setDirection(null!=e.direction?e.direction:n._direction),n.setVisibleAreaColor(null!=e.visibleAreaColor?e.visibleAreaColor:n._visibleAreaColor),n.setHiddenAreaColor(null!=e.hiddenAreaColor?e.hiddenAreaColor:n._hiddenAreaColor),n.initPrimitive(),n}return i}(cm),dm=function(e){lu(i,e);var t=pu(i);function i(e){var n;return ru(this,i),(n=t.call(this,Yd.VIEW_SHED_ANALYSIS)).viewer=e,n.scene=e.getScene(),n.viewshed=new hm({position:new Ke(0,0,0),direction:new Ke(0,0,-1),distance:500,horizontalFov:2*Math.PI/3,verticalFov:Math.PI/2}),n.viewshed.show(),n.scene.objectGroups.add(n.viewshed),n}return au(i,[{key:"enable",value:function(e){e?this.viewshed.show():this.viewshed.hide()}},{key:"destroy",value:function(){}},{key:"onEnter",value:function(){this.enable(!0)}},{key:"onExit",value:function(){this.enable(!1)}},{key:"processMouseDown",value:function(e){}},{key:"processHover",value:function(e){}},{key:"processMouseUp",value:function(e){}},{key:"processMouseMove",value:function(e){}},{key:"processTouchstart",value:function(e){}},{key:"processTouchmove",value:function(e){}},{key:"processTouchend",value:function(e){}}]),i}(Yg),um=function(){function e(t,i){ru(this,e),this.name=t,this.cameraControl=i,this.mouseButtons={ORBIT:n.LEFT,PAN2:n.MIDDLE,PAN:n.RIGHT},this.StateType={NONE:-1,ROTATE:0,DOLLY:1,PAN:2},this.state=this.StateType.NONE,this.zoomSpeed=Math.pow(.95,.2),this.defaultMovementSpeed=.005*xd.SceneSize,this.movementSpeed=this.defaultMovementSpeed,this.minMovementSpeed=.001,this.defaultKeyPanSpeed=2,this.keyPanSpeed=this.defaultKeyPanSpeed,this.minKeyPanSpeed=.01,this.wheelZoomFactor=45e-5,this.pointerLock=!1}return au(e,[{key:"getName",value:function(){return this.name}},{key:"destroy",value:function(){this.scene=null,this.cameraControl=null,this.mouseButtons=null,this.StateType=null}},{key:"onExit",value:function(){}},{key:"onEnter",value:function(){}},{key:"processMouseDown",value:function(e){}},{key:"processMouseMove",value:function(e){}},{key:"processMouseUp",value:function(e){}},{key:"processMouseWheel",value:function(e){}},{key:"processMouseDoubleClick",value:function(e){}},{key:"processKeyDown",value:function(e){}},{key:"processKeyUp",value:function(e){}},{key:"processTouchstart",value:function(e){}},{key:"processTouchmove",value:function(e){}},{key:"processTouchend",value:function(e){}},{key:"processHover",value:function(e){}},{key:"processMovement",value:function(e){}},{key:"processPointerLockEnter",value:function(e){}},{key:"processPointerLockExit",value:function(e){}},{key:"update",value:function(){}},{key:"moveTo",value:function(e,t,i){}},{key:"rotateTo",value:function(e){}},{key:"dispatchEvent",value:function(e){this.cameraControl.viewer.getControlManager().dispatchEvent(e)}},{key:"getDomElement",value:function(){return this.domElement}},{key:"getRendererDomElement",value:function(){return this.rendererDomElement}},{key:"updateButtons",value:function(e){void 0!==e.ORBIT&&(this.mouseButtons.ORBIT=e.ORBIT),void 0!==e.PAN&&(this.mouseButtons.PAN=e.PAN),void 0!==e.PAN2&&(this.mouseButtons.PAN2=e.PAN2),void 0!==e.ZOOM&&(this.mouseButtons.ZOOM=e.ZOOM)}},{key:"isUserInputControl",value:function(){return this.name===Vd.PAN||this.name===Vd.ZOOM||this.name===Vd.ORBIT}}]),e}(),pm=function(e){lu(i,e);var t=pu(i);function i(e){var n;return ru(this,i),(n=t.call(this,Vd.FLY,e)).lookSpeed=.001,n.constrainPitch=!0,n.pitchMin=be.degToRad(5)-.5*Math.PI,n.pitchMax=.5*Math.PI-n.pitchMin,n.pitchDeltaTotal=0,n.moveState=Hd.NONE,n.rotateStart=new ke,n.rotateEnd=new ke,n.rotateDelta=new ke,n._panStart=new ke,n._panEnd=new ke,n._panDelta=new ke,n._pan=new Ke,n._worldDimension=new ke,n.lastMousePoint=new ke,n.isLockHeight=!1,n.lockedHeight=0,n.pickHelper=new pf(e),n.intersectOfMouseDown=null,n}return au(i,[{key:"destroy",value:function(){gu(cu(i.prototype),"destroy",this).call(this),this.rotateStart=null,this.rotateEnd=null,this.rotateDelta=null,this._panStart=null,this._panEnd=null,this._panDelta=null,this._pan=null,this._worldDimension=null,this.lastMousePoint=null,this.intersectOfMouseDown=null,this.pickHelper.destroy(),this.pickHelper=null}},{key:"processMouseDown",value:function(e){e.preventDefault(),e.stopPropagation(),this.lastMousePoint.set(e.clientX,e.clientY);var t=this.cameraControl;if(this.intersectOfMouseDown=null,e.button===this.mouseButtons.ORBIT){if(Kp.NoRotate)return;this.rotateStart.set(e.clientX,e.clientY),this.state=this.StateType.ROTATE,this.dispatchEvent({type:Fd.ON_CONTROL_BEGIN,name:"look",control:this.name})}else if(e.button===this.mouseButtons.PAN||e.button===this.mouseButtons.PAN2){if(Kp.NoPan)return;this._panStart.set(e.clientX,e.clientY),t.userInputHelper.getWorldDimension(e.clientX,e.clientY,this._worldDimension),this.intersectOfMouseDown=t.getLastIntersect(),this.state=this.StateType.PAN,this.isLockHeight&&(this.lockedHeight=e.clientY)}}},{key:"doPan",value:function(e,t){var i=this.cameraControl;this._panEnd.set(e,this.isLockHeight?this.lockedHeight:t),this._panDelta.subVectors(this._panEnd,this._panStart),0===this._panDelta.x&&0===this._panDelta.y||(i.userInputHelper.getPanOffset(this._panStart,this._panEnd,this._worldDimension,this._pan),i.userInputHelper.adjustCameraForPan(this._pan),this._panStart.copy(this._panEnd),i.update(!0))}},{key:"processMouseMove",value:function(e){var t=this.cameraControl;(e.preventDefault(),this.state===this.StateType.ROTATE)?(this.rotateEnd.set(e.clientX,e.clientY),this.rotateDelta.subVectors(this.rotateEnd,this.rotateStart),this.rotateStart.copy(this.rotateEnd),(0!=this.rotateDelta.x||0!=this.rotateDelta.y)&&t.rotateForFly(this.rotateDelta.x*this.lookSpeed,this.rotateDelta.y*this.lookSpeed,this.pitchMin,this.pitchMax)):this.state===this.StateType.PAN&&this.doPan(e.clientX,e.clientY)}},{key:"processMouseUp",value:function(e){if(e.preventDefault(),e.stopPropagation(),e.button!==n.LEFT||this.lastMousePoint.x!==e.clientX||this.lastMousePoint.y!==e.clientY){this.intersectOfMouseDown=null;var t=this.cameraControl;switch(this.state){case this.StateType.ROTATE:this.rotateDelta.set(0,0);t.rotateForFly(0,0,this.pitchMin,this.pitchMax),this.dispatchEvent({type:Fd.ON_CONTROL_END,name:"look",control:this.name});break;case this.StateType.PAN:this.doPan(e.clientX,e.clientY)}t.endOperation(),this.state=this.StateType.NONE}else this.pickHelper.click(e,this.intersectOfMouseDown)}},{key:"processHover",value:function(e){this.pickHelper.handleMouseHover(e)}},{key:"processMouseWheel",value:function(e){e.preventDefault(),e.stopPropagation();var t=this.cameraControl;if(!Kp.NoZoom){var i=e.wheelDelta||e.detail;i=Math.abs(i)>10?i:40*-i,i*=5e-4,Kp.ReverseWheelDirection&&(i*=-1);var n=t.getContainerDimensions();t.zoom(i,n.left+.5*n.width,n.top+.5*n.height)}}},{key:"processKeyDown",value:function(e){if(!Kp.NoKey&&!e.altKey){var t=Hd,i=t.NONE;switch(e.keyCode){case Gp.ZERO:this.movementSpeed=this.defaultMovementSpeed;break;case Gp.PLUS:this.movementSpeed*=1.1;break;case Gp.SUB:this.movementSpeed*=.9,this.minMovementSpeed>this.movementSpeed&&(this.movementSpeed=this.minMovementSpeed);break;case Gp.UP:case Gp.W:i=t.FORWARD;break;case Gp.DOWN:case Gp.S:i=t.BACK;break;case Gp.LEFT:case Gp.A:i=t.LEFT;break;case Gp.RIGHT:case Gp.D:i=t.RIGHT;break;case Gp.Q:i=t.UP;break;case Gp.E:i=t.DOWN}i!==t.NONE&&(this.moveState|=i,this.dispatchEvent({type:Fd.ON_CONTROL_KEYDOWN,event:e,state:i,direction:t,control:this.name}),this.cameraControl.updateFlyMove(this.moveState,this.movementSpeed*Kp.MovementSpeedRate))}}},{key:"processKeyUp",value:function(e){if(!Kp.NoKey){var t=Hd,i=t.NONE;switch(e.keyCode){case Gp.UP:case Gp.W:i=t.FORWARD;break;case Gp.DOWN:case Gp.S:i=t.BACK;break;case Gp.LEFT:case Gp.A:i=t.LEFT;break;case Gp.RIGHT:case Gp.D:i=t.RIGHT;break;case Gp.Q:i=t.UP;break;case Gp.E:i=t.DOWN}i!==t.NONE&&(this.dispatchEvent({type:Fd.ON_CONTROL_KEYUP,event:e,state:i,direction:t,control:this.name}),this.moveState&=~i)}}},{key:"moveTo",value:function(e){this.cameraControl.updateFlyMove(e,this.movementSpeed*Kp.MovementSpeedRate)}}]),i}(um),gm=function(e){lu(i,e);var t=pu(i);function i(e,n){var r;return ru(this,i),(r=t.call(this,e,n)).oldMouseX=-1,r.oldMouseY=-1,r.zoomSpeed=Math.pow(.95,.2),r.touchZoomSpeed=.24,r.modelManager=n.viewer.modelManager,r._worldDimension=new ke,r._rotateStart=new ke,r._rotateEnd=new ke,r._rotateDelta=new ke,r.pickHelper=new pf(n),r.longTapFlag=!1,r.selectPad=(og.isMobileDevice(),null),r.startPt=new ke,r.viewer=n.viewer,r}return au(i,[{key:"destroy",value:function(){gu(cu(i.prototype),"destroy",this).call(this),this.modelManager=null,this._worldDimension=null,this.startPt=null,this.pickHelper.destroy(),this.pickHelper=null,this.selectPad&&(this.selectPad.destroy(),this.selectPad=null),this.viewer=null}},{key:"longTap",value:function(){this.longTapFlag=!0,this.selectPad&&this.selectPad.showOverlay(this.startPt)}},{key:"beginPan",value:function(e,t){this._panStart.set(e,t),this.cameraControl.userInputHelper.getWorldDimension(e,t,this._worldDimension)}},{key:"moveTo",value:function(e){if(void 0!==e){var t=this.cameraControl;if(!Kp.NoKey&&!Kp.NoPan){var i=this.movementSpeed*Kp.MovementSpeedRate,n=this.keyPanSpeed*Kp.MovementSpeedRate,r=Hd;switch(e){case r.FORWARD:t.moveForward(i,!0);break;case r.BACK:t.moveBackward(i,!0);break;case r.LEFT:t.pan(n,0);break;case r.RIGHT:t.pan(-n,0);break;case r.UP:t.pan(0,n);break;case r.DOWN:t.pan(0,-n);break;default:e=r.NONE}e!==r.NONE&&t.update(!0,!0)}}}},{key:"onExit",value:function(){xd.MergeComponent&&this.animationStarted&&(this._stop(),this.animationStarted=!1)}},{key:"resetMobileParamsByBox",value:function(e){var t=new Ke;e.getSize(t);var i=this.cameraControl.viewer.modelManager.isMeterUnit()?100:1e5;(t.x>i||t.y>i)&&(this.touchZoomSpeed=.3)}}]),i}(um),fm=function(e){lu(i,e);var t=pu(i);function i(e){var n;return ru(this,i),(n=t.call(this,Vd.PICK,e)).tabIndex=0,n.intersectOfMouseDown=null,n.pickObjects=[],n}return au(i,[{key:"destroy",value:function(){gu(cu(i.prototype),"destroy",this).call(this),this.pickObjects=null}},{key:"processMouseDown",value:function(e){this.intersectOfMouseDown=null,e.preventDefault(),1>=Math.abs(this.oldMouseX-e.clientX)&&1>=Math.abs(this.oldMouseY-e.clientY)&&(this.intersectOfMouseDown=this.cameraControl.getLastIntersect()),this.oldMouseX=e.clientX,this.oldMouseY=e.clientY}},{key:"processMouseUp",value:function(e){e.preventDefault();var t=1>=Math.abs(this.oldMouseX-e.clientX)&&1>=Math.abs(this.oldMouseY-e.clientY),i=t;return e.button!==n.LEFT&&e.button!==n.RIGHT||!t?(this.intersectOfMouseDown=null,this.oldMouseX=e.clientX,this.oldMouseY=e.clientY,!1):(this.pickObjects=this.pickHelper.pickAllObjectsByPosition(e),this.pickHelper.click(e,this.intersectOfMouseDown),this.cameraControl.update(!0),this.intersectOfMouseDown=null,i)}},{key:"processMouseDoubleClick",value:function(e){e.button===n.LEFT&&this.pickHelper.doubleClick(e)}},{key:"processMouseMove",value:function(){this.pickObjects=[]}},{key:"processMouseWheel",value:function(){this.pickObjects=[]}},{key:"processKeyDown",value:function(e){if(gu(cu(i.prototype),"processKeyDown",this).call(this,e),this.state=this.StateType.NONE,!Kp.NoKey&&this.pickObjects.length>0){switch(e.keyCode){case Gp.TAB:e.shiftKey?(--this.tabIndex,0>this.tabIndex?(this.tabIndex=this.pickObjects.length+this.tabIndex,this.pickHelper.handleTabs(this.pickObjects[this.tabIndex])):this.pickHelper.handleTabs(this.pickObjects[this.tabIndex])):(++this.tabIndex,this.pickObjects.length>this.tabIndex||(this.tabIndex=0),this.pickHelper.handleTabs(this.pickObjects[this.tabIndex]))}this.cameraControl.update(!0)}}},{key:"processKeyUp",value:function(e){switch(e.keyCode){case Gp.ESC:this.cameraControl.viewer.clearSelection(),this.pickHelper.lastPickedUserId=void 0,this.cameraControl.updateView(!0)}}},{key:"processHover",value:function(e){this.pickHelper.handleMouseHover(e),this.pickHelper.handleMouseMovePick(e)}}]),i}(gm),mm=function(e){lu(i,e);var t=pu(i);function i(e){var r,o=arguments.length>1&&void 0!==arguments[1]?arguments[1]:Vd.ORBIT;return ru(this,i),(r=t.call(this,o,e)).mouseButtons={ORBIT:n.LEFT,PAN2:n.MIDDLE,PAN:n.RIGHT},r._rotateStart=new ke,r._rotateEnd=new ke,r._rotateDelta=new ke,r._lastDampingOffset=new ke,r._curDampingOffset=new ke,r.rotatePivot=null,r.enable=!0,r.rotateSpeed=1,r}return au(i,[{key:"processMouseDown",value:function(e){(e.preventDefault(),e.button===this.mouseButtons.ORBIT&&!Kp.NoRotate&&this.enable)&&(this.oldMouseX=e.clientX,this.oldMouseY=e.clientY,this.rotatePivot=this.cameraControl.userInputHelper.getRotatePivot(Kp.RotatePivotMode,{x:e.clientX,y:e.clientY}),this._rotateStart.set(e.clientX,e.clientY),this._rotateEnd.set(e.clientX,e.clientY),this.resetDynamicRotate(),this.dispatchEvent({type:Fd.ON_CONTROL_BEGIN,name:Vd.ORBIT,control:this.name,startPt:this._rotateStart}),this.state=this.StateType.ROTATE)}},{key:"processMouseMove",value:function(e){if(this.state!==this.StateType.ROTATE)return!1;var t=this.cameraControl;if(e.preventDefault(),t.userInputWorking||(t.userInputWorking=!0),this._rotateEnd.set(e.clientX,e.clientY),!this.cameraControl.isEnableDamping()){if(this._rotateDelta.subVectors(this._rotateEnd,this._rotateStart),Math.abs(this._rotateDelta.x)<Yp.EPSILON2&&Math.abs(this._rotateDelta.y)<Yp.EPSILON2)return;this._rotateStart.copy(this._rotateEnd),this._processRotate(this._rotateDelta,this.rotatePivot)}this.cameraControl.update(!0),this.dispatchEvent({type:Fd.ON_CONTROL_ROTATING,control:this.name}),this.dispatchEvent({type:Fd.ON_CONTROL_MOUSEMOVE,name:Vd.ORBIT,control:this.name,event:e})}},{key:"processMouseUp",value:function(e){if(this.state!==this.StateType.ROTATE)return!1;var t=this.cameraControl;return(Math.abs(this.oldMouseX-e.clientX)>Yp.EPSILON2||Math.abs(this.oldMouseY-e.clientY)>Yp.EPSILON2)&&this.cameraControl.update(!0),this.state=this.StateType.NONE,t.endOperation(),t.onUserInputFinished(),this.dispatchEvent({type:Fd.ON_CONTROL_END,name:Vd.ORBIT,control:this.name}),!0}},{key:"processTouchstart",value:function(e){if(1===e.touches.length){if(Kp.NoRotate)return;this.rotatePivot=this.cameraControl.userInputHelper.getRotatePivot(Kp.RotatePivotMode,{x:e.clientX,y:e.clientY}),this._rotateStart.set(e.touches[0].clientX,e.touches[0].clientY),this.state=this.StateType.ROTATE}}},{key:"processTouchmove",value:function(e){if(this.state!==this.StateType.ROTATE)return!1;var t=this.cameraControl;if(e.preventDefault(),1===e.touches.length){this._rotateEnd.set(e.touches[0].clientX,e.touches[0].clientY),this._rotateDelta.subVectors(this._rotateStart,this._rotateEnd);var i=this.viewer.getClientSize(),n=2*Math.PI*this._rotateDelta.x/i.x*this.rotateSpeed,r=2*Math.PI*this._rotateDelta.y/i.y*this.rotateSpeed;t.touchUpdateRotation(n,r),this._rotateStart.copy(this._rotateEnd),this.dispatchEvent({type:Fd.ON_CONTROL_ROTATING,control:this.name})}t.touchUpdate()}},{key:"processTouchend",value:function(e){if(this.state!==this.StateType.ROTATE)return!1;var t=this.cameraControl;switch(e.touches.length){case 0:this.state=this.StateType.NONE,t.touchEndHandler(e);break;case 1:if(Kp.NoRotate)return;this._rotateStart.set(e.touches[0].clientX,e.touches[0].clientY),this.state=this.StateType.ROTATE}}},{key:"dynamicRotate",value:function(){this._rotateDelta.subVectors(this._rotateEnd,this._rotateStart);var e=!1;if((Math.abs(this._rotateDelta.x)>Yp.EPSILON4||Math.abs(this._rotateDelta.y)>Yp.EPSILON4)&&(e=!0),this._lastDampingOffset.length()>Yp.EPSILON4&&(e=!0),e){var t=this.viewer.getClientSize(),i=-2*Math.PI*this._rotateDelta.x/t.x,n=-2*Math.PI*this._rotateDelta.y/t.y;this._lastDampingOffset.add(new ke(i,n)),this._curDampingOffset.copy(this._lastDampingOffset);var r=this._curDampingOffset.multiplyScalar(this.cameraControl.dynamicDampingFactor());this.cameraControl.handleRotation(r.x,r.y,this.rotatePivot),this._rotateStart.copy(this._rotateEnd),this._lastDampingOffset.multiplyScalar(1-this.cameraControl.dynamicDampingFactor()),this.cameraControl.viewer.render()}}},{key:"resetDynamicRotate",value:function(){this._lastDampingOffset.set(0,0),this._curDampingOffset.set(0,0)}},{key:"_processRotate",value:function(e,t){var i=this.viewer.getClientSize(),n=-2*Math.PI*e.x/i.x,r=-2*Math.PI*e.y/i.y;this.cameraControl.handleRotation(n,r,t)}}]),i}(gm),Am=function(e){lu(i,e);var t=pu(i);function i(e){var r;return ru(this,i),(r=t.call(this,Vd.PAN,e)).mouseButtons={ORBIT:n.LEFT,PAN2:n.MIDDLE,PAN:n.RIGHT},r._panStart=new Ke,r._panEnd=new Ke,r._panDelta=new Ke,r._panOffset=new Ke,r._lastDampingOffset=new Ke,r._curDampingOffset=new Ke,r._worldDimension=new Ke,r.enable=!0,r._moving=!1,r}return au(i,[{key:"destroy",value:function(){gu(cu(i.prototype),"destroy",this).call(this),this.mouseButtons=null,this._panStart=null,this._panEnd=null,this._panDelta=null,this._panOffset=null,this._lastDampingOffset=null,this._curDampingOffset=null,this._worldDimension=null}},{key:"processMouseDown",value:function(e){if(!(e.button!==this.mouseButtons.PAN&&e.button!==this.mouseButtons.PAN2||Kp.NoPan)&&this.enable){var t=this.cameraControl;t.userInputWorking||(t.userInputWorking=!0),this.oldMouseX=e.clientX,this.oldMouseY=e.clientY,this._panStart.set(e.clientX,e.clientY),this._panEnd.set(e.clientX,e.clientY),this._panOffset.set(0,0,0),this.resetDynamicPan();var i=this._panStart;t.userInputHelper.getWorldDimension(e.clientX,e.clientY,this._worldDimension),this.dispatchEvent({type:Fd.ON_CONTROL_BEGIN,name:Vd.PAN,control:this.name,startPt:i}),this.state=this.StateType.PAN}}},{key:"processMouseUp",value:function(e){return this.state===this.StateType.PAN&&((Math.abs(this.oldMouseX-e.clientX)>Yp.EPSILON4||Math.abs(this.oldMouseY-e.clientY)>Yp.EPSILON4)&&this.cameraControl.update(!0),this.cameraControl.endOperation(),this.cameraControl.onUserInputFinished(),this.dispatchEvent({type:Fd.ON_CONTROL_END,name:Vd.PAN,control:this.name}),this.state=this.StateType.NONE,!0)}},{key:"processMouseMove",value:function(e){if(this.state!==this.StateType.PAN)return!1;if(this._panEnd.set(e.clientX,e.clientY),!this.cameraControl.isEnableDamping()){if(this._panDelta.subVectors(this._panEnd,this._panStart),Math.abs(this._panDelta.x)<Yp.EPSILON2&&Math.abs(this._panDelta.y)<Yp.EPSILON2)return;this.cameraControl.userInputHelper.getPanOffset(this._panStart,this._panEnd,this._worldDimension,this._panOffset),this.cameraControl.userInputHelper.adjustCameraForPan(this._panOffset),this._panStart.copy(this._panEnd),this.cameraControl.update(!0)}this.dispatchEvent({type:Fd.ON_CONTROL_PANING,name:Vd.PAN,control:this.name}),this.dispatchEvent({type:Fd.ON_CONTROL_MOUSEMOVE,name:Vd.PAN,control:this.name,event:e})}},{key:"processKeyDown",value:function(e){if(!Kp.NoKey&&!Kp.NoPan){var t=this.cameraControl;this._moving=!0;var i=!1,n=this.movementSpeed*Kp.MovementSpeedRate,r=this.keyPanSpeed*Kp.MovementSpeedRate;switch(e.keyCode){case Gp.ZERO:this.keyPanSpeed=t.defaultKeyPanSpeed,this.movementSpeed=t.defaultMovementSpeed;break;case Gp.PLUS:this.keyPanSpeed*=1.1,this.movementSpeed*=1.1;break;case Gp.SUB:this.keyPanSpeed*=.9,this.keyPanSpeed=this.minKeyPanSpeed>this.keyPanSpeed?this.minKeyPanSpeed:this.keyPanSpeed,this.movementSpeed*=.9,this.movementSpeed=this.minMovementSpeed>this.movementSpeed?this.minMovementSpeed:this.movementSpeed;break;case Gp.Q:t.pan(0,r),i=!0;break;case Gp.E:t.pan(0,-r),i=!0;break;case Gp.LEFT:case Gp.A:t.pan(r,0),i=!0;break;case Gp.RIGHT:case Gp.D:t.pan(-r,0),i=!0;break;case Gp.UP:case Gp.W:t.moveStraight(n,!e.shiftKey),i=!0;break;case Gp.DOWN:case Gp.S:t.moveStraight(-n,!e.shiftKey),i=!0}i&&(t.update(!0),this.cameraControl.userInputWorking||(this.cameraControl.userInputWorking=!0))}}},{key:"processKeyUp",value:function(e){if(!Kp.NoKey&&!Kp.NoPan)switch(e.keyCode){case Gp.Q:case Gp.E:case Gp.LEFT:case Gp.A:case Gp.RIGHT:case Gp.D:case Gp.UP:case Gp.W:case Gp.DOWN:case Gp.S:this.cameraControl.onUserInputFinished()}}},{key:"processTouchstart",value:function(e){(this.startPt.set(e.touches[0].clientX,e.touches[0].clientY),this.timeId&&clearTimeout(this.timeId),this.timeId=setTimeout(this.longTap,400),this.selectPad&&this.selectPad.hideOverlay(),2===e.touches.length)&&(Kp.NoPan||(this._panStart.set(.5*(e.touches[0].clientX+e.touches[1].clientX),.5*(e.touches[0].clientY+e.touches[1].clientY)),this.state=this.StateType.PAN))}},{key:"processTouchmove",value:function(e){if(this.state!==this.StateType.PAN)return!1;this.timeId&&clearTimeout(this.timeId);var t=this.cameraControl;if(e.preventDefault(),2===e.touches.length){var i=.5*(e.touches[0].clientX+e.touches[1].clientX),n=.5*(e.touches[0].clientY+e.touches[1].clientY);if(this._panEnd.set(i,n),this._panDelta.subVectors(this._panEnd,this._panStart),3>Math.abs(this._panDelta.x)&&3>Math.abs(this._panDelta.y))return!1;t.userInputHelper.getWorldDimension(i,n,this._worldDimension),t.userInputHelper.getPanOffset(this._panStart,this._panEnd,this._worldDimension,this._panOffset),t.userInputHelper.adjustCameraForPan(this._panOffset),this._panStart.copy(this._panEnd),this.state=this.StateType.PAN,this.modelManager.dispatchEvent({type:Fd.ON_CONTROL_PANING})}t.touchUpdate()}},{key:"processTouchend",value:function(e){if(this.state!==this.StateType.PAN)return!1;this.timeId&&clearTimeout(this.timeId),this.longTapFlag&&(this.longTapFlag=!1,e.preventDefault());var t=this.cameraControl;switch(e.touches.length){case 0:this.state=this.StateType.NONE,t.touchEndHandler(e);break;case 1:if(Kp.NoRotate)return;this._rotateStart.set(e.touches[0].clientX,e.touches[0].clientY),this.state=this.StateType.ROTATE}}},{key:"dynamicPan",value:function(){this._panDelta.subVectors(this._panEnd,this._panStart);var e=!1;if((Math.abs(this._panDelta.x)>Yp.EPSILON2||Math.abs(this._panDelta.y)>Yp.EPSILON2)&&(e=!0),this._lastDampingOffset.length()>Yp.EPSILON2&&(e=!0),e){this._lastDampingOffset.add(this._panOffset),this._curDampingOffset.copy(this._lastDampingOffset);var t=this._curDampingOffset.multiplyScalar(this.cameraControl.dynamicDampingFactor());this.cameraControl.userInputHelper.adjustCameraForPan(t),this.cameraControl.userInputHelper.getPanOffset(this._panStart,this._panEnd,this._worldDimension,this._panOffset),this._panStart.copy(this._panEnd),this._lastDampingOffset.multiplyScalar(1-this.cameraControl.dynamicDampingFactor()),this.cameraControl.viewer.render()}}},{key:"resetDynamicPan",value:function(){this._lastDampingOffset.set(0,0,0),this._curDampingOffset.set(0,0,0)}}]),i}(gm),ym=function(e){lu(i,e);var t=pu(i);function i(e){var n;return ru(this,i),(n=t.call(this,Vd.ZOOM,e)).mouseButtons={},n.enable=!0,n._dollyStart=new ke,n._dollyEnd=new ke,n._dollyDelta=new ke,n.zoomSpeed=Math.pow(.95,.2),n._curZoomFactor={},n}return au(i,[{key:"destroy",value:function(){gu(cu(i.prototype),"destroy",this).call(this),this.mouseButtons=null,this._dollyStart=null,this._dollyEnd=null,this._dollyDelta=null,this._curZoomFactor=null}},{key:"processMouseWheel",value:function(e){if(!Kp.NoZoom&&this.enable){e.preventDefault(),e.stopPropagation();var t=0;e.wheelDelta?t=e.wheelDelta:e.detail&&(t=40*-e.detail),Math.abs(t)>720&&(t=t>0?720:-720),t*=this.wheelZoomFactor,this._curZoomFactor.scale=t=Kp.ReverseWheelDirection?-t:t,this._curZoomFactor.clientX=e.clientX,this._curZoomFactor.clientY=e.clientY,this.cameraControl.isEnableDamping()||this._zoom(t)}}},{key:"processMouseDown",value:function(e){e.preventDefault(),this.state=this.StateType.NONE,e.button!==this.mouseButtons.ZOOM||Kp.NoZoom||(this.state=this.StateType.DOLLY,this._dollyStart.set(e.clientX,e.clientY),this._dollyEnd.set(e.clientX,e.clientY),this.dispatchEvent({type:Fd.ON_CONTROL_BEGIN,name:Vd.ZOOM,control:this.name,startPt:this._dollyStart}))}},{key:"processMouseMove",value:function(e){if(this.state===this.StateType.DOLLY){var t=this.cameraControl;if(e.preventDefault(),t.userInputWorking||(t.userInputWorking=!0),this._dollyEnd.set(e.clientX,e.clientY),!this.cameraControl.isEnableDamping()){if(this._dollyDelta.subVectors(this._dollyEnd,this._dollyStart),Math.abs(this._dollyDelta.x)<Yp.EPSILON2&&Math.abs(this._dollyDelta.y)<Yp.EPSILON2)return;this._zoom((this._dollyDelta.y>0?this.zoomSpeed:1/this.zoomSpeed)-1),this._dollyStart.copy(this._dollyEnd)}this.cameraControl.update(!0),this.dispatchEvent({type:Fd.ON_CONTROL_ZOOM,control:this.name})}}},{key:"processMouseUp",value:function(){if(this.state===this.StateType.DOLLY){var e=this.cameraControl;return this.state=this.StateType.NONE,e.onUserInputFinished(),this.dispatchEvent({type:Fd.ON_CONTROL_END,name:Vd.ZOOM,control:this.name}),!0}}},{key:"processTouchstart",value:function(e){if(2===e.touches.length&&!Kp.NoZoom){var t=e.touches[0].clientX-e.touches[1].clientX,i=e.touches[0].clientY-e.touches[1].clientY;this._dollyStart.set(0,Math.sqrt(t*t+i*i)),this.state=this.StateType.DOLLY}}},{key:"processTouchmove",value:function(e){if(this.state===this.StateType.DOLLY){var t=this.cameraControl;if(e.preventDefault(),2===e.touches.length){var i=e.touches[0].clientX-e.touches[1].clientX,n=e.touches[0].clientY-e.touches[1].clientY,r=Math.sqrt(i*i+n*n);if(this._dollyEnd.set(0,r),this._dollyDelta.subVectors(this._dollyEnd,this._dollyStart),Math.abs(this._dollyDelta.y)>3){var o=(.01*this.touchZoomSpeed+1e-4)*this._dollyDelta.y;this._dollyStart.copy(this._dollyEnd),t.touchDolly(.5*(e.touches[0].clientX+e.touches[1].clientX),.5*(e.touches[0].clientY+e.touches[1].clientY),o),this.state=this.StateType.DOLLY,this.modelManager.dispatchEvent({type:Fd.ON_CONTROL_ZOOM})}}t.touchUpdate()}}},{key:"dynamicZoom",value:function(){var e=!1;Math.abs(this._curZoomFactor.scale)>Yp.EPSILON2?e=!0:this._curZoomFactor.scale=0,e&&(this._curZoomFactor.scale*=1-this.cameraControl.dynamicDampingFactor(),this._zoom(this._curZoomFactor.scale),this.cameraControl.viewer.render())}},{key:"resetDynamicZoom",value:function(){this._curZoomFactor.scale=0}},{key:"_zoom",value:function(e){var t=this.cameraControl;this.cameraControl.dispatchEvent({type:Fd.ON_CONTROL_ZOOM}),t.zoom(e,this._curZoomFactor.clientX,this._curZoomFactor.clientY)}}]),i}(gm),vm=function(){function e(t){ru(this,e),this.viewer=t,this.cameraControl=t.cameraControl,this.panControl=new Am(this.cameraControl),this.orbitControl=new mm(this.cameraControl),this.zoomControl=new ym(this.cameraControl),this.enable=!0,this.currentMouseMode="left"}return au(e,[{key:"setDefaultControlMode",value:function(){this.enable=!0,this.panControl.enable=!0,this.orbitControl.enable=!0,this.zoomControl.enable=!0,this.switchHandMode(this.currentMouseMode)}},{key:"setPanControlMode",value:function(){this.enable=!0,this.panControl.enable=!0,this.orbitControl.enable=!1,this.zoomControl.enable=!0,this.panControl.mouseButtons={PAN2:n.RIGHT,PAN:n.LEFT},this.zoomControl.mouseButtons={}}},{key:"setOrbitControlMode",value:function(){this.enable=!0,this.panControl.enable=!0,this.orbitControl.enable=!0,this.zoomControl.enable=!0,this.setDefaultControlMode()}},{key:"setZoomControlMode",value:function(){this.enable=!0,this.panControl.enable=!0,this.orbitControl.enable=!1,this.zoomControl.enable=!0,this.panControl.mouseButtons={PAN2:n.MIDDLE,PAN:n.RIGHT},this.zoomControl.mouseButtons={ZOOM:n.LEFT}}},{key:"switchHandMode",value:function(e){this.currentMouseMode=e,"left"===e?(this.panControl.mouseButtons={PAN2:n.MIDDLE,PAN:n.RIGHT},this.orbitControl.mouseButtons={ORBIT:n.LEFT}):"right"===e&&(this.panControl.mouseButtons={PAN2:n.MIDDLE,PAN:n.LEFT},this.orbitControl.mouseButtons={ORBIT:n.RIGHT})}},{key:"update",value:function(){this.cameraControl.isEnableDamping()&&this.enable&&(this.panControl.dynamicPan(),this.orbitControl.dynamicRotate(),this.zoomControl.dynamicZoom())}},{key:"processMouseDown",value:function(e){this.enable&&(this.cameraControl.isEnableDamping()&&this.resetDynamicMoving(),this.panControl.processMouseDown(e),this.orbitControl.processMouseDown(e),this.zoomControl.processMouseDown(e))}},{key:"processMouseMove",value:function(e){this.enable&&(this.panControl.processMouseMove(e),this.orbitControl.processMouseMove(e),this.zoomControl.processMouseMove(e))}},{key:"processMouseUp",value:function(e){this.enable&&(this.panControl.processMouseUp(e),this.orbitControl.processMouseUp(e),this.zoomControl.processMouseUp(e))}},{key:"processMouseWheel",value:function(e){this.enable&&(this.cameraControl.isEnableDamping()&&this.resetDynamicMoving(),this.zoomControl.processMouseWheel(e))}},{key:"processKeyDown",value:function(e){this.enable&&this.panControl.processKeyDown(e)}},{key:"processTouchmove",value:function(e){this.enable&&(this.panControl.processTouchmove(e),this.orbitControl.processTouchmove(e),this.zoomControl.processTouchmove(e))}},{key:"processTouchstart",value:function(e){this.enable&&(this.panControl.processTouchstart(e),this.orbitControl.processTouchstart(e),this.zoomControl.processTouchstart(e))}},{key:"processTouchend",value:function(e){this.enable&&(this.panControl.processTouchend(e),this.orbitControl.processTouchend(e),this.zoomControl.processTouchend(e))}},{key:"processKeyUp",value:function(e){this.enable&&this.panControl.processKeyUp(e)}},{key:"resetDynamicMoving",value:function(){this.enable&&(this.orbitControl.resetDynamicRotate(),this.panControl.resetDynamicPan(),this.zoomControl.resetDynamicZoom())}}]),e}(),Cm=function(e){lu(i,e);var t=pu(i);function i(e){var r;ru(this,i),(r=t.call(this,Vd.WALK,e)).mouseButtons={ORBIT:n.LEFT,PAN2:n.MIDDLE,PAN:n.RIGHT},r.pickHelper=new pf(e),r.lastMousePoint=new ke,r._reqid=0,r._animateBinded=r._animate.bind(du(r)),r._clock=new Pc,r.moveState={up:0,down:0,left:0,right:0,forward:0,back:0,pitchUp:0,pitchDown:0,yawLeft:0,yawRight:0,rollLeft:0,rollRight:0},r.startPt=new ke,r.timeId=null,r.rotateSpeed=1,r._rotateStart=new ke,r._rotateEnd=new ke,r._rotateDelta=new ke,r._dollyStart=new ke,r._dollyEnd=new ke,r._dollyDelta=new ke,r._dollyCenter=new ke,r.zoomSpeed=Math.pow(.95,.2),r._panStart=new ke,r._panEnd=new ke,r._panDelta=new ke,r._pan=new Ke,r._worldDimension=new ke,r.selectPad=(og.isMobileDevice(),null),r.moveVector=new Ke(0,0,0),r.rotationVector=new Ke(0,0,0),r.zoomDelta=0,r.rotateStart=new ke,r.rotateEnd=new ke,r.rotateDelta=new ke,r.firstRotate=!0,r.dragLook=!0,r.lockHeightEnabled=!1,r.isLockHeight=!1,r.lockedHeight=0,r.pickEnabled=!0,r.mouseType=null;var o=e.viewer.getScene().getBoundingBoxWorld();return r.defaultMovementSpeed=o?o.getSize(new Ke(0,0,0)).length()/10:1500,r.movementSpeed=r.defaultMovementSpeed,r.shiftSpeedup=!1,r}return au(i,[{key:"setFocuse",value:function(){var e=document.querySelector(".main-canvas");e&&e.focus&&e.focus()}},{key:"destroy",value:function(){gu(cu(i.prototype),"destroy",this).call(this),this.pickHelper.destroy(),this.pickHelper=null,this.selectPad&&(this.selectPad.destroy(),this.selectPad=null),this.timeId&&(clearTimeout(this.timeId),this.timeId=null),this._clock=null,this._animateBinded=null,this.mouseButtons=null,this.moveState=null,this.startPt=null,this.lastMousePoint=null,this.rotateStart=null,this.rotateEnd=null,this.rotateDelta=null,this._rotateStart=null,this._rotateEnd=null,this._rotateDelta=null,this._dollyStart=null,this._dollyEnd=null,this._dollyDelta=null,this._dollyCenter=null,this._panStart=null,this._panEnd=null,this._panDelta=null,this._pan=null,this._worldDimension=null,this.moveVector=null,this.rotationVector=null,this.rotateStart=null,this.rotateEnd=null,this.rotateDelta=null}},{key:"_animate",value:function(){this._reqid=requestAnimationFrame(this._animateBinded),this.updateWalkMove()}},{key:"_start",value:function(){this.moveState={up:0,down:0,left:0,right:0,forward:0,back:0,pitchUp:0,pitchDown:0,yawLeft:0,yawRight:0,rollLeft:0,rollRight:0},this._animate()}},{key:"_stop",value:function(){cancelAnimationFrame(this._reqid)}},{key:"_updateMovement",value:function(){this.moveVector.x=-this.moveState.left+this.moveState.right,this.moveVector.z=this.isLockHeight?0:-this.moveState.down+this.moveState.up,this.moveVector.y=-this.moveState.forward+this.moveState.back}},{key:"_updateRotation",value:function(){this.rotationVector.x=Kp.LockAxisZ?0:-this.moveState.pitchDown+this.moveState.pitchUp,this.rotationVector.y=-this.moveState.yawRight+this.moveState.yawLeft,this.rotationVector.z=-this.moveState.rollRight+this.moveState.rollLeft}},{key:"_doRotate",value:function(e){xd.WalkingWithViewLock&&(e.y=0);var t=this.cameraControl.getContainerDimensions(),i=t.height/2;this.moveState.yawLeft=-e.x/(t.width/2),this.moveState.pitchDown=e.y/i,this._updateRotation()}},{key:"processMouseDown",value:function(e){if(this.oldMouseX=e.clientX,this.oldMouseY=e.clientY,e.preventDefault(),e.stopPropagation(),this.mouseType=e.button,this.lastMousePoint.set(e.clientX,e.clientY),this.firstRotate=!1,e.button===this.mouseButtons.ORBIT){if(Kp.NoRotate)return;this.rotateStart.set(e.clientX,e.clientY),this.state=this.StateType.ROTATE,this.dispatchEvent({type:Fd.ON_CONTROL_BEGIN,name:"look",control:this.name})}else if(e.button===this.mouseButtons.PAN||e.button===this.mouseButtons.PAN2){if(Kp.NoPan)return;this._panStart.set(e.clientX,e.clientY),this._worldDimension=this.cameraControl.userInputHelper.getWorldDimension(e.clientX,e.clientY,this._worldDimension),this.state=this.StateType.PAN,this.dispatchEvent({type:Fd.ON_CONTROL_BEGIN,name:Vd.PAN,control:this.name})}}},{key:"processMouseUp",value:function(e){return e.preventDefault(),e.stopPropagation(),e.button===this.mouseButtons.PAN&&this.setFocuse(),this.mouseType=null,this.pickEnabled&&(e.button===n.LEFT||e.button===n.RIGHT)&&2>Math.abs(this.lastMousePoint.x-e.clientX)&&2>Math.abs(this.lastMousePoint.y-e.clientY)?(this.state=this.StateType.NONE,void this.pickHelper.click(e)):(this.state===this.StateType.ROTATE&&(this.moveState.yawLeft=this.moveState.pitchDown=0,this.dispatchEvent({type:Fd.ON_CONTROL_END,name:"look",control:this.name})),this.state=this.StateType.NONE,!0)}},{key:"processMouseMove",value:function(e){if(e.preventDefault(),this.dragLook&&this.state===this.StateType.ROTATE&&0===this.mouseType){if(this.rotateEnd.set(e.clientX,e.clientY),this.rotateDelta.subVectors(this.rotateEnd,this.rotateStart),0===this.rotateDelta.x&&0===this.rotateDelta.y)return;this.rotateStart.copy(this.rotateEnd),this._doRotate(this.rotateDelta)}else{switch(this.state){case this.StateType.DOLLY:if(this._dollyEnd.set(e.clientX,e.clientY),this._dollyDelta.subVectors(this._dollyEnd,this._dollyStart),0===this._dollyDelta.x&&0===this._dollyDelta.y)return;this.cameraControl.zoom(this._dollyDelta.y>0?this.zoomSpeed:1/this.zoomSpeed,null),this._dollyStart.copy(this._dollyEnd);break;case this.StateType.PAN:if(this._panEnd.set(e.clientX,e.clientY),this._panDelta.subVectors(this._panEnd,this._panStart),0===this._panDelta.x&&0===this._panDelta.y)return;this.cameraControl.userInputHelper.getPanOffset(this._panStart,this._panEnd,this._worldDimension,this._pan),this.cameraControl.userInputHelper.adjustCameraForPan(this._pan),this._panStart.copy(this._panEnd)}this.state!==this.StateType.NONE&&this.cameraControl.update(!0)}}},{key:"processTouchstart",value:function(e){this.startPt.set(e.touches[0].clientX,e.touches[0].clientY),this.timeId&&clearTimeout(this.timeId);switch(this.timeId=setTimeout(this.longTap,400),this.selectPad&&this.selectPad.hideOverlay(),e.touches.length){case 1:if(Kp.NoRotate)return;this._rotateStart.set(e.touches[0].clientX,e.touches[0].clientY),this.state=this.StateType.ROTATE,console.log(this._rotateStart);break;case 2:if(!Kp.NoPan)this._panStart.set(.5*(e.touches[0].clientX+e.touches[1].clientX),.5*(e.touches[0].clientY+e.touches[1].clientY));break;default:this.state=this.StateType.NONE}}},{key:"processTouchmove",value:function(e){this.timeId&&clearTimeout(this.timeId);var t=this.cameraControl;switch(e.preventDefault(),e.touches.length){case 1:this.dragLook&&this.state===this.StateType.ROTATE&&(this._rotateEnd.set(e.touches[0].clientX,e.touches[0].clientY),this._rotateDelta.subVectors(this._rotateEnd,this._rotateStart),this._rotateStart.copy(this._rotateEnd),this._doRotate(this._rotateDelta));break;case 2:if(t.clearTouchRotateState(),!Kp.NoPan){var i=.5*(e.touches[0].clientX+e.touches[1].clientX),n=.5*(e.touches[0].clientY+e.touches[1].clientY);if(this._panEnd.set(i,n),this._panDelta.subVectors(this._panEnd,this._panStart),3>Math.abs(this._panDelta.x)&&3>Math.abs(this._panDelta.y))return;t.userInputHelper.getWorldDimension(i,n,this._worldDimension),t.userInputHelper.getPanOffset(this._panStart,this._panEnd,this._worldDimension,this._pan),t.userInputHelper.adjustCameraForPan(this._pan),this._panStart.copy(this._panEnd),this.state=this.StateType.PAN}}t.touchUpdate()}},{key:"processTouchend",value:function(e){this.timeId&&clearTimeout(this.timeId),this.longTapFlag&&(this.longTapFlag=!1,e.preventDefault());var t=this.cameraControl;switch(e.touches.length){case 0:this.state=this.StateType.NONE,t.touchEndHandler(e);break;case 1:if(Kp.NoRotate)return;this._rotateStart.set(e.touches[0].clientX,e.touches[0].clientY),this.state=this.StateType.ROTATE}}},{key:"processHover",value:function(e){this.dragLook||(this.firstRotate&&(this.firstRotate=!1,this.rotateStart.set(e.clientX,e.clientY)),this.rotateEnd.set(e.clientX,e.clientY),this.rotateDelta.subVectors(this.rotateEnd,this.rotateStart),this.rotateStart.copy(this.rotateEnd),this._doRotate(this.rotateDelta))}},{key:"processMouseWheel",value:function(e){var t=this.cameraControl;if(e.preventDefault(),e.stopPropagation(),!Kp.NoZoom){var i=0;e.wheelDelta?i=e.wheelDelta:e.deltaY&&(i=40*-e.deltaY),Math.abs(i)>720&&(i=i>0?720:-720),i*=this.wheelZoomFactor,Kp.ReverseWheelDirection&&(i*=-1),t.zoom(i,e.clientX,e.clientY),t.delayHandle(),this.dispatchEvent({type:Fd.ON_CONTROL_ZOOM}),this.zoomDelta=i}}},{key:"processKeyDown",value:function(e){if(!Kp.NoKey&&!e.altKey){var t=Hd.NONE;switch(e.keyCode){case Gp.ZERO:this.movementSpeed=this.defaultMovementSpeed;break;case Gp.PLUS:case Gp.NUMPADADD:this.movementSpeed*=1.1;break;case Gp.NUMPADSUBTRACT:case Gp.SUB:this.movementSpeed*=.9,this.minMovementSpeed>this.movementSpeed&&(this.movementSpeed=this.minMovementSpeed);break;case Gp.UP:case Gp.W:t=Hd.FORWARD,this.moveState.forward=1;break;case Gp.DOWN:case Gp.S:t=Hd.BACK,this.moveState.back=1;break;case Gp.LEFT:case Gp.A:t=Hd.LEFT,this.moveState.left=1;break;case Gp.RIGHT:case Gp.D:t=Hd.RIGHT,this.moveState.right=1;break;case Gp.Q:t=Hd.UP,this.moveState.up=1;break;case Gp.E:t=Hd.DOWN,this.moveState.down=1;break;case Gp.SHIFTLEFT:this.shiftSpeedup||(this.movementSpeed+=this.defaultMovementSpeed,this.shiftSpeedup=!0);break;case Gp.TAB:return this.moveVector.set(0,0,0),this.moveState.forward=0,this.moveState.back=0,this.moveState.left=0,this.moveState.right=0,this.moveState.up=0,void(this.moveState.down=0);default:return}this._updateMovement(),this._updateRotation(),t!==Hd.NONE&&this.dispatchEvent({type:Fd.ON_CONTROL_KEYDOWN,event:e,direction:t,control:this.name})}}},{key:"processKeyUp",value:function(e){if(!Kp.NoKey){var t=Hd.NONE;switch(e.keyCode){case Gp.UP:case Gp.W:t=Hd.FORWARD,this.moveState.forward=0;break;case Gp.DOWN:case Gp.S:t=Hd.BACK,this.moveState.back=0;break;case Gp.LEFT:case Gp.A:t=Hd.LEFT,this.moveState.left=0;break;case Gp.RIGHT:case Gp.D:t=Hd.RIGHT,this.moveState.right=0;break;case Gp.Q:t=Hd.UP,this.moveState.up=0;break;case Gp.E:t=Hd.DOWN,this.moveState.down=0;break;case Gp.SHIFTLEFT:this.shiftSpeedup&&(this.movementSpeed-=this.defaultMovementSpeed,this.shiftSpeedup=!1);break;default:return void(t=Hd.NONE)}this._updateMovement(),this._updateRotation(),t!==Hd.NONE&&this.dispatchEvent({type:Fd.ON_CONTROL_KEYUP,event:e,direction:t,control:this.name})}}},{key:"updateWalkMove",value:function(){var e=this._clock.getDelta(),t=this.cameraControl,i=t.camera.position.z;if(0!==this.moveVector.x||0!==this.moveVector.y||0!==this.moveVector.z||0!==this.rotationVector.x||0!==this.rotationVector.y||0!==this.rotationVector.z||0!==this.zoomDelta||0!==t.gravity){var n=this.movementSpeed*Kp.WalkSpeedRate*e;if(1==xd.WalkingWithGravity&&(this.moveVector.z=0,t.computeManHeight(),t.computeGravity()),t.dirtyCamera(!0),0!==this.zoomDelta)t.userInputHelper.adjustCameraForZoom(this.zoomDelta*e),this.zoomDelta=0;0!==n&&t.translateCameraForWalk(this.moveVector,n),t.rotateCameraForWalk(this.rotationVector,this.dragLook?1:2),t.flyOnWorld(!1),this.moveState.pitchUp=0,this.moveState.pitchDown=0,this.moveState.yawLeft=0,this.moveState.yawRight=0,this.moveState.rollLeft=0,this.moveState.rollRight=0,i!==t.camera.position.z&&t.viewer.modelManager.dispatchEvent({type:Fd.ON_CAMERA_HEIGHT_CHANGED,cameraPosition:t.camera.position.clone()}),t.dispatchEvent({type:Fd.ON_CONTROL_WALKING})}}},{key:"onEnter",value:function(){var e=this.cameraControl.getCamera();e.isPerspective||(console.log("Current camera is Orthographic"),e.toPerspective()),this._start()}},{key:"onExit",value:function(){this._stop(),this.moveVector=new Ke(0,0,0),this.moveState={up:0,down:0,left:0,right:0,forward:0,back:0,pitchUp:0,pitchDown:0,yawLeft:0,yawRight:0,rollLeft:0,rollRight:0}}},{key:"rotateTo",value:function(e){this._doRotate(e)}},{key:"moveTo",value:function(e,t,i){if(void 0===i&&(i=!0),void 0===t&&(t=1),i)switch(e){case Hd.FORWARD:this.moveState.forward=t;break;case Hd.BACK:this.moveState.back=t;break;case Hd.LEFT:this.moveState.left=t;break;case Hd.RIGHT:this.moveState.right=t;break;case Hd.UP:this.moveState.up=t;break;case Hd.DOWN:this.moveState.down=t}else switch(e){case Hd.FORWARD:this.moveState.forward=0;break;case Hd.BACK:this.moveState.back=0;break;case Hd.LEFT:this.moveState.left=0;break;case Hd.RIGHT:this.moveState.right=0;break;case Hd.UP:this.moveState.up=0;break;case Hd.DOWN:this.moveState.down=0}this._updateMovement()}},{key:"setHeightLocked",value:function(e){this.lockHeightEnabled&&this.isLockHeight!==e&&(this.isLockHeight=e)}},{key:"setDragLook",value:function(e){this.dragLook!==e&&(this.firstRotate=!0,this.dragLook=e)}},{key:"processPointerLockEnter",value:function(){this.pointerLock=!0}},{key:"processPointerLockExit",value:function(){this.pointerLock=!1}},{key:"processMovement",value:function(e){this.rotateDelta.set(e.movementX||e.mozMovementX||e.webkitMovementX||0,e.movementY||e.mozMovementY||e.webkitMovementY||0),this._doRotate(this.rotateDelta)}}]),i}(um),Im=function(){this.control=null,this.controls={},this.tools=[],this.domElement=null,this.enabled=!0,this.isUpdateRenderList=!0;var e=!1;this.userInputControl=null;var t=this;function i(i){if(t.enabled){for(var n=t.tools,r=n.length-1;r>=0;r-=1)if(n[r].onEvent(i)){switch(i.type){case"mouseup":t.userInputControl.processMouseUp(i),e=!1}return}switch(i.type){case"touchmove":!function(e){t.control.isUserInputControl()||t.control.processTouchmove(e),t.userInputControl.processTouchmove(e)}(i);break;case"touchstart":!function(e){t.control.isUserInputControl()||t.control.processTouchstart(e),t.userInputControl.processTouchstart(e)}(i);break;case"touchend":!function(e){t.control.isUserInputControl()||t.control.processTouchend(e),t.userInputControl.processTouchend(e)}(i);break;case"keydown":!function(e){t.control.isUserInputControl()||t.control.processKeyDown(e),t.userInputControl.processKeyDown(e)}(i);break;case"keyup":!function(e){t.control.isUserInputControl()||t.control.processKeyUp(e),t.userInputControl.processKeyUp(e)}(i);break;case"wheel":case"mousewheel":case"DOMMouseScroll":!function(e){t.cameraChange=!0,t.control.isUserInputControl()||t.control.processMouseWheel(e),t.userInputControl.processMouseWheel(e)}(i);break;case"mousedown":!function(i){t.setFocuse(),e=!0,t.isUpdateRenderList=!1,t.control?(t.control.isUserInputControl()||t.control.processMouseDown(i),t.userInputControl.processMouseDown(i)):Bu.warn("control is null")}(i);break;case"mousemove":!function(i){t.control.name==Vd.THIRDPERSONWALK&&t.setFocuse(),t.pointerLock?t.control.processMovement(i):e?(t.isUpdateRenderList=!1,t.cameraChange=!0,t.control.isUserInputControl()||t.control.processMouseMove(i),t.userInputControl.processMouseMove(i)):t.control.processHover(i)}(i);break;case"mouseup":!function(i){t.isUpdateRenderList=!0,e&&(t.control.isUserInputControl()||t.control.processMouseUp(i),t.userInputControl.processMouseUp(i),e=!1)}(i);break;case"dblclick":t.control.processMouseDoubleClick(i)}}else t.cameraChange=!1}function n(e){e.preventDefault()}function r(e){document.pointerLockElement===t.domElement||document.mozPointerLockElement===t.domElement||document.webkitPointerLockElement===t.domElement?(t.pointerLock=!0,t.control.processPointerLockEnter(e)):(t.pointerLock=!1,t.control.processPointerLockExit(e),t.domElement.focus(),t.control.dispatchEvent({type:Fd.ON_POINTERLOCK_EXIST,name:t.control.getName()}))}function o(e){t.pointerLock=!1,t.control.processPointerLockExit(e),t.control.dispatchEvent({type:Fd.ON_POINTERLOCK_EXIST,name:t.control.getName()})}this._componentTransformTool=void 0,this.setFocuse=function(){if(t.domElement){var e=t.domElement.querySelector(".main-canvas");e&&e.focus&&e.focus()}},this.setFocus=this.setFocuse,this.getCameraControl=function(){return this.cameraControl},this.registerDomEventListeners=function(e){this.domElement=e,e.addEventListener("contextmenu",n,!1),e.addEventListener("mousedown",i,!1),e.addEventListener("mousewheel",i,!1),e.addEventListener("DOMMouseScroll",i,!1),e.addEventListener("wheel",i,!1),e.addEventListener("dblclick",i,!1),window.addEventListener("mousemove",i,!1),window.addEventListener("mouseup",i,!1),e.addEventListener("touchstart",i,!1),e.addEventListener("touchend",i,!1),e.addEventListener("touchmove",i,!1),window.addEventListener("touchmove",(function(e){}),!1),e.addEventListener("keydown",i,!1),window.addEventListener("keyup",i,!1),document.addEventListener("pointerlockchange",r,!1),document.addEventListener("mozpointerlockchange",r,!1),document.addEventListener("webkitpointerlockchange",r,!1),document.addEventListener("pointerlockerror",o,!1),document.addEventListener("mozpointerlockerror",o,!1),document.addEventListener("webkitpointerlockerror",o,!1),this.setFocuse()},this.unregisterDomEventListeners=function(e){e.removeEventListener("contextmenu",n,!1),e.removeEventListener("mousedown",i,!1),e.removeEventListener("mousewheel",i,!1),e.removeEventListener("DOMMouseScroll",i,!1),e.removeEventListener("dblclick",i,!1),window.removeEventListener("mousemove",i,!1),window.removeEventListener("mouseup",i,!1),e.removeEventListener("touchstart",i,!1),e.removeEventListener("touchend",i,!1),e.removeEventListener("touchmove",i,!1),e.removeEventListener("keydown",i,!1),window.removeEventListener("keyup",i,!1),document.removeEventListener("pointerlockchange",r,!1),document.removeEventListener("mozpointerlockchange",r,!1),document.removeEventListener("webkitpointerlockchange",r,!1),document.removeEventListener("pointerlockerror",o,!1),document.removeEventListener("mozpointerlockerror",o,!1),document.removeEventListener("webkitpointerlockerror",o,!1)}};Im.prototype={constructor:Im,destroy:function(){for(var e in this.control=null,this.controls){this.controls[e].destroy()}this.controls={};for(var t=0,i=this.tools.length;i>t;t+=1)this.tools[t].destroy();this.tools=null,this.unregisterDomEventListeners(this.domElement),this.domElement=null},getCurrentControlName:function(){return this.control?this.control.name:""},_getControlByName:function(e,t){var i=this.controls[t],n=Vd;this.viewer=e,this.cameraControl=e.cameraControl;var r=e.cameraControl;switch(t){case n.ORBIT:this.userInputControl.setOrbitControlMode(),i=this.userInputControl.orbitControl;break;case n.PICK:this.userInputControl.setDefaultControlMode(),i=wp.isDefined(i)?i:new fm(r);break;case n.PAN:this.userInputControl.setPanControlMode(),i=this.userInputControl.panControl;break;case n.FLY:this.userInputControl.enable=!1,i=wp.isDefined(i)?i:new pm(r);break;case n.WALK:this.userInputControl.enable=!1,i=wp.isDefined(i)?i:new Cm(r);break;case n.ZOOM:this.userInputControl.setZoomControlMode(),i=this.userInputControl.zoomControl;break;default:i=null,Bu.error("invalid control name")}return i&&(i.name=t,this.controls[t]=i),i},getCurrentControlMode:function(){return this.control},setupUserInputControl:function(e){this.userInputControl=new vm(e)},getCurrentControl:function(){return this.control},setControlMode:function(e,t){var i=this._getControlByName(e,t);i&&this.control!==i&&(null!==this.control&&(this.control.dispatchEvent({type:Fd.ON_CONTROL_EXIST,name:this.control.getName()}),this.control.onExit()),this.control=i,this.control.onEnter(),this.control.dispatchEvent({type:Fd.ON_CONTROL_ENTER,name:this.control.getName()}))},getToolByName:function(e){for(var t=this.tools.length,i=0;t>i;i+=1)if(this.tools[i].name===e)return this.tools[i]},enableTool:function(e,t){for(var i=Yd,n=this.tools,r=0,o=n.length;o>r;r+=1)if(n[r].name===t)return;var a=null;switch(t){case i.PICK_BY_RECT:a=new am(e);break;case i.ZOOM_BY_RECT:a=new sm(e);break;case i.CLIP_BY_BOX:a=new Hg(e);break;case i.CLIP_FILL:a=new tf(e);break;case i.PICK_BY_MEASURE:a=new em(e);break;case i.VIEW_SHED_ANALYSIS:a=new dm(e);break;case i.COMPONENT_TRANSFORM:a=new qg(e.getScene(),e.camera,e.domElement),jg(this._componentTransformTool)&&(a.transformControl._listeners=this._componentTransformTool.transformControl._listeners),this._componentTransformTool=a}a&&n.push(a)},disableTool:function(e){for(var t=this.tools,i=0,n=t.length;n>i;i+=1)if(t[i].name===e){t[i].onExit(),this.dispatchEvent({type:Fd.ON_CONTROL_EXIST,name:e}),t.splice(i,1);break}},setInteractiveState:function(e){this.enabled=e},requestPointerLock:function(){this.control instanceof Cm&&(this.domElement.requestPointerLock=this.domElement.requestPointerLock||this.domElement.mozRequestPointerLock||this.domElement.webkitRequestPointerLock,this.domElement.requestPointerLock())}},Object.assign(Im.prototype,hg.prototype),Object.defineProperties(Im.prototype,{componentTransformTool:{get:function(){var e=this._componentTransformTool;return jg(e)||console.error("TransformTool控件未初始化可以使用viewer3D.controlManager.enableTool方法初始化控件"),e}}});var xm=function(){function e(t,i){ru(this,e),this.id=t,this.object=i}return au(e,[{key:"destroy",value:function(){this.object=null}},{key:"_inDistanceRange",value:function(e,t){return e>=t.near&&t.far>=e}},{key:"raycast",value:function(e,t,i,n,r){}}]),e}();xm.prototype.destroy=function(){};var wm=function(e){lu(i,e);var t=pu(i);function i(e,n){return ru(this,i),t.call(this,e,n)}return au(i,[{key:"raycast",value:function(e,t,i,n,r,o){var a=[];if(this.object.raycast(e,a),a.length>0){a.sort((function(e,t){return e.distance-t.distance}));for(var s=0,l=a.length;l>s;s+=1){var c=a[s];if(this._inDistanceRange(c.distance,i)&&!n.clipPoint(c.point)){o||(i.far=c.distance-wp.MinusEpsilon),r.push(c);break}}}}}]),i}(xm),Mm=function(e){lu(i,e);var t=pu(i);function i(e,n){return ru(this,i),t.call(this,e,n)}return au(i,[{key:"raycast",value:function(e,t,i,n,r,o){var a=this.object,s=a._indicesGroup;if(s){var l=s[t.userId];if(l){for(var c,h=!1,d=0,u=l.length;u>d;d+=1)if(l[d].nodeId===t.nodeId){c=l[d],h=!0;break}if(h){var p=[];if(a.raycastByIndices(e,p,c),p.length>0){p.sort((function(e,t){return e.distance-t.distance}));for(var g=0,f=p.length;f>g;g+=1){var m=p[g];if(this._inDistanceRange(m.distance,i)&&!n.clipPoint(m.point)){o||(i.far=m.distance-wp.MinusEpsilon),m.userId=c.userId,m.indexInfo=c,r.push(m);break}}}}}}}}]),i}(xm),Em=function(e){lu(i,e);var t=pu(i);function i(e,n){return ru(this,i),t.call(this,e,n)}return au(i,[{key:"raycast",value:function(e,t,i,n,r,o){var a=[];if(this.object.raycastByIndices(e,a,null,t.matrix),a.length>0){a.sort((function(e,t){return e.distance-t.distance}));for(var s=0,l=a.length;l>s;s+=1){var c=a[s];if(this._inDistanceRange(c.distance,i)&&!n.clipPoint(c.point)){o||(i.far=c.distance-wp.MinusEpsilon),c.userId=t.userId,c.matrix=t.matrix,r.push(c);break}}}}}]),i}(xm),Bm=function(e){lu(i,e);var t=pu(i);function i(e,n){return ru(this,i),t.call(this,e,n)}return au(i,[{key:"raycast",value:function(e,t,i,n,r,o){var a=[];if(this.object.raycastByIndices(e,a,t,t.matrix),a.length>0){a.sort((function(e,t){return e.distance-t.distance}));for(var s=0,l=a.length;l>s;s+=1){var c=a[s];if(this._inDistanceRange(c.distance,i)&&!n.clipPoint(c.point)){o||(i.far=c.distance-wp.MinusEpsilon),c.userId=t.userId,c.nodeId=t.nodeId,c.matrix=t.matrix,c.indexInfo=t,r.push(c);break}}}}}]),i}(xm),Sm="\n #ifdef HEIGHT_LIMIT_READ\n uniform mat4 heightLimitOrthoMatrix;\n varying vec3 v_HeightLimitOrthoPosition;\n varying float heightWorld;\n #endif\n",bm="\n #ifdef HEIGHT_LIMIT_READ\n vec4 othPostion = heightLimitOrthoMatrix * modelMatrix * vec4( transformed, 1.0 );//???\n othPostion /= othPostion.w;\n v_HeightLimitOrthoPosition = othPostion.xyz;\n heightWorld = (modelMatrix * vec4( transformed, 1.0 )).y;\n #endif\n",km="\n #ifdef HEIGHT_LIMIT_READ\n varying vec3 v_HeightLimitOrthoPosition;\n uniform sampler2D heightLimitSampler;\n uniform sampler2D heightColorSampler;\n varying float heightWorld;\n\n vec2 postProjToScreen(vec2 position)\n {\n vec2 screenPos = position;\n \n return 0.5 *(vec2(screenPos.x, screenPos.y) + 1.0);\n }\n\n float decode_float(vec4 v) {\n vec4 bits = v * 255.0;\n float sign = mix(-1.0, 1.0, step(bits[3], 128.0));\n float expo = floor(mod(bits[3] + 0.1, 128.0)) * 2.0 + floor((bits[2] + 0.1) / 128.0) - 127.0;\n float sig = bits[0] + bits[1] * 256.0 + floor(mod(bits[2] + 0.1, 128.0)) * 256.0 * 256.0;\n return sign * (1.0 + sig / 8388607.0) * pow(2.0, expo);\n }\n\n #endif\n\n #ifdef HEIGHT_LIMIT_WRITE\n uniform float heightLimit;\n uniform bool useHeightLimit;\n\n #define FLOAT_MAX 1.70141184e38\n #define FLOAT_MIN 1.17549435e-38\n lowp vec4 encode_float(highp float v) {\n highp float av = abs(v);\n \n //Handle special cases\n if(av < FLOAT_MIN) {\n return vec4(0.0, 0.0, 0.0, 0.0);\n } else if(v > FLOAT_MAX) {\n return vec4(127.0, 128.0, 0.0, 0.0) / 255.0;\n } else if(v < -FLOAT_MAX) {\n return vec4(255.0, 128.0, 0.0, 0.0) / 255.0;\n }\n \n highp vec4 c = vec4(0,0,0,0);\n \n //Compute exponent and mantissa\n highp float e = floor(log2(av));\n highp float m = av * pow(2.0, -e) - 1.0;\n \n //Unpack mantissa\n c[1] = floor(128.0 * m);\n m -= c[1] / 128.0;\n c[2] = floor(32768.0 * m);\n m -= c[2] / 32768.0;\n c[3] = floor(8388608.0 * m);\n \n //Unpack exponent\n highp float ebias = e + 127.0;\n c[0] = floor(ebias / 2.0);\n ebias -= c[0] * 2.0;\n c[1] += floor(ebias) * 128.0;\n \n //Unpack sign bit\n c[0] += 128.0 * step(0.0, -v);\n \n //Scale back to range\n return c / 255.0;\n }\n #endif\n",Dm="\n #ifdef HEIGHT_LIMIT_READ\n vec2 heightLimitUV = postProjToScreen(v_HeightLimitOrthoPosition.xy);\n if(heightLimitUV.x >= 0.0 && heightLimitUV.x <= 1.0 && heightLimitUV.y >= 0.0 && heightLimitUV.y <= 1.0)\n {\n vec4 color = texture2D(heightColorSampler, heightLimitUV);\n \n vec4 heightColor = texture2D(heightLimitSampler, heightLimitUV);\n float heightLimit0 = decode_float(heightColor);//unpackRGBAToDepth\n if(color.a > 0.01 &&heightWorld > heightLimit0 && (heightColor != vec4(0.0,0.0,0.0,0.0))) // edge\n {\n gl_FragColor = color;//a?\n }\n }\n #endif\n #ifdef HEIGHT_LIMIT_WRITE\n if(useHeightLimit){\n gl_FragColor = encode_float(heightLimit).abgr;//packDepthToRGBA(heightLimit);//(0-1)\n }\n #endif\n\n",Tm="\n #define PHONG\n varying vec3 vViewPosition;\n #ifndef FLAT_SHADED\n varying vec3 vNormal;\n #endif\n #include <common>\n #include <uv_pars_vertex>\n #include <uv2_pars_vertex>\n #include <displacementmap_pars_vertex>\n #include <envmap_pars_vertex>\n #include <color_pars_vertex>\n #include <fog_pars_vertex>\n #include <morphtarget_pars_vertex>\n #include <skinning_pars_vertex>\n #include <shadowmap_pars_vertex>\n #include <logdepthbuf_pars_vertex>\n #ifdef USE_CLIPPING\n #include <clipping_planes_pars_vertex>\n #endif\n\n uniform mat4 u_CullOrthoMatrix;\n varying vec3 v_CullOrthoPosition;\n\n void main()\n {\n vec4 othPos = u_CullOrthoMatrix * (modelMatrix * vec4(position, 1.0));\n othPos /= othPos.w;\n v_CullOrthoPosition = othPos.xyz;\n\n #include <uv_vertex>\n #include <uv2_vertex>\n #include <color_vertex>\n #include <beginnormal_vertex>\n #include <morphnormal_vertex>\n #include <skinbase_vertex>\n #include <skinnormal_vertex>\n #include <defaultnormal_vertex>\n #ifndef FLAT_SHADED\n vNormal = normalize( transformedNormal );\n #endif\n #include <begin_vertex>\n #include <displacementmap_vertex>\n #include <morphtarget_vertex>\n #include <skinning_vertex>\n\n #ifdef USE_SKINNING\n vec4 wPosition = modelMatrix * skinned;\n #else\n vec4 wPosition = modelMatrix * vec4( transformed, 1.0 );\n #endif\n\n vec4 mvPosition = viewMatrix * wPosition;\n gl_Position = projectionMatrix * mvPosition;\n \n #include <logdepthbuf_vertex>\n vViewPosition = - mvPosition.xyz;\n #ifdef USE_CLIPPING\n #include <clipping_planes_vertex>\n #endif\n #include <worldpos_vertex>\n #include <envmap_vertex>\n #include <shadowmap_vertex>\n #include <fog_vertex>\n }",Rm="\n #define PHONG\n uniform vec3 diffuse;\n uniform vec3 emissive;\n uniform vec3 specular;\n uniform float shininess;\n uniform float opacity;\n #include <common>\n #include <packing>\n #include <dithering_pars_fragment>\n #include <color_pars_fragment>\n #include <uv_pars_fragment>\n #include <uv2_pars_fragment>\n #include <map_pars_fragment>\n #include <alphamap_pars_fragment>\n #include <aomap_pars_fragment>\n #include <lightmap_pars_fragment>\n #include <emissivemap_pars_fragment>\n #include <envmap_pars_fragment>\n #include <gradientmap_pars_fragment>\n #include <fog_pars_fragment>\n #include <bsdfs>\n #include <lights_pars_begin>\n #include <lights_phong_pars_fragment>\n #include <shadowmap_pars_fragment>\n #include <bumpmap_pars_fragment>\n #include <normalmap_pars_fragment>\n #include <specularmap_pars_fragment>\n #include <logdepthbuf_pars_fragment>\n #include <csm_fragment>\n #ifdef USE_CLIPPING\n #include <clipping_planes_pars_fragment>\n #endif\n\n uniform float brightness;\n uniform float contrast;\n uniform float saturation;\n uniform float hue;\n uniform float gamma;\n uniform vec4 customColor;\n uniform float useCustomColor;\n\n varying vec3 v_CullOrthoPosition;\n uniform sampler2D u_SamplerExcavation;\n \n vec2 postProjToScreen(vec2 position)\n {\n vec2 screenPos = position;\n \n return 0.5 *(vec2(screenPos.x, screenPos.y) + 1.0);\n }\n\n vec4 depthColor(vec4 color)\n {\n color.r = color.r * color.r * color.r;\n color.g = color.g * color.g * color.g;\n color.b = color.b * color.b;\n return color;\n }\n\n vec3 computeContrast(vec3 rgb, float contrast)\n {\n vec3 color = mix(vec3(0.5), rgb, contrast);\n color = clamp(color, 0.0, 1.0);\n return color;\n }\n\n vec3 computeHue(vec3 rgb, float adjustment)\n {\n const mat3 toYIQ = mat3(0.299, 0.587, 0.114, 0.595716, -0.274453, -0.321263, 0.211456, -0.522591, 0.311135);\n const mat3 toRGB = mat3(1.0, 0.9563, 0.6210, 1.0, -0.2721, -0.6474, 1.0, -1.107, 1.7046);\n vec3 yiq = toYIQ * rgb;\n float hue = atan(yiq.z, yiq.y) + adjustment;\n float chroma = sqrt(yiq.z * yiq.z + yiq.y * yiq.y);\n vec3 color = vec3(yiq.x, chroma * cos(hue), chroma * sin(hue));\n vec3 final = toRGB * color;\n final = clamp(final, 0.0, 1.0);\n return final;\n }\n\n vec3 computeSaturation(vec3 rgb, float adjustment)\n {\n const vec3 W = vec3(0.2125, 0.7154, 0.0721);\n vec3 intensity = vec3(dot(rgb, W));\n vec3 color = mix(intensity, rgb, adjustment);\n color = clamp(color, 0.0, 1.0);\n return color;\n }\n\n vec4 sampleAndBlend(float useCustom, vec4 customColor, vec4 earthColor, float brightness, float contrast, float hue, float saturation, float gamma)\n {\n vec4 value = earthColor;\n if (useCustom == 1.0) {\n value = depthColor(value);\n value.rgb *= customColor.rgb;\n }\n vec3 color = value.rgb;\n float alpha = value.a;\n \n //brightness\n color = mix(vec3(0.0, 0.0, 0.0), color, brightness);\n \n //contrast\n color = computeContrast(color, contrast);\n\n //hue\n color = computeHue(color, hue);\n\n //saturation\n color = computeSaturation(color, saturation);\n\n //gamma\n color = pow(color, vec3(gamma));\n\n return vec4(color, alpha);\n }\n\n void main()\n {\n vec2 uv = postProjToScreen(v_CullOrthoPosition.xy);\n if(uv.x >= 0.0 && uv.x <= 1.0 && uv.y >= 0.0 && uv.y <= 1.0)\n {\n vec4 color = texture2D(u_SamplerExcavation, uv);\n if(color.r > 0.0001)\n {\n discard;\n }\n }\n \n #ifdef USE_CLIPPING\n #include <clipping_planes_fragment>\n #endif\n\n vec4 diffuseColor = vec4( diffuse, opacity );\n ReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\n vec3 totalEmissiveRadiance = emissive;\n #include <logdepthbuf_fragment>\n #include <map_fragment>\n #include <color_fragment>\n #include <alphamap_fragment>\n #include <alphatest_fragment>\n #include <specularmap_fragment>\n #include <normal_fragment_maps>\n #include <normal_fragment_begin>\n #include <emissivemap_fragment>\n #include <lights_phong_fragment>\n \n GeometricContext geometry;\n geometry.position = - vViewPosition;\n geometry.normal = normal;\n geometry.viewDir = normalize( vViewPosition );\n IncidentLight directLight;\n #if ( NUM_DIR_LIGHTS > 0 ) && defined( RE_Direct ) && defined( USE_CSM )\n DirectionalLight directionalLight;\n float shadowValue = calcShadowFactor(geometry.normal);\n shadowValue = max(shadowValue, 0.1);\n #ifdef USE_SHADOWMAP\n if(opacity > 0.9)\n diffuseColor.rgb *= shadowValue;\n #endif\n #if defined( USE_SHADOWMAP ) && NUM_DIR_LIGHT_SHADOWS > 0\n DirectionalLightShadow directionalLightShadow;\n #endif\n #pragma unroll_loop_start\n for ( int i = 4; i < NUM_DIR_LIGHTS; i ++ ) {\n directionalLight = directionalLights[ i ];\n getDirectionalDirectLightIrradiance( directionalLight, geometry, directLight );\n #if defined( USE_SHADOWMAP ) && (NUM_DIR_LIGHT_SHADOWS > 0) && ( UNROLLED_LOOP_INDEX < NUM_DIR_LIGHT_SHADOWS )\n directionalLightShadow = directionalLightShadows[i - 4];\n if(opacity > 0.9)\n diffuseColor.rgb *= all( bvec2(receiveShadow, directLight.visible ) ) ? getShadow( directionalShadowMap[ i - 4 ], directionalLightShadow.shadowMapSize, directionalLightShadow.shadowBias, directionalLightShadow.shadowRadius, vDirectionalShadowCoord[ i - 4 ] ) : 1.0;\n #endif\n }\n #pragma unroll_loop_end\n #endif\n\n #if ( NUM_DIR_LIGHTS > 0 ) && defined( RE_Direct ) && !defined( USE_CSM )\n DirectionalLight directionalLight;\n #if defined( USE_SHADOWMAP ) && NUM_DIR_LIGHT_SHADOWS > 0\n DirectionalLightShadow directionalLightShadow;\n #endif\n #pragma unroll_loop_start\n for ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) {\n directionalLight = directionalLights[ i ];\n getDirectionalDirectLightIrradiance( directionalLight, geometry, directLight );\n #if defined( USE_SHADOWMAP ) && (NUM_DIR_LIGHT_SHADOWS > 0) && ( UNROLLED_LOOP_INDEX < NUM_DIR_LIGHT_SHADOWS )\n directionalLightShadow = directionalLightShadows[ i ];\n if(opacity > 0.9)\n diffuseColor.rgb *= all( bvec2( receiveShadow, directLight.visible ) ) ? getShadow( directionalShadowMap[ i ], directionalLightShadow.shadowMapSize, directionalLightShadow.shadowBias, directionalLightShadow.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0;\n #endif\n }\n #pragma unroll_loop_end\n #endif\n \n vec3 outgoingLight = diffuseColor.rgb;\n #include <envmap_fragment>\n vec4 resultColor = vec4( outgoingLight, diffuseColor.a );\n gl_FragColor = sampleAndBlend(useCustomColor, customColor, resultColor, brightness, contrast, hue, saturation, gamma);\n\n #include <tonemapping_fragment>\n #include <encodings_fragment>\n #include <fog_fragment>\n #include <premultiplied_alpha_fragment>\n #include <dithering_fragment>\n }",Um="\n #ifdef USE_ATTRIBUTE_SIZE\n attribute float attrSize;\n #endif\n uniform float size;\n uniform float scale;\n #include <common>\n #include <color_pars_vertex>\n #include <fog_pars_vertex>\n #include <logdepthbuf_pars_vertex>\n #include <clipping_planes_pars_vertex>\n void main() {\n #include <color_vertex>\n #include <begin_vertex>\n #include <project_vertex>\n #ifdef USE_ATTRIBUTE_SIZE\n gl_PointSize = attrSize;\n #else\n #ifdef USE_SIZEATTENUATION\n gl_PointSize = size * ( scale / - mvPosition.z );\n #else\n gl_PointSize = size;\n #endif\n #endif\n #ifdef USE_POSITION_OFFSET\n float yPos = gl_Position.y;\n float w = gl_Position.w;\n yPos /= w;\n yPos += 0.5 * gl_PointSize / scale;\n yPos *= w;\n gl_Position.y = yPos;\n #endif\n #include <logdepthbuf_vertex>\n #include <clipping_planes_vertex>\n #include <worldpos_vertex>\n #include <fog_vertex>\n }",Fm="\n uniform vec3 diffuse;\n uniform float opacity;\n #include <common>\n #include <packing>\n #include <color_pars_fragment>\n #include <map_particle_pars_fragment>\n #include <fog_pars_fragment>\n #include <shadowmap_pars_fragment>\n #include <logdepthbuf_pars_fragment>\n #include <clipping_planes_pars_fragment>\n void main() {\n #include <clipping_planes_fragment>\n vec3 outgoingLight = vec3( 0.0 );\n vec4 diffuseColor = vec4( diffuse, opacity );\n #include <logdepthbuf_fragment>\n #include <map_particle_fragment>\n #include <color_fragment>\n #include <alphatest_fragment>\n outgoingLight = diffuseColor.rgb;\n gl_FragColor = vec4( outgoingLight, diffuseColor.a );\n #include <premultiplied_alpha_fragment>\n #include <tonemapping_fragment>\n #include <encodings_fragment>\n #include <fog_fragment>\n }",Qm="\n #ifdef VIDEO_CAST_MODE\n const int MAX_VIDEO_CAST_COUNT = 4;\n uniform int videoCastCount;\n struct VideoCastContent {\n mat4 viewProjMatrix;\n mat4 viewMatrix;\n float logDepthBufFC;\n };\n\n uniform VideoCastContent videoCastContents[ MAX_VIDEO_CAST_COUNT ];\n varying float videoCastFragDepth[MAX_VIDEO_CAST_COUNT];\n varying vec3 videoCastWorldPosition;\n #endif\n",Lm="\n #ifdef VIDEO_CAST_MODE\n const int MAX_VIDEO_CAST_COUNT = 4;\n uniform int videoCastCount;\n uniform sampler2D videoCastDepthMaps[ MAX_VIDEO_CAST_COUNT ];\n uniform sampler2D videoCastProjectorMaps[ MAX_VIDEO_CAST_COUNT];\n\n struct VideoCastContent {\n mat4 viewProjMatrix;\n mat4 viewMatrix;\n float logDepthBufFC;\n };\n\n uniform VideoCastContent videoCastContents[ MAX_VIDEO_CAST_COUNT ];\n varying float videoCastFragDepth[MAX_VIDEO_CAST_COUNT];\n varying vec3 videoCastWorldPosition;\n \n float toLinearDepth(float fragCoordZ, float near, float far)\n {\n float viewZ = perspectiveDepthToViewZ( fragCoordZ, near, far );\n return viewZToOrthographicDepth( viewZ, near, far );\n }\n\n float sampleDepthMap(sampler2D depthMap, vec2 uv){\n vec4 depthColor = texture2D(depthMap, uv);\n return unpackRGBAToDepth(depthColor);\n }\n\n float videoCastDepthCompare(sampler2D depthMap, vec2 uv, float depth){\n return step(depth, sampleDepthMap(depthMap, uv));\n }\n\n float videoCastVisibility(sampler2D depthMap, vec2 uv, float depth, float depthBias){\n depth -= depthBias;\n vec2 texelStepSize = 1.0 / vec2(1024.0, 1024.0);\n float radius = 1.0;\n float dx0 = -texelStepSize.x * radius;\n float dy0 = -texelStepSize.y * radius;\n float dx1 = texelStepSize.x * radius;\n float dy1 = texelStepSize.y * radius;\n float visibility =\n (\n videoCastDepthCompare(depthMap, uv, depth) +\n videoCastDepthCompare(depthMap, uv + vec2(dx0, dy0), depth) +\n videoCastDepthCompare(depthMap, uv + vec2(0.0, dy0), depth) +\n videoCastDepthCompare(depthMap, uv + vec2(dx1, dy0), depth) +\n videoCastDepthCompare(depthMap, uv + vec2(dx0, 0.0), depth) +\n videoCastDepthCompare(depthMap, uv + vec2(dx1, 0.0), depth) +\n videoCastDepthCompare(depthMap, uv + vec2(dx0, dy1), depth) +\n videoCastDepthCompare(depthMap, uv + vec2(0.0, dy1), depth) +\n videoCastDepthCompare(depthMap, uv + vec2(dx1, dy1), depth)\n ) * (1.0 / 9.0)\n ;\n return visibility;\n }\n #endif\n",Om="\n #ifdef VIDEO_CAST_MODE\n for (int i=0; i<MAX_VIDEO_CAST_COUNT; i++)\n {\n if (i >= videoCastCount)\n {\n break;\n }\n vec4 videoCastProjPosition = videoCastContents[i].viewProjMatrix * vec4(vsWorldPosition.xyz, 1.0);\n float fragDepth = 1.0 + videoCastProjPosition.w;\n videoCastFragDepth[i] = fragDepth;\n }\n videoCastWorldPosition = vsWorldPosition.xyz;\n #endif\n",Nm="\n #ifdef VIDEO_CAST_MODE\n vec3 resultColor = gl_FragColor.rgb;\n for (int i=0; i<MAX_VIDEO_CAST_COUNT; i++)\n {\n if (i >= videoCastCount)\n {\n break;\n }\n vec4 videoCastViewPosition = videoCastContents[i].viewMatrix * vec4(videoCastWorldPosition, 1.0);\n vec4 videoCastClipPosition = videoCastContents[i].viewProjMatrix * vec4(videoCastWorldPosition, 1.0);\n videoCastClipPosition = videoCastClipPosition / videoCastClipPosition.w;\n vec3 videoCastUV = videoCastClipPosition.xyz * 0.5 + 0.5;\n\n vec4 textureColor = texture2D(videoCastProjectorMaps[i], videoCastUV.xy);\n \n float fragDistance = length(videoCastViewPosition.xyz);\n if(videoCastUV.x >= 0.0 && videoCastUV.x <= 1.0 &&\n videoCastUV.y >=0.0 && videoCastUV.y <= 1.0 &&\n videoCastUV.z >=0.0 && videoCastUV.z <= 1.0)\n {\n float fragZ = log2( videoCastFragDepth[i] ) * videoCastContents[i].logDepthBufFC * 0.5;\n vec4 depthColor = texture2D(videoCastDepthMaps[i], videoCastUV.xy);\n float closetDepth = unpackRGBAToDepth(depthColor);\n float depthBias = 0.002 + smoothstep(100.0, 1000.0, fragDistance) * 0.058;\n \n if (fragZ - depthBias < closetDepth)\n {\n resultColor = textureColor.rgb;\n }\n }\n }\n\n gl_FragColor.rgb = resultColor;\n #endif\n",Pm="\n #ifdef VIEW_SHED_MODE\n const int MAX_VIEWSHED_COUNT = 4;\n uniform int viewshedCount;\n struct ViewshedContent {\n mat4 viewshedViewProjMatrix;\n mat4 viewshedViewMatrix;\n vec4 viewshedVisibleColor;\n vec4 viewshedHiddenColor;\n vec2 viewshedMinMax;\n float viewshedLogDepthBufFC;\n\t\t};\n uniform ViewshedContent viewshedContents[ MAX_VIEWSHED_COUNT ];\n varying float viewshedFragDepth[MAX_VIEWSHED_COUNT];\n varying vec3 viewshedWorldPosition;\n #endif\n",Gm="\n #ifdef VIEW_SHED_MODE\n const int MAX_VIEWSHED_COUNT = 4;\n uniform int viewshedCount;\n uniform sampler2D viewshedDepthMaps[ MAX_VIEWSHED_COUNT ];\n\n struct ViewshedContent {\n mat4 viewshedViewProjMatrix;\n mat4 viewshedViewMatrix;\n vec4 viewshedVisibleColor;\n vec4 viewshedHiddenColor;\n vec2 viewshedMinMax;\n float viewshedLogDepthBufFC;\n\t\t};\n\n uniform ViewshedContent viewshedContents[ MAX_VIEWSHED_COUNT ];\n varying float viewshedFragDepth[MAX_VIEWSHED_COUNT];\n varying vec3 viewshedWorldPosition;\n \n float toLinearDepth(float fragCoordZ, float near, float far)\n {\n float viewZ = perspectiveDepthToViewZ( fragCoordZ, near, far );\n\t\t\treturn viewZToOrthographicDepth( viewZ, near, far );\n }\n\n float sampleDepthMap(sampler2D depthMap, vec2 uv){\n vec4 depthColor = texture2D(depthMap, uv);\n return unpackRGBAToDepth(depthColor);\n }\n\n float viewshedDepthCompare(sampler2D depthMap, vec2 uv, float depth){\n return step(depth, sampleDepthMap(depthMap, uv));\n }\n\n float viewshedVisibility(sampler2D depthMap, vec2 uv, float depth, float depthBias){\n depth -= depthBias;\n vec2 texelStepSize = 1.0 / vec2(1024.0, 1024.0);\n float radius = 1.0;\n float dx0 = -texelStepSize.x * radius;\n float dy0 = -texelStepSize.y * radius;\n float dx1 = texelStepSize.x * radius;\n float dy1 = texelStepSize.y * radius;\n float visibility =\n (\n viewshedDepthCompare(depthMap, uv, depth) +\n viewshedDepthCompare(depthMap, uv + vec2(dx0, dy0), depth) +\n viewshedDepthCompare(depthMap, uv + vec2(0.0, dy0), depth) +\n viewshedDepthCompare(depthMap, uv + vec2(dx1, dy0), depth) +\n viewshedDepthCompare(depthMap, uv + vec2(dx0, 0.0), depth) +\n viewshedDepthCompare(depthMap, uv + vec2(dx1, 0.0), depth) +\n viewshedDepthCompare(depthMap, uv + vec2(dx0, dy1), depth) +\n viewshedDepthCompare(depthMap, uv + vec2(0.0, dy1), depth) +\n viewshedDepthCompare(depthMap, uv + vec2(dx1, dy1), depth)\n ) * (1.0 / 9.0)\n ;\n return visibility;\n }\n #endif\n",Km="\n #ifdef VIEW_SHED_MODE\n for (int i=0; i<MAX_VIEWSHED_COUNT; i++)\n {\n if (i >= viewshedCount)\n {\n break;\n }\n vec4 viewshedProjPosition = viewshedContents[i].viewshedViewProjMatrix * vec4(vsWorldPosition.xyz, 1.0);\n float fragDepth = 1.0 + viewshedProjPosition.w;\n viewshedFragDepth[i] = fragDepth;\n }\n viewshedWorldPosition = vsWorldPosition.xyz;\n #endif\n",Vm="\n #ifdef VIEW_SHED_MODE\n vec3 resultColor = gl_FragColor.rgb;\n for (int i=0; i<MAX_VIEWSHED_COUNT; i++)\n {\n if (i >= viewshedCount)\n {\n break;\n }\n vec4 visibleColor = viewshedContents[i].viewshedVisibleColor;\n vec4 hiddenColor = viewshedContents[i].viewshedHiddenColor;\n vec4 viewshedViewPosition = viewshedContents[i].viewshedViewMatrix * vec4(viewshedWorldPosition, 1.0);\n vec4 viewshedClipPosition = viewshedContents[i].viewshedViewProjMatrix * vec4(viewshedWorldPosition, 1.0);\n viewshedClipPosition = viewshedClipPosition / viewshedClipPosition.w;\n vec3 viewshedUV = viewshedClipPosition.xyz * 0.5 + 0.5;\n\n vec2 minMax = viewshedContents[i].viewshedMinMax;\n float fragDistance = length(viewshedViewPosition.xyz);\n if(fragDistance <= minMax.y &&\n viewshedUV.x >= 0.0 && viewshedUV.x <= 1.0 &&\n viewshedUV.y >=0.0 && viewshedUV.y <= 1.0 &&\n viewshedUV.z >=0.0 && viewshedUV.z <= 1.0)\n {\n float fragZ = log2( viewshedFragDepth[i] ) * viewshedContents[i].viewshedLogDepthBufFC * 0.5;\n vec4 depthColor = texture2D(viewshedDepthMaps[i], viewshedUV.xy);\n float closetDepth = unpackRGBAToDepth(depthColor);\n float depthBias = 0.002 + smoothstep(100.0, 1000.0, fragDistance) * 0.058;\n \n // float visibility = viewshedVisibility(viewshedDepthMaps[i], viewshedUV.xy, fragZ, depthBias);\n // if (visibility == 1.0)\n if (fragZ - depthBias < closetDepth)\n {\n resultColor = mix(visibleColor.rgb, resultColor, 1.0 - visibleColor.a);\n }\n else\n {\n resultColor = mix(hiddenColor.rgb, resultColor, 1.0 - hiddenColor.a);\n }\n }\n }\n\n gl_FragColor.rgb = resultColor;\n #endif\n",Ym="//投影灯光的数量\n#if NUM_PROJECTOR_LIGHTS > 0\n struct ProjectorLight {\n vec3 position;\n mat4 projectorMatrix;\n vec3 color;\n float distance;\n float near;\n float alpha;\n vec4 farPlane;\n int shadow;\n float shadowBias;\n };\n\n uniform ProjectorLight projectorLights[NUM_PROJECTOR_LIGHTS];\n uniform sampler2D projectorTextures[NUM_PROJECTOR_LIGHTS];\n uniform sampler2D projectorAlphaTextures[NUM_PROJECTOR_LIGHTS];\n\n\n void getProjectorDirectLightIrradiance(\n const in ProjectorLight projectorLight,\n const in sampler2D projectorTexture,\n const in sampler2D projectorAlphaTexture,\n const in GeometricContext geometry,\n out IncidentLight directLight)\n {\n vec4 farPlane = projectorLight.farPlane;\n vec3 lVector = projectorLight.position - geometry.position;\n float lightDistance = length( lVector );\n directLight.direction = normalize( lVector );\n vec4 projected = projectorLight.projectorMatrix * vec4(geometry.position, 1.0);\n vec2 projectorUv = 0.5 * (projected.xy / projected.w) + vec2(0.5);\n\n directLight.visible = all(bvec3(\n all(lessThanEqual(projectorUv.xy, vec2(1.0))),\n all(greaterThanEqual(projectorUv.xy, vec2(0.0))),\n projected.z >= 0.0\n ));\n\n if(dot( farPlane.xyz, vWorldPosition) + farPlane.w < 0.0){\n directLight.visible = false;\n }\n\n if (directLight.visible) {\n\n directLight.color = texture2D(projectorTexture, projectorUv).rgb * projectorLight.color;\n directLight.alpha = 1.0;\n \n #if defined(USE_PROJECTORALPHAMAP)\n directLight.alpha = texture2D(projectorAlphaTexture, projectorUv).a;\n #endif\n\n\n } else {\n directLight.color = vec3( 0.0 );\n }\n }\n\n\n \n#endif\n\n",Hm="\n//如果投影灯光的数量大于0\n #if ( NUM_PROJECTOR_LIGHTS > 0 ) && defined( RE_Direct )\n ProjectorLight projectorLight;\n \n //保存模型的原始颜色\n vec3 resColor = gl_FragColor.rgb;\n\n #ifdef USE_PROJECTOR_SHADOWMAP\n // resColor = vec3(1.0);\n #endif\n\n for ( int i = 0; i < NUM_PROJECTOR_LIGHTS; i ++ ) {\n \n projectorLight = projectorLights[ i ];\n \n getProjectorDirectLightIrradiance(projectorLight, projectorTextures[ i], projectorAlphaTextures[ i ], geometry, directLight);\n \n vec3 currentColor = mix(resColor, directLight.color, directLight.alpha);\n \n //不处于阴影\n float isShadow = 1.0;\n\n #ifdef USE_PROJECTOR_SHADOWMAP\n\n isShadow = getShadow2(\n projectorShadowMap[ i ],\n projectorLight.shadowBias,\n vProjectorShadowCoord[ i ]\n ) * directLight.alpha;\n\n float alpha = all( bvec2( projectorLight.shadow, directLight.visible ) )\n ? isShadow : 0.0;\n\n //如果阴影开启\n if(projectorLight.shadow == 1){\n resColor = mix(resColor, directLight.color, alpha * projectorLight.alpha);\n } else if(directLight.visible){\n resColor = mix(gl_FragColor.rgb, currentColor, projectorLight.alpha);\n }\n\n #else\n\n //如果当前处于灯光范围内\n if(directLight.visible){\n resColor = mix(gl_FragColor.rgb, currentColor, projectorLight.alpha);\n }\n\n #endif\n\n RE_Direct( directLight, geometry, material, reflectedLight );\n\n }\n\n gl_FragColor.rgb = resColor;\n\n\n \n \n #endif";xn.projector_lights_pars_begin=Ym,xn.projectorLight_fragment=Hm,xn.projectorLight_pars_vertex="#ifdef USE_PROJECTOR_SHADOWMAP\n #if NUM_PROJECTOR_LIGHTS > 0\n uniform mat4 projectorShadowMatrix[ NUM_PROJECTOR_LIGHTS ];\n varying vec4 vProjectorShadowCoord[ NUM_PROJECTOR_LIGHTS ];\n #endif\n#endif",xn.projectorLight_shadowmap_vertex="#ifdef USE_PROJECTOR_SHADOWMAP\n #if NUM_PROJECTOR_LIGHTS > 0\n #pragma unroll_loop_start\n for ( int i = 0; i < NUM_PROJECTOR_LIGHTS; i ++ ) {\n vProjectorShadowCoord[ i ] = projectorShadowMatrix[ i ] * worldPosition;\n }\n #pragma unroll_loop_end\n #endif\n#endif\n",xn.projectorLight_pars_fragment="#ifdef USE_PROJECTOR_SHADOWMAP\n #if NUM_PROJECTOR_LIGHTS > 0\n uniform sampler2D projectorShadowMap[ NUM_PROJECTOR_LIGHTS ];\n varying vec4 vProjectorShadowCoord[ NUM_PROJECTOR_LIGHTS ];\n #endif\n\n float texture2DCompare2( sampler2D depths, vec2 uv, float compare ) {\n\n return step( compare, unpackRGBAToDepth( texture2D( depths, uv ) ) );\n\n }\n\n float getShadow2( sampler2D shadowMap, float shadowBias, vec4 shadowCoord ) {\n \n float shadow = 1.0;\n\n shadowCoord.xyz /= shadowCoord.w;\n shadowCoord.z += shadowBias * 0.00001;\n\n bvec4 inFrustumVec = bvec4 ( shadowCoord.x >= 0.0, shadowCoord.x <= 1.0, shadowCoord.y >= 0.0, shadowCoord.y <= 1.0 );\n bool inFrustum = all( inFrustumVec );\n\n bvec2 frustumTestVec = bvec2( inFrustum, shadowCoord.z <= 1.0 );\n bool frustumTest = all( frustumTestVec );\n \n if ( frustumTest ) {\n // shadow = step( shadowCoord.z, unpackRGBAToDepth( texture2D( shadowMap, shadowCoord.xy ) ) );\n\n \n vec2 shadowMapSize = vec2(1024.0, 1024.0);\n\n vec2 texelSize = vec2( 1.0 ) / shadowMapSize;\n float dx = texelSize.x;\n float dy = texelSize.y;\n\n vec2 uv = shadowCoord.xy;\n vec2 f = fract( uv * shadowMapSize + 0.5 );\n uv -= f * texelSize;\n\n shadow = (\n texture2DCompare2( shadowMap, uv, shadowCoord.z ) +\n texture2DCompare2( shadowMap, uv + vec2( dx, 0.0 ), shadowCoord.z ) +\n texture2DCompare2( shadowMap, uv + vec2( 0.0, dy ), shadowCoord.z ) +\n texture2DCompare2( shadowMap, uv + texelSize, shadowCoord.z ) +\n mix( texture2DCompare2( shadowMap, uv + vec2( -dx, 0.0 ), shadowCoord.z ),\n texture2DCompare2( shadowMap, uv + vec2( 2.0 * dx, 0.0 ), shadowCoord.z ),\n f.x ) +\n mix( texture2DCompare2( shadowMap, uv + vec2( -dx, dy ), shadowCoord.z ),\n texture2DCompare2( shadowMap, uv + vec2( 2.0 * dx, dy ), shadowCoord.z ),\n f.x ) +\n mix( texture2DCompare2( shadowMap, uv + vec2( 0.0, -dy ), shadowCoord.z ),\n texture2DCompare2( shadowMap, uv + vec2( 0.0, 2.0 * dy ), shadowCoord.z ),\n f.y ) +\n mix( texture2DCompare2( shadowMap, uv + vec2( dx, -dy ), shadowCoord.z ),\n texture2DCompare2( shadowMap, uv + vec2( dx, 2.0 * dy ), shadowCoord.z ),\n f.y ) +\n mix( mix( texture2DCompare2( shadowMap, uv + vec2( -dx, -dy ), shadowCoord.z ),\n texture2DCompare2( shadowMap, uv + vec2( 2.0 * dx, -dy ), shadowCoord.z ),\n f.x ),\n mix( texture2DCompare2( shadowMap, uv + vec2( -dx, 2.0 * dy ), shadowCoord.z ),\n texture2DCompare2( shadowMap, uv + vec2( 2.0 * dx, 2.0 * dy ), shadowCoord.z ),\n f.x ),\n f.y )\n ) * ( 1.0 / 9.0 );\n\n\n }\n\n return shadow;\n }\n#endif";var jm=["uniform bool receiveShadow;","uniform vec3 ambientLightColor;","uniform vec3 lightProbe[ 9 ];","vec3 shGetIrradianceAt( in vec3 normal, in vec3 shCoefficients[ 9 ] ) {"," float x = normal.x, y = normal.y, z = normal.z;"," vec3 result = shCoefficients[ 0 ] * 0.886227;"," result += shCoefficients[ 1 ] * 2.0 * 0.511664 * y;"," result += shCoefficients[ 2 ] * 2.0 * 0.511664 * z;"," result += shCoefficients[ 3 ] * 2.0 * 0.511664 * x;"," result += shCoefficients[ 4 ] * 2.0 * 0.429043 * x * y;"," result += shCoefficients[ 5 ] * 2.0 * 0.429043 * y * z;"," result += shCoefficients[ 6 ] * ( 0.743125 * z * z - 0.247708 );"," result += shCoefficients[ 7 ] * 2.0 * 0.429043 * x * z;"," result += shCoefficients[ 8 ] * 0.429043 * ( x * x - y * y );"," return result;","}","vec3 getLightProbeIrradiance( const in vec3 lightProbe[ 9 ], const in GeometricContext geometry ) {"," vec3 worldNormal = inverseTransformDirection( geometry.normal, viewMatrix );"," vec3 irradiance = shGetIrradianceAt( worldNormal, lightProbe );"," return irradiance;","}","vec3 getAmbientLightIrradiance( const in vec3 ambientLightColor ) {"," vec3 irradiance = ambientLightColor;"," #ifndef PHYSICALLY_CORRECT_LIGHTS"," irradiance *= PI;"," #endif"," return irradiance;","}","#if NUM_DIR_LIGHTS > 0"," struct DirectionalLight {"," vec3 direction;"," vec3 color;"," };"," uniform DirectionalLight directionalLights[ NUM_DIR_LIGHTS ];"," #if defined( USE_SHADOWMAP ) && NUM_DIR_LIGHT_SHADOWS > 0"," struct DirectionalLightShadow {"," float shadowBias;"," float shadowRadius;"," vec2 shadowMapSize;"," };"," uniform DirectionalLightShadow directionalLightShadows[ NUM_DIR_LIGHT_SHADOWS ];"," #endif"," void getDirectionalDirectLightIrradiance( const in DirectionalLight directionalLight, const in GeometricContext geometry, out IncidentLight directLight ) {"," directLight.color = directionalLight.color;"," directLight.direction = directionalLight.direction;"," directLight.visible = true;"," }","#endif","#if NUM_POINT_LIGHTS > 0"," struct PointLight {"," vec3 position;"," vec3 color;"," float distance;"," float decay;"," };"," uniform PointLight pointLights[ NUM_POINT_LIGHTS ];"," #if defined( USE_SHADOWMAP ) && NUM_POINT_LIGHT_SHADOWS > 0"," struct PointLightShadow {"," float shadowBias;"," float shadowRadius;"," vec2 shadowMapSize;"," float shadowCameraNear;"," float shadowCameraFar;"," };"," uniform PointLightShadow pointLightShadows[ NUM_POINT_LIGHT_SHADOWS ];"," #endif"," void getPointDirectLightIrradiance( const in PointLight pointLight, const in GeometricContext geometry, out IncidentLight directLight ) {"," vec3 lVector = pointLight.position - geometry.position;"," directLight.direction = normalize( lVector );"," float lightDistance = length( lVector );"," directLight.color = pointLight.color;"," directLight.color *= punctualLightIntensityToIrradianceFactor( lightDistance, pointLight.distance, pointLight.decay );"," directLight.visible = ( directLight.color != vec3( 0.0 ) );"," }","#endif","#if NUM_SPOT_LIGHTS > 0"," struct SpotLight {"," vec3 position;"," vec3 direction;"," vec3 color;"," float distance;"," float decay;"," float coneCos;"," float penumbraCos;"," };"," uniform SpotLight spotLights[ NUM_SPOT_LIGHTS ];"," #if defined( USE_SHADOWMAP ) && NUM_SPOT_LIGHT_SHADOWS > 0"," struct SpotLightShadow {"," float shadowBias;"," float shadowRadius;"," vec2 shadowMapSize;"," };"," uniform SpotLightShadow spotLightShadows[ NUM_SPOT_LIGHT_SHADOWS ];"," #endif"," void getSpotDirectLightIrradiance( const in SpotLight spotLight, const in GeometricContext geometry, out IncidentLight directLight ) {"," vec3 lVector = spotLight.position - geometry.position;"," directLight.direction = normalize( lVector );"," float lightDistance = length( lVector );"," float angleCos = dot( directLight.direction, spotLight.direction );"," if ( angleCos > spotLight.coneCos ) {"," float spotEffect = smoothstep( spotLight.coneCos, spotLight.penumbraCos, angleCos );"," directLight.color = spotLight.color;"," directLight.color *= spotEffect * punctualLightIntensityToIrradianceFactor( lightDistance, spotLight.distance, spotLight.decay );"," directLight.visible = true;"," } else {"," directLight.color = vec3( 0.0 );"," directLight.visible = false;"," }"," }","#endif","#if NUM_RECT_AREA_LIGHTS > 0"," struct RectAreaLight {"," vec3 color;"," vec3 position;"," vec3 halfWidth;"," vec3 halfHeight;"," };"," uniform sampler2D ltcMat; uniform sampler2D ltcMag;"," uniform RectAreaLight rectAreaLights[ NUM_RECT_AREA_LIGHTS ];","#endif","#if NUM_HEMI_LIGHTS > 0"," struct HemisphereLight {"," vec3 direction;"," vec3 skyColor;"," vec3 groundColor;"," };"," uniform HemisphereLight hemisphereLights[ NUM_HEMI_LIGHTS ];"," vec3 getHemisphereLightIrradiance( const in HemisphereLight hemiLight, const in GeometricContext geometry ) {"," float dotNL = dot( geometry.normal, hemiLight.direction );"," float hemiDiffuseWeight = 0.5 * dotNL + 0.5;"," vec3 irradiance = mix( hemiLight.groundColor, hemiLight.skyColor, hemiDiffuseWeight );"," #ifndef PHYSICALLY_CORRECT_LIGHTS"," irradiance *= PI;"," #endif"," return irradiance;"," }","#endif","#if defined( USE_ENVMAP ) && defined( PHYSICAL )"," vec3 getLightProbeIndirectIrradiance( const in GeometricContext geometry, const in int maxMIPLevel ) {"," vec3 worldNormal = inverseTransformDirection( geometry.normal, viewMatrix );"," #ifdef ENVMAP_TYPE_CUBE"," vec3 queryVec = vec3( flipEnvMap * worldNormal.x, worldNormal.yz );"," #ifdef TEXTURE_LOD_EXT"," vec4 envMapColor = textureCubeLodEXT( envMap, queryVec, float( maxMIPLevel ) );"," #else"," vec4 envMapColor = textureCube( envMap, queryVec, float( maxMIPLevel ) );"," #endif"," envMapColor.rgb = envMapTexelToLinear( envMapColor ).rgb;"," #elif defined( ENVMAP_TYPE_CUBE_UV )"," vec3 queryVec = vec3( flipEnvMap * worldNormal.x, worldNormal.yz );"," vec4 envMapColor = textureCubeUV( queryVec, 1.0 );"," #else"," vec4 envMapColor = vec4( 0.0 );"," #endif"," return PI * envMapColor.rgb * envMapIntensity;"," }"," float getSpecularMIPLevel( const in float blinnShininessExponent, const in int maxMIPLevel ) {"," float maxMIPLevelScalar = float( maxMIPLevel );"," float desiredMIPLevel = maxMIPLevelScalar - 0.79248 - 0.5 * log2( pow2( blinnShininessExponent ) + 1.0 );"," return clamp( desiredMIPLevel, 0.0, maxMIPLevelScalar );"," }"," vec3 getLightProbeIndirectRadiance( const in GeometricContext geometry, const in float blinnShininessExponent, const in int maxMIPLevel ) {"," #ifdef ENVMAP_MODE_REFLECTION"," vec3 reflectVec = reflect( -geometry.viewDir, geometry.normal );"," #else"," vec3 reflectVec = refract( -geometry.viewDir, geometry.normal, refractionRatio );"," #endif"," reflectVec = inverseTransformDirection( reflectVec, viewMatrix );"," float specularMIPLevel = getSpecularMIPLevel( blinnShininessExponent, maxMIPLevel );"," #ifdef ENVMAP_TYPE_CUBE"," vec3 queryReflectVec = vec3( flipEnvMap * reflectVec.x, reflectVec.yz );"," #ifdef TEXTURE_LOD_EXT"," vec4 envMapColor = textureCubeLodEXT( envMap, queryReflectVec, specularMIPLevel );"," #else"," vec4 envMapColor = textureCube( envMap, queryReflectVec, specularMIPLevel );"," #endif"," envMapColor.rgb = envMapTexelToLinear( envMapColor ).rgb;"," #elif defined( ENVMAP_TYPE_CUBE_UV )"," vec3 queryReflectVec = vec3( flipEnvMap * reflectVec.x, reflectVec.yz );"," vec4 envMapColor = textureCubeUV(queryReflectVec, BlinnExponentToGGXRoughness(blinnShininessExponent));"," #elif defined( ENVMAP_TYPE_EQUIREC )"," vec2 sampleUV;"," sampleUV.y = saturate( reflectVec.y * 0.5 + 0.5 );"," sampleUV.x = atan( reflectVec.z, reflectVec.x ) * RECIPROCAL_PI2 + 0.5;"," #ifdef TEXTURE_LOD_EXT"," vec4 envMapColor = texture2DLodEXT( envMap, sampleUV, specularMIPLevel );"," #else"," vec4 envMapColor = texture2D( envMap, sampleUV, specularMIPLevel );"," #endif"," envMapColor.rgb = envMapTexelToLinear( envMapColor ).rgb;"," #elif defined( ENVMAP_TYPE_SPHERE )"," vec3 reflectView = normalize( ( viewMatrix * vec4( reflectVec, 0.0 ) ).xyz + vec3( 0.0,0.0,1.0 ) );"," #ifdef TEXTURE_LOD_EXT"," vec4 envMapColor = texture2DLodEXT( envMap, reflectView.xy * 0.5 + 0.5, specularMIPLevel );"," #else"," vec4 envMapColor = texture2D( envMap, reflectView.xy * 0.5 + 0.5, specularMIPLevel );"," #endif"," envMapColor.rgb = envMapTexelToLinear( envMapColor ).rgb;"," #endif"," return envMapColor.rgb * envMapIntensity;"," }","#endif"].join("\n"),Wm=["#ifdef DOUBLE_SIDED"," float flipNormal = ( float( gl_FrontFacing ) * 2.0 - 1.0 );","#else"," float flipNormal = 1.0;","#endif\n"].join("\n"),Jm=["#ifdef FLAT_SHADED"," vec3 fdx = vec3( dFdx( vViewPosition.x ), dFdx( vViewPosition.y ), dFdx( vViewPosition.z ) );"," vec3 fdy = vec3( dFdy( vViewPosition.x ), dFdy( vViewPosition.y ), dFdy( vViewPosition.z ) );"," vec3 normal = normalize( cross( fdx, fdy ) );","#else"," vec3 normal = normalize( vNormal ) * flipNormal;","#endif","#ifdef USE_NORMALMAP"," normal = perturbNormal2Arb( -vViewPosition, normal );","#elif defined( USE_BUMPMAP )"," normal = perturbNormalArb( -vViewPosition, normal, dHdxy_fwd() );","#endif","vec3 geometryNormal = normal;"].join("\n"),zm=["GeometricContext geometry;","geometry.position = - vViewPosition;","#if NUM_CLIPPING_PLANES == 1"," if (gl_FrontFacing) geometry.normal = normal;"," else if (fillFaceClipDistance < 0.0) geometry.normal = -clippingPlanes[0].xyz;"," else geometry.normal = -normal;","#else"," geometry.normal = normal;","#endif","geometry.viewDir = normalize( vViewPosition );","IncidentLight directLight;","#if ( NUM_POINT_LIGHTS > 0 ) && defined( RE_Direct )"," PointLight pointLight;"," for ( int i = 0; i < NUM_POINT_LIGHTS; i ++ ) {"," pointLight = pointLights[ i ];"," getPointDirectLightIrradiance( pointLight, geometry, directLight );"," #ifdef USE_SHADOWMAP"," directLight.color *= all( bvec2( pointLight.shadow, directLight.visible ) ) ? getPointShadow( pointShadowMap[ i ], pointLight.shadowMapSize, pointLight.shadowBias, pointLight.shadowRadius, vPointShadowCoord[ i ] ,pointLight.shadowCameraNear, pointLight.shadowCameraFar) : 1.0;"," #endif"," RE_Direct( directLight, geometry, material, reflectedLight );"," }","#endif","#if ( NUM_SPOT_LIGHTS > 0 ) && defined( RE_Direct )"," SpotLight spotLight;"," for ( int i = 0; i < NUM_SPOT_LIGHTS; i ++ ) {"," spotLight = spotLights[ i ];"," getSpotDirectLightIrradiance( spotLight, geometry, directLight );"," #ifdef USE_SHADOWMAP"," directLight.color *= all( bvec2( spotLight.shadow, directLight.visible ) ) ? getShadow( spotShadowMap[ i ], spotLight.shadowMapSize, spotLight.shadowBias, spotLight.shadowRadius, vSpotShadowCoord[ i ] ) : 1.0;"," #endif"," RE_Direct( directLight, geometry, material, reflectedLight );"," }","#endif","#if ( NUM_DIR_LIGHTS > 0 ) && defined( RE_Direct )"," DirectionalLight directionalLight;"," for ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) {"," directionalLight = directionalLights[ i ];"," getDirectionalDirectLightIrradiance( directionalLight, geometry, directLight );"," #ifdef USE_SHADOWMAP"," directLight.color *= all( bvec2( directionalLight.shadow, directLight.visible ) ) ? getShadow( directionalShadowMap[ i ], directionalLight.shadowMapSize, directionalLight.shadowBias, directionalLight.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0;"," #endif"," RE_Direct( directLight, geometry, material, reflectedLight );"," }","#endif","#if ( NUM_RECT_AREA_LIGHTS > 0 ) && defined( RE_Direct_RectArea )"," RectAreaLight rectAreaLight;"," for ( int i = 0; i < NUM_RECT_AREA_LIGHTS; i ++ ) {"," rectAreaLight = rectAreaLights[ i ];"," RE_Direct_RectArea( rectAreaLight, geometry, material, reflectedLight );"," }","#endif","#if defined( RE_IndirectDiffuse )"," vec3 irradiance = getAmbientLightIrradiance( ambientLightColor );"," #ifdef USE_LIGHTMAP"," vec3 lightMapIrradiance = texture2D( lightMap, vUv2 ).xyz * lightMapIntensity;"," #ifndef PHYSICALLY_CORRECT_LIGHTS"," lightMapIrradiance *= PI; // factor of PI should not be present; included here to prevent breakage"," #endif"," irradiance += lightMapIrradiance;"," #endif"," #if ( NUM_HEMI_LIGHTS > 0 )"," for ( int i = 0; i < NUM_HEMI_LIGHTS; i ++ ) {"," irradiance += getHemisphereLightIrradiance( hemisphereLights[ i ], geometry );"," }"," #endif"," #if defined( USE_ENVMAP ) && defined( PHYSICAL ) && defined( ENVMAP_TYPE_CUBE_UV )"," irradiance += getLightProbeIndirectIrradiance( /*lightProbe,*/ geometry, 8 );"," #endif"," RE_IndirectDiffuse( irradiance, geometry, material, reflectedLight );","#endif","#if defined( USE_ENVMAP ) && defined( RE_IndirectSpecular )"," vec3 radiance = getLightProbeIndirectRadiance( /*specularLightProbe,*/ geometry, Material_BlinnShininessExponent( material ), 8 );"," #ifndef STANDARD"," vec3 clearCoatRadiance = getLightProbeIndirectRadiance( /*specularLightProbe,*/ geometry, Material_ClearCoat_BlinnShininessExponent( material ), 8 );"," #else"," vec3 clearCoatRadiance = vec3( 0.0 );"," #endif"," RE_IndirectSpecular( radiance, clearCoatRadiance, geometry, material, reflectedLight );","#endif"].join("\n"),qm=["#define PHONG","uniform vec3 diffuse;","uniform vec3 emissive;","uniform vec3 specular;","uniform float shininess;","uniform float opacity;","#include <common>","#include <packing>","#include <dithering_pars_fragment>","#include <color_pars_fragment>","#include <uv_pars_fragment>","#include <uv2_pars_fragment>","#include <map_pars_fragment>","#include <alphamap_pars_fragment>","#include <aomap_pars_fragment>","#include <lightmap_pars_fragment>","#include <emissivemap_pars_fragment>","#include <envmap_pars_fragment>","#include <gradientmap_pars_fragment>","#include <fog_pars_fragment>","#include <bsdfs>","#include <lights_pars_begin>","#include <lights_phong_pars_fragment>","#include <shadowmap_pars_fragment>","#include <bumpmap_pars_fragment>","#include <normalmap_pars_fragment>","#include <specularmap_pars_fragment>","#include <logdepthbuf_pars_fragment>","#include <clipping_planes_pars_fragment>","#include <lights_physical_pars_fragment>","#include <envmap_common_pars_fragment>","#include <envmap_physical_pars_fragment>","void main() {"," #include <clipping_planes_fragment>"," vec4 diffuseColor = vec4( diffuse, opacity );"," ReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );"," vec3 totalEmissiveRadiance = emissive;"," #include <logdepthbuf_fragment>"," #include <map_fragment>"," #include <color_fragment>"," #include <alphamap_fragment>"," #include <alphatest_fragment>"," #include <specularmap_fragment>"," #include <normal_flip>"," #include <normal_fragment_begin>"," #include <emissivemap_fragment>"," float fillFaceClipDistance = 0.0;"," #if NUM_CLIPPING_PLANES == 1"," vec4 plane = clippingPlanes[ 0 ];"," fillFaceClipDistance = dot( vViewPosition, plane.xyz ) - plane.w;"," #endif"," #include <lights_phong_fragment>"," #include <lights_fillFace_template>"," #include <aomap_fragment>"," vec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + reflectedLight.directSpecular + reflectedLight.indirectSpecular + totalEmissiveRadiance;"," #include <envmap_fragment>"," gl_FragColor = vec4( outgoingLight, diffuseColor.a );"," #include <tonemapping_fragment>"," #include <encodings_fragment>"," #include <premultiplied_alpha_fragment>"," #include <dithering_fragment>"," #include <fog_fragment>","}"].join("\n"),Zm=["#define PHONG","varying vec3 vViewPosition;","#ifndef FLAT_SHADED","varying vec3 vNormal;","#endif","#include <common>","#include <uv_pars_vertex>","#include <uv2_pars_vertex>","#include <displacementmap_pars_vertex>","#include <envmap_pars_vertex>","#include <color_pars_vertex>","#include <fog_pars_vertex>","#include <morphtarget_pars_vertex>","#include <skinning_pars_vertex>","#include <shadowmap_pars_vertex>","#include <logdepthbuf_pars_vertex>","#include <clipping_planes_pars_vertex>","void main() {","#include <uv_vertex>","#include <uv2_vertex>","#include <color_vertex>","#include <beginnormal_vertex>","#include <morphnormal_vertex>","#include <skinbase_vertex>","#include <skinnormal_vertex>","#include <defaultnormal_vertex>","#ifndef FLAT_SHADED","vNormal = normalize( transformedNormal );","#endif","#include <begin_vertex>","#include <displacementmap_vertex>","#include <morphtarget_vertex>","#include <skinning_vertex>","#include <project_vertex>","#include <logdepthbuf_vertex>","#include <clipping_planes_vertex>","vViewPosition = - mvPosition.xyz;","#include <worldpos_vertex>","#include <envmap_vertex>","#include <shadowmap_vertex>","#include <fog_vertex>","}"].join("\n"),Xm=["#define PHYSICAL","varying vec3 vViewPosition;","#ifndef FLAT_SHADED","varying vec3 vNormal;","#endif","#include <common>","#include <uv_pars_vertex>","#include <uv2_pars_vertex>","#include <displacementmap_pars_vertex>","#include <color_pars_vertex>","#include <fog_pars_vertex>","#include <morphtarget_pars_vertex>","#include <skinning_pars_vertex>","#include <shadowmap_pars_vertex>","#include <specularmap_pars_fragment>","#include <logdepthbuf_pars_vertex>","#include <clipping_planes_pars_vertex>","void main() {","#include <uv_vertex>","#include <uv2_vertex>","#include <color_vertex>","#include <beginnormal_vertex>","#include <morphnormal_vertex>","#include <skinbase_vertex>","#include <skinnormal_vertex>","#include <defaultnormal_vertex>","#ifndef FLAT_SHADED","vNormal = normalize( transformedNormal );","#endif","#include <begin_vertex>","#include <displacementmap_vertex>","#include <morphtarget_vertex>","#include <skinning_vertex>","#include <project_vertex>","#include <logdepthbuf_vertex>","#include <clipping_planes_vertex>","vViewPosition = - mvPosition.xyz;","#include <worldpos_vertex>","#include <shadowmap_vertex>","#include <fog_vertex>","}"].join("\n"),_m=["#define PHYSICAL","uniform vec3 diffuse;","uniform vec3 emissive;","uniform float roughness;","uniform float metalness;","uniform float opacity;","#ifndef STANDARD","uniform float clearCoat;","uniform float clearCoatRoughness;","#endif","varying vec3 vViewPosition;","#ifndef FLAT_SHADED","varying vec3 vNormal;","#endif","#include <common>","#include <packing>","#include <dithering_pars_fragment>","#include <color_pars_fragment>","#include <uv_pars_fragment>","#include <uv2_pars_fragment>","#include <map_pars_fragment>","#include <alphamap_pars_fragment>","#include <aomap_pars_fragment>","#include <lightmap_pars_fragment>","#include <emissivemap_pars_fragment>","#include <envmap_pars_fragment>","#include <fog_pars_fragment>","#include <bsdfs>","#include <cube_uv_reflection_fragment>","#include <lights_pars_begin>","#include <lights_physical_pars_fragment>","#include <shadowmap_pars_fragment>","#include <bumpmap_pars_fragment>","#include <normalmap_pars_fragment>","#include <roughnessmap_pars_fragment>","#include <metalnessmap_pars_fragment>","#include <logdepthbuf_pars_fragment>","#include <clipping_planes_pars_fragment>","void main() {","#include <clipping_planes_fragment>","vec4 diffuseColor = vec4( diffuse, opacity );","vec3 totalEmissiveRadiance = emissive;","#include <logdepthbuf_fragment>","#include <map_fragment>","#include <color_fragment>","#include <alphamap_fragment>","#include <alphatest_fragment>","#include <specularmap_fragment>","#include <roughnessmap_fragment>","#include <metalnessmap_fragment>","#include <normal_flip>","#include <normal_fragment_begin>","#include <emissivemap_fragment>","const mat4 diffuseMatrix = mat4(-0.07425443828105927, -0.05652861297130585, 0.12247831374406815, 0.2297295778989792,"," -0.05652860924601555, 0.034799136221408844, -0.08437120914459229, -0.13896968960762024,"," 0.12247832119464874, -0.08437121659517288, 0.021763987839221954, 0.12510454654693604,"," 0.2297295778989792, -0.13896968960762024, 0.12510454654693604, 0.6190560460090637);","const vec3 sunDir = vec3(-0.6632131338119507, 0.5486575961112976, -0.509041428565979);","vec3 viewDir = normalize( vViewPosition );","vec4 diffuseDir = diffuseMatrix * vec4(normal, 1.0);","float diffuseTerm = dot(vec4(normal, 1.0), diffuseDir);","float nv = max(dot(normal, -viewDir), 0.0);","float vl = max(dot(viewDir, sunDir), 0.0);","diffuseTerm = diffuseTerm + (nv * (1.0 - vl)) * 0.8;","vec3 H = -normalize(sunDir + viewDir);","float nh = max(dot(normal, H), 0.0);","float specularTerm = pow(nh, 100.0);","vec3 color = 1.05 * vec3(0.5, 0.497, 0.49) * (diffuse * diffuseTerm + vec3(specularTerm)) + diffuse * 0.5;","vec3 outgoingLight = color + totalEmissiveRadiance;","gl_FragColor = vec4( outgoingLight, diffuseColor.a );","#include <tonemapping_fragment>","#include <encodings_fragment>","#include <premultiplied_alpha_fragment>","#include <dithering_fragment>","#include <fog_fragment>","}"].join("\n"),$m=["#define BOS3DPHYSICAL","mat3 transpose2( const in mat3 v ) {\n mat3 tmp;\n tmp[0] = vec3(v[0].x, v[1].x, v[2].x);\n tmp[1] = vec3(v[0].y, v[1].y, v[2].y);\n tmp[2] = vec3(v[0].z, v[1].z, v[2].z);\n return tmp;\n}\n","varying vec3 vViewPosition;","varying vec3 vWorldPosition;","#ifndef FLAT_SHADED"," varying vec3 vNormal;"," #ifdef USE_TANGENT"," varying vec3 vTangent;"," varying vec3 vBitangent;"," #endif","#endif","#ifdef USE_INSTANCE"," attribute float vState;"," attribute float vState2;"," varying float fState;"," attribute float vClipping;"," varying float fClipping;"," attribute float vMirror;"," attribute vec4 aColor;"," varying vec4 vaColor;"," attribute vec3 mcol0;"," attribute vec3 mcol1;"," attribute vec3 mcol2;"," attribute vec3 mcol3;"," #if defined(USE_LIGHTMAP)"," attribute vec4 uv2OffsetRepeat;"," #endif","#ifdef INSTANCE_STATE_TERTIARY"," attribute float vState3;","#endif","#endif","#include <common>","#include <uv_pars_vertex>","#include <uv2_pars_vertex>","#include <displacementmap_pars_vertex>","#include <color_pars_vertex>","#include <fog_pars_vertex>","#include <morphtarget_pars_vertex>","#include <skinning_pars_vertex>","#include <shadowmap_pars_vertex>",xn.projectorLight_pars_vertex,"#include <logdepthbuf_pars_vertex>","#include <clipping_planes_pars_vertex>","#include <view_shed_pars_vertex>","#include <video_cast_pars_vertex>","varying vec4 wPositionForInnerClipping;","#ifdef USE_FILLPATTERN"," varying vec4 vClipPosition;","#endif","#include <heightLimit_pars_vertex>","mat3 inverse_mat3(in mat3 m)","{"," float determinant ="," m[0][0] * (m[1][1] * m[2][2] - m[2][1] * m[1][2])"," - m[1][0] * (m[0][1] * m[2][2] - m[2][1] * m[0][2])"," + m[2][0] * (m[0][1] * m[1][2] - m[1][1] * m[0][2]);"," mat3 inverse;"," inverse[0][0] = + (m[1][1] * m[2][2] - m[2][1] * m[1][2]);"," inverse[1][0] = - (m[1][0] * m[2][2] - m[2][0] * m[1][2]);"," inverse[2][0] = + (m[1][0] * m[2][1] - m[2][0] * m[1][1]);"," inverse[0][1] = - (m[0][1] * m[2][2] - m[2][1] * m[0][2]);"," inverse[1][1] = + (m[0][0] * m[2][2] - m[2][0] * m[0][2]);"," inverse[2][1] = - (m[0][0] * m[2][1] - m[2][0] * m[0][1]);"," inverse[0][2] = + (m[0][1] * m[1][2] - m[1][1] * m[0][2]);"," inverse[1][2] = - (m[0][0] * m[1][2] - m[1][0] * m[0][2]);"," inverse[2][2] = + (m[0][0] * m[1][1] - m[1][0] * m[0][1]);"," inverse /= determinant;"," return inverse;","}","void main() {"," #include <uv_vertex>","#include <uv2_vertex>"," #include <color_vertex>"," #include <beginnormal_vertex>"," #include <morphnormal_vertex>"," #include <skinbase_vertex>"," #include <skinnormal_vertex>"," #include <defaultnormal_vertex>"," #include <begin_vertex>","#ifdef USE_INSTANCE"," vaColor = aColor;","fClipping = vClipping;"," #ifdef INSTANCE_STATE_SECONDARY"," fState = vState2;"," #else"," fState = vState;"," #endif"," #ifdef INSTANCE_STATE_TERTIARY"," fState = vState3;"," #endif"," transformed = vec3(mat4(vec4(mcol0, 0.0),"," vec4(mcol1, 0.0),"," vec4(mcol2, 0.0),"," vec4(mcol3, 1.0)) * vec4(transformed, 1.0));"," #ifdef USE_INSTANCE_NORMAL"," mat3 normalMat = mat3(mcol0, mcol1, mcol2);"," normalMat = inverse_mat3(normalMat);"," normalMat = transposeMat3(normalMat);"," transformedNormal = normalMat * objectNormal;"," transformedNormal = normalMatrix * transformedNormal;"," #ifdef FLIP_SIDED"," transformedNormal = - transformedNormal;"," #endif"," transformedNormal = normalize( transformedNormal );"," #endif","#endif","#ifndef FLAT_SHADED"," vNormal = normalize( transformedNormal );"," #ifdef USE_TANGENT"," vTangent = normalize( transformedTangent );"," vBitangent = normalize( cross( vNormal, vTangent ) * tangent.w );"," #endif","#endif"," #include <morphtarget_vertex>"," #include <skinning_vertex>"," #include <displacementmap_vertex>"," #include <project_vertex>"," #include <logdepthbuf_vertex>"," #include <clipping_planes_vertex>"," vViewPosition = - mvPosition.xyz;","#ifdef USE_FILLPATTERN"," vClipPosition = gl_Position;","#endif","wPositionForInnerClipping = modelMatrix * vec4( transformed, 1.0 );","#include <heightLimit_vertex>"," // 热力图"," #if defined( USE_ENVMAP ) || defined( DISTANCE ) || defined ( USE_SHADOWMAP )|| defined(HEATMAPPOINTSCOUNT) || defined(PROJECTORLIGHT)"," vec4 worldPosition = vec4( transformed, 1.0 );"," #ifdef USE_INSTANCING"," worldPosition = instanceMatrix * worldPosition;"," #endif"," worldPosition = modelMatrix * worldPosition;"," vWorldPosition = vec3(worldPosition.xyz);"," #endif"," #include <shadowmap_vertex>",xn.projectorLight_shadowmap_vertex," #include <fog_vertex>","#ifdef USE_INSTANCE"," if (vMirror <= - 0.01){"," vNormal = vNormal * - 1.0;}","#endif","vec3 vsWorldPosition = vec3(modelMatrix * vec4(transformed, 1.0));","#include <view_shed_vertex>","#include <video_cast_vertex>","}"].join("\n"),eA=["#define BOS3DPHYSICAL","#ifdef PHYSICAL"," #define REFLECTIVITY"," #define CLEARCOAT","#endif","uniform vec3 diffuse;","uniform vec3 emissive;","uniform float roughness;","uniform float metalness;","uniform float opacity;","uniform float imageFade;","#ifndef STANDARD","uniform float clearCoat;","uniform float clearCoatRoughness;","#endif","#ifdef USE_TRANSMISSION"," uniform float transmission;"," uniform float thickness;"," uniform vec3 attenuationColor;"," uniform float attenuationDistance;","#endif","#ifdef REFLECTIVITY"," uniform float reflectivity;","#endif","#ifdef CLEARCOAT"," uniform float clearcoat;"," uniform float clearcoatRoughness;","#endif","#ifdef USE_SHEEN"," uniform vec3 sheen;","#endif","varying vec3 vViewPosition;","varying vec3 vWorldPosition;","#ifndef FLAT_SHADED"," varying vec3 vNormal;"," #ifdef USE_TANGENT"," varying vec3 vTangent;"," varying vec3 vBitangent;"," #endif","#endif","#ifdef USE_INSTANCE"," varying vec4 vaColor;"," varying float fState;"," varying float fClipping;","#endif","#ifdef USE_FILLPATTERN"," uniform vec2 viewportSize;"," uniform sampler2D fillMap;"," varying vec4 vClipPosition;","#endif","varying vec4 wPositionForInnerClipping;","uniform float shift;","uniform float A;","uniform float B;","uniform float C;","uniform float D;","uniform float E;","uniform float F;","uniform float scale;","uniform vec4 blinkColor;","uniform float blinkCoefficient;","uniform float colorState;","uniform int localClipping;","uniform int innerClipping;","uniform mat4 orthoViewProjMatrix;","#include <heightLimit_pars_fragment>","#ifdef HEATMAPPOINTSCOUNT"," uniform float heatmapPoints[HEATMAPPOINTSCOUNT];"," uniform sampler2D heatmapTexture;","#endif","vec3 toneMapCanonFilmic(vec3 color)","{"," color *= (1.0 / shift);"," return (((color * (A * color + C * B)) / (color * (A * color + B) + D * F))) * (1.0 / scale);","}","#include <common>","#include <packing>","#include <dithering_pars_fragment>","#include <color_pars_fragment>","#include <uv_pars_fragment>","#include <uv2_pars_fragment>","#include <map_pars_fragment>","#include <alphamap_pars_fragment>","#include <aomap_pars_fragment>","#include <lightmap_pars_fragment>","#include <emissivemap_pars_fragment>","#include <bsdfs>"," #include <transmission_pars_fragment>","#include <cube_uv_reflection_fragment>","#include <envmap_common_pars_fragment>","#include <envmap_physical_pars_fragment>","#include <fog_pars_fragment>","#include <lights_pars_begin>",xn.projector_lights_pars_begin,"#include <lights_physical_pars_fragment>","#include <shadowmap_pars_fragment>",xn.projectorLight_pars_fragment,"#include <bumpmap_pars_fragment>","#include <normalmap_pars_fragment>","#include <clearcoat_pars_fragment>","#include <roughnessmap_pars_fragment>","#include <metalnessmap_pars_fragment>","#include <logdepthbuf_pars_fragment>","#include <csm_fragment>","#include <clipping_planes_pars_fragment>","#include <view_shed_pars_fragment>","#include <video_cast_pars_fragment>","vec3 hdrDecode(in vec4 rgbm) {","const float rgbmScale = 2.82842712;","vec3 r = rgbm.rgb * (rgbmScale * (1.0 - rgbm.a));","return r * r;","}","vec3 linearToGammaUnreal(in vec3 rgb) {"," return rgb / (rgb + 0.187) * 1.035 * (0.5 / shift);","}","bool floatEqual(in float x, in float y) {"," return (x >= y - 0.01) && (x <= y + 0.01);","}","bool floatNotEqual(in float x, in float y) {"," return (x <= y - 0.01) || (x >= y + 0.01);","}","void main() {"," #include <clipping_planes_fragment>","#ifdef USE_FILLPATTERN"," vec4 clipPosition = vClipPosition;"," clipPosition.xyz /= clipPosition.w; "," clipPosition.xyz = clipPosition.xyz * 0.5 + 0.5; "," vec2 screenPosition = vec2(clipPosition.x * viewportSize.x, clipPosition.y * viewportSize.y);"," float flag = texture2D(fillMap, vec2(screenPosition.x/32.0, screenPosition.y/32.0)).r;"," if(flag == 0.0)"," {"," discard;"," }","#endif"," vec4 diffuseColor = vec4( diffuse, opacity );"," #ifdef USE_INSTANCE"," if (floatEqual(fState, -1.0)) "," discard;"," if (floatNotEqual(fState, 0.0)) "," diffuseColor = vaColor;"," #endif"," vec4 selectedColor = diffuseColor;","#ifndef USE_LIGHTMAP","#endif"," ReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );"," vec3 totalEmissiveRadiance = emissive;","#ifdef USE_TRANSMISSION"," float totalTransmission = transmission;"," float thicknessFactor = thickness;","#endif"," #include <logdepthbuf_fragment>","vec4 gamaColor = diffuseColor ;"," #ifdef USE_MAP"," vec4 texelColor = texture2D( map, vUv );"," texelColor = mapTexelToLinear( texelColor );"," float map_opacity=1.0;"," #ifdef USE_MAP_ALPHA"," map_opacity=texelColor.a;"," #endif"," diffuseColor = vec4( mix(diffuseColor.rgb , texelColor.rgb, imageFade),map_opacity * opacity);"," #ifdef USE_INSTANCE"," if (floatNotEqual(fState, 0.0)) "," diffuseColor = vaColor;"," if (floatEqual(fState, 3.0))"," diffuseColor = gamaColor;"," #endif"," #endif"," #include <color_fragment>","#include <alphamap_fragment_override>"," #include <alphatest_fragment>"," #include <roughnessmap_fragment>"," #include <metalnessmap_fragment>","float flipNormal = 1.0;"," #include <normal_fragment_begin>"," #include <normal_fragment_maps>"," #include <clearcoat_normal_fragment_begin>"," #include <clearcoat_normal_fragment_maps>"," #include <emissivemap_fragment>","vec3 rawDiffuseColor = diffuseColor.rgb;","#ifdef USE_INSTANCE"," if (floatEqual(fState, 3.0)){"," roughnessFactor = 1.0;"," metalnessFactor = 0.0;"," }","#endif"," #include <transmission_fragment>"," #include <lights_physical_fragment>"," #include <lights_fragment_begin>"," #include <lights_fragment_maps>"," #include <lights_fragment_end>","#include <aomap_fragment>","vec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + reflectedLight.directSpecular + reflectedLight.indirectSpecular + totalEmissiveRadiance;","#ifdef USE_COLORWITHOUTLIGHT"," gl_FragColor = diffuseColor;","#else"," #ifdef TRANSPARENCY"," diffuseColor.a *= saturate( 1. - transparency + linearToRelativeLuminance( reflectedLight.directSpecular + reflectedLight.indirectSpecular ) );"," #endif"," gl_FragColor = vec4( outgoingLight, diffuseColor.a );","#endif","#if defined( TONE_MAPPING )"," #if defined(USE_LIGHTMAP)"," #else"," gl_FragColor.rgb = toneMapCanonFilmic( gl_FragColor.rgb );"," #endif","#endif","#ifdef USE_INSTANCE"," #ifdef NOTAFFECTEDBYLIGHT"," if (floatEqual(fState, 2.0))"," gl_FragColor = selectedColor;"," #endif"," #ifdef USE_MAP"," if (floatEqual(fState, 3.0))"," gl_FragColor = vaColor;"," #endif","#endif","#ifdef USE_INSTANCE"," if (floatEqual(fState, 5.0) && floatEqual(colorState, 1.0)){"," gl_FragColor = mix(gl_FragColor, blinkColor, blinkCoefficient);"," }","#else"," if (floatEqual(colorState, 1.0))"," gl_FragColor = mix(gl_FragColor, blinkColor, blinkCoefficient);"," #ifdef NOTAFFECTEDBYLIGHT"," if (floatEqual(colorState, 2.0))"," gl_FragColor = selectedColor;"," #endif","#endif","#include <view_shed_fragment>","#include <video_cast_fragment>","#ifndef USE_LIGHTMAP"," #include <encodings_fragment>","#endif","#include <heightLimit_fragment>","#include <premultiplied_alpha_fragment>","#include <dithering_fragment>","#include <fog_fragment>","#ifdef HEATMAPPOINTSCOUNT"," float heatvalue = 0.0;"," for ( int i = 0; i < HEATMAPPOINTSCOUNT; i += 5 ) {"," float heatpointX = heatmapPoints[i];"," float heatpointY = heatmapPoints[i + 1];"," float heatpointZ = heatmapPoints[i + 2];"," // heatpointIndex保存的是当前热力点的热力值比上最大热力和最小热力差"," // 也就是在热力区间中的百分比位置为0的时候表示最小热力值1的时候表示最大热力值"," // 可以理解为就是热力点中心的热力值只不过范围是0-1"," // 热力最大值和最小值分别是所有热力点中热力最大和最小的值"," float heatpointIndex = heatmapPoints[i + 3];"," float heatpointRadius = heatmapPoints[i + 4];"," float dis = distance(vWorldPosition, vec3(heatpointX, heatpointY, heatpointZ));"," if(dis < heatpointRadius) {"," float step = dis / heatpointRadius;"," // 根据距离计算当前片元在当前热力点下的热力值"," // step表示距离范围0-1越小表示距离热力点越近热力越大将距离区间0-1和热力区间heatpointIndex-0对应起来"," float currentvalue = (1.0 - step) * heatpointIndex;"," // 这里用到了一个颜色叠加的公式,把每个热点对当前片元产生的热力进行叠加,"," // 没有特殊逻辑,也可以简单相加"," heatvalue = heatvalue + currentvalue - heatvalue * currentvalue;"," if (heatvalue > 1.0) {"," heatvalue = 1.0;"," break;"," }"," }"," }"," if (heatvalue > 0.0) {"," vec4 color = texture2D(heatmapTexture, vec2(heatvalue, 0.5));"," heatvalue = 0.5*heatvalue + 0.5;//使下列因子范围为1-0.5"," color = vec4( mix(gl_FragColor.rgb, color.rgb, heatvalue),gl_FragColor.a);"," gl_FragColor = color;"," }","#endif",xn.projectorLight_fragment,"}"].join("\n"),tA=function(e,t,i){return e.replace(t,i)};xn.lights_pars=jm,xn.meshphong_id_vert=Zm,xn.lights_fillFace_template=zm,xn.lights_template="\n GeometricContext geometry;\n\n geometry.position = - vViewPosition;\n geometry.normal = normal;\n geometry.viewDir = normalize( vViewPosition );\n \n IncidentLight directLight;\n \n #if ( NUM_POINT_LIGHTS > 0 ) && defined( RE_Direct )\n \n PointLight pointLight;\n #if defined( USE_SHADOWMAP ) && (NUM_POINT_LIGHT_SHADOWS > 0)\n PointLightShadow pointLightShadow;\n #endif\n #pragma unroll_loop_start\n for ( int i = 0; i < NUM_POINT_LIGHTS; i ++ ) {\n \n pointLight = pointLights[ i ];\n getPointDirectLightIrradiance( pointLight, geometry, directLight );\n \n #if defined( USE_SHADOWMAP ) && (NUM_POINT_LIGHT_SHADOWS > 0) && ( UNROLLED_LOOP_INDEX < NUM_POINT_LIGHT_SHADOWS )\n pointLightShadow = pointLightShadows[ i ];;\n directLight.color *= all( bvec2( receiveShadow, directLight.visible ) ) ? getPointShadow( pointShadowMap[ i ], pointLightShadow.shadowMapSize, pointLightShadow.shadowBias, pointLightShadow.shadowRadius, vPointShadowCoord[ i ] ) : 1.0;\n #endif\n \n RE_Direct( directLight, geometry, material, reflectedLight );\n \n }\n #pragma unroll_loop_end\n \n #endif\n \n #if ( NUM_SPOT_LIGHTS > 0 ) && defined( RE_Direct )\n \n SpotLight spotLight;\n\n #if defined( USE_SHADOWMAP ) && (NUM_SPOT_LIGHT_SHADOWS > 0)\n SpotLightShadow spotLightShadow;\n #endif\n \n #pragma unroll_loop_start\n for ( int i = 0; i < NUM_SPOT_LIGHTS; i ++ ) {\n \n spotLight = spotLights[ i ];\n getSpotDirectLightIrradiance( spotLight, geometry, directLight );\n \n #if defined( USE_SHADOWMAP ) && (NUM_SPOT_LIGHT_SHADOWS > 0) && ( UNROLLED_LOOP_INDEX < NUM_SPOT_LIGHT_SHADOWS )\n spotLightShadow = spotLightShadows[ i ];\n directLight.color *= all( bvec2( receiveShadow, directLight.visible ) ) ? getShadow( spotShadowMap[ i ], spotLightShadow.shadowMapSize, spotLightShadow.shadowBias, spotLightShadow.shadowRadius, vSpotShadowCoord[ i ] ) : 1.0;\n #endif\n \n RE_Direct( directLight, geometry, material, reflectedLight );\n \n }\n #pragma unroll_loop_end\n \n #endif\n \n #if ( NUM_DIR_LIGHTS > 0 ) && defined( RE_Direct )\n \n DirectionalLight directionalLight;\n #if defined( USE_SHADOWMAP ) && NUM_DIR_LIGHT_SHADOWS > 0\n DirectionalLightShadow directionalLightShadow;\n #endif\n #pragma unroll_loop_start\n for ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) {\n \n directionalLight = directionalLights[ i ];\n getDirectionalDirectLightIrradiance( directionalLight, geometry, directLight );\n \n #if defined( USE_SHADOWMAP ) && (NUM_DIR_LIGHT_SHADOWS > 0) && ( UNROLLED_LOOP_INDEX < NUM_DIR_LIGHT_SHADOWS )\n directionalLightShadow = directionalLightShadows[ i ];\n directLight.color *= all( bvec2( receiveShadow, directLight.visible ) ) ? getShadow( directionalShadowMap[ i ], directionalLightShadow.shadowMapSize, directionalLightShadow.shadowBias, directionalLightShadow.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0;\n #endif\n \n RE_Direct( directLight, geometry, material, reflectedLight );\n \n }\n #pragma unroll_loop_end\n \n #endif\n \n #if ( NUM_RECT_AREA_LIGHTS > 0 ) && defined( RE_Direct_RectArea )\n \n RectAreaLight rectAreaLight;\n \n for ( int i = 0; i < NUM_RECT_AREA_LIGHTS; i ++ ) {\n \n rectAreaLight = rectAreaLights[ i ];\n RE_Direct_RectArea( rectAreaLight, geometry, material, reflectedLight );\n \n }\n \n #endif\n \n #if defined( RE_IndirectDiffuse )\n \n vec3 irradiance = getAmbientLightIrradiance( ambientLightColor );\n \n #ifdef USE_LIGHTMAP\n \n vec3 lightMapIrradiance = texture2D( lightMap, vUv2 ).xyz * lightMapIntensity;\n \n #ifndef PHYSICALLY_CORRECT_LIGHTS\n \n lightMapIrradiance *= PI; // factor of PI should not be present; included here to prevent breakage\n \n #endif\n \n irradiance += lightMapIrradiance;\n \n #endif\n \n #if ( NUM_HEMI_LIGHTS > 0 )\n \n for ( int i = 0; i < NUM_HEMI_LIGHTS; i ++ ) {\n \n irradiance += getHemisphereLightIrradiance( hemisphereLights[ i ], geometry );\n \n }\n \n #endif\n \n #if defined( USE_ENVMAP ) && defined( PHYSICAL ) && defined( ENVMAP_TYPE_CUBE_UV )\n \n // TODO, replace 8 with the real maxMIPLevel\n irradiance += getLightProbeIndirectIrradiance( /*lightProbe,*/ geometry, 8 );\n \n #endif\n \n RE_IndirectDiffuse( irradiance, geometry, material, reflectedLight );\n \n #endif\n \n #if defined( USE_ENVMAP ) && defined( RE_IndirectSpecular )\n\n // TODO, replace 8 with the real maxMIPLevel\n vec3 radiance = getLightProbeIndirectRadiance( geometry.viewDir, geometry.normal, material.specularRoughness, 8 );\n \n #ifndef STANDARD\n vec3 clearCoatRadiance = getLightProbeIndirectRadiance( geometry.viewDir, geometry.clearcoatNormal, material.clearcoatRoughness, 8 );\n #else\n vec3 clearCoatRadiance = vec3( 0.0 );\n #endif\n \n RE_IndirectSpecular( radiance, irradiance, clearCoatRadiance, geometry, material, reflectedLight );\n \n #endif\n ",xn.fillFaceFragment=qm,xn.normal_flip=Wm,xn.normal_fragment=Jm,xn.bos3dStandardVertex=$m,xn.bos3dStandardFragment=eA,xn.newStyleVertex=Xm,xn.newStyleFragment=_m,xn.view_shed_pars_vertex=Pm,xn.view_shed_pars_fragment=Gm,xn.view_shed_vertex=Km,xn.view_shed_fragment=Vm,xn.video_cast_pars_vertex=Qm,xn.video_cast_pars_fragment=Lm,xn.video_cast_vertex=Om,xn.video_cast_fragment=Nm,xn.heightLimit_pars_vertex=Sm,xn.heightLimit_vertex=bm,xn.heightLimit_pars_fragment=km,xn.heightLimit_fragment=Dm,xn.map_tile_vertex=Tm,xn.map_tile_fragment=Rm,xn.points_vertex=Um,xn.points_fragment=Fm,xn.depth_parse_fragment="\n uniform float cameraNear;\n uniform float cameraFar;\n uniform mat4 cameraProjection;\n uniform mat4 inverseProjection;\n uniform vec4 viewport;\n\n float getViewZ( const in float depth ) {\n #if defined( USE_LOGDEPTHBUF ) && defined( USE_LOGDEPTHBUF_EXT )\n float near = cameraNear;\n float far = cameraFar;\n float log2Depth = depth * 2.0 / logDepthBufFC;\n float depthFromCamera = pow(2.0, log2Depth) - 1.0;\n float a = far * (1.0 - near / depthFromCamera) / (far - near);\n float viewZ = perspectiveDepthToViewZ( a, cameraNear, cameraFar );\n if (depth == 0.0)\n {\n viewZ = perspectiveDepthToViewZ( 1.0, cameraNear, cameraFar );\n }\n #else\n float viewZ = perspectiveDepthToViewZ( depth, cameraNear, cameraFar );\n #endif\n return viewZ;\n }\n\n vec3 getViewPosition( const in float depth ) {\n #if defined( USE_LOGDEPTHBUF ) && defined( USE_LOGDEPTHBUF_EXT )\n float near = cameraNear;\n float far = cameraFar;\n float log2Depth = depth * 2.0 / logDepthBufFC;\n float depthFromCamera = pow(2.0, log2Depth) - 1.0;\n float x = 2.0 * (gl_FragCoord.x - viewport.x) / viewport.z - 1.0;\n float y = 2.0 * (gl_FragCoord.y - viewport.y) / viewport.w - 1.0;\n float z = 2.0 * (depthFromCamera - near) / (far-near) - 1.0;\n vec4 viewPosition = vec4(x, y, z, 1.0);\n viewPosition *= depthFromCamera;\n viewPosition = inverseProjection * viewPosition;\n #else\n float viewZ = getViewZ(depth);\n float clipW = cameraProjection[2][3] * viewZ + cameraProjection[3][3];\n vec4 clipPosition = vec4( ( vec3( gl_FragCoord.xy / viewport.zw, depth ) - 0.5 ) * 2.0, 1.0 );\n clipPosition *= clipW; //unprojection\n vec4 viewPosition = inverseProjection * clipPosition;\n #endif\n\n return viewPosition.xyz;\n }\n ",xn.csm_fragment="\n uniform vec2 csmCascades[4];\n float calcShadowFactor(vec3 normal)\n {\n float shadowFactor = 1.0;\n #ifdef USE_CSM\n #if ( NUM_DIR_LIGHTS > 0 )\n #ifdef USE_SHADOWMAP\n float viewDepth = vViewPosition.z;\n DirectionalLight directionalLight;\n directionalLight = directionalLights[ 0 ];\n #if defined( USE_SHADOWMAP ) && NUM_DIR_LIGHT_SHADOWS > 0\n DirectionalLightShadow directionalLightShadow;\n #endif\n directionalLightShadow = directionalLightShadows[ 0 ];\n\n float bias = cos(80.0);\n float biasFactor = 0.8;\n if (viewDepth >= csmCascades[0].x && viewDepth < csmCascades[0].y) {\n shadowFactor = getShadow( directionalShadowMap[ 0 ], directionalLightShadow.shadowMapSize, directionalLightShadow.shadowBias, directionalLightShadow.shadowRadius, vDirectionalShadowCoord[ 0 ] );\n float dotNL = dot( normal, directionalLight.direction );\n if (dotNL < bias) {\n shadowFactor = biasFactor;\n }\n }\n\n #if ( NUM_DIR_LIGHTS > 1 )\n directionalLight = directionalLights[ 1 ];\n directionalLightShadow = directionalLightShadows[ 1 ];\n if (viewDepth >= csmCascades[1].x && viewDepth < csmCascades[1].y) {\n shadowFactor = getShadow( directionalShadowMap[ 1 ], directionalLightShadow.shadowMapSize, directionalLightShadow.shadowBias, directionalLightShadow.shadowRadius, vDirectionalShadowCoord[ 1 ] );\n float dotNL = dot( normal, directionalLight.direction );\n if (dotNL < bias) {\n shadowFactor = biasFactor;\n }\n }\n #endif\n\n #if ( NUM_DIR_LIGHTS > 2 )\n directionalLight = directionalLights[ 2 ];\n directionalLightShadow = directionalLightShadows[ 2 ];\n if (viewDepth >= csmCascades[2].x && viewDepth < csmCascades[2].y) {\n shadowFactor = getShadow( directionalShadowMap[ 2 ], directionalLightShadow.shadowMapSize, directionalLightShadow.shadowBias, directionalLightShadow.shadowRadius, vDirectionalShadowCoord[ 2 ] );\n float dotNL = dot( normal, directionalLight.direction );\n if (dotNL < bias) {\n shadowFactor = biasFactor;\n }\n }\n #endif\n\n #if ( NUM_DIR_LIGHTS > 3 )\n directionalLight = directionalLights[ 3 ];\n directionalLightShadow = directionalLightShadows[ 3 ];\n if (viewDepth >= csmCascades[3].x && viewDepth < csmCascades[3].y) {\n shadowFactor = getShadow( directionalShadowMap[ 3 ], directionalLightShadow.shadowMapSize, directionalLightShadow.shadowBias, directionalLightShadow.shadowRadius, vDirectionalShadowCoord[ 3 ] );\n float dotNL = dot( normal, directionalLight.direction );\n if (dotNL < bias) {\n shadowFactor = biasFactor;\n }\n }\n #endif\n #endif\n #endif\n #endif\n shadowFactor = max(shadowFactor, 0.0);\n return shadowFactor;\n }\n ",xn.alphamap_fragment_override="#if !defined(USE_MAP_ALPHA)&&defined(USE_ALPHAMAP)\n diffuseColor.a *= texture2D( map, vUv ).a;\n #endif\n",xn.shadowmap_pars_fragment="\n#ifdef USE_SHADOWMAP\n\n #if NUM_DIR_LIGHT_SHADOWS > 0\n\n uniform sampler2D directionalShadowMap[ NUM_DIR_LIGHT_SHADOWS ];\n varying vec4 vDirectionalShadowCoord[ NUM_DIR_LIGHT_SHADOWS ];\n\n struct DirectionalLightShadow {\n float shadowBias;\n float shadowNormalBias;\n float shadowRadius;\n vec2 shadowMapSize;\n };\n\n uniform DirectionalLightShadow directionalLightShadows[ NUM_DIR_LIGHT_SHADOWS ];\n\n #endif\n\n #if NUM_SPOT_LIGHT_SHADOWS > 0\n\n uniform sampler2D spotShadowMap[ NUM_SPOT_LIGHT_SHADOWS ];\n varying vec4 vSpotShadowCoord[ NUM_SPOT_LIGHT_SHADOWS ];\n\n struct SpotLightShadow {\n float shadowBias;\n float shadowNormalBias;\n float shadowRadius;\n vec2 shadowMapSize;\n };\n\n uniform SpotLightShadow spotLightShadows[ NUM_SPOT_LIGHT_SHADOWS ];\n\n #endif\n\n #if NUM_POINT_LIGHT_SHADOWS > 0\n\n uniform sampler2D pointShadowMap[ NUM_POINT_LIGHT_SHADOWS ];\n varying vec4 vPointShadowCoord[ NUM_POINT_LIGHT_SHADOWS ];\n\n struct PointLightShadow {\n float shadowBias;\n float shadowNormalBias;\n float shadowRadius;\n vec2 shadowMapSize;\n float shadowCameraNear;\n float shadowCameraFar;\n };\n\n uniform PointLightShadow pointLightShadows[ NUM_POINT_LIGHT_SHADOWS ];\n\n #endif\n\n /*\n #if NUM_RECT_AREA_LIGHTS > 0\n\n // TODO (abelnation): create uniforms for area light shadows\n\n #endif\n */\n\n float texture2DCompare( sampler2D depths, vec2 uv, float compare ) {\n\n return step( compare, unpackRGBAToDepth( texture2D( depths, uv ) ) );\n\n }\n\n vec2 texture2DDistribution( sampler2D shadow, vec2 uv ) {\n\n return unpackRGBATo2Half( texture2D( shadow, uv ) );\n\n }\n\n float VSMShadow (sampler2D shadow, vec2 uv, float compare ){\n\n float occlusion = 1.0;\n\n vec2 distribution = texture2DDistribution( shadow, uv );\n\n float hard_shadow = step( compare , distribution.x ); // Hard Shadow\n\n if (hard_shadow != 1.0 ) {\n\n float distance = compare - distribution.x ;\n float variance = max( 0.00000, distribution.y * distribution.y );\n float softness_probability = variance / (variance + distance * distance ); // Chebeyshevs inequality\n softness_probability = clamp( ( softness_probability - 0.3 ) / ( 0.95 - 0.3 ), 0.0, 1.0 ); // 0.3 reduces light bleed\n occlusion = clamp( max( hard_shadow, softness_probability ), 0.0, 1.0 );\n\n }\n return occlusion;\n\n }\n\n float texture2DShadowLerp( sampler2D depths, vec2 size, vec2 uv, float compare ) {\n const vec2 offset = vec2( 0.0, 1.0 );\n vec2 texelSize = vec2( 1.0 ) / size;\n vec2 centroidUV = floor( uv * size + 0.5 ) / size;\n float lb = texture2DCompare( depths, centroidUV + texelSize * offset.xx, compare );\n float lt = texture2DCompare( depths, centroidUV + texelSize * offset.xy, compare );\n float rb = texture2DCompare( depths, centroidUV + texelSize * offset.yx, compare );\n float rt = texture2DCompare( depths, centroidUV + texelSize * offset.yy, compare );\n vec2 f = fract( uv * size + 0.5 );\n float a = mix( lb, lt, f.y );\n float b = mix( rb, rt, f.y );\n float c = mix( a, b, f.x );\n return c;\n }\n \n float getShadow( sampler2D shadowMap, vec2 shadowMapSize, float shadowBias, float shadowRadius, vec4 shadowCoord ) {\n\n float shadow = 1.0;\n\n shadowCoord.xyz /= shadowCoord.w;\n shadowCoord.z += shadowBias;\n\n // if ( something && something ) breaks ATI OpenGL shader compiler\n // if ( all( something, something ) ) using this instead\n\n bvec4 inFrustumVec = bvec4 ( shadowCoord.x >= 0.0, shadowCoord.x <= 1.0, shadowCoord.y >= 0.0, shadowCoord.y <= 1.0 );\n bool inFrustum = all( inFrustumVec );\n\n bvec2 frustumTestVec = bvec2( inFrustum, shadowCoord.z <= 1.0 );\n\n bool frustumTest = all( frustumTestVec );\n\n if ( frustumTest ) {\n\n #if defined( SHADOWMAP_TYPE_PCF )\n\n vec2 texelSize = vec2( 1.0 ) / shadowMapSize;\n\n float dx0 = - texelSize.x * shadowRadius;\n float dy0 = - texelSize.y * shadowRadius;\n float dx1 = + texelSize.x * shadowRadius;\n float dy1 = + texelSize.y * shadowRadius;\n float dx2 = dx0 / 2.0;\n float dy2 = dy0 / 2.0;\n float dx3 = dx1 / 2.0;\n float dy3 = dy1 / 2.0;\n\n shadow = (\n texture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, dy0 ), shadowCoord.z ) +\n texture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy0 ), shadowCoord.z ) +\n texture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, dy0 ), shadowCoord.z ) +\n texture2DCompare( shadowMap, shadowCoord.xy + vec2( dx2, dy2 ), shadowCoord.z ) +\n texture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy2 ), shadowCoord.z ) +\n texture2DCompare( shadowMap, shadowCoord.xy + vec2( dx3, dy2 ), shadowCoord.z ) +\n texture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, 0.0 ), shadowCoord.z ) +\n texture2DCompare( shadowMap, shadowCoord.xy + vec2( dx2, 0.0 ), shadowCoord.z ) +\n texture2DCompare( shadowMap, shadowCoord.xy, shadowCoord.z ) +\n texture2DCompare( shadowMap, shadowCoord.xy + vec2( dx3, 0.0 ), shadowCoord.z ) +\n texture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, 0.0 ), shadowCoord.z ) +\n texture2DCompare( shadowMap, shadowCoord.xy + vec2( dx2, dy3 ), shadowCoord.z ) +\n texture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy3 ), shadowCoord.z ) +\n texture2DCompare( shadowMap, shadowCoord.xy + vec2( dx3, dy3 ), shadowCoord.z ) +\n texture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, dy1 ), shadowCoord.z ) +\n texture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy1 ), shadowCoord.z ) +\n texture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, dy1 ), shadowCoord.z )\n ) * ( 1.0 / 17.0 );\n\n #elif defined( SHADOWMAP_TYPE_PCF_SOFT )\n vec2 texelSize = vec2( 1.0 ) / shadowMapSize;\n float dx0 = - texelSize.x * shadowRadius;\n float dy0 = - texelSize.y * shadowRadius;\n float dx1 = + texelSize.x * shadowRadius;\n float dy1 = + texelSize.y * shadowRadius;\n return (\n texture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx0, dy0 ), shadowCoord.z ) +\n texture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( 0.0, dy0 ), shadowCoord.z ) +\n texture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx1, dy0 ), shadowCoord.z ) +\n texture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx0, 0.0 ), shadowCoord.z ) +\n texture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy, shadowCoord.z ) +\n texture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx1, 0.0 ), shadowCoord.z ) +\n texture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx0, dy1 ), shadowCoord.z ) +\n texture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( 0.0, dy1 ), shadowCoord.z ) +\n texture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx1, dy1 ), shadowCoord.z )\n ) * ( 1.0 / 9.0 );\n\n #elif defined( SHADOWMAP_TYPE_VSM )\n\n shadow = VSMShadow( shadowMap, shadowCoord.xy, shadowCoord.z );\n\n #else // no percentage-closer filtering:\n\n shadow = texture2DCompare( shadowMap, shadowCoord.xy, shadowCoord.z );\n\n #endif\n\n }\n\n return shadow;\n\n }\n\n // cubeToUV() maps a 3D direction vector suitable for cube texture mapping to a 2D\n // vector suitable for 2D texture mapping. This code uses the following layout for the\n // 2D texture:\n //\n // xzXZ\n // y Y\n //\n // Y - Positive y direction\n // y - Negative y direction\n // X - Positive x direction\n // x - Negative x direction\n // Z - Positive z direction\n // z - Negative z direction\n //\n // Source and test bed:\n // https://gist.github.com/tschw/da10c43c467ce8afd0c4\n\n vec2 cubeToUV( vec3 v, float texelSizeY ) {\n\n // Number of texels to avoid at the edge of each square\n\n vec3 absV = abs( v );\n\n // Intersect unit cube\n\n float scaleToCube = 1.0 / max( absV.x, max( absV.y, absV.z ) );\n absV *= scaleToCube;\n\n // Apply scale to avoid seams\n\n // two texels less per square (one texel will do for NEAREST)\n v *= scaleToCube * ( 1.0 - 2.0 * texelSizeY );\n\n // Unwrap\n\n // space: -1 ... 1 range for each square\n //\n // #X## dim := ( 4 , 2 )\n // # # center := ( 1 , 1 )\n\n vec2 planar = v.xy;\n\n float almostATexel = 1.5 * texelSizeY;\n float almostOne = 1.0 - almostATexel;\n\n if ( absV.z >= almostOne ) {\n\n if ( v.z > 0.0 )\n planar.x = 4.0 - v.x;\n\n } else if ( absV.x >= almostOne ) {\n\n float signX = sign( v.x );\n planar.x = v.z * signX + 2.0 * signX;\n\n } else if ( absV.y >= almostOne ) {\n\n float signY = sign( v.y );\n planar.x = v.x + 2.0 * signY + 2.0;\n planar.y = v.z * signY - 2.0;\n\n }\n\n // Transform to UV space\n\n // scale := 0.5 / dim\n // translate := ( center + 0.5 ) / dim\n return vec2( 0.125, 0.25 ) * planar + vec2( 0.375, 0.75 );\n\n }\n\n float getPointShadow( sampler2D shadowMap, vec2 shadowMapSize, float shadowBias, float shadowRadius, vec4 shadowCoord, float shadowCameraNear, float shadowCameraFar ) {\n\n vec2 texelSize = vec2( 1.0 ) / ( shadowMapSize * vec2( 4.0, 2.0 ) );\n\n // for point lights, the uniform @vShadowCoord is re-purposed to hold\n // the vector from the light to the world-space position of the fragment.\n vec3 lightToPosition = shadowCoord.xyz;\n\n // dp = normalized distance from light to fragment position\n float dp = ( length( lightToPosition ) - shadowCameraNear ) / ( shadowCameraFar - shadowCameraNear ); // need to clamp?\n dp += shadowBias;\n\n // bd3D = base direction 3D\n vec3 bd3D = normalize( lightToPosition );\n\n #if defined( SHADOWMAP_TYPE_PCF ) || defined( SHADOWMAP_TYPE_PCF_SOFT ) || defined( SHADOWMAP_TYPE_VSM )\n\n vec2 offset = vec2( - 1, 1 ) * shadowRadius * texelSize.y;\n\n return (\n texture2DCompare( shadowMap, cubeToUV( bd3D + offset.xyy, texelSize.y ), dp ) +\n texture2DCompare( shadowMap, cubeToUV( bd3D + offset.yyy, texelSize.y ), dp ) +\n texture2DCompare( shadowMap, cubeToUV( bd3D + offset.xyx, texelSize.y ), dp ) +\n texture2DCompare( shadowMap, cubeToUV( bd3D + offset.yyx, texelSize.y ), dp ) +\n texture2DCompare( shadowMap, cubeToUV( bd3D, texelSize.y ), dp ) +\n texture2DCompare( shadowMap, cubeToUV( bd3D + offset.xxy, texelSize.y ), dp ) +\n texture2DCompare( shadowMap, cubeToUV( bd3D + offset.yxy, texelSize.y ), dp ) +\n texture2DCompare( shadowMap, cubeToUV( bd3D + offset.xxx, texelSize.y ), dp ) +\n texture2DCompare( shadowMap, cubeToUV( bd3D + offset.yxx, texelSize.y ), dp )\n ) * ( 1.0 / 9.0 );\n\n #else // no percentage-closer filtering\n\n return texture2DCompare( shadowMap, cubeToUV( bd3D, texelSize.y ), dp );\n\n #endif\n\n }\n\n#endif\n",xn.depth_frag="\n #if DEPTH_PACKING == 3200\n\n uniform float opacity;\n\n#endif\n\n#include <common>\n#include <packing>\n#include <uv_pars_fragment>\n#include <map_pars_fragment>\n#include <alphamap_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\n\nvarying vec2 vHighPrecisionZW;\n\nvoid main() {\n\n #include <clipping_planes_fragment>\n\n vec4 diffuseColor = vec4( 1.0 );\n\n #if DEPTH_PACKING == 3200\n\n diffuseColor.a = opacity;\n\n #endif\n\n #include <map_fragment>\n #include <alphamap_fragment>\n #include <alphatest_fragment>\n\n #include <logdepthbuf_fragment>\n\n // Higher precision equivalent of gl_FragCoord.z. This assumes depthRange has been left to its default values.\n float fragCoordZ = 0.5 * vHighPrecisionZW[0] / vHighPrecisionZW[1] + 0.5;\n\n #if DEPTH_PACKING == 3200\n\n gl_FragColor = vec4( vec3( 1.0 - fragCoordZ ), opacity );\n\n #elif DEPTH_PACKING == 3201\n\n gl_FragColor = packDepthToRGBA( gl_FragCoord.z );\n\n #endif\n\n}\n",xn.bos3d_mesh_physical_frag=tA(xn.meshphysical_frag,"#include <alphamap_fragment>","#include <alphamap_fragment_override>"),xn.bos3d_mesh_basic_frag=tA(xn.meshbasic_frag,"#include <alphamap_fragment>","#include <alphamap_fragment_override>"),Mn.background={uniforms:{uvTransform:{value:new De},t2D:{value:null}},vertexShader:"\n varying vec2 vUv;\n uniform mat3 uvTransform;\n #include <clipping_planes_pars_vertex>\n \n void main() {\n \n vUv = ( uvTransform * vec3( uv, 1 ) ).xy;\n #include <begin_vertex>\n #include <project_vertex>\n #include <clipping_planes_vertex>\n \n gl_Position = vec4( position.xy, 1.0, 1.0 );\n \n }\n ",fragmentShader:"\n uniform sampler2D t2D;\n \n varying vec2 vUv;\n #include <clipping_planes_pars_fragment>\n void main() {\n #include <clipping_planes_fragment>\n \n vec4 texColor = texture2D( t2D, vUv );\n \n gl_FragColor = mapTexelToLinear( texColor );\n \n #include <tonemapping_fragment>\n #include <encodings_fragment>\n \n }\n "},Mn.fillFacePhong={uniforms:ln.merge([wn.common,wn.aomap,wn.lightmap,wn.emissivemap,wn.bumpmap,wn.normalmap,wn.displacementmap,wn.gradientmap,wn.fog,wn.lights,{emissive:{value:new pi(0)},specular:{value:new pi(1118481)},shininess:{value:30}}]),vertexShader:xn.meshphong_id_vert,fragmentShader:xn.fillFaceFragment},Mn.newStyle={vertexShader:xn.newStyleVertex,fragmentShader:xn.newStyleFragment},Mn.bos3dStandard={vertexShader:xn.bos3dStandardVertex,fragmentShader:xn.bos3dStandardFragment};var iA=function(e){lu(i,e);var t=pu(i);function i(e){var n;ru(this,i),(n=t.call(this,e)).type="bos3dStandard",n.roughness=1,n.metalness=0,n.originRoughness=1,n.originMetalness=0,n.pureColor=0,n.textureColor=0,n.imageFade=1,n.transparentEx=!1,n._referenceCount=1,n._imageByteSize=0,n.shift=.5,n.A=.64,n.B=.03,n.C=.02,n.D=.54,n.E=0,n.F=.81,n.scale=.92,n.shininess=30,n.receiveIBL=!0;var r=(new pi).setHex(3330982),o=[r.r,r.g,r.b,1];return n.colorState=Jd.NONE,n.blinkColor=(new Le).fromArray(o),n.blinkCoefficient=0,n.fillMap=null,n.viewportSize=new ke(0,0),n.tag=null,n.viewshedCount=-1,n.viewshedContents=[],n.viewshedDepthMaps=[],n.videoCastCount=-1,n.videoCastContents=[],n.videoCastDepthMaps=[],n.videoCastProjectorMaps=[],n.localClipping=-1,n.innerClipping=-1,n.orthoViewProjMatrix=new yt,n.heightLimitSampler=null,n.heightColorSampler=null,n.heightLimitOrthoMatrix=new yt,n.heightLimit=0,n.useHeightLimit=!1,n.useCSM=xd.EnableCSM,n.useMapAlpha=!1,n.uniforms=ln.merge([Mn.standard.uniforms,wn.specularmap,{clearcoat:{value:0},clearcoatMap:{value:null},clearcoatRoughness:{value:0},clearcoatRoughnessMap:{value:null},clearcoatNormalScale:{value:new ke(1,1)},clearcoatNormalMap:{value:null},sheen:{value:new pi(0)},transmission:{value:0},transmissionMap:{value:null},transmissionSamplerSize:{value:new ke},transmissionSamplerMap:{value:null},thickness:{value:0},thicknessMap:{value:null},attenuationDistance:{value:0},attenuationColor:{value:new pi(0)}},{emissive:{value:new pi(0)},roughness:{value:.5},metalness:{value:.5},envMapIntensity:{value:1}},{shift:{value:.5},A:{value:.64},B:{value:.03},C:{value:.02},D:{value:.54},E:{value:0},F:{value:.81},scale:{value:.92},colorState:{value:0},blinkColor:{value:(new Le).fromArray(o)},blinkCoefficient:{value:0},imageFade:{value:1},heatmapPoints:{value:[]},heatmapTexture:{value:null},frustumPlanes:{value:[]}},{viewportSize:{value:new ke(0,0)},fillMap:{value:null}},{viewshedCount:{value:-1},viewshedContents:{value:[]},viewshedDepthMaps:{value:[]}},{videoCastCount:{value:-1},videoCastContents:{value:[]},videoCastDepthMaps:{value:[]},videoCastProjectorMaps:{value:[]}},{localClipping:{value:-1},innerClipping:{value:n.innerClipping},orthoViewProjMatrix:{value:n.orthoViewProjMatrix}},{heightLimitSampler:{value:null},heightColorSampler:{value:null},heightLimitOrthoMatrix:{value:new yt},heightLimit:{value:0},useHeightLimit:{value:!1}},{csmCascades:{value:null}}]),n.vertexShader=xn.bos3dStandardVertex,n.fragmentShader=xn.bos3dStandardFragment,n.defaultAttributeValues={color:[1,1,1],uv:[0,0],uv2:[0,0]},void 0!==e&&(void 0!==e.attributes&&Bu.error("IBLMaterial: attributes should now be defined in THREE.BufferGeometry instead."),null!=e.doubleSide&&e.doubleSide&&(n.side=2),n.setValues(e)),n.lights=!0,n.lights&&(n.uniforms=ln.merge([n.uniforms,wn.lights])),n.useCSM?n.defines.USE_CSM="":delete n.defines.USE_CSM,n.useMapAlpha?n.defines.USE_MAP_ALPHA="":delete n.defines.USE_MAP_ALPHA,n.refreshUniforms&&n.refreshUniforms(),du(n),n._proLectorLightNum=0,n.onBeforeCompile=function(e,t){var i=t._scene.projectorLightCollection;i.activeLightNum>0&&(e.vertexShader="#define PROJECTORLIGHT\n"+e.vertexShader,e.fragmentShader="#define USE_PROJECTORALPHAMAP\n"+e.fragmentShader),i.activeShadowLightNum>0&&(e.vertexShader="#define USE_PROJECTOR_SHADOWMAP\n"+e.vertexShader,e.fragmentShader="#define USE_PROJECTOR_SHADOWMAP\n"+e.fragmentShader),e.fragmentShader=e.fragmentShader.replace(/NUM_PROJECTOR_LIGHTS/g,i.activeLightNum),e.vertexShader=e.vertexShader.replace(/NUM_PROJECTOR_LIGHTS/g,i.activeLightNum)},n}return i}(_s);iA.prototype.update=function(e,t){var i=e.projectorLightCollection;0!==i.activeLightNum&&((i.activeLightNum!==this._proLectorLightNum||i.needsUpdate)&&(this.needsUpdate=!0,this._proLectorLightNum=i.length),e.projectorLightCollection.updateLights(e),this.updateUniforms(e,t))},iA.prototype.updateUniforms=function(e,t){this.updateProjectorLightUniform(e.projectorLightCollection)},iA.prototype.updateProjectorLightUniform=function(e){var t=e.length;this.uniforms.projectorLights.value=[],this.uniforms.projectorTextures.value=[],this.uniforms.projectorShadowMap.value=[],this.uniforms.projectorAlphaTextures.value=[],this.uniforms.farPlanes.value=[],this.uniforms.projectorShadowMatrix.value=[];for(var i=0;t>i;i+=1){var n=e.get(i);this.uniforms.projectorLights.value.push(n.uniforms),this.uniforms.projectorTextures.value.push(n.map),jg(n.shadow.renderTarget)&&(this.uniforms.projectorShadowMap.value.push(n.shadow.renderTarget.texture),this.uniforms.projectorShadowMatrix.value.push(n.uniforms.projectorShadowMatrix)),jg(n.alphaMap)&&this.uniforms.projectorAlphaTextures.value.push(n.alphaMap)}},iA.prototype.destroy=function(){Xs.prototype.dispose.call(this),this.blinkColor=null,this.uniforms=null,this.defaultAttributeValues=null,this.lights=null},iA.prototype.setValues=function(e){if(void 0!==e)for(var t in e){var i=e[t];if(void 0!==i){var n=this[t];void 0!==n&&(n&&n.isColor?n.set(i):n&&n.isVector3&&i&&i.isVector3?n.copy(i):this[t]="overdraw"===t?Number(i):i)}else console.warn("THREE.Material: '"+t+"' parameter is undefined.")}},iA.prototype.copy=function(e){return Xs.prototype.copy.call(this,e),void 0!==e.shift&&(this.shift=e.shift),void 0!==e.A&&(this.A=e.A),void 0!==e.B&&(this.B=e.B),void 0!==e.C&&(this.C=e.C),void 0!==e.D&&(this.D=e.D),void 0!==e.E&&(this.E=e.E),void 0!==e.F&&(this.F=e.F),void 0!==e.scale&&(this.scale=e.scale),void 0!==e.colorState&&(this.colorState=e.colorState),void 0!==e.blinkColor&&this.blinkColor.copy(e.blinkColor),void 0!==e.blinkCoefficient&&(this.blinkCoefficient=e.blinkCoefficient),void 0!==e.imageFade&&(this.imageFade=e.imageFade),void 0!==e.fillMap&&(this.fillMap=e.fillMap),void 0!==e.viewportSize&&this.viewportSize.copy(e.viewportSize),void 0!==e.localClipping&&(this.localClipping=e.localClipping),void 0!==e.innerClipping&&(this.innerClipping=e.innerClipping),void 0!==e.orthoViewProjMatrix&&this.orthoViewProjMatrix.copy(e.orthoViewProjMatrix),void 0!==e.viewshedCount&&(this.viewshedCount=e.viewshedCount),void 0!==e.viewshedContents&&(this.viewshedContents=e.viewshedContents),void 0!==e.viewshedDepthMaps&&(this.viewshedDepthMaps=e.viewshedDepthMaps),void 0!==e.videoCastCount&&(this.videoCastCount=e.videoCastCount),void 0!==e.videoCastContents&&(this.videoCastContents=e.videoCastContents),void 0!==e.videoCastDepthMaps&&(this.videoCastDepthMaps=e.videoCastDepthMaps),void 0!==e.videoCastProjectorMaps&&(this.videoCastProjectorMaps=e.videoCastProjectorMaps),void 0!==e.heightLimitSampler&&(this.heightLimitSampler=e.heightLimitSampler),void 0!==e.heightColorSampler&&(this.heightColorSampler=e.heightColorSampler),void 0!==e.heightLimitOrthoMatrix&&(this.heightLimitOrthoMatrix=e.heightLimitOrthoMatrix),void 0!==e.heightLimit&&(this.heightLimit=e.heightLimit),void 0!==e.useHeightLimit&&(this.useHeightLimit=e.useHeightLimit),void 0!==e.useCSM&&(this.useCSM=e.useCSM),this.opacity>0||(this.opacity=.1),e.onBeforeCompile2&&(this.onBeforeCompile2=e.onBeforeCompile2),Object.assign(this.defines,e.defines),this},iA.prototype.refreshUniforms=function(){this.uniforms.shift.value=this.shift,this.uniforms.A.value=this.A,this.uniforms.B.value=this.B,this.uniforms.C.value=this.C,this.uniforms.D.value=this.D,this.uniforms.E.value=this.E,this.uniforms.F.value=this.F,this.uniforms.scale.value=this.scale,this.uniforms.blinkColor.value.copy(this.blinkColor),this.uniforms.blinkCoefficient.value=this.blinkCoefficient,this.uniforms.colorState.value=this.colorState,this.uniforms.imageFade.value=this.imageFade,this.uniforms.fillMap.value=this.fillMap,this.uniforms.viewportSize.value=this.viewportSize,this.uniforms.localClipping.value=this.localClipping,this.uniforms.innerClipping.value=this.innerClipping,this.uniforms.orthoViewProjMatrix.value.copy(this.orthoViewProjMatrix),this.uniforms.viewshedCount.value=this.viewshedCount,this.uniforms.viewshedContents.value=this.viewshedContents,this.uniforms.viewshedDepthMaps.value=this.viewshedDepthMaps,this.uniforms.videoCastCount.value=this.videoCastCount,this.uniforms.videoCastContents.value=this.videoCastContents,this.uniforms.videoCastDepthMaps.value=this.videoCastDepthMaps,this.uniforms.videoCastProjectorMaps.value=this.videoCastProjectorMaps,this.viewshedCount>0?this.defines.VIEW_SHED_MODE="":delete this.defines.VIEW_SHED_MODE,this.videoCastCount>0?this.defines.VIDEO_CAST_MODE="":delete this.defines.VIDEO_CAST_MODE,this.heightLimitSampler?this.defines.HEIGHT_LIMIT_READ="":delete this.defines.HEIGHT_LIMIT_READ,this.uniforms.heightLimitOrthoMatrix.value=this.heightLimitOrthoMatrix,this.uniforms.heightLimitSampler.value=this.heightLimitSampler,this.uniforms.heightColorSampler.value=this.heightColorSampler,this.uniforms.heightLimit.value=this.heightLimit,this.uniforms.useHeightLimit.value=this.useHeightLimit,this.useCSM?this.defines.USE_CSM="":delete this.defines.USE_CSM,this.useAlphaMap?this.defines.USE_ALPHAMAP="":delete this.defines.USE_ALPHAMAP},iA.prototype.setBlinkColor=function(e){this.blinkColor.fromArray(e.toArray()),this.uniforms.blinkColor.value.copy(this.blinkColor),this.uniforms.blinkCoefficient.value=this.blinkCoefficient,this.uniforms.colorState.value=Jd.BLINK},iA.prototype.updateBlinkUniformValue=function(e,t,i){this.uniforms.colorState.value=e,this.uniforms.blinkColor.value.copy(t),this.uniforms.blinkCoefficient.value=i},iA.prototype.resetBlinkUniformValue=function(){this.uniforms.colorState.value=this.colorState,this.uniforms.blinkColor.value.copy(this.blinkColor),this.uniforms.blinkCoefficient.value=this.blinkCoefficient},Object.defineProperties(iA.prototype,{transparent:{set:function(e){this.transparentEx=e,xd.notDepthWriteByTransparent&&(this.depthWrite=!e)},get:function(){return this.transparentEx}}});var nA={REGULAR:0,FRACTAL:1,DISORDER:2},rA={type:nA.REGULAR,color1:new Du(0,0,0,1),color2:new Du(255,255,255,1),size:10,level:1,phase:1,width:32,height:32,thresholdLow:0,thresholdHigh:1};function oA(){this.m=2147483647,this.a=16807,this.q=127773,this.r=2836,this.seed=1,this.setSeed=function(e){e>0||(e=-e%(this.m-1)+1),e>this.m-1&&(e=this.m-1),this.seed=e},this.nextLong=function(){var e=this.a*(this.seed%this.q)-this.r*Math.floor(this.seed/this.q);return e>0||(e+=this.m),this.seed=e,e},this.next=function(){return this.nextLong()/this.m}}function aA(e,t,i){this.width=e,this.height=t,this.randseed=i,this.gradients=new Array(e*t*2);var n=new oA;n.setSeed(i);for(var r=0;this.gradients.length>r;r+=2){var o,a,s=n.next()*Math.PI*2;o=Math.sin(s),a=Math.cos(s),this.gradients[r]=o,this.gradients[r+1]=a}this.dot=function(e,t,i,n){var r=2*(e+t*this.width);return this.gradients[r]*i+this.gradients[r+1]*n},this.lerp=function(e,t,i){return e+i*(t-e)},this.sCurve=function(e){return e*e*(3-2*e)},this.getValue=function(e,t,i,n){var r=Math.floor(e),o=Math.floor(t),a=e-r,s=t-o,l=r,c=o,h=r===this.width-1?0:r+1,d=o===this.height-1?0:o+1,u=this.dot(l,c,a,s),p=this.dot(h,c,a-1,s),g=this.dot(l,d,a,s-1),f=this.dot(h,d,a-1,s-1),m=this.lerp(u,p,this.sCurve(a)),A=this.lerp(g,f,this.sCurve(a));return this.lerp(m,A,this.sCurve(s))}}var sA,lA=function(e){var t=Object.assign({},rA,e);switch(t.type){case nA.REGULAR:return function(e){var t=10*e.width,i=10*e.height;if(!(e.color1 instanceof Du))return Bu.warn("color1 不合法"),null;if(!(e.color2 instanceof Du))return Bu.warn("color2 不合法"),null;var n=e.color1.toRGBArray(),r=e.color2.toRGBArray(),o=e.thresholdLow,a=e.thresholdHigh,s=10*e.size,l=e.phase;1===s&&(s=1.1);for(var c=new Array(t*i*4),h=new aA(Math.ceil(t/s),Math.ceil(i/s),l),d=0,u=0,p=0,g=0,f=0,m=0,A=0;i>A;A+=1)for(var y=0;t>y;y+=1){var v=(h.getValue(y/s,A/s)+1)/2;if(v>a)d=r[0],u=r[1],p=r[2];else if(o>v)d=n[0],u=n[1],p=n[2];else if(v>=o&&a>=v||o===a){var C=(v-o)/(a-o||1);g=r[0]*C,f=r[1]*C,m=r[2]*C,d=n[0]*(C=1-C)+g,u=n[1]*C+f,p=n[2]*C+m}var I=4*(A*t+y);c[I]=d,c[I+1]=u,c[I+2]=p,c[I+3]=255}var x=document.createElement("canvas");x.width=t,x.height=i;for(var w=x.getContext("2d"),M=w.createImageData(t,i),E=0,B=t*i*4;B>E;E+=1)M.data[E]=c[E];return w.putImageData(M,0,0),x.toDataURL()}(t);case nA.FRACTAL:return function(e){var t=10*e.width,i=10*e.height;if(!(e.color1 instanceof Du))return Bu.warn("color1 不合法"),null;if(!(e.color2 instanceof Du))return Bu.warn("color2 不合法"),null;var n=e.color1.toRGBArray(),r=e.color2.toRGBArray(),o=e.thresholdLow,a=e.thresholdHigh,s=10*e.size,l=e.phase,c=e.level;1===s&&(s=1.1);for(var h=new Array(t*i*4),d=[],u=s,p=0,g=c;g>p;p+=1){var f=new aA(Math.ceil(t/u),Math.ceil(i/u),l);u/=2,d.push(f)}for(var m=0,A=0,y=0,v=0,C=0,I=0,x=0;i>x;x+=1)for(var w=0;t>w;w+=1){for(var M=0,E=s,B=0,S=c;S>B;B+=1)M+=d[B].getValue(w/E,x/E,l)*(c-B),E/=2;var b=(1+(M/=c))/2;if(b>a)m=r[0],A=r[1],y=r[2];else if(o>b)m=n[0],A=n[1],y=n[2];else if(b>=o&&a>=b||o===a){var k=(b-o)/(a-o||1);v=r[0]*k,C=r[1]*k,I=r[2]*k,m=n[0]*(k=1-k)+v,A=n[1]*k+C,y=n[2]*k+I}var D=4*(x*t+w);h[D]=m,h[D+1]=A,h[D+2]=y,h[D+3]=255}var T=document.createElement("canvas");T.width=t,T.height=i;for(var R=T.getContext("2d"),U=R.createImageData(t,i),F=0,Q=t*i*4;Q>F;F+=1)U.data[F]=h[F];return R.putImageData(U,0,0),T.toDataURL()}(t);case nA.DISORDER:return function(e){var t=10*e.width,i=10*e.height;if(!(e.color1 instanceof Du))return Bu.warn("color1 不合法"),null;if(!(e.color2 instanceof Du))return Bu.warn("color2 不合法"),null;var n=e.color1.toRGBArray(),r=e.color2.toRGBArray(),o=e.thresholdLow,a=e.thresholdHigh,s=10*e.size,l=e.phase,c=e.level;1===s&&(s=1.1);for(var h=new Array(t*i*4),d=[],u=s,p=0,g=c;g>p;p+=1){var f=new aA(Math.ceil(t/u),Math.ceil(i/u),l);u/=2,d.push(f)}for(var m=0,A=0,y=0,v=0,C=0,I=0,x=0;i>x;x+=1)for(var w=0;t>w;w+=1){for(var M=0,E=s,B=0,S=c;S>B;B+=1)M+=d[B].getValue(w/E,x/E,l)*(c-B),E/=2;M/=c;var b=Math.abs(M)+.05;if(b>a)m=r[0],A=r[1],y=r[2];else if(o>b)m=n[0],A=n[1],y=n[2];else if(b>=o&&a>=b||o===a){var k=(b-o)/(a-o||1);v=r[0]*k,C=r[1]*k,I=r[2]*k,m=n[0]*(k=1-k)+v,A=n[1]*k+C,y=n[2]*k+I}var D=4*(x*t+w);h[D]=m,h[D+1]=A,h[D+2]=y,h[D+3]=255}var T=document.createElement("canvas");T.width=t,T.height=i;for(var R=T.getContext("2d"),U=R.createImageData(t,i),F=0,Q=t*i*4;Q>F;F+=1)U.data[F]=h[F];return R.putImageData(U,0,0),T.toDataURL()}(t);default:return Bu.warn("不支持的噪波类型"),null}},cA={DefaultMaterial:new $s({color:255,side:2}),DefaultWireframeColor:{color:new pi(0,0,0),opacity:.4},getDefaultStandardMaterial:(sA=null,function(){return sA||(sA=new iA({color:0,side:2})),sA}),createInstancePhongMaterial:function(e){return e.clone()},updateBasicMaterial:function(e,t){e.needsUpdate=!0},setMatrixUniform:function(e){},createPhongMaterial:function(e){var t=new $s(e);return t.type="FillFacePhong",t.uniforms=ln.merge([Mn.fillFacePhong.uniforms]),t.vertexShader=Mn.fillFacePhong.vertexShader,t.fragmentShader=Mn.fillFacePhong.fragmentShader,t.side=2,t},createStandardMaterial:function(e){var t=new iA(e);return xd.EnableTransformAoMap&&(t.defines.USE_TRANSFORM_AOMAP=""),t},createInstanceMaterial:function(e,t){var i=cA.createStandardMaterial(e);return i.defines.USE_INSTANCE="",t&&(i.defines.USE_INSTANCE_NORMAL=""),i.colorState=Jd.BLINK,xd.InfluencedByLight||(i.defines.NOTAFFECTEDBYLIGHT=""),i.refreshUniforms(),i},createMaterialByMaterialBufferAndTexture:function(e,t){var i,n,r,o,a,s,l,c,h=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1,d=cA.createStandardMaterial();if((d.name=e.name||e.id,d.key=e.id,e.emissive&&d.emissive&&(1===e.emissive[0]&&1===e.emissive[1]&&1===e.emissive[2]||d.emissive.setRGB(e.emissive[0],e.emissive[1],e.emissive[2])),e.specular&&d.specular&&d.specular.setRGB(e.specular[0],e.specular[1],e.specular[2]),e.color?d.color.setRGB(e.color[0],e.color[1],e.color[2]):e.emissive&&d.emissive?d.color.setRGB(0,0,0):d.color.setRGB(.72,.72,.72),e.tint&&(d.imageFade=void 0===e.imageFade||0>e.imageFade||e.imageFade>10?.5:e.imageFade,d.color.setRGB(e.tint[0],e.tint[1],e.tint[2])),e.map&&xd.EnableTextureLoading)&&("string"==typeof e.map?void 0!==e.mapOffsetY&&0!==e.mapOffsetY||void 0!==e.mapOffsetX&&0!==e.mapOfsfetX||void 0!==e.mapScaleX&&1!==e.mapScaleX||void 0!==e.mapScaleY&&1!==e.mapScaleY||void 0!==e.mapWAngle&&0!==e.mapWAngle?i=e.mapOffsetX+"_"+e.mapOffsetY+"_"+e.mapScaleX+"_"+e.mapScaleY+"_"+e.mapWAngle+"_"+e.map:t[e.map]?d.map=t[e.map]:Bu.warn(d.name," 中map贴图未找到",e.map):i=xp(JSON.stringify(e.map)),i))if(t[i])d.map=t[i];else{var u=new Fe;if(u.wrapS=u.wrapT=g,"string"==typeof e.map)u.image=t[e.map]&&t[e.map].image?t[e.map].image:null;else{var p=e.map,f=document.createElement("img"),m=lA({type:Number(p.noise_Type),color1:(new Du).fromArray(p.noise_Color1),color2:(new Du).fromArray(p.noise_Color2),size:p.noise_Size,level:p.noise_Levels,phase:p.noise_Phase,width:32,height:32,thresholdLow:p.noise_ThresholdLow,thresholdHigh:p.noise_ThresholdHigh});m&&(f.src=m,u.image=f)}u.needsUpdate=!0,u.image&&(u.offset.x=e.mapOffsetX?e.mapOffsetX:0,u.offset.y=e.mapOffsetY?e.mapOffsetY:0,u.repeat.x=e.mapScaleX?e.mapScaleX:1,u.repeat.y=e.mapScaleY?e.mapScaleY:1,u.rotation=e.mapWAngle?e.mapWAngle:0,t[i]=u,d.map=u)}if(e.bumpMap&&xd.EnableTextureLoading&&(e.bumpScale=Number(e.bumpScale||1)*h,"string"==typeof e.bumpMap?void 0!==e.bumpMapOffsetY&&0!==e.bumpMapOffsetY||void 0!==e.bumpMapOffsetX&&0!==e.bumpMapOfsfetX||void 0!==e.bumpMapScaleX&&1!==e.bumpMapScaleX||void 0!==e.bumpMapScaleY&&1!==e.bumpMapScaleY||void 0!==e.bumpMapWAngle&&0!==e.bumpMapWAngle?n=e.bumpMapOffsetX+"_"+e.bumpMapOffsetY+"_"+e.bumpMapScaleX+"_"+e.bumpMapScaleY+"_"+e.bumpMapWAngle+"_"+e.bumpMap:t[e.bumpMap]?d.bumpMap=t[e.bumpMap]:Bu.warn(d.name," 中bumpMap贴图未找到",e.bumpMap):n=xp(JSON.stringify(e.bumpMap)),n))if(t[n])d.bumpMap=t[n];else{var A=new Fe;if(A.wrapS=A.wrapT=g,"string"==typeof e.bumpMap)A.image=t[e.bumpMap]&&t[e.bumpMap].image?t[e.bumpMap].image:null;else{var y=e.bumpMap,v=document.createElement("img"),C=lA({type:Number(y.noise_Type),color1:(new Du).fromArray(y.noise_Color1),color2:(new Du).fromArray(y.noise_Color2),size:y.noise_Size,level:y.noise_Levels,phase:y.noise_Phase,width:32,height:32,thresholdLow:y.noise_ThresholdLow,thresholdHigh:y.noise_ThresholdHigh});C&&(v.src=C,A.image=v)}A.needsUpdate=!0,A.image&&(A.offset.x=e.bumpMapOffsetX?e.bumpMapOffsetX:0,A.offset.y=e.bumpMapOffsetY?e.bumpMapOffsetY:0,A.repeat.x=e.bumpMapScaleX?e.bumpMapScaleX:1,A.repeat.y=e.bumpMapScaleY?e.bumpMapScaleY:1,A.rotation=e.bumpMapWAngle?e.bumpMapWAngle:0,t[n]=A,d.bumpMap=A)}if((void 0!==e.bumpScale&&(d.bumpScale=e.bumpScale),e.aoMap&&xd.EnableTextureLoading)&&(e.aoMapIntensity=Number(e.aoMapIntensity||1)*h,"string"==typeof e.aoMap?void 0!==e.aoMapOffsetY&&0!==e.aoMapOffsetY||void 0!==e.aoMapOffsetX&&0!==e.aoMapOfsfetX||void 0!==e.aoMapScaleX&&1!==e.aoMapScaleX||void 0!==e.aoMapScaleY&&1!==e.aoMapScaleY||void 0!==e.aoMapWAngle&&0!==e.aoMapWAngle?r=e.aoMapOffsetX+"_"+e.aoMapOffsetY+"_"+e.aoMapScaleX+"_"+e.aoMapScaleY+"_"+e.aoMapWAngle+"_"+e.aoMap:t[e.aoMap]?d.aoMap=t[e.aoMap]:Bu.warn(d.name," 中aoMap贴图未找到",e.aoMap):r=xp(JSON.stringify(e.aoMap)),r))if(t[r])d.aoMap=t[r];else{var I=new Fe;if(I.wrapS=I.wrapT=g,"string"==typeof e.aoMap)I.image=t[e.aoMap]&&t[e.aoMap].image?t[e.aoMap].image:null;else{var x=e.aoMap,w=document.createElement("img"),M=lA({type:Number(x.noise_Type),color1:(new Du).fromArray(x.noise_Color1),color2:(new Du).fromArray(x.noise_Color2),size:x.noise_Size,level:x.noise_Levels,phase:x.noise_Phase,width:32,height:32,thresholdLow:x.noise_ThresholdLow,thresholdHigh:x.noise_ThresholdHigh});M&&(w.src=M,I.image=w)}I.needsUpdate=!0,I.image&&(I.offset.x=e.aoMapOffsetX?e.aoMapOffsetX:0,I.offset.y=e.aoMapOffsetY?e.aoMapOffsetY:0,I.repeat.x=e.aoMapScaleX?e.aoMapScaleX:1,I.repeat.y=e.aoMapScaleY?e.aoMapScaleY:1,I.rotation=e.aoMapWAngle?e.aoMapWAngle:0,t[r]=I,d.aoMap=I)}if((void 0!==e.aoMapIntensity&&(d.aoMapIntensity=e.aoMapIntensity),e.normalMap&&xd.EnableTextureLoading)&&("string"==typeof e.normalMap?void 0!==e.normalMapOffsetY&&0!==e.normalMapOffsetY||void 0!==e.normalMapOffsetX&&0!==e.normalMapOfsfetX||void 0!==e.normalMapScaleX&&1!==e.normalMapScaleX||void 0!==e.normalMapScaleY&&1!==e.normalMapScaleY||void 0!==e.normalMapWAngle&&0!==e.normalMapWAngle?o=e.normalMapOffsetX+"_"+e.normalMapOffsetY+"_"+e.normalMapScaleX+"_"+e.normalMapScaleY+"_"+e.normalMapWAngle+"_"+e.normalMap:t[e.normalMap]?d.normalMap=t[e.normalMap]:Bu.warn(d.name," 中normalMap贴图未找到",e.normalMap):o=xp(JSON.stringify(e.normalMap)),o))if(t[o])d.normalMap=t[o];else{var E=new Fe;if(E.wrapS=E.wrapT=g,"string"==typeof e.normalMap)E.image=t[e.normalMap]&&t[e.normalMap].image?t[e.normalMap].image:null;else{var B=e.normalMap,S=document.createElement("img"),b=lA({type:Number(B.noise_Type),color1:(new Du).fromArray(B.noise_Color1),color2:(new Du).fromArray(B.noise_Color2),size:B.noise_Size,level:B.noise_Levels,phase:B.noise_Phase,width:32,height:32,thresholdLow:B.noise_ThresholdLow,thresholdHigh:B.noise_ThresholdHigh});b&&(S.src=b,E.image=S)}E.needsUpdate=!0,E.image&&(E.offset.x=e.normalMapOffsetX?e.normalMapOffsetX:0,E.offset.y=e.normalMapOffsetY?e.normalMapOffsetY:0,E.repeat.x=e.normalMapScaleX?e.normalMapScaleX:1,E.repeat.y=e.normalMapScaleY?e.normalMapScaleY:1,E.rotation=e.normalMapWAngle?e.normalMapWAngle:0,t[o]=E,d.normalMap=E)}if(void 0!==e.normalScale&&(d.normalScale=(new ke).fromArray(e.normalScale)),e.alphaMap&&xd.EnableTextureLoading){var k;if("string"==typeof e.alphaMap?void 0!==e.alphaMapOffsetY&&0!==e.alphaMapOffsetY||void 0!==e.alphaMapOffsetX&&0!==e.alphaMapOfsfetX||void 0!==e.alphaMapScaleX&&1!==e.alphaMapScaleX||void 0!==e.alphaMapScaleY&&1!==e.alphaMapScaleY||void 0!==e.alphaMapWAngle&&0!==e.alphaMapWAngle?k=e.alphaMapOffsetX+"_"+e.alphaMapOffsetY+"_"+e.alphaMapScaleX+"_"+e.alphaMapScaleY+"_"+e.alphaMapWAngle+"_"+e.alphaMap:t[e.alphaMap]?d.alphaMap=t[e.alphaMap]:Bu.warn(d.name," 中alphaMap贴图未找到",e.alphaMap):k=xp(JSON.stringify(e.alphaMap)),k)if(t[k])d.alphaMap=t[k];else{var D=new Fe;if(D.wrapS=D.wrapT=g,"string"==typeof e.alphaMap)D.image=t[e.alphaMap]&&t[e.alphaMap].image?t[e.alphaMap].image:null;else{var T=e.alphaMap,R=document.createElement("img"),U=lA({type:Number(T.noise_Type),color1:(new Du).fromArray(T.noise_Color1),color2:(new Du).fromArray(T.noise_Color2),size:T.noise_Size,level:T.noise_Levels,phase:T.noise_Phase,width:32,height:32,thresholdLow:T.noise_ThresholdLow,thresholdHigh:T.noise_ThresholdHigh});U&&(R.src=U,D.image=R)}D.needsUpdate=!0,D.image&&(D.offset.x=e.alphaMapOffsetX?e.alphaMapOffsetX:0,D.offset.y=e.alphaMapOffsetY?e.alphaMapOffsetY:0,D.repeat.x=e.alphaMapScaleX?e.alphaMapScaleX:1,D.repeat.y=e.alphaMapScaleY?e.alphaMapScaleY:1,D.rotation=e.alphaMapWAngle?e.alphaMapWAngle:0,t[k]=D,d.alphaMap=D)}d.transparent=!0,d.alphaTest=Number.isNaN(xd.alphaTest)?.5:xd.alphaTest}if(e.envMap&&xd.EnableTextureLoading&&("string"==typeof e.envMap?void 0!==e.envMapOffsetY&&0!==e.envMapOffsetY||void 0!==e.envMapOffsetX&&0!==e.envMapOfsfetX||void 0!==e.envMapScaleX&&1!==e.envMapScaleX||void 0!==e.envMapScaleY&&1!==e.envMapScaleY||void 0!==e.envMapWAngle&&0!==e.envMapWAngle?a=e.envMapOffsetX+"_"+e.envMapOffsetY+"_"+e.envMapScaleX+"_"+e.envMapScaleY+"_"+e.envMapWAngle+"_"+e.envMap:t[e.envMap]?d.envMap=t[e.envMap]:Bu.warn(d.name," 中envMap贴图未找到",e.envMap):a=xp(JSON.stringify(e.envMap)),a))if(t[a])d.envMap=t[a];else{var F=new Fe;if(F.wrapS=F.wrapT=g,"string"==typeof e.envMap)F.image=t[e.envMap]&&t[e.envMap].image?t[e.envMap].image:null;else{var Q=e.envMap,L=document.createElement("img"),O=lA({type:Number(Q.noise_Type),color1:(new Du).fromArray(Q.noise_Color1),color2:(new Du).fromArray(Q.noise_Color2),size:Q.noise_Size,level:Q.noise_Levels,phase:Q.noise_Phase,width:32,height:32,thresholdLow:Q.noise_ThresholdLow,thresholdHigh:Q.noise_ThresholdHigh});O&&(L.src=O,F.image=L)}F.needsUpdate=!0,F.image&&(F.offset.x=e.envMapOffsetX?e.envMapOffsetX:0,F.offset.y=e.envMapOffsetY?e.envMapOffsetY:0,F.repeat.x=e.envMapScaleX?e.envMapScaleX:1,F.repeat.y=e.envMapScaleY?e.envMapScaleY:1,F.rotation=e.envMapWAngle?e.envMapWAngle:0,t[a]=F,d.envMap=F)}if(e.lightMap&&xd.EnableTextureLoading&&(e.lightMapIntensity=Number(e.lightMapIntensity||1)*h,"string"==typeof e.lightMap?void 0!==e.lightMapOffsetY&&0!==e.lightMapOffsetY||void 0!==e.lightMapOffsetX&&0!==e.lightMapOfsfetX||void 0!==e.lightMapScaleX&&1!==e.lightMapScaleX||void 0!==e.lightMapScaleY&&1!==e.lightMapScaleY||void 0!==e.lightMapWAngle&&0!==e.lightMapWAngle?s=e.lightMapOffsetX+"_"+e.lightMapOffsetY+"_"+e.lightMapScaleX+"_"+e.lightMapScaleY+"_"+e.lightMapWAngle+"_"+e.lightMap:t[e.lightMap]?d.lightMap=t[e.lightMap]:Bu.warn(d.name," 中lightMap贴图未找到",e.lightMap):s=xp(JSON.stringify(e.lightMap)),s))if(t[s])d.lightMap=t[s];else{var N=new Fe;if(N.wrapS=N.wrapT=g,"string"==typeof e.lightMap)N.image=t[e.lightMap]&&t[e.lightMap].image?t[e.lightMap].image:null;else{var P=e.lightMap,G=document.createElement("img"),K=lA({type:Number(P.noise_Type),color1:(new Du).fromArray(P.noise_Color1),color2:(new Du).fromArray(P.noise_Color2),size:P.noise_Size,level:P.noise_Levels,phase:P.noise_Phase,width:32,height:32,thresholdLow:P.noise_ThresholdLow,thresholdHigh:P.noise_ThresholdHigh});K&&(G.src=K,N.image=G)}N.needsUpdate=!0,N.image&&(N.offset.x=e.lightMapOffsetX?e.lightMapOffsetX:0,N.offset.y=e.lightMapOffsetY?e.lightMapOffsetY:0,N.repeat.x=e.lightMapScaleX?e.lightMapScaleX:1,N.repeat.y=e.lightMapScaleY?e.lightMapScaleY:1,N.rotation=e.lightMapWAngle?e.lightMapWAngle:0,t[s]=N,d.lightMap=N)}if((void 0!==e.lightMapIntensity&&(d.lightMapIntensity=e.lightMapIntensity),e.emissiveMap&&xd.EnableTextureLoading)&&(e.emissiveIntensity=Number(e.emissiveIntensity||1)*h,"string"==typeof e.emissiveMap?void 0!==e.emissiveMapOffsetY&&0!==e.emissiveMapOffsetY||void 0!==e.emissiveMapOffsetX&&0!==e.emissiveMapOfsfetX||void 0!==e.emissiveMapScaleX&&1!==e.emissiveMapScaleX||void 0!==e.emissiveMapScaleY&&1!==e.emissiveMapScaleY||void 0!==e.emissiveMapWAngle&&0!==e.emissiveMapWAngle?l=e.emissiveMapOffsetX+"_"+e.emissiveMapOffsetY+"_"+e.emissiveMapScaleX+"_"+e.emissiveMapScaleY+"_"+e.emissiveMapWAngle+"_"+e.emissiveMap:t[e.emissiveMap]?d.emissiveMap=t[e.emissiveMap]:Bu.warn(d.name," 中emissiveMap贴图未找到",e.emissiveMap):l=xp(JSON.stringify(e.emissiveMap)),l))if(t[l])d.emissiveMap=t[l];else{var V=new Fe;if(V.wrapS=V.wrapT=g,"string"==typeof e.emissiveMap)V.image=t[e.emissiveMap]&&t[e.emissiveMap].image?t[e.emissiveMap].image:null;else{var Y=e.emissiveMap,H=document.createElement("img"),j=lA({type:Number(Y.noise_Type),color1:(new Du).fromArray(Y.noise_Color1),color2:(new Du).fromArray(Y.noise_Color2),size:Y.noise_Size,level:Y.noise_Levels,phase:Y.noise_Phase,width:32,height:32,thresholdLow:Y.noise_ThresholdLow,thresholdHigh:Y.noise_ThresholdHigh});j&&(H.src=j,V.image=H)}V.needsUpdate=!0,V.image&&(V.offset.x=e.emissiveMapOffsetX?e.emissiveMapOffsetX:0,V.offset.y=e.emissiveMapOffsetY?e.emissiveMapOffsetY:0,V.repeat.x=e.emissiveMapScaleX?e.emissiveMapScaleX:1,V.repeat.y=e.emissiveMapScaleY?e.emissiveMapScaleY:1,V.rotation=e.emissiveMapWAngle?e.emissiveMapWAngle:0,t[l]=V,d.emissiveMap=V)}if((void 0!==e.emissiveIntensity&&(d.emissiveIntensity=e.emissiveIntensity),e.specularMap&&xd.EnableTextureLoading)&&("string"==typeof e.specularMap?void 0!==e.specularMapOffsetY&&0!==e.specularMapOffsetY||void 0!==e.specularMapOffsetX&&0!==e.specularMapOfsfetX||void 0!==e.specularMapScaleX&&1!==e.specularMapScaleX||void 0!==e.specularMapScaleY&&1!==e.specularMapScaleY||void 0!==e.specularMapWAngle&&0!==e.specularMapWAngle?c=e.specularMapOffsetX+"_"+e.specularMapOffsetY+"_"+e.specularMapScaleX+"_"+e.specularMapScaleY+"_"+e.specularMapWAngle+"_"+e.specularMap:t[e.specularMap]?d.specularMap=t[e.specularMap]:Bu.warn(d.name," 中specularMap贴图未找到",e.specularMap):c=xp(JSON.stringify(e.specularMap)),c))if(t[c])d.specularMap=t[c];else{var W=new Fe;if(W.wrapS=W.wrapT=g,"string"==typeof e.specularMap)W.image=t[e.specularMap]&&t[e.specularMap].image?t[e.specularMap].image:null;else{var J=e.specularMap,z=document.createElement("img"),q=lA({type:Number(J.noise_Type),color1:(new Du).fromArray(J.noise_Color1),color2:(new Du).fromArray(J.noise_Color2),size:J.noise_Size,level:J.noise_Levels,phase:J.noise_Phase,width:32,height:32,thresholdLow:J.noise_ThresholdLow,thresholdHigh:J.noise_ThresholdHigh});q&&(z.src=q,W.image=z)}W.needsUpdate=!0,W.image&&(W.offset.x=e.specularMapOffsetX?e.specularMapOffsetX:0,W.offset.y=e.specularMapOffsetY?e.specularMapOffsetY:0,W.repeat.x=e.specularMapScaleX?e.specularMapScaleX:1,W.repeat.y=e.specularMapScaleY?e.specularMapScaleY:1,W.rotation=e.specularMapWAngle?e.specularMapWAngle:0,t[c]=W,d.specularMap=W)}return void 0!==e.shininess&&(d.shininess=e.shininess),void 0!==e.opacity&&(d.opacity=e.opacity,1>e.opacity&&(d.transparent=!0),e.opacity>0||(d.opacity=.1)),d.side=2,d.refreshUniforms&&d.refreshUniforms(),d},createNewStyleMaterial:function(e){var t=new Xs(e);return t.type="NewStyle",t.uniforms=ln.merge([Mn.standard.uniforms]),t.vertexShader=Mn.newStyle.vertexShader,t.fragmentShader=Mn.newStyle.fragmentShader,t.metalness=0,t},createHighlightMaterial:function(){var e=this.createStandardMaterial(xd.SelectionColor);return xd.InfluencedByLight||(e.defines.NOTAFFECTEDBYLIGHT=""),e},getBlinkMaterial:function(e,t){var i=cA.getMaterialParameters(e),n=cA.createStandardMaterial(i);return n.blinkColor.copy(t),n.colorState=Jd.BLINK,n.refreshUniforms(),n},getMaterialParameters:function(e){var t={};return e.hasOwnProperty("color")&&(t.color=e.color),t.opacity=1,t.transparent=!1,e.hasOwnProperty("opacity")&&(t.opacity=e.opacity,1>e.opacity&&(t.transparent=!0)),e.hasOwnProperty("side")&&(t.side=e.side),e.hasOwnProperty("name")&&(t.name=e.name||""),e.hasOwnProperty("emissive")&&(t.emissive=e.emissive),e.hasOwnProperty("emissiveIntensity")&&(t.emissive=e.emissiveIntensity),e.hasOwnProperty("specular")&&(t.specular=e.specular),e.hasOwnProperty("shininess")&&(t.shininess=e.shininess),e.hasOwnProperty("map")&&(t.map=e.map),e.hasOwnProperty("aoMap")&&(t.aoMap=e.aoMap),e.hasOwnProperty("aoMapIntensity")&&(t.aoMapIntensity=e.aoMapIntensity),e.hasOwnProperty("bumpMap")&&(t.bumpMap=e.bumpMap),e.hasOwnProperty("bumpScale")&&(t.bumpScale=e.bumpScale),e.hasOwnProperty("normalMap")&&(t.normalMap=e.normalMap),e.hasOwnProperty("normalScale")&&(t.normalScale=e.normalScale),e.hasOwnProperty("alphaMap")&&(t.alphaMap=e.alphaMap),e.hasOwnProperty("alphaTest")&&(t.alphaTest=e.alphaTest),e.hasOwnProperty("transparent")&&(t.transparent=e.transparent),e.hasOwnProperty("emissiveMap")&&(t.emissiveMap=e.emissiveMap),e.hasOwnProperty("envMap")&&(t.envMap=e.envMap),e.hasOwnProperty("envMapIntensity")&&(t.envMapIntensity=e.envMapIntensity),e.hasOwnProperty("roughness")&&(t.roughness=e.roughness),e.hasOwnProperty("metalness")&&(t.metalness=e.metalness),e.hasOwnProperty("originRoughness")&&(t.originRoughness=e.originRoughness),e.hasOwnProperty("originMetalness")&&(t.originMetalness=e.originMetalness),e.hasOwnProperty("iblProbe")&&(t.iblProbe=e.iblProbe),e.hasOwnProperty("shift")&&(t.shift=e.shift),e.hasOwnProperty("wireframe")&&(t.wireframe=e.wireframe),e.hasOwnProperty("pureColor")&&(t.pureColor=e.pureColor),e.hasOwnProperty("textureColor")&&(t.textureColor=e.textureColor),e.hasOwnProperty("imageFade")&&(t.imageFade=e.imageFade),"bos3d"===e.type&&e.hasOwnProperty("lights")&&(t.lights=e.lights),e.hasOwnProperty("lightMap")&&(t.lightMap=e.lightMap),e.hasOwnProperty("lightMapIntensity")&&(t.lightMapIntensity=e.lightMapIntensity),e.hasOwnProperty("viewportSize")&&(t.viewportSize=e.viewportSize),e.hasOwnProperty("fillMap")&&(t.fillMap=e.fillMap),t},nextHighestPowerOfTwo:function(e){e-=1;for(var t=1;32>t;t<<=1)e|=e>>t;return e+1},ensurePowerOfTwo:function(e){return e},ensureQuadrate:function(e){var t=e.width,i=e.height;if(0===t||0===i||be.isPowerOfTwo(t)&&be.isPowerOfTwo(i)&&t===i)return e;be.isPowerOfTwo(t)||(t=cA.nextHighestPowerOfTwo(t)),be.isPowerOfTwo(i)||(i=cA.nextHighestPowerOfTwo(i));var n=0,r=0;i>t?n=.5*(i-t):r=.5*(t-i);var o=document.createElement("canvas");return o.width=o.height=Math.max(t,i),o.getContext("2d").drawImage(e,0,0,e.width,e.height,n,r,t,i),o},getRGBAFromColorArray:function(e){var t=e[0],i=e[1],n=e[2],r=e[3];return void 0!==r?"rgba("+t+","+i+","+n+","+r+")":"rgb("+t+","+i+","+n+")"},getRGBAFromArray:function(e){var t=255*e[0],i=255*e[1],n=255*e[2],r=255*e[3];return void 0!==r?"rgba("+t+","+i+","+n+","+r+")":"rgb("+t+","+i+","+n+")"},getArrayFromRGBA:function(e){var t=e.split(","),i=parseInt(t[0].split("(")[1],0)/255,n=parseInt(t[1],0)/255,r=parseInt(t[2].split(")")[0],0)/255;return void 0!==t[3]?[i,n,r,parseFloat(t[3].split(")")[0])]:[i,n,r]},getColorArrayFromRGBA:function(e){var t=e.split(","),i=parseInt(t[0].split("(")[1],0),n=parseInt(t[1],0),r=parseInt(t[2].split(")")[0],0);return void 0!==t[3]?[i,n,r,parseFloat(t[3].split(")")[0])]:[i,n,r]},getHexStringFromRGB:function(e){return"#"+("000000"+cA.getHex(cA.getArrayFromRGBA(e)).toString(16)).slice(-6)},getArrayFromColorArray:function(e){return[e[0]/255,e[1]/255,e[2]/255]},getHexStringFromColorArray:function(e){return"#"+("000000"+cA.getHex(cA.getArrayFromColorArray(e)).toString(16)).slice(-6)},getHexStringFromArray:function(e){return"#"+("000000"+cA.getHex(e).toString(16)).slice(-6)},getHex:function(e){return 255*e[0]<<16^255*e[1]<<8^255*e[2]<<0},getColorParamsByMaterial:function(e){return{rgbaColor:[e.color.r,e.color.g,e.color.b,e.opacity],transparent:e.transparent,wireframe:e.wireframe}},getHoverColorByColor:function(e){var t={};return t.r=e.r,t.g=e.g,t.b=e.b,t.a=cA.getHoverOpacity(e.a),t},getHoverOpacity:function(e){return.4>e?e+.3:e-.3},cloneMaterialBaseOnColor:function(e,t){if(!e.color&&!e.diffuse)return e;var i=e.clone();return i.wireframe=t.wireframe,i.opacity=t.opacity,i.transparent=t.transparent,i.color&&i.color.isColor&&t.color&&t.color.isColor&&i.color.copy(t.color),i.diffuse&&i.diffuse.isColor&&t.diffuse&&t.diffuse.isColor&&i.diffuse.copy(t.diffuse),i}};function hA(){var e,t,i=!1,n=new Map,r={},o={},a=new Map,s={},l={},c={},h=new Set,d={};function u(e){var t=1!==e.getAlpha(),i="blink_"+e.getHex().toString()+"_"+parseFloat(e.getAlpha()).toString(),n=o[i];if(!n){var r=new pi(e.r,e.g,e.b);n=new Xs({color:r}),t&&(n.transparent=t,n.opacity=e.getAlpha()),n.name=i,n.createByBos=!0,n._color=e,o[i]=n}return i}function p(t,i){delete r[t];var u=s[t],p=!1,g=n.get(u);if(u&&g){var f=g.componentKeys;f.remove(t),f.length>0||(!function(e){var t=e.model.modelKeysKey+String(e.materialName)+String(e.interval);delete d[t]}(u),n.delete(u),a.delete(u),l[u.materialName].remove(u),c[u.model.modelKey].remove(u)),l[u.materialName].length>0||delete o[u.materialName],c[u.model.modelKey].length>0||(h.delete(i),i.isUpdateBlink=!1,p=!0),delete s[t],i&&(i.blinkMapComponentKeyToRenderState&&i.blinkMapComponentKeyToRenderState[t]&&(delete i.blinkMapComponentKeyToRenderState[t],p=!0),i.blinkMapComponentKeyToMaterialName&&i.blinkMapComponentKeyToMaterialName[t]&&(delete i.blinkMapComponentKeyToMaterialName[t],p=!0),p&&(e.needApplyFilter=!0))}}function g(e,t,i,r,g){e.forEach((function(e,f){var m=e,A=[],y=function(e,t,i){var n=i.modelKey+String(e)+String(t);if(d[n])return d[n];var r={model:i,interval:t,materialName:e};return d[n]=r,r}(t,i,f);m.forEach((function(e){p(e,f),A.push(e),s[e]=y})),u(g);var v,C=a.get(y);C?(v=C).push.apply(v,A):a.set(y,C=A);h.add(f);var I=l[t];I?I.hasValue(y)||I.push(y):l[t]=[y];var x=c[f.modelKey];x?x.hasValue(y)||x.push(y):c[f.modelKey]=[y],n.set(y,{componentKeys:C,materialName:t,interval:i,model:f,material:o[t],lastBlinkTime:(new Date).getTime(),callback:r})}))}function f(){var o,a,s,l=!1,c=(new Date).getTime(),d={};if(0===n.size)return cancelAnimationFrame(t),void(i=!1);h.forEach((function(e){o=e.blinkMapComponentKeyToMaterialName||{},a=e.blinkMapComponentKeyToRenderState||{},s=e.blinkMapMaterialNameToMaterial||{},e.blinkMapComponentKeyToMaterialName={},e.blinkMapComponentKeyToRenderState={},e.blinkMapMaterialNameToMaterial={}}));var u,p=vu(n.keys());try{for(p.s();!(u=p.n()).done;){var g=u.value,m=n.get(g);if(c-m.lastBlinkTime<m.interval){var A,y=vu(m.componentKeys);try{for(y.s();!(A=y.n()).done;){var v=A.value;a[v]&&(m.model.blinkMapComponentKeyToMaterialName[v]=o[v],m.model.blinkMapComponentKeyToRenderState[v]=a[v],m.model.blinkMapMaterialNameToMaterial[m.materialName]=s[m.materialName],d[v]=m.model.blinkMapComponentKeyToRenderState[v])}}catch(e){y.e(e)}finally{y.f()}}else{m.lastBlinkTime=c;var C,I=vu(m.componentKeys);try{for(I.s();!(C=I.n()).done;){var x=C.value;m.model.blinkMapComponentKeyToMaterialName[x]=m.materialName,m.model.blinkMapComponentKeyToRenderState[x]=!r[x]||!r[x],d[x]=m.model.blinkMapComponentKeyToRenderState[x],m.model.blinkMapMaterialNameToMaterial[m.materialName]=m.material,m.model.isUpdateBlink=!0,m.callback&&"function"==typeof m.callback&&m.callback(g,m.model.blinkMapComponentKeyToRenderState[x])}}catch(e){I.e(e)}finally{I.f()}l=!0}}}catch(e){p.e(e)}finally{p.f()}l&&(e.needApplyFilter=!0,r=d,e.render()),t=requestAnimationFrame(f)}this.setComponentBlinkByComponentKeys=function(t,n,r,o,a){e=o,g(t,u(n),r,a,n),i||(f(),i=!0)},this.closeComponentBlinkByComponentKeys=function(e){e.forEach((function(e,t){e.forEach((function(e){p(e,t)}))}))},this.clearBlinkList=function(){h.forEach((function(e){delete e.blinkMapComponentKeyToMaterialName,delete e.blinkMapComponentKeyToRenderState,delete e.blinkMapMaterialNameToMaterial,e.isUpdateBlink=!1})),n=new Map,r={},o={},a=new Map,s={},l={},c={},h=new Set,d={},e.needApplyFilter=!0,e.render()}}var dA=function(){this.className="FilterAction"};dA.prototype.getClassName=function(){return this.className},dA.prototype.applyFilter=function(e){};var uA=function(){dA.call(this),this.className="IdsFilterAction",this.ids=[]};(uA.prototype=Object.create(dA.prototype)).arrayToMap=function(e){for(var t={},i=0;e.length>i;i+=1){var n=e[i];t[n]=n}return t},uA.prototype.constructor=uA,uA.prototype.setIds=function(e){this.ids=e};var pA=function(e,t){uA.call(this),this.className="VisibleIdsFA",this.flag=e,this.isVisible=t};(pA.prototype=Object.create(uA.prototype)).constructor=pA,pA.prototype.applyFilter=function(e){Array.isArray(this.ids)?(e.setVisible(this.ids,this.isVisible,this.flag),e.calculateVisibleComponentsBbox()):Bu.warn("Ids should be type of array.")};var gA=function(e,t){uA.call(this),this.className="OverrideIdsFA",this.flag=e,this.material=t};(gA.prototype=Object.create(uA.prototype)).constructor=gA,gA.prototype.applyFilter=function(e){Array.isArray(this.ids)?e.setMaterial(this.ids,this.material,this.flag):Bu.warn("Ids should be type of array.")};var fA=function(e,t){uA.call(this),this.className="WireframeIdsFA",this.flag=e,this.material=t};(fA.prototype=Object.create(uA.prototype)).constructor=fA,fA.prototype.applyFilter=function(e){Array.isArray(this.ids)?e.setMaterial(this.ids,this.material,this.flag):Bu.warn("Ids should be type of array.")};var mA=function(e){uA.call(this),this.className="IsolateIdsFA",this.isolateHide=e};(mA.prototype=Object.create(uA.prototype)).constructor=mA,mA.prototype.applyFilter=function(e){Array.isArray(this.ids)?(e.clearIsolates(),this.isolateHide?(e.setIsolateHide(this.ids,!0,!1),e.calculateVisibleComponentsBbox()):e.setIsolateTransparent(this.ids,!0,!1)):Bu.warn("Ids should be type of array.")};var AA=function(e,t){uA.call(this),this.className="TransparentIdsFA",this.flag=e,this.isOpaque=t};(AA.prototype=Object.create(uA.prototype)).constructor=AA,AA.prototype.applyFilter=function(e){Array.isArray(this.ids)?e.setTransparent(this.ids,!this.isOpaque,this.flag):Bu.warn("Ids should be type of array.")};var yA=function(){dA.call(this),this.className="ConditionFilterAction",this.conditions=null};(yA.prototype=Object.create(dA.prototype)).constructor=yA;var vA=function(e,t){yA.call(this),this.className="VisibleConditionFA",this.flag=e,this.isVisible=t};(vA.prototype=Object.create(yA.prototype)).constructor=vA,vA.prototype.applyFilter=function(e){var t=this;Array.isArray(this.conditions)?(e.matchConditions(this.conditions,(function(i,n){t.flag===n&&(e.setVisible(i,t.isVisible),i=null)})),e.calculateVisibleComponentsBbox()):Bu.warn("Conditions should be type of array.")};var CA=function(e,t){yA.call(this),this.className="OverrideConditionFA",this.flag=e,this.material=t};(CA.prototype=Object.create(yA.prototype)).constructor=CA,CA.prototype.applyFilter=function(e,t){var i=this;Array.isArray(this.conditions)?e.matchConditions(this.conditions,(function(t,n){i.flag===n&&(e.setMaterial(t,i.material),t=null)})):Bu.warn("Conditions should be type of array.")};var IA=function(e,t){yA.call(this),this.className="TransparentConditionFA",this.flag=e,this.isOpaque=t};(IA.prototype=Object.create(yA.prototype)).constructor=IA,IA.prototype.applyFilter=function(e){var t=this;Array.isArray(this.conditions)?e.matchConditions(this.conditions,(function(i,n){t.flag===n&&(e.setTransparent(i,!t.isOpaque),i=null)})):Bu.warn("Conditions should be type of array.")};var xA=function(e){yA.call(this),this.className="IsolateConditionFA",this.isolateHide=e};(xA.prototype=Object.create(yA.prototype)).constructor=xA,xA.prototype.applyFilter=function(e){e.clearIsolates();var t=this.isolateHide;Array.isArray(this.conditions)?e.matchConditions(this.conditions,(function(i,n){!0!==n?(t?(e.setIsolateHide(i,!n),e.calculateVisibleComponentsBbox()):e.setIsolateTransparent(i,!n),i=null):i=null})):Bu.warn("Conditions should be type of array.")};var wA=function(e){this._activeFilterList=[],this._filterResultModes={},this._defaultReturnValue=e,this._filterPriority=null};wA.prototype.setFilterMode=function(e){this._filterResultModes=e},wA.prototype.setFilterPriority=function(e){this._filterPriority=e},wA.prototype.addBaseFilter=function(e){var t=this._activeFilterList,i=t.indexOf(e);if(null===this._filterPriority)-1===i?t.push(e):i!==t.length-1&&(t.splice(i,1),t.push(e));else if(0===t.length)t.push(e);else{-1!==i&&i!==t.length-1&&t.splice(i,1);for(var n=this._filterPriority[e.getType()],r=0,o=t.length;o>r;r+=1)if(this._filterPriority[t[r].getType()]>n){t.splice(r,0,e);break}r===o&&t.push(e)}},wA.prototype.removeBaseFilter=function(e){var t=this._activeFilterList.indexOf(e);-1!==t&&this._activeFilterList.splice(t,1)},wA.prototype.isEmpty=function(){return 0===this._activeFilterList.length},wA.prototype.hasFilterNotIn=function(e){for(var t=this._activeFilterList,i=t.length-1;i>=0;i-=1){if(void 0===e._filterResultModes[t[i].getType()])return!0}return!1},wA.prototype.apply=function(e){for(var t=this,i=qd,n=null,r=t._activeFilterList.length-1;r>=0;r-=1)switch(t._filterResultModes[(n=t._activeFilterList[r]).getType()]){case i.MATCH_RETURN_TRUE:if(n.match(e))return!0;break;case i.MATCH_RETURN_FALSE:if(n.match(e))return!1;break;case i.NOMATCH_RETURN_TRUE:if(!n.match(e))return!0;break;case i.NOMATCH_RETURN_FALSE:if(!n.match(e))return!1;break;default:return!1}return t._defaultReturnValue},wA.prototype.getApplyFilterId=function(e){for(var t=this,i=qd,n=null,r=t._activeFilterList.length-1;r>=0;r-=1)switch(t._filterResultModes[(n=t._activeFilterList[r]).getType()]){case i.MATCH_RETURN_TRUE:case i.MATCH_RETURN_FALSE:if(n.match(e))return n.getType();break;case i.NOMATCH_RETURN_TRUE:case i.NOMATCH_RETURN_FALSE:if(!n.match(e))return n.getType();break;default:return-1}return-1},Math.log2=Math.log2||function(e){return Math.log(e)/Math.LN2},"function"!=typeof String.prototype.startsWith&&(String.prototype.startsWith=function(e){return this.slice(0,e.length)===e}),Array.prototype.remove||Object.defineProperty(Array.prototype,"remove",{enumerable:!1,value:function(e){var t=this.indexOf(e);t>-1&&this.splice(t,1)}}),"undefined"!=typeof window&&og.isIE11()&&function(){function e(e,t){t=t||{bubbles:!1,cancelable:!1,detail:void 0};var i=document.createEvent("CustomEvent");return i.initCustomEvent(e,t.bubbles,t.cancelable,t.detail),i}e.prototype=window.CustomEvent.prototype,window.CustomEvent=e}(),"function"!=typeof String.prototype.startsWith&&(String.prototype.startsWith=function(e){return this.slice(0,e.length)===e}),"function"!=typeof String.prototype.endsWith&&(String.prototype.endsWith=function(e){return-1!==this.indexOf(e,this.length-e.length)}),"undefined"!=typeof window&&(window.BlobBuilder=window.BlobBuilder||window.WebKitBlobBuilder||window.MozBlobBuilder||window.MSBlobBuilder),Number.isInteger=Number.isInteger||function(e){return"number"==typeof e&&isFinite(e)&&Math.floor(e)===e},String.prototype.repeat=String.prototype.repeat||function(e){if(1>e)return"";for(var t="",i=this.valueOf();e>1;)1&e&&(t+=i),e>>=1,i+=i;return t+i},Array.prototype.fill||Object.defineProperty(Array.prototype,"fill",{enumerable:!1,value:function(e,t,i){i=void 0===i?this.length:i;for(var n=t=void 0===t?0:t;i>n;n+=1)this[n]=e}}),Array.prototype.find||Object.defineProperty(Array.prototype,"find",{enumerable:!1,value:function(e,t){for(var i=this.length,n=0;i>n;n+=1){var r=this[n];if(e.call(t,r,n,this))return r}}}),Array.prototype.hasValue||Object.defineProperty(Array.prototype,"hasValue",{enumerable:!1,value:function(e){return this.indexOf(e)>-1}}),"function"!=typeof Object.assign&&Object.defineProperty(Object,"assign",{value:function(e,t){if(null==e)throw new TypeError("Cannot convert undefined or null to object");for(var i=Object(e),n=1;arguments.length>n;n+=1){var r=arguments[n];if(null!=r)for(var o in r)Object.prototype.hasOwnProperty.call(r,o)&&(i[o]=r[o])}return i},writable:!0,configurable:!0}),ArrayBuffer.prototype.slice||(ArrayBuffer.prototype.slice=function(e,t){if(!t||t>this.byteLength?t=this.byteLength:0>t&&0>(t=this.byteLength+t)&&(t=0),0>e&&0>(e=this.byteLength+e)&&(e=0),e>=t)return new ArrayBuffer;for(var i=t-e,n=new Uint8Array(this,e,i),r=new Uint8Array(i),o=0;i>o;o+=1)r[o]=n[o];return r.buffer}),Float32Array.prototype.slice||(Float32Array.prototype.slice=Float32Array.prototype.subarray),Uint32Array.prototype.slice||(Uint32Array.prototype.slice=Uint32Array.prototype.subarray),Int32Array.prototype.slice||(Int32Array.prototype.slice=Int32Array.prototype.subarray),Int16Array.prototype.slice||(Int16Array.prototype.slice=Int16Array.prototype.subarray);var MA="function"==typeof Symbol&&"symbol"===nu(Symbol.iterator)?function(e){return nu(e)}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":nu(e)};function EA(e,t,i){return t in e?Object.defineProperty(e,t,{value:i,enumerable:!0,configurable:!0,writable:!0}):e[t]=i,e}var BA,SA=function(){function e(e,t){for(var i=0;t.length>i;i+=1){var n=t[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(e,n.key,n)}}return function(t,i,n){return i&&e(t.prototype,i),n&&e(t,n),t}}();HTMLElement.prototype.tap=function(e){var t=0;this.addEventListener("touchstart",(function(e){t=Date.now()})),this.addEventListener("touchend",(function(i){200>Date.now()-t&&e(i)}))},(Boolean(window.ActiveXObject)||"ActiveXObject"in window)&&(HTMLElement.prototype.remove=function(){var e=this.parentNode||this.parentElement;e&&e.removeChild(this)},window.Element&&((BA=Element.prototype).matches=BA.matches||BA.matchesSelector||BA.webkitMatchesSelector||BA.msMatchesSelector||function(e){for(var t=this,i=(t.parentNode||t.document).querySelectorAll(e),n=-1;i[n+=1]&&i[n]!==t;);return Boolean(i[n])}),window.Element&&function(e){e.closest=e.closest||function(e){for(var t=this;t.matches&&!t.matches(e);)t=t.parentNode;return t.matches?t:null}}(Element.prototype)),SVGElement.prototype.getClass=HTMLElement.prototype.getClass=function(e){return this.getAttribute("class")},SVGElement.prototype.hasClass=HTMLElement.prototype.hasClass=function(e){var t=this.getClass();return!!t&&(t&&t.split(" ")).indexOf(e)>-1},SVGElement.prototype.addClass=HTMLElement.prototype.addClass=function(e){var t=this.getClass(),i=t&&t.split(" ");return t?-1===i.indexOf(e)&&(i.push(e),t=i.join(" "),this.setAttribute("class",String(t))):this.setAttribute("class",String(e)),this},SVGElement.prototype.removeClass=HTMLElement.prototype.removeClass=function(e){if(!this.hasClass(e))return this;var t=this.getClass().replace(e,"").trim();return t?this.setAttribute("class",String(t)):this.removeAttribute("class"),this},SVGElement.prototype.toggleClass=HTMLElement.prototype.toggleClass=function(e,t){this.getClass();var i=this.hasClass(e);return null!=t?(t&&!i&&this.addClass(e),t||this.removeClass(e)):i?this.removeClass(e):this.addClass(e),!i},Array.prototype.getObjectByAttribute||Object.defineProperty(Array.prototype,"getObjectByAttribute",{enumerable:!1,value:function(e,t){for(var i=this,n=i.length,r=0;n>r;r+=1)if(i[r][e]===t)return i[r];return!1}}),Array.prototype.removeObjectByAttribute||Object.defineProperty(Array.prototype,"removeObjectByAttribute",{enumerable:!1,value:function(e,t){for(var i=this,n=i.length,r=0;n>r;r+=1)if(i[r][e]===t)return i=i.splice(r,1);return!1}}),Array.prototype.getAllObjectByAttribute||Object.defineProperty(Array.prototype,"getAllObjectByAttribute",{enumerable:!1,value:function(e,t){for(var i=this,n=i.length,r=0,o=[];n>r;r+=1)i[r][e]===t&&o.push(i[r]);return o}}),Array.prototype.removeByValue||Object.defineProperty(Array.prototype,"removeByValue",{enumerable:!1,value:function(e){for(var t=this,i=t.length-1;i>=0;i-=1)t[i]===e&&t.splice(i,1);return t}}),Array.prototype.insert||Object.defineProperty(Array.prototype,"insert",{enumerable:!1,value:function(e,t){return this.splice(e,0,t),this}}),SVGElement.prototype.setCss=HTMLElement.prototype.setCss=function(e){if(e)for(var t in e)this.style[t]=e[t]},SVGElement.prototype.getCss=HTMLElement.prototype.getCss=function(){return this.style};var bA=function(e,t){this._type=e,this._name=t,this._enabled=!1,this._items={},this._relatedCompoundFilterList=[]};bA.prototype.getType=function(){return this._type},bA.prototype.getName=function(){return this._name},bA.prototype.get=function(){return this._items},bA.prototype.getAll=function(){return this._items},bA.prototype.clearAll=function(){var e=this;e._items={},e._enabled&&(e._enabled=!1,e.enableStateChanged())},bA.prototype.clear=function(){this.clearAll()},bA.prototype.isEmpty=function(){return!this._enabled},bA.prototype.forceEnable=function(){this._enabled||(this._enabled=!0,this.enableStateChanged())},bA.prototype.setByData=function(e){var t=this;!function(e){if(null===e)return!0;if("object"!==(void 0===e?"undefined":MA(e)))return!0;for(var t in e)if(e.hasOwnProperty(t))return!1;return!0}(e)?(t._items=e,t._enabled||(t._enabled=!0,t.enableStateChanged())):(t._items={},t._enabled&&(t._enabled=!1,t.enableStateChanged()))},bA.prototype.match=function(e){return!1},bA.prototype.registerToCompoundFilter=function(e){this._relatedCompoundFilterList.push(e)},bA.prototype.enableStateChanged=function(){for(var e=this,t=0,i=e._relatedCompoundFilterList.length;i>t;t+=1)e._enabled?e._relatedCompoundFilterList[t].addBaseFilter(e):e._relatedCompoundFilterList[t].removeBaseFilter(e)};var kA=function(e,t){bA.call(this,e,t)};(kA.prototype=Object.create(bA.prototype)).constructor=kA,kA.prototype.match=function(e){var t=e.userData;return!t||function(e,t){for(var i=!1,n=0,r=e.length;r>n;n+=1){i=!0;var o=e[n];for(var a in o){if(!Array.isArray(o[a])&&t[a]!==o[a]){i=!1;break}if(Array.isArray(o[a])&&-1===o[a].indexOf(t[a])){i=!1;break}}if(i)return!0}return!1}(this._items,t)};var DA=function(e,t){bA.call(this,e,t)};(DA.prototype=Object.create(bA.prototype)).constructor=DA,DA.prototype.add=function(e){var t=this,i=t._items;if(e&&e.length>0){for(var n=0,r=e.length;r>n;n+=1)i[e[n]]=!0;t._enabled||(t._enabled=!0,t.enableStateChanged())}},DA.prototype.remove=function(e){var t=this,i=t._items;if(e&&e.length>0){for(var n=0,r=e.length;r>n;n+=1){var o=e[n];i.hasOwnProperty(o)&&delete i[o]}0===Object.keys(i).length&&t._enabled&&(t._enabled=!1,t.enableStateChanged())}};var TA=function(e,t){DA.call(this,e,t)};(TA.prototype=Object.create(DA.prototype)).constructor=TA,TA.prototype.match=function(e){var t=e.name;if(t){var i=t.indexOf(".");if(-1!==i){var n=t.substring(0,i);return!!this._items[n]}}var r=e.userData;if(r&&(n=r.sceneId))return!!this._items[n];return!1};var RA=function(e,t){DA.call(this,e,t)};(RA.prototype=Object.create(DA.prototype)).constructor=RA,RA.prototype.match=function(e){return!!this._items[e.name]};var UA=function(){this.defaultWireframeColor={color:new pi(0,0,0),opacity:.4},this.wireframeMaterial=new gi(this.defaultWireframeColor),!1===xd.TranslucentDepthDisabled&&(this.wireframeMaterial.transparent=!0),this.instanceWireframeMaterial=cA.createInstanceMaterial(cA.getMaterialParameters(this.wireframeMaterial)),!1===xd.TranslucentDepthDisabled&&(this.instanceWireframeMaterial.transparent=!0),this.wireframeGeometryMap={}};UA.prototype.destroy=function(){this.wireframeMaterial.dispose(),this.wireframeMaterial=null,this.instanceWireframeMaterial.destroy(),this.instanceWireframeMaterial=null,this.wireframeGeometryMap=null,this.defaultWireframeColor.color=null,this.defaultWireframeColor=null},UA.prototype.setWireframeColor=function(e,t){this.wireframeMaterial.color=e,this.wireframeMaterial.opacity=t,this.wireframeMaterial.transparent=1!==t,this.instanceWireframeMaterial.color=e,this.instanceWireframeMaterial.opacity=t,this.instanceWireframeMaterial.transparent=1!==t},UA.prototype.getWireframeColor=function(){var e=this.wireframeMaterial.color.clone();return e.opacity=this.wireframeMaterial.opacity,e},UA.prototype.restoreWireframeColor=function(){var e=this.defaultWireframeColor;this.setWireframeColor(e.color,e.opacity)};var FA=function(){new UA;var e=[{name:"scene",param:{name:"scene",color:8947848,opacity:.4,transparent:!0,side:2}},{name:"darkRed",param:{name:"darkRed",color:10496040,opacity:1,transparent:!1,side:2}},{name:"lightBlue",param:{name:"lightBlue",color:1275840,opacity:1,transparent:!1,side:2}},{name:"black",param:{name:"black",color:0,opacity:.3,transparent:!0,side:2}},{name:"add",param:{name:"add",color:65280,opacity:1,transparent:!0,side:2}},{name:"delete",param:{name:"delete",color:16711680,opacity:.5,transparent:!0,side:2}},{name:"beforeEdit",param:{name:"beforeEdit",color:16432389,opacity:.5,transparent:!0,side:2}},{name:"afterEdit",param:{name:"afterEdit",color:16432389,opacity:1,transparent:!0,side:2}}],t={};t.selection=cA.createHighlightMaterial(),t.selection.name="selection";for(var i=0,n=e.length;n>i;i+=1){var r=e[i],o=r.name;t[o]=cA.createStandardMaterial(r.param),t[o].createByBos=!0}t.red=t.delete,t.green=t.add,t.yellow=t.beforeEdit,t.blue=t.selection;var a={color:8947848,opacity:.2,transparent:!0,side:2},s=cA.createStandardMaterial(a);s.name="isolate";var l={color:8947848,opacity:.2,transparent:!0,side:2},c=cA.createStandardMaterial(l);c.name="looming";var h={color:0,opacity:1,transparent:!1,wireframe:!0,side:2},d=cA.createStandardMaterial(h);d.name="wireframe",t.wireframe=d;var u={color:15293,side:2},p=cA.createStandardMaterial(u);for(var g in p.name="selected",this.getDefaultMaterialName=function(){return"lightBlue"},this.get=function(e){return t[e]},this.getAll=function(){return t},this.add=function(e){var i,n=null,r={};return e&&e.hasOwnProperty("color")&&(r.color=e.color,r.side=2,e.hasOwnProperty("opacity")&&(r.opacity=e.opacity,r.transparent=1!==e.opacity)),i=this._getMaterialName(e),(n=t[i])||(r.name=i,n=cA.createStandardMaterial(r),t[i]=n,t[i].createByBos=!0),i},this.remove=function(e){var i;i=this._getMaterialName(e),t[i]&&delete t[i]},this.has=function(e){return Boolean(t[e])},this.getMaterialNameByColor=function(e){var i;return i=this._getMaterialName(e),t[i]?i:this.add(e)},this.getMaterialNameByWireframe=function(e){var i;return(i=this._getMaterialName(e))&&!t[i]?this.add(e):i},this.addOverrideMaterial=function(e){if(e){var i=e.name;t[i]||(t[i]=e)}},this.updateOverrideMaterial=function(e){e&&(t[e.name]=e)},this.getMaterialParamsFromName=function(e){var t={},i=e.split("_");return"mat"===i[0]?(t.color=parseInt(i[1],0),t.opacity=1):(t.color=parseInt(i[0],0),t.opacity=parseFloat(i[1],0)),t},this._getMaterialName=function(e){var t=null;return e&&e.hasOwnProperty("color")?t=e.hasOwnProperty("opacity")?e.color+"_"+e.opacity:"mat_"+e.color:e&&e.hasOwnProperty("wireframe")?e.wireframe&&(t="wireframe"):t="mat_"+e,t},this.setWireframeMaterial=function(e){t.wireframe.color.setHex(void 0!==e.color?e.color:h.color),t.wireframe.opacity=void 0!==e.opacity?e.opacity:h.opacity,t.wireframe.transparent=void 0!==e.transparent?e.transparent:h.transparent,t.wireframe.side=void 0!==e.side?e.side:h.side,t.wireframe.needsUpdate=!0},this.getWireframeMaterial=function(){return t.wireframe},this.setFrozonMaterial=function(e){c.color.setHex(void 0!==e.color?e.color:l.color),c.opacity=void 0!==e.opacity?e.opacity:l.opacity,c.transparent=void 0!==e.transparent?e.transparent:l.transparent,c.side=void 0!==e.side?e.side:l.side,c.needsUpdate=!0},this.getFrozonMaterial=function(){return c},this.setSelectedMaterial=function(e){p.color.setHex(void 0!==e.color?e.color:u.color),p.opacity=void 0!==e.opacity?e.opacity:u.opacity,p.transparent=void 0!==e.transparent?e.transparent:u.transparent,p.side=void 0!==e.side?e.side:u.side,p.needsUpdate=!0},this.getSelectedMaterial=function(){return p},this.setIsolateMaterial=function(e){s.color.setHex(void 0!==e.color?e.color:a.color),s.opacity=void 0!==e.opacity?e.opacity:a.opacity,s.transparent=void 0!==e.transparent?e.transparent:a.transparent,s.side=void 0!==e.side?e.side:a.side,s.needsUpdate=!0},this.getIsolateMaterial=function(){return s},this.resetIsolateMaterial=function(){s.color.setHex(a.color),s.opacity=a.opacity,s.transparent=a.transparent,s.side=a.side,s.needsUpdate=!0},t)t[g].createByBos=!0},QA=function(e,t){bA.call(this,e,t)};(QA.prototype=Object.create(bA.prototype)).constructor=QA,QA.prototype.match=function(e){return null!==this.getMatchItem(e)},QA.prototype.getMatchItem=function(e){var t=this._items,i=e.userData,n=!1;if(i)for(var r=t.length,o=0;r>o;o+=1){var a=t[o],s=a.condition;for(var l in n=!0,s)if(s[l]!==i[l]){n=!1;break}if(n)return a}return null};var LA=function(e,t){bA.call(this,e,t)};(LA.prototype=Object.create(bA.prototype)).constructor=LA,LA.prototype.remove=function(e,t){var i=this,n=i._items[e];if(n&&t&&t.length>0){for(var r=0,o=t.length;o>r;r+=1){var a=t[r];n.hasOwnProperty(a)&&delete n[a]}wp.isEmptyObject(i._items)&&i._enabled&&(i._enabled=!1,i.enableStateChanged())}},LA.prototype.add=function(e,t,i){var n=this,r=n._items,o=r[e];if(t&&t.length>0){void 0===i&&(i=!0),o||(o=r[e]={});for(var a=0,s=t.length;s>a;a+=1)o[t[a]]=i;n._enabled||(n._enabled=!0,n.enableStateChanged())}},LA.prototype.clear=function(e){var t=this,i=t._items;i.hasOwnProperty(e)&&(delete i[e],wp.isEmptyObject(i)&&t._enabled&&(t._enabled=!1,t.enableStateChanged()))};var OA=function(e,t){bA.call(this,e,t)};(OA.prototype=Object.create(LA.prototype)).constructor=OA,OA.prototype.match=function(e){return null!==this.getMatchItem(e)},OA.prototype.getMatchItem=function(e){var t=this._items,i=e.name;for(var n in t){var r=t[n];if(r[i])return r[i]}return null};var NA=function(e,t){bA.call(this,e,t)};(NA.prototype=Object.create(LA.prototype)).constructor=NA,NA.prototype.match=function(e){return null!==this.getMatchItem(e)},NA.prototype.getMatchItem=function(e){var t=this._items,i=e.userData;if(i)for(var n in t){var r=t[n],o=i[n];if(o&&void 0!==r[o])return r[o]}return null};var PA=function(){var e=qd,t={IDFILTER_OFFSET:0,FILE_VISIBLE:0,FILE_HIDDEN:1,VISIBLE:2,HIDDEN:3,TRANSLUCENT:4,TRANSLUCENT_OTHERS:5,WIREFRAME:24,COLORFUL:25,RENDER_PROMOTION:6,IDFILTER_ENDOFFSET:6,ISOLATEFILTER_OFFSET:7,ISOLATE_HIDDEN:7,ISOLATE_HIDDEN_OTHERS:8,ISOLATE_TRANSLUCENT:9,ISOLATE_TRANSLUCENT_OTHERS:10,ISOLATEFILTER_ENDOFFSET:10,USERFILTER_OFFSET:11,USER_HIDDEN:11,USER_OVERRIDE:12,USER_WITH_BOARDLINE:13,USERFILTER_ENDOFFSET:13,CONDITIONFILTER_OFFSET:14,CONDITION_HIDDEN_OTHERS:14,CONDITION_TRANSLUCENT_OTHERS:15,CONDITION_OVERRIDE:16,CONDITION_BORDERLINE:26,CONDITIONFILTER_ENDOFFSET:16,ISOLATECONDITIONFILTER_OFFSET:17,ISOLATE_CONDITION_HIDDEN:17,ISOLATE_CONDITION_HIDDEN_OTHERS:18,ISOLATE_CONDITION_TRANSLUCENT:19,ISOLATE_CONDITION_TRANSLUCENT_OTHERS:20,ISOLATECONDITIONFILTER_ENDOFFSET:20,FROZENFILTER:21,FROZENCONDITIONFILTER:22,OVERRIDEFILTER:23,BASICFILTER_COUNT:23},i=new wA(!0),n=new wA(!0),r=new wA(!1),o=new wA(!0),a=new wA(!1),s=new wA(!1),l=new wA(!1),c=[],h=null,d=null,u=Kd.DISABLED,p=new FA;!function(){c[t.FILE_VISIBLE]=new TA(t.FILE_VISIBLE,"FILE_VISIBLE"),c[t.FILE_HIDDEN]=new TA(t.FILE_HIDDEN,"FILE_HIDDEN"),c[t.VISIBLE]=new RA(t.VISIBLE,"VISIBLE"),c[t.HIDDEN]=new RA(t.HIDDEN,"HIDDEN"),c[t.TRANSLUCENT]=new RA(t.TRANSLUCENT,"TRANSLUCENT"),c[t.TRANSLUCENT_OTHERS]=new RA(t.TRANSLUCENT_OTHERS,"TRANSLUCENT_OTHERS"),c[t.RENDER_PROMOTION]=new RA(t.RENDER_PROMOTION,"RENDER_PROMOTION"),c[t.WIREFRAME]=new RA(t.WIREFRAME,"WIREFRAME"),c[t.COLORFUL]=new RA(t.COLORFUL,"COLORFUL"),c[t.ISOLATE_HIDDEN]=new RA(t.ISOLATE_HIDDEN,"ISOLATE_HIDDEN"),c[t.ISOLATE_HIDDEN_OTHERS]=new RA(t.ISOLATE_HIDDEN_OTHERS,"ISOLATE_HIDDEN_OTHERS"),c[t.ISOLATE_TRANSLUCENT]=new RA(t.ISOLATE_TRANSLUCENT,"ISOLATE_TRANSLUCENT"),c[t.ISOLATE_TRANSLUCENT_OTHERS]=new RA(t.ISOLATE_TRANSLUCENT_OTHERS,"ISOLATE_TRANSLUCENT_OTHERS"),c[t.USER_HIDDEN]=new NA(t.USER_HIDDEN,"USER_HIDDEN"),c[t.USER_OVERRIDE]=new NA(t.USER_OVERRIDE,"USER_OVERRIDE"),c[t.CONDITION_BORDERLINE]=new kA(t.CONDITION_BORDERLINE,"CONDITION_BORDERLINE"),c[t.CONDITION_HIDDEN_OTHERS]=new kA(t.CONDITION_HIDDEN_OTHERS,"CONDITION_HIDDEN_OTHERS"),c[t.CONDITION_TRANSLUCENT_OTHERS]=new kA(t.CONDITION_TRANSLUCENT_OTHERS,"CONDITION_TRANSLUCENT_OTHERS"),c[t.CONDITION_OVERRIDE]=new QA(t.CONDITION_OVERRIDE,"CONDITION_OVERRIDE"),c[t.ISOLATE_CONDITION_HIDDEN]=new kA(t.ISOLATE_CONDITION_HIDDEN,"ISOLATE_CONDITION_HIDDEN"),c[t.ISOLATE_CONDITION_HIDDEN_OTHERS]=new kA(t.ISOLATE_CONDITION_HIDDEN_OTHERS,"ISOLATE_CONDITION_HIDDEN_OTHERS"),c[t.ISOLATE_CONDITION_TRANSLUCENT]=new kA(t.ISOLATE_CONDITION_TRANSLUCENT,"ISOLATE_CONDITION_TRANSLUCENT"),c[t.ISOLATE_CONDITION_TRANSLUCENT_OTHERS]=new kA(t.ISOLATE_CONDITION_TRANSLUCENT_OTHERS,"ISOLATE_CONDITION_TRANSLUCENT_OTHERS"),d=new RA(t.FROZENFILTER,"FROZENFILTER"),c[t.FROZENCONDITIONFILTER]=new kA(t.FROZENCONDITIONFILTER,"FROZENCONDITIONFILTER"),c[t.FROZENFILTER]=d,h=new OA(t.OVERRIDEFILTER,"OVERRIDEFILTER"),c[t.OVERRIDEFILTER]=h;var u=null,p={};for(u in p[t.HIDDEN]=e.MATCH_RETURN_FALSE,p[t.VISIBLE]=e.NOMATCH_RETURN_FALSE,p[t.USER_HIDDEN]=e.MATCH_RETURN_FALSE,p[t.CONDITION_HIDDEN_OTHERS]=e.NOMATCH_RETURN_FALSE,p[t.ISOLATE_HIDDEN]=e.MATCH_RETURN_FALSE,p[t.ISOLATE_HIDDEN_OTHERS]=e.NOMATCH_RETURN_FALSE,p[t.ISOLATE_CONDITION_HIDDEN_OTHERS]=e.NOMATCH_RETURN_FALSE,i.setFilterMode(p),p)c[u].registerToCompoundFilter(i);var g={};for(u in g[t.FROZENFILTER]=e.MATCH_RETURN_FALSE,g[t.FROZENCONDITIONFILTER]=e.MATCH_RETURN_FALSE,g[t.TRANSLUCENT]=e.MATCH_RETURN_FALSE,g[t.TRANSLUCENT_OTHERS]=e.NOMATCH_RETURN_FALSE,g[t.CONDITION_TRANSLUCENT_OTHERS]=e.NOMATCH_RETURN_FALSE,g[t.ISOLATE_TRANSLUCENT]=e.MATCH_RETURN_FALSE,g[t.ISOLATE_TRANSLUCENT_OTHERS]=e.NOMATCH_RETURN_FALSE,g[t.ISOLATE_CONDITION_TRANSLUCENT_OTHERS]=e.NOMATCH_RETURN_FALSE,o.setFilterMode(g),g)c[u].registerToCompoundFilter(o);var f={};f[t.ISOLATE_TRANSLUCENT]=e.MATCH_RETURN_TRUE,f[t.ISOLATE_TRANSLUCENT_OTHERS]=e.NOMATCH_RETURN_TRUE,f[t.ISOLATE_CONDITION_TRANSLUCENT_OTHERS]=e.NOMATCH_RETURN_TRUE,f[t.CONDITION_TRANSLUCENT_OTHERS]=e.NOMATCH_RETURN_TRUE,f[t.TRANSLUCENT]=e.MATCH_RETURN_TRUE,f[t.TRANSLUCENT_OTHERS]=e.NOMATCH_RETURN_TRUE,f[t.OVERRIDEFILTER]=e.MATCH_RETURN_TRUE,f[t.USER_OVERRIDE]=e.MATCH_RETURN_TRUE,f[t.CONDITION_OVERRIDE]=e.MATCH_RETURN_TRUE,f[t.FROZENFILTER]=e.MATCH_RETURN_TRUE,f[t.FROZENCONDITIONFILTER]=e.MATCH_RETURN_TRUE;var m={};for(u in m[t.ISOLATE_TRANSLUCENT]=5,m[t.ISOLATE_TRANSLUCENT_OTHERS]=5,m[t.ISOLATE_CONDITION_TRANSLUCENT_OTHERS]=5,m[t.CONDITION_TRANSLUCENT_OTHERS]=5,m[t.TRANSLUCENT]=5,m[t.TRANSLUCENT_OTHERS]=5,m[t.OVERRIDEFILTER]=0,m[t.USER_OVERRIDE]=0,m[t.CONDITION_OVERRIDE]=0,m[t.FROZENFILTER]=3,m[t.FROZENCONDITIONFILTER]=3,n.setFilterMode(f),n.setFilterPriority(m),f)c[u].registerToCompoundFilter(n);var A={};for(u in A[t.OVERRIDEFILTER]=e.MATCH_RETURN_TRUE,A[t.USER_OVERRIDE]=e.MATCH_RETURN_TRUE,A[t.CONDITION_OVERRIDE]=e.MATCH_RETURN_TRUE,A[t.CONDITION_TRANSLUCENT_OTHERS]=e.MATCH_RETURN_TRUE,r.setFilterMode(A),A)c[u].registerToCompoundFilter(r);var y={};for(u in y[t.FILE_VISIBLE]=e.NOMATCH_RETURN_TRUE,y[t.FILE_HIDDEN]=e.MATCH_RETURN_TRUE,a.setFilterMode(y),y)c[u].registerToCompoundFilter(a);var v={};for(u in v[t.RENDER_PROMOTION]=e.MATCH_RETURN_TRUE,v[t.ISOLATE_CONDITION_TRANSLUCENT_OTHERS]=e.MATCH_RETURN_TRUE,s.setFilterMode(v),v)c[u].registerToCompoundFilter(s);var C={};for(u in C[t.CONDITION_BORDERLINE]=e.MATCH_RETURN_TRUE,l.setFilterMode(C),C)c[u].registerToCompoundFilter(l)}(),this.getMaterialSelector=function(){return p},this.getBasicFilterList=function(){return c},this.getFilterType=function(){return t},this.saveState=function(){for(var e={},t=null,i=0,n=c.length;n>i;i+=1)e[(t=c[i]).getName()]=t.getAll();return e.sceneState=this.getSceneState(),e.version="1.0",e},this.loadState=function(e){if(this.clearAll(),e.hasOwnProperty("version")){if("1.0"===e.version){for(var i={},n=0,r=c.length;r>n;n+=1)i[c[n].getName()]=n;for(var o in e)"sceneState"!==o&&"version"!==o&&(i.hasOwnProperty(o)?c[i[o]].setByData(e[o]):Bu.warn("Warning: Not supported filter '"+o+"'"))}}else for(var a in e)"sceneState"!==a&&(2>a?c[a].setByData(e[a]):a>2?t.BASICFILTER_COUNT+2>a&&c[a-1].setByData(e[a]):2!==a&&"2"!==a||Bu.warn("Warning: Old version filter data! The selection state is out of the filter, can not restore it."));this.setSceneState(e.sceneState)},this.clear=function(){for(var e=0,i=c.length;i>e;e+=1){var n=c[e].getType();n!==t.FROZENFILTER&&n!==t.CONDITION_BORDERLINE&&c[e].clearAll()}this.setSceneState(Kd.DISABLED)},this.clearAll=function(){for(var e=0,t=c.length;t>e;e+=1)c[e].clearAll();this.setSceneState(Kd.DISABLED)},this.clearIsolate=function(){this.clearAllIsolateList(),this.clearAllIsolateConditions()},this.clearFrozenList=function(){d.clearAll()},this.addToFrozenList=function(e){d.add(e)},this.removeFromFrozenList=function(e){d.remove(e)},this.setFrozenList=function(e){this.clearFrozenList(),this.addToFrozenList(e)},this.setFrozenConditions=function(e){c[t.FROZENCONDITIONFILTER].setByData(e)},this.getFrozenConditions=function(){return c[t.FROZENCONDITIONFILTER].getAll()},this.clearFrozenConditions=function(){c[t.FROZENCONDITIONFILTER].clear()},this.clearFrozen=function(){this.clearFrozenList(),this.clearFrozenConditions()},this.clearAllIdList=function(){var e=null;for(e=t.IDFILTER_OFFSET;t.IDFILTER_ENDOFFSET>=e;e+=1)c[e].clearAll()},this.clearIdList=function(e){var i=t.IDFILTER_OFFSET+e;t.IDFILTER_OFFSET>i||i>t.IDFILTER_ENDOFFSET||c[i].clear()},this.addToIdList=function(e,i){var n=t.IDFILTER_OFFSET+e;t.IDFILTER_OFFSET>n||n>t.IDFILTER_ENDOFFSET||c[n].add(i)},this.removeFromIdList=function(e,i){var n=t.IDFILTER_OFFSET+e;t.IDFILTER_OFFSET>n||n>t.IDFILTER_ENDOFFSET||c[n].remove(i)},this.setIdList=function(e,t){this.clearIdList(e),this.addToIdList(e,t)},this.clearAllOverrideList=function(){h.clearAll()},this.clearOverrideList=function(e){h.clear(e)},this.addToOverrideList=function(e,t,i){t&&t.length>0&&(p.has(i)||(i=p.getDefaultMaterialName()),h.add(e,t,i))},this.removeFromOverrideList=function(e,t){h.remove(e,t)},this.setOverrideList=function(e,t,i){this.clearOverrideList(e),this.addToOverrideList(e,t,i)},this.addToOverrideListByColor=function(e,t,i){var n=p.add(i);h.add(e,t,n)},this.setOverrideListByColor=function(e,t,i){this.clearOverrideList(e),this.addToOverrideListByColor(e,t,i)},this.clearAllUserList=function(){var e=null;for(e=t.USERFILTER_OFFSET;t.USERFILTER_ENDOFFSET>=e;e+=1)c[e].clearAll()},this.clearUserListByType=function(e){var i=t.USERFILTER_OFFSET+e;t.USERFILTER_OFFSET>i||i>t.USERFILTER_ENDOFFSET||c[i].clearAll()},this.clearUserList=function(e,i){var n=t.USERFILTER_OFFSET+e;t.USERFILTER_OFFSET>n||n>t.USERFILTER_ENDOFFSET||c[n].clear(i)},this.addToUserList=function(e,i,n,r){var o=t.USERFILTER_OFFSET+e;t.USERFILTER_OFFSET>o||o>t.USERFILTER_ENDOFFSET||c[o].add(i,n,r)},this.removeFromUserList=function(e,i,n){var r=t.USERFILTER_OFFSET+e;t.USERFILTER_OFFSET>r||r>t.USERFILTER_ENDOFFSET||c[r].remove(i,n)},this.setUserList=function(e,t,i,n){this.clearUserList(e,t),this.addToUserList(e,t,i,n)},this.isIsolate=function(){var e=null;for(e=t.ISOLATEFILTER_OFFSET;t.ISOLATEFILTER_ENDOFFSET>=e;e+=1)if(!c[e].isEmpty())return!0;return!1},this.isFiltering=function(){return!!this.isIsolate()||!(c[t.HIDDEN].isEmpty()&&c[t.VISIBLE].isEmpty()&&c[t.TRANSLUCENT].isEmpty()&&c[t.TRANSLUCENT_OTHERS].isEmpty()&&this.getSceneState()===Kd.DISABLED)},this.setFrozonMaterial=function(e){p.setFrozonMaterial(e)},this.getFrozonMaterial=function(){return p.getFrozonMaterial()},this.setSelectedMaterial=function(e){p.setSelectedMaterial(e)},this.getSelectedMaterial=function(){return p.getSelectedMaterial()},this.setIsolateMaterial=function(e){p.setIsolateMaterial(e)},this.getIsolateMaterial=function(){return p.getIsolateMaterial()},this.resetIsolateMaterial=function(){p.resetIsolateMaterial()},this.clearAllIsolateList=function(){var e=null;for(e=t.ISOLATEFILTER_OFFSET;t.ISOLATEFILTER_ENDOFFSET>=e;e+=1)c[e].clear()},this.clearIsolateList=function(e){var i=t.ISOLATEFILTER_OFFSET+e;t.ISOLATEFILTER_OFFSET>i||i>t.ISOLATEFILTER_ENDOFFSET||c[i].clear()},this.addToIsolateList=function(e,i){var n=t.ISOLATEFILTER_OFFSET+e;t.ISOLATEFILTER_OFFSET>n||n>t.ISOLATEFILTER_ENDOFFSET||c[n].add(i)},this.removeFromIsolateList=function(e,i){var n=t.ISOLATEFILTER_OFFSET+e;t.ISOLATEFILTER_OFFSET>n||n>t.ISOLATEFILTER_ENDOFFSET||c[n].remove(i)},this.setIsolateList=function(e,t){this.clearIsolateList(e),this.addToIsolateList(e,t)},this.setIsolateConditions=function(e,i){var n=t.ISOLATECONDITIONFILTER_OFFSET+i;t.ISOLATECONDITIONFILTER_OFFSET>n||n>t.ISOLATECONDITIONFILTER_ENDOFFSET||c[n].setByData(e)},this.getIsolateConditions=function(e){var i=null,n=t.ISOLATECONDITIONFILTER_OFFSET+e;return t.ISOLATECONDITIONFILTER_OFFSET>n||n>t.ISOLATECONDITIONFILTER_ENDOFFSET||(i=c[n].getAll()),i},this.clearIsolateConditions=function(e){var i=t.ISOLATECONDITIONFILTER_OFFSET+e;t.ISOLATECONDITIONFILTER_OFFSET>i||i>t.ISOLATECONDITIONFILTER_ENDOFFSET||c[i].clear()},this.clearAllIsolateConditions=function(){var e=null;for(e=t.ISOLATECONDITIONFILTER_OFFSET;t.ISOLATECONDITIONFILTER_ENDOFFSET>=e;e+=1)c[e].clearAll()},this.setConditions=function(e,i){var n=t.CONDITIONFILTER_OFFSET+e;t.CONDITIONFILTER_OFFSET>n||n>t.CONDITIONFILTER_ENDOFFSET||c[n].setByData(i)},this.getConditions=function(e){var i=null,n=t.CONDITIONFILTER_OFFSET+e;return t.CONDITIONFILTER_OFFSET>n||n>t.CONDITIONFILTER_ENDOFFSET||(i=c[n].get()),i},this.clearConditions=function(e){var i=t.CONDITIONFILTER_OFFSET+e;t.CONDITIONFILTER_OFFSET>i||i>t.CONDITIONFILTER_ENDOFFSET||c[i].clearAll()},this.clearAllConditions=function(){var e=null;for(e=t.CONDITIONFILTER_OFFSET;t.CONDITIONFILTER_ENDOFFSET>=e;e+=1)c[e].clear()},this.makeSceneTranslucent=function(){this.setSceneState(Kd.TRANSLUCENT)},this.cancelSceneTranslucent=function(){this.setSceneState(Kd.DISABLED)},this.hideScene=function(){this.setSceneState(Kd.HIDDEN)},this.showScene=function(){this.setSceneState(Kd.DISABLED)},this.setSceneState=function(e){u=e},this.getSceneState=function(){return u},this.cancelTranslucent=function(){this.clearIdList(Od.TRANSLUCENT),this.clearIdList(Od.TRANSLUCENT_OTHERS)},this._addIdsToFilter=function(e,i){var n=t.IDFILTER_OFFSET+e;t.IDFILTER_OFFSET>n||n>t.IDFILTER_ENDOFFSET||c[n].add(i)},this.hideByIds=function(e){this._addIdsToFilter(Od.HIDDEN,e)},this.showByIds=function(e){this._addIdsToFilter(Od.VISIBLE,e)},this.makeTranslucentByIds=function(e){this._addIdsToFilter(Od.TRANSLUCENT,e)},this.makeTranslucentOthersByIds=function(e){this._addIdsToFilter(Od.TRANSLUCENT_OTHERS,e)},this._isVisible=function(e){return this.getSceneState()!==Kd.HIDDEN&&i.apply(e)},this._isSelectable=function(e){return this.getSceneState()!==Kd.TRANSLUCENT&&o.apply(e,this.getSceneState())},this._isSelectableById=function(e){return!d.get()[e]},this.getMaterialNameByColor=function(e){return p.getMaterialNameByColor(e)},this.getMaterialNameByWireframe=function(e){return p.getMaterialNameByWireframe(e)},this.addOverrideMaterial=function(e){p.addOverrideMaterial(e)},this.updateOverrideMaterial=function(e){p.updateOverrideMaterial(e)},this.getMaterialByName=function(e){return p.get(e)},this._getOverrideMaterial=function(e){if(this.getSceneState()===Kd.TRANSLUCENT)return p.get("scene");var i=n.getApplyFilterId(e),r=null,o="";switch(i){case t.ISOLATE_TRANSLUCENT:case t.ISOLATE_TRANSLUCENT_OTHERS:case t.ISOLATE_CONDITION_TRANSLUCENT_OTHERS:r=this.getIsolateMaterial();break;case t.CONDITION_TRANSLUCENT_OTHERS:case t.TRANSLUCENT:case t.TRANSLUCENT_OTHERS:r=p.get("scene");break;case t.FROZENFILTER:case t.FROZENCONDITIONFILTER:break;case t.OVERRIDEFILTER:case t.USER_OVERRIDE:case t.CONDITION_OVERRIDE:var a=c[i].getMatchItem(e);o=a.hasOwnProperty("color")?p.getMaterialNameByColor(a.color):a.material?a.material:a}return r||""===o||(p.has(o)||(o=p.getDefaultMaterialName()),r=p.get(o)),r},this._getMaterialName=function(e){if(this.getSceneState()===Kd.TRANSLUCENT)return"scene";var i=n.getApplyFilterId(e),r="";switch(i){case t.ISOLATE_TRANSLUCENT:case t.ISOLATE_TRANSLUCENT_OTHERS:case t.ISOLATE_CONDITION_TRANSLUCENT_OTHERS:r=this.getIsolateMaterial().name;break;case t.CONDITION_TRANSLUCENT_OTHERS:case t.TRANSLUCENT:case t.TRANSLUCENT_OTHERS:r="scene";break;case t.FROZENFILTER:case t.FROZENCONDITIONFILTER:break;case t.OVERRIDEFILTER:case t.USER_OVERRIDE:case t.CONDITION_OVERRIDE:var o=c[i].getMatchItem(e);r=o.hasOwnProperty("color")?p.getMaterialNameByColor(o.color):o.material?o.material:o}return r},this._getMaterialByName=function(e){return e instanceof ai?e:"isolate"===e?p.getIsolateMaterial():"looming"===e||"scene"===e?p.getFrozonMaterial():"selected"===e?p.getSelectedMaterial():p.get(e)},this._hasHighPriorityOverrideMaterial=function(e){return this.getSceneState()===Kd.TRANSLUCENT||r.apply(e)},this._hasOverrideMaterial=function(e){return this.getSceneState()===Kd.TRANSLUCENT||r.apply(e)||n.apply(e)},this._isHiddenFileId=function(e){return a.apply(e)},this._hasHiddenFileIdFilter=function(){return!a.isEmpty()},this._hasVisibleFilter=function(){return this.getSceneState()===Kd.HIDDEN||!i.isEmpty()},this._hasPickableFilter=function(){return this.getSceneState()===Kd.TRANSLUCENT||!o.isEmpty()},this._hasOverrideMaterialFilter=function(){return this.getSceneState()===Kd.TRANSLUCENT||!n.isEmpty()},this._hasLowPriorityOverride=function(){return n.hasFilterNotIn(r)},this._isRenderPromotion=function(e){return s.apply(e)},this._hasRenderPromotionFilter=function(){return!s.isEmpty()},this._isRenderWithBoardline=function(e){return l.apply(e)},this._hasRenderWithBoardlineFilter=function(){return!l.isEmpty()},this._getFilterObjectsKeys=function(e){var t=c[e].get(),i=[];for(var n in t)i.push(n);return i}},GA=function(e){this.materialSelector=e;var t=function(e){var t=[];for(var i in e)!0===e[i]&&t.push(i);return t};this.saveState=function(e){var t=e.getIsolateFilterAction(),i=e.getModelIsolateFilterAction(),n=e.getFilterActionList(),r={isolateAction:t,modelIsolateAction:i,modelActions:e.getModelFilterActionList(),actions:n,sceneState:e.getSceneState(),version:"1.0"};return JSON.stringify(r)},this.createAction=function(e){var t=e.className,i=null;switch(t){case"IsolateIdsFA":(i=new mA(e.isolateHide)).ids=e.ids;break;case"VisibleIdsFA":(i=new pA(e.flag,e.isVisible)).ids=e.ids;break;case"OverrideIdsFA":if(r=e.material){var n=this.materialSelector.getMaterialNameByColor({opacity:e.material.opacity,color:e.material.color});r=this.materialSelector.get(n)}(i=new gA(e.flag,r)).ids=e.ids;break;case"TransparentIdsFA":(i=new AA(e.flag,e.isOpaque)).ids=e.ids;break;case"VisibleConditionFA":(i=new vA(e.flag,e.isVisible)).conditions=e.conditions;break;case"OverrideConditionFA":var r;if(r=e.material){n=this.materialSelector.getMaterialNameByColor({opacity:r.opacity,color:r.color});r=this.materialSelector.get(n)}(i=new CA(e.flag,r)).conditions=e.conditions;break;case"TransparentConditionFA":(i=new IA(e.flag,e.isOpaque)).conditions=e.conditions;break;case"IsolateConditionFA":(i=new xA(e.isolateHide)).conditions=e.conditions;break;default:Bu.warn("Warning: Not supported filterAction '"+t+"'")}return i},this.createActionByOldFilter=function(e,i){var n=[];switch(e){case"CONDITION_OVERRIDE":for(var r=[],o=0;i.length>o;o+=1){var a=i[o];r.push(a.condition)}var s=this.materialSelector.add(p=a.color),l=this.materialSelector.get(s);(g=new CA(!0,l)).conditions=r,n.push(g);break;case"CONDITION_TRANSLUCENT_OTHERS":(g=new IA(!1,!1)).conditions=i,n.push(g);break;case"ISOLATE_CONDITION_HIDEEN_OTHERS":(g=new xA(!0)).conditions=i,n.push(g);break;case"ISOLATE_CONDITION_TRANSLUCENT_OTHERS":(g=new xA(!1)).conditions=i,n.push(g);break;case"ISOLATE_HIDDEN_OTHERS":(g=new mA(!0)).ids=t(i),n.push(g);break;case"ISOLATE_TRANSLUCENT_OTHERS":(g=new mA(!1)).ids=t(i),n.push(g);break;case"OVERRIDEFILTER":for(var c in i)if(i.hasOwnProperty(c)){var h=[],d=i[c];for(var u in d)h.push(u);var p=this.materialSelector.getMaterialParamsFromName(d[u]);s=this.materialSelector.add(p),l=this.materialSelector.get(s);(g=new gA(!0,l)).ids=h,n.push(g)}break;case"TRANSLUCENT":(g=new AA(!0,!1)).ids=t(i),n.push(g);break;case"TRANSLUCTANT_OTHERS":(g=new AA(!1,!1)).ids=t(i),n.push(g);break;case"VISIBLE":var g;(g=new pA(!0,!0)).ids=t(i),n.push(g);break;default:Bu.warn("Warning: Not supported filter '"+e+"'")}return n},this.loadState=function(e,t){t.clearFilterActionList(),t.clearModelFilterActionList(),t.getObjectInfoManager().resetAll(),t.getModelInfoManager().resetAll();var i=JSON.parse(e);if(i.hasOwnProperty("version")&&"1.0"===i.version){var n=i.isolateAction;if(n){var r=this.createAction(n);t.pushBack(r)}for(var o=i.actions,a=0;o.length>a;a+=1){r=this.createAction(o[a]);t.pushBack(r)}var s=i.modelIsolateAction;if(s){r=this.createAction(s);t.pushModelBack(r)}for(var l=i.modelActions,c=0;l.length>c;c+=1){r=this.createAction(l[c]);t.pushModelBack(r)}}t.setSceneState(i.sceneState)}},KA=function(){var e={},t=[],i=!1,n=!1,r=!1,o=!1,a=!1,s=new He;this.init=function(e){},this.clearData=function(){},this.getObjectsMap=function(){},this.add=function(i){e[i]={state:Nd.Visible,modelKey:i,material:null},t=Object.keys(e)},this.remove=function(i){delete e[i],t=Object.keys(e)},this.calculateVisibleComponentsBbox=function(){},this.getVisibleComponentsBbox=function(){return s.isEmpty()&&this.calculateVisibleComponentsBbox(),s},this.arrayToMap=function(e){for(var t={},i=0;e.length>i;i+=1){var n=e[i];t[n]=n}return t},this.isMatchConditions=function(e,t){for(var i=!0,n=0,r=t.length;r>n;n+=1){var o=t[n];for(var a in o){if(!Array.isArray(o[a])&&e[a]!==o[a]){i=!1;break}if(Array.isArray(o[a])&&-1===o[a].indexOf(e[a])){i=!1;break}}if(!0===i)break;t.length-1>n&&(i=!0)}return i},this.matchConditions=function(e,t){},this.setVisible=function(i,r,o){var a=function(e){r?e.state=Nd.Visible:(n=!0,e.state&=~Nd.Visible)};if(void 0===o||!0===o)for(var s=0,l=i.length;l>s;s+=1)e.hasOwnProperty(i[s])&&a(e[i[s]]);else for(var c=this.arrayToMap(i),h=0,d=t.length;d>h;h+=1)c.hasOwnProperty(t[h])||a(e[t[h]])},this.isVisible=function(t){if(e.hasOwnProperty(t))return e[t].state&Nd.Visible>0},this.clearVisible=function(){for(var t in n=!1,e){if(e.hasOwnProperty(t))e[t].state=Nd.Visible}},this.hideAll=function(){for(var t in n=!0,e){if(e.hasOwnProperty(t))e[t].state&=~Nd.Visible}},this.setTransparent=function(n,r,a){var s=function(e){r?(e.state|=Nd.Transparent,i=!0,o=!0):e.state&=~Nd.Transparent};if(void 0===a||!0===a)for(var l=0,c=n.length;c>l;l+=1)e.hasOwnProperty(n[l])&&s(e[n[l]]);else for(var h=this.arrayToMap(n),d=0,u=t.length;u>d;d+=1)h.hasOwnProperty(t[d])||s(e[t[d]])},this.isTransparent=function(t){if(e.hasOwnProperty(t)){var i=e[t],n=(i.state&Nd.Transparent)>0;return n=n||(i.state&Nd.TransparentByIsolate)>0}},this.clearTransparent=function(){for(var t in o=!1,e){if(e.hasOwnProperty(t))e[t].state&=~Nd.Transparent}},this.setMaterial=function(n,r,o){if(void 0===o||!0===o)for(var a=0,s=n.length;s>a;a+=1){if(e.hasOwnProperty(n[a]))e[n[a]].material=r,i=!0}else for(var l=this.arrayToMap(n),c=0,h=t.length;h>c;c+=1){if(!l.hasOwnProperty(t[c]))e[t[c]].material=r,i=!0}},this.getMaterial=function(t){if(e.hasOwnProperty(t))return e[t].material},this.clearMaterial=function(){for(var t in e){e[t].material=null}},this.setIsolateHide=function(i,n,o){var a=function(e){n?(r=!0,e.state|=Nd.HideByIsolate):e.state&=~Nd.HideByIsolate};if(void 0===o||!0===o)for(var s=0,l=i.length;l>s;s+=1)e.hasOwnProperty(i[s])&&a(e[i[s]]);else for(var c=this.arrayToMap(i),h=0,d=t.length;d>h;h+=1)c.hasOwnProperty(t[h])||a(e[t[h]])},this.isIsolateHide=function(t){if(e.hasOwnProperty(t))return(e[t].state&Nd.HideByIsolate)>0},this.setIsolateTransparent=function(n,r,o){var s=function(e){r?(e.state|=Nd.TransparentByIsolate,i=!0,a=!0):e.state&=~Nd.TransparentByIsolate};if(void 0===o||!0===o)for(var l=0,c=n.length;c>l;l+=1)e.hasOwnProperty(n[l])&&s(e[n[l]]);else for(var h=this.arrayToMap(n),d=0,u=t.length;u>d;d+=1)h.hasOwnProperty(t[d])||s(e[t[d]])},this.isIsolateTransparent=function(t){if(e.hasOwnProperty(t))return(e[t].state&Nd.TransparentByIsolate)>0},this.clearIsolateHide=function(){r=!1;var t=Object.keys(e);t.length>0&&this.setIsolateHide(t,!1)},this.clearIsolates=function(){a=!1,r=!1;var t=Object.keys(e);t.length>0&&(this.setIsolateHide(t,!1),this.setIsolateTransparent(t,!1))},this.clearTransparentByIsolate=function(){for(var t in a=!1,e){if(e.hasOwnProperty(t))e[t].state&=~Nd.TransparentByIsolate}},this.isHidden=function(t){if(e.hasOwnProperty(t)){var i=e[t],n=0==(i.state&Nd.Visible);return n=n||(i.state&Nd.HideByIsolate)>0}},this.isFrozen=function(t){if(e.hasOwnProperty(t)){var i=e[t],n=(i.state&Nd.Transparent)>0;return n=n||(i.state&Nd.TransparentByIsolate)>0}},this.resetAll=function(){for(var t in e)e.hasOwnProperty(t)&&(e[t].state=Nd.Visible,e[t].material=null);i=!1,n=r=!1,o=a=!1},this.hasOverrideMaterial=function(t){return void 0===t?i:e.hasOwnProperty(t)?null!==e[t].material||this.isTransparent(t):void 0},this.hasObjectHidden=function(){return n||r},this.hasObjectCantSelected=function(){return n||o||a},this.hasObjectTransparent=function(){return o||a}},VA=new yt,YA=new At;new ct;var HA=new Ke,jA=new Ke,WA=new Ke,JA=new ke,zA=new ke,qA=new ke,ZA=new Ke,XA=new Ke,_A=new Ke,$A=new yt,ey=new Le,ty=new Le,iy=new Le(1,1,1,1);function ny(e,t,i,n,r,o,a,s){HA.fromBufferAttribute(n,o),jA.fromBufferAttribute(n,a),WA.fromBufferAttribute(n,s);var l=function(e,t,i,n,r,o,a){var s=e.material;if(null===(Array.isArray(s)?i.intersectTriangle(n,r,o,!1,a):1===s.side?i.intersectTriangle(o,r,n,!0,a):i.intersectTriangle(n,r,o,2!==s.side,a)))return null;_A.copy(a),_A.applyMatrix4($A);var l=t.ray.origin.distanceTo(_A);return t.near>l||l>t.far?null:{distance:l,point:_A.clone(),object:e}}(e,t,i,HA,jA,WA,XA);if(l){if(r&&r.array&&r.array.length&&(JA.fromBufferAttribute(r,o),zA.fromBufferAttribute(r,a),qA.fromBufferAttribute(r,s),l.uv=function(e,t,i,n,r,o,a){return ri.getBarycoord(e,t,i,n,ZA),r.multiplyScalar(ZA.x),o.multiplyScalar(ZA.y),a.multiplyScalar(ZA.z),r.add(o).add(a),r.clone()}(XA,HA,jA,WA,JA,zA,qA)),n.instanceMatrix){var c=HA.clone().applyMatrix4(n.instanceMatrix),h=jA.clone().applyMatrix4(n.instanceMatrix),d=WA.clone().applyMatrix4(n.instanceMatrix),u={a:o,b:a,c:s,normal:ri.getNormal(c,h,d,new Ke),materialIndex:0};l.face=u}else{var p={a:o,b:a,c:s,normal:ri.getNormal(HA,jA,WA,new Ke),materialIndex:0};l.face=p}l.faceIndex=o}return l}new Le(1,1,1,1);var ry=function(e){lu(i,e);var t=pu(i);function i(e,n,r,o){var a;if(ru(this,i),a=t.call(this,e,n,r),o){a.instanceMatrices=[],a.instanceColors=[],a.instanceShows=[],a.instanceDiffuses=[],a.multiCounts=[];for(var s=0;o.length>s;++s)a.instanceMatrices.push(new Ai(new Float32Array(16*o[s]),16)),a.instanceColors.push(new Ai(new Float32Array(4*o[s]),4)),a.instanceShows.push(new Ai(new Float32Array(new Array(4*o[s]).fill(1)),4)),a.instanceDiffuses.push(new Ai(new Float32Array(new Array(4*o[s]).fill(1)),4)),a.multiCounts.push(o[s])}return a}return au(i,[{key:"setInstanceMatrixAt",value:function(e,t,i){this.instanceMatrices&&this.instanceMatrices.length>e&&(i.toArray(this.instanceMatrices[e].array,16*t),this.instanceMatrices[e].needsUpdate=!0)}},{key:"getInstanceMatrixAt",value:function(e,t){return jg(t)||(t=new yt),t.fromArray(this.instanceMatrices[e].array),t}},{key:"setInstanceColorAt",value:function(e,t,i){this.instanceColors&&this.instanceColors.length>e&&(i.toArray(this.instanceColors[e].array,4*t),this.instanceColors[e].needsUpdate=!0)}},{key:"getInstanceColorAt",value:function(e){return ey.fromArray(this.instanceColors[e].array,0)}},{key:"setInstanceDiffuseAt",value:function(e,t,i){this.instanceDiffuses&&this.instanceDiffuses.length>e&&(i.toArray(this.instanceDiffuses[e].array,4*t),this.instanceDiffuses[e].needsUpdate=!0)}},{key:"getInstanceDiffuseAt",value:function(e){return ty.fromArray(this.instanceDiffuses[e].array,0)}},{key:"setInstanceShowAt",value:function(e){var t=arguments.length>1&&void 0!==arguments[1]&&arguments[1];this.instanceShows&&this.instanceShows.length>e&&(this.instanceShows[e].array[0]=Number(t),this.instanceShows[e].needsUpdate=!0)}},{key:"getInstanceShowAt",value:function(e){return Boolean(this.instanceShows[e].array[0])}},{key:"raycastByIndices",value:function(e,t,i,n){if(n){var r=this.geometry,o=this.material;if(($A=new yt).multiplyMatrices(this.matrixWorld,n),void 0===o)return;VA.copy($A).invert(),YA.copy(e.ray).applyMatrix4(VA);var a,s=null,l=r.attributes.position,c=r.attributes.uv,h=null,d=i.indexStart,u=i.indexStart+i.indexCount,p=r.getIndex().array;for(h=d,a=u;a>h;h+=3)(s=ny(this,e,YA,l,c,p[h],p[h+1],p[h+2]))&&(s.faceIndex=Math.floor(h/3),t.push(s))}}}]),i}(Ba);ry.prototype.isInstancedMeshEx=!0;var oy=function(){var e={},t={};this.init=function(i){for(var n in e=i)t.hasOwnProperty(n)&&!wp.isEmptyObject(t[n])||wp.isEmptyObject(e[n])||(t[n]=Object.keys(e[n]))},this.reinit=function(i){for(var n in t={},e=i)t[n]=Object.keys(i[n])},this.clear=function(){e={},t={}},this.getObjectsMap=function(){return e},this.getObjectIds=function(e){return t.hasOwnProperty(e)?t[e]:[]}},ay=new Le,sy=function(){var e=new oy,t=!1,i=!1,n=!1,r=!1,o=!1,a=!1,s=new He,l=!1;this.inactivatedIdMap={},this.inactivatedIds=[],this.bIsInactivateAll=!1,this.init=function(t){e.init(t)},this.reinit=function(t){e.reinit(t)},this.clearData=function(){e.clear()},this.getObjectsMap=function(){return e.getObjectsMap()},this.calculateVisibleComponentsBbox=function(){s.makeEmpty();var t=e.getObjectsMap();for(var i in t)for(var n=t[i],r=e.getObjectIds(i),o=null,a=0,c=r.length;c>a;a+=1){var h=r[a];if(!this.isHidden(h)){var d=n[h][0];if(d.boundingBox){!o&&d.model&&(o=d.model.getModelMatrix());var u=d.boundingBox.clone();o&&u.applyMatrix4(o),u.isEmpty()||(s.expandByPoint(u.min),s.expandByPoint(u.max))}}}l=!1},this.getVisibleComponentsBbox=function(){return(l||s.isEmpty())&&this.calculateVisibleComponentsBbox(),s},this.needUpdateBoxAfterExplode=function(){l=!0},this.arrayToMap=function(e){for(var t={},i=0;e.length>i;i+=1){var n=e[i];t[n]=n}return t},this.isMatchConditions=function(e,t){for(var i=!0,n=0,r=t.length;r>n;n+=1){var o=t[n];for(var a in o){if(!Array.isArray(o[a])&&e[a]!==o[a]){i=!1;break}if(Array.isArray(o[a])&&-1===o[a].indexOf(e[a])){i=!1;break}}if(!0===i)break;t.length-1>n&&(i=!0)}return i},this.matchConditions=function(t,i){var n=e.getObjectsMap();for(var r in n)for(var o=[],a=[],s=n[r],l=e.getObjectIds(r),c=0,h=l.length;h>c;c+=1){var d=l[c],u=s[d][0].userData||{};u.elementId=s[d][0].userId,this.isMatchConditions(u,t)?o.push(d):a.push(d)}i&&i(o,!0),i&&i(a,!1)},this.getMatchIds=function(t){var i=e.getObjectsMap(),n=[];for(var r in i)for(var o=i[r],a=e.getObjectIds(r),s=0,l=a.length;l>s;s+=1){var c=a[s],h=o[c][0].userData||{};h.elementId=o[c][0].userId,!0===this.isMatchConditions(h,t)&&n.push(c)}return n},this.setVisible=function(t,i,r){var o=function(e,t){if(i?e.state=Nd.Visible:(n=!0,e.state&=~Nd.Visible),e.isMixNode){var r,o=vu(t);try{for(o.s();!(r=o.n()).done;){var a=r.value;a.mesh.setInstanceShowAt(a.groupIndex,i)}}catch(e){o.e(e)}finally{o.f()}}},a=e.getObjectsMap();for(var s in a){var l=a[s];if(void 0===r||!0===r)for(var c=0,h=t.length;h>c;c+=1){if(l.hasOwnProperty(m=t[c])&&this.isActive(m)){var d=l[m][0];o(d,l[m])}}else{for(var u=this.arrayToMap(t),p=e.getObjectIds(s),g=0,f=p.length;f>g;g+=1){var m;!u.hasOwnProperty(m=p[g])&&this.isActive(m)&&o(d=l[m][0])}u=null}}},this.isVisible=function(t){var i=e.getObjectsMap();for(var n in i){var r=i[n];if(r.hasOwnProperty(t))return r[t][0].state&Nd.Visible>0}},this.getInvisibleComponentList=function(){var t=[],i=e.getObjectsMap();for(var n in i){var r=i[n];for(var o in r)r.hasOwnProperty(o)&&this.isHidden(o)&&!this.inactivatedIdMap[o]&&t.push(o)}return t},this.getInactivatedComponentList=function(){return[].concat(this.inactivatedIds)},this.clearVisible=function(){var t=e.getObjectsMap();for(var i in n=!1,this.inactivatedIds.length>0&&(n=!0),t)for(var r=t[i],o=e.getObjectIds(i),a=0,s=o.length;s>a;a+=1){var l=o[a],c=r[l][0];this.isActive(l)&&(c.state=Nd.Visible)}},this.hideAll=function(){var t=e.getObjectsMap();for(var i in n=!0,t)for(var r=t[i],o=e.getObjectIds(i),a=0,s=o.length;s>a;a+=1){r[o[a]][0].state&=~Nd.Visible}},this.setTransparent=function(i,n,r){var a=function(e){n?(e.state|=Nd.Transparent,t=!0,o=!0):e.state&=~Nd.Transparent},s=e.getObjectsMap();for(var l in s){var c=s[l];if(void 0===r||!0===r)for(var h=0,d=i.length;d>h;h+=1){if(this.isActive(A=i[h])&&c.hasOwnProperty(A)){var u=c[A][0];a(u)}}else{for(var p=this.arrayToMap(i),g=e.getObjectIds(l),f=0,m=g.length;m>f;f+=1){var A;this.isActive(A=g[f])&&!p.hasOwnProperty(A)&&a(u=c[A][0])}p=null}}},this.isTransparent=function(t){var i=e.getObjectsMap();for(var n in i){var r=i[n];if(r.hasOwnProperty(t)&&this.isActive(t)){var o=r[t][0],a=(o.state&Nd.Transparent)>0;return a=a||(o.state&Nd.TransparentByIsolate)>0}}},this.getTransparentComponentList=function(){var t=[],i=e.getObjectsMap();for(var n in i){var r=i[n];for(var o in r)if(r.hasOwnProperty(o)&&this.isActive(o)){var a=r[o][0],s=(a.state&Nd.Transparent)>0;(s=s||(a.state&Nd.TransparentByIsolate)>0)&&t.push(o)}}return t},this.clearTransparent=function(){var t=e.getObjectsMap();for(var i in o=!1,t)for(var n=t[i],r=e.getObjectIds(i),a=0,s=r.length;s>a;a+=1){var l=r[a];if(this.isActive(l))n[l][0].state&=~Nd.Transparent}},this.setMaterial=function(i,n,r){var o=e.getObjectsMap();for(var a in o){var s=o[a];if(void 0===r||!0===r)for(var l=0,c=i.length;c>l;l+=1){if(this.isActive(m=i[l])&&s.hasOwnProperty(m)){var h=s[m][0];if(h.material=n,t=!0,h.isMixNode){if(jg(n)){var d=n.color;ay.set(d.r,d.g,d.b,n.opacity)}else ay.copy(iy);h.mesh.setInstanceDiffuseAt(h.groupIndex,h.subInstanceIndex,ay)}}}else{for(var u=this.arrayToMap(i),p=e.getObjectIds(a),g=0,f=p.length;f>g;g+=1){var m;this.isActive(m=p[g])&&!u.hasOwnProperty(m)&&((h=s[m][0]).material=n,t=!0)}u=null}}},this.getMaterial=function(t){var i=e.getObjectsMap();for(var n in i){var r=i[n];if(r.hasOwnProperty(t))return r[t][0].material}},this.clearMaterial=function(){var t=e.getObjectsMap();for(var i in t){var n=t[i];for(var r in n)this.isActive(r)&&(n[r][0].material=null)}},this.setWireFrameMaterial=function(t,n,r){var o=e.getObjectsMap();for(var a in o){var s=o[a];if(void 0===r||!0===r)for(var l=0,c=t.length;c>l;l+=1){if(s.hasOwnProperty(f=t[l])){var h=s[f][0];h.wireFrameMaterial=n,i=!0}}else{for(var d=this.arrayToMap(t),u=e.getObjectIds(a),p=0,g=u.length;g>p;p+=1){var f;d.hasOwnProperty(f=u[p])||((h=s[f][0]).wireFrameMaterial=n,i=!0)}d=null}}},this.getWireFrameMaterial=function(t){var i=e.getObjectsMap();for(var n in i){var r=i[n];if(r.hasOwnProperty(t))return r[t][0].wireFrameMaterial}},this.clearWireFrameMaterial=function(){var t=e.getObjectsMap();for(var i in t){var n=t[i];for(var r in n)n[r][0].wireFrameMaterial=null}},this.clearMaterialByKey=function(t){var i=e.getObjectsMap();for(var n in i){var r=i[n];for(var o in r)-1!==t.indexOf(o)&&(r[o][0].material=null)}},this.setIsolateHide=function(t,i,n){var o=function(e,t){if(i?(r=!0,e.state|=Nd.HideByIsolate):e.state&=~Nd.HideByIsolate,e.isMixNode)for(var n=0,o=t.length;o>n;n++)t[n].mesh.setInstanceShowAt(t[n].groupIndex,!i)},a=e.getObjectsMap();for(var s in a){var l=a[s];if(void 0===n||!0===n)for(var c=0,h=t.length;h>c;c+=1){if(this.isActive(m=t[c])&&l.hasOwnProperty(m)){var d=l[m][0];o(d,l[m])}}else{for(var u=this.arrayToMap(t),p=e.getObjectIds(s),g=0,f=p.length;f>g;g+=1){var m;this.isActive(m=p[g])&&!u.hasOwnProperty(m)&&o(d=l[m][0],l[m])}u=null}}},this.isIsolateHide=function(t){var i=e.getObjectsMap();for(var n in i){var r=i[n];if(r.hasOwnProperty(t))return(r[t][0].state&Nd.HideByIsolate)>0}},this.setIsolateTransparent=function(i,n,r){var o=function(e){n?(e.state|=Nd.TransparentByIsolate,t=!0,a=!0):e.state&=~Nd.TransparentByIsolate},s=e.getObjectsMap();for(var l in s){var c=s[l];if(void 0===r||!0===r)for(var h=0,d=i.length;d>h;h+=1){if(c.hasOwnProperty(A=i[h])){var u=c[A][0];o(u)}}else{for(var p=this.arrayToMap(i),g=e.getObjectIds(l),f=0,m=g.length;m>f;f+=1){var A;!p.hasOwnProperty(A=g[f])&&this.isActive(A)&&o(u=c[A][0])}p=null}}},this.isIsolateTransparent=function(t){var i=e.getObjectsMap();for(var n in i){var r=i[n];if(r.hasOwnProperty(t)&&this.isActive(t))return(r[t][0].state&Nd.TransparentByIsolate)>0}},this.clearIsolateHide=function(){var t=e.getObjectsMap();for(var i in r=!1,t){var n=e.getObjectIds(i);n.length>0&&this.setIsolateHide(n,!1)}},this.clearIsolates=function(){var t=e.getObjectsMap();for(var i in a=!1,r=!1,t){var n=e.getObjectIds(i);n.length>0&&(this.setIsolateHide(n,!1),this.setIsolateTransparent(n,!1))}},this.clearTransparentByIsolate=function(){var t=e.getObjectsMap();for(var i in a=!1,t)for(var n=t[i],r=e.getObjectIds(i),o=0,s=r.length;s>o;o+=1){var l=r[o];if(this.isActive(l))n[l][0].state&=~Nd.TransparentByIsolate}},this.isHidden=function(t){var i=e.getObjectsMap();for(var n in i){var r=i[n];if(r.hasOwnProperty(t)){var o=r[t][0],a=0==(o.state&Nd.Visible);return a=a||(o.state&Nd.HideByIsolate)>0}}},this.isFrozen=function(t){var i=e.getObjectsMap();for(var n in i){var r=i[n];if(r.hasOwnProperty(t)){var o=r[t][0],a=(o.state&Nd.Transparent)>0;return a=a||(o.state&Nd.TransparentByIsolate)>0}}},this.resetAll=function(){var i=e.getObjectsMap();for(var s in i)for(var l=i[s],c=e.getObjectIds(s),h=0,d=c.length;d>h;h+=1){var u=c[h];l[u][0].state=Nd.Visible,this.isActive(u)&&(l[u][0].material=null)}t=!1,n=r=!1,o=a=!1,this.inactivatedIds.length>0&&(n=!0)},this.hasOverrideMaterial=function(i){var n=e.getObjectsMap();if(void 0===i)return t;for(var r in n){var o=n[r];if(o.hasOwnProperty(i))return null!==o[i][0].material||this.isTransparent(i)}},this.hasOverrideMaterialForWireFrame=function(t){var n=e.getObjectsMap();if(null==t)return i;for(var r in n){var o=n[r];if(o.hasOwnProperty(t))return null!==o[t][0].wireFrameMaterial}},this.hasObjectInactivated=function(){return this.inactivatedIds.length>0},this.hasObjectHidden=function(){return n||r},this.hasObjectCantSelected=function(){return this.hasObjectHidden()||this.hasObjectTransparent()||this.hasObjectInactivated()},this.hasObjectTransparent=function(){return o||a},this.deactivateByIds=function(t){var i=!0,r=!1,o=void 0,a=e.getObjectsMap();try{for(var s,l=t[Symbol.iterator]();!(i=(s=l.next()).done);i=!0){var c=s.value;for(var h in a){var d=a[h];if(d.hasOwnProperty(c)){var u=d[c][0];if(u.state&=~Nd.Visible,u.isMixNode)for(var p=d[c],g=0,f=p.length;f>g;g++)p[g].mesh.setInstanceShowAt(p[g].groupIndex,Boolean(u.state))}}this.inactivatedIdMap[c]=!0}}catch(e){r=!0,o=e}finally{try{!i&&l.return&&l.return()}finally{if(r)throw o}}n=!0,this.inactivatedIds=Object.keys(this.inactivatedIdMap)},this.activateByIds=function(t){for(var i=e.getObjectsMap(),r=0,o=t.length;o>r;r+=1){var a=t[r];for(var s in delete this.inactivatedIdMap[a],i){var l=i[s];if(l.hasOwnProperty(a)){var c=l[a][0];if(c.state=Nd.Visible,c.isMixNode)for(var h=l[a],d=0,u=h.length;u>d;d++)h[d].mesh.setInstanceShowAt(h[d].groupIndex,Boolean(c.state))}}}this.inactivatedIds=Object.keys(this.inactivatedIdMap),this.inactivatedIds.length>0&&(n=!0)},this.clearInactivatedIdMap=function(){this.inactivatedIdMap={},this.inactivatedIds=[]},this.isActive=function(e){return!1===this.bIsInactivateAll&&!(!0===this.inactivatedIdMap[e])},this.deactivateAll=function(){this.bIsInactivateAll=!0},this.activateAll=function(){this.bIsInactivateAll=!1},this.getInactivatedIdMap=function(){return this.inactivatedIdMap}},ly=function(e,t){yA.call(this),this.className="OverrideConditionForWireFrameFA",this.flag=e,this.material=t};(ly.prototype=Object.create(yA.prototype)).constructor=ly,ly.prototype.applyFilter=function(e,t){var i=this;this.conditions instanceof Array?e.matchConditions(this.conditions,(function(t,n){i.flag===n&&(e.setWireFrameMaterial(t,i.material),t=null)})):Bu.warn("Conditions should be type of array.")};var cy=function(e,t){uA.call(this),this.className="OverrideIdsForWireFrameFA",this.flag=e,this.material=t};(cy.prototype=Object.create(uA.prototype)).constructor=cy,cy.prototype.applyFilter=function(e){this.ids instanceof Array?e.setWireFrameMaterial(this.ids,this.material,this.flag):Bu.warn("Ids should be type of array.")};var hy=function(){this._filterImpl=new PA;var e=[],t=[],i=null,n=null,r=this._filterImpl.getMaterialSelector(),o=new sy,a=new KA,s=new GA(r),l=new hA;this.observerForSceneState=null,this.setObserverForSceneState=function(e){this.observerForSceneState=e},this.setSceneStateHelper=function(e){},this.getFilterActionList=function(){return e},this.getModelFilterActionList=function(){return t},this.addModel=function(e){a.add(e)},this.removeModel=function(e){a.remove(e)},this.clearFilterActionList=function(){e=[],i=null},this.clearModelFilterActionList=function(){t=[],n=null},this.initFilterManager=function(e){o.init(e)},this.reinitFilterManager=function(e){o.reinit(e)},this.clearFilterManager=function(){o.clearData()};var c=!1;this.isStateChanged=function(){return c},this.enableStateChanged=function(){c=!0},this.disableStateChanged=function(){c=!1},this.getIsolateFilterAction=function(){return i},this.getModelIsolateFilterAction=function(){return n},this.setIsolateAction=function(e){(i=e).apply()},this.getVisibleComponentsBbox=function(){return o.getVisibleComponentsBbox()},this.pushBack=function(t){var n=t.getClassName();"IsolateIdsFA"===n||"IsolateConditionFA"===n?i=t:e.push(t),c=!0,t.applyFilter(o)},this.pushModelBack=function(e){var i=e.getClassName();"IsolateIdsFA"===i||"IsolateConditionFA"===i?n=e:t.push(e),c=!0,e.applyFilter(a)};var h=function(t){for(var i=[],n=0;e.length>n;){var r=e[n];t===r.getClassName()?(i=i.concat(r.ids),e.splice(n,1)):n+=1}return i},d=function(e){for(var i=0;t.length>i;){e===t[i].getClassName()?t.splice(i,1):i+=1}};function u(e,t){var i=t||"";return e.map((function(e){var t=e.clone();for(var n in t.name+="_"+i,e)e.hasOwnProperty(n)&&(e[n]instanceof Fe||e[n]instanceof gn)&&(t[n]=e[n].clone(),t[n].needsUpdate=!0);return t}))}function p(e,t,i,n,r,o,a){var s=Boolean(a||0===a),l=[];s&&!Array.isArray(a)&&(a=[a]);var c,h=vu(r);try{for(h.s();!(c=h.n()).done;){var d=c.value;e._filterImpl.getMaterialByName(d.name)||e._filterImpl.addOverrideMaterial(d)}}catch(e){h.e(e)}finally{h.f()}var u=i[0],p=u.materialId;if(u.originMId===p&&(u.originMId=[].concat(p)),null===u.material)for(var g=0,f=p.length;f>g;g+=1)l[g]=t.models[u.model.modelKey].materialManager.getMaterialById(p[g]);else l=u.material;for(var m=null,A=null,y=0,v=l.length;v>y;y+=1){if(s){if(!a[y])break;m=a[y].compMatOrder,A=a[y].replMatOrder}else m=A=y;if(!r[A]||m>=r.length){r[A]?console.log('构件材质数组越界,越界位置:{"componentKey":'.concat(n,',"order":').concat(m,"}")):console.log('替换材质数组越界,越界位置:{"componentKey":'.concat(n,',"order":').concat(A,"}"));break}l[m]=r[A],p[m]=r[A].name}var C=new gA(!0,l);C.ids=[u.componentKey],o[u.componentKey]=l,e.pushBack(C)}function g(e,t,i,n,r,o,a){var s,l=[];(s=Boolean(a||0===a))&&!Array.isArray(a)&&(a=[a]);var c,h=vu(r);try{for(h.s();!(c=h.n()).done;){e._filterImpl.updateOverrideMaterial(c.value)}}catch(e){h.e(e)}finally{h.f()}for(var d=0,u=i.length;u>d;d+=1){var p=i[d],g=i[0].material;if(null===g)l[d]=t.models[p.model.modelKey].materialManager.getMaterialById(p.materialId),l[d].materialId=p.materialId;else if(Array.isArray(g)){l[d]=g[d]}else l[d]=g}for(var f=null,m=null,A=0,y=l.length;y>A;A+=1){if(s){if(!a[A])break;f=a[A].compMatOrder,m=a[A].replMatOrder}else f=m=A;if(!r[m]||f>=i.length){r[m]?console.log('构件材质数组越界,越界位置:{"componentKey":'.concat(n,',"order":').concat(f,"}")):console.log('替换材质数组越界,越界位置:{"componentKey":'.concat(n,',"order":').concat(m,"}"));break}var v=i[f].nodeId,C=l[f].mapNodeIdToOrigMatId&&l[f].mapNodeIdToOrigMatId[v]?l[f].mapNodeIdToOrigMatId[v]:l[f].materialId;i[f].mesh.geometry.getAttribute("uv")||null===r[m].map&&null===r[m].aoMap?(l[f]=r[m],l[f].mapNodeIdToOrigMatId||(l[f].mapNodeIdToOrigMatId={}),l[f].materialId=r[m].name,l[f].mapNodeIdToOrigMatId[v]=C):console.log('构件node缺少uv:{"componentKey":'.concat(n,',"order":').concat(m,",nodeId").concat(i[f].nodeId,"}"))}var I=new gA(!0,l);I.ids=[n],o&&(o[n]=l),e.pushBack(I)}function f(e,t,i){var n=e.models[t],r=n._handler.defaultManager.meshManager,o=n._handler.instancedManager.meshManager,a=n.loader.getDescriptor(),s=o.getNodeIdxMapByUserId(i),l=n.group.children.find((function(e){return"Geometry"===e.name}));l||((l=new To).name="Geometry",n.group.add(l));var c=new To,h=[];l.add(c);var d=a.mapNodeInfoByComponentKey[i],u=function(a){var l=s[a][0],u=o.getInstanceGeometries(a);u[0].attributes.vState.array[l]=-1,u[0].attributes.vState.needsUpdate=!0;var p=new Ni;u[0].removed||(u[0].removed={}),u[0].removed[l]=!0;for(var g=u[0].attributes.position.array,f=[],m=new Ke,A=o.matrixInfoMapFromUserId[i][a][0].matrix,y=0,v=g.length;v>y;y+=3)m.set(g[y],g[y+1],g[y+2]).applyMatrix4(A),f.push(m.x,m.y,m.z);u[0].attributes.uv&&p.setAttribute("uv",u[0].attributes.uv.clone()),u[0].attributes.uv2&&p.setAttribute("uv2",u[0].attributes.uv2.clone()),u[0].attributes.normal&&p.setAttribute("normal",u[0].attributes.normal.clone());var C=u[0].index.clone();p.setAttribute("position",new Ai(new Float32Array(f),3)),p.setIndex(C);var I,x=o.getMaterialIdByMeshId(a),w=o.manager.model.materialManager.getInstanceMaterialById(x)[0],M=cA.getMaterialParameters(w),E=cA.createStandardMaterial(M),B=new nn(p,E),S=a.split("&")[1],b=i+x+"_"+l+"_cm",k="",D=vu(d);try{for(D.s();!(I=D.n()).done;){var T=I.value;T.geometryId!==S&&T.geometryId.toString()!==S||(k=T.nodeId,T.instanceOrNot=!1,T.isBatched=!1,T.mesh=B,T.instancedRenderOrder=l,T.RenderTypeChange=!0,T.materialId=b,T.uv=!0,h.push(T))}}catch(e){D.e(e)}finally{D.f()}var R=b+"&1&meshes";c.add(B),B.geometry.computeBoundingBox(),B.modelKey=t;var U=su({},i,[{boundingBox:B.geometry.boundingBox,indexCount:C.count,indexStart:0,lightmapIdx:void 0,nodeId:k,positionCount:3*p.attributes.position.count,positionStart:0,userId:i}]);r.mapMaterialIdToMergedNode[R]=[{geometry:p,indices:U,mesh:B,RenderTypeChange:!0}],B._indicesGroup=U,B.computeBoundingBox=function(){var e=this.matrixWorld,t=new He;return t.copy(this.geometry.boundingBox),t.applyMatrix4(e),t},B.intersectBoxWithDistanceByIndices=function(e){return e.ray.intersectBoxWithDistance(this.computeBoundingBox())},B.raycastByIndices=function(e,t){B.raycast(e,t)},n.materialManager.materials[b]=E,e.addMeshToOctantMap(t,R,new Mm(R,B))};for(var p in s)u(p);return e.octantToObjectMap[t].info[i]=h,a.mapNodeInfoByCategory[1]||(a.mapNodeInfoByCategory[1]={}),a.mapNodeInfoByCategory[1][i]=h,delete a.instancedComponent[i],delete a.mapNodeInfoByCategory[0][i],delete o.nodeIdxMapFromUserId[i],r.getPickingNodeGenerator().clearData(),c}this.showAll=function(){this.opaqueAll(),h("VisibleIdsFA"),h("VisibleConditionFA"),o.clearVisible(),o.calculateVisibleComponentsBbox(),this.enableStateChanged()},this.showAllModel=function(){d("VisibleIdsFA"),a.clearVisible(),this.enableStateChanged()},this.hideAll=function(){var e=new pA(!1,!1);e.ids=[],this.pushBack(e)},this.hideAllModel=function(){var e=new pA(!1,!1);e.ids=[],this.pushModelBack(e)},this.getObjectInfoManager=function(){return o},this.getModelInfoManager=function(){return a},this.getMatchIds=function(e){return o.getMatchIds(e)},this._isVisible=function(e){return!o.isHidden(e.userId)},this._isModelVisible=function(e){return!a.isHidden(e)},this._isTransparent=function(e){return o.isTransparent(e.userId)},this.getTransparentComponentList=function(){return o.getTransparentComponentList()},this.getInvisibleComponentList=function(){return o.getInvisibleComponentList()},this.getInactivatedComponentList=function(){return o.getInactivatedComponentList()},this._isModelTransparent=function(e){return a.isTransparent(e)},this._isModelPickable=function(e){return!a.isFrozen(e)||xd.EnableSelectionByTranslucent},this._isSelectable=function(e){if(xd.EnableSelectionByTranslucent)return!0;var t=e.userId;return!o.isFrozen(t)&&this._filterImpl._isSelectableById(t)},this._isPickable=function(e){var t=e.userId;return this.isComponentActive(t)&&this._filterImpl._isSelectableById(t)&&(!o.isFrozen(t)||xd.EnableSelectionByTranslucent)},this._isSelectableById=function(e){return!!xd.EnableSelectionByTranslucent||!o.isFrozen(e)&&this._filterImpl._isSelectableById(e)},this._getOverrideMaterial=function(e){var t=e.userId;return o.isFrozen(t)?this._filterImpl.getFrozonMaterial():o.getMaterial(t)},this._getModelOverrideMaterial=function(e){return a.isFrozen(e)?this._filterImpl.getFrozonMaterial():a.getMaterial(e)},this._getMaterialName=function(e){return this._filterImpl._getMaterialName(e)},this._getMaterialByName=function(e){return this._filterImpl._getMaterialByName(e)},this._hasOverrideMaterial=function(e){return o.hasOverrideMaterial(e.userId)},this._hasModelOverrideMaterial=function(e){return a.hasOverrideMaterial(e)},this._hasHighPriorityOverrideMaterial=function(e){return this._filterImpl._hasHighPriorityOverrideMaterial(e)},this._isHiddenFileId=function(e){return this._filterImpl._isHiddenFileId(e)},this._isRenderPromotion=function(e){return this._filterImpl._isRenderPromotion(e)},this._isRenderWithBoardline=function(e){return this._filterImpl._isRenderWithBoardline(e)},this._hasHiddenFileIdFilter=function(){return this._filterImpl._hasHiddenFileIdFilter()},this._hasVisibleFilter=function(){return o.hasObjectHidden()},this._hasPickableFilter=function(){return o.hasObjectCantSelected()||this._filterImpl._hasPickableFilter()},this._hasTransparentFilter=function(){return o.hasObjectTransparent()},this._hasOverrideMaterialFilter=function(){return o.hasOverrideMaterial()},this._hasModelVisibleFilter=function(){return a.hasObjectHidden()},this._hasModelSelectableFilter=function(){return a.hasObjectCantSelected()},this._hasModelTransparentFilter=function(){return a.hasObjectTransparent()},this._hasModelOverrideMaterialFilter=function(){return a.hasOverrideMaterial()},this._hasLowPriorityOverride=function(){return this._filterImpl._hasLowPriorityOverride()},this._hasRenderPromotionFilter=function(){return this._filterImpl._hasRenderPromotionFilter()},this._hasRenderWithBoardlineFilter=function(){return this._filterImpl._hasRenderWithBoardlineFilter()},this.saveState=function(){return s.saveState(this)},this.loadState=function(e){s.loadState(e,this)},this.clear=function(){o.resetAll(),c=!0},this.clearAll=function(){return this.enableStateChanged(),this._filterImpl.clearAll()},this.clearIsolate=function(){o.clearIsolates()},this.clearFrozenList=function(){return this.enableStateChanged(),this._filterImpl.clearFrozenList()},this.addToFrozenList=function(e){return this.enableStateChanged(),this._filterImpl.addToFrozenList(e)},this.removeFromFrozenList=function(e){return this.enableStateChanged(),this._filterImpl.removeFromFrozenList(e)},this.setFrozenList=function(e){return this.enableStateChanged(),this._filterImpl.setFrozenList(e)},this.setFrozenConditions=function(e){this.enableStateChanged(),this._filterImpl.setFrozenConditions(e)},this.getFrozenConditions=function(){return this._filterImpl.getFrozenConditions()},this.clearFrozenConditions=function(){this.enableStateChanged(),this._filterImpl.clearFrozenConditions()},this.clearFrozen=function(){this.enableStateChanged(),this.clearFrozenList(),this.clearFrozenConditions()},this.clearAllIdList=function(){return this.enableStateChanged(),this._filterImpl.clearAllIdList()},this.clearIdList=function(e){return this.enableStateChanged(),this._filterImpl.clearIdList(e)},this.addToIdList=function(e,t){return this.enableStateChanged(),this._filterImpl.addToIdList(e,t)},this.removeFromIdList=function(e,t){return this.enableStateChanged(),this._filterImpl.removeFromIdList(e,t)},this.setIdList=function(e,t){return this.enableStateChanged(),this._filterImpl.setIdList(e,t)},this.clearAllOverrideList=function(){h("OverrideIdsFA"),h("OverrideConditionFA"),o.clearMaterial();for(var t=0,i=e.length;i>t;t+=1){var n=e[t];"WireframeIdsFA"===n.getClassName()&&n.applyFilter(o)}this.enableStateChanged()},this.clearModelAllOverrideList=function(){d("OverrideIdsFA"),a.clearMaterial(),this.enableStateChanged()},this.clearOverrideList=function(e){return this.enableStateChanged(),this._filterImpl.clearOverrideList(e)},this.addToOverrideList=function(e,t,i){return this.enableStateChanged(),this._filterImpl.addToOverrideList(e,t,i)},this.removeFromOverrideList=function(e,t){return this.enableStateChanged(),this._filterImpl.removeFromOverrideList(e,t)},this.setOverrideList=function(e,t,i){return this.enableStateChanged(),this._filterImpl.setOverrideList(e,t,i)},this.addToOverrideListByColor=function(e,t){var i=null;if(t){var n=this._filterImpl.getMaterialNameByColor(t);i=this._filterImpl.getMaterialByName(n)}var r=new gA(!0,i);r.ids=e,this.pushBack(r)},this.addToOverrideListByCustomerMaterial=function(e,t,i,n,r){var o=this,a={};Array.isArray(i)||(i=[i]);var s=i;return t.forEach((function(t){for(var l in t)n||(s=u(i,l)),t[l][0].isBatched||t[l][0].instanceOrNot||t[l][0].RenderTypeChange?!t[l][0].instanceOrNot&&t[l][0].isBatched||t[l][0].RenderTypeChange?g(o,e,t[l],l,s,a,r):t[l][0].instanceOrNot&&t[l][0].isBatched&&(f(e,t[l][0].model.modelKey,l),g(o,e,t[l],l,s,a,r)):p(o,e,t[l],l,s,a,r)})),a},this.addToModelOverrideListByColor=function(e,t){var i=null;if(t){var n=this._filterImpl.getMaterialNameByColor(t);i=this._filterImpl.getMaterialByName(n)}var r=new gA(!0,i);r.ids=e,this.pushModelBack(r)},this.addToOverrideListByConditions=function(e,t){var i=null;if(t){var n=this._filterImpl.getMaterialNameByColor(t);i=this._filterImpl.getMaterialByName(n)}var r=new CA(!0,i);r.conditions=e,this.pushBack(r)},this.addToOverrideListByConditions=function(e,t){var i=null;if(t){var n=this._filterImpl.getMaterialNameByColor(t);i=this._filterImpl.getMaterialByName(n)}var r=new CA(!0,i);r.conditions=e,this.pushBack(r)},this.addToOverrideListByMaterial=function(e,t){this._filterImpl.addOverrideMaterial(t);var i=new CA(!0,t);i.conditions=e,this.pushBack(i)},this.setOverrideListByColor=function(e,t,i){for(var n=0;t.length>n;n+=1){var r=this._filterImpl.getMaterialNameByColor(i),a=this._filterImpl.getMaterialByName(r);o.setMaterial(t[n],a)}},this.getVisibleComponentSet=function(e){for(var t={},i=Object.keys(e),n=0;i.length>n;n+=1)this._isVisible({userId:i[n]})&&(t[i[n]]=!0);return t},this.clearAllWireframeList=function(){o.clearMaterialByKey(h("WireframeIdsFA")),this.enableStateChanged()},this.addToWireframeByWireframe=function(e,t){var i=null;if(t){var n=this._filterImpl.getMaterialNameByWireframe(t);i=this._filterImpl.getMaterialByName(n)}var r=new fA(!0,i);r.ids=e,this.pushBack(r)},this.clearAllUserList=function(){return this.enableStateChanged(),this._filterImpl.clearAllUserList()},this.clearUserListByType=function(e){return this.enableStateChanged(),this._filterImpl.clearUserListByType(e)},this.clearUserList=function(e,t){return this.enableStateChanged(),this._filterImpl.clearUserList(e,t)},this.addToUserList=function(e,t,i,n){return this.enableStateChanged(),this._filterImpl.addToUserList(e,t,i,n)},this.removeFromUserList=function(e,t,i){this.enableStateChanged(),this._filterImpl.removeFromUserList(e,t,i)},this.setUserList=function(e,t,i,n){this.enableStateChanged(),this._filterImpl.setUserList(e,t,i,n)},this.isIsolate=function(){var e=o.getObjectsMap();for(var t in e){if(e.hasOwnProperty(t))var i=e[t];for(var n in i){var r=o.isIsolateHide(n);if(r|=o.isIsolateTransparent(n))return!0}}return!1},this.isFiltering=function(){var e=this.filterActionList.length>0;return this.isIsolate()||e},this.getFrozonMaterial=function(){return this._filterImpl.getFrozonMaterial()},this.setIsolateMaterial=function(e){this.enableStateChanged(),this._filterImpl.setIsolateMaterial(e)},this.getIsolateMaterial=function(){return this._filterImpl.getIsolateMaterial()},this.resetIsolateMaterial=function(){this.enableStateChanged(),this._filterImpl.resetIsolateMaterial()},this.clearAllIsolateList=function(){o.clearIsolates()},this.clearIsolation=function(){o.clearIsolates(),i=null,c=!0},this.clearModelIsolation=function(){a.clearIsolates(),n=null,c=!0},this.addToIsolateList=function(e,t){var i=new mA("HideOthers"===t);i.ids=e.concat(),this.pushBack(i),this.clearFilterActionList()},this.removeFromIsolateList=function(e){i&&Array.isArray(e)&&(e.forEach((function(e){i.ids.remove(e)})),1>i.ids.length?(o.clearIsolates(),i=null):i.applyFilter(o),this.enableStateChanged())},this.removeModelFromIsolateList=function(e){n&&Array.isArray(e)&&(e.forEach((function(e){n.ids.remove(e)})),1>n.ids.length?(a.clearIsolates(),n=null):n.applyFilter(a),this.enableStateChanged())},this.setIsolateList=function(e,t){var i=new mA(t);i.ids=e.concat(),this.pushBack(i)},this.setModelIsolateList=function(e,t){var i=new mA(t);i.ids=e.concat(),this.pushModelBack(i)},this.setIsolateConditions=function(e,t){var i=new xA(t===Pd.HIDDEN_OTHERS);i.conditions=e,this.pushBack(i),this.clearFilterActionList()},this.getIsolateConditions=function(e){return this._filterImpl.getIsolateConditions(e)},this.clearIsolateConditions=function(e){this.enableStateChanged(),this._filterImpl.clearIsolateConditions(e)},this.clearAllIsolateConditions=function(){this.enableStateChanged(),this._filterImpl.clearAllIsolateConditions()},this.setConditions=function(e,t){if(0===e){o.hideAll();var i=new vA(!0,!0);i.conditions=t,this.pushBack(i)}3===e&&this._filterImpl.setConditions(e,t)},this.getConditions=function(e){return this._filterImpl.getConditions(e)},this.clearConditions=function(e){this.enableStateChanged(),this._filterImpl.clearConditions(e)},this.clearAllConditions=function(){this.enableStateChanged(),this._filterImpl.clearAllConditions()},this.makeSceneTranslucent=function(){this.enableStateChanged(),this._filterImpl.makeSceneTranslucent()},this.cancelSceneTranslucent=function(){this.enableStateChanged(),this._filterImpl.cancelSceneTranslucent()},this.hideScene=function(){this.enableStateChanged(),this._filterImpl.hideScene()},this.showScene=function(){this.enableStateChanged(),this._filterImpl.showScene()},this.setSceneState=function(e){this.enableStateChanged(),this._filterImpl.setSceneState(e)},this.getSceneState=function(){return this._filterImpl.getSceneState()},this.cancelHidden=function(){this.enableStateChanged(),this._filterImpl.cancelHidden()},this.cancelTranslucent=function(){this.enableStateChanged(),this._filterImpl.cancelTranslucent()},this.hideByIds=function(e){var t=new pA(!0,!1);t.ids=e,this.pushBack(t)},this.hideModelByIds=function(e){var t=new pA(!0,!1);t.ids=e,this.pushModelBack(t)},this.hideByConditions=function(e){var t=new vA(!0,!1);t.conditions=e,this.pushBack(t)},this.hideOthersByConditions=function(e){var t=new vA(!1,!1);t.conditions=e,this.pushBack(t)},this.showByIds=function(e){var t=new pA(!0,!0);t.ids=e,this.pushBack(t)},this.showModelByIds=function(e){var t=new pA(!0,!0);t.ids=e,this.pushModelBack(t)},this.showByConditions=function(e){var t=new vA(!0,!0);t.conditions=e,this.pushBack(t)},this.makeTranslucentByIds=function(e){var t=new AA(!0,!1);t.ids=e,this.pushBack(t)},this.makeModelTranslucentByIds=function(e){var t=new AA(!0,!1);t.ids=e,this.pushModelBack(t)},this.makeTranslucentByConditions=function(e){var t=new IA(!0,!1);t.conditions=e,this.pushBack(t)},this.opaqueByIds=function(e){var t=new AA(!0,!0);t.ids=e,this.pushBack(t)},this.opaqueModelByIds=function(e){var t=new AA(!0,!0);t.ids=e,this.pushModelBack(t)},this.opaqueByConditions=function(e){var t=new IA(!0,!0);t.conditions=e,this.pushBack(t)},this.setFrozonMaterial=function(e){this._filterImpl.setFrozonMaterial(e)},this.makeTranslucentOthersByIds=function(e){var t=new AA(!1,!1);t.ids=e,this.pushBack(t)},this.makeTranslucentOthersModelByIds=function(e){var t=new AA(!1,!1);t.ids=e,this.pushModelBack(t)},this.opaqueAll=function(){h("TransparentIdsFA"),h("TransparentConditionFA"),o.clearTransparent(),this.enableStateChanged()},this.opaqueAllModel=function(){d("TransparentIdsFA"),d("TransparentConditionFA"),a.clearTransparent(),this.enableStateChanged()},this.deactivateByIds=function(e){o.deactivateByIds(e),this.observerForSceneState&&this.observerForSceneState(e),this.enableStateChanged()},this.activateByIds=function(e){o.activateByIds(e),this.enableStateChanged()},this.clearInactivatedIdMap=function(){o.clearInactivatedIdMap()},this.getInactivatedIdMap=function(){return o.getInactivatedIdMap()},this.deactivateAll=function(){o.deactivateAll()},this.activateAll=function(){o.activateAll()},this.isComponentActive=function(e){return o.isActive(e)},this.getFilterType=function(){return this._filterImpl._getFilterType()},this._hasOverrideMaterialForWireFrame=function(e){return o.hasOverrideMaterialForWireFrame(e.name)},this._hasOverrideMaterialFilterForWireFrame=function(){return o.hasOverrideMaterialForWireFrame()},this._getOverrideMaterialForWireFrame=function(e){return o.getWireFrameMaterial(e.name)},this._getOverrideWireFrameMaterial=function(e){return o.getWireFrameMaterial(e.name)},this.addToOverrideListForWireFrameByColor=function(e,t){var i=null;if(t){var n=this._filterImpl.getMaterialNameByColor(t);i=this._filterImpl.getMaterialByName(n)}var r=new cy(!0,i);r.ids=e,this.pushBack(r)},this.addToOverrideListForWireFrameByConditions=function(e,t){var i=null;if(t){var n=this._filterImpl.getMaterialNameByColor(t);i=this._filterImpl.getMaterialByName(n)}var r=new ly(!0,i);r.conditions=e,this.pushBack(r)},this._getFilterObjectsKeys=function(e){return this._filterImpl._getFilterObjectsKeys(e)},this.transparentComponentsByKey=function(e,t,i){},this.closeOrigMatModelTransparent=function(e,t){var i=e.models[t].materialManager.materials;for(var n in i){var r=i[n];void 0!==r._origTransparent&&(r.transparent=r._origTransparent,r.needsUpdate=!0),void 0!==r._origOpacity&&(r.opacity=r._origOpacity,r.needsUpdate=!0)}var o=e.models[t].materialManager.instanceMaterials;for(var a in o)o[a].forEach((function(e){void 0!==e._origTransparent&&(e.transparent=e._origTransparent,e.needsUpdate=!0),void 0!==e._origOpacity&&(e.opacity=e._origOpacity,e.needsUpdate=!0)}))},this.transparentModelOrigMatByKey=function(e,t){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:.5,n=e.models[t].materialManager.materials;for(var r in n){var o=n[r];void 0===o._origTransparent&&(o._origTransparent=o.transparent),void 0===o._origOpacity&&(o._origOpacity=o.opacity),o.transparent=!0,o.opacity=i,o.needsUpdate=!0}var a=e.models[t].materialManager.instanceMaterials;for(var s in a)a[s].forEach((function(e){void 0===e._origTransparent&&(e._origTransparent=e.transparent),void 0===e._origOpacity&&(e._origOpacity=e.opacity),e.transparent=!0,e.opacity=i,e.needsUpdate=!0}))},this.setComponentBlinkByComponentKeys=function(e,t,i,n,r){l.setComponentBlinkByComponentKeys(e,t,i,n,r)},this.closeComponentBlinkByComponentKeys=function(e){l.closeComponentBlinkByComponentKeys(e)},this.clearBlinkList=function(){l.clearBlinkList()}};var dy=function(e){lu(i,e);var t=pu(i);function i(e){var n;return ru(this,i),(n=t.call(this)).type="InstancedDepthMaterial",n.uniforms=Mn.depth.uniforms,n.vertexShader=function(e){return e.replace("#include <project_vertex>","\n vec4 mvPosition = modelViewMatrix * vec4(getInstancePosition(transformed), 1.0);\n gl_Position = projectionMatrix * mvPosition;\n ")}(function(e){return e.replace("void main() {","\n attribute float vState; \n attribute vec4 aColor; \n attribute vec3 mcol0;\n attribute vec3 mcol1;\n attribute vec3 mcol2;\n attribute vec3 mcol3;\n #if defined(USE_MAP)\n attribute vec2 muvCol0;\n attribute vec2 muvCol1;\n attribute vec2 muvCol2;\n #endif\n \n varying float vfState;\n \n vec3 getInstancePosition(vec3 position) {\n return vec3(mat4(vec4(mcol0, 0.0),\n vec4(mcol1, 0.0),\n vec4(mcol2, 0.0),\n vec4(mcol3, 1.0)) * vec4(position, 1.0));\n }\n \n void main() {\n vfState = vState;\n ")}(Mn.depth.vertexShader)),n.fragmentShader=function(e){return e.replace("void main() {","\n varying float vfState; \n void main() {\n if (vfState <= -0.99 && vfState >= -1.01) discard;\n \n ")}(Mn.depth.fragmentShader),void 0!==e&&n.setValues(e),n}return i}(Mo);function uy(e,t){var i=e||0,n=t||0;return i===n?0:i>n?1:-1}function py(e,t){var i=e.split(".").map((function(e){return Number(e)||0})),n=t.split(".").map((function(e){return Number(e)||0}));return 0===(uy(i[0],n[0])||uy(i[1],n[1])||uy(i[2],n[2]))}function gy(e,t){var i=e.split(".").map((function(e){return Number(e)||0})),n=t.split(".").map((function(e){return Number(e)||0}));return(uy(i[0],n[0])||uy(i[1],n[1])||uy(i[2],n[2]))>=0}function fy(e,t){var i=e.split(".").map((function(e){return Number(e)||0})),n=t.split(".").map((function(e){return Number(e)||0}));return(uy(i[0],n[0])||uy(i[1],n[1])||uy(i[2],n[2]))>0}function my(e,t){return!gy(e,t)}function Ay(e,t){return!fy(e,t)}dy.prototype.constructor=dy;var yy={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={}}},vy=function e(t,i,n){ru(this,e);var r=this,o=!1,a=0,s=0,l=void 0,c=[];this.onStart=void 0,this.onLoad=t,this.onProgress=i,this.onError=n,this.itemStart=function(e){s+=1,!1===o&&void 0!==r.onStart&&r.onStart(e,a,s),o=!0},this.itemEnd=function(e){a+=1,void 0!==r.onProgress&&r.onProgress(e,a,s),a===s&&(o=!1,void 0!==r.onLoad&&r.onLoad())},this.itemError=function(e){void 0!==r.onError&&r.onError(e)},this.resolveURL=function(e){return l?l(e):e},this.setURLModifier=function(e){return l=e,this},this.addHandler=function(e,t){return c.push(e,t),this},this.removeHandler=function(e){var t=c.indexOf(e);return-1!==t&&c.splice(t,2),this},this.getHandler=function(e){for(var t=0,i=c.length;i>t;t+=2){var n=c[t],r=c[t+1];if(n.global&&(n.lastIndex=0),n.test(e))return r}return null}},Cy=new vy,Iy={},xy=function(e){lu(i,e);var t=pu(i);function i(e){var n;return ru(this,i),(n=t.call(this,e)).model=e.model,n.cacheViable=!0,n.modelKey=e.model.modelKey,n}return au(i,[{key:"load",value:function(e,t,i,n){void 0===e&&(e=""),void 0!==this.path&&(e=this.path+e),e=this.manager.resolveURL(e);var r=this,o=yy.get(e);if(void 0!==o)return r.manager.itemStart(e),setTimeout((function(){t&&t(o),r.manager.itemEnd(e)}),0),o;if(void 0===Iy[e]){var a=e.match(/^data:(.*?)(;base64)?,(.*)$/),s=null;if(a){var l=a[1],c=Boolean(a[2]),h=a[3];h=decodeURIComponent(h),c&&(h=atob(h));try{var d,u=(this.responseType||"").toLowerCase();switch(u){case"arraybuffer":case"blob":for(var p=new Uint8Array(h.length),g=0;h.length>g;g++)p[g]=h.charCodeAt(g);d="blob"===u?new Blob([p.buffer],{type:l}):p.buffer;break;case"document":var f=new DOMParser;d=f.parseFromString(h,l);break;case"json":d=JSON.parse(h);break;default:d=h}setTimeout((function(){t&&t(d),r.manager.itemEnd(e)}),0)}catch(t){setTimeout((function(){n&&n(t),r.manager.itemError(e),r.manager.itemEnd(e)}),0)}}else{for(var m in Iy[e]=[],Iy[e].push({onLoad:t,onProgress:i,onError:n}),(s=new XMLHttpRequest).open("GET",e,!0),s.addEventListener("load",(function(t){var i=this.response,n=Iy[e];if(delete Iy[e],200===this.status||0===this.status){0===this.status&&console.warn("THREE.FileLoader: HTTP Status 0 received."),yy.add(e,i);var o=r.model.getStorage();if(null==i){for(var a=0,s=n.length;s>a;a++){var l=n[a];l.onError&&l.onError(t)}return r.manager.itemEnd(e),r.manager.itemError(e),void Bu.error(e,"response 为 null")}if(!(i instanceof ArrayBuffer||i instanceof Array||i instanceof Blob||i instanceof Object))try{JSON.parse(i),function(e){throw new TypeError('"'+e+'" is read-only')}("response")}catch(e){}if(i instanceof Blob&&og.isIOSDevice()){var c=new FileReader;c.readAsDataURL(i),c.onloadend=function(t){o&&r.cacheViable&&o.put(e,t.target.result,r.modelKey,(function(){r.manager.progress.loaded+=1}),(function(){Bu.warn(e,"缓存失败"),r.manager.progress.failed+=1}));for(var a=0,s=n.length;s>a;a++){var l=n[a];l.onLoad&&l.onLoad(i)}}}else{if(o&&r.cacheViable)if(i.byteLength&&i.byteLength>12e7){for(var h=[],d=4e7,u=Math.floor(i.byteLength/d),p=0;u>=p;p+=1){r.manager.progress.total+=1;var g=null;g=p===u?i.slice(p*d):i.slice(p*d,(p+1)*d);var f=e+"_"+p;h.push(f),o.put(f,g,r.modelKey,(function(){r.manager.progress.loaded+=1}),(function(){r.manager.progress.failed+=1}))}o.put(e,{split:!0,list:h,length:i.byteLength},r.modelKey,(function(){}),(function(){Bu.warn(e,"缓存失败")}))}else o.put(e,i,r.modelKey,(function(){r.manager.progress&&(r.manager.progress.loaded+=1)}),(function(){r.manager.progress&&(Bu.warn(e,"缓存失败"),r.manager.progress.failed+=1)}));for(var m=0,A=n.length;A>m;m++){var y=n[m];y.onLoad&&y.onLoad(i)}}r.manager.itemEnd(e)}else{for(var v=0,C=n.length;C>v;v++){var I=n[v];I.onError&&I.onError(t)}r.manager.itemError(e),r.manager.itemEnd(e)}}),!1),s.addEventListener("progress",(function(t){for(var i=Iy[e],n=0,r=i.length;r>n;n++){var o=i[n];o.onProgress&&o.onProgress(t)}}),!1),s.addEventListener("error",(function(t){var i=Iy[e];delete Iy[e];for(var n=0,o=i.length;o>n;n++){var a=i[n];a.onError&&a.onError(t)}r.manager.itemError(e),r.manager.itemEnd(e)}),!1),s.addEventListener("abort",(function(t){var i=Iy[e];delete Iy[e];for(var n=0,o=i.length;o>n;n++){var a=i[n];a.onError&&a.onError(t)}r.manager.itemError(e),r.manager.itemEnd(e)}),!1),void 0!==this.responseType&&(s.responseType=this.responseType),void 0!==this.withCredentials&&(s.withCredentials=this.withCredentials),s.overrideMimeType&&s.overrideMimeType(void 0!==this.mimeType?this.mimeType:"text/plain"),this.requestHeader)s.setRequestHeader(m,this.requestHeader[m]);s.send(null)}return r.manager.itemStart(e),s}Iy[e].push({onLoad:t,onProgress:i,onError:n})}},{key:"setResponseType",value:function(e){return this.responseType=e,this}},{key:"setMimeType",value:function(e){return this.mimeType=e,this}},{key:"setCacheViable",value:function(e){return this.cacheViable=e,this}}]),i}(function(){function e(t){ru(this,e),this.manager=void 0!==t?t:Cy,this.crossOrigin="anonymous",this.withCredentials=!1,this.path="",this.resourcePath="",this.requestHeader={}}return au(e,[{key:"load",value:function(){}},{key:"loadAsync",value:function(e,t){var i=this;return new Promise((function(n,r){i.load(e,n,t,r)}))}},{key:"parse",value:function(){}},{key:"setCrossOrigin",value:function(e){return this.crossOrigin=e,this}},{key:"setWithCredentials",value:function(e){return this.withCredentials=e,this}},{key:"setPath",value:function(e){return this.path=e,this}},{key:"setResourcePath",value:function(e){return this.resourcePath=e,this}},{key:"setRequestHeader",value:function(e){return this.requestHeader=e,this}}]),e}()),wy=function(e){this.compArr=[],this.compArr=e,Bu.debug(this.compArr)};wy.prototype={constructor:wy,getComponent:function(e){}};var My,Ey,By,Sy,by={EmptyGeometry:new Ni,UnitCylinderInstance:new Za(1,1,1,8,1,!1),UnitBoxInstance:new on(1,1,1),UnitTextureCylinder:null,UnitTextureBox:null,initializeUnitInstances:function(){by.UnitCylinderInstance.boundingBox||by.UnitCylinderInstance.computeBoundingBox(),by.UnitBoxInstance.boundingBox||by.UnitBoxInstance.computeBoundingBox()},destroyUnitInstances:function(){by.UnitCylinderInstance.dispose(),by.UnitBoxInstance.dispose()},getBoxData:function(e){for(var t=[[],[],[],[],[],[]],i=0;4>i;i+=1)t[0].push(-1,0,0);for(i=0;4>i;i+=1)t[1].push(0,-1,0);for(i=0;4>i;i+=1)t[2].push(0,0,-1);for(i=0;4>i;i+=1)t[3].push(0,0,1);for(i=0;4>i;i+=1)t[4].push(0,1,0);for(i=0;4>i;i+=1)t[5].push(1,0,0);var n=[[],[],[],[],[],[]];return n[0]=n[2]=n[4]=[-.5,-.5,-.5,.5,.5,-.5,.5,.5],n[1]=n[3]=n[5]=[-.5,-.5,-.5,.5,.5,-.5,.5,.5],{vertex:[[-.5,-.5,-.5,-.5,-.5,.5,-.5,.5,-.5,-.5,.5,.5],[-.5,-.5,-.5,-.5,-.5,.5,.5,-.5,-.5,.5,-.5,.5],[-.5,-.5,-.5,-.5,.5,-.5,.5,-.5,-.5,.5,.5,-.5],[-.5,-.5,.5,-.5,.5,.5,.5,-.5,.5,.5,.5,.5],[-.5,.5,-.5,-.5,.5,.5,.5,.5,-.5,.5,.5,.5],[.5,-.5,-.5,.5,-.5,.5,.5,.5,-.5,.5,.5,.5]][e],normal:t[e],uv:n[e],index:[[0,1,2,3,2,1],[2,1,0,1,2,3],[0,1,2,3,2,1],[2,1,0,1,2,3],[0,1,2,3,2,1],[2,1,0,1,2,3]][e]}},getPipeData2:(My=[.5,0,.5,.353530875,.353530875,.5,0,.5,.5,-.353530875,.353530875,.5,-.5,0,.5,-.353530875,-.353530875,.5,0,-.5,.5,.353530875,-.353530875,.5,.5,0,.5,.5,0,-.5,.353530875,.353530875,-.5,0,.5,-.5,-.353530875,.353530875,-.5,-.5,0,-.5,-.353530875,-.353530875,-.5,0,-.5,-.5,.353530875,-.353530875,-.5,.5,0,-.5,.5,0,.5,.353530875,.353530875,.5,0,.5,.5,-.353530875,.353530875,.5,-.5,0,.5,-.353530875,-.353530875,.5,0,-.5,.5,.353530875,-.353530875,.5,.5,0,-.5,.353530875,.353530875,-.5,0,.5,-.5,-.353530875,.353530875,-.5,-.5,0,-.5,-.353530875,-.353530875,-.5,0,-.5,-.5,.353530875,-.353530875,-.5],Ey=[0,9,1,1,9,10,1,10,2,2,10,11,2,11,3,3,11,12,3,12,4,4,12,13,4,13,5,5,13,14,5,14,6,6,14,15,6,15,7,7,15,16,7,16,8,8,16,17,18,19,20,18,20,21,18,21,22,18,22,23,18,23,24,18,24,25,26,28,27,26,29,28,26,30,29,26,31,30,26,32,31,26,33,32],By=[1,0,0,.7,.7,0,0,1,0,-.7,.7,0,-1,0,0,-.7,-.7,0,0,-1,0,.7,-.7,0,1,0,0,1,0,0,.7,.7,0,0,1,0,-.7,.7,0,-1,0,0,-.7,-.7,0,0,-1,0,.7,-.7,0,1,0,0,0,0,-1,0,0,-1,0,0,-1,0,0,-1,0,0,-1,0,0,-1,0,0,-1,0,0,-1,0,0,1,0,0,1,0,0,1,0,0,1,0,0,1,0,0,1,0,0,1,0,0,1],Sy=[-.5,.5,-.375,.5,-.25,.5,-.125,.5,0,.5,.125,.5,.25,.5,.375,.5,.5,.5,-.5,-.5,-.375,-.5,-.25,-.5,-.125,-.5,0,-.5,.125,-.5,.25,-.5,.375,-.5,.5,-.5,.5,0,.353530875,.353530875,0,.5,-.353530875,.353530875,-.5,0,-.353530875,-.353530875,0,-.5,.353530875,-.353530875,.5,0,.353530875,.353530875,0,.5,-.353530875,.353530875,-.5,0,-.353530875,-.353530875,0,-.5,.353530875,-.353530875],function(){return{vertex:My,normal:By,uv:Sy,index:Ey}}),getPipeData:function(e){(void 0===e||8>e)&&(e=8),e>256&&(e=256);var t=.5,i=4*e+2,n=3*(4*e-4),r=e+1,o=1/e,a=6.28318530714/e,s=null,l=null,c=[];for(s=0;e>s;s+=1)c.push(t*Math.cos(s*a)),c.push(t*Math.sin(s*a));c.push(t),c.push(0);var h=[];for(l=2*r,s=0;l>s;s+=2)h.push(c[s]),h.push(c[s+1]),h.push(t);for(s=0;l>s;s+=2)h.push(c[s]),h.push(c[s+1]),h.push(-.5);for(l=2*e,s=0;l>s;s+=2)h.push(c[s]),h.push(c[s+1]),h.push(t);for(s=l;s>0;s-=2)h.push(c[s]),h.push(c[s+1]),h.push(-.5);var d=[],u=e+1;for(s=0;e>s;s+=1)d.push(s),d.push(s+u),d.push(s+1),d.push(s+1),d.push(s+u),d.push(s+u+1);var p=2*r;for(s=1;e-1>s;s+=1)d.push(p),d.push(p+s),d.push(p+s+1);for(p+=e,s=1;e-1>s;s+=1)d.push(p),d.push(p+s),d.push(p+s+1);var g=[];for(s=e;s>=0;s-=1)g.push(s*o-t),g.push(-.5);for(s=e;s>=0;s-=1)g.push(s*o-t),g.push(t);for(l=2*e,s=0;l>s;s+=2)g.push(c[s]),g.push(c[s+1]);for(s=l;s>0;s-=2)g.push(c[s]),g.push(c[s+1]);l=3*i;var f=[];for(s=0;l>s;s+=1)f.push(0);var m=null,A=null,y=null,v=new Ke,C=new Ke,I=new Ke,x=new Ke,w=new Ke;for(s=0;n>s;s+=3)A=3*d[s+1],y=3*d[s+2],v.fromArray(h,m=3*d[s]),C.fromArray(h,A),I.fromArray(h,y),x.subVectors(I,C),w.subVectors(v,C),x.cross(w),f[m]+=x.x,f[m+1]+=x.y,f[m+2]+=x.z,f[A]+=x.x,f[A+1]+=x.y,f[A+2]+=x.z,f[y]+=x.x,f[y+1]+=x.y,f[y+2]+=x.z;var M=new Ke;for(l=3*i,s=0;l>s;s+=3)M.fromArray(f,s),M.normalize(),f[s]=M.x,f[s+1]=M.y,f[s+2]=M.z;return{vertex:h,normal:f,uv:g,index:d,edges:e}},getInstancePipeData:function(e,t){var i=this.getPipeData(e);(void 0===e||8>e)&&(e=8),e>256&&(e=256);var n=2*(e+1),r=n+e,o=4*e+2,a=[[],[],[]];a[0]=i.vertex.slice(0,3*n),a[1]=i.vertex.slice(3*n,3*r),a[2]=i.vertex.slice(3*r,3*o);var s=[[],[],[]],l=e+1,c=0;for(c=0;e>c;c+=1)s[0].push(c),s[0].push(c+l),s[0].push(c+1),s[0].push(c+1),s[0].push(c+l),s[0].push(c+l+1);for(c=1;e-1>c;c+=1)s[1].push(0),s[1].push(c),s[1].push(c+1);for(c=1;e-1>c;c+=1)s[2].push(0),s[2].push(c),s[2].push(c+1);var h=[[],[],[]];h[0]=i.uv.slice(0,2*n),h[1]=i.uv.slice(2*n,2*r),h[2]=i.uv.slice(2*r,2*o);var d=[[],[],[]];return d[0]=i.normal.slice(0,3*n),d[1]=i.normal.slice(3*n,3*r),d[2]=i.normal.slice(3*r,3*o),{vertex:a[t],normal:d[t],uv:h[t],index:s[t]}},getUnitTextureCylinder:function(){if(null===by.UnitTextureCylinder){by.UnitTextureCylinder=new Array(3);for(var e=0;3>e;e+=1){var t=by.getInstancePipeData(32,e);by.UnitTextureCylinder[e]=new Ni,by.UnitTextureCylinder[e].setIndex(t.index),by.UnitTextureCylinder[e].setAttribute("position",new Bi(t.vertex,3)),by.UnitTextureCylinder[e].setAttribute("normal",new Bi(t.normal,3)),by.UnitTextureCylinder[e].setAttribute("uv",new Bi(t.uv,2))}}return by.UnitTextureCylinder},getUnitTextureBox:function(){if(null===by.UnitTextureBox){by.UnitTextureBox=new Array(6);for(var e=0;6>e;e+=1){var t=by.getBoxData(e);by.UnitTextureBox[e]=new Ni,by.UnitTextureBox[e].setIndex(t.index),by.UnitTextureBox[e].setAttribute("position",new Bi(t.vertex,3)),by.UnitTextureBox[e].setAttribute("normal",new Bi(t.normal,3)),by.UnitTextureBox[e].setAttribute("uv",new Bi(t.uv,2))}}return by.UnitTextureBox},getBoxBufferGeometryWithUvMatrices:function(e){for(var t=[],i=null,n=new De,r=new Ke,o=!!e,a=0;6>a;a+=1){i=new Ni;var s=by.getBoxData(a);if(o){var l=[];n.set(e[6*a],e[6*a+2],e[6*a+4],e[6*a+1],e[6*a+3],e[6*a+5],0,0,1);for(var c=0,h=s.uv.length;h>c;c+=2)r.set(s.uv[c],s.uv[c+1],1),r.applyMatrix3(n),l.push(r.x),l.push(r.y);i.setAttribute("uv",new Bi(l,2))}i.setIndex(new Ai(Uint32Array.from(s.index),1)),i.setAttribute("position",new Bi(s.vertex,3)),i.setAttribute("normal",new Bi(s.normal,3)),t.push(i)}return by.mergeBufferGeometries2(t)},getPipeBufferGeometryWithUvMatrices:function(e){var t=by.getPipeData(32),i=t.edges,n=!(!e||18!==e.length),r=new Ni;if(n){for(var o=[],a=0,s=e.length;s>a;a+=6){var l=new De;l.set(e[6*a],e[6*a+2],e[6*a+4],e[6*a+1],e[6*a+3],e[6*a+5],0,0,1),o.push(l)}for(var c=[],h=new Ke,d=4*(i+1),u=d+2*i,p=0,g=t.uv.length;g>p;p+=2)h.set(t.uv[p],t.uv[p+1],1),h.applyMatrix3(d>p?o[0]:u>p?o[1]:o[2]),c.push(h.x),c.push(h.y);r.setAttribute("uv",new Bi(c,2))}return r.setIndex(new Mi(t.index,1)),r.setAttribute("position",new Bi(t.vertex,3)),r.setAttribute("normal",new Bi(t.normal,3)),r},getGeometryFromBox3:function(e){var t=new Ni,i=[],n=[],r=e.min,o=e.max,a=r.x,s=r.y,l=r.z,c=o.x,h=o.y,d=o.z;return i.push(a,s,l),i.push(c,s,l),i.push(a,s,d),i.push(c,s,d),i.push(a,h,l),i.push(c,h,l),i.push(a,h,d),i.push(c,h,d),n.push(0,1,3),n.push(0,3,2),n.push(1,5,7),n.push(1,7,3),n.push(5,4,6),n.push(5,6,7),n.push(4,2,6),n.push(4,0,2),n.push(0,4,5),n.push(0,5,1),n.push(2,3,7),n.push(2,7,6),t.setIndex(new Ai(new Uint32Array(n),1)),t.setAttribute("position",new Ai(new Float32Array(i),3)),t},getWorldMatrixOfMesh:function(e){for(var t=[],i=e.parent;i;)t.push(i.matrix),i=i.parent;var n=new yt;if(t.length>0){n=t[t.length-1];for(var r=t.length-2;r>=0;r-=1)n.multiply(t[r])}var o=new yt;return o.multiplyMatrices(n,e.matrix),o},getWorldPositionOfMesh:function(e,t){t||(t=new yt);var i=new yt;i.copy(t).invert();var n=e.clone();return n.applyMatrix4(i),n},getBoundingBoxWorldOfMesh:function(e,t){var i=e.boundingBox;i||(e.geometry.boundingBox||e.geometry.computeBoundingBox(),i=e.geometry.boundingBox);var n=i.clone();n.applyMatrix4(e.matrixWorld);var r=new yt;return r.copy(t).invert(),n.applyMatrix4(r),n},getBoundingBoxByBuffer:function(e){for(var t=1/0,i=1/0,n=1/0,r=-1/0,o=-1/0,a=-1/0,s=new Nu,l=0,c=e.length;c>l;l+=3){var h=e[l],d=e[l+1],u=e[l+2];t>h&&(t=h),i>d&&(i=d),n>u&&(n=u),h>r&&(r=h),d>o&&(o=d),u>a&&(a=u)}return s.min.set(t,i,n),s.max.set(r,o,a),s},mergeBufferGeometriesFromMeshs:function(e,t){for(var i=null!==e[0].geometry.index,n=new Set(Object.keys(e[0].geometry.attributes)),r=new Set(Object.keys(e[0].geometry.morphAttributes)),o={},a={},s=new Ni,l=0;e.length>l;l+=1){var c=e[l].geometry;if(i!==(null!==c.index))return null;for(var h in c.attributes){if(!n.has(h))return console.log("attributes not Used: ",h),null;void 0===o[h]&&(o[h]=[]),o[h].push(c.attributes[h])}for(var h in c.morphAttributes){if(!r.has(h))return null;void 0===a[h]&&(a[h]=[]),a[h].push(c.morphAttributes[h])}null!=c.userData&&(s.userData=s.userData||{},s.userData.mergedUserData=s.userData.mergedUserData||[],s.userData.mergedUserData.push(c.userData))}if(i){var d=0,u=[],p=0,g=0;for(l=0;e.length>l;l+=1){var f=e[l].geometry.index;if(d>0){f=f.clone();for(var m=0;f.count>m;m+=1)f.setX(m,f.getX(m)+d)}u.push(f),d+=e[l].geometry.attributes.position.count,void 0===t[e[l].userId]&&(t[e[l].userId]=[]),t[e[l].userId].push({nodeId:e[l].nodeId,indexStart:p,indexCount:f.count,positionStart:g,positionCount:e[l].geometry.attributes.position.count}),g+=e[l].geometry.attributes.position.count,p+=f.count}var A=this.mergeBufferAttributes(u);if(!A)return null;s.index=A}for(var h in o){var y=this.mergeBufferAttributes(o[h]);if(!y)return null;s.setAttribute(h,y)}for(var h in a){var v=a[h][0].length;if(0===v)break;s.morphAttributes=s.morphAttributes||{},s.morphAttributes[h]=[];for(l=0;v>l;l+=1){var C=[];for(m=0;a[h].length>m;m+=1)C.push(a[h][m][l]);var I=this.mergeBufferAttributes(C);if(!I)return null;s.morphAttributes[h].push(I)}}return s},mergeBufferGeometries:function(e,t){for(var i=null!==e[0].index,n=new Set(Object.keys(e[0].attributes)),r={},o=new Ni,a=0;e.length>a;a+=1){var s=e[a];if(i!==(null!==s.index))return null;for(var l in s.attributes){if(!n.has(l))return null;void 0===r[l]&&(r[l]=[]),r[l].push(s.attributes[l])}}if(i){var c=0,h=[];for(a=0;e.length>a;a+=1){var d=e[a].index;if(c>0){d=d.clone();for(var u=0;d.count>u;u+=1)d.setX(u,d.getX(u)+c)}h.push(d),c+=e[a].attributes.position.count}var p=this.mergeBufferAttributes(h);if(!p)return null;o.index=p}for(var l in r){var g=this.mergeBufferAttributes(r[l],t);if(!g)return null;o.setAttribute(l,g)}return o},reducedGeometry:function(e,t){for(var i={},n=0,r=t.length;r>n;n+=1){var o=t[n];i[o]||(i[o]=[]),i[o].push(n)}var a=0,s=new Float32Array(3*Object.keys(i).length);for(var l in i){for(var c=i[l],h=0,d=c.length;d>h;h+=1)t[c[h]]=a,s[3*a]=e[3*l],s[3*a+1]=e[3*l+1],s[3*a+2]=e[3*l+2];a+=1}return{buffer:s,index:t}},mergeBufferAttributes:function(e,t){for(var i=null,n=null,r=null,o=0,a=0;e.length>a;a+=1){var s=e[a];if(s.isInterleavedBufferAttribute)return null;if(null===i&&(i=s.array.constructor),i!==s.array.constructor)return null;if(null===n&&(n=s.itemSize),n!==s.itemSize)return null;if(null===r&&(r=s.normalized),r!==s.normalized)return null;o+=s.array.length}for(var l=new i(o),c=0,h=!1,d=0;e.length>d;d+=1){if(t&&!t[d].equals(Ed)&&("position"===e[d].name||"normal"===e[d].name)){if("position"===e[d].name&&t[d].applyToBufferAttribute(e[d]),"normal"===e[d].name)(new De).getNormalMatrix(t[d]).applyToBufferAttribute(e[d]);h=!0}if(l.set(e[d].array,c),c+=e[d].array.length,h){var u=(new yt).copy(t[d]).invert();if("position"===e[d].name&&u.applyToBufferAttribute(e[d]),"normal"===e[d].name)(new De).getNormalMatrix(u).applyToBufferAttribute(e[d]);h=!1}}return new Ai(l,n,r)},applyMatrix3ToBuffer:function(){var e=new Ke;return function(t,i,n,r){if(t.equals(Bd))return i;for(var o=n||0,a=r||i.length;a>o;o+=3)e.x=i[o+0],e.y=i[o+1],e.z=i[o+2],e.applyMatrix3(t),i[o+0]=e.x,i[o+1]=e.y,i[o+2]=e.z;return i}}(),applyMatrix4ToBuffer:function(){var e=new Ke;return function(t,i,n,r){if(t.equals(Ed))return i;for(var o=n||0,a=r||i.length;a>o;o+=3)e.x=i[o+0],e.y=i[o+1],e.z=i[o+2],e.applyMatrix4(t),i[o+0]=e.x,i[o+1]=e.y,i[o+2]=e.z;return i}}(),normalizeBuffer:function(e){for(var t=null,i=null,n=null,r=null,o=0,a=e.length;a>o;o+=3)t=e[o],i=e[o+1],n=e[o+2],r=1/Math.sqrt(t*t+i*i+n*n),e[o]=t*r,e[o+1]=i*r,e[o+2]=n*r},disposeBufferFromGeometry:function(e,t){for(var i=0,n=t.length;n>i;i+=1){var r=e.getAttribute(t[i]);r&&(r.array=null)}},disposeIndexBufferFromGeometry:function(e){e.index&&(e.index.array=null)},copyMeshProperties:function(e,t){e.name=t.name,e.up.copy(t.up),e.position.copy(t.position),e.quaternion.copy(t.quaternion),e.scale.copy(t.scale),e.matrix.copy(t.matrix),e.matrixWorld.copy(t.matrixWorld),e.matrixAutoUpdate=t.matrixAutoUpdate,e.matrixWorldNeedsUpdate=t.matrixWorldNeedsUpdate},createBufferGeometryWithPosAndSkin:function(e){var t=new Ni;if(e.isBufferGeometry||e._bufferGeometry){var i=e.isBufferGeometry?e:e._bufferGeometry;t.setAttribute("position",i.getAttribute("position"),3),i.getAttribute("skinIndex")&&t.setAttribute("skinIndex",i.getAttribute("skinIndex"),4),i.getAttribute("skinWeight")&&t.setAttribute("skinWeight",i.getAttribute("skinWeight"),4);var n=i.getIndex();n&&t.setIndex(n)}else if(e.isGeometry){var r=new Bi(3*e.vertices.length,3);if(t.setAttribute("position",r.copyVector3sArray(e.vertices),3),e.skinIndices.length>0){var o=new Bi(4*e.skinIndices.length,4);t.setAttribute("skinIndex",o.copyVector4sArray(e.skinIndices),4)}if(e.skinWeights.length>0){var a=new Bi(4*e.skinWeights.length,4);this.setAttribute("skinWeight",a.copyVector4sArray(e.skinWeights),4)}if(e.faces.length){for(var s=e.faces,l=[],c=0;s.length>c;c+=1){var h=s[c];l.push(h.a,h.b,h.c)}var d=new(wp.arrayMax(l)>65535?Uint32Array:Uint16Array)(3*l.length);t.setIndex(new Ai(d,1).copyIndicesArray(l))}}return t},calculateVolumeOfGeometry:function(e,t,i,n){if(e&&t){var r=0,o=new Ke,a=new Ke,s=new Ke;i||(i=0),n||(n=t.length);for(var l=0,c=0,h=0,d=i,u=i+n;u>d;d+=3){c=t[d+1],h=t[d+2],o.set(e[3*(l=t[d])],e[3*l+1],e[3*l+2]),a.set(e[3*c],e[3*c+1],e[3*c+2]),s.set(e[3*h],e[3*h+1],e[3*h+2]),r+=o.clone().cross(a).dot(s)/6}return r}},minDistanceBetweenTriToMesh:function(e,t,i,n){function r(e,t){return new Ke(e.x-t.x,e.y-t.y,e.z-t.z)}function o(e,t){return new Ke(e.x+t.x,e.y+t.y,e.z+t.z)}function a(e,t,i){return new Ke(e.x+t.x*i,e.y+t.y*i,e.z+t.z*i)}function s(e,t){return e.x*t.x+e.y*t.y+e.z*t.z}function l(e,t){return new Ke(e.y*t.z-e.z*t.y,e.z*t.x-e.x*t.z,e.x*t.y-e.y*t.x)}function c(e,t,i,n){var c,h=s(t,n),d=s(t,t),u=s(n,n),p=r(i,e),g=s(t,p),f=s(n,p),m=null;0>(m=(g*u-f*h)/(d*u-h*h))||isNaN(m)?m=0:m>1&&(m=1);var A=null,y=null,v=null,C=null;return 0>=(c=(m*h-f)/u)||isNaN(c)?(y=i,0>=(m=g/d)||isNaN(m)?(A=e,v=r(i,e)):1>m?(A=a(e,t,m),C=l(p,t),v=l(t,C)):v=r(i,A=o(e,t))):1>c?(y=a(i,n,c),0>=m||isNaN(m)?(A=e,C=l(p,n),v=l(n,C)):1>m?(A=a(e,t,m),0>s(v=l(t,n),p)&&v.multiplyScalar(-1)):(C=l(p=r(i,A=o(e,t)),n),v=l(n,C))):(y=o(i,n),0>=(m=(h+g)/d)||isNaN(m)?(A=e,v=r(y,e)):1>m?(A=a(e,t,m),C=l(p=r(y,e),t),v=l(t,C)):v=r(y,A=o(e,t))),{vec:v,closestP:A,closestQ:y}}function h(e,t){var i=null,n=null,o=[],h=[],d=null;o[0]=r(e[1],e[0]),o[1]=r(e[2],e[1]),o[2]=r(e[0],e[2]),h[0]=r(t[1],t[0]),h[1]=r(t[2],t[1]),h[2]=r(t[0],t[2]);for(var u=null,p=null,g=null,f=0,m=e[0].distanceToSquared(t[0])+1,A=0;3>A;A+=1)for(var y=0;3>y;y+=1){var v=c(e[A],o[A],t[y],h[y]);d=v.vec;var C=s(u=r(n=v.closestQ,i=v.closestP),u);if(m>=C){p=i.clone(),g=n.clone(),m=C;var I=s(r(e[(A+2)%3],i),d),x=s(r(t[(y+2)%3],n),d);if(0>=I&&x>=0)return{start:i.clone(),end:n.clone(),minDistance:Math.sqrt(C)};0>I&&(I=0),x>0&&(x=0),s(u,d)-I+x>0&&(f=1)}}var w=l(o[0],o[1]),M=s(w,w);if(M>1e-15){var E=[];u=r(e[0],t[0]),E[0]=s(u,w),u=r(e[0],t[1]),E[1]=s(u,w),u=r(e[0],t[2]),E[2]=s(u,w);var B=-1;if(E[0]>0&&E[1]>0&&E[2]>0?E[B=E[1]>E[0]?0:1]>E[2]&&(B=2):0>E[0]&&0>E[1]&&0>E[2]&&E[2]>E[B=E[0]>E[1]?0:1]&&(B=2),B>=0&&(f=1,s(u=r(t[B],e[0]),l(w,o[0]))>0&&s(u=r(t[B],e[1]),l(w,o[1]))>0&&s(u=r(t[B],e[2]),l(w,o[2]))>0))return i=a(t[B],w,E[B]/M),n=t[B].clone(),{start:i.clone(),end:n,minDistance:i.distanceTo(n)}}var S=l(h[0],h[1]),b=s(S,S);if(b>1e-15){var k=[];u=r(t[0],e[0]),k[0]=s(u,S),u=r(t[0],e[1]),k[1]=s(u,S),u=r(t[0],e[2]),k[2]=s(u,S);B=-1;if(k[0]>0&&k[1]>0&&k[2]>0?k[B=k[1]>k[0]?0:1]>k[2]&&(B=2):0>k[0]&&0>k[1]&&0>k[2]&&k[2]>k[B=k[0]>k[1]?0:1]&&(B=2),B>=0&&(f=1,s(u=r(e[B],t[0]),l(S,h[0]))>0&&s(u=r(e[B],t[1]),l(S,h[1]))>0&&s(u=r(e[B],t[2]),l(S,h[2]))>0))return{start:i=e[B].clone(),end:(n=a(e[B],S,k[B]/b)).clone(),minDistance:i.distanceTo(n)}}return f?(i=p,n=g,{start:p.clone(),end:g.clone(),minDistance:Math.sqrt(m)}):{start:p.clone(),end:g.clone(),minDistance:0}}var d=new Ke,u=new Ke,p=new Ke;function g(e,t,i,n,r,o){d.fromBufferAttribute(t,i),u.fromBufferAttribute(t,n),p.fromBufferAttribute(t,r),o&&(d.applyMatrix4(o),u.applyMatrix4(o),p.applyMatrix4(o)),e.push(d),e.push(u),e.push(p)}for(var f={start:null,end:null,minDistance:Number.POSITIVE_INFINITY},m=t.geometry,A=m.attributes.position,y=i?i.indexStart:0,v=m.getIndex().array,C=y,I=i?i.indexStart+i.indexCount:v.length;I>C;C+=3){var x=[];g(x,A,v[C],v[C+1],v[C+2],n);var w=h(e,x);if(0>=w.minDistance)return f.minDistance=0,f.start=w.start.clone(),f.end=w.end.clone(),f;f.minDistance>w.minDistance&&(f.minDistance=w.minDistance,f.start=w.start.clone(),f.end=w.end.clone())}return f},minDistanceBetweenTriToTri:function(e,t){function i(e,t){return new Ke(e.x-t.x,e.y-t.y,e.z-t.z)}function n(e,t){return new Ke(e.x+t.x,e.y+t.y,e.z+t.z)}function r(e,t,i){return new Ke(e.x+t.x*i,e.y+t.y*i,e.z+t.z*i)}function o(e,t){return e.x*t.x+e.y*t.y+e.z*t.z}function a(e,t){return new Ke(e.y*t.z-e.z*t.y,e.z*t.x-e.x*t.z,e.x*t.y-e.y*t.x)}function s(e,t,s,l){var c,h=o(t,l),d=o(t,t),u=o(l,l),p=i(s,e),g=o(t,p),f=o(l,p),m=null;0>(m=(g*u-f*h)/(d*u-h*h))||isNaN(m)?m=0:m>1&&(m=1);var A=null,y=null,v=null,C=null;return 0>=(c=(m*h-f)/u)||isNaN(c)?(y=s,0>=(m=g/d)||isNaN(m)?(A=e,v=i(s,e)):1>m?(A=r(e,t,m),C=a(p,t),v=a(t,C)):v=i(s,A=n(e,t))):1>c?(y=r(s,l,c),0>=m||isNaN(m)?(A=e,C=a(p,l),v=a(l,C)):1>m?(A=r(e,t,m),0>o(v=a(t,l),p)&&v.multiplyScalar(-1)):(C=a(p=i(s,A=n(e,t)),l),v=a(l,C))):(y=n(s,l),0>=(m=(h+g)/d)||isNaN(m)?(A=e,v=i(y,e)):1>m?(A=r(e,t,m),C=a(p=i(y,e),t),v=a(t,C)):v=i(y,A=n(e,t))),{vec:v,closestP:A,closestQ:y}}function l(e,t){var n=null,l=null,c=[],h=[],d=null;c[0]=i(e[1],e[0]),c[1]=i(e[2],e[1]),c[2]=i(e[0],e[2]),h[0]=i(t[1],t[0]),h[1]=i(t[2],t[1]),h[2]=i(t[0],t[2]);for(var u=null,p=null,g=null,f=0,m=e[0].distanceToSquared(t[0])+1,A=0;3>A;A+=1)for(var y=0;3>y;y+=1){var v=s(e[A],c[A],t[y],h[y]);d=v.vec;var C=o(u=i(l=v.closestQ,n=v.closestP),u);if(m>=C){p=n.clone(),g=l.clone(),m=C;var I=o(i(e[(A+2)%3],n),d),x=o(i(t[(y+2)%3],l),d);if(0>=I&&x>=0)return{start:n.clone(),end:l.clone(),minDistance:Math.sqrt(C)};0>I&&(I=0),x>0&&(x=0),o(u,d)-I+x>0&&(f=1)}}var w=a(c[0],c[1]),M=o(w,w);if(M>1e-15){var E=[];u=i(e[0],t[0]),E[0]=o(u,w),u=i(e[0],t[1]),E[1]=o(u,w),u=i(e[0],t[2]),E[2]=o(u,w);var B=-1;if(E[0]>0&&E[1]>0&&E[2]>0?E[B=E[1]>E[0]?0:1]>E[2]&&(B=2):0>E[0]&&0>E[1]&&0>E[2]&&E[2]>E[B=E[0]>E[1]?0:1]&&(B=2),B>=0&&(f=1,o(u=i(t[B],e[0]),a(w,c[0]))>0&&o(u=i(t[B],e[1]),a(w,c[1]))>0&&o(u=i(t[B],e[2]),a(w,c[2]))>0))return n=r(t[B],w,E[B]/M),l=t[B].clone(),{start:n.clone(),end:l,minDistance:n.distanceTo(l)}}var S=a(h[0],h[1]),b=o(S,S);if(b>1e-15){var k=[];u=i(t[0],e[0]),k[0]=o(u,S),u=i(t[0],e[1]),k[1]=o(u,S),u=i(t[0],e[2]),k[2]=o(u,S);B=-1;if(k[0]>0&&k[1]>0&&k[2]>0?k[B=k[1]>k[0]?0:1]>k[2]&&(B=2):0>k[0]&&0>k[1]&&0>k[2]&&k[2]>k[B=k[0]>k[1]?0:1]&&(B=2),B>=0&&(f=1,o(u=i(e[B],t[0]),a(S,h[0]))>0&&o(u=i(e[B],t[1]),a(S,h[1]))>0&&o(u=i(e[B],t[2]),a(S,h[2]))>0))return{start:n=e[B].clone(),end:(l=r(e[B],S,k[B]/b)).clone(),minDistance:n.distanceTo(l)}}return f?(n=p,l=g,{start:p.clone(),end:g.clone(),minDistance:Math.sqrt(m)}):{start:p.clone(),end:g.clone(),minDistance:0}}new Ke,new Ke,new Ke;for(var c={start:null,end:null,minDistance:Number.POSITIVE_INFINITY},h=0,d=e.length;d>h;h+=1)for(var u=0,p=t.length;p>u;u+=1){var g=l(e[h],t[u]);if(0>=g.minDistance)return c.minDistance=0,c.start=g.start.clone(),c.end=g.end.clone(),c;c.minDistance>g.minDistance&&(c.minDistance=g.minDistance,c.start=g.start.clone(),c.end=g.end.clone())}return c},calculateTheIntersectionOfGeometryAndPlane:function(e,t){var i=e.getIndex().array,n=e.attributes.position,r=i.length,o=t.clone(),a=0;function s(e,t,i,n,r,o,a,s){o.fromBufferAttribute(t,i),a.fromBufferAttribute(t,n),s.fromBufferAttribute(t,r),e.push(o),e.push(a),e.push(s)}-1===o.normal.x?a=0:1===o.normal.x?(o.normal.x=-1,o.constant*=-1,a=1):-1===o.normal.y?a=2:1===o.normal.y?(o.normal.y=-1,o.constant*=-1,a=3):-1===o.normal.z?a=4:1===o.normal.z&&(o.normal.z=-1,o.constant*=-1,a=5);for(var l=[],c=new xh,h=0,d=r;d>h;h+=3){var u=[];s(u,n,i[h],i[h+1],i[h+2],new Ke,new Ke,new Ke);var p=u[0],g=u[1],f=u[2],m=!1,A=!1,y=!1;switch(a){case 0:case 1:m=o.constant>p.x,A=o.constant>g.x,y=o.constant>f.x;break;case 2:case 3:m=o.constant>p.y,A=o.constant>g.y,y=o.constant>f.y;break;case 4:case 5:m=o.constant>p.z,A=o.constant>g.z,y=o.constant>f.z}var v=null,C=null;m?A?y||(c.set(f,g),(v=o.intersectLine(c,new Ke))&&l.push(v),c.set(f,p),(C=o.intersectLine(c,new Ke))&&l.push(C)):y?(c.set(g,f),(v=o.intersectLine(c,new Ke))&&l.push(v),c.set(g,p),(C=o.intersectLine(c,new Ke))&&l.push(C)):(c.set(g,p),(v=o.intersectLine(c,new Ke))&&l.push(v),c.set(f,p),(C=o.intersectLine(c,new Ke))&&l.push(C)):A?y?(c.set(p,g),(v=o.intersectLine(c,new Ke))&&l.push(v),c.set(p,f),(C=o.intersectLine(c,new Ke))&&l.push(C)):(c.set(p,g),(v=o.intersectLine(c,new Ke))&&l.push(v),c.set(f,g),(C=o.intersectLine(c,new Ke))&&l.push(C)):y&&(c.set(p,f),(v=o.intersectLine(c,new Ke))&&l.push(v),c.set(g,f),(C=o.intersectLine(c,new Ke))&&l.push(C))}if(l.length>=1){for(var I={},x=[],w=[],M=0,E=l.length;E>M;M+=1){var B=l[M].toArray(x).toString();I[B]||(I[B]=[]),2>I[B].length||(B=B+"_"+Math.floor(I[B].length/2+.6),I[B]||(I[B]=[])),I[B].push(M),w.push(B)}var S=[],b=w[0];return S.push(l[0],l[1]),function e(t,i){var n=I[w[t]],r=n[0]===t?n[1]:n[0],o=r%2?r-1:r+1;if(i.push(l[o]),w[o]!==b){if(isNaN(o))return void(S=null);e(o,i)}}(1,S),S}},getShapeGeometryFromGeometryAndPlane:function(e,t){var i=by.calculateTheIntersectionOfGeometryAndPlane(e,t);if(i){var n=0;-1===t.normal.x?n=0:1===t.normal.x?n=1:-1===t.normal.y?n=2:1===t.normal.y?n=3:-1===t.normal.z?n=4:1===t.normal.z&&(n=5);var r=[],o=[],a=[],s=[],l=[];e.boundingBox||e.computeBoundingBox();for(var c=e.boundingBox.getSize(new Ke),h=t.normal.x*c.x*1e-4,d=t.normal.y*c.y*1e-4,u=t.normal.z*c.z*1e-4,p=0,g=i.length;g>p;p+=1){var f=i[p],m=new ke;switch(o.push(f.x+h,f.y+d,f.z+u),n){case 0:case 1:a.push(1,0,0),s.push(f.y,f.z),m.set(f.y,f.z);break;case 2:case 3:a.push(0,1,0),s.push(f.x,f.z),m.set(f.x,f.z);break;case 4:case 5:a.push(0,0,1),s.push(f.x,f.y),m.set(f.x,f.y)}l.push(m)}for(var A=Ds.triangulateShape(l,[]),y=0,v=A.length;v>y;y+=1){var C=A[y];r.push(C[0],C[1],C[2])}var I=new Ni;return I.setIndex(r),I.setAttribute("position",new Bi(o,3)),I.setAttribute("normal",new Bi(a,3)),I.setAttribute("uv",new Bi(s,2)),I}}};by.getBoxMBuffer=function(){for(var e=null,t=null,i=[],n=[],r=[],o=0,a=0;6>a;a+=1){var s=by.getBoxData(a);for(e=0,t=s.vertex.length;t>e;e+=1)i.push(s.vertex[e]);for(e=0,t=s.index.length;t>e;e+=1)r.push(s.index[e]+o);for(o+=s.vertex.length/3,e=0,t=s.normal.length;t>e;e+=1)n.push(s.normal[e])}return function(e){var t=null;if(e){var o=new De,a=new Ke;t=[];for(var s=0;6>s;s+=1){var l=by.getBoxData(s);o.set(e[6*s],e[6*s+2],e[6*s+4],e[6*s+1],e[6*s+3],e[6*s+5],0,0,1);for(var c=0,h=l.uv.length;h>c;c+=2)a.set(l.uv[c],l.uv[c+1],1),a.applyMatrix3(o),t.push(a.x),t.push(a.y)}}return{vertex:i,normal:n,uv:t,index:r}}}(),by.getPipeMBuffer=function(){var e=by.getPipeData(32),t=e.edges,i=e.vertex,n=e.normal,r=e.index;return function(e){var o=null;if(!(!e||18!==e.length)){o=[];for(var a=[],s=0,l=e.length/6;l>s;s+=1){var c=new De;c.set(e[6*s],e[6*s+2],e[6*s+4],e[6*s+1],e[6*s+3],e[6*s+5],0,0,1),a.push(c)}for(var h=by.getPipeData(32),d=4*(t+1),u=d+2*t,p=new Ke,g=0,f=h.uv.length;f>g;g+=2)p.set(h.uv[g],h.uv[g+1],1),p.applyMatrix3(d>g?a[0]:u>g?a[1]:a[2]),o.push(p.x),o.push(p.y)}return{vertex:i,normal:n,uv:o,index:r}}}();var ky={geoHeader:function(e){var t=new Int32Array(e);this.geoCount=t[0],this.headerBuffer=t.slice(1,4*this.geoCount+1)},GeometryReader:function(e,t){Bu.time("GeometryReader"),this.geomMap=[],this.geoCount=new Uint32Array(e,0,1)[0];var i=this.geoCount,n=[],r=0,o=null,a=null,s=null,l=null,c=null,h=null,d=null,u=0,p=null,g=0,f=null,m=0,A=null,y=0,v=null,C=0,I=null;if(gy(t,"2"))for(var x=0;i>x;x+=1){if(n={},r=4*(1+7*i),a=(o=new Uint32Array(e,4*(1+7*x),7))[0],s=o[2],l=o[3],c=o[4],h=o[5],d=o[6],u=r+o[1],p=new Float32Array(e.slice(u,4*s+u)),g=4*s+u,f=new Float32Array(e.slice(g,g+4*l)),m=g+4*l,A=new Uint32Array(e.slice(m,m+4*c)),y=m+4*c,v=new Float32Array(e.slice(y,y+4*h)),C=y+4*h,I=new Int16Array(e.slice(C,C+2*d)),xd.DataReduction){var w=(new yt).makeScale(.001,.001,.001);by.applyMatrix4ToBuffer(w,p)}n.position=p,n.normal=f,n.index=A,n.uv=v,n.materialIndex=I,n.geoId=a,this.geomMap.push(n)}else for(var M=0;i>M;M+=1)n={},r=4*(1+6*i),a=(o=new Uint32Array(e,4*(1+6*M),6))[0],s=o[2],l=o[3],c=o[4],h=o[5],u=r+o[1],p=new Float32Array(e.slice(u,4*s+u)),g=4*s+u,f=new Float32Array(e.slice(g,g+4*l)),m=g+4*l,A=new Uint32Array(e.slice(m,m+4*c)),y=m+4*c,v=new Float32Array(e.slice(y,y+4*h)),n.position=p,n.normal=f,n.index=A,n.uv=v,n.geoId=a,this.geomMap.push(n);Bu.debug(this.geomMap),Bu.timeEnd("GeometryReader")},BatchedGeometryReader:function(e,t){Bu.time("BatchedGeometryReader"),this.geomMap=[],this.geoCount=new Uint32Array(e,0,1)[0];for(var i=this.geoCount,n=0,r=0,o=0,a=[],s=4,l=0;i>l;l+=1){var c={};a.push(c);var h=new Uint32Array(e,s,7);c.geoId=h[0],c.offset=h[1],c.vertexLength=h[2],c.normalLength=h[5],c.indicesLength=h[3],c.uvLength=h[4],c.componentCount=r=h[6],c.nodeInfo=[],s+=28;for(var d=0;r>d;d+=1){var u=new Uint32Array(e,s,1)[0];s+=4;for(var p=0;u>p;p+=1){var g=new Uint32Array(e,s,3);s+=12,c.nodeInfo.push(g)}}c.materialKeyLength=new Uint32Array(e,s,1)[0],s+=4}for(var f=0;i>f;f+=1){var m=a[f],A=m.normalLength,y=m.indicesLength,v=m.uvLength;n=s+m.offset,o=4*m.vertexLength;var C=new Float32Array(e.slice(n,n+o));n+=o,o=4*y;var I=new Uint32Array(e.slice(n,n+o));n+=o,o=4*v;var x=new Float32Array(e.slice(n,n+o));n+=o,o=4*A;var w=new Float32Array(e.slice(n,n+o));n+=o,r=m.componentCount;for(var M={},E=0,B=m.nodeInfo.length;B>E;E+=1){var S=m.nodeInfo[E];o=2*S[0];var b=wp.ab2str(new Int16Array(e.slice(n,n+o)));n+=o,o=2*S[1];var k=wp.ab2str(new Int16Array(e.slice(n,n+o)));n+=o;var D=new Uint32Array(e.slice(n,n+4))[0];n+=4;var T=new Uint32Array(e.slice(n,n+4))[0];n+=4;var R=new Uint32Array(e.slice(n,n+4))[0];n+=4;var U=new Uint32Array(e.slice(n,n+4))[0];n+=4;var F={};F.userId=b,F.nodeId=k,F.positionStart=D,F.positionCount=T,F.indexStart=R,F.indexCount=U,M[b]||(M[b]=[]),M[b].push(F)}o=2*m.materialKeyLength;var Q=wp.ab2str(new Int16Array(e.slice(n,n+o)));if(xd.DataReduction){var L=(new yt).makeScale(.001,.001,.001);by.applyMatrix4ToBuffer(L,C)}var O={};O.position=C,O.normal=w,O.index=I,O.uv=x,O.materialIndex=null,O.geoId=m.geoId,O.materialKey=Q,O.componentInfo=M,this.geomMap.push(O)}Bu.debug(this.geomMap),Bu.timeEnd("BatchedGeometryReader")},NodesReader:function(e,t){Bu.time("NodesReader"),this.geomMap=[],this.nodeCount=new Uint32Array(e,0,1)[0];for(var i=this.nodeCount,n=0,r=0,o=[],a=4,s=0;i>s;s+=1){var l={};o.push(l);var c=new Uint32Array(e,a,5);l.geoId=c[0],l.offset=c[1],l.nodeIdLength=c[2],l.materialKeyLength=c[3],l.matrixLength=c[4],a+=20}for(var h=0;i>h;h+=1){var d=o[h],u=d.materialKeyLength,p=d.matrixLength,g=wp.ab2str(e.slice(n=a+d.offset,n+(r=d.nodeIdLength))),f=wp.ab2str(e.slice(n+=r,n+(r=u)));n+=r,r=8*p;var m=new Float64Array(e.slice(n,n+r));n+=r;var A={};A.nodeId=g,A.geoId=d.geoId,A.material=f,A.matrix=m,this.geomMap.push(A)}Bu.debug(this.geomMap),Bu.timeEnd("NodesReader")},InstancedGeometryReader:function(e,t){Bu.time("InstancedGeometryReader"),this.geomMap=[],this.geoCount=new Uint32Array(e,0,1)[0];for(var i=this.geoCount,n=null,r=0,o=0,a=0,s=[],l=4,c=0;i>c;c+=1){var h={};s.push(h),n=new Uint32Array(e,l,7),h.geoId=n[0],h.offset=n[1],h.vertexLength=n[2],h.normalLength=n[5],h.indicesLength=n[3],h.uvLength=n[4],h.componentCount=o=n[6],h.nodeInfo={},l+=28;var d=[];h.componentKeyLength=d,h.matrixArrayLength=[];for(var u=0;o>u;u+=1){d.push(new Uint32Array(e,l,1)[0]),l+=4;var p=new Uint32Array(e,l,1)[0];l+=4,h.nodeInfo[u]=[];for(var g=0;p>g;g+=1){var f=new Uint32Array(e,l,1)[0];l+=4,h.nodeInfo[u].push(f)}}h.matrixArrayLength=new Uint32Array(e,l,1)[0],l+=4,h.materialKeyLength=new Uint32Array(e,l,1)[0],l+=4}for(var m=0;i>m;m+=1){var A=s[m],y=A.normalLength,v=A.indicesLength,C=A.uvLength;r=l+A.offset,a=4*A.vertexLength;var I=new Float32Array(e.slice(r,r+a));r+=a,a=4*v;var x=new Uint32Array(e.slice(r,r+a));r+=a,a=4*C;var w=new Float32Array(e.slice(r,r+a));r+=a,a=4*y;var M=new Float32Array(e.slice(r,r+a));r+=a;for(var E={},B=[],S=[],b=0,k=0,D=o=A.componentCount;D>k;k+=1){var T=wp.ab2str(e.slice(r,r+(a=A.componentKeyLength[k])));r+=a,S.push(T),E[T]||(E[T]=[]);for(var R=A.nodeInfo[k],U=0,F=R.length;F>U;U+=1){var Q=wp.ab2str(e.slice(r,r+(a=R[U])));r+=a,E[T].push(b),B.push(Q),b+=1}}a=8*A.matrixArrayLength;var L=new Float64Array(e.slice(r,r+a));r+=a;var O=new Float64Array(e.slice(r,r+a));r+=a;var N=new Float64Array(e.slice(r,r+a));r+=a;var P=new Float64Array(e.slice(r,r+a)),G=wp.ab2str(e.slice(r+=a,r+(a=A.materialKeyLength)));r+=a,a=4*B.length*4;var K=new Float32Array(e.slice(r,r+a));if(r+=a,xd.DataReduction){var V=(new yt).makeScale(.001,.001,.001);by.applyMatrix4ToBuffer(V,I)}var Y={};Y.position=I,Y.normal=M,Y.index=x,Y.uv=w,Y.materialIndex=null,Y.geoId=A.geoId,Y.materialKey=G,Y.componentInfo=E,Y.mcol0=L,Y.mcol1=O,Y.mcol2=N,Y.mcol3=P,Y.color=K,Y.nodeIdInfo=B,Y.componentKeyInfo=S,this.geomMap.push(Y)}Bu.debug(this.geomMap),Bu.timeEnd("InstancedGeometryReader")},BoneReader:function(e,t){Bu.time("BoneReader"),this.boneMap=[],this.boneCount=new Uint32Array(e,0,1)[0];for(var i=this.boneCount,n=[],r=0,o=null,a=null,s=null,l=null,c=null,h=null,d=0,u=null,p=0,g=null,f=0,m=null,A=0,y=[],v="[]",C=0;i>C;C+=1){n={},r=4*(1+5*i),a=(o=new Uint32Array(e,4*(1+5*C),5))[0],s=o[2],l=o[3],c=o[3],h=o[4],d=r+o[1],u=new Float32Array(e.slice(d,4*s+d)),p=4*s+d,g=new Uint16Array(e.slice(p,p+2*l)),f=p+2*l,m=new Float32Array(e.slice(f,f+4*c)),A=f+4*c;var I=new Uint8Array(e.slice(A,A+h));v=og.isIE11()?wp.decodeUTF8(I):new TextDecoder("utf-8").decode(I);try{y=JSON.parse(v)}catch(e){Bu.error("解析name出错",e)}n.offsetMatrix=u,n.skinIndex=g,n.skinWeight=m,n.name=y,n.geoId=a,this.boneMap.push(n)}Bu.debug(this.boneMap),Bu.time("BoneReader")}};ky.GeometryReader.prototype={constructor:ky.GeometryReader,getPositionBuffer:function(e){return this.geos[e].position},getIndexBuffer:function(e){return this.geos[e].index},getNormalBuffer:function(e){return this.geos[e].normal},getUVBuffer:function(e){return[]}};var Dy=function(e,t){if(this.materialMap=[],gy(t,"2"))this.materialMap=e;else for(var i=this.materialCount=new Uint32Array(e,0,1)[0],n=4*(1+6*i),r=0;i>r;r+=1){var o=new Uint32Array(e,4*(1+6*r),6),a=o[0],s=o[1],l=o[2],c=o[3],h=o[4],d=o[5],u=new Float32Array(e.slice(n+s,4*l+n+s)),p=new Int16Array(e.slice(4*l+n+s,4*l+n+s+2*c)),g=new Uint8Array(e.slice(4*l+n+s+2*c,4*l+n+s+2*c+h)),f=4*l+n+s+2*c+h,m=new Int16Array(e.slice(f,f+2*d)),A="[]";A=og.isIE11()?wp.decodeUTF8(g):new TextDecoder("utf-8").decode(g);var y=[];try{y=JSON.parse(A)}catch(e){Bu.error("解析纹理出错:",e)}var v={};v.matId=a,v.color=u,v.colorIndex=p,v.texture=y,v.textureIndex=m,this.materialMap.push(v)}Bu.debug(this.materialMap)},Ty={geoHeader:function(e){var t=new Int32Array(e);this.geoCount=t[0],this.headerBuffer=t.slice(1,4*this.geoCount+1)},GeometryReader:function(e,t){this.geomMap=[],this.geoCount=new Uint32Array(e,0,1)[0];for(var i=this.geoCount,n=[],r=0,o=null,a=null,s=null,l=null,c=0,h=null,d=null,u=0,p=0;i>p;p+=1)n={},r=4*(1+4*i),a=(o=new Uint32Array(e,4*(1+4*p),4))[0],s=o[3],l=o[2],c=r+o[1],d=new Uint32Array(e.slice(c,c+4*l)),u=c+4*l,h=new Float32Array(e.slice(u,4*s+u)),n.position=h,n.index=d,n.geoId=a,this.geomMap.push(n);Bu.debug(this.geomMap)},BoneReader:function(e,t){this.boneMap=[],this.boneCount=new Uint32Array(e,0,1)[0];for(var i=this.boneCount,n=[],r=0,o=null,a=null,s=null,l=null,c=null,h=null,d=0,u=null,p=0,g=null,f=0,m=null,A=0,y=[],v="[]",C=0;i>C;C+=1){n={},r=4*(1+5*i),a=(o=new Uint32Array(e,4*(1+5*C),5))[0],s=o[2],l=o[3],c=o[3],h=o[4],d=r+o[1],u=new Float32Array(e.slice(d,4*s+d)),p=4*s+d,g=new Uint16Array(e.slice(p,p+2*l)),f=p+2*l,m=new Float32Array(e.slice(f,f+4*c)),A=f+4*c;var I=new Uint8Array(e.slice(A,A+h));v=og.isIE11()?wp.decodeUTF8(I):new TextDecoder("utf-8").decode(I);try{y=JSON.parse(v)}catch(e){Bu.error("解析name出错",e)}n.offsetMatrix=u,n.skinIndex=g,n.skinWeight=m,n.name=y,n.geoId=a,this.boneMap.push(n)}Bu.debug(this.boneMap)}};Ty.GeometryReader.prototype={constructor:Ty.GeometryReader,getPositionBuffer:function(e){return this.geos[e].position},getIndexBuffer:function(e){return this.geos[e].index},getNormalBuffer:function(e){return this.geos[e].normal},getUVBuffer:function(e){return[]}};var Ry=function(e){this.MaxThreadCount=e||8,this.todoList=[],this.doingCount=0,this.addItem=function(e){void 0!==e&&this.todoList.push(e)},this.run=function(e,t,i){if(0>=this.doingCount)if(0!==this.todoList.length){var n=this.todoList,r=n.length;this.todoList=[],this.doingCount=r;for(var o=Math.min(this.MaxThreadCount,xd.ConcurrencyRequestCount,r),a=this,s=0;o>s;s+=1)l(s)}else i();function l(s){r>s?(t(a.doingCount,r),e(n[s],s+o,l)):1>a.doingCount&&(a.run(e,t,i),t(a.doingCount,r),i())}}},Uy=function(e,t){this.type=t,this.manager=e,this.worker=new Ry(4),this.working=!0};function Fy(e,t,i,n){for(var r=function(e,t){var i=void 0;i="Line"===t||"LineSegments"===t?new $l:new kc;for(var n=new ke,r=new ke,o=new ke,a=!0,s=!1,l=e.match(/[a-df-z][^a-df-z]*/gi),c=0,h=l.length;h>c;c++){var d=l[c],u=(t=d.charAt(0),d.substr(1).trim());switch(!0===a&&(s=!0,a=!1),t){case"M":for(var p=0,g=(y=Qy(u)).length;g>p;p+=2)n.x=y[p+0],n.y=y[p+1],r.x=n.x,r.y=n.y,0===p?i.moveTo(n.x,n.y):i.lineTo(n.x,n.y),0===p&&!0===s&&o.copy(n);break;case"H":for(p=0,g=(y=Qy(u)).length;g>p;p++)n.x=y[p],r.x=n.x,r.y=n.y,i.lineTo(n.x,n.y),0===p&&!0===s&&o.copy(n);break;case"V":for(p=0,g=(y=Qy(u)).length;g>p;p++)n.y=y[p],r.x=n.x,r.y=n.y,i.lineTo(n.x,n.y),0===p&&!0===s&&o.copy(n);break;case"L":for(p=0,g=(y=Qy(u)).length;g>p;p+=2)n.x=y[p+0],n.y=y[p+1],r.x=n.x,r.y=n.y,i.lineTo(n.x,n.y),0===p&&!0===s&&o.copy(n);break;case"C":for(p=0,g=(y=Qy(u)).length;g>p;p+=6)i.bezierCurveTo(y[p+0],y[p+1],y[p+2],y[p+3],y[p+4],y[p+5]),r.x=y[p+2],r.y=y[p+3],n.x=y[p+4],n.y=y[p+5],0===p&&!0===s&&o.copy(n);break;case"S":for(p=0,g=(y=Qy(u)).length;g>p;p+=4)i.bezierCurveTo(Ly(n.x,r.x),Ly(n.y,r.y),y[p+0],y[p+1],y[p+2],y[p+3]),r.x=y[p+0],r.y=y[p+1],n.x=y[p+2],n.y=y[p+3],0===p&&!0===s&&o.copy(n);break;case"Q":for(p=0,g=(y=Qy(u)).length;g>p;p+=4)i.quadraticCurveTo(y[p+0],y[p+1],y[p+2],y[p+3]),r.x=y[p+0],r.y=y[p+1],n.x=y[p+2],n.y=y[p+3],0===p&&!0===s&&o.copy(n);break;case"T":for(p=0,g=(y=Qy(u)).length;g>p;p+=2){var f=Ly(n.x,r.x),m=Ly(n.y,r.y);i.quadraticCurveTo(f,m,y[p+0],y[p+1]),r.x=f,r.y=m,n.x=y[p+0],n.y=y[p+1],0===p&&!0===s&&o.copy(n)}break;case"A":for(p=0,g=(y=Qy(u)).length;g>p;p+=7){var A=n.clone();n.x=y[p+5],n.y=y[p+6],r.x=n.x,r.y=n.y,Oy(i,y[p],y[p+1],y[p+2],y[p+3],y[p+4],A,n),0===p&&!0===s&&o.copy(n)}break;case"m":for(p=0,g=(y=Qy(u)).length;g>p;p+=2)n.x+=y[p+0],n.y+=y[p+1],r.x=n.x,r.y=n.y,0===p?i.moveTo(n.x,n.y):i.lineTo(n.x,n.y),0===p&&!0===s&&o.copy(n);break;case"h":for(p=0,g=(y=Qy(u)).length;g>p;p++)n.x+=y[p],r.x=n.x,r.y=n.y,i.lineTo(n.x,n.y),0===p&&!0===s&&o.copy(n);break;case"v":for(p=0,g=(y=Qy(u)).length;g>p;p++)n.y+=y[p],r.x=n.x,r.y=n.y,i.lineTo(n.x,n.y),0===p&&!0===s&&o.copy(n);break;case"l":for(p=0,g=(y=Qy(u)).length;g>p;p+=2)n.x+=y[p+0],n.y+=y[p+1],r.x=n.x,r.y=n.y,i.lineTo(n.x,n.y),0===p&&!0===s&&o.copy(n);break;case"c":for(p=0,g=(y=Qy(u)).length;g>p;p+=6)i.bezierCurveTo(n.x+y[p+0],n.y+y[p+1],n.x+y[p+2],n.y+y[p+3],n.x+y[p+4],n.y+y[p+5]),r.x=n.x+y[p+2],r.y=n.y+y[p+3],n.x+=y[p+4],n.y+=y[p+5],0===p&&!0===s&&o.copy(n);break;case"s":for(p=0,g=(y=Qy(u)).length;g>p;p+=4)i.bezierCurveTo(Ly(n.x,r.x),Ly(n.y,r.y),n.x+y[p+0],n.y+y[p+1],n.x+y[p+2],n.y+y[p+3]),r.x=n.x+y[p+0],r.y=n.y+y[p+1],n.x+=y[p+2],n.y+=y[p+3],0===p&&!0===s&&o.copy(n);break;case"q":for(p=0,g=(y=Qy(u)).length;g>p;p+=4)i.quadraticCurveTo(n.x+y[p+0],n.y+y[p+1],n.x+y[p+2],n.y+y[p+3]),r.x=n.x+y[p+0],r.y=n.y+y[p+1],n.x+=y[p+2],n.y+=y[p+3],0===p&&!0===s&&o.copy(n);break;case"t":for(p=0,g=(y=Qy(u)).length;g>p;p+=2){f=Ly(n.x,r.x),m=Ly(n.y,r.y);i.quadraticCurveTo(f,m,n.x+y[p+0],n.y+y[p+1]),r.x=f,r.y=m,n.x=n.x+y[p+0],n.y=n.y+y[p+1],0===p&&!0===s&&o.copy(n)}break;case"a":var y;for(p=0,g=(y=Qy(u)).length;g>p;p+=7){A=n.clone();n.x+=y[p+5],n.y+=y[p+6],r.x=n.x,r.y=n.y,Oy(i,y[p],y[p+1],y[p+2],y[p+3],y[p+4],A,n),0===p&&!0===s&&o.copy(n)}break;case"Z":case"z":i.currentPath.autoClose=!0,i.currentPath.curves.length>0&&(n.copy(o),i.currentPath.currentPoint.copy(n),a=!0);break;default:console.warn(d)}s=!1}return i}(e),o="Shape"===r.type?[r]:r.toShapes(!0),a=new Yt,s=0;o.length>s;s++){var l=o[s];if("Line"===t||"LineSegments"===t){for(var c=l.getPoints(),h=0;c.length>h;h+=1){var d=c[h];d.y=-d.y,n&&(d.z=n)}if("LineSegments"===t){var u=(new Ni).setFromPoints(c),p=new La(u,i);a.add(p)}else if("Line"===t){var g=(new Ni).setFromPoints(c),f=new Ua(g,i);a.add(f)}}else if("Mesh"===t){for(var m=new Gs(l),A=m.getAttribute("position"),y=A.array,v=0,C=y.length;C>v;v+=3)y[v+1]=-y[v+1],y[v+2]=n;A.needsUpdate=!0;var I=new nn(m,i);a.add(I)}}return a}function Qy(e){for(var t=e.split(/[\s,]+|(?=\s?[+\-])/),i=0;t.length>i;i+=1){var n=t[i];if(n.indexOf(".")!==n.lastIndexOf("."))for(var r=n.split("."),o=2;r.length>o;o+=1)t.splice(i+o-1,0,"0."+r[o]);t[i]=parseFloat(n)}return t}function Ly(e,t){return e-(t-e)}function Oy(e,t,i,n,r,o,a,s){n=n*Math.PI/180,t=Math.abs(t),i=Math.abs(i);var l=(a.x-s.x)/2,c=(a.y-s.y)/2,h=Math.cos(n)*l+Math.sin(n)*c,d=-Math.sin(n)*l+Math.cos(n)*c,u=t*t,p=i*i,g=h*h,f=d*d,m=g/u+f/p;if(m>1){var A=Math.sqrt(m);u=(t*=A)*t,p=(i*=A)*i}var y=u*f+p*g,v=Math.sqrt(Math.max(0,(u*p-y)/y));r===o&&(v=-v);var C=v*t*d/i,I=-v*i*h/t,x=Math.cos(n)*C-Math.sin(n)*I+(a.x+s.x)/2,w=Math.sin(n)*C+Math.cos(n)*I+(a.y+s.y)/2,M=svgAngle(1,0,(h-C)/t,(d-I)/i),E=svgAngle((h-C)/t,(d-I)/i,(-h-C)/t,(-d-I)/i)%(2*Math.PI);e.currentPath.absellipse(x,w,t,i,M,M+E,0===o,n)}function Ny(e){this.group=e;var t=new pi(16711680);this._lineMaterial=new Sa({color:t,side:2}),this._meshMaterial=new gi({color:t,side:2})}function Py(){this.axisNet=void 0,this.visibleByUser=!1}Uy.prototype={constructor:Uy,addTask:function(e){this.worker.addItem(e)},processTasks:function(e,t,i){var n=this,r=this.worker;this.worker.run((function(t,i,o){n.working&&e(t,(function(){r.doingCount-=1,o(i)}))}),t=t||function(){},i=i||function(){})},stop:function(){this.working=!1},start:function(){this.working=!0}},Ny.prototype.fromJSON=function(e,t){for(var i in e)if(e.hasOwnProperty(i)){var n=e[i];for(var r in n)if(n.hasOwnProperty(r)){var o=n[r],a=o.G.Path;if(a&&a.length>0){var s=o.P.matrix||[0,0];if(o.P.Type&&"LINE"===o.P.Type){for(var l="",c=0,h=a.length;h>c;c+=1)l+=a[c];var d=Fy(l,"LineSegments",this._lineMaterial,t);d.position.setX(s[0]),d.position.setY(-s[1]),this.group.add(d),d.updateMatrixWorld(!0)}else for(var u=0,p=a.length;p>u;u+=1){var g=void 0,f=Fy(a[u],g=o.G.Fill&&o.G.Fill.length===p&&0!==o.G.Fill[u].length?"Mesh":"Line","Line"===g?this._lineMaterial:this._meshMaterial,t);f.position.setX(s[0]),f.position.setY(-s[1]),this.group.add(f),f.updateMatrixWorld(!0)}}}}},Ny.prototype.setColor=function(e,t){if(e){var i=new pi(e);this._lineMaterial.color=i,t&&(this._lineMaterial.opacity=t,this._lineMaterial.transparent=1!==t),this._meshMaterial.color=i,t&&(this._meshMaterial.opacity=t,this._meshMaterial.transparent=1!==t),this._lineMaterial.needsUpdate=!0,this._meshMaterial.needsUpdate=!0}},Ny.prototype.enableStayInFront=function(){this._lineMaterial.transparent=!0,this._meshMaterial.transparent=!0,this._lineMaterial.depthTest=!1,this._meshMaterial.depthTest=!1},Ny.prototype.disableStayInFront=function(){this._lineMaterial.transparent=!1,this._meshMaterial.transparent=!1,this._lineMaterial.depthTest=!0,this._meshMaterial.depthTest=!0},Py.prototype.setupColor=function(e,t){e&&this.axisNet.setColor(e,t)},Py.prototype.hide=function(){this.axisNet&&(this.visibleByUser=!1,this.axisNet.group.visible=!1)},Py.prototype.show=function(){this.axisNet&&(this.visibleByUser=!0,this.axisNet.group.visible=!0)},Py.prototype.privateShow=function(){this.axisNet&&(this.axisNet.group.visible=!0)},Py.prototype.privateHide=function(){this.axisNet&&(this.axisNet.group.visible=!1)},Py.prototype.enableStayInFront=function(){this.axisNet.enableStayInFront()},Py.prototype.disableStayInFront=function(){this.axisNet.disableStayInFront()};var Gy=function(){this.name="",this.componentkeys=[],this.box=void 0,this.center=void 0,this.map=void 0},Ky=function(){this.name="",this.image=void 0,this.width=0,this.height=0,this.sceneWidth=0,this.sceneHeight=0,this.box={x1:0,y1:0,z1:0,x2:0,y2:0,z2:0,offsetX:0,offsetY:0},this.componentKeys=void 0};Ky.prototype.clone=function(){var e=new Ky;return e.name=this.name,e.image=this.image,e.width=this.width,e.height=this.height,e.sceneWidth=this.sceneWidth,e.sceneHeight=this.sceneHeight,e.box=Object.assign({},this.box),e.componentKeys=this.componentKeys?[].concat(this.componentKeys):void 0,e},Gy.parseFloorInfos=function(e){for(var t=[],i=Object.keys(e),n=0,r=i.length;r>n;n+=1){var o=e[i[n]];if(o.length>0){var a=new Gy;a.componentkeys=o,a.name=i[n],t.push(a)}}if(t.length>0)return t};var Vy=function(){this.floors=void 0,this.sortedFloors=void 0,this.factor=1,this.baseFloorIndex=-1,this.averageHeight=0,this.center=void 0},Yy=function(e){return new Promise((function(t,i){var n=Object.assign({type:"get",cache:!0,headers:{"Content-type":"application/x-www-form-urlencoded"},data:null,async:!0,success:null,error:null,beforeSend:null,requestQueue:void 0},e),r=null;for(var o in(r=window.XMLHttpRequest?new XMLHttpRequest:new ActiveXObject("Microsoft.XMLHTTP")).onreadystatechange=function(){if(4===r.readyState||"4"===r.readyState){var e=r.status;e>=200&&300>e||0===e?(n.success&&n.success(r.response||r.responseText,""===r.responseType||"document"===r.responseType&&r.responseXML),t(r.response||r.responseText,""===r.responseType||"document"===r.responseType&&r.responseXML)):(n.error&&n.error(e,r.response||r.responseText,""===r.responseType||"document"===r.responseType&&r.responseXML),i(e,r.response||r.responseText,""===r.responseType||"document"===r.responseType&&r.responseXML))}},r.open(n.type,n.url,n.async),n.headers)r.setRequestHeader(o,n.headers[o]);n.responseType&&(r.responseType=n.responseType),n.requestQueue?n.requestQueue.addRequest(r,n.data):n.beforeSend?n.beforeSend(r,(function(){r.send(n.data)})):r.send(n.data)}))},Hy=function(){function e(){ru(this,e),this.floors=void 0,this.floorExplosionInfo=void 0,this.modelType=void 0,this.modelKey=void 0,this.revitFilter={OST_CeilingOpening:!0,OST_FloorOpening:!0,OST_RoofOpening:!0,OST_Walls:!0,OST_StructuralFraming:!0,OST_CurtainWallPanels:!0,OST_CurtainWallMullions:!0,OST_CurtaSystem:!0,OST_ShaftOpening:!0},this.ifcFilter={IfcWallStandardCase:!0,IfcWall:!0,IfcCurtainWall:!0,IfcBeam:!0,IfcMember:!0}}return au(e,[{key:"generateMiniMap",value:function(e){var t=this;if(this.floors&&this.floors.length>0){var i=xd.MiniMapSize,n=i,r=e.rendererManager.renderer,o=new ke(i,n),a=new Oe(o.x,o.y,{stencilBuffer:!1});r.setRenderTarget(a);var s=new Le,l=r.getPixelRatio();r.getViewport(s),r.setPixelRatio(1),r.setViewport(0,0,o.width,o.height);var c=e.getScene(),h=new Ke,d=new Ke,u=e.getModel(this.modelKey).getBoundingBoxWorld();u.getCenter(h),u.getSize(d);var p=Math.ceil(Math.max(d.x,d.y)),g=p/2,f=new Ke(p,p,d.z);u.setFromCenterAndSize(h,f);var m=new pc;m.up.set(0,1,0),m.position.set(h.x,h.y,u.max.z),m.lookAt(h.x,h.y,u.min.z),m.left=-g,m.right=g,m.top=g,m.bottom=-g,m.near=1,m.far=d.z,m.updateMatrixWorld(!0),m.updateProjectionMatrix();var A=document.createElement("canvas");A.width=o.width,A.height=o.height;var y=A.getContext("2d"),v=new Uint8Array(o.width*o.height*4),C=e.getFilter();this.floors.forEach((function(s){var l=t.findSpecificKeys(s.componentkeys,e);0===l.length&&(l=s.componentkeys);var g=e.getBoundingBoxByIds(l);g.getCenter(h),g.getSize(d);var f=new Ky;f.box.x1=g.min.x,f.box.y1=g.min.y,f.box.z1=g.min.z,f.box.x2=g.max.x,f.box.y2=g.max.y,f.box.z2=g.max.z,f.box.offsetX=g.min.x-u.min.x,f.box.offsetY=g.min.y-u.min.y,f.width=i,f.height=n,f.sceneWidth=p,f.sceneHeight=p,f.name=s.name,f.componentKeys=l,s.map=f,C.setIsolateList(l,!0),e.modelManager.applyFilter(),r.render(c,m),r.readRenderTargetPixels(a,0,0,o.width,o.height,v);for(var I=n/2,x=4*i,w=new Uint8Array(4*i),M=0;I>M;M+=1){var E=M*x,B=(n-M-1)*x;w.set(v.subarray(E,E+x)),v.copyWithin(E,B,B+x),v.set(w,B)}var S=new Uint8ClampedArray(v.buffer),b=new ImageData(S,o.width,o.height);y.putImageData(b,0,0),f.image=A.toDataURL()})),C.clearIsolation(),r.setRenderTarget(null),r.setPixelRatio(l),r.setViewport(s.x,s.y,s.width,s.height)}}},{key:"findSpecificKeys",value:function(e,t){for(var i=[],n=0,r=e.length;r>n;n+=1){var o=t.modelManager.getComponent(e[n]);if(o&&o.length>0){var a=o[0],s=a.buildInCategory,l=a.type;(s&&this.revitFilter[s]||l&&this.ifcFilter[l])&&i.push(e[n])}}return i}},{key:"getMimiMaps",value:function(){if(this.serverMapData)return{msg:"success",data:this.serverMapData.data};if(this.floors&&this.floors.length>0){for(var e=[],t=0,i=this.floors.length;i>t;t+=1){var n=this.floors[t].map;n&&e.push(n.clone())}if(e.length>0)return{msg:"success",data:e}}return{msg:"该模型不支持小地图"}}},{key:"getServerMimiMaps",value:function(e){var t=this.model.dataUrl.floorMapUrl(),i=this.model.accessToken,n=this;if(this.floors&&this.floors.length>0)if(this.serverMapData)e({msg:"success",data:n.serverMapData.data});else{var r={url:t,success:function(t){var i;"SUCCESS"===(i="string"==typeof t?JSON.parse(t):t).code?(n.serverMapData=i,e({msg:"success",data:i.data})):"FAILURE"===i.code?setTimeout((function(){n.getServerMimiMaps(e)}),3e3):e("MAP_NOT_SUPPORTED"===i.code?{msg:"该模型不支持小地图"}:{msg:"获取模型小地图出错"})},error:function(){e({msg:"该模型不支持小地图"})}};i&&(r.headers={Authorization:i}),Yy(r)}}}]),e}(),jy=function(){this.leftChild=null,this.rightChild=null,this.boundingBox=null,this.level=-1,this.components=[]};jy.prototype.init=function(e){if(e&&(void 0!==e.axis&&(this.level=e.axis),e.left&&(this.leftChild=new jy,this.leftChild.init(e.left[0]?e.left[0]:e.left)),e.right&&(this.rightChild=new jy,this.rightChild.init(e.right[0]?e.right[0]:e.right)),e.box&&!e.items&&(this.boundingBox=new He((new Ke).fromArray(e.box.min),(new Ke).fromArray(e.box.max))),e.items))for(var t=0;e.items.length>t;t+=1)this.components.push(e.items[t].key)},jy.prototype.intersect=function(e,t){if(this.boundingBox){if(!1===e.intersectsBox(this.boundingBox))return;this.leftChild&&this.leftChild.intersect(e,t),this.rightChild&&this.rightChild.intersect(e,t);for(var i=0;this.components.length>i;i+=1)t.push(this.components[i])}else for(var n=0;this.components.length>n;n+=1)t.push(this.components[n])},jy.prototype.frustumIntersect=function(e,t,i){if(this.boundingBox){var n=this.boundingBox;if(i&&!i.equals(Ed)&&(n=this.boundingBox.clone()).applyMatrix4(i),!1===e.intersectsBox(n))return;this.leftChild&&this.leftChild.frustumIntersect(e,t,i),this.rightChild&&this.rightChild.frustumIntersect(e,t,i);for(var r=0;this.components.length>r;r+=1)t.push(this.components[r])}else for(var o=0;this.components.length>o;o+=1)t.push(this.components[o])},jy.prototype.destroy=function(){this.leftChild&&this.leftChild.destroy(),this.rightChild&&this.rightChild.destroy(),this.leftChild=null,this.rightChild=null,this.boundingBox=null,this.level=-1,this.components=[]};var Wy=function(e){lu(i,e);var t=pu(i);function i(e){var n;return ru(this,i),(n=t.call(this)).handler=e,n.model=e.model,n.dataVersion=n.model.dataVersion,n.storage=n.model.getStorage(),n.url=e.model.dataUrl,n.offLine=e.model.offLine,n.fileLoader=e.model.fileLoader,n.descriptor=null,n.loader=new xy(du(n)),n.Textureloader=new xy(du(n)),n.jsonLoader=new xy(du(n)),n.loadTaskCount=0,n.maxLoadTaskCount=0,n.loadTextureCount=0,n.maxLoadTextureCount=0,n.textruesLoaded=!1,n.dataLoaded=!1,n.taskComponentManager=new Uy(du(n),"component"),n.taskReuseNodeManager=new Uy(du(n),"component"),n.taskGeometrieManager=new Uy(du(n),"geometrie"),n.taskComponentNodeManager=new Uy(du(n),"nodes"),n.taskMaterialManager=new Uy(du(n),"material"),n.taskTexturesManager=new Uy(du(n),"textures"),n.fileKeyFromModelKey={},n.enableCompressedTexture=!1,n.enableSmallTexture=!1,n.startCallback=null,n.progressCallback=null,n.finishCallback=null,n.progress={total:0,loaded:0,failed:0},n.requests={},n}return i}(xl);Wy.prototype.destroy=function(){for(var e in this.requests)this.requests.hasOwnProperty(e)&&(this.requests[e].abort&&this.requests[e].abort(),delete this.requests[e]);this.taskComponentManager.stop(),this.taskComponentManager=null,this.taskGeometrieManager.stop(),this.taskGeometrieManager=null,this.taskMaterialManager.stop(),this.taskMaterialManager=null,this.taskTexturesManager.stop(),this.taskTexturesManager=null,this.url=null,this.model=null,this.fileLoader=null,this.descriptor=null,this.handler=null,this.startCallback=null,this.progressCallback=null,this.finishCallback=null,this.descriptor&&this.descriptor.destroy()},Wy.prototype.getStorage=function(){return this.storage},Wy.prototype.getDescriptor=function(){return this.descriptor},Wy.prototype.setNotifyProgress=function(e){this.notifyProgress=e},Wy.prototype.load=function(e,t,i){this.startCallback=e,this.progressCallback=t,this.finishCallback=i,this.loadData()},Wy.prototype.loadData=function(){var e=this,t=this.model,i=t.getConfig(),n=i.scene,r=i.animation;if(!n||!n.components||!n.geometries&&(!n.batchedGeometries&&!n.instancedGeometries||1>n.batchedGeometries.length&&1>n.instancedGeometries.length)||!n.materials||!n.textures)return t.setEmptyScene(!0),Bu.error("scene is null,modelKey is ",t.modelKey),void t.dispatchEventEx({type:Fd.ON_LOAD_EMPTY_SCENE,modelKey:t.modelKey});var o=0,a=0,s=0,l=n.components.length||0,c=n.materials.length||0,h=n.textures.length||0,d=n.lights&&n.lights.length||0,u=n.reuseNodes&&n.reuseNodes.length||0,p=[],g=[],f=[],m=[],A=[],y=[],v=[],C=n.textures,I=[],x=[];if(this.map={},my(e.dataVersion,"2.0.0")){for(var w=0;l>w;w+=1)n.components[w].fileKey?p.push(n.components[w].fileKey):t.dispatchEventEx({type:Qd.SCENE_NOT_CLOSE,modelKey:t.modelKey});for(var M=0;c>M;M+=1)n.materials[M].fileKey?g.push(n.materials[M].fileKey):t.dispatchEventEx({type:Qd.SCENE_NOT_CLOSE,modelKey:t.modelKey})}else p=n.components,g=n.materials,Array.isArray(n.nodes)&&(v=n.nodes),x=n.reuseNodes||[];if(n.map&&(this.map=n.map),n.lights&&n.lights.length>0&&(y=n.lights),n.trees.length>0)for(var E=0;n.trees.length>E;E+=1){var B=n.trees[E];"partition"===B.type&&I.push(B.fileKey)}if(r&&i.hasAnimation&&(o=r.bones.length,a=1,s=1,f=r.bones,m.push(r.clips),A.push(r.nodes)),e.maxLoadTaskCount=0,e.maxLoadTaskCount+=l,e.maxLoadTaskCount+=c,e.maxLoadTaskCount+=o,e.maxLoadTaskCount+=a,e.maxLoadTaskCount+=s,e.maxLoadTaskCount+=d,e.maxLoadTaskCount+=I.length,e.maxLoadTaskCount+=u,e.maxLoadTaskCount+=v.length,1>e.maxLoadTaskCount)return Bu.info("Nothing to load ",t.modelKey),void t.dispatchEventEx({type:Qd.SCENE_NOTHING_TO_LOAD,modelKey:t.modelKey});e.progress.total+=e.maxLoadTaskCount,e.startCallback&&e.startCallback(),Bu.time("数据加载时间"),e._loadComponent(p),e._loadMaterial(g),e._loadComponentNode(v),e._loadReuseNode(x),xd.EnableTextureLoading&&h>0?(e.maxLoadTextureCount+=h,e._loadTextures(C)):e._onLoadTexture(),e._loadKDTree(I),e._loadClips(m),e._loadBones(f),e._loadNodes(A),d&&e._loadLights(y),e.offLine&&e.loadAttribute(),i.axis&&e._loadAxisNet(i.axis),e.maxLoadTaskCount+=1,e.loadFloorInfo(e.model.modelKey,(function(){e._onTaskFinished()})),e.loadSceneAndGeos(i)},Wy.prototype.loadSceneAndGeos=function(e){},Wy.prototype.getSceneTaskCount=function(e){return 0},Wy.prototype._loadLightmapConfig=function(e,t){var i=this.model,n=this.descriptor;n&&this.fileLoader.load(e,(function(e){var r;try{r=JSON.parse(e)}catch(e){return void console.log("Lightmap config data exceptions!")}void 0!==r.count.lightmapNum&&r.count.lightmapNum>0&&(i.lightmapNum=r.count.lightmapNum,i.lightmap=!0,n.lightmap=!0,xd.Instance=!1,xd.EnableLightmap=!0),t&&t()}))},Wy.prototype._onTaskFinished=function(){var e=this.model;this.loadTaskCount+=1;var t=this.dealProgressSegment(e,this.loadTaskCount);this.notifyProgress&&(this.progressCallback&&this.progressCallback({total:this.maxLoadTaskCount,loaded:t,modelKey:this.model.modelKey}));this.maxLoadTaskCount>this.loadTaskCount||(this.dataLoaded=!0,this.textruesLoaded&&(Bu.timeEnd("数据加载时间"),this.finishCallback&&this.finishCallback()))},Wy.prototype._onLoadTexture=function(){this.loadTextureCount+=1,this.maxLoadTextureCount>this.loadTextureCount||(this.textruesLoaded=!0,this.dataLoaded&&(Bu.timeEnd("数据加载时间"),this.finishCallback&&this.finishCallback()))},Wy.prototype._loadScene=function(e){var t=this,i=this.model,n=this.url,r=this.fileLoader;r.setResponseType("arraybuffer"),r.load(n.sceneUrl(e),(function(i){t._parseScene(i,e),t._onTaskFinished()}),void 0,(function(e){i.dispatchEvent({type:Qd.LOAD_ERROR,errorType:Qd.LOAD_SCENE_ERROR,event:e}),t._onTaskFinished()}))},Wy.prototype._parseScene=function(e,t){var i=new Loader.SceneReader(e);this.descriptor.mapSceneReader[t]=i,i=null},Wy.prototype._loadLine=function(){var e=this,t=this.model,i=this.url,n=this.fileLoader;n.setResponseType("arraybuffer"),n.load(i.lineUrl(),(function(t){e._parseLine(t),e._onTaskFinished()}),void 0,(function(i){t.dispatchEvent({type:Qd.LOAD_ERROR,errorType:Qd.LOAD_MATERIAL_ERROR,event:i}),e._onTaskFinished()}))},Wy.prototype._parseLine=function(e){for(var t=new Loader.LineReader(e),i=0,n=t.header.lineCount;n>i;++i){var r=t.getPtBuffer(i),o=t.getIdxBuffer(i);if(void 0!==r&&void 0!==o){var a=t.getLineData(i);if(0===a.lineType){for(var s=[],l=1,c=o.length;c>l;l++)s.push(o[l-1]),s.push(o[l]);s.length&&(o=s)}this.descriptor.cacheReferencedMeshBufferData("line-"+a.line_id,{P:r,I:o})}else Bu.log("Error Geometry!")}t=null},Wy.prototype._parseMaterialBinary=function(e){var t,i=this.url,n=this.model.materialManager,r=n.materials,o=n.textures,a=new Loader.MaterialReader(e),s=a.materialCount,l=this,c=[];if(s>=0){var h=this.model.manager.scene;for(t=0;s>t;++t){var d,u={},p=a.getMaterial(t);if(void 0!==p.color&&(u.color=p.color),void 0!==p.opacity&&(u.opacity=p.opacity,1>p.opacity&&(u.transparent=!0)),void 0!==p.side&&p.side&&(u.side=2),void 0!==p.emissive&&(u.emissive=p.emissive),void 0!==p.environment&&(u.envMapIntensity=p.environment),void 0!==p.roughness&&(u.roughness=p.roughness,u.originRoughness=p.roughness),void 0!==p.metalness&&(u.metalness=p.metalness,u.originMetalness=p.metalness),xd.IBL?(u.iblProbe=h.iblProbe,(d=new ImageBasedLighting.IBLMaterial(u)).type="IBL"):d=cA.createStandardMaterial(u),d.name=t,r[t]=d,u=null,xd.EnableTextureLoading){var g=null;p.texture_n>0&&(g=a.getTexture(p.texture_id[0])),g&&c.push({id:t,data:g})}}if(c.length>0){for(s=this.maxLoadTextureCount=c.length,t=0;s>t;t+=1)this._parseTexture(i,c[t],o);c=null}else l._onLoadTexture();if(this.model.lightmap){var f=this.model.lightmapNum;for(this.maxLoadTextureCount+=f,t=0;f>t;t+=1){var m=this._loadTexture(i.textureUrl("lightmap-rgbm"+t+".png"),(function(){l._onLoadTexture()}),void 0,(function(){l._onLoadTexture()}));n.lightmaps[t]=m}}a=null}},Wy.prototype._parseMaterialJson=function(e){var t,i=this.url,n=this.model.materialManager,r=n.materials,o=n.textures,a=new Loader.MaterialReaderJson(e),s=a.count,l=this,c=[];if(s>=0){var h=this.model.manager.scene;for(t=0;s>t;++t){var d,u={},p=a.getMaterial(t),g=p.parameters;if(void 0!==g.color&&(u.color=g.color),void 0!==g.opacity&&(u.opacity=g.opacity,1>g.opacity&&(u.transparent=!0)),void 0!==g.side&&"double"===g.side&&(u.side=2),void 0!==g.emissive&&(u.emissive=g.emissive),void 0!==g.environment&&(u.envMapIntensity=g.environment),void 0!==g.roughness&&(u.roughness=g.roughness,u.originRoughness=g.roughness),void 0!==g.metalness&&(u.metalness=g.metalness,u.originMetalness=g.metalness),void 0!==g.refractionRatio&&(u.refractionRatio=g.refractionRatio),void 0!==g.imageFade&&(u.imageFade=g.imageFade),this.model.lightmap&&(u.lights=!1),xd.IBL?(u.iblProbe=h.iblProbe,(d=new ImageBasedLighting.IBLMaterial(u)).type="IBL"):(d=cA.createStandardMaterial(u)).refreshUniforms(),d.name=t,r[t]=d,u=null,xd.EnableTextureLoading){var f=[],m=p.textures;for(var A in m){"reliefMap"==A&&m.bumpMap||f.push({type:A,data:m[A]})}f.length>0&&c.push({id:t,dataArray:f})}}if(c.length>0){for(s=c.length,t=0;s>t;t+=1){this.maxLoadTextureCount+=(f=c[t].dataArray).length}for(t=0;s>t;t+=1){for(var y=c[t].id,v=[],C=0,I=(f=c[t].dataArray).length;I>C;C++)this._parseTextureJson(i,f[C],v);o[y]=v}c=null}else l._onLoadTexture();if(this.model.lightmap){var x=this.model.lightmapNum;for(this.maxLoadTextureCount+=x,t=0;x>t;t+=1){var w=this._loadTexture(i.lightmapTexUrl("lightmap-rgbm"+t+".png"),(function(){l._onLoadTexture()}),void 0,(function(){l._onLoadTexture()}));n.lightmaps[t]=w}}a=null}},Wy.prototype._loadTexture=function(e,t,i,n){var r,o=Ml.Handlers.get(e),a=this;return null!==o?r=o.load(e,t):(r=new Fe,(o=new Sl).setCrossOrigin("anonymous"),o.load(e,(function(e){r.image=cA.ensurePowerOfTwo(e),r.needsUpdate=!0,t&&t(r)}),i,(function(e){void 0!==n&&n(e),a.model.dispatchEvent({type:Qd.LOAD_ERROR,errorType:Qd.LOAD_TEXTURE_ERROR,event:e})}))),r},Wy.prototype._loadCompressedTexture=function(e,t,i,n){},Wy.prototype._loadTextureByCrypto=function(e,t,i,n){var r,o=Ml.Handlers.get(e),a=this;return null!==o?r=o.load(e,t):(r=new Fe,(o=new TEST.CryptoResourceLoader).loadURL(e,(function(e){var i=new Blob([e],{type:"jpeg"}),o=new Image;o.onload=function(){r.image=cA.ensurePowerOfTwo(o),r.needsUpdate=!0,t&&t(r)},o.onerror=function(e){n&&n(e),a.model.dispatchEvent({type:Qd.LOAD_ERROR,errorType:Qd.LOAD_TEXTURE_ERROR,event:e})},o.src=URL.createObjectURL(i)}),(function(e){void 0!==n&&n(e),a.model.dispatchEvent({type:Qd.LOAD_ERROR,errorType:Qd.LOAD_TEXTURE_ERROR,event:e})}))),r},Wy.prototype._parseTexture=function(e,t,i){var n=window.TEST||{},r=t.id,o=t.data,a=o.id+o.file_name_ext;this.textureLoader=this.enableCompressedTexture&&o.dds?this._loadCompressedTexture:n.CryptoResourceLoader?this._loadTextureByCrypto:this._loadTexture;var s=this;this.textureLoader(e.textureUrl(a),(function(e){e.repeat.fromArray([o.scale_u,o.scale_v]),e.offset.fromArray([o.offset_u,o.offset_v]),e.setRotateAngle&&e.setRotateAngle(o.angle),o.repeat_u&&(e.wrapS=g),o.repeat_v&&(e.wrapT=g),e&&(i[r]=e),s._onLoadTexture()}),void 0,(function(){s._onLoadTexture()}))},Wy.prototype._parseTextureJson=function(e,t,i){var n=window.TEST||{},r=t.type,o=t.data,a=e.textureUrl(o.sourceFile),s=this.enableSmallTexture&&o.texture_small;if(!s&&this.enableCompressedTexture&&o.dds)this.textureLoader=this._loadCompressedTexture;else if(this.textureLoader=n.CryptoResourceLoader?this._loadTextureByCrypto:this._loadTexture,s){var l=a.lastIndexOf(".");a=a.substring(0,l)+"_s"+a.substring(l)}var c=this;this.textureLoader(a,(function(e){e.repeat.fromArray([o.scale[0],o.scale[1]]),e.offset.fromArray([o.offset[0],o.offset[1]]),e.setRotateAngle&&e.setRotateAngle(o.angle),o.repeatU&&(e.wrapS=g),o.repeatV&&(e.wrapT=g),e.texturetype=r,"reliefMap"==r&&(e.texturetype="bumpMap"),o.dataType&&"NormalMap"==o.dataType&&(e.texturetype="normalMap"),o.alpha&&(e.texturetype="alphaMap"),o.depth&&(e.depth=o.depth),e&&i.push(e),c._onLoadTexture()}),void 0,(function(){c._onLoadTexture()}))},Wy.prototype._loadUV2=function(){var e=this,t=this.url,i=this.fileLoader;i.setResponseType("arraybuffer"),i.load(t.uv2Url(),(function(t){e.uv2Buffer=new Uint16Array(t),e._onTaskFinished()}),void 0,(function(t){e._onTaskFinished()})),i.setResponseType(""),i.load(t.uv2MapItemUrl(),(function(t){e.uv2MapItem=JSON.parse(t),e._onTaskFinished()}),void 0,(function(t){e._onTaskFinished()}))},Wy.prototype.getUV2ById=function(e,t){if(this.uv2MapItem&&t){var i=this.uv2MapItem[e];if(i){var n=i.uv1Scale,r=i.uv1Translation,o=i.uv1ByteOffset/2,a=2*t;if(this.uv2Buffer){for(var s=this.uv2Buffer.slice(o,o+a),l=[],c=0;a>c;c+=2)l.push(n[0]*(s[c]/65535)+r[0]),l.push(n[1]*(s[c+1]/65535)+r[1]);return{lightmapIdx:i.lightmapIdx,uv2:l}}}}},Wy.prototype._loadSymbol=function(){var e=this,t=this.url,i=this.fileLoader;i.setResponseType("arraybuffer"),i.load(t.symbolUrl(),(function(t){e.parseSymbol(t),e._onTaskFinished()}),void 0,(function(t){e.model.dispatchEvent({type:Qd.LOAD_ERROR,errorType:Qd.LOAD_SYMBOL_ERROR,event:t}),e._onTaskFinished()}))},Wy.prototype.parseSymbol=function(e){this.descriptor.symbolReader=new Loader.SymbolReader(e)},Wy.prototype._loadOctree=function(e,t){var i=null,n=this.model.configLoader.transformInfos.transformMatrix;this.model.configLoader.transformInfos.octreeTransformed&&(i=new yt).copy(n).invert(),e&&this._loadOctreeBy(i,!1),t&&this._loadOctreeBy(i,!0)},Wy.prototype._loadOctreeBy=function(e,t){var i,n=this,r=this.url,o=this.fileLoader;i=r.octreeUrl(t?"i":"o"),o.setResponseType("arraybuffer"),o.load(i,(function(i){n._parseOctree(i,e,t),n._onTaskFinished()}),void 0,(function(e){n.model.dispatchEvent({type:Qd.LOAD_ERROR,errorType:Qd.LOAD_OCTREEINNER_ERROR,event:e}),n._onTaskFinished()}))},Wy.prototype._parseOctree=function(e,t,i){this.descriptor.octreeRootNode[i?"inner":"outer"]=this._getOctreeRootNode(e,t)},Wy.prototype._getOctreeRootNode=function(e,t){function i(e,i){t&&i.boundingBox.applyMatrix4(t),e.boundingBoxWorld=i.boundingBox.clone(),e.min=i.boundingBox.min,e.max=i.boundingBox.max,e.center=i.boundingBox.getCenter(),e.size=i.boundingBox.getSize().lengthSq(),e.childStart=i.child_s,e.childEnd=i.child_e}function n(e,t){e.octType=0,t.center.x>e.center.x&&(e.octType+=1),t.center.y>e.center.y&&(e.octType+=2),t.center.z>e.center.z&&(e.octType+=4)}var r=null,o=new Loader.OctreeReader(e);if(o.getCount()>0){var a=o.getNode(0);i(r=new Loader.OctreeNode(a.cell_id,0),a),function e(t,r){for(var o=t.childEnd,a=t.childStart;o>a;++a){var s=r.getNode(a),l=new Loader.OctreeNode(s.cell_id,t.depth);i(l,s),t.add(l),n(l,t),l.updateMaxDepth(),e(l,r)}}(r,o)}return o=null,r},Wy.prototype._loadUserId=function(){var e=this,t=this.url,i=this.fileLoader;i.setResponseType("arraybuffer"),i.load(t.userIdUrl(),(function(t){e._parseUserId(t),e._onTaskFinished()}),void 0,(function(t){e.model.dispatchEvent({type:Qd.LOAD_ERROR,errorType:Qd.LOAD_USERID_ERROR,event:t}),e._onTaskFinished()}))},Wy.prototype._parseUserId=function(e){this.descriptor.userIdReader=new Loader.IdReader(e)},Wy.prototype._loadUserData=function(){var e=this,t=this.url,i=this.fileLoader;i.setResponseType(""),i.load(t.userDataUrl(),(function(t){e._parseUserData(t),e._onTaskFinished()}),void 0,(function(t){e.model.dispatchEvent({type:Qd.LOAD_ERROR,errorType:Qd.LOAD_USERDATA_ERROR,event:t}),e._onTaskFinished()}))},Wy.prototype._parseUserData=function(e){this.descriptor.userDataReader=new Loader.UserDataReader(e)},Wy.prototype._loadCamera=function(){var e=this,t=this.url,i=this.fileLoader;i.setResponseType(""),i.load(t.cameraUrl(),(function(t){e._parseCamera(t),e._onTaskFinished()}),void 0,(function(t){e.model.dispatchEvent({type:Qd.LOAD_ERROR,errorType:Qd.LOAD_CAMERA_ERROR,event:t}),e._onTaskFinished()}))},Wy.prototype._parseCamera=function(e){var t=this.model.configLoader.transformInfos.transformMatrix;new Loader.CameraReader(e).parse(this.model,t)},Wy.prototype._parseGeo=function(e,t){for(var i=new Loader.MPKReader(e),n=new yt,r=0,o=i.header.meshCount;o>r;++r){var a=i.getPtBuffer(r),s=i.getIdxBuffer(r),l=i.getNormalBuffer(r),c=i.getMeshData(r),h=i.getUVBuffer(r);null!=a&&null!=s?(0!==c.baseScale&&(a=new Float32Array(a),n.identity(),n.setPosition(new Ke(c.baseX,c.baseY,c.baseZ)),n.scale(new Ke(c.baseScale,c.baseScale,c.baseScale)),GeomUtil.applyMatrix4ToBuffer(n,a)),this.descriptor.cacheReferencedMeshBufferData(c.mesh_id,{P:a,I:s,N:l,UV:h}),this.descriptor.cacheReferencedMeshGeoIds(t,c.mesh_id)):Logger.log("Error Geometry!")}i=null},Wy.prototype._loadBorderline=function(e){var t=this,i=this.url,n=this.fileLoader,r=i.borderLineUrl(e?1:0);n.setResponseType("arraybuffer"),n.load(r,(function(i){t._parseBorderLine(i,e),t._onTaskFinished()}),void 0,(function(e){t.model.dispatchEvent({type:Qd.LOAD_ERROR,errorType:Qd.LOAD_MATERIAL_ERROR,event:e}),t._onTaskFinished()}))},Wy.prototype._parseBorderLine=function(e,t){for(var i=new Loader.LineReader(e),n=[],r=0,o=i.header.lineCount;o>r;++r){var a=i.getLineData(r);n.push({meshId:a.line_id,positionStart:a.ptOffset/4,positionCount:3*a.ptCount,indexStart:a.idxOffset/4,indexCount:a.idxCount})}this.descriptor.cacheBorderLine(t,{P:i.ptBuffer,I:i.idxBuffer,IndexInfos:n}),i=null},Wy.prototype._isLoadGeoBorderlines=function(){var e=this.model.getConfig().metadata;return!(!xd.BorderLineBatched||!e.outline_mpk)},Wy.prototype.getAllBorderlineCount=function(){var e=this.model.getConfig().metadata;return this._isLoadGeoBorderlines()?e.outline_mpk:e.outline_0+e.outline_1},Wy.prototype._loadAllBorderlines=function(e){this._isLoadGeoBorderlines()?e.outline_mpk&&this._loadAllGeoBorderLines(e.outline_mpk):(e.outline_0&&this._loadBorderline(!1),e.outline_1&&this._loadBorderline(!0))},Wy.prototype.delayLoadBorderlines=function(e){this.model.getConfig(),this._isLoadGeoBorderlines()?this._delayLoadGeoBorderlines(e):this._delayLoadTogetherBorderlines(e)},Wy.prototype._delayLoadGeoBorderlines=function(e){var t=this.model.getConfig().metadata;this.startCallback=null,this.progressCallback=null,this.finishCallback=e,this.loadTaskCount=0,this.maxLoadTaskCount=t.outline_mpk,t.outline_mpk&&this._loadAllGeoBorderLines(t.outline_mpk)},Wy.prototype._delayLoadTogetherBorderlines=function(e){var t=this.model.getConfig().metadata;this.startCallback=null,this.progressCallback=null,this.finishCallback=e,this.loadTaskCount=0,this.maxLoadTaskCount=t.outline_0+t.outline_1,t.outline_0&&this._loadBorderline(!1),t.outline_1&&this._loadBorderline(!0)},Wy.prototype._loadAllGeoBorderLines=function(e){this.mpkBorderLineTaskManager||(this.mpkBorderLineTaskManager=new Uy);for(var t=0;e>t;++t)this.mpkBorderLineTaskManager.addTask(t);this.mpkBorderLineTaskManager.processTasks(this._loadGeoBorderLine.bind(this))},Wy.prototype._loadGeoBorderLine=function(e,t){var i=this,n=this.fileLoader,r=this.url,o=e>=this.model.getConfig().metadata.mpk_shared_index;n.setResponseType("arraybuffer"),n.load(r.mpkBorderLineUrl(e),(function(e){i._parseGeoBorderLine(e,o),t(),i._onTaskFinished()}),void 0,(function(e){i._onTaskFinished()}))},Wy.prototype._parseGeoBorderLine=function(e,t){for(var i=new Loader.LineReader(e),n=[],r=0,o=i.header.lineCount;o>r;++r){var a=i.getLineData(r);n.push({meshId:a.line_id,positionStart:a.ptOffset/4,positionCount:3*a.ptCount,indexStart:a.idxOffset/4,indexCount:a.idxCount})}this.descriptor.cacheBorderLine(t,{P:i.ptBuffer,I:i.idxBuffer,IndexInfos:n}),i=null},Wy.prototype.dealProgressSegment=function(e,t){return xd.MergeComponent?t*e.progressPercentage.load:t},Wy.prototype._loadWireframe=function(e){var t=this;if(xd.getDataFromIndexedDB&&!this.offLine){for(var i=this.url,n=[],r=0;e.length>r;r+=1)n.push(i.mpkUrl(e[r]));var o=this.model.getStorage();o&&o.getBatch(n,(function(e){for(var i=function(i){if(e[n[i]])if(!0===e[n[i]].split){var r=e[n[i]].list,l=new Uint8Array(e[n[i]].length);o.getBatch(r,(function(e){for(var o=!0,a=0;r.length>a;a+=1)e[r[a]]?l.set(new Uint8Array(e[r[a]]),4e7*a):(o=!1,Bu.error("获取分割几何失败"));if(o){var s=n[i].indexOf("fileKey=");t._parseWireframe(l.buffer,n[i].slice(s+8)),Bu.debug("load geo from local"),t._onTaskFinished()}else{var c=t.taskGeometrieManager;if(-1===(s=n[i].indexOf("fileKey=")))return void Bu.error("url is not has fileKey");c.addTask(n[i].slice(s+8)),Bu.debug("load geo from net"),t.taskGeometrieManager.processTasks(t.loadWireframe.bind(t))}}),(function(){Bu.error("获取分割几何失败")}))}else s=n[i].indexOf("fileKey="),t._parseWireframe(e[n[i]],n[i].slice(s+8)),Bu.debug("load geo from local"),t._onTaskFinished();else{if(a=t.taskGeometrieManager,-1===(s=n[i].indexOf("fileKey=")))return Bu.error("url is not has fileKey"),{v:void 0};a.addTask(n[i].slice(s+8)),Bu.debug("load geo from net")}},r=0;n.length>r;r+=1){var a,s,l=i(r);if("object"===nu(l))return l.v}t.taskGeometrieManager.processTasks(t.loadWireframe.bind(t))}),(function(){for(var i=t.taskGeometrieManager,n=0;e.length>n;n+=1)i.addTask(e[n]);i.processTasks(t.loadWireframe.bind(t))}))}else{for(var a=this.taskGeometrieManager,s=0;e.length>s;s+=1)a.addTask(e[s]);a.processTasks(t.loadWireframe.bind(t))}},Wy.prototype._loadGeo=function(e){var t=this;if(xd.getDataFromIndexedDB&&!this.offLine){for(var i=this.url,n=[],r=0;e.length>r;r+=1)n.push(i.mpkUrl(e[r]));var o=this.model.getStorage();o&&o.getBatch(n,(function(e){for(var i=function(i){if(e[n[i]])if(!0===e[n[i]].split){var r=e[n[i]].list,l=new Uint8Array(e[n[i]].length);o.getBatch(r,(function(e){for(var o=0;r.length>o;o+=1)e[r[o]]?l.set(new Uint8Array(e[r[o]]),4e7*o):Bu.error("获取分割几何失败");var a=n[i].indexOf("fileKey=");t._parseGeometrie(l.buffer,n[i].slice(a+8)),Bu.debug("load geo from local"),t._onTaskFinished()}),(function(){Bu.error("获取分割几何失败")}))}else s=n[i].indexOf("fileKey="),t._parseGeometrie(e[n[i]],n[i].slice(s+8)),Bu.debug("load geo from local"),t._onTaskFinished();else{if(a=t.taskGeometrieManager,-1===(s=n[i].indexOf("fileKey=")))return Bu.error("url is not has fileKey"),{v:void 0};a.addTask(n[i].slice(s+8)),Bu.debug("load geo from net")}},r=0;n.length>r;r+=1){var a,s,l=i(r);if("object"===nu(l))return l.v}t.taskGeometrieManager.processTasks(t.loadGeometrie.bind(t))}),(function(){for(var i=t.taskGeometrieManager,n=0;e.length>n;n+=1)i.addTask(e[n]);i.processTasks(t.loadGeometrie.bind(t))}))}else{for(var a=this.taskGeometrieManager,s=0;e.length>s;s+=1)a.addTask(e[s]);a.processTasks(t.loadGeometrie.bind(t))}},Wy.prototype._loadComponentNode=function(e){var t=this;if(xd.getDataFromIndexedDB&&!this.offLine){for(var i=this.url,n=[],r=0;e.length>r;r+=1)n.push(i.mpkUrl(e[r]));var o=this.model.getStorage();o&&o.getBatch(n,(function(e){for(var i=function(i){if(e[n[i]])if(!0===e[n[i]].split){var r=e[n[i]].list,l=new Uint8Array(e[n[i]].length);o.getBatch(r,(function(e){for(var o=0;r.length>o;o+=1)e[r[o]]?l.set(new Uint8Array(e[r[o]]),4e7*o):Bu.error("获取分割node失败");var a=n[i].indexOf("fileKey=");t._parseComponentNode(l.buffer,n[i].slice(a+8)),Bu.debug("load geo from local"),t._onTaskFinished()}),(function(){Bu.error("获取分割node失败")}))}else s=n[i].indexOf("fileKey="),t._parseComponentNode(e[n[i]],n[i].slice(s+8)),Bu.debug("load geo from local"),t._onTaskFinished();else{if(a=t.taskComponentNodeManager,-1===(s=n[i].indexOf("fileKey=")))return Bu.error("url is not has fileKey"),{v:void 0};a.addTask(n[i].slice(s+8)),Bu.debug("load component.node from net")}},r=0;n.length>r;r+=1){var a,s,l=i(r);if("object"===nu(l))return l.v}t.taskComponentNodeManager.processTasks(t.loadComponentNode.bind(t))}),(function(){for(var i=t.taskComponentNodeManager,n=0;e.length>n;n+=1)i.addTask(e[n]);i.processTasks(t.loadComponentNode.bind(t))}))}else{for(var a=this.taskComponentNodeManager,s=0;e.length>s;s+=1)a.addTask(e[s]);a.processTasks(t.loadComponentNode.bind(t))}},Wy.prototype._loadKDTree=function(e){var t=this;if(xd.getDataFromIndexedDB&&!this.offLine){for(var i=this.url,n=[],r=0;e.length>r;r+=1)n.push(i.kdTreeUrl(e[r]));var o=this.model.getStorage();o&&o.getBatch(n,(function(e){for(var i=0;n.length>i;i+=1){var r=n[i].indexOf("fileKey=");if(-1===r)return void Bu.error("url is not has fileKey");var o=n[i].slice(r+8);e[n[i]]?(t._parseKDTree(e[n[i]],o),Bu.debug("load kdTree from local"),t._onTaskFinished()):(t.loadKDTree(o,(function(){})),Bu.debug("load kdtree from net"))}}),(function(){for(var i=0;e.length>i;i+=1)t.loadKDTree(e[i],(function(){}))}))}else for(var a=0;e.length>a;a+=1)t.loadKDTree(e[a],(function(){}))},Wy.prototype._loadLights=function(e){var t=this;if(xd.getDataFromIndexedDB&&!this.offLine){for(var i=this.url,n=[],r=0;e.length>r;r+=1)n.push(i.lightUrl(e[r]));var o=this.model.getStorage();o&&o.getBatch(n,(function(e){for(var i=0;n.length>i;i+=1){var r=n[i].indexOf("fileKey=");if(-1===r)return void Bu.error("url is not has fileKey");var o=n[i].slice(r+8);e[n[i]]?(t._parseLight(e[n[i]],o),Bu.debug("load light from local"),t._onTaskFinished()):(t.loadLight(o,(function(){})),Bu.debug("load kdtree from net"))}}),(function(){for(var i=0;e.length>i;i+=1)t.loadLight(e[i],(function(){}))}))}else for(var a=0;e.length>a;a+=1)t.loadLight(e[a],(function(){}))},Wy.prototype._loadBones=function(e){var t=this;if(xd.getDataFromIndexedDB&&!this.offLine){for(var i=this.url,n=[],r=0;e.length>r;r+=1)n.push(i.bonesUrl(e[r]));var o=this.model.getStorage();o&&o.getBatch(n,(function(e){for(var i=0;n.length>i;i+=1)if(e[n[i]])t._parseBones(e[n[i]]),Bu.debug("load Bones from local"),t._onTaskFinished();else{var r=n[i].indexOf("fileKey=");if(-1===r)return void Bu.error("url is not has fileKey");t.loadBones(n[i].slice(r+8),(function(){})),Bu.debug("load Bones from net")}}),(function(){for(var i=0;e.length>i;i+=1)t.loadBones(e[i],(function(){}))}))}else{for(var a=this.taskComponentManager,s=0;e.length>s;s+=1)a.addTask(e[s]);a.processTasks(t.loadBones.bind(t))}},Wy.prototype._loadClips=function(e){var t=this;if(xd.getDataFromIndexedDB&&!this.offLine){for(var i=this.url,n=[],r=0;e.length>r;r+=1)n.push(i.clipsUrl(e[r]));var o=this.model.getStorage();o&&o.getBatch(n,(function(e){for(var i=0;n.length>i;i+=1)if(e[n[i]])t._parseClips(e[n[i]]),Bu.debug("load Clips from local"),t._onTaskFinished();else{var r=n[i].indexOf("fileKey=");if(-1===r)return void Bu.error("url is not has fileKey");t.loadClips(n[i].slice(r+8),(function(){})),Bu.debug("load Clips from net")}}),(function(){for(var i=0;e.length>i;i+=1)t.loadClips(e[i],(function(){}))}))}else{for(var a=this.taskComponentManager,s=0;e.length>s;s+=1)a.addTask(e[s]);a.processTasks(t.loadClips.bind(t))}},Wy.prototype._loadNodes=function(e){var t=this;if(xd.getDataFromIndexedDB&&!this.offLine){for(var i=this.url,n=[],r=0;e.length>r;r+=1)n.push(i.nodesUrl(e[r]));var o=this.model.getStorage();o&&o.getBatch(n,(function(e){for(var i=0;n.length>i;i+=1)if(e[n[i]])t._parseNodes(e[n[i]]),Bu.debug("load Nodes from local"),t._onTaskFinished();else{var r=n[i].indexOf("fileKey=");if(-1===r)return void Bu.error("url is not has fileKey");t.loadNodes(n[i].slice(r+8),(function(){})),Bu.debug("load Nodes from net")}}),(function(){for(var i=0;e.length>i;i+=1)t.loadNodes(e[i],(function(){}))}))}else{for(var a=this.taskComponentManager,s=0;e.length>s;s+=1)a.addTask(e[s]);a.processTasks(t.loadNodes.bind(t))}},Wy.prototype._loadComponent=function(e){var t=this;if(xd.getDataFromIndexedDB&&!this.offLine){for(var i=this.url,n=[],r=0;e.length>r;r+=1)n.push(i.mpkUrl(e[r]));var o=this.model.getStorage();o&&o.getBatch(n,(function(e){for(var i=0;n.length>i;i+=1){if(-1===(a=n[i].indexOf("fileKey="))&&!t.offLine)return void Bu.error("url is not has fileKey");var r=n[i].slice(a+8);if(e[n[i]])t._parseComponent(e[n[i]],r),Bu.debug("load com from local"),t._onTaskFinished();else{var o=t.taskComponentManager;if(t.offLine){var a;if(-1===(a=n[i].indexOf("data/")))return void Bu.error("url is not has data/");o.addTask(n[i].slice(a+5))}else o.addTask(r);o.processTasks(t.loadComponent.bind(t)),Bu.debug("load com from net")}}}),(function(){for(var i=t.taskComponentManager,n=0;e.length>n;n+=1)i.addTask(e[n]);i.processTasks(t.loadComponent.bind(t))}))}else{for(var a=this.taskComponentManager,s=0;e.length>s;s+=1)a.addTask(e[s]);a.processTasks(t.loadComponent.bind(t))}},Wy.prototype._loadReuseNode=function(e){var t=this;if(xd.getDataFromIndexedDB){for(var i=this.url,n=[],r=0;e.length>r;r+=1)n.push(i.mpkUrl(e[r]));var o=this.model.getStorage();o&&o.getBatch(n,(function(e){for(var i=0;n.length>i;i+=1)if(e[n[i]])t._parseReuseNodes(e[n[i]]),Bu.debug("load com from local"),t._onTaskFinished();else{var r=t.taskReuseNodeManager;if(t.offLine){if(-1===(o=n[i].indexOf("data/")))return void Bu.error("url is not has data/");r.addTask(n[i].slice(o+5))}else{var o;if(-1===(o=n[i].indexOf("fileKey=")))return void Bu.error("url is not has fileKey");r.addTask(n[i].slice(o+8))}r.processTasks(t.loadReuseNode.bind(t)),Bu.debug("load com from net")}}),(function(){for(var i=t.taskReuseNodeManager,n=0;e.length>n;n+=1)i.addTask(e[n]);i.processTasks(t.loadReuseNode.bind(t))}))}else{for(var a=this.taskReuseNodeManager,s=0;e.length>s;s+=1)a.addTask(e[s]);a.processTasks(t.loadReuseNode.bind(t))}},Wy.prototype._loadMaterial=function(e){var t=this;if(xd.getDataFromIndexedDB&&!this.offLine){for(var i=this.url,n=[],r=0;e.length>r;r+=1)n.push(i.mpkUrl(e[r]));var o=this.model.getStorage();o&&o.getBatch(n,(function(e){for(var i=0;n.length>i;i+=1)if(e[n[i]])t._parseMaterial(e[n[i]]),Bu.debug("load mat from local"),t._onTaskFinished();else{var r=t.taskMaterialManager,o=n[i].indexOf("fileKey=");if(-1===o)return void Bu.error("url is not has fileKey");r.addTask(n[i].slice(o+8)),r.processTasks(t.loadMaterial.bind(t)),Bu.debug("load mat from net")}}),(function(){for(var i=t.taskMaterialManager,n=0;e.length>n;n+=1)i.addTask(e[n]);i.processTasks(t.loadMaterial.bind(t))}))}else{for(var a=this.taskMaterialManager,s=0;e.length>s;s+=1)a.addTask(e[s]);a.processTasks(t.loadMaterial.bind(t))}},Wy.prototype._loadTextures=function(e){var t=this.model.materialManager.textures,i=this;if(xd.getDataFromIndexedDB&&!this.offLine){for(var n=this.url,r=[],o=0;e.length>o;o+=1)r.push(n.mpkUrl(e[o]));var a=this.model.getStorage();a&&a.getBatch(r,(function(e){for(var n=0;r.length>n;n+=1)if(e[r[n]]){var o,a=function(){if(-1===(o=r[n].indexOf("fileKey=")))return Bu.error("url is not has fileKey"),{v:void 0};var a=e[r[n]];e[r[n]]instanceof Blob||(a=new Blob([e[r[n]]],{type:"image/png"}));var s=r[n].slice(o+8),l=new Fe;Bu.debug("load tex from local"),t[s]=l;var c=document.createElementNS("http://www.w3.org/1999/xhtml","img");l.wrapS=l.wrapT=g,c.onload=function(t){"string"!=typeof e[r[n]]&&window.URL.revokeObjectURL(c.src),i.model.textureNeedsUpdate=!0,l.image=cA.ensurePowerOfTwo(c),i._onLoadTexture()},c.onerror=function(e){i.model.dispatchEventEx({type:Qd.LOAD_TEXTURE_ERROR}),i._onLoadTexture()},c.src="string"==typeof e[r[n]]?e[r[n]]:window.URL.createObjectURL(a),l.image=c,l.needsUpdate=!0}();if("object"===nu(a))return a.v}else{var s=i.taskTexturesManager,l=r[n].indexOf("fileKey=");if(-1===l)return void Bu.error("url is not has fileKey");s.addTask(r[n].slice(l+8)),s.processTasks(i.loadTextures.bind(i)),Bu.debug("load tex from net")}}),(function(){for(var t=i.taskTexturesManager,n=0;e.length>n;n+=1)t.addTask(e[n]);t.processTasks(i.loadTextures.bind(i))}))}else{for(var s=this.taskTexturesManager,l=0;e.length>l;l+=1)s.addTask(e[l]);s.processTasks(i.loadTextures.bind(i))}},Wy.prototype._loadAxisNet=function(e){if(e){var t=this;if(xd.getDataFromIndexedDB&&!this.offLine){var i=this.url.axisNetUrl(e),n=this.model.getStorage();n&&n.getBatch([i],(function(n){if(n[i])t._parseAxisNet(n[i]),Bu.debug("load axisnet from local");else{if(-1===i.indexOf("fileKey="))return void Bu.error("url is not has fileKey");t.loadAxisNet(e),Bu.debug("load axisnet from net")}}),(function(){t.loadAxisNet(e)}))}else t.loadAxisNet(e)}},Wy.prototype._parseWireframe=function(e,t){var i=new Ty.GeometryReader(e,this.dataVersion),n=this.descriptor;if(n){for(var r=i.geoCount,o=0;r>o;o+=1){var a=i.geomMap[o];void 0!==a.position&&void 0!==a.index?n.cacheReferencedMeshWireframeData(a.geoId,a):Bu.error("Error Geometry!")}i=null}},Wy.prototype._parseGeometrie=function(e,t){var i=this.fileKeyFromModelKey[t]||"",n=new ky.GeometryReader(e,this.dataVersion),r=this.descriptor;if(r){for(var o=n.geoCount,a=0;o>a;a+=1){var s=n.geomMap[a];void 0!==s.position&&void 0!==s.index&&void 0!==s.normal?(xd.DEBUG&&window.geoidToFileKeyMap&&(window.geoidToFileKeyMap[s.geoId]=t),r.cacheReferencedMeshBufferData(i+s.geoId,s)):Bu.error("Error Geometry!")}n=null}},Wy.prototype._parseComponentNode=function(e,t){var i=this.fileKeyFromModelKey[t]||"",n=new ky.NodesReader(e,this.dataVersion),r=this.descriptor;if(r){for(var o=n.nodeCount,a=0;o>a;a+=1){var s=n.geomMap[a];void 0!==s.matrix&&void 0!==s.material&&void 0!==s.nodeId?r.cacheReferencedMeshComponentNodeData(i+s.nodeId,s):Bu.error("Error Node!")}n=null}},Wy.prototype._parseMaterial=function(e,t){var i=this.descriptor;if(i){var n=new Dy(e,this.dataVersion);if(Array.isArray(n.materialMap)){var r=n.materialCount;if(0>r)return;for(var o=0;r>o;o+=1){var a=n.materialMap[o];i.cacheReferencedMeshMaterialData(a.matId,a)}}else for(var s in n.materialMap)i.cacheReferencedMeshMaterialData(s,n.materialMap[s]);n=null}},Wy.prototype._parseComponent=function(e,t){if(e){var i=new wy(e),n=i.compArr.length,r=this.descriptor;if(r){for(var o=0;n>o;o+=1){var a=i.compArr[o];r.cacheReferencedMeshComponentData(a.key,a)}i=null}}else Bu.error("没有数据")},Wy.prototype._parseKDTree=function(e,t){var i={};i="string"==typeof e?JSON.parse(e):e,!this.model.kdTreeNode&&i&&(this.model.kdTreeNode=new jy,this.model.kdTreeNode.init(i))},Wy.prototype._parseLight=function(e,t){var i,n=[];if(i="string"==typeof e?JSON.parse(e):e)for(var r=0,o=i.length;o>r;r+=1){var a=i[r],s=void 0,l=a.pos||[0,0,0],c=void 0;switch(a.type){case Dd.DirectionalLight:(s=new fc((new pi).fromArray(a.diffuse),.5)).position.set(l[0]-a.lookat[0],l[1]-a.lookat[1],l[2]-a.lookat[2]),s.name=a.parent,0===a.ambient[0]&&0===a.ambient[1]&&0===a.ambient[2]||(c=new mc((new pi).fromArray(a.ambient),.5));break;case Dd.PointLight:(s=new uc((new pi).fromArray(a.diffuse))).position.set(l[0],l[1],l[2]),s.name=a.parent,0===a.ambient[0]&&0===a.ambient[1]&&0===a.ambient[2]||(c=new mc((new pi).fromArray(a.ambient),.5));break;case Dd.SpotLight:(s=new sc((new pi).fromArray(a.diffuse),.5)).position.set(l[0]-a.lookat[0],l[1]-a.lookat[1],l[2]-a.lookat[2]),s.angle=a.cone_inn||Math.PI/2,s.name=a.parent,0===a.ambient[0]&&0===a.ambient[1]&&0===a.ambient[2]||(c=new mc((new pi).fromArray(a.ambient),.5))}s&&n.push(s),c&&n.push(c)}this.model.addLights(n)},Wy.prototype._parseNodes=function(e,t){var i=this.descriptor;if(i){var n={};n="string"==typeof e?JSON.parse(e):e,Bu.debug("nodes",n),i.cacheReferencedMeshNodesData(n)}},Wy.prototype._parseClips=function(e,t){var i=this.descriptor;if(i){var n={};n="string"==typeof e?JSON.parse(e):e,Bu.debug("clips",n),i.cacheReferencedMeshClipsData(n)}},Wy.prototype._parseBones=function(e,t){var i=new ky.BoneReader(e),n=this.descriptor;if(n){for(var r=i.boneCount,o=0;r>o;o+=1){var a=i.boneMap[o];Bu.debug("bones",a),n.cacheReferencedMeshBoneBufferData(a.geoId,a)}i=null}},Wy.prototype._parseAxisNet=function(e){var t=this.model.getBoundingBoxWorld(),i=0;t&&(i=t.min.z);var n=this.model._getNodeGroup(Vp.AXISNET);n.visible=!1;var r=new Ny(n);r.fromJSON(e,i);var o=new Py;o.axisNet=r,this.model.axisNetManager=o},Wy.prototype.loadWireframe=function(e,t){var i=this,n=this.loader,r=this.url,o=this.model,a=xd.GeoWorkerUrl;if(xd.UseGeoWorker)n.setResponseType("arraybuffer"),n.load(r.mpkUrl(e),(function(e){var n=new Worker(a);n.onmessage=function(e){var n=e.data;for(var r in n)n.hasOwnProperty(r);t(),i._onTaskFinished()},n.postMessage({msg:e})}));else{n.setResponseType("arraybuffer"),n.setCacheViable(!this.offLine);var s=n.load(r.mpkUrl(e),(function(n){i._parseWireframe(n,e),Bu.debug("geo load from online"),t(),i._onTaskFinished()}),void 0,(function(e){o.dispatchEventEx({type:Qd.LOAD_GEOMETRY_ERROR,modelKey:o.modelKey})}));i.requests.loadGeometrie=s}},Wy.prototype.loadGeometrie=function(e,t){var i=this,n=this.loader,r=this.url,o=this.model;n.setResponseType("arraybuffer"),n.setCacheViable(!this.offLine);var a=n.load(r.mpkUrl(e),(function(n){i._parseGeometrie(n,e),Bu.debug("geo load from online"),t(),i._onTaskFinished()}),void 0,(function(e){o.dispatchEventEx({type:Qd.LOAD_GEOMETRY_ERROR,modelKey:o.modelKey}),t(),i._onTaskFinished()}));i.requests.loadGeometrie=a},Wy.prototype.loadComponentNode=function(e,t){var i=this,n=this.loader,r=this.url,o=this.model;n.setResponseType("arraybuffer"),n.setCacheViable(!this.offLine);var a=n.load(r.mpkUrl(e),(function(n){i._parseComponentNode(n,e),Bu.debug("geo load from online"),t(),i._onTaskFinished()}),void 0,(function(e){o.dispatchEventEx({type:Qd.LOAD_COMPONENTNODE_ERROR,modelKey:o.modelKey}),t(),i._onTaskFinished()}));i.requests.loadComponentNode=a},Wy.prototype.loadMaterial=function(e,t){var i=this,n=this.loader,r=this.url,o=this.model,a=xd.GeoWorkerUrl;if(xd.UseGeoWorker)n.setResponseType("arraybuffer"),n.load(r.mpkUrl(e),(function(e){var n=new Worker(a);n.onmessage=function(e){var n=e.data;for(var r in n)n.hasOwnProperty(r);t(),i._onTaskFinished()},n.postMessage({msg:e})}));else{fy(i.dataVersion,"1")?n.setResponseType("json"):n.setResponseType("arraybuffer"),n.setCacheViable(!this.offLine);var s=n.load(r.mpkUrl(e),(function(e){i._parseMaterial(e),Bu.debug("met load from online"),t(),i._onTaskFinished()}),void 0,(function(e){o.dispatchEventEx({type:Qd.LOAD_MATERIAL_ERROR,modelKey:o.modelKey})}));i.requests.loadMaterial=s}},Wy.prototype.loadTextures=function(e,t){var i=this.model.materialManager.textures,n=this,r=this.Textureloader,o=this.url,a=this.model,s=xd.GeoWorkerUrl;if(xd.UseGeoWorker)r.load(o.mpkUrl(e),(function(e){var i=new Worker(s);i.onmessage=function(e){var i=e.data;for(var r in i)i.hasOwnProperty(r);t(),n._onTaskFinished()},i.postMessage({msg:e})}));else{r.setResponseType("arraybuffer"),r.setCacheViable(!this.offLine);var l=r.load(o.textureUrl(e),(function(r){var o=r;r instanceof Blob||(o=new Blob([r],{type:"image/png"})),Bu.debug("tex load from online");var s=new Fe;i[e]=s,s.wrapS=s.wrapT=g;var l=document.createElementNS("http://www.w3.org/1999/xhtml","img");l.onload=function(e){"string"!=typeof o&&window.URL.revokeObjectURL(l.src),s.image=cA.ensurePowerOfTwo(l),n._onLoadTexture(),t(),n.model.textureNeedsUpdate=!0},l.onerror=function(e){a.dispatchEventEx({type:Qd.LOAD_TEXTURE_ERROR,modelKey:a.modelKey}),n._onLoadTexture(),t()},l.src="string"==typeof o?o:window.URL.createObjectURL(o),s.image=l,s.needsUpdate=!0}),void 0,(function(e){a.dispatchEventEx({type:Qd.LOAD_TEXTURE_ERROR,modelKey:a.modelKey}),n._onLoadTexture(),t()}));n.requests.loadTextures=l}},Wy.prototype.loadComponent=function(e,t){var i=this,n=this.jsonLoader,r=this.model,o=this.url,a=xd.GeoWorkerUrl;if(xd.UseGeoWorker)n.setResponseType("json"),n.load(o.mpkUrl(e),(function(e){var n=new Worker(a);n.onmessage=function(e){var n=e.data;for(var r in n)n.hasOwnProperty(r);t(),i._onTaskFinished()},n.postMessage({msg:e})}),(function(e){}));else{n.setResponseType("json"),xd.useGzip&&n.setResponseType("arraybuffer"),n.setCacheViable(!0);var s=n.load(o.mpkUrl(e),(function(n){i._parseComponent(n,e),Bu.debug("component load from online"),t(),i._onTaskFinished()}),void 0,(function(e){r.dispatchEventEx({type:Qd.LOAD_COMPONENT_ERROR,modelKey:r.modelKey})}));i.requests.loadComponent=s}},Wy.prototype.loadKDTree=function(e,t){var i=this,n=this.loader,r=this.model,o=this.url,a=xd.GeoWorkerUrl;if(xd.UseGeoWorker)n.setResponseType("json"),n.load(o.mpkUrl(e),(function(e){var n=new Worker(a);n.onmessage=function(e){var n=e.data;for(var r in n)n.hasOwnProperty(r);t(),i._onTaskFinished()},n.postMessage({msg:e})}),(function(e){}));else{n.setResponseType("json"),n.setCacheViable(!this.offLine);var s=n.load(o.kdTreeUrl(e),(function(n){i._parseKDTree(n,e),Bu.debug("kdtree load from online"),t(),i._onTaskFinished()}),void 0,(function(e){r.dispatchEventEx({type:Qd.LOAD_COMPONENT_ERROR,modelKey:r.modelKey})}));i.requests.loadKDTree=s}},Wy.prototype.loadLight=function(e,t){var i=this,n=this.loader,r=this.model,o=this.url;n.setResponseType("json"),n.setCacheViable(!this.offLine);var a=n.load(o.lightUrl(e),(function(n){i._parseLight(n,e),Bu.debug("light load from online"),t(),i._onTaskFinished()}),void 0,(function(e){r.dispatchEventEx({type:Qd.LOAD_COMPONENT_ERROR,modelKey:r.modelKey})}));i.requests.loadLight=a},Wy.prototype.loadBones=function(e,t){var i=this,n=this.loader,r=this.model,o=this.url,a=xd.GeoWorkerUrl;if(xd.UseGeoWorker)n.setResponseType("arraybuffer"),n.load(o.bonesUrl(e),(function(e){var n=new Worker(a);n.onmessage=function(e){var n=e.data;for(var r in n)n.hasOwnProperty(r);t(),i._onTaskFinished()},n.postMessage({msg:e})}),(function(e){}));else{n.setResponseType("arraybuffer"),n.setCacheViable(!this.offLine);var s=n.load(o.bonesUrl(e),(function(e){i._parseBones(e),Bu.debug("bones load from online"),t(),i._onTaskFinished()}),void 0,(function(e){r.dispatchEventEx({type:Qd.LOAD_COMPONENT_ERROR,modelKey:r.modelKey})}));i.requests.loadBones=s}},Wy.prototype.loadClips=function(e,t){var i=this,n=this.loader,r=this.model,o=this.url,a=xd.GeoWorkerUrl;if(xd.UseGeoWorker)n.setResponseType("json"),n.load(o.mpkUrl(e),(function(e){var n=new Worker(a);n.onmessage=function(e){var n=e.data;for(var r in n)n.hasOwnProperty(r);t(),i._onTaskFinished()},n.postMessage({msg:e})}),(function(e){}));else{n.setResponseType("json"),n.setCacheViable(!this.offLine);var s=n.load(o.clipsUrl(e),(function(e){i._parseClips(e),Bu.debug("Clips load from online"),t(),i._onTaskFinished()}),void 0,(function(e){r.dispatchEventEx({type:Qd.LOAD_COMPONENT_ERROR,modelKey:r.modelKey})}));i.requests.loadClips=s}},Wy.prototype.loadNodes=function(e,t){var i=this,n=this.loader,r=this.model,o=this.url,a=xd.GeoWorkerUrl;if(xd.UseGeoWorker)n.setResponseType("json"),n.load(o.mpkUrl(e),(function(e){var n=new Worker(a);n.onmessage=function(e){var n=e.data;for(var r in n)n.hasOwnProperty(r);t(),i._onTaskFinished()},n.postMessage({msg:e})}),(function(e){}));else{n.setResponseType("json"),n.setCacheViable(!this.offLine);var s=n.load(o.nodesUrl(e),(function(e){i._parseNodes(e),Bu.debug("Nodes load from online"),t(),i._onTaskFinished()}),void 0,(function(e){r.dispatchEventEx({type:Qd.LOAD_COMPONENT_ERROR,modelKey:r.modelKey})}));i.requests.loadNodes=s}},Wy.prototype.loadAttribute=function(e,t){var i=this,n=this.loader,r=this.model,o=this.url,a=xd.GeoWorkerUrl;if(xd.UseGeoWorker)n.setResponseType("json"),n.load(o.mpkUrl(e),(function(e){var n=new Worker(a);n.onmessage=function(e){var n=e.data;for(var r in n)n.hasOwnProperty(r);t(),i._onTaskFinished()},n.postMessage({msg:e})}),(function(e){}));else{n.setResponseType("json"),n.setCacheViable(!this.offLine);var s=n.load(o.attributeUrl(),(function(e){if(e instanceof String)try{e=JSON.parse(e)}catch(e){}r.attributes=e,Bu.debug("Attribute load from online")}),void 0,(function(e){r.dispatchEventEx({type:Qd.LOAD_COMPONENT_ERROR,modelKey:r.modelKey})}));i.requests.loadAttribute=s}},Wy.prototype.loadGeopkOnDemand=function(e,t,i){this.loadTaskCount=0,this.maxLoadTaskCount=e.length,this._loadingOnDemand=!0,this.finishCallback=i;var n=this;if(xd.getDataFromIndexedDB&&!this.offLine){for(var r=this.url,o=[],a=0;e.length>a;a+=1)o.push(r.mpkUrl(e[a]));var s=this.model.getStorage();s&&s.getBatch(o,(function(e){for(var i=function(t){if(e[o[t]])if(!0===e[o[t]].split){var i=e[o[t]].list,r=new Uint8Array(e[o[t]].length);s.getBatch(i,(function(e){for(var a=0;i.length>a;a+=1)e[i[a]]?r.set(new Uint8Array(e[i[a]]),4e7*a):Bu.error("获取分割几何失败");var s=o[t].indexOf("fileKey=");n._parseGeometrie(r.buffer,o[t].slice(s+8)),Bu.debug("load geo from local"),n._onTaskFinished()}),(function(){Bu.error("获取分割几何失败")}))}else l=o[t].indexOf("fileKey="),n._parseGeometrie(e[o[t]],o[t].slice(l+8)),Bu.debug("load geo from local"),n._onTaskFinished();else{if(a=n.taskGeometrieManager,-1===(l=o[t].indexOf("fileKey=")))return Bu.error("url is not has fileKey"),{v:void 0};a.addTask(o[t].slice(l+8)),Bu.debug("load geo from net")}},r=0;o.length>r;r+=1){var a,l,c=i(r);if("object"===nu(c))return c.v}n.taskGeometrieManager.processTasks(n.loadGeometrie.bind(n),t)}),(function(){for(var i=n.taskGeometrieManager,r=0;e.length>r;r+=1)i.addTask(e[r]);i.processTasks(n.loadGeometrie.bind(n),t)}))}else{for(var l=this.taskGeometrieManager,c=0;e.length>c;c+=1)l.addTask(e[c]);l.processTasks(n.loadGeometrie.bind(n),t)}},Wy.prototype.loadAxisNet=function(e,t){var i=this,n=this.loader,r=this.url,o=this.model;fy(i.dataVersion,"1")?n.setResponseType("json"):n.setResponseType("arraybuffer"),n.setCacheViable(!this.offLine);var a=n.load(r.axisNetUrl(e),(function(e){i._parseAxisNet(e),Bu.debug("axis net load from online"),t&&t()}),void 0,(function(e){o.dispatchEventEx({type:Qd.LOAD_AXISNET_ERROR,modelKey:o.modelKey})}));i.requests.loadAxisNet=a},Wy.prototype.loadFloorInfo=function(e,t){var i=this;this._loadFloorInfoFromDB(e,(function(n){n&&n.data?(i._parseFloorInfo(n),t&&t(!0)):i._loadFloorInfoFromNet(e,(function(e){e?(i._parseFloorInfo(e),t&&t(!0)):t&&t(!1)}))}))},Wy.prototype._loadFloorInfoFromDB=function(e,t){if(xd.getDataFromIndexedDB&&!this.offLine){var i=this.url.floorInfoUrl(e),n=this.model.getStorage();n&&n.getBatch([i],(function(e){e[i]?(t(e[i]),Bu.debug("load floorinfo from local")):t()}),(function(){t()}))}else t()},Wy.prototype._loadFloorInfoFromNet=function(e,t){var i=new xy(this),n=this.url,r=this.model;this.model.accessToken&&i.setRequestHeader({Authorization:this.model.accessToken}),fy(this.dataVersion,"1")?i.setResponseType("json"):i.setResponseType("arraybuffer"),i.setCacheViable(!this.offLine);var o=i.load(n.floorInfoUrl(e),(function(e){Bu.debug("floor info load from online"),t&&t(e)}),void 0,(function(i){r.dispatchEventEx({type:Qd.LOAD_FLOORINFO_ERROR,modelKey:e}),t&&t()}));this.requests.loadFloorInfo=o},Wy.prototype._parseReuseNodes=function(e,t){if(e){xd.useGzip&&(e=JSON.parse(wp.ab2str(pako.ungzip(e))));var i=this.descriptor;i&&(i.referencedMeshCache.reuseNodes=e)}else Bu.error("没有数据")},Wy.prototype.loadReuseNode=function(e,t){var i=this,n=this.jsonLoader,r=this.model,o=this.url;n.setResponseType("json"),xd.useGzip&&n.setResponseType("arraybuffer"),n.setCacheViable(!0),n.load(o.mpkUrl(e),(function(e){i._parseReuseNodes(e),Bu.debug("component load from online"),t(),i._onTaskFinished()}),void 0,(function(e){r.dispatchEventEx({type:Qd.LOAD_COMPONENT_ERROR,modelKey:r.modelKey})}))},Wy.prototype._parseFloorInfo=function(e){if(e.data&&0!==Object.keys(e.data).length){var t=new Hy;t.floors=Gy.parseFloorInfos(e.data),t.modelKey=this.model.modelKey;var i=new Vy;i.floors=t.floors,t.floorExplosionInfo=i,t.modelType=this.model.getConfig().type,this.model.floorManager=t,t.model=this.model}};var Jy={IfcRoof:{color:[.837255,.203922,.270588,1]},IfcSlab:{color:[.637255,.603922,.670588,1]},IfcWall:{color:[.537255,.337255,.237255,1]},IfcWallStandardCase:{color:[.537255,.337255,.237255,1]},IfcDoor:{color:[.637255,.603922,.670588,1]},IfcWindow:{color:[.137255,.403922,.870588,.4]},IfcOpeningElement:{color:[.137255,.403922,.870588,.1]},IfcRailing:{color:[.137255,.403922,.870588,1]},IfcColumn:{color:[.137255,.403922,.870588,1]},IfcBeam:{color:[.137255,.403922,.870588,1]},IfcFurnishingElement:{color:[.137255,.403922,.870588,1]},IfcCurtainWall:{color:[.137255,.403922,.870588,1]},IfcStair:{color:[.637255,.603922,.670588,1]},IfcStairFlight:{color:[.637255,.603922,.670588,1]},IfcBuildingElementProxy:{color:[.5,.5,.5,1]},IfcFlowSegment:{color:[.137255,.403922,.870588,1]},IfcFlowitting:{color:[.137255,.403922,.870588,1]},IfcFlowTerminal:{color:[.137255,.403922,.870588,1]},IfcProxy:{color:[.137255,.403922,.870588,1]},IfcSite:{color:[.137255,.403922,.870588,1]},IfcLightFixture:{color:[.8470588235,.8470588235,.870588,1]},IfcDuctSegment:{color:[.8470588235,.427450980392,0,1]},IfcDistributionFlowElement:{color:[.8470588235,.427450980392,0,1]},IfcDuctFitting:{color:[.8470588235,.427450980392,0,1]},IfcPlate:{color:[.137255,.403922,.870588,.5]},IfcAirTerminal:{color:[.8470588235,.427450980392,0,1]},IfcMember:{color:[.8470588235,.427450980392,0,1]},IfcCovering:{color:[.8470588235,.427450980392,0,1]},IfcTransportElement:{color:[.8470588235,.427450980392,0,1]},IfcFlowController:{color:[.8470588235,.427450980392,0,1]},IfcFlowFitting:{color:[.8470588235,.427450980392,0,1]},IfcRamp:{color:[.8470588235,.427450980392,0,1]},IfcFurniture:{color:[.8470588235,.427450980392,0,1]},IfcFooting:{color:[.8470588235,.427450980392,0,1]},IfcSystemFurnitureElement:{color:[.8470588235,.427450980392,0,1]},IfcSpace:{color:[.137255,.303922,.570588,.5]},DEFAULT:{color:[.8470588235,.427450980392,0,1]}},zy=function(e){this.symbolReader=null,this.userIdReader=null,this.userDataReader=null,this.mapSceneReader={},this.lightmap=!1,this.mapNodeInfoByCategory={},this.mapNodeInfoByUserId={},this.mapNodeInfoByNodeId={},this.mapNodeInfoByComponentKey={},this.mapNodeInfoByParameterizedDesc={},this.mapNodeInfoByGeometryId={},this.referencedMeshCache={},this.componentCount=0,this.borderLines={},this.octreeRootNode={inner:null,outer:null,layer:null},this.meshCache={},this.allBones={},this.model=e};function qy(e,t){var i=null;"node"===e.type?i=new Yt:"bone"===e.type&&(i=new Aa,t.allBones[e.name]=i),i.name=lh.sanitizeNodeName(e.name),i.matrix.fromArray(e.transformation||[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1]),i.matrix.decompose(i.position,i.quaternion,i.scale);for(var n=0;e.children.length>n;n+=1){var r=qy(e.children[n],t);r&&i.add(r)}for(var o=0;e.meshes.length>o;o+=1){var a=e.meshes[o];t.model._getHandler().defaultManager.meshManager._readBufferInfo(t.model,[t.model.modelKey+"_"+e.meshes[o]]);var s=t.model._getHandler().defaultManager.meshManager._makeSkinMesh(t.model,[t.model.modelKey+"_"+e.meshes[o]],(function(e){}));t.meshCache[a]=s,s.name=e.name,i.add(s)}return i}zy.EnumNodeItemType={SYMBOL:0,MESH:1,TUBE:2,PIPE:3,BOX:4,BOX_M:5,PIPE_M:6,MESH_REF:7,LINE:8},zy.NodeInfoCategory={INSTANCED:0,STANDARD:1,MIX:2},zy.EnumDataType={NONE:0,MERGE_DATA:1,LAYER:2,LAYER_SCENE:3,ANIMATION:4},zy.EnumKeyframeTrackType={position:"position",scale:"scale",quaternion:"quaternion",weights:"weights"},zy.prototype.destroy=function(){this.destroyReader(),this.octreeRootNode=null,this.mapNodeInfoByCategory={},this.mapNodeInfoByUserId={},this.mapNodeInfoByNodeId={},this.mapNodeInfoByComponentKey={},this.mapNodeInfoByParameterizedDesc={},this.mapNodeInfoByGeometryId={},this.referencedMeshCache={},this.componentCount=0,this.borderLines={}},zy.prototype.destroyReader=function(){this.userIdReader={},this.userDataReader={},this.symbolReader={},this.mapSceneReader={}},zy.prototype.getSceneReaderMap=function(){return this.mapSceneReader},zy.prototype.isValidScene=function(){return!wp.isEmptyObject(this.getSceneReaderMap())||(Bu.log("model load not started!"),!1)},zy.prototype.parseItemData=function(e){var t=this.model;(my(t.dataVersion,"2.0.0")||void 0===t.dataVersion)&&(Bu.time("升级几何结构"),this._updateV1ToV2(t),t.dataVersion="2.0.0",Bu.timeEnd("升级几何结构")),this._readMaterialBuffer(t),t.hasAnimation&&xd.EnableAnimation?(this._parseClips(),this._parseBones()):this._parseGeo();var i={},n=this.referencedMeshCache;for(var r in Bu.time("_readItemData"),n.bufferData&&Object.keys(n.bufferData).length>0||e&&e(),n.components)this._readItemData(i,r,r,void 0,0);t.hasAnimation&&xd.EnableAnimation&&this._parseNodes(),Bu.timeEnd("_readItemData"),i=null,e&&e()},zy.prototype.asyncParseItemData=function(e){for(var t=this.getSceneReaderMap(),i=Object.keys(t),n=i.length,r=0,o=this,a=0;n>a;a+=1){var s=t[i[a]];wp.asyncProcess(s,s.header.componentCount,100,(function(e,t){o._parseItemDataBy(e,t)}),(function(){(r+=1)===n&&e&&e()}))}},zy.prototype._parseItemDataBy=function(e,t){for(var i=e.getComponentInfo(t),n=i.itemIndex;i.itemCount>n;n+=1)this._readItemData(e,n,t)},zy.prototype.parseItemDataByComponentKey=function(e){var t=this.getSceneReaderMap();for(var i in t)this._parseItemDataBy(t[i],e)},zy.prototype._readItemData=function(e,t,i){var n=this.referencedMeshCache.components[t];void 0!==n&&-1!==n.geoId&&this._readMeshInfo(e,i,n,null)},zy.prototype._readSymbolInfo=function(e,t,i){var n=this.symbolReader;if(n){var r=n.header.symbolCount,o=i.toData,a=e.getMatrixInfo(i.matrixId).matrix.clone(),s={matrix:a,ItemId:i.ItemId,originalId:i.originalId,userDataId:i.userDataId,materialId:i.materialId};if(o>=0&&r>o)for(var l=n.getSymbolInfo(o),c=l.itemIndex;l.itemCount>c;c+=1){var h=n.getItemInfo(c);h.type!==zy.EnumNodeItemType.SYMBOL&&this._readMeshInfo(n,t,h,s)}a=null,s=null,n=null}},zy.prototype._readMeshInfo=function(e,t,i,n){var r=null,o=null;null===n?(r=i.originalId,o=i.materials||i.matId):(r=n.originalId,o=n.materialId>-1?n.materialId:i.materialId);var a=null;if(a=this._getMeshNodeAttr(e,i,n)){if(i.buildInCategory&&(a.buildInCategory=i.buildInCategory),a.userId=t,a.name=i.name,a.type=i.type,a.componentKey=t,a.originalId=r,a.materialId=o,a.state=Nd.Visible,a.material=null,a.originMId=o,a.userData=null,a.categoryId=0,a.familyName=i.familyName,a.familySymbol=i.familySymbol,this.lightmap){var s=i.ItemId;n&&(s=n.ItemId+"_"+i.ItemId),a.itemIdUV2=s}a.instanceOrNot=!1,this._classifyNodeInfo(a),a=null}},zy.prototype._getMeshNodeAttrOfPipe=function(e,t,i){var n=e.getMatrixInfo(t.matrixId).matrix.clone();i&&n.multiplyMatrices(i.matrix,n);var r=t.boundingBox.clone();r.applyMatrix4(n);var o=e.getGeomPipeInfo(t.toData),a=o.startPt,s=o.endPt,l=new Ke;l.subVectors(s,a);var c=l.length();l.normalize();var h=o.radius;h>1||(h=100);var d=new Ke(0,1,0),u=new Ke(h,c,h),p=(new Ge).setFromUnitVectors(d,l),g=a.clone().addScaledVector(l,.5*c),f=(new yt).compose(g,p,u);return n.multiply(f),o=null,{nodeId:(i?i.ItemId+"_"+t.ItemId:t.ItemId)+"_pipe",geometryId:"pipe",boundingBox:r,matrix:n}},zy.prototype._getMeshNodeAttrOfTube=function(e,t,i){var n=this._getMeshNodeAttrOfPipe(e,t,i);return n.nodeId+="_tube",n.geometryId="tube",n},zy.prototype._getMeshNodeAttrOfBox=function(e,t,i){var n=e.getMatrixInfo(t.matrixId).matrix.clone();i&&n.multiplyMatrices(i.matrix,n);var r=t.boundingBox.clone();r.applyMatrix4(n);var o=t.boundingBox,a=o.getSize(),s=o.getCenter(),l=(new yt).scale(new Ke(a.x,a.y,a.z));return l.setPosition(s),n.multiply(l),{nodeId:(i?i.ItemId+"_"+t.ItemId:t.ItemId)+"_box",geometryId:"box",boundingBox:r,matrix:n}},zy.prototype._getMeshNodeAttrOfBoxM=function(e,t,i){var n=e.getMatrixInfo(t.matrixId).matrix.clone();i&&n.multiplyMatrices(i.matrix,n);var r=t.boundingBox.clone();return r.applyMatrix4(n),{nodeId:(i?i.ItemId+"_"+t.ItemId:t.ItemId)+"_boxM",geometryId:"boxM",boundingBox:r,matrix:n,uvArrayBuffer:e.getGeomBoxUvInfo(t.toData)}},zy.prototype._getMeshNodeAttrOfPipeM=function(e,t,i){var n=e.getMatrixInfo(t.matrixId).matrix.clone();i&&n.multiplyMatrices(i.matrix,n);var r=t.boundingBox.clone();return r.applyMatrix4(n),{nodeId:(i?i.ItemId+"_"+t.ItemId:t.ItemId)+"_pipeM",geometryId:"pipeM",boundingBox:r,matrix:n,uvArrayBuffer:e.getGeomPipeUvInfo(t.toData)}},zy.prototype._getMeshNodeAttrOfMeshRef=function(e,t,i){var n=e.getMatrixInfo(t.matrixId).matrix.clone();i&&n.multiplyMatrices(i.matrix,n);var r=t.boundingBox.clone();return r.applyMatrix4(n),{nodeId:"refMesh|"+(i?i.ItemId+"_"+t.ItemId:t.ItemId),geometryId:t.toData,boundingBox:r,matrix:n}},zy.prototype._getMeshNodeAttr=function(e,t,i,n){var r=new yt;r.fromArray(t.matrix||[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1]),xd.DataReduction&&r.scale(new Ke(1e3,1e3,1e3));var o=i?t.key+"_"+n:t.key,a=i?t.geoId+"_"+n:t.geoId;if(-1!==a){var s=new Nu,l=this.getReferencedMeshBufferById(t.geoId);return l&&l.position?(s=by.getBoundingBoxByBuffer(l.position)).applyMatrix4(r):Bu.error("没有找到对应几何"),{nodeId:o,guid:t.guid,geometryId:a,originalGeometryId:t.geoId,matrix:r,boundingBox:s,model:this.model}}},zy.prototype._getComponentNodeAttr=function(e,t){var i=new yt;i.fromArray(e.matrix||[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1]),xd.DataReduction&&i.scale(new Ke(1e3,1e3,1e3)),t&&i.multiplyMatrices(t.matrix,i);var n=e.nodeId,r=e.geoId;if(-1!==r){var o=e.maxBoundary||t.maxBoundary,a=e.minBoundary||t.minBoundary,s=new Nu;return s.set(a,o),{nodeId:n,guid:e.guid,geometryId:r,originalGeometryId:e.geoId,matrix:i,boundingBox:s,model:this.model}}},zy.prototype._getLineNodeAttr=function(e,t,i){var n=t.boundingBox.clone(),r=null;return-1!==t.matrixId?(r=e.getMatrixInfo(t.matrixId).matrix.clone(),i&&r.multiplyMatrices(i.matrix,r),n.applyMatrix4(r)):(r=new yt,i&&n.applyMatrix4(i.matrix)),{nodeId:i?"line-"+i.ItemId+"-"+t.ItemId:"line-"+t.ItemId,geometryId:"line-"+t.toData,boundingBox:n,matrix:r}},zy.prototype._classifyNodeInfo=function(e){this._cacheNodeInfoByComponentKey(e),this._cacheNodeInfoByNodeId(e),this._cacheNodeInfoByUserId(e),this._cacheNodeInfoByCategory(e),this._cacheNodeInfoByParameterizedDesc(e)},zy.prototype._cacheNodeInfoByComponentKey=function(e){void 0===this.mapNodeInfoByComponentKey[e.componentKey]&&(this.mapNodeInfoByComponentKey[e.componentKey]=[]),this.mapNodeInfoByComponentKey[e.componentKey].push(e)},zy.prototype._cacheNodeInfoByUserId=function(e){void 0===this.mapNodeInfoByUserId[e.userId]&&(this.mapNodeInfoByUserId[e.userId]=[]),this.mapNodeInfoByUserId[e.userId].push(e)},zy.prototype._cacheNodeInfoByNodeId=function(e){this.mapNodeInfoByNodeId[e.nodeId]=e},zy.prototype._cacheNodeInfoByCategory=function(e){var t=null;void 0===this.mapNodeInfoByCategory[t=e.instanceOrNot?zy.NodeInfoCategory.INSTANCED:zy.NodeInfoCategory.STANDARD]&&(this.mapNodeInfoByCategory[t]={}),void 0===this.mapNodeInfoByCategory[t][e.userId]&&(this.mapNodeInfoByCategory[t][e.userId]=[]),this.mapNodeInfoByCategory[t][e.userId].push(e)},zy.prototype._cacheNodeInfoByParameterizedDesc=function(e){e.parameterizedDesc&&(void 0===this.mapNodeInfoByParameterizedDesc[e.type]&&(this.mapNodeInfoByParameterizedDesc[e.type]=[]),this.mapNodeInfoByParameterizedDesc[e.type].push(e))},zy.prototype._clearNodeInfoCacheWithParameterizedDesc=function(e){if(e)for(var t=0,i=e.length;i>t;t+=1)delete this.mapNodeInfoByParameterizedDesc[e[t]];else this.mapNodeInfoByParameterizedDesc={}},zy.prototype._clearNodeInfoCacheWithComponentKey=function(e){if(e)for(var t=0,i=e.length;i>t;t+=1)delete this.mapNodeInfoByComponentKey[e[t]];else this.mapNodeInfoByComponentKey={}},zy.prototype._clearNodeInfoCacheWithCategory=function(e){if(e)for(var t=this.mapNodeInfoByCategory[zy.NodeInfoCategory.INSTANCED],i=this.mapNodeInfoByCategory[zy.NodeInfoCategory.STANDARD],n=0,r=e.length;r>n;n+=1)t&&delete t[e[n]],i&&delete i[e[n]];else this.mapNodeInfoByCategory={}},zy.prototype.clearNodeInfoCacheByComponentsKey=function(e){this._clearNodeInfoCacheWithComponentKey(e),this._clearNodeInfoCacheWithUserId(e),this._clearNodeInfoCacheWithCategory(e)},zy.prototype._clearNodeInfoCacheWithUserId=function(e){if(e)for(var t=0,i=e.length;i>t;t+=1)delete this.mapNodeInfoByUserId[e[t]],delete this.mapNodeInfoByNodeId[e[t]];else this.mapNodeInfoByUserId={};this.mapNodeInfoByUserId={}},zy.prototype.clearNodeInfoCache=function(){this._clearNodeInfoCacheWithComponentKey(),this._clearNodeInfoCacheWithUserId(),this._clearNodeInfoCacheWithCategory()},zy.prototype.getNodeInfosByComponentKey=function(e){return this.mapNodeInfoByComponentKey[e]},zy.prototype.getNodeInfosWithComponentKey=function(){return this.mapNodeInfoByComponentKey},zy.prototype.getAllNodeInfos=function(){return this.mapNodeInfoByUserId},zy.prototype.getNodeInfosByUserId=function(e){return this.mapNodeInfoByUserId[e]},zy.prototype.getNodeInfosByNodeId=function(e){return this.mapNodeInfoByNodeId[e]},zy.prototype.getNodeInfosWithUserId=function(){return this.mapNodeInfoByUserId},zy.prototype.getStandardNodeInfos=function(){return this.mapNodeInfoByCategory[zy.NodeInfoCategory.STANDARD]},zy.prototype.getInstancedNodeInfos=function(){return this.mapNodeInfoByCategory[zy.NodeInfoCategory.INSTANCED]},zy.prototype.getStandardUserIds=function(){return this.getStandardNodeInfos()?Object.keys(this.getStandardNodeInfos()):[]},zy.prototype.getInstancedUserIds=function(){return this.getInstancedNodeInfos()?Object.keys(this.getInstancedNodeInfos()):[]},zy.prototype.getStandardNodeInfosById=function(e){var t=this.getStandardNodeInfos();return t?t[e]:null},zy.prototype.getInstancedNodeInfosById=function(e){var t=this.getInstancedNodeInfos();return t?t[e]:null},zy.prototype._getUserIdsByCategory=function(e,t){var i=[],n=null;if(n=t===zy.NodeInfoCategory.INSTANCED?this.getInstancedNodeInfos():this.getStandardNodeInfos())for(var r=0,o=e.length;o>r;r+=1)n[e[r]]&&i.push(e[r]);return i},zy.prototype.getInstancedUserIdsByCategory=function(e){return this._getUserIdsByCategory(e,zy.NodeInfoCategory.INSTANCED)},zy.prototype.getStandardUserIdsByCategory=function(e){return this._getUserIdsByCategory(e,zy.NodeInfoCategory.STANDARD)},zy.prototype._traverseNodeInfosByIds=function(e,t,i){for(var n=0,r=t.length;r>n;n+=1){var o=t[n];i(o,e[o])}},zy.prototype.traverseStandardNodeInfos=function(e,t){var i=this.getStandardNodeInfos();i&&(e=e||this.getStandardUserIds(),this._traverseNodeInfosByIds(i,e,t))},zy.prototype.traverseInstancedNodeInfos=function(e,t){var i=this.getInstancedNodeInfos();i&&(e=e||this.getInstancedUserIds(),this._traverseNodeInfosByIds(i,e,t))},zy.prototype.traverseNodeInfosByComponent=function(e){for(var t=Object.keys(this.mapNodeInfoByComponentKey),i=0,n=t.length;n>i;i+=1)for(var r=t[i],o=this.mapNodeInfoByComponentKey[r],a=0,s=o.length;s>a;a+=1)e(r,o[a])},zy.prototype.clearReferencedMeshCache=function(){if(!xd.DEBUG){for(var e in this.referencedMeshCache)delete this.referencedMeshCache[e];this.referencedMeshCache=null}},zy.prototype.cacheReferencedMeshBufferData=function(e,t){this.referencedMeshCache.bufferData||(this.referencedMeshCache.bufferData={}),this.referencedMeshCache.bufferData[e]=t},zy.prototype.cacheReferencedMeshComponentNodeData=function(e,t){this.referencedMeshCache.componentNode||(this.referencedMeshCache.componentNode={}),this.referencedMeshCache.componentNode[e]=t},zy.prototype.cacheReferencedMeshWireframeData=function(e,t){this.referencedMeshCache.wireframeData||(this.referencedMeshCache.wireframeData={}),this.referencedMeshCache.wireframeData[e]=t},zy.prototype.getReferencedMeshBufferData=function(){return this.referencedMeshCache.bufferData},zy.prototype.getReferencedMeshBufferById=function(e){return this.referencedMeshCache&&this.referencedMeshCache.bufferData?this.referencedMeshCache.bufferData[e]:null},zy.prototype.getReferencedMeshComponentNodeById=function(e){return this.referencedMeshCache&&this.referencedMeshCache.componentNode?this.referencedMeshCache.componentNode[e]:null},zy.prototype.getReferencedMeshWireframeDataById=function(e){return this.referencedMeshCache&&this.referencedMeshCache.wireframeData?this.referencedMeshCache.wireframeData[e]:null},zy.prototype.cacheReferencedMeshBoneBufferData=function(e,t){this.referencedMeshCache.bones||(this.referencedMeshCache.bones={}),this.referencedMeshCache.bones[e]=t},zy.prototype.cacheReferencedMeshClipsData=function(e){this.referencedMeshCache.clips=e},zy.prototype.cacheReferencedMeshNodesData=function(e){this.referencedMeshCache.nodes=e},zy.prototype.cacheReferencedMeshComponentData=function(e,t){this.referencedMeshCache.components||(this.referencedMeshCache.components={}),this.referencedMeshCache.components[e]=t},zy.prototype.cacheReferencedMeshMaterialData=function(e,t){this.referencedMeshCache.materials||(this.referencedMeshCache.materials={}),this.referencedMeshCache.materials[e]=t},zy.prototype.cacheReferencedMeshGeoIds=function(e,t){this.referencedMeshCache.mpkIds||(this.referencedMeshCache.mpkIds={}),this.referencedMeshCache.mpkIds[e]||(this.referencedMeshCache.mpkIds[e]=[]),this.referencedMeshCache.mpkIds[e].push(t)},zy.prototype.clearReferencedMeshCacheByGeopkIdxs=function(e,t){if(this.referencedMeshCache.mpkIds)for(var i=0,n=e.length;n>i;i+=1){var r=e[i],o=this.referencedMeshCache.mpkIds[r];if(o){for(var a=0,s=o.length;s>a;a+=1)t&&t(o[a]),delete this.referencedMeshCache[o[a]];delete this.referencedMeshCache.mpkIds[r]}}},zy.prototype.cacheBorderLine=function(e,t){var i=e?"shared":"unique";this.borderLines[i]||(this.borderLines[i]=[]),this.borderLines[i].push(t)},zy.prototype.getSharedBorderLineCache=function(){return this.borderLines.shared},zy.prototype.getUniqueBorderLineCache=function(){return this.borderLines.unique},zy.prototype._isRegularShape=function(e){return e.type===zy.EnumNodeItemType.TUBE||e.type===zy.EnumNodeItemType.PIPE||e.type===zy.EnumNodeItemType.BOX||e.type===zy.EnumNodeItemType.BOX_M||e.type===zy.EnumNodeItemType.PIPE_M},zy.prototype._isInstancedNode=function(e){return!!xd.Instance&&(e.type===zy.EnumNodeItemType.MESH_REF?!!xd.SharedMeshInstanceEnable:!!e.parameterizedDesc)},zy.prototype.getComponentCount=function(){return this.componentCount},zy.prototype.getOctreeRootNode=function(){return this.octreeRootNode},zy.prototype.isUseInnerAndOuterOctree=function(){return!0},zy.prototype.isOctreeOuter=function(e){var t=this.octreeRootNode.inner||this.octreeRootNode.outer;return!(t.min.x>e.x||e.x>t.max.x||t.min.y>e.y||e.y>t.max.y||t.min.z>e.z||e.z>t.max.z)},zy.prototype.getOctreeRoots=function(e){this.octreeRootNode.outer&&e.push(this.octreeRootNode.outer),this.octreeRootNode.inner&&e.push(this.octreeRootNode.inner)},zy.prototype.updateOctreeNodeBy=function(e,t){var i=new He;function n(e,t){i.copy(e.boundingBoxWorld),i.applyMatrix4(t),e.min.copy(i.min),e.max.copy(i.max),e.center=i.getCenter(),e.size=i.getSize().lengthSq()}n(e,t),function e(t,i){for(var r=0,o=t.childOctants.length;o>r;r+=1){var a=t.childOctants[r];n(a,i),e(a,i)}}(e,t)},zy.prototype.updateOctreeNode=function(e){var t=this.getOctreeRootNode();t.outer&&this.updateOctreeNodeBy(t.outer,e),t.inner&&this.updateOctreeNodeBy(t.inner,e)},zy.prototype.removeFromSceneReaderMap=function(e){for(var t=0,i=e.length;i>t;t+=1)this.mapSceneReader[e[t]]&&delete this.mapSceneReader[e[t]]},zy.prototype.isUserIdExist=function(e){return!!this.getNodeInfosByUserId(e)},zy.prototype.addToNodeInfoMap=function(e){for(var t=0,i=e.length;i>t;t+=1)this._cacheNodeInfoByUserId(e[t])},zy.prototype.removeFromNodeInfoMap=function(e){for(var t=this.getAllNodeInfos(),i=0,n=e.length;n>i;i+=1){var r=e[i].userId;t[r]&&delete t[r]}},zy.prototype.cacheNodeInfosOnGeometryId=function(){var e=this.getStandardNodeInfos();for(var t in this.mapNodeInfoByGeometryId={},e)for(var i=e[t],n=0,r=i.length;r>n;n+=1)i[n].geometryId=this.convertGeometryId(i[n].geometryId),this.mapNodeInfoByGeometryId[i[n].geometryId]||(this.mapNodeInfoByGeometryId[i[n].geometryId]=[]),this.mapNodeInfoByGeometryId[i[n].geometryId].push(i[n])},zy.prototype.getNodeInfosOnGeometryId=function(){return this.mapNodeInfoByGeometryId||this.cacheNodeInfosOnGeometryId(),this.mapNodeInfoByGeometryId},zy.prototype.clearNodeInfosWithGeometryId=function(){this.mapNodeInfoByGeometryId={}},zy.prototype.convertGeometryId=function(e){return e},zy.prototype._readMaterialBuffer=function(e){var t=e.materialManager,i=t.materials,n=t.textures,r=this.referencedMeshCache.materials,o=1;for(var a in wp.isEmptyObject(e.subModel)||(o=.001),r){var s=r[a];if(!s)return null;var l=cA.createMaterialByMaterialBufferAndTexture(s,n,o);l.refreshUniforms&&l.refreshUniforms(),i[a]=l,xd.EnableShadow&&e.manager.viewerImpl.rendererManager.csm&&e.manager.viewerImpl.rendererManager.csm.setupMaterial(l)}},zy.prototype._updateV1ToV2=function(){var e=this.referencedMeshCache.components,t=this.referencedMeshCache.bufferData,i=this.referencedMeshCache.materials;for(var n in e)if(e.hasOwnProperty(n)){var r=e[n],o=r.matId,a=t[r.geoId];if(r.materials)continue;if(r.materials=[],!a)continue;var s=i[o];if(!s)continue;var l=this._updateMaterialV1ToV2(o,s);if(l)for(var c in a.materialIndex=l.materialIndex,r.materials=l.materialId,l.materials)l.materials.hasOwnProperty(c)&&(this.referencedMeshCache.materials[c]=l.materials[c])}},zy.prototype._updateMaterialV1ToV2=function(e,t){var i={},n=[],r={};if(!t)return null;for(var o=t.color,a=t.colorIndex,s=t.texture,l=t.textureIndex,c=0;o.length>c;c+=4){var h={};h.color=[o[c],o[c+1],o[c+2]],h.opacity=Math.floor(100*o[c+3])/100,h.transparent=1>o[c+3];var d=(255*h.color[0]<<16^255*h.color[1]<<8^255*h.color[2]<<0)+"_"+h.opacity;r[d]=h,n.push(d)}if(0!==s.length&&a.length===l.length)for(var u=-1,p=0;l.length>p;p+=1)if(u!==a[p]&&(u=a[p],-1!==l[p])){var g=n[a[p]],f=s[l[p]];if(r[g].map=f,-1===g.indexOf(f)){var m=g+"_"+s[l[p]];r[m]=r[g],n.length>Object.keys(r).length-1||delete r[g],n[a[p]]=m}}return i.materials=r,i.materialId=n,i.materialIndex=a,i},zy.prototype._computeVertexNormalsFromFaceNormals=function(e,t,i){for(var n=new Float32Array(i),r=0,o=0,a=0,s=0,l=0,c=0,h=0;e.length>h;h+=3)l=e[h+1],c=e[h+2],o=3*t[h+1],a=3*t[h+2],n[r=3*t[h]]=s=e[h],n[r+1]=l,n[r+2]=c,n[o]=s,n[o+1]=l,n[o+2]=c,n[a]=s,n[a+1]=l,n[a+2]=c;return n},zy.prototype._computeVertexNormalsFromIndex=function(e,t,i){var n=new Float32Array(t.length);if(t){var r=0,o=0,a=0,s=new Ke,l=new Ke,c=new Ke,h=new Ke,d=new Ke;if(e)for(var u=e,p=0;u.length>p;p+=3)o=3*u[p+1],a=3*u[p+2],s.fromArray(t,r=3*u[p]),l.fromArray(t,o),c.fromArray(t,a),h.subVectors(c,l),d.subVectors(s,l),h.cross(d),n[r]+=h.x,n[r+1]+=h.y,n[r+2]+=h.z,n[o]+=h.x,n[o+1]+=h.y,n[o+2]+=h.z,n[a]+=h.x,n[a+1]+=h.y,n[a+2]+=h.z;else for(var g=0,f=t.length;f>g;g+=9)s.fromArray(t,g),l.fromArray(t,g+3),c.fromArray(t,g+6),h.subVectors(c,l),d.subVectors(s,l),h.cross(d),n[g]=h.x,n[g+1]=h.y,n[g+2]=h.z,n[g+3]=h.x,n[g+4]=h.y,n[g+5]=h.z,n[g+6]=h.x,n[g+7]=h.y,n[g+8]=h.z}return n},zy.prototype.addMeshToInfoMap=function(e,t,i,n,r){var o=this.getNodeInfosByComponentKey(e);Array.isArray(o)&&o.forEach((function(e){e.nodeId===t&&(e.mesh=i,e.index=n,e.uv=e.uv||r)}))},zy.prototype._parseGeo=function(){Bu.time("处理几何:计算法线");var e=this.referencedMeshCache;for(var t in e.bufferData){var i=e.bufferData[t];i.position.length!==i.normal.length&&(i.normal=i.normal.length===i.index.length?this._computeVertexNormalsFromFaceNormals(i.normal,i.index,i.position.length):this._computeVertexNormalsFromIndex(i.index,i.position))}Bu.timeEnd("处理几何:计算法线")},zy.prototype._parseBones=function(){var e=this.referencedMeshCache;for(var t in e._offsetMatrix||(e._offsetMatrix={}),e.bufferData){var i=e.bufferData[t];i.position.length!==i.normal.length&&(i.normal=i.normal.length===i.index.length?this._computeVertexNormalsFromFaceNormals(i.normal,i.index,i.position.length):this._computeVertexNormalsFromIndex(i.index,i.position));var n=e.bones[t];if(n){i.skinIndex=n.skinIndex,i.skinWeight=n.skinWeight;var r=n.name;n.offsetMatrix.length/16!==r.length&&Bu.debug("bones的name数量与Matrix数量不符");for(var o=0;r.length>o;o+=1)e._offsetMatrix[r[o]]=(new yt).fromArray(n.offsetMatrix,16*o)}}},zy.prototype._parseClips=function(){for(var e=this.referencedMeshCache.clips,t=[],i=0,n=e.length;n>i;i+=1){for(var r=[],o=e[i],a=0,s=o.tracks.length;s>a;a+=1){var l=o.tracks[a],c=null;switch(l.type){case zy.EnumKeyframeTrackType.weights:c=gl;break;case zy.EnumKeyframeTrackType.quaternion:c=ml;break;case zy.EnumKeyframeTrackType.position:case zy.EnumKeyframeTrackType.scale:default:c=yl}if(0===o.ticksPerSec){o.ticksPerSec=1e3;for(var h=0;l.times.length>h;h+=1)l.times[h]/=o.ticksPerSec}var d=new c(lh.sanitizeNodeName(l.name)+"."+l.type,l.times,l.values,2301);r.push(d)}var u=new vl(void 0!==o.name?o.name:"animation_"+i,o.duration/o.ticksPerSec,r);t.push(u)}this.model.animations=t},zy.prototype._parseNodes=function(){var e=this.referencedMeshCache;e.allBones=[],e.offsetMatrix=[];var t=qy(e.nodes,this);for(var i in e.bufferData){var n=this.meshCache[i];if(n&&n.isSkinnedMesh){for(var r=[],o=[],a=0;e.bones[i].name.length>a;a+=1){var s=e.bones[i].name[a],l=e._offsetMatrix[s],c=this.allBones[s];l&&c&&(r.push(c),o.push(l))}var h=new Ia(r,o);n.bind(h,n.matrixWorld)}}this.model.nodes=t,this.model.manager.getScene().onBeforeRender=function(e,t,i,n){t.updateMatrixWorld(!0)},this.model.group.add(t),(h=new bh(t)).visible=!1,this.model.skeleton=h,this.model.group.add(h),this.model.mixer=new dh(t),this.model.actions=[];for(var d=0;this.model.animations.length>d;d+=1){var u=this.model.mixer.clipAction(this.model.animations[d]);this.model.actions.push(u)}};var Zy=function(e){zy.call(this,e),this.instancedComponent={}};Object.assign(Zy.prototype,zy.prototype),Zy.prototype.parseItemData=function(e){var t=this.model;(my(t.dataVersion,"2.0.0")||void 0===t.dataVersion)&&(Bu.time("升级几何结构"),this._updateV1ToV2(t),t.dataVersion="2.0.0",Bu.timeEnd("升级几何结构")),this._readMaterialBuffer(t),t.hasAnimation&&xd.EnableAnimation?(this._parseClips(),this._parseBones()):(this._parseGeo(),xd.Instance&&Ay(t.dataVersion,"2.0.0")&&this._parseInstanced());var i={},n=this.referencedMeshCache;if(Bu.time("_readItemData"),!n.bufferData||0>=Object.keys(n.bufferData).length)return Bu.warn("缺少几何数据"),!0;for(var r in n.components)this._readItemData(i,r,r,void 0,0);Bu.timeEnd("_readItemData"),i=null,e&&e()},Zy.prototype._readMeshInfo=function(e,t,i,n){var r=this.model.materialManager.materials,o=null,a=null,s=null,l=this.referencedMeshCache;if((i.nodes||i.nodeIds)&&fy(this.model.dataVersion,"2.0.0")){a=i.originalId;var c=i,h=(new yt).fromArray(c.matrix||[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1]);c.matrix=h;var d=[];d=c.nodes?c.nodes:c.nodeIds;for(var u=0;d.length>u;u+=1){var p=d[u];if("object"!==nu(p)&&(p=this.getReferencedMeshComponentNodeById(p)),p){var g,f=null;if(s="",-1!==p.geoId)if(f=this._getComponentNodeAttr(p,c,u)){if(c.buildInCategory&&(f.buildInCategory=c.buildInCategory),!r[s=p.material]){var m=Jy[c.type]?Jy[c.type].color:void 0;m||(Bu.log("Material not found for type: ",c.type),m=Jy.DEFAULT.color),m||(Bu.log("Default material not found for type: ",c.type),m=[1,1,1,1]);var A=new pi(m[0],m[1],m[2]),y=s||A.getHexString()+"_"+m[3],v=r[y];v||(Bu.warn("缺少材质 "+s),v=cA.createStandardMaterial({color:A}),1>m[3]&&(v.transparent=!0,v.opacity=m[3]),v.side=2,r[y]=v),f.material=s=y}if(r[s].aoMap){var C=this.getReferencedMeshBufferById(f.geometryId);C&&(C.uv2=C.uv)}g=f.nodeId;var I=(D=this.userDataReader)?D.getUserData(o):null;f.type=c.type,f.userId=t,f.name=c.name,f.userDataId=o,f.originalId=a,f.materialId=s,f.originMId=s,f.userData=I,f.categoryId=0,f.componentKey=t,f.familyName=c.familyName,f.familySymbol=c.familySymbol;var x=xd.Instance,w=l.reuseNodes.hasOwnProperty(g);f.instanceOrNot=!(!x||!w),f.isBatched=!0,f.state=Nd.Visible,f.material=null,this._classifyNodeInfo(f),f=null}else Bu.debug("非法node")}}}else if(null===n?(o=i.userDataId,a=i.originalId,s=i.materialId||i.matId):(o=n.userDataId,a=n.originalId,s=n.materialId>-1?n.materialId:i.materialId),i.materials||(i.materials=[]),i.materials.length>0)for(u=0;i.materials.length>u;u+=1){var M=null;if(M=this._getMeshNodeAttr(e,i,i.materials.length>1,u),!r[s=i.materials[u]]){var E=Jy[i.type]?Jy[i.type].color:void 0;E||(Bu.log("Material not found for type: ",i.type),E=Jy.DEFAULT.color),E||(Bu.log("Default material not found for type: ",i.type),E=[1,1,1,1]);var B=new pi(E[0],E[1],E[2]),S=s||B.getHexString()+"_"+E[3],b=r[S];b||(Bu.warn("缺少材质 "+s),b=cA.createStandardMaterial({color:B}),1>E[3]&&(b.transparent=!0,b.opacity=E[3]),b.side=2,r[S]=b)}if(r[s].aoMap){var k=this.getReferencedMeshBufferById(M.geometryId);k&&(k.uv2=k.uv)}if(!M)return;var D;I=(D=this.userDataReader)?D.getUserData(o):null;M.type=i.type,M.userId=t,M.name=i.name,M.userDataId=o,M.originalId=a,M.materialId=s,M.originMId=s,M.userData=I,M.categoryId=0,M.componentKey=t,M.familyName=i.familyName,M.familySymbol=i.familySymbol,xd.Instance&&this.instancedComponent[t]?M.instanceOrNot=!0:(M.instanceOrNot=!1,this.instancedGeo[M.originalGeometryId].length>1&&(M.originalGeometryId="")),M.state=Nd.Visible,M.material=null,M.isBatched=!0,this._classifyNodeInfo(M),M=null}else{var T=null,R=Jy[i.type]?Jy[i.type].color:void 0;R||(Bu.log("Material not found for type: ",i.type),R=Jy.DEFAULT.color),R||(Bu.log("Default material not found for type: ",i.type),R=[1,1,1,1]);var U=new pi(R[0],R[1],R[2]),F=U.getHexString()+"_"+R[3],Q=r[F];if(Q||(Q=cA.createStandardMaterial({color:U}),1>R[3]&&(Q.transparent=!0,Q.opacity=R[3]),Q.side=2,r[F]=Q),i.materials.push(F),T=this._getMeshNodeAttr(e,i,!1,0),s=i.materials[0],!T)return;i.buildInCategory&&(T.buildInCategory=i.buildInCategory);t=i.key;T.type=i.type,T.userId=t,T.name=i.name,T.originalId=a,T.materialId=s,T.originMId=s,T.userData={},T.categoryId=0,T.componentKey=t,T.familyName=i.familyName,T.familySymbol=i.familySymbol,T.instanceOrNot=!(!xd.Instance||!this.instancedComponent[t]),T.isBatched=!0,T.state=Nd.Visible,T.material=null,this._classifyNodeInfo(T),T=null}},Zy.prototype._parseGeo=function(){Bu.time("处理几何:按材质拆分构件");var e=this.referencedMeshCache;for(var t in e.bufferData){var i=e.bufferData[t];if(i.position.length!==i.normal.length&&(i.normal=i.normal.length===i.index.length?this._computeVertexNormalsFromFaceNormals(i.normal,i.index,i.position.length):this._computeVertexNormalsFromIndex(i.index,i.position)),void 0!==i.materialIndex){for(var n=void 0,r=[],o=null,a=0;i.materialIndex.length>a;a+=1){var s=i.materialIndex[a];s!==o&&(o=s,void 0!==n&&(n.count=3*a-n.start,r.push(n)),n={start:3*a,materialIndex:o})}if(void 0!==n&&(n.count=3*i.materialIndex.length-n.start,r.push(n)),1===r.length){e.bufferData[t+"_"+r[0].materialIndex]=i}else{for(var l={},c=0;r.length>c;c+=1){var h=r[c];void 0===l[h.materialIndex]&&(l[h.materialIndex]={index:[],count:0}),l[h.materialIndex].index.push({start:h.start,count:h.count}),l[h.materialIndex].count+=h.count}var d=function(){p={},g=l[u];for(var n=0,r=new Uint32Array(g.count),o=0;g.index.length>o;o+=1){var a=g.index[o],s=i.index.slice(a.start,a.start+a.count);r.set(s,n),n+=a.count}f={},r.forEach((function(e,t){f[e]||(f[e]=[]),f[e].push(t)}));var c=Object.keys(f).length;m=new Float32Array(3*c),A=new Float32Array(3*c),y=new Float32Array(2*c),v=0,C=0;var h=0;for(var d in f)if(f.hasOwnProperty(d)){d=Number(d);var I=i.position.slice(3*d,3*d+3),x=i.normal.slice(3*d,3*d+3);if(i.uv.length>0){var w=i.uv.slice(2*d,2*d+2);y.set(w,C),C+=2}m.set(I,v),A.set(x,v),v+=3,f[d].forEach((function(e){r[e]=h})),h+=1}p.index=r,p.position=m,p.normal=A,i.uv&&i.uv.length>0&&(p.uv=y),e.bufferData[t+"_"+u]=p};for(var u in l){var p,g,f,m,A,y,v,C;d()}}}}Bu.timeEnd("处理几何:按材质拆分构件")},Zy.prototype._parseInstanced=function(){Bu.time("_parseInstanced"),this.instancedComponent={};var e={},t={},i=this.referencedMeshCache,n=this.model.materialManager.materials;for(var r in i.components)if(i.components.hasOwnProperty(r)){var o=i.components[r];if((o.nodeIds||o.nodes)&&fy(this.model.dataVersion,"2.0.0"))continue;var a=o.geoId;if(-1===a){Bu.debug("实体没有几何");continue}if(void 0===e[a]&&(e[a]=[]),e[a].push(1),!o.materials||1>o.materials.length){o.materials=[];var s=Jy[o.type]?Jy[o.type].color:void 0;s||(Bu.log("Material not found for type: ",o.type),s=Jy.DEFAULT.color),s||(Bu.log("Default material not found for type: ",o.type),s=[1,1,1,1]);var l=new pi(s[0],s[1],s[2]),c=l.getHexString()+"_"+s[3],h=n[c];h||(Bu.warn("缺少材质 "+c),h=cA.createStandardMaterial({color:l}),1>s[3]&&(h.transparent=!0,h.opacity=s[3]),h.side=2,n[c]=h),o.materials.push(c)}for(var d=0,u=o.materials.length;u>d;d+=1){var p=o.materials[d]+"&"+a;void 0===t[p]&&(t[p]=[]),t[p].push({componentKey:r})}}for(var g in this.instancedGeo=e,t)if(t.hasOwnProperty(g))if(1<t[g].length)for(var f=0;t[g].length>f;f+=1)this.instancedComponent[t[g][f].componentKey]=!0;else delete t[g];Bu.timeEnd("_parseInstanced")};var Xy=function(e){lu(i,e);var t=pu(i);function i(e){var n;return ru(this,i),(n=t.call(this,e)).descriptor=new Zy(e.model),n}return i}(Wy);Xy.prototype.loadSceneAndGeos=function(e){var t=e.scene,i=this.model,n=t.geometries.length||0,r=[];if(this.map={},my(this.dataVersion,"2.0.0"))for(var o=0;n>o;o+=1)t.geometries[o].fileKey?r.push(t.geometries[o].fileKey):i.dispatchEventEx({type:Qd.SCENE_NOT_CLOSE,modelKey:i.modelKey});else r=t.geometries;this.maxLoadTaskCount+=n,this._loadGeo(r)},Xy.prototype.getSceneTaskCount=function(e){var t=e.scenes;return t+=e.lines,t+=e.mpks,xd.BorderLineDelayLoaded||(t+=this.getAllBorderlineCount()),t};var _y=function(e){this.model=e,this.defaultManager=null,this.instancedManager=null,this.model=e,this.loader=null,this.loaded=!1,this.dataReady=!1,this.borderlinesLoaded=!1,this.borderlinesGenerated=!1};_y.prototype.destroy=function(){this.model=null,this.defaultManager.destroy(),this.defaultManager=null,this.instancedManager.destroy(),this.instancedManager=null,this.loader&&(this.loader.destroy(),this.loader=null)},_y.prototype.load=function(e){var t=this,i=this.model;this.loader.setNotifyProgress(e),this.loader.load((function(){i.manager.dispatchEvent({type:Fd.ON_LOAD_START,modelKey:i.modelKey})}),(function(e){i.manager.dispatchEvent({type:Fd.ON_LOAD_PROGRESS,progress:e,modelKey:i.modelKey})}),(function(){t.prepareData((function(){t.processLoadCompleted((function(){i.manager.dispatchEvent({type:Fd.ON_LOAD_COMPLETE,modelKey:i.modelKey})}))}))}))},_y.prototype.processLoadCompleted=function(e){var t=this.model;t.materialManager._updateTextureMapping(),t.materialManager._updateIBL(t),t.setLoaded(!0);var i=t.manager.filter,n=t.manager.getNodeInfos();i.initFilterManager(n),requestAnimationFrame((function(){e&&e(),t.hasAnimation&&xd.EnableAnimation&&t.createPanel(),t.updateMeshNodes(),t.applyFilter(),t.debut(t)}))},_y.prototype.prepareData=function(e){if(!this.dataReady){var t=this;this.loader.getDescriptor().parseItemData((function(){t.dataReady=!0,t.settleData(e)}))}},_y.prototype.prepareWireframe=function(e,t){if(e.isActivateWireframe())if(xd.BorderLineDelayLoaded&&this.loader.getAllBorderlineCount())if(this.borderlinesLoaded)this.borderlinesGenerated&&(this.defaultManager.asyncGenerateWireframe(e),this.instancedManager.generateWireframe(e));else{this.borderlinesLoaded=!0;var i=this;this.loader.delayLoadBorderlines((function(){i.instancedManager.generateWireframe(e),i.defaultManager.asyncGenerateWireframe(e,(function(){i.borderlinesGenerated=!0,t&&t()}))}))}else this.defaultManager.generateWireframe(e),this.instancedManager.generateWireframe(e)},_y.prototype.prepare=function(e){},_y.prototype.needUpdate=function(){return!0},_y.prototype.updateNodes=function(){this.defaultManager.updateNodes(this.model),xd.Instance&&this.instancedManager.updateNodes(this.model)},_y.prototype.isLoaded=function(){return this.loaded},_y.prototype.isDataReady=function(){return this.loaded},_y.prototype.isAllReady=function(){return!0},_y.prototype.isHidden=function(){var e=this.model;return!e.visible&&(e.manager.scene.removeGroupByName(e._getWireframeGroupName()),!0)},_y.prototype.settleData=function(e){},_y.prototype.addNodeInfoToOctantMap=function(){},_y.prototype.applyFilter=function(){this.isLoaded()&&(this.defaultManager.applyFilter(this.model),xd.Instance&&this.instancedManager.applyFilter(this.model))},_y.prototype.applySelection=function(){this.isLoaded()&&(this.defaultManager.applySelection(this.model),xd.Instance&&this.instancedManager.applySelection(this.model))},_y.prototype.clearSelection=function(){this.isLoaded()&&(this.defaultManager.clearSelection(this.model),xd.Instance&&this.instancedManager.clearSelection(this.model))},_y.prototype.applyHover=function(){this.isLoaded()&&(this.defaultManager.applyHover(this.model),xd.Instance&&this.instancedManager.applyHover(this.model))},_y.prototype.clearHover=function(){this.isLoaded()&&(this.defaultManager.clearHover(this.model),xd.Instance&&this.instancedManager.clearHover(this.model))},_y.prototype.applyBlink=function(){this.isLoaded()&&(this.defaultManager.applyBlink(this.model),xd.Instance&&this.instancedManager.applyBlink(this.model))},_y.prototype.clearBlink=function(){this.isLoaded()&&(this.defaultManager.clearBlink(this.model),xd.Instance&&this.instancedManager.clearBlink(this.model))},_y.prototype.applyReplacement=function(){this.isLoaded()&&(this.defaultManager.applyReplacement(this.model),xd.Instance&&this.instancedManager.applyReplacement(this.model))},_y.prototype.getMeshesByUserIds=function(e){if(this.isLoaded()){var t=this.defaultManager.getMeshesByUserIds(this.model,e),i=[];return xd.Instance&&(i=this.instancedManager.getMeshesByUserId(this.model,e)),[].concat(t).concat(i)}},_y.prototype.rebuildIndicesforLightmap=function(){this.defaultManager.rebuildIndices(this.model)},_y.prototype.adjustVisibility=function(e){this.defaultManager.adjustVisibility(this.model,e)},_y.prototype.changeVisibilityOfSelectedObjects=function(e){this.defaultManager.changeVisibilityOfSelectedObjects(this.model,e)},_y.prototype.changeVisibilityOfNonSelectedObjects=function(e){this.defaultManager.changeVisibilityOfNonSelectedObjects(this.model,e)},_y.prototype.adjustInstanceVisibility=function(e){this.instancedManager.adjustVisibility(this.model,e)},_y.prototype.changeInstanceVisibilityOfSelectedObjects=function(e){this.instancedManager.changeVisibilityOfSelectedObjects(this.model,e)},_y.prototype.changeInstanceVisibilityOfNonSelectedObjects=function(e){this.instancedManager.changeVisibilityOfNonSelectedObjects(this.model,e)},_y.prototype.restoreVisibilityOfObjects=function(){this.defaultManager.restoreVisibilityOfObjects(),this.instancedManager.restoreVisibilityOfObjects()},_y.prototype.getBlinkMaterials=function(){var e=[],t=this.model.materialManager.instanceMaterials;for(var i in t)for(var n=t[i],r=0,o=n.length;o>r;r+=1)e.push(n[r]);return e=e.concat(this.defaultManager.meshManager.getBlinkMaterials())},_y.prototype.disposeBufferAfterVbo=function(){this.isLoaded()&&(this.defaultManager.disposeBufferAfterVbo(),this.instancedManager.disposeBufferAfterVbo())},_y.prototype.getGeometryBuffersByUserId=function(e){if(!this.isLoaded())return[];var t=[];return t=(t=t.concat(this.defaultManager.getGeometryBuffersByUserId(this.model,e))).concat(this.instancedManager.getGeometryBuffersByUserId(this.model,e))},_y.prototype.unloadComponents=function(e){},_y.prototype.explosion=function(e){this.isLoaded()&&(this.defaultManager.explosion(this.model,e),xd.Instance&&this.instancedManager.explosion(this.model,e))},_y.prototype.closeExplosion=function(){this.isLoaded()&&(this.defaultManager.closeExplosion(this.model),xd.Instance&&this.instancedManager.closeExplosion(this.model))},_y.prototype.componentsExplosion=function(e){this.isLoaded()&&(this.defaultManager.componentsExplosion(this.model,e),xd.Instance&&this.instancedManager.componentsExplosion(this.model,e))},_y.prototype.closeComponentsExplosion=function(e){this.isLoaded()&&(this.defaultManager.closeComponentsExplosion(this.model,e),xd.Instance&&this.instancedManager.closeComponentsExplosion(this.model,e))},_y.prototype.isHiddenNode=function(e){return this.defaultManager.isHiddenNode(e)||this.instancedManager.isHiddenNode(e)},_y.prototype.moveMeshfromInstancedToDefault=function(e){},_y.prototype.componentApplyMatrix=function(e,t){if(this.loader&&this.loader.descriptor){var i=this.loader.descriptor.getNodeInfosByComponentKey(e);if(i&&i.length>0)for(var n=0;i.length>n;n+=1){var r=i[n];if(r.matrix||(r.matrix=new yt),r.transformation||(r.transformation=!0,r.transformationOriginalMatrix=r.matrix.clone(),r.applyMatrix=new yt,r.boundingBox&&(r.transformationOriginalBoundingBox=r.boundingBox.clone())),r.matrix.premultiply(t),r.applyMatrix.premultiply(t),r.boundingBox&&r.boundingBox.copy(r.transformationOriginalBoundingBox).applyMatrix4(r.applyMatrix),r.isBatched){if(!0===r.instanceOrNot)for(var o=this.instancedManager.meshManager,a=o.getMeshIdByNodeInfo(r),s=o.nodeIdxMapFromUserId[e][a],l=0,c=s.length;c>l;l+=1){var h=s[l];if(r.instanceGeometryIndex===h){var d=o.instanceGeometryMap[a][0];if(!d)continue;var u=d.getAttribute("mcol0"),p=d.getAttribute("mcol1"),g=d.getAttribute("mcol2"),f=d.getAttribute("mcol3"),m=r.matrix;u.array[3*h]=m.elements[0],u.array[3*h+1]=m.elements[1],u.array[3*h+2]=m.elements[2],u.needsUpdate=!0,p.array[3*h]=m.elements[4],p.array[3*h+1]=m.elements[5],p.array[3*h+2]=m.elements[6],p.needsUpdate=!0,g.array[3*h]=m.elements[8],g.array[3*h+1]=m.elements[9],g.array[3*h+2]=m.elements[10],g.needsUpdate=!0,f.array[3*h]=m.elements[12],f.array[3*h+1]=m.elements[13],f.array[3*h+2]=m.elements[14],f.needsUpdate=!0}}else{var A=r.mesh;if(!A)continue;var y=r.index,v=A.geometry;A.geometry.boundingBox=null;var C=v.attributes.position;by.applyMatrix4ToBuffer(t,C.array,y.positionStart,y.positionStart+y.positionCount),C.needsUpdate=!0;var I=this.defaultManager.wireframeManager.getWireFrameLineSegments();if(I)if(Array.isArray(I))for(var x=0,w=I.length;w>x;x+=1)for(var M=I[x]._indicesGroup[e],E=0,B=M.length;B>E;E+=1){var S=M[E];if(M[E].nodeId===r.nodeId){var b=I[x].geometry.attributes.position;by.applyMatrix4ToBuffer(t,b.array,3*S.positionStart,3*(S.positionStart+S.positionCount)),b.needsUpdate=!0;break}}else for(var k=I._indicesGroup[e],D=0,T=k.length;T>D;D+=1){var R=k[D];if(k[D].nodeId===r.nodeId){var U=I.geometry.attributes.position;by.applyMatrix4ToBuffer(t,U.array,3*R.positionStart,3*(R.positionStart+R.positionCount)),U.needsUpdate=!0;break}}}}else{var F=null;if(r.mesh instanceof Array)F=r.mesh;else{if(!(r.mesh instanceof Yt))continue;F=[r.mesh]}for(var Q=0,L=F.length;L>Q;Q+=1){var O=F[Q];r.isExternalComponent&&(O.userData.originalMatrix||(O.userData.originalMatrix=O.matrix.clone()));var N=O.matrixAutoUpdate;O.matrixAutoUpdate=!1,O.applyMatrix4(t),O.matrixAutoUpdate=N,O.updateMatrixWorld(!0)}var P=r.wireframeMeshs;if(P)for(var G=0,K=P.length;K>G;G+=1){var V=P[G];N=V.matrixAutoUpdate,V.matrixAutoUpdate=!1,V.matrix.copy(r.matrix),V.updateMatrixWorld(!0),V.matrixAutoUpdate=N}}}}},_y.prototype.setComponentMatrix=function(e,t){if(this.loader&&this.loader.descriptor){var i=this.loader.descriptor.getNodeInfosByComponentKey(e);if(i&&i.length>0)for(var n=0;i.length>n;n+=1){var r=i[n];r.matrix||(r.matrix=new yt);var o=null;if(r.transformation?o=(new yt).copy(r.applyMatrix).invert():(r.transformation=!0,r.transformationOriginalMatrix=r.matrix.clone(),r.applyMatrix=new yt,r.boundingBox&&(r.transformationOriginalBoundingBox=r.boundingBox.clone())),r.matrix.copy(r.transformationOriginalMatrix).premultiply(t),r.applyMatrix.copy(t),r.boundingBox&&r.boundingBox.copy(r.transformationOriginalBoundingBox).applyMatrix4(r.applyMatrix),r.isBatched){if(!0===r.instanceOrNot)for(var a=this.instancedManager.meshManager,s=a.getMeshIdByNodeInfo(r),l=a.nodeIdxMapFromUserId[e][s],c=0,h=l.length;h>c;c+=1){var d=l[c],u=a.instanceGeometryMap[s][c],p=u.getAttribute("mcol0"),g=u.getAttribute("mcol1"),f=u.getAttribute("mcol2"),m=u.getAttribute("mcol3"),A=r.matrix;p.array[3*d]=A.elements[0],p.array[3*d+1]=A.elements[1],p.array[3*d+2]=A.elements[2],p.needsUpdate=!0,g.array[3*d]=A.elements[4],g.array[3*d+1]=A.elements[5],g.array[3*d+2]=A.elements[6],g.needsUpdate=!0,f.array[3*d]=A.elements[8],f.array[3*d+1]=A.elements[9],f.array[3*d+2]=A.elements[10],f.needsUpdate=!0,m.array[3*d]=A.elements[12],m.array[3*d+1]=A.elements[13],m.array[3*d+2]=A.elements[14],m.needsUpdate=!0}else{var y=r.mesh;if(!y)continue;var v=r.index,C=y.geometry.attributes.position;o&&by.applyMatrix4ToBuffer(o,C.array,v.positionStart,v.positionStart+v.positionCount),by.applyMatrix4ToBuffer(r.applyMatrix,C.array,v.positionStart,v.positionStart+v.positionCount),C.needsUpdate=!0;var I=this.defaultManager.wireframeManager.getWireFrameLineSegments();if(I)if(Array.isArray(I))for(var x=0,w=I.length;w>x;x+=1)for(var M=I[x]._indicesGroup[e],E=0,B=M.length;B>E;E+=1){var S=M[E];if(M[E].nodeId===r.nodeId){var b=I[x].geometry.attributes.position;o&&by.applyMatrix4ToBuffer(o,b.array,3*S.positionStart,3*(S.positionStart+S.positionCount)),by.applyMatrix4ToBuffer(t,b.array,3*S.positionStart,3*(S.positionStart+S.positionCount)),b.needsUpdate=!0;break}}else for(var k=I._indicesGroup[e],D=0,T=k.length;T>D;D+=1){var R=k[D];if(k[D].nodeId===r.nodeId){var U=I.geometry.attributes.position;o&&by.applyMatrix4ToBuffer(o,U.array,3*R.positionStart,3*(R.positionStart+R.positionCount)),by.applyMatrix4ToBuffer(t,U.array,3*R.positionStart,3*(R.positionStart+R.positionCount)),U.needsUpdate=!0;break}}}}else{var F=null;if(r.mesh instanceof Array)F=r.mesh;else{if(!(r.mesh instanceof Yt))continue;F=[r.mesh]}for(var Q=0,L=F.length;L>Q;Q+=1){var O=F[n];r.isExternalComponent&&(O.userData.originalMatrix||(O.userData.originalMatrix=O.matrix.clone()));var N=O.matrixAutoUpdate;O.matrixAutoUpdate=!1,O.matrix.copy(r.matrix),O.applyMatrix4(new yt),O.matrixAutoUpdate=N,O.updateMatrixWorld(!0)}var P=r.wireframeMeshs;if(P)for(var G=0,K=P.length;K>G;G+=1){var V=P[G];N=V.matrixAutoUpdate,V.matrixAutoUpdate=!1,V.matrix.copy(r.matrix),V.updateMatrixWorld(!0),V.matrixAutoUpdate=N}}}}},_y.prototype.resetComponentMatrix=function(e){if(this.loader&&this.loader.descriptor){var t=this.loader.descriptor.getNodeInfosByComponentKey(e);if(t&&t.length>0)for(var i=0;t.length>i;i+=1){var n=t[i];if(n.transformation){n.matrix.copy(n.transformationOriginalMatrix),n.transformationOriginalBoundingBox&&(n.boundingBox=n.transformationOriginalBoundingBox.clone());var r=(new yt).copy(n.applyMatrix).invert();if(n.isBatched){if(!0===n.instanceOrNot)for(var o=this.instancedManager.meshManager,a=o.getMeshIdByNodeInfo(n),s=o.nodeIdxMapFromUserId[e][a],l=0,c=s.length;c>l;l+=1){var h=s[l],d=o.instanceGeometryMap[a][l],u=d.getAttribute("mcol0"),p=d.getAttribute("mcol1"),g=d.getAttribute("mcol2"),f=d.getAttribute("mcol3"),m=n.matrix;u.array[3*h]=m.elements[0],u.array[3*h+1]=m.elements[1],u.array[3*h+2]=m.elements[2],u.needsUpdate=!0,p.array[3*h]=m.elements[4],p.array[3*h+1]=m.elements[5],p.array[3*h+2]=m.elements[6],p.needsUpdate=!0,g.array[3*h]=m.elements[8],g.array[3*h+1]=m.elements[9],g.array[3*h+2]=m.elements[10],g.needsUpdate=!0,f.array[3*h]=m.elements[12],f.array[3*h+1]=m.elements[13],f.array[3*h+2]=m.elements[14],f.needsUpdate=!0}else{var A=n.mesh;if(!A)continue;var y=n.index,v=A.geometry.attributes.position;r&&(by.applyMatrix4ToBuffer(r,v.array,y.positionStart,y.positionStart+y.positionCount),v.needsUpdate=!0);var C=this.defaultManager.wireframeManager.getWireFrameLineSegments();if(C)if(Array.isArray(C))for(var I=0,x=C.length;x>I;I+=1)for(var w=C[I]._indicesGroup[e],M=0,E=w.length;E>M;M+=1){var B=w[M];if(w[M].nodeId===n.nodeId){var S=C[I].geometry.attributes.position;r&&(by.applyMatrix4ToBuffer(r,S.array,3*B.positionStart,3*(B.positionStart+B.positionCount)),by.applyMatrix4ToBuffer(r,S.array,3*B.positionStart,3*(B.positionStart+B.positionCount)),S.needsUpdate=!0);break}}else for(var b=C._indicesGroup[e],k=0,D=b.length;D>k;k+=1){var T=b[k];if(b[k].nodeId===n.nodeId){var R=C.geometry.attributes.position;r&&(by.applyMatrix4ToBuffer(r,R.array,3*T.positionStart,3*(T.positionStart+T.positionCount)),by.applyMatrix4ToBuffer(r,R.array,3*T.positionStart,3*(T.positionStart+T.positionCount)),R.needsUpdate=!0);break}}}}else{var U=null;if(n.mesh instanceof Array)U=n.mesh;else{if(!(n.mesh instanceof Yt))continue;U=[n.mesh]}for(var F=0,Q=U.length;Q>F;F+=1){var L=U[i],O=void 0;if(O=n.isExternalComponent?L.userData.originalMatrix:n.matrix){var N=L.matrixAutoUpdate;L.matrixAutoUpdate=!1,L.matrix.copy(O),L.applyMatrix4(new yt),L.matrixAutoUpdate=N,L.updateMatrixWorld(!0),L.userData.originalMatrix=void 0}}var P=n.wireframeMeshs;if(P)for(var G=0,K=P.length;K>G;G+=1){var V=P[G];N=V.matrixAutoUpdate,V.matrixAutoUpdate=!1,V.matrix.copy(n.matrix),V.updateMatrixWorld(!0),V.matrixAutoUpdate=N}}n.transformationOriginalMatrix=void 0,n.transformationOriginalBoundingBox=void 0,n.applyMatrix=void 0,n.transformation=void 0}}}};var $y=function(e){this.manager=e,this.pickingNodeMap=null,this.pickingNodeGroup=null,this.nodeGroupName="PickingNodeGroup"};$y.prototype.destroy=function(){this.clearData(),this.pickingNodeGroup=null,this.manager=null},$y.prototype.clearData=function(){this.clearAllFromPickingNodeGroup(),this.clearAllFromPickingNodeMap()},$y.prototype.addToPickingNodeMap=function(e,t){this.pickingNodeMap||(this.pickingNodeMap={}),this.pickingNodeMap[e]=t,this.addToPickingNodeGroup(t)},$y.prototype.removeFromPickingNodeMap=function(e){this.pickingNodeMap&&this.pickingNodeMap[e]&&(this.removeFormPickingNodeGroup(e),this.disposePickingNodeById(e),delete this.pickingNodeMap[e])},$y.prototype.addToPickingNodeGroup=function(e){this.pickingNodeGroup||(this.pickingNodeGroup=new To,this.pickingNodeGroup.name=this.nodeGroupName);for(var t=0,i=e.length;i>t;t+=1)this.pickingNodeGroup.add(e[t])},$y.prototype.removeFormPickingNodeGroup=function(e){if(this.pickingNodeGroup)for(var t=this.pickingNodeMap[e],i=0,n=t.length;n>i;i+=1)this.pickingNodeGroup.remove(t[i])},$y.prototype.disposePickingNodeById=function(e){for(var t=this.pickingNodeMap[e],i=0,n=t.length;n>i;i+=1)t[i].material=null,t[i].geometry.dispose(),t[i]=null},$y.prototype.clearAllFromPickingNodeMap=function(){if(this.pickingNodeMap){for(var e=Object.keys(this.pickingNodeMap),t=0,i=e.length;i>t;t+=1)this.disposePickingNodeById(e[t]);this.pickingNodeMap=null}},$y.prototype.clearAllFromPickingNodeGroup=function(){this.pickingNodeGroup&&(this.pickingNodeGroup.children.length=0)},$y.prototype.isPickingMeshesGenerated=function(){return!!this.pickingNodeMap},$y.prototype.generatePickingMeshes=function(){},$y.prototype.updatePickingMeshesState=function(e,t,i){},$y.prototype.resetPickingMeshesState=function(){},$y.prototype.updatePickingMeshes=function(e,t,i){return this.isPickingMeshesGenerated()||(this.generatePickingMeshes(),this.isPickingMeshesGenerated())?(this.resetPickingMeshesState(),this.updatePickingMeshesState(e,t,i),this.getPickingNodeGroup()):null},$y.prototype.getPickingNodeGroup=function(){return this.pickingNodeGroup};var ev=function(e){$y.call(this,e),this.nodeGroupName="PickingBatchedMeshGroup"};Object.assign(ev.prototype,$y.prototype),SA(ev,[{key:"disposePickingNodeById",value:function(e){for(var t=this.pickingNodeMap[e],i=0,n=t.length;n>i;i+=1)t[i]._indicesGroup=null,t[i].material=null,t[i].geometry.dispose(),t[i]=null}},{key:"generatePickingMeshes",value:function(){for(var e=this.manager,t=Object.keys(e.mapMaterialIdToMergedNode),i=0,n=t.length;n>i;i+=1){for(var r=t[i],o=e.getPropertyValueByMaterialKey(r),a=e.mapMaterialIdToMergedNode[r],s=[],l=0,c=a.length;c>l;l+=1){var h=a[l],d=h.geometry,u=h.indices,p=h.mesh,g=new Ni;g.setAttribute("position",d.getAttribute("position")),g.setIndex(d.getIndex());var f=new("lines"===o.type?La:nn)(g,cA.DefaultMaterial);p.matrixWorld.decompose(f.position,f.quaternion,f.scale),f.name=r,f.frustumCulled=!1,f.renderOrder=1,f._indicesGroup=u,s.push(f)}this.addToPickingNodeMap(r,s)}}},{key:"_rebuildGeometryGroup",value:function(e,t,i){var n,r=this.manager.manager,o=0,a=0,s=0,l=e._indicesGroup,c=Object.keys(l),h=[],d={};t.length>c.length?(h=c,d=i):(h=t,d=l);var u=[];for(s=0,n=h.length;n>s;s+=1){var p=h[s];if(r.isPickableNode(p)&&d[p]){var g=l[p];if(g&&g.length>0)for(o=0,a=g.length;a>o;o+=1)u.push({indexStart:g[o].indexStart,indexCount:g[o].indexCount})}}e.visible=!0;var f=e.geometry;if(f.clearGroups(),0!==u.length)for(u.sort((function(e,t){return e.indexStart-t.indexStart})),o=0,a=u.length;a>o;o+=1){var m=u[o].indexStart,A=u[o].indexCount;if(0===o)f.addGroup(m,A,0);else m===u[o-1].indexStart+u[o-1].indexCount?f.groups[f.groups.length-1].count+=A:f.addGroup(m,A,0)}else e.visible=!1}},{key:"updatePickingMeshesState",value:function(e,t,i){for(var n=this.pickingNodeMap,r=Object.keys(n),o=0,a=r.length;a>o;o+=1)for(var s=n[r[o]],l=0,c=s.length;c>l;l+=1)s[l].material=[e],s[l].visible=!1,this._rebuildGeometryGroup(s[l],t,i)}}]);var tv=new He,iv=new yt,nv=new At,rv=new ct,ov=function(e){lu(i,e);var t=pu(i);function i(){var e;return ru(this,i),(e=t.call(this)).type="LineSegmentsEx",e}return i}(La);ov.prototype.init=function(e){},ov.prototype.destroy=function(){},ov.prototype.intersectBoxWithDistance=function(e,t){var i=this.geometry,n=this.matrixWorld;return t&&(n=this.matrixWorld.clone()).multiplyMatrices(this.matrixWorld,t),i.boundingBox||i.computeBoundingBox(),tv.copy(i.boundingBox),tv.applyMatrix4(n),e.ray.intersectBoxWithDistance(tv)},ov.prototype.intersectBoxWithDistanceByIndices=function(e,t){var i=this.geometry.attributes.position.array,n=0,r=i.length;t&&t.indexCount>0&&(n=t.positionStart,r=t.positionStart+t.positionCount);var o=wp.box3FromArrayRange(i,n,r);return o.applyMatrix4(this.matrixWorld),e.ray.intersectBoxWithDistance(o)},ov.prototype.raycastByIndices=function(e,t,i,n){var r=e.linePrecision;e.linePrecision=xd.LineSelectRange||5;var o=e.linePrecision,a=o*o,s=null;n?(s=this.matrixWorld.clone()).multiplyMatrices(this.matrixWorld,n):s=this.matrixWorld;var l=this.geometry;if(null===l.boundingSphere&&l.computeBoundingSphere(),rv.copy(l.boundingSphere),rv.applyMatrix4(s),!1!==e.ray.intersectsSphere(rv)){iv.copy(s).invert(),nv.copy(e.ray).applyMatrix4(iv);var c=new Ke,h=new Ke,d=new Ke,u=new Ke,p=l.attributes.position.array,g=l.index.array,f=0,m=g.length;i&&i.indexCount>0&&(f=i.indexStart,m=i.indexStart+i.indexCount);for(var A=f;m-1>A;A+=2){var y=g[A+1];if(c.fromArray(p,3*g[A]),h.fromArray(p,3*y),a>=nv.distanceSqToSegment(c,h,u,d)){u.applyMatrix4(s);var v=e.ray.origin.distanceTo(u);e.near>v||v>e.far||t.push({distance:v,point:d.clone().applyMatrix4(s),index:A,face:null,faceIndex:null,object:this})}}e.linePrecision=r}};var av=new yt,sv=new At,lv=new ct,cv=new Ke,hv=new Ke,dv=new Ke,uv=new Ke,pv=new Ke,gv=new Ke,fv=new Ke,mv=new Ke,Av=new Ke,yv=new ke,vv=new ke,Cv=new ke,Iv=new Ke,xv=new Ke;function wv(e,t,i,n,r,o,a,s){if(null===(Array.isArray(t)?n.intersectTriangle(r,o,a,!1,s):1===t.side?n.intersectTriangle(a,o,r,!0,s):n.intersectTriangle(r,o,a,2!==t.side,s)))return null;xv.copy(s),xv.applyMatrix4(e.matrixWorld);var l=i.ray.origin.distanceTo(xv);return i.near>l||l>i.far?null:{distance:l,point:xv.clone(),object:e}}function Mv(e,t,i,n,r,o,a,s,l,c,h,d){cv.fromBufferAttribute(r,c),hv.fromBufferAttribute(r,h),dv.fromBufferAttribute(r,d);var u=e.morphTargetInfluences;if(t.morphTargets&&o&&u){fv.set(0,0,0),mv.set(0,0,0),Av.set(0,0,0);for(var p=0,g=o.length;g>p;p+=1){var f=u[p],m=o[p];0!==f&&(uv.fromBufferAttribute(m,c),pv.fromBufferAttribute(m,h),gv.fromBufferAttribute(m,d),a?(fv.addScaledVector(uv,f),mv.addScaledVector(pv,f),Av.addScaledVector(gv,f)):(fv.addScaledVector(uv.sub(cv),f),mv.addScaledVector(pv.sub(hv),f),Av.addScaledVector(gv.sub(dv),f)))}cv.add(fv),hv.add(mv),dv.add(Av)}e.isSkinnedMesh&&(e.boneTransform(c,cv),e.boneTransform(h,hv),e.boneTransform(d,dv));var A=wv(e,t,i,n,cv,hv,dv,Iv);if(A){s&&(yv.fromBufferAttribute(s,c),vv.fromBufferAttribute(s,h),Cv.fromBufferAttribute(s,d),A.uv=ri.getUV(Iv,cv,hv,dv,yv,vv,Cv,new ke)),l&&(yv.fromBufferAttribute(l,c),vv.fromBufferAttribute(l,h),Cv.fromBufferAttribute(l,d),A.uv2=ri.getUV(Iv,cv,hv,dv,yv,vv,Cv,new ke));var y={a:c,b:h,c:d,normal:new Ke,materialIndex:0};ri.getNormal(cv,hv,dv,y.normal),A.face=y}return A}var Ev,Bv=function(e){lu(i,e);var t=pu(i);function i(e,n){var r,o=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};return ru(this,i),(r=t.call(this)).type="MeshEx",r.matrixAutoUpdate=!1,r.active=!1,r.guid="",r.key="",r.typeEx="",r.geometry=e||by.EmptyGeometry,r.material=n||cA.DefaultMaterial,r.visible=!1,r.pickable=!0,r.info=o,r.isMeshEx=!0,r}return i}(nn);Bv.prototype.init=function(e){e&&e.parent&&e.parent.add(this)},Bv.prototype.destroy=function(){this.parent&&this.parent.remove(this),this.userData&&(this.userData=null),this.geometry=null,this.material=null},Bv.prototype.isVisible=function(){return this.visible&&this.active},Bv.prototype.spawn=function(e){void 0!==e.guid&&(this.guid=e.guid),void 0!==e.key&&(this.key=e.key),void 0!==e.name&&(this.name=e.name),void 0!==e.typeEx&&(this.typeEx=e.typeEx),e.geometry&&(this.geometry=e.geometry),e.material&&(this.material=e.material),e.matrix?(this.matrix.copy(e.matrix),this.updateMatrixWorld(!0)):(this.matrix.identity(),this.updateMatrixWorld(!0)),this.modelKey=e.modelKey?e.modelKey:"",e.userData?this.userData=e.userData:this.userData&&(this.userData=null),void 0!==e.visible&&(this.visible=e.visible),void 0!==e.isMesh&&(this.isMesh=e.isMesh),void 0!==e.isLine&&(this.isLine=e.isLine),void 0!==e.isLineSegments&&(this.isLineSegments=e.isLineSegments),this.pickable=void 0===e.pickable||e.pickable,this.renderOrder=e.renderOrder||0,this.active=!0,this.visible=!0,this.frustumCulled=!1,this.matChange=!1},Bv.prototype.clear=function(){this.geometry=by.EmptyGeometry,this.material=cA.DefaultMaterial,this.active=!1,this.visible=!0,this.guid="",this.key="",this.typeEx="",this.frustumCulled=!0,this.material.visible=!1},Bv.prototype.intersectBoxWithDistance=(Ev=new He,function(e,t){var i=this.geometry,n=this.material,r=this.matrixWorld;return t&&(r=new yt).multiplyMatrices(this.matrixWorld,t),void 0===n?-1:(i.boundingBox||i.computeBoundingBox(),Ev.copy(i.boundingBox),Ev.applyMatrix4(r),e.ray.intersectBoxWithDistance(Ev))}),Bv.prototype.intersectBoxWithDistanceByIndices=function(e,t){var i=this.matrixWorld,n=this.computeBoundingBox(t);return n.applyMatrix4(i),e.ray.intersectBoxWithDistance(n)},Bv.prototype.intersectBoxWithClipPlane=function(e,t){var i=this.matrixWorld,n=this.computeBoundingBox(t);return n.applyMatrix4(i),n.intersectsPlane(e)},Bv.prototype.getIntersectionPoints=function(e,t,i,n){var r=new yt;r.copy(this.matrixWorld).invert();var o=e.clone();function a(e,t){var n=t.intersectLine(e);n&&i.push(n.x,n.y,n.z)}o.constant*=-1,o=o.applyMatrix4(r);for(var s,l,c,h=this.geometry.getIndex().array,d=this.geometry.getAttribute("position").array,u=n?0:t.indexStart,p=n?h.length:t.indexStart+t.indexCount,g=new Ke,f=new Ke,m=new Ke,A=new xh,y=new xh,v=new xh,C=u,I=p;I>C;C+=3)l=3*h[C+1],c=3*h[C+2],g.set(d[s=3*h[C]],d[s+1],d[s+2]),f.set(d[l],d[l+1],d[l+2]),m.set(d[c],d[c+1],d[c+2]),n&&(g.applyMatrix4(t.matrix),f.applyMatrix4(t.matrix),m.applyMatrix4(t.matrix)),A.set(g,f),y.set(f,m),v.set(m,g),a(A,o),a(y,o),a(v,o)},Bv.prototype.raycastByIndices=function(){var e=new yt,t=new At,i=new ct,n=new Ke,r=new Ke,o=new Ke,a=new ke,s=new ke,l=new ke,c=new Ke,h=new Ke,d=new Ke,u=new yt;function p(e,t,i,p,g,f,m,A){n.fromBufferAttribute(p,f),r.fromBufferAttribute(p,m),o.fromBufferAttribute(p,A);var y=function(e,t,i,n,r,o,a){var s=e.material;if(null===(Array.isArray(s)?i.intersectTriangle(n,r,o,!1,a):1===s.side?i.intersectTriangle(o,r,n,!0,a):i.intersectTriangle(n,r,o,2!==s.side,a)))return null;d.copy(a),d.applyMatrix4(u);var l=t.ray.origin.distanceTo(d);return t.near>l||l>t.far?null:{distance:l,point:d.clone(),object:e}}(e,t,i,n,r,o,h);if(y){if(g&&g.array&&g.array.length&&(a.fromBufferAttribute(g,f),s.fromBufferAttribute(g,m),l.fromBufferAttribute(g,A),y.uv=function(e,t,i,n,r,o,a){return ri.getBarycoord(e,t,i,n,c),r.multiplyScalar(c.x),o.multiplyScalar(c.y),a.multiplyScalar(c.z),r.add(o).add(a),r.clone()}(h,n,r,o,a,s,l)),p.instanceMatrix){var v=n.clone().applyMatrix4(p.instanceMatrix),C=r.clone().applyMatrix4(p.instanceMatrix),I=o.clone().applyMatrix4(p.instanceMatrix),x={a:f,b:m,c:A,normal:ri.getNormal(v,C,I,new Ke),materialIndex:0};y.face=x}else{var w={a:f,b:m,c:A,normal:ri.getNormal(n,r,o,new Ke),materialIndex:0};y.face=w}y.faceIndex=f}return y}return function(n,r,o,a){var s=this.geometry,l=this.material;if(a){s=this.geometry,l=this.material;if((u=new yt).multiplyMatrices(this.matrixWorld,a),void 0===l)return;if(null===s.boundingSphere&&s.computeBoundingSphere(),i.copy(s.boundingSphere),i.applyMatrix4(u),!1===n.ray.intersectsSphere(i))return;if(e.copy(u).invert(),t.copy(n.ray).applyMatrix4(e),null!==s.boundingBox&&!1===t.intersectsBox(s.boundingBox))return;var c=null,h=null,d=null,g=null,f=s.index;(I=s.attributes.position).instanceMatrix=a;var m=s.attributes.uv,A=null,y=null;if(null!==f)for(A=0,y=f.count;y>A;A+=3)h=f.getX(A),d=f.getX(A+1),g=f.getX(A+2),(c=p(this,n,t,I,m,h,d,g))&&(c.faceIndex=Math.floor(A/3),r.push(c));else for(A=0,y=I.count;y>A;A+=3)(c=p(this,n,t,I,m,h=A,d=A+1,g=A+2))&&(c.index=h,r.push(c))}else{if(u=this.matrixWorld,void 0===l)return;if(i.copy(this.computeBoundingSphere(o)),i.applyMatrix4(u),!1===n.ray.intersectsSphere(i))return;e.copy(u).invert(),t.copy(n.ray).applyMatrix4(e);var v=this.computeBoundingBox(o);if(!1===t.intersectsBox(v))return;c=null,h=null,d=null,g=null;var C,I=s.attributes.position,x=(m=s.attributes.uv,A=null,o.indexStart),w=o.indexStart+o.indexCount,M=s.getIndex().array;for(A=x,C=w;C>A;A+=3)(c=p(this,n,t,I,m,h=M[A],d=M[A+1],g=M[A+2]))&&(c.faceIndex=Math.floor(A/3),r.push(c))}}}(),Bv.prototype.raycastByIndices2=function(){var e=new yt,t=new At,i=new ct,n=new Ke,r=new Ke,o=new Ke,a=new ke,s=new ke,l=new ke,c=new Ke,h=new Ke,d=new Ke,u=new yt;function p(e,t,i,p,g,f,m,A){n.fromBufferAttribute(p,f),r.fromBufferAttribute(p,m),o.fromBufferAttribute(p,A);var y=function(e,t,i,n,r,o,a){var s=e.material;if(null===(s instanceof Array?i.intersectTriangle(n,r,o,!1,a):1===s.side?i.intersectTriangle(o,r,n,!0,a):i.intersectTriangle(n,r,o,2!==s.side,a)))return null;d.copy(a),d.applyMatrix4(u);var l=t.ray.origin.distanceTo(d);return t.near>l||l>t.far?null:{distance:l,point:d.clone(),object:e}}(e,t,i,n,r,o,h);if(y){if(g&&g.array&&g.array.length&&(a.fromBufferAttribute(g,f),s.fromBufferAttribute(g,m),l.fromBufferAttribute(g,A),y.uv=function(e,t,i,n,r,o,a){return ri.barycoordFromPoint(e,t,i,n,c),r.multiplyScalar(c.x),o.multiplyScalar(c.y),a.multiplyScalar(c.z),r.add(o).add(a),r.clone()}(h,n,r,o,a,s,l)),p.instanceMatrix){var v=n.clone().applyMatrix4(p.instanceMatrix),C=r.clone().applyMatrix4(p.instanceMatrix),I=o.clone().applyMatrix4(p.instanceMatrix),x={a:f,b:m,c:A,normal:ri.getNormal(v,C,I,new Ke),materialIndex:0};y.face=x}else{var w={a:f,b:m,c:A,normal:ri.getNormal(n,r,o,new Ke),materialIndex:0};y.face=w}y.faceIndex=f}return y}return function(n,r,o,a){var s=this.geometry,l=this.material;if(a=Boolean(a),o.isInstanced){if(void 0===o.matrix)return;if(u.multiplyMatrices(this.matrixWorld,o.matrix),void 0===l)return;if(a&&(null===s.boundingSphere&&s.computeBoundingSphere(),i.copy(s.boundingSphere),i.applyMatrix4(u),!1===n.ray.intersectsSphere(i)))return;if(e.copy(u).invert(),t.copy(n.ray).applyMatrix4(e),a&&null!==s.boundingBox&&!1===t.intersectsBox(s.boundingBox))return;var c=s.index;(I=s.attributes.position).instanceMatrix=o.matrix;var h,d=s.attributes.uv;if(null!==c)for(v=0,h=c.count;h>v;v+=3)m=c.getX(v),A=c.getX(v+1),y=c.getX(v+2),(f=p(this,n,t,I,d,m,A,y))&&(f.faceIndex=Math.floor(v/3),r.push(f));else for(v=0,h=I.count;h>v;v+=3)(f=p(this,n,t,I,d,m=v,A=v+1,y=v+2))&&(f.index=m,r.push(f))}else if(o.matrix?u.multiplyMatrices(this.matrixWorld,o.matrix):u=this.matrixWorld,void 0!==l&&(!a||(i.copy(this.computeBoundingSphere(o)),i.applyMatrix4(u),!1!==n.ray.intersectsSphere(i)))){if(e.copy(u).invert(),t.copy(n.ray).applyMatrix4(e),a){var g=this.computeBoundingBox(o);if(!1===t.intersectsBox(g))return}var f,m,A,y,v,C,I=s.attributes.position,x=(d=s.attributes.uv,o.indexStart),w=o.indexStart+o.indexCount,M=s.getIndex().array;for(v=x,C=w;C>v;v+=3)(f=p(this,n,t,I,d,m=M[v],A=M[v+1],y=M[v+2]))&&(f.faceIndex=Math.floor(v/3),r.push(f))}}}(),Bv.prototype.computeBoundingBox=function(e){var t=new He,i=this.geometry.attributes.position.array,n=null,r=null;return e?(n=e.positionStart,r=e.positionStart+e.positionCount):(n=0,r=i.length),this.setBoundingBoxFromArray(t,i,n,r),t},Bv.prototype.computeBoundingSphere=function(e){var t=new He,i=new Ke,n=this.geometry.attributes.position.array,r=null,o=null;e?(r=e.positionStart,o=e.positionStart+e.positionCount):(r=0,o=n.length);var a=new ct,s=a.center;this.setBoundingBoxFromArray(t,n,r,o),t.getCenter(s);for(var l=0,c=r,h=o;h>c;c+=3)i.x=n[c],i.y=n[c+1],i.z=n[c+2],l=Math.max(l,s.distanceToSquared(i));return a.radius=Math.sqrt(l),a},Bv.prototype.setBoundingBoxFromArray=function(e,t,i,n){for(var r=Number(1/0),o=Number(1/0),a=Number(1/0),s=-1/0,l=-1/0,c=-1/0,h=i,d=n;d>h;h+=3){var u=t[h],p=t[h+1],g=t[h+2];r>u&&(r=u),o>p&&(o=p),a>g&&(a=g),u>s&&(s=u),p>l&&(l=p),g>c&&(c=g)}e.min.set(r,o,a),e.max.set(s,l,c)},Bv.prototype.raycast=function(e,t){var i=this.geometry,n=this.material,r=this.matrixWorld;if(void 0!==n&&(null===i.boundingSphere&&i.computeBoundingSphere(),lv.copy(i.boundingSphere),lv.applyMatrix4(r),!1!==e.ray.intersectsSphere(lv)&&(av.copy(r).invert(),sv.copy(e.ray).applyMatrix4(av),null===i.boundingBox||!1!==sv.intersectsBox(i.boundingBox)))){var o=null;if(i.isBufferGeometry){var a=null,s=null,l=null,c=i.index,h=i.attributes.position,d=i.morphAttributes.position,u=i.morphTargetsRelative,p=i.attributes.uv,g=i.attributes.uv2,f=i.groups,m=i.drawRange,A=null,y=null,v=null,C=null,I=null,x=null;if(null!==c)if(Array.isArray(n)){for(A=0,v=f.length;v>A;A+=1)if(x=n[(I=f[A]).materialIndex])for(y=Math.max(I.start,m.start),C=Math.min(I.start+I.count,m.start+m.count);C>y;y+=3)a=c.getX(y),s=c.getX(y+1),l=c.getX(y+2),(o=Mv(this,x,e,sv,h,d,u,p,g,a,s,l))&&(o.faceIndex=Math.floor(y/3),o.face.materialIndex=I.materialIndex,t.push(o))}else for(A=Math.max(0,m.start),v=Math.min(c.count,m.start+m.count);v>A;A+=3)a=c.getX(A),s=c.getX(A+1),l=c.getX(A+2),(o=Mv(this,n,e,sv,h,d,u,p,g,a,s,l))&&(o.faceIndex=Math.floor(A/3),t.push(o));else if(void 0!==h)if(Array.isArray(n)){for(A=0,v=f.length;v>A;A+=1)if(x=n[(I=f[A]).materialIndex])for(y=Math.max(I.start,m.start),C=Math.min(I.start+I.count,m.start+m.count);C>y;y+=3)(o=Mv(this,x,e,sv,h,d,u,p,g,a=y,s=y+1,l=y+2))&&(o.faceIndex=Math.floor(y/3),o.face.materialIndex=I.materialIndex,t.push(o))}else for(A=Math.max(0,m.start),v=Math.min(h.count,m.start+m.count);v>A;A+=3)(o=Mv(this,n,e,sv,h,d,u,p,g,a=A,s=A+1,l=A+2))&&(o.faceIndex=Math.floor(A/3),t.push(o))}else if(i.isGeometry){var w=null,M=null,E=null,B=Array.isArray(n),S=i.vertices,b=i.faces,k=null,D=i.faceVertexUvs[0];D.length>0&&(k=D);for(var T=0,R=b.length;R>T;T+=1){var U=b[T],F=B?n[U.materialIndex]:n;if(void 0!==F&&(o=wv(this,F,e,sv,w=S[U.a],M=S[U.b],E=S[U.c],Iv))){if(k&&k[T]){var Q=k[T];yv.copy(Q[0]),vv.copy(Q[1]),Cv.copy(Q[2]),o.uv=ri.getUV(Iv,w,M,E,yv,vv,Cv,new ke)}o.face=U,o.faceIndex=T,t.push(o)}}}}},Bv.prototype.updateFixedFrame=function(e,t){var i,n=[].concat(this.material),r=e.scene,o=vu(n);try{for(o.s();!(i=o.n()).done;){var a=i.value;a&&"bos3dStandard"===a.type&&a.update(r,t)}}catch(e){o.e(e)}finally{o.f()}};var Sv=function(e,t){this.model=t,this.loader=e,this.mapNodeInfoByCategory={},this.mapNodeInfoByUserId={},this.mapNodeInfoByComponentId={},this.referencedMeshCache={},this.nodeInfosOnGeometryId=null,this.componentCount=0,this.meshCache={},this.allBones={}};function bv(e,t){var i=null;"node"===e.type?i=new Yt:"bone"===e.type&&(i=new Aa,t.allBones[e.name]=i),i.name=lh.sanitizeNodeName(e.name),i.matrix.fromArray(e.transformation||[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1]),i.matrix.decompose(i.position,i.quaternion,i.scale);for(var n=0;e.children.length>n;n+=1){var r=bv(e.children[n],t);r&&i.add(r)}for(var o=0;e.meshes.length>o;o+=1){var a=e.meshes[o];t.model._getHandler().defaultManager.meshManager._readBufferInfo(t.model,[t.model.modelKey+"_"+e.meshes[o]]);var s=t.model._getHandler().defaultManager.meshManager._makeSkinMesh(t.model,[t.model.modelKey+"_"+e.meshes[o]],(function(e){}));t.meshCache[a]=s,s.name=e.name,i.add(s)}return i}Sv.EnumNodeItemType={SYMBOL:0,MESH:1,TUBE:2,PIPE:3,BOX:4,BOX_M:5,PIPE_M:6,MESH_REF:7,LINE:8},Sv.NodeInfoCategory={INSTANCED:0,STANDARD:1},Sv.EnumDataType={NONE:0,MERGE_DATA:1,LAYER:2,LAYER_SCENE:3,ANIMATION:4},Sv.EnumKeyframeTrackType={position:"position",scale:"scale",quaternion:"quaternion",weights:"weights"},Sv.prototype.destroy=function(){this.mapNodeInfoByCategory=null,this.mapNodeInfoByUserId=null,this.mapNodeInfoByComponentId=null,this.referencedMeshCache=null,this.nodeInfosOnGeometryId=null},Sv.prototype.clearReferencedMeshCache=function(){if(!xd.DEBUG){for(var e in this.referencedMeshCache)delete this.referencedMeshCache[e];this.referencedMeshCache=null}},Sv.prototype.cacheReferencedMeshBufferData=function(e,t){this.referencedMeshCache.geometries||(this.referencedMeshCache.geometries={}),this.referencedMeshCache.geometries[e]=t},Sv.prototype.cacheReferencedMeshBoneBufferData=function(e,t){this.referencedMeshCache.bones||(this.referencedMeshCache.bones={}),this.referencedMeshCache.bones[e]=t},Sv.prototype.cacheReferencedMeshClipsData=function(e){this.referencedMeshCache.clips=e},Sv.prototype.cacheReferencedMeshNodesData=function(e){this.referencedMeshCache.nodes=e},Sv.prototype.cacheReferencedMeshComponentData=function(e,t){this.referencedMeshCache.components||(this.referencedMeshCache.components={}),this.referencedMeshCache.components[e]=t},Sv.prototype.cacheReferencedMeshMaterialData=function(e,t){this.referencedMeshCache.materials||(this.referencedMeshCache.materials={}),this.referencedMeshCache.materials[e]=t},Sv.prototype.getReferencedMeshBufferData=function(){return this.referencedMeshCache.geometries},Sv.prototype.getReferencedMeshBufferById=function(e){return this.referencedMeshCache.geometries?this.referencedMeshCache.geometries[e]:null},Sv.prototype.cacheReferencedMeshMpkIds=function(e,t){this.referencedMeshCache.mpkIds||(this.referencedMeshCache.mpkIds={}),this.referencedMeshCache.mpkIds[e]||(this.referencedMeshCache.mpkIds[e]=[]),this.referencedMeshCache.mpkIds[e].push(t)},Sv.prototype.clearReferencedMeshCacheByMpkIdxs=function(e,t){if(this.referencedMeshCache.mpkIds)for(var i=0,n=e.length;n>i;i+=1){var r=e[i],o=this.referencedMeshCache.mpkIds[r];if(o){for(var a=0,s=o.length;s>a;a+=1)t&&t(o[a]),delete this.referencedMeshCache[o[a]];delete this.referencedMeshCache.mpkIds[r]}}},Sv.prototype.parseItemData=function(e,t){(py(e.dataVersion,"1.0")||void 0===e.dataVersion)&&(Bu.time("升级几何结构"),this._updateV1ToV2(e),e.dataVersion="2.0",Bu.timeEnd("升级几何结构")),this._readMaterialBuffer222(e),e.hasAnimation&&xd.EnableAnimation?(this._parseClips(),this._parseBones()):(this._parseGeo(),this._parseInstanced());var i=this.loader.getSceneReaderArray();if(!i)return Bu.log("Empty scene"),!1;var n=this.referencedMeshCache;if(Bu.time("_readItemData"),!n.geometries||0>=Object.keys(n.geometries).length)return!0;if(t)for(var r=0,o=t.length;o>r;r+=1)n.components[t[r]]&&this._readItemData(i,t[r],t[r],void 0,0);else for(var a in n.components)this._readItemData(i,a,a,void 0,0);return e.hasAnimation&&xd.EnableAnimation&&this._parseNodes(),Bu.timeEnd("_readItemData"),i=null,!0},Sv.prototype._readItemData=function(e,t,i){var n=this.referencedMeshCache.components[t];void 0!==n&&-1!==n.geoId&&(this.model.merged?this._readMeshInfo(e,i,n,null):this._readMeshInfo2(e,i,n,null))},Sv.prototype._readSymbolInfo=function(e,t,i){var n=this.loader.getSymbolReader();if(n){var r=n.header.symbolCount,o=i.toData,a=e.getMatrixInfo(i.matrixId).matrix.clone(),s={matrix:a,ItemId:i.ItemId,originalId:i.originalId,userDataId:i.userDataId,materialId:i.materialId};if(o>=0&&r>o)for(var l=n.getSymbolInfo(o),c=l.itemIndex;l.itemCount>c;c+=1){var h=n.getItemInfo(c);h.type!==Sv.EnumNodeItemType.SYMBOL&&this._readMeshInfo(n,t,h,s)}a=null,s=null,n=null}},Sv.prototype._readMeshInfo=function(e,t,i,n){var r=this.loader,o=this.model.materialManager.materials,a=null,s=null,l=null;if(null===n?(a=i.userDataId,s=i.originalId,l=i.materialId||i.matId):(a=n.userDataId,s=n.originalId,l=n.materialId>-1?n.materialId:i.materialId),i.materials||(i.materials=[]),i.materials.length>0)for(var c=0;i.materials.length>c;c+=1){var h=null;if(h=this._getMeshNodeAttr(e,i,i.materials.length>1,c),!o[l=i.materials[c]]){var d=Jy[i.type]?Jy[i.type].color:void 0;d||(Bu.log("Material not found for type: ",i.type),d=Jy.DEFAULT.color),d||(Bu.log("Default material not found for type: ",i.type),d=[1,1,1,1]);var u=new pi(d[0],d[1],d[2]),p=l||u.getHexString()+"_"+d[3],g=o[p];g||(Bu.warn("缺少材质 "+l),g=new il({color:u}),1>d[3]&&(g.transparent=!0,g.opacity=d[3]),g.side=2,o[p]=g)}if(o[l].aoMap){var f=this.getReferencedMeshBufferById(h.geometryId);f&&(f.uv2=f.uv)}if(!h)return;var m=r.getUserDataReader(),A=m?m.getUserData(a):null,y=i.key;h.type=i.type,h.userId=y,h.name=i.name,h.userDataId=a,h.originalId=s,h.materialId=l,h.originMId=l,h.userData=A,h.categoryId=0,h.componentId=y,h.familyName=i.familyName,h.familySymbol=i.familySymbol,h.instanceOrNot=!(!xd.Instance||!this.instancedComponent[y]),h.state=Nd.Visible,h.material=null,this._classifyNodeInfo(h),h=null}else{var v=null,C=Jy[i.type]?Jy[i.type].color:void 0;C||(Bu.log("Material not found for type: ",i.type),C=Jy.DEFAULT.color),C||(Bu.log("Default material not found for type: ",i.type),C=[1,1,1,1]);var I=new pi(C[0],C[1],C[2]),x=I.getHexString()+"_"+C[3],w=o[x];if(w||(w=new il({color:I}),1>C[3]&&(w.transparent=!0,w.opacity=C[3]),w.side=2,o[x]=w),i.materials.push(x),v=this._getMeshNodeAttr(e,i,!1,0),l=i.materials[0],!v)return;var M=i.key;v.type=i.type,v.userId=M,v.name=i.name,v.originalId=s,v.materialId=l,v.originMId=l,v.userData={},v.categoryId=0,v.componentId=M,v.familyName=i.familyName,v.familySymbol=i.familySymbol,v.instanceOrNot=!(!xd.Instance||!this.instancedComponent[M]),v.state=Nd.Visible,v.material=null,this._classifyNodeInfo(v),v=null}},Sv.prototype._readMeshInfo2=function(e,t,i,n){var r=this.loader,o=null,a=null,s=null;null===n?(o=i.userDataId,a=i.originalId,s=i.materials||i.matId):(o=n.userDataId,a=n.originalId,s=n.materialId>-1?n.materialId:i.materialId);var l=null;if(l=this._getMeshNodeAttr(e,i,!1)){var c=r.getUserDataReader(),h=c?c.getUserData(o):null,d=i.key;l.type=i.type,l.userId=d,l.name=i.name,l.originalId=a,l.materialId=s,l.originMId=s,l.userData=h,l.categoryId=0,l.componentId=d,l.familyName=i.familyName,l.familySymbol=i.familySymbol,l.state=Nd.Visible,l.material=null,this._classifyNodeInfo(l),l=null}},Sv.prototype._getMeshNodeAttrOfPipe=function(e,t,i){var n=e.getMatrixInfo(t.matrixId).matrix.clone(),r=wp.TemporaryMatrix;r.copy(n);var o=e.getGeomPipeInfo(t.toData),a=o.startPt,s=o.endPt,l=new Ke;l.subVectors(s,a);var c=l.length();l.normalize();var h=o.radius;h>1||(h=100);var d=new Ke(0,1,0),u=new Ke(h,c,h),p=(new Ge).setFromUnitVectors(d,l),g=a.clone().addScaledVector(l,.5*c),f=(new yt).compose(g,p,u);return n.multiply(f),i&&(n.multiplyMatrices(i.matrix,n),r.multiplyMatrices(i.matrix,r)),o=null,{nodeId:(i?i.ItemId+"_"+t.ItemId:t.ItemId)+"_pipe",geometryId:"pipe",boundingBox:t.boundingBox.clone().applyMatrix4(r),matrix:n,finalState:!0}},Sv.prototype._getMeshNodeAttrOfTube=function(e,t,i){var n=this._getMeshNodeAttrOfPipe(e,t,i);return n.nodeId+="_tube",n.geometryId="tube",n},Sv.prototype._getMeshNodeAttrOfBox=function(e,t,i){var n=e.getMatrixInfo(t.matrixId).matrix.clone(),r=wp.TemporaryMatrix;r.copy(n);var o=t.boundingBox,a=o.getSize(),s=o.getCenter(),l=(new yt).scale(new Ke(a.x,a.y,a.z));return l.setPosition(s),n.multiply(l),i&&(n.multiplyMatrices(i.matrix,n),r.multiplyMatrices(i.matrix,r)),{nodeId:(i?i.ItemId+"_"+t.ItemId:t.ItemId)+"_box",geometryId:"box",boundingBox:t.boundingBox.clone().applyMatrix4(r),matrix:n,finalState:!0}},Sv.prototype._getMeshNodeAttrOfBoxM=function(e,t,i){var n=e.getMatrixInfo(t.matrixId).matrix.clone();return i&&n.multiplyMatrices(i.matrix,n),{nodeId:(i?i.ItemId+"_"+t.ItemId:t.ItemId)+"_boxM",geometryId:"boxM",boundingBox:t.boundingBox.clone().applyMatrix4(n),matrix:n,uvArrayBuffer:e.getGeomBoxUvInfo(t.toData),finalState:!0}},Sv.prototype._getMeshNodeAttrOfPipeM=function(e,t,i){var n=e.getMatrixInfo(t.matrixId).matrix.clone();return i&&n.multiplyMatrices(i.matrix,n),{nodeId:(i?i.ItemId+"_"+t.ItemId:t.ItemId)+"_pipeM",geometryId:"pipeM",boundingBox:t.boundingBox.clone().applyMatrix4(n),matrix:n,uvArrayBuffer:e.getGeomPipeUvInfo(t.toData),finalState:!0}},Sv.prototype._getMeshNodeAttrOfMeshRef=function(e,t,i){return{nodeId:"refMesh|"+(i?i.ItemId+"_"+t.ItemId:t.ItemId),geometryId:t.toData,boundingBox:t.boundingBox.clone(),matrix:e.getMatrixInfo(t.matrixId).matrix.clone(),matrixParent:i?i.matrix:null,finalState:!1,transformed:!1,shared:!0}},Sv.prototype._getMeshNodeAttr=function(e,t,i,n){var r=new yt;r.fromArray(t.matrix||[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1]);var o=i?t.key+"_"+n:t.key,a=i?t.geoId+"_"+n:t.geoId;if(-1!==a){var s=new He,l=this.getReferencedMeshBufferById(t.geoId);return l&&l.position?(s=by.getBoundingBoxByBuffer(l.position)).applyMatrix4(r):Bu.warn("no position "),{nodeId:o,guid:t.guid,geometryId:a,originalGeometryId:t.geoId,matrix:r,boundingBox:s,model:this.model}}},Sv.prototype._getLineNodeAttr=function(e,t,i){var n=null,r=null;return-1!==t.matrixId?(r=!1,n=e.getMatrixInfo(t.matrixId).matrix.clone()):(r=!0,n=new yt),{nodeId:i?"line-"+i.ItemId+"-"+t.ItemId:"line-"+t.ItemId,geometryId:"line-"+t.toData,boundingBox:t.boundingBox.clone(),matrix:n,matrixParent:i?i.matrix:null,finalState:!1,transformed:r}},Sv.prototype._classifyNodeInfo=function(e){this._cacheNodeInfoByComponentId(e),this._cacheNodeInfoByUserId(e),this._cacheNodeInfoByCategory(e)},Sv.prototype._cacheNodeInfoByComponentId=function(e){void 0===this.mapNodeInfoByComponentId[e.componentId]&&(this.mapNodeInfoByComponentId[e.componentId]=[]),this.mapNodeInfoByComponentId[e.componentId].push(e)},Sv.prototype._clearNodeInfoCacheWithComponentId=function(e){if(e)for(var t=0,i=e.length;i>t;t+=1)delete this.mapNodeInfoByComponentId[e[t]];else this.mapNodeInfoByComponentId={}},Sv.prototype._clearNodeInfoCacheWithUserId=function(e){if(e)for(var t=0,i=e.length;i>t;t+=1)delete this.mapNodeInfoByUserId[e[t]];else this.mapNodeInfoByUserId={}},Sv.prototype._clearNodeInfoCacheWithCategory=function(e){if(e)for(var t=this.mapNodeInfoByCategory[Sv.NodeInfoCategory.INSTANCED],i=this.mapNodeInfoByCategory[Sv.NodeInfoCategory.STANDARD],n=0,r=e.length;r>n;n+=1)t&&delete t[e[n]],i&&delete i[e[n]];else this.mapNodeInfoByCategory={}},Sv.prototype.clearNodeInfoCache=function(){this._clearNodeInfoCacheWithComponentId(),this._clearNodeInfoCacheWithUserId(),this._clearNodeInfoCacheWithCategory()},Sv.prototype.clearNodeInfoCacheByComponentsKey=function(e){this._clearNodeInfoCacheWithComponentId(e),this._clearNodeInfoCacheWithUserId(e),this._clearNodeInfoCacheWithCategory(e)},Sv.prototype.getNodeInfosWithComponentId=function(){return this.mapNodeInfoByComponentId},Sv.prototype.getNodeInfosByComponentId=function(e){return this.mapNodeInfoByComponentId[e]},Sv.prototype._cacheNodeInfoByUserId=function(e){void 0===this.mapNodeInfoByUserId[e.userId]&&(this.mapNodeInfoByUserId[e.userId]=[]),this.mapNodeInfoByUserId[e.userId].push(e)},Sv.prototype.getNodeInfosByUserId=function(e){return this.mapNodeInfoByUserId[e]},Sv.prototype.getNodeInfosWithUserId=function(){return this.mapNodeInfoByUserId},Sv.prototype._cacheNodeInfoByCategory=function(e){var t=null;void 0===this.mapNodeInfoByCategory[t=e.instanceOrNot?Sv.NodeInfoCategory.INSTANCED:Sv.NodeInfoCategory.STANDARD]&&(this.mapNodeInfoByCategory[t]={}),void 0===this.mapNodeInfoByCategory[t][e.userId]&&(this.mapNodeInfoByCategory[t][e.userId]=[]),this.mapNodeInfoByCategory[t][e.userId].push(e)},Sv.prototype.getNodeInfosByCategory=function(e){return this.mapNodeInfoByCategory[e]},Sv.prototype.getStandardNodeInfos=function(){return this.getNodeInfosByCategory(Sv.NodeInfoCategory.STANDARD)},Sv.prototype.getInstancedNodeInfos=function(){return this.getNodeInfosByCategory(Sv.NodeInfoCategory.INSTANCED)},Sv.prototype.getStandardUserIds=function(){return this.getStandardNodeInfos()?Object.keys(this.getStandardNodeInfos()):null},Sv.prototype.getInstancedUserIds=function(){return this.getInstancedNodeInfos()?Object.keys(this.getInstancedNodeInfos()):null},Sv.prototype.traverseNodeInfos=function(e){if(e)for(var t in this.mapNodeInfoByComponentId)for(var i=this.mapNodeInfoByComponentId[t],n=0,r=i.length;r>n;n+=1)e(t,i[n])},Sv.prototype.getUserIdsByCategory=function(e,t){var i=[],n=null;if(n=t===Sv.NodeInfoCategory.INSTANCED?this.getInstancedNodeInfos():this.getStandardNodeInfos())for(var r=0,o=e.length;o>r;r+=1)n[e[r]]&&i.push(e[r]);return i},Sv.prototype.getInstancedUserIdsByCategory=function(e){return this.getUserIdsByCategory(e,Sv.NodeInfoCategory.INSTANCED)},Sv.prototype.getStandardUserIdsByCategory=function(e){return this.getUserIdsByCategory(e,Sv.NodeInfoCategory.STANDARD)},Sv.prototype.getNodeInfosOnBMpkGeometryId=function(){return this.nodeInfosOnGeometryId||this.cacheNodeInfosOnGeometryId(),this.nodeInfosOnGeometryId},Sv.prototype.cacheNodeInfosOnGeometryId=function(){var e=this.getStandardNodeInfos();for(var t in this.nodeInfosOnGeometryId={},e)for(var i=e[t],n=0,r=i.length;r>n;n+=1){var o=this.loader.convertToBMpkGeometryId(i[n].geometryId);void 0!==o&&(i[n].geometryId=o),this.nodeInfosOnGeometryId[i[n].geometryId]||(this.nodeInfosOnGeometryId[i[n].geometryId]=[]),this.nodeInfosOnGeometryId[i[n].geometryId].push(i[n])}},Sv.prototype.updateNodeInfosByIds=function(e){},Sv.prototype._isRegularShape=function(e){var t=e.type===Sv.EnumNodeItemType.TUBE||e.type===Sv.EnumNodeItemType.PIPE||e.type===Sv.EnumNodeItemType.BOX||e.type===Sv.EnumNodeItemType.BOX_M||e.type===Sv.EnumNodeItemType.PIPE_M;return xd.SharedMeshInstanceEnable&&(t=t||e.type===Sv.EnumNodeItemType.MESH_REF),t},Sv.prototype.getOctreeRoots=function(e){var t=this.loader,i=t.getOctreeRootNodeOuter();i&&e.push(i);var n=t.getOctreeRootNodeInner();n&&e.push(n)},Sv.prototype.getComponentCount=function(){return this.componentCount},Sv.prototype._parseInstanced=function(){this.instancedComponent={};var e={},t={},i=this.referencedMeshCache;for(var n in i.components)if(i.components.hasOwnProperty(n)){var r=i.components[n],o=r.geoId;if(-1===o){Bu.debug("实体没有几何");continue}if(void 0===e[o]&&(e[o]=[],t[o]={}),e[o].push({componentId:n}),!r.materials){r.materials=[];continue}for(var a=0;r.materials.length>a;a+=1){var s=r.materials[a];t[o][s]||(t[o][s]=[]),t[o][s].push({componentId:n,matrix:r.matrix})}}for(var l in e)if(e.hasOwnProperty(l))if(1<e[l].length)for(a=0;e[l].length>a;a+=1)this.instancedComponent[e[l][a].componentId]=!0;else delete e[l],delete t[l]},Sv.prototype._parseBones=function(){var e=this.referencedMeshCache;for(var t in e._offsetMatrix||(e._offsetMatrix={}),e.geometries){var i=e.geometries[t];i.position.length!==i.normal.length&&(i.normal=i.normal.length===i.index.length?this._computeVertexNormalsFromFaceNormals(i.normal,i.index,i.position.length):this._computeVertexNormalsFromIndex(i.index,i.position));var n=e.bones[t];if(n){i.skinIndex=n.skinIndex,i.skinWeight=n.skinWeight;var r=n.name;n.offsetMatrix.length/16!==r.length&&Bu.debug("bones的name数量与Matrix数量不符");for(var o=0;r.length>o;o+=1)e._offsetMatrix[r[o]]=(new yt).fromArray(n.offsetMatrix,16*o)}}},Sv.prototype._parseClips=function(){for(var e=this.referencedMeshCache.clips,t=[],i=0,n=e.length;n>i;i+=1){for(var r=[],o=e[i],a=0,s=o.tracks.length;s>a;a+=1){var l=o.tracks[a],c=null;switch(l.type){case Sv.EnumKeyframeTrackType.weights:c=gl;break;case Sv.EnumKeyframeTrackType.quaternion:c=ml;break;case Sv.EnumKeyframeTrackType.position:case Sv.EnumKeyframeTrackType.scale:default:c=yl}if(0===o.ticksPerSec){o.ticksPerSec=1e3;for(var h=0;l.times.length>h;h+=1)l.times[h]/=o.ticksPerSec}var d=new c(lh.sanitizeNodeName(l.name)+"."+l.type,l.times,l.values,2301);r.push(d)}var u=new vl(void 0!==o.name?o.name:"animation_"+i,o.duration/o.ticksPerSec,r);t.push(u)}this.model.animations=t},Sv.prototype._parseNodes=function(){var e=this.referencedMeshCache;e.allBones=[],e.offsetMatrix=[];var t=bv(e.nodes,this);for(var i in e.geometries){var n=this.meshCache[i];if(n&&n.isSkinnedMesh){for(var r=[],o=[],a=0;e.bones[i].name.length>a;a+=1){var s=e.bones[i].name[a],l=e._offsetMatrix[s],c=this.allBones[s];l&&c&&(r.push(c),o.push(l))}var h=new Ia(r,o);n.bind(h,n.matrixWorld)}}this.model.nodes=t,this.model.manager.getScene().onBeforeRender=function(e,t,i,n){t.updateMatrixWorld(!0)},this.model.group.add(t),(h=new bh(t)).visible=!1,this.model.skeleton=h,this.model.group.add(h),this.model.mixer=new dh(t),this.model.actions=[];for(var d=0;this.model.animations.length>d;d+=1){var u=this.model.mixer.clipAction(this.model.animations[d]);this.model.actions.push(u)}},Sv.prototype._parseGeo=function(){Bu.time("处理几何:按材质拆分构件");var e=this.referencedMeshCache;for(var t in e.geometries){var i=e.geometries[t];if(i.position.length!==i.normal.length&&(i.normal=i.normal.length===i.index.length?this._computeVertexNormalsFromFaceNormals(i.normal,i.index,i.position.length):this._computeVertexNormalsFromIndex(i.index,i.position)),void 0!==i.materialIndex){for(var n=void 0,r=[],o=null,a=0;i.materialIndex.length>a;a+=1){var s=i.materialIndex[a];s!==o&&(o=s,void 0!==n&&(n.count=3*a-n.start,r.push(n)),n={start:3*a,materialIndex:o})}if(void 0!==n&&(n.count=3*i.materialIndex.length-n.start,r.push(n)),1===r.length){e.geometries[t+"_"+r[0].materialIndex]=i}else{for(var l={},c=0;r.length>c;c+=1){var h=r[c];void 0===l[h.materialIndex]&&(l[h.materialIndex]={index:[],count:0}),l[h.materialIndex].index.push({start:h.start,count:h.count}),l[h.materialIndex].count+=h.count}var d=function(){p={},g=l[u];for(var n=0,r=new Uint32Array(g.count),o=0;g.index.length>o;o+=1){var a=g.index[o],s=i.index.slice(a.start,a.start+a.count);r.set(s,n),n+=a.count}f={},r.forEach((function(e,t){f[e]||(f[e]=[]),f[e].push(t)}));var c=Object.keys(f).length;m=new Float32Array(3*c),A=new Float32Array(3*c),y=new Float32Array(2*c),v=0,C=0;var h=0;for(var d in f)if(f.hasOwnProperty(d)){d=Number(d);var I=i.position.slice(3*d,3*d+3),x=i.normal.slice(3*d,3*d+3);if(i.uv.length>0){var w=i.uv.slice(2*d,2*d+2);y.set(w,C),C+=2}m.set(I,v),A.set(x,v),v+=3,f[d].forEach((function(e){r[e]=h})),h+=1}p.index=r,p.position=m,p.normal=A,i.uv&&i.uv.length>0&&(p.uv=y),e.geometries[t+"_"+u]=p};for(var u in l){var p,g,f,m,A,y,v,C;d()}}}}Bu.timeEnd("处理几何:按材质拆分构件")},Sv.prototype._computeVertexNormalsFromFaceNormals=function(e,t,i){for(var n=new Float32Array(i),r=0,o=0,a=0,s=0,l=0,c=0,h=0;e.length>h;h+=3)l=e[h+1],c=e[h+2],o=3*t[h+1],a=3*t[h+2],n[r=3*t[h]]=s=e[h],n[r+1]=l,n[r+2]=c,n[o]=s,n[o+1]=l,n[o+2]=c,n[a]=s,n[a+1]=l,n[a+2]=c;return n},Sv.prototype._computeVertexNormalsFromIndex=function(e,t){var i=new Float32Array(t.length);if(t){var n=0,r=0,o=0,a=new Ke,s=new Ke,l=new Ke,c=new Ke,h=new Ke;if(e)for(var d=e,u=0;d.length>u;u+=3)r=3*d[u+1],o=3*d[u+2],a.fromArray(t,n=3*d[u]),s.fromArray(t,r),l.fromArray(t,o),c.subVectors(l,s),h.subVectors(a,s),c.cross(h),i[n]+=c.x,i[n+1]+=c.y,i[n+2]+=c.z,i[r]+=c.x,i[r+1]+=c.y,i[r+2]+=c.z,i[o]+=c.x,i[o+1]+=c.y,i[o+2]+=c.z;else for(var p=0,g=t.length;g>p;p+=9)a.fromArray(t,p),s.fromArray(t,p+3),l.fromArray(t,p+6),c.subVectors(l,s),h.subVectors(a,s),c.cross(h),i[p]=c.x,i[p+1]=c.y,i[p+2]=c.z,i[p+3]=c.x,i[p+4]=c.y,i[p+5]=c.z,i[p+6]=c.x,i[p+7]=c.y,i[p+8]=c.z}return i},Sv.prototype._readMaterialBuffer222=function(e){var t=e.materialManager,i=t.materials,n=t.textures,r=this.referencedMeshCache.materials;for(var o in r){var a=r[o];if(!a)return null;var s=new il;if(s.name=a.name||o,s.key=o,a.emissive&&s.emissive&&(1===a.emissive[0]&&1===a.emissive[1]&&1===a.emissive[2]||s.emissive.setRGB(a.emissive[0],a.emissive[1],a.emissive[2])),a.color?s.color.setRGB(a.color[0],a.color[1],a.color[2]):s.color.setRGB(.72,.72,.72),a.tint&&s.color.setRGB(a.tint[0],a.tint[1],a.tint[2]),a.specular&&s.specular&&s.specular.setRGB(a.specular[0],a.specular[1],a.specular[2]),a.map)if(void 0!==a.mapOffsetY&&0!==a.mapOffsetY||void 0!==a.mapOffsetX&&0!==a.mapOfsfetX||void 0!==a.mapScaleX&&1!==a.mapScaleX||void 0!==a.mapScaleY&&1!==a.mapScaleY||void 0!==a.mapWAngle&&0!==a.mapWAngle){var l=a.mapOffsetX+"_"+a.mapOffsetY+"_"+a.mapScaleX+"_"+a.mapScaleY+"_"+a.mapWAngle+"_"+a.map;if(n[l])s.map=n[l];else(p=new Fe).wrapS=p.wrapT=g,p.image=n[a.map].image?n[a.map].image:null,p.needsUpdate=!0,p.image&&(p.offset.x=a.mapOffsetX?a.mapOffsetX:0,p.offset.y=a.mapOffsetY?a.mapOffsetY:0,p.repeat.x=a.mapScaleX?a.mapScaleX:1,p.repeat.y=a.mapScaleY?a.mapScaleY:1,p.rotation=a.mapWAngle?a.mapWAngle:0,n[l]=p,s.map=p)}else s.map=n[a.map]?n[a.map]:null;if(a.aoMap)if(void 0!==a.aoMapOffsetY&&0!==a.aoMapOffsetY||void 0!==a.aoMapOffsetX&&0!==a.aoMapOfsfetX||void 0!==a.aoMapScaleX&&1!==a.aoMapScaleX||void 0!==a.aoMapScaleY&&1!==a.aoMapScaleY||void 0!==a.aoMapWAngle&&0!==a.aoMapWAngle){var c=a.aoMapOffsetX+"_"+a.aoMapOffsetY+"_"+a.aoMapScaleX+"_"+a.aoMapScaleY+"_"+a.aoMapWAngle+"_"+a.aoMap;if(n[c])s.aoMap=n[c];else(p=new Fe).wrapS=p.wrapT=g,p.image=n[a.aoMap]&&n[a.aoMap].image?n[a.aoMap].image:null,p.needsUpdate=!0,p.image&&(p.offset.x=a.aoMapOffsetX?a.aoMapOffsetX:0,p.offset.y=a.aoMapOffsetY?a.aoMapOffsetY:0,p.repeat.x=a.aoMapScaleX?a.aoMapScaleX:1,p.repeat.y=a.aoMapScaleY?a.aoMapScaleY:1,p.rotation=a.aoMapWAngle?a.aoMapWAngle:0,n[c]=p,s.aoMap=p)}else s.aoMap=n[a.aoMap]?n[a.aoMap]:null;if(void 0!==a.aoMapIntensity&&(s.aoMapIntensity=a.aoMapIntensity),a.envMap)if(void 0!==a.envMapOffsetY&&0!==a.envMapOffsetY||void 0!==a.envMapOffsetX&&0!==a.envMapOfsfetX||void 0!==a.envMapScaleX&&1!==a.envMapScaleX||void 0!==a.envMapScaleY&&1!==a.envMapScaleY||void 0!==a.envMapWAngle&&0!==a.envMapWAngle){var h=a.envMapOffsetX+"_"+a.envMapOffsetY+"_"+a.envMapScaleX+"_"+a.envMapScaleY+"_"+a.envMapWAngle+"_"+a.envMap;if(n[h])s.envMap=n[h];else(p=new Fe).wrapS=p.wrapT=g,p.image=n[a.envMap].image?n[a.envMap].image:null,p.needsUpdate=!0,p.image&&(p.offset.x=a.envMapOffsetX?a.envMapOffsetX:0,p.offset.y=a.envMapOffsetY?a.envMapOffsetY:0,p.repeat.x=a.envMapScaleX?a.envMapScaleX:1,p.repeat.y=a.envMapScaleY?a.envMapScaleY:1,p.rotation=a.envMapWAngle?a.envMapWAngle:0,n[h]=p,s.envMap=p)}else s.envMap=n[a.envMap]?n[a.envMap]:null;if(a.lightMap)if(void 0!==a.lightMapOffsetY&&0!==a.lightMapOffsetY||void 0!==a.lightMapOffsetX&&0!==a.lightMapOfsfetX||void 0!==a.lightMapScaleX&&1!==a.lightMapScaleX||void 0!==a.lightMapScaleY&&1!==a.lightMapScaleY||void 0!==a.lightMapWAngle&&0!==a.lightMapWAngle){var d=a.lightMapOffsetX+"_"+a.lightMapOffsetY+"_"+a.lightMapScaleX+"_"+a.lightMapScaleY+"_"+a.lightMapWAngle+"_"+a.lightMap;if(n[d])s.lightMap=n[d];else(p=new Fe).wrapS=p.wrapT=g,p.image=n[a.lightMap].image?n[a.lightMap].image:null,p.needsUpdate=!0,p.image&&(p.offset.x=a.lightMapOffsetX?a.lightMapOffsetX:0,p.offset.y=a.lightMapOffsetY?a.lightMapOffsetY:0,p.repeat.x=a.lightMapScaleX?a.lightMapScaleX:1,p.repeat.y=a.lightMapScaleY?a.lightMapScaleY:1,p.rotation=a.lightMapWAngle?a.lightMapWAngle:0,n[d]=p,s.lightMap=p)}else s.lightMap=n[a.lightMap]?n[a.lightMap]:null;if(void 0!==a.lightMapIntensity&&(s.lightMapIntensity=a.lightMapIntensity),a.emissiveMap)if(void 0!==a.emissiveMapOffsetY&&0!==a.emissiveMapOffsetY||void 0!==a.emissiveMapOffsetX&&0!==a.emissiveMapOfsfetX||void 0!==a.emissiveMapScaleX&&1!==a.emissiveMapScaleX||void 0!==a.emissiveMapScaleY&&1!==a.emissiveMapScaleY||void 0!==a.emissiveMapWAngle&&0!==a.emissiveMapWAngle){var u=a.emissiveMapOffsetX+"_"+a.emissiveMapOffsetY+"_"+a.emissiveMapScaleX+"_"+a.emissiveMapScaleY+"_"+a.emissiveMapWAngle+"_"+a.emissiveMap;if(n[u])s.emissiveMap=n[u];else(p=new Fe).wrapS=p.wrapT=g,p.image=n[a.emissiveMap].image?n[a.emissiveMap].image:null,p.needsUpdate=!0,p.image&&(p.offset.x=a.emissiveMapOffsetX?a.emissiveMapOffsetX:0,p.offset.y=a.emissiveMapOffsetY?a.emissiveMapOffsetY:0,p.repeat.x=a.emissiveMapScaleX?a.emissiveMapScaleX:1,p.repeat.y=a.emissiveMapScaleY?a.emissiveMapScaleY:1,p.rotation=a.emissiveMapWAngle?a.emissiveMapWAngle:0,n[u]=p,s.emissiveMap=p)}else s.emissiveMap=n[a.emissiveMap]?n[a.emissiveMap]:null;if(void 0!==a.emissiveIntensity&&(s.emissiveIntensity=a.emissiveIntensity),a.specularMap)if(void 0!==a.specularMapOffsetY&&0!==a.specularMapOffsetY||void 0!==a.specularMapOffsetX&&0!==a.specularMapOfsfetX||void 0!==a.specularMapScaleX&&1!==a.specularMapScaleX||void 0!==a.specularMapScaleY&&1!==a.specularMapScaleY||void 0!==a.specularMapWAngle&&0!==a.specularMapWAngle){var p,f=a.specularMapOffsetX+"_"+a.specularMapOffsetY+"_"+a.specularMapScaleX+"_"+a.specularMapScaleY+"_"+a.specularMapWAngle+"_"+a.specularMap;if(n[f])s.specularMap=n[f];else(p=new Fe).wrapS=p.wrapT=g,p.image=n[a.specularMap].image?n[a.specularMap].image:null,p.needsUpdate=!0,p.image&&(p.offset.x=a.specularMapOffsetX?a.specularMapOffsetX:0,p.offset.y=a.specularMapOffsetY?a.specularMapOffsetY:0,p.repeat.x=a.specularMapScaleX?a.specularMapScaleX:1,p.repeat.y=a.specularMapScaleY?a.specularMapScaleY:1,p.rotation=a.specularMapWAngle?a.specularMapWAngle:0,n[f]=p,s.specularMap=p)}else s.specularMap=n[a.specularMap]?n[a.specularMap]:null;void 0!==a.shininess&&(s.shininess=a.shininess),void 0!==a.opacity&&(s.opacity=a.opacity,1>a.opacity&&(s.transparent=!0),a.opacity>0||(s.opacity=.1)),s.side=2,i[o]=s}},Sv.prototype._updateV1ToV2=function(e){var t=this.referencedMeshCache.components,i=this.referencedMeshCache.geometries,n=this.referencedMeshCache.materials;for(var r in t)if(t.hasOwnProperty(r)){var o=t[r],a=o.matId,s=i[o.geoId];if(o.materials)continue;if(o.materials=[],!s)continue;var l=n[a];if(!l)continue;var c=this._updateMaterialV1ToV2(a,l);if(c)for(var h in s.materialIndex=c.materialIndex,o.materials=c.materialId,c.materials)c.materials.hasOwnProperty(h)&&(this.referencedMeshCache.materials[h]=c.materials[h])}},Sv.prototype._updateMaterialV1ToV2=function(e,t){var i={},n=[],r={};if(!t)return null;for(var o=t.color,a=t.colorIndex,s=t.texture,l=t.textureIndex,c=0;o.length>c;c+=4){var h={};h.color=[o[c],o[c+1],o[c+2]],h.opacity=Math.floor(100*o[c+3])/100,h.transparent=1>o[c+3];var d=(255*h.color[0]<<16^255*h.color[1]<<8^255*h.color[2]<<0)+"_"+h.opacity;r[d]=h,n.push(d)}if(0!==s.length&&a.length===l.length)for(var u=-1,p=0;l.length>p;p+=1){if(u!==a[p])if(u=a[p],-1!==l[p])r[n[a[p]]].map=s[l[p]]}return i.materials=r,i.materialId=n,i.materialIndex=a,i},Sv.prototype.addMeshToInfoMap=function(e,t,i,n){var r=this.getNodeInfosByComponentId(e);Array.isArray(r)&&r.forEach((function(e){e.nodeId===t&&(e.mesh=i,e.index=n)}))};var kv=function(){this.geometries={}};kv.prototype.dispose=function(){this.disposeGeometries(),this.geometries={}},kv.prototype.destory=function(){this.dispose()},kv.prototype.disposeGeometries=function(){for(var e in this.geometries)this.disposeGeometry(e)},kv.prototype.disposeGeometry=function(e){var t=this.geometries[e];if(t){if(Array.isArray(t))for(var i=0,n=t.length;n>i;i+=1)t[i].dispose();else t.dispose();delete this.geometries[e]}},kv.prototype._hasGeometry=function(e){return!!this.geometries[e]},kv.prototype._cacheGeometry=function(e,t){void 0===this.geometries[e]&&(this.geometries[e]=t)},kv.prototype.getNodeIdxMapByUserId=function(e){},kv.prototype.getGeometryById=function(e){return this.geometries[e]},kv.prototype.getGeometryByNodeInfo=function(e,t){return this._hasGeometry(t.geometryId)?this.getGeometryById(t.geometryId):this._createGeometryByNodeInfo(e,t)},kv.prototype._createGeometryByNodeInfo=function(e,t){return this._createGeometry(t.type,t.geometryId,e.getModelDescriptor().getReferencedMeshBufferById(t.geometryId))},kv.prototype._createGeometry=function(e,t,i){if(this._hasGeometry(t))return this.getGeometryById(t);var n=this._createBufferGeometry(e,i);return n?(n.key=t,this._cacheGeometry(t,n),n):null},kv.prototype._createBufferGeometry=function(e,t){var i=Sv.EnumNodeItemType,n=null;switch(1){case i.MESH:case i.MESH_REF:if(!t)return null;if((n=new Ni).setIndex(new Ai(t.index,1)),n.setAttribute("position",new Ai(t.position,3)),t.normal&&t.normal.length>0?n.setAttribute("normal",new Ai(t.normal,3)):n.computeVertexNormals(),t.uv&&t.uv.length>0&&n.setAttribute("uv",new Ai(t.uv,2)),t.uv2&&t.uv2.length>0&&n.setAttribute("uv2",new Ai(t.uv2,2)),t.skinIndex&&t.skinIndex.length>0?n.setAttribute("skinIndex",new Ai(t.skinIndex,4)):Bu.debug("skinIndex 长度为0"),t.skinWeight&&t.skinWeight.length>0?n.setAttribute("skinWeight",new Ai(t.skinWeight,4)):Bu.debug("skinWeight 长度为0"),void 0!==t.materialIndex){for(var r=null,o=[],a=void 0,s=0;t.materialIndex.length>s;s+=1){var l=t.materialIndex[s];l!==a&&(a=l,null!=r&&(r.count=3*s-r.start,o.push(r)),r={start:3*s,materialIndex:a})}null!=r&&(r.count=3*t.materialIndex.length-r.start,o.push(r)),n.groups=o}break;case i.TUBE:case i.PIPE:n=by.UnitCylinderInstance;break;case i.BOX:n=by.UnitBoxInstance;break;case i.BOX_M:n=by.getUnitTextureBox();break;case i.PIPE_M:n=by.getUnitTextureCylinder();break;case i.LINE:if(!t)return null;(n=new Ni).setIndex(new Ai(t.I,1)),n.setAttribute("position",new Ai(t.P,3))}return n},kv.prototype.createBufferByBufferDataWithUV2=function(e,t,i){var n=this.createBufferByBufferData(t,i);if(!n)return null;if(!e.lightmap)return n;var r=[],o=n.index,a=e.getLoader().getUV2ById(t.itemIdUV2,o.length);a&&(t.lightmapIdx=a.lightmapIdx,r=a.uv2);for(var s=n.position,l=n.normal,c=n.uv,h=[],d=[],u=[],p=0;o.length>p;p+=1){var g=o[p];h.push(s[3*g]),h.push(s[3*g+1]),h.push(s[3*g+2]),l&&(d.push(l[3*g]),d.push(l[3*g+1]),d.push(l[3*g+2])),c&&(u.push(c[2*g]),u.push(c[2*g+1])),o[p]=p}return s=null,l=null,c=null,n.uv2=r,n.position=h,n.normal=d,n.uv=u,n},kv.prototype.createBufferByBufferData=function(e,t){this.cachedComponentGeoBuffer||(this.cachedComponentGeoBuffer={});var i=null,n=null,r=null,o=null,a=null,s=Sv.EnumNodeItemType,l=null;switch(1){case s.MESH:case s.MESH_REF:if(!t||!t.buffer)return Bu.debug("缺少几何buffer"),null;var c=t.buffer;if(n=c.index,e.geometryId===e.originalGeometryId?(i=c.position,r=c.normal,o=c.uv?c.uv:null,a=c.uv2?c.uv2:null):(i=Float32Array.from(c.position),r=Float32Array.from(c.normal),o=c.uv?Float32Array.from(c.uv):null,a=c.uv2?Float32Array.from(c.uv2):null),c=null,t.indexInfo){n=n.slice(t.indexInfo.indexStart,t.indexInfo.indexStart+t.indexInfo.indexCount),i=i.slice(t.indexInfo.positionStart,t.indexInfo.positionStart+t.indexInfo.positionCount),r=r.slice(t.indexInfo.positionStart,t.indexInfo.positionStart+t.indexInfo.positionCount),o=o?o.slice(t.indexInfo.uvStart,t.indexInfo.uvStart+t.indexInfo.uvCount):null,a=a?a.slice(t.indexInfo.uvStart,t.indexInfo.uvStart+t.indexInfo.uvCount):null;var h=t.indexInfo.positionStart/3;n.forEach((function(e,t,i){i[t]-=h}))}if(wp.isMirror(e.matrix.elements))for(var d=0,u=n.length;u>d;d+=3){var p=n[d+1];n[d+1]=n[d+2],n[d+2]=p}break;case s.BOX:case s.PIPE:l=by.UnitCylinderInstance,n=Uint32Array.from(l.index.array),i=Float32Array.from(l.attributes.position.array),r=Float32Array.from(l.attributes.normal.array),l=null;break;case s.TUBE:case s.BOX_M:case s.PIPE_M:l=e.type===s.BOX_M||e.type===s.BOX?by.getBoxMBuffer(e.uvArrayBuffer):by.getPipeMBuffer(e.uvArrayBuffer),n=Uint32Array.from(l.index),i=Float32Array.from(l.vertex),r=Float32Array.from(l.normal),l.uv&&(o=Float32Array.from(l.uv),delete l.uv),l=null;break;case s.LINE:if(!t||!t.buffer)return null;if(t.isDataView?(n=Uint32Array.from(t.buffer.I),i=Float32Array.from(t.buffer.P),r=null,o=null):(n=new Uint32Array(t.buffer.I),i=new Float32Array(t.buffer.P),r=null,o=null),t.indexInfo){n=n.slice(t.indexInfo.indexStart,t.indexInfo.indexStart+t.indexInfo.indexCount),i=i.slice(t.indexInfo.positionStart,t.indexInfo.positionStart+t.indexInfo.positionCount);h=t.indexInfo.positionStart/3;n.forEach((function(e,t,i){i[t]-=h}))}break;default:Bu.log("error data!")}if(!this.cachedComponentGeoBuffer[e.geometryId]||e.geometryId!==e.originalGeometryId){var g=e.matrix;if(by.applyMatrix4ToBuffer(g,i),r){var f=new De;f.getNormalMatrix(g),by.applyMatrix3ToBuffer(f,r),by.normalizeBuffer(r)}this.cachedComponentGeoBuffer[e.geometryId]=!0}return e.uv=!!o,{index:n,position:i,normal:r,uv:o,uv2:a}};var Dv=function(e){return kv.call(this),this.manager=e,this._maxIndiceseNum=0,this._materialList=[],this.mapMaterialIdToMergedNode={},this.selectedMeshes=[],this.nonSelectedMeshes=[],this.selectedObjectIds=[],this.blinkMaterials=[],this.mapDestroyedBufferKey={},this};function Tv(e,t,i,n){for(var r=e.getAttribute("position").array,o=t;i>o;o+=3)r[o]+=n.x,r[o+1]+=n.y,r[o+2]+=n.z;e.getAttribute("position").needsUpdate=!0}(Dv.prototype=Object.create(kv.prototype)).destroy=function(){this.dispose(),this.clearData(),this.mapMaterialIdToMergedNode={},this.manager=null,this._materialList=[],this.selectedMeshes=[],this.nonSelectedMeshes=[],this.selectedObjectIds=[],this.blinkMaterials=[],this.mapDestroyedBufferKey={}},Dv.prototype.clearData=function(){this.bufferDestroyed=!1,this.clearAllNodeBuffer(),this._disposeMergedGeometries()},Dv.prototype.getMeshesByUserIds=function(e,t){var i=[];for(var n in this.mapMaterialIdToMergedNode)for(var r=this.mapMaterialIdToMergedNode[n],o=0,a=r.length;a>o;o+=1){var s=r[o],l=s.indices[t];if(l)for(var c=0,h=l.length;h>c;c+=1){var d={};d.mesh=s.mesh,d.indexInfo=l[c],d.matrix=e.getModelMatrix(),i.push(d)}}return i},Dv.prototype.rebuildIndices=function(e){this._materialList.length=0;var t=xd.EnableLightmap&&e.lightmap;this.clearSelectedObjectIds();var i=this.manager.getFilteredUserIds(),n=this.manager.getSelectedUserIds(),r=this.manager.getHoveredUserIds(),o=this.manager.getBlinkedUserIds();e.hasReplacedUserId();var a=e.manager.scene.fillClipPlane&&xd.ClippingCaps,s={};for(var l in this.mapMaterialIdToMergedNode){var c,h=this.getPropertyValueByMaterialKey(l).materialId,d=null,u=null,p=null,g=null,f=null,m=null,A=null,y=null,v=null;n&&n[h]&&(g=n[h]),r&&r[h]&&(f=r[h]),o&&o[h]&&(m=o[h]),i&&i[h]&&(d=i[h][Zd.HIDDEN],u=i[h][Zd.OVERRIDED],p=i[h][Zd.TRANSPARENT]);var C=this.mapMaterialIdToMergedNode[l];for(v=0,c=C.length;c>v;v+=1){var I=C[v],x=I.indices,w=I.geometry;if(w.clearGroups(),w._visible=!0,t)for(var M=e.lightmapNum,E=0;M>E;E+=1){var B="lightmap|"+E;-1===this._materialList.indexOf(B)&&this._materialList.push(B)}if(g||d||u||f||p||xd.EnableLightmap||a||m||e.isUpdateBlink){var S=[];for(var b in x)if(x.hasOwnProperty(b)){if(d&&d[b])continue;var k=x[b];if(k&&k.length>0){if(k.sort((function(e,t){return e.indexStart-t.indexStart})),p&&p[b]){for(A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.TRANSPARENT});continue}if(e.manager.isSelectPriority()){if(g&&g[b]){if(this.cacheSelectedObjectIds(b,l,v),xd.PickingEffect){if(u&&u[b]){var D=u[b],T=this._materialList.indexOf(D);for(-1===T&&(this._materialList.push(D),T=this._materialList.length-1),A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.OVERRIDED+T});continue}for(A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.NONE});continue}for(A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.SELECTED});continue}if(m&&m[b]){if(u&&u[b]){var R="blink|"+u[b],U=this._materialList.indexOf(R);for(-1===U&&(this._materialList.push(R),U=this._materialList.length-1),A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.OVERRIDED+U});continue}for(A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.BLINK});continue}}else{if(m&&m[b]){if(u&&u[b]){var F="blink|"+u[b],Q=this._materialList.indexOf(F);for(-1===Q&&(this._materialList.push(F),Q=this._materialList.length-1),A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.OVERRIDED+Q});continue}for(A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.BLINK});continue}if(g&&g[b]){if(this.cacheSelectedObjectIds(b,l,v),xd.PickingEffect){if(u&&u[b]){var L=u[b],O=this._materialList.indexOf(L);for(-1===O&&(this._materialList.push(L),O=this._materialList.length-1),A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.OVERRIDED+O});continue}for(A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.NONE});continue}for(A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.SELECTED});continue}}if(e.blinkMapComponentKeyToMaterialName&&e.blinkMapComponentKeyToRenderState[b]){var N=e.blinkMapComponentKeyToMaterialName[b],P=this._materialList.indexOf(N);for(-1===P&&(this._materialList.push(N),P=this._materialList.length-1),A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.OVERRIDED+P});continue}if(f&&f[b]){if(u&&u[b]){var G=this._materialList.indexOf(K="hover|"+u[b]);for(-1===G&&(this._materialList.push(K),G=this._materialList.length-1),A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.OVERRIDED+G});continue}for(A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.HOVER});continue}if(u&&u[b]){var K,V=this._materialList.indexOf(K=u[b]);for(-1===V&&(this._materialList.push(K),V=this._materialList.length-1),A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.OVERRIDED+V});continue}if(a&&s[b]){for(A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.CLIPPING});continue}if(xd.EnableLightmap)for(A=0,y=k.length;y>A;A+=1){var Y=this._materialList.indexOf("lightmap|"+k[A].lightmapIdx);S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.OVERRIDED+Y})}else for(A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:0})}}if(S.length>0)for(S.sort((function(e,t){return e.state===t.state?e.indexStart-t.indexStart:e.state-t.state})),A=0,y=S.length;y>A;A+=1){var H=S[A].indexStart,j=S[A].indexCount,W=S[A].state;if(0===A)w.addGroup(H,j,W);else W===S[A-1].state&&H===S[A-1].indexStart+S[A-1].indexCount?w.groups[w.groups.length-1].count+=j:w.addGroup(H,j,W)}else w._visible=!1}}}},Dv.prototype.update=function(e,t){var i=e.manager.filter,n=e.materialManager.materials,r=e.selectedMaterial,o=e.manager.sceneState,a=null,s=null,l=null,c=null,h=null,d=null,u=xd.EnableLightmap&&e.lightmap;if(e.isOnlyWireframe())for(var p in this.mapMaterialIdToMergedNode){var g=this.mapMaterialIdToMergedNode[p];for(l=0,c=g.length;c>l;l+=1){var f=g[l].mesh;f&&(f.visible=!1)}}else{xd.TranslucentDepthDisabled&&(r.depthWrite=!r.transparent);var m=i._getMaterialByName("scene");xd.TranslucentDepthDisabled&&(m.depthWrite=!1);var A=[];this.blinkMaterials.length=0;var y={};if(!u)for(a=0,s=this._materialList.length;s>a;a+=1){var v=null,C=this._materialList[a],I=C.split("|");"blink"===C.split("_")[0]?v=e.blinkMapMaterialNameToMaterial[C]:"hover"===I[0]?(v=i._getMaterialByName(I[1]),v=o.getHoverMaterial(v)):"blink"===I[0]?(v=i._getMaterialByName(I[1]),v=o.getBlinkMaterial(v),y[C]||this.blinkMaterials.push(v)):v=i._getMaterialByName(C)?i._getMaterialByName(C):this.manager.model.materialManager.getMaterialById(C),xd.TranslucentDepthDisabled&&(v.depthWrite=!v.transparent),A[a]=v}for(var x in this.mapMaterialIdToMergedNode){var w=this.getPropertyValueByMaterialKey(x).materialId,M=e.manager.getOverrideMaterialByName(w)||n[w]||cA.getDefaultStandardMaterial();if(M){if(u)for(a=0,s=this._materialList.length;s>a;a+=1){var E=null,B=this._materialList[a].split("|");if("lightmap"===B[0])if(xd.IBL)E=M.clone();else{var S=cA.getMaterialParameters(M);S.lights=!1,(E=cA.createStandardMaterial(S)).lightMap=e.materialManager.lightmaps[B[1]],E.lightMapIntensity=xd.LightmapIntensity}xd.TranslucentDepthDisabled&&E&&(E.depthWrite=!E.transparent),A[a]=E}xd.TranslucentDepthDisabled&&(M.depthWrite=!M.transparent);var b=o.getHoverMaterial(n[w]);xd.TranslucentDepthDisabled&&(b.depthWrite=!b.transparent);var k=this.mapMaterialIdToMergedNode[x];for(l=0,c=k.length;c>l;l+=1){var D=k[l],T=D.geometry;if(null!==T){var R=D.mesh;if(R)if(T._visible){if(T.groups.length>0){var U=y[w];U||(U=y[w]=o.getBlinkMaterial(M),this.blinkMaterials.push(U));var F=[M,r,U,b,m];for(a=0,s=A.length;s>a;a+=1){if(!A[a].createByBos){if(A[a].materialId!==w&&!A[a].mapNodeIdToOrigMatId)continue;if(!Object.keys(A[a].mapNodeIdToOrigMatId).find((function(e){return A[a].mapNodeIdToOrigMatId[e]===w})))continue}for(var Q in T.attributes.uv||(A[a].map=null),k[l].indices){if(e.blinkMapComponentKeyToMaterialName&&e.blinkMapComponentKeyToRenderState[Q])A[a].name&&A[a].name===e.blinkMapComponentKeyToMaterialName[Q]&&(F[5+a]=A[a]);else if(this.manager.mapMaterialIdToUserIdsForFilter[w]&&this.manager.mapMaterialIdToUserIdsForFilter[w][Zd.OVERRIDED])for(var L=Object.keys(this.manager.mapMaterialIdToUserIdsForFilter[w][Zd.OVERRIDED]),O=0,N=L.length;N>O;O+=1)Q===L[O]&&(F[5+a]=A[a])}}if(t){var P=[];for(h=0,d=F.length;d>h;h+=1)P.push(t);F=P}R.material=F}else R.material=t||M;R.visible=!0}else R.visible=!1;else Bu.error("没有mesh对象")}}M=null}}e.isUpdateBlink=!1}},Dv.prototype.explode=function(e,t,i){for(var n in this.mapMaterialIdToMergedNode)for(var r=this.mapMaterialIdToMergedNode[n],o=0,a=r.length;a>o;o+=1){var s=r[o],l=s.geometry;if(null!==l){var c=s.indices;for(var h in c){var d=e.manager.getComponentInfoByUserId(h).boundingBox,u=wp.computeExplodeTranslation(t,d,i),p=c[h];if(p)for(var g=0,f=p.length;f>g;g+=1){var m=p[g].positionStart;Tv(l,m,m+p[g].positionCount,u)}}}}},Dv.prototype.explosion=function(e,t){var i=e.getModelDescriptor().getStandardUserIds();t.componentKey=i,this.componentsExplosion(e,t)},Dv.prototype.closeExplosion=function(e){this.explosion(e,{})},Dv.prototype.componentsExplosion=function(e,t){var i=t.coefficientX||1,n=t.coefficientY||1,r=t.coefficientZ||1,o=t.offsetX||0,a=t.offsetY||0,s=t.offsetZ||0,l=null;if(t.center)l=(new Ke).fromArray(t.center);else if(1!==i||1!==n||1!==r||0!==o||0!==a||0!==s)return;var c=Array.isArray(t.componentKey)?t.componentKey:[t.componentKey],h=new Ke,d=new He,u=new Ke(0,0,0),p=new Ke(0,0,0),g=new Ke,f=new yt,m=e.getModelMatrix();m&&l&&(f.copy(m).invert(),l.applyMatrix4(f));var A=e.manager,y=!1,v=new Ke,C=new Ge,I=new Ke(1,1,1);wp.isEmptyObject(e.subModel)||(y=!0);for(var x=0,w=c.length;w>x;x+=1){var M=c[x];if(M){var E=e.getModelDescriptor().getStandardNodeInfosById(M);if(E)for(var B=0,S=E.length;S>B;B+=1){var b=E[B];if(b){var k=this._getMaterialKeyByNodeInfo(b),D=this.mapMaterialIdToMergedNode[k];if(D)for(var T=0,R=D.length;R>T;T+=1){var U=D[T],F=U.geometry,Q=U.mesh;if(F&&Q){var L=U.indices;if(L){var O=L[M];if(O){d.copy(b.boundingBox),d.getCenter(h),b.userData||(b.userData={}),u.set(0,0,0),p.set(0,0,0);var N=new Ke(1,1,1);if(y&&(Q.matrix.decompose(v,C,I),N.divide(I)),1!==i||1!==n||1!==r||b.userData.explosionFactor){b.userData.explosionFactor||(b.userData.explosionFactor=new Ke(1,1,1),b.userData.explosionBaseDifference=h.sub(l).clone().multiply(N));var P=b.userData.explosionFactor,G=b.userData.explosionBaseDifference;u.set((i-P.x)*G.x,(n-P.y)*G.y,(r-P.z)*G.z),1===i&&1===n&&1===r?(b.userData.explosionFactor=void 0,b.userData.explosionBaseDifference=void 0):P.set(i,n,r)}if(0!==o||0!==a||0!==s||b.userData.explosionOffset){b.userData.explosionOffset||(b.userData.explosionOffset=new Ke(0,0,0));var K=b.userData.explosionOffset;p.set(o*N.x-K.x,a*N.y-K.y,s*N.z-K.z),0===o&&0===a&&0===s?b.userData.explosionOffset=void 0:K.set(o*N.x,a*N.y,s*N.z)}if(g.set(u.x+p.x,u.y+p.y,u.z+p.z),0!==g.x||0!==g.y||0!==g.z){b.userData.explosionFactor||b.userData.explosionOffset?A.explosionList[M]||(A.explosionList[M]=!0):delete A.explosionList[M];var V=g.clone().multiply(I);f.makeTranslation(V.x,V.y,V.z),b.userData.changeOffset=g.clone(),b.transformation||(b.transformation=!0,b.transformationOriginalMatrix=b.matrix.clone(),b.applyMatrix=new yt,b.transformationOriginalBoundingBox=b.boundingBox.clone()),b.matrix.premultiply(f),b.applyMatrix.premultiply(f),b.boundingBox.copy(b.transformationOriginalBoundingBox).applyMatrix4(b.applyMatrix);for(var Y=0,H=O.length;H>Y;Y+=1){var j=O[Y].positionStart;Tv(F,j,j+O[Y].positionCount,g)}F.attributes.position.needsUpdate=!0}}}}}}}}}},Dv.prototype.closeComponentsExplosion=function(e,t){t=Array.isArray(t)?t:[t];this.componentsExplosion(e,{componentKey:t})},Dv.prototype._getNodeGroup=function(e){return e._getNodeGroup(Vp.GEOMETRY,{globalSpace:!0})},Dv.prototype._hasNodeGroup=function(e){return e._hasNodeGroup(Vp.GEOMETRY)},Dv.prototype._resetMaxIndicesNumberPerBathSegment=function(e){xd.SegmentedBatchMergeEnable&&this._maxIndiceseNum>xd.maxIndicesNumberPerBathSegment&&(Bu.log("adjust maxIndicesNumberPerBathSegment value from "+xd.maxIndicesNumberPerBathSegment+" to "+this._maxIndiceseNum+"!"),xd.maxIndicesNumberPerBathSegment=e)},Dv.prototype.asyncCreateMeshNodes=function(e,t,i){var n=this;t&&t.length?this._asyncMergeData(e,t,(function(){Bu.timeEnd("MergeData"),n._makeMeshNodes(e),i&&i()})):i&&i()},Dv.prototype.createBatchedMeshNodes=function(e,t){var i=this,n=this.mapMaterialIdToMergedNode,r=e.manager,o=e.modelKey,a=e._encodedDatabagId,s=this._getNodeGroup(e),l=e.materialManager,c=t.materialKey,h=i.getPropertyValueByMaterialKey(c),d=l.getMaterialById(h.materialId);if(!d){var u=Object.keys(t.componentInfo)[0],p=t.componentInfo[u][0].nodeId,g=e.getModelDescriptor().getNodeInfosByNodeId(p);if(!g)return;g.uv="1"===h.uvProp,c=i._getMaterialKeyByNodeInfo(g,e),h=i.getPropertyValueByMaterialKey(c),d=l.getMaterialById(h.materialId)}var f=new Ni;if(f._visible=!0,f.setIndex(new Ai(t.index,1)),t.position&&t.position.length>0){f.setAttribute("position",new Ai(t.position,3)),t.normal&&t.normal.length===t.position.length&&f.setAttribute("normal",new Ai(t.normal,3));var m=!1;t.uv&&t.uv.length>0>0&&(f.setAttribute("uv",new Ai(t.uv,2)),m=!0),d.aoMap&&f.setAttribute("uv2",new Ai(t.uv,2)),f.getAttribute("normal")||f.computeVertexNormals();var A=t.componentInfo;n[c]||(n[c]=[]);var y=null;if("lines"===h.type)(y=new ov(f)).modelKey=o;else{var v={modelKey:o};(y=new Bv(f,d)).spawn(v)}if(n[c].push({geometry:f,indices:A,mesh:y}),y._indicesGroup=A,!wp.isEmptyObject(e.subModel)){var C=Object.keys(A)[0];if(C){var I=wp.getModelKeyFromComponentKey(C);e.subModel[I]&&y.matrix.copy(e.subModel[I])}}s.add(y),r.addMeshToOctantMap(a,c,new Mm(c,y));var x=function(t){A.hasOwnProperty(t)&&A[t].forEach((function(i){e.addMeshToInfoMap(t,i.nodeId,y,i,m)}))};for(var w in A)x(w);s.updateMatrixWorld(!0),e.manager.viewerImpl.render(),A=null,y=null}},Dv.prototype._asyncMergeData=function(e,t,i){Bu.time("MergeData");var n={},r=this,o=e.getLoader().maxLoadTaskCount,a=e.progressPercentage.load,s=e.progressPercentage.collect,l=t.length,c=Math.ceil(l/e.progressFrequency),h=e.getModelDescriptor().getStandardNodeInfos();requestAnimationFrame(function d(u){var p=u;return function(){var u=null,g=null;for(g=p+c>l?l:p+c,u=p;g>u;u+=1){if(r._collectMergedNodeInfosById(e,t[u],h,n),u===g-1)if(g!==l)e.dispatchEventEx({type:Fd.ON_LOAD_PROGRESS,progress:{total:o,loaded:(u/l*s+a)*o,modelKey:e.modelKey}}),requestAnimationFrame(d(u+1));else e.dispatchEventEx({type:Fd.ON_LOAD_PROGRESS,progress:{total:o,loaded:(s+a)*o,modelKey:e.modelKey}}),r._asyncMergeGeometry(n,e,i)}}}(0))},Dv.prototype._asyncMergeGeometry=function(e,t,i){var n=[];for(var r in e)n.push(r);if(0!==n.length){this._resetMaxIndicesNumberPerBathSegment(this._maxIndiceseNum);var o=this,a=t.getLoader().maxLoadTaskCount,s=t.progressPercentage.load,l=t.progressPercentage.collect,c=t.progressPercentage.merge,h=n.length,d=Math.ceil(h/t.progressFrequency),u=this.mapMaterialIdToMergedNode;requestAnimationFrame(function r(p){var g=p;return function(){var p,f=null;for(f=g+d>h?h:g+d,p=g;f>p;p+=1){if(o._collectMergedGeometriesById(n[p],e,u),p===f-1)if(f!==n.length)t.dispatchEventEx({type:Fd.ON_LOAD_PROGRESS,progress:{total:a,loaded:(p/h*c+s+l)*a,modelKey:t.modelKey},modelKey:t.modelKey}),requestAnimationFrame(r(p+1));else i()}}}(0))}else i()},Dv.prototype._collectMergedNodeInfosById=function(e,t,i,n){for(var r=i[t],o=0,a=r.length;a>o;o+=1){var s=r[o];this._createNodeBuffer(e,s);var l=this._getNodeBufferBy(s.nodeId);if(l){var c=l.index;c&&c.length>this._maxIndiceseNum&&(this._maxIndiceseNum=c.length);var h=this._getMaterialKeyByNodeInfo(s,e);void 0===n[h]&&(n[h]=[]),n[h].push(s)}}},Dv.prototype._collectMergedGeometriesById=function(e,t,i){var n=t[e];void 0===i[e]&&(i[e]=[]);for(var r=[],o=Math.max(n.length/800,500),a=Math.floor(n.length/o),s=n.length,l=0;a>=l;l+=1){for(var c=0,h=0,d=0,u=0,p=0,g=null,f=!1,m=0,A=0,y=s>o?o:s;y>A;A+=1){var v=l*o,C=n[v+A];if(!C)break;(g=this._getNodeBufferBy(C.nodeId))?(h+=g.index.length,c+=g.position.length,g.normal&&(d+=g.normal.length),g.uv&&g.uv.length>0?(f=!0,u+=g.uv.length):u+=g.position.length/3*2,g.uv2&&(p+=g.uv2.length),xd.SegmentedBatchMergeEnable&&h>xd.maxIndicesNumberPerBathSegment?(g.normal&&(d-=g.normal.length),g.uv&&(u-=g.uv.length),g.uv2&&(p-=g.uv2.length),r.push({start:m,end:A,steps:v,arrayPositionLength:c-=g.position.length,arrayIndexLength:h-=g.index.length,arrayNormalLength:d,arrayUVLength:u,arrayUV2Length:p}),c=0,h=0,d=0,u=0,p=0,m=A,A-=1):A===y-1&&r.push({start:m,end:y,steps:v,arrayPositionLength:c,arrayIndexLength:h,arrayNormalLength:d,arrayUVLength:u,arrayUV2Length:p}),g=null):A===y-1&&r.push({start:m,end:y,steps:v,arrayPositionLength:c,arrayIndexLength:h,arrayNormalLength:d,arrayUVLength:u,arrayUV2Length:p})}s-=o}for(var I=0,x=r.length;x>I;I+=1){for(var w=r[I],M=new Ni,E={},B=new Float32Array(w.arrayPositionLength),S=new Uint32Array(w.arrayIndexLength),b=new Float32Array(w.arrayNormalLength),k=new Float32Array(w.arrayUVLength),D=new Float32Array(w.arrayUV2Length),T=0,R=0,U=0,F=0,Q=0,L=[],O=w.start,N=w.end;N>O;O+=1){var P=n[w.steps+O];if(g=this._getNodeBufferBy(P.nodeId)){L.push(P.nodeId);var G=g.index,K=g.position,V=g.normal,Y=g.uv,H=g.uv2;B.set(K,T);for(var j=new Uint32Array(G),W=0,J=j.length;J>W;W+=1)j[W]+=T/3;S.set(j,R),void 0===E[P.userId]&&(E[P.userId]=[]),E[P.userId].push({userId:P.userId,nodeId:P.nodeId,positionStart:T,positionCount:K.length,indexStart:R,indexCount:G.length,lightmapIdx:P.lightmapIdx,boundingBox:P.boundingBox}),R+=G.length,T+=K.length,V&&(b.set(V,U),U+=V.length),f&&(Y?(k.set(Y,F),F+=Y.length):(k.set(new Float32Array(K.length/3*2),F),F+=Y.length)),H&&(D.set(H,Q),Q+=H.length),G=null,K=null,V=null,Y=null,H=null,g=null}}this.clearNodeBufferByNodeIds(L),M._visible=!0,M.setIndex(new Ai(S,1)),M.setAttribute("position",new Ai(B,3)),U>0&&M.setAttribute("normal",new Ai(b,3)),F>0&&M.setAttribute("uv",new Ai(k,2)),Q>0&&M.setAttribute("uv2",new Ai(D,2)),i[e].push({geometry:M,indices:E})}},Dv.prototype.clearAllNodeBuffer=function(){this.cachedNodeBuffer&&(this.cachedNodeBuffer={})},Dv.prototype.clearNodeBufferByNodeIds=function(e){if(this.cachedNodeBuffer)for(var t=0,i=e.length;i>t;t+=1)this.cachedNodeBuffer[e[t]]=null},Dv.prototype._getNodeBufferByNodeInfo=function(e,t){return this.cachedNodeBuffer||this._createNodeBuffer(e,t),this.cachedNodeBuffer[t.nodeId]},Dv.prototype._getNodeBufferBy=function(e){return this.cachedNodeBuffer?this.cachedNodeBuffer[e]:null},Dv.prototype._createNodeBufferForMergedBuffer=function(e,t,i){this.cachedNodeBuffer||(this.cachedNodeBuffer={}),this.cachedNodeBuffer[t.nodeId]||(this.cachedNodeBuffer[t.nodeId]=this.createBufferByBufferDataWithUV2(e,t,i))},Dv.prototype._createNodeBuffer=function(e,t){this._createNodeBufferForMergedBuffer(e,t,{buffer:e.getModelDescriptor().getReferencedMeshBufferById(t.geometryId),isDataView:!0})},Dv.prototype._createGeometries=function(e,t){var i=this,n=e.getModelDescriptor().getNodeInfosOnGeometryId(),r=e.getModelDescriptor().getReferencedMeshBufferData(),o=this._getClassifiedMeshes(n,r);this._dealDataMergedMeshs(e,o,r,n,(function(){i._dealDataMergeableMeshs(e,o,r,n,t)}))},Dv.prototype._getClassifiedMeshes=function(e,t){var i=[],n=[];for(var r in t){var o=t[r].IndexInfos,a=void 0;if(o){if(1>o.length)continue;for(var s=0,l=o.length;l>s;s+=1){if((c=e[o[s].meshId])&&c.length){a=o[s].meshId;break}}}else{var c;(c=e[r])&&c.length&&(a=r)}if(void 0!==a)(c=e[a])&&c.length&&(c[0].type===zy.EnumNodeItemType.LINE||!c[0].instanceOrNot&&c[0].shared?i.push(r):n.push(r))}if(!xd.Instance)for(var r in e)n[r]||i[r]||i.push(r);return{mergeableIdxs:i,mergedIdxs:n}},Dv.prototype._collectMergeableMeshesByIdxId=function(e,t,i,n,r){i[t]&&i[t].IndexInfos?this._collectSharedMeshesByIdxId(e,t,i,n,r):this._collectLineOrIntanceMeshesByIdxId(e,t,i,n,r)},Dv.prototype._collectLineOrIntanceMeshesByIdxId=function(e,t,i,n,r){for(var o=n[t],a={buffer:e.getModelDescriptor().getReferencedMeshBufferById(t)},s=0,l=o.length;l>s;s+=1){var c=o[s];this._createNodeBufferByGeoBufferData(e,c,a);var h=this._getMaterialKeyByNodeInfo(c);r[h]||(r[h]=[]),r[h].push(c)}},Dv.prototype._collectSharedMeshesByIdxId=function(e,t,i,n,r){for(var o=i[t].IndexInfos,a=0,s=o.length;s>a;a+=1){var l=n[o[a].meshId];if(l)for(var c={buffer:e.getModelDescriptor().getReferencedMeshBufferById(t),indexInfo:o[a]},h=0,d=l.length;d>h;h+=1){var u=l[h];this._createNodeBufferByGeoBufferData(e,u,c);var p=this._getMaterialKeyByNodeInfo(u);r[p]||(r[p]=[]),r[p].push(u)}}},Dv.prototype._mergeMergeableMeshes=function(e,t,i,n){var r=Object.keys(t);if(0!==r.length){var o=this,a=e.getLoader().maxLoadTaskCount,s=r.length,l=e.progressPercentage.load,c=e.progressPercentage.collect,h=e.progressPercentage.merge,d=Math.ceil(s/e.progressFrequency);requestAnimationFrame(function u(p){var g=p;return function(){var p=null,f=null;for(f=g+d>s?s:g+d,p=g;f>p;p+=1)o._collectMergedGeometriesById(r[p],t,i),p===f-1&&(f!==s?(e.dispatchEvent({type:Fd.ON_LOAD_PROGRESS,progress:{total:a,loaded:(p/s*h+l+c)*a,modelKey:e.modelKey}}),requestAnimationFrame(u(p+1))):o._makeMeshNodes(e,n))}}(0))}else this._makeMeshNodes(e,n)},Dv.prototype._dealDataMergeableMeshs=function(e,t,i,n,r){if(0!==t.mergeableIdxs.length){var o=this,a=this.mapMaterialIdToMergedNode,s={},l=t.mergedIdxs.length,c=t.mergeableIdxs.length,h=l+c,d=t.mergeableIdxs,u=e.getLoader().maxLoadTaskCount,p=e.progressPercentage.load,g=e.progressPercentage.collect,f=Math.ceil(c/e.progressFrequency);requestAnimationFrame(function t(m){var A=m;return function(){var m=null,y=null;for(y=A+f>c?c:A+f,m=A;y>m;m+=1)o._collectMergeableMeshesByIdxId(e,d[m],i,n,s),m===y-1&&(y!==c?(e.dispatchEvent({type:Fd.ON_LOAD_PROGRESS,progress:{total:u,loaded:((m+l)/h*g+p)*u,modelKey:e.modelKey}}),requestAnimationFrame(t(m+1))):(e.dispatchEvent({type:Fd.ON_LOAD_PROGRESS,progress:{total:u,loaded:(g+p)*u,modelKey:e.modelKey}}),o._mergeMergeableMeshes(e,s,a,r)))}}(0))}else this._makeMeshNodes(e,r)},Dv.prototype._collectDataMergedMeshesByIdxId=function(e,t,i,n,r){var o=t[e],a=o.IndexInfos;if(a&&0!==a.length){var s=!1;o.UV&&(o.UV.byteLength||o.UV.length)&&(s=!0),r.lightmap&&(o=this.getAttributeForLightmapWithDataMerged(o,r,e));for(var l=void 0,c=0,h=a.length;h>c;c+=1){var d=i[a[c].meshId];if(d&&0!==d.length){r.lightmap&&(a[c].lightmapIdx=o.lightmapIdx,a[c].positionStart=3*a[c].indexStart,a[c].positionCount=3*a[c].indexCount),l=a[c].meshId;for(var u=0,p=d.length;p>u;u+=1)d[u].uv=s}}if(void 0!==l){var g=i[l][0],f={},m=this._getMaterialKeyByNodeInfo(g);void 0===n[m]&&(n[m]=[]);for(var A=0,y=a.length;y>A;A+=1)i[a[A].meshId]&&(void 0===f[(g=i[a[A].meshId][0]).userId]&&(f[g.userId]=[]),a[A].userId=g.userId,a[A].nodeId=g.nodeId,a[A].boundingBox=g.boundingBox,f[g.name].push(a[A]));var v=new Ni;v._visible=!0,v.setIndex(new Ai(new Uint32Array(o.I),1)),v.setAttribute("position",new Ai(new Float32Array(o.P),3)),o.N&&(o.N.byteLength||o.N.length)&&v.setAttribute("normal",new Ai(new Float32Array(o.N),3)),s&&v.setAttribute("uv",new Ai(new Float32Array(o.UV),2)),o.UV2&&(v.setAttribute("uv2",new Ai(new Float32Array(o.UV2),2)),v.lightmapIdx=o.lightmapIdx),n[m].push({geometry:v,indices:f})}}},Dv.prototype.getAttributeForLightmapWithDataMerged=function(e,t,i){var n=[],r=new Uint32Array(e.I),o=t.getLoader().getUV2ById("bmpk_"+i,r.length);if(o){var a=o.lightmapIdx;n=o.uv2}for(var s=new Float32Array(e.P),l=new Float32Array(e.N),c=new Float32Array(e.UV),h=[],d=[],u=[],p=0;r.length>p;p+=1){var g=r[p];h.push(s[3*g]),h.push(s[3*g+1]),h.push(s[3*g+2]),l.length>0&&(d.push(l[3*g]),d.push(l[3*g+1]),d.push(l[3*g+2])),c.length>0&&(u.push(c[2*g]),u.push(c[2*g+1])),r[p]=p}return s=null,l=null,c=null,{I:r,UV2:n,P:h,N:d,UV:u,lightmapIdx:a}},Dv.prototype._dealDataMergedMeshs=function(e,t,i,n,r){if(0!==t.mergedIdxs.length){var o=this,a=this.mapMaterialIdToMergedNode,s=t.mergedIdxs,l=s.length,c=t.mergedIdxs.length+t.mergeableIdxs.length,h=e.getLoader().maxLoadTaskCount,d=e.progressPercentage.load,u=e.progressPercentage.collect,p=Math.ceil(l/e.progressFrequency);requestAnimationFrame(function t(g){var f=g;return function(){var g=null,m=null;for(m=f+p>l?l:f+p,g=f;m>g;g+=1)o._collectDataMergedMeshesByIdxId(s[g],i,n,a),g===m-1&&(m!==l?(e.dispatchEvent({type:Fd.ON_LOAD_PROGRESS,progress:{total:h,loaded:(g/c*u+d)*h,modelKey:e.modelKey}}),requestAnimationFrame(t(g+1))):(e.dispatchEvent({type:Fd.ON_LOAD_PROGRESS,progress:{total:h,loaded:(g/c*u+d)*h,modelKey:e.modelKey}}),r&&r()))}}(0))}else r&&r()},Dv.prototype._dealUnsharedMeshs=function(e,t,i){for(var n=this.mapMaterialIdToMergedNode,r=0,o=e.length;o>r;r+=1){var a=i[e[r]],s=a.IndexInfos,l=t[s[0].meshId][0],c={},h=this._getMaterialKeyByNodeInfo(l);void 0===n[h]&&(n[h]=[]);for(var d=0,u=s.length;u>d;d+=1)void 0===c[(l=t[s[d].meshId][0]).userId]&&(c[l.userId]=[]),s[d].userId=l.userId,s[d].nodeId=l.nodeId,c[l.userId].push(s[d]);var p=new Ni;p._visible=!0,p.setIndex(new Ai(new Uint32Array(a.index),1)),p.setAttribute("position",new Ai(new Float32Array(a.position),3)),a.normal&&p.setAttribute("normal",new Ai(new Float32Array(a.normal),3)),a.uv&&p.setAttribute("uv",new Ai(new Float32Array(a.uv),2)),n[h].push({geometry:p,indices:c})}},Dv.prototype._makeMeshNodes=function(e,t){Bu.time("makeMesh");var i=e.manager,n=e.modelKey,r=e._encodedDatabagId,o=this._getNodeGroup(e),a=this.mapMaterialIdToMergedNode;for(var s in a)for(var l=this.getPropertyValueByMaterialKey(s),c=a[s],h=0,d=c.length;d>h;h+=1){var u=c[h].geometry,p=c[h].indices;if(!c[h].mesh){var g=null;if("lines"===l.type)(g=new ov(u)).modelKey=n;else{var f={modelKey:n};(g=new Bv(u)).spawn(f)}if(!wp.isEmptyObject(e.subModel)){var m=Object.keys(p)[0];if(m){var A=wp.getModelKeyFromComponentKey(m);e.subModel[A]&&g.matrix.copy(e.subModel[A])}}g._indicesGroup=p,o.add(g),c[h].mesh=g,i.addMeshToOctantMap(r,s,new Mm(s,g));var y=function(t){p.hasOwnProperty(t)&&p[t].forEach((function(i){e.addMeshToInfoMap(t,i.nodeId,g,i)}))};for(var v in p)y(v);p=null,g=null}}o.updateMatrixWorld(!0),e.dispatchEvent({type:Fd.ON_LOAD_PROGRESS,progress:{total:e.getLoader().maxLoadTaskCount,loaded:e.getLoader().maxLoadTaskCount,modelKey:e.modelKey}}),t&&t(),Bu.timeEnd("makeMesh")},Dv.prototype.createMeshNodes=function(e,t){e.getModelDescriptor().getStandardNodeInfos()?this._createGeometries(e,t):t&&t()},Dv.prototype.applySelection=function(e){},Dv.prototype.clearSelection=function(e){},Dv.prototype.applyHover=function(e){},Dv.prototype.clearHover=function(e){},Dv.prototype.getMeshNode=function(){return this.mapMaterialIdToMergedNode},Dv.prototype._disposeMergedGeometries=function(){for(var e in this.mapMaterialIdToMergedNode){for(var t=this.mapMaterialIdToMergedNode[e],i=0,n=t.length;n>i;i+=1){t[i].geometry.dispose(),delete t[i].geometry,delete t[i].indices,delete t[i].mesh}delete this.mapMaterialIdToMergedNode[e]}},Dv.prototype._getMaterialKeyByNodeInfo=function(e,t){if(t){var i=t.manager.getOverrideMaterialByNodeInfo(e);e.materialId=i?i.name:e.originMId}return wp.getCombinedKeyString([e.materialId,e.uv?"1":"0",e.type===zy.EnumNodeItemType.LINE?"lines":"meshes"])},Dv.prototype.getPropertyValueByMaterialKey=function(e){var t=wp.splitCombinedKeyString(e);return{materialId:t[0],uvProp:t[1],type:t[2]}},Dv.prototype.clearSelectedObjectIds=function(){this.selectedObjectIds.length=0},Dv.prototype.cacheSelectedObjectIds=function(e,t,i){this.selectedObjectIds.push({uid:e,mKey:t,idx:i})},Dv.prototype.adjustVisibility=function(e,t){var i=this._getNodeGroup(e),n=i.visible;t&&!i.bVisible||(i.visible=t),i.bVisible=n},Dv.prototype.changeVisibilityOfSelectedObjects=function(e,t){if(t)for(var i=0,n=this.selectedMeshes.length;n>i;i+=1){var r=this.selectedMeshes[i].object,o=this.selectedMeshes[i].indices;if(r)for(var a=0,s=o.length;s>a;a+=1){var l=r.geometry.groups[o[a].idx];l.start=o[a].start,l.count=o[a].count}}else{this.selectedMeshes.length=0;for(var c={},h=0,d=this.selectedObjectIds.length;d>h;h+=1){var u=this.selectedObjectIds[h].mKey,p=this.selectedObjectIds[h].idx,g=wp.getCombinedKeyString([u,p]);if(!c[g]){c[g]=!0;var f=this.mapMaterialIdToMergedNode[u][p],m=f.mesh;if(m){for(var A=[],y=f.geometry.groups,v=0,C=y.length;C>v;v+=1){var I=y[v];I.materialIndex===Zd.SELECTED&&(A.push({idx:v,start:I.start,count:I.count}),I.start=0,I.count=0)}A.length&&this.selectedMeshes.push({object:m,indices:A})}}}}},Dv.prototype.changeVisibilityOfNonSelectedObjects=function(e,t){if(t)for(var i=0,n=this.nonSelectedMeshes.length;n>i;i+=1){var r=this.nonSelectedMeshes[i].object,o=this.nonSelectedMeshes[i].indices;if(o)for(var a=0,s=o.length;s>a;a+=1){var l=r.geometry.groups[o[a].idx];l.start=o[a].start,l.count=o[a].count}else r.visible=this.nonSelectedMeshes[i].visibility}else{this.nonSelectedMeshes.length=0;for(var c={},h=0,d=this.selectedObjectIds.length;d>h;h+=1){var u=this.selectedObjectIds[h];c[u.mKey]||(c[u.mKey]={}),c[u.mKey][u.idx]=!0}for(var p in this.mapMaterialIdToMergedNode){var g=this.mapMaterialIdToMergedNode[p];if(c[p])for(var f=0,m=g.length;m>f;f+=1){var A=g[f].mesh;if(A){if(!c[p][f]){this.nonSelectedMeshes.push({object:A,indices:null,visibility:A.visible}),A.visible=!1;continue}for(var y=[],v=A.geometry.groups,C=0,I=v.length;I>C;C+=1){var x=v[C];x.materialIndex!==Zd.SELECTED&&(y.push({idx:C,start:x.start,count:x.count}),x.start=0,x.count=0)}y.length>0&&this.nonSelectedMeshes.push({object:A,indices:y})}}else for(var w=0,M=g.length;M>w;w+=1){var E=g[w].mesh;E&&(this.nonSelectedMeshes.push({object:E,indices:null,visibility:E.visible}),E.visible=!1)}}}},Dv.prototype.restoreVisibilityOfObjects=function(){this.selectedMeshes.length=0,this.nonSelectedMeshes.length=0},Dv.prototype.getBlinkMaterials=function(){return this.blinkMaterials},Dv.prototype.disposeBufferAfterVbo=function(){if(!this.bufferDestroyed){var e=0;for(var t in this.mapMaterialIdToMergedNode){for(var i=this.mapMaterialIdToMergedNode[t],n=0,r=i.length;r>n;n+=1){var o=i[n],a=o.geometry;if(null!==a){e+=1;var s=t+"-"+n;this.mapDestroyedBufferKey[s]||o.mesh.visible&&(this.mapDestroyedBufferKey[s]=!0,by.disposeBufferFromGeometry(a,["normal","uv","uv2"]))}}Object.keys(this.mapDestroyedBufferKey).length===e&&(this.mapDestroyedBufferKey={},this.bufferDestroyed=!0)}}},Dv.prototype._traverseMeshNodeMap=function(e){for(var t in this.mapMaterialIdToMergedNode)for(var i=this.mapMaterialIdToMergedNode[t],n=0,r=i.length;r>n;n+=1)e&&e(t,i[n])},Dv.prototype.getGeometryBuffersByUserId=function(e,t){var i=[],n=e.getDatabagId();return this._traverseMeshNodeMap((function(e,r){var o=r.indices[t];if(o)for(var a=r.geometry,s=a.getIndex().array,l=a.getAttribute("position").array,c=0,h=o.length;h>c;c+=1){var d=o[c],u=d.indexStart,p=d.indexStart+d.indexCount,g=s.slice(u,p),f=l.slice(u=d.positionStart,p=d.positionStart+d.positionCount);u/=3,g.forEach((function(e,t,i){i[t]-=u})),i.push({modelKey:n,nodeId:d.nodeId,position:f,index:g})}})),i},Dv.prototype.getPickingNodeGenerator=function(){return this.pickingNodeGenerator||(this.pickingNodeGenerator=new ev(this)),this.pickingNodeGenerator};var Rv=function(e){$y.call(this,e),this.nodeGroupName="PickingBatchedWireFrameGroup"};Object.assign(Rv.prototype,$y.prototype),SA(Rv,[{key:"disposePickingNodeById",value:function(e){for(var t=this.pickingNodeMap[e],i=0,n=t.length;n>i;i+=1)t[i]._indicesGroup=null,t[i].material=null,t[i].geometry.dispose(),t[i]=null}},{key:"generatePickingMeshes",value:function(){var e=this.manager.getWireFrameLineSegments();1>e.length&&(this.manager.generateWireframe(),e=this.manager.getWireFrameLineSegments());for(var t=0,i=e.length;i>t;t+=1){var n=e[t].geometry,r=new Ni;r.setAttribute("position",n.getAttribute("position")),r.setIndex(n.getIndex());var o=new La(r,cA.DefaultMaterial);(new yt).copy(e[t].matrix).multiply(this.manager.model.getModelMatrix()).decompose(o.position,o.quaternion,o.scale),o._indicesGroup=e[t]._indicesGroup,o.frustumCulled=!1,o.renderOrder=2,this.addToPickingNodeMap(t,[o])}}},{key:"_rebuildGeometryGroup",value:function(e,t,i){var n,r=this.manager.manager,o=0,a=0,s=0,l=e._indicesGroup,c=Object.keys(l),h=[],d={};t.length>c.length?(h=c,d=i):(h=t,d=l);var u=[];for(s=0,n=h.length;n>s;s+=1){var p=h[s];if(r.isPickableNode(p)&&d[p]){var g=l[p];if(g&&g.length>0)for(o=0,a=g.length;a>o;o+=1)u.push({indexStart:g[o].indexStart,indexCount:g[o].indexCount})}}e.visible=!0;var f=e.geometry;if(f.clearGroups(),0!==u.length)for(u.sort((function(e,t){return e.indexStart-t.indexStart})),o=0,a=u.length;a>o;o+=1){var m=u[o].indexStart,A=u[o].indexCount;if(0===o)f.addGroup(m,A,0);else m===u[o-1].indexStart+u[o-1].indexCount?f.groups[f.groups.length-1].count+=A:f.addGroup(m,A,0)}else e.visible=!1}},{key:"updatePickingMeshesState",value:function(e,t,i){for(var n=this.pickingNodeMap,r=Object.keys(n),o=0,a=r.length;a>o;o+=1)for(var s=n[r[o]],l=0,c=s.length;c>l;l+=1)s[l].material=[e],s[l].visible=!1,this._rebuildGeometryGroup(s[l],t,i)}}]);var Uv=function(e){this.manager=e,this.model=e.model,this.generated=!1,this.wireframeLineSegments=[],this.wireframeLineSegment=null,this.wireframeGeometryMap=null,this.wireframeDataMap=null,this.userIdMapForNoWireFrame={}};function Fv(e,t,i,n){for(var r=e.getAttribute("position").array,o=t;i>o;o+=1)r[3*o]+=n.x,r[3*o+1]+=n.y,r[3*o+2]+=n.z;e.getAttribute("position").needsUpdate=!0}Uv.prototype.destroy=function(){this.clearData(),this.manager=null,this.userIdMapForNoWireFrame=null,this.pickingNodeGenerator&&(this.pickingNodeGenerator.destroy(),this.pickingNodeGenerator=null)},Uv.prototype.clearData=function(){if(this.generated=!1,this.bufferDestroyed=!1,this.wireframeLineSegments){for(var e=0,t=this.wireframeLineSegments.length;t>e;e+=1)this.wireframeLineSegments[e]._indicesGroup=null,this.wireframeLineSegments[e].geometry.dispose(),this.wireframeLineSegments[e]=null;this.wireframeLineSegments=[]}this.pickingNodeGenerator&&this.pickingNodeGenerator.clearData(),this.wireframeGeometryMap=null,this.userIdMapForNoWireFrame={}},Uv.prototype._createWireframeGeometry=function(e,t){if(this.wireframeGeometryMap||(this.wireframeGeometryMap={}),this.wireframeDataMap||(this.wireframeDataMap={}),!this.wireframeGeometryMap[t.nodeId]){var i=this._getWireframeData(e,t),n=new Ni;n.setIndex(new Mi(i.index,1)),n.setAttribute("position",new Ai(i.buffer,3)),n._userId=t.userId,this.wireframeGeometryMap[t.nodeId]=n}},Uv.prototype._getWireframeData=function(e,t){this.wireframeDataMap||(this.wireframeDataMap={});var i={};if(!this.wireframeDataMap[t.nodeId]){for(var n=e.attributes.position.array.slice(t.positionStart,t.positionStart+t.positionCount),r=e.getIndex().array.slice(t.indexStart,t.indexStart+t.indexCount),o=0,a=r.length;a>o;o+=1)r[o]-=t.positionStart/3;var s=af(n,r);return i=by.reducedGeometry(n,s),this.wireframeDataMap[t.nodeId]=i,i}return this.wireframeDataMap[t.nodeId]},Uv.prototype._createWireframeGeometries=function(e){e||(e=this.model);var t=e.manager.filter,i=e.getModelDescriptor().getStandardNodeInfos();function n(e){var n=i[e];return!(n&&t._hasRenderWithBoardlineFilter()&&!t._isRenderWithBoardline(n[0]))}var r=this.manager.getMeshNode();for(var o in Bu.time("createWireframeGeometry"),r){if("meshes"===this.manager.getPropertyValueByMaterialKey(o).type)for(var a=r[o],s=0,l=a.length;l>s;s+=1){var c,h=a[s];if(h.RenderTypeChange){for(var d=(c=h.geometry.clone()).attributes.position.array,u=[],p=new Ke,g=h.mesh.matrixWorld,f=0,m=d.length;m>f;f+=3)p.set(d[f],d[f+1],d[f+2]).applyMatrix4(g),u.push(p.x,p.y,p.z);c.setAttribute("position",new Ai(new Float32Array(u),3))}else c=h.geometry;if(null!==c){var A=h.indices;for(var y in A){n(y)||(this.userIdMapForNoWireFrame[y]=!0);for(var v=A[y],C=0,I=v.length;I>C;C+=1)this._createWireframeGeometry(c,v[C])}}}}return Bu.timeEnd("createWireframeGeometry"),!0},Uv.prototype._makeWireframe=function(e){e||(e=this.model);var t={},i=e.getWireframeMaterial();for(var n in this.wireframeGeometryMap){var r=this.wireframeGeometryMap[n],o=r._userId,a=new La(r,i);a.userId=o,a.nodeId=n,t[o]||(t[o]=[]),t[o].push(a),a=null}var s={};for(var o in t)if(wp.isEmptyObject(e.subModel)){s[e.modelKey]||(s[e.modelKey]=[]);var l=t[o];for(d=0,u=l.length;u>d;d+=1)s[e.modelKey].push(l[d])}else{var c=wp.getModelKeyFromComponentKey(o);s[c]||(s[c]=[]);for(var h=t[o],d=0,u=h.length;u>d;d+=1)s[c].push(h[d])}if(!wp.isEmptyObject(s))for(var p in s)if(s.hasOwnProperty(p)){var g=s[p];if(g.length>0){var f={},m=by.mergeBufferGeometriesFromMeshs(g,f);if(m){var A=new La(m,e.getWireframeMaterial());if(A.matrixAutoUpdate=!1,A._indicesGroup=f,!wp.isEmptyObject(e.subModel)){var y=Object.keys(f)[0];if(y){var v=wp.getModelKeyFromComponentKey(y);e.subModel[v]&&A.matrix.copy(e.subModel[v])}}this.wireframeLineSegments.push(A)}}}for(var o in t)delete t[o];t=null,this.wireframeGeometryMap=null},Uv.prototype.generateWireframe=function(e,t){e||(e=this.model),this.generated||(this._createWireframeGeometries(e),this._makeWireframe(e),this.generated=!0,t&&t())},Uv.prototype.update=function(e){if(this.manager.hasNodeInfo(e))if(e.isActivateWireframe()){if(this.generateWireframe(e),this.wireframeLineSegments){var t=this._getNodeGroup(e);t.clear();for(var i=0,n=this.wireframeLineSegments.length;n>i;i+=1)t.add(this.wireframeLineSegments[i]);t.updateMatrixWorld(!0)}}else e._hasNodeGroup(Vp.WIREFRAME)&&e._removeNodeGroup(Vp.WIREFRAME)},Uv.prototype.rebuildIndices=function(e){if(this.needDealWireframeLine(e))for(var t=0,i=this.wireframeLineSegments.length;i>t;t+=1){var n=this.wireframeLineSegments[t];n.visible=!0;var r=n._indicesGroup,o=n.geometry;o.clearGroups();var a=e.getWireframeMaterial();n.material=a;var s=this.manager.getFilteredUserIdsForWireFrame(),l=Boolean(s&&Object.keys(s).length);if(!this._existHiddenUserId()&&!l)return;var c=[],h=0,d=0,u=[];for(var p in r)if(!this._isHiddenUserId(p)){var g=r[p];if(g&&g.length>0){if(s[p]){var f=s[p],m=u.indexOf(f);for(-1===m&&(u.push(f),m=u.length-1),h=0,d=g.length;d>h;h+=1)c.push({indexStart:g[h].indexStart,indexCount:g[h].indexCount,state:1+m});continue}for(h=0,d=g.length;d>h;h+=1)c.push({indexStart:g[h].indexStart,indexCount:g[h].indexCount,state:0})}}if(0===c.length)return void(n.visible=!1);for(c.sort((function(e,t){return e.indexStart-t.indexStart})),h=0,d=c.length;d>h;h+=1){var A=c[h].indexStart,y=c[h].indexCount,v=c[h].state;if(0===h)o.addGroup(A,y,v);else v===c[h-1].state&&A===c[h-1].indexStart+c[h-1].indexCount?o.groups[o.groups.length-1].count+=y:o.addGroup(A,y,v)}var C=e.getFilter(),I=[a];for(h=0,d=u.length;d>h;h+=1){var x=C._getMaterialByName(u[h]);I.push(x)}n.material=I}},Uv.prototype.explode=function(e,t,i){},Uv.prototype.explosion=function(e,t){if(this.wireframeLineSegments)for(var i=0,n=this.wireframeLineSegments.length;n>i;i+=1){var r=Object.keys(this.wireframeLineSegments[i]._indicesGroup);t||(t={}),t.componentKey=r,this.componentsExplosion(e,t)}},Uv.prototype.closeExplosion=function(e){this.explosion(e)},Uv.prototype.componentsExplosion=function(e,t){if(this.wireframeLineSegments)for(var i=Array.isArray(t.componentKey)?t.componentKey:[t.componentKey],n=0,r=this.wireframeLineSegments.length;r>n;n+=1)for(var o=this.wireframeLineSegments[n]._indicesGroup,a=this.wireframeLineSegments[n].geometry,s=0,l=i.length;l>s;s+=1){var c=i[s];if(c){var h=e.getModelDescriptor().getStandardNodeInfosById(c);if(h){var d=o[c];if(d){var u=h[0];if(!u||!u.userData||!u.userData.changeOffset)continue;for(var p=0,g=d.length;g>p;p+=1){var f=d[p].positionStart;Fv(a,f,f+d[p].positionCount,u.userData.changeOffset)}u.userData.changeOffset=void 0}}}}},Uv.prototype.closeComponentsExplosion=function(e,t){this.componentsExplosion(e,{componentKey:t})},Uv.prototype._getNodeGroup=function(e){return e._getNodeGroup(Vp.WIREFRAME,{globalSpace:!0})},Uv.prototype.needDealWireframeLine=function(e){return!(!e.isActivateWireframe()||!this.wireframeLineSegments)},Uv.prototype.adjustVisibility=function(e,t){if(this.needDealWireframeLine(e)){var i=this._getNodeGroup(e),n=i.visible;t&&!i.bVisible||(i.visible=t),i.bVisible=n}},Uv.prototype.changeVisibilityOfSelectedObjects=function(e,t){},Uv.prototype.changeVisibilityOfNonSelectedObjects=function(e,t){this.adjustVisibility(e,t)},Uv.prototype.restoreVisibilityOfObjects=function(){},Uv.prototype.disposeBufferAfterVbo=function(){if(this.generated&&!this.bufferDestroyed&&this.wireframeLineSegments)for(var e=0,t=this.wireframeLineSegments.length;t>e;e+=1)this.wireframeLineSegments[e].visible&&(this.bufferDestroyed=!0,by.disposeBufferFromGeometry(this.wireframeLineSegments[e].geometry,["position","normal","uv","uv2"]))},Uv.prototype._existHiddenUserId=function(){var e=this.manager.getHiddenUserIds();return!!(this.userIdMapForNoWireFrame&&Object.keys(this.userIdMapForNoWireFrame).length||e&&Object.keys(e).length)},Uv.prototype._isHiddenUserId=function(e){if(this.userIdMapForNoWireFrame[e])return!0;var t=this.manager.getHiddenUserIds();return!(!t||!t[e])},Uv.prototype.getWireFrameLineSegments=function(){return this.wireframeLineSegments?this.wireframeLineSegments:null},Uv.prototype.getPickingNodeGenerator=function(){return this.pickingNodeGenerator||(this.pickingNodeGenerator=new Rv(this)),this.pickingNodeGenerator};var Qv=function(e,t){this.model=t,this.meshManager=new Dv(this),e||(this.wireframeManager=new Uv(this))};Qv.prototype.destroy=function(){this.meshManager.destroy(),this.meshManager=null,this.wireframeManager.destroy(),this.wireframeManager=null,this._clearFilteredState(),this._clearSelectedState(),this._clearHoveredState(),this._clearBlinkedState()},Qv.prototype.updateNodes=function(e){var t;t=this._collectModelFiltered(e),this.meshManager.update(e,t),this.wireframeManager.update(e)},Qv.prototype.generateWireframe=function(e,t){this.wireframeManager.generateWireframe(e,t)},Qv.prototype.asyncGenerateWireframe=function(e,t){this.wireframeManager.asyncGenerateWireframe(e,t)},Qv.prototype.rebuildIndices=function(e){this._rebuildIndices(e)},Qv.prototype.clearData=function(){this.meshManager.clearData(),this.wireframeManager.clearData(),this._clearFilteredState(),this._clearSelectedState(),this._clearHoveredState(),this._clearBlinkedState()},Qv.prototype.createMeshNodes=function(e,t){this.meshManager.createMeshNodes(e,t)},Qv.prototype.createBatchedMeshNodes=function(e,t){this.meshManager.createBatchedMeshNodes(e,t)},Qv.prototype.asyncCreateMeshNodes=function(e,t,i){this.meshManager.asyncCreateMeshNodes(e,t,i)},Qv.prototype.hasNodeInfo=function(e){return Boolean(e.getModelDescriptor().getStandardNodeInfos())},Qv.prototype.disposeGeometry=function(e){this.meshManager.disposeGeometry(e)},Qv.prototype.getMeshNode=function(){return this.meshManager.getMeshNode()},Qv.prototype.getPropertyValueByMaterialKey=function(e){return this.meshManager.getPropertyValueByMaterialKey(e)},Qv.prototype.getFilteredUserIds=function(){return this.mapMaterialIdToUserIdsForFilter},Qv.prototype.getSelectedUserIds=function(){return this.mapMaterialIdToUserIdsForSelection},Qv.prototype.getHoveredUserIds=function(){return this.mapMaterialIdToUserIdsForHover},Qv.prototype.getBlinkedUserIds=function(){return this.mapBlinkUserIds},Qv.prototype.getHiddenUserIds=function(){return this.hiddenUserIdSetObject},Qv.prototype.getTransparentUserIds=function(){return this.transparentUserIdSetObject},Qv.prototype.applyFilter=function(e,t){if(this.hasNodeInfo(e)){var i=null;i=t||e.getModelDescriptor().getStandardUserIds();var n=e.getModelDescriptor().getStandardNodeInfos();this._collectFilteredUserIds(e,i,n),this._collectFilteredUserIdsForWireFrame(e,i,n),this._collectSelectedUserIds(e.manager.sceneState.selectionSet,n),this._collectHoveredUserIds(e.manager.sceneState.hoverId,n),this._rebuildIndices(e),this.updateNodes(e)}},Qv.prototype.applySelection=function(e){if(this.hasNodeInfo(e)){var t=e.getModelDescriptor().getStandardNodeInfos();this._clearSelectedState(e),this._clearHoveredState(e),this._collectSelectedUserIds(e.manager.sceneState.selectionSet,t),this._collectHoveredUserIds(e.manager.sceneState.hoverId,t),this._rebuildIndices(e),this.updateNodes(e)}},Qv.prototype.clearSelection=function(e){this._clearSelectedState(e),this.applyHover(e)},Qv.prototype.applyHover=function(e){if(this.hasNodeInfo(e)){var t=e.getModelDescriptor().getStandardNodeInfos();this._clearHoveredState(e),this._collectHoveredUserIds(e.manager.sceneState.hoverId,t),this._rebuildIndices(e),this.updateNodes(e)}},Qv.prototype.clearHover=function(e){this._clearHoveredState(e),this._rebuildIndices(e),this.updateNodes(e)},Qv.prototype.applyBlink=function(e){if(this.hasNodeInfo(e)){var t=e.getModelDescriptor().getStandardNodeInfos();this._clearBlinkedState(e),this._clearHoveredState(e),this._collectBlinkedUserIds(e.manager.sceneState.getBlinkComponentsIdMap(),t),this._collectHoveredUserIds(e.manager.sceneState.hoverId,t),this._rebuildIndices(e),this.updateNodes(e)}},Qv.prototype.clearBlink=function(e){this._clearBlinkedState(e),this.applyHover(e)},Qv.prototype.applyReplacement=function(e){this._rebuildIndices(e),this.updateNodes(e)},Qv.prototype._collectFilteredUserIds=function(e,t,i){var n=e.manager.filter,r=n._hasHiddenFileIdFilter(),o=n._hasVisibleFilter(),a=n._hasOverrideMaterialFilter(),s=n._hasTransparentFilter(),l=e.hasReplacedUserId(),c=e.hasHiddenSourceObjectUserId(),h=this.mapMaterialIdToUserIdsForFilter={};if(this.hiddenUserIdSetObject={},this.overrideUserIdSetObject={},this.transparentUserIdSetObject={},r||o||a||s||l||c)for(var d=0;t.length>d;d+=1){var u=t[d],p=i[u];if(p&&p.length)for(var g=0,f=p.length;f>g;g+=1){var m=p[g];if(r&&n._isHiddenFileId(m)||o&&!1===n._isVisible(m)||e.isReplacedUserId(u)||e.isHiddenSourceObjectUserId(u))void 0===h[m.materialId]&&(h[m.materialId]={}),void 0===h[m.materialId][Zd.HIDDEN]&&(h[m.materialId][Zd.HIDDEN]={}),h[m.materialId][Zd.HIDDEN][u]=!0,this.hiddenUserIdSetObject[u]=!0;else if(s&&n._isTransparent(m))void 0===h[m.materialId]&&(h[m.materialId]={}),void 0===h[m.materialId][Zd.TRANSPARENT]&&(h[m.materialId][Zd.TRANSPARENT]={}),h[m.materialId][Zd.TRANSPARENT][u]=!0,this.transparentUserIdSetObject[u]=!0;else if(a&&n._hasOverrideMaterial(m)){var A=n._getOverrideMaterial(m);if(Array.isArray(A)){var y=g,v=A.find((function(e){return!!e.mapNodeIdToOrigMatId&&Object.keys(e.mapNodeIdToOrigMatId).includes(m.nodeId)})),C=v?v.mapNodeIdToOrigMatId[m.nodeId]:A[y].materialId,I=v?v.materialId:"";""!==I&&(void 0===h[C]&&(h[C]={}),void 0===h[C][Zd.OVERRIDED]&&(h[C][Zd.OVERRIDED]={})),h[C]||(h[C]={},h[C][Zd.OVERRIDED]={}),h[C][Zd.OVERRIDED][u]=I,this.overrideUserIdSetObject[u]||(this.overrideUserIdSetObject[u]=[]),this.overrideUserIdSetObject[u][y]=I}else{var x=null!==A?A.name:"";""!==x&&(void 0===h[m.materialId]&&(h[m.materialId]={}),void 0===h[m.materialId][Zd.OVERRIDED]&&(h[m.materialId][Zd.OVERRIDED]={}),h[m.materialId][Zd.OVERRIDED][u]=x,this.overrideUserIdSetObject[u]=x)}}}}},Qv.prototype._collectFilteredUserIdsForWireFrame=function(e,t,i){var n=e.getFilter(),r=n._hasOverrideMaterialFilterForWireFrame();if(this.mapFilteredUserIdsForWireFrame={},r)for(var o=0;t.length>o;o+=1){var a=t[o];if(!this.hiddenUserIdSetObject[a]){var s=i[a];if(s&&s.length)for(var l=0,c=s.length;c>l;l+=1){var h=s[l];if(n._hasOverrideMaterialForWireFrame(h)){var d=n._getOverrideMaterialForWireFrame(h),u=null!==d?d.name:"";""!==u&&(this.mapFilteredUserIdsForWireFrame[a]=u)}}}}},Qv.prototype._collectModelFiltered=function(e){var t=e.manager.filter,i=e.modelKey,n=t._hasModelOverrideMaterialFilter(),r=t._hasModelTransparentFilter(),o=e.manager.modelState.modelSelectionSet;return e.manager.modelState.hoverId===i?e.manager.modelState.getHoverMaterial():o.hasOwnProperty(e.modelKey)?e.manager.modelState.selectionMaterial:r&&t._isModelTransparent(i)?t._getMaterialByName("scene"):n&&t._hasModelOverrideMaterial(i)?t._getModelOverrideMaterial(i):null},Qv.prototype._clearFilteredState=function(){this.mapMaterialIdToUserIdsForFilter=null},Qv.prototype._collectSelectedUserIds=function(e,t){var i=this.mapMaterialIdToUserIdsForSelection={};for(var n in e)if(this.model.modelKey===n)for(var r in e[n]){var o=t[r];if(o&&o.length)for(var a=0,s=o.length;s>a;a+=1)void 0===i[o[a].materialId]&&(i[o[a].materialId]={}),void 0===i[o[a].materialId][r]&&(i[o[a].materialId][r]=!0)}},Qv.prototype._clearSelectedState=function(){this.mapMaterialIdToUserIdsForSelection&&(this.mapMaterialIdToUserIdsForSelection=null)},Qv.prototype._collectHoveredUserIds=function(e,t){var i=this.mapMaterialIdToUserIdsForHover={};if(e&&t[e])for(var n=t[e],r=0,o=n.length;o>r;r+=1)void 0===i[n[r].materialId]&&(i[n[r].materialId]={}),void 0===i[n[r].materialId][e]&&(i[n[r].materialId][e]=!0)},Qv.prototype._clearHoveredState=function(){this.mapMaterialIdToUserIdsForHover&&(this.mapMaterialIdToUserIdsForHover=null)},Qv.prototype._collectBlinkedUserIds=function(e,t){var i=this.mapBlinkUserIds={};for(var n in e){var r=t[n];if(r&&r.length)for(var o=0,a=r.length;a>o;o+=1)void 0===i[r[o].materialId]&&(i[r[o].materialId]={}),void 0===i[r[o].materialId][n]&&(i[r[o].materialId][n]=!0)}},Qv.prototype.calculateClippingIds=function(e,t){this.meshManager.calculateClippingIds(e,t)},Qv.prototype._clearBlinkedState=function(){this.mapBlinkUserIds&&(this.mapBlinkUserIds=null)},Qv.prototype._rebuildIndices=function(e){this.meshManager.rebuildIndices(e),this.wireframeManager.rebuildIndices(e)},Qv.prototype.clearCachedData=function(){this.meshManager.clearAllNodeBuffer()},Qv.prototype.getMeshesByUserIds=function(e,t){return this.meshManager.getMeshesByUserIds(e,t)},Qv.prototype.adjustVisibility=function(e,t){this.meshManager.adjustVisibility(e,t),this.wireframeManager.adjustVisibility(e,t)},Qv.prototype.changeVisibilityOfSelectedObjects=function(e,t){this.meshManager.changeVisibilityOfSelectedObjects(e,t),this.wireframeManager.changeVisibilityOfSelectedObjects(e,t)},Qv.prototype.changeVisibilityOfNonSelectedObjects=function(e,t){this.meshManager.changeVisibilityOfNonSelectedObjects(e,t),this.wireframeManager.changeVisibilityOfNonSelectedObjects(e,t)},Qv.prototype.restoreVisibilityOfObjects=function(){this.meshManager.restoreVisibilityOfObjects(),this.wireframeManager.restoreVisibilityOfObjects()},Qv.prototype.disposeBufferAfterVbo=function(){this.meshManager.disposeBufferAfterVbo(),this.wireframeManager.disposeBufferAfterVbo()},Qv.prototype.getGeometryBuffersByUserId=function(e,t){return this.meshManager.getGeometryBuffersByUserId(e,t)},Qv.prototype.explosion=function(e,t){this.meshManager.explosion(e,t),this.wireframeManager.explosion(e,t)},Qv.prototype.closeExplosion=function(e){this.meshManager.closeExplosion(e),this.wireframeManager.closeExplosion(e)},Qv.prototype.componentsExplosion=function(e,t){this.meshManager.componentsExplosion(e,t),this.wireframeManager.componentsExplosion(e,t)},Qv.prototype.closeComponentsExplosion=function(e,t){this.meshManager.closeComponentsExplosion(e,t),this.wireframeManager.closeComponentsExplosion(e,t)},Qv.prototype.isPickableNode=function(e){var t=this.getHiddenUserIds();if(t&&t[e])return!1;var i=this.getTransparentUserIds();return!(i&&i[e]&&!xd.EnableSelectionByTranslucent)},Qv.prototype.isHiddenNode=function(e){var t=this.getHiddenUserIds();return!(!t||!t[e])},Qv.prototype.getMeshManager=function(){return this.meshManager},Qv.prototype.getWireFrameManager=function(){return this.wireframeManager},Qv.prototype.getFilteredUserIdsForWireFrame=function(){return this.mapFilteredUserIdsForWireFrame};var Lv=function(e){$y.call(this,e),this.nodeGroupName="PickingInstancedMeshGroup"};function Ov(e,t,i){for(var n=e.getAttribute("mcol3").array,r=0;t.length>r;r+=1){var o=t[r];n[3*o]+=i.x,n[3*o+1]+=i.y,n[3*o+2]+=i.z}e.getAttribute("mcol3").needsUpdate=!0}Object.assign(Lv.prototype,$y.prototype),SA(Lv,[{key:"generatePickingMeshes",value:function(){var e=this,t=this.manager,i=t.cachedInstance;t.traverseInstanceNodeMap(null,(function(t,n){for(var r=[],o=0,a=n.length;a>o;o+=1){var s=n[o].geometry,l=n[o],c=new xc;c.setAttribute("position",s.getAttribute("position")),c.setAttribute("mcol0",s.getAttribute("mcol0")),c.setAttribute("mcol1",s.getAttribute("mcol1")),c.setAttribute("mcol2",s.getAttribute("mcol2")),c.setAttribute("mcol3",s.getAttribute("mcol3")),c.setAttribute("vState",new wc(new Float32Array(i.vState[t]),1,!1,1)),c.setIndex(s.getIndex());var h=new nn(c,cA.DefaultMaterial);l.matrixWorld.decompose(h.position,h.quaternion,h.scale),h.name=t,h.frustumCulled=!1,h.renderOrder=1,r.push(h)}e.addToPickingNodeMap(t,r)}))}},{key:"updatePickingMeshesState",value:function(e,t,i){if(this.pickingNodeMap)for(var n=this.manager.manager,r=this.pickingNodeMap,o=0,a=t.length;a>o;o+=1){var s=t[o];if(n.isPickableNode(s)){var l=n.getMeshManager().getNodeIdxMapByUserId(s);if(l)for(var c=Object.keys(l),h=0,d=c.length;d>h;h+=1){var u=c[h],p=r[u];if(p)for(var g=l[u],f=0,m=p.length;m>f;f+=1){var A=p[f];A.material=e,A.visible=!0;for(var y=A.geometry,v=y.getAttribute("vState").array,C=0,I=g.length;I>C;C+=1)v[g[C]]=Wd.NONE;y.getAttribute("vState").needsUpdate=!0}}}}}},{key:"resetPickingMeshesState",value:function(){if(this.pickingNodeMap)for(var e=this.pickingNodeMap,t=Object.keys(e),i=0,n=t.length;n>i;i+=1)for(var r=e[t[i]],o=0,a=r.length;a>o;o+=1)r[o].visible=!1,r[o].geometry.getAttribute("vState").array.fill(Wd.HIDDEN),r[o].geometry.getAttribute("vState").needsUpdate=!0}}]);var Nv=function(e){return kv.call(this),this.manager=e,this.instanceGeometryMap={},this.bufferAttributeMap={},this.instanceNodeMap={},this.nodeIdxMapFromUserId={},this.matrixInfoMapFromUserId={},this.cachedInstance={vState:{},vState2:{},vColor:{},vMirror:{},mcol0:{},mcol1:{},mcol2:{},mcol3:{},muvCol0:{},muvCol1:{},muvCol2:{},userId:{},nodeId:{}},this.selectedMeshes=[],this.nonSelectedMeshes=[],this.selectedObjectIds=[],this};(Nv.prototype=Object.create(kv.prototype)).destroy=function(){this.cachedInstance={},this.instanceNodeMap={},this.bufferAttributeMap={},this.nodeIdxMapFromUserId={},this.matrixInfoMapFromUserId={},this.disposeInstanceGeometries(),this.instanceGeometryMap={},this.manager=null,this.selectedMeshes=[],this.nonSelectedMeshes=[],this.selectedObjectIds=[]},Nv.prototype.clearData=function(){this.bufferDestroyed=!1,this.disposeGeometries(),this.disposeInstanceGeometries(),this.clearInstanceCache(),this.pickingNodeGenerator&&this.pickingNodeGenerator.clearData()},Nv.prototype.clearInstanceCache=function(){this.cachedInstance.vState={},this.cachedInstance.vState2={},this.cachedInstance.vColor={},this.cachedInstance.vMirror={},this.cachedInstance.mcol0={},this.cachedInstance.mcol1={},this.cachedInstance.mcol2={},this.cachedInstance.mcol3={},this.cachedInstance.muvCol0={},this.cachedInstance.muvCol1={},this.cachedInstance.muvCol2={},this.bufferAttributeMap={},this.nodeIdxMapFromUserId={},this.instanceNodeMap={},this.instanceGeometryMap={},this.matrixInfoMapFromUserId={},this.geometries={}},Nv.prototype.updateNodes=function(e){this._getNodeGroup(e).visible=!e.isOnlyWireframe()},Nv.prototype.createMeshNodes=function(e,t){this._createInstanceGeometries(e,t),this._makeInstanceNodes(e)},Nv.prototype.disposeInstanceGeometries=function(){this.traverseInstanceGeometryMap((function(e,t){for(var i=0,n=t.length;n>i;i+=1)t[i].dispose()}))},Nv.prototype._createInstanceGeometries=function(e,t){Bu.time("createInstanceGeometries");var i=this;e.getModelDescriptor().traverseInstancedNodeInfos(t,(function(t,n){for(var r=0,o=n.length;o>r;r+=1){var a=n[r],s=i.getGeometryByNodeInfo(e,a);if(s){var l=e.manager.getOverrideMaterialByNodeInfo(a);l&&(a.materialId=l.name);var c=i.getMeshIdByNodeInfo(a),h=i.cacheInstanceAttributeStateBy(e,c,s,a,l);i.cacheNodeIdxByUserId(a.userId,c,h),a.instanceGeometryIndex=h,i.cacheMatrixInfoByUserId(a.userId,c,{matrix:a.matrix,boundingBox:a.boundingBox}),i.cacheInstanceGeometries(c,s)}}})),Bu.timeEnd("createInstanceGeometries")},Nv.prototype._createBatchedInstanceGeometries=function(e,t){var i=this,n=e.materialManager.getMaterialById(t.materialKey),r=e.getModelDescriptor();if(!n){var o=r.getNodeInfosByNodeId(t.nodeIdInfo[0]);if(!o)return;t.materialKey=o.materialId,n=e.materialManager.getMaterialById(t.materialKey),t.color=[];for(var a=0,s=t.nodeIdInfo.length;s>a;a+=1)t.color.push(n.color.r,n.color.g,n.color.b,n.opacity)}var l=!1;n.aoMap&&(l=!0),t.hasUV2=l;var c=wp.getCombinedKeyString([t.materialKey,t.geoId]),h=this.cachedInstance;if(t.nodeIdInfo.length<1)Bu.error("node 数量为 0 ");else if(h.vState[c])Bu.warn("实例化几何已存在:",c);else{h.vState[c]=new Float32Array(t.nodeIdInfo.length),h.vColor[c]=t.color,h.vMirror[c]=new Float32Array(t.nodeIdInfo.length),h.mcol0[c]=t.mcol0,h.mcol1[c]=t.mcol1,h.mcol2[c]=t.mcol2,h.mcol3[c]=t.mcol3,h.muvCol0[c]=[],h.muvCol1[c]=[],h.muvCol2[c]=[],h.userId[c]=[],h.nodeId[c]=[];for(var d=new yt,u=[],p=0,g=t.nodeIdInfo.length;g>p;p+=1)u=[],h.userId[c].push(t.componentKeyInfo[p]),h.nodeId[c].push(t.nodeIdInfo[p]),u.push(t.mcol0[3*p]),u.push(t.mcol0[3*p+1]),u.push(t.mcol0[3*p+2]),u.push(0),u.push(t.mcol1[3*p]),u.push(t.mcol1[3*p+1]),u.push(t.mcol1[3*p+2]),u.push(0),u.push(t.mcol2[3*p]),u.push(t.mcol2[3*p+1]),u.push(t.mcol2[3*p+2]),u.push(0),u.push(t.mcol3[3*p]),u.push(t.mcol3[3*p+1]),u.push(t.mcol3[3*p+2]),u.push(1),d.fromArray(u),0>d.determinant()&&(h.vMirror[c][p]=-1);for(var f in i.getBufferAttributesBy(c),i.cacheBatchedInstanceGeometries(c,t),t.componentInfo)if(t.componentInfo.hasOwnProperty(f))for(var m=0,A=t.componentInfo[f].length;A>m;m+=1){var y=t.componentInfo[f][m];i.cacheNodeIdxByUserId(f,c,y);var v=r.getNodeInfosByNodeId(t.nodeIdInfo[y]);v&&(v.instanceGeometryIndex=y,i.cacheMatrixInfoByUserId(f,c,{matrix:v.matrix,boundingBox:v.boundingBox}))}i._makeInstanceNodeById(e,c,this.instanceGeometryMap[c])}},Nv.prototype.getBufferAttributesBy=function(e){if(this.bufferAttributeMap[e])return this.bufferAttributeMap[e];var t=this.cachedInstance,i=new wc(new Float32Array(t.mcol0[e]),3,!1,1),n=new wc(new Float32Array(t.mcol1[e]),3,!1,1),r=new wc(new Float32Array(t.mcol2[e]),3,!1,1),o=new wc(new Float32Array(t.mcol3[e]),3,!1,1),a=[],s=[],l=[];if(t.muvCol0[e])for(var c=0,h=t.muvCol0[e].length;h>c;c+=1)a.push(new wc(new Float32Array(t.muvCol0[e][c]),2,!1,1)),s.push(new wc(new Float32Array(t.muvCol1[e][c]),2,!1,1)),l.push(new wc(new Float32Array(t.muvCol2[e][c]),2,!1,1));return this.bufferAttributeMap[e]={attributeMcol0:i,attributeMcol1:n,attributeMcol2:r,attributeMcol3:o,attributeMuvCol0Array:a,attributeMuvCol1Array:s,attributeMuvCol2Array:l},this.bufferAttributeMap[e]},Nv.prototype._addInstanceNodeToScene=function(e,t,i){this._getNodeGroup(e).add(i),i.updateMatrixWorld(!0),e.manager.addMeshToOctantMap(e.modelKey,t,new Em(t,i))},Nv.prototype.addAllInstanceNodeToScene=function(e){this.traverseInstanceNodeMap(null,(function(t,i){for(var n=0,r=i.length;r>n;n+=1)e.manager.addMeshToOctantMap(e._encodedDatabagId,t,new Em(t,i[n]))}))},Nv.prototype._makeInstanceNodeById=function(e,t,i){var n=this.cachedInstance,r=e.materialManager,o=this.getMaterialIdByMeshId(t),a=this.getBufferAttributesBy(t),s=r.getInstanceMaterialById(o,e);this.instanceNodeMap[t]||(this.instanceNodeMap[t]=[]);for(var l=this.instanceNodeMap[t],c=0,h=i.length;h>c;c+=1){i[c].setAttribute("mcol0",a.attributeMcol0),i[c].setAttribute("mcol1",a.attributeMcol1),i[c].setAttribute("mcol2",a.attributeMcol2),i[c].setAttribute("mcol3",a.attributeMcol3),a.attributeMuvCol0Array.length>0&&(i[c].setAttribute("muvCol0",a.attributeMuvCol0Array[c]),i[c].setAttribute("muvCol1",a.attributeMuvCol1Array[c]),i[c].setAttribute("muvCol2",a.attributeMuvCol2Array[c])),i[c].setAttribute("aColor",new wc(new Float32Array(n.vColor[t]),4,!1,1)),i[c].setAttribute("vState",new wc(new Float32Array(n.vState[t]),1,!1,1)),i[c].setAttribute("vState2",new wc(new Float32Array(n.vState[t]),1,!1,1)),i[c].setAttribute("vMirror",new wc(new Float32Array(n.vMirror[t]),1,!1,1)),i[c].getAttribute("vState2").array.fill(Wd.HIDDEN);var d=i[c].index;i[c].addGroup(0,d.count,0),i[c].addGroup(0,d.count,1),s[1].visible=!1;var u=new Bv(i[c],s);if(u.visible=!0,u.modelKey=e.modelKey,u.frustumCulled=!1,l.push(u),!wp.isEmptyObject(e.subModel)){var p=n.userId[t][0];if(p){var g=wp.getModelKeyFromComponentKey(p);e.subModel[g]&&u.matrix.copy(e.subModel[g])}}this._addInstanceNodeToScene(e,t,u)}},Nv.prototype._makeInstanceNodes=function(e){Bu.time("makeInstanceNodes");var t=this;this.traverseInstanceGeometryMap((function(i,n){t._makeInstanceNodeById(e,i,n)})),Bu.timeEnd("makeInstanceNodes")},Nv.prototype.resetInstanceMaterial=function(e){var t=this,i=e.materialManager;this.traverseInstanceGeometryMap((function(n,r){var o=t.getMaterialIdByMeshId(n),a=i.getInstanceMaterialById(o,e);a[0].visible=!0,a[1].visible=!1,a.splice(2,1);for(var s=0,l=r.length;l>s;s+=1){if(r[s].getAttribute("vState").array.fill(Wd.NONE),r[0].removed)for(var c in r[0].removed)r[s].getAttribute("vState").array[c]=-1;r[s].getAttribute("vState").needsUpdate=!0,r[s].getAttribute("vState2").array.fill(Wd.HIDDEN),r[s].getAttribute("vState2").needsUpdate=!0,r[s].deleteAttribute("vState3"),r[s].groups.splice(2,1)}}))},Nv.prototype.clearInstanceStateByUserId=function(e){function t(e,t,i,n){for(var r=e.getAttribute("vState").array,o=e.getAttribute("vState2").array,a=0,s=t.length;s>a;a+=1){var l=t[a];r[l]=i,o[l]=n}e.getAttribute("vState").needsUpdate=!0,e.getAttribute("vState2").needsUpdate=!0}var i=this,n=Wd.NONE,r=Wd.HIDDEN;this.traverseNodeIdxMapByUserId(e,(function(e,o){var a=i.getInstanceGeometries(e);if(a)for(var s=0,l=a.length;l>s;s+=1)t(a[s],o,n,r)}))},Nv.prototype.updateInstanceStateByUserId=function(e,t,i,n){function r(e,t,i,n,r,o,a){var s=e.getAttribute("vState").array,l=e.getAttribute("vState2").array,c=e.getAttribute("aColor"),h=e.getAttribute("vState3"),d=null;null!==a&&(h?d=h.array:((d=(h=e.getAttribute("vState").clone()).array).fill(Wd.HIDDEN),e.setAttribute("vState3",h)));for(var u=c?c.array:null,p=0;t.length>p;p+=1){var g=t[p];s[g]=i,l[g]=n,d&&(d[g]=a),null!==u&&null!==r&&(u[4*g]=r[0],u[4*g+1]=r[1],u[4*g+2]=r[2],u[4*g+3]=r[3])}if(e.getAttribute("vState").needsUpdate=!0,e.getAttribute("vState2").needsUpdate=!0,h&&(h.needsUpdate=!0),c&&(c.needsUpdate=!0),o){var f=!1,m=!1;if(!o[0].visible)if(i!==Wd.HIDDEN)o[0].visible=!0;else{for(var A=0,y=s.length;y>A;A+=1)if(s[A]!==Wd.HIDDEN){f=!0;break}o[0].visible=f}if(!o[1].visible)if(n!==Wd.HIDDEN)o[1].visible=!0;else{for(var v=0,C=l.length;C>v;v+=1)if(l[v]!==Wd.HIDDEN){m=!0;break}o[1].visible=m}}}var o=e.materialManager,a=this;this.traverseNodeIdxMapByUserId(t,(function(s,l){var c=a.getInstanceGeometries(s);if(a.getInstanceNodesById(s),c){var h=null,d=null,u=null;if(i===Wd.HIDDEN){h=Wd.HIDDEN,d=Wd.HIDDEN;for(var p=0,g=c.length;g>p;p+=1)r(c[p],l,h,d,null,null)}else{var f=a.getMaterialIdByMeshId(s),m={};if("string"==typeof n&&"blink"===n.split("_")[0]){m.rgbaColor=[];var A=e.blinkMapMaterialNameToMaterial[n];m.rgbaColor.push(A.color.r,A.color.g,A.color.b,A.opacity),m.transparent=A.transparent,m.wireframe=!1}else m=a.getUsableMaterialColorParamsBy(e,f,i,n);var y=m.rgbaColor,v=i;i===Wd.TRANSPARENT&&(v=Wd.OVERRIDED),i===Wd.SELECTED&&a.cacheSelectedObjectIds(t,s);var C=o.getInstanceMaterialById(f,e),I=C[0];if(I.transparent===m.transparent?(h=v,d=Wd.HIDDEN):(h=Wd.HIDDEN,d=v),!0===m.wireframe){var x=C[2]||cA.createInstanceMaterial(cA.getMaterialParameters(I));x.wireframe=!0,x.defines.INSTANCE_STATE_TERTIARY="",3>C.length&&C.push(x),h=Wd.HIDDEN,d=Wd.HIDDEN,u=v}v===Wd.BLINK&&I.setBlinkColor(e.manager.getBlinkColor());for(p=0,g=c.length;g>p;p+=1){if(!0===m.wireframe){var w=c[p].groups[0];c[p].groups[2]={start:w.start,count:w.count,materialIndex:2}}r(c[p],l,h,d,y,C,u)}}}}))},Nv.prototype.getUsableMaterialColorParamsBy=function(e,t,i,n){var r=e.selectedMaterial,o=e.manager.filter._getMaterialByName("scene"),a=e.materialManager,s=e.manager.getOverrideMaterialByName(t)||a.getMaterialById(t),l=null,c=null;switch(i){case Wd.HOVER:n?(l=e.manager.filter._getMaterialByName(n),c=e.manager.sceneState.getHoverColorByMaterial(l)):c=e.manager.sceneState.getHoverColorByMaterial(s);break;case Wd.SELECTED:c=cA.getColorParamsByMaterial(r);break;case Wd.TRANSPARENT:c=cA.getColorParamsByMaterial(o);break;case Wd.OVERRIDED:case Wd.BLINK:n?(l=e.manager.filter._getMaterialByName(n),c=cA.getColorParamsByMaterial(l)):c=cA.getColorParamsByMaterial(s)}return c},Nv.prototype.getInstanceNodesById=function(e){return this.instanceNodeMap[e]},Nv.prototype.traverseInstanceNodeMap=function(e,t){for(var i=this.instanceNodeMap,n=0,r=(e=e||Object.keys(this.instanceNodeMap)).length;r>n;n+=1){var o=e[n];t(o,i[o])}},Nv.prototype.getInstanceGeometries=function(e){return this.instanceGeometryMap[e]},Nv.prototype.cacheInstanceGeometries=function(e,t){if(!this.instanceGeometryMap[e]){var i=this.instanceGeometryMap[e]=[];t instanceof Array||(t=[t]);for(var n=0,r=t.length;r>n;n+=1)i[n]=new xc,i[n].setIndex(t[n].index),t[n].attributes.position&&i[n].setAttribute("position",t[n].attributes.position),t[n].attributes.normal&&i[n].setAttribute("normal",t[n].attributes.normal),t[n].attributes.uv&&i[n].setAttribute("uv",t[n].attributes.uv),t[n].attributes.uv2&&i[n].setAttribute("uv2",t[n].attributes.uv2)}},Nv.prototype.cacheBatchedInstanceGeometries=function(e,t){if(this.instanceGeometryMap[e])return this.instanceGeometryMap[e][0];var i=this.instanceGeometryMap[e]=[],n=new xc;return i[0]=n,n.setIndex(new Ai(t.index,1)),t.position&&t.position.length>0&&n.setAttribute("position",new Ai(t.position,3)),t.normal&&t.normal.length===t.position.length&&n.setAttribute("normal",new Ai(t.normal,3)),t.uv&&t.uv.length>0&&n.setAttribute("uv",new Ai(t.uv,2)),t.hasUV2&&n.getAttribute("uv")&&n.setAttribute("uv2",n.getAttribute("uv")),n.getAttribute("normal")||n.computeVertexNormals(),n},Nv.prototype.traverseInstanceGeometryMap=function(e){var t=this.instanceGeometryMap;for(var i in t)e(i,t[i])},Nv.prototype.disposeInstanceGeometries=function(){this.traverseInstanceGeometryMap((function(e,t){for(var i=0,n=t.length;n>i;i+=1)t[i].dispose()}))},Nv.prototype.cacheInstanceAttributeStateBy=function(e,t,i,n,r){var o=n.materialId;i instanceof Array||(i=[i]);var a=i.length,s=this.cachedInstance;if(!s.vState[t]){s.vState[t]=[],s.vColor[t]=[],s.vMirror[t]=[],s.mcol0[t]=[],s.mcol1[t]=[],s.mcol2[t]=[],s.mcol3[t]=[],s.muvCol0[t]=[],s.muvCol1[t]=[],s.muvCol2[t]=[],s.userId[t]=[],s.nodeId[t]=[];for(var l=0;a>l;l+=1)s.muvCol0[t][l]=[],s.muvCol1[t][l]=[],s.muvCol2[t][l]=[]}var c=r||e.materialManager.getMaterialById(o);s.userId[t].push(n.userId),s.nodeId[t].push(n.nodeId),s.vColor[t].push(c.color.r,c.color.g,c.color.b,c.opacity),s.vState[t].push(0);var h=n.matrix.elements;return s.mcol0[t].push(h[0],h[1],h[2]),s.mcol1[t].push(h[4],h[5],h[6]),s.mcol2[t].push(h[8],h[9],h[10]),s.mcol3[t].push(h[12],h[13],h[14]),0>n.matrix.determinant()?s.vMirror[t].push(-1):s.vMirror[t].push(0),s.vState[t].length-1},Nv.prototype.cacheNodeIdxByUserId=function(e,t,i){var n=this.nodeIdxMapFromUserId;n[e]||(n[e]={}),n[e][t]||(n[e][t]=[]),n[e][t].push(i)},Nv.prototype.getNodeIdxMapByUserId=function(e){return this.nodeIdxMapFromUserId[e]},Nv.prototype.traverseNodeIdxMapByUserId=function(e,t){var i=this.nodeIdxMapFromUserId[e];for(var n in i)t(n,i[n])},Nv.prototype.traverseNodeIdxMap=function(e,t){for(var i=Object.keys(this.nodeIdxMapFromUserId),n=0,r=i.length;r>n;n+=1){var o=i[n],a=this.nodeIdxMapFromUserId[o];if(!t||!t(o))for(var s in a)e(s,a[s])}},Nv.prototype.cacheMatrixInfoByUserId=function(e,t,i){var n=this.matrixInfoMapFromUserId;n[e]||(n[e]={}),n[e][t]||(n[e][t]=[]),n[e][t].push(i)},Nv.prototype.traverseMatrixInfoMapByUserId=function(e,t){var i=this.matrixInfoMapFromUserId[e];for(var n in i)t(n,i[n])},Nv.prototype.getMeshesByUserId=function(e,t){var i=this,n=[];return this.traverseMatrixInfoMapByUserId(t,(function(t,r){for(var o=i.getInstanceNodesById(t),a=0,s=r.length;s>a;a+=1)for(var l=0,c=o.length;c>l;l+=1){var h={};if(h.matrix=e.getModelMatrix().clone().multiply(r[a].matrix),h.mesh=o[l],1===c)h.boundingBox=r[a].boundingBox;else{var d=h.mesh.geometry.boundingBox;d?d=d.clone():(h.mesh.geometry.computeBoundingBox(),d=h.mesh.geometry.boundingBox.clone()),d.applyMatrix4(h.matrix),h.boundingBox=d}n.push(h)}})),n},Nv.prototype._getNodeGroup=function(e){return e._getNodeGroup(Vp.INSTANCEGEOMETRY,{globalSpace:!0})},Nv.prototype._hasNodeGroup=function(e){return e._hasNodeGroup(Vp.INSTANCEGEOMETRY)},Nv.prototype.clearSelectedObjectIds=function(){this.selectedObjectIds.length=0},Nv.prototype.cacheSelectedObjectIds=function(e,t){this.selectedObjectIds.push({uid:e,mgId:t})},Nv.prototype.adjustVisibility=function(e,t){var i=this._getNodeGroup(e),n=i.visible;t&&!i.bVisible||(i.visible=t),i.bVisible=n},Nv.prototype.changeVisibilityOfSelectedObjects=function(e,t){var i=null;if(t)for(var n=0,r=(i=this.selectedMeshes).length;r>n;n+=1){var o=i[n].object,a=i[n].indices;if(a){if(a.length){for(var s=o.geometry.getAttribute("vState").array,l=o.geometry.getAttribute("vState2").array,c=0,h=a.length;h>c;c+=1)a[c].state?s[a[c].idx]=a[c].state:a[c].state2&&(l[a[c].idx]=a[c].state2);o.geometry.getAttribute("vState").needsUpdate=!0,o.geometry.getAttribute("vState2").needsUpdate=!0}}else o.visible=i[n].visibility}else{this.selectedMeshes.length=0,i=this.selectedMeshes;for(var d={},u=0,p=this.selectedObjectIds.length;p>u;u+=1)d[this.selectedObjectIds[u].mgId]=!0;var g=Object.keys(d);this.traverseInstanceNodeMap(g,(function(e,t){for(var n=0,r=t.length;r>n;n+=1){for(var o=t[n],a=[],s=o.geometry.getAttribute("vState").array,l=o.geometry.getAttribute("vState2").array,c=0,h=s.length;h>c;c+=1)s[c]===Wd.SELECTED?(a.push({idx:c,state:s[c]}),s[c]=Wd.HIDDEN):l[c]===Wd.SELECTED&&(a.push({idx:c,state2:l[c]}),l[c]=Wd.HIDDEN);a.length?(o.geometry.getAttribute("vState").needsUpdate=!0,o.geometry.getAttribute("vState2").needsUpdate=!0,i.push({object:o,indices:a})):(i.push({object:o,indices:null,visibility:o.visible}),o.visible=!1)}}))}},Nv.prototype.changeVisibilityOfNonSelectedObjects=function(e,t){var i=null;if(t)for(var n=0,r=(i=this.nonSelectedMeshes).length;r>n;n+=1){var o=i[n].object,a=i[n].indices;if(a){if(a.length){for(var s=o.geometry.getAttribute("vState").array,l=o.geometry.getAttribute("vState2").array,c=0,h=a.length;h>c;c+=1)void 0!==a[c].state?s[a[c].idx]=a[c].state:void 0!==a[c].state2&&(l[a[c].idx]=a[c].state2);o.geometry.getAttribute("vState").needsUpdate=!0}}else o.visible=i[n].visibility}else{this.nonSelectedMeshes.length=0,i=this.nonSelectedMeshes;for(var d={},u=0,p=this.selectedObjectIds.length;p>u;u+=1)d[this.selectedObjectIds[u].mgId]=!0;this.traverseInstanceNodeMap(null,(function(e,t){if(d[e])for(var n=0,r=t.length;r>n;n+=1){for(var o=[],a=(p=t[n]).geometry.getAttribute("vState").array,s=p.geometry.getAttribute("vState2").array,l=0,c=a.length;c>l;l+=1)a[l]!==Wd.SELECTED&&a[l]!==Wd.HIDDEN?(o.push({idx:l,state:a[l]}),a[l]=Wd.HIDDEN):s[l]!==Wd.SELECTED&&s[l]!==Wd.HIDDEN&&(o.push({idx:l,state2:s[l]}),s[l]=Wd.HIDDEN);o.length&&(p.geometry.getAttribute("vState").needsUpdate=!0,p.geometry.getAttribute("vState2").needsUpdate=!0,i.push({object:p,indices:o}))}else for(var h=0,u=t.length;u>h;h+=1){var p;i.push({object:p=t[h],indices:null,visibility:p.visible}),p.visible=!1}}))}},Nv.prototype.restoreVisibilityOfObjects=function(){this.selectedMeshes.length=0,this.nonSelectedMeshes.length=0},Nv.prototype.getMeshIdByNodeInfo=function(e){return wp.getCombinedKeyString([e.materialId,e.geometryId])},Nv.prototype.getMaterialIdByMeshId=function(e){return wp.splitCombinedKeyString(e)[0]},Nv.prototype.getOriginalMaterialIdByMeshId=function(e){var t=wp.splitCombinedKeyString(e);return wp.splitCombinedKeyString(t[0],"_")[0]},Nv.prototype.disposeBufferAfterVbo=function(){if(!this.bufferDestroyed){this.bufferDestroyed=!0;var e=["muvCol0","muvCol1","muvCol2","mcol0","mcol1","mcol2","mcol3"];xd.EnableExplosion&&e.pop(),this.traverseInstanceGeometryMap((function(t,i){for(var n=0,r=i.length;r>n;n+=1)by.disposeBufferFromGeometry(i[n],e)}))}},Nv.prototype.getGeometryBuffersByUserId=function(e,t){var i=e.getModelDescriptor().getInstancedNodeInfosById(t);if(!i)return[];for(var n=[],r=e.getDatabagId(),o=0,a=i.length;a>o;o+=1){var s=i[o],l=this.getGeometryByNodeInfo(e,s),c=this._isLines(s);if(l instanceof Array)for(var h=0,d=l.length;d>h;h+=1)n.push({isLines:c,modelKey:r,nodeId:s.nodeId,position:l[h].getAttribute("position").array,index:l[h].getIndex().array,matrix:s.matrix});else n.push({modelKey:r,nodeId:s.nodeId,position:l.getAttribute("position").array,index:l.getIndex().array,matrix:s.matrix})}return n},Nv.prototype.explode=function(e,t,i){var n=this;for(var r in n.nodeIdxMapFromUserId)n.traverseNodeIdxMapByUserId(r,(function(o,a){var s=e.manager.getComponentInfoByUserId(r).boundingBox,l=wp.computeExplodeTranslation(t,s,i),c=n.getInstanceGeometries(o);c&&Ov(c[0],a,l)}))},Nv.prototype.explosion=function(e,t){var i=Object.keys(this.nodeIdxMapFromUserId);t.componentKey=i,this.componentsExplosion(e,t)},Nv.prototype.closeExplosion=function(e){this.explosion(e,{})},Nv.prototype.componentsExplosion=function(e,t){var i=t.coefficientX||1,n=t.coefficientY||1,r=t.coefficientZ||1,o=t.offsetX||0,a=t.offsetY||0,s=t.offsetZ||0,l=null;if(t.center)l=(new Ke).fromArray(t.center);else if(1!==i||1!==n||1!==r||0!==o||0!==a||0!==s)return;var c=Array.isArray(t.componentKey)?t.componentKey:[t.componentKey],h=new Ke,d=new He,u=new Ke(0,0,0),p=new Ke(0,0,0),g=new Ke,f=new yt,m=e.getModelMatrix();m&&l&&(f.copy(m).invert(),l.applyMatrix4(f));var A=e.manager,y=!1,v=new Ke,C=new Ge,I=new Ke(1,1,1);wp.isEmptyObject(e.subModel)||(y=!0);for(var x=0,w=c.length;w>x;x+=1){var M=c[x];if(M){var E=e.getModelDescriptor().getInstancedNodeInfosById(M);if(E)for(var B=this.nodeIdxMapFromUserId[M],S=0,b=E.length;b>S;S+=1){var k=E[S];if(k){var D=k.materialId+"&"+k.geometryId,T=new Ke(1,1,1);if(y)this.getInstanceNodesById(D)[0].matrix.decompose(v,C,I),T.divide(I);if(d.copy(k.boundingBox),d.getCenter(h),k.userData||(k.userData={}),u.set(0,0,0),p.set(0,0,0),1!==i||1!==n||1!==r||k.userData.explosionFactor){k.userData.explosionFactor||(k.userData.explosionFactor=new Ke(1,1,1),k.userData.explosionBaseDifference=h.sub(l).clone().multiply(T));var R=k.userData.explosionFactor,U=k.userData.explosionBaseDifference;u.set((i-R.x)*U.x,(n-R.y)*U.y,(r-R.z)*U.z),1===i&&1===n&&1===r?(k.userData.explosionFactor=void 0,k.userData.explosionBaseDifference=void 0):R.set(i,n,r)}if(0!==o||0!==a||0!==s||k.userData.explosionOffset){k.userData.explosionOffset||(k.userData.explosionOffset=new Ke(0,0,0));var F=k.userData.explosionOffset;p.set(o*T.x-F.x,a*T.y-F.y,s*T.z-F.z),0===o&&0===a&&0===s?k.userData.explosionOffset=void 0:F.set(o*T.x,a*T.y,s*T.z)}if(g.set(u.x+p.x,u.y+p.y,u.z+p.z),0!==g.x||0!==g.y||0!==g.z){k.userData.explosionFactor||k.userData.explosionOffset?A.explosionList[M]||(A.explosionList[M]=!0):delete A.explosionList[M];var Q=g.clone().multiply(I),L=f;y&&(L=f.clone()).makeTranslation(g.x,g.y,g.z),f.makeTranslation(Q.x,Q.y,Q.z),k.transformation||(k.transformation=!0,k.transformationOriginalMatrix=k.matrix.clone(),k.applyMatrix=new yt,k.transformationOriginalBoundingBox=k.boundingBox.clone()),k.matrix.premultiply(L),k.applyMatrix.premultiply(f),k.boundingBox.copy(k.transformationOriginalBoundingBox).applyMatrix4(k.applyMatrix);var O=k.matrix,N=B[D];if(N)for(var P=0,G=N.length;G>P;P+=1){var K=N[P];if(k.instanceGeometryIndex===K){var V=this.getInstanceGeometries(D);if(!V)continue;var Y=V[0],H=Y.getAttribute("mcol0"),j=Y.getAttribute("mcol1"),W=Y.getAttribute("mcol2"),J=Y.getAttribute("mcol3");H.array[3*K]=O.elements[0],H.array[3*K+1]=O.elements[1],H.array[3*K+2]=O.elements[2],H.needsUpdate=!0,j.array[3*K]=O.elements[4],j.array[3*K+1]=O.elements[5],j.array[3*K+2]=O.elements[6],j.needsUpdate=!0,W.array[3*K]=O.elements[8],W.array[3*K+1]=O.elements[9],W.array[3*K+2]=O.elements[10],W.needsUpdate=!0,J.array[3*K]=O.elements[12],J.array[3*K+1]=O.elements[13],J.array[3*K+2]=O.elements[14],J.needsUpdate=!0}}}}}}}},Nv.prototype.closeComponentsExplosion=function(e,t){t=Array.isArray(t)?t:[t];this.componentsExplosion(e,{componentKey:t})},Nv.prototype._isLines=function(e){return e.type===zy.EnumNodeItemType.LINE},Nv.prototype.getPickingNodeGenerator=function(){return this.pickingNodeGenerator||(this.pickingNodeGenerator=new Lv(this)),this.pickingNodeGenerator},Nv.prototype.calculateClippingIds=function(e,t){var i=this;for(var n in i.nodeIdxMapFromUserId)this.traverseMatrixInfoMapByUserId(n,(function(n,r){for(var o=i.getInstanceNodesById(n),a=0,s=r.length;s>a;a+=1)for(var l=0,c=o.length;c>l;l+=1)o[l].intersectBoxWithClipPlane(e,r[a])&&o[l].getIntersectionPoints(e,r[a],t,!0)}))};var Pv=function(e){$y.call(this,e),this.nodeGroupName="PickingInstancedWireFrameGroup"};Object.assign(Pv.prototype,$y.prototype),SA(Pv,[{key:"generatePickingMeshes",value:function(){this.manager.generateWireframe(),this.manager.updateNodes();var e=this,t=this.manager,i=t.manager.getCachedInstanceData();t._traverseWireframeGeometryMap((function(n,r){for(var o=[],a=t._getWireframeMeshById(n),s=0,l=r.length;l>s;s+=1){var c=r[s],h=new xc,d=a[s];h.setAttribute("position",c.getAttribute("position")),h.setAttribute("mcol0",c.getAttribute("mcol0")),h.setAttribute("mcol1",c.getAttribute("mcol1")),h.setAttribute("mcol2",c.getAttribute("mcol2")),h.setAttribute("mcol3",c.getAttribute("mcol3")),h.setAttribute("vState",new wc(new Float32Array(i.vState[n]),1,!1,1)),h.setIndex(c.getIndex());var u=new La(h,cA.DefaultMaterial);d.matrixWorld.decompose(u.position,u.quaternion,u.scale),u.name=n,u.frustumCulled=!1,u.renderOrder=2,o.push(u)}e.addToPickingNodeMap(n,o)}))}},{key:"updatePickingMeshesState",value:function(e,t,i){if(this.pickingNodeMap)for(var n=this.manager.manager,r=this.pickingNodeMap,o=0,a=t.length;a>o;o+=1){var s=t[o];if(n.isPickableNode(s)){var l=n.getMeshManager().getNodeIdxMapByUserId(s);if(l)for(var c=Object.keys(l),h=0,d=c.length;d>h;h+=1){var u=c[h],p=r[u];if(p)for(var g=l[u],f=0,m=p.length;m>f;f+=1){var A=p[f];A.material=e,A.visible=!0;for(var y=A.geometry,v=y.getAttribute("vState").array,C=0,I=g.length;I>C;C+=1)v[g[C]]=Wd.NONE;y.getAttribute("vState").needsUpdate=!0}}}}}},{key:"resetPickingMeshesState",value:function(){if(this.pickingNodeMap)for(var e=this.pickingNodeMap,t=Object.keys(e),i=0,n=t.length;n>i;i+=1)for(var r=e[t[i]],o=0,a=r.length;a>o;o+=1)r[o].visible=!1,r[o].geometry.getAttribute("vState").array.fill(Wd.HIDDEN),r[o].geometry.getAttribute("vState").needsUpdate=!0}}]);var Gv=function(e){this.manager=e,this.model=e.model,this.wireframeGeometryMap={},this.wireframeMeshMap={},this.noNeedWireframingIdMap={},this.generated=!1};Gv.prototype.destroy=function(){this.disposeGeometries(),this.wireframeGeometryMap=null,this.noNeedWireframingIdMap=null,this.manager=null},Gv.prototype.clearData=function(){this.generated=!1,this.bufferDestroyed=!1,this.wireframeMesh={},this.disposeGeometries(),this.pickingNodeGenerator&&this.pickingNodeGenerator.clearData(),this.wireframeGeometryMap={},this.noNeedWireframingIdMap={}},Gv.prototype.disposeGeometries=function(){this._traverseWireframeGeometryMap((function(e,t){for(var i=0,n=t.length;n>i;i+=1)t[i].dispose()}))},Gv.prototype.updateNodes=function(e){e||(e=this.model);var t=null;e.isActivateWireframe()?(this.generateWireframe(e),(t=this._getNodeGroup(e)).updateMatrixWorld(!0),t.visible=!0):this._hasNodeGroup(e)&&((t=this._getNodeGroup(e)).visible=!1)},Gv.prototype.resetInstanceMaterial=function(){var e=Wd.NONE;this._traverseWireframeGeometryMap((function(t,i){for(var n=0,r=i.length;r>n;n+=1){for(var o=i[n].getAttribute("vState").array,a=0,s=o.length;s>a;a+=1)o[a]=e;i[n].getAttribute("vState").needsUpdate=!0}})),this._updateNoWireframingState()},Gv.prototype.updateInstanceWireframeByUserId=function(e,t,i,n){if(i===Wd.HIDDEN||i===Wd.NONE||i===Wd.OVERRIDED){var r=null;if(n){var o=e.getFilter()._getMaterialByName(n),a=cA.getColorParamsByMaterial(o);r=a.rgbaColor}var s=this;this.manager.traverseNodeIdxMapByUserId(t,(function(e,t){s._setInstanceWireframeState(e,t,i,r)}))}},Gv.prototype._updateNoWireframingState=function(){var e=this,t=Wd.HIDDEN;this.manager.traverseNodeIdxMap((function(i,n){e._setInstanceWireframeState(i,n,t)}),(function(t){return e._isNeedWireframing(t)}))},Gv.prototype._setInstanceWireframeState=function(e,t,i,n){var r=this._getWireframeGeometryById(e);if(r)for(var o=0,a=r.length;a>o;o+=1){var s=r[o].getAttribute("vState").array,l=null,c=null;n&&(c=(l=r[o].getAttribute("aColor"))?l.array:null);for(var h=0,d=t.length;d>h;h+=1){var u=t[h];s[u]=i,null!==c&&(c[4*u]=n[0],c[4*u+1]=n[1],c[4*u+2]=n[2],c[4*u+3]=n[3])}r[o].getAttribute("vState").needsUpdate=!0,l&&(l.needsUpdate=!0)}},Gv.prototype._generateInstanceWireframe=function(e){e||(e=this.model),this._collectNoWireframingIds(e),this._createInstanceWireframeGeometries(e),this._makeInstanceWireframe(e),this._updateNoWireframingState()},Gv.prototype.generateWireframe=function(e,t){e||(e=this.model),this.generated||(Bu.time("createInstancedWireframeGeometry"),this._generateInstanceWireframe(e),Bu.timeEnd("createInstancedWireframeGeometry"),this.generated=!0)},Gv.prototype._collectNoWireframingIds=function(e){var t=this,i=e.manager.filter;e.getModelDescriptor().traverseInstancedNodeInfos(null,(function(e,n){n&&i._hasRenderWithBoardlineFilter()&&!i._isRenderWithBoardline(n[0])&&(t.noNeedWireframingIdMap[e]=!0)}))},Gv.prototype._createInstanceWireframeGeometries=function(e){var t=this,i={};this.manager.traverseInstanceGeometryMap((function(e,n){for(var r=t._getWireframeBufferById(e,n,i),o=t.wireframeGeometryMap[e]=[],a=0,s=r.length;s>a;a+=1){var l=new xc;l.setIndex(r[a].index),l.setAttribute("position",r[a].position),o.push(l)}})),i=null},Gv.prototype._makeInstanceWireframe=function(e){var t=this,i=this.manager,n=i.getCachedInstanceData(),r=this._getWireframeMaterial(e);this._traverseWireframeGeometryMap((function(o,a){for(var s=i.getBufferAttributesBy(o),l=t.wireframeMeshMap[o]=[],c=0,h=a.length;h>c;c+=1){a[c].setAttribute("vState",new wc(new Float32Array(n.vState[o]),1,!1,1)),a[c].setAttribute("mcol0",s.attributeMcol0),a[c].setAttribute("mcol1",s.attributeMcol1),a[c].setAttribute("mcol2",s.attributeMcol2),a[c].setAttribute("mcol3",s.attributeMcol3);var d=new La(a[c],r);if(d.matrixAutoUpdate=!1,d.frustumCulled=!1,!wp.isEmptyObject(e.subModel)){var u=n.userId[o][0];if(u){var p=wp.getModelKeyFromComponentKey(u);e.subModel[p]&&d.matrix.copy(e.subModel[p])}}l.push(d),t._addWireframeNodeToScene(e,d)}}))},Gv.prototype._addWireframeNodeToScene=function(e,t){this._getNodeGroup(e).add(t),t.updateMatrixWorld(!0)},Gv.prototype._isNeedWireframing=function(e){return!this.noNeedWireframingIdMap||!this.noNeedWireframingIdMap[e]},Gv.prototype._getWireframeMaterial=function(e){return e.getInstanceWireframeMaterial()},Gv.prototype._getWireframeBufferById=function(e,t,i){var n=this.getGeometryIdByMeshId(e);if(i[n])return i[n];i[n]=[];for(var r=0,o=t.length;o>r;r+=1){var a=t[r];i[n].push({index:af(a.attributes.position.array,a.index.array),position:a.attributes.position})}return i[n]},Gv.prototype._getWireframeGeometryById=function(e){return this.wireframeGeometryMap[e]},Gv.prototype._getWireframeMeshById=function(e){return this.wireframeMeshMap[e]},Gv.prototype._traverseWireframeGeometryMap=function(e){var t=this.wireframeGeometryMap;for(var i in t)e(i,t[i])},Gv.prototype._getNodeGroup=function(e){return e._getNodeGroup(Vp.INSTANCEWIREFRAMEGEOMETRY,{globalSpace:!0})},Gv.prototype._hasNodeGroup=function(e){return e._hasNodeGroup(Vp.INSTANCEWIREFRAMEGEOMETRY)},Gv.prototype.getGeometryIdByMeshId=function(e){return wp.splitCombinedKeyString(e)[1]},Gv.prototype.adjustVisibility=function(e,t){if(e.isActivateWireframe()){var i=this._getNodeGroup(e),n=i.visible;t&&!i.bVisible||(i.visible=t),i.bVisible=n}},Gv.prototype.changeVisibilityOfSelectedObjects=function(e,t){},Gv.prototype.changeVisibilityOfNonSelectedObjects=function(e,t){this.adjustVisibility(e,t)},Gv.prototype.restoreVisibilityOfObjects=function(){},Gv.prototype.disposeBufferAfterVbo=function(){if(this.generated&&!this.bufferDestroyed){this.bufferDestroyed=!0;var e=["mcol0","mcol1","mcol2","mcol3"];xd.EnableExplosion&&e.pop(),this._traverseWireframeGeometryMap((function(t,i){for(var n=0,r=i.length;r>n;n+=1)by.disposeBufferFromGeometry(i[n],e)}))}},Gv.prototype.getPickingNodeGenerator=function(){return this.pickingNodeGenerator||(this.pickingNodeGenerator=new Pv(this)),this.pickingNodeGenerator};var Kv=function(e){this.model=e,this.meshManager=new Nv(this),this.wireframeManager=new Gv(this)};Kv.prototype.destroy=function(){this.meshManager.destroy(),this.meshManager=null,this.wireframeManager.destroy(),this.wireframeManager=null},Kv.prototype.clearData=function(){this.meshManager.clearData(),this.wireframeManager.clearData()},Kv.prototype.getGeometryByNodeInfo=function(e,t){return this.meshManager.getGeometryByNodeInfo(e,t)},Kv.prototype.getInstanceGeometries=function(){return this.meshManager.instanceGeometryMap},Kv.prototype.traverseInstanceGeometryMap=function(e){this.meshManager.traverseInstanceGeometryMap(e)},Kv.prototype.getCachedInstanceData=function(){return this.meshManager.cachedInstance},Kv.prototype.getBufferAttributesBy=function(e){return this.meshManager.getBufferAttributesBy(e)},Kv.prototype.traverseNodeIdxMapByUserId=function(e,t){this.meshManager.traverseNodeIdxMapByUserId(e,t)},Kv.prototype.traverseNodeIdxMap=function(e,t){this.meshManager.traverseNodeIdxMap(e,t)},Kv.prototype.getMeshesByUserId=function(e,t){return this.meshManager.getMeshesByUserId(e,t)},Kv.prototype._updateInstanceMaterialByUserId=function(e,t,i,n){this.meshManager.updateInstanceStateByUserId(e,t,i,n)},Kv.prototype._updateInstanceMaterialForWireFrameByUserId=function(e,t,i,n){this.wireframeManager.updateInstanceWireframeByUserId(e,t,i,n)},Kv.prototype._updateInstanceMaterial=function(e){Bu.time("update instance material");var t=Zd;for(var i in this.clearSelectedObjectIds(),this.filteredIds){var n=this.filteredIds[i];if(n[t.HIDDEN])this._updateInstanceMaterialByUserId(e,i,Wd.HIDDEN),this._updateInstanceMaterialForWireFrameByUserId(e,i,Wd.HIDDEN);else if(n[t.NEWBLINK]&&this._updateInstanceMaterialByUserId(e,i,Wd.OVERRIDED,n[t.NEWBLINK]),n[t.TRANSPARENT])this._updateInstanceMaterialByUserId(e,i,Wd.TRANSPARENT);else{if(e.manager.isSelectPriority()){if(n[t.SELECTED]){this._updateInstanceMaterialByUserId(e,i,Wd.SELECTED);continue}if(n[t.BLINK]){n[t.OVERRIDED]?this._updateInstanceMaterialByUserId(e,i,Wd.BLINK,n[t.OVERRIDED]):this._updateInstanceMaterialByUserId(e,i,Wd.BLINK);continue}}else{if(n[t.BLINK]){n[t.OVERRIDED]?this._updateInstanceMaterialByUserId(e,i,Wd.BLINK,n[t.OVERRIDED]):this._updateInstanceMaterialByUserId(e,i,Wd.BLINK);continue}if(n[t.SELECTED]){this._updateInstanceMaterialByUserId(e,i,Wd.SELECTED);continue}}n[t.HOVER]?n[t.OVERRIDED]?this._updateInstanceMaterialByUserId(e,i,Wd.HOVER,n[t.OVERRIDED]):this._updateInstanceMaterialByUserId(e,i,Wd.HOVER):n[t.OVERRIDED]&&this._updateInstanceMaterialByUserId(e,i,Wd.OVERRIDED,n[t.OVERRIDED])}}this._updateInstanceMaterialForWireFrame(e),Bu.timeEnd("update instance material")},Kv.prototype._updateInstanceMaterialForWireFrame=function(e){var t=this.mapFilteredUserIdsForWireFrame;if(t)for(var i=Object.keys(t),n=0,r=i.length;r>n;n+=1){var o=i[n];this.filteredIds&&this.filteredIds[o]&&this.filteredIds[o][Zd.HIDDEN]||this._updateInstanceMaterialForWireFrameByUserId(e,o,Wd.OVERRIDED,t[o])}},Kv.prototype._resetInstanceMaterial=function(e){this.meshManager.resetInstanceMaterial(e),this.wireframeManager.resetInstanceMaterial()},Kv.prototype._collectFilteredUserIds=function(e,t,i){var n=e.manager.filter,r=n._hasHiddenFileIdFilter(),o=n._hasVisibleFilter(),a=n._hasOverrideMaterialFilter(),s=n._hasTransparentFilter(),l=e.hasReplacedUserId(),c=e.hasHiddenUserId(),h=this.filteredIds={};if(this.transparentUserIdSetObject={},r||o||a||s||l||c)for(var d=Zd,u=0;t.length>u;u+=1){var p=t[u],g=i[p];if(g&&g.length){var f=g[0];if(r&&n._isHiddenFileId(f)||o&&!1===n._isVisible(f)||e.isReplacedUserId(p)||e.isHiddenSourceObjectUserId(p))h[p]||(h[p]={}),h[p][d.HIDDEN]=!0;else if(e.blinkMapComponentKeyToMaterialName&&e.blinkMapComponentKeyToMaterialName[p]&&e.blinkMapComponentKeyToRenderState[p])h[p]||(h[p]={}),h[p][d.NEWBLINK]=e.blinkMapComponentKeyToMaterialName[p];else if(s&&n._isTransparent(f))h[p]||(h[p]={}),h[p][d.TRANSPARENT]=!0,this.transparentUserIdSetObject[p]=!0;else if(a&&n._hasOverrideMaterial(f)){var m=n._getOverrideMaterial(f),A=null;if(Array.isArray(m)){var y=f.nodeId.replace(f.componentKey+"_",""),v=parseInt(y,10);""===(A=null!==m[v]?m[v].name:"")&&(A=f.materialId),h[p]||(h[p]={}),h[p][d.OVERRIDED]||(h[p][d.OVERRIDED]=[]),h[p][d.OVERRIDED][v]=A}else""!==(A=null!==m?m.name:"")&&(h[p]||(h[p]={}),h[p][d.OVERRIDED]=A)}else;}}},Kv.prototype._collectModelFiltered=function(e){var t=e.manager.filter,i=e.modelKey,n=t._hasModelOverrideMaterialFilter(),r=t._hasModelTransparentFilter(),o=e.manager.modelState.modelSelectionSet;return e.manager.modelState.hoverId===i?e.manager.modelState.getHoverMaterial():o.hasOwnProperty(e.modelKey)?e.manager.modelState.selectionMaterial:r&&t._isModelTransparent(i)?t._getMaterialByName("scene"):n&&t._hasModelOverrideMaterial(i)?t._getModelOverrideMaterial(i):null},Kv.prototype._collectFilteredUserIdsForWireFrame=function(e,t,i){var n=e.getFilter(),r=n._hasOverrideMaterialFilterForWireFrame();if(this.mapFilteredUserIdsForWireFrame={},r)for(var o=Zd,a=0;t.length>a;a+=1){var s=t[a];if(!(this.filteredIds&&this.filteredIds[s]&&this.filteredIds[s][o.HIDDEN])){var l=i[s];if(l&&l.length){var c=l[0];if(n._hasOverrideMaterialForWireFrame(c)){var h=n._getOverrideMaterialForWireFrame(c),d=null!==h?h.name:"";""!==d&&(this.mapFilteredUserIdsForWireFrame[s]=d)}}}}},Kv.prototype._collectSelectedUserIds=function(e,t){var i=this.filteredIds=this.filteredIds||{},n=Zd,r={};for(var o in e)if(this.model.modelKey===o)for(var a in e[o])t[a]&&(i[a]||(i[a]={}),i[a][n.SELECTED]=!0,r[a]=!0);this.selectedUserIds=Object.keys(r)},Kv.prototype._clearSelectedState=function(e){if(this.filteredIds&&this.selectedUserIds&&this.selectedUserIds.length){for(var t=0,i=this.selectedUserIds.length;i>t;t+=1){var n=this.selectedUserIds[t];this.filteredIds[n]&&(this.meshManager.clearInstanceStateByUserId(n),delete this.filteredIds[n][Zd.SELECTED])}this.selectedUserIds=null}},Kv.prototype._collectHoveredUserIds=function(e,t){var i=this.filteredIds=this.filteredIds||{};this.hoverdUserId=void 0,e&&t[e]&&(i[e]||(i[e]={}),i[e][Zd.HOVER]=!0,this.hoverdUserId=e)},Kv.prototype._clearHoveredState=function(e){this.filteredIds&&this.hoverdUserId&&this.filteredIds[this.hoverdUserId]&&(this.meshManager.clearInstanceStateByUserId(this.hoverdUserId),delete this.filteredIds[this.hoverdUserId][Zd.HOVER],this.hoverdUserId=void 0)},Kv.prototype._collectBlinkedUserIds=function(e,t){var i=this.filteredIds=this.filteredIds||{},n=Zd,r={};for(var o in e)t[o]&&(i[o]||(i[o]={}),i[o][n.BLINK]=!0,r[o]=!0);this.blinkUserIds=Object.keys(r)},Kv.prototype._clearBlinkedState=function(e){if(this.filteredIds&&this.blinkUserIds&&this.blinkUserIds.length){for(var t=0,i=this.blinkUserIds.length;i>t;t+=1){var n=this.blinkUserIds[t];this.filteredIds[n]&&(this.meshManager.clearInstanceStateByUserId(n),delete this.filteredIds[n][Zd.BLINK])}this.blinkUserIds=null}},Kv.prototype.applyFilter=function(e,t){if(this.hasNodeInfo(e)){this.updateNodes(e),this._resetInstanceMaterial(e);var i=null;i=t||e.getModelDescriptor().getInstancedUserIds();var n=e.getModelDescriptor().getInstancedNodeInfos();this._collectFilteredUserIds(e,i,n),this._collectFilteredUserIdsForWireFrame(e,i,n),this._collectSelectedUserIds(e.manager.sceneState.selectionSet,n),this._collectBlinkedUserIds(e.manager.sceneState.getBlinkComponentsIdMap(),n),this._collectHoveredUserIds(e.manager.sceneState.hoverId,n),this._updateInstanceMaterial(e),this.updateNodes(e)}},Kv.prototype.applySelection=function(e){if(this.hasNodeInfo(e)){this._resetInstanceMaterial(e);var t=e.getModelDescriptor().getInstancedNodeInfos();this._clearSelectedState(e),this._clearHoveredState(e),this._collectSelectedUserIds(e.manager.sceneState.selectionSet,t),this._collectHoveredUserIds(e.manager.sceneState.hoverId,t),this._updateInstanceMaterial(e),this.updateNodes(e)}},Kv.prototype.clearSelection=function(e){this._clearSelectedState(e),this.applyHover(e)},Kv.prototype.applyHover=function(e){if(this.hasNodeInfo(e)){var t=e.getModelDescriptor().getInstancedNodeInfos();this._clearHoveredState(e),this._collectHoveredUserIds(e.manager.sceneState.hoverId,t),this._updateInstanceMaterial(e),this.updateNodes(e)}},Kv.prototype.clearHover=function(e){this._clearHoveredState(e),this._updateInstanceMaterial(e),this.updateNodes(e)},Kv.prototype.applyBlink=function(e){if(this.hasNodeInfo(e)){var t=e.getModelDescriptor().getInstancedNodeInfos();this._clearBlinkedState(e),this._clearHoveredState(e),this._collectBlinkedUserIds(e.manager.sceneState.getBlinkComponentsIdMap(),t),this._collectHoveredUserIds(e.manager.sceneState.hoverId,t),this._updateInstanceMaterial(e),this.updateNodes(e)}},Kv.prototype.clearBlink=function(e){this._clearBlinkedState(e),this.applyHover(e)},Kv.prototype.applyReplacement=function(e){this._updateInstanceMaterial(e),this.updateNodes(e)},Kv.prototype.hasNodeInfo=function(e){return Boolean(e.getModelDescriptor().getInstancedNodeInfos())},Kv.prototype.updateNodes=function(e){if(this.hasNodeInfo(e)){var t;if(t=this._collectModelFiltered(e))for(var i=e.getModelDescriptor().getInstancedUserIds(),n=0;i.length>n;n+=1)this._updateInstanceMaterialByUserId(e,i[n],Wd.OVERRIDED,t);this.meshManager.updateNodes(e),this.wireframeManager.updateNodes(e)}},Kv.prototype.generateWireframe=function(e,t){this.wireframeManager.generateWireframe(e,t)},Kv.prototype.createMeshNodes=function(e,t){this.meshManager.createMeshNodes(e,t)},Kv.prototype.createInstancedMeshNodes=function(e,t){this.meshManager._createBatchedInstanceGeometries(e,t)},Kv.prototype.clearCachedData=function(){this.meshManager.disposeGeometries()},Kv.prototype.getMeshesByUserIds=function(e,t){this.meshManager.getMeshesByUserId(e,t)},Kv.prototype.clearSelectedObjectIds=function(){this.meshManager.clearSelectedObjectIds()},Kv.prototype.adjustVisibility=function(e,t){this.meshManager.adjustVisibility(e,t),this.wireframeManager.adjustVisibility(e,t)},Kv.prototype.changeVisibilityOfSelectedObjects=function(e,t){this.meshManager.changeVisibilityOfSelectedObjects(e,t),this.wireframeManager.changeVisibilityOfSelectedObjects(e,t)},Kv.prototype.changeVisibilityOfNonSelectedObjects=function(e,t){this.meshManager.changeVisibilityOfNonSelectedObjects(e,t),this.wireframeManager.changeVisibilityOfNonSelectedObjects(e,t)},Kv.prototype.restoreVisibilityOfObjects=function(){this.meshManager.restoreVisibilityOfObjects(),this.wireframeManager.restoreVisibilityOfObjects()},Kv.prototype.disposeBufferAfterVbo=function(){this.meshManager.disposeBufferAfterVbo(),this.wireframeManager.disposeBufferAfterVbo()},Kv.prototype.addAllInstanceNodeToScene=function(e){this.meshManager.addAllInstanceNodeToScene(e)},Kv.prototype.getGeometryBuffersByUserId=function(e,t){return this.meshManager.getGeometryBuffersByUserId(e,t)},Kv.prototype.explode=function(e,t,i){this.meshManager.explode(e,t,i)},Kv.prototype.explosion=function(e,t){this.meshManager.explosion(e,t)},Kv.prototype.closeExplosion=function(e){this.meshManager.closeExplosion(e)},Kv.prototype.componentsExplosion=function(e,t){this.meshManager.componentsExplosion(e,t)},Kv.prototype.closeComponentsExplosion=function(e,t){this.meshManager.closeComponentsExplosion(e,t)},Kv.prototype.isPickableNode=function(e){if(!this.filteredIds||!this.filteredIds[e])return!0;var t=this.filteredIds[e];return!(t[Zd.HIDDEN]||t[Zd.TRANSPARENT]&&!xd.EnableSelectionByTranslucent)},Kv.prototype.isHiddenNode=function(e){return!!(this.filteredIds&&this.filteredIds[e]&&this.filteredIds[e][Zd.HIDDEN])},Kv.prototype.getMeshManager=function(){return this.meshManager},Kv.prototype.getWireFrameManager=function(){return this.wireframeManager},Kv.prototype.getTransparentUserIds=function(){return this.transparentUserIdSetObject};var Vv=function(e,t){_y.call(this,e),this.defaultManager=new Qv(t,e),this.instancedManager=new Kv(e),this.loader=new Xy(this)};function Yv(e,t){var i=e.__state.conversionName.toString(),n=Math.round(e.r),r=Math.round(e.g),o=Math.round(e.b),a=e.a,s=Math.round(e.h),l=e.s.toFixed(1),c=e.v.toFixed(1);if(t||"THREE_CHAR_HEX"===i||"SIX_CHAR_HEX"===i){for(var h=e.hex.toString(16);6>h.length;)h="0"+h;return"#"+h}return"CSS_RGB"===i?"rgb("+n+","+r+","+o+")":"CSS_RGBA"===i?"rgba("+n+","+r+","+o+","+a+")":"HEX"===i?"0x"+e.hex.toString(16):"RGB_ARRAY"===i?"["+n+","+r+","+o+"]":"RGBA_ARRAY"===i?"["+n+","+r+","+o+","+a+"]":"RGB_OBJ"===i?"{r:"+n+",g:"+r+",b:"+o+"}":"RGBA_OBJ"===i?"{r:"+n+",g:"+r+",b:"+o+",a:"+a+"}":"HSV_OBJ"===i?"{h:"+s+",s:"+l+",v:"+c+"}":"HSVA_OBJ"===i?"{h:"+s+",s:"+l+",v:"+c+",a:"+a+"}":"unknown format"}(Vv.prototype=Object.create(_y.prototype)).prepare=function(e,t){this.isLoaded()&&!this.isHidden()&&(this.prepareWireframe(this.model,t),this.model.getMaterialManager(),this.model.getMaterialManager()._updateTextureMapping(),!this.model.lightmap||this.model.enableLightmap===xd.EnableLightmap&&this.model.lightmapIntensity===xd.LightmapIntensity||(this.model.enableLightmap=xd.EnableLightmap,this.model.lightmapIntensity=xd.LightmapIntensity,this.rebuildIndicesforLightmap(),this.updateNodes()))},Vv.prototype.settleData=function(e){this.addNodeInfoToOctantMap(),this.createMeshNodes(e)},Vv.prototype.addNodeInfoToOctantMap=function(){var e=this.model.manager,t=this.model.getEncodedDatabagId();this.loader.getDescriptor().traverseNodeInfosByComponent((function(i,n){e.addNodeInfoToOctantMap(t,i,n)}))},Vv.prototype.createMeshNodes=function(e){var t=this,i=this.model,n=this.loader.getDescriptor();this.instancedManager.createMeshNodes(i,n.getInstancedUserIds()),this.defaultManager.asyncCreateMeshNodes(i,n.getStandardUserIds(),(function(){i.getMaterialManager()._updateTextureMapping(),t.clearCachedData(i),t.loaded=!0,e&&e()}))},Vv.prototype.clearCachedData=function(e){this.loader.getDescriptor().destroyReader(),this.loader.getDescriptor().clearReferencedMeshCache(),this.defaultManager.clearCachedData(),this.instancedManager.clearCachedData()};var Hv=Array.prototype.forEach,jv=Array.prototype.slice,Wv={BREAK:{},extend:function(e){return this.each(jv.call(arguments,1),(function(t){(this.isObject(t)?Object.keys(t):[]).forEach(function(i){this.isUndefined(t[i])||(e[i]=t[i])}.bind(this))}),this),e},defaults:function(e){return this.each(jv.call(arguments,1),(function(t){(this.isObject(t)?Object.keys(t):[]).forEach(function(i){this.isUndefined(e[i])&&(e[i]=t[i])}.bind(this))}),this),e},compose:function(){var e=jv.call(arguments);return function(){for(var t=jv.call(arguments),i=e.length-1;i>=0;i--)t=[e[i].apply(this,t)];return t[0]}},each:function(e,t,i){if(e)if(Hv&&e.forEach&&e.forEach===Hv)e.forEach(t,i);else if(e.length===e.length+0){var n,r=void 0;for(r=0,n=e.length;n>r;r++)if(r in e&&t.call(i,e[r],r)===this.BREAK)return}else for(var o in e)if(t.call(i,e[o],o)===this.BREAK)return},defer:function(e){setTimeout(e,0)},debounce:function(e,t,i){var n=void 0;return function(){var r=this,o=arguments;function a(){n=null,i||e.apply(r,o)}var s=i||!n;clearTimeout(n),n=setTimeout(a,t),s&&e.apply(r,o)}},toArray:function(e){return e.toArray?e.toArray():jv.call(e)},isUndefined:function(e){return void 0===e},isNull:function(e){return null===e},isNaN:function(e){function t(){return e.apply(this,arguments)}return t.toString=function(){return e.toString()},t}((function(e){return isNaN(e)})),isArray:Array.isArray||function(e){return e.constructor===Array},isObject:function(e){return e===Object(e)},isNumber:function(e){return e===e+0},isString:function(e){return e===e+""},isBoolean:function(e){return!1===e||!0===e},isFunction:function(e){return"[object Function]"===Object.prototype.toString.call(e)}},Jv=[{litmus:Wv.isString,conversions:{THREE_CHAR_HEX:{read:function(e){var t=e.match(/^#([A-F0-9])([A-F0-9])([A-F0-9])$/i);return null!==t&&{space:"HEX",hex:parseInt("0x"+t[1].toString()+t[1].toString()+t[2].toString()+t[2].toString()+t[3].toString()+t[3].toString(),0)}},write:Yv},SIX_CHAR_HEX:{read:function(e){var t=e.match(/^#([A-F0-9]{6})$/i);return null!==t&&{space:"HEX",hex:parseInt("0x"+t[1].toString(),0)}},write:Yv},CSS_RGB:{read:function(e){var t=e.match(/^rgb\(\s*(.+)\s*,\s*(.+)\s*,\s*(.+)\s*\)/);return null!==t&&{space:"RGB",r:parseFloat(t[1]),g:parseFloat(t[2]),b:parseFloat(t[3])}},write:Yv},CSS_RGBA:{read:function(e){var t=e.match(/^rgba\(\s*(.+)\s*,\s*(.+)\s*,\s*(.+)\s*,\s*(.+)\s*\)/);return null!==t&&{space:"RGB",r:parseFloat(t[1]),g:parseFloat(t[2]),b:parseFloat(t[3]),a:parseFloat(t[4])}},write:Yv}}},{litmus:Wv.isNumber,conversions:{HEX:{read:function(e){return{space:"HEX",hex:e,conversionName:"HEX"}},write:function(e){return e.hex}}}},{litmus:Wv.isArray,conversions:{RGB_ARRAY:{read:function(e){return 3===e.length&&{space:"RGB",r:e[0],g:e[1],b:e[2]}},write:function(e){return[e.r,e.g,e.b]}},RGBA_ARRAY:{read:function(e){return 4===e.length&&{space:"RGB",r:e[0],g:e[1],b:e[2],a:e[3]}},write:function(e){return[e.r,e.g,e.b,e.a]}}}},{litmus:Wv.isObject,conversions:{RGBA_OBJ:{read:function(e){return!!(Wv.isNumber(e.r)&&Wv.isNumber(e.g)&&Wv.isNumber(e.b)&&Wv.isNumber(e.a))&&{space:"RGB",r:e.r,g:e.g,b:e.b,a:e.a}},write:function(e){return{r:e.r,g:e.g,b:e.b,a:e.a}}},RGB_OBJ:{read:function(e){return!!(Wv.isNumber(e.r)&&Wv.isNumber(e.g)&&Wv.isNumber(e.b))&&{space:"RGB",r:e.r,g:e.g,b:e.b}},write:function(e){return{r:e.r,g:e.g,b:e.b}}},HSVA_OBJ:{read:function(e){return!!(Wv.isNumber(e.h)&&Wv.isNumber(e.s)&&Wv.isNumber(e.v)&&Wv.isNumber(e.a))&&{space:"HSV",h:e.h,s:e.s,v:e.v,a:e.a}},write:function(e){return{h:e.h,s:e.s,v:e.v,a:e.a}}},HSV_OBJ:{read:function(e){return!!(Wv.isNumber(e.h)&&Wv.isNumber(e.s)&&Wv.isNumber(e.v))&&{space:"HSV",h:e.h,s:e.s,v:e.v}},write:function(e){return{h:e.h,s:e.s,v:e.v}}}}}],zv=void 0,qv=void 0,Zv=function(){qv=!1;var e=arguments.length>1?Wv.toArray(arguments):arguments[0];return Wv.each(Jv,(function(t){if(t.litmus(e))return Wv.each(t.conversions,(function(t,i){if(zv=t.read(e),!1===qv&&!1!==zv)return qv=zv,zv.conversionName=i,zv.conversion=t,Wv.BREAK})),Wv.BREAK})),qv},Xv=void 0,_v={hsv_to_rgb:function(e,t,i){var n=Math.floor(e/60)%6,r=e/60-Math.floor(e/60),o=i*(1-t),a=i*(1-r*t),s=i*(1-(1-r)*t),l=[[i,s,o],[a,i,o],[o,i,s],[o,a,i],[s,o,i],[i,o,a]][n];return{r:255*l[0],g:255*l[1],b:255*l[2]}},rgb_to_hsv:function(e,t,i){var n=Math.min(e,t,i),r=Math.max(e,t,i),o=r-n,a=void 0;return 0===r?{h:NaN,s:0,v:0}:(a=e===r?(t-i)/o:t===r?2+(i-e)/o:4+(e-t)/o,0>(a/=6)&&(a+=1),{h:360*a,s:o/r,v:r/255})},rgb_to_hex:function(e,t,i){var n=this.hex_with_component(0,2,e);return n=this.hex_with_component(n,1,t),n=this.hex_with_component(n,0,i)},component_from_hex:function(e,t){return e>>8*t&255},hex_with_component:function(e,t,i){return i<<(Xv=8*t)|e&~(255<<Xv)}},$v="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},eC=function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")},tC=function(){function e(e,t){for(var i=0;t.length>i;i++){var n=t[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(e,n.key,n)}}return function(t,i,n){return i&&e(t.prototype,i),n&&e(t,n),t}}(),iC=function e(t,i,n){null===t&&(t=Function.prototype);var r=Object.getOwnPropertyDescriptor(t,i);if(void 0===r){var o=Object.getPrototypeOf(t);return null===o?void 0:e(o,i,n)}if("value"in r)return r.value;var a=r.get;return void 0!==a?a.call(n):void 0},nC=function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)},rC=function(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t},oC=function(){function e(){if(eC(this,e),this.__state=Zv.apply(this,arguments),!1===this.__state)throw new Error("Failed to interpret color arguments");this.__state.a=this.__state.a||1}return tC(e,[{key:"toString",value:function(){return Yv(this)}},{key:"toHexString",value:function(){return Yv(this,!0)}},{key:"toOriginal",value:function(){return this.__state.conversion.write(this)}}]),e}();function aC(e,t,i){Object.defineProperty(e,t,{get:function(){return"RGB"===this.__state.space||oC.recalculateRGB(this,t,i),this.__state[t]},set:function(e){"RGB"!==this.__state.space&&(oC.recalculateRGB(this,t,i),this.__state.space="RGB"),this.__state[t]=e}})}function sC(e,t){Object.defineProperty(e,t,{get:function(){return"HSV"===this.__state.space||oC.recalculateHSV(this),this.__state[t]},set:function(e){"HSV"!==this.__state.space&&(oC.recalculateHSV(this),this.__state.space="HSV"),this.__state[t]=e}})}oC.recalculateRGB=function(e,t,i){if("HEX"===e.__state.space)e.__state[t]=_v.component_from_hex(e.__state.hex,i);else{if("HSV"!==e.__state.space)throw new Error("Corrupted color state");Wv.extend(e.__state,_v.hsv_to_rgb(e.__state.h,e.__state.s,e.__state.v))}},oC.recalculateHSV=function(e){var t=_v.rgb_to_hsv(e.r,e.g,e.b);Wv.extend(e.__state,{s:t.s,v:t.v}),Wv.isNaN(t.h)?Wv.isUndefined(e.__state.h)&&(e.__state.h=0):e.__state.h=t.h},oC.COMPONENTS=["r","g","b","h","s","v","hex","a"],aC(oC.prototype,"r",2),aC(oC.prototype,"g",1),aC(oC.prototype,"b",0),sC(oC.prototype,"h"),sC(oC.prototype,"s"),sC(oC.prototype,"v"),Object.defineProperty(oC.prototype,"a",{get:function(){return this.__state.a},set:function(e){this.__state.a=e}}),Object.defineProperty(oC.prototype,"hex",{get:function(){return"HEX"!==!this.__state.space&&(this.__state.hex=_v.rgb_to_hex(this.r,this.g,this.b)),this.__state.hex},set:function(e){this.__state.space="HEX",this.__state.hex=e}});var lC=function(){function e(t,i){eC(this,e),this.initialValue=t[i],this.domElement=document.createElement("div"),this.object=t,this.property=i,this.__onChange=void 0,this.__onFinishChange=void 0}return tC(e,[{key:"onChange",value:function(e){return this.__onChange=e,this}},{key:"onFinishChange",value:function(e){return this.__onFinishChange=e,this}},{key:"setValue",value:function(e){return this.object[this.property]=e,this.__onChange&&this.__onChange.call(this,e),this.updateDisplay(),this}},{key:"getValue",value:function(){return this.object[this.property]}},{key:"updateDisplay",value:function(){return this}},{key:"isModified",value:function(){return this.initialValue!==this.getValue()}}]),e}(),cC={};Wv.each({HTMLEvents:["change"],MouseEvents:["click","mousemove","mousedown","mouseup","mouseover"],KeyboardEvents:["keydown"]},(function(e,t){Wv.each(e,(function(e){cC[e]=t}))}));var hC=/(\d+(\.\d+)?)px/;function dC(e){if("0"===e||Wv.isUndefined(e))return 0;var t=e.match(hC);return Wv.isNull(t)?0:parseFloat(t[1])}var uC={makeSelectable:function(e,t){void 0!==e&&void 0!==e.style&&(e.onselectstart=t?function(){return!1}:function(){},e.style.MozUserSelect=t?"auto":"none",e.style.KhtmlUserSelect=t?"auto":"none",e.unselectable=t?"on":"off")},makeFullscreen:function(e,t,i){var n=i,r=t;Wv.isUndefined(r)&&(r=!0),Wv.isUndefined(n)&&(n=!0),e.style.position="absolute",r&&(e.style.left=0,e.style.right=0),n&&(e.style.top=0,e.style.bottom=0)},fakeEvent:function(e,t,i,n){var r=i||{},o=cC[t];if(!o)throw new Error("Event type "+t+" not supported.");var a=document.createEvent(o);switch(o){case"MouseEvents":a.initMouseEvent(t,r.bubbles||!1,r.cancelable||!0,window,r.clickCount||1,0,0,r.x||r.clientX||0,r.y||r.clientY||0,!1,!1,!1,!1,0,null);break;case"KeyboardEvents":var s=a.initKeyboardEvent||a.initKeyEvent;Wv.defaults(r,{cancelable:!0,ctrlKey:!1,altKey:!1,shiftKey:!1,metaKey:!1,keyCode:void 0,charCode:void 0}),s(t,r.bubbles||!1,r.cancelable,window,r.ctrlKey,r.altKey,r.shiftKey,r.metaKey,r.keyCode,r.charCode);break;default:a.initEvent(t,r.bubbles||!1,r.cancelable||!0)}Wv.defaults(a,n),e.dispatchEvent(a)},bind:function(e,t,i,n){return e.addEventListener?e.addEventListener(t,i,n||!1):e.attachEvent&&e.attachEvent("on"+t,i),uC},unbind:function(e,t,i,n){return e.removeEventListener?e.removeEventListener(t,i,n||!1):e.detachEvent&&e.detachEvent("on"+t,i),uC},addClass:function(e,t){if(void 0===e.className)e.className=t;else if(e.className!==t){var i=e.className.split(/ +/);-1===i.indexOf(t)&&(i.push(t),e.className=i.join(" ").replace(/^\s+/,"").replace(/\s+$/,""))}return uC},removeClass:function(e,t){if(t)if(e.className===t)e.removeAttribute("class");else{var i=e.className.split(/ +/),n=i.indexOf(t);-1!==n&&(i.splice(n,1),e.className=i.join(" "))}else e.className=void 0;return uC},hasClass:function(e,t){return new RegExp("(?:^|\\s+)"+t+"(?:\\s+|$)").test(e.className)||!1},getWidth:function(e){var t=getComputedStyle(e);return dC(t["border-left-width"])+dC(t["border-right-width"])+dC(t["padding-left"])+dC(t["padding-right"])+dC(t.width)},getHeight:function(e){var t=getComputedStyle(e);return dC(t["border-top-width"])+dC(t["border-bottom-width"])+dC(t["padding-top"])+dC(t["padding-bottom"])+dC(t.height)},getOffset:function(e){var t=e,i={left:0,top:0};if(t.offsetParent)do{i.left+=t.offsetLeft,i.top+=t.offsetTop,t=t.offsetParent}while(t);return i},isActive:function(e){return e===document.activeElement&&(e.type||e.href)}},pC=function(e){function t(e,i){eC(this,t);var n=rC(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,i)),r=n;return n.__prev=n.getValue(),n.__checkbox=document.createElement("input"),n.__checkbox.setAttribute("type","checkbox"),uC.bind(n.__checkbox,"change",(function(){r.setValue(!r.__prev)}),!1),n.domElement.appendChild(n.__checkbox),n.updateDisplay(),n}return nC(t,e),tC(t,[{key:"setValue",value:function(e){var i=iC(t.prototype.__proto__||Object.getPrototypeOf(t.prototype),"setValue",this).call(this,e);return this.__onFinishChange&&this.__onFinishChange.call(this,this.getValue()),this.__prev=this.getValue(),i}},{key:"updateDisplay",value:function(){return!0===this.getValue()?(this.__checkbox.setAttribute("checked","checked"),this.__checkbox.checked=!0,this.__prev=!0):(this.__checkbox.checked=!1,this.__prev=!1),iC(t.prototype.__proto__||Object.getPrototypeOf(t.prototype),"updateDisplay",this).call(this)}}]),t}(lC),gC=function(e){function t(e,i,n){eC(this,t);var r=rC(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,i)),o=n,a=r;if(r.__select=document.createElement("select"),Wv.isArray(o)){var s={};Wv.each(o,(function(e){s[e]=e})),o=s}return Wv.each(o,(function(e,t){var i=document.createElement("option");i.innerHTML=t,i.setAttribute("value",e),a.__select.appendChild(i)})),r.updateDisplay(),uC.bind(r.__select,"change",(function(){a.setValue(this.options[this.selectedIndex].value)})),r.domElement.appendChild(r.__select),r}return nC(t,e),tC(t,[{key:"setValue",value:function(e){var i=iC(t.prototype.__proto__||Object.getPrototypeOf(t.prototype),"setValue",this).call(this,e);return this.__onFinishChange&&this.__onFinishChange.call(this,this.getValue()),i}},{key:"updateDisplay",value:function(){return uC.isActive(this.__select)?this:(this.__select.value=this.getValue(),iC(t.prototype.__proto__||Object.getPrototypeOf(t.prototype),"updateDisplay",this).call(this))}}]),t}(lC),fC=function(e){function t(e,i){eC(this,t);var n=rC(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,i)),r=n;function o(){r.setValue(r.__input.value)}return n.__input=document.createElement("input"),n.__input.setAttribute("type","text"),uC.bind(n.__input,"keyup",o),uC.bind(n.__input,"change",o),uC.bind(n.__input,"blur",(function(){r.__onFinishChange&&r.__onFinishChange.call(r,r.getValue())})),uC.bind(n.__input,"keydown",(function(e){13===e.keyCode&&this.blur()})),n.updateDisplay(),n.domElement.appendChild(n.__input),n}return nC(t,e),tC(t,[{key:"updateDisplay",value:function(){return uC.isActive(this.__input)||(this.__input.value=this.getValue()),iC(t.prototype.__proto__||Object.getPrototypeOf(t.prototype),"updateDisplay",this).call(this)}}]),t}(lC);function mC(e){var t=e.toString();return t.indexOf(".")>-1?t.length-t.indexOf(".")-1:0}var AC=function(e){function t(e,i,n){eC(this,t);var r=rC(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,i)),o=n||{};return r.__min=o.min,r.__max=o.max,r.__step=o.step,r.__impliedStep=Wv.isUndefined(r.__step)?0===r.initialValue?1:Math.pow(10,Math.floor(Math.log(Math.abs(r.initialValue))/Math.LN10))/10:r.__step,r.__precision=mC(r.__impliedStep),r}return nC(t,e),tC(t,[{key:"setValue",value:function(e){var i=e;return void 0!==this.__min&&this.__min>i?i=this.__min:void 0!==this.__max&&i>this.__max&&(i=this.__max),void 0!==this.__step&&i%this.__step!=0&&(i=Math.round(i/this.__step)*this.__step),iC(t.prototype.__proto__||Object.getPrototypeOf(t.prototype),"setValue",this).call(this,i)}},{key:"min",value:function(e){return this.__min=e,this}},{key:"max",value:function(e){return this.__max=e,this}},{key:"step",value:function(e){return this.__step=e,this.__impliedStep=e,this.__precision=mC(e),this}}]),t}(lC);var yC=function(e){function t(e,i,n){eC(this,t);var r=rC(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,i,n));r.__truncationSuspended=!1;var o=r,a=void 0;function s(){o.__onFinishChange&&o.__onFinishChange.call(o,o.getValue())}function l(e){var t=a-e.clientY;o.setValue(o.getValue()+t*o.__impliedStep),a=e.clientY}function c(){uC.unbind(window,"mousemove",l),uC.unbind(window,"mouseup",c),s()}return r.__input=document.createElement("input"),r.__input.setAttribute("type","text"),uC.bind(r.__input,"change",(function(){var e=parseFloat(o.__input.value);Wv.isNaN(e)||o.setValue(e)})),uC.bind(r.__input,"blur",(function(){s()})),uC.bind(r.__input,"mousedown",(function(e){uC.bind(window,"mousemove",l),uC.bind(window,"mouseup",c),a=e.clientY})),uC.bind(r.__input,"keydown",(function(e){13===e.keyCode&&(o.__truncationSuspended=!0,this.blur(),o.__truncationSuspended=!1,s())})),r.updateDisplay(),r.domElement.appendChild(r.__input),r}return nC(t,e),tC(t,[{key:"updateDisplay",value:function(){return this.__input.value=this.__truncationSuspended?this.getValue():function(e,t){var i=Math.pow(10,t);return Math.round(e*i)/i}(this.getValue(),this.__precision),iC(t.prototype.__proto__||Object.getPrototypeOf(t.prototype),"updateDisplay",this).call(this)}}]),t}(AC);function vC(e,t,i,n,r){return n+(e-t)/(i-t)*(r-n)}var CC=function(e){function t(e,i,n,r,o){eC(this,t);var a=rC(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,i,{min:n,max:r,step:o})),s=a;function l(e){e.preventDefault();var t=s.__background.getBoundingClientRect();return s.setValue(vC(e.clientX,t.left,t.right,s.__min,s.__max)),!1}function c(){uC.unbind(window,"mousemove",l),uC.unbind(window,"mouseup",c),s.__onFinishChange&&s.__onFinishChange.call(s,s.getValue())}function h(e){var t=e.touches[0].clientX,i=s.__background.getBoundingClientRect();s.setValue(vC(t,i.left,i.right,s.__min,s.__max))}function d(){uC.unbind(window,"touchmove",h),uC.unbind(window,"touchend",d),s.__onFinishChange&&s.__onFinishChange.call(s,s.getValue())}return a.__background=document.createElement("div"),a.__foreground=document.createElement("div"),uC.bind(a.__background,"mousedown",(function(e){document.activeElement.blur(),uC.bind(window,"mousemove",l),uC.bind(window,"mouseup",c),l(e)})),uC.bind(a.__background,"touchstart",(function(e){if(1!==e.touches.length)return;uC.bind(window,"touchmove",h),uC.bind(window,"touchend",d),h(e)})),uC.addClass(a.__background,"slider"),uC.addClass(a.__foreground,"slider-fg"),a.updateDisplay(),a.__background.appendChild(a.__foreground),a.domElement.appendChild(a.__background),a}return nC(t,e),tC(t,[{key:"updateDisplay",value:function(){var e=(this.getValue()-this.__min)/(this.__max-this.__min);return this.__foreground.style.width=100*e+"%",iC(t.prototype.__proto__||Object.getPrototypeOf(t.prototype),"updateDisplay",this).call(this)}}]),t}(AC),IC=function(e){function t(e,i,n){eC(this,t);var r=rC(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,i)),o=r;return r.__button=document.createElement("div"),r.__button.innerHTML=void 0===n?"Fire":n,uC.bind(r.__button,"click",(function(e){return e.preventDefault(),o.fire(),!1})),uC.addClass(r.__button,"button"),r.domElement.appendChild(r.__button),r}return nC(t,e),tC(t,[{key:"fire",value:function(){this.__onChange&&this.__onChange.call(this),this.getValue().call(this.object),this.__onFinishChange&&this.__onFinishChange.call(this,this.getValue())}}]),t}(lC),xC=function(e){function t(e,i){eC(this,t);var n=rC(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,i));n.__color=new oC(n.getValue()),n.__temp=new oC(0);var r=n;n.domElement=document.createElement("div"),uC.makeSelectable(n.domElement,!1),n.__selector=document.createElement("div"),n.__selector.className="selector",n.__saturation_field=document.createElement("div"),n.__saturation_field.className="saturation-field",n.__field_knob=document.createElement("div"),n.__field_knob.className="field-knob",n.__field_knob_border="2px solid ",n.__hue_knob=document.createElement("div"),n.__hue_knob.className="hue-knob",n.__hue_field=document.createElement("div"),n.__hue_field.className="hue-field",n.__input=document.createElement("input"),n.__input.type="text",n.__input_textShadow="0 1px 1px ",uC.bind(n.__input,"keydown",(function(e){13===e.keyCode&&d.call(this)})),uC.bind(n.__input,"blur",d),uC.bind(n.__selector,"mousedown",(function(){uC.addClass(this,"drag").bind(window,"mouseup",(function(){uC.removeClass(r.__selector,"drag")}))})),uC.bind(n.__selector,"touchstart",(function(){uC.addClass(this,"drag").bind(window,"touchend",(function(){uC.removeClass(r.__selector,"drag")}))}));var o,a=document.createElement("div");function s(e){p(e),uC.bind(window,"mousemove",p),uC.bind(window,"touchmove",p),uC.bind(window,"mouseup",c),uC.bind(window,"touchend",c)}function l(e){g(e),uC.bind(window,"mousemove",g),uC.bind(window,"touchmove",g),uC.bind(window,"mouseup",h),uC.bind(window,"touchend",h)}function c(){uC.unbind(window,"mousemove",p),uC.unbind(window,"touchmove",p),uC.unbind(window,"mouseup",c),uC.unbind(window,"touchend",c),u()}function h(){uC.unbind(window,"mousemove",g),uC.unbind(window,"touchmove",g),uC.unbind(window,"mouseup",h),uC.unbind(window,"touchend",h),u()}function d(){var e=Zv(this.value);!1!==e?(r.__color.__state=e,r.setValue(r.__color.toOriginal())):this.value=r.__color.toString()}function u(){r.__onFinishChange&&r.__onFinishChange.call(r,r.__color.toOriginal())}function p(e){-1===e.type.indexOf("touch")&&e.preventDefault();var t=r.__saturation_field.getBoundingClientRect(),i=e.touches&&e.touches[0]||e,n=(i.clientX-t.left)/(t.right-t.left),o=1-(i.clientY-t.top)/(t.bottom-t.top);return o>1?o=1:0>o&&(o=0),n>1?n=1:0>n&&(n=0),r.__color.v=o,r.__color.s=n,r.setValue(r.__color.toOriginal()),!1}function g(e){-1===e.type.indexOf("touch")&&e.preventDefault();var t=r.__hue_field.getBoundingClientRect(),i=1-((e.touches&&e.touches[0]||e).clientY-t.top)/(t.bottom-t.top);return i>1?i=1:0>i&&(i=0),r.__color.h=360*i,r.setValue(r.__color.toOriginal()),!1}return Wv.extend(n.__selector.style,{width:"122px",height:"102px",padding:"3px",backgroundColor:"#222",boxShadow:"0px 1px 3px rgba(0,0,0,0.3)"}),Wv.extend(n.__field_knob.style,{position:"absolute",width:"12px",height:"12px",border:n.__field_knob_border+(.5>n.__color.v?"#fff":"#000"),boxShadow:"0px 1px 3px rgba(0,0,0,0.5)",borderRadius:"12px",zIndex:1}),Wv.extend(n.__hue_knob.style,{position:"absolute",width:"15px",height:"2px",borderRight:"4px solid #fff",zIndex:1}),Wv.extend(n.__saturation_field.style,{width:"100px",height:"100px",border:"1px solid #555",marginRight:"3px",display:"inline-block",cursor:"pointer"}),Wv.extend(a.style,{width:"100%",height:"100%",background:"none"}),MC(a,"top","rgba(0,0,0,0)","#000"),Wv.extend(n.__hue_field.style,{width:"15px",height:"100px",border:"1px solid #555",cursor:"ns-resize",position:"absolute",top:"3px",right:"3px"}),(o=n.__hue_field).style.background="",o.style.cssText+="background: -moz-linear-gradient(top, #ff0000 0%, #ff00ff 17%, #0000ff 34%, #00ffff 50%, #00ff00 67%, #ffff00 84%, #ff0000 100%);",o.style.cssText+="background: -webkit-linear-gradient(top, #ff0000 0%,#ff00ff 17%,#0000ff 34%,#00ffff 50%,#00ff00 67%,#ffff00 84%,#ff0000 100%);",o.style.cssText+="background: -o-linear-gradient(top, #ff0000 0%,#ff00ff 17%,#0000ff 34%,#00ffff 50%,#00ff00 67%,#ffff00 84%,#ff0000 100%);",o.style.cssText+="background: -ms-linear-gradient(top, #ff0000 0%,#ff00ff 17%,#0000ff 34%,#00ffff 50%,#00ff00 67%,#ffff00 84%,#ff0000 100%);",o.style.cssText+="background: linear-gradient(top, #ff0000 0%,#ff00ff 17%,#0000ff 34%,#00ffff 50%,#00ff00 67%,#ffff00 84%,#ff0000 100%);",Wv.extend(n.__input.style,{outline:"none",textAlign:"center",color:"#fff",border:0,fontWeight:"bold",textShadow:n.__input_textShadow+"rgba(0,0,0,0.7)"}),uC.bind(n.__saturation_field,"mousedown",s),uC.bind(n.__saturation_field,"touchstart",s),uC.bind(n.__field_knob,"mousedown",s),uC.bind(n.__field_knob,"touchstart",s),uC.bind(n.__hue_field,"mousedown",l),uC.bind(n.__hue_field,"touchstart",l),n.__saturation_field.appendChild(a),n.__selector.appendChild(n.__field_knob),n.__selector.appendChild(n.__saturation_field),n.__selector.appendChild(n.__hue_field),n.__hue_field.appendChild(n.__hue_knob),n.domElement.appendChild(n.__input),n.domElement.appendChild(n.__selector),n.updateDisplay(),n}return nC(t,e),tC(t,[{key:"updateDisplay",value:function(){var e=Zv(this.getValue());if(!1!==e){var t=!1;Wv.each(oC.COMPONENTS,(function(i){if(!Wv.isUndefined(e[i])&&!Wv.isUndefined(this.__color.__state[i])&&e[i]!==this.__color.__state[i])return t=!0,{}}),this),t&&Wv.extend(this.__color.__state,e)}Wv.extend(this.__temp.__state,this.__color.__state),this.__temp.a=1;var i=.5>this.__color.v||this.__color.s>.5?255:0,n=255-i;Wv.extend(this.__field_knob.style,{marginLeft:100*this.__color.s-7+"px",marginTop:100*(1-this.__color.v)-7+"px",backgroundColor:this.__temp.toHexString(),border:this.__field_knob_border+"rgb("+i+","+i+","+i+")"}),this.__hue_knob.style.marginTop=100*(1-this.__color.h/360)+"px",this.__temp.s=1,this.__temp.v=1,MC(this.__saturation_field,"left","#fff",this.__temp.toHexString()),this.__input.value=this.__color.toString(),Wv.extend(this.__input.style,{backgroundColor:this.__color.toHexString(),color:"rgb("+i+","+i+","+i+")",textShadow:this.__input_textShadow+"rgba("+n+","+n+","+n+",.7)"})}}]),t}(lC),wC=["-moz-","-o-","-webkit-","-ms-",""];function MC(e,t,i,n){e.style.background="",Wv.each(wC,(function(r){e.style.cssText+="background: "+r+"linear-gradient("+t+", "+i+" 0%, "+n+" 100%); "}))}var EC=function(e,t){var i=t||document,n=document.createElement("style");n.type="text/css",n.innerHTML=e;var r=i.getElementsByTagName("head")[0];try{r.appendChild(n)}catch(e){}},BC='<div id="dg-save" class="dg dialogue">\n\n Here\'s the new load parameter for your <code>GUI</code>\'s constructor:\n\n <textarea id="dg-new-constructor"></textarea>\n\n <div id="dg-save-locally">\n\n <input id="dg-local-storage" type="checkbox"/> Automatically save\n values to <code>localStorage</code> on exit.\n\n <div id="dg-local-explain">The values saved to <code>localStorage</code> will\n override those passed to <code>dat.GUI</code>\'s constructor. This makes it\n easier to work incrementally, but <code>localStorage</code> is fragile,\n and your friends may not see the same values you do.\n\n </div>\n\n </div>\n\n</div>',SC=function(e,t){var i=e[t];return Wv.isArray(arguments[2])||Wv.isObject(arguments[2])?new gC(e,t,arguments[2]):Wv.isNumber(i)?Wv.isNumber(arguments[2])&&Wv.isNumber(arguments[3])?Wv.isNumber(arguments[4])?new CC(e,t,arguments[2],arguments[3],arguments[4]):new CC(e,t,arguments[2],arguments[3]):Wv.isNumber(arguments[4])?new yC(e,t,{min:arguments[2],max:arguments[3],step:arguments[4]}):new yC(e,t,{min:arguments[2],max:arguments[3]}):Wv.isString(i)?new fC(e,t):Wv.isFunction(i)?new IC(e,t,""):Wv.isBoolean(i)?new pC(e,t):null};var bC=window.requestAnimationFrame||window.webkitRequestAnimationFrame||window.mozRequestAnimationFrame||window.oRequestAnimationFrame||window.msRequestAnimationFrame||function(e){setTimeout(e,1e3/60)},kC=function(){function e(){eC(this,e),this.backgroundElement=document.createElement("div"),Wv.extend(this.backgroundElement.style,{backgroundColor:"rgba(0,0,0,0.8)",top:0,left:0,display:"none",zIndex:"1000",opacity:0,WebkitTransition:"opacity 0.2s linear",transition:"opacity 0.2s linear"}),uC.makeFullscreen(this.backgroundElement),this.backgroundElement.style.position="fixed",this.domElement=document.createElement("div"),Wv.extend(this.domElement.style,{position:"fixed",display:"none",zIndex:"1001",opacity:0,WebkitTransition:"-webkit-transform 0.2s ease-out, opacity 0.2s linear",transition:"transform 0.2s ease-out, opacity 0.2s linear"}),document.body.appendChild(this.backgroundElement),document.body.appendChild(this.domElement);var t=this;uC.bind(this.backgroundElement,"click",(function(){t.hide()}))}return tC(e,[{key:"show",value:function(){var e=this;this.backgroundElement.style.display="block",this.domElement.style.display="block",this.domElement.style.opacity=0,this.domElement.style.webkitTransform="scale(1.1)",this.layout(),Wv.defer((function(){e.backgroundElement.style.opacity=1,e.domElement.style.opacity=1,e.domElement.style.webkitTransform="scale(1)"}))}},{key:"hide",value:function(){var e=this,t=function t(){e.domElement.style.display="none",e.backgroundElement.style.display="none",uC.unbind(e.domElement,"webkitTransitionEnd",t),uC.unbind(e.domElement,"transitionend",t),uC.unbind(e.domElement,"oTransitionEnd",t)};uC.bind(this.domElement,"webkitTransitionEnd",t),uC.bind(this.domElement,"transitionend",t),uC.bind(this.domElement,"oTransitionEnd",t),this.backgroundElement.style.opacity=0,this.domElement.style.opacity=0,this.domElement.style.webkitTransform="scale(1.1)"}},{key:"layout",value:function(){this.domElement.style.left=window.innerWidth/2-uC.getWidth(this.domElement)/2+"px",this.domElement.style.top=window.innerHeight/2-uC.getHeight(this.domElement)/2+"px"}}]),e}();EC(function(e){if(e&&"undefined"!=typeof window){var t=document.createElement("style");return t.setAttribute("type","text/css"),t.innerHTML=e,document.head.appendChild(t),e}}(".dg ul{list-style:none;margin:0;padding:0;width:100%;clear:both}.dg.ac{position:fixed;top:0;left:0;right:0;height:0;z-index:0}.dg:not(.ac) .main{overflow:hidden}.dg.main{-webkit-transition:opacity .1s linear;-o-transition:opacity .1s linear;-moz-transition:opacity .1s linear;transition:opacity .1s linear}.dg.main.taller-than-window{overflow-y:auto}.dg.main.taller-than-window .close-button{opacity:1;margin-top:-1px;border-top:1px solid #2c2c2c}.dg.main ul.closed .close-button{opacity:1 !important}.dg.main:hover .close-button,.dg.main .close-button.drag{opacity:1}.dg.main .close-button{-webkit-transition:opacity .1s linear;-o-transition:opacity .1s linear;-moz-transition:opacity .1s linear;transition:opacity .1s linear;border:0;line-height:19px;height:20px;cursor:pointer;text-align:center;background-color:#000}.dg.main .close-button.close-top{position:relative}.dg.main .close-button.close-bottom{position:absolute}.dg.main .close-button:hover{background-color:#111}.dg.a{float:right;margin-right:15px;overflow-y:visible}.dg.a.has-save>ul.close-top{margin-top:0}.dg.a.has-save>ul.close-bottom{margin-top:27px}.dg.a.has-save>ul.closed{margin-top:0}.dg.a .save-row{top:0;z-index:1002}.dg.a .save-row.close-top{position:relative}.dg.a .save-row.close-bottom{position:fixed}.dg li{-webkit-transition:height .1s ease-out;-o-transition:height .1s ease-out;-moz-transition:height .1s ease-out;transition:height .1s ease-out;-webkit-transition:overflow .1s linear;-o-transition:overflow .1s linear;-moz-transition:overflow .1s linear;transition:overflow .1s linear}.dg li:not(.folder){cursor:auto;height:27px;line-height:27px;padding:0 4px 0 5px}.dg li.folder{padding:0;border-left:4px solid rgba(0,0,0,0)}.dg li.title{cursor:pointer;margin-left:-4px}.dg .closed li:not(.title),.dg .closed ul li,.dg .closed ul li>*{height:0;overflow:hidden;border:0}.dg .cr{clear:both;padding-left:3px;height:27px;overflow:hidden}.dg .property-name{cursor:default;float:left;clear:left;width:40%;overflow:hidden;text-overflow:ellipsis}.dg .c{float:left;width:60%;position:relative}.dg .c input[type=text]{border:0;margin-top:4px;padding:3px;width:100%;float:right}.dg .has-slider input[type=text]{width:30%;margin-left:0}.dg .slider{float:left;width:66%;margin-left:-5px;margin-right:0;height:19px;margin-top:4px}.dg .slider-fg{height:100%}.dg .c input[type=checkbox]{margin-top:7px}.dg .c select{margin-top:5px}.dg .cr.function,.dg .cr.function .property-name,.dg .cr.function *,.dg .cr.boolean,.dg .cr.boolean *{cursor:pointer}.dg .cr.color{overflow:visible}.dg .selector{display:none;position:absolute;margin-left:-9px;margin-top:23px;z-index:10}.dg .c:hover .selector,.dg .selector.drag{display:block}.dg li.save-row{padding:0}.dg li.save-row .button{display:inline-block;padding:0px 6px}.dg.dialogue{background-color:#222;width:460px;padding:15px;font-size:13px;line-height:15px}#dg-new-constructor{padding:10px;color:#222;font-family:Monaco, monospace;font-size:10px;border:0;resize:none;box-shadow:inset 1px 1px 1px #888;word-wrap:break-word;margin:12px 0;display:block;width:440px;overflow-y:scroll;height:100px;position:relative}#dg-local-explain{display:none;font-size:11px;line-height:17px;border-radius:3px;background-color:#333;padding:8px;margin-top:10px}#dg-local-explain code{font-size:10px}#dat-gui-save-locally{display:none}.dg{color:#eee;font:11px 'Lucida Grande', sans-serif;text-shadow:0 -1px 0 #111}.dg.main::-webkit-scrollbar{width:5px;background:#1a1a1a}.dg.main::-webkit-scrollbar-corner{height:0;display:none}.dg.main::-webkit-scrollbar-thumb{border-radius:5px;background:#676767}.dg li:not(.folder){background:#1a1a1a;border-bottom:1px solid #2c2c2c}.dg li.save-row{line-height:25px;background:#dad5cb;border:0}.dg li.save-row select{margin-left:5px;width:108px}.dg li.save-row .button{margin-left:5px;margin-top:1px;border-radius:2px;font-size:9px;line-height:7px;padding:4px 4px 5px 4px;background:#c5bdad;color:#fff;text-shadow:0 1px 0 #b0a58f;box-shadow:0 -1px 0 #b0a58f;cursor:pointer}.dg li.save-row .button.gears{background:#c5bdad url() 2px 1px no-repeat;height:7px;width:8px}.dg li.save-row .button:hover{background-color:#bab19e;box-shadow:0 -1px 0 #b0a58f}.dg li.folder{border-bottom:0}.dg li.title{padding-left:16px;background:#000 url() 6px 10px no-repeat;cursor:pointer;border-bottom:1px solid rgba(255,255,255,0.2)}.dg .closed li.title{background-image:url()}.dg .cr.boolean{border-left:3px solid #806787}.dg .cr.color{border-left:3px solid}.dg .cr.function{border-left:3px solid #e61d5f}.dg .cr.number{border-left:3px solid #2FA1D6}.dg .cr.number input[type=text]{color:#2FA1D6}.dg .cr.string{border-left:3px solid #1ed36f}.dg .cr.string input[type=text]{color:#1ed36f}.dg .cr.function:hover,.dg .cr.boolean:hover{background:#111}.dg .c input[type=text]{background:#303030;outline:none}.dg .c input[type=text]:hover{background:#3c3c3c}.dg .c input[type=text]:focus{background:#494949;color:#fff}.dg .c .slider{background:#303030;cursor:ew-resize}.dg .c .slider-fg{background:#2FA1D6;max-width:100%}.dg .c .slider:hover{background:#3c3c3c}.dg .c .slider:hover .slider-fg{background:#44abda}\n"));var DC="Default",TC=function(){try{return!!window.localStorage}catch(e){return!1}}(),RC=void 0,UC=!0,FC=void 0,QC=!1,LC=[],OC=function e(t){var i=this,n=t||{};this.domElement=document.createElement("div"),this.__ul=document.createElement("ul"),this.domElement.appendChild(this.__ul),uC.addClass(this.domElement,"dg"),this.__folders={},this.__controllers=[],this.__rememberedObjects=[],this.__rememberedObjectIndecesToControllers=[],this.__listening=[],n=Wv.defaults(n,{closeOnTop:!1,autoPlace:!0,width:e.DEFAULT_WIDTH}),n=Wv.defaults(n,{resizable:n.autoPlace,hideable:n.autoPlace}),Wv.isUndefined(n.load)?n.load={preset:DC}:n.preset&&(n.load.preset=n.preset),Wv.isUndefined(n.parent)&&n.hideable&&LC.push(this),n.resizable=Wv.isUndefined(n.parent)&&n.resizable,n.autoPlace&&Wv.isUndefined(n.scrollable)&&(n.scrollable=!0);var r=TC&&"true"===localStorage.getItem(YC(this,"isLocal")),o=void 0,a=void 0;if(Object.defineProperties(this,{parent:{get:function(){return n.parent}},scrollable:{get:function(){return n.scrollable}},autoPlace:{get:function(){return n.autoPlace}},closeOnTop:{get:function(){return n.closeOnTop}},preset:{get:function(){return i.parent?i.getRoot().preset:n.load.preset},set:function(e){i.parent?i.getRoot().preset=e:n.load.preset=e,function(e){for(var t=0;e.__preset_select.length>t;t++)e.__preset_select[t].value===e.preset&&(e.__preset_select.selectedIndex=t)}(this),i.revert()}},width:{get:function(){return n.width},set:function(e){n.width=e,zC(i,e)}},name:{get:function(){return n.name},set:function(e){n.name=e,a&&(a.innerHTML=n.name)}},closed:{get:function(){return n.closed},set:function(t){n.closed=t,n.closed?uC.addClass(i.__ul,e.CLASS_CLOSED):uC.removeClass(i.__ul,e.CLASS_CLOSED),this.onResize(),i.__closeButton&&(i.__closeButton.innerHTML=t?e.TEXT_OPEN:e.TEXT_CLOSED)}},load:{get:function(){return n.load}},useLocalStorage:{get:function(){return r},set:function(e){TC&&(r=e,e?uC.bind(window,"unload",o):uC.unbind(window,"unload",o),localStorage.setItem(YC(i,"isLocal"),e))}}}),Wv.isUndefined(n.parent)){if(this.closed=n.closed||!1,uC.addClass(this.domElement,e.CLASS_MAIN),uC.makeSelectable(this.domElement,!1),TC&&r){i.useLocalStorage=!0;var s=localStorage.getItem(YC(this,"gui"));s&&(n.load=JSON.parse(s))}this.__closeButton=document.createElement("div"),this.__closeButton.innerHTML=e.TEXT_CLOSED,uC.addClass(this.__closeButton,e.CLASS_CLOSE_BUTTON),n.closeOnTop?(uC.addClass(this.__closeButton,e.CLASS_CLOSE_TOP),this.domElement.insertBefore(this.__closeButton,this.domElement.childNodes[0])):(uC.addClass(this.__closeButton,e.CLASS_CLOSE_BOTTOM),this.domElement.appendChild(this.__closeButton)),uC.bind(this.__closeButton,"click",(function(){i.closed=!i.closed}))}else{void 0===n.closed&&(n.closed=!0);var l=document.createTextNode(n.name);uC.addClass(l,"controller-name"),a=NC(i,l);uC.addClass(this.__ul,e.CLASS_CLOSED),uC.addClass(a,"title"),uC.bind(a,"click",(function(e){return e.preventDefault(),i.closed=!i.closed,!1})),n.closed||(this.closed=!1)}n.autoPlace&&(Wv.isUndefined(n.parent)&&(UC&&(FC=document.createElement("div"),uC.addClass(FC,"dg"),uC.addClass(FC,e.CLASS_AUTO_PLACE_CONTAINER),document.body.appendChild(FC),UC=!1),FC.appendChild(this.domElement),uC.addClass(this.domElement,e.CLASS_AUTO_PLACE)),this.parent||zC(i,n.width)),this.__resizeHandler=function(){i.onResizeDebounced()},uC.bind(window,"resize",this.__resizeHandler),uC.bind(this.__ul,"webkitTransitionEnd",this.__resizeHandler),uC.bind(this.__ul,"transitionend",this.__resizeHandler),uC.bind(this.__ul,"oTransitionEnd",this.__resizeHandler),this.onResize(),n.resizable&&JC(this),this.saveToLocalStorageIfPossible=o=function(){TC&&"true"===localStorage.getItem(YC(i,"isLocal"))&&localStorage.setItem(YC(i,"gui"),JSON.stringify(i.getSaveObject()))},n.parent||function(){var e=i.getRoot();e.width+=1,Wv.defer((function(){e.width-=1}))}()};function NC(e,t,i){var n=document.createElement("li");return t&&n.appendChild(t),i?e.__ul.insertBefore(n,i):e.__ul.appendChild(n),e.onResize(),n}function PC(e){uC.unbind(window,"resize",e.__resizeHandler),e.saveToLocalStorageIfPossible&&uC.unbind(window,"unload",e.saveToLocalStorageIfPossible)}function GC(e,t){var i=e.__preset_select[e.__preset_select.selectedIndex];i.innerHTML=t?i.value+"*":i.value}function KC(e,t){var i=e.getRoot(),n=i.__rememberedObjects.indexOf(t.object);if(-1!==n){var r=i.__rememberedObjectIndecesToControllers[n];if(void 0===r&&(i.__rememberedObjectIndecesToControllers[n]=r={}),r[t.property]=t,i.load&&i.load.remembered){var o=i.load.remembered,a=void 0;if(o[e.preset])a=o[e.preset];else{if(!o.Default)return;a=o.Default}if(a[n]&&void 0!==a[n][t.property]){var s=a[n][t.property];t.initialValue=s,t.setValue(s)}}}}function VC(e,t,i,n){if(void 0===t[i])throw new Error('Object "'+t+'" has no property "'+i+'"');var r=void 0;if(n.color)r=new xC(t,i);else{var o=[t,i].concat(n.factoryArgs);r=SC.apply(e,o)}n.before instanceof lC&&(n.before=n.before.__li),KC(e,r),uC.addClass(r.domElement,"c");var a=document.createElement("span");uC.addClass(a,"property-name"),a.innerHTML=r.property;var s=document.createElement("div");s.appendChild(a),s.appendChild(r.domElement);var l=NC(e,s,n.before);return uC.addClass(l,OC.CLASS_CONTROLLER_ROW),uC.addClass(l,r instanceof xC?"color":$v(r.getValue())),function(e,t,i){if(i.__li=t,i.__gui=e,Wv.extend(i,{options:function(t){if(arguments.length>1){var n=i.__li.nextElementSibling;return i.remove(),VC(e,i.object,i.property,{before:n,factoryArgs:[Wv.toArray(arguments)]})}if(Wv.isArray(t)||Wv.isObject(t)){var r=i.__li.nextElementSibling;return i.remove(),VC(e,i.object,i.property,{before:r,factoryArgs:[t]})}},name:function(e){return i.__li.firstElementChild.firstElementChild.innerHTML=e,i},listen:function(){return i.__gui.listen(i),i},remove:function(){return i.__gui.remove(i),i}}),i instanceof CC){var n=new yC(i.object,i.property,{min:i.__min,max:i.__max,step:i.__step});Wv.each(["updateDisplay","onChange","onFinishChange","step","min","max"],(function(e){var t=i[e],r=n[e];i[e]=n[e]=function(){var e=Array.prototype.slice.call(arguments);return r.apply(n,e),t.apply(i,e)}})),uC.addClass(t,"has-slider"),i.domElement.insertBefore(n.domElement,i.domElement.firstElementChild)}else if(i instanceof yC){var r=function(t){if(Wv.isNumber(i.__min)&&Wv.isNumber(i.__max)){var n=i.__li.firstElementChild.firstElementChild.innerHTML,r=i.__gui.__listening.indexOf(i)>-1;i.remove();var o=VC(e,i.object,i.property,{before:i.__li.nextElementSibling,factoryArgs:[i.__min,i.__max,i.__step]});return o.name(n),r&&o.listen(),o}return t};i.min=Wv.compose(r,i.min),i.max=Wv.compose(r,i.max)}else i instanceof pC?(uC.bind(t,"click",(function(){uC.fakeEvent(i.__checkbox,"click")})),uC.bind(i.__checkbox,"click",(function(e){e.stopPropagation()}))):i instanceof IC?(uC.bind(t,"click",(function(){uC.fakeEvent(i.__button,"click")})),uC.bind(t,"mouseover",(function(){uC.addClass(i.__button,"hover")})),uC.bind(t,"mouseout",(function(){uC.removeClass(i.__button,"hover")}))):i instanceof xC&&(uC.addClass(t,"color"),i.updateDisplay=Wv.compose((function(e){return t.style.borderLeftColor=i.__color.toString(),e}),i.updateDisplay),i.updateDisplay());i.setValue=Wv.compose((function(t){return e.getRoot().__preset_select&&i.isModified()&&GC(e.getRoot(),!0),t}),i.setValue)}(e,l,r),e.__controllers.push(r),r}function YC(e,t){return document.location.href+"."+t}function HC(e,t,i){var n=document.createElement("option");n.innerHTML=t,n.value=t,e.__preset_select.appendChild(n),i&&(e.__preset_select.selectedIndex=e.__preset_select.length-1)}function jC(e,t){t.style.display=e.useLocalStorage?"block":"none"}function WC(e){var t=e.__save_row=document.createElement("li");uC.addClass(e.domElement,"has-save"),e.__ul.insertBefore(t,e.__ul.firstChild),uC.addClass(t,"save-row");var i=document.createElement("span");i.innerHTML="&nbsp;",uC.addClass(i,"button gears");var n=document.createElement("span");n.innerHTML="Save",uC.addClass(n,"button"),uC.addClass(n,"save");var r=document.createElement("span");r.innerHTML="New",uC.addClass(r,"button"),uC.addClass(r,"save-as");var o=document.createElement("span");o.innerHTML="Revert",uC.addClass(o,"button"),uC.addClass(o,"revert");var a=e.__preset_select=document.createElement("select");if(e.load&&e.load.remembered?Wv.each(e.load.remembered,(function(t,i){HC(e,i,i===e.preset)})):HC(e,DC,!1),uC.bind(a,"change",(function(){for(var t=0;e.__preset_select.length>t;t++)e.__preset_select[t].innerHTML=e.__preset_select[t].value;e.preset=this.value})),t.appendChild(a),t.appendChild(i),t.appendChild(n),t.appendChild(r),t.appendChild(o),TC){var s=document.getElementById("dg-local-explain"),l=document.getElementById("dg-local-storage");document.getElementById("dg-save-locally").style.display="block","true"===localStorage.getItem(YC(0,"isLocal"))&&l.setAttribute("checked","checked"),jC(e,s),uC.bind(l,"change",(function(){e.useLocalStorage=!e.useLocalStorage,jC(e,s)}))}var c=document.getElementById("dg-new-constructor");uC.bind(c,"keydown",(function(e){!e.metaKey||67!==e.which&&67!==e.keyCode||RC.hide()})),uC.bind(i,"click",(function(){c.innerHTML=JSON.stringify(e.getSaveObject(),void 0,2),RC.show(),c.focus(),c.select()})),uC.bind(n,"click",(function(){e.save()})),uC.bind(r,"click",(function(){var t=prompt("Enter a new preset name.");t&&e.saveAs(t)})),uC.bind(o,"click",(function(){e.revert()}))}function JC(e){var t=void 0;function i(i){return i.preventDefault(),e.width+=t-i.clientX,e.onResize(),t=i.clientX,!1}function n(){uC.removeClass(e.__closeButton,OC.CLASS_DRAG),uC.unbind(window,"mousemove",i),uC.unbind(window,"mouseup",n)}function r(r){return r.preventDefault(),t=r.clientX,uC.addClass(e.__closeButton,OC.CLASS_DRAG),uC.bind(window,"mousemove",i),uC.bind(window,"mouseup",n),!1}e.__resize_handle=document.createElement("div"),Wv.extend(e.__resize_handle.style,{width:"6px",marginLeft:"-3px",height:"200px",cursor:"ew-resize",position:"absolute"}),uC.bind(e.__resize_handle,"mousedown",r),uC.bind(e.__closeButton,"mousedown",r),e.domElement.insertBefore(e.__resize_handle,e.domElement.firstElementChild)}function zC(e,t){e.domElement.style.width=t+"px",e.__save_row&&e.autoPlace&&(e.__save_row.style.width=t+"px"),e.__closeButton&&(e.__closeButton.style.width=t+"px")}function qC(e,t){var i={};return Wv.each(e.__rememberedObjects,(function(n,r){var o={};Wv.each(e.__rememberedObjectIndecesToControllers[r],(function(e,i){o[i]=t?e.initialValue:e.getValue()})),i[r]=o})),i}function ZC(e){0!==e.length&&bC.call(window,(function(){ZC(e)})),Wv.each(e,(function(e){e.updateDisplay()}))}OC.toggleHide=function(){QC=!QC,Wv.each(LC,(function(e){e.domElement.style.display=QC?"none":""}))},OC.CLASS_AUTO_PLACE="a",OC.CLASS_AUTO_PLACE_CONTAINER="ac",OC.CLASS_MAIN="main",OC.CLASS_CONTROLLER_ROW="cr",OC.CLASS_TOO_TALL="taller-than-window",OC.CLASS_CLOSED="closed",OC.CLASS_CLOSE_BUTTON="close-button",OC.CLASS_CLOSE_TOP="close-top",OC.CLASS_CLOSE_BOTTOM="close-bottom",OC.CLASS_DRAG="drag",OC.DEFAULT_WIDTH=245,OC.TEXT_CLOSED="关闭控制器",OC.TEXT_OPEN="打开控制器",OC._keydownHandler=function(e){"text"===document.activeElement.type||72!==e.which&&72!==e.keyCode||OC.toggleHide()},uC.bind(window,"keydown",OC._keydownHandler,!1),Wv.extend(OC.prototype,{add:function(e,t){return VC(this,e,t,{factoryArgs:Array.prototype.slice.call(arguments,2)})},addColor:function(e,t){return VC(this,e,t,{color:!0})},remove:function(e){this.__ul.removeChild(e.__li),this.__controllers.splice(this.__controllers.indexOf(e),1);var t=this;Wv.defer((function(){t.onResize()}))},destroy:function(){if(this.parent)throw new Error("Only the root GUI should be removed with .destroy(). For subfolders, use gui.removeFolder(folder) instead.");this.autoPlace&&FC.removeChild(this.domElement);var e=this;Wv.each(this.__folders,(function(t){e.removeFolder(t)})),uC.unbind(window,"keydown",OC._keydownHandler,!1),PC(this)},addFolder:function(e){if(void 0!==this.__folders[e])throw new Error('You already have a folder in this GUI by the name "'+e+'"');var t={name:e,parent:this};t.autoPlace=this.autoPlace,this.load&&this.load.folders&&this.load.folders[e]&&(t.closed=this.load.folders[e].closed,t.load=this.load.folders[e]);var i=new OC(t);this.__folders[e]=i;var n=NC(this,i.domElement);return uC.addClass(n,"folder"),i},removeFolder:function(e){this.__ul.removeChild(e.domElement.parentElement),delete this.__folders[e.name],this.load&&this.load.folders&&this.load.folders[e.name]&&delete this.load.folders[e.name],PC(e);var t=this;Wv.each(e.__folders,(function(t){e.removeFolder(t)})),Wv.defer((function(){t.onResize()}))},open:function(){this.closed=!1},close:function(){this.closed=!0},hide:function(){this.domElement.style.display="none"},show:function(){this.domElement.style.display=""},onResize:function(){var e=this.getRoot();if(e.scrollable){var t=uC.getOffset(e.__ul).top,i=0;Wv.each(e.__ul.childNodes,(function(t){e.autoPlace&&t===e.__save_row||(i+=uC.getHeight(t))})),window.innerHeight-t-20<i?(uC.addClass(e.domElement,OC.CLASS_TOO_TALL),e.__ul.style.height=window.innerHeight-t-20+"px"):(uC.removeClass(e.domElement,OC.CLASS_TOO_TALL),e.__ul.style.height="auto")}e.__resize_handle&&Wv.defer((function(){e.__resize_handle.style.height=e.__ul.offsetHeight+"px"})),e.__closeButton&&(e.__closeButton.style.width=e.width+"px")},onResizeDebounced:Wv.debounce((function(){this.onResize()}),50),remember:function(){if(Wv.isUndefined(RC)&&((RC=new kC).domElement.innerHTML=BC),this.parent)throw new Error("You can only call remember on a top level GUI.");var e=this;Wv.each(Array.prototype.slice.call(arguments),(function(t){0===e.__rememberedObjects.length&&WC(e),-1===e.__rememberedObjects.indexOf(t)&&e.__rememberedObjects.push(t)})),this.autoPlace&&zC(this,this.width)},getRoot:function(){for(var e=this;e.parent;)e=e.parent;return e},getSaveObject:function(){var e=this.load;return e.closed=this.closed,this.__rememberedObjects.length>0&&(e.preset=this.preset,e.remembered||(e.remembered={}),e.remembered[this.preset]=qC(this)),e.folders={},Wv.each(this.__folders,(function(t,i){e.folders[i]=t.getSaveObject()})),e},save:function(){this.load.remembered||(this.load.remembered={}),this.load.remembered[this.preset]=qC(this),GC(this,!1),this.saveToLocalStorageIfPossible()},saveAs:function(e){this.load.remembered||(this.load.remembered={},this.load.remembered.Default=qC(this,!0)),this.load.remembered[e]=qC(this),this.preset=e,HC(this,e,!0),this.saveToLocalStorageIfPossible()},revert:function(e){Wv.each(this.__controllers,(function(t){this.getRoot().load.remembered?KC(e||this.getRoot(),t):t.setValue(t.initialValue),t.__onFinishChange&&t.__onFinishChange.call(t,t.getValue())}),this),Wv.each(this.__folders,(function(e){e.revert(e)})),e||GC(this.getRoot(),!1)},listen:function(e){var t=0===this.__listening.length;this.__listening.push(e),t&&ZC(this.__listening)},updateDisplay:function(){Wv.each(this.__controllers,(function(e){e.updateDisplay()})),Wv.each(this.__folders,(function(e){e.updateDisplay()}))}});var XC=OC,_C=function(e){var t=this;this.indexedDB=window.indexedDB||window.mozIndexedDB||window.webkitIndexedDB||window.msIndexedDB;var i=wp.extend({},{dbName:"bos3d",store:"default",version:1,indexes:["id"],keyPath:"id"},e);this.IDBOpenDBRequest=null,this.dbName=i.dbName;var n=this.version=i.version;this.storeName=i.store;var r=i.keyPath,o=this.indexedDB.open(this.dbName,n);o.onupgradeneeded=function(e){Bu.log("DB version changed to "+n);var o=e.target.result,a=null;if(!1===o.objectStoreNames.contains(t.storeName)){a=o.createObjectStore(t.storeName,{keyPath:r});for(var s=0;i.indexes.length>s;s+=1){var l=i.indexes[s];a.createIndex(l,l,{unique:!1})}}},o.onsuccess=function(e){t.IDBOpenDBRequest=e.target.result,Bu.log("成功建立并打开数据库:"+t.IDBOpenDBRequest.name+" version "+n),t.dispatchEvent({type:Fd.ON_DATABASE_OPEN})},o.onerror=function(e){Bu.error("IndexedDB",e),t.dispatchEvent({type:Fd.ON_DATABASE_EEEOR})},o.onblocked=function(e){Bu.warn("Please close all other tabs with this site open!",e)}};Object.assign(_C.prototype,hg.prototype),Object.assign(_C.prototype,{constructor:_C,get:function(e,t,i){if(this.IDBOpenDBRequest){var n=this.IDBOpenDBRequest.transaction([this.storeName]).objectStore(this.storeName).get(e);n.onsuccess=function(e){"function"==typeof t&&t(e.target.result?e.target.result.data:null)},n.onerror=function(e){Bu.error("getDataByKey error"),"function"==typeof i&&i(e)}}},getBatch:function(e,t,i){if(this.IDBOpenDBRequest){for(var n=this.IDBOpenDBRequest.transaction([this.storeName]).objectStore(this.storeName),r={},o=[],a=0;e.length>a;a+=1)o.push(new Promise((function(t,i){var r=e[a],o=n.index("id").get(r);o.onsuccess=function(e){t(e.target.result)},o.onerror=function(e){Bu.error(r,"failed",e),i(e)}})));Promise.all(o).then((function(e){for(var i=0;e.length>i;i+=1)e[i]&&(r[e[i].id]=e[i].data);t(r)})).catch((function(e){Bu.debug(e),e instanceof TypeError?Bu.error(e):t(r)}))}},setBatch:function(e,t,i){if(this.IDBOpenDBRequest)for(var n=this.IDBOpenDBRequest.transaction([this.storeName],"readwrite").objectStore(this.storeName),r=0;e.length>r;r+=1){n.put({id:e[r].key,data:e[r]}).onsuccess=function(e){}}},set:function(e,t,i,n){var r=performance.now();if(this.IDBOpenDBRequest){var o=this.IDBOpenDBRequest.transaction([this.storeName],"readwrite").objectStore(this.storeName).add([{id:e,data:t}]);o.onsuccess=function(e){"function"==typeof i&&i(e.target.result),Bu.debug("Saved state to IndexedDB. "+(performance.now()-r).toFixed(2)+"ms")},o.onerror=function(e){"function"==typeof n&&n(e)}}},put:function(e,t,i,n,r){if(this.IDBOpenDBRequest){var o=performance.now(),a=this.IDBOpenDBRequest.transaction([i],"readwrite").objectStore(i).put({id:e,data:t});a.onsuccess=function(e){"function"==typeof n&&n(e.target.result),Bu.debug("Saved state to IndexedDB. "+(performance.now()-o).toFixed(2)+"ms")},a.onerror=function(e){Bu.error("离线存储出错:",e.target.error.name,":",e.target.error.message),"function"==typeof r&&r(e)}}},delete:function(e,t,i){if(this.IDBOpenDBRequest){var n=this.IDBOpenDBRequest.transaction(this.storeName,"readwrite").objectStore(this.storeName).delete(e);n.onsuccess=function(e){Bu.debug("delete data form IndexedDB."),"function"==typeof t&&t(e.target.result)},n.onerror=function(e){Bu.error("IndexedDB",e),"function"==typeof i&&i(e)}}},clear:function(e,t){if(this.IDBOpenDBRequest){var i=this.IDBOpenDBRequest.transaction(this.storeName,"readwrite").objectStore(this.storeName).clear();i.onsuccess=function(t){Bu.debug("Cleared IndexedDB."),"function"==typeof e&&e(t.target.result)},i.onerror=function(e){Bu.error("IndexedDB",e),"function"==typeof t&&t(e)}}},deleteDatabase:function(e){indexedDB.deleteDatabase(this.dbName),Bu.debug(this.dbName+"数据库已删除"),"function"==typeof e&&e()},close:function(e){this.IDBOpenDBRequest&&(this.IDBOpenDBRequest.close(),Bu.debug("数据库已关闭"),"function"==typeof e&&e())},getIndex:function(e,t,i,n){var r=e.transaction(t,"readwrite").objectStore(t).index("id");r.openCursor().onsuccess=function(){var e=this.result;e&&(Bu.debug(e.value),e.continue())};var o=IDBKeyRange.only(2),a=r.openCursor(o);a.onsuccess=function(){var e=a.result;e&&Bu.info(e.value)}},destroy:function(){this.close(),this.IDBOpenDBRequest=null,this.dbName=null,this.storeName=null}});var $C=function(e){this.serverUrl=e.serverUrl,this.modelKey=e.modelKey,this.dbName=e.dbName,this.offLine=e.offLine,this.shareParameter=""!==e.share?"&share="+e.share:""};$C.prototype.projectUrl=function(e){return this.offLine?this.serverUrl+"/"+this.modelKey+"/resource/scene/scene.json":this.serverUrl+"/api/"+this.dbName+"/models?modelKey="+(e||this.modelKey)+this.shareParameter},$C.prototype.sceneUrl=function(e){return this.serverUrl+this.modelKey+"/scene/scene_"+(e=e||0)+xd.ZipResourcePostfix},$C.prototype.sceneIdUrl=function(){return this.serverUrl+this.modelKey+"/scene/scene_id"+xd.ZipResourcePostfix},$C.prototype.userIdUrl=function(){return this.serverUrl+this.modelKey+"/scene/user_id"+xd.ZipResourcePostfix},$C.prototype.octreeUrl=function(e){return this.serverUrl+this.modelKey+"/scene/octree_"+e+xd.ZipResourcePostfix},$C.prototype.symbolUrl=function(){return this.serverUrl+this.modelKey+"/symbol/symbol"+xd.ZipResourcePostfix},$C.prototype.mpkUrl=function(e){return this.offLine?this.serverUrl+"/"+this.modelKey+"/resource/data/"+e:gy(this.apiVersion,"1.6.0")?this.serverUrl+"/data?fileKey="+e:this.serverUrl+"/api/"+this.dbName+"/files?fileKey="+e},$C.prototype.texUrl=function(e){return this.offLine?this.serverUrl+"/"+this.modelKey+"/resource/data/Texture/"+e:gy(this.apiVersion,"1.6.0")?this.serverUrl+"/data?fileKey="+e:this.serverUrl+"/api/"+this.dbName+"/files?fileKey="+e},$C.prototype.bonesUrl=function(e){return this.offLine?this.serverUrl+"/"+this.modelKey+"/resource/data/"+e:gy(this.apiVersion,"1.6.0")?this.serverUrl+"/data?fileKey="+e:this.serverUrl+"/api/"+this.dbName+"/files?fileKey="+e},$C.prototype.nodesUrl=function(e){return this.offLine?this.serverUrl+"/"+this.modelKey+"/resource/data/"+e:gy(this.apiVersion,"1.6.0")?this.serverUrl+"/data?fileKey="+e:this.serverUrl+"/api/"+this.dbName+"/files?fileKey="+e},$C.prototype.clipsUrl=function(e){return this.offLine?this.serverUrl+"/"+this.modelKey+"/resource/data/"+e:gy(this.apiVersion,"1.6.0")?this.serverUrl+"/data?fileKey="+e:this.serverUrl+"/api/"+this.dbName+"/files?fileKey="+e},$C.prototype.kdTreeUrl=function(e){return this.offLine?this.serverUrl+"/"+this.modelKey+"/resource/data/"+e:gy(this.apiVersion,"1.6.0")?this.serverUrl+"/data?fileKey="+e:this.serverUrl+"/api/"+this.dbName+"/files?fileKey="+e},$C.prototype.lightUrl=function(e){return this.offLine?this.serverUrl+"/"+this.modelKey+"/resource/data/"+e:gy(this.apiVersion,"1.6.0")?this.serverUrl+"/data?fileKey="+e:this.serverUrl+"/api/"+this.dbName+"/files?fileKey="+e},$C.prototype.rootTilesUrl=function(e){return this.offLine?this.serverUrl+"/"+this.modelKey+"/tileset.json":this.serverUrl+"/api/"+this.dbName+"/geomodels/"+this.modelKey+"/data/tileset.json"},$C.prototype.tilesUrl=function(e){return this.offLine?this.serverUrl+"/"+this.modelKey+"/"+e:this.serverUrl+"/api/"+this.dbName+"/geomodels/"+this.modelKey+"/data/"+e},$C.prototype.b3dmUrl=function(e){return this.offLine?this.serverUrl+"/"+this.modelKey+"/"+e:this.serverUrl+"/api/"+this.dbName+"/geomodels/"+this.modelKey+"/data/"+e},$C.prototype.attributeUrl=function(){if(this.offLine)return this.serverUrl+"/"+this.modelKey+"/resource/attribute/attribute.json"},$C.prototype.meshIdUrl=function(){return this.serverUrl+this.modelKey+"/mpk/mesh_id"+xd.ZipResourcePostfix},$C.prototype.materialUrl=function(){return this.serverUrl+this.modelKey+"/material/material"+xd.ZipResourcePostfix},$C.prototype.materialIdUrl=function(){return this.serverUrl+this.modelKey+"/material/material_id"+xd.ZipResourcePostfix},$C.prototype.userDataUrl=function(){return this.serverUrl+this.modelKey+"/userdata/userdata"+xd.ZipResourcePostfix},$C.prototype.textureUrl=function(e){return this.offLine?this.serverUrl+"/"+this.modelKey+"/resource/data/"+e:gy(this.apiVersion,"1.6.0")?this.serverUrl+"/data?fileKey="+e:this.serverUrl+"/api/"+this.dbName+"/files?fileKey="+e+this.shareParameter},$C.prototype.axisNetUrl=function(e){return this.offLine?this.serverUrl+"/"+this.modelKey+"/resource/data/"+e:gy(this.apiVersion,"1.6.0")?this.serverUrl+"/data?fileKey="+e:this.serverUrl+"/api/"+this.dbName+"/files?fileKey="+e},$C.prototype.floorInfoUrl=function(e){return this.offLine?this.serverUrl+"/"+e+"/resource/floor/floorKey.json":this.serverUrl+"/api/"+this.dbName+"/components/floorkeys?modelKey="+e+this.shareParameter},$C.prototype.floorMapUrl=function(e){return this.offLine?this.serverUrl+"/"+this.modelKey+"/resource/floor/map.json":this.serverUrl+"/api/"+this.dbName+"/models/maps?modelKey="+this.modelKey+this.shareParameter};var eI,tI={};tI.getBatchedGeometryReaderWorker=(eI=window.URL.createObjectURL(new Blob(["var Utils={};\nvar Reader={}; function ab2str (buf) {\n return new TextDecoder().decode(new Uint8Array(buf));\n }\n \n function str2ab (str) {\n return new TextEncoder().encode(str).buffer;\n }\n \n Utils.ab2str = ab2str;\n Utils.str2ab = str2ab;Reader['batchedGeometryReader']=function(hzpE1){let geomMap=[];var YeTR2=new self['Uint32Array'](hzpE1,0,1)[0];var EU3=0;var gnhKnB4=null;var KYSfPtPo5=0;var TyGSj_hd6=0;var I7=[];var wYD8=4;for(let n=0;n<YeTR2;n+=1){let geomInfo={};I7['push'](geomInfo);let infors=new self['Uint32Array'](hzpE1,wYD8,7);geomInfo['geoId']=infors[0];geomInfo['offset']=infors[1];geomInfo['vertexLength']=infors[2];geomInfo['normalLength']=infors[5];geomInfo['indicesLength']=infors[3];geomInfo['uvLength']=infors[4];KYSfPtPo5=infors[6];geomInfo['componentCount']=KYSfPtPo5;geomInfo['nodeInfo']=[];wYD8+=7*4;for(let m=0;m<KYSfPtPo5;m+=1){let nodeCount=new self['Uint32Array'](hzpE1,wYD8,1)[0];wYD8+=4;for(let k=0;k<nodeCount;k+=1){let node=new self['Uint32Array'](hzpE1,wYD8,3);wYD8+=12;geomInfo['nodeInfo']['push'](node)}}geomInfo['materialKeyLength']=new self['Uint32Array'](hzpE1,wYD8,1)[0];wYD8+=4}for(var sCNoi$b$9=0;sCNoi$b$9<YeTR2;sCNoi$b$9+=1){let geoInfo=I7[sCNoi$b$9];let vertexLength=geoInfo['vertexLength'];let normalLength=geoInfo['normalLength'];let IndicesLength=geoInfo['indicesLength'];let uvLength=geoInfo['uvLength'];EU3=wYD8+geoInfo['offset'];TyGSj_hd6=vertexLength*4;let verticesData=new self['Float32Array'](hzpE1['slice'](EU3,EU3+TyGSj_hd6));EU3+=TyGSj_hd6;TyGSj_hd6=IndicesLength*4;let indicesData=new self['Uint32Array'](hzpE1['slice'](EU3,EU3+TyGSj_hd6));EU3+=TyGSj_hd6;TyGSj_hd6=uvLength*4;let uvData=new self['Float32Array'](hzpE1['slice'](EU3,EU3+TyGSj_hd6));EU3+=TyGSj_hd6;TyGSj_hd6=normalLength*4;let normalsData=new self['Float32Array'](hzpE1['slice'](EU3,EU3+TyGSj_hd6));EU3+=TyGSj_hd6;KYSfPtPo5=geoInfo['componentCount'];let componentInfo={};for(let m=0,mLen=geoInfo['nodeInfo']['length'];m<mLen;m+=1){let nodeInfo=geoInfo['nodeInfo'][m];TyGSj_hd6=nodeInfo[0]*2;let userId=Utils['ab2str'](new self['Int16Array'](hzpE1['slice'](EU3,EU3+TyGSj_hd6)));EU3+=TyGSj_hd6;TyGSj_hd6=nodeInfo[1]*2;let nodeId=Utils['ab2str'](new self['Int16Array'](hzpE1['slice'](EU3,EU3+TyGSj_hd6)));EU3+=TyGSj_hd6;let positionStart=new self['Uint32Array'](hzpE1['slice'](EU3,EU3+4))[0];EU3+=4;let positionCount=new self['Uint32Array'](hzpE1['slice'](EU3,EU3+4))[0];EU3+=4;let indexStart=new self['Uint32Array'](hzpE1['slice'](EU3,EU3+4))[0];EU3+=4;let indexCount=new self['Uint32Array'](hzpE1['slice'](EU3,EU3+4))[0];EU3+=4;let node={};node['userId']=userId;node['nodeId']=nodeId;node['positionStart']=positionStart;node['positionCount']=positionCount;node['indexStart']=indexStart;node['indexCount']=indexCount;if(!componentInfo[userId]){componentInfo[userId]=[]}componentInfo[userId]['push'](node)}TyGSj_hd6=geoInfo['materialKeyLength']*2;let materialKey=Utils['ab2str'](new self['Int16Array'](hzpE1['slice'](EU3,EU3+TyGSj_hd6)));let geom={};geom['position']=self['Array']['prototype']['slice']['call'](verticesData);geom['normal']=self['Array']['prototype']['slice']['call'](normalsData);geom['index']=self['Array']['prototype']['slice']['call'](indicesData);geom['uv']=self['Array']['prototype']['slice']['call'](uvData);geom['materialIndex']=gnhKnB4;geom['geoId']=geoInfo['geoId'];geom['materialKey']=materialKey;geom['componentInfo']=componentInfo;geomMap['push'](geom)}return{geos:Utils['str2ab'](JSON['stringify'](geomMap))}};self.addEventListener(\"message\", function (event) {\n \n var data = event.data;\n \n //console.time('read BG_worker');\n var result = Reader.batchedGeometryReader(data.bufferData);\n //console.timeEnd('read BG_worker');\n \n self.postMessage(result, [result.geos]);\n self.close();\n \n}, false);"])),function(){return new Worker(eI)}),tI.getInstancedGeometryReaderWorker=function(){var e=window.URL.createObjectURL(new Blob(["var Utils={};\nvar Reader={}; function ab2str (buf) {\n return new TextDecoder().decode(new Uint8Array(buf));\n }\n \n function str2ab (str) {\n return new TextEncoder().encode(str).buffer;\n }\n \n Utils.ab2str = ab2str;\n Utils.str2ab = str2ab;Reader['instancedGeometryReader']=function(s1){let geomMap=[];var UQ2=new self['Uint32Array'](s1,0,1)[0];var ELsmdM3=null;var CngC4=0;var Ese5=null;var kbelbnlV6=0;var zY7=0;var kNtCk_n8=[];var yrM9=4;for(let n=0;n<UQ2;n+=1){let geomInfo={};kNtCk_n8['push'](geomInfo);ELsmdM3=new self['Uint32Array'](s1,yrM9,7);geomInfo['geoId']=ELsmdM3[0];geomInfo['offset']=ELsmdM3[1];geomInfo['vertexLength']=ELsmdM3[2];geomInfo['normalLength']=ELsmdM3[5];geomInfo['indicesLength']=ELsmdM3[3];geomInfo['uvLength']=ELsmdM3[4];kbelbnlV6=ELsmdM3[6];geomInfo['componentCount']=kbelbnlV6;geomInfo['nodeInfo']={};yrM9+=7*4;let componentKeyLength=[];let matrixArrayLength=[];geomInfo['componentKeyLength']=componentKeyLength;geomInfo['matrixArrayLength']=matrixArrayLength;for(let m=0;m<kbelbnlV6;m+=1){componentKeyLength['push'](new self['Uint32Array'](s1,yrM9,1)[0]);yrM9+=4;let nodeCount=new self['Uint32Array'](s1,yrM9,1)[0];yrM9+=4;geomInfo['nodeInfo'][m]=[];for(let k=0;k<nodeCount;k+=1){let nodeIdLength=new self['Uint32Array'](s1,yrM9,1)[0];yrM9+=4;geomInfo['nodeInfo'][m]['push'](nodeIdLength)}}geomInfo['matrixArrayLength']=new self['Uint32Array'](s1,yrM9,1)[0];yrM9+=4;geomInfo['materialKeyLength']=new self['Uint32Array'](s1,yrM9,1)[0];yrM9+=4}for(var m10=0;m10<UQ2;m10+=1){let geoInfo=kNtCk_n8[m10];let vertexLength=geoInfo['vertexLength'];let normalLength=geoInfo['normalLength'];let IndicesLength=geoInfo['indicesLength'];let uvLength=geoInfo['uvLength'];CngC4=yrM9+geoInfo['offset'];zY7=vertexLength*4;let verticesData=new self['Float32Array'](s1['slice'](CngC4,CngC4+zY7));CngC4+=zY7;zY7=IndicesLength*4;let indicesData=new self['Uint32Array'](s1['slice'](CngC4,CngC4+zY7));CngC4+=zY7;zY7=uvLength*4;let uvData=new self['Float32Array'](s1['slice'](CngC4,CngC4+zY7));CngC4+=zY7;zY7=normalLength*4;let normalsData=new self['Float32Array'](s1['slice'](CngC4,CngC4+zY7));CngC4+=zY7;kbelbnlV6=geoInfo['componentCount'];let componentInfo={};let nodeIdInfo=[];let componentKeyInfo=[];let nodeIndex=0;for(let i=0,iLen=kbelbnlV6;i<iLen;i+=1){let componentKeyLength=geoInfo['componentKeyLength'][i];zY7=componentKeyLength;let componentKey=Utils['ab2str'](s1['slice'](CngC4,CngC4+zY7));CngC4+=zY7;componentKeyInfo['push'](componentKey);if(!componentInfo[componentKey]){componentInfo[componentKey]=[]}let nodeInfo=geoInfo['nodeInfo'][i];for(let j=0,jLen=nodeInfo['length'];j<jLen;j+=1){let nodeIdLength=nodeInfo[j];zY7=nodeIdLength;let nodeId=Utils['ab2str'](s1['slice'](CngC4,CngC4+zY7));CngC4+=zY7;componentInfo[componentKey]['push'](nodeIndex);nodeIdInfo['push'](nodeId);nodeIndex+=1}}zY7=geoInfo['matrixArrayLength']*8;let mcol0=new self['Float64Array'](s1['slice'](CngC4,CngC4+zY7));CngC4+=zY7;let mcol1=new self['Float64Array'](s1['slice'](CngC4,CngC4+zY7));CngC4+=zY7;let mcol2=new self['Float64Array'](s1['slice'](CngC4,CngC4+zY7));CngC4+=zY7;let mcol3=new self['Float64Array'](s1['slice'](CngC4,CngC4+zY7));CngC4+=zY7;zY7=geoInfo['materialKeyLength'];let materialKey=Utils['ab2str'](s1['slice'](CngC4,CngC4+zY7));CngC4+=zY7;zY7=nodeIdInfo['length']*4*4;let color=new self['Float32Array'](s1['slice'](CngC4,CngC4+zY7));CngC4+=zY7;let geom={};geom['position']=self['Array']['prototype']['slice']['call'](verticesData);geom['normal']=self['Array']['prototype']['slice']['call'](normalsData);geom['index']=self['Array']['prototype']['slice']['call'](indicesData);geom['uv']=self['Array']['prototype']['slice']['call'](uvData);geom['materialIndex']=Ese5;geom['geoId']=geoInfo['geoId'];geom['materialKey']=materialKey;geom['componentInfo']=componentInfo;geom['mcol0']=self['Array']['prototype']['slice']['call'](mcol0);geom['mcol1']=self['Array']['prototype']['slice']['call'](mcol1);geom['mcol2']=self['Array']['prototype']['slice']['call'](mcol2);geom['mcol3']=self['Array']['prototype']['slice']['call'](mcol3);geom['color']=self['Array']['prototype']['slice']['call'](color);geom['nodeIdInfo']=nodeIdInfo;geom['componentKeyInfo']=componentKeyInfo;geomMap['push'](geom)}return{geos:Utils['str2ab'](JSON['stringify'](geomMap))}};self.addEventListener(\"message\", function (event) {\n\n var data = event.data;\n\n //console.time('read BG_worker');\n var result = Reader.instancedGeometryReader(data.bufferData);\n //console.timeEnd('read BG_worker');\n\n self.postMessage(result, [result.geos]);\n self.close();\n\n}, false);"]));return function(){return new Worker(e)}}();var iI=function(e){zy.call(this,e),this.instancedComponent={}};Object.assign(iI.prototype,zy.prototype),iI.prototype.parseItemData=function(e){this._readMaterialBuffer(this.model);var t={},i=this.referencedMeshCache;for(var n in Bu.time("_readItemData"),i.components)i.components.hasOwnProperty(n)&&this._readItemData(t,n,n,void 0,0);Bu.timeEnd("_readItemData"),t=null,e&&e()},iI.prototype._readItemData=function(e,t,i){var n=this.referencedMeshCache.components[t];void 0!==n&&this._readMeshInfo(e,i,n,null)},iI.prototype._readMeshInfo=function(e,t,i,n){var r=this.referencedMeshCache,o=this.model.materialManager.materials,a=null;if(i.nodes||i.nodeIds){a=i.originalId;var s=(new yt).fromArray(i.matrix||[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1]);i.matrix=s;var l=[];l=i.nodes?i.nodes:i.nodeIds;for(var c=0;l.length>c;c+=1){var h=l[c];if("object"!==nu(h)&&(h=this.getReferencedMeshComponentNodeById(h)),h){var d,u=null,p="";if(-1!==h.geoId)if(u=this._getComponentNodeAttr(h,i,c)){if(i.buildInCategory&&(u.buildInCategory=i.buildInCategory),!o[p=h.material]){var g=Jy[i.type]?Jy[i.type].color:void 0;g||(Bu.log("Material not found for type: ",i.type),g=Jy.DEFAULT.color),g||(Bu.log("Default material not found for type: ",i.type),g=[1,1,1,1]);var f=new pi(g[0],g[1],g[2]),m=p||f.getHexString()+"_"+g[3],A=o[m];A||(Bu.warn("缺少材质 "+p),A=cA.createStandardMaterial({color:f}),1>g[3]&&(A.transparent=!0,A.opacity=g[3]),A.side=2,o[m]=A),u.material=p=m}if(o[p].aoMap){var y=this.getReferencedMeshBufferById(u.geometryId);y&&(y.uv2=y.uv)}d=u.nodeId;var v=this.userDataReader,C=v?v.getUserData(null):null;u.type=i.type,u.userId=t,u.name=i.name,u.userDataId=null,u.originalId=a,u.materialId=p,u.originMId=p,u.userData=C,u.categoryId=0,u.componentKey=t,u.familyName=i.familyName,u.familySymbol=i.familySymbol;var I=xd.Instance,x=r.reuseNodes.hasOwnProperty(d);u.instanceOrNot=!(!I||!x),u.isBatched=!0,u.state=Nd.Visible,u.material=null,this._classifyNodeInfo(u),u=null}else Bu.debug("非法node")}}}},iI.prototype._parseInstanced=function(){Bu.time("_parseInstanced"),this.instancedComponent={},this.instancedNode={};var e={},t=this.referencedMeshCache,i=t.componentNodes,n=this.model.materialManager.materials;for(var r in t.components)if(t.components.hasOwnProperty(r))for(var o=t.components[r],a=0,s=o.Nodes.length;s>a;a+=1){var l=o.Nodes[a],c=i[l],h=c.geometry,d=c.material;if(-1!==h){if(!d&&0!==d){var u=Jy[o.type]?Jy[o.type].color:void 0;u||(Bu.log("Material not found for type: ",o.type),u=Jy.DEFAULT.color),u||(Bu.log("Default material not found for type: ",o.type),u=[1,1,1,1]);var p=new pi(u[0],u[1],u[2]),g=p.getHexString()+"_"+u[3],f=n[g];f||(Bu.warn("缺少材质 "+g),f=cA.createStandardMaterial({color:p}),1>u[3]&&(f.transparent=!0,f.opacity=u[3]),f.side=2,n[g]=f),c.material=g,d=g}var m=d+"&"+h;void 0===e[m]&&(e[m]=[]),e[m].push({nodeId:l})}else Bu.debug("实体没有几何")}for(var A in e)if(e.hasOwnProperty(A))if(1<e[A].length)for(var y=0;e[A].length>y;y+=1)this.instancedComponent[e[A][y].nodeId]=!0;else delete e[A];Bu.timeEnd("_parseInstanced")};var nI=function(e){lu(i,e);var t=pu(i);function i(e){var n;return ru(this,i),(n=t.call(this,e)).maxGeoLoadTaskCount=0,n.geoLoadTaskCount=0,n.taskInstancedGeometrieManager=new Uy(du(n),"geometrie"),n.descriptor=new iI(e.model),n}return i}(Wy);nI.prototype._parseMaterial=function(e,t){if(e){var i=this.descriptor;if(i)for(var n in e)i.cacheReferencedMeshMaterialData(n,e[n])}else Bu.error("没有数据")},nI.prototype.loadBatchedGeometrie=function(e,t){var i=this,n=this.loader,r=this.url,o=this.model;n.setResponseType("arraybuffer"),n.setCacheViable(!this.offLine);var a=n.load(r.mpkUrl(e),(function(n){i._parseBatchedGeometrie(n,e,(function(){i._onGeoTaskFinished()})),Bu.debug("geo load from online"),t()}),void 0,(function(e){o.dispatchEventEx({type:Qd.LOAD_GEOMETRY_ERROR,modelKey:o.modelKey}),t(),i._onGeoTaskFinished()}));i.requests.loadGeometrie=a},nI.prototype.loadInstancedGeometrie=function(e,t){var i=this,n=this.loader,r=this.url,o=this.model;n.setResponseType("arraybuffer"),n.setCacheViable(!this.offLine);var a=n.load(r.mpkUrl(e),(function(n){i._parseInstancedGeometrie(n,e,(function(){Bu.debug("geo load from online"),i._onGeoTaskFinished()})),t()}),void 0,(function(e){o.dispatchEventEx({type:Qd.LOAD_GEOMETRY_ERROR,modelKey:o.modelKey}),t(),i._onGeoTaskFinished()}));i.requests.loadGeometrie=a},nI.prototype._parseGeometrie=function(e,t){if(e){var i=this.descriptor;if(i)for(var n in e)e.hasOwnProperty(n)&&(e[n].position=new Float32Array(e[n].positions),delete e[n].positions,e[n].index=new Uint32Array(e[n].indices),delete e[n].indices,e[n].normal=new Float32Array(e[n].normals),e[n].uv=new Float32Array(e[n].uv),delete e[n].normals,i.cacheReferencedMeshBufferData(n,e[n]))}else Bu.error("没有数据")},nI.prototype._parseBatchedGeometrie=function(e,t,i){var n=this,r=new ky.BatchedGeometryReader(e,this.dataVersion),o=this.descriptor;if(o)if(xd.UseReaderWorker){var a=tI.getBatchedGeometryReaderWorker();a.addEventListener("message",(function(e){var t=JSON.parse(wp.ab2str(e.data.geos));Bu.time("createBatchedMeshNodes");for(var r=function(){var e=t[s];if(void 0===e.position||void 0===e.index||void 0===e.normal)return Bu.error("Error Geometry!"),"continue";e.position=new Float32Array(e.position),e.uv=new Float32Array(e.uv),e.normal=new Float32Array(e.normal),e.index=new Uint32Array(e.index),o.cacheReferencedMeshBufferData(e.geoId,e),requestAnimationFrame((function(){n.handler.createBatchedMeshNodes(e)}))},s=0;t.length>s;s+=1)r();n.model.manager.viewerImpl.render(),Bu.timeEnd("createBatchedMeshNodes"),a.terminate(),i&&i()}),!1),a.postMessage({bufferData:e},e)}else{var s=r.geoCount;Bu.time("createBatchedMeshNodes");for(var l=0;s>l;l+=1){var c=r.geomMap[l];void 0!==c.position&&void 0!==c.index&&void 0!==c.normal?(o.cacheReferencedMeshBufferData(c.geoId,c),this.handler.createBatchedMeshNodes(c)):Bu.error("Error Geometry!")}this.model.manager.viewerImpl.render(),Bu.timeEnd("createBatchedMeshNodes"),r=null,i&&i()}},nI.prototype._parseInstancedGeometrie=function(e,t,i){var n=this,r=this.descriptor;if(r)if(xd.UseReaderWorker){var o=tI.getInstancedGeometryReaderWorker();o.addEventListener("message",(function(e){var t=JSON.parse(wp.ab2str(e.data.geos));Bu.time("createInstancedMeshNodes");for(var a=function(){var e=t[s];if(void 0===e.position||void 0===e.index||void 0===e.normal)return Bu.error("Error Geometry!"),"continue";e.position=new Float32Array(e.position),e.uv=new Float32Array(e.uv),e.normal=new Float32Array(e.normal),e.index=new Uint32Array(e.index),e.mcol0=new Float64Array(e.mcol0),e.mcol1=new Float64Array(e.mcol1),e.mcol2=new Float64Array(e.mcol2),e.mcol3=new Float64Array(e.mcol3),e.color=new Float32Array(e.color),r.cacheReferencedMeshBufferData(e.geoId,e),requestAnimationFrame((function(){n.handler.createInstancedMeshNodes(e)}))},s=0;t.length>s;s+=1)a();n.model.manager.viewerImpl.render(),Bu.timeEnd("createInstancedMeshNodes"),o.terminate(),i&&i()}),!1),o.postMessage({bufferData:e},e)}else{var a=new ky.InstancedGeometryReader(e,this.dataVersion),s=a.geoCount;Bu.time("createInstancedMeshNodes");for(var l=0;s>l;l+=1){var c=a.geomMap[l];void 0!==c.position&&void 0!==c.index&&void 0!==c.normal?(r.cacheReferencedMeshBufferData(c.geoId,c),this.handler.createInstancedMeshNodes(c)):Bu.error("Error Geometry!")}this.model.manager.viewerImpl.render(),a=null,Bu.timeEnd("createInstancedMeshNodes"),i&&i()}},nI.prototype.startLoadSceneAndGeos=function(e){Bu.time("几何数据加载时间");var t=e.scene,i=t.instancedGeometries.length||0,n=t.batchedGeometries,r=t.instancedGeometries;this.maxGeoLoadTaskCount+=t.batchedGeometries.length||0,this.maxGeoLoadTaskCount+=i,this._loadBatchedGeo(n),this._loadInstancedGeo(r)},nI.prototype._loadBatchedGeo=function(e){var t=this;if(xd.getDataFromIndexedDB&&!this.offLine){for(var i=this.url,n=[],r=0;e.length>r;r+=1)n.push(i.mpkUrl(e[r]));var o=this.model.getStorage();if(o)for(var a=function(){var i=n.splice(0,30);o.getBatch(i,(function(e){for(var n=function(n){if(e[i[n]])if(!0===e[i[n]].split){var r=e[i[n]].list,l=new Uint8Array(e[i[n]].length);o.getBatch(r,(function(e){for(var o=!0,a=0;r.length>a;a+=1)e[r[a]]?l.set(new Uint8Array(e[r[a]]),4e7*a):(o=!1,Bu.error("获取分割几何失败"));if(o){var s=i[n].indexOf("fileKey=");t._parseBatchedGeometrie(l.buffer,i[n].slice(s+8),(function(){t._onGeoTaskFinished()})),Bu.debug("load geo from local")}else{var c=t.taskGeometrieManager,h=i[n].indexOf("fileKey=");if(-1===h)return void Bu.error("url is not has fileKey");c.addTask(i[n].slice(h+8)),Bu.debug("load geo from net"),t.taskGeometrieManager.processTasks(t.loadBatchedGeometrie.bind(t))}}),(function(){Bu.error("获取分割几何失败")}))}else s=i[n].indexOf("fileKey="),t._parseBatchedGeometrie(e[i[n]],i[n].slice(s+8),(function(){t._onGeoTaskFinished()})),Bu.debug("load geo from local");else{if(a=t.taskGeometrieManager,-1===(s=i[n].indexOf("fileKey=")))return Bu.error("url is not has fileKey"),{v:void 0};a.addTask(i[n].slice(s+8)),Bu.debug("load geo from net")}},r=0;i.length>r;r+=1){var a,s,l=n(r);if("object"===nu(l))return l.v}t.taskGeometrieManager.processTasks(t.loadBatchedGeometrie.bind(t))}),(function(){for(var i=t.taskGeometrieManager,n=0;e.length>n;n+=1)i.addTask(e[n]);i.processTasks(t.loadBatchedGeometrie.bind(t))}))};n.length>0;)a()}else{for(var s=this.taskGeometrieManager,l=0;e.length>l;l+=1)s.addTask(e[l]);s.processTasks(t.loadBatchedGeometrie.bind(t))}},nI.prototype._loadInstancedGeo=function(e){var t=this;if(xd.getDataFromIndexedDB&&!this.offLine){for(var i=this.url,n=[],r=0;e.length>r;r+=1)n.push(i.mpkUrl(e[r]));var o=this.model.getStorage();if(o)for(var a=function(){var i=n.splice(0,30);o.getBatch(i,(function(e){for(var n=function(n){if(e[i[n]])if(!0===e[i[n]].split){var r=e[i[n]].list,l=new Uint8Array(e[i[n]].length);o.getBatch(r,(function(e){for(var o=0;r.length>o;o+=1)e[r[o]]?l.set(new Uint8Array(e[r[o]]),4e7*o):Bu.error("获取分割几何失败");var a=i[n].indexOf("fileKey=");t._parseInstancedGeometrie(l.buffer,i[n].slice(a+8),(function(){t._onGeoTaskFinished()})),Bu.debug("load geo from local")}),(function(){Bu.error("获取分割几何失败")}))}else s=i[n].indexOf("fileKey="),t._parseInstancedGeometrie(e[i[n]],i[n].slice(s+8),(function(){t._onGeoTaskFinished()})),Bu.debug("load geo from local");else{if(a=t.taskInstancedGeometrieManager,-1===(s=i[n].indexOf("fileKey=")))return Bu.error("url is not has fileKey"),{v:void 0};a.addTask(i[n].slice(s+8)),Bu.debug("load geo from net")}},r=0;i.length>r;r+=1){var a,s,l=n(r);if("object"===nu(l))return l.v}t.taskInstancedGeometrieManager.processTasks(t.loadInstancedGeometrie.bind(t))}),(function(){for(var i=t.taskInstancedGeometrieManager,n=0;e.length>n;n+=1)i.addTask(e[n]);i.processTasks(t.loadInstancedGeometrie.bind(t))}))};n.length>0;)a()}else{for(var s=this.taskInstancedGeometrieManager,l=0;e.length>l;l+=1)s.addTask(e[l]);s.processTasks(t.loadInstancedGeometrie.bind(t))}},nI.prototype._onGeoTaskFinished=function(){(this.geoLoadTaskCount+=1,this.notifyProgress)&&(this.progressCallback&&this.progressCallback({total:this.maxLoadTaskCount+this.maxGeoLoadTaskCount,loaded:.8*(this.loadTaskCount+this.geoLoadTaskCount),modelKey:this.model.modelKey}));this.maxGeoLoadTaskCount>this.geoLoadTaskCount||(this.dataLoaded=!0,Bu.timeEnd("几何数据加载时间"),this.geoFinishCallback&&this.geoFinishCallback())},nI.prototype.getSceneTaskCount=function(e){var t=e.scenes;return t+=e.lines,t+=e.mpks,xd.BorderLineDelayLoaded||(t+=this.getAllBorderlineCount()),t};var rI=function(e,t){_y.call(this,e),this.defaultManager=new Qv(t,e),this.instancedManager=new Kv(e),this.loader=new nI(this)};(rI.prototype=Object.create(_y.prototype)).prepare=function(e,t){this.isLoaded()&&!this.isHidden()&&(this.prepareWireframe(this.model,t),this.model.getMaterialManager(),this.model.getMaterialManager()._updateTextureMapping(),!this.model.lightmap||this.model.enableLightmap===xd.EnableLightmap&&this.model.lightmapIntensity===xd.LightmapIntensity||(this.model.enableLightmap=xd.EnableLightmap,this.model.lightmapIntensity=xd.LightmapIntensity,this.rebuildIndicesforLightmap(),this.updateNodes()))},rI.prototype.settleData=function(e){var t=this;this.addNodeInfoToOctantMap(),t.model.setLoaded(!0);this.loader.geoFinishCallback=function(){t.loaded=!0,t.model.getMaterialManager()._updateTextureMapping(),t.clearCachedData(t.model),e&&e()},this.loader.startLoadSceneAndGeos(this.model.getConfig())},rI.prototype.addNodeInfoToOctantMap=function(){var e=this.model.manager,t=this.model.getEncodedDatabagId();this.loader.getDescriptor().traverseNodeInfosByComponent((function(i,n){e.addNodeInfoToOctantMap(t,i,n)}))},rI.prototype.createMeshNodes=function(e){var t=this,i=this.model;xd.stepLoad&&i.setLoaded(!0);var n=this.loader.getDescriptor();this.instancedManager.createMeshNodes(i,n.getInstancedUserIds()),this.defaultManager.asyncCreateMeshNodes(i,n.getStandardUserIds(),(function(){i.getMaterialManager()._updateTextureMapping(),t.clearCachedData(i),t.loaded=!0,e&&e()}))},rI.prototype.clearCachedData=function(e){this.loader.getDescriptor().destroyReader(),this.loader.getDescriptor().clearReferencedMeshCache(),this.defaultManager.clearCachedData(),this.instancedManager.clearCachedData()},rI.prototype.createBatchedMeshNodes=function(e){this.defaultManager.createBatchedMeshNodes(this.model,e)},rI.prototype.createInstancedMeshNodes=function(e){this.instancedManager.createInstancedMeshNodes(this.model,e)};var oI=function(e){lu(i,e);var t=pu(i);function i(e){var n;return ru(this,i),(n=t.call(this,e))._loadingOnDemand=!1,n}return i}(Wy);oI.prototype.loadGeopkOnDemand=function(e,t,i){this.loadTaskCount=0,this.maxLoadTaskCount=e.length,this._loadingOnDemand=!0,this.finishCallback=i;var n=this;if(xd.getDataFromIndexedDB&&!this.offLine){for(var r=this.url,o=[],a=0;e.length>a;a+=1)o.push(r.mpkUrl(e[a]));var s=this.model.getStorage();s&&s.getBatch(o,(function(e){for(var i=function(t){if(e[o[t]])if(!0===e[o[t]].split){var i=e[o[t]].list,r=new Uint8Array(e[o[t]].length);s.getBatch(i,(function(e){for(var a=0;i.length>a;a+=1)e[i[a]]?r.set(new Uint8Array(e[i[a]]),4e7*a):Bu.error("获取分割几何失败");var s=o[t].indexOf("fileKey=");n._parseGeometrie(r.buffer,o[t].slice(s+8)),Bu.debug("load geo from local"),n._onTaskFinished()}),(function(){Bu.error("获取分割几何失败")}))}else l=o[t].indexOf("fileKey="),n._parseGeometrie(e[o[t]],o[t].slice(l+8)),Bu.debug("load geo from local"),n._onTaskFinished();else{if(a=n.taskGeometrieManager,-1===(l=o[t].indexOf("fileKey=")))return Bu.error("url is not has fileKey"),{v:void 0};a.addTask(o[t].slice(l+8)),Bu.debug("load geo from net")}},r=0;o.length>r;r+=1){var a,l,c=i(r);if("object"===nu(c))return c.v}n.taskGeometrieManager.processTasks(n.loadGeometrie.bind(n),t)}),(function(){for(var i=n.taskGeometrieManager,r=0;e.length>r;r+=1)i.addTask(e[r]);i.processTasks(n.loadGeometrie.bind(n),t)}))}else{for(var l=this.taskGeometrieManager,c=0;e.length>c;c+=1)l.addTask(e[c]);l.processTasks(n.loadGeometrie.bind(n),t,i)}},oI.prototype.resetProcessState=function(e){this.loadTaskCount=0,this.maxLoadTaskCount=e,this._loadingOnDemand=!0},oI.prototype.dealProgressSegment=function(e,t){return xd.MergeComponent&&this._loadingOnDemand?t*e.progressPercentage.load:t},oI.prototype._loadLayerKey=function(){var e=this,t=this.fileLoader,i=this.url,n=this.model,r=this.handler.getLayerProvider();t.setResponseType(""),t.load(i.layerKeyUrl(),(function(t){var i=new LayerKeyReader(t),n=[],o=i.getData();r.cacheLayerKeys(o);for(var a=0,s=i.getCount();s>a;++a){var l=i.getLayerKey(a),c=r.formatLayerIds(l);n.push(c[0])}e._loadLayer(n)}),void 0,(function(t){n.dispatchEvent({type:Qd.LOAD_ERROR,errorType:Qd.LOAD_MPK_ERROR,event:t}),e._onTaskFinished()}))},oI.prototype._loadLayer=function(e){var t=this,i=this.fileLoader,n=this.url,r=this.model,o=this.handler.getLayerProvider();i.setResponseType("arraybuffer"),i.load(n.layerUrl(),(function(i){for(var n=new LayerReader(i),r=0,a=n.getLayerCount();a>r;++r)if(void 0!==e[r]){for(var s=[],l=n.getLayerData(r),c=n.getGeopkList(r),h=0,d=c.length;d>h;h+=1)s.push(c[h]);o.cacheLayerData(e[r],{layerId:l.layer_id,boundingBox:l.boundingBox,mpkIdxs:s})}t._onTaskFinished()}),void 0,(function(e){r.dispatchEvent({type:Qd.LOAD_ERROR,errorType:Qd.LOAD_MPK_ERROR,event:e}),t._onTaskFinished()}))},oI.prototype.delayLoadResources=function(e){var t=this.model.getConfig().metadata;t&&0!==t.lines?(this.startCallback=null,this.progressCallback=null,this.finishCallback=e,this.loadTaskCount=0,this.maxLoadTaskCount=0,this.maxLoadTaskCount+=t.lines,t.lines&&this._loadLine()):e&&e()};var aI=function(e){Zy.call(this,e)};(aI.prototype=Object.assign(aI.prototype,Zy.prototype)).parseItemData=function(e,t){var i=this.model;(my(i.dataVersion,"2.0.0")||void 0===i.dataVersion)&&(Bu.time("升级几何结构"),this._updateV1ToV2(i),i.dataVersion="2.0.0",Bu.timeEnd("升级几何结构")),this._readMaterialBuffer(i),i.hasAnimation&&xd.EnableAnimation?(this._parseClips(),this._parseBones()):(this._parseGeo(),xd.Instance&&Ay(i.dataVersion,"2.0.0")&&this._parseInstanced());var n={};if(!n)return Bu.log("Empty scene"),!1;var r=this.referencedMeshCache;if(Bu.time("_readItemData"),!r.bufferData||0>=Object.keys(r.bufferData).length)return!0;if(e)for(var o=0,a=e.length;a>o;o+=1)r.components[e[o]]&&this._readItemData(n,e[o],e[o],void 0,0);else for(var s in r.components)this._readItemData(n,s,s,void 0,0);i.hasAnimation&&xd.EnableAnimation&&this._parseNodes(),Bu.timeEnd("_readItemData"),n=null,t&&t()};var sI=function(e){lu(i,e);var t=pu(i);function i(e){var n;return ru(this,i),(n=t.call(this,e)).descriptor=new aI(e.model),n}return i}(oI);sI.prototype.loadSceneAndMpks=function(e){this._loadScene(0),this._loadLayerKey(),xd.BorderLineDelayLoaded||this._loadAllBorderlines(e)},sI.prototype.getSceneTaskCount=function(e){var t=2;return xd.BorderLineDelayLoaded||(t+=this.getAllBorderlineCount()),t};var lI=function(e){_y.call(this,e),this.layerDataLoaded=!1,this.loadedUserIdsObject=null,this.loadedUserIds=null,this.layerProvider=null,this.firstToLoad=!1};(lI.prototype=Object.assign(lI.prototype,_y.prototype)).destroy=function(){lI.prototype.destroy.call(this),this.loadedUserIdsObject=null,this.loadedUserIds=null,this.layerProvider.destroy(),this.layerProvider=null},lI.prototype.getLayerProvider=function(){return this.layerProvider},lI.prototype.load=function(e){var t=this,i=this.model;this.loader.setNotifyProgress(e),this.loader.load((function(){i.manager.dispatchEvent({type:Fd.ON_LOAD_START})}),(function(e){i.manager.dispatchEvent({type:Fd.ON_LOAD_PROGRESS,progress:e})}),(function(){t.processLoadCompleted((function(){i.manager.dispatchEvent({type:Fd.ON_LOAD_COMPLETE,modelKey:t.model.modelKey})}))}))},lI.prototype.unload=function(e,t){},lI.prototype.loadGeopkOnDemand=function(e,t,i,n){var r=this,o=this.model,a=!e,s=function(e){o.manager.dispatchEvent({type:Fd.ON_LOAD_PROGRESS,progress:e})};this.firstToLoad?this.loader.delayLoadResources((function(){r.firstToLoad=!1,r.loader.finishCallback=null,r.prepareData((function(){r.loader.progressCallback=s,r.getLayerProvider().setConditionsOnDemandLoad(e),r._loadGeopkOnDemand(a,t,i,n)}))})):(r.loader.progressCallback=s,r.getLayerProvider().setConditionsOnDemandLoad(e),r._loadGeopkOnDemand(a,t,i,n))},lI.prototype._loadGeopkOnDemand=function(e,t,i,n){var r=this,o=this.model;this.layerDataLoaded=!1,t&&t(),o.manager.dispatchEvent({type:Fd.ON_LOAD_START}),this.getLayerProvider().loadGeopkOnDemand(e,(function(e){r.dealData(e)}),(function(e,t){}),i,(function(){r.layerDataLoaded=!0,o.manager.updateFilterManager(),Bu.log("load finish"),o.dispatchEventEx({type:Fd.ON_DEMAND_LOAD_COMPLETE,data:{boundingBox:o.manager.getLoadOnDemandDirector().getBoundingBoxForUsedComponent()},modelKey:r.model.modelKey}),n&&n()}))},lI.prototype.processLoadCompleted=function(e){var t=this.model;t.materialManager._updateTextureMapping(),t.materialManager._updateIBL(t),t.loaded=!0,t.updateOctreeNode(),requestAnimationFrame((function(){e&&e(),t.debut(t)}))},lI.prototype.isAllReady=function(){return!(!this.isLoaded()||this.isHidden()||!this.isLayerDataLoaded())},lI.prototype.applyFilter=function(){if(this.isLoaded()&&this.isLayerDataLoaded()){var e=this.model.getModelDescriptor().getStandardUserIdsByCategory(this.loadedUserIds);if(e.length&&this.defaultManager.applyFilter(this.model,e),xd.Instance){var t=this.model.getModelDescriptor().getInstancedUserIdsByCategory(this.loadedUserIds);t.length&&this.instancedManager.applyFilter(this.model,t)}}},lI.prototype.needUpdate=function(){return!!this.isLayerDataLoaded()},lI.prototype.clearData=function(){},lI.prototype.initData=function(e){},lI.prototype.dealMeshNodes=function(e){},lI.prototype.dealData=function(e){var t=this;this.initData((function(){t.model.manager.loadOverrideMaterialsByDemand((function(){t.dealMeshNodes(e)}),(function(){t.dealMeshNodes(e)}))}))},lI.prototype.getLoadedUserIdsObject=function(){return this.loadedUserIdsObject},lI.prototype.isLayerDataLoaded=function(){return this.layerDataLoaded},lI.prototype.clearLoadedState=function(){this.layerDataLoaded=!1,this.loadedUserIdsObject=null,this.loadedUserIds=null};var cI=function(e){this.model=e,this.conditionsChanged=!0,this.nodeInfosWithLayerKey={},this.cachedLayerData={},this.cacheAttributes=null,this.cacheSpecialtysLevels={},this.mapLayerKeys={},this.lastUsedGeopkIdxsObject=null,this.lastUsedLayerIdsObject=null,this.lastUsedLayerData=null,this.mapNeededConditions=null};cI.prototype.destroy=function(){this.cachedLayerData=null,this.nodeInfosWithLayerKey=null,this.cacheAttributes=null,this.cacheSpecialtysLevels=null,this.mapLayerKeys=null,this.lastUsedLayerData=null,this.lastUsedGeopkIdxsObject=null,this.lastUsedLayerIdsObject=null,this.mapNeededConditions=null},cI.prototype.clearData=function(){},cI.prototype.loadLayerDataByIdxs=function(e,t,i,n){},cI.prototype.dealLayerDataLoading=function(e,t,i,n,r){},cI.prototype.loadGeopkOnDemand=function(e,t,i,n,r){var o=e?this.getAllLayerIdxData():this.getUsedLayerIdxData();this.dealLayerDataLoading(this.getLayerIdxInfoByLayerData(o),t,i,n,r)},cI.prototype.getUsedIdxsInfoFrom=function(e,t){var i=null,n={},r={},o={},a={};if(e&&e.length)for(var s=0,l=e.length;l>s;s+=1)n[i=e[s]]=!0;if(t)if(wp.isEmptyObject(n))o=t;else{for(i in t)n[i]&&(a[i]=!0);if(wp.isEmptyObject(a))r=n,o=t;else{for(i in t)a[i]||(o[i]=!0);for(i in n)a[i]||(r[i]=!0)}}else wp.isEmptyObject(n)||(r=n);return{objCurrUsedIdxs:n,addIdxs:Object.keys(r),removeIdxs:Object.keys(o)}},cI.prototype.getLayerIdxInfoByLayerData=function(e){var t=null,i=null;e?(t=e.layerIds,i=e.mpkIdxs):(t=null,i=null);var n=this.getUsedIdxsInfoFrom(t,this.lastUsedLayerIdsObject);this.lastUsedLayerIdsObject=n.objCurrUsedIdxs;var r=this.getUsedIdxsInfoFrom(i,this.lastUsedGeopkIdxsObject);return this.lastUsedGeopkIdxsObject=r.objCurrUsedIdxs,{layerScene:n,mpk:r}},cI.prototype.getUsedLayerIdxData=function(){if(!this.isConditionsChanged()&&this.lastUsedLayerData)return this.lastUsedLayerData;this.setConditionsChanged(!1);var e=this.getConditionsOnDemand();if(!e)return this.lastUsedLayerData=null,null;this.getCachedLayerData();for(var t=[],i=e,n=this.model.getModelDescriptor().referencedMeshCache.components,r=this.model,o=r.getModelDescriptor(),a=0,s=i.length;s>a;a+=1){var l=i[a],c=n[l];if(c)if((c.nodes||c.nodeIds)&&fy(r.dataVersion,"2.0.0"))for(var h=null,d=0,u=(h=c.nodes?c.nodes:c.nodeIds).length;u>d;d+=1){var p=h[d];if("object"!==nu(p)&&(p=o.getReferencedMeshComponentNodeById(p)),p){var g=this.getFileKeyByGeoId(p.geoId);g&&t.push(g)}}else{var f=this.getFileKeyByGeoId(n[l].geoId);f&&t.push(f)}}return this.lastUsedLayerData={layerIds:[],layerKeys:[],boundingBoxes:[],mpkIdxs:t},this.lastUsedLayerData},cI.prototype.getFileKeyByGeoId=function(e){for(var t in this.cachedLayerData)if(this.cachedLayerData.hasOwnProperty(t)){var i=this.cachedLayerData[t];if(e>=i[0]&&i[1]>=e)return t}return window.geoidToFileKeyMap?window.geoidToFileKeyMap[e]:null},cI.prototype.getAllLayerIdxData=function(){this.setConditionsChanged(!1);var e=this.getCachedLayerData();if(!e)return null;var t=[],i=[],n=[],r=[];for(var o in e){for(var a=e[o].mpkIdxs,s=0,l=a.length;l>s;s+=1)n.push(a[s]);t.push(o),i.push(e[o].layerId),r.push(e[o].boundingBox)}return{layerIds:i,layerKeys:t,boundingBoxes:r,mpkIdxs:n}},cI.prototype.getUserIdsOnDemand=function(){var e={},t=this.getConditionsOnDemand();if(t)for(var i in t)e[t[i]]=!0;return e},cI.prototype.cacheLayerData=function(e,t){this.cachedLayerData[e]=t},cI.prototype.getCachedLayerData=function(){return this.cachedLayerData},cI.prototype.clearNodeInfoCacheWithLayerKey=function(){this.nodeInfosWithLayerKey={}},cI.prototype.cacheNodeInfoByLayerKey=function(e,t){this.nodeInfosWithLayerKey[e]||(this.nodeInfosWithLayerKey[e]=[]),this.nodeInfosWithLayerKey[e].push(t)},cI.prototype.cacheNodeInfosWithLayerKey=function(){var e=this.model.getModelDescriptor().getAllNodeInfos();for(var t in e)for(var i=e[t],n=0,r=i.length;r>n;n+=1){var o=i[n],a=this.formatLayerIds(o.userData);this.cacheNodeInfoByLayerKey(a[0],o)}},cI.prototype.cacheLayerKeys=function(e){this.mapLayerKeys=e;var t={},i=this.getLayerKeyAttributes();for(var n in e){var r=e[n],o=r[i[0]],a=r[i[1]];t.hasOwnProperty(o)||(t[o]=[]),t.hasOwnProperty(a)||(t[a]=[]),t[o].push(a),t[a].push(o)}this.cacheSpecialtysLevels=t},cI.prototype.getLayerKeyAttributes=function(){if(this.cacheAttributes)return this.cacheAttributes;var e=[],t=Object.keys(this.mapLayerKeys),i=this.mapLayerKeys[t[0]];for(var n in i)i.hasOwnProperty(n)&&e.push(n);return this.cacheAttributes=e,this.cacheAttributes},cI.prototype.formatLayerIds=function(e){var t=[];if(!e)return t.push("unknown"),t;var i=this.getFileKeyByGeoId(e.originalGeometryId);return t.push(i||"unknown"),t},cI.prototype.getLevelsOrSpecialtys=function(e){return this.cacheSpecialtysLevels.hasOwnProperty(e)?this.cacheSpecialtysLevels[e]:(Bu.warn("Attribute "+e+"has no according levels or specialtys."),[])},cI.prototype.getUnionBoundingBoxOnDemand=function(){var e=this.getBoundingBoxesOnDemand();if(e&&e.length>0){for(var t=new He,i=0,n=e.length;n>i;i+=1)t.union(e[i]);return t}return null},cI.prototype.getBoundingBoxesOnDemand=function(){var e=this.getUsedLayerIdxData();return e?e.boundingBoxes:null},cI.prototype.setConditionsOnDemandLoad=function(e){this.mapNeededConditions=e,this.setConditionsChanged(!0)},cI.prototype.setConditionsChanged=function(e){this.conditionsChanged=e},cI.prototype.getConditionsOnDemand=function(){return this.mapNeededConditions},cI.prototype.isConditionsChanged=function(){return this.conditionsChanged};var hI=function(e){cI.call(this,e)};(hI.prototype=Object.assign(hI.prototype,cI.prototype)).loadLayerDataByIdxs=function(e,t,i,n){this.model.getLoader().resetProcessState(t.length),this.model.getLoader().loadGeopkOnDemand(t,(function(e,t){i&&i(t-e,t)}),n)},hI.prototype.dealLayerDataLoading=function(e,t,i,n,r){var o=e.mpk;if(0!==o.addIdxs.length||0!==o.removeIdxs.length){var a=!1;o.removeIdxs.length>0&&(a=!0,i&&i(null,o.removeIdxs)),o.addIdxs.length>0?this.loadLayerDataByIdxs(null,o.addIdxs,n,(function(){t&&t(r)})):a?t&&t(r):r&&r()}else t&&t(r)};var dI=function(e){return lI.call(this,e),this.layerProvider=new hI(e),this};(dI.prototype=Object.assign(dI.prototype,lI.prototype)).settleData=function(e){this.addNodeInfoToOctantMap(),this.getLayerProvider().cacheNodeInfosWithLayerKey(),this.loaded=!0,e&&e()},dI.prototype.clearData=function(){this.model.clearNodeGroup(),this.model.clearMeshFromOctantMap(),this.getLayerProvider().clearData(),this.model.clearWireframeElementCount(),this.defaultManager.clearData(),this.instancedManager.clearData(),this.clearLoadedState()},dI.prototype.addNodeInfoToOctantMap=function(){var e=this.model.manager,t=this.model.getEncodedDatabagId();this.model.getModelDescriptor().traverseNodeInfosByComponent((function(i,n){e.addNodeInfoToOctantMap(t,i,n)}))},dI.prototype.initData=function(e){var t=this;t.model.getModelDescriptor().parseItemData(t.layerProvider.getConditionsOnDemand(),(function(){t.settleData(),t.loadedUserIdsObject=t.getLayerProvider().getUserIdsOnDemand(),t.loadedUserIds=Object.keys(t.loadedUserIdsObject),e&&e()}))},dI.prototype.unload=function(e,t){var i=this;this.model.getModelDescriptor().clearReferencedMeshCacheByGeopkIdxs(t,(function(e){i.defaultManager.disposeGeometry(e)}))};var uI=function(e,t){return dI.call(this,e,t),this.tag="layer",this.defaultManager=new Qv(t,e),this.instancedManager=new Kv(e),this.loader=new sI(this),this};(uI.prototype=Object.assign(uI.prototype,dI.prototype)).prepare=function(e,t){this.isAllReady()&&(this.prepareWireframe(this.model,t),this.model.getMaterialManager()._updateTextureMapping(this.model))},uI.prototype.dealMeshNodes=function(e){delete this.model.manager.octantToObjectMap[this.model.modelKey],this.addNodeInfoToOctantMap();var t=this.model.getModelDescriptor().getInstancedUserIdsByCategory(this.loadedUserIds);this.model._removeNodeGroup(Vp.INSTANCEGEOMETRY),this.model._removeNodeGroup(Vp.INSTANCEWIREFRAMEGEOMETRY),this.instancedManager.meshManager.dispose(),this.instancedManager.meshManager.clearData(),this.instancedManager.wireframeManager.clearData(),this.instancedManager.meshManager.disposeInstanceGeometries(),t.length&&this.instancedManager.createMeshNodes(this.model,t);var i=this.model.getModelDescriptor().getStandardUserIdsByCategory(this.loadedUserIds);this.model._removeNodeGroup(Vp.GEOMETRY),this.model._removeNodeGroup(Vp.WIREFRAME),this.defaultManager.meshManager.dispose(),this.defaultManager.meshManager.clearData(),this.defaultManager.wireframeManager.clearData(),i.length?this.defaultManager.asyncCreateMeshNodes(this.model,i,e):e&&e()},uI.prototype.unloadComponents=function(e,t){for(var i=this.model.modelKey,n=0,r=e.length;r>n;n+=1)this.model.manager.removeBatchedMeshFromOctantMap(i,e[n]);this.model.getModelDescriptor().clearNodeInfoCacheByComponentsKey(e),this.dealMeshNodes(t)};var pI=function(e){zy.call(this,e)};(pI.prototype=Object.assign(pI.prototype,zy.prototype)).parseItemData=function(e,t){var i=this.model;(my(i.dataVersion,"2.0.0")||void 0===i.dataVersion)&&(Bu.time("升级几何结构"),this._updateV1ToV2(i),i.dataVersion="2.0.0",Bu.timeEnd("升级几何结构")),this._readMaterialBuffer(i),i.hasAnimation&&xd.EnableAnimation?(this._parseClips(),this._parseBones()):this._parseGeo();var n={};if(!n)return Bu.log("Empty scene"),!1;var r=this.referencedMeshCache;if(Bu.time("_readItemData"),!r.bufferData||0>=Object.keys(r.bufferData).length)return!0;if(e)for(var o=0,a=e.length;a>o;o+=1)r.components[e[o]]&&this._readItemData(n,e[o],e[o],void 0,0);else for(var s in r.components)this._readItemData(n,s,s,void 0,0);i.hasAnimation&&xd.EnableAnimation&&this._parseNodes(),Bu.timeEnd("_readItemData"),n=null,t&&t()};var gI=function(e){lu(i,e);var t=pu(i);function i(e){var n;return ru(this,i),(n=t.call(this,e)).descriptor=new pI(e.model),n}return i}(oI);gI.prototype.loadSceneAndMpks=function(e){this._loadScene(0),this._loadLayerKey(),xd.BorderLineDelayLoaded||this._loadAllBorderlines(e)},gI.prototype.getSceneTaskCount=function(e){var t=2;return xd.BorderLineDelayLoaded||(t+=this.getAllBorderlineCount()),t};var fI=function(e){$y.call(this,e),this.nodeGroupName="PickingMeshGroup"};Object.assign(fI.prototype,$y.prototype),SA(fI,[{key:"disposePickingNodeById",value:function(e){for(var t=Object.keys(this.pickingNodeMap[e]),i=0,n=t.length;n>i;i+=1)for(var r=this.pickingNodeMap[e][t[i]],o=0,a=r.length;a>o;o+=1)r[o].material=null,r[o].geometry.dispose(),r[o]=null}},{key:"removeFormPickingNodeGroup",value:function(e){if(this.pickingNodeGroup)for(var t=Object.keys(this.pickingNodeMap[e]),i=0,n=t.length;n>i;i+=1)for(var r=this.pickingNodeMap[e][t[i]],o=0,a=r.length;a>o;o+=1)this.pickingNodeGroup.remove(r[o])}},{key:"addToPickingNodeMap",value:function(e,t,i){this.pickingNodeMap||(this.pickingNodeMap={}),this.pickingNodeMap[e]||(this.pickingNodeMap[e]={}),this.pickingNodeMap[e][t]=i,this.addToPickingNodeGroup(i)}},{key:"generatePickingMeshes",value:function(e){var t=this;this.manager.traverseActiveMeshMap(e,(function(e,i,n){if(!t._isExistNode(e,i)){for(var r=[],o=0,a=n.length;a>o;o+=1){var s=n[o],l=new Ni;l.setAttribute("position",s.geometry.getAttribute("position")),l.setIndex(s.geometry.getIndex()),l._withDrawRange&&l.setDrawRange(s.geometry.drawRange.start,s.geometry.drawRange.count);var c=new(s.isLineSegments?La:nn)(l,cA.DefaultMaterial);by.copyMeshProperties(c,s),c.renderOrder=c.isMesh?1:2,r.push(c)}t.addToPickingNodeMap(e,i,r)}}))}},{key:"_isExistNode",value:function(e,t){return!!(this.pickingNodeMap&&this.pickingNodeMap[e]&&this.pickingNodeMap[e][t])}},{key:"updatePickingMeshesState",value:function(e,t,i){if(this.pickingNodeMap)for(var n=this.pickingNodeMap,r=this.manager,o=0,a=t.length;a>o;o+=1){var s=t[o];if(n[s]&&r.isPickableNode(s)){var l=r.getActiveMeshMapById(s);if(l)for(var c=Object.keys(n[s]),h=0,d=c.length;d>h;h+=1){var u=c[h];if(l[u]){var p=n[s][u];if(p)for(var g=0,f=p.length;f>g;g+=1)p[g].material=e,p[g].visible=!0}}}}}},{key:"resetPickingMeshesState",value:function(){if(this.pickingNodeMap)for(var e=this.pickingNodeMap,t=Object.keys(e),i=0,n=t.length;n>i;i+=1)for(var r=t[i],o=Object.keys(e[r]),a=0,s=o.length;s>a;a+=1)for(var l=e[r][o[a]],c=0,h=l.length;h>c;c+=1)l[c].visible=!1}},{key:"updatePickingMeshes",value:function(e,t,i){return this.generatePickingMeshes(t),this.resetPickingMeshesState(),this.updatePickingMeshesState(e,t,i),this.getPickingNodeGroup()}}]);var mI=function(e){lu(i,e);var t=pu(i);function i(e,n){var r;return ru(this,i),(r=t.call(this)).type="SkinnedMeshEx",r.matrixAutoUpdate=!0,r.active=!1,r.guid="",r.key="",r.typeEx="",r.geometry=e||by.EmptyGeometry,r.material=n||cA.DefaultMaterial,r.visible=!1,r.castShadow=xd.EnableShadow,r.receiveShadow=xd.EnableShadow,r}return i}(ma);mI.prototype.init=function(e){e&&e.parent&&e.parent.add(this)},mI.prototype.destroy=function(){this.parent&&this.parent.remove(this),this.userData&&(this.userData=null),this.geometry=null,this.material=null},mI.prototype.isVisible=function(){return this.visible&&this.active},mI.prototype.spawn=function(e){void 0!==e.guid&&(this.guid=e.guid),void 0!==e.key&&(this.key=e.key),void 0!==e.name&&(this.name=e.name),void 0!==e.typeEx&&(this.typeEx=e.typeEx),e.geometry&&(this.geometry=e.geometry),e.material&&(this.material=e.material),e.matrix?(this.matrix.copy(e.matrix),this.updateMatrixWorld(!0)):(this.matrix.identity(),this.updateMatrixWorld(!0)),this.modelKey=e.modelKey?e.modelKey:"",e.userData?this.userData=e.userData:this.userData&&(this.userData=null),void 0!==e.visible&&(this.visible=e.visible),this.renderOrder=e.renderOrder||0,this.active=!0,this.visible=!0,this.frustumCulled=!1,this.matChange=!1},mI.prototype.clear=function(){this.geometry=by.EmptyGeometry,this.material=cA.DefaultMaterial,this.active=!1,this.visible=!0,this.guid="",this.key="",this.typeEx="",this.frustumCulled=!0,this.material.visible=!1},mI.prototype.intersectBoxWithDistance=function(){var e=new He;return function(t,i){var n=this.geometry,r=this.material,o=this.matrixWorld;return i&&(o=new yt).multiplyMatrices(this.matrixWorld,i),void 0===r?-1:(n.boundingBox||n.computeBoundingBox(),e.copy(n.boundingBox),e.applyMatrix4(o),t.ray.intersectBoxWithDistance(e))}}(),mI.prototype.intersectBoxWithDistanceByIndices=function(e,t){var i=this.matrixWorld,n=this.computeBoundingBox(t);return n.applyMatrix4(i),e.ray.intersectBoxWithDistance(n)},mI.prototype.intersectBoxWithClipPlane=function(e,t){var i=this.matrixWorld,n=this.computeBoundingBox(t);return n.applyMatrix4(i),n.intersectsPlane(e)},mI.prototype.raycastByIndices=function(){var e=new yt,t=new At,i=new ct,n=new Ke,r=new Ke,o=new Ke,a=new ke,s=new ke,l=new ke,c=new Ke,h=new Ke,d=new Ke,u=new yt;function p(e,t,i,p,g,f,m,A){n.fromBufferAttribute(p,f),r.fromBufferAttribute(p,m),o.fromBufferAttribute(p,A);var y=function(e,t,i,n,r,o,a){var s=e.material;if(null===(Array.isArray(s)?i.intersectTriangle(n,r,o,!1,a):1===s.side?i.intersectTriangle(o,r,n,!0,a):i.intersectTriangle(n,r,o,2!==s.side,a)))return null;d.copy(a),d.applyMatrix4(u);var l=t.ray.origin.distanceTo(d);return t.near>l||l>t.far?null:{distance:l,point:d.clone(),object:e}}(e,t,i,n,r,o,h);if(y){if(g&&g.array&&g.array.length&&(a.fromBufferAttribute(g,f),s.fromBufferAttribute(g,m),l.fromBufferAttribute(g,A),y.uv=function(e,t,i,n,r,o,a){return ri.getBarycoord(e,t,i,n,c),r.multiplyScalar(c.x),o.multiplyScalar(c.y),a.multiplyScalar(c.z),r.add(o).add(a),r.clone()}(h,n,r,o,a,s,l)),p.instanceMatrix){var v=n.clone().applyMatrix4(p.instanceMatrix),C=r.clone().applyMatrix4(p.instanceMatrix),I=o.clone().applyMatrix4(p.instanceMatrix),x={a:f,b:m,c:A,normal:ri.getNormal(v,C,I,new Ke),materialIndex:0};y.face=x}else{var w={a:f,b:m,c:A,normal:ri.getNormal(n,r,o,new Ke),materialIndex:0};y.face=w}y.faceIndex=f}return y}return function(n,r,o,a){var s=this.geometry,l=this.material;if(a){s=this.geometry,l=this.material;if((u=new yt).multiplyMatrices(this.matrixWorld,a),void 0===l)return;if(null===s.boundingSphere&&s.computeBoundingSphere(),i.copy(s.boundingSphere),i.applyMatrix4(u),!1===n.ray.intersectsSphere(i))return;if(e.copy(u).invert(),t.copy(n.ray).applyMatrix4(e),null!==s.boundingBox&&!1===t.intersectsBox(s.boundingBox))return;var c=null,h=null,d=null,g=null,f=s.index;(I=s.attributes.position).instanceMatrix=a;var m=s.attributes.uv,A=null,y=null;if(null!==f)for(A=0,y=f.count;y>A;A+=3)h=f.getX(A),d=f.getX(A+1),g=f.getX(A+2),(c=p(this,n,t,I,m,h,d,g))&&(c.faceIndex=Math.floor(A/3),r.push(c));else for(A=0,y=I.count;y>A;A+=3)(c=p(this,n,t,I,m,h=A,d=A+1,g=A+2))&&(c.index=h,r.push(c))}else{if(u=this.matrixWorld,void 0===l)return;if(i.copy(this.computeBoundingSphere(o)),i.applyMatrix4(u),!1===n.ray.intersectsSphere(i))return;e.copy(u).invert(),t.copy(n.ray).applyMatrix4(e);var v=this.computeBoundingBox(o);if(!1===t.intersectsBox(v))return;c=null,h=null,d=null,g=null;var C,I=s.attributes.position,x=(m=s.attributes.uv,A=null,o.indexStart),w=o.indexStart+o.indexCount,M=s.getIndex().array;for(A=x,C=w;C>A;A+=3)(c=p(this,n,t,I,m,h=M[A],d=M[A+1],g=M[A+2]))&&(c.faceIndex=Math.floor(A/3),r.push(c))}}}(),mI.prototype.minDistanceToTri=function(e,t,i){function n(e,t){return new Ke(e.x-t.x,e.y-t.y,e.z-t.z)}function r(e,t){return new Ke(e.x+t.x,e.y+t.y,e.z+t.z)}function o(e,t,i){return new Ke(e.x+t.x*i,e.y+t.y*i,e.z+t.z*i)}function a(e,t){return e.x*t.x+e.y*t.y+e.z*t.z}function s(e,t){return new Ke(e.y*t.z-e.z*t.y,e.z*t.x-e.x*t.z,e.x*t.y-e.y*t.x)}function l(e,t,i,l){var c,h=a(t,l),d=a(t,t),u=a(l,l),p=n(i,e),g=a(t,p),f=a(l,p),m=null;0>(m=(g*u-f*h)/(d*u-h*h))||isNaN(m)?m=0:m>1&&(m=1);var A=null,y=null,v=null,C=null;return 0>=(c=(m*h-f)/u)||isNaN(c)?(y=i,0>=(m=g/d)||isNaN(m)?(A=e,v=n(i,e)):1>m?(A=o(e,t,m),C=s(p,t),v=s(t,C)):v=n(i,A=r(e,t))):1>c?(y=o(i,l,c),0>=m||isNaN(m)?(A=e,C=s(p,l),v=s(l,C)):1>m?(A=o(e,t,m),0>a(v=s(t,l),p)&&v.multiplyScalar(-1)):(C=s(p=n(i,A=r(e,t)),l),v=s(l,C))):(y=r(i,l),0>=(m=(h+g)/d)||isNaN(m)?(A=e,v=n(y,e)):1>m?(A=o(e,t,m),C=s(p=n(y,e),t),v=s(t,C)):v=n(y,A=r(e,t))),{vec:v,closestP:A,closestQ:y}}function c(e,t){var i=null,r=null,c=[],h=[],d=null;c[0]=n(e[1],e[0]),c[1]=n(e[2],e[1]),c[2]=n(e[0],e[2]),h[0]=n(t[1],t[0]),h[1]=n(t[2],t[1]),h[2]=n(t[0],t[2]);for(var u=null,p=null,g=null,f=0,m=e[0].distanceToSquared(t[0])+1,A=0;3>A;A+=1)for(var y=0;3>y;y+=1){var v=l(e[A],c[A],t[y],h[y]);d=v.vec;var C=a(u=n(r=v.closestQ,i=v.closestP),u);if(m>=C){p=i.clone(),g=r.clone(),m=C;var I=a(n(e[(A+2)%3],i),d),x=a(n(t[(y+2)%3],r),d);if(0>=I&&x>=0)return{start:i.clone(),end:r.clone(),minDistance:Math.sqrt(C)};0>I&&(I=0),x>0&&(x=0),a(u,d)-I+x>0&&(f=1)}}var w=s(c[0],c[1]),M=a(w,w);if(M>1e-15){var E=[];u=n(e[0],t[0]),E[0]=a(u,w),u=n(e[0],t[1]),E[1]=a(u,w),u=n(e[0],t[2]),E[2]=a(u,w);var B=-1;if(E[0]>0&&E[1]>0&&E[2]>0?E[B=E[1]>E[0]?0:1]>E[2]&&(B=2):0>E[0]&&0>E[1]&&0>E[2]&&E[2]>E[B=E[0]>E[1]?0:1]&&(B=2),B>=0&&(f=1,a(u=n(t[B],e[0]),s(w,c[0]))>0&&a(u=n(t[B],e[1]),s(w,c[1]))>0&&a(u=n(t[B],e[2]),s(w,c[2]))>0))return i=o(t[B],w,E[B]/M),r=t[B].clone(),i.distanceTo(r)}var S=s(h[0],h[1]),b=a(S,S);if(b>1e-15){var k=[];u=n(t[0],e[0]),k[0]=a(u,S),u=n(t[0],e[1]),k[1]=a(u,S),u=n(t[0],e[2]),k[2]=a(u,S);B=-1;if(k[0]>0&&k[1]>0&&k[2]>0?k[B=k[1]>k[0]?0:1]>k[2]&&(B=2):0>k[0]&&0>k[1]&&0>k[2]&&k[2]>k[B=k[0]>k[1]?0:1]&&(B=2),B>=0&&(f=1,a(u=n(e[B],t[0]),s(S,h[0]))>0&&a(u=n(e[B],t[1]),s(S,h[1]))>0&&a(u=n(e[B],t[2]),s(S,h[2]))>0))return{start:i=e[B].clone(),end:(r=o(e[B],S,k[B]/b)).clone(),minDistance:i.distanceTo(r)}}return f?(i=p,r=g,{start:p.clone(),end:g.clone(),minDistance:Math.sqrt(m)}):{start:p.clone(),end:g.clone(),minDistance:0}}var h=new Ke,d=new Ke,u=new Ke;function p(e,t,i,n,r,o){h.fromBufferAttribute(t,i),d.fromBufferAttribute(t,n),u.fromBufferAttribute(t,r),o&&(h.applyMatrix4(o),d.applyMatrix4(o),u.applyMatrix4(o)),e.push(h),e.push(d),e.push(u)}for(var g={start:null,end:null,minDistance:Number.POSITIVE_INFINITY},f=this.geometry,m=f.attributes.position,A=t?t.indexStart:0,y=f.getIndex().array,v=A,C=t?t.indexStart+t.indexCount:y.length;C>v;v+=3){var I=[];p(I,m,y[v],y[v+1],y[v+2],i);var x=c(e,I);if(0>=x.minDistance)return g.minDistance=0,g;g.minDistance>x.minDistance&&(g.minDistance=x.minDistance,g.start=x.start.clone(),g.end=x.end.clone())}return g},mI.prototype.computeBoundingBox=function(e){var t=new He,i=this.geometry.attributes.position.array,n=null,r=null;return e?(n=e.positionStart,r=e.positionStart+e.positionCount):(n=0,r=i.length),this.setBoundingBoxFromArray(t,i,n,r),t},mI.prototype.computeBoundingSphere=function(e){var t=new He,i=new Ke,n=this.geometry.attributes.position.array,r=null,o=null;e?(r=e.positionStart,o=e.positionStart+e.positionCount):(r=0,o=n.length);var a=new ct,s=a.center;this.setBoundingBoxFromArray(t,n,r,o),t.getCenter(s);for(var l=0,c=r,h=o;h>c;c+=3)i.x=n[c],i.y=n[c+1],i.z=n[c+2],l=Math.max(l,s.distanceToSquared(i));return a.radius=Math.sqrt(l),a},mI.prototype.setBoundingBoxFromArray=function(e,t,i,n){for(var r=Number(1/0),o=Number(1/0),a=Number(1/0),s=-1/0,l=-1/0,c=-1/0,h=i,d=n;d>h;h+=3){var u=t[h],p=t[h+1],g=t[h+2];r>u&&(r=u),o>p&&(o=p),a>g&&(a=g),u>s&&(s=u),p>l&&(l=p),g>c&&(c=g)}e.min.set(r,o,a),e.max.set(s,l,c)};var AI=function(e){return kv.call(this),this.manager=e,this.nodePriority={high:[],medium:[],low:[]},this.visibleOctant=[],this.occlusionVisibleOctant=[],this.usedNodeInfosObject={},this.lineNodes={},this.blinkMaterials=[],this.selectedMeshes=[],this.nonSelectedMeshes=[],this.selectedObjectIds=[],this.activeMeshMap={},this};(AI.prototype=Object.create(kv.prototype)).destroy=function(){this.dispose(),this.clearData(),this.pickingNodeGenerator&&(this.pickingNodeGenerator.destroy(),this.pickingNodeGenerator=null),this.activeMeshMap=null,this.manager=null,this.nodePriority=null,this.visibleOctant=null,this.occlusionVisibleOctant=null,this.nodePriority=null,this.lineNodes=null,this.blinkMaterials=null},AI.prototype.disposeLineNodes=function(){for(var e in this.lineNodes){var t=this.lineNodes[e];t.geometry.dispose(),t=null,delete this.lineNodes[e]}},AI.prototype.clearData=function(){this.pickingNodeGenerator&&this.pickingNodeGenerator.clearData(),this._clearActiveMeshMap(),this.disposeGeometries(),this.disposeLineNodes(),this._clearNodePriorityData(!0),this._clearUsedNodeInfosObject(),this.visibleOctant.length=0,this.occlusionVisibleOctant.length=0},AI.prototype.update=function(e,t,i){this._updateMeshNodes(e,t,i)},AI.prototype.cullNodes=function(e,t){this._clearNodePriorityData(!1),this._adjustLowNodePriorityLength(e);var i=0;return i=xd.EnableOctant?this._cullNodesWithOctant(e,t):this._cullNodesWithFull(e),this._calcPrioritizedNodeCount(e,i)},AI.prototype.getPriorityNodes=function(){return[this.nodePriority.high,this.nodePriority.medium,this.nodePriority.low]},AI.prototype._cullNodesWithOctant=function(e,t){var i=0,n=0,r=this.manager.getLoader(e).getOctreeRootNodeInner(),o=this.manager.getLoader(e).getOctreeRootNodeOuter();if(this.manager.getContainsCamera(e)||!o)return this.visibleOctant.length=0,r&&this._frustumCull(e,t,r),o&&this._frustumCull(e,t,o),(n=this.visibleOctant.length)>0&&(this._sortVisibleOctant(t),i=this._logicCull(e,!0,!0,i,n)),i;o&&(this.visibleOctant.length=0,this._frustumCull(e,t,o),(n=this.visibleOctant.length)>0&&(this._sortVisibleOctant(t),i=this._logicCull(e,!0,!1,i,n)));var a=this.manager.getFilter(e);(Object.keys(this.nodePriority.low).length+this.nodePriority.high.length+this.nodePriority.medium.length<this.manager.getRenderableCount(e)||a._hasRenderPromotionFilter())&&((r=this.manager.getLoader(e).getOctreeRootNodeInner())&&(this.visibleOctant.length=0,this._frustumCull(e,t,r),(n=this.visibleOctant.length)>0&&(this._sortVisibleOctant(e,t),i=this._logicCull(e,!0,!1,i,n))));return i},AI.prototype._cullNodesWithFull=function(e){var t=e.getModelDescriptor().getComponentCount();return 0===t?0:this._logicCullWithFull(e,t)},AI.prototype._calcPrioritizedNodeCount=function(e,t){var i=t+this.nodePriority.high.length+this.nodePriority.medium.length;return i>this.manager.getRenderableCount(e)&&(i=this.manager.getRenderableCount(e)),i},AI.prototype._updateMeshNodes=function(e,t,i){if(this.filter=e.getFilter(),e.isOnlyWireframe()){e._getNodeGroup(Vp.GEOMETRY).visible=!1}else{var n=e.getModelDescriptor().getStandardNodeInfos();if(n){this.clearSelectedObjectIds(),e._getNodeGroup(Vp.GEOMETRY).visible=!0;var r=e.manager.filter,o=e.selectedMaterial,a=e.manager.sceneState,s=e.manager;if(s.octantToObjectMap&&s.octantToObjectMap[e.modelKey]){var l=s.octantToObjectMap[e.modelKey].mesh,c=e.materialManager.materials,h=this.manager.hiddenUserIdSetObject,d=this.manager.overrideUserIdSetObject,u=this.manager.transparentUserIdSetObject,p=this.manager.selectedUserIdSetObject,g=this.manager.hoveredUserIdSetObject;this.blinkMaterials.length=0,t||(t=e.getModelDescriptor().getStandardUserIds()),xd.TranslucentDepthDisabled&&(o.depthWrite=!o.transparent);var f=r._getMaterialByName("scene");xd.TranslucentDepthDisabled&&(f.depthWrite=!1);for(var m=0;t.length>m;m+=1){var A=t[m];if(n[A]){var y=n[A][0];if(y)if(l[A]){var v=l[A][0];if(v instanceof xm&&(v=v.object),v)if(h&&h[A])v.visible=!1;else{v.visible=!0;var C=[];if(u&&u[A]&&!xd.EnableSelectionByTranslucent){for(var I=0;y.materialId.length>I;I+=1)C.push(i||f);v.material=C}else if(p&&p[A])if(this.cacheSelectedObjectIds(A),xd.PickingEffect)for(var x=r._getOverrideMaterial(y),w=0;y.materialId.length>w;w+=1)C.push(i||x);else{for(var M=0;y.materialId.length>M;M+=1)C.push(i||o);v.material=C}else if(e.blinkMapComponentKeyToRenderState&&e.blinkMapComponentKeyToRenderState[A])Array.isArray(v.material)?v.material.fill(e.blinkMapMaterialNameToMaterial[e.blinkMapComponentKeyToMaterialName[A]]):v.material=e.blinkMapMaterialNameToMaterial[e.blinkMapComponentKeyToMaterialName[A]];else if(g&&g[A]){for(var E=0;y.materialId.length>E;E+=1)if(d[A]){var B=r._getMaterialByName(d[A]),S=a.getHoverMaterial(i||B);C.push(S)}else{var b=a.getHoverMaterial(i||c[y.materialId[E]]);C.push(b)}v.material=C}else if(u&&u[A]){for(var k=0;y.materialId.length>k;k+=1)C.push(i||f);v.material=C}else if(d&&d[A]){for(var D=0;y.materialId.length>D;D+=1)if(Array.isArray(d[A])){(T=c[y.materialId[D]])||(T=r._getMaterialByName(d[A][D])),C.push(i||T)}else{var T=r._getMaterialByName(d[A]);C.push(i||T)}v.material=C}else{for(var R=0;y.materialId.length>R;R+=1){T=c[y.materialId[R]];C.push(i||T)}v.material=C}}}else Bu.error(A,"没有创建对应的mesh")}}}}}},AI.prototype._getUsableMaterial=function(e,t,i,n){var r=t.materialId,o=t.userId,a=e.materialManager.materials,s=e.manager.sceneState,l=e.manager.filter,c=null,h=s.isSelected(o);!0!==h||l._isPickable(t)||(h=!1),i?xd.PickingEffect?c=l._getOverrideMaterial(t):(c=l._getOverrideMaterial(t))&&!h||(c=i):n&&(c=l._getOverrideMaterial(t));var d=e.manager.getOverrideMaterialByNodeInfo(t);return c=c||d||a[r],xd.Hover&&!xd.EnableRenderPass&&s.hoverId===o&&!1===h&&(c=s.getHoverMaterial(c)),c},AI.prototype._dealMeshes=function(e,t,i,n,r){var o=this.getGeometryByNodeInfo(e,t),a=e.pool,s=0;if(Array.isArray(o))for(var l=0,c=o.length;c>l;l+=1){s=a.get({modelKey:e.modelKey,nodeId:t.nodeId,userId:t.userId,originalId:t.originalId,userData:t.userData,geometry:o[l],matrix:t.matrix,material:n,renderOrder:n.transparent?0:xd.MaximumDepth-t.cellDepth,visible:i}),null}else s=a.get({modelKey:e.modelKey,nodeId:t.nodeId,userId:t.userId,originalId:t.originalId,userData:t.userData,geometry:o,matrix:t.matrix,material:n,renderOrder:n.transparent?0:xd.MaximumDepth-t.cellDepth,visible:i});0>s||r.curOctantId!==t.octantId&&(s>0&&e.manager.addObjectRangeToOctantMap(r.curOctantId,r.octantStartIndex,s-1),r.octantStartIndex=s,r.curOctantId=t.octantId)},AI.prototype._dealLineSegments=function(e,t,i,n){var r=this.getGeometryByNodeInfo(e,t);if(r){var o=this._getLineSegmentsNodeGroup(e),a=this.lineNodes[t.nodeId];a||((a=new ov(r,n)).nodeId=t.nodeId,a.name=t.name,a.geometryId=t.geometryId,a.modelKey=e.modelKey,this.lineNodes[t.nodeId]=a),a.material=n,a.visible=i,o.add(a),a.updateMatrixWorld(!0),this._cacheActiveMesh(t.userId,t.nodeId,a)}},AI.prototype._frustumCull=function(e,t,i){var n=e.manager,r=t.getFrustum(),o=xd.OctantDepth,a=t.projScreenMatrix,s=new He;function l(e,t,i,n,r){var o=null;if(t&&i>e.depth&&(s.set(e.min,e.max),o=t.intersectsBox(s)),o){if(n){var c=s.applyMatrix4(a),h=c.getSize().length(),d=c.getCenter().z;e.priority=h/(d=d>1e-6?d:1e-6),r.push(e)}else r.push(e);for(var u=0,p=e.childOctants.length;p>u;u+=1)l(e.childOctants[u],t,i,n,r)}}(xd.DEBUG&&n.showOctreeBox(i),l(i,r,o,!0,this.visibleOctant),xd.OcclusionTranslucentEnabled)&&l(i,this.manager.getFrustumFromOcclusionCamera(),o,!1,this.occlusionVisibleOctant);return!0},AI.prototype._logicCull=function(e,t,i,n,r){var o=e.manager,a=o.filter,s=a._hasHiddenFileIdFilter(),l=a._hasOverrideMaterialFilter(),c=o.sceneState.selectionSet,h=a._hasRenderPromotionFilter(),d=this.nodePriority.high,u=this.nodePriority.medium,p=this.nodePriority.low,g=this.nodePriority.low.length,f=e.getModelDescriptor().getNodeInfosWithComponentKey();function m(e,t){if(!(s&&a._isHiddenFileId(e)||!1===a._isVisible(e)))if(c.hasOwnProperty(e.userId)||l&&a._hasHighPriorityOverrideMaterial(e))d.push(e);else{var i=!1;if(h&&a._isRenderPromotion(e)&&(i=!0),t){var r=e.userData,o=r?r.categoryId:void 0;o&&t[o]&&(i=!0)}i?u.push(e):g>n&&(p[n]=e,n+=1)}}var A=o.getCategoriesFromHighPriority("outer");!0===i&&(A=o.getCategoriesFromHighPriority("inner"));for(var y=0,v=0,C=0;r>C;C+=1){var I=null,x=0;t?(I=this.visibleOctant[C].octantId,x=this.visibleOctant[C].depth):I=C;var w=f[I];if(w){var M=this._getUsedNodeInfosByComponentKey(I);if(!M){for(y=0,v=w.length;v>y;y+=1){(B=w[y]).octantId=I,B.cellDepth=x,this._isSatisfied(e,B)&&this._cacheUsedNodeInfosByComponentKey(I,B)}M=this._getUsedNodeInfosByComponentKey(I)}if(M){var E=M.default;for(y=0,v=E.length;v>y;y+=1){var B;m(B=E[y],A)}}}}return Bu.timeEnd("collectNodeInfo"),n},AI.prototype._clearUsedNodeInfosObject=function(){for(var e in this.usedNodeInfosObject)delete this.usedNodeInfosObject[e].default,delete this.usedNodeInfosObject[e].instance,delete this.usedNodeInfosObject[e];this.usedNodeInfosObject={}},AI.prototype._getUsedNodeInfosByComponentKey=function(e){return this.usedNodeInfosObject[e]},AI.prototype._cacheUsedNodeInfosByComponentKey=function(e,t){this.usedNodeInfosObject[e]||(this.usedNodeInfosObject[e]={},this.usedNodeInfosObject[e].default=[],this.usedNodeInfosObject[e].instance=[]),this.usedNodeInfosObject[e].default.push(t)},AI.prototype._isSatisfied=function(e,t){var i=e.getLoadedUserIdsObject();return!i||Boolean(i[t.userId])},AI.prototype._logicCullWithFull=function(e,t){return this._logicCull(e,!1,!0,0,t)},AI.prototype._sortVisibleOctant=function(e,t){},AI.prototype._applyOcclusionTranslucent=function(e){if(xd.OcclusionTranslucentEnabled){var t=e.pool.getObjects(),i=e.manager.octantToObjectMap,n=this.occlusionVisibleOctant.length;if(n>0)for(var r=e.manager.getFrustumFromOcclusionCamera(),o=0;n>o;o+=1){var a=i[this.occlusionVisibleOctant[o].octantId];if(a&&a.length>0)for(var s=0,l=a.length;l>s;s+=2)for(var c=a[s];a[s+1]>=c;c+=1){var h=t[c][0];Zp.intersectObjectWithFrustum(h,r)&&this._overrideOcclusionMaterial(h)}}}},AI.prototype._overrideOcclusionMaterial=function(e,t){var i=t.material;if(i&&!1===i.transparent){var n=e.manager.acquireMaterial(),r=n.material;i.color?r.color.copy(i.color):n.resetColor(),r.opacity=xd.OcclusionOpacity,t.material=r,t.material.needsUpdate=!0}},AI.prototype._clearNodePriorityData=function(e){var t=this.nodePriority;t.high.length=0,t.medium.length=0,e&&(t.low.length=0)},AI.prototype._adjustLowNodePriorityLength=function(e){0===this.nodePriority.low.length&&(this.nodePriority.low.length=this.manager.getRenderableCount(e))},AI.prototype._clearLineSegmentsNodeGroup=function(e){this._getLineSegmentsNodeGroup(e).clear()},AI.prototype._getLineSegmentsNodeGroup=function(e){return e._getNodeGroup(Vp.LINESEGMENTS,{globalSpace:!0})},AI.prototype._isLineSegments=function(e){return e.type===Sv.EnumNodeItemType.LINE},AI.prototype.getBlinkMaterials=function(e){return this.blinkMaterials},AI.prototype._makeMesh=function(e,t,i){var n=e.modelKey,r=e.manager,o=e.getModelDescriptor().getStandardNodeInfos();if(o){t||(t=e.getModelDescriptor().getInstancedUserIds());for(var a=e.getModelDescriptor(),s=e._getNodeGroup(Vp.GEOMETRY,{globalSpace:!0}),l=e.materialManager.materials,c=0,h=t.length;h>c;c+=1){var d=e.getModelDescriptor().getNodeInfosByComponentKey(t[c]);if(!d||!d[0].mesh)for(var u=o[t[c]],p=0,g=u.length;g>p;p+=1){var f=u[p];if(f){var m=f.geometryId,A=this.getGeometryById(m);if(A){var y=f.materialId||a.referencedMeshCache.components[t[c]].matId,v=null;if(v=[],py(e.dataVersion,"1.0")||void 0===e.dataVersion){var C=l[y];if(f.materialId=[],!C)continue;if(Array.isArray(C))if(C.length>1)for(p=0;C.length>p;p+=1)f.materialId.push(y+"_"+p),l[y+"_"+p]=C[p];else l[y]=C[0],f.materialId.push(y);else f.materialId.push(y);for(p=0;f.materialId.length>p;p+=1)v.push(l[f.materialId[p]])}else for(p=0;y.length>p;p+=1){var I=l[y[p]];I||(I=cA.DefaultMaterial),v.push(I)}if(1>v.length){var x=Jy[f.type]?Jy[f.type].color:void 0;x||(Bu.log("Material not found for type: ",f.type),x=Jy.DEFAULT.color),x||(Bu.log("Default material not found for type: ",f.type),x=[1,1,1,1]);var w=new pi(x[0],x[1],x[2]),M=w.getHexString()+"_"+x[3],E=l[M];E||(E=new il({color:w}),1>x[3]&&(E.transparent=!0,E.opacity=x[3]),E.side=2,l[M]=E),A.groups=[{start:0,count:A.index.count,materialIndex:0}],f.materialId.push(M),v.push(E)}for(var B=0;v.length>B;B+=1)v[B].aoMap&&A.attributes.uv&&(A.attributes.uv2=A.attributes.uv);var S=new Bv(A,v),b={matrix:f.matrix,modelKey:n,name:f.name,key:f.componentKey,userData:{},typeEx:f.type};S.spawn(b),s.add(S),r.addMeshToOctantMap(n,f.componentKey,new wm(f.componentKey,S));var k={indexCount:A.index.count,indexStart:0,lightmapIdx:void 0,nodeId:f.componentKey,positionCount:3*A.attributes.position.count,positionStart:0,userId:f.componentKey};S._indicesGroup={},S._indicesGroup[f.componentKey]=[k],e.addMeshToInfoMap(f.componentKey,f.componentKey,S,k),S.geometryId=f.geometryId,this._cacheActiveMesh(f.userId,f.nodeId,S),m=null,y=null,b=null,v=null,A=null,S=null}}}}s.updateMatrixWorld(!0),i&&i()}},AI.prototype._makeSkinMesh=function(e,t,i){var n=e.modelKey,r=e.manager,o=e.getModelDescriptor().getStandardNodeInfos();if(o){t||(t=e.getModelDescriptor().getInstancedUserIds());for(var a=e.getModelDescriptor(),s=e.materialManager.materials,l=0,c=t.length;c>l;l+=1)for(var h=o[t[l]],d=0,u=h.length;u>d;d+=1){var p=h[d];if(p){var g=p.geometryId,f=this.getGeometryById(g);if(f){var m=p.materialId||a.referencedMeshCache.components[t[l]].matId,A=null;A=[];for(d=0;m.length>d;d+=1){var y=s[m[d]];y||(y=cA.DefaultMaterial),A.push(y)}if(1>A.length){var v=Jy[p.type]?Jy[p.type].color:void 0;v||(Bu.log("Material not found for type: ",p.type),v=Jy.DEFAULT.color),v||(Bu.log("Default material not found for type: ",p.type),v=[1,1,1,1]);var C=new pi(v[0],v[1],v[2]),I=C.getHexString()+"_"+v[3],x=s[I];x||(x=new il({color:C}),1>v[3]&&(x.transparent=!0,x.opacity=v[3]),x.side=2,s[I]=x),f.groups=[{start:0,count:f.index.count,materialIndex:0}],p.materialId.push(I),A.push(x)}for(var w=0;A.length>w;w+=1)A[w].aoMap&&(f.attributes.uv2=f.attributes.uv);var M=null;if("skinIndex"in f.attributes&&"skinWeight"in f.attributes){M=new mI(f,A);for(var E=0;A.length>E;E+=1)A[E].skinning=!0;console.log("SkinnedMesh 类型mesh")}else M=new Bv(f,A);var B={matrix:p.matrix,modelKey:n,name:p.name,key:p.componentKey,userData:{},typeEx:p.type};M.spawn(B),r.addMeshToOctantMap(n,p.componentKey,new wm(p.componentKey,M));var S={indexCount:f.index.count,indexStart:0,lightmapIdx:void 0,nodeId:p.componentKey,positionCount:f.attributes.position.count,positionStart:0,userId:p.componentKey};return M._indicesGroup={},M._indicesGroup[p.componentKey]=[S],e.addMeshToInfoMap(p.componentKey,p.componentKey,M,S),M.geometryId=p.geometryId,this._cacheActiveMesh(p.userId,p.nodeId,M),g=null,m=null,B=null,A=null,f=null,M}}}}},AI.prototype._readBufferInfo=function(e,t){var i=e.getModelDescriptor().getStandardNodeInfos();if(i){t||(t=e.getModelDescriptor().getInstancedUserIds());for(var n=e.getModelDescriptor(),r=e.materialManager.materials,o=e.materialManager.textures,a=0,s=t.length;s>a;a+=1)for(var l=i[t[a]],c=0,h=l.length;h>c;c+=1){var d=n.referencedMeshCache.components[l[c].componentKey],u=d.type;if(-1!==d.geoId){var p=this.getGeometryById(d.geoId);if(p||(p=this.getGeometryByNodeInfo(e,l[c])))if(gy(e.dataVersion,"2.0.0"));else{var g=r[d.matId];if(g){if(e.textureNeedsUpdate&&void 0!==e.dataVersion&&my(e.dataVersion,"2.0.0")&&(e.textureNeedsUpdate=!1,g.textures.length>0))if(g.materials.length>1)for(c=0;g.UVgroup.length>c;c+=1)for(A=(m=g.UVgroup[c]).start,y=m.count,v=m.textureIndex,a=0;g.groups.length>a;a+=1){x=(C=g.groups[a]).count,w=C.materialIndex;if((A===(I=C.start)||A+y===I+x||I>A&&y>x)&&y>=x){E=g.materials[w];(M=o[g.textures[v]])&&E&&(E.map=M)}}else g.materials[0].map=o[g.textures[0]]}else if(g=this._readMaterialBuffer(d.matId,e)){if(0===g.materials.length){(C=Jy[u]?Jy[u].color:void 0)||(Bu.log("Material not found for type: ",u),C=Jy.DEFAULT.color),C||Bu.log("Default material not found for type: ",u);var f=new il({color:new pi(C[0],C[1],C[2])});1>C[3]&&(f.transparent=!0,f.opacity=C[3]),f.side=2,g.materials.push(f),g.groups.push({start:0,count:h=p.index.count,materialIndex:0})}if(g.textures.length>0)if(g.materials.length>1)for(var c=0;g.UVgroup.length>c;c+=1)for(var m,A=(m=g.UVgroup[c]).start,y=m.count,v=m.textureIndex,a=0;g.groups.length>a;a+=1){var C,I,x=(C=g.groups[a]).count,w=C.materialIndex;if((A===(I=C.start)||A+y===I+x||I>A&&y>x)&&y>=x){var M,E=g.materials[w];(M=o[g.textures[v]])&&E&&(E.map=M)}}else g.materials[0].map=o[g.textures[0]];p&&g&&(p.groups=g.groups),r[d.matId]=g.materials}}}else Bu.debug("实体没有几何")}}},AI.prototype.createMeshNodes=function(e,t){this._readBufferInfo(e,t),e.hasAnimation&&xd.EnableAnimation?this._makeSkinMesh(e):this._makeMesh(e)},AI.prototype.asyncCreateMeshNodes=function(e,t,i){this._readBufferInfo(e,t),e.hasAnimation&&xd.EnableAnimation?i&&i():this._makeMesh(e,t,i)},AI.prototype._readMaterialBuffer=function(e,t){var i=t.getModelDescriptor().referencedMeshCache.materials[e];if(!i)return null;var n=i.color,r=i.colorIndex,o=i.texture,a=i.textureIndex,s=[],l=[],c=[];if(new Dl,n.length>4){for(var h=0;n.length/4>h;h+=1){var d=new il({color:new pi(n[4*h],n[4*h+1],n[4*h+2])});1>n[4*h+3]&&(d.transparent=!0,d.opacity=n[4*h+3]),d.side=2,s.push(d),d=null}for(var u=null,p=void 0,g=0;r.length>g;g+=1){var f=r[g];f!==p&&(p=f,null!=u&&(u.count=3*g-u.start,l.push(u)),u={start:3*g,materialIndex:p})}null!=u&&(u.count=3*r.length-u.start,l.push(u))}else if(4===n.length){var m=new il({color:new pi(n[0],n[1],n[2])});1>n[3]&&(m.transparent=!0,m.opacity=n[3]),m.side=2,s.push(m),l.push({start:0,count:3*r.length,materialIndex:0})}for(var A=null,y=void 0,v=a,C=0;v.length>C;C+=1){var I=v[C];I!==y&&(y=I,null!=A&&(A.count=3*C-A.start,c.push(A)),A={start:3*C,textureIndex:y})}return null!=A&&(A.count=3*v.length-A.start,c.push(A)),{materials:s,groups:l,textures:o,UVgroup:c}},AI.prototype.clearSelectedObjectIds=function(){this.selectedObjectIds.length=0},AI.prototype.cacheSelectedObjectIds=function(e){this.selectedObjectIds.push(e)},AI.prototype.adjustVisibility=function(e,t){var i=this._getNodeGroup(e),n=i.visible;t&&!i.bVisible||(i.visible=t),i.bVisible=n},AI.prototype.changeVisibilityOfSelectedObjects=function(e,t){var i=e.manager,n=i.octantToObjectMap[e.modelKey].mesh;this.selectedMeshes.length=0;for(var r=0,o=this.selectedObjectIds.length;o>r;r+=1){var a=this.selectedObjectIds[r],s=n[a][0];s&&(i.filter._isVisible({userId:a})&&(s.visible=t))}},AI.prototype.changeVisibilityOfNonSelectedObjects=function(e,t){var i=e.manager,n=i.octantToObjectMap[e.modelKey].mesh;this.selectedMeshes.length=0;for(var r={},o=0,a=this.selectedObjectIds.length;a>o;o+=1){r[this.selectedObjectIds[o]]=!0}for(var s in n)if(n.hasOwnProperty(s)&&!r[s]){var l=n[s][0];if(!l)continue;if(!i.filter._isVisible({userId:s}))continue;l.visible=t}},AI.prototype.restoreVisibilityOfObjects=function(){this.selectedMeshes.length=0,this.nonSelectedMeshes.length=0},AI.prototype._getNodeGroup=function(e){return e._getNodeGroup(Vp.GEOMETRY,{globalSpace:!0})},AI.prototype.getMeshesByUserIds=function(e,t){var i=t,n=e.getModelDescriptor().getNodeInfosByComponentKey(i);if(n){for(var r=[],o=0,a=n.length;a>o;o+=1)for(var s=n[o],l=s.mesh,c=l._indicesGroup[i],h=0,d=c.length;d>h;h+=1){var u={};u.mesh=l,u.indexInfo=c[h],u.matrix=l.matrix.clone().multiply(e.getModelMatrix()),u.boundingBox=s.boundingBox.clone().applyMatrix4(u.matrix),r.push(u)}return r}return null},AI.prototype._getUsedGeometry=function(e,t){var i=null;if(!xd.Instance&&t.uvArrayBuffer){var n=t.geometryId+"|"+t.nodeId;if(i=this.getGeometryById(n))return i;var r=this._createGeometryByNodeInfo(e,t);r instanceof Array||(r=[r]),i=[];for(var o=new De,a=new Ke,s=t.uvArrayBuffer,l=0,c=r.length;c>l;l+=1){var h=new Ni;h.setIndex(r[l].index),h.setAttribute("position",r[l].attributes.position,3),h.setAttribute("normal",r[l].attributes.normal,3),o.set(s[6*l],s[6*l+2],s[6*l+4],s[6*l+1],s[6*l+3],s[6*l+5],0,0,1);for(var d=[],u=r[l].attributes.uv.array,p=0,g=u.length;g>p;p+=2)a.set(u[p],u[p+1],1),a.applyMatrix3(o),d.push(a.x),d.push(a.y);h.setAttribute("uv",new Bi(d,2)),i.push(h)}this._cacheGeometry(n,i)}else i=this.getGeometryByNodeInfo(e,t);return i},AI.prototype.getGeometryBuffersByUserId=function(e,t){var i=e.getModelDescriptor().getStandardNodeInfosById(t);if(!i)return[];for(var n=[],r=e.getDatabagId(),o=0,a=i.length;a>o;o+=1){var s=i[o],l=this.getGeometryByNodeInfo(e,s);if(l){var c=this._isLines(s);if(l instanceof Array)for(var h=0,d=l.length;d>h;h+=1)n.push({isLines:c,modelKey:r,nodeId:s.nodeId,position:l[h].getAttribute("position").array,index:l[h].getIndex().array,matrix:s.matrix});else n.push({isLines:c,modelKey:r,nodeId:s.nodeId,position:l.getAttribute("position").array,index:l.getIndex().array,matrix:s.matrix})}}return n},AI.prototype.traverseActiveMeshMap=function(e,t){for(var i=0,n=(e=e||Object.keys(this.activeMeshMap)).length;n>i;i+=1){var r=e[i];if(this.activeMeshMap[r])for(var o=Object.keys(this.activeMeshMap[r]),a=0,s=o.length;s>a;a+=1){var l=o[a];t(r,l,this.activeMeshMap[r][l])}}},AI.prototype.getActiveMeshMapById=function(e){return this.activeMeshMap[e]},AI.prototype._clearActiveMeshMap=function(){this.activeMeshMap={}},AI.prototype._cacheActiveMesh=function(e,t,i){this.activeMeshMap[e]||(this.activeMeshMap[e]={}),this.activeMeshMap[e][t]||(this.activeMeshMap[e][t]=[]),this.activeMeshMap[e][t].push(i)},AI.prototype._isLines=function(e){return e.type===zy.EnumNodeItemType.LINE},AI.prototype.getPickingNodeGenerator=function(){return this.pickingNodeGenerator||(this.pickingNodeGenerator=new fI(this)),this.pickingNodeGenerator},AI.prototype.isPickableNode=function(e){return!this.filter||this.filter._isPickable({userId:e})};var yI=function(e){$y.call(this,e),this.nodeGroupName="PickingWireFrameGroup"};Object.assign(yI.prototype,$y.prototype),SA(yI,[{key:"disposePickingNodeById",value:function(e){for(var t=Object.keys(this.pickingNodeMap[e]),i=0,n=t.length;n>i;i+=1)for(var r=this.pickingNodeMap[e][t[i]],o=0,a=r.length;a>o;o+=1)r[o].material=null,r[o].geometry.dispose(),r[o]=null}},{key:"addToPickingNodeMap",value:function(e,t,i){this.pickingNodeMap||(this.pickingNodeMap={}),this.pickingNodeMap[e]||(this.pickingNodeMap[e]={}),this.pickingNodeMap[e][t]=i,this.addToPickingNodeGroup(i)}},{key:"removeFormPickingNodeGroup",value:function(e){if(this.pickingNodeGroup)for(var t=Object.keys(this.pickingNodeMap[e]),i=0,n=t.length;n>i;i+=1)for(var r=this.pickingNodeMap[e][t[i]],o=0,a=r.length;a>o;o+=1)this.pickingNodeGroup.remove(r[o])}},{key:"generatePickingMeshes",value:function(e){var t=this,i=this.manager;this.manager.manager.getMeshManager().traverseActiveMeshMap(e,(function(e,n,r){if(!(r&&r.length&&r[0].isLineSegments||t._isExistNode(e,n))){var o=0,a=0,s=r[0].geometryId,l=[];for(o=0,a=r.length;a>o;o+=1)l.push(r[o].geometry);var c=i._getWireframeGeometryById(s,l),h=[];for(o=0,a=c.length;a>o;o+=1){var d=new La(c[o],cA.DefaultMaterial);by.copyMeshProperties(d,r[o]),d.renderOrder=2,h.push(d)}t.addToPickingNodeMap(e,n,h)}}))}},{key:"_isExistNode",value:function(e,t){return!!(this.pickingNodeMap&&this.pickingNodeMap[e]&&this.pickingNodeMap[e][t])}},{key:"updatePickingMeshesState",value:function(e,t,i){if(this.pickingNodeMap)for(var n=this.pickingNodeMap,r=this.manager.manager.getMeshManager(),o=0,a=t.length;a>o;o+=1){var s=t[o];if(n[s]&&r.isPickableNode(s)){var l=r.getActiveMeshMapById(s);if(l)for(var c=Object.keys(n[s]),h=0,d=c.length;d>h;h+=1){var u=c[h];if(l[u]){var p=n[s][u];if(p)for(var g=0,f=p.length;f>g;g+=1)p[g].material=e,p[g].visible=!0}}}}}},{key:"resetPickingMeshesState",value:function(){if(this.pickingNodeMap)for(var e=this.pickingNodeMap,t=Object.keys(e),i=0,n=t.length;n>i;i+=1)for(var r=t[i],o=Object.keys(e[r]),a=0,s=o.length;s>a;a+=1)for(var l=e[r][o[a]],c=0,h=l.length;h>c;c+=1)l[c].visible=!1}},{key:"updatePickingMeshes",value:function(e,t,i){return this.generatePickingMeshes(t),this.resetPickingMeshesState(),this.updatePickingMeshesState(e,t,i),this.getPickingNodeGroup()}}]);var vI=function(e){this.manager=e,this.wireframeGeometries={},this.wireframeLineMeshes={}};vI.prototype._disposeGeometries=function(){for(var e in this.wireframeGeometries)this._disposeGeometry(e)},vI.prototype.destroy=function(){this.manager=null,this._clearWireframeLineMeshes(),this.wireframeLineMeshes=null,this._disposeGeometries(),this.wireframeGeometries=null},vI.prototype.clearData=function(){this._clearWireframeLineMeshes(),this._disposeGeometries()},vI.prototype.update=function(e,t){this.isActivateWireframe(e)?(this._clearWireframeGroupNode(e),this._generateWireframeNodes(e,t),this._getWireWireframeGroupNode(e).updateMatrixWorld(!0)):this._removeWireframeGroupNode(e)},vI.prototype._disposeGeometry=function(e){var t=this.wireframeGeometries[e];if(t){if(Array.isArray(t))for(var i=0,n=t.length;n>i;i+=1)t[i].dispose();else t.dispose();delete this.wireframeGeometries[e]}},vI.prototype._clearWireframeLineMeshes=function(){for(var e in this.wireframeLineMeshes)delete this.wireframeLineMeshes[e];this.wireframeLineMeshes={}},vI.prototype._clearWireframeGroupNode=function(e){this._getWireWireframeGroupNode(e).clear()},vI.prototype._removeWireframeGroupNode=function(e){e._removeNodeGroup(this._getWireframeGroupName(e))},vI.prototype.isActivateWireframe=function(e){return e.isActivateWireframe()},vI.prototype._getWireWireframeGroupNode=function(e){return e._getNodeGroup(this._getWireframeGroupName(e),{globalSpace:!0})},vI.prototype._getWireframeGeometryByNodeInfo=function(e,t){return this._getWireframeGeometryById(t.geometryId,this.manager.getGeometryByNodeInfo(e,t),e)},vI.prototype._getWireframeGeometryById=function(e,t,i){if(this.wireframeGeometries[e])return this.wireframeGeometries[e];var n=[],r=null,o=null;if(Array.isArray(t))for(var a=0,s=t.length;s>a;a+=1)o=af(t[a].attributes.position.array,t[a].index.array),(r=new Ni).setIndex(new Mi(o,1)),r.setAttribute("position",t[a].attributes.position,3),n.push(r);else o=af(t.attributes.position.array,t.index.array),(r=new Ni).setIndex(new Mi(o,1)),r.setAttribute("position",t.attributes.position,3),n.push(r);return this.wireframeGeometries[e]=n,this.wireframeGeometries[e]},vI.prototype._makeWireframeLineMeshes=function(e,t,i){var n=this.wireframeLineMeshes[t.nodeId];if(!n){n=this.wireframeLineMeshes[t.nodeId]=[];for(var r=this._getWireframeGeometryByNodeInfo(e,t),o=0,a=r.length;a>o;o+=1){var s=new La(r[o],this._getWireframeMaterial(e));s.name=t.nodeId+"_"+o,s.applyMatrix4(t.matrix),s.matrixAutoUpdate=!1,n.push(s)}t.wireframeMeshs=n}for(var l=0,c=n.length;c>l;l+=1)i.add(n[l])},vI.prototype._generateWireframeNodes=function(e,t){var i=this._getWireWireframeGroupNode(e),n=e.getModelDescriptor().getStandardNodeInfos();t||(t=e.getModelDescriptor().getStandardUserIds());for(var r,o,a=this.manager.getHiddenUserIds(),s=0;t.length>s;s+=1){var l=t[s],c=n[l][0];a[l]||(r=c,o=this._getFilter(e),r.type===Sv.EnumNodeItemType.LINE||xd.Instance&&("box"===r.geometryId||"boxM"===r.geometryId)||o._hasRenderWithBoardlineFilter()&&!o._isRenderWithBoardline(r)||this._makeWireframeLineMeshes(e,c,i))}},vI.prototype._getWireframeGroupName=function(e){return e._getWireframeGroupName()},vI.prototype._getWireframeMaterial=function(e){return e.getWireframeMaterial()},vI.prototype._getFilter=function(e){return e.manager.filter},vI.prototype.adjustVisibility=function(e,t){if(e.isActivateWireframe()){var i=this._getWireWireframeGroupNode(e),n=i.visible;t&&!i.bVisible||(i.visible=t),i.bVisible=n}},vI.prototype.changeVisibilityOfSelectedObjects=function(e,t){},vI.prototype.changeVisibilityOfNonSelectedObjects=function(e,t){this.adjustVisibility(e,t)},vI.prototype.restoreVisibilityOfObjects=function(){},vI.prototype.getPickingNodeGenerator=function(){return this.pickingNodeGenerator||(this.pickingNodeGenerator=new yI(this)),this.pickingNodeGenerator};var CI=function(e){this.meshManager=new AI(this),this.model=e,this.wireframeManager=new vI(this)};CI.prototype.destroy=function(){this.meshManager.destroy(),this.meshManager=null,this.wireframeManager.destroy(),this.wireframeManager=null},CI.prototype.clearData=function(){this.meshManager.clearData(),this.wireframeManager.clearData()},CI.prototype.disposeGeometry=function(e){this.meshManager.disposeGeometry(e)},CI.prototype.cullNodes=function(e,t){this.hasNodeInfo(e)&&this.meshManager.cullNodes(e,t)},CI.prototype.updateNodes=function(e,t){if(this.hasNodeInfo(e)){var i;i=this._collectModelFiltered(e),this.meshManager.update(e,t,i),this.wireframeManager.update(e,t)}},CI.prototype.applyFilter=function(e,t){if(this.hasNodeInfo(e)){var i=null;i=t||e.getModelDescriptor().getStandardUserIds();var n=e.getModelDescriptor().getStandardNodeInfos();this._collectFilteredUserIds(e.manager.filter,i,n),this._collectSelectedUserIds(e.manager.sceneState.selectionSet,n),this._collectHoveredUserIds(e.manager.sceneState.hoverId,n),this.updateNodes(e,t)}},CI.prototype.applySelection=function(e){if(this.hasNodeInfo(e)){var t=e.getModelDescriptor().getStandardNodeInfos();this._clearSelectedState(e),this._clearHoveredState(e),this._collectSelectedUserIds(e.manager.sceneState.selectionSet,t),this._collectHoveredUserIds(e.manager.sceneState.hoverId,t),this.updateNodes(e)}},CI.prototype.clearSelection=function(e){this._clearSelectedState(e),this.applyHover(e)},CI.prototype.applyHover=function(e){if(this.hasNodeInfo(e)){var t=e.getModelDescriptor().getStandardNodeInfos();this._clearHoveredState(e),this._collectHoveredUserIds(e.manager.sceneState.hoverId,t),this.updateNodes(e)}},CI.prototype.clearHover=function(e){this._clearHoveredState(e),this.updateNodes(e)},CI.prototype.applyBlink=function(e){},CI.prototype.clearBlink=function(e){},CI.prototype.getPriorityNodes=function(){return this.meshManager.getPriorityNodes()},CI.prototype.getGeometryByNodeInfo=function(e,t){return this.meshManager.getGeometryByNodeInfo(e,t)},CI.prototype.getRenderableCount=function(e){return e.renderableCount},CI.prototype.getLoader=function(e){return e.loader},CI.prototype.getContainsCamera=function(e){return e.containsCamera},CI.prototype.getFilter=function(e){return e.manager.filter},CI.prototype.hasNodeInfo=function(e){return!!e.getModelDescriptor().getStandardNodeInfos()},CI.prototype.createMeshNodes=function(e){this.meshManager.createMeshNodes(e)},CI.prototype.asyncCreateMeshNodes=function(e,t,i){this.meshManager.asyncCreateMeshNodes(e,t,i)},CI.prototype._collectFilteredUserIds=function(e,t,i){var n=e._hasHiddenFileIdFilter(),r=e._hasVisibleFilter(),o=e._hasOverrideMaterialFilter(),a=e._hasTransparentFilter();if(this.mapMaterialIdToUserIdsForFilter={},this.hiddenUserIdSetObject={},this.overrideUserIdSetObject={},this.transparentUserIdSetObject={},n||r||o||a)for(var s=0;t.length>s;s+=1){var l=t[s],c=i[l];if(c&&c.length)for(var h=0,d=c.length;d>h;h+=1){var u=c[h];if(n&&e._isHiddenFileId(u)||r&&!1===e._isVisible(u))this.hiddenUserIdSetObject[l]=!0;else if(a&&e._isTransparent(u))this.transparentUserIdSetObject[l]=!0;else if(o&&e._hasOverrideMaterial(u)){var p=e._getOverrideMaterial(u);if(Array.isArray(p)){for(var g=[],f=0,m=p.length;m>f;f++){var A=null!==p[f]?p[f].name:"";""!==A&&g.push(A)}this.overrideUserIdSetObject[l]=g}else{var y=null!==p?p.name:"";""!==y&&(this.overrideUserIdSetObject[l]=y)}}}}},CI.prototype._collectModelFiltered=function(e){var t=e.manager.filter,i=e.modelKey,n=t._hasModelOverrideMaterialFilter(),r=t._hasModelTransparentFilter(),o=e.manager.modelState.modelSelectionSet;return e.manager.modelState.hoverId===i?e.manager.modelState.getHoverMaterial():o.hasOwnProperty(e.modelKey)?e.manager.modelState.selectionMaterial:r&&t._isModelTransparent(i)?t._getMaterialByName("scene"):n&&t._hasModelOverrideMaterial(i)?t._getModelOverrideMaterial(i):null},CI.prototype._clearFilteredState=function(){this.hiddenUserIdSetObject={},this.overrideUserIdSetObject={},this.transparentUserIdSetObject={}},CI.prototype.getFilteredUserIds=function(){return this.mapMaterialIdToUserIdsForFilter},CI.prototype.getSelectedUserIds=function(){return this.mapMaterialIdToUserIdsForSelection},CI.prototype.getHoveredUserIds=function(){return this.mapMaterialIdToUserIdsForHover},CI.prototype.getBlinkedUserIds=function(){return this.mapBlinkUserIds},CI.prototype.getHiddenUserIds=function(){return this.hiddenUserIdSetObject},CI.prototype._collectSelectedUserIds=function(e,t){for(var i in this.selectedUserIdSetObject={},e)if(e.hasOwnProperty(i)){if(!t[i])continue;this.selectedUserIdSetObject[i]=!0}},CI.prototype._clearSelectedState=function(){this.selectedUserIdSetObject={}},CI.prototype._collectHoveredUserIds=function(e,t){if(this.hoveredUserIdSetObject={},e&&t[e]){var i=t[e];this.hoveredUserIdSetObject={},i&&(this.hoveredUserIdSetObject[e]=!0)}},CI.prototype._clearHoveredState=function(){this.hoveredUserIdSetObject={}},CI.prototype.getMeshesByUserIds=function(e,t){return this.meshManager.getMeshesByUserIds(e,t)},CI.prototype.adjustVisibility=function(e,t){this.meshManager.adjustVisibility(e,t),this.wireframeManager.adjustVisibility(e,t)},CI.prototype.changeVisibilityOfSelectedObjects=function(e,t){this.meshManager.changeVisibilityOfSelectedObjects(e,t),this.wireframeManager.changeVisibilityOfSelectedObjects(e,t)},CI.prototype.changeVisibilityOfNonSelectedObjects=function(e,t){this.meshManager.changeVisibilityOfNonSelectedObjects(e,t),this.wireframeManager.changeVisibilityOfNonSelectedObjects(e,t)},CI.prototype.restoreVisibilityOfObjects=function(){this.meshManager.restoreVisibilityOfObjects(),this.wireframeManager.restoreVisibilityOfObjects()},CI.prototype.isPickableNode=function(e){var t=this.getHiddenUserIds();if(t&&t[e])return!1;var i=this.getTransparentUserIds();return!(i&&i[e]&&!xd.EnableSelectionByTranslucent)},CI.prototype.isHiddenNode=function(e){var t=this.getHiddenUserIds();return!(!t||!t[e])},CI.prototype.getMeshManager=function(){return this.meshManager},CI.prototype.getWireFrameManager=function(){return this.wireframeManager},CI.prototype.getTransparentUserIds=function(){return this.transparentUserIdSetObject};var II=function(e){lu(i,e);var t=pu(i);function i(e){var n;return ru(this,i),(n=t.call(this,e)).tag="layer",n.defaultManager=new CI,n.instancedManager=new Kv,n.loader=new gI(du(n)),n}return i}(dI);II.prototype.destroy=function(){this.defaultManager.destroy(),this.defaultManager=null,this.instancedManager.destroy(),this.instancedManager=null},II.prototype.prepareData=function(e){},II.prototype.prepare=function(e){this.isAllReady()&&(this.model.getMaterialManager()._updateTextureMapping(),this.model.clearMeshFromOctantMap())},II.prototype.updateNodes=function(){},II.prototype.addNodeInfoToOctantMap=function(){},II.prototype.dealMeshNodes=function(e){e&&e()},II.prototype.disposeBufferAfterVbo=function(){},II.prototype.dealMeshNodes=function(e){this.model.getModelDescriptor().getInstancedUserIdsByCategory(this._loadedUserIds);var t=this.model,i=this;this.defaultManager.asyncCreateMeshNodes(t,t.getModelDescriptor().getStandardUserIds(),(function(){i.updateNodes(),e&&e()}))},II.prototype.unloadComponents=function(e,t){for(var i=this.model.modelKey,n=0,r=e.length;r>n;n+=1){var o=this.model.getModelDescriptor().getNodeInfosByComponentKey(e[n]);if(o){for(var a=0,s=o.length;s>a;a+=1){var l=o[a];if(l.mesh)this.defaultManager.meshManager.disposeGeometry(l.mesh.geometry.key),l.mesh.destroy()}this.model.manager.removeMeshFromOctantMap(i,e[n])}}this.model.getModelDescriptor().clearNodeInfoCacheByComponentsKey(e),t&&t()};var xI=function(e){Zy.call(this,e),this.instancedComponent={}};Object.assign(xI.prototype,Zy.prototype),xI.prototype.parseItemData=function(e){this._readMaterialBuffer(this.model),this._parseGeo(),xd.Instance&&this._parseInstanced();var t={},i=this.referencedMeshCache;for(var n in Bu.time("_readItemData"),i.components)i.components.hasOwnProperty(n)&&this._readItemData(t,n,n,void 0,0);Bu.timeEnd("_readItemData"),t=null,e&&e()},xI.prototype._readItemData=function(e,t,i){var n=this.referencedMeshCache.components[t];void 0!==n&&this._readMeshInfo(e,i,n,null)},xI.prototype._readMeshInfo=function(e,t,i,n){var r=this.referencedMeshCache,o=this.model.materialManager.materials,a=null,s=null,l=this.model.subModel[i.subModel];if(i.nodes||i.nodeIds){s=i.originalId;var c=(new yt).fromArray(i.matrix||[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1]);i.matrix=c;var h=[];h=i.nodes?i.nodes:i.nodeIds;for(var d=0;h.length>d;d+=1){var u=h[d];if("object"!==nu(u)&&(u=this.getReferencedMeshComponentNodeById(u)),u){var p,g=null,f="";if(-1!==u.geoId)if((g=this._getMeshNodeAttr(u,i,d)).boundingBox.applyMatrix4(l),g){if(i.buildInCategory&&(g.buildInCategory=i.buildInCategory),!o[f=u.material]){var m=Jy[i.type]?Jy[i.type].color:void 0;m||(Bu.log("Material not found for type: ",i.type),m=Jy.DEFAULT.color),m||(Bu.log("Default material not found for type: ",i.type),m=[1,1,1,1]);var A=new pi(m[0],m[1],m[2]),y=f||A.getHexString()+"_"+m[3],v=o[y];v||(Bu.warn("缺少材质 "+f),v=cA.createStandardMaterial({color:A}),1>m[3]&&(v.transparent=!0,v.opacity=m[3]),v.side=2,o[y]=v),g.material=f=y}if(o[f].aoMap){var C=this.getReferencedMeshBufferById(g.geometryId);C&&(C.uv2=C.uv)}p=g.nodeId;var I=(R=this.userDataReader)?R.getUserData(a):null;g.type=i.type,g.userId=t,g.name=i.name,g.userDataId=a,g.originalId=s,g.materialId=f,g.originMId=f,g.userData=I,g.categoryId=0,g.componentKey=t,g.familyName=i.familyName,g.familySymbol=i.familySymbol;var x=xd.Instance,w=r.reuseNodes.hasOwnProperty(p);g.instanceOrNot=!(!x||!w),g.isBatched=!0,g.state=Nd.Visible,g.material=null,this._classifyNodeInfo(g),g=null}else Bu.debug("非法node")}}}else{var M=i,E="";if(null===n?(a=M.userDataId,s=M.originalId,E=M.materialId||M.matId):(a=n.userDataId,s=n.originalId,E=n.materialId>-1?n.materialId:M.materialId),M.materials||(M.materials=[]),M.materials.length>0)for(d=0;M.materials.length>d;d+=1){var B=null;if(B=this._getOldMeshNodeAttr(e,M,M.materials.length>1,d)){if(M.buildInCategory&&(B.buildInCategory=M.buildInCategory),B.boundingBox.applyMatrix4(l),!o[E=M.materials[d]]){var S=Jy[M.type]?Jy[M.type].color:void 0;S||(Bu.log("Material not found for type: ",M.type),S=Jy.DEFAULT.color),S||(Bu.log("Default material not found for type: ",M.type),S=[1,1,1,1]);var b=new pi(S[0],S[1],S[2]),k=E||b.getHexString()+"_"+S[3],D=o[k];D||(Bu.warn("缺少材质 "+E),D=cA.createStandardMaterial({color:b}),1>S[3]&&(D.transparent=!0,D.opacity=S[3]),D.side=2,o[k]=D)}if(o[E].aoMap){var T=this.getReferencedMeshBufferById(B.geometryId);T&&(T.uv2=T.uv)}if(!B)return;var R;I=(R=this.userDataReader)?R.getUserData(a):null;B.type=M.type,B.userId=M.key,B.name=M.name,B.userDataId=a,B.originalId=s,B.materialId=E,B.originMId=E,B.userData=I,B.categoryId=0,B.componentKey=M.key,B.familyName=M.familyName,B.familySymbol=M.familySymbol,xd.Instance&&this.instancedComponent[M.key]?B.instanceOrNot=!0:(B.instanceOrNot=!1,this.instancedGeo[B.originalGeometryId].length>1&&(B.originalGeometryId="")),B.state=Nd.Visible,B.material=null,B.isBatched=!0,this._classifyNodeInfo(B),B=null}else Bu.debug("非法node")}else{var U=null,F=Jy[M.type]?Jy[M.type].color:void 0;F||(Bu.log("Material not found for type: ",M.type),F=Jy.DEFAULT.color),F||(Bu.log("Default material not found for type: ",M.type),F=[1,1,1,1]);var Q=new pi(F[0],F[1],F[2]),L=Q.getHexString()+"_"+F[3],O=o[L];if(O||(O=cA.createStandardMaterial({color:Q}),1>F[3]&&(O.transparent=!0,O.opacity=F[3]),O.side=2,o[L]=O),M.materials.push(L),(U=this._getOldMeshNodeAttr(e,M,!1,0)).boundingBox.applyMatrix4(l),E=M.materials[0],!U)return;t=M.key;U.type=M.type,U.userId=t,U.name=M.name,U.originalId=s,U.materialId=E,U.originMId=E,U.userData={},U.categoryId=0,U.componentKey=t,U.familyName=M.familyName,U.familySymbol=M.familySymbol,U.instanceOrNot=!(!xd.Instance||!this.instancedComponent[t]),U.isBatched=!0,U.state=Nd.Visible,U.material=null,this._classifyNodeInfo(U),U=null}}},xI.prototype._getMeshNodeAttr=function(e,t,i){var n=new yt;n.fromArray(e.matrix||[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1]),xd.DataReduction&&n.scale(new Ke(1e3,1e3,1e3)),t&&n.multiplyMatrices(t.matrix,n),e.geoId=t.subModel+e.geoId;var r=e.nodeId,o=e.geoId;if(-1!==o){var a=e.maxBoundary||t.maxBoundary,s=e.minBoundary||t.minBoundary,l=new Nu;return l.set(s,a),{nodeId:r,guid:e.guid,geometryId:o,originalGeometryId:e.geoId,matrix:n,boundingBox:l,model:this.model}}},xI.prototype._getOldMeshNodeAttr=function(e,t,i,n){var r=new yt;r.fromArray(t.matrix||[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1]),xd.DataReduction&&r.scale(new Ke(1e3,1e3,1e3));var o=i?t.key+"_"+n:t.key,a=i?t.geoId+"_"+n:t.geoId;if(-1!==a){var s=new Nu,l=this.getReferencedMeshBufferById(t.geoId);return l&&l.position?(s=by.getBoundingBoxByBuffer(l.position)).applyMatrix4(r):Bu.warn("no position "),{nodeId:o,guid:t.guid,geometryId:a,originalGeometryId:t.geoId,matrix:r,boundingBox:s,model:this.model}}};var wI=function(e){lu(i,e);var t=pu(i);function i(e){var n;return ru(this,i),(n=t.call(this,e)).maxGeoLoadTaskCount=0,n.geoLoadTaskCount=0,n.taskInstancedGeometrieManager=new Uy(du(n),"geometrie"),n.descriptor=new xI(e.model),n}return i}(Wy);wI.prototype.loadData=function(){for(var e=this,t=this,i=this.model,n=i.getConfig(),r=!1,o=0,a=0,s=0,l=0,c=[],h=[],d=[],u=[],p=[],g=[],f=[],m=[],A=[],y=function(y,v){var C=n.children[y];if(x=n.animation,!(I=n.scene[y])||!I.components||!I.geometries&&(!I.batchedGeometries&&!I.instancedGeometries||1>I.batchedGeometries.length&&1>I.instancedGeometries.length)||!I.materials||!I.textures)return Bu.error("scene is null,modelKey is ",i.modelKey),i.dispatchEventEx({type:Fd.ON_LOAD_EMPTY_SCENE,modelKey:i.modelKey}),"continue";if(r=!0,o+=I.components.length||0,I.components.forEach((function(e){t.fileKeyFromModelKey[e]=C})),a+=I.materials.length||0,s+=I.textures.length||0,l+=I.reuseNodes&&I.reuseNodes.length||0,f=f.concat(I.textures),e.map=e.map||[],2>Number(I.geo))return Bu.error("不支持1.0版本的几何结构和其他版本混合加载。"),{v:void 0};if(c=c.concat(I.components),d=d.concat(I.materials),A=A.concat(I.reuseNodes||[]),Array.isArray(I.nodes)&&(h=h.concat(I.nodes)),f=f.concat(I.textures),I.map&&e.map.push(I.map),I.trees.length>0)for(w=0;I.trees.length>w;w+=1)"partition"===(M=I.trees[w]).type&&(m.push(M.fileKey),t.fileKeyFromModelKey[M.fileKey]=C);I.lights&&I.lights.length>0&&(g=g.concat(I.lights)),x&&(u.push(x.clips),p.push(x.nodes))},v=0,C=n.scene.length;C>v;v+=1){var I,x,w,M,E=y(v);if("continue"!==E&&"object"===nu(E))return E.v}if(i.setEmptyScene(!r),t.maxLoadTaskCount=0,t.maxLoadTaskCount+=o,t.maxLoadTaskCount+=a,t.maxLoadTaskCount+=m.length,t.maxLoadTaskCount+=l,t.maxLoadTaskCount+=h.length,t.maxLoadTaskCount+=g.length,1>t.maxLoadTaskCount)return Bu.info("Nothing to load ",i.modelKey),void i.dispatchEventEx({type:Qd.SCENE_NOTHING_TO_LOAD,modelKey:i.modelKey});t.progress.total+=t.maxLoadTaskCount,t.startCallback&&t.startCallback(),Bu.time("数据加载时间"),t._loadComponent(c),t._loadMaterial(d),t._loadComponentNode(h),t._loadReuseNode(A),xd.EnableTextureLoading&&s>0?(t.maxLoadTextureCount+=s,t._loadTextures(f)):t._onLoadTexture(),t._loadKDTree(m),g.length>0&&t._loadLights(g),t.offLine&&t.loadAttribute(),t.maxLoadTaskCount+=1,t.loadFloorInfo(t.model.modelKey,(function(){t._onTaskFinished()})),t.loadSceneAndGeos(n)},wI.prototype.loadReuseNode=function(e,t){var i=this,n=this.jsonLoader,r=this.model,o=this.url;n.setResponseType("json"),xd.useGzip&&n.setResponseType("arraybuffer"),n.setCacheViable(!0),n.load(o.mpkUrl(e),(function(e){i._parseReuseNodes(e),Bu.debug("component load from online"),t(),i._onTaskFinished()}),void 0,(function(e){r.dispatchEventEx({type:Qd.LOAD_COMPONENT_ERROR,modelKey:r.modelKey})}))},wI.prototype._parseComponent=function(e,t){var i=this.fileKeyFromModelKey[t]||"";if(e){var n=this.descriptor;if(n)for(var r in xd.useGzip&&(e=JSON.parse(wp.ab2str(pako.ungzip(e)))),e)if(e.hasOwnProperty(r)){var o=e[r];-1!==o.geoId&&(o.geoId=i+o.geoId,o.subModel=i),n.cacheReferencedMeshComponentData(e[r].key,e[r])}}else Bu.error("没有数据")},wI.prototype._parseMaterial=function(e,t){if(e){if(e instanceof ArrayBuffer)try{e=JSON.parse(wp.ab2str(e))}catch(e){Bu.error("处理材质出错")}var i=this.descriptor;if(i)for(var n in e)i.cacheReferencedMeshMaterialData(n,e[n])}else Bu.error("没有数据")},wI.prototype.loadBatchedGeometrie=function(e,t){var i=this,n=this.loader,r=this.url,o=this.model;n.setResponseType("arraybuffer"),n.setCacheViable(!this.offLine);var a=n.load(r.mpkUrl(e),(function(n){i._parseBatchedGeometrie(n,e),Bu.debug("geo load from online"),i._onGeoTaskFinished(),t()}),void 0,(function(e){o.dispatchEventEx({type:Qd.LOAD_GEOMETRY_ERROR,modelKey:o.modelKey}),t(),i._onGeoTaskFinished()}));i.requests.loadGeometrie=a},wI.prototype.loadInstancedGeometrie=function(e,t){var i=this,n=this.loader,r=this.url,o=this.model;n.setResponseType("arraybuffer"),n.setCacheViable(!this.offLine);var a=n.load(r.mpkUrl(e),(function(n){i._parseInstancedGeometrie(n,e),Bu.debug("geo load from online"),i._onGeoTaskFinished(),t()}),void 0,(function(e){o.dispatchEventEx({type:Qd.LOAD_GEOMETRY_ERROR,modelKey:o.modelKey}),t(),i._onGeoTaskFinished()}));i.requests.loadGeometrie=a},wI.prototype._parseBatchedGeometrie=function(e,t){var i=this.fileKeyFromModelKey[t]||"",n=new ky.BatchedGeometryReader(e,this.dataVersion),r=this.descriptor;if(r){for(var o=n.geoCount,a=0;o>a;a+=1){var s=n.geomMap[a];void 0!==s.position&&void 0!==s.index&&void 0!==s.normal?(s.geoId=i+s.geoId,r.cacheReferencedMeshBufferData(s.geoId,s),this.handler.createBatchedMeshNodes(s)):Bu.error("Error Geometry!")}this.model.manager.viewerImpl.render(),n=null}},wI.prototype._parseInstancedGeometrie=function(e,t){var i=this.fileKeyFromModelKey[t]||"",n=new ky.InstancedGeometryReader(e,this.dataVersion),r=this.descriptor;if(r){for(var o=n.geoCount,a=0;o>a;a+=1){var s=n.geomMap[a];void 0!==s.position&&void 0!==s.index&&void 0!==s.normal?(s.geoId=i+s.geoId,r.cacheReferencedMeshBufferData(s.geoId,s),this.handler.createInstancedMeshNodes(s)):Bu.error("Error Geometry!")}this.model.manager.viewerImpl.render(),n=null}},wI.prototype._parseReuseNodes=function(e,t){if(e){xd.useGzip&&(e=JSON.parse(wp.ab2str(pako.ungzip(e))));var i=this.descriptor;if(i)if(i.referencedMeshCache.reuseNodes)for(var n in e)i.referencedMeshCache.reuseNodes[n]=e[n];else i.referencedMeshCache.reuseNodes=e}else Bu.error("没有数据")},wI.prototype.startLoadSceneAndGeos=function(e){Bu.time("几何数据加载时间");for(var t=e.scene,i=this,n=0,r=0,o=[],a=[],s=function(s,l){var c=t[s],h=e.children[s];(c.batchedGeometries&&c.batchedGeometries.length>0||c.instancedGeometries&&c.instancedGeometries.length>0)&&(n+=c.batchedGeometries.length||0,r+=c.instancedGeometries.length||0,o=o.concat(c.batchedGeometries),a=a.concat(c.instancedGeometries),c.batchedGeometries.forEach((function(e){i.fileKeyFromModelKey[e]=h})),c.instancedGeometries.forEach((function(e){i.fileKeyFromModelKey[e]=h})))},l=0,c=t.length;c>l;l+=1)s(l);i.maxGeoLoadTaskCount+=n,i.maxGeoLoadTaskCount+=r,i.maxGeoLoadTaskCount>0||i._onGeoTaskFinished(),this._loadBatchedGeo(o),this._loadInstancedGeo(a)},wI.prototype.loadSceneAndGeos=function(e){for(var t=e.scene,i=this,n=0,r=[],o=function(o,a){var s=t[o],l=e.children[o];s.geometries&&s.geometries.length>0&&!(s.batchedGeometries&&s.batchedGeometries.length>0||s.instancedGeometries&&s.instancedGeometries.length>0)&&(n+=s.geometries.length||0,r=r.concat(s.geometries),s.geometries.forEach((function(e){i.fileKeyFromModelKey[e]=l})))},a=0,s=t.length;s>a;a+=1)o(a);i.maxLoadTaskCount+=n,this._loadGeo(r)},wI.prototype._loadBatchedGeo=function(e){var t=this;if(xd.getDataFromIndexedDB&&!this.offLine){for(var i=this.url,n=[],r=0;e.length>r;r+=1)n.push(i.mpkUrl(e[r]));var o=this.model.getStorage();o&&o.getBatch(n,(function(e){for(var i=function(i){if(e[n[i]])if(!0===e[n[i]].split){var r=e[n[i]].list,l=new Uint8Array(e[n[i]].length);o.getBatch(r,(function(e){for(var o=!0,a=0;r.length>a;a+=1)e[r[a]]?l.set(new Uint8Array(e[r[a]]),4e7*a):(o=!1,Bu.error("获取分割几何失败"));if(o){var s=n[i].indexOf("fileKey=");t._parseBatchedGeometrie(l.buffer,n[i].slice(s+8)),t._onGeoTaskFinished(),Bu.debug("load geo from local")}else{var c=t.taskGeometrieManager,h=n[i].indexOf("fileKey=");if(-1===h)return void Bu.error("url is not has fileKey");c.addTask(n[i].slice(h+8)),Bu.debug("load geo from net"),t.taskGeometrieManager.processTasks(t.loadBatchedGeometrie.bind(t))}}),(function(){Bu.error("获取分割几何失败")}))}else s=n[i].indexOf("fileKey="),t._parseBatchedGeometrie(e[n[i]],n[i].slice(s+8)),t._onGeoTaskFinished(),Bu.debug("load geo from local");else{if(a=t.taskGeometrieManager,-1===(s=n[i].indexOf("fileKey=")))return Bu.error("url is not has fileKey"),{v:void 0};a.addTask(n[i].slice(s+8)),Bu.debug("load geo from net")}},r=0;n.length>r;r+=1){var a,s,l=i(r);if("object"===nu(l))return l.v}t.taskGeometrieManager.processTasks(t.loadBatchedGeometrie.bind(t))}),(function(){for(var i=t.taskGeometrieManager,n=0;e.length>n;n+=1)i.addTask(e[n]);i.processTasks(t.loadBatchedGeometrie.bind(t))}))}else{for(var a=this.taskGeometrieManager,s=0;e.length>s;s+=1)a.addTask(e[s]);a.processTasks(t.loadBatchedGeometrie.bind(t))}},wI.prototype._loadInstancedGeo=function(e){var t=this;if(xd.getDataFromIndexedDB&&!this.offLine){for(var i=this.url,n=[],r=0;e.length>r;r+=1)n.push(i.mpkUrl(e[r]));var o=this.model.getStorage();o&&o.getBatch(n,(function(e){for(var i=function(i){if(e[n[i]])if(!0===e[n[i]].split){var r=e[n[i]].list,l=new Uint8Array(e[n[i]].length);o.getBatch(r,(function(e){for(var o=0;r.length>o;o+=1)e[r[o]]?l.set(new Uint8Array(e[r[o]]),4e7*o):Bu.error("获取分割几何失败");var a=n[i].indexOf("fileKey=");t._parseInstancedGeometrie(l.buffer,n[i].slice(a+8)),t._onGeoTaskFinished(),Bu.debug("load geo from local")}),(function(){Bu.error("获取分割几何失败")}))}else s=n[i].indexOf("fileKey="),t._parseInstancedGeometrie(e[n[i]],n[i].slice(s+8)),t._onGeoTaskFinished(),Bu.debug("load geo from local");else{if(a=t.taskInstancedGeometrieManager,-1===(s=n[i].indexOf("fileKey=")))return Bu.error("url is not has fileKey"),{v:void 0};a.addTask(n[i].slice(s+8)),Bu.debug("load geo from net")}},r=0;n.length>r;r+=1){var a,s,l=i(r);if("object"===nu(l))return l.v}t.taskInstancedGeometrieManager.processTasks(t.loadInstancedGeometrie.bind(t))}),(function(){for(var i=t.taskInstancedGeometrieManager,n=0;e.length>n;n+=1)i.addTask(e[n]);i.processTasks(t.loadInstancedGeometrie.bind(t))}))}else{for(var a=this.taskInstancedGeometrieManager,s=0;e.length>s;s+=1)a.addTask(e[s]);a.processTasks(t.loadInstancedGeometrie.bind(t))}},wI.prototype._onGeoTaskFinished=function(){(this.geoLoadTaskCount+=1,this.notifyProgress)&&(this.progressCallback&&this.progressCallback({total:this.maxLoadTaskCount+this.maxGeoLoadTaskCount,loaded:.8*(this.loadTaskCount+this.geoLoadTaskCount),modelKey:this.model.modelKey}));this.maxGeoLoadTaskCount>this.geoLoadTaskCount||(this.dataLoaded=!0,Bu.timeEnd("几何数据加载时间"),this.geoFinishCallback&&this.geoFinishCallback())},wI.prototype.getSceneTaskCount=function(e){var t=e.scenes;return t+=e.lines,t+=e.mpks,xd.BorderLineDelayLoaded||(t+=this.getAllBorderlineCount()),t},wI.prototype._parseKDTree=function(e,t){var i={};i="string"==typeof e?JSON.parse(e):e,this.model.kdTreeNode=this.model.kdTreeNode||[];var n=this.fileKeyFromModelKey[t]||"";if(i){var r=new jy;r.modelKey=n,r.init(i),this.model.kdTreeNode.push(r)}};var MI=function(e,t){_y.call(this,e),this.defaultManager=new Qv(t,e),this.instancedManager=new Kv(e),this.loader=new wI(this)};(MI.prototype=Object.create(_y.prototype)).prepare=function(e,t){this.isLoaded()&&!this.isHidden()&&(this.prepareWireframe(this.model,t),this.model.getMaterialManager(),this.model.getMaterialManager()._updateTextureMapping(),!this.model.lightmap||this.model.enableLightmap===xd.EnableLightmap&&this.model.lightmapIntensity===xd.LightmapIntensity||(this.model.enableLightmap=xd.EnableLightmap,this.model.lightmapIntensity=xd.LightmapIntensity,this.rebuildIndicesforLightmap(),this.updateNodes()))},MI.prototype.settleData=function(e){var t=this;this.addNodeInfoToOctantMap();var i=!1,n=!1;this.createMeshNodes((function(){i=!0,n&&(t.loaded=!0,t.model.getMaterialManager()._updateTextureMapping(),t.clearCachedData(t.model),e&&e())})),t.model.setLoaded(!0);this.loader.geoFinishCallback=function(){n=!0,i&&(t.loaded=!0,t.model.getMaterialManager()._updateTextureMapping(),t.clearCachedData(t.model),e&&e())},this.loader.startLoadSceneAndGeos(this.model.getConfig())},MI.prototype.addNodeInfoToOctantMap=function(){var e=this.model.manager,t=this.model.getEncodedDatabagId();this.loader.getDescriptor().traverseNodeInfosByComponent((function(i,n){e.addNodeInfoToOctantMap(t,i,n)}))},MI.prototype.createMeshNodes=function(e){var t=this,i=this.model;xd.stepLoad&&i.setLoaded(!0);var n=this.loader.getDescriptor();this.instancedManager.createMeshNodes(i,n.getInstancedUserIds()),this.defaultManager.asyncCreateMeshNodes(i,n.getStandardUserIds(),(function(){i.getMaterialManager()._updateTextureMapping(),t.loaded=!0,e&&e()}))},MI.prototype.clearCachedData=function(e){this.loader.getDescriptor().destroyReader(),this.loader.getDescriptor().clearReferencedMeshCache(),this.defaultManager.clearCachedData(),this.instancedManager.clearCachedData()},MI.prototype.createBatchedMeshNodes=function(e){this.defaultManager.createBatchedMeshNodes(this.model,e)},MI.prototype.createInstancedMeshNodes=function(e){this.instancedManager.createInstancedMeshNodes(this.model,e)};var EI=function(e){zy.call(this,e)};Object.assign(EI.prototype,zy.prototype);var BI=function(e){lu(i,e);var t=pu(i);function i(e){var n;return ru(this,i),(n=t.call(this,e)).descriptor=new EI(e.model),n}return i}(Wy);BI.prototype.loadSceneAndGeos=function(e){var t=e.scene,i=this.model,n=t.geometries.length||0,r=[];if(this.map={},my(this.dataVersion,"2.0.0"))for(var o=0;n>o;o+=1)t.geometries[o].fileKey?r.push(t.geometries[o].fileKey):i.dispatchEventEx({type:Qd.SCENE_NOT_CLOSE,modelKey:i.modelKey});else r=t.geometries;this.maxLoadTaskCount+=n,this._loadGeo(r)},BI.prototype.getSceneTaskCount=function(e){var t=e.scenes;return t+=e.lines,t+=e.mpks,xd.BorderLineDelayLoaded||(t+=this.getAllBorderlineCount()),t};var SI=function(e,t){_y.call(this,e),this.defaultManager=new CI(t,e),this.instancedManager=new Kv(e),this.loader=new BI(this)};Object.assign(SI.prototype,_y.prototype),SI.prototype.prepare=function(e){this.isLoaded()&&!this.isHidden()&&(this.model.getMaterialManager()._updateTextureMapping(),this.model.clearMeshFromOctantMap(),this.instancedManager.addAllInstanceNodeToScene(this.model),this.defaultManager.cullNodes(this.model,e),this.prepareWireframe(this.model),this.updateNodes())},SI.prototype.prepareWireframe=function(e,t){e.isActivateWireframe()&&this.instancedManager.generateWireframe(e)},SI.prototype.settleData=function(e){this.addNodeInfoToOctantMap(),this.createMeshNodes(e)},SI.prototype.addNodeInfoToOctantMap=function(){var e=this.model.manager,t=this.model.getEncodedDatabagId();this.model.getModelDescriptor().traverseNodeInfosByComponent((function(i,n){e.addNodeInfoToOctantMap(t,i,n)}))},SI.prototype.createMeshNodes=function(e){var t=this.model,i=this;this.instancedManager.createMeshNodes(this.model,this.model.getModelDescriptor().getInstancedUserIds()),this.defaultManager.asyncCreateMeshNodes(t,t.getModelDescriptor().getStandardUserIds(),(function(){t.getMaterialManager()._updateTextureMapping(),i.updateNodes(),t.getModelDescriptor().clearReferencedMeshCache(),i.loaded=!0,e&&e()}))},SI.prototype.disposeBufferAfterVbo=function(){},SI.prototype.explosion=function(e){if(this.isLoaded()){var t=this.model.getComponentlist();e.componentKey=t,this.componentsExplosion(e)}},SI.prototype.closeExplosion=function(){this.explosion({})},SI.prototype.componentsExplosion=function(e){if(this.isLoaded()){var t=e.coefficientX||1,i=e.coefficientY||1,n=e.coefficientZ||1,r=e.offsetX||0,o=e.offsetY||0,a=e.offsetZ||0,s=null;if(e.center)s=(new Ke).fromArray(e.center);else if(1!==t||1!==i||1!==n||0!==r||0!==o||0!==a)return;var l=this.model,c=l.manager,h=Array.isArray(e.componentKey)?e.componentKey:[e.componentKey],d=new Ke,u=new He,p=new Ke(0,0,0),g=new Ke(0,0,0),f=new Ke,m=l.getModelMatrix(),A=new yt;m&&s&&(A.copy(m).invert(),s.applyMatrix4(A));for(var y=0;h.length>y;y+=1){var v=h[y],C=l.getComponentInfo(v);if(C&&C.length>0)for(var I=0,x=C.length;x>I;I+=1){var w=C[I],M=w.mesh;if(M){if(u.copy(w.boundingBox),u.getCenter(d),w.userData||(w.userData={}),p.set(0,0,0),g.set(0,0,0),1!==t||1!==i||1!==n||w.userData.explosionFactor){w.userData.explosionFactor||(w.userData.explosionFactor=new Ke(1,1,1),w.userData.explosionBaseDifference=d.sub(s).clone());var E=w.userData.explosionFactor,B=w.userData.explosionBaseDifference;p.set((t-E.x)*B.x,(i-E.y)*B.y,(n-E.z)*B.z),1===t&&1===i&&1===n?(w.userData.explosionFactor=void 0,w.userData.explosionBaseDifference=void 0):E.set(t,i,n)}if(0!==r||0!==o||0!==a||w.userData.explosionOffset){w.userData.explosionOffset||(w.userData.explosionOffset=new Ke(0,0,0));var S=w.userData.explosionOffset;g.set(r-S.x,o-S.y,a-S.z),0===r&&0===o&&0===a?w.userData.explosionOffset=void 0:S.set(r,o,a)}if(f.set(p.x+g.x,p.y+g.y,p.z+g.z),0!==f.x||0!==f.y||0!==f.z){w.userData.explosionFactor||w.userData.explosionOffset?c.explosionList[v]||(c.explosionList[v]=!0):delete c.explosionList[v],A.makeTranslation(f.x,f.y,f.z),w.transformation||(w.transformation=!0,w.transformationOriginalMatrix=w.matrix.clone(),w.applyMatrix=new yt,w.transformationOriginalBoundingBox=w.boundingBox.clone()),w.matrix.premultiply(A),w.applyMatrix.premultiply(A),w.boundingBox.copy(w.transformationOriginalBoundingBox).applyMatrix4(w.applyMatrix);var b=M.matrixAutoUpdate;M.matrixAutoUpdate=!1,M.applyMatrix4(A),M.updateMatrixWorld(!0),M.matrixAutoUpdate=b;var k=w.wireframeMeshs;if(k)for(var D=0,T=k.length;T>D;D+=1){var R=k[D];b=R.matrixAutoUpdate,R.matrixAutoUpdate=!1,R.matrix.copy(M.matrix),R.updateMatrixWorld(!0),R.matrixAutoUpdate=b}}}}}}},SI.prototype.closeComponentsExplosion=function(e){var t=Array.isArray(e)?e:[e];this.componentsExplosion({componentKey:t})};const bI={chunkSize:524288,maxWorkers:"undefined"!=typeof navigator&&navigator.hardwareConcurrency||2,terminateWorkerTimeout:5e3,useWebWorkers:!0,workerScripts:void 0},kI=Object.assign({},bI);function DI(){return kI}function TI(e){if(void 0!==e.chunkSize&&(kI.chunkSize=e.chunkSize),void 0!==e.maxWorkers&&(kI.maxWorkers=e.maxWorkers),void 0!==e.terminateWorkerTimeout&&(kI.terminateWorkerTimeout=e.terminateWorkerTimeout),void 0!==e.useWebWorkers&&(kI.useWebWorkers=e.useWebWorkers),void 0!==e.Deflate&&(kI.Deflate=e.Deflate),void 0!==e.Inflate&&(kI.Inflate=e.Inflate),void 0!==e.workerScripts){if(e.workerScripts.deflate){if(!Array.isArray(e.workerScripts.deflate))throw new Error("workerScripts.deflate must be an array");kI.workerScripts||(kI.workerScripts={}),kI.workerScripts.deflate=e.workerScripts.deflate}if(e.workerScripts.inflate){if(!Array.isArray(e.workerScripts.inflate))throw new Error("workerScripts.inflate must be an array");kI.workerScripts||(kI.workerScripts={}),kI.workerScripts.inflate=e.workerScripts.inflate}}}const RI=[];for(let e=0;256>e;e++){let t=e;for(let e=0;8>e;e++)1&t?t=t>>>1^3988292384:t>>>=1;RI[e]=t}class UI{constructor(e){this.crc=e||-1}append(e){let t=0|this.crc;for(let i=0,n=0|e.length;n>i;i++)t=t>>>8^RI[255&(t^e[i])];this.crc=t}get(){return~this.crc}}const FI={concat(e,t){if(0===e.length||0===t.length)return e.concat(t);const i=e[e.length-1],n=FI.getPartial(i);return 32===n?e.concat(t):FI._shiftRight(t,n,0|i,e.slice(0,e.length-1))},bitLength(e){const t=e.length;if(0===t)return 0;return 32*(t-1)+FI.getPartial(e[t-1])},clamp(e,t){if(t>32*e.length)return e;const i=(e=e.slice(0,Math.ceil(t/32))).length;return t&=31,i>0&&t&&(e[i-1]=FI.partial(t,e[i-1]&2147483648>>t-1,1)),e},partial:(e,t,i)=>32===e?t:(i?0|t:t<<32-e)+1099511627776*e,getPartial:e=>Math.round(e/1099511627776)||32,_shiftRight(e,t,i,n){for(void 0===n&&(n=[]);t>=32;t-=32)n.push(i),i=0;if(0===t)return n.concat(e);for(let r=0;e.length>r;r++)n.push(i|e[r]>>>t),i=e[r]<<32-t;const r=FI.getPartial(e.length?e[e.length-1]:0);return n.push(FI.partial(t+r&31,t+r>32?i:n.pop(),1)),n}},QI={bytes:{fromBits(e){const t=FI.bitLength(e)/8,i=new Uint8Array(t);let n;for(let r=0;t>r;r++)0==(3&r)&&(n=e[r/4]),i[r]=n>>>24,n<<=8;return i},toBits(e){const t=[];let i,n=0;for(i=0;e.length>i;i++)n=n<<8|e[i],3==(3&i)&&(t.push(n),n=0);return 3&i&&t.push(FI.partial(8*(3&i),n)),t}}},LI={sha1:function(e){e?(this._h=e._h.slice(0),this._buffer=e._buffer.slice(0),this._length=e._length):this.reset()}};LI.sha1.prototype={blockSize:512,reset:function(){const e=this;return e._h=this._init.slice(0),e._buffer=[],e._length=0,e},update:function(e){const t=this;"string"==typeof e&&(e=QI.utf8String.toBits(e));const i=t._buffer=FI.concat(t._buffer,e),n=t._length,r=t._length=n+FI.bitLength(e);if(r>9007199254740991)throw new Error("Cannot hash more than 2^53 - 1 bits");const o=new Uint32Array(i);let a=0;for(let e=t.blockSize+n-(t.blockSize+n&t.blockSize-1);r>=e;e+=t.blockSize)t._block(o.subarray(16*a,16*(a+1))),a+=1;return i.splice(0,16*a),t},finalize:function(){const e=this;let t=e._buffer;const i=e._h;t=FI.concat(t,[FI.partial(1,1)]);for(let e=t.length+2;15&e;e++)t.push(0);for(t.push(Math.floor(e._length/4294967296)),t.push(0|e._length);t.length;)e._block(t.splice(0,16));return e.reset(),i},_init:[1732584193,4023233417,2562383102,271733878,3285377520],_key:[1518500249,1859775393,2400959708,3395469782],_f:function(e,t,i,n){return e>19?e>39?e>59?e>79?void 0:t^i^n:t&i|t&n|i&n:t^i^n:t&i|~t&n},_S:function(e,t){return t<<e|t>>>32-e},_block:function(e){const t=this,i=t._h,n=Array(80);for(let t=0;16>t;t++)n[t]=e[t];let r=i[0],o=i[1],a=i[2],s=i[3],l=i[4];for(let e=0;79>=e;e++){e>=16&&(n[e]=t._S(1,n[e-3]^n[e-8]^n[e-14]^n[e-16]));const i=t._S(5,r)+t._f(e,o,a,s)+l+n[e]+t._key[Math.floor(e/20)]|0;l=s,s=a,a=t._S(30,o),o=r,r=i}i[0]=i[0]+r|0,i[1]=i[1]+o|0,i[2]=i[2]+a|0,i[3]=i[3]+s|0,i[4]=i[4]+l|0}};const OI=class{constructor(e){const t=this;t._tables=[[[],[],[],[],[]],[[],[],[],[],[]]],t._tables[0][0][0]||t._precompute();const i=t._tables[0][4],n=t._tables[1],r=e.length;let o,a,s,l=1;if(4!==r&&6!==r&&8!==r)throw new Error("invalid aes key size");for(t._key=[a=e.slice(0),s=[]],o=r;4*r+28>o;o++){let e=a[o-1];(o%r==0||8===r&&o%r==4)&&(e=i[e>>>24]<<24^i[e>>16&255]<<16^i[e>>8&255]<<8^i[255&e],o%r==0&&(e=e<<8^e>>>24^l<<24,l=l<<1^283*(l>>7))),a[o]=a[o-r]^e}for(let e=0;o;e++,o--){const t=a[3&e?o:o-4];s[e]=4>=o||4>e?t:n[0][i[t>>>24]]^n[1][i[t>>16&255]]^n[2][i[t>>8&255]]^n[3][i[255&t]]}}encrypt(e){return this._crypt(e,0)}decrypt(e){return this._crypt(e,1)}_precompute(){const e=this._tables[0],t=this._tables[1],i=e[4],n=t[4],r=[],o=[];let a,s,l,c;for(let e=0;256>e;e++)o[(r[e]=e<<1^283*(e>>7))^e]=e;for(let h=a=0;!i[h];h^=s||1,a=o[a]||1){let o=a^a<<1^a<<2^a<<3^a<<4;o=o>>8^255&o^99,i[h]=o,n[o]=h,c=r[l=r[s=r[h]]];let d=16843009*c^65537*l^257*s^16843008*h,u=257*r[o]^16843008*o;for(let i=0;4>i;i++)e[i][h]=u=u<<24^u>>>8,t[i][o]=d=d<<24^d>>>8}for(let i=0;5>i;i++)e[i]=e[i].slice(0),t[i]=t[i].slice(0)}_crypt(e,t){if(4!==e.length)throw new Error("invalid aes block size");const i=this._key[t],n=i.length/4-2,r=[0,0,0,0],o=this._tables[t],a=o[0],s=o[1],l=o[2],c=o[3],h=o[4];let d,u,p,g=e[0]^i[0],f=e[t?3:1]^i[1],m=e[2]^i[2],A=e[t?1:3]^i[3],y=4;for(let e=0;n>e;e++)d=a[g>>>24]^s[f>>16&255]^l[m>>8&255]^c[255&A]^i[y],u=a[f>>>24]^s[m>>16&255]^l[A>>8&255]^c[255&g]^i[y+1],p=a[m>>>24]^s[A>>16&255]^l[g>>8&255]^c[255&f]^i[y+2],A=a[A>>>24]^s[g>>16&255]^l[f>>8&255]^c[255&m]^i[y+3],y+=4,g=d,f=u,m=p;for(let e=0;4>e;e++)r[t?3&-e:e]=h[g>>>24]<<24^h[f>>16&255]<<16^h[m>>8&255]<<8^h[255&A]^i[y++],d=g,g=f,f=m,m=A,A=d;return r}},NI=class{constructor(e,t){this._prf=e,this._initIv=t,this._iv=t}reset(){this._iv=this._initIv}update(e){return this.calculate(this._prf,e,this._iv)}incWord(e){if(255==(e>>24&255)){let t=e>>16&255,i=e>>8&255,n=255&e;255===t?(t=0,255===i?(i=0,255===n?n=0:++n):++i):++t,e=0,e+=t<<16,e+=i<<8,e+=n}else e+=1<<24;return e}incCounter(e){0===(e[0]=this.incWord(e[0]))&&(e[1]=this.incWord(e[1]))}calculate(e,t,i){let n;if(!(n=t.length))return[];const r=FI.bitLength(t);for(let r=0;n>r;r+=4){this.incCounter(i);const n=e.encrypt(i);t[r]^=n[0],t[r+1]^=n[1],t[r+2]^=n[2],t[r+3]^=n[3]}return FI.clamp(t,r)}},PI=class{constructor(e){const t=this,i=t._hash=LI.sha1,n=[[],[]],r=i.prototype.blockSize/32;t._baseHash=[new i,new i],e.length>r&&(e=i.hash(e));for(let t=0;r>t;t++)n[0][t]=909522486^e[t],n[1][t]=1549556828^e[t];t._baseHash[0].update(n[0]),t._baseHash[1].update(n[1]),t._resultHash=new i(t._baseHash[0])}reset(){const e=this;e._resultHash=new e._hash(e._baseHash[0]),e._updated=!1}update(e){this._updated=!0,this._resultHash.update(e)}digest(){const e=this,t=e._resultHash.finalize(),i=new e._hash(e._baseHash[1]).update(t).finalize();return e.reset(),i}},GI={name:"PBKDF2"},KI=Object.assign({hash:{name:"HMAC"}},GI),VI=Object.assign({iterations:1e3,hash:{name:"SHA-1"}},GI),YI=["deriveBits"],HI=[8,12,16],jI=[16,24,32],WI=[0,0,0,0],JI=QI.bytes,zI=OI,qI=NI,ZI=PI;class XI{constructor(e,t,i){Object.assign(this,{password:e,signed:t,strength:i-1,pendingInput:new Uint8Array(0)})}async append(e){const t=this;if(t.password){const i=ix(e,0,HI[t.strength]+2);await async function(e,t,i){await ex(e,i,ix(t,0,HI[e.strength]));const n=ix(t,HI[e.strength]),r=e.keys.passwordVerification;if(r[0]!=n[0]||r[1]!=n[1])throw new Error("Invalid pasword")}(t,i,t.password),t.password=null,t.aesCtrGladman=new qI(new zI(t.keys.key),Array.from(WI)),t.hmac=new ZI(t.keys.authentication),e=ix(e,HI[t.strength]+2)}return $I(t,e,new Uint8Array(e.length-10-(e.length-10)%16),0,10,!0)}flush(){const e=this,t=e.pendingInput,i=ix(t,0,t.length-10),n=ix(t,t.length-10);let r=new Uint8Array(0);if(i.length){const t=JI.toBits(i);e.hmac.update(t);const n=e.aesCtrGladman.update(t);r=JI.fromBits(n)}let o=!0;if(e.signed){const t=ix(JI.fromBits(e.hmac.digest()),0,10);for(let e=0;10>e;e++)t[e]!=n[e]&&(o=!1)}return{valid:o,data:r}}}class _I{constructor(e,t){Object.assign(this,{password:e,strength:t-1,pendingInput:new Uint8Array(0)})}async append(e){const t=this;let i=new Uint8Array(0);t.password&&(i=await async function(e,t){const i=crypto.getRandomValues(new Uint8Array(HI[e.strength]));return await ex(e,t,i),tx(i,e.keys.passwordVerification)}(t,t.password),t.password=null,t.aesCtrGladman=new qI(new zI(t.keys.key),Array.from(WI)),t.hmac=new ZI(t.keys.authentication));const n=new Uint8Array(i.length+e.length-e.length%16);return n.set(i,0),$I(t,e,n,i.length,0)}flush(){const e=this;let t=new Uint8Array(0);if(e.pendingInput.length){const i=e.aesCtrGladman.update(JI.toBits(e.pendingInput));e.hmac.update(i),t=JI.fromBits(i)}const i=ix(JI.fromBits(e.hmac.digest()),0,10);return{data:tx(t,i),signature:i}}}function $I(e,t,i,n,r,o){const a=t.length-r;let s;for(e.pendingInput.length&&(t=tx(e.pendingInput,t),i=function(e,t){if(t&&t>e.length){const i=e;(e=new Uint8Array(t)).set(i,0)}return e}(i,a-a%16)),s=0;a-16>=s;s+=16){const r=JI.toBits(ix(t,s,s+16));o&&e.hmac.update(r);const a=e.aesCtrGladman.update(r);o||e.hmac.update(a),i.set(JI.fromBits(a),s+n)}return e.pendingInput=ix(t,s),i}async function ex(e,t,i){const n=(new TextEncoder).encode(t),r=await crypto.subtle.importKey("raw",n,KI,!1,YI),o=await crypto.subtle.deriveBits(Object.assign({salt:i},VI),r,8*(2*jI[e.strength]+2)),a=new Uint8Array(o);e.keys={key:JI.toBits(ix(a,0,jI[e.strength])),authentication:JI.toBits(ix(a,jI[e.strength],2*jI[e.strength])),passwordVerification:ix(a,2*jI[e.strength])}}function tx(e,t){let i=e;return e.length+t.length&&(i=new Uint8Array(e.length+t.length),i.set(e,0),i.set(t,e.length)),i}function ix(e,t,i){return e.subarray(t,i)}class nx{constructor(e,t){Object.assign(this,{password:e,passwordVerification:t}),sx(this,e)}append(e){const t=this;if(t.password){const i=ox(t,e.subarray(0,12));if(t.password=null,i[11]!=t.passwordVerification)throw new Error("Invalid pasword");e=e.subarray(12)}return ox(t,e)}flush(){return{valid:!0,data:new Uint8Array(0)}}}class rx{constructor(e,t){Object.assign(this,{password:e,passwordVerification:t}),sx(this,e)}append(e){const t=this;let i,n;if(t.password){t.password=null;const r=crypto.getRandomValues(new Uint8Array(12));r[11]=t.passwordVerification,i=new Uint8Array(e.length+r.length),i.set(ax(t,r),0),n=12}else i=new Uint8Array(e.length),n=0;return i.set(ax(t,e),n),i}flush(){return{data:new Uint8Array(0)}}}function ox(e,t){const i=new Uint8Array(t.length);for(let n=0;t.length>n;n++)i[n]=cx(e)^t[n],lx(e,i[n]);return i}function ax(e,t){const i=new Uint8Array(t.length);for(let n=0;t.length>n;n++)i[n]=cx(e)^t[n],lx(e,t[n]);return i}function sx(e,t){e.keys=[305419896,591751049,878082192],e.crcKey0=new UI(e.keys[0]),e.crcKey2=new UI(e.keys[2]);for(let i=0;t.length>i;i++)lx(e,t.charCodeAt(i))}function lx(e,t){e.crcKey0.append([t]),e.keys[0]=~e.crcKey0.get(),e.keys[1]=dx(e.keys[1]+hx(e.keys[0])),e.keys[1]=dx(Math.imul(e.keys[1],134775813)+1),e.crcKey2.append([e.keys[1]>>>24]),e.keys[2]=~e.crcKey2.get()}function cx(e){const t=2|e.keys[2];return hx(Math.imul(t,1^t)>>>8)}function hx(e){return 255&e}function dx(e){return 4294967295&e}class ux{constructor(e,{signature:t,password:i,signed:n,compressed:r,zipCrypto:o,passwordVerification:a,encryptionStrength:s},{chunkSize:l}){const c=Boolean(i);Object.assign(this,{signature:t,encrypted:c,signed:n,compressed:r,inflate:r&&new e({chunkSize:l}),crc32:n&&new UI,zipCrypto:o,decrypt:c&&o?new nx(i,a):new XI(i,n,s)})}async append(e){const t=this;return t.encrypted&&e.length&&(e=await t.decrypt.append(e)),t.compressed&&e.length&&(e=await t.inflate.append(e)),(!t.encrypted||t.zipCrypto)&&t.signed&&e.length&&t.crc32.append(e),e}async flush(){const e=this;let t,i=new Uint8Array(0);if(e.encrypted){const t=e.decrypt.flush();if(!t.valid)throw new Error("Invalid signature");i=t.data}if((!e.encrypted||e.zipCrypto)&&e.signed){const i=new DataView(new Uint8Array(4).buffer);if(t=e.crc32.get(),i.setUint32(0,t),e.signature!=i.getUint32(0,!1))throw new Error("Invalid signature")}return e.compressed&&(i=await e.inflate.append(i)||new Uint8Array(0),await e.inflate.flush()),{data:i,signature:t}}}class px{constructor(e,{encrypted:t,signed:i,compressed:n,level:r,zipCrypto:o,password:a,passwordVerification:s,encryptionStrength:l},{chunkSize:c}){Object.assign(this,{encrypted:t,signed:i,compressed:n,deflate:n&&new e({level:r||5,chunkSize:c}),crc32:i&&new UI,zipCrypto:o,encrypt:t&&o?new rx(a,s):new _I(a,l)})}async append(e){const t=this;let i=e;return t.compressed&&e.length&&(i=await t.deflate.append(e)),t.encrypted&&i.length&&(i=await t.encrypt.append(i)),(!t.encrypted||t.zipCrypto)&&t.signed&&e.length&&t.crc32.append(e),i}async flush(){const e=this;let t,i=new Uint8Array(0);if(e.compressed&&(i=await e.deflate.flush()||new Uint8Array(0)),e.encrypted){i=await e.encrypt.append(i);const n=e.encrypt.flush();t=n.signature;const r=new Uint8Array(i.length+n.data.length);r.set(i,0),r.set(n.data,i.length),i=r}return e.encrypted&&!e.zipCrypto||!e.signed||(t=e.crc32.get()),{data:i,signature:t}}}var gx=(e,t,i,n,r,o,a)=>(Object.assign(e,{busy:!0,codecConstructor:t,options:Object.assign({},i),scripts:a,terminate(){e.worker&&!e.busy&&(e.worker.terminate(),e.interface=null)},onTaskFinished(){e.busy=!1,r(e)}}),o?function(e,t){let i;return e.interface||(e.worker=new Worker(new URL(e.scripts[0],"undefined"==typeof document&&"undefined"==typeof location?new(require("url").URL)("file:"+__filename).href:"undefined"==typeof document?location.href:document.currentScript&&document.currentScript.src||new URL("BOS3D.min.js",document.baseURI).href)),e.worker.addEventListener("message",(function(t){const n=t.data;if(i){const t=n.error,r=n.type;if(t){const n=new Error(t.message);n.stack=t.stack,i.reject(n),i=null,e.onTaskFinished()}else if("init"==r||"flush"==r||"append"==r){const t=n.data;"flush"==r?(i.resolve({data:new Uint8Array(t),signature:n.signature}),i=null,e.onTaskFinished()):i.resolve(t&&new Uint8Array(t))}}}),!1),e.interface={append:e=>n({type:"append",data:e}),flush:()=>n({type:"flush"})}),e.interface;async function n(n){if(!i){const i=e.options,n=e.scripts.slice(1);await r({scripts:n,type:"init",options:i,config:{chunkSize:t.chunkSize}})}return r(n)}function r(t){const n=e.worker,r=new Promise(((e,t)=>i={resolve:e,reject:t}));try{if(t.data)try{t.data=t.data.buffer,n.postMessage(t,[t.data])}catch(e){n.postMessage(t)}else n.postMessage(t)}catch(t){i.reject(t),i=null,e.onTaskFinished()}return r}}(e,n):function(e,t){const i=function(e,t,i){return t.codecType.startsWith("deflate")?new px(e,t,i):t.codecType.startsWith("inflate")?new ux(e,t,i):void 0}(e.codecConstructor,e.options,t);return{async append(t){try{return await i.append(t)}catch(t){throw e.onTaskFinished(),t}},async flush(){try{return await i.flush()}finally{e.onTaskFinished()}}}}(e,n));let fx=[],mx=[];function Ax(e){e.terminateTimeout&&(clearTimeout(e.terminateTimeout),e.terminateTimeout=null)}class yx{constructor(){this.size=0}init(){this.initialized=!0}}class vx extends yx{}class Cx extends yx{writeUint8Array(e){this.size+=e.length}}class Ix extends vx{constructor(e){super(),this.blob=e,this.size=e.size}async readUint8Array(e,t){const i=new FileReader;return new Promise(((n,r)=>{i.onload=e=>n(new Uint8Array(e.target.result)),i.onerror=()=>r(i.error),i.readAsArrayBuffer(this.blob.slice(e,e+t))}))}}class xx extends Cx{constructor(e){super(),this.offset=0,this.contentType=e,this.blob=new Blob([],{type:e})}async writeUint8Array(e){super.writeUint8Array(e),this.blob=new Blob([this.blob,e.buffer],{type:this.contentType}),this.offset=this.blob.size}getData(){return this.blob}}const wx="\0☺☻♥♦♣♠•◘○◙♂♀♪♫☼►◄↕‼¶§▬↨↑↓→←∟↔▲▼ !\"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}~⌂ÇüéâäàåçêëèïîìÄÅÉæÆôöòûùÿÖÜ¢£¥₧ƒáíóúñѪº¿⌐¬½¼¡«»░▒▓│┤╡╢╖╕╣║╗╝╜╛┐└┴┬├─┼╞╟╚╔╩╦╠═╬╧╨╤╥╙╘╒╓╫╪┘┌█▄▌▐▀αßΓπΣσµτΦΘΩδ∞φε∩≡±≥≤⌠⌡÷≈°∙·√ⁿ²■ ".split("");function Mx(e,t){if(e&&e.aborted)throw t.flush(),new Error("Abort error")}async function Ex(e,t){return t.length&&await e.writeUint8Array(t),t.length}const Bx=["filename","rawFilename","directory","encrypted","compressedSize","uncompressedSize","lastModDate","rawLastModDate","comment","rawComment","signature","extraField","rawExtraField","bitFlag","extraFieldZip64","extraFieldUnicodePath","extraFieldUnicodeComment","extraFieldAES","filenameUTF8","commentUTF8","offset","zip64","compressionMethod","extraFieldNTFS","lastAccessDate","creationDate","extraFieldExtendedTimestamp","version","versionMadeBy","msDosCompatible","internalFileAttribute","externalFileAttribute"];class Sx{constructor(e){Bx.forEach((t=>this[t]=e[t]))}}const bx="File format is not recognized",kx=["uncompressedSize","compressedSize","offset"];class Dx{constructor(e,t={}){Object.assign(this,{reader:e,options:t,config:DI()})}async getEntries(e={}){const t=this,i=t.reader;if(i.initialized||await i.init(),22>i.size)throw new Error(bx);const n=await async function(e,t,i,n,r){const o=new Uint8Array(4);!function(e,t,i){e.setUint32(0,101010256,!0)}(Yx(o));return await a(22)||await a(Math.min(1048582,i));async function a(t){const n=i-t,r=await Hx(e,n,t);for(let e=r.length-22;e>=0;e--)if(r[e]==o[0]&&r[e+1]==o[1]&&r[e+2]==o[2]&&r[e+3]==o[3])return{offset:n+e,buffer:r.slice(e,e+22).buffer}}}(i,0,i.size);if(!n)throw new Error("End of central directory not found");const r=Yx(n);let o=Kx(r,12),a=Kx(r,16),s=Gx(r,8),l=0;if(4294967295==a||65535==s){const e=Yx(await Hx(i,n.offset-20,20));if(117853008!=Kx(e,0))throw new Error("End of Zip64 central directory not found");a=Vx(e,8);let t=await Hx(i,a,56),r=Yx(t);const c=n.offset-20-56;if(101075792!=Kx(r,0)&&a!=c){const e=a;a=c,l=a-e,t=await Hx(i,a,56),r=Yx(t)}if(101075792!=Kx(r,0))throw new Error("End of Zip64 central directory locator not found");s=Vx(r,24),o=Kx(e,4),a-=Vx(r,40)}if(0>a||a>=i.size)throw new Error(bx);let c=0,h=await Hx(i,a,i.size-a),d=Yx(h);const u=n.offset-o;if(33639248!=Kx(d,c)&&a!=u){const e=a;a=u,l=a-e,h=await Hx(i,a,i.size-a),d=Yx(h)}if(0>a||a>=i.size)throw new Error(bx);const p=[];for(let n=0;s>n;n++){const r=new Tx(i,t.config,t.options);if(33639248!=Kx(d,c))throw new Error("Central directory header not found");Rx(r,d,c+6);const o=Boolean(r.bitFlag.languageEncodingFlag),a=c+46,u=a+r.filenameLength,g=u+r.extraFieldLength,f=Gx(d,c+4),m=0==(0&f);Object.assign(r,{versionMadeBy:f,msDosCompatible:m,compressedSize:0,uncompressedSize:0,commentLength:Gx(d,c+32),directory:m&&16==(16&Px(d,c+38)),offset:Kx(d,c+42)+l,internalFileAttribute:Kx(d,c+34),externalFileAttribute:Kx(d,c+38),rawFilename:h.subarray(a,u),filenameUTF8:o,commentUTF8:o,rawExtraField:h.subarray(u,g)});const A=g+r.commentLength;r.rawComment=h.subarray(g,A),r.filename=Lx(r.rawFilename,r.filenameUTF8?"utf-8":Qx(t,e,"filenameEncoding")),r.comment=Lx(r.rawComment,r.commentUTF8?"utf-8":Qx(t,e,"commentEncoding")),!r.directory&&r.filename.endsWith("/")&&(r.directory=!0),Ux(r,r,d,c+6);const y=new Sx(r);if(y.getData=(e,t)=>r.getData(e,y,t),p.push(y),c=A,e.onprogress)try{e.onprogress(n+1,s,new Sx(r))}catch(e){}}return p}async close(){}}class Tx{constructor(e,t,i){Object.assign(this,{reader:e,config:t,options:i})}async getData(e,t,i={}){const n=this,{reader:r,offset:o,extraFieldAES:a,compressionMethod:s,config:l,bitFlag:c,signature:h,rawLastModDate:d,compressedSize:u}=n,p=n.localDirectory={};r.initialized||await r.init();let g=await Hx(r,o,30);const f=Yx(g);let m=Qx(n,i,"password");if(m=m&&m.length&&m,a&&99!=a.originalCompressionMethod)throw new Error("Compression method not supported");if(0!=s&&8!=s)throw new Error("Compression method not supported");if(67324752!=Kx(f,0))throw new Error("Local file header not found");Rx(p,f,4),g=await Hx(r,o,30+p.filenameLength+p.extraFieldLength),p.rawExtraField=g.subarray(30+p.filenameLength),Ux(n,p,f,4),t.lastAccessDate=p.lastAccessDate,t.creationDate=p.creationDate;const A=n.encrypted&&p.encrypted,y=A&&!a;if(A){if(!y&&void 0===a.strength)throw new Error("Encryption method not supported");if(!m)throw new Error("File contains encrypted entry")}const v=await function(e,t,i){const n=!(!t.compressed&&!t.signed&&!t.encrypted)&&(t.useWebWorkers||void 0===t.useWebWorkers&&i.useWebWorkers),r=n&&i.workerScripts?i.workerScripts[t.codecType]:[];if(i.maxWorkers>fx.length){const a={};return fx.push(a),gx(a,e,t,i,o,n,r)}{const a=fx.find((e=>!e.busy));return a?(Ax(a),gx(a,e,t,i,o,n,r)):new Promise((i=>mx.push({resolve:i,codecConstructor:e,options:t,webWorker:n,scripts:r})))}function o(e){if(mx.length){const[{resolve:t,codecConstructor:n,options:r,webWorker:a,scripts:s}]=mx.splice(0,1);t(gx(e,n,r,i,o,a,s))}else e.worker?(Ax(e),Number.isFinite(i.terminateWorkerTimeout)&&i.terminateWorkerTimeout>=0&&(e.terminateTimeout=setTimeout((()=>{fx=fx.filter((t=>t!=e)),e.terminate()}),i.terminateWorkerTimeout))):fx=fx.filter((t=>t!=e))}}(l.Inflate,{codecType:"inflate",password:m,zipCrypto:y,encryptionStrength:a&&a.strength,signed:Qx(n,i,"checkSignature"),passwordVerification:y&&(c.dataDescriptor?d>>>8&255:h>>>24&255),signature:h,compressed:0!=s,encrypted:A,useWebWorkers:Qx(n,i,"useWebWorkers")},l);e.initialized||await e.init();const C=Qx(n,i,"signal"),I=o+30+p.filenameLength+p.extraFieldLength;return await async function(e,t,i,n,r,o,a){const s=Math.max(o.chunkSize,64);return async function o(l=0,c=0){const h=a.signal;if(r>l){Mx(h,e);const d=await t.readUint8Array(l+n,Math.min(s,r-l)),u=d.length;Mx(h,e);const p=await e.append(d);if(Mx(h,e),c+=await Ex(i,p),a.onprogress)try{a.onprogress(l+u,r)}catch(e){}return o(l+s,c)}{const t=await e.flush();return c+=await Ex(i,t.data),{signature:t.signature,length:c}}}()}(v,r,e,I,u,l,{onprogress:i.onprogress,signal:C}),e.getData()}}function Rx(e,t,i){const n=e.rawBitFlag=Gx(t,i+2),r=1==(1&n),o=Kx(t,i+6);Object.assign(e,{encrypted:r,version:Gx(t,i),bitFlag:{level:(6&n)>>1,dataDescriptor:8==(8&n),languageEncodingFlag:2048==(2048&n)},rawLastModDate:o,lastModDate:Ox(o),filenameLength:Gx(t,i+22),extraFieldLength:Gx(t,i+24)})}function Ux(e,t,i,n){const r=t.rawExtraField,o=t.extraField=new Map,a=Yx(new Uint8Array(r));let s=0;try{for(;r.length>s;){const e=Gx(a,s),t=Gx(a,s+2);o.set(e,{type:e,data:r.slice(s+4,s+4+t)}),s+=4+t}}catch(e){}const l=Gx(i,n+4);t.signature=Kx(i,n+10),t.uncompressedSize=Kx(i,n+18),t.compressedSize=Kx(i,n+14);const c=o.get(1);c&&(function(e,t){t.zip64=!0;const i=Yx(e.data);e.values=[];for(let t=0;t<Math.floor(e.data.length/8);t++)e.values.push(Vx(i,0+8*t));const n=kx.filter((e=>4294967295==t[e]));for(let t=0;n.length>t;t++)e[n[t]]=e.values[t];kx.forEach((i=>{if(4294967295==t[i]){if(void 0===e[i])throw new Error("Zip64 extra field not found");t[i]=e[i]}}))}(c,t),t.extraFieldZip64=c);const h=o.get(28789);h&&(Fx(h,"filename","rawFilename",t,e),t.extraFieldUnicodePath=h);const d=o.get(25461);d&&(Fx(d,"comment","rawComment",t,e),t.extraFieldUnicodeComment=d);const u=o.get(39169);u?(function(e,t,i){const n=Yx(e.data);e.vendorVersion=Px(n,0),e.vendorId=Px(n,2);const r=Px(n,4);e.strength=r,e.originalCompressionMethod=i,t.compressionMethod=e.compressionMethod=Gx(n,5)}(u,t,l),t.extraFieldAES=u):t.compressionMethod=l;const p=o.get(10);p&&(function(e,t){const i=Yx(e.data);let n,r=4;try{for(;e.data.length>r&&!n;){const t=Gx(i,r),o=Gx(i,r+2);1==t&&(n=e.data.slice(r+4,r+4+o)),r+=4+o}}catch(e){}try{if(n&&24==n.length){const i=Yx(n),r=i.getBigUint64(0,!0),o=i.getBigUint64(8,!0),a=i.getBigUint64(16,!0);Object.assign(e,{rawLastModDate:r,rawLastAccessDate:o,rawCreationDate:a});const s=Nx(r),l={lastModDate:s,lastAccessDate:Nx(o),creationDate:Nx(a)};Object.assign(e,l),Object.assign(t,l)}}catch(e){}}(p,t),t.extraFieldNTFS=p);const g=o.get(21589);g&&(function(e,t){const i=Yx(e.data),n=Px(i,0),r=[],o=[];1==(1&n)&&(r.push("lastModDate"),o.push("rawLastModDate")),2==(2&n)&&(r.push("lastAccessDate"),o.push("rawLastAccessDate")),4==(4&n)&&(r.push("creationDate"),o.push("rawCreationDate"));let a=1;r.forEach(((n,r)=>{if(e.data.length>=a+4){const s=Kx(i,a);t[n]=e[n]=new Date(1e3*s);e[o[r]]=s}a+=4}))}(g,t),t.extraFieldExtendedTimestamp=g)}function Fx(e,t,i,n,r){const o=Yx(e.data);e.version=Px(o,0),e.signature=Kx(o,1);const a=new UI;a.append(r[i]);const s=Yx(new Uint8Array(4));s.setUint32(0,a.get(),!0),e[t]=(new TextDecoder).decode(e.data.subarray(5)),e.valid=!r.bitFlag.languageEncodingFlag&&e.signature==Kx(s,0),e.valid&&(n[t]=e[t],n[t+"UTF8"]=!0)}function Qx(e,t,i){return void 0===t[i]?e.options[i]:t[i]}function Lx(e,t){return t&&"cp437"!=t.trim().toLowerCase()?new TextDecoder(t).decode(e):(e=>{let t="";for(let i=0;e.length>i;i++)t+=wx[e[i]];return t})(e)}function Ox(e){const t=(4294901760&e)>>16,i=65535&e;try{return new Date(1980+((65024&t)>>9),((480&t)>>5)-1,31&t,(63488&i)>>11,(2016&i)>>5,2*(31&i),0)}catch(e){}}function Nx(e){return new Date(Number(e/BigInt(1e4)-BigInt(116444736e5)))}function Px(e,t){return e.getUint8(t)}function Gx(e,t){return e.getUint16(t,!0)}function Kx(e,t){return e.getUint32(t,!0)}function Vx(e,t){return Number(e.getBigUint64(t,!0))}function Yx(e){return new DataView(e.buffer)}function Hx(e,t,i){return e.readUint8Array(t,i)}
/*
*@license
Copyright (c) 2021 Gildas Lormeau. All rights reserved.
Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions are met:
1. Redistributions of source code must retain the above copyright notice,
this list of conditions and the following disclaimer.
2. Redistributions in binary form must reproduce the above copyright
notice, this list of conditions and the following disclaimer in
the documentation and/or other materials provided with the distribution.
3. The names of the authors may not be used to endorse or promote products
derived from this software without specific prior written permission.
THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,
INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,
INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,
INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,
OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/(()=>{if("function"==typeof URL.createObjectURL){const e=(()=>{const e=[];for(let t=0;256>t;t++){let i=t;for(let e=0;8>e;e++)1&i?i=i>>>1^3988292384:i>>>=1;e[t]=i}class t{constructor(e){this.crc=e||-1}append(t){let i=0|this.crc;for(let n=0,r=0|t.length;r>n;n++)i=i>>>8^e[255&(i^t[n])];this.crc=i}get(){return~this.crc}}const i={concat(e,t){if(0===e.length||0===t.length)return e.concat(t);const n=e[e.length-1],r=i.getPartial(n);return 32===r?e.concat(t):i._shiftRight(t,r,0|n,e.slice(0,e.length-1))},bitLength(e){const t=e.length;if(0===t)return 0;return 32*(t-1)+i.getPartial(e[t-1])},clamp(e,t){if(t>32*e.length)return e;const n=(e=e.slice(0,Math.ceil(t/32))).length;return t&=31,n>0&&t&&(e[n-1]=i.partial(t,e[n-1]&2147483648>>t-1,1)),e},partial:(e,t,i)=>32===e?t:(i?0|t:t<<32-e)+1099511627776*e,getPartial:e=>Math.round(e/1099511627776)||32,_shiftRight(e,t,n,r){for(void 0===r&&(r=[]);t>=32;t-=32)r.push(n),n=0;if(0===t)return r.concat(e);for(let i=0;e.length>i;i++)r.push(n|e[i]>>>t),n=e[i]<<32-t;const o=i.getPartial(e.length?e[e.length-1]:0);return r.push(i.partial(t+o&31,t+o>32?n:r.pop(),1)),r}},n={bytes:{fromBits(e){const t=i.bitLength(e)/8,n=new Uint8Array(t);let r;for(let i=0;t>i;i++)0==(3&i)&&(r=e[i/4]),n[i]=r>>>24,r<<=8;return n},toBits(e){const t=[];let n,r=0;for(n=0;e.length>n;n++)r=r<<8|e[n],3==(3&n)&&(t.push(r),r=0);return 3&n&&t.push(i.partial(8*(3&n),r)),t}}},r={sha1:function(e){e?(this._h=e._h.slice(0),this._buffer=e._buffer.slice(0),this._length=e._length):this.reset()}};r.sha1.prototype={blockSize:512,reset:function(){const e=this;return e._h=this._init.slice(0),e._buffer=[],e._length=0,e},update:function(e){const t=this;"string"==typeof e&&(e=n.utf8String.toBits(e));const r=t._buffer=i.concat(t._buffer,e),o=t._length,a=t._length=o+i.bitLength(e);if(a>9007199254740991)throw new Error("Cannot hash more than 2^53 - 1 bits");const s=new Uint32Array(r);let l=0;for(let e=t.blockSize+o-(t.blockSize+o&t.blockSize-1);a>=e;e+=t.blockSize)t._block(s.subarray(16*l,16*(l+1))),l+=1;return r.splice(0,16*l),t},finalize:function(){const e=this;let t=e._buffer;const n=e._h;t=i.concat(t,[i.partial(1,1)]);for(let e=t.length+2;15&e;e++)t.push(0);for(t.push(Math.floor(e._length/4294967296)),t.push(0|e._length);t.length;)e._block(t.splice(0,16));return e.reset(),n},_init:[1732584193,4023233417,2562383102,271733878,3285377520],_key:[1518500249,1859775393,2400959708,3395469782],_f:function(e,t,i,n){return e>19?e>39?e>59?e>79?void 0:t^i^n:t&i|t&n|i&n:t^i^n:t&i|~t&n},_S:function(e,t){return t<<e|t>>>32-e},_block:function(e){const t=this,i=t._h,n=Array(80);for(let t=0;16>t;t++)n[t]=e[t];let r=i[0],o=i[1],a=i[2],s=i[3],l=i[4];for(let e=0;79>=e;e++){e>=16&&(n[e]=t._S(1,n[e-3]^n[e-8]^n[e-14]^n[e-16]));const i=t._S(5,r)+t._f(e,o,a,s)+l+n[e]+t._key[Math.floor(e/20)]|0;l=s,s=a,a=t._S(30,o),o=r,r=i}i[0]=i[0]+r|0,i[1]=i[1]+o|0,i[2]=i[2]+a|0,i[3]=i[3]+s|0,i[4]=i[4]+l|0}};const o={name:"PBKDF2"},a=Object.assign({hash:{name:"HMAC"}},o),s=Object.assign({iterations:1e3,hash:{name:"SHA-1"}},o),l=["deriveBits"],c=[8,12,16],h=[16,24,32],d=[0,0,0,0],u=n.bytes,p=class{constructor(e){const t=this;t._tables=[[[],[],[],[],[]],[[],[],[],[],[]]],t._tables[0][0][0]||t._precompute();const i=t._tables[0][4],n=t._tables[1],r=e.length;let o,a,s,l=1;if(4!==r&&6!==r&&8!==r)throw new Error("invalid aes key size");for(t._key=[a=e.slice(0),s=[]],o=r;4*r+28>o;o++){let e=a[o-1];(o%r==0||8===r&&o%r==4)&&(e=i[e>>>24]<<24^i[e>>16&255]<<16^i[e>>8&255]<<8^i[255&e],o%r==0&&(e=e<<8^e>>>24^l<<24,l=l<<1^283*(l>>7))),a[o]=a[o-r]^e}for(let e=0;o;e++,o--){const t=a[3&e?o:o-4];s[e]=4>=o||4>e?t:n[0][i[t>>>24]]^n[1][i[t>>16&255]]^n[2][i[t>>8&255]]^n[3][i[255&t]]}}encrypt(e){return this._crypt(e,0)}decrypt(e){return this._crypt(e,1)}_precompute(){const e=this._tables[0],t=this._tables[1],i=e[4],n=t[4],r=[],o=[];let a,s,l,c;for(let e=0;256>e;e++)o[(r[e]=e<<1^283*(e>>7))^e]=e;for(let h=a=0;!i[h];h^=s||1,a=o[a]||1){let o=a^a<<1^a<<2^a<<3^a<<4;o=o>>8^255&o^99,i[h]=o,n[o]=h,c=r[l=r[s=r[h]]];let d=16843009*c^65537*l^257*s^16843008*h,u=257*r[o]^16843008*o;for(let i=0;4>i;i++)e[i][h]=u=u<<24^u>>>8,t[i][o]=d=d<<24^d>>>8}for(let i=0;5>i;i++)e[i]=e[i].slice(0),t[i]=t[i].slice(0)}_crypt(e,t){if(4!==e.length)throw new Error("invalid aes block size");const i=this._key[t],n=i.length/4-2,r=[0,0,0,0],o=this._tables[t],a=o[0],s=o[1],l=o[2],c=o[3],h=o[4];let d,u,p,g=e[0]^i[0],f=e[t?3:1]^i[1],m=e[2]^i[2],A=e[t?1:3]^i[3],y=4;for(let e=0;n>e;e++)d=a[g>>>24]^s[f>>16&255]^l[m>>8&255]^c[255&A]^i[y],u=a[f>>>24]^s[m>>16&255]^l[A>>8&255]^c[255&g]^i[y+1],p=a[m>>>24]^s[A>>16&255]^l[g>>8&255]^c[255&f]^i[y+2],A=a[A>>>24]^s[g>>16&255]^l[f>>8&255]^c[255&m]^i[y+3],y+=4,g=d,f=u,m=p;for(let e=0;4>e;e++)r[t?3&-e:e]=h[g>>>24]<<24^h[f>>16&255]<<16^h[m>>8&255]<<8^h[255&A]^i[y++],d=g,g=f,f=m,m=A,A=d;return r}},g=class{constructor(e,t){this._prf=e,this._initIv=t,this._iv=t}reset(){this._iv=this._initIv}update(e){return this.calculate(this._prf,e,this._iv)}incWord(e){if(255==(e>>24&255)){let t=e>>16&255,i=e>>8&255,n=255&e;255===t?(t=0,255===i?(i=0,255===n?n=0:++n):++i):++t,e=0,e+=t<<16,e+=i<<8,e+=n}else e+=1<<24;return e}incCounter(e){0===(e[0]=this.incWord(e[0]))&&(e[1]=this.incWord(e[1]))}calculate(e,t,n){let r;if(!(r=t.length))return[];const o=i.bitLength(t);for(let i=0;r>i;i+=4){this.incCounter(n);const r=e.encrypt(n);t[i]^=r[0],t[i+1]^=r[1],t[i+2]^=r[2],t[i+3]^=r[3]}return i.clamp(t,o)}},f=class{constructor(e){const t=this,i=t._hash=r.sha1,n=[[],[]],o=i.prototype.blockSize/32;t._baseHash=[new i,new i],e.length>o&&(e=i.hash(e));for(let t=0;o>t;t++)n[0][t]=909522486^e[t],n[1][t]=1549556828^e[t];t._baseHash[0].update(n[0]),t._baseHash[1].update(n[1]),t._resultHash=new i(t._baseHash[0])}reset(){const e=this;e._resultHash=new e._hash(e._baseHash[0]),e._updated=!1}update(e){this._updated=!0,this._resultHash.update(e)}digest(){const e=this,t=e._resultHash.finalize(),i=new e._hash(e._baseHash[1]).update(t).finalize();return e.reset(),i}};class m{constructor(e,t,i){Object.assign(this,{password:e,signed:t,strength:i-1,pendingInput:new Uint8Array(0)})}async append(e){const t=this;if(t.password){const i=I(e,0,c[t.strength]+2);await async function(e,t,i){await v(e,i,I(t,0,c[e.strength]));const n=I(t,c[e.strength]),r=e.keys.passwordVerification;if(r[0]!=n[0]||r[1]!=n[1])throw new Error("Invalid pasword")}(t,i,t.password),t.password=null,t.aesCtrGladman=new g(new p(t.keys.key),Array.from(d)),t.hmac=new f(t.keys.authentication),e=I(e,c[t.strength]+2)}return y(t,e,new Uint8Array(e.length-10-(e.length-10)%16),0,10,!0)}flush(){const e=this,t=e.pendingInput,i=I(t,0,t.length-10),n=I(t,t.length-10);let r=new Uint8Array(0);if(i.length){const t=u.toBits(i);e.hmac.update(t);const n=e.aesCtrGladman.update(t);r=u.fromBits(n)}let o=!0;if(e.signed){const t=I(u.fromBits(e.hmac.digest()),0,10);for(let e=0;10>e;e++)t[e]!=n[e]&&(o=!1)}return{valid:o,data:r}}}class A{constructor(e,t){Object.assign(this,{password:e,strength:t-1,pendingInput:new Uint8Array(0)})}async append(e){const t=this;let i=new Uint8Array(0);t.password&&(i=await async function(e,t){const i=crypto.getRandomValues(new Uint8Array(c[e.strength]));return await v(e,t,i),C(i,e.keys.passwordVerification)}(t,t.password),t.password=null,t.aesCtrGladman=new g(new p(t.keys.key),Array.from(d)),t.hmac=new f(t.keys.authentication));const n=new Uint8Array(i.length+e.length-e.length%16);return n.set(i,0),y(t,e,n,i.length,0)}flush(){const e=this;let t=new Uint8Array(0);if(e.pendingInput.length){const i=e.aesCtrGladman.update(u.toBits(e.pendingInput));e.hmac.update(i),t=u.fromBits(i)}const i=I(u.fromBits(e.hmac.digest()),0,10);return{data:C(t,i),signature:i}}}function y(e,t,i,n,r,o){const a=t.length-r;let s;for(e.pendingInput.length&&(t=C(e.pendingInput,t),i=function(e,t){if(t&&t>e.length){const i=e;(e=new Uint8Array(t)).set(i,0)}return e}(i,a-a%16)),s=0;a-16>=s;s+=16){const r=u.toBits(I(t,s,s+16));o&&e.hmac.update(r);const a=e.aesCtrGladman.update(r);o||e.hmac.update(a),i.set(u.fromBits(a),s+n)}return e.pendingInput=I(t,s),i}async function v(e,t,i){const n=(new TextEncoder).encode(t),r=await crypto.subtle.importKey("raw",n,a,!1,l),o=await crypto.subtle.deriveBits(Object.assign({salt:i},s),r,8*(2*h[e.strength]+2)),c=new Uint8Array(o);e.keys={key:u.toBits(I(c,0,h[e.strength])),authentication:u.toBits(I(c,h[e.strength],2*h[e.strength])),passwordVerification:I(c,2*h[e.strength])}}function C(e,t){let i=e;return e.length+t.length&&(i=new Uint8Array(e.length+t.length),i.set(e,0),i.set(t,e.length)),i}function I(e,t,i){return e.subarray(t,i)}class x{constructor(e,t){Object.assign(this,{password:e,passwordVerification:t}),B(this,e)}append(e){const t=this;if(t.password){const i=M(t,e.subarray(0,12));if(t.password=null,i[11]!=t.passwordVerification)throw new Error("Invalid pasword");e=e.subarray(12)}return M(t,e)}flush(){return{valid:!0,data:new Uint8Array(0)}}}class w{constructor(e,t){Object.assign(this,{password:e,passwordVerification:t}),B(this,e)}append(e){const t=this;let i,n;if(t.password){t.password=null;const r=crypto.getRandomValues(new Uint8Array(12));r[11]=t.passwordVerification,i=new Uint8Array(e.length+r.length),i.set(E(t,r),0),n=12}else i=new Uint8Array(e.length),n=0;return i.set(E(t,e),n),i}flush(){return{data:new Uint8Array(0)}}}function M(e,t){const i=new Uint8Array(t.length);for(let n=0;t.length>n;n++)i[n]=b(e)^t[n],S(e,i[n]);return i}function E(e,t){const i=new Uint8Array(t.length);for(let n=0;t.length>n;n++)i[n]=b(e)^t[n],S(e,t[n]);return i}function B(e,i){e.keys=[305419896,591751049,878082192],e.crcKey0=new t(e.keys[0]),e.crcKey2=new t(e.keys[2]);for(let t=0;i.length>t;t++)S(e,i.charCodeAt(t))}function S(e,t){e.crcKey0.append([t]),e.keys[0]=~e.crcKey0.get(),e.keys[1]=D(e.keys[1]+k(e.keys[0])),e.keys[1]=D(Math.imul(e.keys[1],134775813)+1),e.crcKey2.append([e.keys[1]>>>24]),e.keys[2]=~e.crcKey2.get()}function b(e){const t=2|e.keys[2];return k(Math.imul(t,1^t)>>>8)}function k(e){return 255&e}function D(e){return 4294967295&e}class T{constructor(e,{signature:i,password:n,signed:r,compressed:o,zipCrypto:a,passwordVerification:s,encryptionStrength:l},{chunkSize:c}){const h=Boolean(n);Object.assign(this,{signature:i,encrypted:h,signed:r,compressed:o,inflate:o&&new e({chunkSize:c}),crc32:r&&new t,zipCrypto:a,decrypt:h&&a?new x(n,s):new m(n,r,l)})}async append(e){const t=this;return t.encrypted&&e.length&&(e=await t.decrypt.append(e)),t.compressed&&e.length&&(e=await t.inflate.append(e)),(!t.encrypted||t.zipCrypto)&&t.signed&&e.length&&t.crc32.append(e),e}async flush(){const e=this;let t,i=new Uint8Array(0);if(e.encrypted){const t=e.decrypt.flush();if(!t.valid)throw new Error("Invalid signature");i=t.data}if((!e.encrypted||e.zipCrypto)&&e.signed){const i=new DataView(new Uint8Array(4).buffer);if(t=e.crc32.get(),i.setUint32(0,t),e.signature!=i.getUint32(0,!1))throw new Error("Invalid signature")}return e.compressed&&(i=await e.inflate.append(i)||new Uint8Array(0),await e.inflate.flush()),{data:i,signature:t}}}class R{constructor(e,{encrypted:i,signed:n,compressed:r,level:o,zipCrypto:a,password:s,passwordVerification:l,encryptionStrength:c},{chunkSize:h}){Object.assign(this,{encrypted:i,signed:n,compressed:r,deflate:r&&new e({level:o||5,chunkSize:h}),crc32:n&&new t,zipCrypto:a,encrypt:i&&a?new w(s,l):new A(s,c)})}async append(e){const t=this;let i=e;return t.compressed&&e.length&&(i=await t.deflate.append(e)),t.encrypted&&i.length&&(i=await t.encrypt.append(i)),(!t.encrypted||t.zipCrypto)&&t.signed&&e.length&&t.crc32.append(e),i}async flush(){const e=this;let t,i=new Uint8Array(0);if(e.compressed&&(i=await e.deflate.flush()||new Uint8Array(0)),e.encrypted){i=await e.encrypt.append(i);const n=e.encrypt.flush();t=n.signature;const r=new Uint8Array(i.length+n.data.length);r.set(i,0),r.set(n.data,i.length),i=r}return e.encrypted&&!e.zipCrypto||!e.signed||(t=e.crc32.get()),{data:i,signature:t}}}const U={init(e){e.scripts&&e.scripts.length&&importScripts.apply(void 0,e.scripts);const t=e.options;let i;self.initCodec&&self.initCodec(),t.codecType.startsWith("deflate")?i=self.Deflate:t.codecType.startsWith("inflate")&&(i=self.Inflate),F=function(e,t,i){return t.codecType.startsWith("deflate")?new R(e,t,i):t.codecType.startsWith("inflate")?new T(e,t,i):void 0}(i,t,e.config)},append:async e=>({data:await F.append(e.data)}),flush:()=>F.flush()};let F;function Q(e){return e.map((([e,t])=>new Array(e).fill(t,0,e))).flat()}addEventListener("message",(async e=>{const t=e.data,i=t.type,n=U[i];if(n)try{t.data&&(t.data=new Uint8Array(t.data));const e=await n(t)||{};if(e.type=i,e.data)try{e.data=e.data.buffer,postMessage(e,[e.data])}catch(t){postMessage(e)}else postMessage(e)}catch(e){postMessage({type:i,error:{message:e.message,stack:e.stack}})}}));const L=[0,1,2,3].concat(...Q([[2,4],[2,5],[4,6],[4,7],[8,8],[8,9],[16,10],[16,11],[32,12],[32,13],[64,14],[64,15],[2,0],[1,16],[1,17],[2,18],[2,19],[4,20],[4,21],[8,22],[8,23],[16,24],[16,25],[32,26],[32,27],[64,28],[64,29]]));function O(){const e=this;function t(e,t){let i=0;do{i|=1&e,e>>>=1,i<<=1}while(--t>0);return i>>>1}e.build_tree=function(i){const n=e.dyn_tree,r=e.stat_desc.static_tree,o=e.stat_desc.elems;let a,s,l,c=-1;for(i.heap_len=0,i.heap_max=573,a=0;o>a;a++)0!==n[2*a]?(i.heap[++i.heap_len]=c=a,i.depth[a]=0):n[2*a+1]=0;for(;2>i.heap_len;)l=i.heap[++i.heap_len]=2>c?++c:0,n[2*l]=1,i.depth[l]=0,i.opt_len--,r&&(i.static_len-=r[2*l+1]);for(e.max_code=c,a=Math.floor(i.heap_len/2);a>=1;a--)i.pqdownheap(n,a);l=o;do{a=i.heap[1],i.heap[1]=i.heap[i.heap_len--],i.pqdownheap(n,1),s=i.heap[1],i.heap[--i.heap_max]=a,i.heap[--i.heap_max]=s,n[2*l]=n[2*a]+n[2*s],i.depth[l]=Math.max(i.depth[a],i.depth[s])+1,n[2*a+1]=n[2*s+1]=l,i.heap[1]=l++,i.pqdownheap(n,1)}while(i.heap_len>=2);i.heap[--i.heap_max]=i.heap[1],function(t){const i=e.dyn_tree,n=e.stat_desc.static_tree,r=e.stat_desc.extra_bits,o=e.stat_desc.extra_base,a=e.stat_desc.max_length;let s,l,c,h,d,u,p=0;for(h=0;15>=h;h++)t.bl_count[h]=0;for(i[2*t.heap[t.heap_max]+1]=0,s=t.heap_max+1;573>s;s++)l=t.heap[s],h=i[2*i[2*l+1]+1]+1,h>a&&(h=a,p++),i[2*l+1]=h,l>e.max_code||(t.bl_count[h]++,d=0,l>=o&&(d=r[l-o]),u=i[2*l],t.opt_len+=u*(h+d),n&&(t.static_len+=u*(n[2*l+1]+d)));if(0!==p){do{for(h=a-1;0===t.bl_count[h];)h--;t.bl_count[h]--,t.bl_count[h+1]+=2,t.bl_count[a]--,p-=2}while(p>0);for(h=a;0!==h;h--)for(l=t.bl_count[h];0!==l;)c=t.heap[--s],c>e.max_code||(i[2*c+1]!=h&&(t.opt_len+=(h-i[2*c+1])*i[2*c],i[2*c+1]=h),l--)}}(i),function(e,i,n){const r=[];let o,a,s,l=0;for(o=1;15>=o;o++)r[o]=l=l+n[o-1]<<1;for(a=0;i>=a;a++)s=e[2*a+1],0!==s&&(e[2*a]=t(r[s]++,s))}(n,e.max_code,i.bl_count)}}function N(e,t,i,n,r){const o=this;o.static_tree=e,o.extra_bits=t,o.extra_base=i,o.elems=n,o.max_length=r}function P(e,t,i,n,r){const o=this;o.good_length=e,o.max_lazy=t,o.nice_length=i,o.max_chain=n,o.func=r}O._length_code=[0,1,2,3,4,5,6,7].concat(...Q([[2,8],[2,9],[2,10],[2,11],[4,12],[4,13],[4,14],[4,15],[8,16],[8,17],[8,18],[8,19],[16,20],[16,21],[16,22],[16,23],[32,24],[32,25],[32,26],[31,27],[1,28]])),O.base_length=[0,1,2,3,4,5,6,7,8,10,12,14,16,20,24,28,32,40,48,56,64,80,96,112,128,160,192,224,0],O.base_dist=[0,1,2,3,4,6,8,12,16,24,32,48,64,96,128,192,256,384,512,768,1024,1536,2048,3072,4096,6144,8192,12288,16384,24576],O.d_code=function(e){return 256>e?L[e]:L[256+(e>>>7)]},O.extra_lbits=[0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0],O.extra_dbits=[0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13],O.extra_blbits=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,3,7],O.bl_order=[16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15],N.static_ltree=[12,8,140,8,76,8,204,8,44,8,172,8,108,8,236,8,28,8,156,8,92,8,220,8,60,8,188,8,124,8,252,8,2,8,130,8,66,8,194,8,34,8,162,8,98,8,226,8,18,8,146,8,82,8,210,8,50,8,178,8,114,8,242,8,10,8,138,8,74,8,202,8,42,8,170,8,106,8,234,8,26,8,154,8,90,8,218,8,58,8,186,8,122,8,250,8,6,8,134,8,70,8,198,8,38,8,166,8,102,8,230,8,22,8,150,8,86,8,214,8,54,8,182,8,118,8,246,8,14,8,142,8,78,8,206,8,46,8,174,8,110,8,238,8,30,8,158,8,94,8,222,8,62,8,190,8,126,8,254,8,1,8,129,8,65,8,193,8,33,8,161,8,97,8,225,8,17,8,145,8,81,8,209,8,49,8,177,8,113,8,241,8,9,8,137,8,73,8,201,8,41,8,169,8,105,8,233,8,25,8,153,8,89,8,217,8,57,8,185,8,121,8,249,8,5,8,133,8,69,8,197,8,37,8,165,8,101,8,229,8,21,8,149,8,85,8,213,8,53,8,181,8,117,8,245,8,13,8,141,8,77,8,205,8,45,8,173,8,109,8,237,8,29,8,157,8,93,8,221,8,61,8,189,8,125,8,253,8,19,9,275,9,147,9,403,9,83,9,339,9,211,9,467,9,51,9,307,9,179,9,435,9,115,9,371,9,243,9,499,9,11,9,267,9,139,9,395,9,75,9,331,9,203,9,459,9,43,9,299,9,171,9,427,9,107,9,363,9,235,9,491,9,27,9,283,9,155,9,411,9,91,9,347,9,219,9,475,9,59,9,315,9,187,9,443,9,123,9,379,9,251,9,507,9,7,9,263,9,135,9,391,9,71,9,327,9,199,9,455,9,39,9,295,9,167,9,423,9,103,9,359,9,231,9,487,9,23,9,279,9,151,9,407,9,87,9,343,9,215,9,471,9,55,9,311,9,183,9,439,9,119,9,375,9,247,9,503,9,15,9,271,9,143,9,399,9,79,9,335,9,207,9,463,9,47,9,303,9,175,9,431,9,111,9,367,9,239,9,495,9,31,9,287,9,159,9,415,9,95,9,351,9,223,9,479,9,63,9,319,9,191,9,447,9,127,9,383,9,255,9,511,9,0,7,64,7,32,7,96,7,16,7,80,7,48,7,112,7,8,7,72,7,40,7,104,7,24,7,88,7,56,7,120,7,4,7,68,7,36,7,100,7,20,7,84,7,52,7,116,7,3,8,131,8,67,8,195,8,35,8,163,8,99,8,227,8],N.static_dtree=[0,5,16,5,8,5,24,5,4,5,20,5,12,5,28,5,2,5,18,5,10,5,26,5,6,5,22,5,14,5,30,5,1,5,17,5,9,5,25,5,5,5,21,5,13,5,29,5,3,5,19,5,11,5,27,5,7,5,23,5],N.static_l_desc=new N(N.static_ltree,O.extra_lbits,257,286,15),N.static_d_desc=new N(N.static_dtree,O.extra_dbits,0,30,15),N.static_bl_desc=new N(null,O.extra_blbits,0,19,7);const G=[new P(0,0,0,0,0),new P(4,4,8,4,1),new P(4,5,16,8,1),new P(4,6,32,32,1),new P(4,4,16,16,2),new P(8,16,32,32,2),new P(8,16,128,128,2),new P(8,32,128,256,2),new P(32,128,258,1024,2),new P(32,258,258,4096,2)],K=["need dictionary","stream end","","","stream error","data error","","buffer error","",""];function V(e,t,i,n){const r=e[2*t],o=e[2*i];return o>r||r==o&&n[i]>=n[t]}function Y(){const e=this;let t,i,n,r,o,a,s,l,c,h,d,u,p,g,f,m,A,y,v,C,I,x,w,M,E,B,S,b,k,D,T,R,U;const F=new O,Q=new O,L=new O;let P,Y,H,j,W,J,z,q;function Z(){let t;for(t=0;286>t;t++)T[2*t]=0;for(t=0;30>t;t++)R[2*t]=0;for(t=0;19>t;t++)U[2*t]=0;T[512]=1,e.opt_len=e.static_len=0,H=W=0}function X(e,t){let i,n=-1,r=e[1],o=0,a=7,s=4;0===r&&(a=138,s=3),e[2*(t+1)+1]=65535;for(let l=0;t>=l;l++)i=r,r=e[2*(l+1)+1],++o<a&&i==r||(s>o?U[2*i]+=o:0!==i?(i!=n&&U[2*i]++,U[32]++):o>10?U[36]++:U[34]++,o=0,n=i,0===r?(a=138,s=3):i==r?(a=6,s=3):(a=7,s=4))}function _(t){e.pending_buf[e.pending++]=t}function $(e){_(255&e),_(e>>>8&255)}function ee(e,t){let i;const n=t;q>16-n?(i=e,z|=i<<q&65535,$(z),z=i>>>16-q,q+=n-16):(z|=e<<q&65535,q+=n)}function te(e,t){const i=2*e;ee(65535&t[i],65535&t[i+1])}function ie(e,t){let i,n,r=-1,o=e[1],a=0,s=7,l=4;for(0===o&&(s=138,l=3),i=0;t>=i;i++)if(n=o,o=e[2*(i+1)+1],++a>=s||n!=o){if(l>a)do{te(n,U)}while(0!=--a);else 0!==n?(n!=r&&(te(n,U),a--),te(16,U),ee(a-3,2)):a>10?(te(18,U),ee(a-11,7)):(te(17,U),ee(a-3,3));a=0,r=n,0===o?(s=138,l=3):n==o?(s=6,l=3):(s=7,l=4)}}function ne(){16==q?($(z),z=0,q=0):q>=8&&(_(255&z),z>>>=8,q-=8)}function re(t,i){let n,r,o;if(e.pending_buf[j+2*H]=t>>>8&255,e.pending_buf[j+2*H+1]=255&t,e.pending_buf[P+H]=255&i,H++,0===t?T[2*i]++:(W++,t--,T[2*(O._length_code[i]+256+1)]++,R[2*O.d_code(t)]++),0==(8191&H)&&S>2){for(n=8*H,r=I-A,o=0;30>o;o++)n+=R[2*o]*(5+O.extra_dbits[o]);if(n>>>=3,W<Math.floor(H/2)&&n<Math.floor(r/2))return!0}return H==Y-1}function oe(t,i){let n,r,o,a,s=0;if(0!==H)do{n=e.pending_buf[j+2*s]<<8&65280|255&e.pending_buf[j+2*s+1],r=255&e.pending_buf[P+s],s++,0===n?te(r,t):(o=O._length_code[r],te(o+256+1,t),a=O.extra_lbits[o],0!==a&&(r-=O.base_length[o],ee(r,a)),n--,o=O.d_code(n),te(o,i),a=O.extra_dbits[o],0!==a&&(n-=O.base_dist[o],ee(n,a)))}while(H>s);te(256,t),J=t[513]}function ae(){q>8?$(z):q>0&&_(255&z),z=0,q=0}function se(t,i,n){ee(0+(n?1:0),3),function(t,i,n){ae(),J=8,$(i),$(~i),e.pending_buf.set(l.subarray(t,t+i),e.pending),e.pending+=i}(t,i)}function le(t,i,n){let r,o,a=0;S>0?(F.build_tree(e),Q.build_tree(e),a=function(){let t;for(X(T,F.max_code),X(R,Q.max_code),L.build_tree(e),t=18;t>=3&&0===U[2*O.bl_order[t]+1];t--);return e.opt_len+=3*(t+1)+5+5+4,t}(),r=e.opt_len+3+7>>>3,o=e.static_len+3+7>>>3,r>=o&&(r=o)):r=o=i+5,i+4>r||-1==t?o==r?(ee(2+(n?1:0),3),oe(N.static_ltree,N.static_dtree)):(ee(4+(n?1:0),3),function(e,t,i){let n;for(ee(e-257,5),ee(t-1,5),ee(i-4,4),n=0;i>n;n++)ee(U[2*O.bl_order[n]+1],3);ie(T,e-1),ie(R,t-1)}(F.max_code+1,Q.max_code+1,a+1),oe(T,R)):se(t,i,n),Z(),n&&ae()}function ce(e){le(0>A?-1:A,I-A,e),A=I,t.flush_pending()}function he(){let e,i,n,r;do{if(r=c-w-I,0===r&&0===I&&0===w)r=o;else if(-1==r)r--;else if(I>=o+o-262){l.set(l.subarray(o,o+o),0),x-=o,I-=o,A-=o,e=p,n=e;do{i=65535&d[--n],d[n]=o>i?0:i-o}while(0!=--e);e=o,n=e;do{i=65535&h[--n],h[n]=o>i?0:i-o}while(0!=--e);r+=o}if(0===t.avail_in)return;e=t.read_buf(l,I+w,r),w+=e,w>=3&&(u=255&l[I],u=(u<<m^255&l[I+1])&f)}while(262>w&&0!==t.avail_in)}function de(e){let t,i,n=E,r=I,a=M;const c=I>o-262?I-(o-262):0;let d=D;const u=s,p=I+258;let g=l[r+a-1],f=l[r+a];M>=k&&(n>>=2),d>w&&(d=w);do{if(t=e,l[t+a]==f&&l[t+a-1]==g&&l[t]==l[r]&&l[++t]==l[r+1]){r+=2,t++;do{}while(l[++r]==l[++t]&&l[++r]==l[++t]&&l[++r]==l[++t]&&l[++r]==l[++t]&&l[++r]==l[++t]&&l[++r]==l[++t]&&l[++r]==l[++t]&&l[++r]==l[++t]&&p>r);if(i=258-(p-r),r=p-258,i>a){if(x=e,a=i,i>=d)break;g=l[r+a-1],f=l[r+a]}}}while((e=65535&h[e&u])>c&&0!=--n);return a>w?w:a}function ue(t){return t.total_in=t.total_out=0,t.msg=null,e.pending=0,e.pending_out=0,i=113,r=0,F.dyn_tree=T,F.stat_desc=N.static_l_desc,Q.dyn_tree=R,Q.stat_desc=N.static_d_desc,L.dyn_tree=U,L.stat_desc=N.static_bl_desc,z=0,q=0,J=8,Z(),function(){c=2*o,d[p-1]=0;for(let e=0;p-1>e;e++)d[e]=0;B=G[S].max_lazy,k=G[S].good_length,D=G[S].nice_length,E=G[S].max_chain,I=0,A=0,w=0,y=M=2,C=0,u=0}(),0}e.depth=[],e.bl_count=[],e.heap=[],T=[],R=[],U=[],e.pqdownheap=function(t,i){const n=e.heap,r=n[i];let o=i<<1;for(;e.heap_len>=o&&(e.heap_len>o&&V(t,n[o+1],n[o],e.depth)&&o++,!V(t,r,n[o],e.depth));)n[i]=n[o],i=o,o<<=1;n[i]=r},e.deflateInit=function(t,i,r,c,u,A){return c||(c=8),u||(u=8),A||(A=0),t.msg=null,-1==i&&(i=6),1>u||u>9||8!=c||9>r||r>15||0>i||i>9||0>A||A>2?-2:(t.dstate=e,a=r,o=1<<a,s=o-1,g=u+7,p=1<<g,f=p-1,m=Math.floor((g+3-1)/3),l=new Uint8Array(2*o),h=[],d=[],Y=1<<u+6,e.pending_buf=new Uint8Array(4*Y),n=4*Y,j=Math.floor(Y/2),P=3*Y,S=i,b=A,ue(t))},e.deflateEnd=function(){return 42!=i&&113!=i&&666!=i?-2:(e.pending_buf=null,d=null,h=null,l=null,e.dstate=null,113==i?-3:0)},e.deflateParams=function(e,t,i){let n=0;return-1==t&&(t=6),0>t||t>9||0>i||i>2?-2:(G[S].func!=G[t].func&&0!==e.total_in&&(n=e.deflate(1)),S!=t&&(S=t,B=G[S].max_lazy,k=G[S].good_length,D=G[S].nice_length,E=G[S].max_chain),b=i,n)},e.deflateSetDictionary=function(e,t,n){let r,a=n,c=0;if(!t||42!=i)return-2;if(3>a)return 0;for(a>o-262&&(a=o-262,c=n-a),l.set(t.subarray(c,c+a),0),I=a,A=a,u=255&l[0],u=(u<<m^255&l[1])&f,r=0;a-3>=r;r++)u=(u<<m^255&l[r+2])&f,h[r&s]=d[u],d[u]=r;return 0},e.deflate=function(c,g){let E,k,D,T,R;if(g>4||0>g)return-2;if(!c.next_out||!c.next_in&&0!==c.avail_in||666==i&&4!=g)return c.msg=K[4],-2;if(0===c.avail_out)return c.msg=K[7],-5;var U;if(t=c,T=r,r=g,42==i&&(k=8+(a-8<<4)<<8,D=(S-1&255)>>1,D>3&&(D=3),k|=D<<6,0!==I&&(k|=32),k+=31-k%31,i=113,_((U=k)>>8&255),_(255&U)),0!==e.pending){if(t.flush_pending(),0===t.avail_out)return r=-1,0}else if(0===t.avail_in&&T>=g&&4!=g)return t.msg=K[7],-5;if(666==i&&0!==t.avail_in)return c.msg=K[7],-5;if(0!==t.avail_in||0!==w||0!=g&&666!=i){switch(R=-1,G[S].func){case 0:R=function(e){let i,r=65535;for(r>n-5&&(r=n-5);;){if(1>=w){if(he(),0===w&&0==e)return 0;if(0===w)break}if(I+=w,w=0,i=A+r,(0===I||I>=i)&&(w=I-i,I=i,ce(!1),0===t.avail_out))return 0;if(I-A>=o-262&&(ce(!1),0===t.avail_out))return 0}return ce(4==e),0===t.avail_out?4==e?2:0:4==e?3:1}(g);break;case 1:R=function(e){let i,n=0;for(;;){if(262>w){if(he(),262>w&&0==e)return 0;if(0===w)break}if(w>=3&&(u=(u<<m^255&l[I+2])&f,n=65535&d[u],h[I&s]=d[u],d[u]=I),0!==n&&o-262>=(I-n&65535)&&2!=b&&(y=de(n)),y<3)i=re(0,255&l[I]),w--,I++;else if(i=re(I-x,y-3),w-=y,B<y||w<3)I+=y,y=0,u=255&l[I],u=(u<<m^255&l[I+1])&f;else{y--;do{I++,u=(u<<m^255&l[I+2])&f,n=65535&d[u],h[I&s]=d[u],d[u]=I}while(0!=--y);I++}if(i&&(ce(!1),0===t.avail_out))return 0}return ce(4==e),0===t.avail_out?4==e?2:0:4==e?3:1}(g);break;case 2:R=function(e){let i,n,r=0;for(;;){if(262>w){if(he(),262>w&&0==e)return 0;if(0===w)break}if(w>=3&&(u=(u<<m^255&l[I+2])&f,r=65535&d[u],h[I&s]=d[u],d[u]=I),M=y,v=x,y=2,0!==r&&B>M&&o-262>=(I-r&65535)&&(2!=b&&(y=de(r)),5>=y&&(1==b||3==y&&I-x>4096)&&(y=2)),M<3||M<y)if(0!==C){if(i=re(0,255&l[I-1]),i&&ce(!1),I++,w--,0===t.avail_out)return 0}else C=1,I++,w--;else{n=I+w-3,i=re(I-1-v,M-3),w-=M-1,M-=2;do{++I<=n&&(u=(u<<m^255&l[I+2])&f,r=65535&d[u],h[I&s]=d[u],d[u]=I)}while(0!=--M);if(C=0,y=2,I++,i&&(ce(!1),0===t.avail_out))return 0}}return 0!==C&&(i=re(0,255&l[I-1]),C=0),ce(4==e),0===t.avail_out?4==e?2:0:4==e?3:1}(g)}if(2!=R&&3!=R||(i=666),0==R||2==R)return 0===t.avail_out&&(r=-1),0;if(1==R){if(1==g)ee(2,3),te(256,N.static_ltree),ne(),9>1+J+10-q&&(ee(2,3),te(256,N.static_ltree),ne()),J=7;else if(se(0,0,!1),3==g)for(E=0;p>E;E++)d[E]=0;if(t.flush_pending(),0===t.avail_out)return r=-1,0}}return 4!=g?0:1}}function H(){const e=this;e.next_in_index=0,e.next_out_index=0,e.avail_in=0,e.total_in=0,e.avail_out=0,e.total_out=0}function j(e){const t=new H,i=(n=e&&e.chunkSize?e.chunkSize:65536)+5*(Math.floor(n/16383)+1);var n;const r=new Uint8Array(i);let o=e?e.level:-1;void 0===o&&(o=-1),t.deflateInit(o),t.next_out=r,this.append=function(e,n){let o,a,s=0,l=0,c=0;const h=[];if(e.length){t.next_in_index=0,t.next_in=e,t.avail_in=e.length;do{if(t.next_out_index=0,t.avail_out=i,o=t.deflate(0),0!=o)throw new Error("deflating: "+t.msg);t.next_out_index&&h.push(t.next_out_index==i?new Uint8Array(r):r.slice(0,t.next_out_index)),c+=t.next_out_index,n&&t.next_in_index>0&&t.next_in_index!=s&&(n(t.next_in_index),s=t.next_in_index)}while(t.avail_in>0||0===t.avail_out);return h.length>1?(a=new Uint8Array(c),h.forEach((function(e){a.set(e,l),l+=e.length}))):a=h[0]||new Uint8Array(0),a}},this.flush=function(){let e,n,o=0,a=0;const s=[];do{if(t.next_out_index=0,t.avail_out=i,e=t.deflate(4),1!=e&&0!=e)throw new Error("deflating: "+t.msg);i-t.avail_out>0&&s.push(r.slice(0,t.next_out_index)),a+=t.next_out_index}while(t.avail_in>0||0===t.avail_out);return t.deflateEnd(),n=new Uint8Array(a),s.forEach((function(e){n.set(e,o),o+=e.length})),n}}H.prototype={deflateInit:function(e,t){const i=this;return i.dstate=new Y,t||(t=15),i.dstate.deflateInit(i,e,t)},deflate:function(e){const t=this;return t.dstate?t.dstate.deflate(t,e):-2},deflateEnd:function(){const e=this;if(!e.dstate)return-2;const t=e.dstate.deflateEnd();return e.dstate=null,t},deflateParams:function(e,t){const i=this;return i.dstate?i.dstate.deflateParams(i,e,t):-2},deflateSetDictionary:function(e,t){const i=this;return i.dstate?i.dstate.deflateSetDictionary(i,e,t):-2},read_buf:function(e,t,i){const n=this;let r=n.avail_in;return r>i&&(r=i),0===r?0:(n.avail_in-=r,e.set(n.next_in.subarray(n.next_in_index,n.next_in_index+r),t),n.next_in_index+=r,n.total_in+=r,r)},flush_pending:function(){const e=this;let t=e.dstate.pending;t>e.avail_out&&(t=e.avail_out),0!==t&&(e.next_out.set(e.dstate.pending_buf.subarray(e.dstate.pending_out,e.dstate.pending_out+t),e.next_out_index),e.next_out_index+=t,e.dstate.pending_out+=t,e.total_out+=t,e.avail_out-=t,e.dstate.pending-=t,0===e.dstate.pending&&(e.dstate.pending_out=0))}};const W=[0,1,3,7,15,31,63,127,255,511,1023,2047,4095,8191,16383,32767,65535],J=[96,7,256,0,8,80,0,8,16,84,8,115,82,7,31,0,8,112,0,8,48,0,9,192,80,7,10,0,8,96,0,8,32,0,9,160,0,8,0,0,8,128,0,8,64,0,9,224,80,7,6,0,8,88,0,8,24,0,9,144,83,7,59,0,8,120,0,8,56,0,9,208,81,7,17,0,8,104,0,8,40,0,9,176,0,8,8,0,8,136,0,8,72,0,9,240,80,7,4,0,8,84,0,8,20,85,8,227,83,7,43,0,8,116,0,8,52,0,9,200,81,7,13,0,8,100,0,8,36,0,9,168,0,8,4,0,8,132,0,8,68,0,9,232,80,7,8,0,8,92,0,8,28,0,9,152,84,7,83,0,8,124,0,8,60,0,9,216,82,7,23,0,8,108,0,8,44,0,9,184,0,8,12,0,8,140,0,8,76,0,9,248,80,7,3,0,8,82,0,8,18,85,8,163,83,7,35,0,8,114,0,8,50,0,9,196,81,7,11,0,8,98,0,8,34,0,9,164,0,8,2,0,8,130,0,8,66,0,9,228,80,7,7,0,8,90,0,8,26,0,9,148,84,7,67,0,8,122,0,8,58,0,9,212,82,7,19,0,8,106,0,8,42,0,9,180,0,8,10,0,8,138,0,8,74,0,9,244,80,7,5,0,8,86,0,8,22,192,8,0,83,7,51,0,8,118,0,8,54,0,9,204,81,7,15,0,8,102,0,8,38,0,9,172,0,8,6,0,8,134,0,8,70,0,9,236,80,7,9,0,8,94,0,8,30,0,9,156,84,7,99,0,8,126,0,8,62,0,9,220,82,7,27,0,8,110,0,8,46,0,9,188,0,8,14,0,8,142,0,8,78,0,9,252,96,7,256,0,8,81,0,8,17,85,8,131,82,7,31,0,8,113,0,8,49,0,9,194,80,7,10,0,8,97,0,8,33,0,9,162,0,8,1,0,8,129,0,8,65,0,9,226,80,7,6,0,8,89,0,8,25,0,9,146,83,7,59,0,8,121,0,8,57,0,9,210,81,7,17,0,8,105,0,8,41,0,9,178,0,8,9,0,8,137,0,8,73,0,9,242,80,7,4,0,8,85,0,8,21,80,8,258,83,7,43,0,8,117,0,8,53,0,9,202,81,7,13,0,8,101,0,8,37,0,9,170,0,8,5,0,8,133,0,8,69,0,9,234,80,7,8,0,8,93,0,8,29,0,9,154,84,7,83,0,8,125,0,8,61,0,9,218,82,7,23,0,8,109,0,8,45,0,9,186,0,8,13,0,8,141,0,8,77,0,9,250,80,7,3,0,8,83,0,8,19,85,8,195,83,7,35,0,8,115,0,8,51,0,9,198,81,7,11,0,8,99,0,8,35,0,9,166,0,8,3,0,8,131,0,8,67,0,9,230,80,7,7,0,8,91,0,8,27,0,9,150,84,7,67,0,8,123,0,8,59,0,9,214,82,7,19,0,8,107,0,8,43,0,9,182,0,8,11,0,8,139,0,8,75,0,9,246,80,7,5,0,8,87,0,8,23,192,8,0,83,7,51,0,8,119,0,8,55,0,9,206,81,7,15,0,8,103,0,8,39,0,9,174,0,8,7,0,8,135,0,8,71,0,9,238,80,7,9,0,8,95,0,8,31,0,9,158,84,7,99,0,8,127,0,8,63,0,9,222,82,7,27,0,8,111,0,8,47,0,9,190,0,8,15,0,8,143,0,8,79,0,9,254,96,7,256,0,8,80,0,8,16,84,8,115,82,7,31,0,8,112,0,8,48,0,9,193,80,7,10,0,8,96,0,8,32,0,9,161,0,8,0,0,8,128,0,8,64,0,9,225,80,7,6,0,8,88,0,8,24,0,9,145,83,7,59,0,8,120,0,8,56,0,9,209,81,7,17,0,8,104,0,8,40,0,9,177,0,8,8,0,8,136,0,8,72,0,9,241,80,7,4,0,8,84,0,8,20,85,8,227,83,7,43,0,8,116,0,8,52,0,9,201,81,7,13,0,8,100,0,8,36,0,9,169,0,8,4,0,8,132,0,8,68,0,9,233,80,7,8,0,8,92,0,8,28,0,9,153,84,7,83,0,8,124,0,8,60,0,9,217,82,7,23,0,8,108,0,8,44,0,9,185,0,8,12,0,8,140,0,8,76,0,9,249,80,7,3,0,8,82,0,8,18,85,8,163,83,7,35,0,8,114,0,8,50,0,9,197,81,7,11,0,8,98,0,8,34,0,9,165,0,8,2,0,8,130,0,8,66,0,9,229,80,7,7,0,8,90,0,8,26,0,9,149,84,7,67,0,8,122,0,8,58,0,9,213,82,7,19,0,8,106,0,8,42,0,9,181,0,8,10,0,8,138,0,8,74,0,9,245,80,7,5,0,8,86,0,8,22,192,8,0,83,7,51,0,8,118,0,8,54,0,9,205,81,7,15,0,8,102,0,8,38,0,9,173,0,8,6,0,8,134,0,8,70,0,9,237,80,7,9,0,8,94,0,8,30,0,9,157,84,7,99,0,8,126,0,8,62,0,9,221,82,7,27,0,8,110,0,8,46,0,9,189,0,8,14,0,8,142,0,8,78,0,9,253,96,7,256,0,8,81,0,8,17,85,8,131,82,7,31,0,8,113,0,8,49,0,9,195,80,7,10,0,8,97,0,8,33,0,9,163,0,8,1,0,8,129,0,8,65,0,9,227,80,7,6,0,8,89,0,8,25,0,9,147,83,7,59,0,8,121,0,8,57,0,9,211,81,7,17,0,8,105,0,8,41,0,9,179,0,8,9,0,8,137,0,8,73,0,9,243,80,7,4,0,8,85,0,8,21,80,8,258,83,7,43,0,8,117,0,8,53,0,9,203,81,7,13,0,8,101,0,8,37,0,9,171,0,8,5,0,8,133,0,8,69,0,9,235,80,7,8,0,8,93,0,8,29,0,9,155,84,7,83,0,8,125,0,8,61,0,9,219,82,7,23,0,8,109,0,8,45,0,9,187,0,8,13,0,8,141,0,8,77,0,9,251,80,7,3,0,8,83,0,8,19,85,8,195,83,7,35,0,8,115,0,8,51,0,9,199,81,7,11,0,8,99,0,8,35,0,9,167,0,8,3,0,8,131,0,8,67,0,9,231,80,7,7,0,8,91,0,8,27,0,9,151,84,7,67,0,8,123,0,8,59,0,9,215,82,7,19,0,8,107,0,8,43,0,9,183,0,8,11,0,8,139,0,8,75,0,9,247,80,7,5,0,8,87,0,8,23,192,8,0,83,7,51,0,8,119,0,8,55,0,9,207,81,7,15,0,8,103,0,8,39,0,9,175,0,8,7,0,8,135,0,8,71,0,9,239,80,7,9,0,8,95,0,8,31,0,9,159,84,7,99,0,8,127,0,8,63,0,9,223,82,7,27,0,8,111,0,8,47,0,9,191,0,8,15,0,8,143,0,8,79,0,9,255],z=[80,5,1,87,5,257,83,5,17,91,5,4097,81,5,5,89,5,1025,85,5,65,93,5,16385,80,5,3,88,5,513,84,5,33,92,5,8193,82,5,9,90,5,2049,86,5,129,192,5,24577,80,5,2,87,5,385,83,5,25,91,5,6145,81,5,7,89,5,1537,85,5,97,93,5,24577,80,5,4,88,5,769,84,5,49,92,5,12289,82,5,13,90,5,3073,86,5,193,192,5,24577],q=[3,4,5,6,7,8,9,10,11,13,15,17,19,23,27,31,35,43,51,59,67,83,99,115,131,163,195,227,258,0,0],Z=[0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0,112,112],X=[1,2,3,4,5,7,9,13,17,25,33,49,65,97,129,193,257,385,513,769,1025,1537,2049,3073,4097,6145,8193,12289,16385,24577],_=[0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13];function $(){let e,t,i,n,r,o;function a(e,t,a,s,l,c,h,d,u,p,g){let f,m,A,y,v,C,I,x,w,M,E,B,S,b,k;M=0,v=a;do{i[e[t+M]]++,M++,v--}while(0!==v);if(i[0]==a)return h[0]=-1,d[0]=0,0;for(x=d[0],C=1;15>=C&&0===i[C];C++);for(I=C,C>x&&(x=C),v=15;0!==v&&0===i[v];v--);for(A=v,x>v&&(x=v),d[0]=x,b=1<<C;v>C;C++,b<<=1)if(0>(b-=i[C]))return-3;if(0>(b-=i[v]))return-3;for(i[v]+=b,o[1]=C=0,M=1,S=2;0!=--v;)o[S]=C+=i[M],S++,M++;v=0,M=0;do{0!==(C=e[t+M])&&(g[o[C]++]=v),M++}while(++v<a);for(a=o[A],o[0]=v=0,M=0,y=-1,B=-x,r[0]=0,E=0,k=0;A>=I;I++)for(f=i[I];0!=f--;){for(;I>B+x;){if(y++,B+=x,k=A-B,k=k>x?x:k,(m=1<<(C=I-B))>f+1&&(m-=f+1,S=I,k>C))for(;++C<k&&(m<<=1)>i[++S];)m-=i[S];if(k=1<<C,p[0]+k>1440)return-3;r[y]=E=p[0],p[0]+=k,0!==y?(o[y]=v,n[0]=C,n[1]=x,C=v>>>B-x,n[2]=E-r[y-1]-C,u.set(n,3*(r[y-1]+C))):h[0]=E}for(n[1]=I-B,a>M?s>g[M]?(n[0]=256>g[M]?0:96,n[2]=g[M++]):(n[0]=c[g[M]-s]+16+64,n[2]=l[g[M++]-s]):n[0]=192,m=1<<I-B,C=v>>>B;k>C;C+=m)u.set(n,3*(E+C));for(C=1<<I-1;0!=(v&C);C>>>=1)v^=C;for(v^=C,w=(1<<B)-1;(v&w)!=o[y];)y--,B-=x,w=(1<<B)-1}return 0!==b&&1!=A?-5:0}function s(a){let s;for(e||(e=[],t=[],i=new Int32Array(16),n=[],r=new Int32Array(15),o=new Int32Array(16)),a>t.length&&(t=[]),s=0;a>s;s++)t[s]=0;for(s=0;16>s;s++)i[s]=0;for(s=0;3>s;s++)n[s]=0;r.set(i.subarray(0,15),0),o.set(i.subarray(0,16),0)}this.inflate_trees_bits=function(i,n,r,o,l){let c;return s(19),e[0]=0,c=a(i,0,19,19,null,null,r,n,o,e,t),-3==c?l.msg="oversubscribed dynamic bit lengths tree":-5!=c&&0!==n[0]||(l.msg="incomplete dynamic bit lengths tree",c=-3),c},this.inflate_trees_dynamic=function(i,n,r,o,l,c,h,d,u){let p;return s(288),e[0]=0,p=a(r,0,i,257,q,Z,c,o,d,e,t),0!=p||0===o[0]?(-3==p?u.msg="oversubscribed literal/length tree":-4!=p&&(u.msg="incomplete literal/length tree",p=-3),p):(s(288),p=a(r,i,n,0,X,_,h,l,d,e,t),0!=p||0===l[0]&&i>257?(-3==p?u.msg="oversubscribed distance tree":-5==p?(u.msg="incomplete distance tree",p=-3):-4!=p&&(u.msg="empty distance tree with lengths",p=-3),p):0)}}function ee(){const e=this;let t,i,n,r,o=0,a=0,s=0,l=0,c=0,h=0,d=0,u=0,p=0,g=0;function f(e,t,i,n,r,o,a,s){let l,c,h,d,u,p,g,f,m,A,y,v,C,I,x,w;g=s.next_in_index,f=s.avail_in,u=a.bitb,p=a.bitk,m=a.write,A=a.read>m?a.read-m-1:a.end-m,y=W[e],v=W[t];do{for(;20>p;)f--,u|=(255&s.read_byte(g++))<<p,p+=8;if(l=u&y,c=i,h=n,w=3*(h+l),0!==(d=c[w]))for(;;){if(u>>=c[w+1],p-=c[w+1],0!=(16&d)){for(d&=15,C=c[w+2]+(u&W[d]),u>>=d,p-=d;15>p;)f--,u|=(255&s.read_byte(g++))<<p,p+=8;for(l=u&v,c=r,h=o,w=3*(h+l),d=c[w];;){if(u>>=c[w+1],p-=c[w+1],0!=(16&d)){for(d&=15;d>p;)f--,u|=(255&s.read_byte(g++))<<p,p+=8;if(I=c[w+2]+(u&W[d]),u>>=d,p-=d,A-=C,m<I){x=m-I;do{x+=a.end}while(0>x);if(d=a.end-x,C>d){if(C-=d,m-x>0&&d>m-x)do{a.window[m++]=a.window[x++]}while(0!=--d);else a.window.set(a.window.subarray(x,x+d),m),m+=d,x+=d,d=0;x=0}}else x=m-I,m-x>0&&2>m-x?(a.window[m++]=a.window[x++],a.window[m++]=a.window[x++],C-=2):(a.window.set(a.window.subarray(x,x+2),m),m+=2,x+=2,C-=2);if(m-x>0&&C>m-x)do{a.window[m++]=a.window[x++]}while(0!=--C);else a.window.set(a.window.subarray(x,x+C),m),m+=C,x+=C,C=0;break}if(0!=(64&d))return s.msg="invalid distance code",C=s.avail_in-f,C=C>p>>3?p>>3:C,f+=C,g-=C,p-=C<<3,a.bitb=u,a.bitk=p,s.avail_in=f,s.total_in+=g-s.next_in_index,s.next_in_index=g,a.write=m,-3;l+=c[w+2],l+=u&W[d],w=3*(h+l),d=c[w]}break}if(0!=(64&d))return 0!=(32&d)?(C=s.avail_in-f,C=C>p>>3?p>>3:C,f+=C,g-=C,p-=C<<3,a.bitb=u,a.bitk=p,s.avail_in=f,s.total_in+=g-s.next_in_index,s.next_in_index=g,a.write=m,1):(s.msg="invalid literal/length code",C=s.avail_in-f,C=C>p>>3?p>>3:C,f+=C,g-=C,p-=C<<3,a.bitb=u,a.bitk=p,s.avail_in=f,s.total_in+=g-s.next_in_index,s.next_in_index=g,a.write=m,-3);if(l+=c[w+2],l+=u&W[d],w=3*(h+l),0===(d=c[w])){u>>=c[w+1],p-=c[w+1],a.window[m++]=c[w+2],A--;break}}else u>>=c[w+1],p-=c[w+1],a.window[m++]=c[w+2],A--}while(A>=258&&f>=10);return C=s.avail_in-f,C=C>p>>3?p>>3:C,f+=C,g-=C,p-=C<<3,a.bitb=u,a.bitk=p,s.avail_in=f,s.total_in+=g-s.next_in_index,s.next_in_index=g,a.write=m,0}e.init=function(e,o,a,s,l,c){t=0,d=e,u=o,n=a,p=s,r=l,g=c,i=null},e.proc=function(e,m,A){let y,v,C,I,x,w,M,E=0,B=0,S=0;for(S=m.next_in_index,I=m.avail_in,E=e.bitb,B=e.bitk,x=e.write,w=e.read>x?e.read-x-1:e.end-x;;)switch(t){case 0:if(w>=258&&I>=10&&(e.bitb=E,e.bitk=B,m.avail_in=I,m.total_in+=S-m.next_in_index,m.next_in_index=S,e.write=x,A=f(d,u,n,p,r,g,e,m),S=m.next_in_index,I=m.avail_in,E=e.bitb,B=e.bitk,x=e.write,w=e.read>x?e.read-x-1:e.end-x,0!=A)){t=1==A?7:9;break}s=d,i=n,a=p,t=1;case 1:for(y=s;y>B;){if(0===I)return e.bitb=E,e.bitk=B,m.avail_in=I,m.total_in+=S-m.next_in_index,m.next_in_index=S,e.write=x,e.inflate_flush(m,A);A=0,I--,E|=(255&m.read_byte(S++))<<B,B+=8}if(v=3*(a+(E&W[y])),E>>>=i[v+1],B-=i[v+1],C=i[v],0===C){l=i[v+2],t=6;break}if(0!=(16&C)){c=15&C,o=i[v+2],t=2;break}if(0==(64&C)){s=C,a=v/3+i[v+2];break}if(0!=(32&C)){t=7;break}return t=9,m.msg="invalid literal/length code",A=-3,e.bitb=E,e.bitk=B,m.avail_in=I,m.total_in+=S-m.next_in_index,m.next_in_index=S,e.write=x,e.inflate_flush(m,A);case 2:for(y=c;y>B;){if(0===I)return e.bitb=E,e.bitk=B,m.avail_in=I,m.total_in+=S-m.next_in_index,m.next_in_index=S,e.write=x,e.inflate_flush(m,A);A=0,I--,E|=(255&m.read_byte(S++))<<B,B+=8}o+=E&W[y],E>>=y,B-=y,s=u,i=r,a=g,t=3;case 3:for(y=s;y>B;){if(0===I)return e.bitb=E,e.bitk=B,m.avail_in=I,m.total_in+=S-m.next_in_index,m.next_in_index=S,e.write=x,e.inflate_flush(m,A);A=0,I--,E|=(255&m.read_byte(S++))<<B,B+=8}if(v=3*(a+(E&W[y])),E>>=i[v+1],B-=i[v+1],C=i[v],0!=(16&C)){c=15&C,h=i[v+2],t=4;break}if(0==(64&C)){s=C,a=v/3+i[v+2];break}return t=9,m.msg="invalid distance code",A=-3,e.bitb=E,e.bitk=B,m.avail_in=I,m.total_in+=S-m.next_in_index,m.next_in_index=S,e.write=x,e.inflate_flush(m,A);case 4:for(y=c;y>B;){if(0===I)return e.bitb=E,e.bitk=B,m.avail_in=I,m.total_in+=S-m.next_in_index,m.next_in_index=S,e.write=x,e.inflate_flush(m,A);A=0,I--,E|=(255&m.read_byte(S++))<<B,B+=8}h+=E&W[y],E>>=y,B-=y,t=5;case 5:for(M=x-h;0>M;)M+=e.end;for(;0!==o;){if(0===w&&(x==e.end&&0!==e.read&&(x=0,w=e.read>x?e.read-x-1:e.end-x),0===w&&(e.write=x,A=e.inflate_flush(m,A),x=e.write,w=e.read>x?e.read-x-1:e.end-x,x==e.end&&0!==e.read&&(x=0,w=e.read>x?e.read-x-1:e.end-x),0===w)))return e.bitb=E,e.bitk=B,m.avail_in=I,m.total_in+=S-m.next_in_index,m.next_in_index=S,e.write=x,e.inflate_flush(m,A);e.window[x++]=e.window[M++],w--,M==e.end&&(M=0),o--}t=0;break;case 6:if(0===w&&(x==e.end&&0!==e.read&&(x=0,w=e.read>x?e.read-x-1:e.end-x),0===w&&(e.write=x,A=e.inflate_flush(m,A),x=e.write,w=e.read>x?e.read-x-1:e.end-x,x==e.end&&0!==e.read&&(x=0,w=e.read>x?e.read-x-1:e.end-x),0===w)))return e.bitb=E,e.bitk=B,m.avail_in=I,m.total_in+=S-m.next_in_index,m.next_in_index=S,e.write=x,e.inflate_flush(m,A);A=0,e.window[x++]=l,w--,t=0;break;case 7:if(B>7&&(B-=8,I++,S--),e.write=x,A=e.inflate_flush(m,A),x=e.write,w=e.read>x?e.read-x-1:e.end-x,e.read!=e.write)return e.bitb=E,e.bitk=B,m.avail_in=I,m.total_in+=S-m.next_in_index,m.next_in_index=S,e.write=x,e.inflate_flush(m,A);t=8;case 8:return A=1,e.bitb=E,e.bitk=B,m.avail_in=I,m.total_in+=S-m.next_in_index,m.next_in_index=S,e.write=x,e.inflate_flush(m,A);case 9:return A=-3,e.bitb=E,e.bitk=B,m.avail_in=I,m.total_in+=S-m.next_in_index,m.next_in_index=S,e.write=x,e.inflate_flush(m,A);default:return A=-2,e.bitb=E,e.bitk=B,m.avail_in=I,m.total_in+=S-m.next_in_index,m.next_in_index=S,e.write=x,e.inflate_flush(m,A)}},e.free=function(){}}$.inflate_trees_fixed=function(e,t,i,n){return e[0]=9,t[0]=5,i[0]=J,n[0]=z,0};const te=[16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15];function ie(e,t){const i=this;let n,r=0,o=0,a=0,s=0;const l=[0],c=[0],h=new ee;let d=0,u=new Int32Array(4320);const p=new $;i.bitk=0,i.bitb=0,i.window=new Uint8Array(t),i.end=t,i.read=0,i.write=0,i.reset=function(e,t){t&&(t[0]=0),6==r&&h.free(e),r=0,i.bitk=0,i.bitb=0,i.read=i.write=0},i.reset(e,null),i.inflate_flush=function(e,t){let n,r,o;return r=e.next_out_index,o=i.read,n=(o>i.write?i.end:i.write)-o,n>e.avail_out&&(n=e.avail_out),0!==n&&-5==t&&(t=0),e.avail_out-=n,e.total_out+=n,e.next_out.set(i.window.subarray(o,o+n),r),r+=n,o+=n,o==i.end&&(o=0,i.write==i.end&&(i.write=0),n=i.write-o,n>e.avail_out&&(n=e.avail_out),0!==n&&-5==t&&(t=0),e.avail_out-=n,e.total_out+=n,e.next_out.set(i.window.subarray(o,o+n),r),r+=n,o+=n),e.next_out_index=r,i.read=o,t},i.proc=function(e,t){let g,f,m,A,y,v,C,I;for(A=e.next_in_index,y=e.avail_in,f=i.bitb,m=i.bitk,v=i.write,C=i.read>v?i.read-v-1:i.end-v;;){let x,w,M,E,B,S,b,k;switch(r){case 0:for(;3>m;){if(0===y)return i.bitb=f,i.bitk=m,e.avail_in=y,e.total_in+=A-e.next_in_index,e.next_in_index=A,i.write=v,i.inflate_flush(e,t);t=0,y--,f|=(255&e.read_byte(A++))<<m,m+=8}switch(g=7&f,d=1&g,g>>>1){case 0:f>>>=3,m-=3,g=7&m,f>>>=g,m-=g,r=1;break;case 1:x=[],w=[],M=[[]],E=[[]],$.inflate_trees_fixed(x,w,M,E),h.init(x[0],w[0],M[0],0,E[0],0),f>>>=3,m-=3,r=6;break;case 2:f>>>=3,m-=3,r=3;break;case 3:return f>>>=3,m-=3,r=9,e.msg="invalid block type",t=-3,i.bitb=f,i.bitk=m,e.avail_in=y,e.total_in+=A-e.next_in_index,e.next_in_index=A,i.write=v,i.inflate_flush(e,t)}break;case 1:for(;32>m;){if(0===y)return i.bitb=f,i.bitk=m,e.avail_in=y,e.total_in+=A-e.next_in_index,e.next_in_index=A,i.write=v,i.inflate_flush(e,t);t=0,y--,f|=(255&e.read_byte(A++))<<m,m+=8}if((~f>>>16&65535)!=(65535&f))return r=9,e.msg="invalid stored block lengths",t=-3,i.bitb=f,i.bitk=m,e.avail_in=y,e.total_in+=A-e.next_in_index,e.next_in_index=A,i.write=v,i.inflate_flush(e,t);o=65535&f,f=m=0,r=0!==o?2:0!==d?7:0;break;case 2:if(0===y)return i.bitb=f,i.bitk=m,e.avail_in=y,e.total_in+=A-e.next_in_index,e.next_in_index=A,i.write=v,i.inflate_flush(e,t);if(0===C&&(v==i.end&&0!==i.read&&(v=0,C=i.read>v?i.read-v-1:i.end-v),0===C&&(i.write=v,t=i.inflate_flush(e,t),v=i.write,C=i.read>v?i.read-v-1:i.end-v,v==i.end&&0!==i.read&&(v=0,C=i.read>v?i.read-v-1:i.end-v),0===C)))return i.bitb=f,i.bitk=m,e.avail_in=y,e.total_in+=A-e.next_in_index,e.next_in_index=A,i.write=v,i.inflate_flush(e,t);if(t=0,g=o,g>y&&(g=y),g>C&&(g=C),i.window.set(e.read_buf(A,g),v),A+=g,y-=g,v+=g,C-=g,0!=(o-=g))break;r=0!==d?7:0;break;case 3:for(;14>m;){if(0===y)return i.bitb=f,i.bitk=m,e.avail_in=y,e.total_in+=A-e.next_in_index,e.next_in_index=A,i.write=v,i.inflate_flush(e,t);t=0,y--,f|=(255&e.read_byte(A++))<<m,m+=8}if(a=g=16383&f,(31&g)>29||(g>>5&31)>29)return r=9,e.msg="too many length or distance symbols",t=-3,i.bitb=f,i.bitk=m,e.avail_in=y,e.total_in+=A-e.next_in_index,e.next_in_index=A,i.write=v,i.inflate_flush(e,t);if(g=258+(31&g)+(g>>5&31),!n||g>n.length)n=[];else for(I=0;g>I;I++)n[I]=0;f>>>=14,m-=14,s=0,r=4;case 4:for(;4+(a>>>10)>s;){for(;3>m;){if(0===y)return i.bitb=f,i.bitk=m,e.avail_in=y,e.total_in+=A-e.next_in_index,e.next_in_index=A,i.write=v,i.inflate_flush(e,t);t=0,y--,f|=(255&e.read_byte(A++))<<m,m+=8}n[te[s++]]=7&f,f>>>=3,m-=3}for(;19>s;)n[te[s++]]=0;if(l[0]=7,g=p.inflate_trees_bits(n,l,c,u,e),0!=g)return-3==(t=g)&&(n=null,r=9),i.bitb=f,i.bitk=m,e.avail_in=y,e.total_in+=A-e.next_in_index,e.next_in_index=A,i.write=v,i.inflate_flush(e,t);s=0,r=5;case 5:for(;g=a,s<258+(31&g)+(g>>5&31);){let o,h;for(g=l[0];g>m;){if(0===y)return i.bitb=f,i.bitk=m,e.avail_in=y,e.total_in+=A-e.next_in_index,e.next_in_index=A,i.write=v,i.inflate_flush(e,t);t=0,y--,f|=(255&e.read_byte(A++))<<m,m+=8}if(g=u[3*(c[0]+(f&W[g]))+1],h=u[3*(c[0]+(f&W[g]))+2],16>h)f>>>=g,m-=g,n[s++]=h;else{for(I=18==h?7:h-14,o=18==h?11:3;g+I>m;){if(0===y)return i.bitb=f,i.bitk=m,e.avail_in=y,e.total_in+=A-e.next_in_index,e.next_in_index=A,i.write=v,i.inflate_flush(e,t);t=0,y--,f|=(255&e.read_byte(A++))<<m,m+=8}if(f>>>=g,m-=g,o+=f&W[I],f>>>=I,m-=I,I=s,g=a,I+o>258+(31&g)+(g>>5&31)||16==h&&1>I)return n=null,r=9,e.msg="invalid bit length repeat",t=-3,i.bitb=f,i.bitk=m,e.avail_in=y,e.total_in+=A-e.next_in_index,e.next_in_index=A,i.write=v,i.inflate_flush(e,t);h=16==h?n[I-1]:0;do{n[I++]=h}while(0!=--o);s=I}}if(c[0]=-1,B=[],S=[],b=[],k=[],B[0]=9,S[0]=6,g=a,g=p.inflate_trees_dynamic(257+(31&g),1+(g>>5&31),n,B,S,b,k,u,e),0!=g)return-3==g&&(n=null,r=9),t=g,i.bitb=f,i.bitk=m,e.avail_in=y,e.total_in+=A-e.next_in_index,e.next_in_index=A,i.write=v,i.inflate_flush(e,t);h.init(B[0],S[0],u,b[0],u,k[0]),r=6;case 6:if(i.bitb=f,i.bitk=m,e.avail_in=y,e.total_in+=A-e.next_in_index,e.next_in_index=A,i.write=v,1!=(t=h.proc(i,e,t)))return i.inflate_flush(e,t);if(t=0,h.free(e),A=e.next_in_index,y=e.avail_in,f=i.bitb,m=i.bitk,v=i.write,C=i.read>v?i.read-v-1:i.end-v,0===d){r=0;break}r=7;case 7:if(i.write=v,t=i.inflate_flush(e,t),v=i.write,C=i.read>v?i.read-v-1:i.end-v,i.read!=i.write)return i.bitb=f,i.bitk=m,e.avail_in=y,e.total_in+=A-e.next_in_index,e.next_in_index=A,i.write=v,i.inflate_flush(e,t);r=8;case 8:return t=1,i.bitb=f,i.bitk=m,e.avail_in=y,e.total_in+=A-e.next_in_index,e.next_in_index=A,i.write=v,i.inflate_flush(e,t);case 9:return t=-3,i.bitb=f,i.bitk=m,e.avail_in=y,e.total_in+=A-e.next_in_index,e.next_in_index=A,i.write=v,i.inflate_flush(e,t);default:return t=-2,i.bitb=f,i.bitk=m,e.avail_in=y,e.total_in+=A-e.next_in_index,e.next_in_index=A,i.write=v,i.inflate_flush(e,t)}}},i.free=function(e){i.reset(e,null),i.window=null,u=null},i.set_dictionary=function(e,t,n){i.window.set(e.subarray(t,t+n),0),i.read=i.write=n},i.sync_point=function(){return 1==r?1:0}}const ne=[0,0,255,255];function re(){const e=this;function t(e){return e&&e.istate?(e.total_in=e.total_out=0,e.msg=null,e.istate.mode=7,e.istate.blocks.reset(e,null),0):-2}e.mode=0,e.method=0,e.was=[0],e.need=0,e.marker=0,e.wbits=0,e.inflateEnd=function(t){return e.blocks&&e.blocks.free(t),e.blocks=null,0},e.inflateInit=function(i,n){return i.msg=null,e.blocks=null,8>n||n>15?(e.inflateEnd(i),-2):(e.wbits=n,i.istate.blocks=new ie(i,1<<n),t(i),0)},e.inflate=function(e,t){let i,n;if(!e||!e.istate||!e.next_in)return-2;const r=e.istate;for(t=4==t?-5:0,i=-5;;)switch(r.mode){case 0:if(0===e.avail_in)return i;if(i=t,e.avail_in--,e.total_in++,8!=(15&(r.method=e.read_byte(e.next_in_index++)))){r.mode=13,e.msg="unknown compression method",r.marker=5;break}if(8+(r.method>>4)>r.wbits){r.mode=13,e.msg="invalid window size",r.marker=5;break}r.mode=1;case 1:if(0===e.avail_in)return i;if(i=t,e.avail_in--,e.total_in++,n=255&e.read_byte(e.next_in_index++),((r.method<<8)+n)%31!=0){r.mode=13,e.msg="incorrect header check",r.marker=5;break}if(0==(32&n)){r.mode=7;break}r.mode=2;case 2:if(0===e.avail_in)return i;i=t,e.avail_in--,e.total_in++,r.need=(255&e.read_byte(e.next_in_index++))<<24&4278190080,r.mode=3;case 3:if(0===e.avail_in)return i;i=t,e.avail_in--,e.total_in++,r.need+=(255&e.read_byte(e.next_in_index++))<<16&16711680,r.mode=4;case 4:if(0===e.avail_in)return i;i=t,e.avail_in--,e.total_in++,r.need+=(255&e.read_byte(e.next_in_index++))<<8&65280,r.mode=5;case 5:return 0===e.avail_in?i:(i=t,e.avail_in--,e.total_in++,r.need+=255&e.read_byte(e.next_in_index++),r.mode=6,2);case 6:return r.mode=13,e.msg="need dictionary",r.marker=0,-2;case 7:if(i=r.blocks.proc(e,i),-3==i){r.mode=13,r.marker=0;break}if(0==i&&(i=t),1!=i)return i;i=t,r.blocks.reset(e,r.was),r.mode=12;case 12:return 1;case 13:return-3;default:return-2}},e.inflateSetDictionary=function(e,t,i){let n=0,r=i;if(!e||!e.istate||6!=e.istate.mode)return-2;const o=e.istate;return r>=1<<o.wbits&&(r=(1<<o.wbits)-1,n=i-r),o.blocks.set_dictionary(t,n,r),o.mode=7,0},e.inflateSync=function(e){let i,n,r,o,a;if(!e||!e.istate)return-2;const s=e.istate;if(13!=s.mode&&(s.mode=13,s.marker=0),0===(i=e.avail_in))return-5;for(n=e.next_in_index,r=s.marker;0!==i&&4>r;)e.read_byte(n)==ne[r]?r++:r=0!==e.read_byte(n)?0:4-r,n++,i--;return e.total_in+=n-e.next_in_index,e.next_in_index=n,e.avail_in=i,s.marker=r,4!=r?-3:(o=e.total_in,a=e.total_out,t(e),e.total_in=o,e.total_out=a,s.mode=7,0)},e.inflateSyncPoint=function(e){return e&&e.istate&&e.istate.blocks?e.istate.blocks.sync_point():-2}}function oe(){}function ae(e){const t=new oe,i=e&&e.chunkSize?Math.floor(2*e.chunkSize):131072,n=new Uint8Array(i);let r=!1;t.inflateInit(),t.next_out=n,this.append=function(e,o){const a=[];let s,l,c=0,h=0,d=0;if(0!==e.length){t.next_in_index=0,t.next_in=e,t.avail_in=e.length;do{if(t.next_out_index=0,t.avail_out=i,0!==t.avail_in||r||(t.next_in_index=0,r=!0),s=t.inflate(0),r&&-5===s){if(0!==t.avail_in)throw new Error("inflating: bad input")}else if(0!==s&&1!==s)throw new Error("inflating: "+t.msg);if((r||1===s)&&t.avail_in===e.length)throw new Error("inflating: bad input");t.next_out_index&&a.push(t.next_out_index===i?new Uint8Array(n):n.slice(0,t.next_out_index)),d+=t.next_out_index,o&&t.next_in_index>0&&t.next_in_index!=c&&(o(t.next_in_index),c=t.next_in_index)}while(t.avail_in>0||0===t.avail_out);return a.length>1?(l=new Uint8Array(d),a.forEach((function(e){l.set(e,h),h+=e.length}))):l=a[0]||new Uint8Array(0),l}},this.flush=function(){t.inflateEnd()}}oe.prototype={inflateInit:function(e){const t=this;return t.istate=new re,e||(e=15),t.istate.inflateInit(t,e)},inflate:function(e){const t=this;return t.istate?t.istate.inflate(t,e):-2},inflateEnd:function(){const e=this;if(!e.istate)return-2;const t=e.istate.inflateEnd(e);return e.istate=null,t},inflateSync:function(){const e=this;return e.istate?e.istate.inflateSync(e):-2},inflateSetDictionary:function(e,t){const i=this;return i.istate?i.istate.inflateSetDictionary(i,e,t):-2},read_byte:function(e){return this.next_in[e]},read_buf:function(e,t){return this.next_in.subarray(e,e+t)}},self.initCodec=()=>{self.Deflate=j,self.Inflate=ae}}).toString(),t=URL.createObjectURL(new Blob(["("+e+")()"],{type:"text/javascript"}));TI({workerScripts:{inflate:[t],deflate:[t]}})}})();var jx=function(e){lu(i,e);var t=pu(i);function i(){return ru(this,i),t.call(this)}return au(i,[{key:"addGroupInstanced",value:function(e,t,i,n){this.groups.push({start:e,count:t,materialIndex:void 0!==i?i:0,instanceIndex:n})}}]),i}(Ni);jx.prototype.isBufferGeometry=!0;var Wx=function(e){lu(i,e);var t=pu(i);function i(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:new jx,n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:new gi;return ru(this,i),t.call(this,e,n)}return i}(nn),Jx=function(e){lu(i,e);var t=pu(i);function i(e){var n;return ru(this,i),(n=t.call(this,e)).dracoLoader=null,n.ktx2Loader=null,n.meshoptDecoder=null,n.pluginCallbacks=[],n.register((function(e){return new _x(e)})),n.register((function(e){return new ew(e)})),n.register((function(e){return new tw(e)})),n.register((function(e){return new $x(e)})),n.register((function(e){return new Zx(e)})),n.register((function(e){return new iw(e)})),n}return au(i,[{key:"load",value:function(e,t,i,n){var r,o=this;r=""!==this.resourcePath?this.resourcePath:""!==this.path?this.path:Ic.extractUrlBase(e),this.manager.itemStart(e);var a=function(t){n?n(t):console.error(t),o.manager.itemError(e),o.manager.itemEnd(e)},s=new Bl(this.manager);s.setPath(this.path),s.setResponseType("arraybuffer"),s.setRequestHeader(this.requestHeader),s.setWithCredentials(this.withCredentials),s.load(e,(function(i){try{o.parse(i,r,(function(i){t(i),o.manager.itemEnd(e)}),a)}catch(e){a(e)}}),i,a)}},{key:"setDRACOLoader",value:function(e){return this.dracoLoader=e,this}},{key:"setDDSLoader",value:function(){throw new Error('THREE.GLTFLoader: "MSFT_texture_dds" no longer supported. Please update to "KHR_texture_basisu".')}},{key:"setKTX2Loader",value:function(e){return this.ktx2Loader=e,this}},{key:"setMeshoptDecoder",value:function(e){return this.meshoptDecoder=e,this}},{key:"register",value:function(e){return-1===this.pluginCallbacks.indexOf(e)&&this.pluginCallbacks.push(e),this}},{key:"unregister",value:function(e){return-1!==this.pluginCallbacks.indexOf(e)&&this.pluginCallbacks.splice(this.pluginCallbacks.indexOf(e),1),this}},{key:"parse",value:function(e,t,i,n){var r,o={},a={};if("string"==typeof e)r=e;else if(Ic.decodeText(new Uint8Array(e,0,4))===nw){try{o[qx.KHR_BINARY_GLTF]=new aw(e)}catch(e){return void(n&&n(e))}r=o[qx.KHR_BINARY_GLTF].content}else r=Ic.decodeText(new Uint8Array(e));var s=JSON.parse(r);if(void 0===s.asset||s.asset.version[0]<2)n&&n(new Error("THREE.GLTFLoader: Unsupported asset. glTF versions >=2.0 are supported."));else{var l=new Lw(s,{path:t||this.resourcePath||"",crossOrigin:this.crossOrigin,requestHeader:this.requestHeader,manager:this.manager,ktx2Loader:this.ktx2Loader,meshoptDecoder:this.meshoptDecoder});l.fileLoader.setRequestHeader(this.requestHeader);for(var c=0;this.pluginCallbacks.length>c;c++){var h=this.pluginCallbacks[c](l);a[h.name]=h,o[h.name]=!0}if(s.extensionsUsed)for(var d=0;s.extensionsUsed.length>d;++d){var u=s.extensionsUsed[d],p=s.extensionsRequired||[];switch(u){case qx.KHR_MATERIALS_UNLIT:o[u]=new Xx;break;case qx.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS:o[u]=new hw;break;case qx.KHR_DRACO_MESH_COMPRESSION:o[u]=new sw(s,this.dracoLoader);break;case qx.KHR_TEXTURE_TRANSFORM:o[u]=new lw;break;case qx.KHR_MESH_QUANTIZATION:o[u]=new dw;break;default:0>p.indexOf(u)||void 0!==a[u]||console.warn('THREE.GLTFLoader: Unknown extension "'+u+'".')}}l.setExtensions(o),l.setPlugins(a),l.parse(i,n)}}}]),i}(Ml);function zx(){var e={};return{get:function(t){return e[t]},add:function(t,i){e[t]=i},remove:function(t){delete e[t]},removeAll:function(){e={}}}}var qx={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"},Zx=function(){function e(t){ru(this,e),this.parser=t,this.name=qx.KHR_LIGHTS_PUNCTUAL,this.cache={refs:{},uses:{}}}return au(e,[{key:"_markDefs",value:function(){for(var e=this.parser,t=this.parser.json.nodes||[],i=0,n=t.length;n>i;i++){var r=t[i];r.extensions&&r.extensions[this.name]&&void 0!==r.extensions[this.name].light&&e._addNodeRef(this.cache,r.extensions[this.name].light)}}},{key:"_loadLight",value:function(e){var t=this.parser,i="light:"+e,n=t.cache.get(i);if(n)return n;var r,o=t.json,a=((o.extensions&&o.extensions[this.name]||{}).lights||[])[e],s=new pi(16777215);void 0!==a.color&&s.fromArray(a.color);var l=void 0!==a.range?a.range:0;switch(a.type){case"directional":(r=new fc(s)).target.position.set(0,0,-1),r.add(r.target);break;case"point":(r=new uc(s)).distance=l;break;case"spot":(r=new sc(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,r.angle=a.spot.outerConeAngle,r.penumbra=1-a.spot.innerConeAngle/a.spot.outerConeAngle,r.target.position.set(0,0,-1),r.add(r.target);break;default:throw new Error("THREE.GLTFLoader: Unexpected light type: "+a.type)}return r.position.set(0,0,0),r.decay=2,void 0!==a.intensity&&(r.intensity=a.intensity),r.name=t.createUniqueName(a.name||"light_"+e),n=Promise.resolve(r),t.cache.add(i,n),n}},{key:"createNodeAttachment",value:function(e){var t=this,i=this.parser,n=i.json.nodes[e],r=(n.extensions&&n.extensions[this.name]||{}).light;return void 0===r?null:this._loadLight(r).then((function(e){return i._getNodeRef(t.cache,r,e)}))}}]),e}(),Xx=function(){function e(){ru(this,e),this.name=qx.KHR_MATERIALS_UNLIT}return au(e,[{key:"getMaterialType",value:function(){return gi}},{key:"extendParams",value:function(e,t,i){var n=[];e.color=new pi(1,1,1),e.opacity=1;var r=t.pbrMetallicRoughness;if(r){if(Array.isArray(r.baseColorFactor)){var o=r.baseColorFactor;e.color.fromArray(o),e.opacity=o[3]}void 0!==r.baseColorTexture&&n.push(i.assignTexture(e,"map",r.baseColorTexture))}return Promise.all(n)}}]),e}(),_x=function(){function e(t){ru(this,e),this.parser=t,this.name=qx.KHR_MATERIALS_CLEARCOAT}return au(e,[{key:"getMaterialType",value:function(e){var t=this.parser.json.materials[e];return t.extensions&&t.extensions[this.name]?_s:null}},{key:"extendMaterialParams",value:function(e,t){var i=this.parser,n=i.json.materials[e];if(!n.extensions||!n.extensions[this.name])return Promise.resolve();var r=[],o=n.extensions[this.name];if(void 0!==o.clearcoatFactor&&(t.clearcoat=o.clearcoatFactor),void 0!==o.clearcoatTexture&&r.push(i.assignTexture(t,"clearcoatMap",o.clearcoatTexture)),void 0!==o.clearcoatRoughnessFactor&&(t.clearcoatRoughness=o.clearcoatRoughnessFactor),void 0!==o.clearcoatRoughnessTexture&&r.push(i.assignTexture(t,"clearcoatRoughnessMap",o.clearcoatRoughnessTexture)),void 0!==o.clearcoatNormalTexture&&(r.push(i.assignTexture(t,"clearcoatNormalMap",o.clearcoatNormalTexture)),void 0!==o.clearcoatNormalTexture.scale)){var a=o.clearcoatNormalTexture.scale;t.clearcoatNormalScale=new ke(a,-a)}return Promise.all(r)}}]),e}(),$x=function(){function e(t){ru(this,e),this.parser=t,this.name=qx.KHR_MATERIALS_TRANSMISSION}return au(e,[{key:"getMaterialType",value:function(e){var t=this.parser.json.materials[e];return t.extensions&&t.extensions[this.name]?_s:null}},{key:"extendMaterialParams",value:function(e,t){var i=this.parser,n=i.json.materials[e];if(!n.extensions||!n.extensions[this.name])return Promise.resolve();var r=[],o=n.extensions[this.name];return void 0!==o.transmissionFactor&&(t.transmission=o.transmissionFactor),void 0!==o.transmissionTexture&&r.push(i.assignTexture(t,"transmissionMap",o.transmissionTexture)),Promise.all(r)}}]),e}(),ew=function(){function e(t){ru(this,e),this.parser=t,this.name=qx.KHR_TEXTURE_BASISU}return au(e,[{key:"loadTexture",value:function(e){var t=this.parser,i=t.json,n=i.textures[e];if(!n.extensions||!n.extensions[this.name])return null;var r=i.images[n.extensions[this.name].source],o=t.options.ktx2Loader;if(!o){if(i.extensionsRequired&&i.extensionsRequired.indexOf(this.name)>=0)throw new Error("THREE.GLTFLoader: setKTX2Loader must be called before loading KTX2 textures");return null}return t.loadTextureImage(e,r,o)}}]),e}(),tw=function(){function e(t){ru(this,e),this.parser=t,this.name=qx.EXT_TEXTURE_WEBP,this.isSupported=null}return au(e,[{key:"loadTexture",value:function(e){var t=this.name,i=this.parser,n=i.json,r=n.textures[e];if(!r.extensions||!r.extensions[t])return null;var o=n.images[r.extensions[t].source],a=i.textureLoader;if(o.uri){var s=i.options.manager.getHandler(o.uri);null!==s&&(a=s)}return this.detectSupport().then((function(r){if(r)return i.loadTextureImage(e,o,a);if(n.extensionsRequired&&n.extensionsRequired.indexOf(t)>=0)throw new Error("THREE.GLTFLoader: WebP required by asset but unsupported.");return i.loadTexture(e)}))}},{key:"detectSupport",value:function(){return this.isSupported||(this.isSupported=new Promise((function(e){var t=new Image;t.src="",t.onload=t.onerror=function(){e(1===t.height)}}))),this.isSupported}}]),e}(),iw=function(){function e(t){ru(this,e),this.name=qx.EXT_MESHOPT_COMPRESSION,this.parser=t}return au(e,[{key:"loadBufferView",value:function(e){var t=this.parser.json,i=t.bufferViews[e];if(i.extensions&&i.extensions[this.name]){var n=i.extensions[this.name],r=this.parser.getDependency("buffer",n.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([r,o.ready]).then((function(e){var t=n.byteOffset||0,i=n.byteLength||0,r=n.count,a=n.byteStride,s=new ArrayBuffer(r*a),l=new Uint8Array(e[0],t,i);return o.decodeGltfBuffer(new Uint8Array(s),r,a,l,n.mode,n.filter),s}))}return null}}]),e}(),nw="glTF",rw=1313821514,ow=5130562,aw=function e(t){ru(this,e),this.name=qx.KHR_BINARY_GLTF,this.content=null,this.body=null;var i=new DataView(t,0,12);if(this.header={magic:Ic.decodeText(new Uint8Array(t.slice(0,4))),version:i.getUint32(4,!0),length:i.getUint32(8,!0)},this.header.magic!==nw)throw new Error("THREE.GLTFLoader: Unsupported glTF-Binary header.");if(2>this.header.version)throw new Error("THREE.GLTFLoader: Legacy binary file detected.");for(var n=this.header.length-12,r=new DataView(t,12),o=0;n>o;){var a=r.getUint32(o,!0),s=r.getUint32(o+=4,!0);if(o+=4,s===rw){var l=new Uint8Array(t,12+o,a);this.content=Ic.decodeText(l)}else if(s===ow){var c=12+o;this.body=t.slice(c,c+a)}o+=a}if(null===this.content)throw new Error("THREE.GLTFLoader: JSON content not found.")},sw=function(){function e(t,i){if(ru(this,e),!i)throw new Error("THREE.GLTFLoader: No DRACOLoader instance provided.");this.name=qx.KHR_DRACO_MESH_COMPRESSION,this.json=t,this.dracoLoader=i,this.dracoLoader.preload()}return au(e,[{key:"decodePrimitive",value:function(e,t){var i=this.json,n=this.dracoLoader,r=e.extensions[this.name].bufferView,o=e.extensions[this.name].attributes,a={},s={},l={};for(var c in o){var h=Mw[c]||c.toLowerCase();a[h]=o[c]}for(var d in e.attributes){var u=Mw[d]||d.toLowerCase();if(void 0!==o[d]){var p=i.accessors[e.attributes[d]];l[u]=Cw[p.componentType],s[u]=!0===p.normalized}}return t.getDependency("bufferView",r).then((function(e){return new Promise((function(t){n.decodeDracoFile(e,(function(e){for(var i in e.attributes){var n=s[i];void 0!==n&&(e.attributes[i].normalized=n)}t(e)}),a,l)}))}))}}]),e}(),lw=function(){function e(){ru(this,e),this.name=qx.KHR_TEXTURE_TRANSFORM}return au(e,[{key:"extendTexture",value:function(e,t){return void 0!==t.texCoord&&console.warn('THREE.GLTFLoader: Custom UV sets in "'+this.name+'" extension not yet supported.'),void 0===t.offset&&void 0===t.rotation&&void 0===t.scale||(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),e.needsUpdate=!0),e}}]),e}(),cw=function(e){lu(i,e);var t=pu(i);function i(e){var n;ru(this,i),(n=t.call(this)).isGLTFSpecularGlossinessMaterial=!0;var r=["#ifdef USE_SPECULARMAP","\tuniform sampler2D specularMap;","#endif"].join("\n"),o=["#ifdef USE_GLOSSINESSMAP","\tuniform sampler2D glossinessMap;","#endif"].join("\n"),a=["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"),s=["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"),l=["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"),c={specular:{value:(new pi).setHex(16777215)},glossiness:{value:1},specularMap:{value:null},glossinessMap:{value:null}};return n._extraUniforms=c,n.onBeforeCompile=function(e){for(var t in c)e.uniforms[t]=c[t];e.fragmentShader=e.fragmentShader.replace("uniform float roughness;","uniform vec3 specular;").replace("uniform float metalness;","uniform float glossiness;").replace("#include <roughnessmap_pars_fragment>",r).replace("#include <metalnessmap_pars_fragment>",o).replace("#include <roughnessmap_fragment>",a).replace("#include <metalnessmap_fragment>",s).replace("#include <lights_physical_fragment>",l)},Object.defineProperties(du(n),{specular:{get:function(){return c.specular.value},set:function(e){c.specular.value=e}},specularMap:{get:function(){return c.specularMap.value},set:function(e){c.specularMap.value=e,e?this.defines.USE_SPECULARMAP="":delete this.defines.USE_SPECULARMAP}},glossiness:{get:function(){return c.glossiness.value},set:function(e){c.glossiness.value=e}},glossinessMap:{get:function(){return c.glossinessMap.value},set:function(e){c.glossinessMap.value=e,e?(this.defines.USE_GLOSSINESSMAP="",this.defines.USE_UV=""):(delete this.defines.USE_GLOSSINESSMAP,delete this.defines.USE_UV)}}}),delete n.metalness,delete n.roughness,delete n.metalnessMap,delete n.roughnessMap,n.setValues(e),n}return au(i,[{key:"copy",value:function(e){return gu(cu(i.prototype),"copy",this).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}}]),i}(Xs),hw=function(){function e(){ru(this,e),this.name=qx.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS,this.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"]}return au(e,[{key:"getMaterialType",value:function(){return cw}},{key:"extendParams",value:function(e,t,i){var n=t.extensions[this.name];e.color=new pi(1,1,1),e.opacity=1;var r=[];if(Array.isArray(n.diffuseFactor)){var o=n.diffuseFactor;e.color.fromArray(o),e.opacity=o[3]}if(void 0!==n.diffuseTexture&&r.push(i.assignTexture(e,"map",n.diffuseTexture)),e.emissive=new pi(0,0,0),e.glossiness=void 0!==n.glossinessFactor?n.glossinessFactor:1,e.specular=new pi(1,1,1),Array.isArray(n.specularFactor)&&e.specular.fromArray(n.specularFactor),void 0!==n.specularGlossinessTexture){var a=n.specularGlossinessTexture;r.push(i.assignTexture(e,"glossinessMap",a)),r.push(i.assignTexture(e,"specularMap",a))}return Promise.all(r)}},{key:"createMaterial",value:function(e){var t=new cw(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=0,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=.98,t}}]),e}(),dw=function e(){ru(this,e),this.name=qx.KHR_MESH_QUANTIZATION},uw=function(e){lu(i,e);var t=pu(i);function i(e,n,r,o){return ru(this,i),t.call(this,e,n,r,o)}return au(i,[{key:"copySampleValue_",value:function(e){for(var t=this.resultBuffer,i=this.sampleValues,n=this.valueSize,r=e*n*3+n,o=0;o!==n;o++)t[o]=i[r+o];return t}}]),i}(sl);uw.prototype.beforeStart_=uw.prototype.copySampleValue_,uw.prototype.afterEnd_=uw.prototype.copySampleValue_,uw.prototype.interpolate_=function(e,t,i,n){for(var r=this.resultBuffer,o=this.sampleValues,a=this.valueSize,s=2*a,l=3*a,c=n-t,h=(i-t)/c,d=h*h,u=d*h,p=e*l,g=p-l,f=-2*u+3*d,m=u-d,A=1-f,y=m-d+h,v=0;v!==a;v++){r[v]=A*o[g+v+a]+y*(o[g+v+s]*c)+f*o[p+v+a]+m*(o[p+v]*c)}return r};var pw=0,gw=1,fw=2,mw=3,Aw=4,yw=5,vw=6,Cw={5120:Int8Array,5121:Uint8Array,5122:Int16Array,5123:Uint16Array,5125:Uint32Array,5126:Float32Array},Iw={9728:A,9729:C,9984:y,9985:I,9986:v,9987:x},xw={33071:f,33648:m,10497:g},ww={SCALAR:1,VEC2:2,VEC3:3,VEC4:4,MAT2:4,MAT3:9,MAT4:16},Mw={POSITION:"position",NORMAL:"normal",TANGENT:"tangent",TEXCOORD_0:"uv",TEXCOORD_1:"uv2",COLOR_0:"color",WEIGHTS_0:"skinWeight",JOINTS_0:"skinIndex"},Ew={scale:"scale",translation:"position",rotation:"quaternion",weights:"morphTargetInfluences"},Bw={CUBICSPLINE:void 0,LINEAR:H,STEP:Y},Sw="OPAQUE",bw="MASK",kw="BLEND";function Dw(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 Tw(e,t,i){for(var n in i.extensions)void 0===e[n]&&(t.userData.gltfExtensions=t.userData.gltfExtensions||{},t.userData.gltfExtensions[n]=i.extensions[n])}function Rw(e,t){void 0!==t.extras&&("object"===nu(t.extras)?Object.assign(e.userData,t.extras):console.warn("THREE.GLTFLoader: Ignoring primitive type .extras, "+t.extras))}function Uw(e,t){if(e.updateMorphTargets(),void 0!==t.weights)for(var i=0,n=t.weights.length;n>i;i++)e.morphTargetInfluences[i]=t.weights[i];if(t.extras&&Array.isArray(t.extras.targetNames)){var r=t.extras.targetNames;if(e.morphTargetInfluences.length===r.length){e.morphTargetDictionary={};for(var o=0,a=r.length;a>o;o++)e.morphTargetDictionary[r[o]]=o}else console.warn("THREE.GLTFLoader: Invalid extras.targetNames length. Ignoring names.")}}function Fw(e){for(var t="",i=Object.keys(e).sort(),n=0,r=i.length;r>n;n++)t+=i[n]+":"+e[i[n]]+";";return t}function Qw(e){switch(e){case Int8Array:return 1/127;case Uint8Array:return 1/255;case Int16Array:return 1/32767;case Uint16Array:return 1/65535;default:throw new Error("THREE.GLTFLoader: Unsupported normalized accessor component type.")}}var Lw=function(){function e(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},i=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};ru(this,e),this.json=t,this.extensions={},this.plugins={},this.options=i,this.cache=new zx,this.associations=new Map,this.primitiveCache={},this.meshCache={refs:{},uses:{}},this.cameraCache={refs:{},uses:{}},this.lightCache={refs:{},uses:{}},this.textureCache={},this.nodeNamesUsed={},this.textureLoader="undefined"!=typeof createImageBitmap&&!1===/Firefox/.test(navigator.userAgent)?new bc(this.options.manager):new Dl(this.options.manager),this.textureLoader.setCrossOrigin(this.options.crossOrigin),this.textureLoader.setRequestHeader(this.options.requestHeader),this.fileLoader=new Bl(this.options.manager),this.fileLoader.setResponseType("arraybuffer"),"use-credentials"===this.options.crossOrigin&&this.fileLoader.setWithCredentials(!0)}return au(e,[{key:"setExtensions",value:function(e){this.extensions=e}},{key:"setPlugins",value:function(e){this.plugins=e}},{key:"parse",value:function(e,t){var i=this,n=this.json,r=this.extensions;this.cache.removeAll(),this._invokeAll((function(e){return e._markDefs&&e._markDefs()})),Promise.all(this._invokeAll((function(e){return e.beforeRoot&&e.beforeRoot()}))).then((function(){return Promise.all([i.getDependencies("scene"),i.getDependencies("animation"),i.getDependencies("camera")])})).then((function(t){var o={scene:t[0][n.scene||0],scenes:t[0],animations:t[1],cameras:t[2],asset:n.asset,parser:i,userData:{}};Tw(r,o,n),Rw(o,n),Promise.all(i._invokeAll((function(e){return e.afterRoot&&e.afterRoot(o)}))).then((function(){e(o)}))})).catch(t)}},{key:"_markDefs",value:function(){for(var e=this.json.nodes||[],t=this.json.skins||[],i=this.json.meshes||[],n=0,r=t.length;r>n;n++)for(var o=t[n].joints,a=0,s=o.length;s>a;a++)e[o[a]].isBone=!0;for(var l=0,c=e.length;c>l;l++){var h=e[l];void 0!==h.mesh&&(this._addNodeRef(this.meshCache,h.mesh),void 0!==h.skin&&(i[h.mesh].isSkinnedMesh=!0)),void 0!==h.camera&&this._addNodeRef(this.cameraCache,h.camera)}}},{key:"_addNodeRef",value:function(e,t){void 0!==t&&(void 0===e.refs[t]&&(e.refs[t]=e.uses[t]=0),e.refs[t]++)}},{key:"_getNodeRef",value:function(e,t,i){if(1>=e.refs[t])return i;var n=i.clone();return n.name+="_instance_"+e.uses[t]++,n}},{key:"_invokeOne",value:function(e){var t=Object.values(this.plugins);t.push(this);for(var i=0;t.length>i;i++){var n=e(t[i]);if(n)return n}return null}},{key:"_invokeAll",value:function(e){var t=Object.values(this.plugins);t.unshift(this);for(var i=[],n=0;t.length>n;n++){var r=e(t[n]);r&&i.push(r)}return i}},{key:"getDependency",value:function(e,t){var i=e+":"+t,n=this.cache.get(i);if(!n){switch(e){case"scene":n=this.loadScene(t);break;case"node":n=this.loadNode(t);break;case"mesh":n=this._invokeOne((function(e){return e.loadMesh&&e.loadMesh(t)}));break;case"accessor":n=this.loadAccessor(t);break;case"bufferView":n=this._invokeOne((function(e){return e.loadBufferView&&e.loadBufferView(t)}));break;case"buffer":n=this.loadBuffer(t);break;case"material":n=this._invokeOne((function(e){return e.loadMaterial&&e.loadMaterial(t)}));break;case"texture":n=this._invokeOne((function(e){return e.loadTexture&&e.loadTexture(t)}));break;case"skin":n=this.loadSkin(t);break;case"animation":n=this.loadAnimation(t);break;case"camera":n=this.loadCamera(t);break;default:throw new Error("Unknown type: "+e)}this.cache.add(i,n)}return n}},{key:"getDependencies",value:function(e){var t=this.cache.get(e);if(!t){var i=this;t=Promise.all((this.json[e+("mesh"===e?"es":"s")]||[]).map((function(t,n){return i.getDependency(e,n)}))),this.cache.add(e,t)}return t}},{key:"loadBuffer",value:function(e){var t=this.json.buffers[e],i=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[qx.KHR_BINARY_GLTF].body);var n=this.options;return new Promise((function(e,r){i.load(Dw(t.uri,n.path),e,void 0,(function(){r(new Error('THREE.GLTFLoader: Failed to load buffer "'+t.uri+'".'))}))}))}},{key:"loadBufferView",value:function(e){var t=this.json.bufferViews[e];return this.getDependency("buffer",t.buffer).then((function(e){var i=t.byteOffset||0;return e.slice(i,i+(t.byteLength||0))}))}},{key:"loadAccessor",value:function(e){var t=this,i=this.json,n=this.json.accessors[e];if(void 0===n.bufferView&&void 0===n.sparse)return Promise.resolve(null);var r=[];return r.push(void 0!==n.bufferView?this.getDependency("bufferView",n.bufferView):null),void 0!==n.sparse&&(r.push(this.getDependency("bufferView",n.sparse.indices.bufferView)),r.push(this.getDependency("bufferView",n.sparse.values.bufferView))),Promise.all(r).then((function(e){var r,o,a=e[0],s=ww[n.type],l=Cw[n.componentType],c=l.BYTES_PER_ELEMENT,h=n.byteOffset||0,d=void 0!==n.bufferView?i.bufferViews[n.bufferView].byteStride:void 0,u=!0===n.normalized;if(d&&d!==c*s){var p=Math.floor(h/d),g="InterleavedBuffer:"+n.bufferView+":"+n.componentType+":"+p+":"+n.count,f=t.cache.get(g);f||(r=new l(a,p*d,n.count*d/c),f=new Yo(r,d/c),t.cache.add(g,f)),o=new jo(f,s,h%d/c,u)}else r=null===a?new l(n.count*s):new l(a,h,n.count*s),o=new Ai(r,s,u);if(void 0!==n.sparse){var m=n.sparse.values.byteOffset||0,A=new(0,Cw[n.sparse.indices.componentType])(e[1],n.sparse.indices.byteOffset||0,n.sparse.count*ww.SCALAR),y=new l(e[2],m,n.sparse.count*s);null!==a&&(o=new Ai(o.array.slice(),o.itemSize,o.normalized));for(var v=0,C=A.length;C>v;v++){var I=A[v];if(o.setX(I,y[v*s]),2>s||o.setY(I,y[v*s+1]),3>s||o.setZ(I,y[v*s+2]),4>s||o.setW(I,y[v*s+3]),s>=5)throw new Error("THREE.GLTFLoader: Unsupported itemSize in sparse BufferAttribute.")}}return o}))}},{key:"loadTexture",value:function(e){var t=this.json,i=t.images[t.textures[e].source],n=this.textureLoader;if(i.uri){var r=this.options.manager.getHandler(i.uri);null!==r&&(n=r)}return this.loadTextureImage(e,i,n)}},{key:"loadTextureImage",value:function(e,t,i){var n=this,r=this.json,o=this.options,a=r.textures[e],s=(t.uri||t.bufferView)+":"+a.sampler;if(this.textureCache[s])return this.textureCache[s];var l=self.URL||self.webkitURL,c=t.uri||"",h=!1,d=!0,u=c.search(/\.jpe?g($|\?)/i)>0||0===c.search(/^data\:image\/jpeg/);if(("image/jpeg"===t.mimeType||u)&&(d=!1),void 0!==t.bufferView)c=n.getDependency("bufferView",t.bufferView).then((function(e){if("image/png"===t.mimeType){var i=new DataView(e,25,1).getUint8(0,!1);d=6===i||4===i||3===i}h=!0;var n=new Blob([e],{type:t.mimeType});return c=l.createObjectURL(n)}));else if(void 0===t.uri)throw new Error("THREE.GLTFLoader: Image "+e+" is missing URI and bufferView");var p=Promise.resolve(c).then((function(e){return new Promise((function(t,n){var r=t;!0===i.isImageBitmapLoader&&(r=function(e){t(new Ja(e))}),i.load(Dw(e,o.path),r,void 0,n)}))})).then((function(t){!0===h&&l.revokeObjectURL(c),t.flipY=!1,a.name&&(t.name=a.name),d||(t.format=k);var i=(r.samplers||{})[a.sampler]||{};return t.magFilter=Iw[i.magFilter]||C,t.minFilter=Iw[i.minFilter]||x,t.wrapS=xw[i.wrapS]||g,t.wrapT=xw[i.wrapT]||g,n.associations.set(t,{type:"textures",index:e}),t}));return this.textureCache[s]=p,p}},{key:"assignTexture",value:function(e,t,i){var n=this;return this.getDependency("texture",i.index).then((function(r){if(void 0===i.texCoord||0==i.texCoord||"aoMap"===t&&1==i.texCoord||console.warn("THREE.GLTFLoader: Custom UV set "+i.texCoord+" for texture "+t+" not yet supported."),n.extensions[qx.KHR_TEXTURE_TRANSFORM]){var o=void 0!==i.extensions?i.extensions[qx.KHR_TEXTURE_TRANSFORM]:void 0;if(o){var a=n.associations.get(r);r=n.extensions[qx.KHR_TEXTURE_TRANSFORM].extendTexture(r,o),n.associations.set(r,a)}}e[t]=r}))}},{key:"assignFinalMaterial",value:function(e){var t=e.geometry,i=e.material,n=void 0!==t.attributes.tangent,r=void 0!==t.attributes.color,o=void 0===t.attributes.normal,a=Object.keys(t.morphAttributes).length>0,s=a&&void 0!==t.morphAttributes.normal;if(e.isPoints){var l="PointsMaterial:"+i.uuid,c=this.cache.get(l);c||(c=new Na,ai.prototype.copy.call(c,i),c.color.copy(i.color),c.map=i.map,c.sizeAttenuation=!1,this.cache.add(l,c)),i=c}else if(e.isLine){var h="LineBasicMaterial:"+i.uuid,d=this.cache.get(h);d||(d=new Sa,ai.prototype.copy.call(d,i),d.color.copy(i.color),this.cache.add(h,d)),i=d}if(n||r||o||a){var u="ClonedMaterial:"+i.uuid+":";i.isGLTFSpecularGlossinessMaterial&&(u+="specular-glossiness:"),n&&(u+="vertex-tangents:"),r&&(u+="vertex-colors:"),o&&(u+="flat-shading:"),a&&(u+="morph-targets:"),s&&(u+="morph-normals:");var p=this.cache.get(u);p||(p=i.clone(),r&&(p.vertexColors=!0),o&&(p.flatShading=!0),a&&(p.morphTargets=!0),s&&(p.morphNormals=!0),n&&(p.vertexTangents=!0,p.normalScale&&(p.normalScale.y*=-1),p.clearcoatNormalScale&&(p.clearcoatNormalScale.y*=-1)),this.cache.add(u,p),this.associations.set(p,this.associations.get(i))),i=p}i.aoMap&&void 0===t.attributes.uv2&&void 0!==t.attributes.uv&&t.setAttribute("uv2",t.attributes.uv),e.material=i}},{key:"getMaterialType",value:function(){return Xs}},{key:"loadMaterial",value:function(e){var t,i=this,n=this.extensions,r=this.json.materials[e],o={},a=r.extensions||{},s=[];if(a[qx.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS]){var l=n[qx.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS];t=l.getMaterialType(),s.push(l.extendParams(o,r,i))}else if(a[qx.KHR_MATERIALS_UNLIT]){var c=n[qx.KHR_MATERIALS_UNLIT];t=c.getMaterialType(),s.push(c.extendParams(o,r,i))}else{var h=r.pbrMetallicRoughness||{};if(o.color=new pi(1,1,1),o.opacity=1,Array.isArray(h.baseColorFactor)){var d=h.baseColorFactor;o.color.fromArray(d),o.opacity=d[3]}void 0!==h.baseColorTexture&&s.push(i.assignTexture(o,"map",h.baseColorTexture)),o.metalness=void 0!==h.metallicFactor?h.metallicFactor:1,o.roughness=void 0!==h.roughnessFactor?h.roughnessFactor:1,void 0!==h.metallicRoughnessTexture&&(s.push(i.assignTexture(o,"metalnessMap",h.metallicRoughnessTexture)),s.push(i.assignTexture(o,"roughnessMap",h.metallicRoughnessTexture))),t=this._invokeOne((function(t){return t.getMaterialType&&t.getMaterialType(e)})),s.push(Promise.all(this._invokeAll((function(t){return t.extendMaterialParams&&t.extendMaterialParams(e,o)}))))}!0===r.doubleSided&&(o.side=2);var u=r.alphaMode||Sw;return u===kw?(o.transparent=!0,o.depthWrite=!1):(o.transparent=!1,u===bw&&(o.alphaTest=void 0!==r.alphaCutoff?r.alphaCutoff:.5)),void 0!==r.normalTexture&&t!==gi&&(s.push(i.assignTexture(o,"normalMap",r.normalTexture)),o.normalScale=new ke(1,-1),void 0!==r.normalTexture.scale&&o.normalScale.set(r.normalTexture.scale,-r.normalTexture.scale)),void 0!==r.occlusionTexture&&t!==gi&&(s.push(i.assignTexture(o,"aoMap",r.occlusionTexture)),void 0!==r.occlusionTexture.strength&&(o.aoMapIntensity=r.occlusionTexture.strength)),void 0!==r.emissiveFactor&&t!==gi&&(o.emissive=(new pi).fromArray(r.emissiveFactor)),void 0!==r.emissiveTexture&&t!==gi&&s.push(i.assignTexture(o,"emissiveMap",r.emissiveTexture)),Promise.all(s).then((function(){var a;return a=t===cw?n[qx.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS].createMaterial(o):new t(o),r.name&&(a.name=r.name),a.map&&(a.map.encoding=_),a.emissiveMap&&(a.emissiveMap.encoding=_),Rw(a,r),i.associations.set(a,{type:"materials",index:e}),r.extensions&&Tw(n,a,r),a}))}},{key:"createUniqueName",value:function(e){for(var t=lh.sanitizeNodeName(e||""),i=t,n=1;this.nodeNamesUsed[i];++n)i=t+"_"+n;return this.nodeNamesUsed[i]=!0,i}},{key:"loadGeometries",value:function(e){var t=this,i=this.extensions,n=this.primitiveCache;function r(e){return i[qx.KHR_DRACO_MESH_COMPRESSION].decodePrimitive(e,t).then((function(i){return Nw(i,e,t)}))}for(var o,a,s=[],l=0,c=e.length;c>l;l++){var h=e[l],d=(a=void 0,(a=(o=h).extensions&&o.extensions[qx.KHR_DRACO_MESH_COMPRESSION])?"draco:"+a.bufferView+":"+a.indices+":"+Fw(a.attributes):o.indices+":"+Fw(o.attributes)+":"+o.mode),u=n[d];if(u)s.push(u.promise);else{var p=void 0;p=h.extensions&&h.extensions[qx.KHR_DRACO_MESH_COMPRESSION]?r(h):Nw(new jx,h,t),n[d]={primitive:h,promise:p},s.push(p)}}return Promise.all(s)}},{key:"loadMesh",value:function(e){for(var t,i=this,n=this.extensions,r=this.json.meshes[e],o=r.primitives,a=[],s=0,l=o.length;l>s;s++){var c=void 0===o[s].material?(void 0===(t=this.cache).DefaultMaterial&&(t.DefaultMaterial=new Xs({color:16777215,emissive:0,metalness:1,roughness:1,transparent:!1,depthTest:!0,side:0})),t.DefaultMaterial):this.getDependency("material",o[s].material);a.push(c)}return a.push(i.loadGeometries(o)),Promise.all(a).then((function(t){for(var a=t.slice(0,t.length-1),s=t[t.length-1],l=[],c=0,h=s.length;h>c;c++){var d=s[c],u=o[c],p=void 0,g=a[c];if(u.mode===Aw||u.mode===yw||u.mode===vw||void 0===u.mode)!0!==(p=!0===r.isSkinnedMesh?new ma(d,g):new Wx(d,g)).isSkinnedMesh||p.geometry.attributes.skinWeight.normalized||p.normalizeSkinWeights(),u.mode===yw?p.geometry=Pw(p.geometry,1):u.mode===vw&&(p.geometry=Pw(p.geometry,2));else if(u.mode===gw)p=new La(d,g);else if(u.mode===mw)p=new Ua(d,g);else if(u.mode===fw)p=new Oa(d,g);else{if(u.mode!==pw)throw new Error("THREE.GLTFLoader: Primitive mode unsupported: "+u.mode);p=new Ya(d,g)}Object.keys(p.geometry.morphAttributes).length>0&&Uw(p,r),p.name=i.createUniqueName(r.name||"mesh_"+e),Rw(p,r),u.extensions&&Tw(n,p,u),i.assignFinalMaterial(p),l.push(p)}if(1===l.length)return l[0];for(var f=new To,m=0,A=l.length;A>m;m++)f.add(l[m]);return f}))}},{key:"loadCamera",value:function(e){var t,i=this.json.cameras[e],n=i[i.type];if(n)return"perspective"===i.type?t=new dn(be.radToDeg(n.yfov),n.aspectRatio||1,n.znear||1,n.zfar||2e6):"orthographic"===i.type&&(t=new pc(-n.xmag,n.xmag,n.ymag,-n.ymag,n.znear,n.zfar)),i.name&&(t.name=this.createUniqueName(i.name)),Rw(t,i),Promise.resolve(t);console.warn("THREE.GLTFLoader: Missing camera parameters.")}},{key:"loadSkin",value:function(e){var t=this.json.skins[e],i={joints:t.joints};return void 0===t.inverseBindMatrices?Promise.resolve(i):this.getDependency("accessor",t.inverseBindMatrices).then((function(e){return i.inverseBindMatrices=e,i}))}},{key:"loadAnimation",value:function(e){for(var t=this.json.animations[e],i=[],n=[],r=[],o=[],a=[],s=0,l=t.channels.length;l>s;s++){var c=t.channels[s],h=t.samplers[c.sampler],d=c.target,u=void 0!==t.parameters?t.parameters[h.input]:h.input,p=void 0!==t.parameters?t.parameters[h.output]:h.output;i.push(this.getDependency("node",void 0!==d.node?d.node:d.id)),n.push(this.getDependency("accessor",u)),r.push(this.getDependency("accessor",p)),o.push(h),a.push(d)}return Promise.all([Promise.all(i),Promise.all(n),Promise.all(r),Promise.all(o),Promise.all(a)]).then((function(i){for(var n=i[0],r=i[1],o=i[2],a=i[3],s=i[4],l=[],c=function(e,t){var i=n[e],c=r[e],h=o[e],d=a[e],u=s[e];if(void 0===i)return"continue";i.updateMatrix(),i.matrixAutoUpdate=!0;var p=void 0;switch(Ew[u.path]){case Ew.weights:p=gl;break;case Ew.rotation:p=ml;break;case Ew.position:case Ew.scale:default:p=yl}var g=i.name?i.name:i.uuid,f=void 0!==d.interpolation?Bw[d.interpolation]:H,m=[];Ew[u.path]===Ew.weights?i.traverse((function(e){!0===e.isMesh&&e.morphTargetInfluences&&m.push(e.name?e.name:e.uuid)})):m.push(g);var A=h.array;if(h.normalized){for(var y=Qw(A.constructor),v=new Float32Array(A.length),C=0,I=A.length;I>C;C++)v[C]=A[C]*y;A=v}for(var x=0,w=m.length;w>x;x++){var M=new p(m[x]+"."+Ew[u.path],c.array,A,f);"CUBICSPLINE"===d.interpolation&&(M.createInterpolant=function(e){return new uw(this.times,this.values,this.getValueSize()/3,e)},M.createInterpolant.isInterpolantFactoryMethodGLTFCubicSpline=!0),l.push(M)}},h=0,d=n.length;d>h;h++)c(h);return new vl(t.name?t.name:"animation_"+e,void 0,l)}))}},{key:"createNodeMesh",value:function(e){var t=this,i=this.json.nodes[e];return void 0===i.mesh?null:t.getDependency("mesh",i.mesh).then((function(e){var n=t._getNodeRef(t.meshCache,i.mesh,e);return void 0!==i.weights&&n.traverse((function(e){if(e.isMesh)for(var t=0,n=i.weights.length;n>t;t++)e.morphTargetInfluences[t]=i.weights[t]})),n}))}},{key:"loadNode",value:function(e){var t,i,n=this.extensions,r=this,o=this.json.nodes[e],a=o.name?r.createUniqueName(o.name):"";return(t=[],i=r._invokeOne((function(t){return t.createNodeMesh&&t.createNodeMesh(e)})),i&&t.push(i),void 0!==o.camera&&t.push(r.getDependency("camera",o.camera).then((function(e){return r._getNodeRef(r.cameraCache,o.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 i;if((i=!0===o.isBone?new Aa:t.length>1?new To:1===t.length?t[0]:new Yt)!==t[0])for(var s=0,l=t.length;l>s;s++)i.add(t[s]);if(o.name&&(i.userData.name=o.name,i.name=a),Rw(i,o),o.extensions&&Tw(n,i,o),void 0!==o.matrix){var c=new yt;c.fromArray(o.matrix),i.applyMatrix4(c)}else void 0!==o.translation&&i.position.fromArray(o.translation),void 0!==o.rotation&&i.quaternion.fromArray(o.rotation),void 0!==o.scale&&i.scale.fromArray(o.scale);return r.associations.set(i,{type:"nodes",index:e}),i}))}},{key:"loadScene",value:function(e){var t=this.json,i=this.extensions,n=this.json.scenes[e],r=new To;n.name&&(r.name=this.createUniqueName(n.name)),Rw(r,n),n.extensions&&Tw(i,r,n);for(var o=n.nodes||[],a=[],s=0,l=o.length;l>s;s++)a.push(Ow(o[s],r,t,this));return Promise.all(a).then((function(){return r}))}}]),e}();function Ow(e,t,i,n){var r=i.nodes[e];return n.getDependency("node",e).then((function(e){return void 0===r.skin?e:n.getDependency("skin",r.skin).then((function(e){for(var i=[],r=0,o=(t=e).joints.length;o>r;r++)i.push(n.getDependency("node",t.joints[r]));return Promise.all(i)})).then((function(i){return e.traverse((function(e){if(e.isMesh){for(var n=[],r=[],o=0,a=i.length;a>o;o++){var s=i[o];if(s){n.push(s);var l=new yt;void 0!==t.inverseBindMatrices&&l.fromArray(t.inverseBindMatrices.array,16*o),r.push(l)}else console.warn('THREE.GLTFLoader: Joint "%s" could not be found.',t.joints[o])}e.bind(new Ia(n,r),e.matrixWorld)}})),e}));var t})).then((function(e){t.add(e);var o=[];if(r.children)for(var a=r.children,s=0,l=a.length;l>s;s++){o.push(Ow(a[s],e,i,n))}return Promise.all(o)}))}function Nw(e,t,i){var n=t.attributes,r=[];function o(t,n){return i.getDependency("accessor",t).then((function(t){e.setAttribute(n,t)}))}for(var a in n){var s=Mw[a]||a.toLowerCase();s in e.attributes||r.push(o(n[a],s))}if(void 0!==t.indices&&!e.index){var l=i.getDependency("accessor",t.indices).then((function(t){e.setIndex(t)}));r.push(l)}return Rw(e,t),function(e,t,i){var n=t.attributes,r=new He;if(void 0!==n.POSITION){var o=i.json.accessors[n.POSITION],a=o.min,s=o.max;if(void 0!==a&&void 0!==s){if(r.set(new Ke(a[0],a[1],a[2]),new Ke(s[0],s[1],s[2])),o.normalized){var l=Qw(Cw[o.componentType]);r.min.multiplyScalar(l),r.max.multiplyScalar(l)}var c=t.targets;if(void 0!==c){for(var h=new Ke,d=new Ke,u=0,p=c.length;p>u;u++){var g=c[u];if(void 0!==g.POSITION){var f=i.json.accessors[g.POSITION],m=f.min,A=f.max;if(void 0!==m&&void 0!==A){if(d.setX(Math.max(Math.abs(m[0]),Math.abs(A[0]))),d.setY(Math.max(Math.abs(m[1]),Math.abs(A[1]))),d.setZ(Math.max(Math.abs(m[2]),Math.abs(A[2]))),f.normalized){var y=Qw(Cw[f.componentType]);d.multiplyScalar(y)}h.max(d)}else console.warn("THREE.GLTFLoader: Missing min/max properties for accessor POSITION.")}}r.expandByVector(h)}e.boundingBox=r;var v=new ct;r.getCenter(v.center),v.radius=r.min.distanceTo(r.max)/2,e.boundingSphere=v}else console.warn("THREE.GLTFLoader: Missing min/max properties for accessor POSITION.")}}(e,t,i),Promise.all(r).then((function(){return void 0!==t.targets?function(e,t,i){for(var n=!1,r=!1,o=0,a=t.length;a>o;o++){var s=t[o];if(void 0!==s.POSITION&&(n=!0),void 0!==s.NORMAL&&(r=!0),n&&r)break}if(!n&&!r)return Promise.resolve(e);for(var l=[],c=[],h=0,d=t.length;d>h;h++){var u=t[h];if(n){var p=void 0!==u.POSITION?i.getDependency("accessor",u.POSITION):e.attributes.position;l.push(p)}if(r){var g=void 0!==u.NORMAL?i.getDependency("accessor",u.NORMAL):e.attributes.normal;c.push(g)}}return Promise.all([Promise.all(l),Promise.all(c)]).then((function(t){var i=t[1];return n&&(e.morphAttributes.position=t[0]),r&&(e.morphAttributes.normal=i),e.morphTargetsRelative=!0,e}))}(e,t.targets,i):e}))}function Pw(e,t){var i=e.getIndex();if(null===i){var n=[],r=e.getAttribute("position");if(void 0===r)return console.error("THREE.GLTFLoader.toTrianglesDrawMode(): Undefined position attribute. Processing not possible."),e;for(var o=0;r.count>o;o++)n.push(o);e.setIndex(n),i=e.getIndex()}var a=i.count-2,s=[];if(2===t)for(var l=1;a>=l;l++)s.push(i.getX(0)),s.push(i.getX(l)),s.push(i.getX(l+1));else for(var c=0;a>c;c++)c%2==0?(s.push(i.getX(c)),s.push(i.getX(c+1)),s.push(i.getX(c+2))):(s.push(i.getX(c+2)),s.push(i.getX(c+1)),s.push(i.getX(c)));s.length/3!==a&&console.error("THREE.GLTFLoader.toTrianglesDrawMode(): Unable to generate correct amount of triangles.");var h=e.clone();return h.setIndex(s),h}var Gw=function(e){this.baseElementPickingId=0,this.elementDesc={},this.elementMatrix={},this.elementMatrixGroup={},this.srcMeshGeoInfo=e.geoInfo?e.geoInfo:null,this.propertiesData=e.propInfo?e.propInfo:null,this.elementInfo=e.elemInfo?e.elemInfo:null,this.elementKeyToIdMap={},this.elementPickingIds=[],this.sceneTag=e.sceneTag?e.sceneTag:null,this.SetElementDesc=function(e,t){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:null;this.elementDesc[e]=t,i&&(this.elementKeyToIdMap[i]||(this.elementKeyToIdMap[i]=[]),this.elementKeyToIdMap[i].push(e+this.baseElementPickingId))},this.SetElementMatrix=function(e,t){this.elementMatrix[e]=t},this.SetElementGroupMatrix=function(e,t){this.elementMatrixGroup[e]=t},this.AddElementWitId=function(e){var t=e+0;return this.elementPickingIds.push(t),t},this.GetElementPickingIdByKey=function(e){return void 0!==this.elementKeyToIdMap[e]?this.elementKeyToIdMap[e]:null},this.GetElementKeyByPickingId=function(e){return this.elementDesc[e-this.baseElementPickingId].key},this.GetElementGeometryDesc=function(e){var t=this.elementDesc[e-this.baseElementPickingId];return{positionBuffer:t.mesh.geometry.attributes.position.data,indexBuffer:t.mesh.geometry.index,indexOffset:3*t.groupStart,triangleCount:t.groupCount,matrix:(new Matrix4).multiplyMatrices(this.elementMatrix[e-this.baseElementPickingId],this.elementMatrixGroup[e-this.baseElementPickingId])}},this.GetElementBounds=function(e){return this.elementInfo?{min:this.elementInfo[e-this.baseElementPickingId].minBoundary,max:this.elementInfo[e-this.baseElementPickingId].maxBoundary}:null},this.GetElementInfo=function(e){return this.elementInfo?this.elementInfo[e-this.baseElementPickingId]:null},this.GetElementCount=function(){return this.elementPickingIds.length},this.GetElementDesc=function(e){return this.elementDesc[e-this.baseElementPickingId]},this.GetElementDescWithInternalId=function(e){return this.elementDesc[e]},this.GetElementPickingIdWithRelativeId=function(e){return e+this.baseElementPickingId},this.GetElementRelativeIdWithPickingId=function(e){return e-this.baseElementPickingId},this.GetElementGroupDesc=function(e){for(var t=0,i=0;this.propertiesData.length>i;++i){if(this.propertiesData[i].g+t>=e-this.baseElementPickingId){var n=[],r=[];if(!this.propertiesData[i].prop["编码"])return[];for(var o=this.propertiesData[i].g+t,a=t;o>a;++a)n.push(this.elementDesc[a]),r.push(this.baseElementPickingId+a);return{groupDescs:n,groupIds:r}}t+=this.propertiesData[i].g}return[]},this.GetElementMatrix=function(e){return this.elementMatrix[e-this.baseElementPickingId]},this.GetElementGroupMatrix=function(e){return this.elementMatrixGroup[e-this.baseElementPickingId]},this.GetElementProperty=function(e){for(var t=0,i=0;this.propertiesData.length>i;++i){if(this.propertiesData[i].g+t>e-this.baseElementPickingId)return this.propertiesData[i].prop;t+=this.propertiesData[i].g}return{}},this.GetElementGroupBoundsCenter=function(e){for(var t=0,i=0;this.propertiesData.length>i;++i){if(this.propertiesData[i].g+t>=e-this.baseElementPickingId)return this.propertiesData[i].bounds&&this.propertiesData[i].bounds.center?new Vector3(this.propertiesData[i].bounds.center[0],this.propertiesData[i].bounds.center[1],this.propertiesData[i].bounds.center[2]):null;t+=this.propertiesData[i].g}return null},this.GetElementGroupBounds=function(e){for(var t=0,i=0;this.propertiesData.length>i;++i){if(this.propertiesData[i].g+t>=e-this.baseElementPickingId)return this.propertiesData[i].bounds&&this.propertiesData[i].bounds.center?{center:new Vector3(this.propertiesData[i].bounds.center[0],this.propertiesData[i].bounds.center[1],this.propertiesData[i].bounds.center[2]),size:new Vector3(this.propertiesData[i].bounds.size[0],this.propertiesData[i].bounds.size[1],this.propertiesData[i].bounds.size[2])}:null;t+=this.propertiesData[i].g}return null},this.QueryElementFromProperty=function(e){for(var t=0,i=[],n=0;this.propertiesData.length>n;++n)this.propertiesData[n].prop["名称"]==e.name&&this.propertiesData[n].prop["编码"]==e.code&&i.push(this.baseElementPickingId+t+1),t+=this.propertiesData[n].g;return i.length>0?i:null}},Kw=function(e){zy.call(this,e),this.symbolReader=null,this.userIdReader=null,this.userDataReader=null,this.mapSceneReader={},this.lightmap=!1,this.mapNodeInfoByCategory={},this.mapNodeInfoByUserId={},this.mapNodeInfoByNodeId={},this.mapNodeInfoByComponentKey={},this.mapNodeInfoByParameterizedDesc={},this.mapNodeInfoByGeometryId={},this.mapNodeInfoByElementId={},this.referencedMeshCache={},this.componentCount=0,this.borderLines={},this.octreeRootNode={inner:null,outer:null,layer:null},this.meshCache={},this.allBones={},this.model=e,this.sceneTasks=[]};Object.assign(Kw.prototype,zy.prototype),Kw.prototype._cacheNodeInfoByElementId=function(e){this.mapNodeInfoByElementId[e.elementId]=e},Kw.prototype.getNodeInfosByElementId=function(e){return this.mapNodeInfoByElementId[e]},Kw.prototype.pushSceneTask=function(e){this.sceneTasks.push(e)},Kw.prototype.buildScene=function(e){for(var t=0;this.sceneTasks.length>t;t+=1)this._buildScene(this.sceneTasks[t]);e&&e()},Kw.prototype._buildScene=function(e){new Gw(e)},Kw.prototype.destroy=function(){this.destroyReader(),this.octreeRootNode=null,this.mapNodeInfoByCategory={},this.mapNodeInfoByUserId={},this.mapNodeInfoByNodeId={},this.mapNodeInfoByComponentKey={},this.mapNodeInfoByParameterizedDesc={},this.mapNodeInfoByGeometryId={},this.referencedMeshCache={},this.componentCount=0,this.borderLines={}},Kw.prototype.destroyReader=function(){this.userIdReader={},this.userDataReader={},this.symbolReader={},this.mapSceneReader={}},Kw.prototype.getSceneReaderMap=function(){return this.mapSceneReader},Kw.prototype.isValidScene=function(){return!wp.isEmptyObject(this.getSceneReaderMap())||(Bu.log("model load not started!"),!1)},Kw.prototype.parseItemData=function(e){var t=this.model;(my(t.dataVersion,"2.0.0")||void 0===t.dataVersion)&&(Bu.time("升级几何结构"),this._updateV1ToV2(t),t.dataVersion="2.0.0",Bu.timeEnd("升级几何结构")),this._readMaterialBuffer(t),t.hasAnimation&&xd.EnableAnimation?(this._parseClips(),this._parseBones()):this._parseGeo();var i={},n=this.referencedMeshCache;for(var r in Bu.time("_readItemData"),n.bufferData&&Object.keys(n.bufferData).length>0||e&&e(),n.components)this._readItemData(i,r,r,void 0,0);t.hasAnimation&&xd.EnableAnimation&&this._parseNodes(),Bu.timeEnd("_readItemData"),i=null,e&&e()},Kw.prototype.asyncParseItemData=function(e){for(var t=this.getSceneReaderMap(),i=Object.keys(t),n=i.length,r=0,o=this,a=0;n>a;a+=1){var s=t[i[a]];wp.asyncProcess(s,s.header.componentCount,100,(function(e,t){o._parseItemDataBy(e,t)}),(function(){(r+=1)===n&&e&&e()}))}},Kw.prototype._parseItemDataBy=function(e,t){for(var i=e.getComponentInfo(t),n=i.itemIndex;i.itemCount>n;n+=1)this._readItemData(e,n,t)},Kw.prototype.parseItemDataByComponentKey=function(e){var t=this.getSceneReaderMap();for(var i in t)this._parseItemDataBy(t[i],e)},Kw.prototype._readItemData=function(e,t,i){var n=this.referencedMeshCache.components[t];void 0!==n&&-1!==n.geoId&&this._readMeshInfo(e,i,n,null)},Kw.prototype._readSymbolInfo=function(e,t,i){var n=this.symbolReader;if(n){var r=n.header.symbolCount,o=i.toData,a=e.getMatrixInfo(i.matrixId).matrix.clone(),s={matrix:a,ItemId:i.ItemId,originalId:i.originalId,userDataId:i.userDataId,materialId:i.materialId};if(o>=0&&r>o)for(var l=n.getSymbolInfo(o),c=l.itemIndex;l.itemCount>c;c+=1){var h=n.getItemInfo(c);h.type!==Kw.EnumNodeItemType.SYMBOL&&this._readMeshInfo(n,t,h,s)}a=null,s=null,n=null}},Kw.prototype._readMeshInfo=function(e){var t=e.info,i=new He;t.minBoundary&&(i.expandByPoint(new Ke(t.minBoundary.x,t.minBoundary.y,t.minBoundary.z)),i.expandByPoint(new Ke(t.maxBoundary.x,t.maxBoundary.y,t.maxBoundary.z)));var n=null;(n={nodeId:e.key+"_"+e.elementId,elementId:e.elementId,groupIndex:e.groupIndex,subInstanceIndex:e.subInstanceIndex,guid:e.guid,geometryId:e.geoId,originalGeometryId:e.geoId,matrix:e.matrix.clone(),boundingBox:i,model:this.model,mesh:e.mesh,group:{start:e.groupStart,count:e.groupCount,elementId:e.elementId}})&&(t.buildInCategory&&(n.buildInCategory=t.buildInCategory),n.userId=t.key,n.name=t.name,n.type=t.type,n.componentKey=t.key,n.originalId=null,n.materialId=e.materialId,n.state=Nd.Visible,n.material=null,n.originMId=e.materialId,n.userData=null,n.categoryId=0,n.familyName=t.familyName||"",n.familySymbol=t.familySymbol||"",n.isMixNode=!0,this._classifyNodeInfo(n),this._cacheNodeInfoByElementId(n),n=null)},Kw.prototype._getMeshNodeAttr=function(e,t,i,n){var r=new yt;r.fromArray(t.matrix||[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1]),xd.DataReduction&&r.scale(new Ke(1e3,1e3,1e3));var o=i?t.key+"_"+n:t.key,a=i?t.geoId+"_"+n:t.geoId;if(-1!==a){var s=new Nu,l=this.getReferencedMeshBufferById(t.geoId);return l&&l.position?(s=by.getBoundingBoxByBuffer(l.position)).applyMatrix4(r):Bu.error("没有找到对应几何"),{nodeId:o,guid:t.guid,geometryId:a,originalGeometryId:t.geoId,matrix:r,boundingBox:s,model:this.model}}},Kw.prototype._getComponentNodeAttr=function(e,t){var i=new yt;i.fromArray(e.matrix||[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1]),xd.DataReduction&&i.scale(new Ke(1e3,1e3,1e3)),t&&i.multiplyMatrices(t.matrix,i);var n=e.nodeId,r=e.geoId;if(-1!==r){var o=e.maxBoundary||t.maxBoundary,a=e.minBoundary||t.minBoundary,s=new Nu;return s.set(a,o),{nodeId:n,guid:e.guid,geometryId:r,originalGeometryId:e.geoId,matrix:i,boundingBox:s,model:this.model}}},Kw.prototype._cacheNodeInfoByCategory=function(e){var t;void 0===this.mapNodeInfoByCategory[t=zy.NodeInfoCategory.MIX]&&(this.mapNodeInfoByCategory[t]={}),void 0===this.mapNodeInfoByCategory[t][e.userId]&&(this.mapNodeInfoByCategory[t][e.userId]=[]),this.mapNodeInfoByCategory[t][e.userId].push(e)},Kw.prototype._cacheNodeInfoByParameterizedDesc=function(e){e.parameterizedDesc&&(void 0===this.mapNodeInfoByParameterizedDesc[e.type]&&(this.mapNodeInfoByParameterizedDesc[e.type]=[]),this.mapNodeInfoByParameterizedDesc[e.type].push(e))},Kw.prototype._clearNodeInfoCacheWithParameterizedDesc=function(e){if(e)for(var t=0,i=e.length;i>t;t+=1)delete this.mapNodeInfoByParameterizedDesc[e[t]];else this.mapNodeInfoByParameterizedDesc={}},Kw.prototype._clearNodeInfoCacheWithComponentKey=function(e){if(e)for(var t=0,i=e.length;i>t;t+=1)delete this.mapNodeInfoByComponentKey[e[t]];else this.mapNodeInfoByComponentKey={}},Kw.prototype._clearNodeInfoCacheWithCategory=function(e){if(e)for(var t=this.mapNodeInfoByCategory[Kw.NodeInfoCategory.INSTANCED],i=this.mapNodeInfoByCategory[Kw.NodeInfoCategory.STANDARD],n=0,r=e.length;r>n;n+=1)t&&delete t[e[n]],i&&delete i[e[n]];else this.mapNodeInfoByCategory={}},Kw.prototype.clearNodeInfoCacheByComponentsKey=function(e){this._clearNodeInfoCacheWithComponentKey(e),this._clearNodeInfoCacheWithUserId(e),this._clearNodeInfoCacheWithCategory(e)},Kw.prototype._clearNodeInfoCacheWithUserId=function(e){if(e)for(var t=0,i=e.length;i>t;t+=1)delete this.mapNodeInfoByUserId[e[t]],delete this.mapNodeInfoByNodeId[e[t]];else this.mapNodeInfoByUserId={};this.mapNodeInfoByUserId={}},Kw.prototype.clearNodeInfoCache=function(){this._clearNodeInfoCacheWithComponentKey(),this._clearNodeInfoCacheWithUserId(),this._clearNodeInfoCacheWithCategory()},Kw.prototype.getNodeInfosByComponentKey=function(e){return this.mapNodeInfoByComponentKey[e]},Kw.prototype.getNodeInfosWithComponentKey=function(){return this.mapNodeInfoByComponentKey},Kw.prototype.getAllNodeInfos=function(){return this.mapNodeInfoByUserId},Kw.prototype.getNodeInfosByUserId=function(e){return this.mapNodeInfoByUserId[e]},Kw.prototype.getNodeInfosByNodeId=function(e){return this.mapNodeInfoByNodeId[e]},Kw.prototype.getNodeInfosWithUserId=function(){return this.mapNodeInfoByUserId},Kw.prototype.getStandardNodeInfos=function(){return this.mapNodeInfoByCategory[zy.NodeInfoCategory.STANDARD]},Kw.prototype.getMixNodeInfos=function(){},Kw.prototype.getInstancedNodeInfos=function(){return this.mapNodeInfoByCategory[zy.NodeInfoCategory.INSTANCED]},Kw.prototype.getStandardUserIds=function(){return this.getStandardNodeInfos()?Object.keys(this.getStandardNodeInfos()):[]},Kw.prototype.getInstancedUserIds=function(){return this.getInstancedNodeInfos()?Object.keys(this.getInstancedNodeInfos()):[]},Kw.prototype.getStandardNodeInfosById=function(e){var t=this.getStandardNodeInfos();return t?t[e]:null},Kw.prototype.getInstancedNodeInfosById=function(e){var t=this.getInstancedNodeInfos();return t?t[e]:null},Kw.prototype._getUserIdsByCategory=function(e,t){var i=[],n=null;if(n=t===Kw.NodeInfoCategory.INSTANCED?this.getInstancedNodeInfos():this.getStandardNodeInfos())for(var r=0,o=e.length;o>r;r+=1)n[e[r]]&&i.push(e[r]);return i},Kw.prototype.getInstancedUserIdsByCategory=function(e){return this._getUserIdsByCategory(e,Kw.NodeInfoCategory.INSTANCED)},Kw.prototype.getStandardUserIdsByCategory=function(e){return this._getUserIdsByCategory(e,Kw.NodeInfoCategory.STANDARD)},Kw.prototype._traverseNodeInfosByIds=function(e,t,i){for(var n=0,r=t.length;r>n;n+=1){var o=t[n];i(o,e[o])}},Kw.prototype.traverseStandardNodeInfos=function(e,t){var i=this.getStandardNodeInfos();i&&(e=e||this.getStandardUserIds(),this._traverseNodeInfosByIds(i,e,t))},Kw.prototype.traverseInstancedNodeInfos=function(e,t){var i=this.getInstancedNodeInfos();i&&(e=e||this.getInstancedUserIds(),this._traverseNodeInfosByIds(i,e,t))},Kw.prototype.traverseNodeInfosByComponent=function(e){for(var t=Object.keys(this.mapNodeInfoByComponentKey),i=0,n=t.length;n>i;i+=1)for(var r=t[i],o=this.mapNodeInfoByComponentKey[r],a=0,s=o.length;s>a;a+=1)e(r,o[a])},Kw.prototype.clearReferencedMeshCache=function(){if(!xd.DEBUG){for(var e in this.referencedMeshCache)delete this.referencedMeshCache[e];this.referencedMeshCache=null}},Kw.prototype.cacheReferencedMeshBufferData=function(e,t){this.referencedMeshCache.bufferData||(this.referencedMeshCache.bufferData={}),this.referencedMeshCache.bufferData[e]=t},Kw.prototype.cacheReferencedMeshComponentNodeData=function(e,t){this.referencedMeshCache.componentNode||(this.referencedMeshCache.componentNode={}),this.referencedMeshCache.componentNode[e]=t},Kw.prototype.cacheReferencedMeshWireframeData=function(e,t){this.referencedMeshCache.wireframeData||(this.referencedMeshCache.wireframeData={}),this.referencedMeshCache.wireframeData[e]=t},Kw.prototype.getReferencedMeshBufferData=function(){return this.referencedMeshCache.bufferData},Kw.prototype.getReferencedMeshBufferById=function(e){return this.referencedMeshCache&&this.referencedMeshCache.bufferData?this.referencedMeshCache.bufferData[e]:null},Kw.prototype.getReferencedMeshComponentNodeById=function(e){return this.referencedMeshCache&&this.referencedMeshCache.componentNode?this.referencedMeshCache.componentNode[e]:null},Kw.prototype.getReferencedMeshWireframeDataById=function(e){return this.referencedMeshCache&&this.referencedMeshCache.wireframeData?this.referencedMeshCache.wireframeData[e]:null},Kw.prototype.cacheReferencedMeshBoneBufferData=function(e,t){this.referencedMeshCache.bones||(this.referencedMeshCache.bones={}),this.referencedMeshCache.bones[e]=t},Kw.prototype.cacheReferencedMeshClipsData=function(e){this.referencedMeshCache.clips=e},Kw.prototype.cacheReferencedMeshNodesData=function(e){this.referencedMeshCache.nodes=e},Kw.prototype.cacheReferencedMeshComponentData=function(e,t){this.referencedMeshCache.components||(this.referencedMeshCache.components={}),this.referencedMeshCache.components[e]=t},Kw.prototype.cacheReferencedMeshMaterialData=function(e,t){this.referencedMeshCache.materials||(this.referencedMeshCache.materials={}),this.referencedMeshCache.materials[e]=t},Kw.prototype.cacheReferencedMeshGeoIds=function(e,t){this.referencedMeshCache.mpkIds||(this.referencedMeshCache.mpkIds={}),this.referencedMeshCache.mpkIds[e]||(this.referencedMeshCache.mpkIds[e]=[]),this.referencedMeshCache.mpkIds[e].push(t)},Kw.prototype.clearReferencedMeshCacheByGeopkIdxs=function(e,t){if(this.referencedMeshCache.mpkIds)for(var i=0,n=e.length;n>i;i+=1){var r=e[i],o=this.referencedMeshCache.mpkIds[r];if(o){for(var a=0,s=o.length;s>a;a+=1)t&&t(o[a]),delete this.referencedMeshCache[o[a]];delete this.referencedMeshCache.mpkIds[r]}}},Kw.prototype.cacheBorderLine=function(e,t){var i=e?"shared":"unique";this.borderLines[i]||(this.borderLines[i]=[]),this.borderLines[i].push(t)},Kw.prototype.getSharedBorderLineCache=function(){return this.borderLines.shared},Kw.prototype.getUniqueBorderLineCache=function(){return this.borderLines.unique},Kw.prototype._isRegularShape=function(e){return e.type===Kw.EnumNodeItemType.TUBE||e.type===Kw.EnumNodeItemType.PIPE||e.type===Kw.EnumNodeItemType.BOX||e.type===Kw.EnumNodeItemType.BOX_M||e.type===Kw.EnumNodeItemType.PIPE_M},Kw.prototype._isInstancedNode=function(e){return!!xd.Instance&&(e.type===Kw.EnumNodeItemType.MESH_REF?Boolean(xd.SharedMeshInstanceEnable):Boolean(e.parameterizedDesc))},Kw.prototype.getComponentCount=function(){return this.componentCount},Kw.prototype.getOctreeRootNode=function(){return this.octreeRootNode},Kw.prototype.removeFromSceneReaderMap=function(e){for(var t=0,i=e.length;i>t;t+=1)this.mapSceneReader[e[t]]&&delete this.mapSceneReader[e[t]]},Kw.prototype.isUserIdExist=function(e){return!!this.getNodeInfosByUserId(e)},Kw.prototype.addToNodeInfoMap=function(e){for(var t=0,i=e.length;i>t;t+=1)this._cacheNodeInfoByUserId(e[t])},Kw.prototype.removeFromNodeInfoMap=function(e){for(var t=this.getAllNodeInfos(),i=0,n=e.length;n>i;i+=1){var r=e[i].userId;t[r]&&delete t[r]}},Kw.prototype.cacheNodeInfosOnGeometryId=function(){var e=this.getStandardNodeInfos();for(var t in this.mapNodeInfoByGeometryId={},e)for(var i=e[t],n=0,r=i.length;r>n;n+=1)i[n].geometryId=this.convertGeometryId(i[n].geometryId),this.mapNodeInfoByGeometryId[i[n].geometryId]||(this.mapNodeInfoByGeometryId[i[n].geometryId]=[]),this.mapNodeInfoByGeometryId[i[n].geometryId].push(i[n])},Kw.prototype.getNodeInfosOnGeometryId=function(){return this.mapNodeInfoByGeometryId||this.cacheNodeInfosOnGeometryId(),this.mapNodeInfoByGeometryId},Kw.prototype.clearNodeInfosWithGeometryId=function(){this.mapNodeInfoByGeometryId={}},Kw.prototype.convertGeometryId=function(e){return e},Kw.prototype._readMaterialBuffer=function(e){var t=e.materialManager,i=t.materials,n=t.textures,r=this.referencedMeshCache.materials,o=1;for(var a in wp.isEmptyObject(e.subModel)||(o=.001),r){var s=r[a];if(!s)return null;var l=cA.createMaterialByMaterialBufferAndTexture(s,n,o);l.refreshUniforms&&l.refreshUniforms(),i[a]=l,xd.EnableShadow&&e.manager.viewerImpl.rendererManager.csm&&e.manager.viewerImpl.rendererManager.csm.setupMaterial(l)}},Kw.prototype._updateV1ToV2=function(){var e=this.referencedMeshCache.components,t=this.referencedMeshCache.bufferData,i=this.referencedMeshCache.materials;for(var n in e)if(e.hasOwnProperty(n)){var r=e[n],o=r.matId,a=t[r.geoId];if(r.materials)continue;if(r.materials=[],!a)continue;var s=i[o];if(!s)continue;var l=this._updateMaterialV1ToV2(o,s);if(l)for(var c in a.materialIndex=l.materialIndex,r.materials=l.materialId,l.materials)l.materials.hasOwnProperty(c)&&(this.referencedMeshCache.materials[c]=l.materials[c])}},Kw.prototype._updateMaterialV1ToV2=function(e,t){var i={},n=[],r={};if(!t)return null;for(var o=t.color,a=t.colorIndex,s=t.texture,l=t.textureIndex,c=0;o.length>c;c+=4){var h={};h.color=[o[c],o[c+1],o[c+2]],h.opacity=Math.floor(100*o[c+3])/100,h.transparent=1>o[c+3];var d=(255*h.color[0]<<16^255*h.color[1]<<8^255*h.color[2]<<0)+"_"+h.opacity;r[d]=h,n.push(d)}if(0!==s.length&&a.length===l.length)for(var u=-1,p=0;l.length>p;p+=1)if(u!==a[p]&&(u=a[p],-1!==l[p])){var g=n[a[p]],f=s[l[p]];if(r[g].map=f,-1===g.indexOf(f)){var m=g+"_"+s[l[p]];r[m]=r[g],n.length>Object.keys(r).length-1||delete r[g],n[a[p]]=m}}return i.materials=r,i.materialId=n,i.materialIndex=a,i},Kw.prototype._computeVertexNormalsFromFaceNormals=function(e,t,i){for(var n=new Float32Array(i),r=0,o=0,a=0,s=0,l=0,c=0,h=0;e.length>h;h+=3)l=e[h+1],c=e[h+2],o=3*t[h+1],a=3*t[h+2],n[r=3*t[h]]=s=e[h],n[r+1]=l,n[r+2]=c,n[o]=s,n[o+1]=l,n[o+2]=c,n[a]=s,n[a+1]=l,n[a+2]=c;return n},Kw.prototype._computeVertexNormalsFromIndex=function(e,t,i){var n=new Float32Array(t.length);if(t){var r=0,o=0,a=0,s=new Ke,l=new Ke,c=new Ke,h=new Ke,d=new Ke;if(e)for(var u=e,p=0;u.length>p;p+=3)o=3*u[p+1],a=3*u[p+2],s.fromArray(t,r=3*u[p]),l.fromArray(t,o),c.fromArray(t,a),h.subVectors(c,l),d.subVectors(s,l),h.cross(d),n[r]+=h.x,n[r+1]+=h.y,n[r+2]+=h.z,n[o]+=h.x,n[o+1]+=h.y,n[o+2]+=h.z,n[a]+=h.x,n[a+1]+=h.y,n[a+2]+=h.z;else for(var g=0,f=t.length;f>g;g+=9)s.fromArray(t,g),l.fromArray(t,g+3),c.fromArray(t,g+6),h.subVectors(c,l),d.subVectors(s,l),h.cross(d),n[g]=h.x,n[g+1]=h.y,n[g+2]=h.z,n[g+3]=h.x,n[g+4]=h.y,n[g+5]=h.z,n[g+6]=h.x,n[g+7]=h.y,n[g+8]=h.z}return n},Kw.prototype.addMeshToInfoMap=function(e,t,i,n,r){var o=this.getNodeInfosByComponentKey(e);Array.isArray(o)&&o.forEach((function(e){e.nodeId===t&&(e.mesh=i,e.index=n,e.uv=e.uv||r)}))},Kw.prototype._parseGeo=function(){Bu.time("处理几何:计算法线");var e=this.referencedMeshCache;for(var t in e.bufferData){var i=e.bufferData[t];i.position.length!==i.normal.length&&(i.normal=i.normal.length===i.index.length?this._computeVertexNormalsFromFaceNormals(i.normal,i.index,i.position.length):this._computeVertexNormalsFromIndex(i.index,i.position))}Bu.timeEnd("处理几何:计算法线")};var Vw=function(e){lu(i,e);var t=pu(i);function i(e){var n;return ru(this,i),(n=t.call(this,e)).taskPackManager=new Uy(du(n),"pack"),n.descriptor=new Kw(e.model),n.sceneTasks=[],n.progressState={file:0,zip:0,glTF:0},n}return i}(Wy);Vw.prototype.destroy=function(){for(var e in this.requests)this.requests.hasOwnProperty(e)&&(this.requests[e].abort&&this.requests[e].abort(),delete this.requests[e]);this.taskComponentManager.stop(),this.taskComponentManager=null,this.taskGeometrieManager.stop(),this.taskGeometrieManager=null,this.taskMaterialManager.stop(),this.taskMaterialManager=null,this.taskTexturesManager.stop(),this.taskTexturesManager=null,this.url=null,this.model=null,this.fileLoader=null,this.descriptor=null,this.handler=null,this.startCallback=null,this.progressCallback=null,this.finishCallback=null,this.descriptor&&this.descriptor.destroy()},Vw.prototype.load=function(e,t,i){this.startCallback=e,this.progressCallback=t,this.finishCallback=i,this.loadData()},Vw.prototype.loadData=function(){var e=this,t=this.model,i=t.getConfig(),n=i.scene;if(!n||!n.packs)return t.setEmptyScene(!0),Bu.error("scene is null,modelKey is ",t.modelKey),void t.dispatchEventEx({type:Fd.ON_LOAD_EMPTY_SCENE,modelKey:t.modelKey});var r=n.packs.length||0,o=[];if(gy(e.dataVersion,"3.0.0")?o=n.packs:Bu.error("数据版本错误"),e.maxLoadTaskCount=0,e.maxLoadTaskCount+=r,1>e.maxLoadTaskCount)return Bu.info("Nothing to load ",t.modelKey),void t.dispatchEventEx({type:Qd.SCENE_NOTHING_TO_LOAD,modelKey:t.modelKey});e.progress.total+=e.maxLoadTaskCount,e.startCallback&&e.startCallback(),Bu.time("数据加载时间"),e._onLoadTexture(),e._loadPack(o),e.offLine&&e.loadAttribute(),i.axis&&e._loadAxisNet(i.axis),e.maxLoadTaskCount+=1,e.loadFloorInfo(e.model.modelKey,(function(){e._onTaskFinished()})),e.loadSceneAndGeos(i)},Vw.prototype.progressInform=function(e,t){var i=this.model;switch(e){case"file":this.progressState.file=i.progressPercentage.file*(t/this.maxLoadTaskCount);break;case"zip":this.progressState.zip=i.progressPercentage.zip*(t/this.maxLoadTaskCount);break;case"glTF":this.progressState.glTF=i.progressPercentage.glTF*(t/this.maxLoadTaskCount)}this.notifyProgress&&(this.progressCallback&&this.progressCallback({total:this.maxLoadTaskCount,loaded:this.loadTaskCount+this.progressState.file+this.progressState.zip+this.progressState.glTF,modelKey:this.model.modelKey}))},Vw.prototype.loadSceneAndGeos=function(e){},Vw.prototype._loadScene=function(e){var t=new Jx(this);t.setCrossOrigin("anonymous");var i=this,n=[];Bu.time("glTF解析"),t.load(e.fileUrl,(function(t){var r=t.scene||t.scenes[0];if(Bu.timeEnd("glTF解析"),n.forEach(URL.revokeObjectURL),e.matrixDesc&&e.structDesc){var o=[e.matrixDesc,e.structDesc];e.geoInfo&&o.push(e.geoInfo),e.propInfo&&o.push(e.propInfo),e.elemInfo&&o.push(e.elemInfo),Bu.time("json加载和解析"),function(e,t,i,n){var r=[],o=0,a=t;function s(t){r.push(t),a.length>(o+=1)?l(a[o],i):n&&n(e,r)}function l(e,t){e?new Bl(t).load(e,(function(e){""===e&&(e="{}"),s(JSON.parse(e))}),null,(function(){s(null)})):s(null)}l(a[o],i)}(r,o,i,(function(e,t){Bu.timeEnd("json加载和解析"),i.getDescriptor().pushSceneTask({gltfScene:e,iMatrix:t[0],structDesc:t[1],geoInfo:t[2],propInfo:t[3],elemInfo:t[4],sceneTag:i.sceneTag}),i._onTaskFinished()}))}}),(function(e){i.progressInform("glTF",e.loaded/e.total)}),null)},Vw.prototype.dealProgressSegment=function(e,t){return.5*t},Vw.prototype._loadPack=function(e){var t=this;if(xd.getDataFromIndexedDB){for(var i=this.url,n=[],r=0;e.length>r;r+=1)n.push(i.mpkUrl(e[r]));var o=this.model.getStorage();o&&o.getBatch(n,(function(e){for(var i=function(i){if(e[n[i]])if(!0===e[n[i]].split){var r=e[n[i]].list,l=new Uint8Array(e[n[i]].length);o.getBatch(r,(function(e){for(var o=0;r.length>o;o+=1)e[r[o]]?l.set(new Uint8Array(e[r[o]]),4e7*o):Bu.error("获取分割pack失败");var a=n[i].indexOf("fileKey=");t.progressInform("file",1),t._parsePack(l.buffer,n[i].slice(a+8)),Bu.debug("load pack from local")}),(function(){Bu.error("获取分割pack失败")}))}else s=n[i].indexOf("fileKey="),t.progressInform("file",1),t._parsePack(e[n[i]],n[i].slice(s+8)),Bu.debug("load pack from local");else{if(a=t.taskPackManager,t.offLine){if(-1===(s=n[i].indexOf("data/")))return Bu.error("url is not has data/"),{v:void 0};a.addTask(n[i].slice(s+5))}else{if(-1===(s=n[i].indexOf("fileKey=")))return Bu.error("url is not has fileKey"),{v:void 0};a.addTask(n[i].slice(s+8))}a.processTasks(t.loadPack.bind(t)),Bu.debug("load pack from net")}},r=0;n.length>r;r+=1){var a,s,l=i(r);if("object"===nu(l))return l.v}}),(function(){for(var i=t.taskPackManager,n=0;e.length>n;n+=1)i.addTask(e[n]);i.processTasks(t.loadPack.bind(t))}))}else{for(var a=this.taskPackManager,s=0;e.length>s;s+=1)a.addTask(e[s]);a.processTasks(t.loadPack.bind(t))}},Vw.prototype._parsePack2=function(e,t,i){},Vw.prototype._parsePack=function(e,t,i){var n=this;if(e){var r=new Blob([e]);Bu.time("zip解压"),Bu.time("zip处理"),new Dx(new Ix(r)).getEntries().then((function(e){Bu.timeEnd("zip解压");var t={},i=[];Bu.time("zip解压-文件转换");for(var r=function(r){var o=e[r];i.push(o.getData(new xx).then((function(i){t["blob:./"+o.filename]=URL.createObjectURL(i),n.progressInform("zip",Object.keys(t).length/e.length)})))},o=0;e.length>o;o+=1)r(o);return Promise.all(i).then((function(){return Bu.timeEnd("zip解压-文件转换"),t}))})).then((function(e){return{urlResolver:function(t){return e[t]?e[t]:t},find:function(t){"string"==typeof t&&(t=new RegExp(t.replace(/\./g,"\\.")));var i=[];for(var n in e)null!==n.match(t)&&i.push(n);return i}}})).then((function(e){Bu.timeEnd("zip处理"),n.setURLModifier(e.urlResolver);var t=e.find("geoinfo.json"),i=e.find("properties.json"),r=e.find("components.json");n._loadScene({fileUrl:e.find(/\.(gltf|glb)$/i)[0],matrixDesc:e.find("smatrix.json")[0],structDesc:e.find("structdesc.json")[0],geoInfo:t.length>0?t[0]:null,propInfo:i.length>0?i[0]:null,elemInfo:r.length>0?r[0]:null,isFromZip:!0})})).catch(i)}else Bu.error("没有数据")},Vw.prototype.loadPack=function(e,t){var i=this,n=this.loader,r=this.model,o=this.url;if(xd.UseGeoWorker);else{n.setResponseType("arraybuffer"),n.setCacheViable(!0);var a=n.load(o.mpkUrl(e),(function(n){i._parsePack(n,e),Bu.debug("component load from online"),t()}),(function(e){(e.lengthComputable||0!==e.total)&&i.progressInform("file",e.loaded/e.total)}),(function(e){r.dispatchEventEx({type:Qd.LOAD_COMPONENT_ERROR,modelKey:r.modelKey})}));i.requests.loadPack=a}};var Yw=function(e){var t=1>=arguments.length||void 0===arguments[1]||arguments[1],i=arguments.length>2&&void 0!==arguments[2]&&arguments[2],n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:0,r=new pi(e+1),o=0==n?.5:Math.pow(2,n-1);return new Le(r.r,r.g,r.b,t?(i?1:-1)*o:0)},Hw=function(e){return e-1},jw=function(e){var t=this;this.viewer=e.viewer,this.scene=this.viewer.getScene(),this.idColorOverrideMaterial=new _s,this.DEBUG_OFFLINE_RT=!1,this.pickingTasks=[],this.setupInstancedShaderWithVertexColor=function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{wireframe:!1},i=["vec3 colorTable[8];","colorTable[0] = vec3(1.0, 0.0, 0.0);","colorTable[1] = vec3(0.0, 1.0, 0.0);","colorTable[2] = vec3(0.0, 0.0, 1.0);","colorTable[3] = vec3(1.0, 1.0, 0.0);","colorTable[4] = vec3(1.0, 0.0, 0.0);","colorTable[5] = vec3(1.0, 0.5, 0.0);","colorTable[6] = vec3(1.0, 0.8, 0.0);"].join("\n"),n=["attribute vec4 instanceColor;","attribute vec4 instanceShows;","attribute vec4 instanceDiffuses;","varying vec4 vInstanceColor;","varying vec4 vInstanceDiffuse;",t.wireframe?"attribute vec4 texcoord2;":"",t.wireframe?"varying vec3 vBarycentric;":"","#include <common>"].join("\n"),r=["#include <begin_vertex>","\tvInstanceColor = instanceColor;","\tvInstanceDiffuse = instanceDiffuses;",t.wireframe?"\tvBarycentric = texcoord2.xyz;":""].join("\n"),o=["vec4 decodeF2V(float value){","return mod(floor(vec4(value + 0.003921, value * 0.5 + 0.003921, value * 0.25 + 0.003921, value * 0.125 + 0.003921)), vec4(2.0));","}"].join("\n"),a=["vec4 decodeF2VEx(float value){","return mod(floor(vec4(value * 0.0625 + 0.003921, value * 0.03125 + 0.003921, value * 0.015625 + 0.003921, value * 0.0078125 + 0.003921)), vec4(2.0));","}"].join("\n"),s=["float detectEdge(){","vec3 d = fwidth(vBarycentric);","vec3 a3 = smoothstep(vec3(0.0), d * 2.5, vBarycentric);","return min(min(a3.x, a3.y), a3.z);","}"].join("\n"),l=["varying vec4 vInstanceColor;","varying vec3 vBarycentric;","varying vec4 vInstanceDiffuse;",o,a,t.wireframe?s:"","#include <common>"].join("\n"),c=["if (vInstanceColor.w == 0.0)discard;","float opacityEpsilon = sign(vInstanceColor.w);","vec4 colorFlag = decodeF2V(abs(vInstanceColor.w));","vec4 colorFlagEx = decodeF2VEx(abs(vInstanceColor.w));",i,"vec3 instanceColor = vInstanceDiffuse.rgb * diffuse;","vec4 diffuseColor = vec4( instanceColor * (1.0 - (colorFlag.x + colorFlag.y + colorFlag.z + colorFlag.w) ) + ","colorTable[0] * colorFlag.x + ","colorTable[1] * colorFlag.y + ","colorTable[2] * colorFlag.z + ","colorTable[3] * colorFlag.w + ","colorTable[4] * colorFlagEx.x + ","colorTable[5] * colorFlagEx.y + ","colorTable[6] * colorFlagEx.z,","opacity);"].join("\n"),h=[t.wireframe?"outgoingLight.xyz = mix(vec3(0.0), outgoingLight.xyz, max(colorFlagEx.w, detectEdge()));":"","gl_FragColor = vec4(outgoingLight, diffuseColor.a );"].join("\n");e.onBeforeCompile2=e.onBeforeCompile,e.onBeforeCompile=function(t,i){t.vertexShader=t.vertexShader.replace("#include <common>",n).replace("#include <begin_vertex>",r).replace("#include <fog_vertex>","#include <fog_vertex>\ngl_Position *= instanceShows.x;"),t.fragmentShader=t.fragmentShader.replace("#include <common>",l).replace("vec4 diffuseColor = vec4( diffuse, opacity );",c).replace("gl_FragColor = vec4( outgoingLight, diffuseColor.a );",h),e.onBeforeCompile2&&e.onBeforeCompile2(t,i)},t.wireframe&&(e.extensions={derivatives:!0})},this.getPickedIdByMouseEx=function(e,i,n,r){var o=e*t.offlineWidth,a=i*t.offlineHeight,s=t.viewer.camera;!function(e){if(t.applySize(),t.idColorOverrideMaterial){var i=["attribute vec4 instanceColor;","attribute vec4 instanceShows;","varying vec4 vInstanceColor;","#include <common>"].join("\n"),n=["#include <begin_vertex>","\tvInstanceColor = instanceColor;"].join("\n"),r=["varying vec4 vInstanceColor;","#include <common>"].join("\n"),o=["gl_FragColor = vec4(vInstanceColor.xyz, 1.0 );"].join("\n");t.idColorOverrideMaterial.onBeforeCompile=function(e,t){e.vertexShader=e.vertexShader.replace("#include <common>",i).replace("#include <begin_vertex>",n).replace("#include <fog_vertex>","#include <fog_vertex>\ngl_Position *= instanceShows.x;"),e.fragmentShader=e.fragmentShader.replace("#include <common>",r).replace("gl_FragColor = vec4( outgoingLight, diffuseColor.a );",o)}}t.scene.overrideMaterial=t.idColorOverrideMaterial,t.offlineRenderer.setRenderTarget(t.DEBUG_OFFLINE_RT?null:t.pickingRenderTarget),t.offlineRenderer.clearDepth(),t.offlineRenderer.clear(),t.offlineRenderer.render(t.scene,e),t.scene.overrideMaterial=null}(s),t.offlineRenderer.readRenderTargetPixels(t.pickingRenderTarget,o,t.offlineHeight-a,1,1,t.pixelBuffer);var l,c,h,d,u,p={pickedId:Hw(t.pixelBuffer[0]<<16|t.pixelBuffer[1]<<8|t.pixelBuffer[2])};return r||(!function(e){if(t.applySize(),t.normalDepthOverrideMaterial||(t.normalDepthOverrideMaterial=new tl),t.normalDepthOverrideMaterial){var i=["varying vec4 projectionPosition;","varying vec4 modelviewPosition;","varying vec3 worldNormal;","#include <common>"].join("\n"),n=["projectionPosition = projectionMatrix * mvPosition;","modelviewPosition = mvPosition;","#include <clipping_planes_vertex>","worldNormal = normal;"].join("\n"),r=["varying vec4 projectionPosition;","varying vec4 modelviewPosition;","varying vec3 worldNormal;","uniform sampler2D tDepth;","#include <packing>"].join("\n"),o=["vec2 screenUV = (projectionPosition.xy / vec2( projectionPosition.w) + vec2(1.0)) * 0.5;","float sceneRawDepth = texture2D( tDepth, screenUV ).x;","gl_FragColor = vec4(packNormalToRGB(worldNormal), sceneRawDepth);"].join("\n");t.normalDepthOverrideMaterial.onBeforeCompile=function(e){e.uniforms.tDepth={value:t.pickingRenderTarget.depthTexture},e.vertexShader=e.vertexShader.replace("#include <common>",i).replace("#include <clipping_planes_vertex>",n),e.fragmentShader=e.fragmentShader.replace("#include <packing>",r).replace("gl_FragColor = vec4( packNormalToRGB( normal ), opacity );",o)}}t.scene.overrideMaterial=t.normalDepthOverrideMaterial,t.offlineRenderer.setRenderTarget(t.DEBUG_OFFLINE_RT?null:t.ndRenderTarget),t.offlineRenderer.clearDepth(),t.offlineRenderer.render(t.scene,e),t.scene.overrideMaterial=null}(s),t.offlineRenderer.readRenderTargetPixels(t.ndRenderTarget,o,t.offlineHeight-a,1,1,t.pixelBufferFloat),l=new Ke(2*t.pixelBufferFloat[0]-1,2*t.pixelBufferFloat[1]-1,2*t.pixelBufferFloat[2]-1),h=s,d=new ke(e,i),u=new Le(2*d.x-1,-(2*d.y-1),2*t.pixelBufferFloat[3]-1,1).applyMatrix4(h.projectionMatrixInverse),c=new Le(u.x/u.w,u.y/u.w,u.z/u.w,1).applyMatrix4(h.matrixWorld),p.normal=l,p.point=(new Ke).copy(c),p.distance=s.position.clone().sub(c).length()),n&&n(p),p},this.applySize=function(){var e=this.viewer.rendererManager.getRendererSize();t.offlineRenderer.setSize(e.x,e.y)},t.offlineWidth=200,t.offlineHeight=t.offlineWidth,t.offlineRenderer=new Po,t.offlineRenderer.setPixelRatio(window.devicePixelRatio),t.offlineRenderer.setSize(t.offlineWidth,t.offlineHeight),t.offlineRenderer.setClearColor(16777215),t.offlineRenderer.autoClear=!1,t.pickingRenderTarget=new Oe(t.offlineWidth,t.offlineHeight),t.pickingRenderTarget.texture.generateMipmaps=!1,t.pickingRenderTarget.texture.minFilter=A,t.pickingRenderTarget.texture.magFilter=A,t.pickingRenderTarget.stencilBuffer=!1,t.pickingRenderTarget.depthBuffer=!0,t.pickingRenderTarget.depthTexture=new za,t.pickingRenderTarget.depthTexture.type=E,t.ndRenderTarget=new Oe(t.offlineWidth,t.offlineHeight,{type:B}),t.ndRenderTarget.texture.generateMipmaps=!1,t.ndRenderTarget.texture.minFilter=A,t.ndRenderTarget.texture.magFilter=A,t.ndRenderTarget.stencilBuffer=!1,t.pixelBuffer=new Uint8Array(4),t.pixelBufferFloat=new Float32Array(4),t.currentPickedId=16777215},Ww=function(e){return kv.call(this),this.manager=e,this._maxIndiceseNum=0,this._materialList=[],this.mapMaterialIdToMergedNode={},this.selectedMeshes=[],this.nonSelectedMeshes=[],this.selectedObjectIds=[],this.blinkMaterials=[],this.mapDestroyedBufferKey={},this};function Jw(e,t,i,n){for(var r=e.getAttribute("position").array,o=t;i>o;o+=3)r[o]+=n.x,r[o+1]+=n.y,r[o+2]+=n.z;e.getAttribute("position").needsUpdate=!0}(Ww.prototype=Object.create(kv.prototype)).destroy=function(){this.dispose(),this.clearData(),this.mapMaterialIdToMergedNode={},this.manager=null,this._materialList=[],this.selectedMeshes=[],this.nonSelectedMeshes=[],this.selectedObjectIds=[],this.blinkMaterials=[],this.mapDestroyedBufferKey={}},Ww.prototype.clearData=function(){this.bufferDestroyed=!1,this.clearAllNodeBuffer(),this._disposeMergedGeometries()},Ww.prototype.createMeshNodes=function(e,t,i){Bu.time("createMesh");var n=this,r=this._getNodeGroup(e),o=e.getModelDescriptor(),a=e.materialManager,s=e.manager,l=a.materials,c=o.sceneTasks[0],h=c.iMatrix,d=c.structDesc,u=c.gltfScene.children[0];u.updateMatrix(!0);var p=c.gltfScene.children.length==d.length?c.gltfScene.children:u.children;if(p.length!=d.length)console.error("Mesh doesnt match description!");else for(var g=d.length,f=0;g>f;++f){var m=p[f],A=d[f],y=[],v=[],C=[],I=m.material.clone();I.map&&(I.map.encoding=X),l[I.name]=I,m.visible=!1,e.picker?e.picker.setupInstancedShaderWithVertexColor(I):Bu.error("缺失拾取器"),C.push(I);for(var x=0;A.length>x;++x){var w=h[A[x].n].it.length+1;v.push(w),y.push(S={start:A[x].s,count:A[x].c,instanceCount:w,name:A[x].n})}var M=new ry(m.geometry,C,1,v);n._cacheGeometry(m.geometry.id,m.geometry),M.geometry.clearGroups();for(var E=0,B=0;y.length>B;++B){var S,b=h[(S=y[B]).name].it,k=h[S.name].id;E++,M.geometry.addGroupInstanced(3*S.start,3*S.count,0,B);for(var D=b.length+1,T=0;D>T;T++){var R=null,U=new yt,F=0;if(T==b.length){R=(Q=new yt).multiply(u.matrix),F=parseInt(S.name,10)}else{var Q,L=b[T];(Q=new yt).set(L[0],L[1],L[2],L[3],L[4],L[5],L[6],L[7],L[8],L[9],L[10],L[11],0,0,0,1),U.set(L[0],L[1],L[2],L[3],L[4],L[5],L[6],L[7],L[8],L[9],L[10],L[11],0,0,0,1),R=Q.multiply(u.matrix),F=k[T]}M.setInstanceMatrixAt(B,T,R);var O=Yw(F);M.setInstanceColorAt(B,T,O);var N=null,P={};c.elemInfo&&c.elemInfo[F]&&(N=(P=c.elemInfo[F]).key),n.manager.model.getModelDescriptor()._readMeshInfo({elementId:F,mesh:M,groupStart:S.start,groupCount:S.count,matrix:U.clone(),materialId:I.name,key:N,info:P,groupIndex:B,subInstanceIndex:T}),n.manager.model.getModelDescriptor().rootGroupNodeMatrix=u.matrix}}M.geometry._originalGroups=wp.clone(M.geometry.groups,!0),M.modelKey=e.modelKey,s.addMeshToOctantMap(e.modelKey,M.uuid,new Bm(M.uuid,M)),E>0&&r.add(M)}Bu.timeEnd("createMesh")},Ww.prototype._getNodeGroup=function(e){return e._getNodeGroup(Vp.SLM,{globalSpace:!0})},Ww.prototype.getMeshesByUserIds=function(e,t){var i=[];for(var n in this.mapMaterialIdToMergedNode)for(var r=this.mapMaterialIdToMergedNode[n],o=0,a=r.length;a>o;o+=1){var s=r[o],l=s.indices[t];if(l)for(var c=0,h=l.length;h>c;c+=1){var d={};d.mesh=s.mesh,d.indexInfo=l[c],d.matrix=e.getModelMatrix(),i.push(d)}}return i},Ww.prototype.rebuildIndices=function(e){this._materialList.length=0;var t=xd.EnableLightmap&&e.lightmap;this.clearSelectedObjectIds();var i=this.manager.getFilteredUserIds(),n=this.manager.getSelectedUserIds(),r=this.manager.getHoveredUserIds(),o=this.manager.getBlinkedUserIds();e.hasReplacedUserId();var a=e.manager.scene.fillClipPlane&&xd.ClippingCaps,s={};for(var l in this.mapMaterialIdToMergedNode){var c,h=this.getPropertyValueByMaterialKey(l).materialId,d=null,u=null,p=null,g=null,f=null,m=null,A=null,y=null,v=null;n&&n[h]&&(g=n[h]),r&&r[h]&&(f=r[h]),o&&o[h]&&(m=o[h]),i&&i[h]&&(d=i[h][Zd.HIDDEN],u=i[h][Zd.OVERRIDED],p=i[h][Zd.TRANSPARENT]);var C=this.mapMaterialIdToMergedNode[l];for(v=0,c=C.length;c>v;v+=1){var I=C[v],x=I.indices,w=I.geometry;if(w.clearGroups(),w._visible=!0,t)for(var M=e.lightmapNum,E=0;M>E;E+=1){var B="lightmap|"+E;-1===this._materialList.indexOf(B)&&this._materialList.push(B)}if(g||d||u||f||p||xd.EnableLightmap||a||m||e.isUpdateBlink){var S=[];for(var b in x)if(x.hasOwnProperty(b)){if(d&&d[b])continue;var k=x[b];if(k&&k.length>0){if(k.sort((function(e,t){return e.indexStart-t.indexStart})),p&&p[b]){for(A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.TRANSPARENT});continue}if(e.manager.isSelectPriority()){if(g&&g[b]){if(this.cacheSelectedObjectIds(b,l,v),xd.PickingEffect){if(u&&u[b]){var D=u[b],T=this._materialList.indexOf(D);for(-1===T&&(this._materialList.push(D),T=this._materialList.length-1),A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.OVERRIDED+T});continue}for(A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.NONE});continue}for(A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.SELECTED});continue}if(m&&m[b]){if(u&&u[b]){var R="blink|"+u[b],U=this._materialList.indexOf(R);for(-1===U&&(this._materialList.push(R),U=this._materialList.length-1),A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.OVERRIDED+U});continue}for(A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.BLINK});continue}}else{if(m&&m[b]){if(u&&u[b]){var F="blink|"+u[b],Q=this._materialList.indexOf(F);for(-1===Q&&(this._materialList.push(F),Q=this._materialList.length-1),A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.OVERRIDED+Q});continue}for(A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.BLINK});continue}if(g&&g[b]){if(this.cacheSelectedObjectIds(b,l,v),xd.PickingEffect){if(u&&u[b]){var L=u[b],O=this._materialList.indexOf(L);for(-1===O&&(this._materialList.push(L),O=this._materialList.length-1),A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.OVERRIDED+O});continue}for(A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.NONE});continue}for(A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.SELECTED});continue}}if(e.blinkMapComponentKeyToMaterialName&&e.blinkMapComponentKeyToRenderState[b]){var N=e.blinkMapComponentKeyToMaterialName[b],P=this._materialList.indexOf(N);for(-1===P&&(this._materialList.push(N),P=this._materialList.length-1),A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.OVERRIDED+P});continue}if(f&&f[b]){if(u&&u[b]){var G=this._materialList.indexOf(K="hover|"+u[b]);for(-1===G&&(this._materialList.push(K),G=this._materialList.length-1),A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.OVERRIDED+G});continue}for(A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.HOVER});continue}if(u&&u[b]){var K,V=this._materialList.indexOf(K=u[b]);for(-1===V&&(this._materialList.push(K),V=this._materialList.length-1),A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.OVERRIDED+V});continue}if(a&&s[b]){for(A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.CLIPPING});continue}if(xd.EnableLightmap)for(A=0,y=k.length;y>A;A+=1){var Y=this._materialList.indexOf("lightmap|"+k[A].lightmapIdx);S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:Zd.OVERRIDED+Y})}else for(A=0,y=k.length;y>A;A+=1)S.push({indexStart:k[A].indexStart,indexCount:k[A].indexCount,state:0})}}if(S.length>0)for(S.sort((function(e,t){return e.state===t.state?e.indexStart-t.indexStart:e.state-t.state})),A=0,y=S.length;y>A;A+=1){var H=S[A].indexStart,j=S[A].indexCount,W=S[A].state;if(0===A)w.addGroup(H,j,W);else W===S[A-1].state&&H===S[A-1].indexStart+S[A-1].indexCount?w.groups[w.groups.length-1].count+=j:w.addGroup(H,j,W)}else w._visible=!1}}}},Ww.prototype.update=function(e,t){var i=e.manager.filter,n=e.materialManager.materials,r=e.selectedMaterial,o=e.manager.sceneState,a=null,s=null,l=null,c=null,h=null,d=null,u=xd.EnableLightmap&&e.lightmap;if(e.isOnlyWireframe())for(var p in this.mapMaterialIdToMergedNode){var g=this.mapMaterialIdToMergedNode[p];for(l=0,c=g.length;c>l;l+=1){var f=g[l].mesh;f&&(f.visible=!1)}}else{xd.TranslucentDepthDisabled&&(r.depthWrite=!r.transparent);var m=i._getMaterialByName("scene");xd.TranslucentDepthDisabled&&(m.depthWrite=!1);var A=[];this.blinkMaterials.length=0;var y={};if(!u)for(a=0,s=this._materialList.length;s>a;a+=1){var v=null,C=this._materialList[a],I=C.split("|");"blink"===C.split("_")[0]?v=e.blinkMapMaterialNameToMaterial[C]:"hover"===I[0]?(v=i._getMaterialByName(I[1]),v=o.getHoverMaterial(v)):"blink"===I[0]?(v=i._getMaterialByName(I[1]),v=o.getBlinkMaterial(v),y[C]||this.blinkMaterials.push(v)):v=i._getMaterialByName(C)?i._getMaterialByName(C):this.manager.model.materialManager.getMaterialById(C),xd.TranslucentDepthDisabled&&(v.depthWrite=!v.transparent),A[a]=v}for(var x in this.mapMaterialIdToMergedNode){var w=this.getPropertyValueByMaterialKey(x).materialId,M=e.manager.getOverrideMaterialByName(w)||n[w]||cA.getDefaultStandardMaterial();if(M){if(u)for(a=0,s=this._materialList.length;s>a;a+=1){var E=null,B=this._materialList[a].split("|");if("lightmap"===B[0])if(xd.IBL)E=M.clone();else{var S=cA.getMaterialParameters(M);S.lights=!1,(E=cA.createStandardMaterial(S)).lightMap=e.materialManager.lightmaps[B[1]],E.lightMapIntensity=xd.LightmapIntensity}xd.TranslucentDepthDisabled&&E&&(E.depthWrite=!E.transparent),A[a]=E}xd.TranslucentDepthDisabled&&(M.depthWrite=!M.transparent);var b=o.getHoverMaterial(n[w]);xd.TranslucentDepthDisabled&&(b.depthWrite=!b.transparent);var k=this.mapMaterialIdToMergedNode[x];for(l=0,c=k.length;c>l;l+=1){var D=k[l],T=D.geometry;if(null!==T){var R=D.mesh;if(R)if(T._visible){if(T.groups.length>0){var U=y[w];U||(U=y[w]=o.getBlinkMaterial(M),this.blinkMaterials.push(U));var F=[M,r,U,b,m];for(a=0,s=A.length;s>a;a+=1){if(!A[a].createByBos){if(A[a].materialId!==w&&!A[a].mapNodeIdToOrigMatId)continue;if(!Object.keys(A[a].mapNodeIdToOrigMatId).find((function(e){return A[a].mapNodeIdToOrigMatId[e]===w})))continue}for(var Q in T.attributes.uv||(A[a].map=null),k[l].indices){if(e.blinkMapComponentKeyToMaterialName&&e.blinkMapComponentKeyToRenderState[Q])A[a].name&&A[a].name===e.blinkMapComponentKeyToMaterialName[Q]&&(F[5+a]=A[a]);else if(this.manager.mapMaterialIdToUserIdsForFilter[w]&&this.manager.mapMaterialIdToUserIdsForFilter[w][Zd.OVERRIDED])for(var L=Object.keys(this.manager.mapMaterialIdToUserIdsForFilter[w][Zd.OVERRIDED]),O=0,N=L.length;N>O;O+=1)Q===L[O]&&(F[5+a]=A[a])}}if(t){var P=[];for(h=0,d=F.length;d>h;h+=1)P.push(t);F=P}R.material=F}else R.material=t||M;R.visible=!0}else R.visible=!1;else Bu.error("没有mesh对象")}}M=null}}e.isUpdateBlink=!1}},Ww.prototype.explode=function(e,t,i){for(var n in this.mapMaterialIdToMergedNode)for(var r=this.mapMaterialIdToMergedNode[n],o=0,a=r.length;a>o;o+=1){var s=r[o],l=s.geometry;if(null!==l){var c=s.indices;for(var h in c){var d=e.manager.getComponentInfoByUserId(h).boundingBox,u=wp.computeExplodeTranslation(t,d,i),p=c[h];if(p)for(var g=0,f=p.length;f>g;g+=1){var m=p[g].positionStart;Jw(l,m,m+p[g].positionCount,u)}}}}},Ww.prototype.explosion=function(e,t){var i=e.getModelDescriptor().getStandardUserIds();t.componentKey=i,this.componentsExplosion(e,t)},Ww.prototype.closeExplosion=function(e){this.explosion(e,{})},Ww.prototype.componentsExplosion=function(e,t){var i=t.coefficientX||1,n=t.coefficientY||1,r=t.coefficientZ||1,o=t.offsetX||0,a=t.offsetY||0,s=t.offsetZ||0,l=null;if(t.center)l=(new Ke).fromArray(t.center);else if(1!==i||1!==n||1!==r||0!==o||0!==a||0!==s)return;var c=Array.isArray(t.componentKey)?t.componentKey:[t.componentKey],h=new Ke,d=new He,u=new Ke(0,0,0),p=new Ke(0,0,0),g=new Ke,f=new yt,m=e.getModelMatrix();m&&l&&(f.copy(m).invert(),l.applyMatrix4(f));var A=e.manager,y=!1,v=new Ke,C=new Ge,I=new Ke(1,1,1);wp.isEmptyObject(e.subModel)||(y=!0);for(var x=0,w=c.length;w>x;x+=1){var M=c[x];if(M){var E=e.getModelDescriptor().getStandardNodeInfosById(M);if(E)for(var B=0,S=E.length;S>B;B+=1){var b=E[B];if(b){var k=this._getMaterialKeyByNodeInfo(b),D=this.mapMaterialIdToMergedNode[k];if(D)for(var T=0,R=D.length;R>T;T+=1){var U=D[T],F=U.geometry,Q=U.mesh;if(F&&Q){var L=U.indices;if(L){var O=L[M];if(O){d.copy(b.boundingBox),d.getCenter(h),b.userData||(b.userData={}),u.set(0,0,0),p.set(0,0,0);var N=new Ke(1,1,1);if(y&&(Q.matrix.decompose(v,C,I),N.divide(I)),1!==i||1!==n||1!==r||b.userData.explosionFactor){b.userData.explosionFactor||(b.userData.explosionFactor=new Ke(1,1,1),b.userData.explosionBaseDifference=h.sub(l).clone().multiply(N));var P=b.userData.explosionFactor,G=b.userData.explosionBaseDifference;u.set((i-P.x)*G.x,(n-P.y)*G.y,(r-P.z)*G.z),1===i&&1===n&&1===r?(b.userData.explosionFactor=void 0,b.userData.explosionBaseDifference=void 0):P.set(i,n,r)}if(0!==o||0!==a||0!==s||b.userData.explosionOffset){b.userData.explosionOffset||(b.userData.explosionOffset=new Ke(0,0,0));var K=b.userData.explosionOffset;p.set(o*N.x-K.x,a*N.y-K.y,s*N.z-K.z),0===o&&0===a&&0===s?b.userData.explosionOffset=void 0:K.set(o*N.x,a*N.y,s*N.z)}if(g.set(u.x+p.x,u.y+p.y,u.z+p.z),0!==g.x||0!==g.y||0!==g.z){b.userData.explosionFactor||b.userData.explosionOffset?A.explosionList[M]||(A.explosionList[M]=!0):delete A.explosionList[M];var V=g.clone().multiply(I);f.makeTranslation(V.x,V.y,V.z),b.userData.changeOffset=g.clone(),b.transformation||(b.transformation=!0,b.transformationOriginalMatrix=b.matrix.clone(),b.applyMatrix=new yt,b.transformationOriginalBoundingBox=b.boundingBox.clone()),b.matrix.premultiply(f),b.applyMatrix.premultiply(f),b.boundingBox.copy(b.transformationOriginalBoundingBox).applyMatrix4(b.applyMatrix);for(var Y=0,H=O.length;H>Y;Y+=1){var j=O[Y].positionStart;Jw(F,j,j+O[Y].positionCount,g)}F.attributes.position.needsUpdate=!0}}}}}}}}}},Ww.prototype.closeComponentsExplosion=function(e,t){t=Array.isArray(t)?t:[t];this.componentsExplosion(e,{componentKey:t})},Ww.prototype._hasNodeGroup=function(e){return e._hasNodeGroup(Vp.GEOMETRY)},Ww.prototype._resetMaxIndicesNumberPerBathSegment=function(e){xd.SegmentedBatchMergeEnable&&this._maxIndiceseNum>xd.maxIndicesNumberPerBathSegment&&(Bu.log("adjust maxIndicesNumberPerBathSegment value from "+xd.maxIndicesNumberPerBathSegment+" to "+this._maxIndiceseNum+"!"),xd.maxIndicesNumberPerBathSegment=e)},Ww.prototype.createBatchedMeshNodes=function(e,t){var i=this,n=this.mapMaterialIdToMergedNode,r=e.manager,o=e.modelKey,a=e._encodedDatabagId,s=this._getNodeGroup(e),l=e.materialManager,c=t.materialKey,h=i.getPropertyValueByMaterialKey(c),d=l.getMaterialById(h.materialId);if(!d){var u=Object.keys(t.componentInfo)[0],p=t.componentInfo[u][0].nodeId,g=e.getModelDescriptor().getNodeInfosByNodeId(p);if(!g)return;g.uv="1"===h.uvProp,c=i._getMaterialKeyByNodeInfo(g,e),h=i.getPropertyValueByMaterialKey(c),d=l.getMaterialById(h.materialId)}var f=new Ni;if(f._visible=!0,f.setIndex(new Ai(t.index,1)),t.position&&t.position.length>0){f.setAttribute("position",new Ai(t.position,3)),t.normal&&t.normal.length===t.position.length&&f.setAttribute("normal",new Ai(t.normal,3));var m=!1;t.uv&&t.uv.length>0>0&&(f.setAttribute("uv",new Ai(t.uv,2)),m=!0),d.aoMap&&f.setAttribute("uv2",new Ai(t.uv,2)),f.getAttribute("normal")||f.computeVertexNormals();var A=t.componentInfo;n[c]||(n[c]=[]);var y=null;if("lines"===h.type)(y=new ov(f)).modelKey=o;else{var v={modelKey:o};(y=new Bv(f,d)).spawn(v)}if(n[c].push({geometry:f,indices:A,mesh:y}),y._indicesGroup=A,!wp.isEmptyObject(e.subModel)){var C=Object.keys(A)[0];if(C){var I=wp.getModelKeyFromComponentKey(C);e.subModel[I]&&y.matrix.copy(e.subModel[I])}}s.add(y),r.addMeshToOctantMap(a,c,new Mm(c,y));var x=function(t){A.hasOwnProperty(t)&&A[t].forEach((function(i){e.addMeshToInfoMap(t,i.nodeId,y,i,m)}))};for(var w in A)x(w);s.updateMatrixWorld(!0),e.manager.viewerImpl.render(),A=null,y=null}},Ww.prototype._asyncMergeData=function(e,t,i){Bu.time("MergeData");var n={},r=this,o=e.getLoader().maxLoadTaskCount,a=e.progressPercentage.load,s=e.progressPercentage.collect,l=t.length,c=Math.ceil(l/e.progressFrequency),h=e.getModelDescriptor().getStandardNodeInfos();requestAnimationFrame(function d(u){var p=u;return function(){var u=null,g=null;for(g=p+c>l?l:p+c,u=p;g>u;u+=1){if(r._collectMergedNodeInfosById(e,t[u],h,n),u===g-1)if(g!==l)e.dispatchEventEx({type:Fd.ON_LOAD_PROGRESS,progress:{total:o,loaded:(u/l*s+a)*o,modelKey:e.modelKey}}),requestAnimationFrame(d(u+1));else e.dispatchEventEx({type:Fd.ON_LOAD_PROGRESS,progress:{total:o,loaded:(s+a)*o,modelKey:e.modelKey}}),r._asyncMergeGeometry(n,e,i)}}}(0))},Ww.prototype._asyncMergeGeometry=function(e,t,i){var n=[];for(var r in e)n.push(r);if(0!==n.length){this._resetMaxIndicesNumberPerBathSegment(this._maxIndiceseNum);var o=this,a=t.getLoader().maxLoadTaskCount,s=t.progressPercentage.load,l=t.progressPercentage.collect,c=t.progressPercentage.merge,h=n.length,d=Math.ceil(h/t.progressFrequency),u=this.mapMaterialIdToMergedNode;requestAnimationFrame(function r(p){var g=p;return function(){var p,f=null;for(f=g+d>h?h:g+d,p=g;f>p;p+=1){if(o._collectMergedGeometriesById(n[p],e,u),p===f-1)if(f!==n.length)t.dispatchEventEx({type:Fd.ON_LOAD_PROGRESS,progress:{total:a,loaded:(p/h*c+s+l)*a,modelKey:t.modelKey},modelKey:t.modelKey}),requestAnimationFrame(r(p+1));else i()}}}(0))}else i()},Ww.prototype._collectMergedNodeInfosById=function(e,t,i,n){for(var r=i[t],o=0,a=r.length;a>o;o+=1){var s=r[o];this._createNodeBuffer(e,s);var l=this._getNodeBufferBy(s.nodeId);if(l){var c=l.index;c&&c.length>this._maxIndiceseNum&&(this._maxIndiceseNum=c.length);var h=this._getMaterialKeyByNodeInfo(s,e);void 0===n[h]&&(n[h]=[]),n[h].push(s)}}},Ww.prototype._collectMergedGeometriesById=function(e,t,i){var n=t[e];void 0===i[e]&&(i[e]=[]);for(var r=[],o=Math.max(n.length/800,500),a=Math.floor(n.length/o),s=n.length,l=0;a>=l;l+=1){for(var c=0,h=0,d=0,u=0,p=0,g=null,f=!1,m=0,A=0,y=s>o?o:s;y>A;A+=1){var v=l*o,C=n[v+A];if(!C)break;(g=this._getNodeBufferBy(C.nodeId))?(h+=g.index.length,c+=g.position.length,g.normal&&(d+=g.normal.length),g.uv&&g.uv.length>0?(f=!0,u+=g.uv.length):u+=g.position.length/3*2,g.uv2&&(p+=g.uv2.length),xd.SegmentedBatchMergeEnable&&h>xd.maxIndicesNumberPerBathSegment?(g.normal&&(d-=g.normal.length),g.uv&&(u-=g.uv.length),g.uv2&&(p-=g.uv2.length),r.push({start:m,end:A,steps:v,arrayPositionLength:c-=g.position.length,arrayIndexLength:h-=g.index.length,arrayNormalLength:d,arrayUVLength:u,arrayUV2Length:p}),c=0,h=0,d=0,u=0,p=0,m=A,A-=1):A===y-1&&r.push({start:m,end:y,steps:v,arrayPositionLength:c,arrayIndexLength:h,arrayNormalLength:d,arrayUVLength:u,arrayUV2Length:p}),g=null):A===y-1&&r.push({start:m,end:y,steps:v,arrayPositionLength:c,arrayIndexLength:h,arrayNormalLength:d,arrayUVLength:u,arrayUV2Length:p})}s-=o}for(var I=0,x=r.length;x>I;I+=1){for(var w=r[I],M=new Ni,E={},B=new Float32Array(w.arrayPositionLength),S=new Uint32Array(w.arrayIndexLength),b=new Float32Array(w.arrayNormalLength),k=new Float32Array(w.arrayUVLength),D=new Float32Array(w.arrayUV2Length),T=0,R=0,U=0,F=0,Q=0,L=[],O=w.start,N=w.end;N>O;O+=1){var P=n[w.steps+O];if(g=this._getNodeBufferBy(P.nodeId)){L.push(P.nodeId);var G=g.index,K=g.position,V=g.normal,Y=g.uv,H=g.uv2;B.set(K,T);for(var j=new Uint32Array(G),W=0,J=j.length;J>W;W+=1)j[W]+=T/3;S.set(j,R),void 0===E[P.userId]&&(E[P.userId]=[]),E[P.userId].push({userId:P.userId,nodeId:P.nodeId,positionStart:T,positionCount:K.length,indexStart:R,indexCount:G.length,lightmapIdx:P.lightmapIdx,boundingBox:P.boundingBox}),R+=G.length,T+=K.length,V&&(b.set(V,U),U+=V.length),f&&(Y?(k.set(Y,F),F+=Y.length):(k.set(new Float32Array(K.length/3*2),F),F+=Y.length)),H&&(D.set(H,Q),Q+=H.length),G=null,K=null,V=null,Y=null,H=null,g=null}}this.clearNodeBufferByNodeIds(L),M._visible=!0,M.setIndex(new Ai(S,1)),M.setAttribute("position",new Ai(B,3)),U>0&&M.setAttribute("normal",new Ai(b,3)),F>0&&M.setAttribute("uv",new Ai(k,2)),Q>0&&M.setAttribute("uv2",new Ai(D,2)),i[e].push({geometry:M,indices:E})}},Ww.prototype.clearAllNodeBuffer=function(){this.cachedNodeBuffer&&(this.cachedNodeBuffer={})},Ww.prototype.clearNodeBufferByNodeIds=function(e){if(this.cachedNodeBuffer)for(var t=0,i=e.length;i>t;t+=1)this.cachedNodeBuffer[e[t]]=null},Ww.prototype._getNodeBufferByNodeInfo=function(e,t){return this.cachedNodeBuffer||this._createNodeBuffer(e,t),this.cachedNodeBuffer[t.nodeId]},Ww.prototype._getNodeBufferBy=function(e){return this.cachedNodeBuffer?this.cachedNodeBuffer[e]:null},Ww.prototype._createNodeBufferForMergedBuffer=function(e,t,i){this.cachedNodeBuffer||(this.cachedNodeBuffer={}),this.cachedNodeBuffer[t.nodeId]||(this.cachedNodeBuffer[t.nodeId]=this.createBufferByBufferDataWithUV2(e,t,i))},Ww.prototype._createNodeBuffer=function(e,t){this._createNodeBufferForMergedBuffer(e,t,{buffer:e.getModelDescriptor().getReferencedMeshBufferById(t.geometryId),isDataView:!0})},Ww.prototype._createGeometries=function(e,t){var i=this,n=e.getModelDescriptor().getNodeInfosOnGeometryId(),r=e.getModelDescriptor().getReferencedMeshBufferData(),o=this._getClassifiedMeshes(n,r);this._dealDataMergedMeshs(e,o,r,n,(function(){i._dealDataMergeableMeshs(e,o,r,n,t)}))},Ww.prototype._getClassifiedMeshes=function(e,t){var i=[],n=[];for(var r in t){var o=t[r].IndexInfos,a=void 0;if(o){if(1>o.length)continue;for(var s=0,l=o.length;l>s;s+=1){if((c=e[o[s].meshId])&&c.length){a=o[s].meshId;break}}}else{var c;(c=e[r])&&c.length&&(a=r)}if(void 0!==a)(c=e[a])&&c.length&&(c[0].type===zy.EnumNodeItemType.LINE||!c[0].instanceOrNot&&c[0].shared?i.push(r):n.push(r))}if(!xd.Instance)for(var r in e)n[r]||i[r]||i.push(r);return{mergeableIdxs:i,mergedIdxs:n}},Ww.prototype._collectMergeableMeshesByIdxId=function(e,t,i,n,r){i[t]&&i[t].IndexInfos?this._collectSharedMeshesByIdxId(e,t,i,n,r):this._collectLineOrIntanceMeshesByIdxId(e,t,i,n,r)},Ww.prototype._collectLineOrIntanceMeshesByIdxId=function(e,t,i,n,r){for(var o=n[t],a={buffer:e.getModelDescriptor().getReferencedMeshBufferById(t)},s=0,l=o.length;l>s;s+=1){var c=o[s];this._createNodeBufferByGeoBufferData(e,c,a);var h=this._getMaterialKeyByNodeInfo(c);r[h]||(r[h]=[]),r[h].push(c)}},Ww.prototype._collectSharedMeshesByIdxId=function(e,t,i,n,r){for(var o=i[t].IndexInfos,a=0,s=o.length;s>a;a+=1){var l=n[o[a].meshId];if(l)for(var c={buffer:e.getModelDescriptor().getReferencedMeshBufferById(t),indexInfo:o[a]},h=0,d=l.length;d>h;h+=1){var u=l[h];this._createNodeBufferByGeoBufferData(e,u,c);var p=this._getMaterialKeyByNodeInfo(u);r[p]||(r[p]=[]),r[p].push(u)}}},Ww.prototype._mergeMergeableMeshes=function(e,t,i,n){var r=Object.keys(t);if(0!==r.length){var o=this,a=e.getLoader().maxLoadTaskCount,s=r.length,l=e.progressPercentage.load,c=e.progressPercentage.collect,h=e.progressPercentage.merge,d=Math.ceil(s/e.progressFrequency);requestAnimationFrame(function u(p){var g=p;return function(){var p=null,f=null;for(f=g+d>s?s:g+d,p=g;f>p;p+=1)o._collectMergedGeometriesById(r[p],t,i),p===f-1&&(f!==s?(e.dispatchEvent({type:Fd.ON_LOAD_PROGRESS,progress:{total:a,loaded:(p/s*h+l+c)*a,modelKey:e.modelKey}}),requestAnimationFrame(u(p+1))):o._makeMeshNodes(e,n))}}(0))}else this._makeMeshNodes(e,n)},Ww.prototype._dealDataMergeableMeshs=function(e,t,i,n,r){if(0!==t.mergeableIdxs.length){var o=this,a=this.mapMaterialIdToMergedNode,s={},l=t.mergedIdxs.length,c=t.mergeableIdxs.length,h=l+c,d=t.mergeableIdxs,u=e.getLoader().maxLoadTaskCount,p=e.progressPercentage.load,g=e.progressPercentage.collect,f=Math.ceil(c/e.progressFrequency);requestAnimationFrame(function t(m){var A=m;return function(){var m=null,y=null;for(y=A+f>c?c:A+f,m=A;y>m;m+=1)o._collectMergeableMeshesByIdxId(e,d[m],i,n,s),m===y-1&&(y!==c?(e.dispatchEvent({type:Fd.ON_LOAD_PROGRESS,progress:{total:u,loaded:((m+l)/h*g+p)*u,modelKey:e.modelKey}}),requestAnimationFrame(t(m+1))):(e.dispatchEvent({type:Fd.ON_LOAD_PROGRESS,progress:{total:u,loaded:(g+p)*u,modelKey:e.modelKey}}),o._mergeMergeableMeshes(e,s,a,r)))}}(0))}else this._makeMeshNodes(e,r)},Ww.prototype._collectDataMergedMeshesByIdxId=function(e,t,i,n,r){var o=t[e],a=o.IndexInfos;if(a&&0!==a.length){var s=!1;o.UV&&(o.UV.byteLength||o.UV.length)&&(s=!0),r.lightmap&&(o=this.getAttributeForLightmapWithDataMerged(o,r,e));for(var l=void 0,c=0,h=a.length;h>c;c+=1){var d=i[a[c].meshId];if(d&&0!==d.length){r.lightmap&&(a[c].lightmapIdx=o.lightmapIdx,a[c].positionStart=3*a[c].indexStart,a[c].positionCount=3*a[c].indexCount),l=a[c].meshId;for(var u=0,p=d.length;p>u;u+=1)d[u].uv=s}}if(void 0!==l){var g=i[l][0],f={},m=this._getMaterialKeyByNodeInfo(g);void 0===n[m]&&(n[m]=[]);for(var A=0,y=a.length;y>A;A+=1)i[a[A].meshId]&&(void 0===f[(g=i[a[A].meshId][0]).userId]&&(f[g.userId]=[]),a[A].userId=g.userId,a[A].nodeId=g.nodeId,a[A].boundingBox=g.boundingBox,f[g.name].push(a[A]));var v=new Ni;v._visible=!0,v.setIndex(new Ai(new Uint32Array(o.I),1)),v.setAttribute("position",new Ai(new Float32Array(o.P),3)),o.N&&(o.N.byteLength||o.N.length)&&v.setAttribute("normal",new Ai(new Float32Array(o.N),3)),s&&v.setAttribute("uv",new Ai(new Float32Array(o.UV),2)),o.UV2&&(v.setAttribute("uv2",new Ai(new Float32Array(o.UV2),2)),v.lightmapIdx=o.lightmapIdx),n[m].push({geometry:v,indices:f})}}},Ww.prototype.getAttributeForLightmapWithDataMerged=function(e,t,i){var n=[],r=new Uint32Array(e.I),o=t.getLoader().getUV2ById("bmpk_"+i,r.length);if(o){var a=o.lightmapIdx;n=o.uv2}for(var s=new Float32Array(e.P),l=new Float32Array(e.N),c=new Float32Array(e.UV),h=[],d=[],u=[],p=0;r.length>p;p+=1){var g=r[p];h.push(s[3*g]),h.push(s[3*g+1]),h.push(s[3*g+2]),l.length>0&&(d.push(l[3*g]),d.push(l[3*g+1]),d.push(l[3*g+2])),c.length>0&&(u.push(c[2*g]),u.push(c[2*g+1])),r[p]=p}return s=null,l=null,c=null,{I:r,UV2:n,P:h,N:d,UV:u,lightmapIdx:a}},Ww.prototype._dealDataMergedMeshs=function(e,t,i,n,r){if(0!==t.mergedIdxs.length){var o=this,a=this.mapMaterialIdToMergedNode,s=t.mergedIdxs,l=s.length,c=t.mergedIdxs.length+t.mergeableIdxs.length,h=e.getLoader().maxLoadTaskCount,d=e.progressPercentage.load,u=e.progressPercentage.collect,p=Math.ceil(l/e.progressFrequency);requestAnimationFrame(function t(g){var f=g;return function(){var g=null,m=null;for(m=f+p>l?l:f+p,g=f;m>g;g+=1)o._collectDataMergedMeshesByIdxId(s[g],i,n,a),g===m-1&&(m!==l?(e.dispatchEvent({type:Fd.ON_LOAD_PROGRESS,progress:{total:h,loaded:(g/c*u+d)*h,modelKey:e.modelKey}}),requestAnimationFrame(t(g+1))):(e.dispatchEvent({type:Fd.ON_LOAD_PROGRESS,progress:{total:h,loaded:(g/c*u+d)*h,modelKey:e.modelKey}}),r&&r()))}}(0))}else r&&r()},Ww.prototype._dealUnsharedMeshs=function(e,t,i){for(var n=this.mapMaterialIdToMergedNode,r=0,o=e.length;o>r;r+=1){var a=i[e[r]],s=a.IndexInfos,l=t[s[0].meshId][0],c={},h=this._getMaterialKeyByNodeInfo(l);void 0===n[h]&&(n[h]=[]);for(var d=0,u=s.length;u>d;d+=1)void 0===c[(l=t[s[d].meshId][0]).userId]&&(c[l.userId]=[]),s[d].userId=l.userId,s[d].nodeId=l.nodeId,c[l.userId].push(s[d]);var p=new Ni;p._visible=!0,p.setIndex(new Ai(new Uint32Array(a.index),1)),p.setAttribute("position",new Ai(new Float32Array(a.position),3)),a.normal&&p.setAttribute("normal",new Ai(new Float32Array(a.normal),3)),a.uv&&p.setAttribute("uv",new Ai(new Float32Array(a.uv),2)),n[h].push({geometry:p,indices:c})}},Ww.prototype._makeMeshNodes=function(e,t){Bu.time("makeMesh");var i=e.manager,n=e.modelKey,r=e._encodedDatabagId,o=this._getNodeGroup(e),a=this.mapMaterialIdToMergedNode;for(var s in a)for(var l=this.getPropertyValueByMaterialKey(s),c=a[s],h=0,d=c.length;d>h;h+=1){var u=c[h].geometry,p=c[h].indices;if(!c[h].mesh){var g=null;if("lines"===l.type)(g=new ov(u)).modelKey=n;else{var f={modelKey:n};(g=new Bv(u)).spawn(f)}if(!wp.isEmptyObject(e.subModel)){var m=Object.keys(p)[0];if(m){var A=wp.getModelKeyFromComponentKey(m);e.subModel[A]&&g.matrix.copy(e.subModel[A])}}g._indicesGroup=p,o.add(g),c[h].mesh=g,i.addMeshToOctantMap(r,s,new Mm(s,g));var y=function(t){p.hasOwnProperty(t)&&p[t].forEach((function(i){e.addMeshToInfoMap(t,i.nodeId,g,i)}))};for(var v in p)y(v);p=null,g=null}}o.updateMatrixWorld(!0),e.dispatchEvent({type:Fd.ON_LOAD_PROGRESS,progress:{total:e.getLoader().maxLoadTaskCount,loaded:e.getLoader().maxLoadTaskCount,modelKey:e.modelKey}}),t&&t(),Bu.timeEnd("makeMesh")},Ww.prototype.applySelection=function(e){},Ww.prototype.clearSelection=function(e){},Ww.prototype.applyHover=function(e){},Ww.prototype.clearHover=function(e){},Ww.prototype.getMeshNode=function(){return this.mapMaterialIdToMergedNode},Ww.prototype._disposeMergedGeometries=function(){for(var e in this.mapMaterialIdToMergedNode){for(var t=this.mapMaterialIdToMergedNode[e],i=0,n=t.length;n>i;i+=1){t[i].geometry.dispose(),delete t[i].geometry,delete t[i].indices,delete t[i].mesh}delete this.mapMaterialIdToMergedNode[e]}},Ww.prototype._getMaterialKeyByNodeInfo=function(e,t){if(t){var i=t.manager.getOverrideMaterialByNodeInfo(e);e.materialId=i?i.name:e.originMId}return wp.getCombinedKeyString([e.materialId,e.uv?"1":"0",e.type===zy.EnumNodeItemType.LINE?"lines":"meshes"])},Ww.prototype.getPropertyValueByMaterialKey=function(e){var t=wp.splitCombinedKeyString(e);return{materialId:t[0],uvProp:t[1],type:t[2]}},Ww.prototype.clearSelectedObjectIds=function(){this.selectedObjectIds.length=0},Ww.prototype.cacheSelectedObjectIds=function(e,t,i){this.selectedObjectIds.push({uid:e,mKey:t,idx:i})},Ww.prototype.adjustVisibility=function(e,t){var i=this._getNodeGroup(e),n=i.visible;t&&!i.bVisible||(i.visible=t),i.bVisible=n},Ww.prototype.changeVisibilityOfSelectedObjects=function(e,t){if(t)for(var i=0,n=this.selectedMeshes.length;n>i;i+=1){var r=this.selectedMeshes[i].object,o=this.selectedMeshes[i].indices;if(r)for(var a=0,s=o.length;s>a;a+=1){var l=r.geometry.groups[o[a].idx];l.start=o[a].start,l.count=o[a].count}}else{this.selectedMeshes.length=0;for(var c={},h=0,d=this.selectedObjectIds.length;d>h;h+=1){var u=this.selectedObjectIds[h].mKey,p=this.selectedObjectIds[h].idx,g=wp.getCombinedKeyString([u,p]);if(!c[g]){c[g]=!0;var f=this.mapMaterialIdToMergedNode[u][p],m=f.mesh;if(m){for(var A=[],y=f.geometry.groups,v=0,C=y.length;C>v;v+=1){var I=y[v];I.materialIndex===Zd.SELECTED&&(A.push({idx:v,start:I.start,count:I.count}),I.start=0,I.count=0)}A.length&&this.selectedMeshes.push({object:m,indices:A})}}}}},Ww.prototype.changeVisibilityOfNonSelectedObjects=function(e,t){if(t)for(var i=0,n=this.nonSelectedMeshes.length;n>i;i+=1){var r=this.nonSelectedMeshes[i].object,o=this.nonSelectedMeshes[i].indices;if(o)for(var a=0,s=o.length;s>a;a+=1){var l=r.geometry.groups[o[a].idx];l.start=o[a].start,l.count=o[a].count}else r.visible=this.nonSelectedMeshes[i].visibility}else{this.nonSelectedMeshes.length=0;for(var c={},h=0,d=this.selectedObjectIds.length;d>h;h+=1){var u=this.selectedObjectIds[h];c[u.mKey]||(c[u.mKey]={}),c[u.mKey][u.idx]=!0}for(var p in this.mapMaterialIdToMergedNode){var g=this.mapMaterialIdToMergedNode[p];if(c[p])for(var f=0,m=g.length;m>f;f+=1){var A=g[f].mesh;if(A){if(!c[p][f]){this.nonSelectedMeshes.push({object:A,indices:null,visibility:A.visible}),A.visible=!1;continue}for(var y=[],v=A.geometry.groups,C=0,I=v.length;I>C;C+=1){var x=v[C];x.materialIndex!==Zd.SELECTED&&(y.push({idx:C,start:x.start,count:x.count}),x.start=0,x.count=0)}y.length>0&&this.nonSelectedMeshes.push({object:A,indices:y})}}else for(var w=0,M=g.length;M>w;w+=1){var E=g[w].mesh;E&&(this.nonSelectedMeshes.push({object:E,indices:null,visibility:E.visible}),E.visible=!1)}}}},Ww.prototype.restoreVisibilityOfObjects=function(){this.selectedMeshes.length=0,this.nonSelectedMeshes.length=0},Ww.prototype.getBlinkMaterials=function(){return this.blinkMaterials},Ww.prototype.disposeBufferAfterVbo=function(){if(!this.bufferDestroyed){var e=0;for(var t in this.mapMaterialIdToMergedNode){for(var i=this.mapMaterialIdToMergedNode[t],n=0,r=i.length;r>n;n+=1){var o=i[n],a=o.geometry;if(null!==a){e+=1;var s=t+"-"+n;this.mapDestroyedBufferKey[s]||o.mesh.visible&&(this.mapDestroyedBufferKey[s]=!0,by.disposeBufferFromGeometry(a,["normal","uv","uv2"]))}}Object.keys(this.mapDestroyedBufferKey).length===e&&(this.mapDestroyedBufferKey={},this.bufferDestroyed=!0)}}},Ww.prototype._traverseMeshNodeMap=function(e){for(var t in this.mapMaterialIdToMergedNode)for(var i=this.mapMaterialIdToMergedNode[t],n=0,r=i.length;r>n;n+=1)e&&e(t,i[n])},Ww.prototype.getGeometryBuffersByUserId=function(e,t){var i=[],n=e.getDatabagId();return this._traverseMeshNodeMap((function(e,r){var o=r.indices[t];if(o)for(var a=r.geometry,s=a.getIndex().array,l=a.getAttribute("position").array,c=0,h=o.length;h>c;c+=1){var d=o[c],u=d.indexStart,p=d.indexStart+d.indexCount,g=s.slice(u,p),f=l.slice(u=d.positionStart,p=d.positionStart+d.positionCount);u/=3,g.forEach((function(e,t,i){i[t]-=u})),i.push({databagId:n,nodeId:d.nodeId,position:f,index:g})}})),i},Ww.prototype.getPickingNodeGenerator=function(){return this.pickingNodeGenerator||(this.pickingNodeGenerator=new ev(this)),this.pickingNodeGenerator};var zw=function(e){this.meshManager=new Ww(this),this.model=e,this.wireframeManager=new Uv(this)};zw.prototype.destroy=function(){this.meshManager.destroy(),this.meshManager=null,this.wireframeManager.destroy(),this.wireframeManager=null},zw.prototype.clearData=function(){this.meshManager.clearData(),this.wireframeManager.clearData()},zw.prototype.disposeGeometry=function(e){this.meshManager.disposeGeometry(e)},zw.prototype.cullNodes=function(e,t){this.hasNodeInfo(e)&&this.meshManager.cullNodes(e,t)},zw.prototype.updateNodes=function(e,t){if(this.hasNodeInfo(e)){var i;i=this._collectModelFiltered(e),this.meshManager.update(e,t,i),this.wireframeManager.update(e,t)}},zw.prototype.applyFilter=function(e,t){if(this.hasNodeInfo(e)){var i=null;i=t||e.getModelDescriptor().getMixNodeInfos();var n=e.getModelDescriptor().getMixNodeInfos();this._collectFilteredUserIds(e.manager.filter,i,n),this._collectSelectedUserIds(e.manager.sceneState.selectionSet,n),this._collectHoveredUserIds(e.manager.sceneState.hoverId,n),this.updateNodes(e,t)}},zw.prototype.applySelection=function(e){if(this.hasNodeInfo(e)){var t=e.getModelDescriptor().getMixNodeInfos();this._clearSelectedState(e),this._clearHoveredState(e),this._collectSelectedUserIds(e.manager.sceneState.selectionSet,t),this._collectHoveredUserIds(e.manager.sceneState.hoverId,t),this.updateNodes(e)}},zw.prototype.clearSelection=function(e){this._clearSelectedState(e),this.applyHover(e)},zw.prototype.applyHover=function(e){if(this.hasNodeInfo(e)){var t=e.getModelDescriptor().getMixNodeInfos();this._clearHoveredState(e),this._collectHoveredUserIds(e.manager.sceneState.hoverId,t),this.updateNodes(e)}},zw.prototype.clearHover=function(e){this._clearHoveredState(e),this.updateNodes(e)},zw.prototype.applyBlink=function(e){},zw.prototype.clearBlink=function(e){},zw.prototype.getPriorityNodes=function(){return this.meshManager.getPriorityNodes()},zw.prototype.getGeometryByNodeInfo=function(e,t){return this.meshManager.getGeometryByNodeInfo(e,t)},zw.prototype.getRenderableCount=function(e){return e.renderableCount},zw.prototype.getLoader=function(e){return e.loader},zw.prototype.getContainsCamera=function(e){return e.containsCamera},zw.prototype.getFilter=function(e){return e.manager.filter},zw.prototype.hasNodeInfo=function(e){return!!e.getModelDescriptor().getMixNodeInfos()},zw.prototype.createMeshNodes=function(e){this.meshManager.createMeshNodes(e)},zw.prototype.asyncCreateMeshNodes=function(e,t,i){this.meshManager.asyncCreateMeshNodes(e,t,i)},zw.prototype._collectFilteredUserIds=function(e,t,i){var n=e._hasHiddenFileIdFilter(),r=e._hasVisibleFilter(),o=e._hasOverrideMaterialFilter(),a=e._hasTransparentFilter();if(this.mapMaterialIdToUserIdsForFilter={},this.hiddenUserIdSetObject={},this.overrideUserIdSetObject={},this.transparentUserIdSetObject={},n||r||o||a)for(var s=0;t.length>s;s+=1){var l=t[s],c=i[l];if(c&&c.length)for(var h=0,d=c.length;d>h;h+=1){var u=c[h];if(n&&e._isHiddenFileId(u)||r&&!1===e._isVisible(u))this.hiddenUserIdSetObject[l]=!0;else if(a&&e._isTransparent(u))this.transparentUserIdSetObject[l]=!0;else if(o&&e._hasOverrideMaterial(u)){var p=e._getOverrideMaterial(u);if(Array.isArray(p)){for(var g=[],f=0,m=p.length;m>f;f++){var A=null!==p[f]?p[f].name:"";""!==A&&g.push(A)}this.overrideUserIdSetObject[l]=g}else{var y=null!==p?p.name:"";""!==y&&(this.overrideUserIdSetObject[l]=y)}}}}},zw.prototype._collectModelFiltered=function(e){var t=e.manager.filter,i=e.modelKey,n=t._hasModelOverrideMaterialFilter(),r=t._hasModelTransparentFilter(),o=e.manager.modelState.modelSelectionSet;return e.manager.modelState.hoverId===i?e.manager.modelState.getHoverMaterial():o.hasOwnProperty(e.modelKey)?e.manager.modelState.selectionMaterial:r&&t._isModelTransparent(i)?t._getMaterialByName("scene"):n&&t._hasModelOverrideMaterial(i)?t._getModelOverrideMaterial(i):null},zw.prototype._clearFilteredState=function(){this.hiddenUserIdSetObject={},this.overrideUserIdSetObject={},this.transparentUserIdSetObject={}},zw.prototype.getFilteredUserIds=function(){return this.mapMaterialIdToUserIdsForFilter},zw.prototype.getSelectedUserIds=function(){return this.mapMaterialIdToUserIdsForSelection},zw.prototype.getHoveredUserIds=function(){return this.mapMaterialIdToUserIdsForHover},zw.prototype.getBlinkedUserIds=function(){return this.mapBlinkUserIds},zw.prototype.getHiddenUserIds=function(){return this.hiddenUserIdSetObject},zw.prototype._collectSelectedUserIds=function(e,t){for(var i in this.selectedUserIdSetObject={},e)if(e.hasOwnProperty(i)){if(!t[i])continue;this.selectedUserIdSetObject[i]=!0}},zw.prototype._clearSelectedState=function(){this.selectedUserIdSetObject={}},zw.prototype._collectHoveredUserIds=function(e,t){if(this.hoveredUserIdSetObject={},e&&t[e]){var i=t[e];this.hoveredUserIdSetObject={},i&&(this.hoveredUserIdSetObject[e]=!0)}},zw.prototype._clearHoveredState=function(){this.hoveredUserIdSetObject={}},zw.prototype.getMeshesByUserIds=function(e,t){return this.meshManager.getMeshesByUserIds(e,t)},zw.prototype.adjustVisibility=function(e,t){this.meshManager.adjustVisibility(e,t),this.wireframeManager.adjustVisibility(e,t)},zw.prototype.changeVisibilityOfSelectedObjects=function(e,t){this.meshManager.changeVisibilityOfSelectedObjects(e,t),this.wireframeManager.changeVisibilityOfSelectedObjects(e,t)},zw.prototype.changeVisibilityOfNonSelectedObjects=function(e,t){this.meshManager.changeVisibilityOfNonSelectedObjects(e,t),this.wireframeManager.changeVisibilityOfNonSelectedObjects(e,t)},zw.prototype.restoreVisibilityOfObjects=function(){this.meshManager.restoreVisibilityOfObjects(),this.wireframeManager.restoreVisibilityOfObjects()},zw.prototype.isPickableNode=function(e){var t=this.getHiddenUserIds();if(t&&t[e])return!1;var i=this.getTransparentUserIds();return!(i&&i[e]&&!xd.EnableSelectionByTranslucent)},zw.prototype.isHiddenNode=function(e){var t=this.getHiddenUserIds();return!(!t||!t[e])},zw.prototype.getMeshManager=function(){return this.meshManager},zw.prototype.getWireFrameManager=function(){return this.wireframeManager},zw.prototype.getTransparentUserIds=function(){return this.transparentUserIdSetObject};var qw=new yt,Zw=function(e,t){_y.call(this,e),this.defaultManager=new zw(e),this.instancedManager=new Kv(e),this.loader=new Vw(this)};Object.assign(Zw.prototype,_y.prototype),Zw.prototype.prepareData=function(e){if(!this.dataReady){var t=this;this.loader.getDescriptor().buildScene((function(){t.dataReady=!0,t.settleData(e)}))}},Zw.prototype.prepare=function(e){this.isLoaded()&&!this.isHidden()&&(this.model.getMaterialManager()._updateTextureMapping(),this.model.clearMeshFromOctantMap(),this.instancedManager.addAllInstanceNodeToScene(this.model),this.defaultManager.cullNodes(this.model,e),this.prepareWireframe(this.model),this.updateNodes())};var Xw=new yt;Zw.prototype.componentApplyMatrix=function(e,t){if(jg(this.loader)&&jg(this.loader.descriptor)){var i=this.loader.descriptor.getNodeInfosByComponentKey(e);if(jg(i)&&0!==i.length)for(var n=0;i.length>n;n+=1){var r=i[n];r.matrix||(r.matrix=new yt),r.transformation||(r.transformation=!0,r.transformationOriginalMatrix=r.matrix.clone(),r.applyMatrix=new yt,r.boundingBox&&(r.transformationOriginalBoundingBox=r.boundingBox.clone())),r.matrix.premultiply(t),r.applyMatrix.premultiply(t),r.boundingBox&&r.boundingBox.copy(r.transformationOriginalBoundingBox).applyMatrix4(r.applyMatrix);var o=null;if(r.mesh instanceof Array)o=r.mesh;else{if(!(r.mesh instanceof Yt))continue;o=[r.mesh]}for(var a=0,s=o.length;s>a;a+=1){var l=o[a];r.isExternalComponent&&(l.userData.originalMatrix||(l.userData.originalMatrix=l.matrix.clone())),l.getInstanceMatrixAt(r.groupIndex,Xw),Xw.premultiply(t),l.setInstanceMatrixAt(r.groupIndex,r.subInstanceIndex,Xw)}}}},Zw.prototype.setComponentMatrix=function(){if(jg(this.loader)&&jg(this.loader.descriptor)){var e=this.loader.descriptor.getNodeInfosByComponentKey(key);if(jg(e)&&0!==e.length)for(var t=0;e.length>t;t+=1){var i=e[t];i.matrix||(i.matrix=new yt),i.transformation?(new yt).copy(i.applyMatrix).invert():(i.transformation=!0,i.transformationOriginalMatrix=i.matrix.clone(),i.applyMatrix=new yt,i.boundingBox&&(i.transformationOriginalBoundingBox=i.boundingBox.clone())),i.matrix.copy(i.transformationOriginalMatrix).premultiply(matrix4),i.applyMatrix.copy(matrix4),i.boundingBox&&i.boundingBox.copy(i.transformationOriginalBoundingBox).applyMatrix4(i.applyMatrix);var n=null;if(i.mesh instanceof Array)n=i.mesh;else{if(!(i.mesh instanceof Yt))continue;n=[i.mesh]}for(var r=0,o=n.length;o>r;r+=1){var a=n[t];i.isExternalComponent&&(a.userData.originalMatrix||(a.userData.originalMatrix=a.matrix.clone())),a.getInstanceMatrixAt(i.groupIndex,Xw),Xw.copy(i.matrix),Xw.premultiply(new yt),a.setInstanceMatrixAt(i.groupIndex,i.subInstanceIndex,Xw)}}}},Zw.prototype.resetComponentMatrix=function(){if(jg(this.loader)&&jg(this.loader.descriptor)){var e=this.loader.descriptor.getNodeInfosByComponentKey(key);if(jg(e)&&0!==e.length)for(var t=0;e.length>t;t+=1){var i=e[t];if(i.transformation){i.matrix.copy(i.transformationOriginalMatrix),i.transformationOriginalBoundingBox&&(i.boundingBox=i.transformationOriginalBoundingBox.clone());var n=null;if(i.mesh instanceof Array)n=i.mesh;else{if(!(i.mesh instanceof Yt))continue;n=[i.mesh]}for(var r=0,o=n.length;o>r;r+=1){var a=n[t],s=void 0;(s=i.isExternalComponent?a.userData.originalMatrix:i.matrix)&&(a.getInstanceMatrixAt(i.groupIndex,Xw),Xw.copy(s),Xw.premultiply(new yt),a.setInstanceMatrixAt(i.groupIndex,i.subInstanceIndex,Xw),a.userData.originalMatrix=void 0)}i.transformationOriginalMatrix=void 0,i.transformationOriginalBoundingBox=void 0,i.applyMatrix=void 0,i.transformation=void 0}}}},Zw.prototype.prepareWireframe=function(e,t){e.isActivateWireframe()&&this.instancedManager.generateWireframe(e)},Zw.prototype.settleData=function(e){this.createMeshNodes(e),this.addNodeInfoToOctantMap()},Zw.prototype.addNodeInfoToOctantMap=function(){var e=this.model.manager,t=this.model.getEncodedDatabagId();this.model.getModelDescriptor().traverseNodeInfosByComponent((function(i,n){e.addNodeInfoToOctantMap(t,i,n)}))},Zw.prototype.createMeshNodes=function(e){var t=this.model;this.instancedManager.createMeshNodes(this.model,this.model.getModelDescriptor().getInstancedUserIds()),this.defaultManager.createMeshNodes(t),this.loaded=!0,e&&e()},Zw.prototype.disposeBufferAfterVbo=function(){},Zw.prototype.explosion=function(e){if(this.isLoaded()){var t=this.model.getComponentlist();e.componentKey=t,this.componentsExplosion(e)}},Zw.prototype.closeExplosion=function(){this.explosion({})},Zw.prototype.componentsExplosion=function(e){if(this.isLoaded()){var t=e.coefficientX||1,i=e.coefficientY||1,n=e.coefficientZ||1,r=e.offsetX||0,o=e.offsetY||0,a=e.offsetZ||0,s=null;if(e.center)s=(new Ke).fromArray(e.center);else if(1!==t||1!==i||1!==n||0!==r||0!==o||0!==a)return;var l=this.model,c=l.manager,h=Array.isArray(e.componentKey)?e.componentKey:[e.componentKey],d=new Ke,u=new He,p=new Ke(0,0,0),g=new Ke(0,0,0),f=new Ke,m=l.getModelMatrix(),A=new yt;m&&s&&(A.copy(m).invert(),s.applyMatrix4(A));for(var y=0;h.length>y;y+=1){var v=h[y],C=l.getComponentInfo(v);if(C&&C.length>0)for(var I=0,x=C.length;x>I;I+=1){var w=C[I],M=w.mesh;if(M){if(u.copy(w.boundingBox),u.getCenter(d),w.userData||(w.userData={}),p.set(0,0,0),g.set(0,0,0),1!==t||1!==i||1!==n||w.userData.explosionFactor){w.userData.explosionFactor||(w.userData.explosionFactor=new Ke(1,1,1),w.userData.explosionBaseDifference=d.sub(s).clone());var E=w.userData.explosionFactor,B=w.userData.explosionBaseDifference;p.set((t-E.x)*B.x,(i-E.y)*B.y,(n-E.z)*B.z),1===t&&1===i&&1===n?(w.userData.explosionFactor=void 0,w.userData.explosionBaseDifference=void 0):E.set(t,i,n)}if(0!==r||0!==o||0!==a||w.userData.explosionOffset){w.userData.explosionOffset||(w.userData.explosionOffset=new Ke(0,0,0));var S=w.userData.explosionOffset;g.set(r-S.x,o-S.y,a-S.z),0===r&&0===o&&0===a?w.userData.explosionOffset=void 0:S.set(r,o,a)}if(f.set(p.x+g.x,p.y+g.y,p.z+g.z),0!==f.x||0!==f.y||0!==f.z){w.userData.explosionFactor||w.userData.explosionOffset?c.explosionList[v]||(c.explosionList[v]=!0):delete c.explosionList[v],A.makeTranslation(f.x,f.y,f.z),w.transformation||(w.transformation=!0,w.transformationOriginalMatrix=w.matrix.clone(),w.applyMatrix=new yt,w.transformationOriginalBoundingBox=w.boundingBox.clone()),w.matrix.premultiply(A),w.applyMatrix.premultiply(A),w.boundingBox.copy(w.transformationOriginalBoundingBox).applyMatrix4(w.applyMatrix);var b=M.matrixAutoUpdate;M.matrixAutoUpdate=!1,w.isMixNode?(M.getInstanceMatrixAt(w.groupIndex,qw),qw.premultiply(A),M.setInstanceMatrixAt(w.groupIndex,w.subInstanceIndex,qw)):(M.applyMatrix4(A),M.updateMatrixWorld(!0)),M.matrixAutoUpdate=b;var k=w.wireframeMeshs;if(k)for(var D=0,T=k.length;T>D;D+=1){var R=k[D];b=R.matrixAutoUpdate,R.matrixAutoUpdate=!1,R.matrix.copy(M.matrix),R.updateMatrixWorld(!0),R.matrixAutoUpdate=b}}}}}}},Zw.prototype.closeComponentsExplosion=function(e){var t=Array.isArray(e)?e:[e];this.componentsExplosion({componentKey:t})};var _w=function(e){this.model=e,this.config=null,this.statistics={renderableCount:0,renderableTotal:xd.maxObjectNumInPool,renderableTotalForPool:xd.maxObjectNumInPool,numOfElements:0,numOfTriangles:0,memoeryInfo:null},this.transformInfos={octreeTransformed:!0,originalBoundingBox:null,boundingBox:null,position:new Ke,rotation:new Ge,scale:new Ke(1,1,1),transformMatrix:new yt,originalMatrix:new yt}};_w.prototype.destroy=function(){this.model=null,this.config=null,this.statistics=null,this.transformInfos=null},_w.prototype.load=function(e){var t=this,i=this.model,n=i.dataUrl,r=function(r){var o={};if("string"==typeof r)try{o=JSON.parse(r)}catch(e){return i.setEmptyScene(!0),void i.dispatchEventEx({type:Fd.ON_LOAD_INVALID_SCENE,modelKey:i.modelKey})}else o=r;if(o&&"SUCCESS"===o.code){if(xd.offLine)t.model.getStorage().put(n.projectUrl(),o,t.model.modelKey,(function(){}),(function(){}));if(-1===Number(o.data.status))return void i.dispatchEventEx({type:Qd.PARSEFAILE,modelKey:i.modelKey});if(3>Number(o.data.status)&&(i.dispatchEventEx({type:Qd.PARSING,modelKey:i.modelKey}),!(o.data.scene&&o.data.scene.packs&&xd.usePack)))return;if(o.data.type===Xd.DWG)return i.dispatchEventEx({type:Qd.IS2D,modelKey:i.modelKey}),void Bu.error("模型 ",i.modelKey," 是图纸文件请使用BOS2D库加载");!o.data.profiles||o.data.children&&o.data.children.length>1?(t.dataVersion="2.0.0",n.apiVersion="2.0.0",t.model.dataVersion=t.dataVersion):(t.dataVersion=o.data.profiles.geo||"1.0.0",n.apiVersion=o.data.profiles.api,t.model.dataVersion=t.dataVersion),t._parse(o.data),i.dispatchEventEx({type:Fd.ON_LOAD_CONFIG_FINISH,modelKey:i.modelKey}),e&&e()}else Bu.log(i.modelKey,"config load error! ",o.message),i.dispatchEventEx({type:Fd.ON_LOAD_ERROR,modelKey:i.modelKey,code:o.code,message:o.message}),i.manager.unload(i.modelKey)};if(xd.offLine){var o=this.model.getStorage();o&&o.getBatch([n.projectUrl()],(function(e){e[n.projectUrl()]?r(e[n.projectUrl()]):Yy({type:"GET",url:n.projectUrl(),headers:{Authorization:i.accessToken},success:r,error:function(e){i.dispatchEventEx({type:Fd.ON_NETWORK_ERROR,modelKey:i.modelKey,data:e})}})}),(function(){}))}else Yy({type:"GET",url:n.projectUrl(),headers:{Authorization:i.accessToken},success:r,error:function(e,t){switch(e){case 401:i.dispatchEventEx({type:Fd.ACCOUNT_NO_EXIST,modelKey:i.modelKey,data:t});break;case 403:i.dispatchEventEx({type:Fd.NO_PERMISSION,modelKey:i.modelKey,data:t});break;default:i.dispatchEventEx({type:Fd.ON_NETWORK_ERROR,modelKey:i.modelKey,data:e})}}})},_w.prototype._parse=function(e){this.config=e,e.lengthUnit&&(this.model.originalLengthUnit=e.lengthUnit),xd.AutoMergeComponent&&e.componentCount>xd.AutoMergeComponentCount&&(xd.MergeComponent=!0),this._toStatistics(e),this._setTransformInfos(e),this._chooseRendering(e),this._setHandler(e)},_w.prototype._getDataProvider=function(e){if(xd.DataProvider===zd.MERGED&&void 0!==e.bmpks&&e.bmpks>0)return Bu.debug("data from: merged"),zd.MERGED;if(xd.LoadComponentOnDemand&&e.scene&&e.scene.map){if(xd.DataProvider===zd.LAYER_SCENE)return e.layers>1?(Bu.debug("data from: layer scene"),zd.LAYER_SCENE):(Bu.debug("data from: layer"),zd.LAYER);if(xd.DataProvider===zd.LAYER)return Bu.debug("data from: layer"),zd.LAYER}if(xd.DataProvider===zd.AUTO){if(xd.LoadComponentOnDemand&&e.scene&&e.scene.map)return gy(this.dataVersion,"2.0.0")&&(xd.MergeComponent=!0),Bu.debug("data from: layer"),zd.LAYER;if(!xd.loadBatch&&e.scene.geometries&&e.scene.geometries.length>0)return fy(this.dataVersion,"2.0.0")&&(xd.MergeComponent=!0),zd.DEFAULT;if(e.scene.batchedGeometries&&e.scene.batchedGeometries.length>0||e.scene.instancedGeometries&&e.scene.instancedGeometries.length>0)return xd.MergeComponent=!0,zd.MERGED;if(xd.MergeComponent&&void 0!==e.bmpks&&e.bmpks>0)return Bu.debug("data from: merged"),zd.MERGED}return Bu.debug("data from: default"),zd.DEFAULT},_w.prototype._chooseRendering=function(e){this.model.manager.chooseRendering(this.statistics.memoeryInfo)},_w.prototype._setHandler=function(e){var t=!1,i=this._getDataProvider(e),n=null,r=this.model;if(Array.isArray(e.scene)){for(var o=0,a=e.children.length;a>o;o+=1){var s=e.scene[o];s&&(r.subModel[e.children[o]]=(new yt).fromArray(s.matrix||[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1]))}n=new MI(r,t),r.merged=!0,xd.MergeComponent=!0}else if(e.scene.packs&&xd.usePack)n=new Zw(r),r.progressPercentage={load:.9,file:.3,zip:.4,glTF:.2,read:.05,mesh:.05,collect:.5,merge:.1},xd.MergeComponent=!0,r.picker=new jw({viewer:r.manager.viewerImpl});else if(r.hasAnimation&&xd.EnableAnimation)n=new SI(r);else if(xd.MergeComponent){switch(i){case zd.LAYER:xd.HasLayerData=!0,xd.LoadGeoOnDemand=!0,(n=new uI(r,t)).layerProvider.cachedLayerData=e.scene.map;break;case zd.LAYER_SCENE:xd.HasLayerData=!0,xd.LoadGeoOnDemand=!0;break;case zd.MERGED:n=new rI(r,t);break;default:n=new Vv(r,t)}r.merged=!0}else if(xd.OrganizeNodesByCameraView)switch(i){case zd.LAYER:case zd.LAYER_SCENE:xd.HasLayerData=!0,xd.LoadGeoOnDemand=!0}else switch(i){case zd.LAYER:xd.HasLayerData=!0,xd.LoadGeoOnDemand=!0,(n=new II(r)).layerProvider.cachedLayerData=e.scene.map;break;case zd.LAYER_SCENE:xd.HasLayerData=!0,xd.LoadGeoOnDemand=!0;break;case zd.MERGED:break;default:n=new SI(r)}r._handler=n},_w.prototype._setTransformInfos=function(e){if(this.model.hasAnimation=e.hasAnimation,this.transformInfos.octreeTransformed=!1,this.transformInfos.boundingBox&&this.transformInfos.boundingBox.isBox3||(this.transformInfos.boundingBox=new He),this.transformInfos.boundingBox.expandByPoint(new Ke(e.minBoundary.x,e.minBoundary.y,e.minBoundary.z)),this.transformInfos.boundingBox.expandByPoint(new Ke(e.maxBoundary.x,e.maxBoundary.y,e.maxBoundary.z)),this.transformInfos.transformMatrix.fromArray(e.matrix||[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1]),e.transform&&Array.isArray(e.transform)){var t=(new yt).fromArray(e.transform||[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1]);this.transformInfos.transformMatrix.multiplyMatrices(this.transformInfos.transformMatrix,t)}this.transformInfos.originalMatrix.copy(this.transformInfos.transformMatrix),this.model.setModelMatrix(this.transformInfos.transformMatrix),this.transformInfos.transformMatrix.compose(this.transformInfos.position,this.transformInfos.rotation,this.transformInfos.scale),this.model.manager.updateScene()},_w.prototype._toStatistics=function(e){e.count={},e.count.texture_pixels&&e.count.texture_pixels>xd.MaxTexturePixels&&(xd.EnableTextureLoading=!1),void 0!==e.count&&(void 0!==e.count.mesh_face&&(this.statistics.numOfTriangles+=e.count.mesh_face),this.statistics.renderableTotal=0,this.statistics.renderableTotalForPool=0,void 0!==e.count.geom_box&&void 0!==e.count.geom_pipe&&void 0!==e.count.geom_tube&&void 0!==e.count.mesh?(this.statistics.renderableTotal+=e.count.geom_box,this.statistics.renderableTotal+=e.count.geom_pipe,this.statistics.renderableTotal+=e.count.geom_tube,this.statistics.renderableTotal+=e.count.mesh,this.statistics.renderableTotalForPool+=6*e.count.geom_box,this.statistics.renderableTotalForPool+=3*e.count.geom_pipe,this.statistics.renderableTotalForPool+=e.count.geom_tube,this.statistics.renderableTotalForPool+=e.count.mesh,this.statistics.numOfTriangles+=12*e.count.geom_box,this.statistics.numOfTriangles+=32*e.count.geom_pipe,this.statistics.numOfTriangles+=32*e.count.geom_tube):void 0!==e.count.geom&&void 0!==e.count.mesh&&(this.statistics.renderableTotal+=e.count.geom,this.statistics.renderableTotal+=e.count.mesh,this.statistics.numOfTriangles+=12*e.count.geom,this.statistics.numOfElements=this.statistics.renderableTotal,this.statistics.renderableTotalForPool=this.statistics.renderableTotal),void 0!==e.count.item&&(this.statistics.numOfElements=e.count.item)),this.statistics.memoeryInfo=this._computeApproximateMemoerySize(e)},_w.prototype._computeApproximateMemoerySize=function(e){var t=0,i=0,n=1/1048576,r=e.count.mesh_vertex||0,o=e.count.mesh_face||0,a=e.count.geom_box||0,s=e.count.geom_pipe||0,l=130,c=124,h=e.count.texture_pixels||0;i+=8*r,i+=3*o,i+=0,i+=0,t+=6*r,t+=3*o,t+=0,t+=0;var d=0;if(d+=o,a>0&&(d+=12*a),s>0&&(d+=c*s),d+=0,xd.Instance){a>0&&(i+=192,i+=36,i+=24*a,t+=144,t+=36,t+=18*a),s>0&&(i+=1040,i+=372,i+=24*s,t+=780,t+=372,t+=18*s)}else a>0&&(i+=24*a*8,i+=12*a*3,t+=24*a*6,t+=12*a*3),s>0&&(i+=s*l*8,i+=s*c*3,t+=s*l*6,t+=s*c*3);return xd.EnableTextureLoading&&(i+=4*h,t+=4*h),i*=4,t*=4,i*=n,t*=n,{maxMemoerySize:i=Math.ceil(i),minMemoerySize:t=Math.ceil(t),triangleNumber:d,instanceEnabled:xd.Instance}},_w.prototype.getMemoeryInfo=function(){return this.statistics.memoeryInfo},_w.prototype.getStatistics=function(){return this.statistics},_w.prototype.getConfig=function(){return this.config},_w.prototype.getTransforms=function(){return this.transformInfos},_w.prototype.setRenderableCount=function(e){this.statistics.renderableCount=e};var $w=function(e){Xy.call(this,e),this.descriptor=new Zy(e.model),this.fileKeyFromModelKey={}};($w.prototype=Object.assign($w.prototype,Xy.prototype)).loadData=function(){var e=this,t=this.model;this.modelDataVersion=t.configLoader.modelDataVersion,t.getConfig();var i=t.configLoader.scenes,n=[],r=[],o=[],a=[],s=[],l=[],c=[],h=[];e.maxLoadTaskCount=0,e.maxLoadTextureCount=0;for(var d=function(d){var u=i[d].scene,D=i[d].dataVersion,T=i[d].modelKey;if(!(u&&u.components&&u.geometries&&u.materials&&u.textures))return t.setEmptyScene(!0),Bu.error("scene is null,modelKey is ",T),t.dispatchEventEx({type:Fd.ON_LOAD_EMPTY_SCENE,modelKey:T}),{v:void 0};if(p=u.components.length||0,g=u.geometries.length||0,f=u.materials.length||0,m=u.textures.length||0,A=[],y=[],v=[],C=[],I=[],x=[],w=u.textures,M=[],py(D,"2.0.0"))A=u.components,y=u.geometries,v=u.materials;else{for(E=0;p>E;E+=1)u.components[E].fileKey?A.push(u.components[E].fileKey):t.dispatchEventEx({type:Qd.SCENE_NOT_CLOSE,modelKey:T});for(B=0;g>B;B+=1)u.geometries[B].fileKey?y.push(u.geometries[B].fileKey):t.dispatchEventEx({type:Qd.SCENE_NOT_CLOSE,modelKey:T});for(S=0;f>S;S+=1)u.materials[S].fileKey?v.push(u.materials[S].fileKey):t.dispatchEventEx({type:Qd.SCENE_NOT_CLOSE,modelKey:T})}if(u.trees.length>0)for(b=0;u.trees.length>b;b+=1)"partition"===(k=u.trees[b]).type&&M.push(k.fileKey);e.maxLoadTaskCount+=p,e.maxLoadTaskCount+=g,e.maxLoadTaskCount+=f,xd.EnableTextureLoading&&(e.maxLoadTextureCount+=m),e.maxLoadTaskCount+=0,e.maxLoadTaskCount+=0,e.maxLoadTaskCount+=0,e.maxLoadTaskCount+=M.length,A.forEach((function(t){e.fileKeyFromModelKey[t]=T})),y.forEach((function(t){e.fileKeyFromModelKey[t]=T})),v.forEach((function(t){e.fileKeyFromModelKey[t]=T})),C.forEach((function(t){e.fileKeyFromModelKey[t]=T})),I.forEach((function(t){e.fileKeyFromModelKey[t]=T})),x.forEach((function(t){e.fileKeyFromModelKey[t]=T})),w.forEach((function(t){e.fileKeyFromModelKey[t]=T})),M.forEach((function(t){e.fileKeyFromModelKey[t]=T})),n=n.concat(A),r=r.concat(y),o=o.concat(v),a=a.concat(C),s=s.concat(I),l=l.concat(x),c=c.concat(w),h=h.concat(M)},u=0;i.length>u;u+=1){var p,g,f,m,A,y,v,C,I,x,w,M,E,B,S,b,k,D=d(u);if("object"===nu(D))return D.v}if(e.progress.total+=e.maxLoadTaskCount,1>e.maxLoadTaskCount)return Bu.info("Nothing to load ",t.modelKey),void t.dispatchEventEx({type:Qd.SCENE_NOTHING_TO_LOAD,modelKey:t.modelKey});Bu.time("数据加载时间"),e._loadComponent(n),e._loadMaterial(o),xd.EnableTextureLoading&&e.maxLoadTextureCount.length>0?e._loadTextures(c):e._onLoadTexture(),e._loadTextures(c),e._loadKDTree(h),e._loadClips(s),e._loadBones(a),e._loadNodes(l),e.offLine&&e.loadAttribute(),e._loadGeo(r)},$w.prototype.loadSceneAndGeos=function(e){this._loadGeo(e)},$w.prototype._loadGeometrie=function(e){var t=this;if(xd.getDataFromIndexedDB&&!this.offLine){var i=this.url,n=[],r=[];n.push(r);for(var o=0,a=0;e.length>a;a+=1)50>o||(n.push(r=[]),o=0),o+=1,r.push(i.mpkUrl(e[a]));var s=this.model.getStorage();if(s)for(var l=function(i,r){var o=n[r];s.getBatch(o,(function(e){for(var i=function(i){if(-1===(r=o[i].indexOf("fileKey=")))return Bu.error("url is not has fileKey"),{v:void 0};var n=o[i].slice(r+8);if(e[o[i]])if(!0===e[o[i]].split){var l=e[o[i]].list,c=new Uint8Array(e[o[i]].length);s.getBatch(l,(function(e){for(var i=0;l.length>i;i+=1)e[l[i]]?c.set(new Uint8Array(e[l[i]]),4e7*i):Bu.error("获取分割几何失败");t._parseGeometrie(c.buffer,n),Bu.debug("load geo from local"),t._onTaskFinished()}),(function(){Bu.error("获取分割几何失败")}))}else t._parseGeometrie(e[o[i]],n),Bu.debug("load geo from local"),t._onTaskFinished();else{if(a=t.taskGeometrieManager,-1===o[i].indexOf("fileKey="))return Bu.error("url is not has fileKey"),{v:void 0};a.addTask(n),Bu.debug("load geo from net")}},n=0;o.length>n;n+=1){var r,a,l=i(n);if("object"===nu(l))return l.v}t.taskGeometrieManager.processTasks(t.loadGeometrie.bind(t))}),(function(){for(var i=t.taskGeometrieManager,n=0;e.length>n;n+=1)i.addTask(e[n]);i.processTasks(t.loadGeometrie.bind(t))}))},c=0,h=n.length;h>c;c+=1)l(0,c)}else{for(var d=this.taskGeometrieManager,u=0;e.length>u;u+=1)d.addTask(e[u]);d.processTasks(t.loadGeometrie.bind(t))}},$w.prototype._loadKDTree=function(e){var t=this;if(xd.getDataFromIndexedDB&&!this.offLine){var i=this.url,n=[],r=[];n.push(r);for(var o=0,a=0;e.length>a;a+=1)50>o||(n.push(r=[]),o=0),o+=1,r.push(i.mpkUrl(e[a]));var s=this.model.getStorage();if(s)for(var l=function(i,r){var o=n[r];s.getBatch(o,(function(e){for(var i=0;o.length>i;i+=1){var n=o[i].indexOf("fileKey=");if(-1===n)return void Bu.error("url is not has fileKey");var r=o[i].slice(n+8);if(e[o[i]])t._parseKDTree(e[o[i]],r),Bu.debug("load kdtree from local"),t._onTaskFinished();else{var a=t.taskComponentManager;if(-1===o[i].indexOf("fileKey="))return void Bu.error("url is not has fileKey");a.addTask(r),a.processTasks(t.loadKDTree.bind(t)),Bu.debug("load kdtree from net")}}}),(function(){for(var i=t.taskComponentManager,n=0;e.length>n;n+=1)i.addTask(e[n]);i.processTasks(t.loadKDTree.bind(t))}))},c=0,h=n.length;h>c;c+=1)l(0,c)}else{for(var d=this.taskComponentManager,u=0;e.length>u;u+=1)d.addTask(e[u]);d.processTasks(t.loadKDTree.bind(t))}},$w.prototype._loadBones=function(e){var t=this;if(xd.getDataFromIndexedDB&&!this.offLine){for(var i=this.url,n=[],r=0;e.length>r;r+=1)n.push(i.bonesUrl(e[r]));var o=this.model.getStorage();o&&o.getBatch(n,(function(e){for(var i=0;n.length>i;i+=1){var r=n[i].indexOf("fileKey=");if(-1===r)return void Bu.error("url is not has fileKey");var o=n[i].slice(r+8);if(e[n[i]])t._parseBones(e[n[i]],o),Bu.debug("load Bones from local"),t._onTaskFinished();else{if(-1===n[i].indexOf("fileKey="))return void Bu.error("url is not has fileKey");t.loadBones(n[i].slice(r+8),(function(){})),Bu.debug("load Bones from net")}}}),(function(){for(var i=0;e.length>i;i+=1)t.loadBones(e[i],(function(){}))}))}else{for(var a=this.taskComponentManager,s=0;e.length>s;s+=1)a.addTask(e[s]);a.processTasks(t.loadBones.bind(t))}},$w.prototype._loadClips=function(e){var t=this;if(xd.getDataFromIndexedDB&&!this.offLine){for(var i=this.url,n=[],r=0;e.length>r;r+=1)n.push(i.clipsUrl(e[r]));var o=this.model.getStorage();o&&o.getBatch(n,(function(e){for(var i=0;n.length>i;i+=1){var r=n[i].indexOf("fileKey=");if(-1===r)return void Bu.error("url is not has fileKey");var o=n[i].slice(r+8);if(e[n[i]])t._parseClips(e[n[i]],o),Bu.debug("load Clips from local"),t._onTaskFinished();else{if(-1===n[i].indexOf("fileKey="))return void Bu.error("url is not has fileKey");t.loadClips(n[i].slice(r+8),(function(){})),Bu.debug("load Clips from net")}}}),(function(){for(var i=0;e.length>i;i+=1)t.loadClips(e[i],(function(){}))}))}else{for(var a=this.taskComponentManager,s=0;e.length>s;s+=1)a.addTask(e[s]);a.processTasks(t.loadClips.bind(t))}},$w.prototype._loadNodes=function(e){var t=this;if(xd.getDataFromIndexedDB&&!this.offLine){for(var i=this.url,n=[],r=0;e.length>r;r+=1)n.push(i.nodesUrl(e[r]));var o=this.model.getStorage();o&&o.getBatch(n,(function(e){for(var i=0;n.length>i;i+=1){var r=n[i].indexOf("fileKey=");if(-1===r)return void Bu.error("url is not has fileKey");var o=n[i].slice(r+8);if(e[n[i]])t._parseNodes(e[n[i]],o),Bu.debug("load Nodes from local"),t._onTaskFinished();else{if(-1===n[i].indexOf("fileKey="))return void Bu.error("url is not has fileKey");t.loadNodes(n[i].slice(r+8),(function(){})),Bu.debug("load Nodes from net")}}}),(function(){for(var i=0;e.length>i;i+=1)t.loadNodes(e[i],(function(){}))}))}else{for(var a=this.taskComponentManager,s=0;e.length>s;s+=1)a.addTask(e[s]);a.processTasks(t.loadNodes.bind(t))}},$w.prototype._loadComponent=function(e){var t=this;if(xd.getDataFromIndexedDB&&!this.offLine){var i=this.url,n=[],r=[];n.push(r);for(var o=0,a=0;e.length>a;a+=1)50>o||(n.push(r=[]),o=0),o+=1,r.push(i.mpkUrl(e[a]));var s=this.model.getStorage();if(s)for(var l=function(i,r){var o=n[r];s.getBatch(o,(function(e){for(var i=0;o.length>i;i+=1){var n=o[i].indexOf("fileKey=");if(-1===n)return void Bu.error("url is not has fileKey");var r=o[i].slice(n+8);if(e[o[i]])t._parseComponent(e[o[i]],r),Bu.debug("load com from local"),t._onTaskFinished();else{var a=t.taskComponentManager;if(-1===o[i].indexOf("fileKey="))return void Bu.error("url is not has fileKey");a.addTask(r),a.processTasks(t.loadComponent.bind(t)),Bu.debug("load com from net")}}}),(function(){for(var i=t.taskComponentManager,n=0;e.length>n;n+=1)i.addTask(e[n]);i.processTasks(t.loadComponent.bind(t))}))},c=0,h=n.length;h>c;c+=1)l(0,c)}else{for(var d=this.taskComponentManager,u=0;e.length>u;u+=1)d.addTask(e[u]);d.processTasks(t.loadComponent.bind(t))}},$w.prototype._loadMaterial=function(e){var t=this;if(xd.getDataFromIndexedDB&&!this.offLine){for(var i=this.url,n=[],r=0;e.length>r;r+=1)n.push(i.mpkUrl(e[r]));var o=this.model.getStorage();o&&o.getBatch(n,(function(e){for(var i=0;n.length>i;i+=1){var r=n[i].indexOf("fileKey=");if(-1===r)return void Bu.error("url is not has fileKey");var o=n[i].slice(r+8);if(e[n[i]])t._parseMaterial(e[n[i]],o),Bu.debug("load mat from local"),t._onTaskFinished();else{var a=t.taskMaterialManager;if(-1===n[i].indexOf("fileKey="))return void Bu.error("url is not has fileKey");a.addTask(o),a.processTasks(t.loadMaterial.bind(t)),Bu.debug("load mat from net")}}}),(function(){for(var i=t.taskMaterialManager,n=0;e.length>n;n+=1)i.addTask(e[n]);i.processTasks(t.loadMaterial.bind(t))}))}else{for(var a=this.taskMaterialManager,s=0;e.length>s;s+=1)a.addTask(e[s]);a.processTasks(t.loadMaterial.bind(t))}},$w.prototype._loadTextures=function(e){var t=this.model.materialManager.textures,i=this;if(xd.getDataFromIndexedDB&&!this.offLine){for(var n=this.url,r=[],o=0;e.length>o;o+=1)r.push(n.mpkUrl(e[o]));var a=this.model.getStorage();a&&a.getBatch(r,(function(e){for(var n=0;r.length>n;n+=1)if(e[r[n]]){var o=r[n].indexOf("fileKey=");if(-1===o)return void Bu.error("url is not has fileKey");var a=r[n].slice(o+8),s=new Fe;Bu.debug("load tex from local"),t[a]=s;var l=document.createElement("img");s.wrapS=s.wrapT=g,l.onload=function(t){"string"!=typeof e[r[n]]&&window.URL.revokeObjectURL(l.src),i.model.textureNeedsUpdate=!0,i._onLoadTexture()},l.onerror=function(e){i.model.dispatchEventEx({type:Qd.LOAD_TEXTURE_ERROR})},l.src="string"==typeof e[r[n]]?e[r[n]]:window.URL.createObjectURL(e[r[n]]),s.image=l,s.needsUpdate=!0}else{var c=i.taskTexturesManager,h=r[n].indexOf("fileKey=");if(-1===h)return void Bu.error("url is not has fileKey");c.addTask(r[n].slice(h+8)),c.processTasks(i.loadTextures.bind(i)),Bu.debug("load tex from net")}}),(function(){for(var t=i.taskTexturesManager,n=0;e.length>n;n+=1)t.addTask(e[n]);t.processTasks(i.loadTextures.bind(i))}))}else{for(var s=this.taskTexturesManager,l=0;e.length>l;l+=1)s.addTask(e[l]);s.processTasks(i.loadTextures.bind(i))}},$w.prototype._parseGeometrie=function(e,t){var i=this.fileKeyFromModelKey[t]||"",n=new ky.GeometryReader(e,this.modelDataVersion[i]),r=this.descriptor;if(r){for(var o=n.geoCount,a=0;o>a;a+=1){var s=n.geomMap[a];void 0!==s.position&&void 0!==s.index&&void 0!==s.normal?r.cacheReferencedMeshBufferData(i+s.geoId,s):Bu.error("Error Geometry!")}n=null}},$w.prototype._parseMaterial=function(e,t){var i=this.descriptor;if(i){var n=new Dy(e,this.modelDataVersion[this.fileKeyFromModelKey[t]||""]);if(Array.isArray(n.materialMap)){var r=n.materialCount;if(0>r)return;for(var o=0;r>o;o+=1){var a=n.materialMap[o];i.cacheReferencedMeshMaterialData(a.matId,a)}}else for(var s in n.materialMap)i.cacheReferencedMeshMaterialData(s,n.materialMap[s]);n=null}},$w.prototype._parseComponent=function(e,t){if(e){var i=new wy(e),n=i.compArr.length,r=this.descriptor;if(r){for(var o=this.fileKeyFromModelKey[t]||"",a=0;n>a;a+=1){var s=i.compArr[a];-1!==s.geoId&&(s.geoId=o+s.geoId,-1!==s.matId&&(s.matId=o+s.matId),this.model.submodel[o]=this.model.submodel[o]||[],this.model.submodel[o].push(s.key)),r.cacheReferencedMeshComponentData(s.key,s)}i=null}}else Bu.error("没有数据")},$w.prototype._parseKDTree=function(e,t){var i={};if(i="string"==typeof e?JSON.parse(e):e,this.model.kdTreeNode=this.model.kdTreeNode||[],i){var n=new jy;n.init(i),this.model.kdTreeNode.push(n)}},$w.prototype._parseNodes=function(e,t){var i=this.descriptor;if(i){var n={};n="string"==typeof e?JSON.parse(e):e,Bu.debug("nodes",n),i.cacheReferencedMeshNodesData(n)}},$w.prototype._parseClips=function(e,t){var i=this.descriptor;if(i){var n={};n="string"==typeof e?JSON.parse(e):e,Bu.debug("clips",n),i.cacheReferencedMeshClipsData(n)}},$w.prototype._parseBones=function(e,t){var i=new ky.BoneReader(e),n=this.descriptor;if(n){for(var r=i.boneCount,o=0;r>o;o+=1){var a=i.boneMap[o];Bu.debug("bones",a),n.cacheReferencedMeshBoneBufferData(a.geoId,a)}i=null}},$w.prototype._loadComponent=function(e){var t=this;if(xd.getDataFromIndexedDB&&!this.offLine){var i=this.url,n=[],r=[];n.push(r);for(var o=0,a=0;e.length>a;a+=1)50>o||(n.push(r=[]),o=0),o+=1,r.push(i.mpkUrl(e[a]));var s=this.model.getStorage();if(s)for(var l=function(i,r){var o=n[r];s.getBatch(o,(function(e){for(var i=0;o.length>i;i+=1){var n=o[i].indexOf("fileKey=");if(-1===n)return void Bu.error("url is not has fileKey");var r=o[i].slice(n+8);if(e[o[i]])t._parseComponent(e[o[i]],r),Bu.debug("load com from local"),t._onTaskFinished();else{var a=t.taskComponentManager;if(-1===o[i].indexOf("fileKey="))return void Bu.error("url is not has fileKey");a.addTask(r),a.processTasks(t.loadComponent.bind(t)),Bu.debug("load com from net")}}}),(function(){for(var i=t.taskComponentManager,n=0;e.length>n;n+=1)i.addTask(e[n]);i.processTasks(t.loadComponent.bind(t))}))},c=0,h=n.length;h>c;c+=1)l(0,c)}else{for(var d=this.taskComponentManager,u=0;e.length>u;u+=1)d.addTask(e[u]);d.processTasks(t.loadComponent.bind(t))}},$w.prototype.loadGeometrie=function(e,t){var i=this,n=this.loader,r=this.url,o=this.model,a=xd.GeoWorkerUrl;xd.UseGeoWorker?(n.setResponseType("arraybuffer"),n.load(r.mpkUrl(e),(function(e){var n=new Worker(a);n.onmessage=function(e){var n=e.data;for(var r in n)n.hasOwnProperty(r);t(),i._onTaskFinished()},n.postMessage({msg:e})}))):(n.setResponseType("arraybuffer"),n.setCacheViable(!this.offLine),n.load(r.mpkUrl(e),(function(n){i._parseGeometrie(n,e,e),Bu.debug("geo load from online"),t(),i._onTaskFinished()}),void 0,(function(e){o.dispatchEventEx({type:Qd.LOAD_GEOMETRY_ERROR,modelKey:o.modelKey})})))},$w.prototype.loadMaterial=function(e,t){var i=this,n=this.loader,r=this.url,o=this.model,a=xd.GeoWorkerUrl;xd.UseGeoWorker?(n.setResponseType("arraybuffer"),n.load(r.mpkUrl(e),(function(e){var n=new Worker(a);n.onmessage=function(e){var n=e.data;for(var r in n)n.hasOwnProperty(r);t(),i._onTaskFinished()},n.postMessage({msg:e})}))):(n.setResponseType(i.modelDataVersion[i.fileKeyFromModelKey[e]||""]>1?"json":"arraybuffer"),n.setCacheViable(!this.offLine),n.load(r.mpkUrl(e),(function(n){i._parseMaterial(n,e),Bu.debug("met load from online"),t(),i._onTaskFinished()}),void 0,(function(e){o.dispatchEventEx({type:Qd.LOAD_MATERIAL_ERROR,modelKey:o.modelKey})})))},$w.prototype.loadTextures=function(e,t){var i=this.model.materialManager.textures,n=this,r=this.Textureloader,o=this.url,a=this.model,s=xd.GeoWorkerUrl;xd.UseGeoWorker?r.load(o.mpkUrl(e),(function(e){var i=new Worker(s);i.onmessage=function(e){var i=e.data;for(var r in i)i.hasOwnProperty(r);t(),n._onTaskFinished()},i.postMessage({msg:e})})):(r.setResponseType("blob"),r.setMimeType("text/plain"),r.setCacheViable(!this.offLine),r.load(o.textureUrl(e),(function(r){Bu.debug("tex load from online");var o=new Fe;i[e]=o,o.wrapS=o.wrapT=g;var s=document.createElement("img");s.onload=function(e){"string"!=typeof r&&window.URL.revokeObjectURL(s.src),t(),n.model.textureNeedsUpdate=!0,n._onLoadTexture()},s.onerror=function(e){a.dispatchEventEx({type:Qd.LOAD_TEXTURE_ERROR,modelKey:a.modelKey})},s.src="string"==typeof r?r:window.URL.createObjectURL(r),o.image=s,o.needsUpdate=!0}),void 0,(function(e){a.dispatchEventEx({type:Qd.LOAD_TEXTURE_ERROR,modelKey:a.modelKey})})))},$w.prototype.loadComponent=function(e,t){var i=this,n=this.jsonLoader,r=this.model,o=this.url,a=xd.GeoWorkerUrl;xd.UseGeoWorker?(n.setResponseType("json"),n.load(o.mpkUrl(e),(function(e){var n=new Worker(a);n.onmessage=function(e){var n=e.data;for(var r in n)n.hasOwnProperty(r);t(),i._onTaskFinished()},n.postMessage({msg:e})}),(function(e){}))):(n.setResponseType("json"),n.setCacheViable(!this.offLine),n.load(o.mpkUrl(e),(function(n){i._parseComponent(n,e),Bu.debug("component load from online"),t(),i._onTaskFinished()}),void 0,(function(e){r.dispatchEventEx({type:Qd.LOAD_COMPONENT_ERROR,modelKey:r.modelKey})})))},$w.prototype.loadKDTree=function(e,t){var i=this,n=this.loader,r=this.model,o=this.url,a=xd.GeoWorkerUrl;xd.UseGeoWorker?(n.setResponseType("json"),n.load(o.mpkUrl(e),(function(e){var n=new Worker(a);n.onmessage=function(e){var n=e.data;for(var r in n)n.hasOwnProperty(r);t(),i._onTaskFinished()},n.postMessage({msg:e})}),(function(e){}))):(n.setResponseType("json"),n.setCacheViable(!this.offLine),n.load(o.kdTreeUrl(e),(function(n){i._parseKDTree(n,e),Bu.debug("kdtree load from online"),t(),i._onTaskFinished()}),void 0,(function(e){r.dispatchEventEx({type:Qd.LOAD_COMPONENT_ERROR,modelKey:r.modelKey})})))},$w.prototype.loadBones=function(e,t){var i=this,n=this.loader,r=this.model,o=this.url,a=xd.GeoWorkerUrl;xd.UseGeoWorker?(n.setResponseType("arraybuffer"),n.load(o.bonesUrl(e),(function(e){var n=new Worker(a);n.onmessage=function(e){var n=e.data;for(var r in n)n.hasOwnProperty(r);t(),i._onTaskFinished()},n.postMessage({msg:e})}),(function(e){}))):(n.setResponseType("arraybuffer"),n.setCacheViable(!this.offLine),n.load(o.bonesUrl(e),(function(n){i._parseBones(n,e),Bu.debug("bones load from online"),t(),i._onTaskFinished()}),void 0,(function(e){r.dispatchEventEx({type:Qd.LOAD_COMPONENT_ERROR,modelKey:r.modelKey})})))},$w.prototype.loadClips=function(e,t){var i=this,n=this.loader,r=this.model,o=this.url,a=xd.GeoWorkerUrl;xd.UseGeoWorker?(n.setResponseType("json"),n.load(o.mpkUrl(e),(function(e){var n=new Worker(a);n.onmessage=function(e){var n=e.data;for(var r in n)n.hasOwnProperty(r);t(),i._onTaskFinished()},n.postMessage({msg:e})}),(function(e){}))):(n.setResponseType("json"),n.setCacheViable(!this.offLine),n.load(o.clipsUrl(e),(function(n){i._parseClips(n,e),Bu.debug("Clips load from online"),t(),i._onTaskFinished()}),void 0,(function(e){r.dispatchEventEx({type:Qd.LOAD_COMPONENT_ERROR,modelKey:r.modelKey})})))},$w.prototype.loadNodes=function(e,t){var i=this,n=this.loader,r=this.model,o=this.url,a=xd.GeoWorkerUrl;xd.UseGeoWorker?(n.setResponseType("json"),n.load(o.mpkUrl(e),(function(e){var n=new Worker(a);n.onmessage=function(e){var n=e.data;for(var r in n)n.hasOwnProperty(r);t(),i._onTaskFinished()},n.postMessage({msg:e})}),(function(e){}))):(n.setResponseType("json"),n.setCacheViable(!this.offLine),n.load(o.nodesUrl(e),(function(n){i._parseNodes(n,e),Bu.debug("Nodes load from online"),t(),i._onTaskFinished()}),void 0,(function(e){r.dispatchEventEx({type:Qd.LOAD_COMPONENT_ERROR,modelKey:r.modelKey})})))};var eM=function(e,t){_y.call(this,e),this.defaultManager=new Qv(t,e),this.instancedManager=new Kv(e),this.loader=new $w(this)};eM.prototype=Object.create(Vv.prototype);var tM=function(e){_w.call(this,e),this.modelDataVersion={}};(tM.prototype=Object.assign(tM.prototype,_w.prototype)).load=function(e){var t=this,i=this.model;this.config={};var n=i.dataUrl,r=function(r){var o={};if("string"==typeof r)try{o=JSON.parse(r)}catch(e){return i.setEmptyScene(!0),void i.dispatchEventEx({type:Fd.ON_LOAD_INVALID_SCENE,modelKey:i.modelKey})}else o=r;if(o&&"SUCCESS"===o.code){if(xd.offLine)t.model.getStorage().put(n.projectUrl(),o,t.model.modelKey,(function(){}),(function(){}));if(-1===Number(o.data.status))return void i.dispatchEventEx({type:Qd.PARSEFAILE,modelKey:i.modelKey});if(3>Number(o.data.status))return void i.dispatchEventEx({type:Qd.PARSING,modelKey:i.modelKey});t.dataVersion=o.data.profiles.geo||"1.0.0",n.apiVersion=o.data.profiles.api,t.model.dataVersion=t.dataVersion,t._parse(o.data),i.dispatchEventEx({type:Fd.ON_LOAD_CONFIG_FINISH,modelKey:i.modelKey}),e&&e()}else Bu.log(i.modelKey,"config load error! ",o.message),i.dispatchEventEx({type:Fd.ON_LOAD_ERROR,modelKey:i.modelKey,code:o.code,message:o.message})};if(xd.offLine){var o=this.model.getStorage();o&&o.getBatch([n.projectUrl()],(function(e){e[n.projectUrl()]?r(e[n.projectUrl()]):Yy({type:"GET",url:n.projectUrl(),headers:{Authorization:i.accessToken},success:r,error:function(e){i.dispatchEventEx({type:Fd.ON_NETWORK_ERROR,modelKey:i.modelKey,data:e})}})}),(function(){}))}else{for(var a=[],s=function(){var e=i.modelKeys[l];a.push(new Promise((function(t,r){Yy({type:"GET",url:n.projectUrl(e),headers:{Authorization:i.accessToken},success:function(i){t({modelKey:e,data:i})},error:function(t,n){switch(t){case 401:i.dispatchEventEx({type:Fd.ACCOUNT_NO_EXIST,modelKey:e,data:n});break;case 403:i.dispatchEventEx({type:Fd.NO_PERMISSION,modelKey:e,data:n});break;default:i.dispatchEventEx({type:Fd.ON_NETWORK_ERROR,modelKey:e,data:t})}r(t,n)}})})))},l=0;i.modelKeys.length>l;l+=1)s();Promise.all(a).then((function(r){for(var o=[],a=0,s={},l=0;r.length>l;l+=1)if(r[l]){var c=r[l].data,h=r[l].modelKey,d={};if("string"==typeof c)try{d=JSON.parse(c)}catch(e){return void i.dispatchEventEx({type:Fd.ON_LOAD_INVALID_SCENE,modelKey:h})}else d=c;if(d&&"SUCCESS"===d.code){if(xd.offLine)t.model.getStorage().put(n.projectUrl(),d,t.model.modelKey,(function(){}),(function(){}));var u=d.data.scene||null,p=d.data.profiles.geo||"1.0.0";if(n.apiVersion=d.data.profiles.api,o.push({scene:u,modelKey:d.data.key,dataVersion:p}),t.modelDataVersion[d.data.key]=p,s[p]=!0,a+=d.data.componentCount,-1===Number(d.data.status))return void i.dispatchEventEx({type:Qd.PARSEFAILE,modelKey:h});if(3>Number(d.data.status))return void i.dispatchEventEx({type:Qd.PARSING,modelKey:h});t.dataVersion=d.data.profiles.geo||"1.0.0",t.sceneReader=t.sceneReader||[],i.setConfig(d.data),t._parse(d.data)}else Bu.log(i.modelKey,"config load error! ",d.message),i.dispatchEventEx({type:Fd.ON_LOAD_ERROR,modelKey:h,code:d.code,message:d.message})}var g=new eM(i,!1);i._handler=g,t.model.componentCount=a,i.dispatchEventEx({type:Fd.ON_LOAD_CONFIG_FINISH,modelKey:i.modelKey}),t.scenes=o,e&&e()})).catch((function(e){console.log(e)}))}},tM.prototype._parse=function(e){this.config=e,e.lengthUnit&&(this.model.originalLengthUnit=e.lengthUnit),xd.MergeComponent=!0,this._toStatistics(e),this._setTransformInfos(e),this._chooseRendering(e)};var iM={};iM.brdf_vs=["varying vec2 vUV;","void main() {"," vUV = uv;"," gl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);","}"].join("\n"),iM.brdf_fs=["varying vec2 vUV;","uniform sampler2D HammersleyTable;","const float PI = 3.14159265358979;","float GGX(float NdotV, float alpha)","{"," float alpha2 = pow(alpha, 2.0);"," return 2.0 * NdotV / (NdotV + sqrt(alpha2 + (1.0 - alpha2) * NdotV * NdotV));","}","float G_Smith(float NdotV, float NdotL, float roughness)","{"," float alpha = pow(roughness, 2.0);"," return GGX(NdotV, alpha) * GGX(NdotL, alpha);","}","vec3 ImportanceSampleGGX(vec2 Xi, vec3 N, float roughness)","{"," float a = roughness * roughness;"," float Phi = 2.0 * PI * Xi.x; "," float CosTheta = sqrt((1.0 - Xi.y) / (1.0 + (a * a - 1.0) * Xi.y)); "," float SinTheta = sqrt(1.0 - CosTheta * CosTheta);"," vec3 H;"," H.x = SinTheta * cos(Phi); "," H.y = SinTheta * sin(Phi); "," H.z = CosTheta;"," vec3 UpVector = abs(N.z) < 0.999 ? vec3(0.0, 0.0, 1.0) : vec3(1.0, 0.0, 0.0); "," vec3 TangentX = normalize(cross(UpVector, N)); "," vec3 TangentY = cross(N, TangentX);"," return normalize(TangentX * H.x + TangentY * H.y + N * H.z);","}","vec2 IntegrateBRDF(float NdotV, float roughness)","{"," vec3 N = vec3(0.0, 0.0, 1.0);"," vec3 V = vec3(sqrt(1.0 - NdotV * NdotV), 0.0, NdotV);"," vec2 result = vec2(0.0, 0.0);"," const int NumSamples = 1024;"," for (int i = 0; i < NumSamples; i++)"," {"," float u = float(i) / float(NumSamples);"," vec2 Xi = vec2(u, texture2D(HammersleyTable, vec2(u)).r);"," vec3 H = ImportanceSampleGGX(Xi, N, roughness);"," vec3 L = 2.0 * dot(V, H) * H - V;"," float NdotL = saturate(L.z);"," float NdotH = saturate(H.z);"," float VdotH = saturate(dot(V, H));"," float NdotV = saturate(dot(N, V));"," if (NdotL > 0.0)"," {"," float G = G_Smith(NdotV, NdotL, roughness);"," float G_Vis = G * VdotH / (NdotH * NdotV); "," float F = pow(1.0 - VdotH, 5.0);"," result.x += (1.0 - F) * G_Vis;"," result.y += F * G_Vis;"," }"," }"," return result / float(NumSamples);","}","void main()","{"," vec2 brdf = IntegrateBRDF(vUV.x, vUV.y);"," gl_FragColor = vec4(brdf, 0.0, 1.0);","}"].join("\n"),iM.BRDFMap=function(e,t){this.texture=null,this.resolution=t||512,this.brdfMaterial=new cn({vertexShader:iM.brdf_vs,fragmentShader:iM.brdf_fs,uniforms:{HammersleyTable:{value:e}},lights:!1}),this.quad=new nn(new In(window.innerWidth,window.innerHeight),this.brdfMaterial),this.quad.position.z=-100},iM.BRDFMap.prototype.constructor=iM.BRDFMap,iM.BRDFMap.prototype.generateMap=function(e){var t=new Vo;t.add(this.quad);var i=new pc(window.innerWidth/-2,window.innerWidth/2,window.innerHeight/2,window.innerHeight/-2,-1e4,1e4);i.position.z=100;var n=new Oe(this.resolution,this.resolution,{minFilter:C,magFilter:A,format:k});e.setRenderTarget(n),e.clear(),e.render(t,i),this.texture=n.texture};var nM=function(){this.instanceMaterials={},this.materials={},this.textures={},this.lightmaps={},this.ensureImagePowerOfTwo=!1};nM.prototype.changeAllMaterials=function(e,t){},nM.prototype.destroy=function(){this.instanceMaterials={},this.materials={},this.textures={},this.lightmaps={}},nM.prototype.disposeInstanceMaterials=function(e){var t=this.instanceMaterials;for(var i in t){var n=t[i];if(Array.isArray(n))for(var r=0,o=n.length;o>r;r+=1)n[r].dispose();else n.dispose()}},nM.prototype.disposeMaterials=function(e){for(var t in this.materials)this.materials[t].dispose();this.disposeInstanceMaterials(e)},nM.prototype.updateMaterialsValue=function(e,t,i){var n=this.materials,r=this.instanceMaterials,o=null;for(var a in n)for(var a in(o=n[a])&&o[t]&&(o[t]=i,"function"==typeof o.refreshUniforms&&o.refreshUniforms(),o.needsUpdate=!0),r)if(o=r[a])if(Array.isArray(o))for(var s=0,l=o.length;l>s;s+=1)o[s][t]&&(o[s][t]=i,"function"==typeof o[s].refreshUniforms&&o[s].refreshUniforms(),o[s].needsUpdate=!0);else o[t]&&(o[t]=i,"function"==typeof o.refreshUniforms&&o.refreshUniforms(),o.needsUpdate=!0)},nM.prototype.enableColorWithoutLight=function(e){var t=this.materials,i=this.instanceMaterials,n=null;if(e){for(var r in t)(n=t[r])&&(n.defines.USE_COLORWITHOUTLIGHT="",n.needsUpdate=!0);for(var r in i)if(n=i[r])if(n instanceof Array)for(var o=0,a=n.length;a>o;o+=1)n[o].defines.USE_COLORWITHOUTLIGHT="",n[o].needsUpdate=!0;else n.defines.USE_COLORWITHOUTLIGHT="",n.needsUpdate=!0}else{for(var r in t)(n=t[r])&&(delete n.defines.USE_COLORWITHOUTLIGHT,n.needsUpdate=!0);for(var r in i)if(n=i[r])if(n instanceof Array)for(o=0,a=n.length;a>o;o+=1)delete n[o].defines.USE_COLORWITHOUTLIGHT,n[o].needsUpdate=!0;else delete n.defines.USE_COLORWITHOUTLIGHT,n.needsUpdate=!0}},nM.prototype._updateTextureMapping=function(e){var t=xd.EnableTextureMapping,i=this.ensureImagePowerOfTwo;function n(e,t){if(t){if(void 0===t.length)e.map=t;else for(var n=0;t.length>n;n+=1)i||(t[n].image=cA.ensurePowerOfTwo(t[n].image)),"map"===t[n].texturetype?e.map=t[n]:"bumpMap"===t[n].texturetype?t[n].depth&&(e.bumpScale=t[n].depth):"specularMap"===t[n].texturetype?e.specularMap=t[n]:"alphaMap"===t[n].texturetype?(e.alphaMap=t[n],e.alphaTest=.01,e.map=t[n],e.transparent=!0):"emissiveMap"===t[n].texturetype?e.emissiveMap=t[n]:"environmentMap"===t[n].texturetype?e.envMap=t[n]:"normalMap"===t[n].texturetype?(e.normalMap=t[n],t[n].depth&&e.normalScale.set(t[n].depth,t[n].depth)):Bu.warn("This map type is not supported yet:",t[n].texturetype);xd.IBL&&e.refreshUniforms(),e.needsUpdate=!0}else e.textureColor&&e.color.setStyle(e.textureColor),e.needsUpdate=!0}if(this.lastTextureEnabled!==t){var r=this.textures,o=this.materials;if(e)var a=e.manager.getMaterialOverrideSet(),s=a?a.materialsByName:null,l=a?a.textures:null;var c=this.instanceMaterials,h=null,d=null;if(t){for(h in o){if(d=o[h])n(d,u=r[h])}for(h in c)if(d=c[h]){var u=r[h];if(l&&l[h]&&(u=l[h]),Array.isArray(d))for(var p=0,g=d.length;g>p;p+=1)n(d[p],u);else n(d,u)}for(h in s){if(d=s[h])n(d,u=l[h.split("#")[0]])}this.ensureImagePowerOfTwo=!0}else{if(!a)for(h in o)(d=o[h])&&(d.map=null,d.needsUpdate=!0);for(h in c)if(d=c[h])if(Array.isArray(d))for(p=0,g=d.length;g>p;p+=1)d[p].pureColor&&(d[p].color.setStyle(d[p].pureColor),d[p].map=null,d[p].needsUpdate=!0),a||(d[p].map=null,d[p].needsUpdate=!0);else d.pureColor&&(d.color.setStyle(d.pureColor),d.map=null,d.needsUpdate=!0),a||(d.map=null,d.needsUpdate=!0);for(h in s)(d=s[h])&&(d.map=null,d.needsUpdate=!0,d.pureColor&&d.color.setStyle(d.pureColor))}this.lastTextureEnabled=t}},nM.prototype.updateMaterials=function(e){var t=this.materials;for(var i in t)if(t.hasOwnProperty(i)){var n=t[i];n.IBLMaps=e.manager.scene.IBLMaps,n.refreshUniforms()}},nM.prototype._updateIBL=function(e){var t=e.manager.scene;if(xd.IBL&&null!==t.iblProbe&&t.iblProbe.isComputed){this.materialManager.updateMaterials(e);var i=t.IBLcfg,n=i[Object.keys(i)[t.IBLIndex]];for(var r in n)this.materialManager.updateMaterialsValue(e,r,n[r])}},nM.prototype.changeAllMaterials=function(e,t){var i=this.materials;for(var n in i)if(i.hasOwnProperty(n)){var r=cA.getMaterialParameters(i[n]),o=null;t?(delete r.textureColor,delete r.pureColor,delete r.imageFade,r.lights=!0,(o=new iM.IBLMaterial(r)).type="IBL",o.refreshUniforms()):(delete r.iblProbe,(o=cA.createStandardMaterial(r)).roughness=r.originRoughness,o.metalness=r.originMetalness,o.refreshUniforms()),o.name=n,i[n]=o,r=null}},nM.prototype.switchNewStyleMaterial=function(e,t){var i=this.materials;for(var n in i)if(i.hasOwnProperty(n)){var r=cA.getMaterialParameters(i[n]),o=null;(o=t?cA.createNewStyleMaterial(r):cA.createStandardMaterial(r)).name=n,i[n]=o,r=null}},nM.prototype.getInstanceMaterialById=function(e,t){if(this.instanceMaterials[e])return this.instanceMaterials[e];var i=cA.getMaterialParameters(t.manager.getOverrideMaterialByName(e)||this.materials[e]),n=i.transparent,r=cA.createInstanceMaterial(i,!0);r.transparent=!1;var o=cA.createInstanceMaterial(i,!0);return o.transparent=!0,xd.TranslucentDepthDisabled&&(o.depthWrite=!1),n===r.transparent?(this.instanceMaterials[e]=[r,o],o.defines.INSTANCE_STATE_SECONDARY=""):(this.instanceMaterials[e]=[o,r],r.defines.INSTANCE_STATE_SECONDARY=""),this.instanceMaterials[e]},nM.prototype.getMaterialById=function(e){return this.materials[e]};var rM=function(e,t,i,n){var r=this;this.manager=e,this.modelKey=t.modelKey,this.projectKey=t.dbName,this.offLine=t.offLine,this.accessToken=t.token||"",this.shareKey=t.share||"",this.dataVersion=null,this.debut=n,this.dataUrl=new $C(t),this.submodel={},this.loadingManager=new xl,this.loadingManager.model=this,this.fileLoader=new xy(this.loadingManager),this.configLoader=new _w(this),this.firstOctreeTransform=!0,this.numOfElements=0,this.numOfTriangles=0,this.singleStepMode=!1,this.sizeOfNextStep=0,this.needUpdate=!1,this.boundingBoxWorld=null,this.rotation=new Ge,this.position=new Ke,this.scale=new Ke(1,1,1),this.transformMatrix=new yt,this.selectedMaterial=this.manager.sceneState.selectionMaterial,this.materialManager=new nM,this.wireframeManager=new UA,this.axisNetManager=void 0,this.floorManager=void 0,this.containsCamera=!1,this.loaded=!1,this.visible=!0,this.emptyScene=!1,this.cameraList=[],this.index=0,this.modelConfig=null,this.kdTreeNode=null,this.parseCfgFinish=void 0,this.progressPercentage={load:.4,collect:.5,merge:.1},this.progressFrequency=10,this._encodedDatabagId=this.modelKey,this.groupName=Vp.MODEL+"|"+this.modelKey,this.group=this.manager.scene.getOrCreateGroup(this.groupName,{pickableType:Rd.Geometry,globalSpace:!0}),this._handler=null,this.lightmap=!1,this.lightmapNum=0,this.enableLightmap=!1,this.lightmapIntensity=xd.LightmapIntensity,this.minDistanceObjects={},this.prioritizedNodeCount=0,this.plugins=[],this.merged=!1,t.modelKeys&&(this.modelGroup=!0,this.groupKey=t.modelKey,this.modelKeys=t.modelKeys,this.progressFrequency=100,this.merged=!0,this.configLoader=new tM(this)),this.subModel={},og.isSupportIndexedDB()?(this.storage=new _C({store:this.modelKey,version:1,dbName:this.modelKey}),this.storage.addEventListener(Fd.ON_DATABASE_OPEN,(function(e){i&&i(r,!0)})),this.storage.addEventListener(Fd.ON_DATABASE_EEEOR,(function(e){r.storage=void 0,i&&i(r,!1)}))):(r.storage=void 0,i&&i(this,!1)),this._viewerImpl=e.viewerImpl};Object.assign(rM.prototype,hg.prototype),rM.prototype.getStorage=function(){return this.storage},rM.prototype.destroy=function(){this.selectedMaterial=null,this.cameraList=null,this.occlusionCamera&&(this.occlusionCamera=null),this.panel&&this.panel.destroy(),this._removeMeshNodeGroup(),this.removeAllFromOctantMap(),this._handler&&(this._handler.destroy(),this._handler=null),this.wireframeManager.destroy(),this.wireframeManager=null,this.materialManager.disposeMaterials(this),this.materialManager.destroy(),this.materialManager=null,this.manager=null,this.plugins=null,this.dataUrl=null,this.fileLoader=null,this.configLoader.destroy(),this.configLoader=null},rM.prototype._getWireframeGroupName=function(){return Vp.WIREFRAME+"|"+this.modelKey},rM.prototype.load=function(e){var t=this;this.configLoader.load((function(){t.parseCfgFinish&&t.parseCfgFinish(),t.manager.updateScene(),t._getHandler().load(e)}))},rM.prototype.setCrossOrigin=function(e){this.fileLoader.setCrossOrigin(e)},rM.prototype.prepare=function(e,t){var i=this._getHandler();i&&i.prepare(e,t)},rM.prototype.dispatchEventEx=function(e){e.modelKey=this.modelKey,this.manager.dispatchEvent(e)},rM.prototype.setLoaded=function(e){this.loaded=e},rM.prototype.isLoaded=function(){return this.loaded},rM.prototype.getTransformMatrix=function(){return this.transformMatrix},rM.prototype.isEmptyScene=function(){return this.emptyScene},rM.prototype.setEmptyScene=function(e){this.emptyScene=e},rM.prototype.isLayerData=function(){return!(!this._handler||"layer"!==this._handler.tag)},rM.prototype.setConfig=function(e){this.configLoader.config=e},rM.prototype.getConfig=function(){return this.configLoader.config},rM.prototype.isVisible=function(){return this.manager.filter._isModelVisible(this.modelKey)},rM.prototype.setVisible=function(e){e?this.manager.filter.showModelByIds([this.modelKey]):this.manager.filter.hideModelByIds([this.modelKey])},rM.prototype.calculateCameraModelRelation=function(e){this.containsCamera=this.getModelDescriptor().isOctreeOuter(e)},rM.prototype.addCamera=function(e){this.cameraList.push(e)},rM.prototype.getCameraNameList=function(){for(var e=[],t=this.cameraList.length-1;t>=0;t-=1)e.push(this.cameraList[t].name);return e},rM.prototype.getCamera=function(e){for(var t=this.cameraList.length-1;t>=0;t-=1)if(this.cameraList[t].name===e)return this.cameraList[t];return null},rM.prototype.updateOctreeNode=function(e){if(e||this.firstOctreeTransform){this.firstOctreeTransform&&(this.firstOctreeTransform=!1);var t=this.manager.scene.getMatrixGlobal();this.getModelDescriptor().updateOctreeNode(t)}},rM.prototype.isDataReady=function(){var e=this._handler;return!!e&&e.isDataReady()},rM.prototype.updateMeshNodes=function(e){var t=this._getHandler();if(t){if("layer"===t.tag&&!t.layerDataLoaded)return;t.updateNodes()}},rM.prototype._getHandler=function(e){return this._handler},rM.prototype.getMeshesByUserIds=function(e){if(e){var t=this._getHandler();return t?t.getMeshesByUserIds(e):void 0}},rM.prototype.applyFilter=function(){if(!1!==this.manager.filter._isModelVisible(this.modelKey)){for(var e=0,t=this.plugins.length;t>e;e+=1)this.plugins[e].applyFilter();this.group.visible=!0;var i=this._getHandler();i&&i.applyFilter()}else this.group.visible=!1},rM.prototype.applySelection=function(){for(var e=0,t=this.plugins.length;t>e;e+=1)this.plugins[e].applySelection();var i=this._getHandler();i&&i.applySelection()},rM.prototype.clearSelection=function(){for(var e=0,t=this.plugins.length;t>e;e+=1)this.plugins[e].clearSelection();var i=this._getHandler();i&&i.clearSelection()},rM.prototype.applyHover=function(){for(var e=0,t=this.plugins.length;t>e;e+=1)this.plugins[e].applyHover();var i=this._getHandler();i&&i.applyHover()},rM.prototype.clearHover=function(){for(var e=0,t=this.plugins.length;t>e;e+=1)this.plugins[e].clearHover();var i=this._getHandler();i&&i.clearHover()},rM.prototype.applyBlink=function(){var e=this._getHandler();e&&e.applyBlink()},rM.prototype.clearBlink=function(){var e=this._getHandler();e&&e.clearBlink()},rM.prototype.applyReplacement=function(){var e=this._getHandler();e&&e.applyReplacement()},rM.prototype._removeMeshNodeGroup=function(){this._removeNodeGroup(Vp.GEOMETRY),this._removeNodeGroup(Vp.INSTANCEGEOMETRY),this._removeNodeGroup(Vp.WIREFRAME),this._removeNodeGroup(Vp.INSTANCEWIREFRAMEGEOMETRY),this._removeNodeGroup(Vp.AXISNET),this._removeSceneGroup(),this.group=null},rM.prototype._getNodeGroup=function(e,t){for(var i=this.group.children,n=0,r=i.length;r>n;n+=1)if(i[n].name===e)return i[n];var o=new cm(e,t);return this.group.add(o),o.globalSpace&&(o.matrixAutoUpdate=!1,o.updateMatrixWorld(!0)),o},rM.prototype._removeNodeGroup=function(e){this.group.removeByName(e)},rM.prototype._hasNodeGroup=function(e){return this.group.hasChild(e)},rM.prototype._removeSceneGroup=function(){this.manager.scene.removeGroupByName(this.groupName),this.manager.scene.removeGroupByName(this._getWireframeGroupName())},rM.prototype.removeAllFromOctantMap=function(){this.manager.removeAllFromOctantMap(this.modelKey)},rM.prototype.clearMeshFromOctantMap=function(){this.manager.removeMeshFromOctantMap(this.modelKey)},rM.prototype.getDatabagId=function(){return this.modelKey},rM.prototype.getEncodedDatabagId=function(){return this.modelKey},rM.prototype.getMaterialManager=function(){return this.materialManager},rM.prototype.clearWireframeElementCount=function(){this.wireframeElementCount=void 0},rM.prototype.getWireframeElementCount=function(){if(void 0!==this.wireframeElementCount)return this.wireframeElementCount;var e=this.getModelDescriptor().getAllNodeInfos(),t=this.manager.filter,i=0;for(var n in e){var r=e[n];t._hasRenderWithBoardlineFilter()&&!t._isRenderWithBoardline(r[0])||(i+=r.length)}return this.wireframeElementCount=i,i},rM.prototype.isActivateWireframe=function(){return this.manager.isDrawingBoardlineEnabled()},rM.prototype.isOnlyWireframe=function(){return this.manager.isOnlyWireframe()},rM.prototype.getLoadedUserIdsObject=function(){return this._handler&&this._handler.getLoadedUserIdsObject?this._handler.getLoadedUserIdsObject():null},rM.prototype.clearNodeGroup=function(){var e=this._getNodeGroup(Vp.GEOMETRY,{globalSpace:!0});e.clear(),(e=this._getNodeGroup(Vp.WIREFRAME,{globalSpace:!0})).clear(),(e=this._getNodeGroup(Vp.INSTANCEGEOMETRY,{globalSpace:!0})).clear(),(e=this._getNodeGroup(Vp.INSTANCEWIREFRAMEGEOMETRY,{globalSpace:!0})).clear()},rM.prototype.getWireframeMaterial=function(){return this.wireframeManager.wireframeMaterial},rM.prototype.getInstanceWireframeMaterial=function(){return this.wireframeManager.instanceWireframeMaterial},rM.prototype.getMaterialByMaterialId=function(e){return this.materialManager.materials[e]},rM.prototype.adjustProgressPercentage=function(e,t,i){this.progressPercentage.load=e,this.progressPercentage.collect=t,this.progressPercentage.merge=i},rM.prototype.setReplacedUserIdMap=function(e){this.replacedUserIdMap=wp.isOwnEmptyObject(e)?null:e},rM.prototype.hasReplacedUserId=function(){return!wp.isEmptyObject(this.replacedUserIdMap)},rM.prototype.isReplacedUserId=function(e){return this.replacedUserIdMap&&this.replacedUserIdMap[e]},rM.prototype.registerPlugin=function(e){this.plugins.push(e)},rM.prototype.disposeBufferAfterVbo=function(){var e=this._getHandler();e&&e.disposeBufferAfterVbo()},rM.prototype.isHiddenUserId=function(e){var t=this._getHandler();return!!t&&t.isHiddenNode(e)},rM.prototype.hasHiddenUserId=function(){return this.manager.hasHiddenUserId()},rM.prototype.isHiddenSourceObjectUserId=function(e){return this.manager.isHiddenSourceObjectUserId(e)},rM.prototype.hasHiddenSourceObjectUserId=function(){return this.manager.hasHiddenSourceObjectUserId()},rM.prototype.getModelDescriptor=function(){return this._handler.loader.getDescriptor()},rM.prototype.getLoader=function(){return this._handler.loader},rM.prototype.getConfig=function(){return this.configLoader.getConfig()},rM.prototype.getTransforms=function(){return this.configLoader.getTransforms()},rM.prototype.getStatistics=function(){return this.configLoader.getStatistics()},rM.prototype.setRenderableCount=function(e){this.configLoader.setRenderableCount(e),this._handler&&this._handler.clearPriorityNodesSet&&this._handler.clearPriorityNodesSet(!0)},rM.prototype.getRenderableCount=function(){return this.configLoader.getStatistics().renderableCount},rM.prototype.getBoundingBoxWorld=function(){return this.configLoader.getTransforms().boundingBox},rM.prototype.calculateBoundingBox=function(){var e=this.getModelDescriptor().getAllNodeInfos(),t=new He;for(var i in e)for(var n=e[i],r=0,o=n.length;o>r;r+=1){var a=n[r];a.boundingBox&&t.union(a.boundingBox)}var s=this.getModelMatrix();s&&t.applyMatrix4(s),this.configLoader.getTransforms().boundingBox.copy(t)},rM.prototype.calculateClippingIds=function(){var e=this._getHandler();e&&e.calculateClippingIds()},rM.prototype.explode=function(e){var t=this.getBoundingBoxWorld().getCenter(),i=this._getHandler();i&&i.explode(t,e)},rM.prototype.formatLayerIds=function(e){return this.getLayerProvider().formatLayerIds(e)},rM.prototype.getBoundingBoxOfGeometries=function(e){for(var t=!e,i=new He,n=0;e.length>n;n+=1){var r=this.group.getObjectByProperty("guid",e[n]);if(r){var o=r.geometry;if(o){if(t||o){o.boundingBox||o.computeBoundingBox();var a=o.boundingBox;if(a){var s=a.clone();r.matrixWorld&&s.applyMatrix4(r.matrixWorld),i.expandByPoint(s.min),i.expandByPoint(s.max)}}}else Bu.log("empty geometry!")}}return i},rM.prototype.setModelMatrix=function(e){this.group.matrix.copy(e),this.group.updateMatrixWorld(!0);var t=this.configLoader.transformInfos;t&&t.boundingBox&&(t.transformMatrix.copy(e),t.originalBoundingBox?this.calculateBoundingBox():(t.originalBoundingBox=t.boundingBox.clone(),t.boundingBox.applyMatrix4(e))),this.manager.updateSceneBoundingBox()},rM.prototype.applyModelMatrix=function(e){var t=this.configLoader.transformInfos;t&&t.boundingBox&&(t.transformMatrix.premultiply(e),t.originalBoundingBox||(t.originalBoundingBox=t.boundingBox.clone()),t.boundingBox.applyMatrix4(e)),this.group.matrix.copy(t.transformMatrix),this.group.updateMatrixWorld(!0),this.manager.updateSceneBoundingBox()},rM.prototype.getModelMatrix=function(){var e=null;return this.group.matrix&&(e=this.group.matrix.clone()),e},rM.prototype.resetModelMatrix=function(){var e=this.configLoader.transformInfos.originalMatrix;e&&this.setModelMatrix(e)},rM.prototype.overturnYAndZaxis=function(){var e=(new yt).makeRotationFromEuler(new bt(Math.PI/2,0,0));this.group.matrix&&(e.multiply(this.group.matrix),this.setModelMatrix(e))},rM.prototype.hasComponent=function(e){return!!this.getModelDescriptor().getNodeInfosByUserId(e)},rM.prototype.getComponentInfo=function(e){return this.getModelDescriptor().getNodeInfosByComponentKey(e)},rM.prototype.getComponentlist=function(){var e=[],t=this.getModelDescriptor();for(var i in t.mapNodeInfoByComponentKey)t.mapNodeInfoByComponentKey.hasOwnProperty(i)&&e.push(i);return e},rM.prototype.addMeshToInfoMap=function(e,t,i,n,r){this.getModelDescriptor().addMeshToInfoMap(e,t,i,n,r)},rM.prototype.loadGeopkOnDemand=function(e,t,i){this._handler&&"layer"===this._handler.tag&&this._handler.loadGeopkOnDemand(e,t,i)},rM.prototype.unloadGeopkOnDemand=function(e,t){this._handler&&"layer"===this._handler.tag&&this._handler.unloadComponents(e,t)},rM.prototype.loadAllGeosOnDemand=function(e,t,i){this._handler&&"layer"===this._handler.tag&&this._handler.loadAllGeosOnDemand(e,t,i)},rM.prototype.getUnionBoundingBoxOnDemand=function(){return this.getLayerProvider().getUnionBoundingBoxOnDemand()},rM.prototype.setConditionsChangedOnDemand=function(e){this.getLayerProvider().setConditionsChanged(e)},rM.prototype.explosion=function(e){var t=this._getHandler();Bu.time("模型离散用时"),t&&(this.explosioning=!0,t.explosion(e)),Bu.timeEnd("模型离散用时"),this.calculateBoundingBox()},rM.prototype.closeExplosion=function(){Bu.time("取消模型离散用时");var e=this._getHandler();e&&(e.closeExplosion(),this.explosioning=!1),Bu.timeEnd("取消模型离散用时")},rM.prototype.componentsExplosion=function(e){var t=this._getHandler();if(1===(e.coefficientX||1)&&1===(e.coefficientY||1)&&1===(e.coefficientZ||1)&&0===(e.offsetX||0)&&0===(e.offsetY||0)&&0===(e.offsetZ||0))return this.explosioning=!1,this.closeComponentsExplosion(e.componentKey),void this.calculateBoundingBox();Bu.time("构件离散用时"),t&&(this.explosioning=!0,t.componentsExplosion(e),this.calculateBoundingBox()),Bu.timeEnd("构件离散用时")},rM.prototype.closeComponentsExplosion=function(e){Bu.time("取消构件离散用时");var t=this._getHandler();t&&(t.closeComponentsExplosion(e),this.explosioning=!1),Bu.timeEnd("取消构件离散用时")},rM.prototype.floorExplosion=function(e){if(this.floorManager){var t=this.floorManager.floorExplosionInfo;this.explosioning=!0;var i=this._getHandler();if(!i)return!1;if(!t.sortedFloors){for(var n=[],r=0,o=t.floors.length;o>r;r+=1){var a=t.floors[r],s=this.manager.getBoundingBoxByIds(a.componentkeys);if(!s.isEmpty()){a.box=s;var l=new Ke;a.box.getCenter(l),a.center=l,n.push(a)}}n.sort((function(e,t){return e.center.z-t.center.z})),t.sortedFloors=n;for(var c=0,h=1/0,d=0,u=0,p=n.length;p>u;u+=1){var g=Math.abs(n[u].center.z);h>g&&(c=u,h=g);var f=new Ke;n[u].box.getSize(f),d+=f.z}t.baseFloorIndex=c,t.averageHeight=d/n.length;var m=n[c].center.toArray();t.center=m}for(var A=(e-1)*t.averageHeight,y=0,v=t.sortedFloors.length;v>y;y+=1){if(y!==t.baseFloorIndex)i.componentsExplosion({offsetZ:(y-t.baseFloorIndex)*A,componentKey:t.sortedFloors[y].componentkeys,center:t.center})}return this.calculateBoundingBox(),!0}return!1},rM.prototype.closeFloorExplosion=function(){if(this.floorManager){var e=this.floorManager.floorExplosionInfo;if(e&&e.sortedFloors){var t=this._getHandler();if(t){for(var i=0,n=e.sortedFloors.length;n>i;i+=1){t.closeComponentsExplosion(e.sortedFloors[i].componentkeys)}this.calculateBoundingBox(),this.explosioning=!1}}}},rM.prototype.showModel=function(e){this.nodes.visible=e},rM.prototype.updateMaterials=function(){var e=this.materials;for(var t in e)if(e.hasOwnProperty(t)){var i=e[t];i.IBLMaps=this.manager.scene.IBLMaps,i.refreshUniforms()}},rM.prototype.updateMaterialsValue=function(e,t){var i=this.materials;for(var n in i)if(i.hasOwnProperty(n)){var r=i[n];r.hasOwnProperty(e)&&(r[e]=t,r.refreshUniforms(),r.needsUpdate=!0)}},rM.prototype.changeAllMaterials=function(e){var t=this.materials;for(var i in t)if(t.hasOwnProperty(i)){var n=cA.getMaterialParameters(t[i]),r=null;e?(delete n.textureColor,delete n.pureColor,delete n.imageFade,n.lights=!0,(r=new iM.IBLMaterial(n)).type="IBL",r.refreshUniforms()):(delete n.iblProbe,(r=cA.createStandardMaterial(n)).roughness=n.originRoughness,r.metalness=n.originMetalness,r.refreshUniforms()),r.name=i,t[i]=r,n=null}},rM.prototype.getAllComponents=function(){return this.getComponentlist()},rM.prototype.getComponentKeysByTypeFromList=function(e,t){for(var i=this.getModelDescriptor(),n=[],r=0;e.length>r;r+=1)i.mapNodeInfoByComponentKey.hasOwnProperty(e[r])&&i.mapNodeInfoByComponentKey[e[r]][0].type===t&&n.push(e[r]);return n},rM.prototype.getComponentKeysByType=function(e){var t=this.getModelDescriptor(),i=[];for(var n in t.mapNodeInfoByComponentKey)t.mapNodeInfoByComponentKey.hasOwnProperty(n)&&t.mapNodeInfoByComponentKey[n][0].type===e&&i.push(n);return i},rM.prototype.getAllComponentKeyType=function(){var e={},t=[],i=this.getModelDescriptor();for(var n in i.mapNodeInfoByComponentKey)if(i.mapNodeInfoByComponentKey.hasOwnProperty(n)){var r=i.mapNodeInfoByComponentKey[n][0].type;e[r]||(e[r]=!0,t.push(r))}return t},rM.prototype.getComponentKeysByName=function(e){var t=this.getModelDescriptor(),i=[];for(var n in t.mapNodeInfoByComponentKey)t.mapNodeInfoByComponentKey.hasOwnProperty(n)&&t.mapNodeInfoByComponentKey[n][0].name===e&&i.push(n);return i},rM.prototype.getComponentKeysByProperty=function(e,t){var i=this.getModelDescriptor(),n=[];for(var r in i.mapNodeInfoByComponentKey)i.mapNodeInfoByComponentKey.hasOwnProperty(r)&&i.mapNodeInfoByComponentKey[r][0][e]===t&&n.push(r);return n},rM.prototype._getLayerHandler=function(){return this._layerHandler},rM.prototype.prepareData=function(){var e=this;this.materialManager._updateTextureMapping(),this.materialManager._updateIBL(this);var t=this._getHandler();t&&t.prepareData((function(){e.loaded=!0,e.hasAnimation&&xd.EnableAnimation&&e.createPanel(),e.debut(e)}))},rM.prototype.isUserIdExist=function(e){return!!this.getModelDescriptor().getNodeInfosByUserId(e)},rM.prototype.getNodeInfosByUserId=function(e){return this.getModelDescriptor().getNodeInfosByUserId(e)},rM.prototype.getNodeInfos=function(){return this.getModelDescriptor().getNodeInfosWithUserId()},rM.prototype.getFilter=function(){return this.manager.filter},rM.prototype.getOctreeRoots=function(e){this.getModelDescriptor().getOctreeRoots(e)},rM.prototype.getPickingMeshes=function(e,t,i,n){this._dealNonInstancedNodesForPicking(e,t,i,n),this._dealInstancedNodesForPicking(e,t,i,n),this._dealPluginNodesForPicking(e,t,i,n)},rM.prototype._dealNonInstancedNodesForPicking=function(e,t,i,n){if(this._handler){var r=this._handler.defaultManager;if(r.hasNodeInfo(this)){var o=r.getMeshManager().getPickingNodeGenerator().updatePickingMeshes(e.selectedMaterial,i,n);o&&t.meshes.push(o);var a=r.getWireFrameManager().getPickingNodeGenerator().updatePickingMeshes(e.wireframeMaterial,i,n);a&&t.meshes.push(a)}}},rM.prototype._dealInstancedNodesForPicking=function(e,t,i,n){if(this._handler){var r=this._handler.instancedManager;if(r.hasNodeInfo(this)){var o=r.getMeshManager().getPickingNodeGenerator().updatePickingMeshes(e.instancedSelectedMaterial,i,n);o&&t.meshes.push(o);var a=r.getWireFrameManager().getPickingNodeGenerator().updatePickingMeshes(e.instancedWireFrameMaterial,i,n);a&&t.meshes.push(a)}}},rM.prototype._dealPluginNodesForPicking=function(e,t,i,n){if(this._handler)for(var r=this.plugins,o=0,a=r.length;a>o;o+=1){var s=r[o].getPickingNodeGenerator().updatePickingMeshes(e.selectedMaterial,i,n);s&&t.meshes.push(s)}},rM.prototype.onWSWorkerMessage=function(){},rM.prototype.onPDWorkerMessage=function(){},rM.prototype._overrideOcclusionMaterial=function(e){var t=e.material;if(t&&!1===t.transparent){var i=this.manager.acquireMaterial(),n=i.material;t.color?n.color.copy(t.color):i.resetColor(),n.opacity=xd.OcclusionOpacity,e.material=n,e.material.needsUpdate=!0}},rM.prototype.showSkeleton=function(e){this.skeleton.visible=e},rM.prototype.deactivateAllActions=function(){this.needUpdate=!1,this.actions.forEach((function(e){e.stop()}))},rM.prototype.activateAllActions=function(){this.needUpdate=!0;for(var e=0;this.actions.length>e;e+=1)this.setWeight(this.actions[e],0===e?1:0);this.actions.forEach((function(e){e.play()}))},rM.prototype.pauseAllActions=function(){this.needUpdate=!1,this.actions.forEach((function(e){e.paused=!0}))},rM.prototype.toSingleStepMode=function(){this.unPauseAllActions(),this.singleStepMode=!0,this.sizeOfNextStep=this.settings["调整步长"]},rM.prototype.pauseContinue=function(){this.singleStepMode?(this.singleStepMode=!1,this.unPauseAllActions()):this.paused?(this.paused=!1,this.unPauseAllActions()):(this.paused=!0,this.pauseAllActions())},rM.prototype.unPauseAllActions=function(){this.needUpdate=!0,this.actions.forEach((function(e){e.paused=!1}))},rM.prototype.setWeight=function(e,t){e.enabled=!0,e.setEffectiveTimeScale(1),e.setEffectiveWeight(t)},rM.prototype.modifyTimeScale=function(e){this.mixer.timeScale=e},rM.prototype.createPanel=function(){var e=this,t=new XC({width:300}),i=t.addFolder(this.modelKey),n=i.addFolder("可见性"),r=i.addFolder("激活/失活"),o=i.addFolder("暂停/步进"),a=i.addFolder("混合权重"),s=i.addFolder("综合速度");this.settings={"显示模型":!0,"显示骨骼":!1,"关闭全部动画":this.deactivateAllActions.bind(e),"激活所有动画":this.activateAllActions.bind(e),"暂停/继续":this.pauseContinue.bind(e),"单步动画":this.toSingleStepMode.bind(e),"调整步长":.05,"使用默认持续时间":!0,"设置自定义持续时间":3.5,"modify idle weight":0,"modify walk weight":1,"modify run weight":0,"修改时间尺度":1};var l=this.settings;n.add(l,"显示模型").onChange(this.showModel.bind(e)),n.add(l,"显示骨骼").onChange(this.showSkeleton.bind(e)),r.add(l,"关闭全部动画"),r.add(l,"激活所有动画"),o.add(l,"暂停/继续"),o.add(l,"单步动画"),o.add(l,"调整步长",.01,.1,.001);for(var c=this.actions,h=function(t){var i=c[t]._clip.name;l[i]=0===t?1:0,a.add(l,i,0,1,.01).listen().onChange((function(i){e.setWeight(c[t],i)}))},d=0;c.length>d;d+=1)h(d);s.add(l,"修改时间尺度",0,10,.01).onChange(this.modifyTimeScale.bind(e)),n.open(),r.open(),o.open(),a.open(),s.open(),this.panel=t},rM.prototype.getTransformGroup=function(){return this.transformGroup||(this.transformGroup=this.manager.scene.getOrCreateGroup(Vp.TRANSFORM),this.group.add(this.transformGroup),this.transformGroup.updateMatrixWorld(!0)),this.transformGroup},rM.prototype.getComponentKeysBySubmodelKey=function(e){return this.submodel[e]||[]},rM.prototype.getTrianglesCount=function(){var e=0,t=0,i=0,n=0,r={};return this.group.traverse((function(o){if(o.isInstancedMeshEx&&o.multiCounts){for(var a=o.geometry,s=a.groups,l=0;s.length>l;l++){var c=s[l].count*o.multiCounts[l];t+=c,e+=3*c}var h=a.getAttribute("position").count;i+=h,n+=a.index.count/3}else if(o.isMesh){var d=o.geometry,u=d.getAttribute("position").count,p=d.index.count/3,g=d.getAttribute("vState");r[d.id]||(i+=u,n+=p,r[d.id]=!0),g&&(u*=g.count,p*=g.count),e+=u,t+=p}})),r=null,{positionsCount:e,trianglesCount:t,realPositionCount:i,realTrianglesCount:n}},rM.prototype._computeApproximateMemoerySize=function(){var e={},t=0,i=1/1048576,n=0,r=0,o=0;this.group.traverse((function(i){if(i.isMesh){var a=i.geometry,s=a.getAttribute("position").count,l=a.index.count/3,c=a.getAttribute("vState"),h=a.getAttribute("uv"),d=a.getAttribute("uv2");if(!e[a.id]){e[a.id]=!0;var u=6*s;h&&(u+=2*s),d&&(u+=2*s),t+=u+=3*l,u>o&&(o=u),c&&(n+=u*c.count,t+=19*s)}for(var p=0,g=i.material.length;g>p;p+=1){var f=i.material[0],m=void 0;f.map&&(m=f.map).image&&(m.image instanceof HTMLCanvasElement||m.image instanceof HTMLImageElement)&&(r+=m.image.height*m.image.width*3),f.bumpMap&&(m=f.bumpMap).image&&(m.image instanceof HTMLCanvasElement||m.image instanceof HTMLImageElement)&&(r+=m.image.height*m.image.width*3),f.aoMap&&(m=f.aoMap).image&&(m.image instanceof HTMLCanvasElement||m.image instanceof HTMLImageElement)&&(r+=m.image.height*m.image.width*3),f.normalMap&&(m=f.normalMap).image&&(m.image instanceof HTMLCanvasElement||m.image instanceof HTMLImageElement)&&(r+=m.image.height*m.image.width*3),f.alphaMap&&(m=f.alphaMap).image&&(m.image instanceof HTMLCanvasElement||m.image instanceof HTMLImageElement)&&(r+=m.image.height*m.image.width*3),f.envMap&&(m=f.envMap).image&&(m.image instanceof HTMLCanvasElement||m.image instanceof HTMLImageElement)&&(r+=m.image.height*m.image.width*3),f.lightMap&&(m=f.lightMap).image&&(m.image instanceof HTMLCanvasElement||m.image instanceof HTMLImageElement)&&(r+=m.image.height*m.image.width*3),f.emissiveMap&&(m=f.emissiveMap).image&&(m.image instanceof HTMLCanvasElement||m.image instanceof HTMLImageElement)&&(r+=m.image.height*m.image.width*3),f.specularMap&&(m=f.specularMap).image&&(m.image instanceof HTMLCanvasElement||m.image instanceof HTMLImageElement)&&(r+=m.image.height*m.image.width*3)}}else if(i.isLineSegments){var A=i.geometry;if(A&&"Geometry"!==A.type){var y=A.getAttribute("position").count,v=A.getAttribute("vState");t+=3*y,v&&(t+=13*y)}}}));var a=[],s=0;for(var l in this.materialManager.textures){var c=this.materialManager.textures[l];c.image&&(c.image instanceof HTMLCanvasElement||c.image instanceof HTMLImageElement)&&(a.hasValue(c.image)||(a.push(c.image),s+=c.image.height*c.image.width*3))}a=null,console.log("贴图内存",s*i,"MB"),console.log("实例化显存",4*n*i,"MB"),console.log("实例化单次最大显存",4*o*i,"MB"),console.log("贴图显存",r*i,"MB"),t*=4,t*=i,t+=s*i,t=Math.ceil(t),console.log(t+"MB")},rM.prototype.addLights=function(e){this.lightGroup=this.lightGroup||new To,this.group.add(this.lightGroup),this.lightGroup.visible=!1;for(var t=0,i=e.length;i>t;t+=1)this.lightGroup.add(e[t]),e[t].updateMatrixWorld()},rM.prototype.hasLights=function(){return this.lightGroup&&this.lightGroup.children.length>0},rM.prototype.enabledLights=function(){this.lightGroup.visible=!0},rM.prototype.disabledLights=function(){this.lightGroup.visible=!1},rM.prototype.getMapNodeInfoByComponentKey=function(e){return this.descriptor.mapNodeInfoByComponentKey[e]},rM.prototype.componentApplyMatrix=function(e,t){this._handler&&this._handler.componentApplyMatrix(e,t)},rM.prototype.setComponentMatrix=function(e,t){this._handler&&this._handler.setComponentMatrix(e,t)},rM.prototype.resetComponentMatrix=function(e){this._handler&&this._handler.resetComponentMatrix(e)},Object.defineProperties(rM.prototype,{modelConfig:{get:function(){return Bu.warn("BOS3D.Model: .modelConfig 现在为 .getConfig()"),this.getConfig()},set:function(e){this.setConfig(e)}},loader:{get:function(){return this._getHandler().loader}},descriptor:{get:function(){return this.getModelDescriptor()}}});var oM={getBoxFromTileBoundingVolumeBox:function(e){var t=new He,i=(new Ke).fromArray(e,0),n=new Ke;return n.fromArray(e,3),n.add(i),t.expandByPoint(n),n.fromArray(e,6),n.add(i),t.expandByPoint(n),n.fromArray(e,9),n.add(i),t.expandByPoint(n),t},getSphereFromTileBoundingVolumeSphere:function(e){var t=(new Ke).fromArray(e,0);return new ct(t,e[3]||0)},getTransfrom:function(e){return Array.isArray(e)?(new yt).fromArray(e):new yt},getSSE:function(e){var t=this.getBoxByComponentsKey(e),i=this.viewerImpl.camera,n=t.getCenter(new Ke),r=t.getSize().length(),o=this.viewerImpl.getRenderer().domElement.width,a=i.fov;return r*o/(2*i.position.clone().sub(n).length()*Math.tan(a/2))}},aM=function(e){_w.call(this,e)};function sM(e,t,i){if(0>t)throw new Error("byteOffset cannot be negative.");if(0>i)throw new Error("byteLength cannot be negative.");if(t+i>e.byteLength)throw new Error("sub-region exceeds array bounds.");return e=e.subarray(t=t||0,t+(i=i||e.byteLength-t)),sM.decode(e)}function lM(e,t,i){return e>=t&&i>=e}(aM.prototype=Object.create(_w.prototype)).load=function(e){var t=this,i=this.model,n=i.dataUrl;Yy({type:"GET",url:n.rootTilesUrl(),headers:{Authorization:i.accessToken},success:function(r){var o={};if("string"==typeof r)try{o=JSON.parse(r)}catch(e){return i.setEmptyScene(!0),void i.dispatchEventEx({type:Fd.ON_LOAD_INVALID_SCENE,modelKey:i.modelKey})}else o=r;if(o){if(xd.offLine)t.model.getStorage().put(n.projectUrl(),o,t.model.modelKey,(function(){}),(function(){}));t._parse(o),i.dispatchEventEx({type:Fd.ON_LOAD_CONFIG_FINISH,modelKey:i.modelKey}),e&&e()}else Bu.log(i.modelKey,"config load error! ",o.message),i.dispatchEventEx({type:Fd.ON_LOAD_ERROR,modelKey:i.modelKey,code:o.code,message:o.message})},error:function(e,t){switch(e){case 401:i.dispatchEventEx({type:Fd.ACCOUNT_NO_EXIST,modelKey:i.modelKey,data:t});break;case 403:i.dispatchEventEx({type:Fd.NO_PERMISSION,modelKey:i.modelKey,data:t});break;default:i.dispatchEventEx({type:Fd.ON_NETWORK_ERROR,modelKey:i.modelKey,data:e})}}})},aM.prototype._parse=function(e){this.config=e,e.lengthUnit&&(this.model.originalLengthUnit=e.lengthUnit||"m"),this._toStatistics(e),this._setTransformInfos(e),this._chooseRendering(e)},aM.prototype._setTransformInfos=function(e){this.model.hasAnimation=!1,this.transformInfos.octreeTransformed=!1,this.transformInfos.boundingBox&&this.transformInfos.boundingBox.isBox3||(this.transformInfos.boundingBox=oM.getBoxFromTileBoundingVolumeBox(e.root.boundingVolume.box)),this.transformInfos.transformMatrix.compose(this.transformInfos.position,this.transformInfos.rotation,this.transformInfos.scale),this.transformInfos.transformMatrix.fromArray(e.matrix||[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1]),this.model.setModelMatrix(this.transformInfos.transformMatrix),this.model.manager.updateScene()},sM.decodeWithTextDecoder=function(e){return new TextDecoder("utf-8").decode(e)},sM.decodeWithFromCharCode=function(e){for(var t="",i=function(e){for(var t=0,i=0,n=0,r=128,o=191,a=[],s=e.length,l=0;s>l;l+=1){var c=e[l];if(0===n){if(lM(c,0,127)){a.push(c);continue}if(lM(c,194,223)){n=1,t=31&c;continue}if(lM(c,224,239)){224===c&&(r=160),237===c&&(o=159),n=2,t=15&c;continue}if(lM(c,240,244)){240===c&&(r=144),244===c&&(o=143),n=3,t=7&c;continue}throw new Error("String decoding failed.")}lM(c,r,o)?(r=128,o=191,t=t<<6|63&c,(i+=1)===n&&(a.push(t),t=n=i=0)):(t=n=i=0,r=128,o=191,l-=1)}return a}(e),n=i.length,r=0;n>r;r+=1){var o=i[r];o>65535?(o-=65536,t+=String.fromCharCode(55296+(o>>10),56320+(1023&o))):t+=String.fromCharCode(o)}return t},sM.decode="undefined"!=typeof TextDecoder?sM.decodeWithTextDecoder:sM.decodeWithFromCharCode;var cM=function(){function e(e){Ml.call(this,e),this.dracoLoader=null,this.ddsLoader=null}function t(){var e={};return{get:function(t){return e[t]},add:function(t,i){e[t]=i},remove:function(t){delete e[t]},removeAll:function(){e={}}}}e.prototype=Object.assign(Object.create(Ml.prototype),{constructor:e,load:function(e,t,i,n){var r,o=this;r=""!==this.resourcePath?this.resourcePath:""!==this.path?this.path:Ic.extractUrlBase(e),o.manager.itemStart(e);var a=function(t){n?n(t):console.error(t),o.manager.itemError(e),o.manager.itemEnd(e)},s=new xy(o.manager);s.setPath(this.path),s.setResponseType("arraybuffer"),"use-credentials"===o.crossOrigin&&s.setWithCredentials(!0),s.load(e,(function(i){try{o.parse(i,r,(function(i){t(i),o.manager.itemEnd(e)}),a)}catch(e){a(e)}}),i,a)},setDRACOLoader:function(e){return this.dracoLoader=e,this},setDDSLoader:function(e){return this.ddsLoader=e,this},parse:function(e,t,s,l){var u,g={};if("string"==typeof e)u=e;else{var f=Ic.decodeText(new Uint8Array(e,0,4));if(f===a){try{g[i.KHR_BINARY_GLTF]=new c(e)}catch(e){return void(l&&l(e))}u=g[i.KHR_BINARY_GLTF].content}else if("b3dm"===f){try{g[i.KHR_BINARY_GLTF]=new c(function(e){var t=0;t=0;var i=Uint32Array.BYTES_PER_ELEMENT,n=new Uint8Array(e),r=new DataView(e),o=r.getUint32(t+=i,!0);if(1!==o)throw new Error("Only Batched 3D Model version 1 is supported. Version "+o+" is not.");var a=r.getUint32(t+=i,!0),s=r.getUint32(t+=i,!0),l=r.getUint32(t+=i,!0),c=r.getUint32(t+=i,!0),h=r.getUint32(t+=i,!0);if(t+=i,570425344>c?570425344>h||(t-=i,c=s,h=l,s=0,l=0):(t-=2*i,c=l,h=0,s=0,l=0),0===s);else{var d=sM(n,t,s);JSON.parse(d),t+=s}if(t+=l,c>0){var u=sM(n,t,c);JSON.parse(u),t+=c,h>0&&(t+=h)}var p=0+a-t;if(0===p)throw new Error("glTF byte length must be greater than 0.");return t%4==0||new Uint8Array(n.subarray(t,t+p)),e.slice(t)}(e))}catch(e){return void(l&&l(e))}u=g[i.KHR_BINARY_GLTF].content}else u=Ic.decodeText(new Uint8Array(e))}var m=JSON.parse(u);if(void 0===m.asset||m.asset.version[0]<2)l&&l(new Error("THREE.GLTFLoader: Unsupported asset. glTF versions >=2.0 are supported."));else{if(m.extensionsUsed)for(var A=0;m.extensionsUsed.length>A;++A){var y=m.extensionsUsed[A],v=m.extensionsRequired||[];switch(y){case i.KHR_LIGHTS_PUNCTUAL:g[y]=new r(m);break;case i.KHR_MATERIALS_UNLIT:g[y]=new o;break;case i.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS:g[y]=new p;break;case i.KHR_DRACO_MESH_COMPRESSION:g[y]=new h(m,this.dracoLoader);break;case i.MSFT_TEXTURE_DDS:g[y]=new n(this.ddsLoader);break;case i.KHR_TEXTURE_TRANSFORM:g[y]=new d;break;case i.KHR_MESH_QUANTIZATION:g[y]=new w;break;default:0>v.indexOf(y)||console.warn('THREE.GLTFLoader: Unknown extension "'+y+'".')}}new $(m,g,{path:t||this.resourcePath||"",crossOrigin:this.crossOrigin,manager:this.manager}).parse(s,l)}}});var i={KHR_BINARY_GLTF:"KHR_binary_glTF",KHR_DRACO_MESH_COMPRESSION:"KHR_draco_mesh_compression",KHR_LIGHTS_PUNCTUAL:"KHR_lights_punctual",KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS:"KHR_materials_pbrSpecularGlossiness",KHR_MATERIALS_UNLIT:"KHR_materials_unlit",KHR_TEXTURE_TRANSFORM:"KHR_texture_transform",KHR_MESH_QUANTIZATION:"KHR_mesh_quantization",MSFT_TEXTURE_DDS:"MSFT_texture_dds"};function n(e){if(!e)throw new Error("THREE.GLTFLoader: Attempting to load .dds texture without importing DDSLoader");this.name=i.MSFT_TEXTURE_DDS,this.ddsLoader=e}function r(e){this.name=i.KHR_LIGHTS_PUNCTUAL,this.lightDefs=(e.extensions&&e.extensions[i.KHR_LIGHTS_PUNCTUAL]||{}).lights||[]}function o(){this.name=i.KHR_MATERIALS_UNLIT}r.prototype.loadLight=function(e){var t,i=this.lightDefs[e],n=new pi(16777215);void 0!==i.color&&n.fromArray(i.color);var r=void 0!==i.range?i.range:0;switch(i.type){case"directional":(t=new fc(n)).target.position.set(0,0,-1),t.add(t.target);break;case"point":(t=new uc(n)).distance=r;break;case"spot":(t=new sc(n)).distance=r,i.spot=i.spot||{},i.spot.innerConeAngle=void 0!==i.spot.innerConeAngle?i.spot.innerConeAngle:0,i.spot.outerConeAngle=void 0!==i.spot.outerConeAngle?i.spot.outerConeAngle:Math.PI/4,t.angle=i.spot.outerConeAngle,t.penumbra=1-i.spot.innerConeAngle/i.spot.outerConeAngle,t.target.position.set(0,0,-1),t.add(t.target);break;default:throw new Error('THREE.GLTFLoader: Unexpected light type, "'+i.type+'".')}return t.position.set(0,0,0),t.decay=2,void 0!==i.intensity&&(t.intensity=i.intensity),t.name=i.name||"light_"+e,Promise.resolve(t)},o.prototype.getMaterialType=function(){return gi},o.prototype.extendParams=function(e,t,i){var n=[];e.color=new pi(1,1,1),e.opacity=1;var r=t.pbrMetallicRoughness;if(r){if(Array.isArray(r.baseColorFactor)){var o=r.baseColorFactor;e.color.fromArray(o),e.opacity=o[3]}void 0!==r.baseColorTexture&&n.push(i.assignTexture(e,"map",r.baseColorTexture))}return Promise.all(n)};var a="glTF",s=1313821514,l=5130562;function c(e){this.name=i.KHR_BINARY_GLTF,this.content=null,this.body=null;var t=new DataView(e,0,12);if(this.header={magic:Ic.decodeText(new Uint8Array(e.slice(0,4))),version:t.getUint32(4,!0),length:t.getUint32(8,!0)},this.header.magic!==a)throw new Error("THREE.GLTFLoader: Unsupported glTF-Binary header.");if(2>this.header.version)throw new Error("THREE.GLTFLoader: Legacy binary file detected.");for(var n=new DataView(e,12),r=0;n.byteLength>r;){var o=n.getUint32(r,!0),c=n.getUint32(r+=4,!0);if(r+=4,c===s){var h=new Uint8Array(e,12+r,o);this.content=Ic.decodeText(h)}else if(c===l){var d=12+r;this.body=e.slice(d,d+o)}r+=o}if(null===this.content)throw new Error("THREE.GLTFLoader: JSON content not found.")}function h(e,t){if(!t)throw new Error("THREE.GLTFLoader: No DRACOLoader instance provided.");this.name=i.KHR_DRACO_MESH_COMPRESSION,this.json=e,this.dracoLoader=t,this.dracoLoader.preload()}function d(){this.name=i.KHR_TEXTURE_TRANSFORM}function u(e){Xs.call(this),this.isGLTFSpecularGlossinessMaterial=!0;var t=["#ifdef USE_SPECULARMAP","\tuniform sampler2D specularMap;","#endif"].join("\n"),i=["#ifdef USE_GLOSSINESSMAP","\tuniform sampler2D glossinessMap;","#endif"].join("\n"),n=["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"),r=["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;","vec3 dxy = max( abs( dFdx( geometryNormal ) ), abs( dFdy( geometryNormal ) ) );","float geometryRoughness = max( max( dxy.x, dxy.y ), dxy.z );","material.specularRoughness = max( 1.0 - glossinessFactor, 0.0525 );// 0.0525 corresponds to the base mip of a 256 cubemap.","material.specularRoughness += geometryRoughness;","material.specularRoughness = min( material.specularRoughness, 1.0 );","material.specularColor = specularFactor.rgb;"].join("\n"),a={specular:{value:(new pi).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;"),e.fragmentShader=e.fragmentShader.replace("uniform float metalness;","uniform float glossiness;"),e.fragmentShader=e.fragmentShader.replace("#include <roughnessmap_pars_fragment>",t),e.fragmentShader=e.fragmentShader.replace("#include <metalnessmap_pars_fragment>",i),e.fragmentShader=e.fragmentShader.replace("#include <roughnessmap_fragment>",n),e.fragmentShader=e.fragmentShader.replace("#include <metalnessmap_fragment>",r),e.fragmentShader=e.fragmentShader.replace("#include <lights_physical_fragment>",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}},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_ROUGHNESSMAP=""):(delete this.defines.USE_ROUGHNESSMAP,delete this.defines.USE_GLOSSINESSMAP)}}}),delete this.metalness,delete this.roughness,delete this.metalnessMap,delete this.roughnessMap,this.setValues(e)}function p(){return{name:i.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 u},extendParams:function(e,t,i){var n=t.extensions[this.name];e.color=new pi(1,1,1),e.opacity=1;var r=[];if(Array.isArray(n.diffuseFactor)){var o=n.diffuseFactor;e.color.fromArray(o),e.opacity=o[3]}if(void 0!==n.diffuseTexture&&r.push(i.assignTexture(e,"map",n.diffuseTexture)),e.emissive=new pi(0,0,0),e.glossiness=void 0!==n.glossinessFactor?n.glossinessFactor:1,e.specular=new pi(1,1,1),Array.isArray(n.specularFactor)&&e.specular.fromArray(n.specularFactor),void 0!==n.specularGlossinessTexture){var a=n.specularGlossinessTexture;r.push(i.assignTexture(e,"glossinessMap",a)),r.push(i.assignTexture(e,"specularMap",a))}return Promise.all(r)},createMaterial:function(e){var t=new u(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=0,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=.98,t}}}function w(){this.name=i.KHR_MESH_QUANTIZATION}function M(e,t,i,n){sl.call(this,e,t,i,n)}h.prototype.decodePrimitive=function(e,t){var i=this.json,n=this.dracoLoader,r=e.extensions[this.name].bufferView,o=e.extensions[this.name].attributes,a={},s={},l={};for(var c in o){var h=N[c]||c.toLowerCase();a[h]=o[c]}for(c in e.attributes){h=N[c]||c.toLowerCase();if(void 0!==o[c]){var d=i.accessors[e.attributes[c]];l[h]=F[d.componentType],s[h]=!0===d.normalized}}return t.getDependency("bufferView",r).then((function(e){return new Promise((function(t){n.decodeDracoFile(e,(function(e){for(var i in e.attributes){var n=s[i];void 0!==n&&(e.attributes[i].normalized=n)}t(e)}),a,l)}))}))},d.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},(u.prototype=Object.create(Xs.prototype)).constructor=u,u.prototype.copy=function(e){return Xs.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},(M.prototype=Object.create(sl.prototype)).constructor=M,M.prototype.beforeStart_=M.prototype.copySampleValue_=function(e){for(var t=this.resultBuffer,i=this.sampleValues,n=this.valueSize,r=e*n*3+n,o=0;o!==n;o++)t[o]=i[r+o];return t},M.prototype.afterEnd_=M.prototype.copySampleValue_,M.prototype.interpolate_=function(e,t,i,n){for(var r=this.resultBuffer,o=this.sampleValues,a=this.valueSize,s=2*a,l=3*a,c=n-t,h=(i-t)/c,d=h*h,u=d*h,p=e*l,g=p-l,f=-2*u+3*d,m=u-d,A=1-f,y=m-d+h,v=0;v!==a;v++){r[v]=A*o[g+v+a]+y*(o[g+v+s]*c)+f*o[p+v+a]+m*(o[p+v]*c)}return r};var E=0,B=1,S=2,b=3,T=4,R=5,U=6,F={5120:Int8Array,5121:Uint8Array,5122:Int16Array,5123:Uint16Array,5125:Uint32Array,5126:Float32Array},Q={9728:A,9729:C,9984:y,9985:I,9986:v,9987:x},L={33071:f,33648:m,10497:g},O={SCALAR:1,VEC2:2,VEC3:3,VEC4:4,MAT2:4,MAT3:9,MAT4:16},N={POSITION:"position",NORMAL:"normal",TANGENT:"tangent",TEXCOORD_0:"uv",TEXCOORD_1:"uv2",COLOR_0:"color",WEIGHTS_0:"skinWeight",JOINTS_0:"skinIndex"},P={scale:"scale",translation:"position",rotation:"quaternion",weights:"morphTargetInfluences"},G={CUBICSPLINE:void 0,LINEAR:H,STEP:Y},K="OPAQUE",V="MASK",j="BLEND",W={"image/png":D,"image/jpeg":k};function J(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 z(e,t,i){for(var n in i.extensions)void 0===e[n]&&(t.userData.gltfExtensions=t.userData.gltfExtensions||{},t.userData.gltfExtensions[n]=i.extensions[n])}function q(e,t){void 0!==t.extras&&("object"===nu(t.extras)?Object.assign(e.userData,t.extras):console.warn("THREE.GLTFLoader: Ignoring primitive type .extras, "+t.extras))}function Z(e,t){if(e.updateMorphTargets(),void 0!==t.weights)for(var i=0,n=t.weights.length;n>i;i++)e.morphTargetInfluences[i]=t.weights[i];if(t.extras&&Array.isArray(t.extras.targetNames)){var r=t.extras.targetNames;if(e.morphTargetInfluences.length===r.length){e.morphTargetDictionary={};for(i=0,n=r.length;n>i;i++)e.morphTargetDictionary[r[i]]=i}else console.warn("THREE.GLTFLoader: Invalid extras.targetNames length. Ignoring names.")}}function X(e){for(var t="",i=Object.keys(e).sort(),n=0,r=i.length;r>n;n++)t+=i[n]+":"+e[i[n]]+";";return t}function $(e,i,n){this.json=e||{},this.extensions=i||{},this.options=n||{},this.cache=new t,this.primitiveCache={},this.textureLoader=new Dl(this.options.manager),this.textureLoader.setCrossOrigin(this.options.crossOrigin),this.fileLoader=new xy(this.options.manager),this.fileLoader.setResponseType("arraybuffer"),"use-credentials"===this.options.crossOrigin&&this.fileLoader.setWithCredentials(!0)}function ee(e,t,i){var n=t.attributes,r=[];function o(t,n){return i.getDependency("accessor",t).then((function(t){e.setAttribute(n,t)}))}for(var a in n){var s=N[a]||a.toLowerCase();s in e.attributes||r.push(o(n[a],s))}if(void 0!==t.indices&&!e.index){var l=i.getDependency("accessor",t.indices).then((function(t){e.setIndex(t)}));r.push(l)}return q(e,t),function(e,t,i){var n=t.attributes,r=new He;if(void 0!==n.POSITION){var o=(h=i.json.accessors[n.POSITION]).max;if(void 0!==(d=h.min)&&void 0!==o){r.set(new Ke(d[0],d[1],d[2]),new Ke(o[0],o[1],o[2]));var a=t.targets;if(void 0!==a)for(var s=new Ke,l=0,c=a.length;c>l;l++){var h,d,u=a[l];if(void 0!==u.POSITION)o=(h=i.json.accessors[u.POSITION]).max,void 0!==(d=h.min)&&void 0!==o?(s.setX(Math.max(Math.abs(d[0]),Math.abs(o[0]))),s.setY(Math.max(Math.abs(d[1]),Math.abs(o[1]))),s.setZ(Math.max(Math.abs(d[2]),Math.abs(o[2]))),r.expandByVector(s)):console.warn("THREE.GLTFLoader: Missing min/max properties for accessor POSITION.")}e.boundingBox=r;var p=new ct;r.getCenter(p.center),p.radius=r.min.distanceTo(r.max)/2,e.boundingSphere=p}else console.warn("THREE.GLTFLoader: Missing min/max properties for accessor POSITION.")}}(e,t,i),Promise.all(r).then((function(){return void 0!==t.targets?function(e,t,i){for(var n=!1,r=!1,o=0,a=t.length;a>o&&(void 0!==(c=t[o]).POSITION&&(n=!0),void 0!==c.NORMAL&&(r=!0),!n||!r);o++);if(!n&&!r)return Promise.resolve(e);var s=[],l=[];for(o=0,a=t.length;a>o;o++){var c=t[o];if(n){var h=void 0!==c.POSITION?i.getDependency("accessor",c.POSITION):e.attributes.position;s.push(h)}r&&(h=void 0!==c.NORMAL?i.getDependency("accessor",c.NORMAL):e.attributes.normal,l.push(h))}return Promise.all([Promise.all(s),Promise.all(l)]).then((function(t){var i=t[1];return n&&(e.morphAttributes.position=t[0]),r&&(e.morphAttributes.normal=i),e.morphTargetsRelative=!0,e}))}(e,t.targets,i):e}))}function te(e,t){var i=e.getIndex();if(null===i){var n=[],r=e.getAttribute("position");if(void 0===r)return console.error("THREE.GLTFLoader.toTrianglesDrawMode(): Undefined position attribute. Processing not possible."),e;for(var o=0;r.count>o;o++)n.push(o);e.setIndex(n),i=e.getIndex()}var a=i.count-2,s=[];if(2===t)for(o=1;a>=o;o++)s.push(i.getX(0)),s.push(i.getX(o)),s.push(i.getX(o+1));else for(o=0;a>o;o++)o%2==0?(s.push(i.getX(o)),s.push(i.getX(o+1)),s.push(i.getX(o+2))):(s.push(i.getX(o+2)),s.push(i.getX(o+1)),s.push(i.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 $.prototype.parse=function(e,t){var i=this,n=this.json,r=this.extensions;this.cache.removeAll(),this.markDefs(),Promise.all([this.getDependencies("scene"),this.getDependencies("animation"),this.getDependencies("camera")]).then((function(t){var o={scene:t[0][n.scene||0],scenes:t[0],animations:t[1],cameras:t[2],asset:n.asset,parser:i,userData:{}};z(r,o,n),q(o,n),e(o)})).catch(t)},$.prototype.markDefs=function(){for(var e=this.json.nodes||[],t=this.json.skins||[],i=this.json.meshes||[],n={},r={},o=0,a=t.length;a>o;o++)for(var s=t[o].joints,l=0,c=s.length;c>l;l++)e[s[l]].isBone=!0;for(var h=0,d=e.length;d>h;h++){var u=e[h];void 0!==u.mesh&&(void 0===n[u.mesh]&&(n[u.mesh]=r[u.mesh]=0),n[u.mesh]++,void 0!==u.skin&&(i[u.mesh].isSkinnedMesh=!0))}this.json.meshReferences=n,this.json.meshUses=r},$.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.loadMesh(t);break;case"accessor":r=this.loadAccessor(t);break;case"bufferView":r=this.loadBufferView(t);break;case"buffer":r=this.loadBuffer(t);break;case"material":r=this.loadMaterial(t);break;case"texture":r=this.loadTexture(t);break;case"skin":r=this.loadSkin(t);break;case"animation":r=this.loadAnimation(t);break;case"camera":r=this.loadCamera(t);break;case"light":r=this.extensions[i.KHR_LIGHTS_PUNCTUAL].loadLight(t);break;default:throw new Error("Unknown type: "+e)}this.cache.add(n,r)}return r},$.prototype.getDependencies=function(e){var t=this.cache.get(e);if(!t){var i=this;t=Promise.all((this.json[e+("mesh"===e?"es":"s")]||[]).map((function(t,n){return i.getDependency(e,n)}))),this.cache.add(e,t)}return t},$.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[i.KHR_BINARY_GLTF].body);var r=this.options;return new Promise((function(e,i){n.load(J(t.uri,r.path),e,void 0,(function(){i(new Error('THREE.GLTFLoader: Failed to load buffer "'+t.uri+'".'))}))}))},$.prototype.loadBufferView=function(e){var t=this.json.bufferViews[e];return this.getDependency("buffer",t.buffer).then((function(e){var i=t.byteOffset||0;return e.slice(i,i+(t.byteLength||0))}))},$.prototype.loadAccessor=function(e){var t=this,i=this.json,n=this.json.accessors[e];if(void 0===n.bufferView&&void 0===n.sparse)return Promise.resolve(null);var r=[];return r.push(void 0!==n.bufferView?this.getDependency("bufferView",n.bufferView):null),void 0!==n.sparse&&(r.push(this.getDependency("bufferView",n.sparse.indices.bufferView)),r.push(this.getDependency("bufferView",n.sparse.values.bufferView))),Promise.all(r).then((function(e){var r,o,a=e[0],s=O[n.type],l=F[n.componentType],c=l.BYTES_PER_ELEMENT,h=n.byteOffset||0,d=void 0!==n.bufferView?i.bufferViews[n.bufferView].byteStride:void 0,u=!0===n.normalized;if(d&&d!==c*s){var p=Math.floor(h/d),g="InterleavedBuffer:"+n.bufferView+":"+n.componentType+":"+p+":"+n.count,f=t.cache.get(g);f||(r=new l(a,p*d,n.count*d/c),f=new Yo(r,d/c),t.cache.add(g,f)),o=new jo(f,s,h%d/c,u)}else r=null===a?new l(n.count*s):new l(a,h,n.count*s),o=new Ai(r,s,u);if(void 0!==n.sparse){var m=n.sparse.values.byteOffset||0,A=new(0,F[n.sparse.indices.componentType])(e[1],n.sparse.indices.byteOffset||0,n.sparse.count*O.SCALAR),y=new l(e[2],m,n.sparse.count*s);null!==a&&(o=new Ai(o.array.slice(),o.itemSize,o.normalized));for(var v=0,C=A.length;C>v;v++){var I=A[v];if(o.setX(I,y[v*s]),2>s||o.setY(I,y[v*s+1]),3>s||o.setZ(I,y[v*s+2]),4>s||o.setW(I,y[v*s+3]),s>=5)throw new Error("THREE.GLTFLoader: Unsupported itemSize in sparse BufferAttribute.")}}return o}))},$.prototype.loadTexture=function(e){var t,n=this,r=this.json,o=this.options,a=this.textureLoader,s=window.URL||window.webkitURL,l=r.textures[e],c=l.extensions||{},h=(t=c[i.MSFT_TEXTURE_DDS]?r.images[c[i.MSFT_TEXTURE_DDS].source]:r.images[l.source]).uri,d=!1;return void 0!==t.bufferView&&(h=n.getDependency("bufferView",t.bufferView).then((function(e){d=!0;var i=new Blob([e],{type:t.mimeType});return h=s.createObjectURL(i)}))),Promise.resolve(h).then((function(e){var t=o.manager.getHandler(e);return t||(t=c[i.MSFT_TEXTURE_DDS]?n.extensions[i.MSFT_TEXTURE_DDS].ddsLoader:a),new Promise((function(i,n){t.load(J(e,o.path),i,void 0,n)}))})).then((function(e){!0===d&&s.revokeObjectURL(h),e.flipY=!1,l.name&&(e.name=l.name),t.mimeType in W&&(e.format=W[t.mimeType]);var i=(r.samplers||{})[l.sampler]||{};return e.magFilter=Q[i.magFilter]||C,e.minFilter=Q[i.minFilter]||x,e.wrapS=L[i.wrapS]||g,e.wrapT=L[i.wrapT]||g,e}))},$.prototype.assignTexture=function(e,t,n){var r=this;return this.getDependency("texture",n.index).then((function(o){if(!o.isCompressedTexture)switch(t){case"aoMap":case"emissiveMap":case"metalnessMap":case"normalMap":case"roughnessMap":o.format=k}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."),r.extensions[i.KHR_TEXTURE_TRANSFORM]){var a=void 0!==n.extensions?n.extensions[i.KHR_TEXTURE_TRANSFORM]:void 0;a&&(o=r.extensions[i.KHR_TEXTURE_TRANSFORM].extendTexture(o,a))}e[t]=o}))},$.prototype.assignFinalMaterial=function(e){var t=e.geometry,i=e.material,n=void 0!==t.attributes.tangent,r=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=this.cache.get(d="PointsMaterial:"+i.uuid);c||(c=new Na,ai.prototype.copy.call(c,i),c.color.copy(i.color),c.map=i.map,c.sizeAttenuation=!1,this.cache.add(d,c)),i=c}else if(e.isLine){var h=this.cache.get(d="LineBasicMaterial:"+i.uuid);h||(h=new Sa,ai.prototype.copy.call(h,i),h.color.copy(i.color),this.cache.add(d,h)),i=h}if(n||r||o||a||s){var d="ClonedMaterial:"+i.uuid+":";i.isGLTFSpecularGlossinessMaterial&&(d+="specular-glossiness:"),a&&(d+="skinning:"),n&&(d+="vertex-tangents:"),r&&(d+="vertex-colors:"),o&&(d+="flat-shading:"),s&&(d+="morph-targets:"),l&&(d+="morph-normals:");var u=this.cache.get(d);u||(u=i.clone(),a&&(u.skinning=!0),n&&(u.vertexTangents=!0),r&&(u.vertexColors=!0),o&&(u.flatShading=!0),s&&(u.morphTargets=!0),l&&(u.morphNormals=!0),this.cache.add(d,u)),i=u}i.aoMap&&void 0===t.attributes.uv2&&void 0!==t.attributes.uv&&t.setAttribute("uv2",new Ai(t.attributes.uv.array,2)),i.normalScale&&!n&&(i.normalScale.y=-i.normalScale.y),e.material=i},$.prototype.loadMaterial=function(e){var t,n=this,r=this.extensions,o=this.json.materials[e],a={},s=o.extensions||{},l=[];if(s[i.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS]){var c=r[i.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS];t=c.getMaterialType(),l.push(c.extendParams(a,o,n))}else if(s[i.KHR_MATERIALS_UNLIT]){var h=r[i.KHR_MATERIALS_UNLIT];t=h.getMaterialType(),l.push(h.extendParams(a,o,n))}else{t=Xs;var d=o.pbrMetallicRoughness||{};if(a.color=new pi(1,1,1),a.opacity=1,Array.isArray(d.baseColorFactor)){var p=d.baseColorFactor;a.color.fromArray(p),a.opacity=p[3]}void 0!==d.baseColorTexture&&l.push(n.assignTexture(a,"map",d.baseColorTexture)),a.metalness=void 0!==d.metallicFactor?d.metallicFactor:1,a.roughness=void 0!==d.roughnessFactor?d.roughnessFactor:1,void 0!==d.metallicRoughnessTexture&&(l.push(n.assignTexture(a,"metalnessMap",d.metallicRoughnessTexture)),l.push(n.assignTexture(a,"roughnessMap",d.metallicRoughnessTexture)))}!0===o.doubleSided&&(a.side=2);var g=o.alphaMode||K;return g===j?(a.transparent=!0,a.depthWrite=!1):(a.transparent=!1,g===V&&(a.alphaTest=void 0!==o.alphaCutoff?o.alphaCutoff:.5)),void 0!==o.normalTexture&&t!==gi&&(l.push(n.assignTexture(a,"normalMap",o.normalTexture)),a.normalScale=new ke(1,1),void 0!==o.normalTexture.scale&&a.normalScale.set(o.normalTexture.scale,o.normalTexture.scale)),void 0!==o.occlusionTexture&&t!==gi&&(l.push(n.assignTexture(a,"aoMap",o.occlusionTexture)),void 0!==o.occlusionTexture.strength&&(a.aoMapIntensity=o.occlusionTexture.strength)),void 0!==o.emissiveFactor&&t!==gi&&(a.emissive=(new pi).fromArray(o.emissiveFactor)),void 0!==o.emissiveTexture&&t!==gi&&l.push(n.assignTexture(a,"emissiveMap",o.emissiveTexture)),Promise.all(l).then((function(){var e;return e=t===u?r[i.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS].createMaterial(a):new t(a),o.name&&(e.name=o.name),e.map&&(e.map.encoding=_),e.emissiveMap&&(e.emissiveMap.encoding=_),q(e,o),o.extensions&&z(r,e,o),e}))},$.prototype.loadGeometries=function(e){var t=this,n=this.extensions,r=this.primitiveCache;function o(e){return n[i.KHR_DRACO_MESH_COMPRESSION].decodePrimitive(e,t).then((function(i){return ee(i,e,t)}))}for(var a,s,l=[],c=0,h=e.length;h>c;c++){var d,u=e[c],p=(s=void 0,(s=(a=u).extensions&&a.extensions[i.KHR_DRACO_MESH_COMPRESSION])?"draco:"+s.bufferView+":"+s.indices+":"+X(s.attributes):a.indices+":"+X(a.attributes)+":"+a.mode),g=r[p];if(g)l.push(g.promise);else d=u.extensions&&u.extensions[i.KHR_DRACO_MESH_COMPRESSION]?o(u):ee(new Ni,u,t),r[p]={primitive:u,promise:d},l.push(d)}return Promise.all(l)},$.prototype.loadMesh=function(e){for(var t,i=this,n=this.json.meshes[e],r=n.primitives,o=[],a=0,s=r.length;s>a;a++){var l=void 0===r[a].material?(void 0===(t=this.cache).DefaultMaterial&&(t.DefaultMaterial=new Xs({color:16777215,emissive:0,metalness:1,roughness:1,transparent:!1,depthTest:!0,side:0})),t.DefaultMaterial):this.getDependency("material",r[a].material);o.push(l)}return o.push(i.loadGeometries(r)),Promise.all(o).then((function(t){for(var o=t.slice(0,t.length-1),a=t[t.length-1],s=[],l=0,c=a.length;c>l;l++){var h,d=a[l],u=r[l],p=o[l];if(u.mode===T||u.mode===R||u.mode===U||void 0===u.mode)!0!==(h=!0===n.isSkinnedMesh?new ma(d,p):new nn(d,p)).isSkinnedMesh||h.geometry.attributes.skinWeight.normalized||h.normalizeSkinWeights(),u.mode===R?h.geometry=te(h.geometry,1):u.mode===U&&(h.geometry=te(h.geometry,2));else if(u.mode===B)h=new La(d,p);else if(u.mode===b)h=new Ua(d,p);else if(u.mode===S)h=new Oa(d,p);else{if(u.mode!==E)throw new Error("THREE.GLTFLoader: Primitive mode unsupported: "+u.mode);h=new Ya(d,p)}Object.keys(h.geometry.morphAttributes).length>0&&Z(h,n),h.name=n.name||"mesh_"+e,a.length>1&&(h.name+="_"+l),q(h,n),i.assignFinalMaterial(h),s.push(h)}if(1===s.length)return s[0];var g=new To;for(l=0,c=s.length;c>l;l++)g.add(s[l]);return g}))},$.prototype.loadCamera=function(e){var t,i=this.json.cameras[e],n=i[i.type];if(n)return"perspective"===i.type?t=new dn(be.radToDeg(n.yfov),n.aspectRatio||1,n.znear||1,n.zfar||2e6):"orthographic"===i.type&&(t=new pc(n.xmag/-2,n.xmag/2,n.ymag/2,n.ymag/-2,n.znear,n.zfar)),i.name&&(t.name=i.name),q(t,i),Promise.resolve(t);console.warn("THREE.GLTFLoader: Missing camera parameters.")},$.prototype.loadSkin=function(e){var t=this.json.skins[e],i={joints:t.joints};return void 0===t.inverseBindMatrices?Promise.resolve(i):this.getDependency("accessor",t.inverseBindMatrices).then((function(e){return i.inverseBindMatrices=e,i}))},$.prototype.loadAnimation=function(e){for(var t=this.json.animations[e],i=[],n=[],r=[],o=[],a=[],s=0,l=t.channels.length;l>s;s++){var c=t.channels[s],h=t.samplers[c.sampler],d=c.target,u=void 0!==t.parameters?t.parameters[h.input]:h.input,p=void 0!==t.parameters?t.parameters[h.output]:h.output;i.push(this.getDependency("node",void 0!==d.node?d.node:d.id)),n.push(this.getDependency("accessor",u)),r.push(this.getDependency("accessor",p)),o.push(h),a.push(d)}return Promise.all([Promise.all(i),Promise.all(n),Promise.all(r),Promise.all(o),Promise.all(a)]).then((function(i){for(var n=i[0],r=i[1],o=i[2],a=i[3],s=i[4],l=[],c=0,h=n.length;h>c;c++){var d=n[c],u=r[c],p=o[c],g=a[c],f=s[c];if(void 0!==d){var m;switch(d.updateMatrix(),d.matrixAutoUpdate=!0,P[f.path]){case P.weights:m=gl;break;case P.rotation:m=ml;break;case P.position:case P.scale:default:m=yl}var A=d.name?d.name:d.uuid,y=void 0!==g.interpolation?G[g.interpolation]:H,v=[];P[f.path]===P.weights?d.traverse((function(e){!0===e.isMesh&&e.morphTargetInfluences&&v.push(e.name?e.name:e.uuid)})):v.push(A);var C=p.array;if(p.normalized){var I;if(C.constructor===Int8Array)I=1/127;else if(C.constructor===Uint8Array)I=1/255;else if(C.constructor==Int16Array)I=1/32767;else{if(C.constructor!==Uint16Array)throw new Error("THREE.GLTFLoader: Unsupported output accessor component type.");I=1/65535}for(var x=new Float32Array(C.length),w=0,E=C.length;E>w;w++)x[w]=C[w]*I;C=x}for(w=0,E=v.length;E>w;w++){var B=new m(v[w]+"."+P[f.path],u.array,C,y);"CUBICSPLINE"===g.interpolation&&(B.createInterpolant=function(e){return new M(this.times,this.values,this.getValueSize()/3,e)},B.createInterpolant.isInterpolantFactoryMethodGLTFCubicSpline=!0),l.push(B)}}}return new vl(t.name?t.name:"animation_"+e,void 0,l)}))},$.prototype.loadNode=function(e){var t,n=this.json,r=this.extensions,o=this,a=n.meshReferences,s=n.meshUses,l=n.nodes[e];return(t=[],void 0!==l.mesh&&t.push(o.getDependency("mesh",l.mesh).then((function(e){var t;if(a[l.mesh]>1){var i=s[l.mesh]++;(t=e.clone()).name+="_instance_"+i}else t=e;return void 0!==l.weights&&t.traverse((function(e){if(e.isMesh)for(var t=0,i=l.weights.length;i>t;t++)e.morphTargetInfluences[t]=l.weights[t]})),t}))),void 0!==l.camera&&t.push(o.getDependency("camera",l.camera)),l.extensions&&l.extensions[i.KHR_LIGHTS_PUNCTUAL]&&void 0!==l.extensions[i.KHR_LIGHTS_PUNCTUAL].light&&t.push(o.getDependency("light",l.extensions[i.KHR_LIGHTS_PUNCTUAL].light)),Promise.all(t)).then((function(e){var t;if((t=!0===l.isBone?new Aa:e.length>1?new To:1===e.length?e[0]:new Yt)!==e[0])for(var i=0,n=e.length;n>i;i++)t.add(e[i]);if(l.name&&(t.userData.name=l.name,t.name=lh.sanitizeNodeName(l.name)),q(t,l),l.extensions&&z(r,t,l),void 0!==l.matrix){var o=new yt;o.fromArray(l.matrix),t.applyMatrix4(o)}else void 0!==l.translation&&t.position.fromArray(l.translation),void 0!==l.rotation&&t.quaternion.fromArray(l.rotation),void 0!==l.scale&&t.scale.fromArray(l.scale);return t}))},$.prototype.loadScene=function(){function e(t,i,n,r){var o=n.nodes[t];return r.getDependency("node",t).then((function(e){return void 0===o.skin?e:r.getDependency("skin",o.skin).then((function(e){for(var i=[],n=0,o=(t=e).joints.length;o>n;n++)i.push(r.getDependency("node",t.joints[n]));return Promise.all(i)})).then((function(i){return e.traverse((function(e){if(e.isMesh){for(var n=[],r=[],o=0,a=i.length;a>o;o++){var s=i[o];if(s){n.push(s);var l=new yt;void 0!==t.inverseBindMatrices&&l.fromArray(t.inverseBindMatrices.array,16*o),r.push(l)}else console.warn('THREE.GLTFLoader: Joint "%s" could not be found.',t.joints[o])}e.bind(new Ia(n,r),e.matrixWorld)}})),e}));var t})).then((function(t){i.add(t);var a=[];if(o.children)for(var s=o.children,l=0,c=s.length;c>l;l++){a.push(e(s[l],t,n,r))}return Promise.all(a)}))}return function(t){var i=this.json,n=this.extensions,r=this.json.scenes[t],o=new To;r.name&&(o.name=r.name),q(o,r),r.extensions&&z(n,o,r);for(var a=r.nodes||[],s=[],l=0,c=a.length;c>l;l++)s.push(e(a[l],o,i,this));return Promise.all(s).then((function(){return o}))}}(),e}(),hM="REPLACE",dM=function e(t,i,n,r){Yt.call(this);var o=this;if(this.isRoot=r||!1,r||(this.matrix=oM.getTransfrom(n.transform)),this.refine=n.refine||hM,this.geometricError=n.geometricError||0,this.boundingBox=oM.getBoxFromTileBoundingVolumeBox(n.boundingVolume.box),this.scene=null,this.model=t,this.json=n,this.level=i&&i.level+1||0,this.matrixAutoUpdate=!1,this.hasB3DM=!1,n.content&&(n.content.url.endsWith("json")?o.loadContent(n.content.url):n.content.url.endsWith("b3dm")&&(o.hasB3DM=!0,o.model.tilesList[n.content.url]=o,i&&i.hasB3DM||(o.firstB3DM=!0,o.loadB3DM(n.content.url)))),n.children)for(var a=0,s=n.children.length;s>a;a+=1)o.add(new e(t,o,n.children[a]))};(dM.prototype=Object.create(Yt.prototype)).loadContent=function(e){var t=this,i=t.model,n=i.dataUrl.tilesUrl(e);function r(){var e=i.fileLoader;e.setResponseType("json"),e.setCacheViable(!0),e.setRequestHeader({Authorization:i.accessToken}),e.load(n,(function(e){var n={};if("string"==typeof e)try{n=JSON.parse(e)}catch(e){return void i.dispatchEventEx({type:Fd.ON_LOAD_INVALID_DATA,modelKey:i.modelKey})}else n=e;t.add(new dM(i,parent,n.root,parent.level+1,!0))}),(function(e,t){switch(e){case 401:i.dispatchEventEx({type:Fd.ACCOUNT_NO_EXIST,modelKey:i.modelKey,data:t});break;case 403:i.dispatchEventEx({type:Fd.NO_PERMISSION,modelKey:i.modelKey,data:t});break;default:i.dispatchEventEx({type:Fd.ON_NETWORK_ERROR,modelKey:i.modelKey,data:e})}}))}if(xd.getDataFromIndexedDB){var o=i.getStorage();o&&o.get(n,(function(e){if(e){var n={};if("string"==typeof e)try{n=JSON.parse(e)}catch(e){return void i.dispatchEventEx({type:Fd.ON_LOAD_INVALID_DATA,modelKey:i.modelKey})}else n=e;t.add(new dM(i,parent,n.root,!0))}else r()}),(function(){r()}))}else r()},dM.prototype.loadB3DM=function(e){var t=this,i=t.model;t.loaderManager=new vy,t.loaderManager.model=i;var n=new cM(t.loaderManager);function r(e){t.scene=e,t.loading=!1,t.loaded=!0,t.add(e.scene),i.tileLoadFinish()}t.loading=!0;var o=i.dataUrl.b3dmUrl(e||t.json.content.url);if(xd.getDataFromIndexedDB){var a=i.getStorage();a&&a.get(o,(function(i){i?n.parse(i,e||t.json.content.url,r):n.load(o,r)}),(function(){n.load(o,r)}))}else n.load(o,r)};var uM=function(e,t,i,n){rM.call(this,e,t,i,n),this.configLoader=new aM(this),this.tilesList={},this.isTilesModel=!0};(uM.prototype=Object.create(rM.prototype)).load=function(e){var t=this;this.configLoader.load((function(){t.parseCfgFinish&&t.parseCfgFinish(),t.manager.updateScene(),t.group.add(new dM(t,null,t.configLoader.config.root,!0)),t.loaded=!0}))},uM.prototype.tileLoadStart=function(){},uM.prototype.tileLoadFinish=function(){this.group.updateMatrixWorld(!0,!0),this.manager.viewerImpl.render()},uM.prototype.tileUnloadStart=function(){},uM.prototype.tileUnloadFinish=function(){},uM.prototype.checkTilesDataChanged=function(e){for(var t in Bu.time("checkTilesDataChanged"),this.tilesList)if(this.tilesList.hasOwnProperty(t)){var i=this.tilesList[t];this.tilesNeedLoad(i.boundingBox.getCenter((new Ke).applyMatrix4(i.parent.matrixWorld).applyMatrix4(i.matrix)),i.boundingBox.getSize(new Ke).length())||i.firstB3DM?i.scene||i.loading?i.visible=!0:i.loadB3DM():e?(i.remove(i.scene),i.scene=null):i.visible=!1}Bu.timeEnd("checkTilesDataChanged")},uM.prototype.tilesNeedLoad=function(e,t){var i,n=this.manager.cameraFov;return i=(t||0)*this.manager.domElementWidth/(2*this.manager.cameraPosition.clone().sub(e).length()*Math.tan(n/2)),Bu.debug("几何误差:",i),i>xd.geometricErrorThresholdValue};var pM=function(){this.size=0,this.counter=0,this.expansion=1,this._pool=null};pM.prototype.init=function(e,t){this.classType=e,this._pool=[],this._expand(t)},pM.prototype._expand=function(e){this.size+=e;for(var t=0;e>t;t+=1)this._pool.push(new this.classType)},pM.prototype.acquire=function(){return this.size>this.counter||(this.expansion=Math.round(1.2*this.expansion)+1,this._expand(this.expansion)),this._pool[this.counter++]},pM.prototype.clear=function(){this.counter=0},pM.prototype.destroy=function(){for(var e=0,t=this.size;t>e;e+=1)this._pool[e].destroy();this.counter=0,this.size=0,this.expansion=1,this._pool=null},pM.prototype.getObjects=function(){return this._pool};var gM=[];gM.push("clipPlane_right"),gM.push("clipPlane_left"),gM.push("clipPlane_back"),gM.push("clipPlane_front"),gM.push("clipPlane_top"),gM.push("clipPlane_bottom");var fM=new Ge,mM=new Ke(1,0,0),AM=new Ke(0,1,0),yM=new Ke(0,0,1),vM=new yt,CM=function(e,t,i,n,r,o,a,s,l,c,h,d){this.enable=e,this.visible=t,this.rotatable=i,this.calculation=n,this.planeOffset=r.slice(0),this.planeRotate=o.slice(0),this.position=a,this.scale=s,this.quaternion=l,this.cubeSize=c,this.center=h,this.boundingBox=d},IM=function(e){lu(i,e);var t=pu(i);function i(e,n){var r;return ru(this,i),(r=t.call(this,Vp.CLIPPLANE,{priority:20})).cubeSize=e.clone(),r.center=n.clone(),r.visible=!1,r.rotatable=!1,r.selectIndex=null,r.planeOffset=new Array(6),r.planeRotate=[0,0,0],r.observer=null,r.uniforms={iClipPlane:{type:"i",value:0},vClipPlane:{type:"v4v",value:[new Le,new Le,new Le,new Le,new Le,new Le]}},r.clipplanes=null,r.calculation=!0,r.boundingBox=new He,r.planeMaterial=new ig({color:8158334,opacity:0,transparent:!0,side:2,lights:!0}),r.planeHighLightMatrial=new ig({color:255,opacity:.1,transparent:!0,side:2,lights:!0}),r}return au(i,[{key:"calculateClipBoundingBox",value:function(e){this.boundingBox.setFromObject(this)}},{key:"getClipBoundingBox",value:function(){return this.boundingBox}},{key:"isVisible",value:function(){return this.visible}},{key:"getPlaneNormal",value:function(e){var t=new Le,i=Math.floor(e/2);return t.setComponent(i,Math.pow(-1,e%2)),t.w=.5*-this.cubeSize.getComponent(i),this.planeOffset[e]=0,t}},{key:"initPlaneModel",value:function(e){var t=Math.floor(e/2),i=e%2,n=new In(0===t?this.cubeSize.z:this.cubeSize.x,1===t?this.cubeSize.z:this.cubeSize.y),r=new nn(n,this.planeMaterial);switch(r.name=gM[e],r.customTag=!0,r.position.setComponent(t,Math.pow(-1,i)*this.cubeSize.getComponent(t)*.5),e){case 0:r.rotation.y=.5*Math.PI;break;case 1:r.rotation.y=.5*-Math.PI;break;case 2:r.rotation.x=.5*-Math.PI;break;case 3:r.rotation.x=.5*Math.PI;break;case 4:break;case 5:r.rotation.x=Math.PI}r.renderOrder=90,this.add(r)}},{key:"initCapsBox",value:function(){if(this.boxMesh)return this.boxMesh;var e=new on(this.cubeSize.x,this.cubeSize.y,this.cubeSize.z);e.groups=null;var t=new ig({color:16776960,side:2,stencilWrite:!0,stencilFunc:de,stencilRef:1,stencilFuncMask:255,stencilFail:oe,stencilZFail:oe,stencilZPass:oe}),i=new nn(e,t);return i.matrixWorld=this.matrixWorld,i.matrix=this.matrix,i.name="capsBox",this.boxMesh=i,i}},{key:"initWireframes",value:function(){var e=[.5*-this.cubeSize.x,.5*-this.cubeSize.y,.5*-this.cubeSize.z,.5*this.cubeSize.x,.5*-this.cubeSize.y,.5*-this.cubeSize.z,.5*this.cubeSize.x,.5*this.cubeSize.y,.5*-this.cubeSize.z,.5*-this.cubeSize.x,.5*this.cubeSize.y,.5*-this.cubeSize.z,.5*-this.cubeSize.x,.5*-this.cubeSize.y,.5*this.cubeSize.z,.5*this.cubeSize.x,.5*-this.cubeSize.y,.5*this.cubeSize.z,.5*this.cubeSize.x,.5*this.cubeSize.y,.5*this.cubeSize.z,.5*-this.cubeSize.x,.5*this.cubeSize.y,.5*this.cubeSize.z],t=new Ni,i=new ig({color:0,lights:!0});t.setIndex([0,1,1,2,2,3,3,0,4,5,5,6,6,7,7,4,0,4,3,7,1,5,2,6]),t.setAttribute("position",new Bi(e,3)),t.setAttribute("color",new Bi([1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1],3)),t.computeBoundingSphere();var n=new La(t,i);n.name="Wireframes",n.customTag=!0,this.add(n)}},{key:"updateClippingParams",value:function(e){}},{key:"enable",value:function(e,t){this.visible=t,this.uniforms.iClipPlane.value=e?6:0,this.updateClippingParams(this.uniforms),this.boxMesh&&(this.boxMesh.visible=t)}},{key:"isEnabled",value:function(){return 0!==this.uniforms.iClipPlane.value}},{key:"store",value:function(){return new CM(!!this.uniforms.iClipPlane.value,this.visible,this.rotatable,this.calculation,this.planeOffset,this.planeRotate,this.position.clone(),this.scale.clone(),this.quaternion.clone(),this.cubeSize.clone(),this.center.clone(),this.boundingBox.clone())}},{key:"restore",value:function(e){this.calculation=!0,this.calculationPlanes(e.cubeSize,e.center),this.enable(e.enable,e.visible),this.rotatable=e.rotatable,this.calculation=e.calculation;for(var t=0;6>t;t+=1)this.planeOffset[t]=e.planeOffset[t];for(var i=0;3>i;i+=1)this.planeRotate[i]=e.planeRotate[i];this.position.copy(e.position),this.scale.copy(e.scale),this.quaternion._w=e.quaternion._w,this.quaternion._x=e.quaternion._x,this.quaternion._y=e.quaternion._y,this.quaternion._z=e.quaternion._z,this.update()}},{key:"reset",value:function(){this.calculation=!0;for(var e=0;6>e;e+=1)this.planeOffset[e]=0;for(e=0;3>e;e+=1)this.planeRotate[e]=0;this.position.copy(this.center),this.scale.copy(new Ke(1,1,1)),this.quaternion.copy(new Ge),this.update()}},{key:"calculationPlanes",value:function(e,t,i){if(this.calculation||i){this.cubeSize.copy(e),this.center.copy(t);for(var n=this.children.length-1;n>=0;n-=1)this.remove(this.children[n]);for(n=0;6>n;n+=1)this.uniforms.vClipPlane.value[n]=this.getPlaneNormal(n),this.initPlaneModel(n);this.initWireframes(),this.clipplanes=this.uniforms.vClipPlane.value.slice(0),this.reset()}}},{key:"update",value:function(){this.updateMatrixWorld(),vM.copy(this.matrix).invert(),vM.transpose();for(var e=0;6>e;++e)this.uniforms.vClipPlane.value[e]=this.clipplanes[e].clone().applyMatrix4(vM);this.updateClippingParams(this.uniforms),this.observer&&this.observer()}},{key:"offset",value:function(e,t){this.calculation=!1;var i=Math.floor(e/2);this.cubeSize.getComponent(i),e%2==0&&this.planeOffset[e]+t>0&&(t=-this.planeOffset[e]),e%2==1&&0>this.planeOffset[e]+t&&(t=-this.planeOffset[e]),this.planeOffset[e]+=t;for(var n=new Ke,r=0;6>r;r+=1){var o=this.clipplanes[r].clone(),a=this.planeOffset[r],s=new Ke(o.x*a,o.y*a,o.z*a);n.add(s)}var l=1+n.getComponent(i)/this.cubeSize.getComponent(i);if((l=0===l?1e-5:l)>0){this.scale.setComponent(i,l);var c=this.uniforms.vClipPlane.value[e].clone(),h=new Ke(c.x,c.y,c.z);h.normalize();var d=new Ke(h.x*(s=t),h.y*s,h.z*s);e%2==1?this.position.sub(d.multiplyScalar(.5)):this.position.add(d.multiplyScalar(.5)),this.update()}else this.planeOffset[e]-=t}},{key:"rotX",value:function(e){this.calculation=!1,fM.setFromAxisAngle(mM,e),this.quaternion.multiply(fM),this.update()}},{key:"rotY",value:function(e){this.calculation=!1,fM.setFromAxisAngle(AM,e),this.quaternion.multiply(fM),this.update()}},{key:"setSectionBox",value:function(e,t){this.calculation=!0;var i=new Ke(t.x-e.x,t.y-e.y,t.z-e.z),n=new Ke(.5*(e.x+t.x),.5*(e.y+t.y),.5*(e.z+t.z));this.calculationPlanes(i,n)}},{key:"calculateOffsetByBox",value:function(e,t){var i=t.x-this.center.x-.5*this.cubeSize.x;this.planeOffset[0]>i?(this.moveSectionPlane("left",this.center.x-.5*this.cubeSize.x-e.x),this.moveSectionPlane("right",i)):(this.moveSectionPlane("right",i),this.moveSectionPlane("left",this.center.x-.5*this.cubeSize.x-e.x));var n=t.y-this.center.y-.5*this.cubeSize.y;this.planeOffset[2]>n?(this.moveSectionPlane("bottom",this.center.y-.5*this.cubeSize.y-e.y),this.moveSectionPlane("top",n)):(this.moveSectionPlane("top",n),this.moveSectionPlane("bottom",this.center.y-.5*this.cubeSize.y-e.y));var r=t.z-this.center.z-.5*this.cubeSize.z;this.planeOffset[4]>r?(this.moveSectionPlane("back",this.center.z-.5*this.cubeSize.z-e.z),this.moveSectionPlane("front",r)):(this.moveSectionPlane("front",r),this.moveSectionPlane("back",this.center.z-.5*this.cubeSize.z-e.z))}},{key:"getPlaneIndexByName",value:function(e){var t=-1;return"right"===e?t=0:"left"===e?t=1:"top"===e?t=2:"bottom"===e?t=3:"front"===e?t=4:"back"===e&&(t=5),t}},{key:"moveSectionPlane",value:function(e,t){var i=this.getPlaneIndexByName(e);-1!==i&&(i%2!=0&&(t=-t),this.offset(i,t-this.planeOffset[i]))}},{key:"recalculate",value:function(){return this.filter.getVisibleComponentsBbox()}},{key:"setProcess",value:function(e,t){var i=this.getPlaneIndexByName(e),n=0;(2>i?n=this.cubeSize.x:4>i?n=this.cubeSize.y:6>i&&(n=this.cubeSize.z),t>1?t=1:0>t&&(t=0),-1!==i)&&(i%2!=1&&(t=-t),this.offset(i,t*n-this.planeOffset[i]))}},{key:"getProcess",value:function(e){var t=this.getPlaneIndexByName(e);-1===t&&console.log("faceName is illegal");var i=0;2>t?i=this.cubeSize.x:4>t?i=this.cubeSize.y:6>t&&(i=this.cubeSize.z);var n=1;t%2!=1&&(n=-1);var r=n*this.planeOffset[t]/i;return r>1?r=1:0>r&&(r=0),r}},{key:"rotateSectionBox",value:function(e,t){"x"==e?this.planeRotate[0]=t:"y"===e?this.planeRotate[1]=t:"z"===e&&(this.planeRotate[2]=t),this.calculation=!0;var i=new Ge;i.setFromAxisAngle(mM,this.planeRotate[0]);var n=new Ge;n.setFromAxisAngle(AM,this.planeRotate[1]);var r=new Ge;r.setFromAxisAngle(yM,this.planeRotate[2]);var o=new Ge;o.multiply(i),o.multiply(n),o.multiply(r),this.quaternion.copy(o),this.update()}},{key:"highLight",value:function(){null!=this.selectIndex&&(this.children[this.selectIndex].material=this.planeHighLightMatrial)}},{key:"cancelHighLight",value:function(){null!=this.selectIndex&&(this.children[this.selectIndex].material=this.planeMaterial,this.selectIndex=null)}},{key:"init",value:function(){this.calculationPlanes(this.cubeSize,this.center)}},{key:"hitTest",value:function(e){var t=null,i=null;if(this.raycast(e),null!=this.selectIndex){var n=e.ray,r=new Jt,o=this.uniforms.vClipPlane.value[this.selectIndex];r.setComponents(o.x,o.y,o.z,o.w),t=n.distanceToPlane(r),i=0>n.direction.dot(r.normal)}return{sign:i,distance:t}}},{key:"raycast",value:function(e){if(this.visible){var t=[],i=null;this.selectIndex=null;for(var n=0;6>n;n+=1)if(this.children[n].raycast(e,t),t.length>0){var r=t.pop();i&&r.distance>=i.distance||(i=r,this.selectIndex=n),t=[]}}}}]),i}(cm);wn.line={linewidth:{value:1},resolution:{value:new ke(1,1)},dashScale:{value:1},dashSize:{value:1},dashOffset:{value:0},gapSize:{value:1},opacity:{value:1}},Mn.line={uniforms:ln.merge([wn.common,wn.fog,wn.line]),vertexShader:"\n #include <common>\n #include <color_pars_vertex>\n #include <fog_pars_vertex>\n #include <logdepthbuf_pars_vertex>\n #include <clipping_planes_pars_vertex>\n\n uniform float linewidth;\n uniform vec2 resolution;\n\n attribute vec3 instanceStart;\n attribute vec3 instanceEnd;\n\n attribute vec3 instanceColorStart;\n attribute vec3 instanceColorEnd;\n\n varying vec2 vUv;\n\n #ifdef USE_DASH\n\n uniform float dashScale;\n attribute float instanceDistanceStart;\n attribute float instanceDistanceEnd;\n varying float vLineDistance;\n\n #endif\n\n void trimSegment( const in vec4 start, inout vec4 end ) {\n\n // trim end segment so it terminates between the camera plane and the near plane\n\n // conservative estimate of the near plane\n float a = projectionMatrix[ 2 ][ 2 ]; // 3nd entry in 3th column\n float b = projectionMatrix[ 3 ][ 2 ]; // 3nd entry in 4th column\n float nearEstimate = - 0.5 * b / a;\n\n float alpha = ( nearEstimate - start.z ) / ( end.z - start.z );\n\n end.xyz = mix( start.xyz, end.xyz, alpha );\n\n }\n\n void main() {\n\n #ifdef USE_COLOR\n\n vColor.xyz = ( position.y < 0.5 ) ? instanceColorStart : instanceColorEnd;\n\n #endif\n\n #ifdef USE_DASH\n\n vLineDistance = ( position.y < 0.5 ) ? dashScale * instanceDistanceStart : dashScale * instanceDistanceEnd;\n\n #endif\n\n float aspect = resolution.x / resolution.y;\n\n vUv = uv;\n\n // camera space\n vec4 start = modelViewMatrix * vec4( instanceStart, 1.0 );\n vec4 end = modelViewMatrix * vec4( instanceEnd, 1.0 );\n\n // special case for perspective projection, and segments that terminate either in, or behind, the camera plane\n // clearly the gpu firmware has a way of addressing this issue when projecting into ndc space\n // but we need to perform ndc-space calculations in the shader, so we must address this issue directly\n // perhaps there is a more elegant solution -- WestLangley\n\n bool perspective = ( projectionMatrix[ 2 ][ 3 ] == - 1.0 ); // 4th entry in the 3rd column\n\n if ( perspective ) {\n\n if ( start.z < 0.0 && end.z >= 0.0 ) {\n\n trimSegment( start, end );\n\n } else if ( end.z < 0.0 && start.z >= 0.0 ) {\n\n trimSegment( end, start );\n\n }\n\n }\n\n // clip space\n vec4 clipStart = projectionMatrix * start;\n vec4 clipEnd = projectionMatrix * end;\n\n // ndc space\n vec2 ndcStart = clipStart.xy / clipStart.w;\n vec2 ndcEnd = clipEnd.xy / clipEnd.w;\n\n // direction\n vec2 dir = ndcEnd - ndcStart;\n\n // account for clip-space aspect ratio\n dir.x *= aspect;\n dir = normalize( dir );\n\n // perpendicular to dir\n vec2 offset = vec2( dir.y, - dir.x );\n\n // undo aspect ratio adjustment\n dir.x /= aspect;\n offset.x /= aspect;\n\n // sign flip\n if ( position.x < 0.0 ) offset *= - 1.0;\n\n // endcaps\n if ( position.y < 0.0 ) {\n\n offset += - dir;\n\n } else if ( position.y > 1.0 ) {\n\n offset += dir;\n\n }\n\n // adjust for linewidth\n offset *= linewidth;\n\n // adjust for clip-space to screen-space conversion // maybe resolution should be based on viewport ...\n offset /= resolution.y;\n\n // select end\n vec4 clip = ( position.y < 0.5 ) ? clipStart : clipEnd;\n\n // back to clip space\n offset *= clip.w;\n\n clip.xy += offset;\n\n gl_Position = clip;\n\n vec4 mvPosition = ( position.y < 0.5 ) ? start : end; // this is an approximation\n\n #include <logdepthbuf_vertex>\n #include <clipping_planes_vertex>\n #include <fog_vertex>\n\n }\n ",fragmentShader:"\n uniform vec3 diffuse;\n uniform float opacity;\n\n #ifdef USE_DASH\n\n uniform float dashSize;\n uniform float dashOffset;\n uniform float gapSize;\n\n #endif\n\n varying float vLineDistance;\n\n #include <common>\n #include <color_pars_fragment>\n #include <fog_pars_fragment>\n #include <logdepthbuf_pars_fragment>\n #include <clipping_planes_pars_fragment>\n\n varying vec2 vUv;\n\n void main() {\n\n #include <clipping_planes_fragment>\n\n #ifdef USE_DASH\n\n if ( vUv.y < - 1.0 || vUv.y > 1.0 ) discard; // discard endcaps\n\n if ( mod( vLineDistance + dashOffset, dashSize + gapSize ) > dashSize ) discard; // todo - FIX\n\n #endif\n\n float alpha = opacity;\n\n #ifdef ALPHA_TO_COVERAGE\n\n // artifacts appear on some hardware if a derivative is taken within a conditional\n float a = vUv.x;\n float b = ( vUv.y > 0.0 ) ? vUv.y - 1.0 : vUv.y + 1.0;\n float len2 = a * a + b * b;\n float dlen = fwidth( len2 );\n\n if ( abs( vUv.y ) > 1.0 ) {\n\n alpha = 1.0 - smoothstep( 1.0 - dlen, 1.0 + dlen, len2 );\n\n }\n\n #else\n\n if ( abs( vUv.y ) > 1.0 ) {\n\n float a = vUv.x;\n float b = ( vUv.y > 0.0 ) ? vUv.y - 1.0 : vUv.y + 1.0;\n float len2 = a * a + b * b;\n\n if ( len2 > 1.0 ) discard;\n\n }\n\n #endif\n\n vec4 diffuseColor = vec4( diffuse, alpha );\n\n #include <logdepthbuf_fragment>\n #include <color_fragment>\n\n gl_FragColor = vec4( diffuseColor.rgb, alpha );\n\n #include <tonemapping_fragment>\n #include <encodings_fragment>\n #include <fog_fragment>\n #include <premultiplied_alpha_fragment>\n\n }\n "};var xM=function(e){lu(i,e);var t=pu(i);function i(e){var n;return ru(this,i),n=t.call(this,{type:"LineMaterial",uniforms:ln.clone(Mn.line.uniforms),vertexShader:Mn.line.vertexShader,fragmentShader:Mn.line.fragmentShader,clipping:!0}),Object.defineProperties(du(n),{color:{enumerable:!0,get:function(){return this.uniforms.diffuse.value},set:function(e){this.uniforms.diffuse.value=e}},linewidth:{enumerable:!0,get:function(){return this.uniforms.linewidth.value},set:function(e){this.uniforms.linewidth.value=e}},dashed:{enumerable:!0,get:function(){return Boolean("USE_DASH"in this.defines)},set:function(e){Boolean(e)!==Boolean("USE_DASH"in this.defines)&&(this.needsUpdate=!0),!0===e?this.defines.USE_DASH="":delete this.defines.USE_DASH}},dashScale:{enumerable:!0,get:function(){return this.uniforms.dashScale.value},set:function(e){this.uniforms.dashScale.value=e}},dashSize:{enumerable:!0,get:function(){return this.uniforms.dashSize.value},set:function(e){this.uniforms.dashSize.value=e}},dashOffset:{enumerable:!0,get:function(){return this.uniforms.dashOffset.value},set:function(e){this.uniforms.dashOffset.value=e}},gapSize:{enumerable:!0,get:function(){return this.uniforms.gapSize.value},set:function(e){this.uniforms.gapSize.value=e}},opacity:{enumerable:!0,get:function(){return this.uniforms.opacity.value},set:function(e){this.uniforms.opacity.value=e}},resolution:{enumerable:!0,get:function(){return this.uniforms.resolution.value},set:function(e){this.uniforms.resolution.value.copy(e)}},alphaToCoverage:{enumerable:!0,get:function(){return Boolean("ALPHA_TO_COVERAGE"in this.defines)},set:function(e){Boolean(e)!==Boolean("ALPHA_TO_COVERAGE"in this.defines)&&(this.needsUpdate=!0),!0===e?(this.defines.ALPHA_TO_COVERAGE="",this.extensions.derivatives=!0):(delete this.defines.ALPHA_TO_COVERAGE,this.extensions.derivatives=!1)}}}),n.setValues(e),n}return i}(cn);xM.prototype.isLineMaterial=!0;var wM=new He,MM=new Ke,EM=function(e){lu(i,e);var t=pu(i);function i(){var e;ru(this,i),(e=t.call(this)).type="LineSegmentsGeometry";return e.setIndex([0,2,1,2,3,1,2,4,3,4,5,3,4,6,5,6,7,5]),e.setAttribute("position",new Bi([-1,2,0,1,2,0,-1,1,0,1,1,0,-1,0,0,1,0,0,-1,-1,0,1,-1,0],3)),e.setAttribute("uv",new Bi([-1,2,1,2,-1,1,1,1,-1,-1,1,-1,-1,-2,1,-2],2)),e}return au(i,[{key:"applyMatrix4",value:function(e){var t=this.attributes.instanceStart,i=this.attributes.instanceEnd;return void 0!==t&&(t.applyMatrix4(e),i.applyMatrix4(e),t.needsUpdate=!0),null!==this.boundingBox&&this.computeBoundingBox(),null!==this.boundingSphere&&this.computeBoundingSphere(),this}},{key:"setPositions",value:function(e){var t;e instanceof Float32Array?t=e:Array.isArray(e)&&(t=new Float32Array(e));var i=new ph(t,6,1);return this.setAttribute("instanceStart",new jo(i,3,0)),this.setAttribute("instanceEnd",new jo(i,3,3)),this.computeBoundingBox(),this.computeBoundingSphere(),this}},{key:"setColors",value:function(e){var t;e instanceof Float32Array?t=e:Array.isArray(e)&&(t=new Float32Array(e));var i=new ph(t,6,1);return this.setAttribute("instanceColorStart",new jo(i,3,0)),this.setAttribute("instanceColorEnd",new jo(i,3,3)),this}},{key:"fromWireframeGeometry",value:function(e){return this.setPositions(e.attributes.position.array),this}},{key:"fromEdgesGeometry",value:function(e){return this.setPositions(e.attributes.position.array),this}},{key:"fromMesh",value:function(e){return this.fromWireframeGeometry(new Js(e.geometry)),this}},{key:"fromLineSegments",value:function(e){var t=e.geometry;if(!t.isGeometry)return t.isBufferGeometry&&this.setPositions(t.attributes.position.array),this;console.error("THREE.LineSegmentsGeometry no longer supports Geometry. Use THREE.BufferGeometry instead.")}},{key:"computeBoundingBox",value:function(){null===this.boundingBox&&(this.boundingBox=new He);var e=this.attributes.instanceStart,t=this.attributes.instanceEnd;void 0!==e&&void 0!==t&&(this.boundingBox.setFromBufferAttribute(e),wM.setFromBufferAttribute(t),this.boundingBox.union(wM))}},{key:"computeBoundingSphere",value:function(){null===this.boundingSphere&&(this.boundingSphere=new ct),null===this.boundingBox&&this.computeBoundingBox();var e=this.attributes.instanceStart,t=this.attributes.instanceEnd;if(void 0!==e&&void 0!==t){var i=this.boundingSphere.center;this.boundingBox.getCenter(i);for(var n=0,r=0,o=e.count;o>r;r+=1)MM.fromBufferAttribute(e,r),n=Math.max(n,i.distanceToSquared(MM)),MM.fromBufferAttribute(t,r),n=Math.max(n,i.distanceToSquared(MM));this.boundingSphere.radius=Math.sqrt(n),isNaN(this.boundingSphere.radius)&&console.error("THREE.LineSegmentsGeometry.computeBoundingSphere(): Computed radius is NaN. The instanced position data is likely to have NaN values.",this)}}},{key:"toJSON",value:function(){}},{key:"applyMatrix",value:function(e){return console.warn("THREE.LineSegmentsGeometry: applyMatrix() has been renamed to applyMatrix4()."),this.applyMatrix4(e)}}]),i}(xc);EM.prototype.isLineSegmentsGeometry=!0;var BM=new Ke,SM=new Ke,bM=new Le,kM=new Le,DM=new Le,TM=new Ke,RM=new yt,UM=new xh,FM=new Ke,QM=new He,LM=new ct,OM=new Le,NM=function(e){lu(i,e);var t=pu(i);function i(){var e,n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:new EM,r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:new xM({color:16777215*Math.random()});return ru(this,i),(e=t.call(this,n,r)).type="LineSegments2",e}return au(i,[{key:"computeLineDistances",value:function(){for(var e=this.geometry,t=e.attributes.instanceStart,i=e.attributes.instanceEnd,n=new Float32Array(2*t.count),r=0,o=0,a=t.count;a>r;r+=1,o+=2)BM.fromBufferAttribute(t,r),SM.fromBufferAttribute(i,r),n[o]=0===o?0:n[o-1],n[o+1]=n[o]+BM.distanceTo(SM);var s=new ph(n,2,1);return e.setAttribute("instanceDistanceStart",new jo(s,1,0)),e.setAttribute("instanceDistanceEnd",new jo(s,1,1)),this}},{key:"raycast",value:function(e,t){null===e.camera&&console.error('LineSegments2: "Raycaster.camera" needs to be set in order to raycast against LineSegments2.');var i=e.ray,n=e.camera,r=n.projectionMatrix,o=this.matrixWorld,a=this.geometry,s=this.material,l=s.resolution,c=s.linewidth+(void 0!==e.params.Line2&&e.params.Line2.threshold||0),h=a.attributes.instanceStart,d=a.attributes.instanceEnd,u=-n.near,p=2*Math.max(c/l.width,c/l.height);null===a.boundingSphere&&a.computeBoundingSphere(),LM.copy(a.boundingSphere).applyMatrix4(o);var g=Math.max(n.near,LM.distanceToPoint(i.origin));OM.set(0,0,-g,1).applyMatrix4(n.projectionMatrix),OM.multiplyScalar(1/OM.w),OM.applyMatrix4(n.projectionMatrixInverse);var f=.5*Math.abs(p/OM.w);if(LM.radius+=f,!1!==e.ray.intersectsSphere(LM)){null===a.boundingBox&&a.computeBoundingBox(),QM.copy(a.boundingBox).applyMatrix4(o);var m=Math.max(n.near,QM.distanceToPoint(i.origin));OM.set(0,0,-m,1).applyMatrix4(n.projectionMatrix),OM.multiplyScalar(1/OM.w),OM.applyMatrix4(n.projectionMatrixInverse);var A=.5*Math.abs(p/OM.w);if(QM.max.x+=A,QM.max.y+=A,QM.max.z+=A,QM.min.x-=A,QM.min.y-=A,QM.min.z-=A,!1!==e.ray.intersectsBox(QM)){i.at(1,DM),DM.w=1,DM.applyMatrix4(n.matrixWorldInverse),DM.applyMatrix4(r),DM.multiplyScalar(1/DM.w),DM.x*=l.x/2,DM.y*=l.y/2,DM.z=0,TM.copy(DM),RM.multiplyMatrices(n.matrixWorldInverse,o);for(var y=0,v=h.count;v>y;y+=1){if(bM.fromBufferAttribute(h,y),kM.fromBufferAttribute(d,y),bM.w=1,kM.w=1,bM.applyMatrix4(RM),kM.applyMatrix4(RM),!(bM.z>u&&kM.z>u)){if(bM.z>u)bM.lerp(kM,(bM.z-u)/(bM.z-kM.z));else if(kM.z>u){kM.lerp(bM,(kM.z-u)/(kM.z-bM.z))}bM.applyMatrix4(r),kM.applyMatrix4(r),bM.multiplyScalar(1/bM.w),kM.multiplyScalar(1/kM.w),bM.x*=l.x/2,bM.y*=l.y/2,kM.x*=l.x/2,kM.y*=l.y/2,UM.start.copy(bM),UM.start.z=0,UM.end.copy(kM),UM.end.z=0;var C=UM.closestPointToPointParameter(TM,!0);UM.at(C,FM);var I=be.lerp(bM.z,kM.z,C),x=I>=-1&&1>=I,w=TM.distanceTo(FM)<.5*c;if(x&&w){UM.start.fromBufferAttribute(h,y),UM.end.fromBufferAttribute(d,y),UM.start.applyMatrix4(o),UM.end.applyMatrix4(o);var M=new Ke,E=new Ke;i.distanceSqToSegment(UM.start,UM.end,E,M),t.push({point:E,pointOnLine:M,distance:i.origin.distanceTo(E),object:this,face:null,faceIndex:y,uv:null,uv2:null})}}}}}}}]),i}(nn);NM.prototype.LineSegments2=!0;var PM=new Ge,GM=new Ke(1,0,0),KM=new Ke(0,1,0),VM=new Ke(0,0,1),YM=new yt,HM=function(e,t,i,n,r,o,a,s,l,c){this.enable=e,this.visible=t,this.rotatable=i,this.planeOffset=n,this.position=r,this.scale=o,this.quaternion=a,this.cubeSize=s,this.center=l,this.normalIndex=c},jM=function(e){lu(i,e);var t=pu(i);function i(e,n){var r;return ru(this,i),(r=t.call(this,Vp.FILLCLIPPLANE,{priority:20})).cubeSize=e.clone(),r.originBoundingBox=(new He).setFromCenterAndSize(n,e),r.boundingBox=r.originBoundingBox.clone(),r.center=n.clone(),r.lengthSize=.8*r.originBoundingBox.getSize(new Ke).length(),r.planeOffset=0,r.normalIndex=3,r.visible=!1,r.rotatable=!1,r.hit=!1,r.clipplane=new Le,r.observer=null,r.renderClipPlane=new Jt,r.angleA=0,r.angleB=0,r.capsIntersectPosition=[],r.capsIntersectContour={},r.clipPlaneBox=null,r.innerClipping=!1,r.limitDragging=!0,r.orthoViewProjMatrix=new yt,r.planeWidth=null,r.planeHeight=null,r.uniforms={iClipPlane:{value:0},vClipPlane:{value:new Array(new Le)}},r.planeMaterial=new ig({color:6724044,opacity:.3,transparent:!0,side:2,lights:!0}),r.planeMaterial.visible=!1,r.planeHighLightMatrial=new ig({color:6724044,opacity:.3,transparent:!0,side:2,lights:!0}),r}return au(i,[{key:"initPlaneModel",value:function(){for(var e=this.children.length-1;e>=0;e-=1)this.remove(this.children[e]);this.planeOffset=0;var t=this.lengthSize,i=new In(t,t),n=new nn(i,this.planeMaterial);n.name="fillClipPlane",n.customTag=!0,n.renderOrder=90,this.position.copy(this.center),this.clipplane.set(0,0,1,0),this.planeMesh=n,this.planeMesh.geometry.computeBoundingBox(),this.clipPlaneBox=this.planeMesh.geometry.boundingBox,this.add(n)}},{key:"initWireframes",value:function(){var e=.5*this.lengthSize,t=[-e,e,0,e,e,0,-e,-e,0,e,-e,0],i=new Ni,n=new ig({color:2003199,lights:!0});i.setIndex([0,1,1,3,3,2,2,0]),i.setAttribute("position",new Bi(t,3));var r=new La(i,n);r.name="Wireframes",r.customTag=!0,this.wireframeMesh=r,this.add(r)}},{key:"resizeGeometry",value:function(e,t){var i=new In(e,t);this.planeMesh.geometry=i,this.planeMesh.geometry.computeBoundingBox(),this.clipPlaneBox=this.planeMesh.geometry.boundingBox;var n=.5*e,r=.5*t,o=[-n,r,0,n,r,0,-n,-r,0,n,-r,0],a=new Ni;if(a.setIndex([0,1,1,3,3,2,2,0]),a.setAttribute("position",new Bi(o,3)),this.wireframeMesh.geometry=a,this.capPlane){var s=new In(e,t);this.capPlane.planeMesh.geometry=s}}},{key:"getCoordinate",value:function(){var e=this.planeWidth?.5*this.planeWidth:.5*this.lengthSize,t=this.planeHeight?.5*this.planeHeight:.5*this.lengthSize,i=new Ke(-e,t,0);i.applyMatrix4(this.matrix);var n=new Ke(e,t,0);n.applyMatrix4(this.matrix);var r=new Ke(-e,-t,0);return r.applyMatrix4(this.matrix),{axisX:i.clone().sub(n).normalize(),axisY:i.clone().sub(r).normalize()}}},{key:"initCapsPlane",value:function(){if(this.capPlane)return this.capPlane;this.planeMesh||this.initPlaneModel();var e=this.lengthSize,t=new In(e,e),i=new ig({color:16776960,side:2,stencilWrite:!0,stencilFunc:de,stencilRef:1,stencilFuncMask:255,stencilFail:oe,stencilZFail:oe,stencilZPass:oe}),n=new nn(t,i),r=this.planeMesh;n.matrixWorld=r.matrixWorld,n.matrix=this.matrix;for(var o=.5*this.lengthSize,a=.01*this.lengthSize,s=[],l=o-a;l>-o;l-=a)s.push(l,o,0),s.push(o,l,0);for(l=-o+a;o>l;l+=a)s.push(-o,l,0),s.push(l,-o,0);var c=new xM({color:2236962,stencilWrite:!0,stencilFunc:de,stencilRef:1,stencilFuncMask:255,stencilFail:oe,stencilZFail:oe,stencilZPass:oe});c.linewidth=1,c.resolution.set(window.innerWidth,window.innerHeight),c.depthTest=!1;var h=new EM;h.setPositions(s);var d=new NM(h,c);return d.matrix=this.matrix,d.matrixWorld=r.matrixWorld,this.capPlane={planeMesh:n,lineMesh:d},this.capPlane}},{key:"addToCapsWireframe",value:function(e){if(this.capsWireframe)this.capsWireframe.geometry.setPositions(this.capsIntersectPosition),this.capsWireframe.geometry._maxInstanceCount=void 0;else{var t=new EM;t.setPositions(this.capsIntersectPosition),this.capsWireframe=new NM(t,new xM({color:2236962,linewidth:1,polygonOffset:!0,polygonOffsetFactor:-1,polygonOffsetUnits:-10,resolution:new ke(window.innerWidth,window.innerHeight)})),e.manager.scene.getOrCreateGroup(Vp.CAPSWIREFRAME,{globalSpace:!0}).add(this.capsWireframe),this.capsWireframe.updateMatrixWorld(!0)}}},{key:"clearCapsWireframe",value:function(){this.capsIntersectPosition.length=0,this.capsIntersectPosition=[],this.capsWireframe&&this.capsWireframe.geometry.deleteAttribute("instanceStart"),this.capsWireframe&&this.capsWireframe.geometry.deleteAttribute("instanceEnd")}},{key:"calculateClippingIds",value:function(){}},{key:"updateClippingParams",value:function(e){}},{key:"getFillClipBoundingBox",value:function(){return this.boundingBox}},{key:"getFillClipPlaneBoundingBox",value:function(){var e=this.clipPlaneBox.clone();return e.applyMatrix4(this.planeMesh.matrix),e}},{key:"calculateFillClipBoundingBox",value:function(e){this.boundingBox=this.originBoundingBox.clone(),0!==this.clipplane.x?1===this.clipplane.x?this.boundingBox.max.x=e.x:this.boundingBox.min.x=e.x:0!==this.clipplane.y?1===this.clipplane.y?this.boundingBox.max.y=e.y:this.boundingBox.min.y=e.y:0!==this.clipplane.z&&(1===this.clipplane.z?this.boundingBox.max.z=e.z:this.boundingBox.min.z=e.z)}},{key:"enable",value:function(e,t){this.visible=t,this.uniforms.iClipPlane.value=e?1:0,this.capPlane&&(this.capPlane.lineMesh.visible=t,this.capPlane.planeMesh.visible=t),this.update()}},{key:"isEnabled",value:function(){return 0!==this.uniforms.iClipPlane.value}},{key:"update",value:function(){if(this.updateMatrixWorld(),YM.copy(this.matrix).invert(),YM.transpose(),this.uniforms.vClipPlane.value[0]=this.clipplane.clone().applyMatrix4(YM),this.innerClipping){var e=this.planeWidth,t=this.planeHeight;this.orthoCamera=new pc(-e/2,e/2,t/2,-t/2,.1,2e3),this.orthoCamera.position.set(this.position.x,this.position.y,this.position.z);var i=this.uniforms.vClipPlane.value[0].clone(),n=new Ke(i.x,i.y,i.z);n.normalize();var r=new Ke(this.position.x,this.position.y,this.position.z);r.add(n),this.orthoCamera.lookAt(r),this.orthoCamera.updateMatrixWorld(!0),this.orthoViewProjMatrix.copy(this.orthoCamera.projectionMatrix),YM.copy(this.orthoCamera.matrixWorld).invert(),this.orthoViewProjMatrix.multiply(YM)}this.updateClippingParams(this.uniforms),this.observer&&this.observer()}},{key:"getClipPlane",value:function(){return this.clipplane.clone()}},{key:"offset",value:function(e){var t=this.cubeSize.length();this.planeOffset+=e,this.limitDragging&&Math.abs(this.planeOffset)>.5*t&&(this.planeOffset=this.planeOffset>0?.5*t:.5*-t);var i=this.uniforms.vClipPlane.value[0].clone(),n=new Ke(i.x,i.y,i.z);n.normalize();var r=new Ke(n.x*this.planeOffset,n.y*this.planeOffset,n.z*this.planeOffset);this.position.copy(this.center).add(r),this.update()}},{key:"setOffset",value:function(e){var t=this.cubeSize.length();this.planeOffset=e,this.limitDragging&&Math.abs(e)>.5*t&&(this.planeOffset=e>0?.5*t:.5*-t);var i=this.uniforms.vClipPlane.value[0].clone(),n=new Ke(i.x,i.y,i.z);n.normalize();var r=new Ke(n.x*this.planeOffset,n.y*this.planeOffset,n.z*this.planeOffset);this.position.copy(this.center).add(r),this.update()}},{key:"changeNormal",value:function(e){this.quaternion.set(0,0,0,1),this.angleA=0,this.angleB=0,this.setNormal(e)}},{key:"setNormal",value:function(e){var t=this.planeMesh,i=this.wireframeMesh;0===e?(this.clipplane.set(1,0,0,0),t.rotation.set(0,Math.PI/2,0),i.rotation.set(0,Math.PI/2,0)):1===e?(this.clipplane.set(-1,0,0,0),t.rotation.set(0,-Math.PI/2,0),i.rotation.set(0,-Math.PI/2,0)):2===e?(this.clipplane.set(0,0,1,0),t.rotation.set(Math.PI,0,0),i.rotation.set(Math.PI,0,0)):3===e?(this.clipplane.set(0,0,-1,0),t.rotation.set(0,0,0),i.rotation.set(0,0,0)):4===e?(this.clipplane.set(0,1,0,0),t.rotation.set(-Math.PI/2,0,0),i.rotation.set(-Math.PI/2,0,0)):5===e&&(this.clipplane.set(0,-1,0,0),t.rotation.set(Math.PI/2,0,0),i.rotation.set(Math.PI/2,0,0)),this.normalIndex=e,t.updateMatrixWorld(),i.updateMatrixWorld(),this.capPlane&&(this.capPlane.planeMesh.matrixWorld=t.matrixWorld,this.capPlane.lineMesh.matrixWorld=t.matrixWorld),this.update()}},{key:"rotX",value:function(e){PM.setFromAxisAngle(GM,e),this.quaternion.multiply(PM),this.update()}},{key:"rotY",value:function(e){PM.setFromAxisAngle(KM,e),this.quaternion.multiply(PM),this.update()}},{key:"rotateByAxis",value:function(e,t){PM.setFromAxisAngle(e,t),this.quaternion.multiply(PM)}},{key:"rotateAngleOffset",value:function(e,t){var i=this.normalIndex;e=e%360/180*Math.PI,0===i||1===i?("y"===t&&this.rotateByAxis(VM,e),"z"===t&&this.rotateByAxis(KM,e)):2===i||3===i?("x"===t&&this.rotateByAxis(GM,e),"z"===t&&this.rotateByAxis(KM,e)):4!==i&&5!==i||("x"===t&&this.rotateByAxis(GM,e),"y"===t&&this.rotateByAxis(VM,e)),this.update()}},{key:"setRotateAngle",value:function(e,t){this.quaternion.set(0,0,0,1);var i=this.normalIndex;t=0>(t=void 0===t?this.angleB:t%360)?360+t:t,this.angleA=e=0>(e=void 0===e?this.angleA:e%360)?360+e:e,this.angleB=t,e=e/180*Math.PI,t=t/180*Math.PI,0===i||1===i?(t=0===i?t:-t,this.rotateByAxis(VM,e=0===i?-e:e),this.rotateByAxis(KM,t)):2===i||3===i?(this.rotateByAxis(GM,e),this.rotateByAxis(KM,t)):4!==i&&5!==i||(t=3===i?t:-t,this.rotateByAxis(GM,e=3===i?-e:e),this.rotateByAxis(VM,t)),this.update()}},{key:"getRotateAngle",value:function(){return{angleA:this.angleA,angleB:this.angleB}}},{key:"highLight",value:function(){this.planeMesh.material=this.planeHighLightMatrial}},{key:"cancelHighLight",value:function(){this.planeMesh.material=this.planeMaterial,this.hit=!1}},{key:"store",value:function(){return new HM(!!this.uniforms.iClipPlane.value,this.visible,this.rotatable,this.planeOffset,this.position.clone(),this.scale.clone(),this.quaternion.clone(),this.cubeSize.clone(),this.center.clone())}},{key:"restore",value:function(e){this.enable(e.enable,e.visible),this.rotatable=e.rotatable,this.planeOffset=e.planeOffset,this.position.copy(e.position),this.scale.copy(e.scale),this.quaternion._w=e.quaternion._w,this.quaternion._x=e.quaternion._x,this.quaternion._y=e.quaternion._y,this.quaternion._z=e.quaternion._z,this.normalIndex=void 0===e.normalIndex?this.normalIndex:e.normalIndex,this.setNormal(this.normalIndex)}},{key:"setProcess",value:function(e){var t=this.cubeSize.length();e>1?e=1:-1>e&&(e=-1),this.planeOffset=e*t*.5;var i=this.uniforms.vClipPlane.value[0].clone(),n=new Ke(i.x,i.y,i.z);n.normalize();var r=new Ke(n.x*this.planeOffset,n.y*this.planeOffset,n.z*this.planeOffset);this.position.copy(this.center).add(r),this.update()}},{key:"restoreRotation",value:function(){this.quaternion.set(0,0,0,1),this.update()}},{key:"getProcess",value:function(){var e=this.cubeSize.length();return this.planeOffset/e*2}},{key:"init",value:function(){this.initPlaneModel(),this.initWireframes()}},{key:"hitTest",value:function(e){if(this.visible){var t=null,i=null;if(this.hit=this.raycast(e),this.hit){var n=e.ray,r=new Jt,o=this.uniforms.vClipPlane.value[0];r.setComponents(o.x,o.y,o.z,o.w),t=n.distanceToPlane(r),i=0>n.direction.dot(r.normal)}return{sign:i,distance:t}}this.hit=!1}},{key:"raycast",value:function(e,t){var i=[];return this.planeMesh.raycast(e,i),i.length>0}},{key:"resize",value:function(e,t){var i=e.length()/this.lengthSize;this.scale.set(i,i,i),this.cubeSize.copy(e),t&&(this.center=t.clone(),this.position.copy(this.center)),this.offset(0),this.updateMatrixWorld()}},{key:"setBorder",value:function(e,t,i){this.planeWidth=e,this.planeHeight=t,this.resizeGeometry(e,t),this.cubeSize.set(1,e,t),this.originBoundingBox=(new He).setFromCenterAndSize(this.center,this.cubeSize),this.boundingBox=this.originBoundingBox.clone(),this.innerClipping=!wp.isDefined(i)||i,this.limitDragging=!1,this.update()}},{key:"getSideLength",value:function(){return this.lengthSize*this.scale.x}},{key:"updateCamera",value:function(e){!1!==this.visible&&(e.calculateNearFar({fillClipPlane:!0}),e.cameraControl.updateCamera())}}]),i}(cm),WM="\n #include <common>\n #include <logdepthbuf_pars_vertex>\n\n varying vec2 vUv;\n varying vec3 vNormal;\n\n void main()\n {\n vUv = vec2( uv.x, uv.y );\n vNormal = normal;\n\n gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );\n\n #include <logdepthbuf_vertex>\n }\n ",JM="\n uniform vec3 color;\n uniform float opacity;\n uniform float time;\n uniform vec3 moveDir;\n\n varying vec2 vUv;\n varying vec3 vNormal;\n\n #include <common>\n #include <packing>\n #include <logdepthbuf_pars_fragment>\n\n void main(void){\n #include <logdepthbuf_fragment>\n\n vec3 col = 0.5 + 0.5*cos(time+vUv.xyx+vec3(0,2,4));\n\n float cusOpacity = 0.0;\n\n if(moveDir.x * vNormal.x < 0.1 || moveDir.y * vNormal.y < 0.1 || moveDir.z * vNormal.z < 0.1){\n cusOpacity = opacity;\n }\n\n if(dot(moveDir, vNormal) < 0.01){\n cusOpacity = 0.0;\n }\n\n gl_FragColor = vec4(col, cusOpacity);\n }\n ",zM=function(e){lu(i,e);var t=pu(i);function i(){var e,n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};ru(this,i);var r=Wg(n.opacity,.6),o={opacity:{value:r},time:{value:0},moveDir:{value:new Ke}};return(e=t.call(this,{uniforms:o,vertexShader:WM,fragmentShader:JM,transparent:!0,depthTest:!1,depthWrite:!1,side:2})).HighLightFaceMaterial=!0,e.type="DynamicTexture1Material",e.setValues(n),e}return au(i,[{key:"time",get:function(){return this.uniforms.time.value},set:function(e){this.uniforms.time.value=e}},{key:"moveDir",get:function(){return this.uniforms.moveDir.value},set:function(e){this.uniforms.moveDir.value.copy(e)}}]),i}(cn),qM=function(e){lu(i,e);var t=pu(i);function i(){var e,n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};ru(this,i);var r=n.box,o=Wg(n.color,16776960),a=Wg(n.createHighLightMesh,!1),s=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]),l=[1,1,1,-1,1,1,-1,-1,1,1,-1,1,1,1,-1,-1,1,-1,-1,-1,-1,1,-1,-1],c=new Ni;return c.setIndex(new Ai(s,1)),c.setAttribute("position",new Bi(l,3)),(e=t.call(this,c,new Sa({color:o,toneMapped:!1}))).box=r,e.type="Box3Helper",e.geometry.computeBoundingSphere(),e._scale=(new Ke).copy(e.scale),e.translate=new Ke,e._translateArray=[],e.cacheLength=3,e.sizeChange=!1,e.highLightMesh=void 0,e.isCreateHighLightMesh=a,e.isCreateHighLightMesh&&!jg(e.highLightMesh)&&e.createHighLightMesh(),e}return au(i,[{key:"sizeX",get:function(){return 2*this.scale.x}},{key:"sizeY",get:function(){return 2*this.scale.y}},{key:"sizeZ",get:function(){return 2*this.scale.z}},{key:"size",get:function(){return{x:this.sizeX,y:this.sizeY,z:this.sizeZ}}},{key:"createHighLightMesh",value:function(){var e=new on(1,1,1),t=new nn(e,new zM);t.updateMatrixWorld(),t.scale.multiplyScalar(2),this.highLightMesh=t,this.addObject(t)}},{key:"updateMatrixWorld",value:function(e){var t=this.box;t.isEmpty()||(t.getCenter(this.position),t.getSize(this._scale),this._scale.multiplyScalar(.5),this.sizeChange=!Ke.equalsEps(this.scale,this._scale),this.scale.copy(this._scale),gu(cu(i.prototype),"updateMatrixWorld",this).call(this,e))}},{key:"setTranslate",value:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:0;this.translate.set(e,t,i)}},{key:"resetTranslate",value:function(){this._translateArray=[],this.translate.set(0,0,0)}},{key:"updateFixedFrame",value:function(e){this.sizeChange=!1,this.isCreateHighLightMesh&&!jg(this.highLightMesh)&&this.createHighLightMesh(),jg(this.highLightMesh)&&(this.highLightMesh.material.time=.1*e.frameNumber,this.highLightMesh.material.moveDir=this.translate)}}]),i}(La),ZM=function(){function e(t){var i;ru(this,e),this.name="DeveloperError",this.message=t;try{throw new Error}catch(e){i=e.stack}this.stack=i,jg(Object.create)&&(this.prototype=Object.create(Error.prototype))}return au(e,[{key:"toString",value:function(){var e=this.name+": "+this.message;return jg(this.stack)&&(e+="\n"+this.stack.toString()),e}}],[{key:"throwInstantiationError",value:function(){throw new e("This function defines an interface and should not be called directly.")}}]),e}();function XM(){return!0}function _M(e,t){function i(){throw new ZM(t)}for(var n in t=Wg(t,"This object was destroyed, i.e., destroy() was called."),e)"function"==typeof e[n]&&(e[n]=i);e.isDestroyed=XM}var $M=function(e){lu(i,e);var t=pu(i);function i(e){var n;return ru(this,i),(n=t.call(this))._scene=e,n._viewerImpl=e.viewerImpl,n.models=new Map,n.boxHelperMap=new Map,n}return au(i,[{key:"scene",get:function(){return this._scene}},{key:"viewerImpl",get:function(){return this._viewerImpl}},{key:"updateFromModel",value:function(e,t){this.models.set(e,t)}},{key:"updateBoxHelper",value:function(e){jg(this.boxHelperMap.get(e))}},{key:"createBoxHelper",value:function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},i=this.boxHelperMap.get(e);if(jg(i))i.visible=!0;else{var n=this.getBox(e);if(jg(n)){var r=Wg(t.createHighLightMesh,!1),o=Wg(t.color,13244156);(i=new qM({box:(new He).copy(n),color:o,createHighLightMesh:r})).material.depthTest=!1,i.updateMatrixWorld(!0),this.addObject(i),this.boxHelperMap.set(e,i)}}}},{key:"getBox",value:function(e){var t=this.models.get(e);return jg(t)&&t instanceof Jg?(t.computeBoundingBox(),t.boundingBox):this.viewerImpl.getComponentInfoByUserId(e).boundingBox}},{key:"getHelper",value:function(e){return this.boxHelperMap.get(e)}},{key:"removeHelper",value:function(e){var t=this.getHelper(e);jg(t)&&(this.boxHelperMap.delete(e),this.removeObject(t))}},{key:"destroy",value:function(){for(var e=this.length,t=0;e>t;t++){var i=this.get(t);this.removeObject(i)}return _M(this)}}]),i}(Jg),eE=new Ke,tE=new yt,iE=new He,nE=new Ke,rE=new Ke,oE=new Ke,aE=new Ke,sE=new Ke,lE=new Ke,cE=new Ke,hE=new Ke,dE=new yt,uE=void 0,pE=void 0,gE=void 0,fE=void 0,mE=new Ke,AE=void 0,yE=new Ke,vE=function(e){lu(i,e);var t=pu(i);function i(e){var n,r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return ru(this,i),(n=t.call(this)).innerCollisionThreshold=Wg(r.innerCollisionThreshold,500),n.dampingDistance=new Ke(100,100,100),n.scaleThreshold=1,n._scene=e,n._viewerImpl=e.viewerImpl,n._aabbCollection=e.aabbCollection,n.transformControl=void 0,n.selectedObjectId=void 0,n._isExternalObject=!1,n._collection=void 0,n.selectObjects=[],n._selectedComponentKey=void 0,n._targetObjects=new Set,n.targetObjectsMap=new Map,n.selectObjectBoxHelper=void 0,n.selectBoxCenter=new Ke,n.selectBoxSize=new Ke,n.selectTransformBoxHelper=void 0,n.transformBoxCenter=new Ke,n.transformBoxSize=new Ke,n.targetBox=new He,n.targetBoxCenter=new Ke,n.targetBoxSize=new Ke,n.targetObjectExpandBox=new He,n.targetObjectExpandBoxSize=new Ke,n.targetObjectExpandBoxCenter=new Ke,n.adsorbBoxSize=new Ke,n.adsorbBoxCenter=new Ke,n.isTargetBoxColliding=!1,n.isColliding=!1,n._originIsColliding=!1,n.lastCollidingId=void 0,n._changeMethods={adsorbObjectChange:n.update.bind(du(n)),mouseUp:n.reSetSelectTransformBoxHelper.bind(du(n))},n.sortDistanceTargetArray=[],n._originId=void 0,n.targetId=void 0,n._enabled=!1,n.centerOffset=new Ke,n.adsorbingEvent={type:"adsorbing",translate:new Ke},n}return au(i,[{key:"enabled",get:function(){return this._enabled},set:function(e){this._enabled=e,e||jg(this.targetAABB)&&(this.targetAABB.resetTranslate(),this.viewerImpl.cancelTransformComponent()),this.visible=e}},{key:"viewerImpl",get:function(){return this.scene.viewerImpl}},{key:"isExternalObject",get:function(){return this._isExternalObject}},{key:"originId",get:function(){return this._originId}},{key:"changeMethods",get:function(){return this._changeMethods}},{key:"scene",get:function(){return this._scene}},{key:"aabbCollection",get:function(){return this._aabbCollection}},{key:"targetObjects",get:function(){return this._targetObjects}},{key:"cameraControl",get:function(){return this._viewerImpl.cameraControl}},{key:"targetAABB",get:function(){if(jg(this.targetId))return this.aabbCollection.getHelper(this.targetId)}},{key:"targetCollisionThreshold",get:function(){return jg(this.targetId)?this.targetObjectsMap.get(this.targetId).collisionThreshold:0}},{key:"transformBox",get:function(){return this.selectTransformBoxHelper.box}},{key:"setSelectedObjectByComponentId",value:function(e){if(!jg(e)||!this.enabled)return!1;this.targetObjectsMap.has(e)&&(this.targetObjectsMap.delete(e),this.lastCollidingId=void 0),this.selectedObjectId=e,iE.copy(this.aabbCollection.getBox(e)),jg(this.selectObjectBoxHelper)&&(this.removeObject(this.selectObjectBoxHelper),this.selectObjectBoxHelper=void 0),this.selectObjectBoxHelper=this.createBoxHelper(iE,!0),jg(this.selectTransformBoxHelper)&&(this.removeObject(this.selectTransformBoxHelper),this.selectTransformBoxHelper=void 0),this.selectTransformBoxHelper=this.createBoxHelper(iE),this.selectTransformBoxHelper.material.depthTest=!1,this.selectTransformBoxHelper.material.depthWrite=!1,this.componentTransformTool=this.viewerImpl.controlManager.componentTransformTool,this.transformControl=this.componentTransformTool.transformControl,this.transformControl.removeTranslateXYZ(),this._isExternalObject=!1,this._collection=void 0}},{key:"setSelectedObjectByCollection",value:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};yE.set(0,0,0);var t=e.collection,i=Wg(e.updateBoundingBox,!0);if(!jg(t))throw new ZM("collection参数缺失!");t.updateMatrixWorld(!0),i&&t.computeBoundingBox();var n=t.userData.modelKey;yE=t.getBoundingBoxCenter(yE),t.matrixWorld.decompose(t.position,t.quaternion,t.scale),this.centerOffset.subVectors(t.position,yE),this.aabbCollection.updateFromModel(t.userData.modelKey,t),this.selectedObjectId=n,iE.copy(this.aabbCollection.getBox(n)),jg(this.selectObjectBoxHelper)&&(this.removeObject(this.selectObjectBoxHelper),this.selectObjectBoxHelper=void 0),this.selectObjectBoxHelper=this.createBoxHelper(iE,!0),jg(this.selectTransformBoxHelper)&&(this.removeObject(this.selectTransformBoxHelper),this.selectTransformBoxHelper=void 0),this.selectTransformBoxHelper=this.createBoxHelper(iE),this.selectTransformBoxHelper.material.depthTest=!1,this.componentTransformTool=this.viewerImpl.controlManager.componentTransformTool,this.transformControl=this.componentTransformTool.transformControl,this.transformControl.removeTranslateXYZ(),this._isExternalObject=!0,this._collection=t}},{key:"endAdsorb",value:function(){var e=arguments.length>0&&void 0!==arguments[0]&&arguments[0];jg(this.targetAABB)&&this.targetAABB.resetTranslate(),this._isExternalObject=!1,this._collection=void 0,this.selectedObjectId=void 0,this.centerOffset.set(0,0,0),this.removeObject(this.selectObjectBoxHelper),this.selectObjectBoxHelper=void 0,this.removeObject(this.selectTransformBoxHelper),this.selectTransformBoxHelper=void 0,this.viewerImpl.cancelTransformComponent(e)}},{key:"setTransformControl",value:function(e){if(!jg(e))return!1;this.componentTransformTool=e,this.transformControl=e.transformControl,this.transformControl.removeTranslateXYZ();var t=this.changeMethods,i=t.adsorbObjectChange,n=t.mouseUp;return this.transformControl.hasEventListener("objectChange",i)||this.transformControl.addEventListener("objectChange",i),this.transformControl.hasEventListener("mouseUp",n)||this.transformControl.addEventListener("mouseUp",n),!0}},{key:"removeTransformControl",value:function(){var e=this.transformControl,t=this.changeMethods,i=t.adsorbObjectChange;e.removeEventListener("mouseUp",t.mouseUp),e.removeEventListener("objectChange",i),this.componentTransformTool=void 0}},{key:"reset",value:function(){var e=this.control,t=this.changeMethods,i=t.adsorbObjectChange,n=t.mouseUp;e.hasEventListener("adsorbObjectChange",i)&&e.removeEventListener("adsorbObjectChange",i),e.hasEventListener("mouseUp",n)&&e.removeEventListener("mouseUp",n),this.transformControl=void 0}},{key:"addTargetObjectByIds",value:function(e){var t,i=vu(e);try{for(i.s();!(t=i.n()).done;){var n=t.value;this.targetObjects.add(n.componentId);var r=Wg(n.collisionThreshold,this.innerCollisionThreshold);Wg(n.createHighLightMesh,!0)&&this.aabbCollection.createBoxHelper(n.componentId,{createHighLightMesh:!0});var o=this.aabbCollection.getBox(n.componentId),a=(new He).copy(o),s=(new He).copy(a).expandByScalar(r);this.targetObjectsMap.set(n.componentId,{id:n.componentId,collisionThreshold:r,box:a,boxCenter:a.getCenter(new Ke),boxSize:a.getSize(new Ke),expandBox:s,expandBoxCenter:s.getCenter(new Ke),expandBoxSize:s.getSize(new Ke),distanceToSelectCenter:1/0,translateDirDistance:-1/0})}}catch(e){i.e(e)}finally{i.f()}}},{key:"removeTargetObjectByIds",value:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:[];if(Array.isArray(e)&&0!==e.length){var t,i=vu(e);try{for(i.s();!(t=i.n()).done;){var n=t.value;this.targetObjectsMap.has(n)&&(this.targetObjectsMap.delete(n),this.aabbCollection.removeHelper(n))}}catch(e){i.e(e)}finally{i.f()}}}},{key:"createBoxHelper",value:function(e,t){var i=new qM({box:(new He).copy(e),color:65280,createHighLightMesh:t});return i.updateMatrixWorld(!0),this.addObject(i),i}},{key:"updateTotalBox",value:function(){this.selectObjectBoxHelper.updateMatrixWorld(!0),this.selectObjectBoxHelper.box.getCenter(this.selectBoxCenter),this.selectObjectBoxHelper.box.getSize(this.selectBoxSize),this.selectTransformBoxHelper.updateMatrixWorld(!0),this.selectTransformBoxHelper.box.getCenter(this.transformBoxCenter),this.selectTransformBoxHelper.box.getSize(this.transformBoxSize)}},{key:"updateDistance",value:function(){var e=this.selectObjectBoxHelper.position;return rE=rE.addVectors(this.targetObjectExpandBoxSize,this.selectBoxSize).multiplyScalar(.5),oE=oE.addVectors(this.targetBoxSize,this.selectBoxSize).multiplyScalar(.5),aE=aE.subVectors(this.targetBoxSize,this.selectBoxSize).multiplyScalar(.5),sE.set(Math.abs(this.transformBoxCenter.x-this.targetBoxCenter.x),Math.abs(this.transformBoxCenter.y-this.targetBoxCenter.y),Math.abs(this.transformBoxCenter.z-this.targetBoxCenter.z)),lE.set(Math.abs(rE.x-sE.x),Math.abs(rE.y-sE.y),Math.abs(rE.z-sE.z)),cE.set(Math.abs(e.x-this.targetBoxCenter.x),Math.abs(e.y-this.targetBoxCenter.y),Math.abs(e.z-this.targetBoxCenter.z)),{targetExpandSelectAddSize:rE,transformTargetDistance:sE,distance:lE,selectTargetDistance:cE}}},{key:"updateTotalMatrix",value:function(e){this.updateSelectTransformBoxHelper(e),this.updateSelectObjectBoxHelper(e)}},{key:"updateHelperCenter",value:function(e){this.selectTransformBoxHelper.box.applyMatrix4(tE),this.selectTransformBoxHelper.updateMatrix(),this.selectTransformBoxHelper.updateMatrixWorld(!0),this.selectTransformBoxHelper.box.getCenter(this.transformBoxCenter),this.selectTransformBoxHelper.box.getSize(this.transformBoxSize)}},{key:"sortByDistance",value:function(){var e,t=this.targetObjectsMap,i=vu(t.keys());try{for(i.s();!(e=i.n()).done;){var n=t.get(e.value);n.distanceToSelectCenter=n.boxCenter.distanceToSquared(this.selectObjectBoxHelper.position)}}catch(e){i.e(e)}finally{i.f()}var r=this.sortDistanceTargetArray;r=Array.from(t),this.sortDistanceTargetArray=r.sort((function(e,t){return e[1].distanceToSelectCenter-t[1].distanceToSelectCenter}))}},{key:"sortByDirX",value:function(){var e,t=this.targetObjectsMap,i=Math.sign(eE.x),n=this.selectTransformBoxHelper.position,r=this.selectTransformBoxHelper.size,o=vu(t.values());try{for(o.s();!(e=o.n()).done;){var a=e.value,s=a.boxCenter.x-a.boxSize.x/2-(n.x+r.x/2),l=a.boxCenter.x+a.boxSize.x/2-(n.x-r.x/2),c=a.boxCenter.z-a.boxSize.z/2-(n.z+r.z/2),h=a.boxCenter.z+a.boxSize.z/2-(n.z-r.z/2);if(Math.abs(a.boxCenter.x-n.x)<a.boxSize.x/2+r.x/2&&(h>be.EPSILON7||c>be.EPSILON7)){AE={id:this._originId};break}a.translateDirDistance=i>0?s:l,jg(AE)?(this.selectTransformBoxHelper.box.intersectsBox(a.expandBox)||this.selectTransformBoxHelper.box.containsBox(a.expandBox))&&Math.abs(a.translateDirDistance)<Math.abs(AE.translateDirDistance)&&(AE=a):(AE=a).translateDirDistance=a.translateDirDistance}}catch(e){o.e(e)}finally{o.f()}}},{key:"sortByDirY",value:function(){var e=this.targetObjectsMap,t=Math.sign(eE.y);AE=void 0;var i,n=this.selectTransformBoxHelper.position,r=this.selectTransformBoxHelper.size,o=vu(e.values());try{for(o.s();!(i=o.n()).done;){var a=i.value,s=a.boxCenter.y-a.boxSize.y/2-(n.y+r.y/2),l=a.boxCenter.y+a.boxSize.y/2-(n.y-r.y/2),c=a.boxCenter.z-a.boxSize.z/2-(n.z+r.z/2),h=a.boxCenter.z+a.boxSize.z/2-(n.z-r.z/2);if(Math.abs(a.boxCenter.y-n.y)<a.boxSize.y/2+r.y/2&&(c>be.EPSILON7||h>be.EPSILON7)){AE={id:this._originId};break}a.translateDirDistance=t>0?s:l,jg(AE)?(this.selectTransformBoxHelper.box.intersectsBox(a.expandBox)||this.selectTransformBoxHelper.box.containsBox(a.expandBox))&&Math.abs(a.translateDirDistance)<Math.abs(AE.translateDirDistance)&&(AE=a):(AE=a).translateDirDistance=a.translateDirDistance}}catch(e){o.e(e)}finally{o.f()}}},{key:"sortByDirZ",value:function(){var e=this.targetObjectsMap,t=Math.sign(eE.z);AE=void 0;var i,n=this.selectTransformBoxHelper.position,r=this.selectTransformBoxHelper.size,o=vu(e.values());try{for(o.s();!(i=o.n()).done;){var a=i.value;a.translateDirDistance=t>0?a.boxCenter.z-a.boxSize.z/2-(n.z+r.z/2):a.boxCenter.z+a.boxSize.z/2-(n.z-r.z/2),jg(AE)?(this.selectTransformBoxHelper.box.intersectsBox(a.expandBox)||this.selectTransformBoxHelper.box.containsBox(a.expandBox))&&Math.abs(a.translateDirDistance)<Math.abs(AE.translateDirDistance)&&(AE=a):(AE=a).translateDirDistance=a.translateDirDistance}}catch(e){o.e(e)}finally{o.f()}}},{key:"getCollectId",value:function(){if(eE.lengthSq()<be.EPSILON7)return{id:this.lastCollidingId};this._originId=jg(AE)?AE.id:void 0,AE=void 0;var e=Ke.getMaxAbsComponent(eE);if(jg(this.lastCollidingId)){var t=this.targetObjectsMap.get(this.lastCollidingId);if(this.updateTotalBox(),this.updateDistance(),(this.selectTransformBoxHelper.box.intersectsBox(t.box)||this.selectTransformBoxHelper.box.containsBox(t.box))&&t.collisionThreshold>=lE[e])return AE={id:this.lastCollidingId}}return this.updateTotalBox(),this.updateDistance(),"x"===e?this.sortByDirX():"y"===e?this.sortByDirY():this.sortByDirZ(),jg(AE)?AE:{id:void 0}}},{key:"executeCollision",value:function(e){this.isColliding=!1;var t=this.getCollectId();if(jg(t.id)){this.targetId!==t.id&&jg(this.targetId)&&this.aabbCollection.getHelper(this.targetId).resetTranslate(),this.targetId=t.id;var i=this.targetObjectsMap.get(this.targetId);this.isColliding=this.selectTransformBoxHelper.box.intersectsBox(i.expandBox),this.isColliding&&(this.lastCollidingId!==this.targetId&&(this._originIsColliding=!1),this.targetBox.copy(this.aabbCollection.getBox(this.targetId)),this.targetBox.getCenter(this.targetBoxCenter),this.targetBox.getSize(this.targetBoxSize),this.targetObjectExpandBox.copy(this.targetBox),this.targetObjectExpandBox.expandByScalar(i.collisionThreshold),this.targetObjectExpandBox.getCenter(this.targetObjectExpandBoxCenter),this.targetObjectExpandBox.getSize(this.targetObjectExpandBoxSize),this.lastCollidingId=this.targetId,this.isTargetBoxColliding=this.selectTransformBoxHelper.box.intersectsBox(this.targetBox))}else this.isColliding=!1}},{key:"updateSelectObjectBoxHelper",value:function(){jg(this.selectObjectBoxHelper)&&(this.selectObjectBoxHelper.box.copy(this.selectTransformBoxHelper.box),this.selectObjectBoxHelper.updateMatrix(),this.selectObjectBoxHelper.updateMatrixWorld(!0))}},{key:"reSetSelectTransformBoxHelper",value:function(){if(jg(this.selectTransformBoxHelper)){var e=this._collection;jg(e)&&jg(e.computeBoundingBox)&&(e.updateMatrixWorld(!0),e.computeBoundingBox(),this.selectObjectBoxHelper.box.copy(e.boundingBox),this.selectObjectBoxHelper.updateMatrixWorld()),this.selectTransformBoxHelper.box.copy(this.selectObjectBoxHelper.box),this.selectTransformBoxHelper.updateMatrix(),this.selectTransformBoxHelper.updateMatrixWorld(!0),this.selectTransformBoxHelper.box.getCenter(this.transformBoxCenter),this.selectTransformBoxHelper.box.getSize(this.transformBoxSize),this.componentTransformTool.transformObject.position.copy(this.selectObjectBoxHelper.position),this.componentTransformTool.transformObject.updateMatrixWorld(!0)}}},{key:"highLightAdsorbPlane",value:function(){var e=this.selectObjectBoxHelper.position;cE.set(Math.abs(e.x-this.targetBoxCenter.x),Math.abs(e.y-this.targetBoxCenter.y),Math.abs(e.z-this.targetBoxCenter.z)),mE.subVectors(cE,oE),Math.abs(mE.x)<be.EPSILON5&&this.targetAABB.setTranslate(Math.sign(e.x-this.targetBoxCenter.x),0,0),Math.abs(mE.y)<be.EPSILON5&&this.targetAABB.setTranslate(0,Math.sign(e.y-this.targetBoxCenter.y),0),Math.abs(mE.z)<be.EPSILON5&&this.targetAABB.setTranslate(0,0,Math.sign(e.z-this.targetBoxCenter.z))}},{key:"updateSelectTransformBoxHelper",value:function(e){jg(this.selectTransformBoxHelper)&&(this.selectTransformBoxHelper.box.applyMatrix4(e),this.selectTransformBoxHelper.updateMatrix(),this.selectTransformBoxHelper.box.getCenter(this.transformBoxCenter),this.selectTransformBoxHelper.box.getSize(this.transformBoxSize),this.selectTransformBoxHelper.updateMatrixWorld(!0))}},{key:"executeCloseAdsorb",value:function(e){if(!this.selectTransformBoxHelper.box.intersectsBox(this.targetObjectsMap.get(this.targetId).box))if(this.updateTotalBox(),this.updateDistance(),tE.identity(),0!==e.y||0===e.x||0===e.z)if(0!==e.z||0===e.x||0===e.y)if(0!==e.x||0===e.y||0===e.z){e.normalize(),this.targetBox.getCenter(this.targetBoxCenter);var t=new Ke,i=Number(Boolean(e.x)),n=Number(Boolean(e.y)),r=Number(Boolean(e.z));t.set(this.targetBoxCenter.x*i+this.selectBoxCenter.x*(1-i)-oE.x*Math.sign(e.x)*Number(Boolean(e.x)),this.targetBoxCenter.y*n+this.selectBoxCenter.y*(1-n)-oE.y*Math.sign(e.y)*Number(Boolean(e.y)),this.targetBoxCenter.z*r+this.selectBoxCenter.z*(1-r)-oE.z*Math.sign(e.z)*Number(Boolean(e.z))),this.selectObjectBoxHelper.box.getCenter(this.selectBoxCenter),this.selectObjectBoxHelper.box.setFromCenterAndSize(t,this.selectBoxSize),this.selectObjectBoxHelper.updateMatrixWorld(!0),this.targetAABB.setTranslate(-i,-n,-r)}else this.executeNoneAxisXAdsorb(e);else this.executeNoneAxisZAdsorb(e);else this.executeNoneAxisYAdsorb(e)}},{key:"executeFarAdsorb",value:function(){}},{key:"executeNoneAxisYAdsorb",value:function(e){e.normalize(),this.targetBox.getCenter(this.targetBoxCenter);var t=new Ke;Math.abs(lE.x)<Math.abs(lE.z)&&t.set(this.targetBoxCenter.x-oE.x*Math.sign(e.x),this.selectBoxCenter.y,this.selectBoxCenter.z),Math.abs(lE.x)>Math.abs(lE.z)&&t.set(this.selectBoxCenter.x,this.selectBoxCenter.y,this.targetBoxCenter.z-oE.z*Math.sign(e.z)),this.selectObjectBoxHelper.box.getCenter(this.selectBoxCenter),this.selectObjectBoxHelper.box.setFromCenterAndSize(t,this.selectBoxSize),this.selectObjectBoxHelper.updateMatrixWorld(!0)}},{key:"executeNoneAxisZAdsorb",value:function(e){e.normalize(),this.targetBox.getCenter(this.targetBoxCenter);var t=new Ke;Math.abs(lE.x)<Math.abs(lE.y)&&t.set(this.targetBoxCenter.x-oE.x*Math.sign(e.x),this.selectBoxCenter.y,this.selectBoxCenter.z),Math.abs(lE.x)>Math.abs(lE.y)&&t.set(this.selectBoxCenter.x,this.targetBoxCenter.y-oE.y*Math.sign(e.y),this.selectBoxCenter.z),this.selectObjectBoxHelper.box.getCenter(this.selectBoxCenter),this.selectObjectBoxHelper.box.setFromCenterAndSize(t,this.selectBoxSize),this.selectObjectBoxHelper.updateMatrixWorld(!0)}},{key:"executeNoneAxisXAdsorb",value:function(e){e.normalize(),this.targetBox.getCenter(this.targetBoxCenter);var t=new Ke;Math.abs(lE.y)>Math.abs(lE.z)&&t.set(this.selectBoxCenter.x,this.selectBoxCenter.y,this.targetBoxCenter.z-oE.z*Math.sign(e.x)),Math.abs(lE.y)<Math.abs(lE.z)&&t.set(this.selectBoxCenter.x,this.targetBoxCenter.y-oE.y*Math.sign(e.y),this.selectBoxCenter.z),this.selectObjectBoxHelper.box.getCenter(this.selectBoxCenter),this.selectObjectBoxHelper.box.setFromCenterAndSize(t,this.selectBoxSize),this.selectObjectBoxHelper.updateMatrixWorld(!0)}},{key:"executeContinuousAdsorb",value:function(e){this.updateTotalBox(),this.updateDistance(),hE.set(0,0,0),this.adsorbingEvent.translate.copy(e),this.dispatchEvent(this.adsorbingEvent),cE.equalXEPSILON6(oE)&&this.executePlaneYZContinuousAdsorb(e),cE.equalYEPSILON6(oE)&&this.executePlaneXZContinuousAdsorb(e),cE.equalZEPSILON6(oE)&&this.executePlaneXYContinuousAdsorb(e)}},{key:"executePlaneYZContinuousAdsorb",value:function(){hE.y=eE.y,hE.z=eE.z,this.selectObjectBoxHelper.box.translate(hE),this.selectObjectBoxHelper.box.getCenter(this.selectBoxCenter),this.selectObjectBoxHelper.updateMatrixWorld(!0),Math.abs(eE.y)>Math.abs(eE.z)&&0===eE.x?this.dirYEdgeAlignment(eE):Math.abs(eE.z)>Math.abs(eE.y)&&0===eE.x&&this.dirZEdgeAlignment(eE)}},{key:"executePlaneXZContinuousAdsorb",value:function(){hE.x=eE.x,hE.z=eE.z,this.selectObjectBoxHelper.box.translate(hE),this.selectObjectBoxHelper.box.getCenter(this.selectBoxCenter),this.selectObjectBoxHelper.updateMatrixWorld(!0),Math.abs(eE.x)>Math.abs(eE.z)&&0===eE.y?this.dirXEdgeAlignment(eE):Math.abs(eE.z)>Math.abs(eE.x)&&0===eE.y&&this.dirZEdgeAlignment(eE)}},{key:"executePlaneXYContinuousAdsorb",value:function(e){hE.x=e.x,hE.y=e.y,this.selectObjectBoxHelper.box.translate(hE),this.selectObjectBoxHelper.box.getCenter(this.selectBoxCenter),this.selectObjectBoxHelper.box.getSize(this.selectBoxSize),this.selectObjectBoxHelper.updateMatrixWorld(!0),Math.abs(e.y)>Math.abs(e.x)&&0===e.z?this.dirYEdgeAlignment(e):Math.abs(e.x)>Math.abs(e.y)&&0===e.z&&this.dirXEdgeAlignment(e)}},{key:"dirXEdgeAlignment",value:function(e){var t=this.selectTransformBoxHelper.sizeX;uE=this.targetBoxCenter.x+this.targetBoxSize.x/2-(this.transformBoxCenter.x+t/2),pE=this.targetBoxCenter.x-this.targetBoxSize.x/2-(this.transformBoxCenter.x-t/2),gE=this.transformBoxCenter.x+t/2-(this.targetBoxCenter.x-this.targetBoxSize.x/2),fE=this.transformBoxCenter.x-t/2-(this.targetBoxCenter.x+this.targetBoxSize.x/2);var i=new Ke;return 0>=e.x||0>gE||gE>this.innerCollisionThreshold?e.x>=0||fE>0||Math.abs(fE)>this.innerCollisionThreshold?Math.abs(uE)>this.innerCollisionThreshold&&Math.abs(pE)>this.innerCollisionThreshold?(i.copy(this.selectBoxCenter),i.x=this.transformBoxCenter.x,this.selectObjectBoxHelper.box.setFromCenterAndSize(i,this.selectBoxSize),this.selectObjectBoxHelper.box.getCenter(this.selectBoxCenter),void this.selectObjectBoxHelper.updateMatrixWorld(!0)):(Math.abs(uE)>Math.abs(pE)||Math.abs(uE)>this.innerCollisionThreshold||(i.copy(this.transformBoxCenter),i.x=this.targetBoxCenter.x+this.targetBoxSize.x/2-this.selectBoxSize.x/2,this.selectObjectBoxHelper.box.getCenter(this.selectBoxCenter),this.selectObjectBoxHelper.box.setFromCenterAndSize(i,this.selectBoxSize),this.selectObjectBoxHelper.updateMatrixWorld(!0)),void(Math.abs(uE)>Math.abs(pE)&&(i.copy(this.transformBoxCenter),i.x=this.targetBoxCenter.x-this.targetBoxSize.x/2+this.selectBoxSize.x/2,this.selectObjectBoxHelper.box.getCenter(this.selectBoxCenter),this.selectObjectBoxHelper.box.setFromCenterAndSize(i,this.selectBoxSize),this.selectObjectBoxHelper.updateMatrixWorld(!0)))):(i.copy(this.transformBoxCenter),i.x=this.targetBoxCenter.x+this.targetBoxSize.x/2+this.selectBoxSize.x/2,this.selectObjectBoxHelper.box.setFromCenterAndSize(i,this.selectBoxSize),this.selectObjectBoxHelper.box.getCenter(this.selectBoxCenter),void this.selectObjectBoxHelper.updateMatrixWorld(!0)):(i.copy(this.transformBoxCenter),i.x=this.targetBoxCenter.x-this.targetBoxSize.x/2-this.selectBoxSize.x/2,this.selectObjectBoxHelper.box.setFromCenterAndSize(i,this.selectBoxSize),this.selectObjectBoxHelper.box.getCenter(this.selectBoxCenter),void this.selectObjectBoxHelper.updateMatrixWorld(!0))}},{key:"dirYEdgeAlignment",value:function(e){uE=this.targetBoxCenter.y+this.targetBoxSize.y/2-(this.transformBoxCenter.y+this.transformBoxSize.y/2),pE=this.targetBoxCenter.y-this.targetBoxSize.y/2-(this.transformBoxCenter.y-this.transformBoxSize.y/2),gE=this.transformBoxCenter.y+this.transformBoxSize.y/2-(this.targetBoxCenter.y-this.targetBoxSize.y/2),fE=this.transformBoxCenter.y-this.transformBoxSize.y/2-(this.targetBoxCenter.y+this.targetBoxSize.y/2);var t=new Ke;return 0>=e.y||0>gE||gE>this.innerCollisionThreshold?e.y>=0||fE>0||Math.abs(fE)>this.innerCollisionThreshold?Math.abs(uE)>this.innerCollisionThreshold&&Math.abs(pE)>this.innerCollisionThreshold?(t.copy(this.selectBoxCenter),t.y=this.transformBoxCenter.y,this.selectObjectBoxHelper.box.setFromCenterAndSize(t,this.selectBoxSize),this.selectObjectBoxHelper.box.getCenter(this.selectBoxCenter),void this.selectObjectBoxHelper.updateMatrixWorld(!0)):(Math.abs(uE)>Math.abs(pE)||Math.abs(uE)>this.innerCollisionThreshold||(t.copy(this.transformBoxCenter),t.y=this.targetBoxCenter.y+this.targetBoxSize.y/2-this.selectBoxSize.y/2,this.selectObjectBoxHelper.box.getCenter(this.selectBoxCenter),this.selectObjectBoxHelper.box.setFromCenterAndSize(t,this.selectBoxSize),this.selectObjectBoxHelper.updateMatrixWorld(!0)),void(Math.abs(uE)>Math.abs(pE)&&(t.copy(this.transformBoxCenter),t.y=this.targetBoxCenter.y-this.targetBoxSize.y/2+this.selectBoxSize.y/2,this.selectObjectBoxHelper.box.getCenter(this.selectBoxCenter),this.selectObjectBoxHelper.box.setFromCenterAndSize(t,this.selectBoxSize),this.selectObjectBoxHelper.updateMatrixWorld(!0)))):(t.copy(this.transformBoxCenter),t.y=this.targetBoxCenter.y+this.targetBoxSize.y/2+this.selectBoxSize.y/2,this.selectObjectBoxHelper.box.setFromCenterAndSize(t,this.selectBoxSize),this.selectObjectBoxHelper.box.getCenter(this.selectBoxCenter),void this.selectObjectBoxHelper.updateMatrixWorld(!0)):(t.copy(this.transformBoxCenter),t.y=this.targetBoxCenter.y-this.targetBoxSize.y/2-this.selectBoxSize.y/2,this.selectObjectBoxHelper.box.setFromCenterAndSize(t,this.selectBoxSize),this.selectObjectBoxHelper.box.getCenter(this.selectBoxCenter),void this.selectObjectBoxHelper.updateMatrixWorld(!0))}},{key:"dirZEdgeAlignment",value:function(){uE=this.targetBoxCenter.z+this.targetBoxSize.z/2-(this.transformBoxCenter.z+this.transformBoxSize.z/2),pE=this.targetBoxCenter.z-this.targetBoxSize.z/2-(this.transformBoxCenter.z-this.transformBoxSize.z/2),gE=this.transformBoxCenter.z+this.transformBoxSize.z/2-(this.targetBoxCenter.z-this.targetBoxSize.z/2),fE=this.transformBoxCenter.z-this.transformBoxSize.z/2-(this.targetBoxCenter.z+this.targetBoxSize.z/2);var e=new Ke,t=Math.min(this.innerCollisionThreshold,this.targetBoxSize.z/2);return 0>=eE.z||0>gE||gE>t?eE.z>=0||fE>0||Math.abs(fE)>t?Math.abs(uE)>t&&Math.abs(pE)>t?(e.copy(this.selectBoxCenter),e.z=this.transformBoxCenter.z,this.selectObjectBoxHelper.box.setFromCenterAndSize(e,this.selectBoxSize),this.selectObjectBoxHelper.box.getCenter(this.selectBoxCenter),void this.selectObjectBoxHelper.updateMatrixWorld(!0)):(Math.abs(uE)>Math.abs(pE)||Math.abs(uE)>t||(e.copy(this.transformBoxCenter),e.z=this.targetBoxCenter.z+this.targetBoxSize.z/2-this.selectBoxSize.z/2,this.selectObjectBoxHelper.box.setFromCenterAndSize(e,this.selectBoxSize),this.selectObjectBoxHelper.box.getCenter(this.selectBoxCenter),this.selectObjectBoxHelper.updateMatrixWorld(!0)),void(Math.abs(uE)>Math.abs(pE)&&(e.copy(this.transformBoxCenter),e.z=this.targetBoxCenter.z-this.targetBoxSize.z/2+this.selectBoxSize.z/2,this.selectObjectBoxHelper.box.getCenter(this.selectBoxCenter),this.selectObjectBoxHelper.box.setFromCenterAndSize(e,this.selectBoxSize),this.selectObjectBoxHelper.updateMatrixWorld(!0)))):(e.copy(this.transformBoxCenter),e.z=this.targetBoxCenter.z+this.targetBoxSize.z/2+this.selectBoxSize.z/2,this.selectObjectBoxHelper.box.setFromCenterAndSize(e,this.selectBoxSize),this.selectObjectBoxHelper.box.getCenter(this.selectBoxCenter),void this.selectObjectBoxHelper.updateMatrixWorld(!0)):(e.copy(this.transformBoxCenter),e.z=this.targetBoxCenter.z-this.targetBoxSize.z/2-this.selectBoxSize.z/2,this.selectObjectBoxHelper.box.setFromCenterAndSize(e,this.selectBoxSize),this.selectObjectBoxHelper.box.getCenter(this.selectBoxCenter),void this.selectObjectBoxHelper.updateMatrixWorld(!0))}},{key:"updateBoxHelperFromBox3",value:function(e,t){jg(t)&&(t.getCenter(nE),e.position.copy(nE),e.updateMatrixWorld())}},{key:"update",value:function(e){if(this.enabled&&jg(this.selectedObjectId)){if(tE.copy(e.matrix),eE.setFromMatrixPosition(tE),"translate"===e.mode||"scale"===e.mode)this.updateSelectTransformBoxHelper(tE);else if("rotate"===e.mode)return this.selectTransformBoxHelper.box.copy(this.aabbCollection.getBox(this.selectedObjectId)),this.selectTransformBoxHelper.updateMatrixWorld(!0),this.transformBoxCenter.copy(this.selectTransformBoxHelper.position),this.transformBoxSize.copy(this.selectTransformBoxHelper.scale),this.transformBoxSize.multiplyScalar(2),this.selectObjectBoxHelper.box.copy(this.aabbCollection.getBox(this.selectedObjectId)),this.selectObjectBoxHelper.updateMatrixWorld(!0),this.selectBoxCenter.copy(this.selectTransformBoxHelper.position),this.selectBoxSize.copy(this.selectTransformBoxHelper.scale),void this.selectBoxSize.multiplyScalar(2);var t=this.componentTransformTool.transformControl.object;jg(t)&&t.position.copy(this.selectObjectBoxHelper.position),this.executeCollision(tE),jg(this.targetId)?(this.selectObjectBoxHelper.box.intersectsBox(this.targetBox)||this.targetAABB.resetTranslate(),this.isColliding||this.updateSelectObjectBoxHelper(tE),this.isColliding&&!this._originIsColliding&&this.executeCloseAdsorb(eE),this._originIsColliding&&this.isColliding&&(this.executeContinuousAdsorb(eE),this.selectObjectBoxHelper.box.intersectsBox(this.targetBox)&&this.highLightAdsorbPlane()),this.selectObjectBoxHelper.box.intersectsBox(this.targetBox)||this.targetAABB.resetTranslate(),this._originIsColliding&&!this.isColliding&&this.executeFarAdsorb(eE),this._originIsColliding=this.isColliding):this.updateSelectObjectBoxHelper(tE)}}},{key:"setAdsorbNormal",value:function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};if(jg(this.selectedObjectId))if(e!==this.selectedObjectId){var i={x:Wg(t.x,0),y:Wg(t.y,0),z:Wg(t.z,0)};if(0===i.x)if(0===i.y)if(0===i.z);else{var n=this.setAdsorbAxisZ(e,i);this.updateTranslate(n.ps,n.offset,i)}else{var r=this.setAdsorbAxisY(e,i);this.updateTranslate(r.ps,r.offset,i)}else{var o=this.setAdsorbAxisX(e,i);this.updateTranslate(o.ps,o.offset,i)}}else console.warn("选中对象与被吸附对象重合");else console.warn("当前选中对象不存在!")}},{key:"setAdsorbAxisX",value:function(e,t){var i=this.selectObjectBoxHelper.position,n=this.selectObjectBoxHelper.size;this.targetId=e;var r=this.aabbCollection.get(e),o=r.position,a={x:o.x+.5*(n.x+r.size.x)*Math.sign(t.x),y:o.y,z:o.z};return{ps:a,offset:{x:a.x-i.x,y:a.y-i.y,z:a.z-i.z}}}},{key:"setAdsorbAxisY",value:function(e,t){var i=this.selectObjectBoxHelper.position,n=this.selectObjectBoxHelper.size;this.targetId=e;var r=this.aabbCollection.getHelper(e),o=r.position,a={x:o.x,y:o.y+.5*(n.y+r.size.y)*Math.sign(t.y),z:o.z};return{ps:a,offset:{x:a.x-i.x,y:a.y-i.y,z:a.z-i.z}}}},{key:"setAdsorbAxisZ",value:function(e,t){var i=this.selectObjectBoxHelper.position,n=this.selectObjectBoxHelper.size;this.targetId=e;var r=this.aabbCollection.getHelper(e),o=r.position,a={x:o.x,y:o.y,z:o.z+.5*(n.z+r.size.z)*Math.sign(t.z)};return{ps:a,offset:{x:a.x-i.x,y:a.y-i.y,z:a.z-i.z}}}},{key:"updateTranslate",value:function(e,t,i){dE.makeTranslation(t.x,t.y,t.z);var n=this.componentTransformTool.transformControl,r=this._collection,o=this.viewerImpl,a=this.selectedObjectId;this.isExternalObject?(r.position.addVectors(e,this.centerOffset),r.updateMatrixWorld(!0),n.object.position.add(t),n.updateMatrixWorld()):(o.componentApplyMatrix2(a,dE,!1),o.setComponentPositionByKey(a,[e.x,e.y,e.z]),o.getScene().expandBoundingBoxWorldBy(n.object)),this.updateSelectTransformBoxHelper(dE),this.updateSelectObjectBoxHelper(dE),this._originIsColliding=!0,this.lastCollidingId=this.targetId,this.targetAABB.setTranslate(Math.sign(i.x),Math.sign(i.y),Math.sign(i.z))}}]),i}(Jg),CE=function(e){lu(i,e);var t=pu(i);function i(e){var n;return ru(this,i),(n=t.call(this,e))._needsUpdate=!1,n}return au(i,[{key:"needsUpdate",get:function(){return this._needsUpdate}},{key:"activeLightNum",get:function(){for(var e=0,t=this.length,i=0;t>i;i++)this.get(i).visible&&e++;return e}},{key:"activeShadowLightNum",get:function(){for(var e=0,t=this.length,i=0;t>i;i++){var n=this.get(i);this.get(i).visible&&n.enabledShadow&&e++}return e}},{key:"preUpdate",value:function(){for(var e=this.children,t=this.length,i=0;t>i;i++)e[i].updateRenderTarget()}},{key:"updatePostRender",value:function(){this._needsUpdate=!1}},{key:"updateLights",value:function(e){for(var t=this.children,i=this.length,n=0;i>n;n++)t[n].update(e)}}]),i}(Jg);function IE(e,t){if(null===e||"object"!==nu(e))return e;t=Wg(t,!1);var i=new e.constructor;for(var n in e)if(e.hasOwnProperty(n)){var r=e[n];t&&(r=IE(r,t)),i[n]=r}return i}var xE=new bl,wE=new Dl,ME=new Bl;e.getTimestamp=void 0,e.getTimestamp="undefined"!=typeof performance&&"function"==typeof performance.now&&isFinite(performance.now())?function(){return performance.now()}:function(){return Date.now()};var EE={SECONDS_PER_MILLISECOND:.001,SECONDS_PER_MINUTE:60,MINUTES_PER_HOUR:60,HOURS_PER_DAY:24,SECONDS_PER_HOUR:3600,MINUTES_PER_DAY:1440,SECONDS_PER_DAY:86400,DAYS_PER_JULIAN_CENTURY:36525,PICOSECOND:1e-9,MODIFIED_JULIAN_DATE_DIFFERENCE:2400000.5};
/**
@license
tween.js - https://github.com/sole/tween.js
Copyright (c) 2010-2012 Tween.js authors.
Easing equations Copyright (c) 2001 Robert Penner http://robertpenner.com/easing/
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE.
*/void 0===Date.now&&(Date.now=function(){return(new Date).valueOf()});var BE,SE,bE=(BE=[],{REVISION:"13",getAll:function(){return BE},removeAll:function(){BE=[]},add:function(e){BE.push(e)},remove:function(e){var t=BE.indexOf(e);-1!==t&&BE.splice(t,1)},update:function(e){if(0===BE.length)return!1;var t=0;for(e=void 0!==e?e:"undefined"!=typeof window&&void 0!==window.performance&&void 0!==window.performance.now?window.performance.now():Date.now();BE.length>t;)BE[t].update(e)?t++:BE.splice(t,1);return!0}});bE.Tween=function(e){var t=e,i={},n={},r={},o=1e3,a=0,s=!1,l=!1,c=0,h=null,d=bE.Easing.Linear.None,u=bE.Interpolation.Linear,p=[],g=null,f=!1,m=null,A=null,y=null;for(var v in e)i[v]=parseFloat(e[v],10);this.to=function(e,t){return void 0!==t&&(o=t),n=e,this},this.start=function(e){for(var o in bE.add(this),l=!0,f=!1,h=void 0!==e?e:"undefined"!=typeof window&&void 0!==window.performance&&void 0!==window.performance.now?window.performance.now():Date.now(),h+=c,n){if(n[o]instanceof Array){if(0===n[o].length)continue;n[o]=[t[o]].concat(n[o])}i[o]=t[o],i[o]instanceof Array==!1&&(i[o]*=1),r[o]=i[o]||0}return this},this.stop=function(){return l?(bE.remove(this),l=!1,null!==y&&y.call(t),this.stopChainedTweens(),this):this},this.stopChainedTweens=function(){for(var e=0,t=p.length;t>e;e++)p[e].stop()},this.delay=function(e){return c=e,this},this.repeat=function(e){return a=e,this},this.yoyo=function(e){return s=e,this},this.easing=function(e){return d=e,this},this.interpolation=function(e){return u=e,this},this.chain=function(){return p=arguments,this},this.onStart=function(e){return g=e,this},this.onUpdate=function(e){return m=e,this},this.onComplete=function(e){return A=e,this},this.onStop=function(e){return y=e,this},this.update=function(e){var l;if(h>e)return!0;!1===f&&(null!==g&&g.call(t),f=!0);var y=(e-h)/o,v=d(y=y>1?1:y);for(l in n){var C=i[l]||0,I=n[l];I instanceof Array?t[l]=u(I,v):("string"==typeof I&&(I=C+parseFloat(I,10)),"number"==typeof I&&(t[l]=C+(I-C)*v))}if(null!==m&&m.call(t,v),1==y){if(a>0){for(l in isFinite(a)&&(a-=1),r){if("string"==typeof n[l]&&(r[l]=r[l]+parseFloat(n[l],10)),s){var x=r[l];r[l]=n[l],n[l]=x}i[l]=r[l]}return h=e+c,!0}null!==A&&A.call(t);for(var w=0,M=p.length;M>w;w++)p[w].start(e);return!1}return!0}},bE.Easing={Linear:{None:function(e){return e}},Quadratic:{In:function(e){return e*e},Out:function(e){return e*(2-e)},InOut:function(e){return 1>(e*=2)?.5*e*e:-.5*(--e*(e-2)-1)}},Cubic:{In:function(e){return e*e*e},Out:function(e){return--e*e*e+1},InOut:function(e){return 1>(e*=2)?.5*e*e*e:.5*((e-=2)*e*e+2)}},Quartic:{In:function(e){return e*e*e*e},Out:function(e){return 1- --e*e*e*e},InOut:function(e){return 1>(e*=2)?.5*e*e*e*e:-.5*((e-=2)*e*e*e-2)}},Quintic:{In:function(e){return e*e*e*e*e},Out:function(e){return--e*e*e*e*e+1},InOut:function(e){return 1>(e*=2)?.5*e*e*e*e*e:.5*((e-=2)*e*e*e*e+2)}},Sinusoidal:{In:function(e){return 1-Math.cos(e*Math.PI/2)},Out:function(e){return Math.sin(e*Math.PI/2)},InOut:function(e){return.5*(1-Math.cos(Math.PI*e))}},Exponential:{In:function(e){return 0===e?0:Math.pow(1024,e-1)},Out:function(e){return 1===e?1:1-Math.pow(2,-10*e)},InOut:function(e){return 0===e?0:1===e?1:1>(e*=2)?.5*Math.pow(1024,e-1):.5*(2-Math.pow(2,-10*(e-1)))}},Circular:{In:function(e){return 1-Math.sqrt(1-e*e)},Out:function(e){return Math.sqrt(1- --e*e)},InOut:function(e){return 1>(e*=2)?-.5*(Math.sqrt(1-e*e)-1):.5*(Math.sqrt(1-(e-=2)*e)+1)}},Elastic:{In:function(e){var t,i=.1;return 0===e?0:1===e?1:(!i||1>i?(i=1,t=.1):t=.4*Math.asin(1/i)/(2*Math.PI),-i*Math.pow(2,10*(e-=1))*Math.sin((e-t)*(2*Math.PI)/.4))},Out:function(e){var t,i=.1;return 0===e?0:1===e?1:(!i||1>i?(i=1,t=.1):t=.4*Math.asin(1/i)/(2*Math.PI),i*Math.pow(2,-10*e)*Math.sin((e-t)*(2*Math.PI)/.4)+1)},InOut:function(e){var t,i=.1,n=.4;return 0===e?0:1===e?1:(!i||1>i?(i=1,t=.1):t=n*Math.asin(1/i)/(2*Math.PI),1>(e*=2)?i*Math.pow(2,10*(e-=1))*Math.sin((e-t)*(2*Math.PI)/n)*-.5:i*Math.pow(2,-10*(e-=1))*Math.sin((e-t)*(2*Math.PI)/n)*.5+1)}},Back:{In:function(e){var t=1.70158;return e*e*((t+1)*e-t)},Out:function(e){var t=1.70158;return--e*e*((t+1)*e+t)+1},InOut:function(e){var t=2.5949095;return 1>(e*=2)?e*e*((t+1)*e-t)*.5:.5*((e-=2)*e*((t+1)*e+t)+2)}},Bounce:{In:function(e){return 1-bE.Easing.Bounce.Out(1-e)},Out:function(e){return 1/2.75>e?7.5625*e*e:2/2.75>e?7.5625*(e-=1.5/2.75)*e+.75:2.5/2.75>e?7.5625*(e-=2.25/2.75)*e+.9375:7.5625*(e-=2.625/2.75)*e+.984375},InOut:function(e){return.5>e?.5*bE.Easing.Bounce.In(2*e):.5*bE.Easing.Bounce.Out(2*e-1)+.5}}},bE.Interpolation={Linear:function(e,t){var i=e.length-1,n=i*t,r=Math.floor(n),o=bE.Interpolation.Utils.Linear;return 0>t?o(e[0],e[1],n):t>1?o(e[i],e[i-1],i-n):o(e[r],e[r+1>i?i:r+1],n-r)},Bezier:function(e,t){var i,n=0,r=e.length-1,o=Math.pow,a=bE.Interpolation.Utils.Bernstein;for(i=0;r>=i;i++)n+=o(1-t,r-i)*o(t,i)*e[i]*a(r,i);return n},CatmullRom:function(e,t){var i=e.length-1,n=i*t,r=Math.floor(n),o=bE.Interpolation.Utils.CatmullRom;return e[0]===e[i]?(0>t&&(r=Math.floor(n=i*(1+t))),o(e[(r-1+i)%i],e[r],e[(r+1)%i],e[(r+2)%i],n-r)):0>t?e[0]-(o(e[0],e[0],e[1],e[1],-n)-e[0]):t>1?e[i]-(o(e[i],e[i],e[i-1],e[i-1],n-i)-e[i]):o(e[r?r-1:0],e[r],e[r+1>i?i:r+1],e[r+2>i?i:r+2],n-r)},Utils:{Linear:function(e,t,i){return(t-e)*i+e},Bernstein:function(e,t){var i=bE.Interpolation.Utils.Factorial;return i(e)/i(t)/i(e-t)},Factorial:(SE=[1],function(e){var t,i=1;if(SE[e])return SE[e];for(t=e;t>1;t--)i*=t;return SE[e]=i}),CatmullRom:function(e,t,i,n,r){var o=.5*(i-e),a=.5*(n-t),s=r*r;return(2*t-2*i+o+a)*(r*s)+(-3*t+3*i-2*o-a)*s+o*r+t}}};var kE={LINEAR_NONE:bE.Easing.Linear.None,QUADRACTIC_IN:bE.Easing.Quadratic.In,QUADRACTIC_OUT:bE.Easing.Quadratic.Out,QUADRACTIC_IN_OUT:bE.Easing.Quadratic.InOut,CUBIC_IN:bE.Easing.Cubic.In,CUBIC_OUT:bE.Easing.Cubic.Out,CUBIC_IN_OUT:bE.Easing.Cubic.InOut,QUARTIC_IN:bE.Easing.Quartic.In,QUARTIC_OUT:bE.Easing.Quartic.Out,QUARTIC_IN_OUT:bE.Easing.Quartic.InOut,QUINTIC_IN:bE.Easing.Quintic.In,QUINTIC_OUT:bE.Easing.Quintic.Out,QUINTIC_IN_OUT:bE.Easing.Quintic.InOut,SINUSOIDAL_IN:bE.Easing.Sinusoidal.In,SINUSOIDAL_OUT:bE.Easing.Sinusoidal.Out,SINUSOIDAL_IN_OUT:bE.Easing.Sinusoidal.InOut,EXPONENTIAL_IN:bE.Easing.Exponential.In,EXPONENTIAL_OUT:bE.Easing.Exponential.Out,EXPONENTIAL_IN_OUT:bE.Easing.Exponential.InOut,CIRCULAR_IN:bE.Easing.Circular.In,CIRCULAR_OUT:bE.Easing.Circular.Out,CIRCULAR_IN_OUT:bE.Easing.Circular.InOut,ELASTIC_IN:bE.Easing.Elastic.In,ELASTIC_OUT:bE.Easing.Elastic.Out,ELASTIC_IN_OUT:bE.Easing.Elastic.InOut,BACK_IN:bE.Easing.Back.In,BACK_OUT:bE.Easing.Back.Out,BACK_IN_OUT:bE.Easing.Back.InOut,BOUNCE_IN:bE.Easing.Bounce.In,BOUNCE_OUT:bE.Easing.Bounce.Out,BOUNCE_IN_OUT:bE.Easing.Bounce.InOut},DE=function(e){lu(i,e);var t=pu(i);function i(){var e,n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return ru(this,i),(e=t.call(this)).isAvoid=Wg(n.isAvoid,!1),e}return au(i,[{key:"updateFixedFrame",value:function(e){var t=this.length;if(0!==this.length)if(this.visible){for(var i=0;t>i;i++)this.get(i).updateFixedFrame(e);this.isAvoid&&function(e){for(var t=[],i=0,n=e.length;n>i;++i){var r=e.get(i),o=r.element;TE(t,o)[0]?(r.setVisible(!1),r._originShow=!1):(r.setVisible(!0),r._originShow=!0,t.push(o))}}(this)}else for(var n=0;t>n;n++)this.get(n).setVisible(!1)}}]),i}(Jg);function TE(e,t){for(var i=0,n=e.length;n>i;i++){var r=e[i];if(!(t.offsetLeft>r.offsetLeft+r.offsetWidth||r.offsetLeft>t.offsetLeft+t.offsetWidth||t.offsetTop>r.offsetTop+r.offsetHeight||r.offsetTop>t.offsetTop+t.offsetHeight))return[!0,r]}return[!1]}function RE(e,t,i,n,r,o,a,s,l,c){this._tweens=e,this._tweenjs=t,this._startObject=IE(i),this._stopObject=IE(n),this._duration=r,this._delay=o,this._easingFunction=a,this._update=s,this._complete=l,this.cancel=c,this.needsStart=!0}function UE(){this._tweens=[]}Object.defineProperties(RE.prototype,{startObject:{get:function(){return this._startObject}},stopObject:{get:function(){return this._stopObject}},duration:{get:function(){return this._duration}},delay:{get:function(){return this._delay}},easingFunction:{get:function(){return this._easingFunction}},update:{get:function(){return this._update}},complete:{get:function(){return this._complete}},tweenjs:{get:function(){return this._tweenjs}}}),RE.prototype.cancelTween=function(){this._tweens.remove(this)},Object.defineProperties(UE.prototype,{length:{get:function(){return this._tweens.length}}}),UE.prototype.add=function(e){if(!jg((e=Wg(e,Wg.EMPTY_OBJECT)).startObject)||!jg(e.stopObject))throw new ZM("options.startObject and options.stopObject are required.");if(!jg(e.duration)||0>e.duration)throw new ZM("options.duration is required and must be positive.");if(0===e.duration)return jg(e.complete)&&e.complete(),new RE(this);var t=e.duration/EE.SECONDS_PER_MILLISECOND,i=Wg(e.delay,0),n=i/EE.SECONDS_PER_MILLISECOND,r=Wg(e.easingFunction,kE.LINEAR_NONE),o=e.startObject,a=new bE.Tween(o);a.to(IE(e.stopObject),t),a.delay(n),a.easing(r),jg(e.update)&&a.onUpdate((function(){e.update(o)})),a.onComplete(Wg(e.complete,null)),a.repeat(Wg(e._repeat,0));var s=new RE(this,a,e.startObject,e.stopObject,e.duration,i,r,e.update,e.complete,e.cancel);return this._tweens.push(s),s},UE.prototype.addProperty=function(e){var t=(e=Wg(e,Wg.EMPTY_OBJECT)).object,i=e.property,n=e.startValue,r=e.stopValue;if(!jg(t)||!jg(e.property))throw new ZM("options.object and options.property are required.");if(!jg(t[i]))throw new ZM("options.object must have the specified property.");if(!jg(n)||!jg(r))throw new ZM("options.startValue and options.stopValue are required.");return this.add({startObject:{value:n},stopObject:{value:r},duration:Wg(e.duration,3),delay:e.delay,easingFunction:e.easingFunction,update:function(e){t[i]=e.value},complete:e.complete,cancel:e.cancel,_repeat:e._repeat})},UE.prototype.addAlpha=function(e){var t=(e=Wg(e,Wg.EMPTY_OBJECT)).material;if(!jg(t))throw new ZM("options.material is required.");var i=[];for(var n in t.uniforms)t.uniforms.hasOwnProperty(n)&&jg(t.uniforms[n])&&jg(t.uniforms[n].alpha)&&i.push(n);if(0===i.length)throw new ZM("material has no properties with alpha components.");return this.add({startObject:{alpha:Wg(e.startValue,0)},stopObject:{alpha:Wg(e.stopValue,1)},duration:Wg(e.duration,3),delay:e.delay,easingFunction:e.easingFunction,update:function(e){for(var n=i.length,r=0;n>r;++r)t.uniforms[i[r]].alpha=e.alpha},complete:e.complete,cancel:e.cancel})},UE.prototype.addOffsetIncrement=function(e){var t=(e=Wg(e,Wg.EMPTY_OBJECT)).material;if(!jg(t))throw new ZM("material is required.");if(!jg(t.uniforms.offset))throw new ZM("material.uniforms must have an offset property.");var i=t.uniforms;return this.addProperty({object:i,property:"offset",startValue:i.offset,stopValue:i.offset+1,duration:e.duration,delay:e.delay,easingFunction:e.easingFunction,update:e.update,cancel:e.cancel,_repeat:1/0})},UE.prototype.remove=function(e){if(!jg(e))return!1;var t=this._tweens.indexOf(e);return-1!==t&&(e.tweenjs.stop(),jg(e.cancel)&&e.cancel(),this._tweens.splice(t,1),!0)},UE.prototype.removeAll=function(){for(var e=this._tweens,t=0;e.length>t;++t){var i=e[t];i.tweenjs.stop(),jg(i.cancel)&&i.cancel()}e.length=0},UE.prototype.contains=function(e){return jg(e)&&-1!==this._tweens.indexOf(e)},UE.prototype.get=function(e){if(!jg(e))throw new ZM("index is required.");return this._tweens[e]},UE.prototype.update=function(t){var i=this._tweens,n=0;for(t=jg(t)?t/EE.SECONDS_PER_MILLISECOND:e.getTimestamp();i.length>n;){var r=i[n],o=r.tweenjs;r.needsStart?(r.needsStart=!1,o.start(t)):o.update(t)?n++:(o.stop(),i.splice(n,1))}};var FE=function(e,t){this.cls=e,this.size=t,this._pool=[],this.counter=0};FE.prototype.init=function(e){for(var t=0,i=this.size;i>t;t+=1){var n=new this.cls;n.init(e),this._pool[t]=n}},FE.prototype.resize=function(e,t){this.size=e,this.collect(),this.init(t)},FE.prototype.get=function(e){return this.size>this.counter?(this._pool[this.counter].spawn(e),this.counter+=1,this.counter-1):(Bu.log("the pool is full"),-1)},FE.prototype.clear=function(){for(var e=0,t=this.size;t>e;e+=1)this._pool[e].clear();this.counter=0},FE.prototype.destroy=function(){this.collect()},FE.prototype.collect=function(){this._pool=[],this.counter=0},FE.prototype.getObjects=function(){return this._pool};var QE=function(e){lu(i,e);var t=pu(i);function i(e,n){var r;ru(this,i);var o=new Ni;return o.setAttribute("position",new Ai(new Float32Array(72),3)),r=t.call(this,o,new Sa({color:n})),void 0!==e&&r.updateBBox(e),r}return i}(La);QE.prototype.unload=function(){},QE.prototype.updateBBox=function(e){var t=e.min,i=e.max,n=this.geometry.attributes.position.array;n[0]=i.x,n[1]=i.y,n[2]=i.z,n[3]=t.x,n[4]=i.y,n[5]=i.z,n[6]=t.x,n[7]=i.y,n[8]=i.z,n[9]=t.x,n[10]=t.y,n[11]=i.z,n[12]=t.x,n[13]=t.y,n[14]=i.z,n[15]=i.x,n[16]=t.y,n[17]=i.z,n[18]=i.x,n[19]=t.y,n[20]=i.z,n[21]=i.x,n[22]=i.y,n[23]=i.z,n[24]=i.x,n[25]=i.y,n[26]=t.z,n[27]=t.x,n[28]=i.y,n[29]=t.z,n[30]=t.x,n[31]=i.y,n[32]=t.z,n[33]=t.x,n[34]=t.y,n[35]=t.z,n[36]=t.x,n[37]=t.y,n[38]=t.z,n[39]=i.x,n[40]=t.y,n[41]=t.z,n[42]=i.x,n[43]=t.y,n[44]=t.z,n[45]=i.x,n[46]=i.y,n[47]=t.z,n[48]=i.x,n[49]=i.y,n[50]=i.z,n[51]=i.x,n[52]=i.y,n[53]=t.z,n[54]=t.x,n[55]=i.y,n[56]=i.z,n[57]=t.x,n[58]=i.y,n[59]=t.z,n[60]=t.x,n[61]=t.y,n[62]=i.z,n[63]=t.x,n[64]=t.y,n[65]=t.z,n[66]=i.x,n[67]=t.y,n[68]=i.z,n[69]=i.x,n[70]=t.y,n[71]=t.z,this.geometry.attributes.position.needsUpdate=!0,this.geometry.computeBoundingBox(),this.geometry.computeBoundingSphere(),this.matrixAutoUpdate=!1};var LE=function(e){lu(i,e);var t=pu(i);function i(){var e;return ru(this,i),(e=t.call(this,Vp.EXTERNALSCENEMANAGER,{pickableType:Rd.Geometry,priority:20})).globalSpace=!0,e}return i}(cm);LE.prototype.getNode=function(e){for(var t=this.children,i=0,n=t.length;n>i;i+=1)if(t[i].name===e.toString())return t[i];return null},LE.prototype.removeNodeByName=function(e){var t=this.getNode(e);return!!t&&(this.remove(t),!0)},LE.prototype.clearNodes=function(){this.clear()},LE.prototype.setNodeVisibleByName=function(e,t){var i=this.getNode(e);return!!i&&(i.visible=t,!0)},LE.prototype.showAllNodes=function(){for(var e=this.children,t=0,i=e.length;i>t;t+=1)e[t].visible=!0},LE.prototype.hideAllNodes=function(){for(var e=this.children,t=0,i=e.length;i>t;t+=1)e[t].visible=!1};var OE=function(e){lu(i,e);var t=pu(i);function i(){var e;return ru(this,i),(e=t.call(this,Vp.EXTRUDEBODYMANAGER,{pickableType:Rd.Geometry,priority:20})).globalSpace=!0,e.mapColorToNodeId={},e.selectionIds={},e.selectionColor={red:50,green:224,blue:240,alpha:.3},e.selectionEdgeColor={red:50,green:224,blue:240,alpha:1},e}return i}(cm);function NE(e){this.scene=e,this.lightArray=void 0,this.lightHelperArray=void 0,this.lightHelper=!1,this._currentPreset=void 0,this._intensityFactor=xd.LightIntensityFactor,this.defaultShadowLightDir=new Ke(100,-100,-160),this.defaultLightDir=new Ke(100,-100,-160),this.shadowLightDir=new Ke(100,-100,-160),this.lightDir=new Ke(100,-100,-160),this._ambientLight=void 0,this.setLightPreset(xd.LightPreset)}OE.prototype.addNode=function(e,t,i,n,r,o){o=void 0===o||o;var a=this.getNode(e);if(a)return a.material=n,this.setColorInMap(a.name,n),void((a=this.getNode("wireframe_"+e))&&(a.material=r,this.setColorInMap(a.name,r)));var s=[],l=0;if(t.belong&&"user"===t.belong)s=t.roomBoundary,l=t.offsetZ;else{t.version&&"2.0"===t.version&&(t=t.loops&&t.loops.length>0?t.loops[0]:[]);for(var c=t.length,h=0;c>h;h+=1)for(var d=t[h],u=d.length,p=0;u-1>p;p+=1){var g=d[p];s.push(new ke(g.x,g.y)),0===h&&0===p&&(l=g.z)}s.length>0&&s.push(s[0])}var f=new $l(s),m=new Us(f,{amount:i});n.depthTest=!o,m.boundingBox||m.computeBoundingBox();var A=new nn(m,n);A.name=e.toString(),A.translateZ(l),this.setColorInMap(A.name,n),this.add(A),this.updateMatrixWorld(!0);var y=A.geometry.faces,v=[];for(h=0,u=y.length;u>h;h+=1)v.push(y[h].a),v.push(y[h].b),v.push(y[h].c);var C=A.geometry.vertices,I=[];for(h=0,u=C.length;u>h;h+=1)I.push(C[h].x),I.push(C[h].y),I.push(C[h].z);var x=af(I,v,Math.PI/3.5),w=new Ni;w.setIndex(new Mi(x,1)),w.setAttribute("position",new Bi(I,3)),r.depthTest=!o,r.transparent=!0;var M=new La(w,r);M.translateZ(l),M.name="wireframe_"+e,this.setColorInMap(M.name,r),this.add(M),this.updateMatrixWorld(!0)},OE.prototype.setColorInMap=function(e,t){this.mapColorToNodeId[e]={red:255*t.color.r,green:255*t.color.g,blue:255*t.color.b,alpha:t.opacity}},OE.prototype.createMaterial=function(e){return cA.createStandardMaterial(e)},OE.prototype.setNodeMaterial=function(e,t,i){var n=this.getNode(e);if(n){var r=n.material;for(var o in t){r.hasOwnProperty(a=o)&&(r[a]="color"===a?new pi(t[o]):t[o])}}if(n=this.getNode("wireframe_"+e)){r=n.material;for(var o in i){var a;r.hasOwnProperty(a=o)&&(r[a]="color"===a?new pi(i[o]):i[o])}}},OE.prototype.getNode=function(e){for(var t=this.children,i=0,n=t.length;n>i;i+=1)if(t[i].name===e.toString())return t[i];return null},OE.prototype.removeNodeById=function(e){var t=this.getNode(e);return t&&(delete this.mapColorToNodeId[t.name],this.remove(t)),!!(t=this.getNode("wireframe_"+e))&&(delete this.mapColorToNodeId[t.name],this.remove(t),!0)},OE.prototype.clearNodes=function(){this.clear(),this.mapColorToNodeId={}},OE.prototype.setNodeVisibleById=function(e,t){var i=this.getNode(e);return i&&(i.visible=t),!!(i=this.getNode("wireframe_"+e))&&(i.visible=t,!0)},OE.prototype.showAllNodes=function(){for(var e=this.children,t=0,i=e.length;i>t;t+=1)e[t].visible=!0},OE.prototype.hideAllNodes=function(){for(var e=this.children,t=0,i=e.length;i>t;t+=1)e[t].visible=!1},OE.prototype.setNodeColorById=function(e,t){var i=this.getNode(e);if(i){var n=i.material;return n.color=new pi(t.red/255,t.green/255,t.blue/255),n.opacity=t.alpha,t!==this.selectionColor&&t!==this.selectionEdgeColor&&this.setColorInMap(i.name,n),!0}return!1},OE.prototype.getNodeColorById=function(e){return this.mapColorToNodeId[e]},OE.prototype.setWireframeColorById=function(e,t){return this.setNodeColorById("wireframe_"+e,t)},OE.prototype.getWireframeColorById=function(e){return this.getNodeColorById("wireframe_"+e)},OE.prototype.applySelection=function(e){this.clearSelection();var t=this.selectionIds,i=this.mapColorToNodeId,n=e.sceneState.selectionSet;for(var r in n)i[r]&&(t[r]=!0,this.setNodeColorById(r,this.selectionColor),this.setWireframeColorById(r,this.selectionEdgeColor))},OE.prototype.clearSelection=function(){var e=this.mapColorToNodeId;if(this.selectionIds){for(var t=this.children,i=0,n=t.length;n>i;i+=1){var r=t[i],o=e[r.name];r.material.color=new pi(o.red/255,o.green/255,o.blue/255),r.material.opacity=o.alpha}this.selectionIds={}}},OE.prototype.applyHover=function(e){var t=e.sceneState;if(t.hoverId&&!t.isSelected(t.hoverId)){var i=this.getNode(t.hoverId);if(i){this.hoveredId=t.hoverId;var n=this.mapColorToNodeId[this.hoveredId],r=cA.getHoverColorByColor({r:n.red/255,g:n.green/255,b:n.blue/255,a:n.alpha});i.material.color.setRGB(r.r,r.g,r.b),i.material.opacity=r.a}}},OE.prototype.clearHover=function(){var e=this.hoveredId;if(e)if(this.selectionIds[e])this.hoveredId=null;else{var t=this.getNode(e);if(t){var i=this.mapColorToNodeId[e];t.material.color.setRGB(i.red/255,i.green/255,i.blue/255),t.material.opacity=i.alpha,this.hoveredId=null}else this.hoveredId=null}},NE.prototype.destroy=function(){this.scene=void 0,this._clearLights(),this._clearLightHelpers()},NE.prototype.currentLights=function(){if(this.lightArray)return[].concat(this.lightArray)},NE.prototype.setLightPreset=function(e){this._currentPreset!==e&&(xd.LightPreset=e,this._currentPreset=e,this._clearLights(),this._clearLightHelpers(),this._createLights(),this.setIntensityFactor(this._intensityFactor),this.lightHelper&&this._createLightHelpers())},NE.prototype.getLightPreset=function(){return this._currentPreset},NE.prototype.updateLights=function(e){if(this.lightArray){var t=new Ke(0,0,1),i=Math.PI/4,n=1e3,r=e.position.clone();r.sub(e.target),r.normalize();var o=null;if(0===this._currentPreset){var a=this.lightArray[1];a.position.set(r.x,r.y,r.z),a.updateMatrixWorld(!0)}else if(1===this._currentPreset||3===this._currentPreset){var s=this.lightArray[2],l=this.lightArray[3];o=r.clone().applyAxisAngle(t,-1.2*i),s.position.copy(o).normalize(),s.position.multiplyScalar(n),s.position.z=600,s.updateMatrixWorld(),o=r.clone().applyAxisAngle(t,Number(i)),l.position.copy(o).normalize(),l.position.multiplyScalar(n),l.position.z=600,l.updateMatrixWorld()}else if(2===this._currentPreset){var c=this.lightArray[1],h=this.scene.getBoundingBox().getCenter(new Ke),d=new Ke(h.x-(o=this.lightDir).x,h.y-o.y,h.z-o.z);c.position.copy(d),c.target.position.set(h.x,h.y,h.z),c.target.updateMatrixWorld(!0),c.updateMatrixWorld(!0)}else{c=this.lightArray[1];o=r.clone().applyAxisAngle(t,-2*i),c.position.copy(o).normalize(),c.position.multiplyScalar(n),c.position.z=600,c.updateMatrixWorld()}this.lightHelperArray&&this.updateLightHelper()}},NE.prototype.updateLightHelper=function(){for(var e=0;this.lightHelperArray.length>e;e+=1){var t=this.lightHelperArray[e];t.update(),t.updateMatrixWorld(!0)}},NE.prototype.setIntensityFactor=function(e){if(!isNaN(e)){var t=Number(e);if(t>=0&&(this._intensityFactor=t,xd.LightIntensityFactor=this._intensityFactor,this.lightArray))for(var i=0,n=this.lightArray.length;n>i;i+=1){var r=this.lightArray[i];r.intensity=r.initIntensity*this._intensityFactor}}},NE.prototype.getIntensityFactor=function(){return this._intensityFactor},NE.prototype.setAmbientLightIntensity=function(e){if(this._ambientLight){if(isNaN(e))return;var t=Number(e);if(0>t)return;this._ambientLight.intensity=t}},NE.prototype.getAmbientLightIntensity=function(){if(this._ambientLight)return this._ambientLight.intensity},NE.prototype._createLights=function(){var e=null;switch(this._currentPreset){case 0:e=this._lightPreset0();break;case 1:e=this._lightPreset1();break;case 2:e=this._lightPreset2();break;case 3:e=this._lightPreset3();break;case 4:e=this._lightPreset4();break;default:(e=this._commonLights(.72))[1].color.setHex(16777215)}if(this.lightArray=e,this.scene&&this.lightArray)for(var t=0,i=this.lightArray.length;i>t;t+=1)this.scene.add(this.lightArray[t]),this.lightArray[t].updateMatrixWorld()},NE.prototype._clearLights=function(){if(this.lightArray){for(var e=0;this.lightArray.length>e;e+=1){var t=this.lightArray[e];t.parent&&t.parent.remove(t)}this.lightArray=void 0}this._ambientLight=void 0},NE.prototype._createLightHelpers=function(){if(this.lightArray)for(var e=0;this.lightArray.length>e;e+=1){var t=this.lightArray[e];if(t instanceof fc){var i=new Oh(t,6e3);this.lightHelperArray||(this.lightHelperArray=[]),this.lightHelperArray.push(i),this.scene&&this.scene.add(i)}}},NE.prototype._clearLightHelpers=function(){if(this.lightHelperArray){for(var e=0;this.lightHelperArray.length>e;e+=1){var t=this.lightHelperArray[e];t.parent&&t.parent.remove(t)}this.lightHelperArray=void 0}},NE.prototype._commonLights=function(e,t){var i=[],n=new mc(16777215,.6);n.intensity=.3,n.initIntensity=n.intensity,i.push(n),this._ambientLight=n;var r=new fc(16777215,1);return r.color.setHex(14800580),r.position.set(-100,100,160),r.intensity=.72,r.initIntensity=r.intensity,r.distance=300,r.updateMatrixWorld(),i.push(r),xd.EnableShadow&&(r.castShadow=!0,r.shadow.camera.near=0,r.shadow.camera.far=5e6,r.shadow.camera.left=-2e5,r.shadow.camera.right=2e5,r.shadow.camera.top=2e5,r.shadow.camera.bottom=-2e5,r.distance=1110,r.shadow.mapSize.height=1028,r.shadow.mapSize.width=1028),i},NE.prototype._lightPreset0=function(){var e=null;if(!xd.EnableLightmap){e=[];var t=.3,i=new tc(16777215,16777215,t);e.push(i),i.initIntensity=t,i.position.set(0,0,500),i.updateMatrixWorld(!0);var n=new fc(16777215,t=.7);e.push(n),n.initIntensity=t,n.color.setHSL(.1,.95,1),n.position.set(-1,1,.75),n.position.multiplyScalar(50)}return e},NE.prototype._lightPreset1=function(){var e=this._commonLights(.4,.56);e||(e=[]);var t=new fc(16777215,1);e.push(t),t.color.setHex(16777215),t.position.set(100,100,100),t.intensity=.4,t.initIntensity=t.intensity,t.updateMatrixWorld();var i=new fc(16777215,1);return e.push(i),i.color.setHex(16777215),i.position.set(-100,-100,100),i.intensity=.18,i.initIntensity=i.intensity,i.updateMatrixWorld(),e},NE.prototype._lightPreset2=function(){var e=this._commonLights();e||(e=[]);var t=new fc(16777215,1);e.push(t),t.position.set(60,130,80),t.intensity=.28,t.initIntensity=t.intensity,t.updateMatrixWorld();var i=new fc(16777215,1);e.push(i),i.color.setHex(8100788),i.position.set(100,-100,80),i.intensity=.22,i.initIntensity=i.intensity,i.updateMatrixWorld();var n=new fc(16777215,1);return e.push(n),n.color.setHex(8100788),n.position.set(-140,-50,80),n.intensity=.18,n.initIntensity=n.intensity,n.updateMatrixWorld(),e},NE.prototype._lightPreset3=function(){var e=this._commonLights(.4,.56);e||(e=[]);var t=new fc(16777215,1);e.push(t),t.color.setHex(16777215),t.position.set(100,100,100),t.intensity=.22,t.initIntensity=t.intensity,t.updateMatrixWorld();var i=new fc(16777215,1);return e.push(i),i.color.setHex(16777215),i.position.set(-100,-100,100),i.intensity=.18,i.initIntensity=i.intensity,i.updateMatrixWorld(),e},NE.prototype._lightPreset4=function(){var e=this._commonLights(.4,.56);e||(e=[]);var t=new fc(16777215,1);e.push(t),t.color.setHex(16777215),t.position.set(100,100,100),t.intensity=.4,t.initIntensity=t.intensity,t.updateMatrixWorld();var i=new fc(16777215,1);return e.push(i),i.color.setHex(16777215),i.position.set(-100,-100,100),i.intensity=.1,i.initIntensity=i.intensity,i.updateMatrixWorld(),e[0].intensity=.3,e[1].intensity=.2,this.enableShadowLight(),e},NE.prototype.enableShadowLight=function(){this.lightCastShadow?this.lightCastShadow.visible=!0:(this.lightCastShadow=new fc(16777215,.15),this.lightCastShadow.intensity=.5,this.lightCastShadow.initIntensity=.5,this.lightCastShadow.castShadow=!0,this.lightCastShadow.shadow.mapSize.width=1024,this.lightCastShadow.shadow.mapSize.height=1024,this.lightCastShadow.shadow.bias=-9e-4,this.scene.add(this.lightCastShadow)),this.lightCastShadow.updateMatrixWorld()},NE.prototype.getLightDirFromAltitudeAndAzimuth=function(e,t){var i=Math.sin(t),n=Math.cos(t);t>0&&(n=-n);var r=Math.sin(e)/Math.cos(e);return new Ke(i,n,r).multiplyScalar(-100)},NE.prototype.disableShadowLight=function(){this.lightCastShadow&&(this.lightCastShadow.visible=!1)},NE.prototype.updateShadowLight=function(){if(null!==this.scene.geometryGroup.boundingBox&&this.lightCastShadow&&this.lightCastShadow.visible){var e=this.scene.getBoundingBox().clone(),t=new Ke,i=e.getSize(t);i.multiplyScalar(.2),e.min.sub(i),e.max.add(i);var n=e.getCenter(new Ke),r=this.shadowLightDir,o=new Ke(n.x-r.x,n.y-r.y,n.z-r.z);this.lightCastShadow.position.set(o.x,o.y,o.z),this.lightCastShadow.target.position.set(n.x,n.y,n.z),this.lightCastShadow.target.updateMatrixWorld(!0),this.lightCastShadow.updateMatrixWorld(!0);var a=this.lightCastShadow.shadow.camera;a.position.set(o.x,o.y,o.z),a.lookAt(n),a.updateMatrixWorld(),a.matrixWorldInverse.copy(a.matrixWorld).invert(),i=e.getSize(new Ke),e.min.z=e.min.z-.05*i.z;var s=new Jt(new Ke(0,0,1),-e.min.z),l=s.normal.dot(r),c=e.max.clone(),h=-(c.dot(s.normal)+s.constant)/l,d=new Ke;d.copy(r).multiplyScalar(h).add(c),e.expandByPoint(d),e.applyMatrix4(a.matrixWorldInverse),a.left=e.min.x,a.right=e.max.x,a.top=e.max.y,a.bottom=e.min.y,a.far=1.5*-e.min.z,a.near=-e.max.z,a.updateProjectionMatrix()}},NE.prototype.setShadowAttributes=function(e){var t=this.lightCastShadow.shadow.camera,i=this.lightCastShadow.shadow,n=this.lightCastShadow;e.position&&(t.position.copy(e.position),n.position.copy(e.position)),e.target&&(t.lookAt(e.target),n.target.position.copy(e.target)),e.far&&(t.far=e.far),e.near&&(t.near=e.near),e.mapSizeWidth&&(i.mapSize.width=e.mapSizeWidth),e.mapSizeHeight&&(i.mapSize.height=e.mapSizeHeight),e.bias&&(i.bias=e.bias),n.updateMatrixWorld(!0),n.target.updateMatrixWorld(!0),t.updateMatrixWorld(!0),t.matrixWorldInverse.copy(t.matrixWorld).invert(),t.updateProjectionMatrix()},NE.prototype.resetShadowAttributes=function(){this.lightCastShadow.shadow.mapSize.width=1024,this.lightCastShadow.shadow.mapSize.height=1024,this.lightCastShadow.shadow.bias=-9e-4,this.shadowLightDir=new Ke(100,-100,-160),this.updateShadowLight()},NE.prototype.disableLights=function(){if(this.lightArray)for(var e=0,t=this.lightArray.length;t>e;e+=1)this.lightArray[e].visible=!1},NE.prototype.enableLights=function(){if(this.lightArray)for(var e=0,t=this.lightArray.length;t>e;e+=1)this.lightArray[e].visible=!0};var PE=new ke,GE=new He,KE=function(e){lu(i,e);var t=pu(i);function i(e){var n;return ru(this,i),(n=t.call(this)).type="Scene",n.autoUpdate=!1,n.tempVector3=new Ke,n.objectGroups=new cm,n.add(n.objectGroups),n.geometryGroup=new cm(Vp.GEOMETRY,{pickableType:Rd.Geometry,globalSpace:!0}),n.geometryGroup.boundingBox=new He,n.pool=new FE(Bv,0),n.expandScalar=1.01,n.clipPlanes=null,n.fillClipPlane=null,n.areaNode=null,n.extrudeBodyManager=null,n.externalScene=null,n.externalComponentManager=null,n.customPlaneManager=null,n.axisGridManager=null,n.lightManager=new NE(du(n)),n.selectedMeshes=[],n.nonSelectedMeshes=[],n.selectedInstanceMeshes=[],n.nonSelectedInstanceMeshes=[],n.sunDirection=new Ke(-1,1.6,1),n._planIntersect=new Ke,n._renderedObjects=[],n.componentTransformControl=void 0,n._viewerImpl=e,n._projectorLightCollection=new CE,n.addObject(n._projectorLightCollection),n._aabbCollection=new $M(du(n)),n.addObject(n._aabbCollection),n._adsorbControl=new vE(du(n)),n.addObject(n._adsorbControl),n.renderer=void 0,n._tweens=new UE,n.frameState={scene:du(n),viewerImpl:void 0,frameNumber:0,maxAnisotropy:0,pixelRatio:void 0,bufferSize:PE},n}return i}(Vo);KE.prototype.createCapStencilMaterials=function(){this.backMaterial||(this.backMaterial=cA.createStandardMaterial({color:16711680,colorWrite:!1,depthWrite:!1,depthTest:!1,side:1,stencilWrite:!0,stencilFunc:ue,stencilRef:1,stencilFuncMask:255,stencilFail:oe,stencilZFail:oe,stencilZPass:se}),this.frontMaterial=cA.createStandardMaterial({color:255,colorWrite:!1,depthWrite:!1,depthTest:!1,side:0,stencilWrite:!0,stencilFunc:ue,stencilRef:1,stencilFuncMask:255,stencilFail:oe,stencilZFail:oe,stencilZPass:le}),this.backInstanceMaterial=cA.createStandardMaterial({color:16711680,colorWrite:!1,depthWrite:!1,depthTest:!1,side:1,stencilWrite:!0,stencilFunc:ue,stencilRef:1,stencilFuncMask:255,stencilFail:oe,stencilZFail:oe,stencilZPass:se}),this.backInstanceMaterial.defines.USE_INSTANCE="",this.backInstanceMaterial.defines.USE_INSTANCE_NORMAL="",this.frontInstanceMaterial=cA.createStandardMaterial({color:255,colorWrite:!1,depthWrite:!1,depthTest:!1,side:0,stencilWrite:!0,stencilFunc:ue,stencilRef:1,stencilFuncMask:255,stencilFail:oe,stencilZFail:oe,stencilZPass:le}),this.frontInstanceMaterial.defines.USE_INSTANCE="",this.frontInstanceMaterial.defines.USE_INSTANCE_NORMAL="")},KE.prototype.destroy=function(){this.lightManager.destroy(),this.lightManager=null,this.clearAll(),this.pool.destroy(),this.pool=null,this.geometryGroup=null,this.objectGroups=null,this.clipPlanes=null,this.fillClipPlane=null,this.boundaryEdge=null,this.extrudeBodyManager=null,this.externalComponentManager=null,this.axisGridManager=null,this.IBLMaps=null,this.transformMatrix=null,this.selectedMeshes=null,this.nonSelectedMeshes=null,this.selectedInstanceMeshes=null,this.nonSelectedInstanceMeshes=null,this._renderedObjects=null},KE.prototype.resizePool=function(e){xd.MergeComponent||(this.geometryGroup.clear(),this.pool.resize(e,{parent:this.geometryGroup}))},KE.prototype.clearAll=function(){this.pool.clear(),this.autoUpdate=!1},KE.prototype.getRootNode=function(){return this.geometryGroup},KE.prototype.hasBoundingBox=function(){return!!this.geometryGroup.boundingBox},KE.prototype.getBoundingBox=function(){var e=this.getBoundingBoxWorld();return e.applyMatrix4(this.geometryGroup.matrix),e},KE.prototype.getOriginalBoundingBoxWorld=function(){return this.originalBoundingBoxWorld},KE.prototype.getGeometryBoundingBox=function(){var e=new He;e.copy(this.geometryGroup.boundingBox);var t=new Ke,i=e.getSize(t);return i.multiplyScalar(this.expandScalar-1),e.min.sub(i),e.max.add(i),e.applyMatrix4(this.geometryGroup.matrix),e},KE.prototype.getBoundingBoxWorld=function(){var e=new He,t=new Ke;return function(){e.copy(this.geometryGroup.boundingBox),this.componentTransformControl&&e.union(this.componentTransformControl.getBoundingBox());var i=e.getSize(t);return i.multiplyScalar(this.expandScalar-1),e.min.sub(i),e.max.add(i),this.fillClipPlane&&this.fillClipPlane.visible?e.expandByObject(this.fillClipPlane):this.clipPlanes&&this.clipPlanes.visible&&e.expandByObject(this.clipPlanes),e}}(),KE.prototype.setBoundingBoxWorld=function(e){this.geometryGroup.boundingBox?this.geometryGroup.boundingBox.copy(e):this.geometryGroup.boundingBox=e;var t=e.clone();if(this.clipPlanes&&this.clipPlanes.visible){var i=t.getSize(new Ke);i.multiplyScalar(this.expandScalar-1),t.min.sub(i),t.max.add(i),this.clipPlanes.setSectionBox(t.min,t.max)}if(this.fillClipPlane&&this.fillClipPlane.visible){var n=new Ke;t.getSize(n),n.multiplyScalar(.05),t.min.sub(n),t.max.add(n),this.fillClipPlane.resize(t.getSize(n),t.getCenter(new Ke))}},KE.prototype.expandBoundingBoxWorldBy=function(e){if(e){var t=e;e instanceof Array==!1&&(t=[e]);for(var i=0,n=t.length;n>i;i+=1){var r=t[i];(r instanceof nn||r instanceof Yt)&&this.geometryGroup.boundingBox.expandByObject(r)}}},KE.prototype.getTransformMatrixGlobal=function(){return this.transformMatrix},KE.prototype.getMatrixGlobal=function(){return this.geometryGroup.matrix.clone()},KE.prototype.getGlobalScaleFactor=function(){return this.geometryGroup.matrix.elements[0]},KE.prototype.getMatrixWorldGlobal=function(){return this.geometryGroup.matrixWorld},KE.prototype.getRotationGlobal=function(){if(this.geometryGroup.matrix){var e=new yt;e.extractRotation(this.geometryGroup.matrix);var t=new bt;return t.setFromRotationMatrix(e),t}return null},KE.prototype.getTrackingPointFromBoundingBox=function(e,t){if(!this.geometryGroup.boundingBox)return null;var i=t.origin,n=this.getBoundingBox(),r=0,o=[new Ke,new Ke,new Ke,new Ke,new Ke,new Ke,new Ke,new Ke];o[0].set(n.min.x,n.min.y,n.min.z),o[1].set(n.min.x,n.min.y,n.max.z),o[2].set(n.min.x,n.max.y,n.min.z),o[3].set(n.min.x,n.max.y,n.max.z),o[4].set(n.max.x,n.min.y,n.min.z),o[5].set(n.max.x,n.min.y,n.max.z),o[6].set(n.max.x,n.max.y,n.min.z),o[7].set(n.max.x,n.max.y,n.max.z);for(var a=0;8>a;a+=1){var s=new Ke;s.subVectors(o[a],i);var l=s.dot(e);l>r&&(r=l)}var c=e.clone().multiplyScalar(r),h=i.clone().add(c),d=new Jt;return d.setFromNormalAndCoplanarPoint(e,h),t.intersectPlane(d,new Ke)},KE.prototype.getNearDepthByRect=function(e,t){var i=1/0,n=new yt,r=new Ke;function o(e){r.setFromMatrixPosition(e.matrixWorld),r.applyProjection(n);var t=r.z;t>=i||0>t||t>1||(i=t)}function a(e,t){if(t instanceof Bv){if(!function(e,t){if(!t.boundingBox||t instanceof nn){var i=t.geometry;null===i.boundingBox&&i.computeBoundingBox(),GE.copy(i.boundingBox),GE.applyMatrix4(t.matrixWorld)}else GE.copy(t.boundingBox),GE.applyMatrix4(t.matrixWorld);return e.intersectsBox(GE)}(e,t))return;o(t)}else if(t.worldBoundingBox){if(!e.intersectsBox(t.worldBoundingBox))return;o(t)}var i=t.children;if(i)for(var n=0,r=i.length;r>n;n++){var s=i[n];s.visible&&a(e,s)}}n.multiplyMatrices(t.projectionMatrix,t.matrixWorldInverse);for(var s=this.geometryGroup.children,l=0,c=s.length;c>l;l++){var h=s[l];h.visible&&a(e,h)}return i},KE.prototype.getExpandScalar=function(){return this.expandScalar},KE.prototype.hasClipPlanes=function(){return null!==this.clipPlanes},KE.prototype.getClipPlanes=function(e){var t=this.getBoundingBox(),i=t.getSize(new Ke),n=t.getCenter(this.tempVector3);return null===this.clipPlanes?(this.clipPlanes=new IM(i,n),this.objectGroups.add(this.clipPlanes)):e&&this.clipPlanes.setSectionBox(t.min,t.max),this.clipPlanes},KE.prototype.setClipPlanes=function(e){if(e){var t=this.getClipPlanes();e.setFromCenterAndSize(e.getCenter(new Ke),e.getSize(new Ke).multiplyScalar(this.expandScalar)),t.setSectionBox(e.min,e.max)}},KE.prototype.resetClipPlanes=function(){var e=this.getClipPlanes(),t=this.getBoundingBox();e.reset(),t.max.x!==-1/0&&t.max.y!==-1/0&&t.max.z!==-1/0&&t.min.x!==1/0&&t.min.y!==1/0&&t.min.z!==1/0?(t.setFromCenterAndSize(t.getCenter(new Ke),t.getSize(new Ke)),e.setSectionBox(t.min,t.max)):this.clipPlanes=null},KE.prototype.hasFillClipPlanes=function(){return null!=this.fillClipPlane},KE.prototype.getFillClipPlane=function(){var e=new He;e.copy(this.geometryGroup.boundingBox),e.applyMatrix4(this.geometryGroup.matrix);var t=e.getSize(new Ke);t.multiplyScalar(.05),e.min.sub(t),e.max.add(t);var i=e.getSize(new Ke),n=e.getCenter(new Ke);return null===this.fillClipPlane?(this.fillClipPlane=new jM(i,n),this.objectGroups.add(this.fillClipPlane)):this.fillClipPlane.cubeSize.equals(i)||this.fillClipPlane.resize(i,n),this.fillClipPlane},KE.prototype.disableClipPlanes=function(){null!=this.clipPlanes&&(this.clipPlanes.enable(!1,!1),this.clipPlanes.update()),null!=this.fillClipPlane&&(this.fillClipPlane.enable(!1,!1),this.fillClipPlane.update())},KE.prototype.getAreaNode=function(){return this.areaNode},KE.prototype.getAxisGridManager=function(){return this.axisGridManager},KE.prototype.getExtrudeBodyManager=function(){return null===this.extrudeBodyManager&&(this.extrudeBodyManager=new OE,this.objectGroups.add(this.extrudeBodyManager),this.extrudeBodyManager.matrix.copy(this.geometryGroup.matrix),this.extrudeBodyManager.matrixAutoUpdate=!1,this.extrudeBodyManager.updateMatrixWorld(!0)),this.extrudeBodyManager},KE.prototype.getCustomPlaneManager=function(){return this.customPlaneManager},KE.prototype.getExternalScene=function(){return null===this.externalScene&&(this.externalScene=new LE,this.add(this.externalScene),this.externalScene.updateMatrixWorld(!0)),this.externalScene},KE.prototype.shrinkScopeByClipPlane=function(e,t){if(this.clipPlanes&&this.clipPlanes.isEnabled()){var i=this.clipPlanes.hitTest(e);if(null===i.distance&&void 0===i.distance)return;i.sign?i.distance>t.near&&(t.near=i.distance):t.far>i.distance&&(t.far=i.distance)}},KE.prototype.updateWorldMatrixByMatrix=function(e){for(var t=this.objectGroups.children,i=0,n=t.length;n>i;i+=1)t[i].globalSpace&&(t[i].matrix.copy(e),t[i].matrixAutoUpdate=!1,t[i].updateMatrixWorld(!0))},KE.prototype.currentLights=function(){return this.lightManager.currentLights()},KE.prototype.setLightPreset=function(e){this.lightManager.setLightPreset(e)},KE.prototype.getLightPreset=function(){return this.lightManager.getLightPreset()},KE.prototype.setLightIntensityFactor=function(e){this.lightManager.setIntensityFactor(e)},KE.prototype.updateLights=function(e){this.lightManager.updateLights(e)},KE.prototype.setAmbientLightIntensity=function(e){this.lightManager.setAmbientLightIntensity(e)},KE.prototype.getAmbientLightIntensity=function(){return this.lightManager.getAmbientLightIntensity()},KE.prototype.getOrCreateGroup=function(e,t){for(var i=this.objectGroups.children,n=0,r=i.length;r>n;n+=1)if(i[n].name===e)return i[n];var o=new cm(e,t);return o.isGlobalSpace()&&(o.matrix.copy(this.geometryGroup.matrix),o.matrixAutoUpdate=!1,o.updateMatrixWorld(!0)),this.objectGroups.add(o),o},KE.prototype.getGroup=function(e){for(var t=this.objectGroups.children,i=0,n=t.length;n>i;i+=1)if(t[i].name===e)return t[i];return null},KE.prototype.getGroupType=function(e){var t=e.split("|");return{groupType:t[0],modelKey:t.length>1?t[1]:void 0}},KE.prototype.getGroups=function(){return this.objectGroups.children},KE.prototype.removeGroup=function(e){this.objectGroups.remove(e)},KE.prototype.removeGroupByName=function(e){this.objectGroups.removeByName(e)},KE.prototype.hasGroup=function(e){return this.objectGroups.hasChild(e)},KE.prototype.prepareScene=function(){},KE.prototype.parseRootNode=function(e){var t=this.geometryGroup,i=wp.box3FromObject(e.minBoundary,e.maxBoundary);null===t.boundingBox||t.boundingBox.isEmpty()?t.boundingBox=i:(t.boundingBox.expandByPoint(i.min),t.boundingBox.expandByPoint(i.max)),t.updateMatrixWorld(!0)},KE.prototype.intersectToWorld=function(e,t){var i=this.getMatrixGlobal();e.worldPosition=by.getWorldPositionOfMesh(e.point,i);var n=t.getComponentInfoByUserId(e.userId);n&&(e.worldBoundingBox=n.boundingBox.clone())},KE.prototype.worldToDrawing=function(e){var t=this.getMatrixGlobal(),i=new Ke(e.x,e.y,e.z);return i.applyMatrix4(t),i},KE.prototype.drawingToWorld=function(e){var t=this.getMatrixGlobal(),i=new yt;i.copy(t).invert();var n=new Ke(e.x,e.y,e.z);return n.applyMatrix4(i),n},KE.prototype.getBoundingBoxWorldByMesh=function(e){var t=this.getMatrixGlobal(),i=e.boundingBox;i||(e.geometry.boundingBox||e.geometry.computeBoundingBox(),i=e.geometry.boundingBox);var n=i.clone();n.applyMatrix4(e.matrixWorld);var r=new yt;return r.copy(t).invert(),n.applyMatrix4(r),n},KE.prototype.getObjectPool=function(){return this.pool},KE.prototype.getBoundingBoxOfGeometries=function(e){var t=new He,i=[];if(Array.isArray(e))i=e;else for(var n in e)e.hasOwnProperty(n)&&i.push(n);for(var r=0,o=i.length;o>r;r+=1){var a=this.objectGroups.getObjectByProperty("key",i[r]);if(a){var s=a.geometry;if(s){s.boundingBox||s.computeBoundingBox();var l=s.boundingBox;if(l){var c=l.clone();a.matrixWorld&&c.applyMatrix4(a.matrixWorld),t.expandByPoint(c.min),t.expandByPoint(c.max)}}else Bu.log("empty geometry!")}}return t},KE.prototype.adjustInstanceVisibility=function(e){this.traverse((function(t){if((t instanceof nn||t instanceof La)&&t.geometry instanceof xc){var i=t.visible;e&&!t.bVisible||(t.visible=e),t.bVisible=i}}))},KE.prototype.adjustVisibility=function(e){this.traverse((function(t){if((t instanceof nn||t instanceof La)&&!(t.geometry instanceof xc)){var i=t.visible;e&&!t.bVisible||(t.visible=e),t.bVisible=i}}))},KE.prototype.changeVisibilityOfSelectedObjects=function(e){var t=this;e||(t.selectedMeshes.length=0,t.selectedInstanceMeshes.length=0);var i=t.selectedMeshes,n=t.selectedInstanceMeshes;this.traverse((function(r){(r instanceof nn||r instanceof La)&&(r.geometry instanceof xc?e?function(e){for(var i=0,n=t.selectedInstanceMeshes.length;n>i;i+=1)if(e===t.selectedInstanceMeshes[i].object){for(var r=t.selectedInstanceMeshes[i].indices,o=e.geometry.getAttribute("vState").array,a=0,s=r.length;s>a;a+=1)o[r[a]]=Wd.SELECTED;e.geometry.getAttribute("vState").needsUpdate=!0}}(r):function(e){if(e.visible){for(var t=[],i=e.geometry.getAttribute("vState").array,r=0;i.length>r;r+=1)i[r]===Wd.SELECTED&&(t.push(r),i[r]=Wd.HIDDEN);t.length&&(e.geometry.getAttribute("vState").needsUpdate=!0,n.push({object:e,indices:t}))}}(r):e?function(e){for(var i=0,n=t.selectedMeshes.length;n>i;i+=1)if(e===t.selectedMeshes[i].object)for(var r=t.selectedMeshes[i].indices,o=0,a=r.length;a>o;o+=1){var s=r[o],l=e.geometry.groups[s.idx];l.start=s.start,l.count=s.count}}(r):function(e){if(e._indicesGroup&&e.visible){var t=[],n=e.geometry.groups;if(n&&n.length){for(var r=0,o=n.length;o>r;r+=1){var a=n[r];a.materialIndex===Zd.SELECTED&&(t.push({idx:r,start:a.start,count:a.count}),a.start=0,a.count=0)}t.length&&i.push({object:e,indices:t})}}}(r))}))},KE.prototype.changeVisibilityOfNonSelectedObjects=function(e){var t=this;e||(t.nonSelectedMeshes.length=0,t.nonSelectedInstanceMeshes.length=0);var i=t.nonSelectedMeshes,n=t.nonSelectedInstanceMeshes;this.traverse((function(r){(r instanceof nn||r instanceof La)&&(r.geometry instanceof xc?e?function(e){for(var i=0,n=t.nonSelectedInstanceMeshes.length;n>i;i+=1)if(e===t.nonSelectedInstanceMeshes[i].object){for(var r=t.nonSelectedInstanceMeshes[i].indices,o=e.geometry.getAttribute("vState").array,a=0,s=r.length;s>a;a+=1)o[r[a].idx]=r[a].state;e.geometry.getAttribute("vState").needsUpdate=!0}}(r):function(e){if(e.visible){for(var t=[],i=e.geometry.getAttribute("vState").array,r=0,o=i.length;o>r;r+=1)i[r]!==Wd.SELECTED&&i[r]!==Wd.HIDDEN&&(t.push({idx:r,state:i[r]}),i[r]=Wd.HIDDEN);t.length&&(e.geometry.getAttribute("vState").needsUpdate=!0,n.push({object:e,indices:t}))}}(r):e?function(e){for(var i=0,n=t.nonSelectedMeshes.length;n>i;i+=1)if(e===t.nonSelectedMeshes[i].object){var r=t.nonSelectedMeshes[i].indices;if(null===r)e.visible=!0;else for(var o=0,a=r.length;a>o;o+=1){var s=r[o],l=e.geometry.groups[s.idx];l.start=s.start,l.count=s.count}}}(r):function(e){if(e._indicesGroup&&e.visible){var t=[],n=e.geometry.groups;if(n&&n.length){for(var r=0,o=n.length;o>r;r+=1){var a=n[r];a.materialIndex!==Zd.SELECTED&&(t.push({idx:r,start:a.start,count:a.count}),a.start=0,a.count=0)}t.length?i.push({object:e,indices:t}):(e.visible=!1,i.push({object:e,indices:null}))}else e.visible=!1,i.push({object:e,indices:null})}}(r))}))},KE.prototype.clearSelectedAndNonSelectedMeshes=function(){this.selectedMeshes.length=0,this.nonSelectedMeshes.length=0,this.selectedInstanceMeshes.length=0,this.nonSelectedInstanceMeshes.length=0},KE.prototype.setSkyBox=function(e,t,i,n,r){var o=e,a=t;if(a){var s=this;(new bl).setPath(o).load(a,(function(e){s.background=e,i&&i()}),n,r)}else Bu.error("天空盒资源无效")},KE.prototype.drawBoundingBox=function(e){if(e){var t=this.getOrCreateGroup("BoundingBox",{pickable:0,priority:2}),i=this.getBoundingBox();void 0===this.boudingBoxNode?(this.boudingBoxNode=new QE(i,16711680),t.add(this.boudingBoxNode)):this.boudingBoxNode.updateBBox(i),this.boudingBoxNode.updateMatrixWorld(!0)}else this.removeGroupByName("BoundingBox")},KE.prototype.calculateGisMapBox=function(e){var t=this.getGroup("ExternalComponentManager"),i=this.getBoundingBoxWorld(),n=i.clone();if(t){var r=e.position.clone(),o=this.getMatrixWorldGlobal(),a=(new yt).copy(o).invert();r.applyMatrix4(a);var s=6370856e3,l=r.z-i.min.z;l=Math.abs(l);var c=s*Math.acos(s/(s+l));n.min.x=r.x-c,n.max.x=r.x+c,n.min.y=r.y-c,n.max.y=r.y+c,n.min.z=i.min.z,n.max.z=i.max.z}return n},KE.prototype.getReceivingPlane=function(e){if(!this.receivingPlane){this.receivingPlane=this.getOrCreateGroup(Vp.RECEIVESHADOWPLANE);var t=new qs;t.transparent=!0,t.opacity=.2,t.side=2;var i=new In(1e6,1e6),n=new nn(i,t);n.receiveShadow=!0,this.receivingPlane.add(n),this.add(this.receivingPlane),this.receivingPlane.matrixAutoUpdate=!1,this.updateReceivingPlane()}return this.receivingPlane.visible=e,this.receivingPlane},KE.prototype.updateReceivingPlane=function(){var e=this.receivingPlane.children[0],t=this.getBoundingBoxWorld(),i=t.getCenter(new Ke),n=t.getSize(new Ke);e.position.z=t.min.z-.05*n.z,e.position.x=i.x,e.position.y=i.y,e.scale.x=n.x/1e4,e.scale.y=n.y/1e4,this.receivingPlane.updateMatrixWorld(!0)},KE.prototype.executeUpdate=function(e){this.updateFrameState(),this.updateFixedFrame(this.frameState,e)},KE.prototype.executeUpdatePostRender=function(){this.updatePostRender(this.frameState)},KE.prototype.updateFrameState=function(){var e=this.frameState;e.frameNumber+=1,e.pixelRatio=this.renderer.getPixelRatio(),e.viewerImpl=this.viewerImpl,this.renderer.getSize(e.bufferSize)},KE.prototype.initializeFrame=function(){this._tweens.update()},Object.defineProperties(KE.prototype,{lightArray:{get:function(){return Bu.warn("BOS3D.Scene: .lightArray 现在为 .lightManager.lightArray"),this.lightManager.lightArray}},lightHelperArray:{get:function(){return Bu.warn("BOS3D.Scene: .lightHelperArray 现在为 .lightManager.lightHelperArray"),this.lightManager.lightHelperArray}},projectorLightCollection:{get:function(){return this._projectorLightCollection}},tweens:{get:function(){return this._tweens}},aabbCollection:{get:function(){return this._aabbCollection}},adsorbControl:{get:function(){return this._adsorbControl}},viewerImpl:{get:function(){return this._viewerImpl},set:function(e){this._viewerImpl=e,this.frameState.viewerImpl=e,this.aabbCollection._viewerImpl=e}}});var VE=function(e){this.selectionSet={},this.modelSelectionSet={},this.selectionMaterial=cA.createHighlightMaterial(),this.selectionMaterial.colorState=Jd.SELECT,this.selectionMaterial.name="selection",this.selectionMaterial.refreshUniforms(),this.hoverId=void 0,this.hoverMaterialDefaultParams={color:14540253,opacity:.9,transparent:!0,side:2},this.hoverMaterial=cA.createStandardMaterial(this.hoverMaterialDefaultParams),this.hoverMaterial.name="hover",this.boxMaterialDefaultParams={color:16776960,opacity:1,transparent:!1},this.boxMaterial=new Sa(this.boxMaterialDefaultParams),this.boxMaterial.name="box",this.modelManager=e,this.blinkComponentIds={};var t=this;this.filter=e.filter,this.filter.observerForSceneState=function(i){t.removeSelection(i),t.clearBlinkComponentsById(i),e.viewerImpl.render()},this.phongHoverMaterial=new $s(this.hoverMaterialDefaultParams),this.phongSelectionMaterial=new $s(xd.SelectionColor)};VE.prototype={constructor:VE,destroy:function(){this.selectionSet=null,this.blinkComponentIds=null,this.modelManager=null,this.selectionMaterial.destroy(),this.selectionMaterial=null,this.hoverMaterial.destroy(),this.hoverMaterial=null,this.phongHoverMaterial.dispose(),this.phongHoverMaterial=null,this.phongSelectionMaterial.dispose(),this.phongSelectionMaterial=null},_dispatchChangeEvent:function(){var e=this.getSelection();if(xd.EnableSelectionBoundingBox){var t=this.modelManager.scene.getOrCreateGroup("BoundingBox");if(e&&e.length>0){var i=this.modelManager.viewerImpl.getBoundingBoxByIds(e);if(i.isEmpty())return void(t.visible=!1);t.visible=!0;var n=t.getObjectByName("Box");if(!n){var r=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 Ni;a.setIndex(new Ai(r,1)),a.setAttribute("position",new Ai(o,3)),(n=new La(a,this.boxMaterial)).name="Box",n.matrixAutoUpdate=!1,t.add(n)}var s=n.geometry.attributes.position,l=s.array,c=i.min,h=i.max;l[0]=h.x,l[1]=h.y,l[2]=h.z,l[3]=c.x,l[4]=h.y,l[5]=h.z,l[6]=c.x,l[7]=c.y,l[8]=h.z,l[9]=h.x,l[10]=c.y,l[11]=h.z,l[12]=h.x,l[13]=h.y,l[14]=c.z,l[15]=c.x,l[16]=h.y,l[17]=c.z,l[18]=c.x,l[19]=c.y,l[20]=c.z,l[21]=h.x,l[22]=c.y,l[23]=c.z,s.needsUpdate=!0}else t.visible=!1}else{var d=this.modelManager.scene.getObjectByName("BoundingBox");d&&(d.visible=!1)}this.modelManager.dispatchEvent({type:Fd.ON_SELECTION_CHANGED,selectionList:e})},clearSelection:function(e){var t,i=!1;if(void 0===e){var n=[];for(var r in this.selectionSet){for(var o in i=!1,t=this.getSelectionSet(r))if(t.hasOwnProperty(o)){i=!0;break}i&&n.push(r)}if(n.length){for(var a=0,s=n.length;s>a;a+=1)this.selectionSet[n[a]]={},this.modelManager.clearSelection(n[a]);this._dispatchChangeEvent()}}else{for(var o in t=this.getSelectionSet(e))if(t.hasOwnProperty(o)){i=!0;break}i&&(this.selectionSet[e]={},this.modelManager.clearSelection(e),this._dispatchChangeEvent())}},clearModelSelection:function(){var e=!1;for(var t in this.modelSelectionSet)if(this.modelSelectionSet.hasOwnProperty(t)){e=!0,this.modelSelectionSet={};break}e&&(this.modelManager.clearSelection(),this._dispatchChangeEvent())},addSelection:function(e,t){if(e&&e.length>=1){var i,n=[],r=!1,o=this.modelManager,a=this.filter;if(void 0===t){for(var s={},l=o.getModelKeys(),c=[],h=0,d=l.length;d>h;h+=1){var u=l[h];i=this.getSelectionSet(u),r=!1;for(var p=e.length-1;p>=0;p-=1){o.isUserIdExist(m=e[p],u)&&(!i[m]&&a.isComponentActive(m,u)&&(i[m]=!0,r=!0),s[m]=!0)}r&&c.push(u)}for(p=e.length-1;p>=0;p-=1){s[m=e[p]]||n.push(m)}if(n.length>0&&o.dispatchEvent({type:Fd.ON_SELECTION_FAILED,failedId:n}),c.length){for(var g=0,f=c.length;f>g;g+=1)this.modelManager.applySelection(c[g]);this._dispatchChangeEvent()}}else{i=this.getSelectionSet(t);for(p=e.length-1;p>=0;p-=1){var m;o.isUserIdExist(m=e[p],t)?!i[m]&&a.isComponentActive(m,t)&&(i[m]=!0,r=!0):n.push(m)}n.length>0&&o.dispatchEvent({type:Fd.ON_SELECTION_FAILED,failedId:n}),r&&(this.modelManager.applySelection(t),this._dispatchChangeEvent())}}},addModelSelection:function(e){if(e){for(var t=this.modelSelectionSet,i=!1,n=e.length-1;n>=0;n-=1){var r=e[n];!t.hasOwnProperty(r)&&this.filter.isComponentActive(r)&&(t[r]=!0,i=!0)}i&&(this.modelManager.applySelection(),this._dispatchChangeEvent())}},setSelection:function(e,t){if(e&&e.length>=1)if(void 0===t){for(var i in this.selectionSet)delete this.selectionSet[i];this.addSelection(e)}else this.selectionSet[t]={},this.addSelection(e,t)},setModelSelection:function(e){e||(e=[]);for(var t=[],i=e.length-1;i>=0;i-=1)this.modelManager.isUserIdExist(e[i])||t.push(e[i]);t.length>0&&this.modelManager.dispatchEvent({type:Fd.ON_SELECTION_FAILED,failedId:t});var n=this.modelSelectionSet={};for(i=e.length-1;i>=0;i-=1){this.filter.isComponentActive(e[i])&&(n[e[i]]=!0)}this.modelManager.applySelection(),this._dispatchChangeEvent()},removeSelection:function(e,t){if(e&&e.length>=1){var i=!1;if(void 0===t){var n=[];for(var r in this.selectionSet){var o=this.getSelectionSet(r);i=!1;for(var a=0,s=e.length;s>a;a+=1){var l=e[a];o[l]&&(delete o[l],i=!0)}i&&n.push(r)}if(n.length){for(var c=0,h=n.length;h>c;c+=1)this.modelManager.applySelection(n[c]);this._dispatchChangeEvent()}}else{for(var d=this.getSelectionSet(t),u=0,p=e.length;p>u;u+=1){var g=e[u];d[g]&&(delete d[g],i=!0)}i&&(this.modelManager.applySelection(t),this._dispatchChangeEvent())}}},removeModelSelection:function(e){var t=!1,i=this.modelSelectionSet;if(e&&e.length>0)for(var n=0,r=e.length;r>n;n+=1){var o=e[n];i.hasOwnProperty(o)&&(delete i[o],t=!0)}t&&(this.modelManager.applySelection(),this._dispatchChangeEvent())},getSelection:function(e){var t={};if(void 0===e)for(var i in this.selectionSet)for(var n=this.getSelectionSet(i),r=Object.keys(n),o=0,a=r.length;a>o;o+=1)t[r[o]]=!0;else t=this.getSelectionSet(i);return Object.keys(t)},getModelSelection:function(){return Object.keys(this.modelSelectionSet)},hasSelection:function(e){var t,i=!1;if(void 0===e)for(var n in this.selectionSet){for(var r in t=this.getSelectionSet(n))if(t.hasOwnProperty[r]){i=!0;break}if(i)break}else for(var r in t=this.getSelection(e))if(t.hasOwnProperty[r]){i=!0;break}return i},hasModelSelection:function(){return this.getSelection().length>0},getSelectionSet:function(e){if(void 0===e){var t={};for(var i in this.selectionSet)for(var n=this.getSelectionSet(i),r=Object.keys(n),o=0,a=r.length;a>o;o+=1)t[r[o]]=!0;return t}return void 0===this.selectionSet[e]&&(this.selectionSet[e]={}),this.selectionSet[e]},getModelSelectionSet:function(){return this.selectionSet},isSelected:function(e,t){var i,n=!1;if(void 0===t){for(var r in this.selectionSet)if((i=this.selectionSet[r])&&i[e]){n=!0;break}}else(i=this.selectionSet[t])&&i[e]&&(n=!0);return n},isModelSelected:function(e){return this.modelSelectionSet.hasOwnProperty(e)},setHoverId:function(e,t){this.hoverId=e,this.modelManager.applyHover(t)},clearHover:function(e){this.hoverId=void 0,this.modelManager.clearHover(e)},getHoverMaterial:function(e){var t=e&&e.isMeshPhongMaterial?this.phongHoverMaterial.clone():this.hoverMaterial.clone();if(e&&e.hasOwnProperty("color")){var i=e.color.clone(),n=Math.max(i.r,Math.max(i.g,i.b));0===n&&(n=.5),i.r+=0===i.r?.3*n:.2*i.r,i.g+=0===i.g?.3*n:.2*i.g,i.b+=0===i.b?.3*n:.2*i.b,i.r>1&&(i.r=1),i.g>1&&(i.g=1),i.b>1&&(i.b=1),1===i.r&&1===i.g&&1===i.b&&(i.r=.87,i.g=.87,i.b=.87),t.color.setHex(i.getHex()),t.opacity=void 0!==e.opacity?e.opacity:this.hoverMaterialDefaultParams.opacity,t.transparent=void 0!==e.transparent?e.transparent:this.hoverMaterialDefaultParams.transparent,t.side=void 0!==e.side?e.side:this.hoverMaterialDefaultParams.side,void 0!==e.metalness&&(t.metalness=e.metalness),void 0!==e.roughness&&(t.roughness=e.roughness),void 0!==e.bumpMap&&(t.bumpMap=e.bumpMap),void 0!==e.alphaMap&&(t.alphaMap=e.alphaMap),void 0!==e.emissiveMap&&(t.emissiveMap=e.emissiveMap),void 0!==e.envMap&&(t.envMap=e.envMap),void 0!==e.envMapIntensity&&(t.envMapIntensity=e.envMapIntensity),null!=e.map&&(t.map=e.map),t.opacity=cA.getHoverOpacity(t.opacity),t.transparent=!0,t.needsUpdate=!0}return t},getHoverColorByMaterial:function(e){var t=void 0!==e.opacity?e.opacity:this.hoverMaterialDefaultParams.opacity;if(t=cA.getHoverOpacity(t),!e.hasOwnProperty("color"))return{rgbaColor:[this.hoverMaterial.color.r,this.hoverMaterial.color.g,this.hoverMaterial.color.b,t],transparent:true};var i=e.color.clone();return{rgbaColor:[i.r,i.g,i.b,t],transparent:true}},setSelectionColor:function(e,t){var i=this.selectionMaterial.opacity;t=void 0===t?i:t,"0x"+this.selectionMaterial.color.getHexString()===e&&i===t||(this.selectionMaterial.color.setHex(e),t&&(this.selectionMaterial.opacity=t),this.selectionMaterial.needsUpdate=!0)},getSelectionColor:function(){var e=this.selectionMaterial.opacity;return new Du(this.selectionMaterial.color.getHex(),e)},getSelectionMaterial:function(){return this.selectionMaterial.clone()},setBlinkComponentsById:function(e,t){if(this.blinkComponentIds={},e&&0!==e.length){for(var i=e.length-1;i>=0;i-=1){this.filter.isComponentActive(e[i],t)&&(this.blinkComponentIds[e[i]]=!0)}this.modelManager.applyBlink()}},addBlinkComponentsById:function(e,t){if(e&&e.length){for(var i=this.blinkComponentIds,n=!1,r=e.length-1;r>=0;r-=1){var o=e[r];!i[o]&&this.filter.isComponentActive(o)&&(i[o]=!0,n=!0)}n&&this.modelManager.applyBlink()}},clearBlinkComponentsById:function(e,t){if(e&&e.length){for(var i=!1,n=this.blinkComponentIds,r=0,o=e.length;o>r;r+=1){var a=e[r];n[a]&&(delete n[a],i=!0)}i&&this.modelManager.applyBlink()}},clearAllBlinkComponents:function(){var e=!1;wp.isOwnEmptyObject(this.blinkComponentIds)||(e=!0,this.blinkComponentIds={}),e&&this.modelManager.clearBlink()},getBlinkComponents:function(){return Object.keys(this.blinkComponentIds)},getBlinkComponentsIdMap:function(e){var t=this;if(this.modelManager.getBlinkEnabled()){if(e){var i=this.getBlinkComponents(),n={};return i.forEach((function(i){var r=t.modelManager.filterHelper.distributeId(i),o=r.modelKey,a=r.objectId;o&&o.toString()!==e.toString()||(n[a]=t.blinkComponentIds[i])})),n}return this.blinkComponentIds}return null},getBlinkMaterial:function(e){return cA.getBlinkMaterial(e,this.modelManager.getBlinkColor())},getBoxMaterial:function(){return this.boxMaterial.clone()},setBoxColor:function(e,t){var i=this.boxMaterial.opacity;t=void 0===t?i:t,"0x"+this.boxMaterial.color.getHexString()===e&&i===t||(this.boxMaterial.color.setHex(e),t&&(this.boxMaterial.opacity=t),this.boxMaterial.needsUpdate=!0,this.boxMaterial.color.setHex(e),this.boxMaterial.needsUpdate=!0)}};var YE=function(){this.hiddenUserIdMap={}};YE.prototype.destroy=function(){this.hiddenUserIdMap=null},YE.prototype.hideByUserId=function(e,t){this.hiddenUserIdMap||(this.hiddenUserIdMap={}),this.hiddenUserIdMap[e]=!!t},YE.prototype.cancelHiddenByUserId=function(e){this.hiddenUserIdMap&&delete this.hiddenUserIdMap[e]},YE.prototype.cancelAllHidden=function(){this.hiddenUserIdMap=null},YE.prototype.isHidden=function(e){return!!this.hiddenUserIdMap[e]},YE.prototype.hasHidden=function(){return!wp.isEmptyObject(this.hiddenUserIdMap)};var HE=function(){this.materialDefaultParams={color:14540253,opacity:.5,transparent:!0,side:0},this.material=cA.createPhongMaterial(this.materialDefaultParams)};HE.prototype.destroy=function(){this.material=null},HE.prototype.resetColor=function(){this.material.color.setHex(this.materialDefaultParams.color)},HE.prototype.resetOpacity=function(){this.material.opacity=this.materialDefaultParams.opacity},HE.prototype.reset=function(){this.material.color.setHex(this.materialDefaultParams.color),this.material.opacity=this.materialDefaultParams.opacity,this.material.transparent=this.materialDefaultParams.transparent,this.material.side=this.materialDefaultParams.side,this.material.needsUpdate=!0};var jE=function(e){this.manager=e,this.requestCount=0,this.maxRequestCount=1e5,this.loading=!1,this.delayIntervalTime=300};jE.prototype.destroy=function(){this.manager=null,this.currentConditions=null,this.delayLoadTimer&&(clearTimeout(this.delayLoadTimer),this.delayLoadTimer=null)},jE.prototype.isValidModel=function(e){return!(e.isEmptyScene()||!e.isLayerData())},jE.prototype.loadGeopkOnDemandByConditionsWithDelay=function(e,t,i,n){var r=this,o=this.delayIntervalTime;r.delayLoadTimer&&clearTimeout(r.delayLoadTimer),r.delayLoadTimer=setTimeout((function(){r.loadGeopkOnDemandByConditions(e,t,i,n)}),o)},jE.prototype.loadGeopkOnDemandByConditions=function(e,t,i,n){if(this.currentConditions=e,this.requestCount+=1,this.requestCount>this.maxRequestCount&&(this.requestCount=0),!this.loading){this.loading=!0;var r=this;requestAnimationFrame(function e(o){var a=o,s=r.currentConditions;return function(){r._loadGeopkOnDemandByConditions(s,t,i,(function(){a!==r.requestCount?requestAnimationFrame(e(r.requestCount)):(r.loading=!1,n&&n(s),s=null)}))}}(this.requestCount))}},jE.prototype._loadGeopkOnDemandByConditions=function(e,t,i,n){var r=this;this.manager.traverseModels((function(o){r.isValidModel(o)&&o._getHandler().loadGeopkOnDemand(e,t,i,n)}))},jE.prototype.getBoundingBoxOnDemand=function(){var e=new He,t=this;return this.manager.traverseModels((function(i){if(t.isValidModel(i)){var n=i._getHandler().getLayerProvider().getUnionBoundingBoxOnDemand();n&&e.union(n)}})),e.isEmpty()?null:e},jE.prototype.isLoading=function(){return this.loading},jE.prototype.getBoundingBoxForUsedComponent=function(){var e=this.manager,t=new He;return e.traverseModels((function(i){var n=i.getLoadedUserIdsObject();n&&t.union(e.getBoundingBoxByIds(n))})),t.isEmpty()?null:t};var WE=function(e,t){xd.UseWorker&&og.isSupportWorker(),og.isMobileDevice()&&(xd.maxObjectNumInPool=6e3,xd.maxDrawCacheNum=4e3),this.scene=new KE(t),this.filter=e,this.crossOrigin=!0,this.models={},this.viewerImpl=t,this.materialPool=null,this.occlusionCamera=null,this.containsCamera=!1,this.highPriorityCategories={inner:{},outer:{}},this.octantToObjectMap={},this.instanceGeometries={},this.sceneState=new VE(this),this.modelState=new VE(this),this.filter.setSceneStateHelper(this.sceneState),this.rotation=new Ge,this.boundingBox=new He,this.explosionList={},this.IBLMaterial=!1,this.clippingCaps=!1,this.blinkStartTime=null,this.blinkEnabled=!1,this.blinkIntervalTime=600,this.blinkPermited=!1,this.defaultBlinkColor=(new pi).setHex(3330982),this.defaultBlinkAlpha=1,this.blinkColor=new Le(this.defaultBlinkColor.r,this.defaultBlinkColor.g,this.defaultBlinkColor.b,this.defaultBlinkAlpha),this.selectPriority=!0,this.materialOverrideSet=null,this.plugins=[],this.cameraFov=0,this.cameraPosition=new Ke,this.domElementWidth=1,this.transformComponent={}};Object.assign(WE.prototype,hg.prototype),WE.prototype.destroy=function(){for(var e in this.removeAllEventListener(),this.models)this.models[e].destroy();this.models=null,this.octantToObjectMap=null,this.materialPool&&(this.materialPool.destroy(),this.materialPool=null),this.occlusionCamera&&(this.occlusionCamera=null);for(var t=0,i=this.plugins.length;i>t;t+=1)this.plugins[t].destroy();this.plugins=null,this.loadOnDemandDirector&&(this.loadOnDemandDirector.destroy(),this.loadOnDemandDirector=null),this.highPriorityCategories=null,this.rotation=null,this.boundingBox=null,this.scene.destroy(),this.scene=null,this.filter=null,this.sceneState.destroy(),this.sceneState=null,this.modelState.destroy(),this.modelState=null,this.blinkStartTime=null,this.defaultBlinkColor=null,this.blinkColor=null,this.floorExplosionList=null,this.explosionTranslation=null},WE.prototype.registerPlugin=function(e){this.plugins.push(e)},WE.prototype.removeAllEventListener=function(){this._listeners=void 0},WE.prototype.prepareCapScene=function(){this.capsScene?this.clippingCaps||(this.initCapPlane(),this.initCapBox()):(this.capsScene=new KE,this.clippingCaps||(this.initCapPlane(),this.initCapBox()),this.scene.createCapStencilMaterials())},WE.prototype.initCapPlane=function(){var e=this.scene.getFillClipPlane().initCapsPlane();this.capsScene.add(e.planeMesh),this.capsScene.add(e.lineMesh),this.clippingCaps=!0},WE.prototype.initCapBox=function(){var e=this.scene.getClipPlanes().initCapsBox();e.material.needsUpdate=!0,e.visible=!0,this.capsScene.add(e),this.clippingCaps=!0},WE.prototype.getAllComponents=function(){return this.scene.pool._pool},WE.prototype.getAllComponentsKey=function(){var e=[];for(var t in this.models)if(this.models.hasOwnProperty(t)){var i=this.models[t];if(i){var n=i.getComponentlist();e=e.concat(n)}}return e},WE.prototype.getComponentsKeyByModelKey=function(e){var t=[];if(this.models.hasOwnProperty(e)){var i=this.models[e];if(i)t=i.getComponentlist()}return t},WE.prototype.getComponent=function(e){for(var t in this.models)if(this.models.hasOwnProperty(t)){var i=this.models[t];if(i.isLoaded()&&i.getComponentInfo(e)){var n=i.getComponentInfo(e);if(n)return n}}for(var r=0,o=this.plugins.length;o>r;r+=1)if(this.plugins[r].getNodeInfosByUserId){var a=this.plugins[r].getNodeInfosByUserId(e);if(a)return a}},WE.prototype.getStorage=function(){return this.storage},WE.prototype.updateTransformComponentList=function(e){this.transformComponent[e]=!0},WE.prototype._updateOcclusionCamera=function(e){var t=e.near,i=e.distanceFromWorldToDrawing(this.getMatrixWorldGlobal(),xd.OcclusionDistanceToCamera);this.occlusionCamera?this.occlusionCamera.copy(e):this.occlusionCamera=e.clone(),this.occlusionCamera.setNearFar(t,i),this.occlusionCamera.updateMVP()},WE.prototype._clearMaterialPool=function(){this.materialPool&&this.materialPool.clear()},WE.prototype.acquireMaterial=function(){return this.materialPool?this.materialPool.acquire():null},WE.prototype.getObjectPool=function(){return this.scene.getObjectPool()},WE.prototype.getFrustumFromOcclusionCamera=function(){return this.occlusionCamera.getFrustum(!1)},WE.prototype.getOcclusionCamera=function(){return this.occlusionCamera},WE.prototype.prepareScene=function(e,t){var i=this.models;for(var n in xd.MergeComponent||(this.clearPool(),this.clearObjectRangeFromOctantMap()),xd.OcclusionTranslucentEnabled&&(null===this.materialPool&&(this.materialPool=new pM,this.materialPool.init(HE,50)),this._clearMaterialPool(),this._updateOcclusionCamera(e)),i)if(i.hasOwnProperty(n)){var r=i[n];!xd.RendererWhenLoad&&!r.isLoaded()||r.isEmptyScene()||r.prepare(e,t)}this.dealStateChanged()},WE.prototype.clearPool=function(){this.scene.getObjectPool().clear()},WE.prototype.clearObjectRangeFromOctantMap=function(){this.octantToObjectMap&&this.octantToObjectMap.pool&&(this.octantToObjectMap.pool={})},WE.prototype.setDrawableModel=function(e){this.isDrawableModel=e},WE.prototype.isDrawable=function(){return this.isDrawableModel},WE.prototype.load=function(e,t,i){var n=this.models,r=n[e.modelKey],o=this;if(this.setDrawableModel(!1),void 0!==r)return this.setDrawableModel(!0),r.isVisible()||(r.setVisible(!0),r.dispatchEventEx({type:Fd.ON_LOAD_COMPLETE})),r;var a=[];for(var s in n)n.hasOwnProperty(s)&&a.push(n[s].index);a.sort();for(var l=0;a.length>l&&a[l]===l;l+=1);return r=new("GIS"===e.type?uM:rM)(this,e,(function(t,i){if(xd.UseWorker){if(o.websocketWorker&&o.prepareDataWorkers){var n=JSON.parse(window.localStorage.getItem("bos_IndexedDB"));n||(n={version:1}),window.localStorage.setItem("bos_IndexedDB",JSON.stringify(n));var a=n.version;o.websocketWorker.postMessage({type:"INITIALIZE_DATABASE",data:{modelKey:r.modelKey,dbName:r.projectKey,version:a}}),o.websocketWorker.onmessage=r.onWSWorkerMessage,o.prepareDataWorkers.postMessage({type:"INITIALIZE_DATABASE",data:{modelKey:r.modelKey,dbName:r.projectKey,version:a}}),o.prepareDataWorkers.onmessage=r.onPDWorkerMessage}}else t.load(e.notifyProgress)}),i),this.filter.addModel(r.modelKey),this.models[e.modelKey]=r,r},WE.prototype.loadTiles=function(e,t,i){var n=this.models,r=n[e.modelKey],o=this;if(void 0!==r)return r.isVisible()||(r.setVisible(!0),r.dispatchEventEx({type:Fd.ON_LOAD_COMPLETE})),r;var a=[];for(var s in n)n.hasOwnProperty(s)&&a.push(n[s].index);a.sort();for(var l=0;a.length>l&&a[l]===l;l+=1);return r=new uM(this,e,(function(t,i){if(xd.UseWorker){if(o.websocketWorker&&o.prepareDataWorkers){var n=JSON.parse(window.localStorage.getItem("bos_IndexedDB"));n||(n={version:1}),window.localStorage.setItem("bos_IndexedDB",JSON.stringify(n));var a=n.version;o.websocketWorker.postMessage({type:"INITIALIZE_DATABASE",data:{modelKey:r.modelKey,dbName:r.projectKey,version:a}}),o.websocketWorker.onmessage=r.onWSWorkerMessage,o.prepareDataWorkers.postMessage({type:"INITIALIZE_DATABASE",data:{modelKey:r.modelKey,dbName:r.projectKey,version:a}}),o.prepareDataWorkers.onmessage=r.onPDWorkerMessage}}else t.load(e.notifyProgress)}),i),this.models[e.modelKey]=r,r},WE.prototype.loadModels=function(e){var t=this.models[e.modelKey],i=this;return void 0!==t?(t.isVisible()||(t.setVisible(!0),t.dispatchEventEx({type:Fd.ON_LOAD_COMPLETE})),t):(t=new rM(this,e,(function(){if(xd.UseWorker){if(i.websocketWorker&&i.prepareDataWorkers){var n=JSON.parse(window.localStorage.getItem("bos_IndexedDB"));n||(n={version:1}),window.localStorage.setItem("bos_IndexedDB",JSON.stringify(n));var r=n.version;i.websocketWorker.postMessage({type:"INITIALIZE_DATABASE",data:{modelKey:t.modelKey,dbName:t.projectKey,version:r}}),i.websocketWorker.onmessage=t.onWSWorkerMessage,i.prepareDataWorkers.postMessage({type:"INITIALIZE_DATABASE",data:{modelKey:t.modelKey,dbName:t.projectKey,version:r}}),i.prepareDataWorkers.onmessage=t.onPDWorkerMessage}}else t.load(e.notifyProgress)})),this.models[e.modelKey]=t,t)},WE.prototype.unload=function(e){var t=this.models[e];return!!t&&(t.destroy(),delete this.models[e],this.filter.removeModel(e),this.filter.reinitFilterManager(this.getNodeInfos()),this.updateScene(),this.updateFilterManager(),this.filter.getObjectInfoManager().calculateVisibleComponentsBbox(),!0)},WE.prototype.unloadAll=function(){for(var e=this.getModelKeys(),t=0,i=e.length;i>t;t+=1)this.unload(e[t]);this.clearPool(),this.models={}},WE.prototype.showModel=function(e){var t=this.models[e];return!!t&&(t.setVisible(!0),!0)},WE.prototype.hideModel=function(e){var t=this.models[e];return!!t&&(t.setVisible(!1),!0)},WE.prototype.getModelKeys=function(){var e=this.models,t=[];for(var i in e)e.hasOwnProperty(i)&&t.push(i);return t},WE.prototype.updateScene=function(){this.updateSceneBoundingBox()},WE.prototype.updateSceneBoundingBox=function(){var e=this.models,t=this.boundingBox;for(var i in t.makeEmpty(),e)if(e.hasOwnProperty(i)){var n=e[i];if(!n.isEmptyScene()){var r=n.getBoundingBoxWorld();if(!r||r.isEmpty())continue;t.isEmpty()?t.copy(r):(t.expandByPoint(r.min),t.expandByPoint(r.max))}}for(var o=0,a=this.plugins.length;a>o;o+=1){var s=this.plugins[o];if("function"==typeof s.getBoundingBoxWorld){var l=s.getBoundingBoxWorld();l&&t.union(l)}}this.scene.setBoundingBoxWorld(t)},WE.prototype.parseSceneRootNode=function(e){this.scene.parseRootNode(e),this.updateSceneBoundingBox()},WE.prototype.updateSceneRootMatrix=function(){var e=!1,t=new yt,i=new yt,n=new Ge,r=this.models;for(var o in this.models)if(r.hasOwnProperty(o)){var a=r[o];if(!a.isEmptyScene()){n.copy(a.getTransforms().rotation),t.copy(a.getTransforms().transformMatrix),e=a.getTransforms().transformed;break}}if(this.scene.setTransformMatrixGlobal(t),e)i.copy(t);else{var s=new Ke(1,1,1),l=xd.SceneSize,c=this.boundingBox.getSize(new Ke),h=Math.max(c.x,c.y,c.z);s.multiplyScalar(l/h),i.makeRotationFromQuaternion(n),i.scale(s)}this.scene.updateWorldMatrixByMatrix(i)},WE.prototype.updateSceneRenderable=function(){var e=this.models,t=xd.maxObjectNumInPool,i=[],n=0;for(var r in e){if(e.hasOwnProperty(r))(s=e[r]).isEmptyScene()||(n+=s.model.getStatistics().renderableTotalForPool,i.push(r))}for(var o=0,a=i.length;a>o;o+=1){var s=e[r=i[o]],l=Math.floor(s.getStatistics().renderableTotalForPool/n*t);l>s.getStatistics().renderableTotalForPool&&(l=s.getStatistics().renderableTotalForPool),s.setRenderableCount(l)}},WE.prototype.updateOctreeNode=function(){var e=this.models;for(var t in this.models)if(e.hasOwnProperty(t)){var i=e[t];i.isLoaded()&&!i.isEmptyScene()&&i.updateOctreeNode(!0)}},WE.prototype.updateMaterials=function(){var e=this.models;for(var t in this.models)if(e.hasOwnProperty(t)){var i=e[t];i.isLoaded()&&!i.isEmptyScene()&&i.materialManager.updateMaterials(i)}},WE.prototype.updateMaterialsValue=function(e,t){var i=this.models;for(var n in this.models)if(i.hasOwnProperty(n)){var r=i[n];r.isLoaded()&&!r.isEmptyScene()&&r.materialManager.updateMaterialsValue(r,e,t)}this.materialOverrideSet&&this.materialOverrideSet.updateMaterialsValue(e,t)},WE.prototype.enableColorWithoutLight=function(e){var t=this.models;for(var i in this.models)if(t.hasOwnProperty(i)){var n=t[i];n.isLoaded()&&n.isEmptyScene()}},WE.prototype.switchNewStyleMaterial=function(e){var t=this.models;for(var i in this.models)if(t.hasOwnProperty(i)){var n=t[i];n.isLoaded()&&!n.isEmptyScene()&&n.materialManager.switchNewStyleMaterial(n,e)}},WE.prototype.changeAllMaterials=function(e){if(this.IBLMaterial!==e){var t=this.models;for(var i in this.models)if(t.hasOwnProperty(i)){var n=t[i];n.isEmptyScene()||n.materialManager.changeAllMaterials(n,e)}this.IBLMaterial=e}},WE.prototype.setCrossOrigin=function(e){this.crossOrigin=e},WE.prototype.getMatrixWorldGlobal=function(){return this.scene.getMatrixWorldGlobal()},WE.prototype.hasModel=function(){var e=this.models;for(var t in e){if(e.hasOwnProperty(t))if(e[t].isLoaded())return!0}return!1},WE.prototype.isEmpty=function(){if(this.hasModel())return!1;for(var e=!1,t=0,i=this.plugins.length;i>t;t+=1){var n=this.plugins[t];if("function"==typeof n.isEmpty&&!n.isEmpty()){e=!0;break}}return!e},WE.prototype.hasModelDataReady=function(){var e=this.models,t=!1;for(var i in e){if(e.hasOwnProperty(i))if(t=!0,!e[i].isDataReady())return!1}return t},WE.prototype.isLayerData=function(){var e=this.models;for(var t in e){if(e.hasOwnProperty(t))if(e[t].isLayerData())return!0}return!1},WE.prototype.getModel=function(e){var t=this.models[e];return t||null},WE.prototype.getFirstModel=function(){var e=Object.keys(this.models)[0];return this.models[e]},WE.prototype.showOctreeBox=function(e){xd.ShowOctant||this.scene.removeGroupByName(Vp.OCTREENODE)},WE.prototype.setCategoriesToHighPriority=function(e,t){var i=e.length;if(i>=1)for(var n=this.highPriorityCategories[t]={},r=0;i>r;r+=1)n[e[r]]=!0},WE.prototype.getCategoriesFromHighPriority=function(e){return this.highPriorityCategories[e]},WE.prototype.clearCategoriesFromHighPriority=function(e){this.highPriorityCategories[e]={}},WE.prototype.clearAllCategoriesFromHighPriority=function(){this.clearCategoriesFromHighPriority("inner"),this.clearCategoriesFromHighPriority("outer")},WE.prototype.calculateCameraModelRelation=function(e){var t=!1,i=this.models;for(var n in i)if(i.hasOwnProperty(n)){var r=i[n];r&&r.isLoaded()&&!r.isEmptyScene()&&(r.calculateCameraModelRelation(e),t=t||r.containsCamera)}this.containsCamera=t},WE.prototype.getCameraNameList=function(){var e=this.models,t=[];for(var i in e)if(e.hasOwnProperty(i)){var n=e[i];n.isEmptyScene()||(t=t.concat(n.getCameraNameList()))}return t},WE.prototype.getCamera=function(e){var t=this.models,i=null;for(var n in t)if(t.hasOwnProperty(n)){var r=t[n];if(!r.isEmptyScene()&&(i=r.getCamera(e)))break}return i},WE.prototype.getNumOfElements=function(){var e=this.models,t=0;for(var i in this.models)if(e.hasOwnProperty(i)){var n=e[i];n.isEmptyScene()||(t+=n.getStatistics().numOfElements)}return t},WE.prototype.getNumOfRenderables=function(){var e=this.models,t=0;for(var i in this.models)if(e.hasOwnProperty(i)){var n=e[i];n.isEmptyScene()||(t+=n.getStatistics().renderableTotal)}return t},WE.prototype.getNumOfTriangles=function(){var e=this.models,t=0;for(var i in this.models)if(e.hasOwnProperty(i)){var n=e[i];n.isEmptyScene()||(t+=n.getStatistics().numOfTriangles)}return t},WE.prototype.getScene=function(){return this.scene},WE.prototype.getOctreeRoots=function(){var e=this.models,t={};for(var i in e)if(e.hasOwnProperty(i)){var n=e[i];if(n.isLoaded()&&!n.isEmptyScene()){var r=n.getEncodedDatabagId();t[r]=[],n.getModelDescriptor().getOctreeRoots(t[r])}}return t},WE.prototype.getModelSnapshotPhoto=function(){return this.viewerImpl.render(),{imgURL:this.viewerImpl.getRenderer().domElement.toDataURL("image/png"),height:this.viewerImpl.domElement.offsetHeight,width:this.viewerImpl.domElement.offsetWidth}},WE.prototype.addMeshToOctantMap=function(e,t,i){var n=this.octantToObjectMap;n[e]||(n[e]={}),n[e].mesh||(n[e].mesh={}),n[e].mesh[t]||(n[e].mesh[t]=[]),n[e].mesh[t].push(i)},WE.prototype.addNodeInfoToOctantMap=function(e,t,i){var n=this.octantToObjectMap;n[e]||(n[e]={}),n[e].info||(n[e].info={}),n[e].info[t]||(n[e].info[t]=[]),n[e].info[t].push(i)},WE.prototype.removeNodeInfoFromOctantMap=function(e,t){var i=this.octantToObjectMap;if(i[e]&&i[e].info&&i[e].info[t.componentKey])for(var n=i[e].info[t.componentKey],r=n.length-1;r>=0;r-=1)if(t.nodeId===n[r].nodeId){n.splice(r);break}},WE.prototype.clearNodeInfosFromOctantMap=function(e){var t=this.octantToObjectMap;t[e]&&t[e].info&&(t[e]=null)},WE.prototype.removeAllFromOctantMap=function(e){var t=this.octantToObjectMap;t[e]&&delete t[e]},WE.prototype.clearMeshFromOctantMap=function(e){var t=this.octantToObjectMap;t[e]&&t[e].mesh&&delete t[e].mesh},WE.prototype.removeMeshFromOctantMap=function(e,t){var i=this.octantToObjectMap;if(i[e]&&i[e].mesh){var n=0,r=i[e].mesh[t];for(n=r.length-1;n>=0;n-=1)delete r[n];delete i[e].mesh[t]}},WE.prototype.removeBatchedMeshFromOctantMap=function(e,t){var i=this.octantToObjectMap;if(i[e]&&i[e].mesh&&i[e].info){var n=0,r=i[e].info[t];if(r){for(n=r.length-1;n>=0;n-=1)r.splice(n);delete i[e].info[t]}}},WE.prototype.getOctantMap=function(){return this.octantToObjectMap},WE.prototype.isFilterApplied=function(){return this.filterApplied},WE.prototype.setFilterApplied=function(e){this.filterApplied=e},WE.prototype.applyFilter=function(){for(var e in Bu.time("applyFilter"),this.models){this.models[e].applyFilter()}for(var t=0,i=this.plugins.length;i>t;t+=1)this.plugins[t].applyFilter();this.setFilterApplied(!0),Bu.timeEnd("applyFilter")},WE.prototype.applySelection=function(){for(var e in this.selectPriority=!0,this.models){this.models[e].applySelection()}this.scene.getExtrudeBodyManager().applySelection(this);for(var t=0,i=this.plugins.length;i>t;t+=1)this.plugins[t].applySelection()},WE.prototype.clearSelection=function(){for(var e in this.selectPriority=!0,this.models){this.models[e].clearSelection()}this.scene.getExtrudeBodyManager().clearSelection();for(var t=0,i=this.plugins.length;i>t;t+=1)this.plugins[t].clearSelection()},WE.prototype.applyHover=function(){if(xd.Hover&&!xd.EnableRenderPass)for(var e in this.models){this.models[e].applyHover()}this.scene.getExtrudeBodyManager().applyHover(this);for(var t=0,i=this.plugins.length;i>t;t+=1)this.plugins[t].applyHover()},WE.prototype.clearHover=function(){if(xd.Hover&&!xd.EnableRenderPass)for(var e in this.models){this.models[e].clearHover()}this.scene.getExtrudeBodyManager().clearHover();for(var t=0,i=this.plugins.length;i>t;t+=1)this.plugins[t].clearHover()},WE.prototype.chooseRendering=function(e){},WE.prototype.isUserIdExist=function(e){var t=!1;for(var i in this.models){if(this.models.hasOwnProperty(i))if(this.models[i].getModelDescriptor().isUserIdExist(e)){t=!0;break}}for(var n=0,r=this.plugins.length;r>n;n+=1)if(this.plugins[n].isUserIdExist&&this.plugins[n].isUserIdExist(e)){t=!0;break}return t},WE.prototype.getNodeInfosByUserId=function(e){var t=[];for(var i in this.models){var n=this.models[i];if(n&&n.isLoaded()){var r=this.models[i].getModelDescriptor().getNodeInfosByUserId(e);r&&(t=t.concat(r))}}for(var o=0,a=this.plugins.length;a>o;o+=1)if(this.plugins[o].getNodeInfosByUserId){var s=this.plugins[o].getNodeInfosByUserId(e);s&&(t=t.concat(s))}return t.length?t:null},WE.prototype.getNodeInfos=function(){var e={};for(var t in this.models)if(this.models[t].isLoaded()){var i=this.models[t].getModelDescriptor().getAllNodeInfos();i&&(e[t]=i)}var n=this.getNodeInfosInPlugins();return Object.assign(e,n),e},WE.prototype.getNodeInfosInPlugins=function(){for(var e={},t=0,i=this.plugins.length;i>t;t+=1)this.plugins[t].getAllNodeInfos&&this.plugins[t].getAllNodeInfos(e);return e},WE.prototype.getMaterialByNodeId=function(e,t,i){var n=this.models[e];if(!n)return null;for(var r=n.getModelDescriptor().getNodeInfosByUserId(t),o=-1,a=0,s=r.length;s>a;a+=1)if(r[a].nodeId===i){o=a;break}return-1!==o?n.getMaterialByMaterialId(r[o].materialId):null},WE.prototype.getNodeInfoByNodeId=function(e,t,i){var n=this.models[e];if(!n)return null;for(var r=n.getModelDescriptor().getNodeInfosByUserId(t),o=-1,a=0,s=r.length;s>a;a+=1)if(r[a].nodeId===i){o=a;break}return-1!==o?r[o]:null},WE.prototype.getComponentInfoByUserId=function(e){var t=this.getNodeInfosByUserId(e);if(t&&t.length>0){for(var i=new He,n=[],r=0,o=t.length;o>r;r+=1)i.union(t[r].boundingBox),-1===n.indexOf(t[r].materialId)&&n.push(t[r].materialId);return{userId:e,state:0,materials:n,boundingBox:i,userData:t[0].userData}}return null},WE.prototype.getBoundingBoxByIds=function(e){var t=this.getScene(),i=new He;for(var n in e)if(!this.isHiddenUserId(n)){Array.isArray(e)&&(n=e[n]);var r=this.getComponentInfoByUserId(n);if(r)i.union(r.boundingBox);else{var o=t.getExtrudeBodyManager().getNode(n);if(o){var a=o.geometry.boundingBox.clone();o.matrix&&a.applyMatrix4(o.matrix),i.union(a)}}}return i},WE.prototype.createMaterialOverrideSet=function(e,t){this.materialOverrideSet=new MaterialOverriderSet(e,t),xd.EnableTextureMapping=!0},WE.prototype.getMaterialOverrideSet=function(){return this.materialOverrideSet},WE.prototype.getOverrideMaterialByNodeInfo=function(e){return this.materialOverrideSet?this.materialOverrideSet.getOverrideMaterialByNodeInfo(e):null},WE.prototype.getOverrideMaterialByName=function(e){return this.materialOverrideSet?this.materialOverrideSet.getOverrideMaterialByName(e):null},WE.prototype.loadOverrideMaterialsByDemand=function(e,t){if(this.materialOverrideSet){var i=this.getConditions();this.materialOverrideSet.loadByDemand(i,e,t)}else t&&t()},WE.prototype.getConditions=function(){var e={},t={},i={};for(var n in this.models){var r=this.models[n].getModelDescriptor().getAllNodeInfos();if(r)for(var n in r)if(r.hasOwnProperty(n))for(var o=0,a=r[n].length;a>o;o+=1){var s=r[n][o].userData;t[r[n][o].userId]=!0,i[s.systemTypeId]=!0,e[s.familyId]=!0}}return{familyIds:e,elementIds:t,systemTypeIds:i}},WE.prototype.isHiddenUserId=function(e){var t=!1;for(var i in this.models){if(this.models.hasOwnProperty(i))if((i=this.models[i]).isHiddenUserId(e)){t=!0;break}}return t},WE.prototype.isHiddenSourceObjectUserId=function(e){return!!this.sourceObjectManager&&this.sourceObjectManager.isHidden(e)},WE.prototype.hasHiddenSourceObjectUserId=function(){return!!this.sourceObjectManager&&this.sourceObjectManager.hasHidden()},WE.prototype.updateMeshNodes=function(){for(var e in this.models){if(this.models.hasOwnProperty(e))(e=this.models[e]).updateMeshNodes()}},WE.prototype.getMinDistanceObjects=function(e,t){var i=this,n={};for(var r in this.models)if(this.models.hasOwnProperty(r)){(r=this.models[r]).minDistanceObjects={};var o=r.getMeshesByUserIds(e),a=r.getMeshesByUserIds(t);if(o&&o.length>0&&(n[e]=o),a&&a.length>0&&(n[t]=a),n[e]&&n[t])return n}var s=null,l=null,c=null,h=null,d=null,u=function(){var n={},r=function(e,t,i){var r={};r.mesh=e;var o=new yt;i?o.multiplyMatrices(i,e.matrix):o=e.matrix,r.matrix=o;var a=e.geometry.boundingBox;a||(e.geometry.computeBoundingBox(),a=r.mesh.geometry.boundingBox);var s=a.clone().applyMatrix4(o);r.boundingBox=s,n[t]&&(n[t]=[]),n[t].push(r)};if(!(s=i.scene.getGroup("ExternalComponentManager")))return{v:void 0};for(c=0,h=(l=s.children).length;h>c;c+=1)(d=l[c]).name!==e&&d.name!==t||(wp.isGroupObject(d)?d.traverseVisible((function(e){wp.isMeshObject(e)&&r(e,d.name,d.matrix)})):r(d,d.name));return{v:n}}();return u&&u.v&&(u.v[e]&&u.v[e].length>0&&(n[e]=u.v[e]),u.v[t]&&u.v[t].length>0&&(n[t]=u.v[t]),n[e]&&n[t])||n[e]&&n[t]?n:null},WE.prototype.getMeshByUserId=function(e){for(var t in this.models)if(this.models.hasOwnProperty(t)){var i=(t=this.models[t]).getMeshesByUserIds(e);if(i)return i}return null},WE.prototype.adjustVisibility=function(e){for(var t in this.models)this.models[t]&&this.models[t]._getHandler().adjustVisibility(e);for(var i=0,n=this.plugins.length;n>i;i+=1){var r=this.plugins[i];r.adjustVisibility&&"function"==typeof r.adjustVisibility&&r.adjustVisibility(e)}this.otherAdjustVisibility&&this.otherAdjustVisibility(e)},WE.prototype.changeVisibilityOfSelectedObjects=function(e){for(var t in this.models)this.models[t]&&this.models[t]._getHandler().changeVisibilityOfSelectedObjects(e);for(var i=0,n=this.plugins.length;n>i;i+=1){var r=this.plugins[i];r.changeVisibilityOfSelectedObjects&&"function"==typeof r.changeVisibilityOfSelectedObjects&&r.changeVisibilityOfSelectedObjects(e)}},WE.prototype.changeVisibilityOfNonSelectedObjects=function(e){for(var t in this.models)this.models[t]&&this.models[t]._getHandler().changeVisibilityOfNonSelectedObjects(e);this.otherAdjustVisibility&&this.otherAdjustVisibility(e);for(var i=0,n=this.plugins.length;n>i;i+=1){var r=this.plugins[i];r.changeVisibilityOfNonSelectedObjects&&"function"==typeof r.changeVisibilityOfNonSelectedObjects&&r.changeVisibilityOfNonSelectedObjects(e)}},WE.prototype.adjustInstanceVisibility=function(e){for(var t in this.models)this.models[t]&&this.models[t].merged&&this.models[t]._getHandler().adjustInstanceVisibility(e)},WE.prototype.adjustVisibilityOfObjectsWithoutOutline=function(e){for(var t in this.models)if(this.models[t]){var i=this.models[t].axisNetManager;i&&i.visibleByUser&&(e?this.models[t].axisNetManager.privateShow():this.models[t].axisNetManager.privateHide())}for(var n=0,r=this.plugins.length;r>n;n+=1){var o=this.plugins[n];o.adjustVisibilityOfObjectsWithoutOutline&&"function"==typeof o.adjustVisibilityOfObjectsWithoutOutline&&o.adjustVisibilityOfObjectsWithoutOutline(e)}var a;this.scene.hasClipPlanes()&&((a=this.scene.getClipPlanes()).isEnabled()&&(!1===e&&a.visible?(a.visible=!1,a._hideByModelManager=!0):!0===e&&a._hideByModelManager&&(a.visible=!0,delete a._hideByModelManager)));this.scene.hasFillClipPlanes()&&((a=this.scene.getFillClipPlane()).isEnabled()&&(!1===e&&a.visible?(a.visible=!1,a._hideByModelManager=!0):!0===e&&a._hideByModelManager&&(a.visible=!0,delete a._hideByModelManager)));this.scene.receivingPlane&&(!1===e&&this.scene.receivingPlane.visible?(this.scene.receivingPlane.visible=!1,this.scene.receivingPlane._hideByModelManager=!0):!0===e&&this.scene.receivingPlane._hideByModelManager&&(this.scene.receivingPlane.visible=!0,delete this.scene.receivingPlane._hideByModelManager)),this.otherAdjustVisibility&&this.otherAdjustVisibility(e);for(var s=this.scene.children,l=(n=0,s.length);l>n;n+=1){var c=s[n];c!==this.scene.objectGroups&&!0!==c.isLight&&!0===c.isObject3D&&(c.visible=e)}},WE.prototype.changeInstanceVisibilityOfSelectedObjects=function(e){for(var t in this.models)this.models[t]&&this.models[t].merged&&this.models[t]._getHandler().changeInstanceVisibilityOfSelectedObjects(e)},WE.prototype.changeInstanceVisibilityOfNonSelectedObjects=function(e){for(var t in this.models)this.models[t]&&this.models[t].merged&&this.models[t]._getHandler().changeInstanceVisibilityOfNonSelectedObjects(e)},WE.prototype.restoreVisibilityOfObjects=function(){for(var e in this.models)this.models[e]&&this.models[e]._getHandler().restoreVisibilityOfObjects();this.otherAdjustVisibility&&this.otherAdjustVisibility(!0)},WE.prototype.getComponentKeysByTypeFromList=function(e,t){var i=[];for(var n in this.models){if(this.models.hasOwnProperty(n))if((n=this.models[n]).isLoaded()){var r=n.getComponentKeysByTypeFromList(e,t);r&&(i=i.concat(r))}}return i},WE.prototype.getComponentKeysByType=function(e){var t=[];for(var i in this.models){if(this.models.hasOwnProperty(i))if((i=this.models[i]).isLoaded()){var n=i.getComponentKeysByType(e);n&&(t=t.concat(n))}}return t},WE.prototype.getComponentKeysByName=function(e){var t=[];for(var i in this.models)if(this.models.hasOwnProperty(i)){var n=(i=this.models[i]).getComponentKeysByName(e);n&&(t=t.concat(n))}return t},WE.prototype.getComponentKeysByProperty=function(e,t){var i=[];for(var n in this.models)if(this.models.hasOwnProperty(n)){var r=(n=this.models[n]).getComponentKeysByProperty(e,t);r&&(i=i.concat(r))}return i},WE.prototype.getBlinkMaterials=function(){var e=[];for(var t in this.models)this.models[t]&&this.models[t]._getHandler().getBlinkMaterials&&(e=e.concat(this.models[t]._getHandler().getBlinkMaterials()));return e},WE.prototype.resetBlinkMaterial=function(){for(var e=this.getBlinkMaterials(),t=0,i=e.length;i>t;t+=1)e[t].resetBlinkUniformValue()},WE.prototype.updateBlinkMaterial=function(){if(null!==this.blinkStartTime){if(Date.now()-this.blinkStartTime>=this.blinkIntervalTime){this.blinkStartTime=Date.now(),this.indexSwitch=!this.indexSwitch;for(var e=this.indexSwitch?Jd.BLINK:Jd.NONE,t=this.getBlinkMaterials(),i=0,n=t.length;n>i;i+=1)t[i].updateBlinkUniformValue(e,this.blinkColor)}}else this.blinkStartTime=Date.now()},WE.prototype.getBlinkColor=function(){return this.blinkColor},WE.prototype.setBlinkColor=function(e,t){if(e){var i=wp.hexToRgb(e);this.blinkColor.fromArray([i.r,i.g,i.b,t||1])}else this.blinkColor.set(this.defaultBlinkColor.r,this.defaultBlinkColor.g,this.defaultBlinkColor.b,this.defaultBlinkAlpha)},WE.prototype.setBlinkIntervalTime=function(e){this.blinkIntervalTime>0&&(this.blinkIntervalTime=e)},WE.prototype.enableBlink=function(e){this.blinkEnabled=e,e?null===this.blinkStartTime&&(this.blinkStartTime=Date.now()):(this.blinkStartTime=null,this.resetBlinkMaterial()),this.applyBlink()},WE.prototype.getBlinkEnabled=function(){return!this.isBlinkPermited()&&this.blinkEnabled},WE.prototype.getBlinkComponentsIdMap=function(){return this.isBlinkPermited()?null:this.sceneState.getBlinkComponentsIdMap()},WE.prototype.applyBlink=function(){if(!this.isBlinkPermited())for(var e in this.selectPriority=!1,this.models){this.models[e].applyBlink()}},WE.prototype.clearBlink=function(){if(!this.isBlinkPermited())for(var e in this.selectPriority=!1,this.models){this.models[e].clearBlink()}},WE.prototype.permitBlink=function(e){this.blinkPermited=e},WE.prototype.isBlinkPermited=function(){return this.blinkPermited},WE.prototype.isSelectPriority=function(){return this.selectPriority},WE.prototype.getSceneState=function(){return this.sceneState},WE.prototype.getModelSceneState=function(){return this.modelState},WE.prototype.disposeBufferAfterVbo=function(){if(xd.EnableDisposeBufferAfterVbo)for(var e in this.models){this.models[e].disposeBufferAfterVbo()}},WE.prototype.getSourceObjectManager=function(){return this.sourceObjectManager||(this.sourceObjectManager=new YE),this.sourceObjectManager},WE.prototype.isHiddenUserId=function(e){return!!this.sourceObjectManager&&this.sourceObjectManager.isHidden(e)},WE.prototype.hasHiddenUserId=function(){return!!this.sourceObjectManager&&this.sourceObjectManager.hasHidden()},WE.prototype.traverseModels=function(e,t){for(var i in this.models){var n=this.models[i];if(t&&t(n))break;e&&e(n)}},WE.prototype.traverseLoadedModels=function(e){for(var t in this.models){var i=this.models[t];i&&i.isLoaded()&&e(i)}},WE.prototype.getStatisticsInfo=function(){var e=0,t=0,i=0,n=0;for(var r in this.models){var o=this.models[r];if(o&&o.isLoaded()){var a=o.getTrianglesCount();e+=a.positionsCount,t+=a.trianglesCount,i+=a.realPositionCount,n+=a.realTrianglesCount}}return{positionsCount:e,trianglesCount:t,realPositionCount:i,realTrianglesCount:n,componentCount:this.getAllComponentsKey().length}},WE.prototype.dealStateChanged=function(){this.hasModelDataReady()&&(this.isRenderStateChanged()||this.filter.isStateChanged())&&(this.isRenderStateChanged()&&this.setRenderStateChanged(!1),this.filter.isStateChanged()&&this.filter.disableStateChanged(),this.applyFilter())},WE.prototype.setRenderStateChanged=function(e){this._renderStateChanged=e},WE.prototype.isRenderStateChanged=function(){return this._renderStateChanged},WE.prototype.hasLoadOnDemandDirector=function(){return!!this.loadOnDemandDirector},WE.prototype.getLoadOnDemandDirector=function(){return this.loadOnDemandDirector||(this.loadOnDemandDirector=new jE(this)),this.loadOnDemandDirector},WE.prototype.checkLayerDataLoading=function(){return!!(this.isLayerData()&&this.hasLoadOnDemandDirector()&&this.getLoadOnDemandDirector().isLoading())&&(this.filter.isStateChanged()&&this.filter.disableStateChanged(),!0)},WE.prototype.updateFilterManager=function(){var e=this.getNodeInfos(),t=this.filter;t.clearFilterManager(),t.initFilterManager(e),t.isStateChanged()&&t.disableStateChanged(),this.updateMeshNodes(),this.applyFilter()},WE.prototype.isDrawingBoardlineEnabled=function(){return!(!xd.DrawingBoardlineEnabled||xd.DrawingStyle!==jd.BOARDLINE&&xd.DrawingStyle!==jd.SHADINGWITHLINE)},WE.prototype.isOnlyWireframe=function(){return xd.DrawingStyle===jd.BOARDLINE},WE.prototype.getExplosionExtent=function(){return this.explosionExtent},WE.prototype.setExplosionExtent=function(e){var t=e-this.explosionExtent;for(var i in this.models)this.models[i]&&this.models[i].explode(t);this.explosionExtent=e},WE.prototype.updateAnimation=function(){var e=this.viewerImpl.clock.getDelta();for(var t in this.models)if(this.models.hasOwnProperty(t)){var i=this.models[t];if(i.hasAnimation&&i.mixer){var n=i.mixer;i.singleStepMode?(n.update(i.sizeOfNextStep),i.sizeOfNextStep=0):n.update(e)}}},WE.prototype.needUpdateAnimation=function(){for(var e in this.models)if(this.models.hasOwnProperty(e)){var t=this.models[e];if(t.hasAnimation&&t.mixer&&t.needUpdate)return!0}return!1},WE.prototype.hasAnimation=function(){for(var e in this.models)if(this.models.hasOwnProperty(e)){var t=this.models[e];if(t.hasAnimation&&t.mixer)return!0}return!1},WE.prototype.unloadGeopkOnDemand=function(e,t){var i=this.models;for(var n in i)if(i.hasOwnProperty(n)){var r=i[n];r.isLoaded()&&!r.isEmptyScene()&&r.isLayerData()&&r.unloadGeopkOnDemand(e,t)}},WE.prototype.loadGeopkOnDemand=function(e,t,i,n){this.getLoadOnDemandDirector().loadGeopkOnDemandByConditions(e,t,i,n)},WE.prototype.loadAllGeosOnDemand=function(e,t){var i=this.models;for(var n in i)if(i.hasOwnProperty(n)){var r=i[n];r.isLoaded()&&!r.isEmptyScene()&&r.isLayerData()&&r.loadAllGeosOnDemand(e,t)}},WE.prototype.getBoundingBoxOnDemand=function(){var e=this.models,t=new He;for(var i in e)if(e.hasOwnProperty(i)){var n=e[i];if(n.isLoaded()&&!n.isEmptyScene()&&n.isLayerData()){var r=n.getUnionBoundingBoxOnDemand();r&&t.union(r)}}return t},WE.prototype.setConditionsOnDemandLoad=function(e){this.conditionsOnDemandLoad=e;var t=this.models;for(var i in t)if(t.hasOwnProperty(i)){var n=t[i];n.isLoaded()&&!n.isEmptyScene()&&n.isLayerData()&&n.setConditionsChangedOnDemand(!0)}},WE.prototype.getConditionsOnDemandLoad=function(){return this.conditionsOnDemandLoad},WE.prototype.componentsExplosion=function(e){var t=this.models;for(var i in t){if(t.hasOwnProperty(i))t[i].componentsExplosion(e)}},WE.prototype.closeComponentsExplosion=function(e){var t=this.models;for(var i in t){if(t.hasOwnProperty(i))t[i].closeComponentsExplosion(e)}},WE.prototype.canFloorExplosion=function(){var e=this.models,t=!1;for(var i in e){if(e.hasOwnProperty(i))e[i].floorManager&&(t=!0)}return t},WE.prototype.floorExplosion=function(e){var t=this.models,i=!1;for(var n in t){if(t.hasOwnProperty(n))t[n].floorExplosion(e)&&(this.updateSceneBoundingBox(),i=!0)}return i},WE.prototype.closeFloorExplosion=function(){var e=this.models;for(var t in e){if(e.hasOwnProperty(t))e[t].closeFloorExplosion()}},WE.prototype.checkTilesDataChanged=function(e,t){if(!this.cameraPosition.equals(e.position)||this.cameraFov!==e.fov||this.domElementWidth!==t.domElement.width){this.cameraFov=e.fov||45,this.cameraPosition=e.position.clone()||new Ke,this.domElementWidth=t.domElement.width||1e3;var i=!1,n=this.checkMemory();for(var r in n>xd.MaximumAvailableMemory&&(i=!0),this.models)if(this.models.hasOwnProperty(r)){var o=this.models[r];o.isTilesModel&&o.checkTilesDataChanged(i)}}},WE.prototype.checkMemory=function(){var e=0,t=this.viewerImpl.getRenderer().info;return e+=6*(t.render.triangles||0),e+=1024*(t.memory.textures||0)*1024/4,e+=1024*(t.render.calls||0)/4,e+=1024*(t.memory.geometries||0)/4,e*=1/1048576,e=Math.ceil(e)},WE.prototype.getMeshIdFromOctantMap=function(e){return e.single?e.nodeId:e.instanceOrNot?wp.getCombinedKeyString(e.uv2Info?[e.materialId,e.geometryId,e.uv2Info.byteOffset]:[e.materialId,e.geometryId]):xd.MergeComponent?wp.getCombinedKeyString([e.materialId,e.uv?"1":"0",e.type===zy.EnumNodeItemType.LINE?"lines":"meshes"]):e.nodeId},WE.prototype.computeRenderTime=function(){for(var e=this,t=this.getModelKeys(),i=function(i){var n=e.getModel(t[i]),a=n._getNodeGroup("InstanceGeometry").children.length,s=n._getNodeGroup("Geometry").children.length,l=n._getNodeGroup("InstanceWireframeGeometry").children.length,c=n._getNodeGroup("Wireframe").children.length;r=0,o=0;n.group.traverse((function(e){if(e.isMesh){var t=e.geometry,i=t.getAttribute("position").count,n=t.index.count/3,h=t.getAttribute("vState"),d=6*i;if(t.getAttribute("uv")&&(d+=2*i),t.getAttribute("uv2")&&(d+=2*i),d+=3*n,h){var u=24e-5*d/15e3*h.count;.02>u&&(u=.02),r+=u}else{var p=.004+((s+a)/3e4*1e-4+1e-4)*d/(350*(1+(s+a)/25e3))*(t.group?t.group.length:1);.0085>p&&(p=.0085),o+=p}}else if(e.isLineSegments){var g=e.geometry;if(g&&"Geometry"!==g.type){var f=g.getAttribute("position").count,m=g.getAttribute("vState"),A=3*f;if(A+=g.index.count,m){var y=24e-5*A/15e3*m.count;.02>y&&(y=.02),r+=y}else{var v=.004+((c+a)/3e4*1e-4+1e-4)*A/(350*(1+(c+l)/25e3))*(g.group?g.group.length:1);.0085>v&&(v=.0085),o+=v}}}})),console.log("渲染耗时",r+o),console.log("实例化渲染时间",r),console.log("批量渲染时间",o)},n=0;t.length>n;n+=1){var r,o;i(n)}},WE.prototype.getSceneUnit=function(){return xd.SceneUnit};var JE=function(e){lu(i,e);var t=pu(i);function i(e){var n;return ru(this,i),(n=t.call(this,e)).type="InstancedMeshBasicMaterial",n.uniforms=Mn.basic.uniforms,n.vertexShader=function(e){return e.replace("#include <project_vertex>","\n vec4 mvPosition = modelViewMatrix * vec4(getInstancePosition(transformed), 1.0);\n gl_Position = projectionMatrix * mvPosition;\n ")}(function(e){return e.replace("void main() {","\n attribute float vState; \n attribute vec3 mcol0;\n attribute vec3 mcol1;\n attribute vec3 mcol2;\n attribute vec3 mcol3; \n varying float vfState;\n \n vec3 getInstancePosition(vec3 position) {\n return vec3(mat4(vec4(mcol0, 0.0),\n vec4(mcol1, 0.0),\n vec4(mcol2, 0.0),\n vec4(mcol3, 1.0)) * vec4(position, 1.0));\n }\n \n void main() {\n vfState = vState;\n ")}(Mn.basic.vertexShader)),n.fragmentShader=function(e){return e.replace("void main() {","\n varying float vfState; \n void main() {\n if (vfState <= -0.99 && vfState >= -1.01) discard;\n \n ")}(Mn.basic.fragmentShader),n}return i}(gi);function zE(e,t){return e.groupOrder!==t.groupOrder?e.groupOrder-t.groupOrder:e.renderOrder!==t.renderOrder?t.renderOrder-e.renderOrder:e.z!==t.z?t.z-e.z:e.id-t.id}var qE=function(e){this.viewer=e;var t=xd.SelectionColor.color;this.wireframeMaterial=new gi({color:t,opacity:1,transparent:!0,blending:5,blendSrc:a,blendDst:o,blendEquation:r}),this.selectedMaterial=new gi({color:t,opacity:.3,transparent:!0}),this.skinningWireframeMaterial=new gi({color:t,opacity:1,transparent:!0,blending:5,blendSrc:a,blendDst:o,blendEquation:r,skinning:!0}),this.skinningSelectedMaterial=new gi({color:t,opacity:.3,transparent:!0,skinning:!0}),this.selectedLineMaterial=new xM({color:t,opacity:1,transparent:!0,linewidth:2,dashed:!1}),this.instancedWireFrameMaterial=new JE({color:t,opacity:1,transparent:!0,blending:5,blendSrc:a,blendDst:o,blendEquation:r}),this.instancedSelectedMaterial=new JE({color:t,opacity:.3,transparent:!0}),this.selectionScene=new Vo,this.selectionScene.autoUpdate=!1,this.selectionObjectGroup=new cm,this.selectionObjectGroup.name="PickingObjectGroup",this.selectionObjectGroup.matrixAutoUpdate=!1,this.selectionScene.add(this.selectionObjectGroup),this.lastSelectedUserIdMap=null,this.lastSelectedUserIds=null};qE.prototype.destroy=function(){this.wireframeMaterial.dispose(),this.wireframeMaterial=null,this.selectedMaterial.dispose(),this.selectedMaterial=null,this.skinningWireframeMaterial.dispose(),this.skinningWireframeMaterial=null,this.skinningSelectedMaterial.dispose(),this.skinningSelectedMaterial=null,this.selectedLineMaterial.dispose(),this.selectedLineMaterial=null,this.instancedWireFrameMaterial.dispose(),this.instancedWireFrameMaterial=null,this.instancedSelectedMaterial.dispose(),this.instancedSelectedMaterial=null,this.selectionObjectGroup.clear(),this.selectionObjectGroup=null,this.selectionScene=null,this.lastSelectedUserIdMap=null,this.lastSelectedUserIds=null,this.viewer=null},qE.prototype.apply=function(e){var t=this.viewer,i=t.getSelection();if(!i||!i.length)return this._clearSelectedUserIdsCache(),void this._clearMeshesFromScene();(e||this._isSelectionsChanged())&&(this._cacheSelectedUserIds(i),this._updateScene(i));var n=t.rendererManager.getRenderer().getTransparentSort();t.rendererManager.getRenderer().setTransparentSort(zE),this._render(t.rendererManager.getRenderer(),t.camera),t.rendererManager.getRenderer().setTransparentSort(n)},qE.prototype._isSelectionsChanged=function(){var e=this.lastSelectedUserIds;if(!e)return!0;var t=this.viewer.getSelection(),i=t.length;if(i!==e.length)return!0;for(var n=!1,r=this.lastSelectedUserIdMap,o=i-1;o>=0;o-=1)if(!r[t[o]]){n=!0;break}return n},qE.prototype._cacheSelectedUserIds=function(e){this.lastSelectedUserIds=e.slice(0),this.lastSelectedUserIdMap=wp.arrayToMap(e)},qE.prototype._clearSelectedUserIdsCache=function(){this.lastSelectedUserIds=null,this.lastSelectedUserIdMap=null},qE.prototype._render=function(e,t){var i=e.autoClearColor,n=e.autoClearDepth,r=e.autoClearStencil;e.autoClearColor=!1,e.autoClearDepth=!0,e.autoClearStencil=!1,e.render(this.selectionScene,t),e.autoClearColor=i,e.autoClearDepth=n,e.autoClearStencil=r},qE.prototype._updateScene=function(e){this._clearMeshesFromScene(),this._addMeshesToScene(this._getSelectedMeshes(e)),this._updateMatrixWorldForScene(),this._updateSelectedLineMaterial()},qE.prototype._clearMeshesFromScene=function(){this.selectionObjectGroup.clear()},qE.prototype._addMeshesToScene=function(e){for(var t=0,i=e.length;i>t;t+=1)this.selectionObjectGroup.add(e[t])},qE.prototype._updateMatrixWorldForScene=function(){this.selectionObjectGroup.matrix.copy(this.viewer.getScene().getMatrixGlobal()),this.selectionObjectGroup.updateMatrixWorld(!0)},qE.prototype._getSelectedMeshes=function(e){var t={meshes:[]},i=this,n=wp.arrayToMap(e);return this.viewer.getModelManager().traverseLoadedModels((function(r){r.getPickingMeshes(i,t,e,n)})),t.meshes},qE.prototype._updateSelectedLineMaterial=function(){xd.PickingLineWidthEnabled&&this.selectedLineMaterial.resolution.set(this.viewer.domElement.offsetWidth,this.viewer.domElement.offsetHeight)},qE.prototype.setSelectionColor=function(e,t){var i=this.selectedMaterial.opacity;t=void 0===t?i:t,"0x"+this.selectedMaterial.color.getHexString()===e&&i===t||(this.selectedMaterial.color.setHex(e),this.skinningSelectedMaterial.color.setHex(e),this.instancedSelectedMaterial.color.setHex(e),void 0===t&&null===t||(this.selectedMaterial.opacity=t,this.skinningSelectedMaterial.opacity=t,this.instancedSelectedMaterial.opacity=t,1>t?(this.selectedMaterial.transparent=!0,this.skinningSelectedMaterial.transparent=!0,this.instancedSelectedMaterial.transparent=!0):(this.selectedMaterial.transparent=!1,this.skinningSelectedMaterial.transparent=!1,this.instancedSelectedMaterial.transparent=!1)),this.selectedMaterial.needsUpdate=!0,this.skinningSelectedMaterial.needsUpdate=!0,this.instancedSelectedMaterial.needsUpdate=!0)},qE.prototype.getSelectionColor=function(e,t){var i=this.selectedMaterial.opacity;return new Du(this.selectedMaterial.color.getHex(),i)},qE.prototype.setLineSelectionColor=function(e,t){var i=this.wireframeMaterial.opacity;t=void 0===t?i:t,"0x"+this.wireframeMaterial.color.getHexString()===e&&i===t||(this.wireframeMaterial.color.setHex(e),this.skinningWireframeMaterial.color.setHex(e),this.selectedLineMaterial.color.setHex(e),this.instancedWireFrameMaterial.color.setHex(e),void 0===t&&null===t||(this.wireframeMaterial.opacity=t,this.skinningWireframeMaterial.opacity=t,this.selectedLineMaterial.opacity=t,this.instancedWireFrameMaterial.opacity=t,1>t?(this.wireframeMaterial.transparent=!0,this.skinningWireframeMaterial.transparent=!0,this.selectedLineMaterial.transparent=!0,this.instancedWireFrameMaterial.transparent=!0):(this.wireframeMaterial.transparent=!1,this.skinningWireframeMaterial.transparent=!1,this.selectedLineMaterial.transparent=!1,this.instancedWireFrameMaterial.transparent=!1)),this.wireframeMaterial.needsUpdate=!0,this.skinningWireframeMaterial.needsUpdate=!0,this.selectedLineMaterial.needsUpdate=!0,this.instancedWireFrameMaterial.needsUpdate=!0)},qE.prototype.getLineSelectionColor=function(){var e=this.wireframeMaterial.opacity;return new Du(this.wireframeMaterial.color.getHex(),e)};var ZE=new yt,XE=function(){function e(t){ru(this,e),t=t||{},this.vertices={near:[new Ke,new Ke,new Ke,new Ke],far:[new Ke,new Ke,new Ke,new Ke]},void 0!==t.projectionMatrix&&this.setFromProjectionMatrix(t.projectionMatrix,t.maxFar||1e4)}return au(e,[{key:"setFromProjectionMatrix",value:function(e,t){var i=0===e.elements[11];return ZE.copy(e).invert(),this.vertices.near[0].set(1,1,-1),this.vertices.near[1].set(1,-1,-1),this.vertices.near[2].set(-1,-1,-1),this.vertices.near[3].set(-1,1,-1),this.vertices.near.forEach((function(e){e.applyMatrix4(ZE)})),this.vertices.far[0].set(1,1,1),this.vertices.far[1].set(1,-1,1),this.vertices.far[2].set(-1,-1,1),this.vertices.far[3].set(-1,1,1),this.vertices.far.forEach((function(e){e.applyMatrix4(ZE);var n=Math.abs(e.z);i?e.z*=Math.min(t/n,1):e.multiplyScalar(Math.min(t/n,1))})),this.vertices}},{key:"split",value:function(t,i){for(;t.length>i.length;)i.push(new e);i.length=t.length;for(var n=0;t.length>n;n+=1){var r=i[n];if(0===n)for(var o=0;4>o;o+=1)r.vertices.near[o].copy(this.vertices.near[o]);else for(var a=0;4>a;a+=1)r.vertices.near[a].lerpVectors(this.vertices.near[a],this.vertices.far[a],t[n-1]);if(n===t-1)for(var s=0;4>s;s+=1)r.vertices.far[s].copy(this.vertices.far[s]);else for(var l=0;4>l;l+=1)r.vertices.far[l].lerpVectors(this.vertices.near[l],this.vertices.far[l],t[n])}}},{key:"toSpace",value:function(e,t){for(var i=0;4>i;i+=1)t.vertices.near[i].copy(this.vertices.near[i]).applyMatrix4(e),t.vertices.far[i].copy(this.vertices.far[i]).applyMatrix4(e)}}]),e}(),_E={lights_fragment_begin:"\nGeometricContext geometry;\n\ngeometry.position = - vViewPosition;\ngeometry.normal = normal;\ngeometry.viewDir = ( isOrthographic ) ? vec3( 0, 0, 1 ) : normalize( vViewPosition );\n\n#ifdef CLEARCOAT\n\n\tgeometry.clearcoatNormal = clearcoatNormal;\n\n#endif\n\nIncidentLight directLight;\n\n#if ( NUM_POINT_LIGHTS > 0 ) && defined( RE_Direct )\n\n\tPointLight pointLight;\n\t#if defined( USE_SHADOWMAP ) && NUM_POINT_LIGHT_SHADOWS > 0\n\tPointLightShadow pointLightShadow;\n\t#endif\n\n\t#pragma unroll_loop\n\tfor ( int i = 0; i < NUM_POINT_LIGHTS; i ++ ) {\n\n\t\tpointLight = pointLights[ i ];\n\n\t\tgetPointDirectLightIrradiance( pointLight, geometry, directLight );\n\n\t\t#if defined( USE_SHADOWMAP ) && ( UNROLLED_LOOP_INDEX < NUM_POINT_LIGHT_SHADOWS )\n\t\tpointLightShadow = pointLightShadows[ i ];\n\t\tdirectLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getPointShadow( pointShadowMap[ i ], pointLightShadow.shadowMapSize, pointLightShadow.shadowBias, pointLightShadow.shadowRadius, vPointShadowCoord[ i ], pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraFar ) : 1.0;\n\t\t#endif\n\n\t\tRE_Direct( directLight, geometry, material, reflectedLight );\n\n\t}\n\n#endif\n\n#if ( NUM_SPOT_LIGHTS > 0 ) && defined( RE_Direct )\n\n\tSpotLight spotLight;\n\t#if defined( USE_SHADOWMAP ) && NUM_SPOT_LIGHT_SHADOWS > 0\n\tSpotLightShadow spotLightShadow;\n\t#endif\n\n\t#pragma unroll_loop\n\tfor ( int i = 0; i < NUM_SPOT_LIGHTS; i ++ ) {\n\n\t\tspotLight = spotLights[ i ];\n\n\t\tgetSpotDirectLightIrradiance( spotLight, geometry, directLight );\n\n\t\t#if defined( USE_SHADOWMAP ) && ( UNROLLED_LOOP_INDEX < NUM_SPOT_LIGHT_SHADOWS )\n\t\tspotLightShadow = spotLightShadows[ i ];\n\t\tdirectLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getShadow( spotShadowMap[ i ], spotLightShadow.shadowMapSize, spotLightShadow.shadowBias, spotLightShadow.shadowRadius, vSpotShadowCoord[ i ] ) : 1.0;\n\t\t#endif\n\n\t\tRE_Direct( directLight, geometry, material, reflectedLight );\n\n\t}\n\n#endif\n\n#if ( NUM_DIR_LIGHTS > 0) && defined( RE_Direct ) && defined( USE_CSM ) && defined( CSM_CASCADES )\n\n\tDirectionalLight directionalLight;\n\tfloat linearDepth = (vViewPosition.z) / (shadowFar - cameraNear);\n\t#if defined( USE_SHADOWMAP ) && NUM_DIR_LIGHT_SHADOWS > 0\n\tDirectionalLightShadow directionalLightShadow;\n\t#endif\n\n\t#if defined( USE_SHADOWMAP ) && defined( CSM_FADE )\n\tfor ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) {\n\n\t\tdirectionalLight = directionalLights[ i ];\n\t\tgetDirectionalDirectLightIrradiance( directionalLight, geometry, directLight );\n\n\t\t// NOTE: Depth gets larger away from the camera.\n\t\t// cascade.x is closer, cascade.y is further\n\t\tvec2 cascade = CSM_cascades[ i ];\n\t\tfloat cascadeCenter = ( cascade.x + cascade.y ) / 2.0;\n\t\tfloat closestEdge = linearDepth < cascadeCenter ? cascade.x : cascade.y;\n\t\tfloat margin = 0.25 * pow( closestEdge, 2.0 );\n\t\tfloat csmx = cascade.x - margin / 2.0;\n\t\tfloat csmy = cascade.y + margin / 2.0;\n\t\tif( i < NUM_DIR_LIGHT_SHADOWS && linearDepth >= csmx && ( linearDepth < csmy || i == CSM_CASCADES - 1 ) ) {\n\n\t\t\tfloat dist = min( linearDepth - csmx, csmy - linearDepth );\n\t\t\tfloat ratio = clamp( dist / margin, 0.0, 1.0 );\n\t\t\tif( i < NUM_DIR_LIGHT_SHADOWS ) {\n\n\t\t\t\tvec3 prevColor = directLight.color;\n\t\t\t\tdirectionalLightShadow = directionalLightShadows[ i ];\n\t\t\t\tdirectLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getShadow( directionalShadowMap[ i ], directionalLightShadow.shadowMapSize, directionalLightShadow.shadowBias, directionalLightShadow.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0;\n\n\t\t\t\tbool shouldFadeLastCascade = i == CSM_CASCADES - 1 && linearDepth > cascadeCenter;\n\t\t\t\tdirectLight.color = mix( prevColor, directLight.color, shouldFadeLastCascade ? ratio : 1.0 );\n\n\t\t\t}\n\n\t\t\tReflectedLight prevLight = reflectedLight;\n\t\t\tRE_Direct( directLight, geometry, material, reflectedLight );\n\n\t\t\tbool shouldBlend = i != CSM_CASCADES - 1 || i == CSM_CASCADES - 1 && linearDepth < cascadeCenter;\n\t\t\tfloat blendRatio = shouldBlend ? ratio : 1.0;\n\n\t\t\treflectedLight.directDiffuse = mix( prevLight.directDiffuse, reflectedLight.directDiffuse, blendRatio );\n\t\t\treflectedLight.directSpecular = mix( prevLight.directSpecular, reflectedLight.directSpecular, blendRatio );\n\t\t\treflectedLight.indirectDiffuse = mix( prevLight.indirectDiffuse, reflectedLight.indirectDiffuse, blendRatio );\n\t\t\treflectedLight.indirectSpecular = mix( prevLight.indirectSpecular, reflectedLight.indirectSpecular, blendRatio );\n\n\t\t}\n\n\t}\n\t#else\n\n\t#pragma unroll_loop\n\tfor ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) {\n\n\t\tdirectionalLight = directionalLights[ i ];\n\t\tgetDirectionalDirectLightIrradiance( directionalLight, geometry, directLight );\n\n\t\t#if defined( USE_SHADOWMAP ) && ( UNROLLED_LOOP_INDEX < NUM_DIR_LIGHT_SHADOWS )\n\n\t\tdirectionalLightShadow = directionalLightShadows[ i ];\n\t\tif(linearDepth >= CSM_cascades[UNROLLED_LOOP_INDEX].x && linearDepth < CSM_cascades[UNROLLED_LOOP_INDEX].y) directLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getShadow( directionalShadowMap[ i ], directionalLightShadow.shadowMapSize, directionalLightShadow.shadowBias, directionalLightShadow.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0;\n\n\t\t#endif\n\n\t\tif(linearDepth >= CSM_cascades[UNROLLED_LOOP_INDEX].x && (linearDepth < CSM_cascades[UNROLLED_LOOP_INDEX].y || UNROLLED_LOOP_INDEX == CSM_CASCADES - 1)) RE_Direct( directLight, geometry, material, reflectedLight );\n\n\t}\n\n\t#endif\n\n#endif\n\n\n#if ( NUM_DIR_LIGHTS > 0 ) && defined( RE_Direct ) && !defined( USE_CSM ) && !defined( CSM_CASCADES )\n\n\tDirectionalLight directionalLight;\n\t#if defined( USE_SHADOWMAP ) && NUM_DIR_LIGHT_SHADOWS > 0\n\tDirectionalLightShadow directionalLightShadow;\n\t#endif\n\n\t#pragma unroll_loop\n\tfor ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) {\n\n\t\tdirectionalLight = directionalLights[ i ];\n\n\t\tgetDirectionalDirectLightIrradiance( directionalLight, geometry, directLight );\n\n\t\t#if defined( USE_SHADOWMAP ) && ( UNROLLED_LOOP_INDEX < NUM_DIR_LIGHT_SHADOWS )\n\t\tdirectionalLightShadow = directionalLightShadows[ i ];\n\t\tdirectLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getShadow( directionalShadowMap[ i ], directionalLightShadow.shadowMapSize, directionalLightShadow.shadowBias, directionalLightShadow.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0;\n\t\t#endif\n\n\t\tRE_Direct( directLight, geometry, material, reflectedLight );\n\n\t}\n\n#endif\n\n#if ( NUM_RECT_AREA_LIGHTS > 0 ) && defined( RE_Direct_RectArea )\n\n\tRectAreaLight rectAreaLight;\n\n\t#pragma unroll_loop\n\tfor ( int i = 0; i < NUM_RECT_AREA_LIGHTS; i ++ ) {\n\n\t\trectAreaLight = rectAreaLights[ i ];\n\t\tRE_Direct_RectArea( rectAreaLight, geometry, material, reflectedLight );\n\n\t}\n\n#endif\n\n#if defined( RE_IndirectDiffuse )\n\n\tvec3 iblIrradiance = vec3( 0.0 );\n\n\tvec3 irradiance = getAmbientLightIrradiance( ambientLightColor );\n\n\tirradiance += getLightProbeIrradiance( lightProbe, geometry );\n\n\t#if ( NUM_HEMI_LIGHTS > 0 )\n\n\t\t#pragma unroll_loop\n\t\tfor ( int i = 0; i < NUM_HEMI_LIGHTS; i ++ ) {\n\n\t\t\tirradiance += getHemisphereLightIrradiance( hemisphereLights[ i ], geometry );\n\n\t\t}\n\n\t#endif\n\n#endif\n\n#if defined( RE_IndirectSpecular )\n\n\tvec3 radiance = vec3( 0.0 );\n\tvec3 clearcoatRadiance = vec3( 0.0 );\n\n#endif\n",lights_pars_begin:"\n#if defined( USE_CSM ) && defined( CSM_CASCADES )\nuniform vec2 CSM_cascades[CSM_CASCADES];\nuniform float cameraNear;\nuniform float shadowFar;\n#endif\n\t"+xn.lights_pars_begin},$E=new yt,eB=new XE,tB=new XE,iB=new Ke;new Ke;var nB=new He,rB=[],oB=[],aB=function(){function e(t){ru(this,e),this.camera=(t=t||{}).camera,this.parent=t.parent,this.cascades=t.cascades||3,this.maxFar=t.maxFar||1e5,this.mode=t.mode||"practical",this.shadowMapSize=t.shadowMapSize||2048,this.shadowBias=t.shadowBias||1e-6,this.lightDirection=t.lightDirection||new Ke(1,-1,1).normalize(),this.lightIntensity=t.lightIntensity||1,this.lightNear=t.lightNear||1,this.lightFar=t.lightFar||2e3,this.lightMargin=t.lightMargin||200,this.customSplitsCallback=t.customSplitsCallback,this.fade=!1,this.mainFrustum=new XE,this.frustums=[],this.breaks=[],this.lights=[],this.shaders=new Map,this.createLights(),this.getBreaks(),this.initCascades(),this.injectInclude()}return au(e,[{key:"createLights",value:function(){for(var e=0;this.cascades>e;e++){var t=new fc(16777215,this.lightIntensity);t.castShadow=!0,t.intensity=.72,t.distance=300,t.color.setHex(14800580),t.position.set(-100,100,160),t.shadow.mapSize.width=this.shadowMapSize,t.shadow.mapSize.height=this.shadowMapSize,t.shadow.camera.near=this.lightNear,t.shadow.camera.far=this.lightFar,t.shadow.bias=this.shadowBias,t.updateMatrixWorld(),this.parent.add(t),this.parent.add(t.target),this.lights.push(t)}}},{key:"initCascades",value:function(){var e=this.camera;e.updateProjectionMatrix(),this.mainFrustum.setFromProjectionMatrix(e.projectionMatrix,this.maxFar),this.mainFrustum.split(this.breaks,this.frustums)}},{key:"getBreaks",value:function(){var e=this.camera,t=Math.min(e.far,this.maxFar);switch(this.breaks.length=0,this.mode){case"uniform":i(this.cascades,e.near,t,this.breaks);break;case"logarithmic":n(this.cascades,e.near,t,this.breaks);break;case"practical":!function(e,t,r,o,a){rB.length=0,oB.length=0,n(e,t,r,oB),i(e,t,r,rB);for(var s=1;e>s;s++)a.push(be.lerp(rB[s-1],oB[s-1],o));a.push(1)}(this.cascades,e.near,t,.5,this.breaks);break;case"custom":void 0===this.customSplitsCallback&&console.error("CSM: Custom split scheme callback not defined."),this.customSplitsCallback(this.cascades,e.near,t,this.breaks)}function i(e,t,i,n){for(var r=1;e>r;r++)n.push((t+(i-t)*r/e)/i);n.push(1)}function n(e,t,i,n){for(var r=1;e>r;r++)n.push(t*(i/t)*(r/e)/i);n.push(1)}}},{key:"update",value:function(e){for(var t=this.frustums,i=0;t.length>i;i++){var n=this.lights[i];n.shadow.camera.updateMatrixWorld(!0),$E.multiplyMatrices(n.shadow.camera.matrixWorldInverse,e),t[i].toSpace($E,eB);var r=eB.vertices.near,o=eB.vertices.far,a=o[0],s=void 0;s=a.distanceTo(o[2])>a.distanceTo(r[2])?o[2]:r[2];var l=a.distanceTo(s);nB.makeEmpty();for(var c=0;4>c;c++)nB.expandByPoint(r[c]),nB.expandByPoint(o[c]);if(this.fade){var h=this.camera,d=Math.max(h.far,this.maxFar);l+=.25*Math.pow(t[i].vertices.far[0].z/(d-h.near),2)*(d-h.near)}var u=l/this.shadowMapSize;nB.getCenter(iB),iB.z=nB.max.z+this.lightMargin,iB.x=Math.floor(iB.x/u)*u,iB.y=Math.floor(iB.y/u)*u,iB.applyMatrix4(n.shadow.camera.matrixWorld),n.shadow.camera.left=-l/2,n.shadow.camera.right=l/2,n.shadow.camera.top=l/2,n.shadow.camera.bottom=-l/2,n.position.copy(iB),n.target.position.copy(iB),n.target.position.x+=this.lightDirection.x,n.target.position.y+=this.lightDirection.y,n.target.position.z+=this.lightDirection.z,n.shadow.camera.updateProjectionMatrix(),n.shadow.camera.updateMatrixWorld()}}},{key:"injectInclude",value:function(){xn.lights_fragment_begin=_E.lights_fragment_begin,xn.lights_pars_begin=_E.lights_pars_begin}},{key:"setupMaterial",value:function(e){e.defines=e.defines||{},e.defines.USE_CSM=1,e.defines.CSM_CASCADES=this.cascades,this.fade&&(e.defines.CSM_FADE="");var t=[],i=this,n=this.shaders;e.onBeforeCompile=function(r){var o=Math.min(i.camera.far,i.maxFar);i.getExtendedBreaks(t),console.log("www",t,t.length),r.uniforms.CSM_cascades={value:t},r.uniforms.cameraNear={value:i.camera.near},r.uniforms.shadowFar={value:o},n.set(e,r)},n.set(e,null)}},{key:"updateUniforms",value:function(){var e=Math.min(this.camera.far,this.maxFar);this.shaders.forEach((function(t,i){if(null!==t){var n=t.uniforms;this.getExtendedBreaks(n.CSM_cascades.value),n.cameraNear.value=this.camera.near,n.shadowFar.value=e}!this.fade&&"CSM_FADE"in i.defines?(delete i.defines.CSM_FADE,i.needsUpdate=!0):this.fade&&!("CSM_FADE"in i.defines)&&(i.defines.CSM_FADE="",i.needsUpdate=!0)}),this)}},{key:"getExtendedBreaks",value:function(e){for(;this.breaks.length>e.length;)e.push(new ke);e.length=this.breaks.length;for(var t=0;this.cascades>t;t++){var i=this.breaks[t];e[t].x=this.breaks[t-1]||0,e[t].y=i}}},{key:"updateFrustums",value:function(){this.getBreaks(),this.initCascades(),this.updateUniforms()}},{key:"helper",value:function(e){for(var t,i,n=new Sa({color:16777215}),r=new Yt,o=0;this.frustums.length>o;o++){this.frustums[o].toSpace(e,tB),t=new Ni,i=[];for(var a=0;5>a;a++){var s=tB.vertices.near[4===a?0:a];i.push(s.x,s.y,s.z)}t.setAttribute("position",new Ai(new Float32Array(i),3)),r.add(new Ua(t,n)),t=new Ni,i=[];for(var l=0;5>l;l++){var c=tB.vertices.far[4===l?0:l];i.push(c.x,c.y,c.z)}t.setAttribute("position",new Ai(new Float32Array(i),3)),r.add(new Ua(t,n));for(var h=0;4>h;h++){t=new Ni;var d=tB.vertices.near[h],u=tB.vertices.far[h];(i=[]).push(d.x,d.y,d.z),i.push(u.x,u.y,u.z),t.setAttribute("position",new Ai(new Float32Array(i),3)),r.add(new Ua(t,n))}}return r}},{key:"remove",value:function(){for(var e=0;this.lights.length>e;e++)this.parent.remove(this.lights[e])}},{key:"dispose",value:function(){var e=this.shaders;e.forEach((function(e,t){delete t.onBeforeCompile,delete t.defines.USE_CSM,delete t.defines.CSM_CASCADES,delete t.defines.CSM_FADE,delete e.uniforms.CSM_cascades,delete e.uniforms.cameraNear,delete e.uniforms.shadowFar,t.needsUpdate=!0})),e.clear()}}]),e}(),sB=new ke,lB=function(e){this.viewer=e,this.renderer=null,this.countRenderRequest=0,this.maxCountRenderRequest=1e4,this.rendering=!1,this.incrementRenderHandle=0,this.composer=null,this.blinkHandle=0,this.transparentSort=function(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}};lB.prototype.destroy=function(){this.incrementRenderHandle>0&&cancelAnimationFrame(this.incrementRenderHandle),this.blinkHandle>0&&cancelAnimationFrame(this.blinkHandle),this.composer&&(this.composer.destroy(),this.composer=null),this.renderer&&(this.renderer.destroy&&this.orderedRenderer&&(this.renderer.destroy(),this.renderer.setRenderer&&this.renderer.setRenderer(null),this.orderedRenderer=null),this.renderer.dispose(),this.renderer.domElement.parentNode&&this.renderer.domElement.parentNode.removeChild(this.renderer.domElement)),this.renderer=null,this.pickingEffecter&&(this.pickingEffecter.destroy(),this.pickingEffecter=null),this.viewer=null},lB.prototype.setupRenderer=function(e){if(!this.renderer){var t=this.viewer;this.renderer=new Po(e),this.viewer.scene.renderer=this.renderer,this.renderer._scene=this.viewer.scene;var i=t.domElement.offsetWidth,n=t.domElement.offsetHeight;this.renderer.toneMapping=1,this.renderer.setTransparentSort(this.transparentSort),this.renderer.setClearColor(0,0),this.renderer.setPixelRatio(window.devicePixelRatio||1),this.renderer.setSize(i,n),this.renderer.sortObjects=!0,this.renderer.domElement.setAttribute("tabindex","0"),this.renderer.domElement.setAttribute("class","main-canvas"),t.domElement.appendChild(this.renderer.domElement)}},lB.prototype.resetupRenderer=function(e){var t=this.viewer;e.context=this.renderer.getContext();var i=new Po(e);i.setClearColor(this.renderer.getClearColor(),this.renderer.getClearAlpha()),i.setPixelRatio(this.renderer.getPixelRatio());var n=this.renderer.getSize(new ke);i.setSize(n.x,n.y),i.gammaFactor=this.renderer.gammaFactor,i.sortObjects=this.renderer.sortObjects,i.domElement=this.renderer.domElement,i.toneMapping=this.renderer.toneMapping,i.shadowMap.enabled=this.renderer.shadowMap.enabled,i.clippingPlanes=this.renderer.clippingPlanes,i.shadowMap.enabled=this.renderer.shadowMap.enabled,i.shadowMap.type=this.renderer.shadowMap.type,i.shadowMap.autoUpdate=this.renderer.shadowMap.autoUpdate,i.shadowMap.needsUpdate=this.renderer.shadowMap.needsUpdate,i.setTransparentSort(this.transparentSort),this.renderer=i,this.viewer.scene.renderer=this.renderer,this.renderer._scene=this.viewer.scene,this.composer&&this.composer.reinit(this.renderer,t.modelManager,t.getScene(),t.camera,n.x,n.y)},lB.prototype.setupShadowMap=function(e){var t=this.viewer,i=new aB({maxFar:e.far,cascades:4,mode:e.mode,parent:t.getScene().getExternalScene(),shadowMapSize:1024,lightDirection:new Ke(e.lightX,e.lightY,e.lightZ).normalize(),camera:t.camera});this.csm=i;var n=new XC;n.add(e,"orthographic").onChange((function(e){})),n.add(e,"fade").onChange((function(e){i.fade=e,i.updateFrustums()})),n.add(e,"far",1,5e7).step(1).name("shadow far").onChange((function(e){i.maxFar=e,i.updateFrustums()})),n.add(e,"mode",["uniform","logarithmic","practical"]).name("frustum split mode").onChange((function(e){i.mode=e,i.updateFrustums()})),n.add(e,"lightX",-1,1).name("light direction x").onChange((function(e){i.lightDirection.x=e})),n.add(e,"lightY",-1,1).name("light direction y").onChange((function(e){i.lightDirection.y=e})),n.add(e,"lightZ",-1,1).name("light direction z").onChange((function(e){i.lightDirection.z=e})),n.add(e,"margin",0,2e6).name("light margin").onChange((function(e){i.lightMargin=e})),n.add(e,"lightNear",1,1e7).name("light near").onChange((function(e){for(var t=0;i.lights.length>t;t+=1)i.lights[t].shadow.camera.near=e,i.lights[t].shadow.camera.updateProjectionMatrix()})),n.add(e,"lightFar",1,1e8).name("light far").onChange((function(e){for(var t=0;i.lights.length>t;t+=1)i.lights[t].shadow.camera.far=e,i.lights[t].shadow.camera.updateProjectionMatrix()}))},lB.prototype._applyPickingEffectForIncrement=function(){if(this.getPickingEffecter()){var e=this.viewer.modelManager.isFilterApplied();this.orderedRenderer.restart(),this.orderedRenderer.setNonBreakingRender(!0),this.pickingEffecter.apply(e),this.orderedRenderer.setNonBreakingRender(!1)}},lB.prototype._applyPickingEffect=function(){if(this.getPickingEffecter()){var e=this.viewer.modelManager.isFilterApplied();this.pickingEffecter.apply(e)}},lB.prototype._forceRenderOneFrame=function(){var e=this.viewer,t=e.camera,i=e.modelManager.getScene();this.orderedRenderer?(this.orderedRenderer.restart(),this.orderedRenderer.setNonBreakingRender(!0),this.renderer.render(i,t,null,!0),this.orderedRenderer.setNonBreakingRender(!1)):(this.renderer.setRenderTarget(null),this.renderer.clear(),this.renderer.render(i,t))},lB.prototype.incrementRender=function(e){if(this.countRenderRequest+=1,this.countRenderRequest>this.maxCountRenderRequest&&(this.countRenderRequest=0),!this.rendering&&!this.pickingEffectRendering){this.rendering=!0;var t=this,i=this.viewer,n=i.camera,r=i.modelManager,o=i.editorManager,a=i.getScene(),s=this.renderer;r.calculateCameraModelRelation(n.position),i.cameraControl.updateCamera(),i.calculateNearFar(),a.updateLights(n);var l=o.isUpdateRenderList;s.resetIncrementRender(),s.setObjectListUpdateState(l),l&&r.prepareScene(n),this.incrementRenderHandle=requestAnimationFrame(function e(l,c){var h=l;return function(){s.autoClear=c,o.cameraChange?(s.resetIncrementRender(),s.autoClear=!0,o.cameraChange=!1):s.autoClear=c,s.render(a,n)||h!==t.countRenderRequest?(t.rendering=!1,h!==t.countRenderRequest?i.render():(t.pickingEffectRendering=!0,t._applyPickingEffectForIncrement(),r.setFilterApplied(!1),i.onRenderFinishedCallback(),r.disposeBufferAfterVbo(),t.pickingEffectRendering=!1)):t.incrementRenderHandle=requestAnimationFrame(e(h,!1))}}(t.countRenderRequest,!0)),i.onRenderCallback(),i.cameraControl.setCameraChanging(!1)}},lB.prototype.fullRender=function(){var e=this,t=this.viewer,i=t.camera,n=t.modelManager,r=t.getScene(),o=this.renderer;this.blinkHandle>0&&cancelAnimationFrame(this.blinkHandle),function a(){t.cameraControl.updateCamera(),t.calculateNearFar(),r.updateLights(i),n.getBlinkEnabled()&&n.updateBlinkMaterial();var s=r.fillClipPlane&&r.fillClipPlane.visible,l=r.clipPlanes&&r.clipPlanes.visible&&xd.EnableBoxClippingCaps;if(xd.ClippingCaps&&(s||l)&&xd.EnableClippingCaps){if(s||l){var c=r.getFillClipPlane(),h=r.getClipPlanes(),d=t.modelManager.getModelKeys();n.prepareCapScene(),o.clear(),o.autoClear=!1,s?(c.capPlane.planeMesh.visible=!0,c.capPlane.lineMesh.visible=!0,h.boxMesh.visible=!1):(c.capPlane.planeMesh.visible=!1,c.capPlane.lineMesh.visible=!1,h.boxMesh.visible=!0),c.planeHighLightMatrial.visible=!1,h.planeHighLightMatrial.visible=!1,h.planeMaterial.visible=!1,r.overrideMaterial=r.backMaterial;for(var u={},p=0,g=d.length;g>p;p+=1){var f=d[p],m=t.modelManager.getModel(f);if(u[f]={},m){var A=m._getNodeGroup(Vp.GEOMETRY,{globalSpace:!0});u[f][Vp.GEOMETRY]=A.visible,A=m._getNodeGroup(Vp.WIREFRAME,{globalSpace:!0}),u[f][Vp.WIREFRAME]=A.visible,A=m._getNodeGroup(Vp.INSTANCEGEOMETRY,{globalSpace:!0}),u[f][Vp.INSTANCEGEOMETRY]=A.visible,A.visible=!1,A=m._getNodeGroup(Vp.INSTANCEWIREFRAMEGEOMETRY,{globalSpace:!0}),u[f][Vp.INSTANCEWIREFRAMEGEOMETRY]=A.visible,A.visible=!1}}o.render(r,i),r.overrideMaterial=r.backInstanceMaterial;for(var y=0,v=d.length;v>y;y+=1){var C=d[y],I=t.modelManager.getModel(C);if(I){var x=I._getNodeGroup(Vp.GEOMETRY,{globalSpace:!0});x.visible=!1,(x=I._getNodeGroup(Vp.WIREFRAME,{globalSpace:!0})).visible=!1,(x=I._getNodeGroup(Vp.INSTANCEGEOMETRY,{globalSpace:!0})).visible=u[C][Vp.INSTANCEGEOMETRY],(x=I._getNodeGroup(Vp.INSTANCEWIREFRAMEGEOMETRY,{globalSpace:!0})).visible=u[C][Vp.INSTANCEWIREFRAMEGEOMETRY]}}o.render(r,i),r.overrideMaterial=r.frontMaterial;for(var w=0,M=d.length;M>w;w+=1){var E=d[w],B=t.modelManager.getModel(E);if(B){var S=B._getNodeGroup(Vp.GEOMETRY,{globalSpace:!0});S.visible=u[E][Vp.GEOMETRY],(S=B._getNodeGroup(Vp.WIREFRAME,{globalSpace:!0})).visible=u[E][Vp.WIREFRAME],S=B._getNodeGroup(Vp.INSTANCEGEOMETRY,{globalSpace:!0}),u[E][Vp.INSTANCEGEOMETRY]=S.visible,S.visible=!1,S=B._getNodeGroup(Vp.INSTANCEWIREFRAMEGEOMETRY,{globalSpace:!0}),u[E][Vp.INSTANCEWIREFRAMEGEOMETRY]=S.visible,S.visible=!1}}o.render(r,i),r.overrideMaterial=r.frontInstanceMaterial;for(var b=0,k=d.length;k>b;b+=1){var D=d[b],T=t.modelManager.getModel(D);if(T){var R=T._getNodeGroup(Vp.GEOMETRY,{globalSpace:!0});R.visible=!1,(R=T._getNodeGroup(Vp.WIREFRAME,{globalSpace:!0})).visible=!1,(R=T._getNodeGroup(Vp.INSTANCEGEOMETRY,{globalSpace:!0})).visible=u[D][Vp.INSTANCEGEOMETRY],(R=T._getNodeGroup(Vp.INSTANCEWIREFRAMEGEOMETRY,{globalSpace:!0})).visible=u[D][Vp.INSTANCEWIREFRAMEGEOMETRY]}}o.render(r,i),o.render(n.capsScene,i),r.overrideMaterial=null,c.planeHighLightMatrial.visible=!0,h.planeHighLightMatrial.visible=!0,h.planeMaterial.visible=!0;for(var U=0,F=d.length;F>U;U+=1){var Q=d[U],L=t.modelManager.getModel(Q);if(L){var O=L._getNodeGroup(Vp.GEOMETRY,{globalSpace:!0});O.visible=u[Q][Vp.GEOMETRY],(O=L._getNodeGroup(Vp.WIREFRAME,{globalSpace:!0})).visible=u[Q][Vp.WIREFRAME],(O=L._getNodeGroup(Vp.INSTANCEGEOMETRY,{globalSpace:!0})).visible=u[Q][Vp.INSTANCEGEOMETRY],(O=L._getNodeGroup(Vp.INSTANCEWIREFRAMEGEOMETRY,{globalSpace:!0})).visible=u[Q][Vp.INSTANCEWIREFRAMEGEOMETRY]}}u=null,o.render(r,i)}}else!xd.PickingEffect&&xd.EnableSelectionOutline&&e.composer&&t.getSelection().length>0?e.composer.render():(o.setRenderTarget(null),o.clear(),o.render(r,i));e._applyPickingEffect(),n.setFilterApplied(!1),t.onRenderListener(),t.onRenderFinishedListener(),t.cameraControl.isCameraChanging()&&n.dispatchEvent({type:Fd.ON_CAMERA_CHANGED_AND_RENDERED}),t.cameraControl.setCameraChanging(!1),n.getBlinkEnabled()&&(e.blinkHandle=requestAnimationFrame(a)),n.disposeBufferAfterVbo()}()},lB.prototype.fillCavityRender=function(e){var t=this.viewer,i=t.camera,n=t.modelManager,r=this.renderer,o=t.getScene();function a(e,t,i,n){var r=new To,o=new gi;o.depthWrite=!1,o.depthTest=!1,o.colorWrite=!1,o.stencilWrite=!0,o.stencilFunc=ue;var a=o.clone();a.side=1,a.clippingPlanes=[t],a.stencilFail=ce,a.stencilZFail=ce,a.stencilZPass=ce;var s=new nn(e,a);s.matrixWorld=n.matrixWorld,s.renderOrder=i,r.add(s);var l=o.clone();l.side=0,l.clippingPlanes=[t],l.stencilFail=he,l.stencilZFail=he,l.stencilZPass=he;var c=new nn(e,l);return c.renderOrder=i,c.matrixWorld=n.matrixWorld,r.add(c),r}this.blinkHandle>0&&cancelAnimationFrame(this.blinkHandle),function e(){t.cameraControl.updateCamera(),t.calculateNearFar(),o.updateLights(i),n.getBlinkEnabled()&&n.updateBlinkMaterial();var s=o.fillClipPlane&&o.fillClipPlane.visible,l=o.clipPlanes&&o.clipPlanes.visible,c=r.autoClear,h=r.sortObjects;if(xd.ClippingCaps&&(s||l)){if(s){var d=o.getFillClipPlane(),u=o.getClipPlanes(),p=t.modelManager.getModelKeys();n.prepareCapScene(),r.clear(),r.autoClear=!1,s?(d.capPlane.planeMesh.visible=!0,d.capPlane.lineMesh.visible=!0,u.boxMesh.visible=!1):(d.capPlane.planeMesh.visible=!1,d.capPlane.lineMesh.visible=!1,u.boxMesh.visible=!0),d.planeHighLightMatrial.visible=!1,u.planeHighLightMatrial.visible=!1,u.planeMaterial.visible=!1,o.overrideMaterial=o.backMaterial;for(var g={},f=0,m=p.length;m>f;f+=1){var A=p[f],y=t.modelManager.getModel(A);if(g[A]={},y){var v=y._getNodeGroup(Vp.GEOMETRY,{globalSpace:!0});g[A][Vp.GEOMETRY]=v.visible,v=y._getNodeGroup(Vp.WIREFRAME,{globalSpace:!0}),g[A][Vp.WIREFRAME]=v.visible,v=y._getNodeGroup(Vp.INSTANCEGEOMETRY,{globalSpace:!0}),g[A][Vp.INSTANCEGEOMETRY]=v.visible,v.visible=!1,v=y._getNodeGroup(Vp.INSTANCEWIREFRAMEGEOMETRY,{globalSpace:!0}),g[A][Vp.INSTANCEWIREFRAMEGEOMETRY]=v.visible,v.visible=!1}}r.render(o,i),o.overrideMaterial=o.backInstanceMaterial;for(var C=0,I=p.length;I>C;C+=1){var x=p[C],w=t.modelManager.getModel(x);if(w){var M=w._getNodeGroup(Vp.GEOMETRY,{globalSpace:!0});M.visible=!1,(M=w._getNodeGroup(Vp.WIREFRAME,{globalSpace:!0})).visible=!1,(M=w._getNodeGroup(Vp.INSTANCEGEOMETRY,{globalSpace:!0})).visible=g[x][Vp.INSTANCEGEOMETRY],(M=w._getNodeGroup(Vp.INSTANCEWIREFRAMEGEOMETRY,{globalSpace:!0})).visible=g[x][Vp.INSTANCEWIREFRAMEGEOMETRY]}}r.render(o,i),o.overrideMaterial=o.frontMaterial;for(var E=0,B=p.length;B>E;E+=1){var S=p[E],b=t.modelManager.getModel(S);if(b){var k=b._getNodeGroup(Vp.GEOMETRY,{globalSpace:!0});k.visible=g[S][Vp.GEOMETRY],(k=b._getNodeGroup(Vp.WIREFRAME,{globalSpace:!0})).visible=g[S][Vp.WIREFRAME],k=b._getNodeGroup(Vp.INSTANCEGEOMETRY,{globalSpace:!0}),g[S][Vp.INSTANCEGEOMETRY]=k.visible,k.visible=!1,k=b._getNodeGroup(Vp.INSTANCEWIREFRAMEGEOMETRY,{globalSpace:!0}),g[S][Vp.INSTANCEWIREFRAMEGEOMETRY]=k.visible,k.visible=!1}}r.render(o,i),o.overrideMaterial=o.frontInstanceMaterial;for(var D=0,T=p.length;T>D;D+=1){var R=p[D],U=t.modelManager.getModel(R);if(U){var F=U._getNodeGroup(Vp.GEOMETRY,{globalSpace:!0});F.visible=!1,(F=U._getNodeGroup(Vp.WIREFRAME,{globalSpace:!0})).visible=!1,(F=U._getNodeGroup(Vp.INSTANCEGEOMETRY,{globalSpace:!0})).visible=g[R][Vp.INSTANCEGEOMETRY],(F=U._getNodeGroup(Vp.INSTANCEWIREFRAMEGEOMETRY,{globalSpace:!0})).visible=g[R][Vp.INSTANCEWIREFRAMEGEOMETRY]}}r.render(o,i),r.render(n.capsScene,i),o.overrideMaterial=null,s?d.planeHighLightMatrial.visible=!0:(u.planeHighLightMatrial.visible=!0,u.planeMaterial.visible=!0);for(var Q=0,L=p.length;L>Q;Q+=1){var O=p[Q],N=t.modelManager.getModel(O);if(N){var P=N._getNodeGroup(Vp.GEOMETRY,{globalSpace:!0});P.visible=g[O][Vp.GEOMETRY],(P=N._getNodeGroup(Vp.WIREFRAME,{globalSpace:!0})).visible=g[O][Vp.WIREFRAME],(P=N._getNodeGroup(Vp.INSTANCEGEOMETRY,{globalSpace:!0})).visible=g[O][Vp.INSTANCEGEOMETRY],(P=N._getNodeGroup(Vp.INSTANCEWIREFRAMEGEOMETRY,{globalSpace:!0})).visible=g[O][Vp.INSTANCEWIREFRAMEGEOMETRY]}}g=null,r.render(o,i)}if(l){r.clear(),r.autoClear=!1,r.sortObjects=!0,r.localClippingEnabled=!0;var G=t.modelManager.getModelKeys(),K=r.clippingPlanes;r.clippingPlanes=[];var V=o.getClipPlanes(),Y=new Vo;Y.autoUpdate=!1;for(var H=0,j=o.lightArray.length;j>H;H+=1)Y.add(o.lightArray[H].clone());for(var W=[],J=0;6>J;J+=1)W[J]=V.children[J].clone();for(var z=0,q=G.length;q>z;z+=1){var Z=t.modelManager.getModel(G[z]);if(Z)for(var X=Z._getNodeGroup(Vp.GEOMETRY,{globalSpace:!0}),_=0,$=X.children.length;$>_;_+=1){var ee=new To;ee.name="object";var te=[],ie=[];Y.add(ee);var ne=X.children[_];if(ne.visible){for(var re=ne.geometry,oe=[],se=0;6>se;se+=1)oe[se]=K[se].clone();for(var le=function(e){(he=new To).name="poGroup";var t=oe[e];(de=a(re,t,e+1,ne)).name="stencilGroup",ue=new Xs({color:ne.material[0].color,metalness:.1,roughness:.75,clippingPlanes:oe.filter((function(e){return e!==t})),stencilWrite:!0,stencilRef:0,stencilFunc:517,stencilFail:ae,stencilZFail:ae,stencilZPass:ae});var i=W[e].clone();i.material=ue,i.testNumber=e,i.onAfterRender=function(){r.clearStencil()},i.renderOrder=e+1.1,ee.add(de),he.add(i),te.push(i),Y.add(he),ie.push(he)},ce=0;6>ce;ce+=1){var he,de,ue;le(ce)}for(var pe=ne.clone(),ge=0,fe=pe.material.length;fe>ge;ge+=1)pe.material[ge].clippingPlanes=oe;pe.renderOrder=6,ee.add(pe),r.render(Y,i),Y.remove(ee);for(var me=0,Ae=ie.length;Ae>me;me+=1)Y.remove(ie[me]);te=null}}}r.sortObjects=h,r.clippingPlanes=K,r.autoClear=c,r.localClippingEnabled=!1}}else xd.EnableSelectionOutline&&t.composer&&t.getSelection().length>0?t.composer.render():(r.setRenderTarget(null),r.clear(),r.render(o,i));t.onRenderListener(),t.onRenderFinishedListener(),t.cameraControl.setCameraChanging(!1),n.getBlinkEnabled()&&(t.blinkHandle=requestAnimationFrame(e)),n.disposeBufferAfterVbo()}()},lB.prototype.fillCavityRender2=function(e){var t=this.viewer,i=t.camera,n=t.modelManager,r=this.renderer,o=t.getScene();this.blinkHandle>0&&cancelAnimationFrame(this.blinkHandle),function e(){t.cameraControl.updateCamera(),t.calculateNearFar(),o.updateLights(i),n.getBlinkEnabled()&&n.updateBlinkMaterial();var a=o.fillClipPlane&&o.fillClipPlane.visible,s=o.clipPlanes&&o.clipPlanes.visible,l=r.autoClear;if(xd.ClippingCaps&&(a||s)){if(a){var c=o.getFillClipPlane(),h=o.getClipPlanes(),d=t.modelManager.getModelKeys();n.prepareCapScene(),r.clear(),r.autoClear=!1,a?(c.capPlane.planeMesh.visible=!0,c.capPlane.lineMesh.visible=!0,h.boxMesh.visible=!1):(c.capPlane.planeMesh.visible=!1,c.capPlane.lineMesh.visible=!1,h.boxMesh.visible=!0),c.planeHighLightMatrial.visible=!1,h.planeHighLightMatrial.visible=!1,h.planeMaterial.visible=!1,o.overrideMaterial=o.backMaterial;for(var u={},p=0,g=d.length;g>p;p+=1){var f=d[p],m=t.modelManager.getModel(f);if(u[f]={},m){var A=m._getNodeGroup(Vp.GEOMETRY,{globalSpace:!0});u[f][Vp.GEOMETRY]=A.visible,A=m._getNodeGroup(Vp.WIREFRAME,{globalSpace:!0}),u[f][Vp.WIREFRAME]=A.visible,A=m._getNodeGroup(Vp.INSTANCEGEOMETRY,{globalSpace:!0}),u[f][Vp.INSTANCEGEOMETRY]=A.visible,A.visible=!1,A=m._getNodeGroup(Vp.INSTANCEWIREFRAMEGEOMETRY,{globalSpace:!0}),u[f][Vp.INSTANCEWIREFRAMEGEOMETRY]=A.visible,A.visible=!1}}r.render(o,i),o.overrideMaterial=o.backInstanceMaterial;for(var y=0,v=d.length;v>y;y+=1){var C=d[y],I=t.modelManager.getModel(C);if(I){var x=I._getNodeGroup(Vp.GEOMETRY,{globalSpace:!0});x.visible=!1,(x=I._getNodeGroup(Vp.WIREFRAME,{globalSpace:!0})).visible=!1,(x=I._getNodeGroup(Vp.INSTANCEGEOMETRY,{globalSpace:!0})).visible=u[C][Vp.INSTANCEGEOMETRY],(x=I._getNodeGroup(Vp.INSTANCEWIREFRAMEGEOMETRY,{globalSpace:!0})).visible=u[C][Vp.INSTANCEWIREFRAMEGEOMETRY]}}r.render(o,i),o.overrideMaterial=o.frontMaterial;for(var w=0,M=d.length;M>w;w+=1){var E=d[w],B=t.modelManager.getModel(E);if(B){var S=B._getNodeGroup(Vp.GEOMETRY,{globalSpace:!0});S.visible=u[E][Vp.GEOMETRY],(S=B._getNodeGroup(Vp.WIREFRAME,{globalSpace:!0})).visible=u[E][Vp.WIREFRAME],S=B._getNodeGroup(Vp.INSTANCEGEOMETRY,{globalSpace:!0}),u[E][Vp.INSTANCEGEOMETRY]=S.visible,S.visible=!1,S=B._getNodeGroup(Vp.INSTANCEWIREFRAMEGEOMETRY,{globalSpace:!0}),u[E][Vp.INSTANCEWIREFRAMEGEOMETRY]=S.visible,S.visible=!1}}r.render(o,i),o.overrideMaterial=o.frontInstanceMaterial;for(var b=0,k=d.length;k>b;b+=1){var D=d[b],T=t.modelManager.getModel(D);if(T){var R=T._getNodeGroup(Vp.GEOMETRY,{globalSpace:!0});R.visible=!1,(R=T._getNodeGroup(Vp.WIREFRAME,{globalSpace:!0})).visible=!1,(R=T._getNodeGroup(Vp.INSTANCEGEOMETRY,{globalSpace:!0})).visible=u[D][Vp.INSTANCEGEOMETRY],(R=T._getNodeGroup(Vp.INSTANCEWIREFRAMEGEOMETRY,{globalSpace:!0})).visible=u[D][Vp.INSTANCEWIREFRAMEGEOMETRY]}}r.render(o,i),r.render(n.capsScene,i),o.overrideMaterial=null,a?c.planeHighLightMatrial.visible=!0:(h.planeHighLightMatrial.visible=!0,h.planeMaterial.visible=!0);for(var U=0,F=d.length;F>U;U+=1){var Q=d[U],L=t.modelManager.getModel(Q);if(L){var O=L._getNodeGroup(Vp.GEOMETRY,{globalSpace:!0});O.visible=u[Q][Vp.GEOMETRY],(O=L._getNodeGroup(Vp.WIREFRAME,{globalSpace:!0})).visible=u[Q][Vp.WIREFRAME],(O=L._getNodeGroup(Vp.INSTANCEGEOMETRY,{globalSpace:!0})).visible=u[Q][Vp.INSTANCEGEOMETRY],(O=L._getNodeGroup(Vp.INSTANCEWIREFRAMEGEOMETRY,{globalSpace:!0})).visible=u[Q][Vp.INSTANCEWIREFRAMEGEOMETRY]}}u=null,r.render(o,i)}if(s){r.clear(),r.autoClear=!1;for(var N=t.modelManager.getModelKeys(),P=r.clippingPlanes,G=r.tempPlanes||[],K=0;6>K;K+=1){if(G[K]){if(G[K].equals(P[K]))continue;G[K]=P[K].clone()}else G[K]=P[K].clone();for(var V=0,Y=N.length;Y>V;V+=1){var H=t.modelManager.getModel(N[V]);if(H){var j=H._getNodeGroup(Vp.GEOMETRY,{globalSpace:!0}),W=H._getNodeGroup("sectionFill_"+K);W.clear();for(var J=0,z=j.children.length;z>J;J+=1){var q=j.children[J];if(q.visible){var Z=G[K].clone().applyMatrix4(q.matrixWorld),X=q.geometry;if(X.boundingBox||X.computeBoundingBox(),X.boundingBox.intersectsPlane(Z)){var _=by.getShapeGeometryFromGeometryAndPlane(X,Z);if(_){var $=new nn(_,q.material[0]);W.add($),$.matrixWorld.copy(q.matrixWorld)}}}}}}}r.tempPlanes=G,r.autoClear=l,r.setRenderTarget(null),r.clear(),r.render(o,i)}}else xd.EnableSelectionOutline&&t.composer&&t.getSelection().length>0?t.composer.render():(r.setRenderTarget(null),r.clear(),r.render(o,i));t.onRenderListener(),t.onRenderFinishedListener(),t.cameraControl.setCameraChanging(!1),n.getBlinkEnabled()&&(t.blinkHandle=requestAnimationFrame(e)),n.disposeBufferAfterVbo()}()},lB.prototype.render=function(e){if(this.renderer){var t=this.viewer,i=t.modelManager;if(i.isEmpty())return Bu.log("model not loaded!"),void this._forceRenderOneFrame();i.checkLayerDataLoading()||(t._checkDataChanged(),t.getScene(),t.camera.updateMatrixWorld(),this.csm&&(this.csm.update(t.camera.matrixWorld),this.csm.updateFrustums()),xd.IncrementRender?this.incrementRender(e):xd.FillCavity?this.fillCavityRender2(e):this.fullRender(e))}},lB.prototype.getRenderer=function(){return this.renderer},lB.prototype.setSize=function(e,t){this.renderer.setPixelRatio(window.devicePixelRatio||1),this.renderer.setSize(e,t),this.composer&&this.composer.setSize(e,t)},lB.prototype.getRendererSize=function(){return this.renderer?this.renderer.getSize(sB):sB},lB.prototype.getPickingEffecter=function(){return xd.PickingEffect?(this.pickingEffecter||(this.pickingEffecter=new qE(this.viewer)),this.pickingEffecter):null};var cB=function(e){lu(i,e);var t=pu(i);function i(e,n){var r;ru(this,i),(r=t.call(this,e,n)).type="SkinnedMesh",r.isSkinnedMesh=!0,r.bindMode="attached",r.bindMatrix=new yt,r.bindMatrixInverse=new yt;var o=r.initBones(),a=new Ia(o);return r.bind(a,r.matrixWorld),r.normalizeSkinWeights(),r}return au(i,[{key:"initBones",value:function(){var e=[],t=null,i=null,n=null,r=null;if(this.geometry&&void 0!==this.geometry.bones){for(n=0,r=this.geometry.bones.length;r>n;n+=1)i=this.geometry.bones[n],t=new Aa,e.push(t),t.name=i.name,t.position.fromArray(i.pos),t.quaternion.fromArray(i.rotq),void 0!==i.scl&&t.scale.fromArray(i.scl);for(n=0,r=this.geometry.bones.length;r>n;n+=1)-1!==(i=this.geometry.bones[n]).parent&&null!==i.parent&&void 0!==e[i.parent]?e[i.parent].add(e[n]):this.add(e[n])}return this.updateMatrixWorld(!0),e}},{key:"bind",value: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()}},{key:"pose",value:function(){this.skeleton.pose()}},{key:"normalizeSkinWeights",value:function(){var e=null,t=null;if(this.geometry&&this.geometry.isGeometry)for(t=0;this.geometry.skinWeights.length>t;t+=1){var i=this.geometry.skinWeights[t];(e=1/i.lengthManhattan())!==1/0?i.multiplyScalar(e):i.set(1,0,0,0)}else if(this.geometry&&this.geometry.isBufferGeometry){var n=new Le,r=this.geometry.attributes.skinWeight;for(t=0;r.count>t;t+=1)n.x=r.getX(t),n.y=r.getY(t),n.z=r.getZ(t),n.w=r.getW(t),(e=1/n.lengthManhattan())!==1/0?n.multiplyScalar(e):n.set(1,0,0,0),r.setXYZW(t,n.x,n.y,n.z,n.w)}}},{key:"updateMatrixWorld",value:function(e){La.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)}},{key:"clone",value:function(){return new this.constructor(this.geometry,this.material).copy(this)}}]),i}(La),hB=function(e){$y.call(this,e),this.nodeGroupName="PickingExternalMeshGroup",this.pickingEffecter=this.manager.viewer.rendererManager.getPickingEffecter()};Object.assign(hB.prototype,$y.prototype),SA(hB,[{key:"destroy",value:function(){this.pickingEffecter=null}},{key:"_disposeGeometryByNode",value:function(e){e.traverseVisible((function(t){t!==e&&(t.isMesh||t.isLine)&&(t.material=null,t.geometry.dispose())}))}},{key:"disposePickingNodeById",value:function(e){for(var t=this.pickingNodeMap[e],i=0,n=t.length;n>i;i+=1)this._disposeGeometryByNode(t[i]),t[i]=null}},{key:"updatePickingMeshes",value:function(e,t,i){if(this.pickingNodeMap){for(var n=Object.keys(this.pickingNodeMap),r=0,o=n.length;o>r;r+=1){var a=n[r],s=this.pickingNodeMap[a],l=0,c=0;if(i[a]&&this.manager.isPickableNode({userId:a,name:a}))for(l=0,c=s.length;c>l;l+=1)s[l].visible=!0;else for(l=0,c=s.length;c>l;l+=1)s[l].visible=!1}return this.getPickingNodeGroup()}}},{key:"addNode",value:function(e,t){this.addToPickingNodeMap(e,t)}},{key:"removeNodeById",value:function(e){this.removeFromPickingNodeMap(e)}},{key:"clearNodes",value:function(){this.clearData()}},{key:"addToPickingNodeMap",value:function(e,t){for(var i=[],n=!xd.BatchMergeEnabled,r=0,o=t.length;o>r;r+=1){var a=this._createPickingNodeBy(t[r],n);if(a)if(Array.isArray(a))for(var s=0,l=a.length;l>s;s+=1)a[s].name=e,i.push(a[s]);else a.name=e,i.push(a)}this.pickingNodeMap||(this.pickingNodeMap={}),this.pickingNodeMap[e]=i,this.addToPickingNodeGroup(i)}},{key:"_createPickingNodeBy",value:function(e,t){var i=this,n={},r={};if("Object3D"===e.type||e instanceof To||e instanceof cm){var o=new To;o.copy(e,!1),e.animations&&(o.animations=e.animations),e.traverseVisible((function(o){if(o!==e){var a=null;if("Object3D"===o.type||o instanceof To||o instanceof cm||o instanceof Aa)(a=o instanceof Aa?new Aa:new To).copy(o,!1),n[o.uuid]={destination:a,source:o};else{if(!o.isMesh&&!o.isLine)return;(a=i._createPickingMeshesBy(o,t))&&(r[o.uuid]={destination:a,source:o})}a=null}}));var a=0,s=0,l=null,c=Object.keys(n);for(a=0,s=c.length;s>a;a+=1){var h=n[c[a]];h.source.parent!==e?n[l=h.source.parent.uuid].destination.add(h.destination):o.add(h.destination)}var d=Object.keys(r);for(a=0,s=d.length;s>a;a+=1){var u=r[d[a]],p=0,g=0;if(u.source.parent===e)if(Array.isArray(u.destination))for(p=0,g=u.destination.length;g>p;p+=1)o.add(u.destination[p]);else o.add(u.destination);else if(l=u.source.parent.uuid,Array.isArray(u.destination))for(p=0,g=u.destination.length;g>p;p+=1)n[l].destination.add(u.destination[p]);else n[l].destination.add(u.destination)}return o}return e.isMesh||e.isLine?i._createPickingMeshesBy(e,t):null}},{key:"_createLineMeshBy",value:function(e,t,i){var n=null,r=null,o=this.pickingEffecter;if(xd.PickingLineWidthEnabled){n=o.selectedLineMaterial;var a=new EM;e.isLineSegments?a.fromLineSegments(e):e.isLineLoop?a.fromLineLoop(e):a.fromLine(e),r=new NM(a,n),by.copyMeshProperties(r,e),r.renderOrder=1}else n=o.selectedMaterial,r=e.isLineSegments?new La(t,n):e.isLineLoop?new Oa(t,n):new Ua(t,n),by.copyMeshProperties(r,e),r.renderOrder=0;return r}},{key:"_createMeshBy",value:function(e,t,i){var n=new nn(t,this.pickingEffecter.selectedMaterial);return by.copyMeshProperties(n,e),n.renderOrder=i?1:0,n}},{key:"_createSkinnedMeshBy",value:function(e,t,i){var n=new ma(t,this.pickingEffecter.skinningSelectedMaterial);return by.copyMeshProperties(n,e),n.renderOrder=i?1:0,n.bindMatrix.copy(e.bindMatrix),n.bindMatrixInverse.copy(e.bindMatrixInverse),n.bindMode=e.bindMode,n.userData=e.userData,n.skeleton=e.skeleton,n}},{key:"_createSkinnedWireFrameBy",value:function(e,t,i){if(!t.index)return null;var n=this.pickingEffecter.skinningWireframeMaterial,r=af(t.attributes.position.array,t.index.array),o=new Ni;o.setIndex(new Mi(r,1)),o.setAttribute("position",t.getAttribute("position")),o.setAttribute("skinIndex",t.getAttribute("skinIndex")),o.setAttribute("skinWeight",t.getAttribute("skinWeight"));var a=new cB(o,n);return by.copyMeshProperties(a,e),a.bindMatrix.copy(e.bindMatrix),a.bindMatrixInverse.copy(e.bindMatrixInverse),a.bindMode=e.bindMode,a.userData=e.userData,a.skeleton=e.skeleton,a.renderOrder=i?0:1,a}},{key:"_createWireFrameBy",value:function(e,t,i){if(!t.index)return null;var n=this.pickingEffecter.wireframeMaterial,r=af(t.attributes.position.array,t.index.array),o=new Ni;o.setIndex(new Mi(r,1)),o.setAttribute("position",t.getAttribute("position"));var a=new La(o,n);return by.copyMeshProperties(a,e),a.renderOrder=i?0:1,a}},{key:"_createPickingMeshesBy",value:function(e,t){var i=by.createBufferGeometryWithPosAndSkin(e.geometry);if(!i)return null;if(e.isLineSegments)return this._createLineMeshBy(e,i,t);var n=null,r=null;return e.isSkinnedMesh?(n=this._createSkinnedMeshBy(e,i,t),r=this._createSkinnedWireFrameBy(e,i,t)):(n=this._createMeshBy(e,i,t),r=this._createWireFrameBy(e,i,t)),r?[n,r]:n}},{key:"setAccumulateTransform",value:function(e,t,i,n){if(this.pickingNodeMap&&this.pickingNodeMap[e])for(var r=this.pickingNodeMap[e],o=0,a=r.length;a>o;o+=1){var s=r[o];t&&(s.position.x+=t.x,s.position.y+=t.y,s.position.z+=t.z),i&&(s.scale.x*=i.x,s.scale.y*=i.y,s.scale.z*=i.z),n&&(s.rotation.x+=n.x,s.rotation.y+=n.y,s.rotation.z+=n.z),s.updateMatrixWorld()}}},{key:"setTransform",value:function(e,t,i,n,r){if(this.pickingNodeMap&&this.pickingNodeMap[e])for(var o=this.pickingNodeMap[e],a=0,s=o.length;s>a;a+=1){var l=o[a];r?this.manager.setTransformForClonedMesh(l,t,i,n):this.manager.setTransformForMesh(l,t,i,n)}}},{key:"rotateOnBasePoint",value:function(e,t,i,n){if(this.pickingNodeMap&&this.pickingNodeMap[e]){var r=this.pickingNodeMap[e];if(r)for(var o=0,a=r.length;a>o;o+=1){var s=r[o],l=(new Ge).setFromAxisAngle(i,n);s.quaternion.premultiply(l),s.position.sub(t),s.position.applyQuaternion(l),s.position.add(t),s.updateMatrixWorld()}}}},{key:"applyTransform",value:function(e,t,i,n){if(this.pickingNodeMap&&this.pickingNodeMap[e]){var r=this.manager.getTransformMatrix(t,i,n);this.applyTransformMatrix(e,r)}}},{key:"applyTransformMatrix",value:function(e,t){if(this.pickingNodeMap&&this.pickingNodeMap[e])for(var i=this.pickingNodeMap[e],n=0,r=i.length;r>n;n+=1)this.manager.updateMatrixWorldForMesh(i[n],t)}}]);var dB=function(e){this.viewer=e,this.viewer.modelManager.registerPlugin(this),this.meshes={},this.customSelectMaterials={},this.modelKey="ExternalComponent",this.objectIds=null,this.lastFilteredIds=null,this.firstAnimation=!0,this.animationIds={},this.animationLength=0,this.animationId=0,this.invalidObjectType=["invalidPlane"],this.floorExplosion=!1,this.boundingBoxWorld=void 0};dB.prototype.destroy=function(){this.pickingNodeGenerator&&(this.pickingNodeGenerator.destroy(),this.pickingNodeGenerator=null),this._removeNodeGroup(),this.meshes=null,this.customSelectMaterials=null,this.objectIds=null,this.lastFilteredIds=null,this._cancelAnimate(),this.firstAnimation=null,this.animationIds=null,this.invalidObjectType=null,this.viewer=null},dB.prototype.addExternalObject=function(e){if(e&&(e instanceof To||e instanceof nn)){var t=wp.createUUID();this.meshes[t]=[e];var i={name:t,userId:t,nodeId:t,state:Nd.Visible,mesh:[e],isExternalComponent:!0,matrix:e.matrixWorld.clone()},n=new He;return n.setFromObject(e),i.boundingBox=n,e.key=t,this._getNodeGroup().add(e),this._addToNodeInfoMap(i),this._cacheNodeMaterial(e),this.boundingBoxWorld?this.boundingBoxWorld.union(n):this.boundingBoxWorld=n.clone(),this.viewer.modelManager.updateSceneBoundingBox(),this._updateFilterManager(),this.objectIds=Object.keys(this.meshes),{nodeId:t}}},dB.prototype.getObjectCenterAndMatrixByNodeId=function(e){var t,i=this.getNodeInfosByUserId(e);if(i&&i.length>0){t={matrix:[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1],center:[0,0,0]};var n=i[0];if(n.matrix&&(t.matrix=n.matrix.toArray()),n.boundingBox){var r=new Ke;n.boundingBox.getCenter(r),t.center=r.toArray()}}return t},dB.prototype.addNode=function(e,t,i,n){if(this.meshes[e])Bu.error("Warning: name is already exist, please change name ");else if(-1===this.invalidObjectType.indexOf(t.type)){t instanceof Array||(t=[t]),this.meshes[e]=t,this._isPickingEffectEnabled()&&this.getPickingNodeGenerator().addNode(e,t),void 0===i&&(i=!1),n&&(this.customSelectMaterials[e]=n);for(var r=new He,o=0,a=t.length;a>o;o+=1){var s=new He;s.setFromObject(t[o]),s.isEmpty()&&s.min.x===1/0&&t[o].position&&(s.min.copy(t[o].position),s.max.copy(t[o].position)),r.union(s),t[o].box=s,t[o].originBox=s.clone();var l=new yt;l.copy(t[o].matrix).invert(),t[o].originBox.applyMatrix4(l),this._initializeAnimation(t[o],e);var c=t[o];c.key=e,this._getNodeGroup().add(c),c.updateMatrixWorld(!0),i||this._cacheNodeMaterial(c)}var h={name:e,userId:e,state:Nd.Visible,boundingBox:r,mesh:t,isExternalComponent:!0};1===t.length&&(h.matrix=t[0].matrixWorld.clone()),this._addToNodeInfoMap(h),this.boundingBoxWorld?this.boundingBoxWorld.union(r):this.boundingBoxWorld=r.clone(),this.viewer.modelManager.updateSceneBoundingBox(),this._updateFilterManager(),this.objectIds=Object.keys(this.meshes)}else Bu.error("Warning: the object is invalid")},dB.prototype.getNodeById=function(e){var t=this.meshes[e];return t&&1===t.length?t[0]:t},dB.prototype.removeNodeById=function(e){var t=this.meshes[e];if(!t)return!1;t[0].autoAnimation&&(delete this.animationIds[e],this.animationLength-=1,0===this.animationLength&&this._cancelAnimate()),delete this.meshes[e],this._isPickingEffectEnabled()&&this.getPickingNodeGenerator().removeNodeById(e),this.customSelectMaterials[e]&&delete this.customSelectMaterials[e];for(var i=this._getNodeGroup(),n=0,r=t.length;r>n;n+=1)i.remove(t[n]);return this.filteredIds&&this.filteredIds[e]&&delete this.filteredIds[e],this.lastFilteredIds&&this.lastFilteredIds[e]&&delete this.lastFilteredIds[e],this.viewer.removeFromSelection([e]),this.viewer.cancelTransformComponentByKey(e),this._removeFromNodeInfoMap(e),this._updateFilterManager(),this.objectIds=Object.keys(this.meshes),this.viewer.modelManager.updateSceneBoundingBox(),!0},dB.prototype.clearNodes=function(){this._isPickingEffectEnabled()&&this.getPickingNodeGenerator().clearNodes(),this._getNodeGroup().clear(),this._clearNodeInfoMap(),this.meshes={},this.customSelectMaterials={},this.objectIds=null,this.animationIds={},this.animationLength=0,this._cancelAnimate()},dB.prototype.getAllNodes=function(){return this.meshes},dB.prototype.isEmpty=function(){return!this._hasNode()},dB.prototype.setTransform=function(e,t,i,n,r){if(this.floorExplosion&&r)r();else{var o=this.meshes[e];if(o){for(var a=0,s=o.length;s>a;a+=1){var l=o[a];l.position.x=(t=t||l.position).x,l.position.y=t.y,l.position.z=t.z,l.scale.x=(i=i||l.scale).x,l.scale.y=i.y,l.scale.z=i.z,l.setRotationFromQuaternion(n=n||l.quaternion),l.updateMatrixWorld();var c=l.originBox.clone();l.box=c.applyMatrix4(l.matrix),l.levelName=null}this._isPickingEffectEnabled()&&this.getPickingNodeGenerator().setTransform(e,t,i,n)}}},dB.prototype.getTransform=function(e){var t=this.meshes[e];return t?{position:t[0].position,scale:t[0].scale,rotate:t[0].quaternion}:null},dB.prototype.applyTransform=function(e,t,i,n){if(this.meshes[e]){t=t||new Ke,i=i||new Ke(1,1,1),n=n||new Ge;var r=new yt;r.compose(t,n,i),this.applyTransformMatrix(e,r),this._isPickingEffectEnabled()&&this.getPickingNodeGenerator().applyTransformMatrix(e,r)}},dB.prototype.applyTransformMatrix=function(e,t){var i=this.meshes[e];if(i)for(var n=0,r=i.length;r>n;n+=1){var o=i[n];o._oriMatrix||(o._oriMatrix=o.matrix.clone()),o.matrix.multiplyMatrices(t,o._oriMatrix),o.updateMatrixWorld(!0);var a=o.originBox.clone();o.box=a.applyMatrix4(o.matrix)}},dB.prototype.applyFilter=function(){this._hasNode()&&(this._collectFilteredIds(),this._collectSelectedIds(),this._collectHoveredIds(),this._updateNodes())},dB.prototype.applySelection=function(){this._hasNode()&&(this._collectSelectedIds(),this._collectHoveredIds(),this._updateNodes())},dB.prototype.clearSelection=function(){this._hasNode()&&(this._clearSelectedIds(),this.applyHover())},dB.prototype.applyHover=function(){this._hasNode()&&(this._collectHoveredIds(),this._updateNodes())},dB.prototype.clearHover=function(){this._hasNode()&&(this._clearHoveredIds(),this._updateNodes())},dB.prototype.getNodeInfosByUserId=function(e){if(this.nodeInfoMap)return this.nodeInfoMap[e]},dB.prototype.getAllNodeInfos=function(e){e[this.modelKey]=this.nodeInfoMap||{}},dB.prototype.calculateBoundingBox=function(){if(this.nodeInfoMap){var e=new He,t=new He;for(var i in this.nodeInfoMap)for(var n=this.nodeInfoMap[i],r=0,o=n.length;o>r;r+=1){var a=n[r],s=a.mesh,l=new He;for(r=0,o=s.length;o>r;r+=1)t.makeEmpty(),t.setFromObject(s[r]),t.isEmpty()&&t.min.x===1/0&&s[r].position&&(t.min.copy(s[r].position),t.max.copy(s[r].position)),l.union(t);a.boundingBox.copy(l),e.union(a.boundingBox)}this.boundingBoxWorld?this.boundingBoxWorld.copy(e):this.boundingBoxWorld=e}},dB.prototype.recalculateComponentBoundingbox=function(e){var t=this.getNodeInfosByUserId(e);if(t)for(var i=0,n=t.length;n>i;i+=1){var r=t[i],o=r.mesh,a=new He,s=new He;for(i=0,n=o.length;n>i;i+=1)s.setFromObject(o[i]),s.isEmpty()&&s.min.x===1/0&&o[i].position&&(s.min.copy(o[i].position),s.max.copy(o[i].position)),a.union(s);r.boundingBox.copy(a)}},dB.prototype.getBoundingBoxWorld=function(){if(this.boundingBoxWorld)return this.boundingBoxWorld.clone()},dB.prototype.adjustVisibility=function(e){this._getNodeGroup().visible=e},dB.prototype.changeVisibilityOfSelectedObjects=function(e){if(this.selectedIds)for(var t=this.viewer.modelManager.filter,i=0,n=this.selectedIds.length;n>i;i+=1){var r=this.selectedIds[i],o=this.meshes[r];if(o&&t._isVisible({userId:r}))for(var a=0,s=o.length;s>a;a+=1)o[a].visible=e}},dB.prototype.changeVisibilityOfNonSelectedObjects=function(e){if(this.objectIds){var t={};if(this.selectedIds)for(var i=0,n=this.selectedIds.length;n>i;i+=1)t[this.selectedIds[i]]=!0;for(var r=this.viewer.modelManager.filter,o=0,a=this.objectIds.length;a>o;o+=1){var s=this.objectIds[o];if(!t[s]&&r._isVisible({userId:s}))for(var l=this.meshes[s],c=0,h=l.length;h>c;c+=1)l[c].visible=e}}},dB.prototype.adjustVisibilityOfObjectsWithoutOutline=function(e){if(this.objectIds)for(var t=this.viewer.modelManager.filter,i=0,n=this.objectIds.length;n>i;i+=1){var r=this.objectIds[i];if(t._isVisible({userId:r}))for(var o=this.meshes[r],a=0,s=o.length;s>a;a+=1)o[a].isSprite&&(o[a].visible=e)}},dB.prototype._addToNodeInfoMap=function(e){this.nodeInfoMap||(this.nodeInfoMap={}),this.nodeInfoMap[e.userId]||(this.nodeInfoMap[e.userId]=[]),this.nodeInfoMap[e.userId].push(e)},dB.prototype._removeFromNodeInfoMap=function(e){this.nodeInfoMap&&this.nodeInfoMap[e]&&delete this.nodeInfoMap[e]},dB.prototype._clearNodeInfoMap=function(){this.nodeInfoMap=null},dB.prototype._updateFilterManager=function(){var e=this.viewer.modelManager;e.filter.reinitFilterManager(e.getNodeInfos())},dB.prototype._canBePick=function(e){return!!e._oriMaterial},dB.prototype._getNodeGroup=function(){return this.viewer.modelManager.scene.getOrCreateGroup(Vp.EXTERNALCOMPONENTMANAGER,{pickableType:Rd.Geometry,globalSpace:!0})},dB.prototype._removeNodeGroup=function(){this.viewer.modelManager.scene.removeGroupByName(Vp.EXTERNALCOMPONENTMANAGER)},dB.prototype._cacheNodeMaterial=function(e){wp.isGroupObject(e)?e.traverse((function(e){if(wp.isMeshObject(e)&&!e._oriMaterial&&(e._oriMaterial=e.material,!e.geometry.index&&e.geometry.attributes&&e.geometry.attributes.position)){for(var t=[],i=0,n=e.geometry.attributes.position.array.length/3;n>i;i+=1)t.push(i);e.geometry.setIndex(new Ai(new Uint32Array(t),1))}})):e._oriMaterial||(e._oriMaterial=e.material)},dB.prototype._collectFilteredIds=function(){var e=this.filteredIds={},t=this.viewer.modelManager.filter,i=t._hasHiddenFileIdFilter(),n=t._hasVisibleFilter(),r=t._hasOverrideMaterialFilter(),o=t._hasTransparentFilter();if(i||n||r||o)for(var a=this.objectIds,s=Zd,l=0,c=a.length;c>l;l+=1){var h=a[l],d={userId:h};if(n&&!1===t._isVisible(d))e[h]||(e[h]={}),e[h][s.HIDDEN]=!0;else if(o&&t._isTransparent(d))e[h]||(e[h]={}),e[h][s.TRANSPARENT]=!0;else if(r&&t._hasOverrideMaterial(d)){var u=t._getOverrideMaterial(d),p=u?u.name:"";e[h]||(e[h]={}),e[h][s.OVERRIDED]=p}}},dB.prototype._collectSelectedIds=function(){var e=this.filteredIds=this.filteredIds||{},t=Zd,i=this.viewer.modelManager.sceneState.getSelection(),n={};this._clearSelectedIds();for(var r=0,o=i.length;o>r;r+=1){var a=i[r];this.canBeSelectedId(a)&&(e[a]||(e[a]={}),e[a][t.SELECTED]=!0,n[a]=!0)}this.selectedIds=Object.keys(n)},dB.prototype._clearSelectedIds=function(){if(this.filteredIds&&this.selectedIds&&this.selectedIds.length){for(var e=0,t=this.selectedIds.length;t>e;e+=1){var i=this.selectedIds[e];this.filteredIds[i]&&delete this.filteredIds[i][Zd.SELECTED]}this.selectedIds=null}},dB.prototype._collectHoveredIds=function(){var e=this.viewer.modelManager.sceneState.hoverId;if(e&&this._hasObjectId(e)){var t=this.filteredIds=this.filteredIds||{};this.hoveredId=e,t[e]||(t[e]={}),t[e][Zd.HOVER]=!0}},dB.prototype._clearHoveredIds=function(){this.filteredIds&&this.hoveredId&&this.filteredIds[this.hoveredId]&&(delete this.filteredIds[this.hoveredId][Zd.HOVER],this.hoveredId=void 0)},dB.prototype._hasObjectId=function(e){return!!this.meshes[e]},dB.prototype.isUserIdExist=function(e){return this._hasObjectId(e)},dB.prototype.canBeSelectedId=function(e){var t=this.meshes[e];return!(!t||t[0].disPickable)},dB.prototype._hasNode=function(){return!(!this.objectIds||!this.objectIds.length)},dB.prototype._traverseNodeById=function(e,t){if(this._hasObjectId(e))for(var i=this,n=this.meshes[e],r=0,o=n.length;o>r;r+=1){var a=n[r];wp.isGroupObject(a)?a.traverseVisible((function(e){wp.isMeshObject(e)&&i._canBePick(e)&&t&&t(e)})):(wp.isMeshObject(a)||a.isSprite)&&i._canBePick(a)&&t&&t(a)}},dB.prototype._resetNodeMaterial=function(){var e=this.lastFilteredIds;if(e&&e.length)for(var t=0,i=e.length;i>t;t+=1)this._updateNodeVisible(e[t],!0),this._traverseNodeById(e[t],(function(e){e.material=e._oriMaterial}))},dB.prototype._updateNodeVisible=function(e,t){if(this._hasObjectId(e))for(var i=this.meshes[e],n=0,r=i.length;r>n;n+=1)i[n].visible=t},dB.prototype._updateNodeById=function(e,t){if(this._hasObjectId(e)){var i=this.viewer.modelManager.sceneState,n=Zd,r=this.filteredIds[e];if(r)if(r[n.HIDDEN])this._updateNodeVisible(e,!1);else{var o=function(e,t){if(e._oriMaterial instanceof Array){for(var i=[],n=0,r=e._oriMaterial.length;r>n;n+=1){var o=e._oriMaterial[n];o instanceof iA?i.push(t):i.push=cA.cloneMaterialBaseOnColor(o,t)}e.material=i}else e.material=e._oriMaterial instanceof iA?t:cA.cloneMaterialBaseOnColor(e._oriMaterial,t)};if(r[n.TRANSPARENT]){var a=t._getMaterialByName("scene");this._traverseNodeById(e,(function(e){o(e,a)}))}else if(this._isPickingEffectEnabled()||!r[n.SELECTED]){if(r[n.HOVER])if(r[n.OVERRIDED]){var s=i.getHoverMaterial(t._getMaterialByName(r[n.OVERRIDED]));this._traverseNodeById(e,(function(e){o(e,s)}))}else this._traverseNodeById(e,(function(e){var t=i.getHoverMaterial(e._oriMaterial);o(e,t)}));else if(r[n.OVERRIDED]){var l=t._getMaterialByName(r[n.OVERRIDED]);this._traverseNodeById(e,(function(e){o(e,l)}))}}else{var c=i.selectionMaterial,h=this.customSelectMaterials[e];this._traverseNodeById(e,(function(e){h?e.material=h:e._oriMaterial.isMeshPhongMaterial?(e.material=i.phongSelectionMaterial,e.material.skinning=e._oriMaterial.skinning):o(e,c)}))}}}},dB.prototype._updateNodes=function(){var e=this.viewer.modelManager.filter;if(this._resetNodeMaterial(),this.filteredIds){for(var t in this.filteredIds)this._updateNodeById(t,e);this.lastFilteredIds=Object.keys(this.filteredIds)}},dB.prototype._initializeAnimation=function(e,t){if(e.autoAnimation){if("fire"===e.type){var i=xd.SceneSize,n=this.viewer.getBoundingBoxWorld().getSize(new Ke),r=Math.max(n.x,n.y,n.z);e._initializeSizetween(i/r/.01421)}this.firstAnimation&&(this._animate(),this.firstAnimation=!1),this.animationIds[t]=!0,this.animationLength+=1}},dB.prototype._animate=function(){var e=this;!function t(){for(var i in e.animationId=requestAnimationFrame(t),e.animationIds)for(var n=e.meshes[i],r=0,o=n.length;o>r;r+=1)n[r].autoAnimation&&n[r].update&&n[r].update();e.viewer.render()}()},dB.prototype._cancelAnimate=function(){this.firstAnimation=!0,cancelAnimationFrame(this.animationId),this.animationId=0},dB.prototype.isPickableNode=function(e){if(!this.canBeSelectedId(e.userId))return!1;var t=this.viewer.modelManager.filter;return!t._isHiddenFileId(e)&&!1!==t._isVisible(e)&&!(t._isTransparent(e)&&!xd.EnableSelectionByTranslucent)},dB.prototype._isPickingEffectEnabled=function(){return!1},dB.prototype.getPickingNodeGenerator=function(){return this.pickingNodeGenerator||(this.pickingNodeGenerator=new hB(this)),this.pickingNodeGenerator},dB.prototype.setCloneComponentMaterialsByKey=function(e,t,i){var n=this.meshes[e][0];if(!n)return{result:!1,message:"mesh isn`t exist",code:-1};if(!n.byClone)return{result:!1,message:"mesh isn`t qualified",code:-2};var r=0===i||Boolean(i);if(Array.isArray(t)||(t=[t]),r&&(Array.isArray(i)||(i=[i])),Array.isArray(n.material))if(r){var o,a=0,s=vu(i);try{for(s.s();!(o=s.n()).done;){var l=o.value;if(!n.material[l]||!t[a])break;n.material[l]=t[a],a+=1}}catch(e){s.e(e)}finally{s.f()}}else{var c,h=0,d=vu(t);try{for(d.s();!(c=d.n()).done;){var u=c.value;if(!n.material[h])break;n.material[h]=u,h+=1}}catch(e){d.e(e)}finally{d.f()}}else n.material=t[0]},dB.prototype.getModelManager=function(){return this.viewer.modelManager};var uB="off",pB={};function gB(){var e=(new Date).getTime(),t=Object.keys(pB);if(0!==t.length){for(var i=0,n=t;n.length>i;i++){var r=n[i],o=pB[r];if(o.isPause)o.lastTime=e;else if(e-o.lastTime>=o.interval){if(o.callback(o.param),o.times===o.runTimes+1){delete pB[r];continue}o.lastTime=e,o.runTimes+=1}}requestAnimationFrame(gB)}else uB="off"}function fB(){}fB.prototype.registerTimerListener=function(e,t,i,n){var r=(new Date).getTime();return pB[r]={callback:e,interval:t,times:i,param:n,lastTime:r,runTimes:0,isPause:!1,pauseDValue:0},"off"===uB&&(gB(),uB="on"),r},fB.prototype.removeTimerListener=function(e){delete pB[e]},fB.prototype.pause=function(e){var t=pB[e],i=(new Date).getTime();t&&(t.pauseDValue=i-t.lastTime,t.isPause=!0)},fB.prototype.continue=function(e){var t=pB[e],i=(new Date).getTime();t&&(t.lastTime=i-t.pauseDValue,t.pauseDValue=0,t.isPause=!1)};var mB=new Ke,AB=new Ge,yB=new Ke,vB=new Ke,CB=new Ke,IB=new Ke,xB=function(){this.domElement=null,this.camera=null,this.highlightManager=null,this.controller=document.getElementById("viewerController"),this.countRenderRequest=0,this.maxCountRenderRequest=1e4,this.rendering=!1,this.incrementRenderHandle=0,this.callbacks={},this.tempBox=new He,this.tempVector3=new Ke,this.enableCameraNearFar=!0,this.currentHomeView=kd.Home,this.initialView=kd.Home,this.filter=new hy,this.modelManager=new WE(this.filter,this),this.isRecalculationPlanes=!1,this.calculationPlanesBind=this.calculationPlanes.bind(this),this.addRenderFinishedListener(this.calculationPlanesBind),this.uuid="",this.transitionAnimationState=!0,this.animator=new Op,this._renderStateChanged=!1;var e=this;this._renderTimer=null,this.blinkHandle=0,this.needCheckTilesDataChange=!1,this.clock=new Pc,this.rendererManager=new lB(this),this.cameraStateWithFrustum=!1,this.checkNeedRender=function(){(e.needRender||e.modelManager.needUpdateAnimation())&&(e.needRender=xd.ContinueRender||!1,e.modelManager.updateAnimation(),e._render()),e._renderTimer=requestAnimationFrame(e.checkNeedRender)},this.checkNeedApplyFilter=function(){e.needApplyFilter&&(e.needApplyFilter=!1,e.modelManager.applyFilter(),e.render()),e._applyFilterTimer=requestAnimationFrame(e.checkNeedApplyFilter)},this.timerManager=new fB,this.clientSize=new ke};Object.assign(xB.prototype,hg.prototype),Object.assign(xB.prototype,{constructor:xB,addRenderListener:function(e){this.addEventListener("render",e)},removeRenderListener:function(e){this.removeEventListener("render",e)},onRenderListener:function(){this.dispatchEvent("render")},addRenderFinishedListener:function(e){this.addEventListener("renderFinished",e)},removeRenderFinishedListener:function(e){this.removeEventListener("renderFinished",e)},onRenderFinishedListener:function(){this.dispatchEvent("renderFinished")},removeAllListeners:function(){this.removeAllEventListener()},destroy:function(){if(this.stopRedner(),this.stopApplyFilter(),this.removeAllListeners(),this.controlManager.unregisterDomEventListeners(this.domElement),this.renderer){var e=document.getElementById(this.uuid);this.domElement.contains(this.getRenderer().domElement)&&this.domElement.removeChild(e)}this.domElement=null,this.renderSettings.canvas=null,this.renderSettings.context=null,this.renderSettings=null,this.rendererManager.destroy(),this.rendererManager=null,this.camera=null,this.defaultCamera=null,this.cameraControl.destroy(),this.cameraControl=null,this.controlManager.destroy(),this.modelManager.destroy(),this.modelManager=null,this.controlManager=null,this.tmpBox=null,this.filter=null,this.calculationPlanesBind=null,this.animator=null},init:function(e){var t=this;t.uuid=be.generateUUID(),this.domElement=e,this.resetBackgroundColor();var i={alpha:!0,preserveDrawingBuffer:!0,antialias:!0,depth:!0,maxDrawCacheNum:xd.maxDrawCacheNum,logarithmicDepthBuffer:!1,stencil:!0};xd.logarithmicDepthBuffer&&(i.logarithmicDepthBuffer=!0),xd.DisableAntialias&&(i.antialias=!1);var n=null;try{(n=document.createElement("canvas")).style.outline="none",n.getContext("webgl",i)||n.getContext("experimental-webgl",i)||(i.antialias=!1)}catch(e){return!1}by.initializeUnitInstances();var r=document.createElement("div");r.setAttribute("id",t.uuid),r.style.width="100%",r.style.height="100%",i.canvas=n,this.renderSettings=i,this.camera=this.defaultCamera=new Dp(Md.PERSPECTIVE,{width:e.offsetWidth,height:e.offsetHeight,fov:45,near:.1,far:200*xd.SceneSize}),this.camera.up=new Ke(0,0,1),this.camera.realUp=new Ke(0,0,1),this.camera.lookAt(this.camera.target),this.cameraControl=new Kg(this,this.getScene(),this.camera,e,(function(e){t.render(e)})),this.controlManager=new Im,this.controlManager.setupUserInputControl(this),this.controlManager.setControlMode(this,"pick"),this.setOrbitButton("left"),this.setReverseWheelDirection(!1),this.registerDomEventListener(Fd.ON_CONTROL_END,(function(){t.needCheckTilesDataChange=!0})),this.registerDomEventListener(Fd.ON_CONTROL_ZOOM,(function(){t.needCheckTilesDataChange=!0})),t.rendererManager.setupRenderer(t.renderSettings),r.appendChild(this.getRenderer().domElement),this.domElement.appendChild(r),this.controlManager.registerDomEventListeners(r),this.startRender(),this.startApplyFilter()},getDomElement:function(){return this.domElement?this.domElement:null},getRendererDomElement:function(){return this.getRenderer()&&this.getRenderer().domElement?this.getRenderer().domElement:null},render:function(){this.needRender=!0},startRender:function(){this._renderTimer=requestAnimationFrame(this.checkNeedRender)},stopRedner:function(){cancelAnimationFrame(this._renderTimer)},startApplyFilter:function(){this._applyFilterTimer=requestAnimationFrame(this.checkNeedApplyFilter)},stopApplyFilter:function(){cancelAnimationFrame(this._applyFilterTimer)},_render:function(e){var t=this.scene;t.dispatchEvent({type:"preUpdate",scene:t}),t.initializeFrame(),t.projectorLightCollection.preUpdate(),t.dispatchEvent({type:"preRender",scene:t}),t.executeUpdate(this.camera),this.rendererManager.render(e),t.dispatchEvent({type:"postRender",scene:t}),t.executeUpdatePostRender()},incrementRender:function(e){var t=this,i=this.camera,n=this.modelManager,r=this.getRenderer(),o=this.getScene();if(this.countRenderRequest+=1,this.countRenderRequest>this.maxCountRenderRequest&&(this.countRenderRequest=0),!this.rendering){this.rendering=!0,n.calculateCameraModelRelation(i.position),this.ar(),this.cameraControl.updateCamera(),o.updateLights(i);var a=this.controlManager.isUpdateRenderList;r.resetIncrementRender(),r.setObjectListUpdateState(a),this.incrementRenderHandle=requestAnimationFrame(function e(n,a){var s=n;return function(){r.autoClear=a,t.controlManager.cameraChange?(r.resetIncrementRender(),r.autoClear=!0,t.controlManager.cameraChange=!1):r.autoClear=a,r.render(o,i)||s!==t.countRenderRequest?(t.rendering=!1,s!==t.countRenderRequest?t.render():t.onRenderFinishedListener()):t.incrementRenderHandle=requestAnimationFrame(e(s,!1))}}(t.countRenderRequest,!0)),a&&n.prepareScene(i),this.onRenderFinishedListener(),this.cameraControl.setCameraChanging(!1)}},fullRender:function(e){var t=this,i=this.camera,n=this.modelManager,r=this.getRenderer(),o=this.getScene();this.blinkHandle>0&&cancelAnimationFrame(this.blinkHandle),function e(){t.calculateNearFar(),t.cameraControl.updateCamera(),o.updateLights(i),n.getBlinkEnabled()&&n.updateBlinkMaterial();var a=o.fillClipPlane&&o.fillClipPlane.visible,s=o.clipPlanes&&o.clipPlanes.visible&&xd.EnableBoxClippingCaps;if(xd.ClippingCaps&&(a||s)&&xd.EnableClippingCaps){if(a||s){var l=o.getFillClipPlane(),c=o.getClipPlanes(),h=t.modelManager.getModelKeys();n.prepareCapScene(),r.clear(),r.autoClear=!1,a?(l.capPlane.planeMesh.visible=!0,l.capPlane.lineMesh.visible=!0,c.boxMesh.visible=!1):(l.capPlane.planeMesh.visible=!1,l.capPlane.lineMesh.visible=!1,c.boxMesh.visible=!0),l.planeHighLightMatrial.visible=!1,c.planeHighLightMatrial.visible=!1,c.planeMaterial.visible=!1,o.overrideMaterial=o.backMaterial;for(var d={},u=0,p=h.length;p>u;u+=1){var g=h[u],f=t.modelManager.getModel(g);if(d[g]={},f){var m=f._getNodeGroup(Vp.GEOMETRY,{globalSpace:!0});d[g][Vp.GEOMETRY]=m.visible,m=f._getNodeGroup(Vp.WIREFRAME,{globalSpace:!0}),d[g][Vp.WIREFRAME]=m.visible,m=f._getNodeGroup(Vp.INSTANCEGEOMETRY,{globalSpace:!0}),d[g][Vp.INSTANCEGEOMETRY]=m.visible,m.visible=!1,m=f._getNodeGroup(Vp.INSTANCEWIREFRAMEGEOMETRY,{globalSpace:!0}),d[g][Vp.INSTANCEWIREFRAMEGEOMETRY]=m.visible,m.visible=!1}}r.render(o,i),o.overrideMaterial=o.backInstanceMaterial;for(var A=0,y=h.length;y>A;A+=1){var v=h[A],C=t.modelManager.getModel(v);if(C){var I=C._getNodeGroup(Vp.GEOMETRY,{globalSpace:!0});I.visible=!1,(I=C._getNodeGroup(Vp.WIREFRAME,{globalSpace:!0})).visible=!1,(I=C._getNodeGroup(Vp.INSTANCEGEOMETRY,{globalSpace:!0})).visible=d[v][Vp.INSTANCEGEOMETRY],(I=C._getNodeGroup(Vp.INSTANCEWIREFRAMEGEOMETRY,{globalSpace:!0})).visible=d[v][Vp.INSTANCEWIREFRAMEGEOMETRY]}}r.render(o,i),o.overrideMaterial=o.frontMaterial;for(var x=0,w=h.length;w>x;x+=1){var M=h[x],E=t.modelManager.getModel(M);if(E){var B=E._getNodeGroup(Vp.GEOMETRY,{globalSpace:!0});B.visible=d[M][Vp.GEOMETRY],(B=E._getNodeGroup(Vp.WIREFRAME,{globalSpace:!0})).visible=d[M][Vp.WIREFRAME],B=E._getNodeGroup(Vp.INSTANCEGEOMETRY,{globalSpace:!0}),d[M][Vp.INSTANCEGEOMETRY]=B.visible,B.visible=!1,B=E._getNodeGroup(Vp.INSTANCEWIREFRAMEGEOMETRY,{globalSpace:!0}),d[M][Vp.INSTANCEWIREFRAMEGEOMETRY]=B.visible,B.visible=!1}}r.render(o,i),o.overrideMaterial=o.frontInstanceMaterial;for(var S=0,b=h.length;b>S;S+=1){var k=h[S],D=t.modelManager.getModel(k);if(D){var T=D._getNodeGroup(Vp.GEOMETRY,{globalSpace:!0});T.visible=!1,(T=D._getNodeGroup(Vp.WIREFRAME,{globalSpace:!0})).visible=!1,(T=D._getNodeGroup(Vp.INSTANCEGEOMETRY,{globalSpace:!0})).visible=d[k][Vp.INSTANCEGEOMETRY],(T=D._getNodeGroup(Vp.INSTANCEWIREFRAMEGEOMETRY,{globalSpace:!0})).visible=d[k][Vp.INSTANCEWIREFRAMEGEOMETRY]}}r.render(o,i),r.render(n.capsScene,i),o.overrideMaterial=null,l.planeHighLightMatrial.visible=!0,c.planeHighLightMatrial.visible=!0,c.planeMaterial.visible=!0;for(var R=0,U=h.length;U>R;R+=1){var F=h[R],Q=t.modelManager.getModel(F);if(Q){var L=Q._getNodeGroup(Vp.GEOMETRY,{globalSpace:!0});L.visible=d[F][Vp.GEOMETRY],(L=Q._getNodeGroup(Vp.WIREFRAME,{globalSpace:!0})).visible=d[F][Vp.WIREFRAME],(L=Q._getNodeGroup(Vp.INSTANCEGEOMETRY,{globalSpace:!0})).visible=d[F][Vp.INSTANCEGEOMETRY],(L=Q._getNodeGroup(Vp.INSTANCEWIREFRAMEGEOMETRY,{globalSpace:!0})).visible=d[F][Vp.INSTANCEWIREFRAMEGEOMETRY]}}d=null,r.render(o,i)}}else xd.EnableSelectionOutline&&t.composer&&t.getSelection().length>0?t.composer.render():(r.setRenderTarget(null),r.clear(),r.render(o,i));t.onRenderListener(),t.onRenderFinishedListener(),t.cameraControl.setCameraChanging(!1),n.getBlinkEnabled()&&(t.blinkHandle=requestAnimationFrame(e)),n.disposeBufferAfterVbo()}()},resize:function(e,t){if(this.camera&&this.getRenderer()){var i=this.getDomElement();i&&(i.style.height=t+"px",i.style.width=e+"px"),this.camera.setSize(e,t),this.camera.updateProjectionMatrix(),this.rendererManager.setSize(e,t),this.dispatchEvent({type:"resize",data:{width:e,height:t}}),this.render()}},resizeByFrustum:function(e,t){this.camera&&this.getRenderer()&&(this.camera.updateProjectionMatrixByFrustum=!0,this.camera.setSizeByFrustum(e,t),this.render(),this.camera.updateProjectionMatrixByFrustum=!1)},calculateNearFar:function(){this.calculateNearFar2()},calculateNearFar2:function(){var e=this.getScene(),t=e.getBoundingBoxWorld(),i=this.getRenderer();if(this.enableCameraNearFar){var n=this.camera,r=n.position.clone().sub(e.getBoundingBoxWorld().getCenter(new Ke)).length(),o=e.getBoundingBoxWorld().getSize(new Ke),a=o.length();if(null!==t&&!t.isEmpty()){this.modelManager.hasAnimation()?o.multiplyScalar(2):o.multiplyScalar(.05),t.min.sub(o),t.max.add(o),t.applyMatrix4(n.matrixWorldInverse);var s=t.getSize(new Ke).length()/1e3,l=100;1e-4>s?l=.001:.001>s?l=.01:.01>s?l=.1:.1>s?l=1:1>s&&(l=10);var c=1,h=0;t.max.z>0&&0>t.min.z?(h=-t.min.z,c=Math.min(s/2,l/2)):(h=-t.min.z,c=Math.max(Math.min(s,l),-t.max.z)),i.shadowMap.enabled&&(h*=3,c/=3),h=Math.max(c+1,h),.1>(h=Math.min(h,r+a))-c&&(c/=2),n.setNearFar(c,h)}}},resetSelectionColor:function(e,t){this.modelManager.sceneState.setSelectionColor(e,t)},calculateMinDistance:function(e,t){if(Bu.time("计算最小距离"),e===t){var i=this.getBoundingBoxByIds([e]).getCenter(new Ke);return{start:i,end:i,minDistance:0}}function n(e,t){for(var i=0,n=0,r=0;3>r;r+=1){var o=e.min.getComponent(r),a=e.max.getComponent(r),s=t.min.getComponent(r),l=t.max.getComponent(r),c=0;o>l?c=o-l:s>a&&(c=s-a),i+=c*c;var h=Math.max(l,a)-Math.min(o,s);n+=h*h}return{minDis:Math.sqrt(i),maxDis:Math.sqrt(n)}}var r=new Ke,o=new Ke,a=new Ke;function s(e,t,i,n,r,o,a,s,l){a.fromBufferAttribute(t,i),s.fromBufferAttribute(t,n),l.fromBufferAttribute(t,r),o&&(a.applyMatrix4(o),s.applyMatrix4(o),l.applyMatrix4(o)),e.push(a),e.push(s),e.push(l)}function l(e,t,i){var n={start:null,end:null,minDistance:i},l=e.mesh,c=e.indexInfo,h=l.matrix.clone().multiply(e.matrix),d=l.geometry,u=d.attributes.position,p=c?c.indexStart:0,g=d.getIndex().array,f=c?c.indexStart+c.indexCount:g.length,m=t.mesh,A=t.indexInfo,y=m.matrix.clone().multiply(t.matrix),v=m.geometry,C=v.attributes.position,I=A?A.indexStart:0,x=v.getIndex().array,w=A?A.indexStart+A.indexCount:x.length,M=e.boundingBox,E=t.boundingBox;if(M.intersectsBox(E)){for(var B=p,S=f;S>B;B+=3){var b=[];s(b,u,g[B],g[B+1],g[B+2],h,r,o,a);var k=by.minDistanceBetweenTriToMesh(b,m,A,y);n.minDistance>k.minDistance&&(n.minDistance=k.minDistance,n.start=k.start,n.end=k.end)}return n}var D=M.getSize(new Ke),T=E.getSize(new Ke),R=M.min.x-E.max.x,U=M.min.y-E.max.y,F=M.min.z-E.max.z,Q=E.min.x-M.max.x,L=E.min.y-M.max.y,O=E.min.z-M.max.z,N=E.min.x>M.min.x?M.min.x:E.min.x,P=E.min.y>M.min.y?M.min.y:E.min.y,G=E.min.z>M.min.z?M.min.z:E.min.z,K=M.max.x>E.max.x?M.max.x:E.max.x,V=M.max.y>E.max.y?M.max.y:E.max.y,Y=M.max.z>E.max.z?M.max.z:E.max.z,H=R;switch(U>H&&(H=U),F>H&&(H=F),Q>H&&(H=Q),L>H&&(H=L),O>H&&(H=O),H){case R:N+=T.x/2,K-=D.x/2;break;case U:P+=T.y/2,V-=D.y/2;break;case F:G+=T.z/2,Y-=D.z/2;break;case Q:N+=D.x/2,K-=T.x/2;break;case L:P+=D.y/2,V-=T.y/2;break;case O:G+=D.z/2,Y-=T.z/2}for(var j=new He(new Ke(N,P,G),new Ke(K,V,Y)),W=[],J=[],z=[],q=[],Z=p,X=f;X>Z;Z+=3){var _=[];s(_,u,g[Z],g[Z+1],g[Z+2],h,new Ke,new Ke,new Ke),z.push(_);for(var $=0,ee=_.length;ee>$;$+=1)if(j.containsPoint(_[$])){W.push(_);break}}for(var te=I,ie=w;ie>te;te+=3){var ne=[];s(ne,C,x[te],x[te+1],x[te+2],y,new Ke,new Ke,new Ke),q.push(ne);for(var re=0,oe=ne.length;oe>re;re+=1)if(j.containsPoint(ne[re])){J.push(ne);break}}W.length||(W=z),J.length||(J=q);var ae=by.minDistanceBetweenTriToTri(W,J);return n.minDistance>ae.minDistance&&(n.minDistance=ae.minDistance,n.start=ae.start,n.end=ae.end),n}var c=this.modelManager.getMinDistanceObjects(e,t);if(!c)return-1;var h=[],d={start:null,end:null,minDistance:Number.POSITIVE_INFINITY};for(var u in c){if(!c[u].boundingBox){var p=this.getBoundingBoxByIds([u]);c[u].boundingBox=p}h.push(c[u])}if(1>h[0].length||1>h[1].length)return Bu.timeEnd("计算最小距离"),-1;var g=h[0],f=h[1],m=g.length,A=f.length,y=null,v=Number.POSITIVE_INFINITY;if(m>1||A>1){y={};for(var C=0;m>C;C+=1)for(var I=g[C],x=0;A>x;x+=1){var w=f[x];w.boundingBox=f.boundingBox,I.boundingBox=g.boundingBox;var M=n(I.boundingBox,w.boundingBox);v=M.maxDis>v?v:M.maxDis,y[C+"_"+x]=M}}for(var E=0;m>E;E+=1)for(var B=g[E],S=0;A>S;S+=1){if(y){var b=y[E+"_"+S].minDis;if(b>v||b>d.minDistance)continue}var k=f[S];k.boundingBox=f.boundingBox,B.boundingBox=g.boundingBox;var D=l(B,k,d.minDistance);if(d.minDistance>D.minDistance&&(d.minDistance=D.minDistance,d.start=D.start,d.end=D.end),0===d.minDistance)return Bu.timeEnd("计算最小距离"),d}return y=null,Bu.timeEnd("计算最小距离"),d},registerDomEventListeners:function(){this.domElement&&this.controlManager.registerDomEventListeners(this.domElement)},unregisterDomEventListeners:function(){this.domElement&&this.controlManager.unregisterDomEventListeners(this.domElement)},registerEventListener:function(e,t){this.modelManager.addEventListener(e,t)},unregisterEventListener:function(e,t){this.modelManager.removeEventListener(e,t)},registerCameraEventListener:function(e,t){this.cameraControl.addEventListener(e,t)},unregisterCameraEventListener:function(e,t){this.cameraControl.removeEventListener(e,t)},registerDomEventListener:function(e,t){this.controlManager.addEventListener(e,t)},unregisterDomEventListener:function(e,t){this.controlManager.removeEventListener(e,t)},load:function(e){var t=this;return this.modelManager.load(e,(function(){}),(function(e){Bu.time("Rendering: "),t.camera.dirty=!0,t.camera.dirty?t.render():(t.zoomAll(),t.goToInitialView()),Bu.timeEnd("Rendering: ")}))},loadWithType:function(){},loadTiles:function(e){var t=this;return this.modelManager.loadTiles(e,(function(){void 0===t._useBatchMerge&&(t._useBatchMerge=t.modelManager.shouldUseBatchRendering(),xd.MergeComponent=t._useBatchMerge,t._setupRenderer())}),(function(e){Bu.time("Rendering: "),t.camera.dirty=!0,t.camera.dirty?t.render():(t.zoomAll(),t.goToInitialView()),Bu.timeEnd("Rendering: ")}))},unload:function(e){var t=this.modelManager.unload(e);return t&&(xd.UserControlView||this.zoomAll(),this.render()),t},unloadAll:function(){this.modelManager.unloadAll(),this.render()},showModel:function(e){this.modelManager.showModel(e)&&this.render()},hideModel:function(e){this.modelManager.hideModel(e)&&this.render()},translateModel:function(e){var t=this._transformModelByKey(e);t&&t.switchToTranslateMode()},rotateModel:function(e){var t=this._transformModelByKey(e);t&&t.switchToRotateMode()},scaleModel:function(e){},showScene:function(e,t){e&&(e.setVisible(t),this.render())},clearAll:function(){this.getScene().clearAll()},restore:function(){this.getFilter().clear(),this.getScene().disableClipPlanes(),this.modelManager.dispatchEvent({type:Fd.ON_VIEWER_RESTORED})},getScene:function(){return this.modelManager.scene},getCapsScene:function(){return this.modelManager.capsScene},getControlManager:function(){return this.controlManager},getUserdataByUserId:function(e){var t=this.modelManager.getNodeInfosByUserId(e);return t&&t instanceof Array?t[0].userData:null},getFilter:function(){return this.filter},getCurrentControlName:function(){return this.controlManager.getCurrentControlName()},getCurrentControlMode:function(){return this.controlManager.getCurrentControlMode()},setControlMode:function(e){this.controlManager.setControlMode(this,e),this.render()},setControlDefault:function(){this.setControlMode(Vd.PICK)},getBoundingBoxWorld:function(){return this.getScene().getBoundingBoxWorld()},getBoundingBox:function(){return this.getScene().getBoundingBox()},getModel:function(e){return this.modelManager.getModel(e)},getModelManager:function(){return this.modelManager},setModelMatrix:function(e,t){var i=this.getModel(t);i&&i.setModelMatrix(e)},getModelMatrix:function(e){var t=null,i=this.getModel(e);return i&&(t=i.getModelMatrix()),t},overturnYAndZaxis:function(e){var t=this.getModel(e);t&&t.overturnYAndZaxis()},zoomIn:function(e){void 0===e&&(e=.1),0>e&&(e=0),this.cameraControl.zoom(e)},zoomOut:function(e){void 0===e&&(e=.1),e>0?e*=-1:e=0,this.cameraControl.zoom(e)},zoomAll:function(e,t,i){var n=this.getScene().getBoundingBox();this._zoomToLocalBox(n,e,t,i)},zoomToBuilding:function(e,t,i){this.zoomAll(e,t,i)},zoomToSelection:function(e,t,i){var n=this.getScene(),r=this.getBoundingBoxByIds(this.modelManager.sceneState.getSelection());r.isEmpty()&&(r=n.getBoundingBox()),!0===this.getTransitionAnimationState()?this.animator.setStandardView(kd.Keep,this,r,e):this._zoomToLocalBox(r,e,t,i)},_zoomToLocalBox:function(e,t,i,n){this.camera.zoomToBox(e,t,i,n),this.cameraControl.update(!0,!0),this.cameraControl.dirtyCamera(!0)},zoomToBox:function(e,t,i,n){var r=new He;e?(r.copy(e),r.applyMatrix4(this.getScene().getMatrixGlobal())):r.copy(this.getScene().getBoundingBox()),!0===this.getTransitionAnimationState()?this.animator.setStandardView(kd.Keep,this,r,t):this._zoomToLocalBox(r,t,i,n)},zoomToBoxByDirection:function(e,t,i,n){if(t){if(t&&e){var r=e.clone(),o=r.getCenter(new Ke).clone().add(t);r.applyMatrix4(this.getScene().getMatrixGlobal()),o.applyMatrix4(this.getScene().getMatrixGlobal());var a=o.clone().sub(r.getCenter(new Ke));a.length()>1e-4?(a.normalize(),this.camera.realUp.copy(Yt.DefaultUp),this._zoomToLocalBox(r,i,n,a)):this._zoomToLocalBox(r,i,n)}}else this.zoomToBox(e,i,n)},zoomToBoxWithOuterBox:function(e,t,i,n){if(t){if(t&&e){var r=e.clone(),o=t.getCenter(new Ke);r.applyMatrix4(this.getScene().getMatrixGlobal()),o.applyMatrix4(this.getScene().getMatrixGlobal());var a=o.clone().sub(r.getCenter(new Ke));a.length()>1e-4?(a.normalize(),this.camera.realUp.copy(Yt.DefaultUp),this.controlManager.zoomToBox(this,r,i,n,a)):this.controlManager.zoomToBox(this,r,i,n)}}else this.zoomToBox(e,i,n)},getObjectsInBox:function(e,t){var i=new He;return i.copy(e),i.applyMatrix4(this.getScene().getMatrixGlobal()),rm.getObjectsInBox(this.getScene(),i,this.modelManager,this,t)},setStandardView:function(e,t,i,n){var r=this.camera,o=this.getScene().getBoundingBox();this.transitionAnimationState?this.animator.setStandardView(e,this,o,t,i,n):(r.setStandardView(e,o),this.camera.zoomToBox(o,t),this.cameraControl.update(!0,!0),n&&n())},rotateCameraByViewCubeSide:function(e){this._viewCubeAnimator&&(this._viewCubeAnimator.cancelAnimation(),this._viewCubeAnimator=void 0);var t=this.camera,i=this.getScene().getGeometryBoundingBox(),n=new Vg,r=this;n.rotateCameraByViewCubeSide(t,i,e,(function(e,t,i,n){r.camera.position.copy(i);var o=new Ke(0,1,0);o.applyQuaternion(t),r.camera.up=o,r.camera.realUp=o.clone(),r.camera.lookAt(n),r.camera.target=n,1>e||r.camera.quaternion.copy(t),r.cameraControl.update(!0)})),this._viewCubeAnimator=n},cancelCurrentAnimationByViewCube:function(){this._viewCubeAnimator&&(this._viewCubeAnimator.cancelAnimation(),this._viewCubeAnimator=void 0)},getLineSelectRange:function(){return xd.LineSelectRange},setLineSelectRange:function(e){xd.LineSelectRange=e},_setStandardView:function(e,t){var i=this.camera,n=this.getScene().getBoundingBox();i.setStandardView(e,n),i.zoomToBox(n,t)},setStandardViewWithBox:function(e,t,i,n){if(t?t.applyMatrix4(this.getScene().getMatrixGlobal()):t=this.getScene().getBoundingBox(),this.transitionAnimationState)this.animator.setStandardView(e,this,t,i);else{var r=this.camera;r.setStandardView(e,t),r.zoomToBox(t,i,n),this.cameraControl.update(!0,!0)}},setTopView:function(e,t,i){this.setStandardViewWithBox(kd.Top,e,t,i)},setInitialView:function(e){this.initialView=e,this._setStandardView(e)},goToInitialView:function(e){this.setStandardView(this.initialView,e,null)},setHomeView:function(e){this.currentHomeView=e,this._setStandardView(e)},getHomeView:function(){return this.currentHomeView},goToHomeView:function(e){this.setStandardView(this.currentHomeView,e,null)},rotateByAxis:function(e,t,i){var n=i||this.cameraControl.calculatePivot(Ld.CENTER,null),r=2*Math.PI/60/60*e;if(t&&"x"!==t){if("y"!==t)return void Bu.warn("Illegal rotation axis for ViewerImpl.rotateByAxis().");this.cameraControl.handleRotation(0,-r,n)}else this.cameraControl.handleRotation(-r,0,n);this.cameraControl.update(!0)},lookAt:function(e,t,i){var n=new Ke;n.subVectors(t,e),this.camera.lookAtEx(t,n,i),this.cameraControl.updateCamera(t),this.render()},setImageResPath:function(e){xd.TextureResRoot=e},setLimitFrameTime:function(e){xd.IncrementRender&&(e>0||(e=30),xd.LimitFrameTime=e)},limitFrameRate:function(e){xd.IncrementRender&&(e>0||(e=4),xd.LimitFrameTime=1e3/e)},transformCamera:function(e){return Zp.transformCamera(e,this.modelManager.scene)},getCamera:function(){var e=this.getScene().getMatrixGlobal(),t=this.cameraControl.getCamera(),i=this.cameraControl.getCameraName(),n=new Hp(i,t.position,t.target,t.up);n=Dp.drawingToWorld(n,e);var r={};if(this.cameraStateWithFrustum){var o=2*(t.near*Math.tan(.5*be.DEG2RAD*t.fov)/t.zoom);r=new Hp(i,n.position,n.target,n.up,t.fov,void 0,t.aspect*o,o)}else r=new Hp(i,n.position,n.target,n.up,t.fov,void 0);return JSON.stringify(r)},setCameraStateWithFrustum:function(e){this.cameraStateWithFrustum=e},setCamera:function(e,t,i){this.camera.dirty=!0;var n=this,r=Zp.parseCameraInfo(e);if(null===r)Bu.log("Invalid camera info string. Fail to set camera.");else if(this.switchToCamera(r.name)){var o=this.getScene().getMatrixGlobal(),a=Dp.worldToDrawing(r,o);if(this.transitionAnimationState){var s={position:this.camera.position.clone(),target:this.camera.target.clone(),up:this.camera.realUp.clone()||this.camera.up.clone()};this.animator.active(s,a,this,(function(e){n.cameraControl.update(!0,!0)}),(function(){r.frustumWidth&&r.frustumHeight&&n.resizeByFrustum(r.frustumWidth,r.frustumHeight),i&&i()}))}else{var l=new Ke;l.subVectors(a.target,a.position),this.camera.lookAtEx(a.target,l,a.up),t&&this.cameraControl.updateCamera(),r.frustumWidth&&r.frustumHeight&&(n.cameraControl.update(!0,!0),n.resizeByFrustum(r.frustumWidth,r.frustumHeight)),i&&i()}}},getRenderBufferScreenShot:function(e,t,i,n){this._render();var r=this.getRenderer().domElement,o=r.toDataURL("image/png"),a=r.width,s=r.height,l=window.devicePixelRatio||1,c=t||a/l,h=i||s/l;if(!c||!h)return n?(n(o),null):o;var d,u=null,p=null,g=0,f=0;if(c>h||c/h>a/s?(u=c,f=h/2-(p=s/a*c)/2):(p=h,g=c/2-(u=a/s*h)/2),n)return(d=new Image).onload=function(){var t=document.createElement("canvas"),i=t.getContext("2d");t.width=c,t.height=h,e&&(i.fillStyle=e,i.fillRect(0,0,c,h)),i.drawImage(d,g,f,u,p);var r=t.toDataURL("image/png");n(r)},d.src=o,null;(d=new Image).src=o;var m=document.createElement("canvas"),A=m.getContext("2d");return m.width=c,m.height=h,e&&(A.fillStyle=e,A.fillRect(0,0,c,h)),A.drawImage(d,g,f,u,p),m.toDataURL("image/png")},screenShot:function(e,t,i){var n=this;return this._render(),function(){var r=n.getRenderer().domElement,o=r.toDataURL("image/png"),a=r.width,s=r.height,l=e,c=t;if(!l||!c)return i?(i(o),null):o;var h=null,d=null,u=0,p=0;if(l>c||l/c>a/s?(h=l,p=c/2-(d=s/a*l)/2):(d=c,u=l/2-(h=a/s*c)/2),i){var g=new Image;return g.onload=function(){var e=document.createElement("canvas"),t=e.getContext("2d");e.width=l,e.height=c,t.drawImage(g,u,p,h,d);var n=e.toDataURL("image/png");i(n)},g.src=o,null}}()},canvas2image:function(e,t,i,n){var r=null,o=this;return n?(this.getRenderBufferScreenShot(e,t,i,(function(e){n(e),o.render()})),null):(r=this.getRenderBufferScreenShot(e,t,i),this.render(),r)},lockAxisZ:function(e,t){var i=this.cameraControl;if(i){var n=i.getZenith(),r=this.getBoundingBox().getCenter().clone();if(e&&void 0!==t||(t=null),t){var o=t[0],a=t[1];n>a?i.handleRotation(0,a-n,r):o>n&&i.handleRotation(0,o-n,r),this.render()}this.cameraControl.lockAxisZ(e),this.cameraControl.setLockAxisZRange(t)}},isLockedAxisZ:function(){return this.cameraControl.isLockedAxisZ()},enableTranslucentByDClick:function(e){xd.EnableDemolishByDClick=e},enableHitDetection:function(e){xd.EnableHitDetection=e},enableRotate:function(e){Kp.NoRotate=!e},rotateCamera:function(e,t){this.cameraControl.processRotate(e,t),this.cameraControl.update()},getActiveCameraInfo:function(){var e={};e.up=new Ke,e.dir=new Ke;var t=this.camera,i=t.getWorldDirection(new Ke);return e.up.copy(t.realUp||t.up),e.dir.copy(i),e.quaternion=t.quaternion.clone(),e},calculationPlanes:function(){if(this.isRecalculationPlanes){this.isRecalculationPlanes=!1;var e=this.getScene(),t=this.getBoundingBoxByIds();t.isEmpty()&&(t=e.getBoundingBox()),e.getClipPlanes().calculationPlanes(t.getSize(new Ke),t.getCenter(new Ke)),this.render()}},recalculationPlanes:function(){this.isRecalculationPlanes=!0},setOctantDepth:function(e){xd.OctantDepth=e},resizePool:function(e){xd.maxObjectNumInPool=e,this.modelManager.updateSceneRenderable(),this.render()},setCategoriesToHighPriority:function(e,t){this.modelManager.setCategoriesToHighPriority(e,0===t?"inner":"outer")},clearCategoriesFromHighPriority:function(e){this.modelManager.clearCategoriesFromHighPriority(0===e?"inner":"outer")},clearAllCategoriesFromHighPriority:function(){this.modelManager.clearAllCategoriesFromHighPriority()},isolate:function(e,t){var i=this.getFilter();switch(t){case"hide":i.setIsolateConditions(e,Pd.HIDDEN_OTHERS);break;case"translucent":i.setIsolateConditions(e,Pd.TRANSLUCENT_OTHERS);break;default:Bu.warn("no this isolate state : "+t)}},setIsolateMaterial:function(e){this.getFilter().setIsolateMaterial(e)},resetIsolateMaterial:function(){this.getFilter().resetIsolateMaterial()},setOrbitButton:function(e){var t=this.controlManager._getControlByName(this,Vd.ORBIT),i=this.controlManager._getControlByName(this,Vd.PICK),r={};"left"===e?r={ORBIT:n.LEFT,PAN2:n.MIDDLE,PAN:n.RIGHT}:"right"===e&&(r={ORBIT:n.RIGHT,PAN2:n.MIDDLE,PAN:n.LEFT}),t&&t.updateButtons(r),i&&i.updateButtons(r)},showPickedInformation:function(e){},setOrbitEnabled:function(e){Kp.NoRotate=!0!==e},getOrbitEnabled:function(){return!Kp.NoRotate},setSelectPadCallback:function(e){var t=this.controlManager.getCurrentControlMode();t&&t.selectPad&&(t.selectPad.callback=e)},setDeviceMobile:function(e){xd.IsMobile=e||!1},setPointRotateMode:function(e){Kp.RotatePivotMode=e},worldToDrawing:function(e){if(!this.cameraControl)return Bu.warn("camera is not initialized!!!"),null;var t=this.getScene().worldToDrawing(e);return{x:t.x,y:t.y,z:t.z}},drawingToWorld:function(e){if(!this.cameraControl)return Bu.warn("camera is not initialized!!!"),null;var t=this.getScene().drawingToWorld(e);return{x:t.x,y:t.y,z:t.z}},worldToCanvas:function(e){var t=this.cameraControl;if(!t)return Bu.warn("camera is not initialized!!!"),null;var i=t.getContainerDimensions();if(!i)return null;var n=t.getCamera(),r=this.getScene().worldToDrawing(e);return Zp.drawingToCanvas(n,r,i.width,i.height)},canvasToWorld:function(e){var t=this.cameraControl;if(!t)return Bu.warn("camera is not initialized!!!"),null;var i=t.getContainerDimensions();if(!i)return null;var n=t.getCamera(),r=this.getScene(),o=Zp.canvasToDrawing(n,e,i.width,i.height),a=r.drawingToWorld(o);return{x:a.x,y:a.y,z:a.z}},worldToClient:function(e){var t=this.cameraControl;if(!t)return Bu.warn("camera is not initialized!!!"),null;var i=t.getContainerDimensions();if(!i)return null;var n=t.getCamera(),r=this.getScene().worldToDrawing(e),o=Zp.drawingToCanvas(n,r,i.width,i.height);return o?(o.x+=i.left,o.y+=i.top,o):null},worldPointsToClient:function(e,t){var i=this.cameraControl;if(!i)return Bu.warn("camera is not initialized!!!"),null;var n=i.getContainerDimensions();if(!n)return null;var r=i.getCamera(),o=this.getScene(),a=o.worldToDrawing(e),s=o.worldToDrawing(t),l=Zp.drawingPointsToCanvas(r,a,s,n.width,n.height);return l?(l.start.x+=n.left,l.start.y+=n.top,l.end.x+=n.left,l.end.y+=n.top,l):null},clientToWorld:function(e){var t=this.cameraControl;if(!t)return Bu.warn("camera is not initialized!!!"),null;var i=t.getContainerDimensions();if(!i)return null;(o={x:e.x,y:e.y,z:e.z}).x-=i.left,o.y-=i.top;var n=t.getCamera(),r=this.getScene(),o=Zp.canvasToDrawing(n,o,i.width,i.height),a=r.drawingToWorld(o);return{x:a.x,y:a.y,z:a.z}},insideCamera:function(e){var t=this.cameraControl;if(!t)return Bu.warn("camera is not initialized!!!"),!1;var i=this.getScene().worldToDrawing(e);return t.getFrustum().containsPoint(i)},locateToPointWithParallelEye:function(e){var t=this.cameraControl;if(!t)return Bu.warn("camera is not initialized!!!"),!1;var i=this.getScene().worldToDrawing(e);t.flyToPointWithParallelEye(i)},locateToPoint:function(e){var t=this.cameraControl;if(!t)return Bu.warn("camera is not initialized!!!"),!1;var i=this.getScene().worldToDrawing(e);t.flyToPoint(i)},enableHover:function(e){xd.Hover=e},getObjectsByClientCoordinates:function(e){return new tg(this).getObjectsByClientCoordinates(e)},getIBLManager:function(){return this.IBLManager},loadEnvMap:function(e){for(var t=["posx.hdr","negx.hdr","posy.hdr","negy.hdr","posz.hdr","negz.hdr"],i=[],n=0;6>n;n+=1)i.push("/"+e+"/"+t[n]);var r=this;(new(void 0)).load(B,i,(function(e){r.environmentCubeMap=e,r.modelManager.updateMaterialsValue("envMap",e),r.render()}))},setEnvMapIntensity:function(e){this.modelManager.updateMaterialsValue("envMapIntensity",e),this.setRenderStateChanged(!0),this.render()},closeEnvMap:function(){this.modelManager.updateMaterialsValue("envMap",null),this.render()},enableSSAO:function(e){return!xd.IncrementRender&&(xd.EnableRenderPass=e,xd.SSAO=e,this.setRenderStateChanged(!0),this.render(),!0)},switchNewStyleMaterial:function(e){this.modelManager.switchNewStyleMaterial(e),this.setRenderStateChanged(!0),this.render()},enableColorWithoutLight:function(e){this.modelManager.enableColorWithoutLight(e),this.setRenderStateChanged(!0),this.render()},addPlane:function(e,t,i,n){var r=new Ke;r.addVectors(new Ke(e.x,e.y,e.z),new Ke(t.x,t.y,t.z)),r.multiplyScalar(.5);var o=new In(t.x-e.x,t.y-e.y),a=new nn(o,new gi({side:2,transparent:!0,depthTest:!0}));a.position.copy(r),a.renderOrder=10,this.getScene().getOrCreateGroup(Vp.CUSTOMPLANE,{globalSpace:!0}).add(a),a.updateMatrixWorld(!0);var s=this;return(new Dl).load(i,(function(e){a.material.map=e,a.material.needsUpdate=!0,s.setRenderStateChanged(!0),n&&n()})),a},removePlane:function(e){var t=this.getScene().getGroup(Vp.CUSTOMPLANE);t&&t.remove(e)},clearPlane:function(){var e=this.getScene().getGroup(Vp.CUSTOMPLANE);e&&e.clear()},enableTextureMapping:function(e){xd.EnableTextureMapping=e},enableLightmap:function(e){xd.EnableLightmap!==e&&(xd.EnableLightmap=e)},setLightmapIntensity:function(e){xd.LightmapIntensity!==e&&(xd.LightmapIntensity=e)},setReverseWheelDirection:function(e){Kp.ReverseWheelDirection=Boolean(e)},getReverseWheelDirection:function(){return Kp.ReverseWheelDirection},setMovementSpeedRate:function(e){void 0!==e&&(Kp.MovementSpeedRate=e)},getMovementSpeedRate:function(){return Kp.MovementSpeedRate},moveTo:function(e,t,i){var n=this.controlManager.control;n&&n.moveTo(e,t,i)},rotateTo:function(e){var t=this.controlManager.control;t&&t.rotateTo(e)},enableOcclusionTranslucent:function(e){xd.OcclusionTranslucentEnabled=Boolean(e)},setOcclusionOpacity:function(e){xd.OcclusionOpacity=e},setOcclusionDistanceToCamera:function(e){xd.OcclusionDistanceToCamera=e},fitAndRotateBySelection:function(){this.cameraControl&&this.cameraControl.fitAndRotateBySelection()},setRoamingWalkHeight:function(e,t,i){if(Array.isArray(e)){var n=this.cameraControl;if(!n)return Bu.log("camera is not initialized!!!"),!1;if(t>0||(t=1750),void 0===i&&(i=!0),n.setCameraHeight(e,t),i){var r=this.controlManager.getCurrentControl();r&&r.name===Vd.WALK&&r.update&&n.flyOnWorld()}}else Bu.log("elevations is not arry")},setRoamingWalkAbsoluteHeight:function(e,t){var i=this.cameraControl;if(!i)return Bu.log("camera is not initialized!!!"),!1;if(void 0===t&&(t=!0),i.setCameraAbsoluteHeight(e),t){var n=this.controlManager.getCurrentControl();n&&n.name===Vd.WALK&&n.update&&i.flyOnWorld()}},cameraToWorld:function(e){return this.camera?Dp.drawingToWorld(e,this.getScene().getMatrixGlobal()):null},cameraToDrawing:function(e){return this.camera?Dp.worldToDrawing(e,this.getScene().getMatrixGlobal()):null},clearSelection:function(){this.modelManager.sceneState.clearSelection()},clearModelSelection:function(){this.modelManager.modelState.clearModelSelection()},addToSelection:function(e){this.modelManager.sceneState.addSelection(e)},addToModelSelection:function(e){this.modelManager.modelState.addModelSelection(e)},removeFromSelection:function(e){this.modelManager.sceneState.removeSelection(e)},removeFromModelSelection:function(e){this.modelManager.modelState.removeModelSelection(e)},setSelection:function(e){this.modelManager.sceneState.setSelection(e)},setModelSelection:function(e){this.modelManager.modelState.setModelSelection(e)},getSelection:function(){return this.modelManager.sceneState.getSelection()},getModelSelection:function(){return this.modelManager.modelState.getModelSelection()},setSelectionColor:function(e,t){var i=e,n=t;e instanceof Du&&(i=e.getHex(),n=e.getAlpha()),this.modelManager.sceneState.setSelectionColor(i,n);var r=this.rendererManager.getPickingEffecter();r&&r.setSelectionColor(i,n)},getSelectionColor:function(){return this.modelManager.sceneState.getSelectionColor()},restoreSelectionColor:function(){this.setSelectionColor(new Du(xd.SelectionColor.color,xd.SelectionColor.opacity))},setModelSelectionColor:function(e,t){this.modelManager.modelState.setSelectionColor(e,t)},pickByPoint:function(e){var t=this.cameraControl;if(!1===t.enabled)return!1;var i=new ke(e.x,e.y),n=t.getIntersectContext(i),r=t.intersector.pick(n),o=this.getScene();if(r){o.intersectToWorld(r,this);var a={};return a.faceIndex=r.faceIndex,a.componentKey=r.userId,a.worldPosition=r.worldPosition,a.worldBoundingBox=r.worldBoundingBox,a}return null},pickByPointWithNormal:function(e){var t=this.getScene(),i=this.cameraControl;if(!1===i.enabled)return null;var n=new ke(e.x,e.y),r=i.getIntersectContext(n),o=i.intersector.pick(r);if(!o)return null;t.intersectToWorld(o,this),o.cx=n.x,o.cy=n.y;var a=[];a.push(o);var s=t.getMatrixGlobal(),l=o.face.normal.clone(),c=o.worldPosition.clone(),h=new At(c,l);h.applyMatrix4(s);var d=i.intersector.getIntersectByRay(r,h);return d&&(t.intersectToWorld(d,this),a.push(d)),a},toDefaultOrthographicCamera:function(e){this.switchToCamera(Md.ORTHOGRAPHIC),(e||void 0===e)&&this.render()},toDefaultPerspectiveCamera:function(e){this.switchToCamera(Md.PERSPECTIVE),(e||void 0===e)&&this.render()},getCameraNameList:function(){return["pesp","orth"].concat(this.modelManager.getCameraNameList())},switchToCamera:function(e){var t=!0;if(e===Md.PERSPECTIVE)this.camera=this.defaultCamera,this.camera.toPerspective();else if(e===Md.ORTHOGRAPHIC)this.camera=this.defaultCamera,this.camera.toOrthographic();else{var i=this.modelManager.getCamera(e);i?this.camera=i:(Bu.log("Fail to switch because not found camera '"+e+"'"),t=!1)}return t&&this.cameraControl.setCamera(this.camera),this.render(),t},getNumOfElements:function(){return this.modelManager.getNumOfElements()},getNumOfRenderables:function(){return this.modelManager.getNumOfRenderables()},getNumOfTriangles:function(){return this.modelManager.getNumOfTriangles()},setLightPreset:function(e){this.getScene().setLightPreset(e),this.setRenderStateChanged(!0)},getLightPreset:function(){return this.getScene().getLightPreset()},setLightIntensityFactor:function(e){this.getScene().setLightIntensityFactor(e),this.render()},setAmbientLightIntensity:function(e){this.getScene().setAmbientLightIntensity(e),this.render()},getAmbientLightIntensity:function(){return this.getScene().getAmbientLightIntensity()},setWalkHeightLocked:function(e){var t=this.controlManager.getCurrentControl();t&&t.name===Vd.WALK&&t.setHeightLocked(e)},setWalkLookMousePressed:function(e){var t=this.controlManager.getCurrentControl();t&&t.name===Vd.WALK&&t.setDragLook(e)},setWalkSpeedRate:function(e){var t=this.controlManager.getCurrentControl();t&&t.name===Vd.WALK&&(Kp.MovementSpeedRate=e)},getWalkSpeedRate:function(){return Kp.WalkSpeedRate},setDrawingStyle:function(e){xd.DrawingStyle=e,this.modelManager.applyFilter(),this.setRenderStateChanged(!0)},getWireframeColor:function(e){var t=this.modelManager;if(e&&t.models[e])return t.models[e].wireframeManager.getWireframeColor();for(var i in t.models){return t.models[i].wireframeManager.getWireframeColor()}},setWireframeColor:function(e,t){var i=this.modelManager;if(t&&i.models[t])i.models[t].wireframeManager.setWireframeColor(new pi(e),e.a||1);else for(var n in i.models)i.models[n].wireframeManager.setWireframeColor(new pi(e),e.a||1);this.setRenderStateChanged(!0)},restoreWireframeColor:function(e){var t=this.modelManager;if(e&&t.models[e])t.models[e].wireframeManager.restoreWireframeColor();else for(var i in t.models)t.models[i].wireframeManager.restoreWireframeColor();this.setRenderStateChanged(!0)},setInstanceMode:function(e){!xd.Instance===e&&(xd.Instance=e,this.getScene().getOrCreateGroup(Vp.INSTANCEGEOMETRY,{globalSpace:!0}).visible=!!e)},setTransitionAnimationState:function(e){this.transitionAnimationState=e},getTransitionAnimationState:function(){return this.transitionAnimationState},clipPoint:function(e){var t=this.getRenderer().clippingPlanes;if(t&&t.length>0)for(var i=0;t.length>i;i+=1){var n=t[i];if(e.dot(n.normal)<-n.constant)return!0}return!1},setExposureShift:function(e){xd.ToneMapping=1,this.modelManager.updateMaterialsValue("shift",e>0?-.4*e+.5:-4*e+.5),this.setRenderStateChanged(!0)},setRenderStateChanged:function(e){this.modelManager&&this.modelManager.setRenderStateChanged(e)},isRenderStateChanged:function(){return this.modelManager._renderStateChanged},getComponentInfoByUserId:function(e){return this.modelManager.getComponentInfoByUserId(e)},getBoundingBoxByIds:function(e){var t=new He;if(Array.isArray(e)){for(var i=0;e.length>i;i+=1)if(!this.modelManager.isHiddenUserId(e[i])){var n=this.getModelByComponentKey(e[i]),r=this.getComponentInfoByUserId(e[i]);if(r)if(n){var o=r.boundingBox.clone().applyMatrix4(n.getModelMatrix());t.union(o)}else t.union(r.boundingBox)}}else for(var a in e)if(!this.modelManager.isHiddenUserId(a)){var s=this.getModelByComponentKey(a),l=this.getComponentInfoByUserId(a);if(l)if(s){var c=l.boundingBox.clone().applyMatrix4(s.getModelMatrix());t.union(c)}else t.union(l.boundingBox)}return t.isEmpty()||t.applyMatrix4(this.getScene().getMatrixGlobal()),t},setConditionsOnDemandLoad:function(e,t,i,n){t=t||!0,this.modelManager.setConditionsOnDemandLoad(e),t&&this.modelManager.loadGeopkOnDemand(i,n)},loadGeopkOnDemand:function(e,t,i,n){var r=this;this.modelManager.loadGeopkOnDemand(e,t,i,(function(){var e=r.modelManager.getNodeInfos();r.filter.reinitFilterManager(e),r.setRenderStateChanged(!0),r.render(),n&&n()}))},unloadGeopkOnDemand:function(e,t){var i=this;this.filter._hasVisibleFilter()&&(this.filter.showByIds(e),this.filter.removeFromIsolateList(e)),this.filter._hasOverrideMaterialFilter()&&(this.filter.addToOverrideListByColor(e,null),this.filter.addToWireframeByWireframe(e,null)),this.filter._hasTransparentFilter()&&this.filter.opaqueByIds(e),this.removeFromSelection(e);for(var n=0,r=e.length;r>n;n+=1);this.modelManager.unloadGeopkOnDemand(e,(function(){var e=i.modelManager.getNodeInfos();i.filter.reinitFilterManager(e),i.setRenderStateChanged(!0),i.render(),t&&t()}))},getBoundingBoxOnDemand:function(){return this.modelManager.getBoundingBoxOnDemand()},getScreenCoordFromSceneCoord:function(e){var t=[];if(e.isVector3){var i=e.clone();i.applyMatrix4(this.camera.matrixWorldInverse);var n=i.z>0;return i.applyMatrix4(this.camera.projectionMatrix),t[0]=(i.x+1)*this.domElement.clientWidth/2,t[1]=(1-i.y)*this.domElement.clientHeight/2,t[2]=n?1:0,t}if(Array.isArray(e)){var r=new Ke(e[0],e[1],e[2]);r.applyMatrix4(this.camera.matrixWorldInverse);n=r.z>0;return r.applyMatrix4(this.camera.projectionMatrix),t[0]=(r.x+1)*this.domElement.clientWidth/2,t[1]=(1-r.y)*this.domElement.clientHeight/2,t[2]=n?1:0,r=null,t}},_checkDataChanged:function(){var e=this.modelManager;e.hasModelDataReady()&&(this.getFilter().isStateChanged()||this.isRenderStateChanged())&&(this.isRenderStateChanged()&&this.setRenderStateChanged(!1),this.getFilter().isStateChanged()&&this.getFilter().disableStateChanged(),this.needApplyFilter=!0),this.needCheckTilesDataChange&&(this.needCheckTilesDataChange=!1,e.checkTilesDataChanged(this.camera,this.getRenderer()))},_checkLayerDataLoading:function(){return!(!this.modelManager.isLayerData()||!this._layerDataLoading)&&(this.getFilter().isStateChanged()&&this.getFilter().disableStateChanged(),!0)},setOutlineEdgeColor:function(e){this.rendererManager.composer&&this.rendererManager.composer.setOutlineEdgeColor(e);var t=this.rendererManager.getPickingEffecter();t&&t.setLineSelectionColor(e.getHex(),e.opacity)},getOutlineEdgeColor:function(){if(this.rendererManager.composer)return this.rendererManager.composer.getOutlineEdgeColor();var e=this.rendererManager.getPickingEffecter();return e?e.getLineSelectionColor():void 0},restoreOutlineEdgeColor:function(e){this.setOutlineEdgeColor(new Du(xd.SelectionColor.color,xd.SelectionColor.opacity))},enableSelectedColorIsAffectedByLight:function(e){xd.InfluencedByLight=e,xd.InfluencedByLight?delete this.modelManager.getSceneState().selectionMaterial.defines.NOTAFFECTEDBYLIGHT:this.modelManager.getSceneState().selectionMaterial.defines.NOTAFFECTEDBYLIGHT=""},enableLogarithmicDepthBuffer:function(e){xd.logarithmicDepthBuffer!==e&&(xd.logarithmicDepthBuffer=e,this.renderSettings.logarithmicDepthBuffer=e,this.rendererManager.resetupRenderer(this.renderSettings||{}),this._render(),this.updateShadowLight())},enableBlinkComponents:function(e){this.modelManager.isBlinkPermited()||(this.modelManager.enableBlink(e),this.render())},setBlinkComponentsById:function(e){this.modelManager.isBlinkPermited()||this.modelManager.sceneState.setBlinkComponentsById(e)},addBlinkComponentsById:function(e){this.modelManager.isBlinkPermited()||this.modelManager.sceneState.addBlinkComponentsById(e)},clearBlinkComponentsById:function(e){this.modelManager.isBlinkPermited()||this.modelManager.sceneState.clearBlinkComponentsById(e)},clearAllBlinkComponents:function(){this.modelManager.isBlinkPermited()||this.modelManager.sceneState.clearAllBlinkComponents()},getBlinkComponents:function(){return this.modelManager.isBlinkPermited()?null:this.modelManager.sceneState.getBlinkComponents()},setBlinkColor:function(e){this.modelManager.isBlinkPermited()||this.modelManager.setBlinkColor(e.color,e.opacity)},setBlinkIntervalTime:function(e){this.modelManager.isBlinkPermited()||this.modelManager.setBlinkIntervalTime(e)},getModelByComponentKey:function(e){var t=null;for(var i in this.modelManager.models)if(this.modelManager.models.hasOwnProperty(i)&&(t=this.modelManager.getModel(i))&&t.isLoaded()&&t.hasComponent(e))return t},getSceneState:function(){return{state:this.getFilter().saveState(),camera:this.getCamera(),selection:this.getSelection(),modelSelection:this.getModelSelection()}},setSceneState:function(e){void 0!==e.camera&&"object"!==nu(e.camera)||(e.camera=JSON.stringify(e.camera)),this.clearSelection(),this.clearModelSelection(),this.setCamera(e.camera,!1),this.setSelection(e.selection),this.setModelSelection(e.modelSelection),this.getFilter().loadState(e.state)},setComponentPositionByKey:function(e,t){var i=(new Ke).fromArray(t);this.getModelManager(),new yt;var n=this.modelManager.getComponent(e);if(n&&n.length>=1){for(var r=new He,o=0,a=n.length;a>o;o+=1){r&&r.union(n[o].boundingBox)}r.getCenter(vB);var s=this.getModelByComponentKey(e);if(s){var l=s.getModelMatrix();if(l){var c=new yt;c.copy(l).invert(),i.applyMatrix4(c)}}i.sub(vB);var h=(new yt).makeTranslation(i.x,i.y,i.z);this.componentApplyMatrix2(e,h,!0),this.updateTransformControlIfBindingComKeyEqual(e)}},setBackgroundColor:function(e,t){if(t)this.setBackgroundColors([{color:e,stop:"0%"},{color:t,stop:"100%"}],"180deg");else{var i=this.getDomElement();i&&(i.style.background=e.getRGBA())}},setBackgroundColors:function(e,t){var i=this.getDomElement(),n=t||"0deg",r=[];if(e&&e.length>0){1===e.length&&this.setBackgroundColor(e[0].color||e[0]);for(var o=0;e.length>o;o+=1){var a=e[o].color.getRGBA()+" "+e[o].stop;r.push(a)}var s=n+", "+r.join(",");i&&(i.style.background="linear-gradient("+s+")")}},resetBackgroundColor:function(){this.getDomElement()&&(this.domElement.style.background="linear-gradient(180deg, #CDEEFF 30%, #F5F5F5 100%)")},getComponentLocalMatrixByKey:function(e){if(e){var t=this.modelManager.getComponent(e);if(t&&t.length>0&&t[0].matrix)return t[0].matrix.clone()}},getComponentWorldMatrixByKey:function(e){var t=this.getComponentLocalMatrixByKey(e);if(t){var i=this.getModelByComponentKey(e);if(i){var n=i.getModelMatrix();t.premultiply(n)}return t}},setComponentLocalMatrixByKey:function(e,t){if(e){var i=this.modelManager.getComponent(e);if(i&&i.length>0){var n=i[0].mesh;return n.matrix.fromArray(t),n.updateMatrixWorld(!0),this.render(),!0}}return!1},_transformComponentByKey:function(e,t,i){var n=this;if(e){var r=this.controlManager.getToolByName(Yd.COMPONENT_TRANSFORM);if(r&&r.bindingComponentKey===e)return r;var o=this.getModelByComponentKey(e),a=function(e){n.render()},s=function(i){var r=n.adsorbControl;if("string"==typeof e&&i.matrix&&i.object){if(n.componentApplyMatrix2(e,i.matrix,!1),jg(o)&&r.enabled&&jg(r.selectObjectBoxHelper)){var a=r.selectObjectBoxHelper.position;n.setComponentPositionByKey(e,[a.x,a.y,a.z])}n.getScene().expandBoundingBoxWorldBy(i.object)}e instanceof Jg&&jg(i.matrix)&&jg(i.object)&&(i.matrix.decompose(mB,AB,yB),"rotate"===i.mode&&(e.quaternion.multiply(AB),i.rotateSpace===zg.LOCAL&&(e.boundingBox.getCenter(vB),e.computeBoundingBox(),(CB=e.boundingBox.getCenter(CB)).sub(e.position),e.position.copy(e.originPs),e.position.sub(CB),e.computeBoundingBox(),(IB=e.boundingBox.getCenter(IB)).sub(vB),e.position.sub(IB)),e.updateMatrixWorld(!0)),"translate"===i.mode&&(e.position.add(mB),e.originPs.copy(e.position)),"scale"===i.mode&&e.scale.multiply(yB),e.updateMatrixWorld(!0)),t&&t(e)};if("string"!=typeof e){if(e instanceof Yt){var l=e;return this.controlManager.enableTool(this,Yd.COMPONENT_TRANSFORM),r=this.controlManager.getToolByName(Yd.COMPONENT_TRANSFORM),jg(e.computeBoundingBox)&&e.computeBoundingBox(),r.transformObject.position.copy(e.boundingBox.getCenter(new Ke(0,0,0))),r.transformObject.updateMatrixWorld(!0),r.transformComponent(l,a,s),r.bindingComponentKey=void 0,r}return}var c=this.modelManager.getComponent(e);if(c&&c.length>0){var h=n.externalComponentManager;h&&h.getNodeInfosByUserId(e)&&h.recalculateComponentBoundingbox(e);for(var d=new He,u=0,p=c.length;p>u;u+=1)d.union(c[u].transformationOriginalBoundingBox?c[u].transformationOriginalBoundingBox:c[u].boundingBox);var g=new nn(by.getGeometryFromBox3(d));if(g.matrixAutoUpdate=!1,c[0].transformation&&g.matrix.copy(c[0].applyMatrix),o){var f=o.getModelMatrix();if(f){var m=new To;m.matrixAutoUpdate=!1,m.matrix.copy(f),m.updateMatrixWorld(!0),m.add(g)}}return g.updateMatrixWorld(!0),this.controlManager.enableTool(this,Yd.COMPONENT_TRANSFORM),(r=this.controlManager.getToolByName(Yd.COMPONENT_TRANSFORM)).transformComponent(g,a,s,void 0,(function(t){if(o)o.calculateBoundingBox();else{var r=n.externalComponentManager;r&&r.getNodeInfosByUserId(e)&&r.calculateBoundingBox()}n.modelManager.updateSceneBoundingBox(),i&&i(e)})),r.bindingComponentKey=e,this.modelManager.updateTransformComponentList(e),r}}},_transformModelByKey:function(e){if(e&&"string"==typeof e){var t=this.getModel(e);if(t&&t.isLoaded()&&t.isVisible()){var i=this,n=t.getBoundingBoxWorld();if(n.isEmpty())return;var r=new nn(by.getGeometryFromBox3(n));r.matrixAutoUpdate=!1,r.updateMatrixWorld(!0),this.controlManager.enableTool(this,Yd.COMPONENT_TRANSFORM);var o=this.controlManager.getToolByName(Yd.COMPONENT_TRANSFORM);return o.transformComponent(r,(function(e){i.render()}),(function(e){e&&e.matrix&&t.applyModelMatrix(e.matrix)})),o}}},translateComponentByKey:function(e,t,i){var n=this._transformComponentByKey(e,t,i);n&&(this.controlManager._componentTransformTool=n,n.switchToTranslateMode())},scaleComponentByKey:function(e,t,i){var n=this._transformComponentByKey(e,t,i);n&&n.switchToScaleMode()},rotateComponentByKey:function(e,t,i){var n=this._transformComponentByKey(e,t,i);n&&n.switchToRotateMode()},cancelTransformComponent:function(e){var t=this.controlManager.getToolByName(Yd.COMPONENT_TRANSFORM);t&&(e&&this.restoreComponentTransform(),t.cancelTransformComponent(),this.controlManager.disableTool(t.name))},cancelTransformComponentByKey:function(e){if(e&&"string"==typeof e){var t=this.controlManager.getToolByName(Yd.COMPONENT_TRANSFORM);t&&t.bindingComponentKey===e&&(t.cancelTransformComponent(),this.controlManager.disableTool(t.name))}},restoreComponentTransform:function(){var e=this.controlManager.getToolByName(Yd.COMPONENT_TRANSFORM);e&&(e.bindingComponentKey?this.restoreComponentTransformByKey(e.bindingComponentKey):e.restoreComponentOriginalTransformState()&&this.render())},restoreComponentTransformByKey:function(e){e&&"string"==typeof e&&(this.resetComponentMatrix(e),this.updateTransformControlIfBindingComKeyEqual(e))},updateTransformControlIfBindingComKeyEqual:function(e){var t=this.controlManager.getToolByName(Yd.COMPONENT_TRANSFORM);t&&t.bindingComponentKey===e&&(t.cancelTransformComponent(),this._transformComponentByKey(e))},increaseComponentTransformControlSize:function(){var e=this.controlManager.getToolByName(Yd.COMPONENT_TRANSFORM);e&&e.increaseTransformControlSize()&&this.render()},decreaseComponentTransformControlSize:function(){var e=this.controlManager.getToolByName(Yd.COMPONENT_TRANSFORM);e&&e.decreaseTransformControlSize()&&this.render()},setComponentTransformControlSize:function(e){var t=this.controlManager.getToolByName(Yd.COMPONENT_TRANSFORM);t&&"number"==typeof e&&e>0&&(t.setComponentTransformControlSize(e),t.update(),this.render())},getComponentTransformControlSize:function(){var e=this.controlManager.getToolByName(Yd.COMPONENT_TRANSFORM);if(e)return e.getComponentTransformControlSize()},setComponentTransformSpaceToLocalSpace:function(){var e=this.controlManager.getToolByName(Yd.COMPONENT_TRANSFORM);e&&e.setTransformSpaceToLocalSpace()&&this.render()},setComponentTransformSpaceToWorldSpace:function(){var e=this.controlManager.getToolByName(Yd.COMPONENT_TRANSFORM);e&&e.setTransformSpaceToWorldSpace()&&this.render()},switchComponentTransformSpaceBetweenLocalAndWorld:function(){var e=this.controlManager.getToolByName(Yd.COMPONENT_TRANSFORM);e&&e.switchTransformSpace()&&this.render()},showComponentTransformOnAxis:function(e){var t=this.controlManager.getToolByName(Yd.COMPONENT_TRANSFORM);t&&t.showTransformOnAxis(e)&&this.render()},hideComponentTransformOnAxis:function(e){var t=this.controlManager.getToolByName(Yd.COMPONENT_TRANSFORM);t&&t.hideTransformOnAxis(e)&&this.render()},disableComponentTransform:function(){var e=this.controlManager.getToolByName(Yd.COMPONENT_TRANSFORM);e&&e.disableTransform()&&this.render()},enableComponentTransform:function(){var e=this.controlManager.getToolByName(Yd.COMPONENT_TRANSFORM);e&&e.enableTransform()&&this.render()},componentApplyMatrix:function(e,t){var i=this.getModelManager(),n=this.getModelByComponentKey(e);if(n){i.explosionList[e]||(i.explosionList[e]=!0);var r=n._getHandler();if(r instanceof SI){var o=this.modelManager.getComponent(e);if(o&&o[0]&&o[0].mesh){var a=o[0].mesh;if(a){a.userData.originalMatrix||(a.userData.originalMatrix=a.matrixWorld.clone());var s=new Ke(a.userData.originalMatrix.elements[12],a.userData.originalMatrix.elements[13],a.userData.originalMatrix.elements[14]),l=new yt;l.setPosition(s);var c=new yt;c.setPosition(s.multiplyScalar(-1)),a.matrixWorld.multiply(c).multiply(t).multiply(l)}}}else if(r instanceof Vv){var h=n.getModelDescriptor(),d=h.mapNodeInfoByCategory[1],u=h.mapNodeInfoByCategory[0];if(d.hasOwnProperty(e))for(var p=d[e],g=0;p.length>g;g+=1){var f=p[g],m=f.mesh;if(m){var A=f.index,y=m.geometry.attributes.position;by.applyMatrix4ToBuffer(t,y.array,A.positionStart,A.positionStart+A.positionCount),y.needsUpdate=!0}}if(u.hasOwnProperty(e))for(var v=u[e],C=r.instancedManager.meshManager,I=0;v.length>I;I+=1)for(var x=v[I],w=C.getMeshIdByNodeInfo(x),M=C.nodeIdxMapFromUserId[e][w],E=0,B=M.length;B>E;E+=1){var S=M[E],b=C.instanceGeometryMap[w][E],k=b.getAttribute("mcol0"),D=b.getAttribute("mcol1"),T=b.getAttribute("mcol2"),R=b.getAttribute("mcol3");x.transformation||(x.transformation=!0,x.transformationOriginalMatrix=x.matrix.clone());var U=(new Ke).fromArray(x.transformationOriginalMatrix.elements,12),F=new yt;F.setPosition(U);var Q=new yt;Q.setPosition(U.multiplyScalar(-1));var L=new yt;L.fromArray([k.array[3*S],k.array[3*S+1],k.array[3*S+2],0,D.array[3*S],D.array[3*S+1],D.array[3*S+2],0,T.array[3*S],T.array[3*S+1],T.array[3*S+2],0,R.array[3*S],R.array[3*S+1],R.array[3*S+2],1],0),L.multiply(Q).multiply(t).multiply(F),k.array[3*S]=L.elements[0],k.array[3*S+1]=L.elements[1],k.array[3*S+2]=L.elements[2],k.needsUpdate=!0,D.array[3*S]=L.elements[4],D.array[3*S+1]=L.elements[5],D.array[3*S+2]=L.elements[6],D.needsUpdate=!0,T.array[3*S]=L.elements[8],T.array[3*S+1]=L.elements[9],T.array[3*S+2]=L.elements[10],T.needsUpdate=!0,R.array[3*S]=L.elements[12],R.array[3*S+1]=L.elements[13],R.array[3*S+2]=L.elements[14],R.needsUpdate=!0,x.matrix=L}}else Bu.warn("当前模式下暂不支持构件变换")}this.render()},componentApplyMatrix2:function(e,t){var i=2>=arguments.length||void 0===arguments[2]||arguments[2],n=this.getModelByComponentKey(e),r=this.getModelManager();if(n)n.componentApplyMatrix(e,t);else{var o=r.getComponent(e);if(o&&o.length>0)for(var a=0;o.length>a;a+=1){var s=o[a];s.matrix||(s.matrix=new yt),s.transformation||(s.transformation=!0,s.transformationOriginalMatrix=s.matrix.clone(),s.applyMatrix=new yt,s.boundingBox&&(s.transformationOriginalBoundingBox=s.boundingBox.clone())),s.matrix.premultiply(t),s.applyMatrix.premultiply(t),s.boundingBox&&s.boundingBox.copy(s.transformationOriginalBoundingBox).applyMatrix4(s.applyMatrix);var l=null;if(s.mesh instanceof Array)l=s.mesh;else{if(!(s.mesh instanceof Yt))continue;l=[s.mesh]}for(var c=0,h=l.length;h>c;c+=1){var d=l[c];s.isExternalComponent&&(d.userData.originalMatrix||(d.userData.originalMatrix=d.matrix.clone()));var u=d.matrixAutoUpdate;d.matrixAutoUpdate=!1,d.applyMatrix4(t),d.matrixAutoUpdate=u,d.updateMatrixWorld(!0)}var p=s.wireframeMeshs;if(p)for(var g=0,f=p.length;f>g;g+=1){var m=p[g];u=m.matrixAutoUpdate,m.matrixAutoUpdate=!1,m.matrix.copy(s.matrix),m.updateMatrixWorld(!0),m.matrixAutoUpdate=u}}}if(void 0===i&&(i=!0),i){if(n)n.calculateBoundingBox();else{var A=this.externalComponentManager;A&&A.getNodeInfosByUserId(e)&&A.calculateBoundingBox()}this.modelManager.updateSceneBoundingBox()}this.modelManager.updateTransformComponentList(e),this.render()},setComponentMatrix:function(e,t){this.setComponentMatrix2(e,t)},setComponentMatrix2:function(e,t,i){var n=this.getModelByComponentKey(e),r=this.getModelManager();if(n)n.setComponentMatrix(e,t);else{var o=r.getComponent(e);if(o&&o.length>0)for(var a=0;o.length>a;a+=1){var s=o[a];s.matrix||(s.matrix=new yt),s.transformation?(new yt).copy(s.applyMatrix).invert():(s.transformation=!0,s.transformationOriginalMatrix=s.matrix.clone(),s.applyMatrix=new yt,s.boundingBox&&(s.transformationOriginalBoundingBox=s.boundingBox.clone())),s.matrix.copy(s.transformationOriginalMatrix).premultiply(t),s.applyMatrix.copy(t),s.boundingBox&&s.boundingBox.copy(s.transformationOriginalBoundingBox).applyMatrix4(s.applyMatrix);var l=null;if(s.mesh instanceof Array)l=s.mesh;else{if(!(s.mesh instanceof Yt))continue;l=[s.mesh]}for(var c=0,h=l.length;h>c;c+=1){var d=l[a];s.isExternalComponent&&(d.userData.originalMatrix||(d.userData.originalMatrix=d.matrix.clone()));var u=d.matrixAutoUpdate;d.matrixAutoUpdate=!1,d.matrix.copy(s.matrix),d.applyMatrix4(new yt),d.matrixAutoUpdate=u,d.updateMatrixWorld(!0)}var p=s.wireframeMeshs;if(p)for(var g=0,f=p.length;f>g;g+=1){var m=p[g];u=m.matrixAutoUpdate,m.matrixAutoUpdate=!1,m.matrix.copy(s.matrix),m.updateMatrixWorld(!0),m.matrixAutoUpdate=u}}}if(void 0===i&&(i=!0),i){if(n)n.calculateBoundingBox();else{var A=this.externalComponentManager;A&&A.getNodeInfosByUserId(e)&&A.calculateBoundingBox()}this.modelManager.updateSceneBoundingBox()}this.render()},resetComponentMatrix:function(e,t){var i=this.getModelByComponentKey(e),n=this.getModelManager();if(i)i.resetComponentMatrix(e);else{var r=n.getComponent(e);if(r&&r.length>0)for(var o=0;r.length>o;o+=1){var a=r[o];if(a.transformation){a.matrix.copy(a.transformationOriginalMatrix),a.transformationOriginalBoundingBox&&(a.boundingBox=a.transformationOriginalBoundingBox.clone());var s=null;if(a.mesh instanceof Array)s=a.mesh;else{if(!(a.mesh instanceof Yt))continue;s=[a.mesh]}for(var l=0,c=s.length;c>l;l+=1){var h=s[o],d=void 0;if(d=a.isExternalComponent?h.userData.originalMatrix:a.matrix){var u=h.matrixAutoUpdate;h.matrixAutoUpdate=!1,h.matrix.copy(d),h.applyMatrix4(new yt),h.matrixAutoUpdate=u,h.updateMatrixWorld(!0),h.userData.originalMatrix=void 0}}var p=a.wireframeMeshs;if(p)for(var g=0,f=p.length;f>g;g+=1){var m=p[g];u=m.matrixAutoUpdate,m.matrixAutoUpdate=!1,m.matrix.copy(a.matrix),m.updateMatrixWorld(!0),m.matrixAutoUpdate=u}a.transformationOriginalMatrix=void 0,a.transformationOriginalBoundingBox=void 0,a.applyMatrix=void 0,a.transformation=void 0}}}if(void 0===t&&(t=!0),t){if(i)i.calculateBoundingBox();else{var A=this.externalComponentManager;A&&A.getNodeInfosByUserId(e)&&A.calculateBoundingBox()}this.modelManager.updateSceneBoundingBox()}this.render()},calculateComponentVolume:function(e){var t=this.modelManager.getComponent(e),i=this.modelManager.getMeshByUserId(e),n=new Ke,r=new Ke,o=new Ge;if(t&&t.length>0){Bu.time("计算体积");for(var a=0,s=0,l=t.length;l>s;s+=1){var c=t[s];if(c.isExternalComponent)for(var h=c.mesh,d=0,u=h.length;u>d;d+=1){var p=h[d];p.matrixWorld.decompose(r,o,n);var g=p.geometry,f=n.x||1,m=by.calculateVolumeOfGeometry(g.attributes.position.array,g.index.array);m&&(a+=m*f*f*f)}else if(i){var A=c.mesh||i[s].mesh;if(A){A.matrixWorld.decompose(r,o,n);var y=A.geometry,v=n.x||1,C=A._indicesGroup;if(C&&!c.instanceOrNot)for(var I=C[e],x=0,w=I.length;w>x;x+=1){var M=I[x],E=by.calculateVolumeOfGeometry(y.attributes.position.array,y.index.array,M.indexStart,M.indexCount);E&&(a+=E*v*v*v)}else{var B=by.calculateVolumeOfGeometry(y.attributes.position.array,y.index.array);B&&(a+=B*v*v*v)}}}}var S=this.getBoundingBoxByIds([e]),b=new Ke;return S.getCenter(b),Bu.timeEnd("计算体积"),{volume:a,position:b.toArray()}}},setAxisNetColor:function(e,t){var i=!1,n=this.modelManager;for(var r in n.models){var o=n.models[r];o.axisNetManager&&(o.axisNetManager.setupColor(e,t),i=!0)}i&&this.render(!0)},showAxisNet:function(){var e=!1,t=this.modelManager;for(var i in t.models){var n=t.models[i];n.axisNetManager&&(n.axisNetManager.show(),e=!0)}e&&this.render(!0)},hideAxisNet:function(){var e=!1,t=this.modelManager;for(var i in t.models){var n=t.models[i];n.axisNetManager&&(n.axisNetManager.hide(),e=!0)}e&&this.render(!0)},enableAxisNetStayInFront:function(){var e=!1,t=this.modelManager;for(var i in t.models){var n=t.models[i];n.axisNetManager&&(n.axisNetManager.enableStayInFront(),e=!0)}e&&this.render(!0)},disableAxisNetStayInFront:function(){var e=!1,t=this.modelManager;for(var i in t.models){var n=t.models[i];n.axisNetManager&&(n.axisNetManager.disableStayInFront(),e=!0)}e&&this.render(!0)},enableSnap:function(e){this.controlManager.getToolByName(Yd.PICK_BY_RECT).enableSnap(e)},pickToPoint:function(e,t){return this.controlManager.control.pickHelper.pickToPoint(e,t)},getViewportSize:function(){return this.rendererManager.getRendererSize()},getRenderer:function(){return this.rendererManager.getRenderer()},getExternalComponentManager:function(){return this.externalComponentManager||(this.externalComponentManager=new dB(this)),this.externalComponentManager},addExternalObject:function(e,t,i,n){e=e||wp.createUUID();this.getExternalComponentManager().addNode(e,t,i,n),this.render()},addExternalObjects:function(e,t,i){for(var n=this.getExternalComponentManager(),r=[],o=0;e.length>o;o+=1){var a=wp.createUUID();n.addNode(a,e[o],t,i),r.push(a)}return this.render(),r},removeExternalObjectByName:function(e){this.getExternalComponentManager().removeNodeById(e),this.render()},clearExternalObjects:function(){this.getExternalComponentManager().clearNodes(),this.render()},getExternalObjectByName:function(e){return this.getExternalComponentManager().getNodeById(e)},getAllExternalObjects:function(){return Object.values(this.getExternalComponentManager().getAllNodes())},getModelFloorMapsByKey:function(e,t){var i=this.modelManager.models[e];if(i&&i.floorManager){if("function"!=typeof t)return i.floorManager.getMimiMaps();i.floorManager.getServerMimiMaps(t)}},getReceivingPlane:function(e){return this.getScene().getReceivingPlane(e)},enableShadow:function(e){this.getReceivingPlane(e),e?this.getScene().lightManager.enableShadowLight():this.getScene().lightManager.disableShadowLight();var t=this.getRenderer();t.shadowMap.enabled=e,t.shadowMap.type=2,t.shadowMap.autoUpdate=!1,t.shadowMap.needsUpdate=!0;for(var i=this.getScene().getGroups(),n=this.getScene(),r=0;i.length>r;r+=1){var o=n.getGroupType(i[r].name);o.groupType!==Vp.IBLCUBE&&("ClipPlane"!==o.groupType&&this.traverseGroupEnableShadow(i[r],e))}this.updateShadowLight()},updateShadowLight:function(){this.getScene().lightManager.updateShadowLight(),this.getRenderer().shadowMap.needsUpdate=!0,this._render(),this.rendererManager.renderer.setClearColor(0,0),this._render()},traverseGroupEnableShadow:function(e,t){var i=this;this.getRenderer(),function(e){if(e instanceof nn){var n=e.material;if(n instanceof Array){var r=null;if("PhoneLightingMaterial"===n[0].type)return;e.castShadow=t,e.receiveShadow=t;for(var o=0;n.length>o;o+=1)n[o].needsUpdate=!0,r=n[o].defines;e.customDepthMaterial=t&&r&&r.hasOwnProperty("USE_INSTANCE")?i.getInstanceDepthMaterial():void 0}else{if("PhoneLightingMaterial"===n.type)return;e.castShadow=t,e.receiveShadow=t,n.needsUpdate=!0;var a=n.defines;e.customDepthMaterial=t&&a&&a.hasOwnProperty("USE_INSTANCE")?i.getInstanceDepthMaterial():void 0,n.needsUpdate=!0}}}(e);for(var n=e.children,r=0,o=n.length;o>r;r+=1)this.traverseGroupEnableShadow(n[r],t)},getInstanceDepthMaterial:function(){if(this.instanceDepthMaterial)return this.instanceDepthMaterial;var e=new dy;return e.depthPacking=re,this.instanceDepthMaterial=e,this.instanceDepthMaterial},updateShadowMap:function(){4===xd.LightPreset&&(this.getRenderer().shadowMap.needsUpdate=!0)},cloneComponent:function(e){function t(e){for(var t in e)e.hasOwnProperty(t)&&(e[t]instanceof Fe||e[t]instanceof gn)&&(e[t]=e[t].clone(),e[t].needsUpdate=!0)}var i,n=this.modelManager.getComponent(e),r=new Ni,o=n[0].model,a=o.materialManager,s=this.getExternalComponentManager(),l=[];if(n[0].isBatched&&!n[0].instanceOrNot)!function(){var e,o=[],c=[],h=[],d=[],u=[],p=0,g=0,f=[],m=0,A=vu(n);try{var y=function(){var i,n,s,A,y=e.value,v=y.index,C=y.mesh.geometry,I=y.mesh.geometry.attributes,x=I.position.array.slice(v.positionStart,v.positionStart+v.positionCount),w=I.normal.array.slice(v.positionStart,v.positionStart+v.positionCount),M=void 0;if(I.uv)M=I.uv.array.slice(v.positionStart/3*2,(v.positionStart+v.positionCount)/3*2);else{var E=x.length/3*2;(M=new Array(E)).fill(0,0,E)}var B=void 0;if(I.uv2)B=I.uv2.array.slice(v.positionStart/3*2,(v.positionStart+v.positionCount)/3*2);else{var S=M.length;(B=new Array(S)).fill(0,0,S)}var b=v.positionStart/3,k=C.index.array,D=v.indexCount,T=y.originMId;l.push(T);var R=cA.getMaterialParameters(a.getMaterialById(T)),U=cA.createStandardMaterial(R);t(U),f.push(U),u.push.apply(u,mu(k.slice(v.indexStart,v.indexStart+v.indexCount).map((function(e){return e-b+g})))),o=(i=o).concat.apply(i,mu(x)),c=(n=c).concat.apply(n,mu(w)),h=(s=h).concat.apply(s,mu(M)),d=(A=d).concat.apply(A,mu(B)),r.groups.push({start:p,count:D,materialIndex:m}),p+=D,g+=v.positionCount/3,m+=1};for(A.s();!(e=A.n()).done;)y()}catch(e){A.e(e)}finally{A.f()}r.setAttribute("position",new Ai(new Float32Array(o),3)),r.setAttribute("uv",new Ai(new Float32Array(h),2)),r.setAttribute("uv2",new Ai(new Float32Array(d),2)),r.setAttribute("normal",new Ai(new Float32Array(c),3)),r.setIndex(new Ai(new Uint32Array(u),1)),i=new nn(r,f),s.addExternalObject(i)}();else if(n[0].isBatched&&n[0].instanceOrNot)!function(){var n=o._handler.instancedManager.meshManager,a=n.getNodeIdxMapByUserId(e),c=[],h=[],d=[],u=[],p=n.matrixInfoMapFromUserId[e][Object.keys(n.matrixInfoMapFromUserId[e])[0]][0].matrix,g=0,f=0,m=0,A=[],y=0;for(var v in a){var C,I,x,w=n.getInstanceGeometries(v),M=w[0].index.array;if(f=w[0].index.count,c=(C=c).concat.apply(C,mu(w[0].attributes.position.array)),h=(I=h).concat.apply(I,mu(w[0].attributes.normal.array)),w[0].attributes.uv){var E;d=(E=d).concat.apply(E,mu(w[0].attributes.uv.array))}else{var B=2*f,S=new Array(B);S.fill(0,0,B),d=d.concat(S)}u=(x=u).concat.apply(x,mu(M.map((function(e){return e+g})))),g=c.length/3;var b=n.getMaterialIdByMeshId(v),k=n.manager.model.materialManager.getInstanceMaterialById(b)[0],D=cA.getMaterialParameters(k),T=cA.createStandardMaterial(D);l.push(b),t(T),A.push(T),r.groups.push({start:m,count:f,materialIndex:y}),m+=f,y+=1}r.setAttribute("position",new Ai(new Float32Array(c),3)),r.setAttribute("uv",new Ai(new Float32Array(d),2)),r.setAttribute("normal",new Ai(new Float32Array(h),3)),r.setIndex(new Ai(new Uint32Array(u),1)),(i=new nn(r,A)).applyMatrix4(p),i.updateMatrixWorld(),s.addExternalObject(i)}();else{var c=o.getModelDescriptor().getNodeInfosByComponentKey(e)[0].originMId;if(l=c,i=n[0].mesh.clone(),Array.isArray(c))i.material=c.map((function(e){var i=a.getMaterialById(e),n=cA.getMaterialParameters(i),r=cA.createStandardMaterial(n);return t(r),r}));else{var h=a.getMaterialById(c),d=cA.getMaterialParameters(h),u=cA.createStandardMaterial(d);t(u),i.material=u}s.addExternalObject(i)}return i?(i.byClone=!0,i.originMId=l,i.originComponentKey=e,i):null},setComponentBlinkByComponentKeys:function(e,t,i,n){var r=this,o=new Map;e.forEach((function(e){var t=r.getModelByComponentKey(e);if(t)if(o.has(t))o.get(t).add(e);else{var i=new Set;i.add(e),o.set(t,i)}})),this.filter.setComponentBlinkByComponentKeys(o,t,i,this,n)},closeComponentBlinkByComponentKeys:function(e){var t=this,i=new Map;e.forEach((function(e){var n=t.getModelByComponentKey(e);if(n)if(i.has(n))i.get(n).add(e);else{var r=new Set;r.add(e),i.set(n,r)}})),this.filter.closeComponentBlinkByComponentKeys(i)},getTimerManager:function(){return this.timerManager},clearBlinkList:function(){this.filter.clearBlinkList()},_setAdsorbSelectedObject:function(e){var t=arguments.length>1&&void 0!==arguments[1]&&arguments[1];t&&("string"!=typeof e?this.adsorbControl.setSelectedObjectByCollection({collection:e}):this.adsorbControl.setSelectedObjectByComponentId(e))},getRotationCenter:function(){return this.rotationCenter},getClientSize:function(){var e=this.domElement===document?this.domElement.body:this.domElement;return this.clientSize.set(e.clientWidth,e.clientHeight),this.clientSize}}),Object.defineProperties(xB.prototype,{renderer:{get:function(){return console.warn("BOS3D.ViewerImpl: .renderer 现在为 .getRenderer()"),this.getRenderer()}},composer:{get:function(){return console.warn("BOS3D.ViewerImpl: .composer 现在为 .rendererManager.composer"),this.rendererManager.composer}},scene:{get:function(){return this.modelManager.scene}},capsScene:{get:function(){return this.modelManager.capsScene}},sceneCamera:{get:function(){return this.camera}},adsorbControl:{get:function(){return this.scene.adsorbControl}}});var wB="",MB="",EB=function(e){lu(i,e);var t=pu(i);function i(e,n){var r;ru(this,i),(r=t.call(this,e)).type="Water";var o=du(r),a=n||{},s=void 0!==a.color?a.color:new Le(1,1,1,1),l=a.textureWidth||512,c=a.textureHeight||512,h=a.clipBias||0,d=a.flowDirection||new ke(1,0),u=a.flowSpeed||.03,p=a.reflectivity||1,f=a.scale||1,m=a.shader||i.WaterShader;r.reflectorTexturePosition=a.reflectorTexturePosition,r.refractorTexturePosition=a.refractorTexturePosition;var A=new Dl,y=a.flowMap||void 0,v=a.normalMap0||A.load(wB),C=a.normalMap1||A.load(MB),I=.15,x=.075,w=new yt,M=new Pc;if(void 0===Tu)return Bu.error("THREE.Water: Required component THREE.Reflector not found."),uu(r);if(void 0===Ru)return Bu.error("THREE.Water: Required component THREE.Refractor not found."),uu(r);var E=new Tu(e,{textureWidth:l,textureHeight:c,clipBias:h});E.position.copy(r.reflectorTexturePosition),E.updateMatrixWorld(!0);var B=new Ru(e,{textureWidth:l,textureHeight:c,clipBias:h});return B.position.copy(r.refractorTexturePosition),B.updateMatrixWorld(!0),r.material=new cn({uniforms:ln.merge([m.uniforms]),vertexShader:m.vertexShader,fragmentShader:m.fragmentShader,transparent:!0}),r.material.clipping=!0,r.material.side=2,void 0!==y?(r.material.defines.USE_FLOWMAP="",r.material.uniforms.tFlowMap={type:"t",value:y}):r.material.uniforms.flowDirection={type:"v2",value:d},v.wrapS=g,v.wrapT=g,C.wrapS=g,C.wrapT=g,r.material.uniforms.tReflectionMap.value=E.getRenderTarget().texture,r.material.uniforms.tRefractionMap.value=B.getRenderTarget().texture,r.material.uniforms.tNormalMap0.value=v,r.material.uniforms.tNormalMap1.value=C,r.material.uniforms.color.value=s,r.material.uniforms.reflectivity.value=p,r.material.uniforms.textureMatrix.value=w,r.material.uniforms.config.value.x=0,r.material.uniforms.config.value.y=x,r.material.uniforms.config.value.z=x,r.material.uniforms.config.value.w=f,r.onBeforeRender=function(e,t,i){var n,r;!function(e){w.set(.5,0,0,.5,0,.5,0,.5,0,0,.5,.5,0,0,0,1),w.multiply(e.projectionMatrix),w.multiply(e.matrixWorldInverse),w.multiply(o.matrixWorld)}(i),n=M.getDelta(),(r=o.material.uniforms.config).value.x+=u*n,r.value.y=r.value.x+x,I>r.value.x?I>r.value.y||(r.value.y=r.value.y-I):(r.value.x=0,r.value.y=x),o.visible=!1,E.position.equals(this.reflectorTexturePosition)||(E.position.copy(this.reflectorTexturePosition),E.updateMatrixWorld(!0)),B.position.equals(this.refractorTexturePosition)||(B.position.copy(this.refractorTexturePosition),B.updateMatrixWorld(!0)),o.cameraProjectionMatrix||(o.cameraProjectionMatrix=i.projectionMatrix.clone()),i.projectionMatrix.equals(o.cameraProjectionMatrix)||(o.needUpdate=!0),o.waterMatrixWorld||(o.waterMatrixWorld=o.matrixWorld.clone()),o.matrixWorld.equals(o.waterMatrixWorld)||(o.needUpdate=!0),o.needUpdate&&(E.onBeforeRender(e,t,i),B.onBeforeRender(e,t,i),o.needUpdate=!1),o.material.uniforms.tReflectionMap.value=E.getRenderTarget().texture,o.material.uniforms.tRefractionMap.value=B.getRenderTarget().texture,o.visible=!0},r}return i}(nn);EB.WaterShader={uniforms:{color:{type:"v4",value:null},reflectivity:{type:"f",value:0},tReflectionMap:{type:"t",value:null},tRefractionMap:{type:"t",value:null},tNormalMap0:{type:"t",value:null},tNormalMap1:{type:"t",value:null},textureMatrix:{type:"m4",value:null},config:{type:"v4",value:new Le}},vertexShader:["#include <fog_pars_vertex>","uniform mat4 textureMatrix;","varying vec4 vCoord;","varying vec2 vUv;","varying vec3 vToEye;","#include <clipping_planes_pars_vertex>","void main() {"," vUv = uv;"," vCoord = textureMatrix * vec4( position, 1.0 );"," vec4 worldPosition = modelMatrix * vec4( position, 1.0 );"," vToEye = cameraPosition - worldPosition.xyz;"," vec4 mvPosition = viewMatrix * worldPosition;"," gl_Position = projectionMatrix * mvPosition;"," #include <clipping_planes_vertex>"," #include <fog_vertex>","}"].join("\n"),fragmentShader:["#include <common>","#include <fog_pars_fragment>","uniform sampler2D tReflectionMap;","uniform sampler2D tRefractionMap;","uniform sampler2D tNormalMap0;","uniform sampler2D tNormalMap1;","#ifdef USE_FLOWMAP"," uniform sampler2D tFlowMap;","#else"," uniform vec2 flowDirection;","#endif","uniform vec4 color;","uniform float reflectivity;","uniform vec4 config;","#include <clipping_planes_pars_fragment>","varying vec4 vCoord;","varying vec2 vUv;","varying vec3 vToEye;","void main() {"," #include <clipping_planes_fragment>"," float flowMapOffset0 = config.x;"," float flowMapOffset1 = config.y;"," float halfCycle = config.z;"," float scale = config.w;"," vec3 toEye = normalize( vToEye );"," vec2 flow;"," #ifdef USE_FLOWMAP"," flow = texture2D( tFlowMap, vUv ).rg * 2.0 - 1.0;"," #else"," flow = flowDirection;"," #endif"," flow.x *= - 1.0;"," vec4 normalColor0 = texture2D( tNormalMap0, ( vUv * scale ) + flow * flowMapOffset0 );"," vec4 normalColor1 = texture2D( tNormalMap1, ( vUv * scale ) + flow * flowMapOffset1 );"," float flowLerp = abs( halfCycle - flowMapOffset0 ) / halfCycle;"," vec4 normalColor = mix( normalColor0, normalColor1, flowLerp );"," vec3 normal = normalize( vec3( normalColor.r * 2.0 - 1.0, normalColor.b, normalColor.g * 2.0 - 1.0 ) );"," float theta = max( dot( toEye, normal ), 0.0 );"," float reflectance = reflectivity + ( 1.0 - reflectivity ) * pow( ( 1.0 - theta ), 5.0 );"," vec3 coord = vCoord.xyz / vCoord.w;"," vec2 uv = coord.xy + coord.z * normal.xz * 0.05;"," vec4 reflectColor = texture2D( tReflectionMap, vec2( 1.0 - uv.x, uv.y ) );"," vec4 refractColor = texture2D( tRefractionMap, uv );"," gl_FragColor = color * mix( refractColor, reflectColor, reflectance );"," #include <tonemapping_fragment>"," #include <encodings_fragment>"," #include <fog_fragment>","}"].join("\n")};var BB=function(e){e?(this.boundary=e.boundary,this.color=e.color,this.viewer=e.viewer,this.scale=e.scale,this.xDirection=e.xDirection,this.yDirection=e.yDirection,this.reflectivity=e.reflectivity,e.reflectorTexturePosition?"number"==typeof e.reflectorTexturePosition.x?"number"==typeof e.reflectorTexturePosition.y?"number"==typeof e.reflectorTexturePosition.z?(this.reflectorTexturePosition=(new Ke).copy(e.reflectorTexturePosition),e.refractorTexturePosition?"number"==typeof e.refractorTexturePosition.x?"number"==typeof e.refractorTexturePosition.y?"number"==typeof e.refractorTexturePosition.z?(this.refractorTexturePosition=(new Ke).copy(e.refractorTexturePosition),this.viewer&&this.viewer instanceof xB?(e.geometry||0!==this.boundary.length)&&(this.geometry=e.geometry||new Uu(this.boundary),this.water=new EB(this.geometry,{color:new Le(this.color.r,this.color.g,this.color.b,this.color.a),scale:this.scale,reflectivity:this.reflectivity,flowDirection:new ke(this.xDirection,this.yDirection),textureWidth:1024,textureHeight:1024,reflectorTexturePosition:this.reflectorTexturePosition,refractorTexturePosition:this.refractorTexturePosition}),this.height=e.height,this.water.translateZ(this.height),this.water.renderOrder=-1,this.water.disPickable=!0,this.id=wp.createUUID(),this.water.name=this.id,this.water.autoAnimation=!0,this.viewer.addExternalObject(this.id,this.water)):Bu.log("ERROR::viewer must not support.")):Bu.error("缺少参数 reflectorTexturePosition.z"):Bu.error("缺少参数 reflectorTexturePosition.y"):Bu.error("缺少参数 reflectorTexturePosition.x"):Bu.error("缺少参数 reflectorTexturePosition")):Bu.error("缺少参数 reflectorTexturePosition.z"):Bu.error("缺少参数 reflectorTexturePosition.y"):Bu.error("缺少参数 reflectorTexturePosition.x"):Bu.error("缺少参数 reflectorTexturePosition")):Bu.error("ERROR::waterEffectConfig 不能为空.")};BB.prototype.getBoundary=function(){return this.boundary},BB.prototype.getColor=function(){return this.color},BB.prototype.getScale=function(){return this.scale},BB.prototype.getXDirection=function(){return this.xDirection},BB.prototype.getYDirection=function(){return this.yDirection},BB.prototype.setColor=function(e){e instanceof Du?(this.color=e,this.water.material.uniforms.color.value.set(this.color.r,this.color.g,this.color.b,this.color.a)):Bu.log("ERROR::color should be instance of BOS3D.Color")},BB.prototype.setScale=function(e){this.scale=e,this.water.material.uniforms.config.value.w=e},BB.prototype.setReflectivity=function(e){this.reflectivity=e,this.water.material.uniforms.reflectivity.value=e},BB.prototype.getReflectivity=function(){return this.reflectivity},BB.prototype.getReflectorTexturePosition=function(){return this.reflectorTexturePosition.clone()},BB.prototype.getRefractorTexturePosition=function(){return this.refractorTexturePosition.clone()},BB.prototype.setReflectorTexturePosition=function(e){e?"number"==typeof e.x?"number"==typeof e.y?"number"==typeof e.z?(this.reflectorTexturePosition=new Ke(e.x,e.y,e.z),this.water.reflectorTexturePosition=this.reflectorTexturePosition):Bu.error("缺少参数 position.z"):Bu.error("缺少参数 position.y"):Bu.error("缺少参数 position.x"):Bu.error("缺少参数 position")},BB.prototype.setRefractorTexturePosition=function(e){e?"number"==typeof e.x?"number"==typeof e.y?"number"==typeof e.z?(this.refractorTexturePosition=new Ke(e.x,e.y,e.z),this.water.refractorTexturePosition=this.refractorTexturePosition):Bu.error("缺少参数 position.z"):Bu.error("缺少参数 position.y"):Bu.error("缺少参数 position.x"):Bu.error("缺少参数 position")},BB.prototype.setXDirection=function(e){this.xDirection=e,this.water.material.uniforms.flowDirection.value.x=e},BB.prototype.setYDirection=function(e){this.yDirection=e,this.water.material.uniforms.flowDirection.value.y=e},BB.prototype.remove=function(){this.viewer.removeExternalObjectByName(this.id)},BB.prototype.setHeight=function(e){this.height=e,this.water.translateZ(e),this.water.updateMatrixWorld(!0)},BB.prototype.getHeight=function(){return this.height},BB.prototype.setGeometry=function(e){e.isGeometry||e.isBufferGeometry?(this.geometry=e,this.water.geometry=e):Bu.log("ERROR::geometry type not support")},BB.prototype.getGeometry=function(){return this.geometry},BB.prototype.getWaterObject=function(){return this.water};var SB=Symbol("_flowing"),bB=function(){function e(t){ru(this,e),this.viewer=t.viewer3D;var i=t.opt;this.arrowParameters=i,this.arrowParameters.speed=this.arrowParameters.speed||5,this.arrowParameters.spacing=this.arrowParameters.spacing||100,this.arrowArray=[],this.pathNumb=0,this.totalLength=0,this.path=[],!0===i.customizeMesh?this.geometricModelLength=i.meshLength:i.arrowShape?(i.arrowShape.rectangleLength=i.arrowShape.rectangleLength||500,i.arrowShape.triangleBottomHeight=i.arrowShape.triangleBottomHeight||260,this.geometricModelLength=i.arrowShape.rectangleLength+i.arrowShape.triangleBottomHeight?i.arrowShape.triangleBottomHeight:260):this.geometricModelLength=760,this.intervalLength=this.geometricModelLength+i.spacing,this.materialObject={},this.materialsInit=this.arrowParameters.materialsInit||"default",this.materialsUpdate=this.arrowParameters.materialsUpdate||"fixed",this.isFlowing=!1,i.callback&&(i.callback.enter&&(this.callbackEnter=i.callback.enter),i.callback.out&&(this.callbackOut=i.callback.out)),this.meshGroupId=wp.createUUID(),this.meshGroup?this.meshGroup.children=[]:this.meshGroup=new To}return au(e,[{key:"calculationPathOffset",value:function(){for(var e=this.path,t=0;e.length>t;t+=1){var i=(new Ke).copy(e[t].startingPoint),n=new Ge,r=new Ge,o=new Ke(1,1,1);if(e[t].offset){var a=(new Ke).copy(e[t].offset.pathDepthAxis).applyQuaternion(n);i.add(a.multiplyScalar(e[t].offset.depth)),r.setFromAxisAngle(e[t].startPoint2EndPointAxis,e[t].angle),n.premultiply(r),r.setFromAxisAngle(e[t].vectorNormalize,e[t].offset.angle),n.premultiply(r)}else r.setFromAxisAngle(e[t].startPoint2EndPointAxis,e[t].angle),n.premultiply(r);e[t].rotationComponent={},e[t].rotationComponent.position=i,e[t].rotationComponent.quaternion=n,e[t].rotationComponent.scale=o}}},{key:"translationPath",value:function(){var e=new Ke(1,0,0),t=this.arrowParameters.points,i=t.length-1,n=[];this.totalLength=0;for(var r=0;i>r;r+=1){var o={};if(o.startingPoint=new Ke(t[r].x,t[r].y,t[r].z),o.endingPoint=new Ke(t[r+1].x,t[r+1].y,t[r+1].z),o.length=o.startingPoint.distanceTo(o.endingPoint),o.vector=(new Ke).subVectors(o.endingPoint,o.startingPoint),o.vectorNormalize=(new Ke).subVectors(o.endingPoint,o.startingPoint).normalize(),o.startPoint2EndPointAxis=(new Ke).crossVectors(e,o.vectorNormalize).normalize(),o.numb=r,o.angle=e.angleTo(o.vectorNormalize),this.arrowParameters.offset&&this.arrowParameters.offset[r+1]){var a={},s=this.arrowParameters.offset[r+1],l=s.depth,c=s.angle,h=void 0===c?0:c;a.depth=void 0===l?0:l,a.angle=Math.PI/180*h,a.pathDepthAxis=new Ke(0,1,0).applyAxisAngle(o.startPoint2EndPointAxis,o.angle),a.pathDepthAxis.applyAxisAngle(o.vectorNormalize,a.angle).normalize(),o.offset=a}this.totalLength+=o.length,n.push(o)}this.path=n,this.pathNumb=this.path.length}},{key:"calculationArrowAmount",value:function(){var e=this.arrowParameters,t=0;if(e.createMode&&"number"===e.createMode&&e.arrowAmount&&e.arrowAmount>0)if(e.intervalMode&&"strict"===e.intervalMode){if(t=Math.floor(this.totalLength/this.intervalLength),e.arrowAmount>t)return{code:"001",message:"Too many arrows,over the length of the path"};this.arrowAmount=e.arrowAmount,this.CreateMode="number",this.IntervalMode="strict"}else{if(t=Math.floor(this.totalLength/this.geometricModelLength),e.arrowAmount>t)return{code:"001",message:"Too many arrows,over the length of the path"};this.arrowAmount=e.arrowAmount,this.CreateMode="number";var i=Math.floor(100*(this.totalLength-this.intervalLength*e.arrowAmount)/e.arrowAmount)/100;this.intervalLength+=i,this.IntervalMode="free"}else{if(e.createMode&&"number"===e.createMode&&e.arrowAmount&&1>e.arrowAmount)return{code:"002",message:"the number is error"};if(t=Math.floor(this.totalLength/this.intervalLength),e.intervalMode&&"strict"===e.intervalMode)this.IntervalMode="strict";else{var n=Math.floor(100*(this.totalLength%this.intervalLength)/t)/100;this.intervalLength+=n,this.IntervalMode="free"}this.arrowAmount=t,this.CreateMode="space"}}},{key:"createArrowArray",value:function(){var e=this.arrowAmount;if(!0===this.arrowParameters.customizeMesh)for(var t=0;e>t;t+=1){var i=this.arrowParameters.mesh.clone();i.material=this.materialObject.default,this.arrowArray.push(i),this.meshGroup.add(i)}else for(var n=this.arrowParameters.arrowShape,r=void 0===n?{}:n,o=r.triangleBottomLength||400,a=r.triangleBottomHeight||260,s=r.rectangleWidth||180,l=r.rectangleLength||500,c=r.arrowHeight||80,h=new Float32Array([a+l,c,0,l,c,o/2,l,c,-o/2,a+l,0,0,l,0,o/2,l,0,-o/2,l,c,-s/2,l,c,s/2,0,c,s/2,0,c,-s/2,l,0,-s/2,l,0,s/2,0,0,s/2,0,0,-s/2]),d=[2,1,0,3,4,5,0,1,4,0,4,3,1,2,4,4,2,5,5,2,0,3,5,0,8,7,6,9,8,6,13,9,6,10,13,6,12,8,9,9,13,12,12,13,10,12,10,11,7,8,12,11,7,12],u=0;e>u;u+=1){var p=this.createArrowMesh(h,d);p.arrowID=u,this.arrowArray.push(p),this.meshGroup.add(p)}}},{key:"createArrowMesh",value:function(e,t){var i=new Ni;i.setIndex(t);var n=new Ai(e,3);return i.attributes.position=n,new nn(i,this.materialObject.default)}},{key:"createMaterialArray",value:function(){for(var e=this.arrowParameters.colors,t=this.arrowParameters.materials,i=this.path.length,n=1;i>=n;n+=1)t&&t[n]?this.materialObject[n]=t[n]:e&&e[n]&&(this.materialObject[n]=new gi({color:e[n]}));t&&t.default?this.materialObject.default=t.default:e&&e.default?this.materialObject.default=new gi({color:e.default}):(this.materialObject.default=new gi({color:10606038}),this.materialObject.default.transparent=!0,this.materialObject.default.opacity=.8)}},{key:"initPostition",value:function(){var e=this.arrowArray,t=this.path,i=e.length,n=0,r=this.intervalLength,o=0,a=new Ge;if(this.arrowParameters.enterSceMod&&"progressive"===this.arrowParameters.enterSceMod)for(var s=0;i>s;s+=1){var l=e[s];l.quaternion.copy(a),l.position.x=t[n].startingPoint.x,l.position.y=t[n].startingPoint.y,l.position.z=t[n].startingPoint.z,l.pathOrder=n,t[n].offset?(l.translateOnAxis(t[n].vectorNormalize,-r*o),l.translateOnAxis(t[n].offset.pathDepthAxis,t[n].offset.depth),l.rotateOnWorldAxis(t[n].startPoint2EndPointAxis,t[n].angle),l.rotateOnWorldAxis(t[n].vectorNormalize,t[n].offset.angle)):(l.translateOnAxis(t[n].vectorNormalize,-r*o),l.rotateOnWorldAxis(t[n].startPoint2EndPointAxis,t[n].angle)),l.visible=!1,l.userData.BosArrowExt={},l.userData.BosArrowExt.enterState="unenter","path"===this.materialsInit&&this.materialObject[n+1]&&(l.material=this.materialObject[n+1]),l.updateMatrixWorld(),o+=1}else for(var c=0,h=0;i>h;h+=1){var d=e[h];d.quaternion.copy(a);var u=t[n];u.offset?(d.position.x=u.startingPoint.x,d.position.y=u.startingPoint.y,d.position.z=u.startingPoint.z,d.translateOnAxis(u.vectorNormalize,r*o+c),d.translateOnAxis(u.offset.pathDepthAxis,u.offset.depth),d.rotateOnWorldAxis(u.startPoint2EndPointAxis,u.angle),d.rotateOnWorldAxis(u.vectorNormalize,u.offset.angle)):(d.position.x=u.startingPoint.x,d.position.y=u.startingPoint.y,d.position.z=u.startingPoint.z,d.translateOnAxis(u.vectorNormalize,r*o+c),d.rotateOnWorldAxis(u.startPoint2EndPointAxis,u.angle)),d.pathOrder=n,"path"===this.materialsInit&&this.materialObject[n+1]&&(d.material=this.materialObject[n+1]),u.length-c>r*(o+1)||(c=r*(o+1)-u.length+c,n+=1,o=-1),d.updateMatrixWorld(),o+=1}this.viewer.removeExternalObjectByName(this.meshGroupId),this.viewer.addExternalObject(this.meshGroupId,this.meshGroup)}},{key:"setSpeed",value:function(e){this.isFlowing?(this.stopFlow(),this.arrowParameters.speed=e,this.startFlow()):this.arrowParameters.speed=e}},{key:"init",value:function(){this.translationPath(),this.calculationPathOffset(),this.calculationArrowAmount(),this.createMaterialArray(),this.createArrowArray(),this.initPostition()}},{key:"updatePosition",value:function(){var e=this,t=this.path,i=this.arrowParameters.speed;this.arrowArray.forEach((function(n){if(!n.lockPosUpDate||!0!==n.lockPosUpDate){var r=0;if(n.userData.BosArrowExt&&n.userData.BosArrowExt.enterState&&"unenter"===n.userData.BosArrowExt.enterState){var o=n.position.distanceTo(t[0].endingPoint);return t[0].length>o&&("fixed"!==e.materialsUpdate&&e.materialObject[0]?n.material=e.materialObject[0]:"fixed"===e.materialsUpdate||e.materialObject[0]||(n.material=e.materialObject.default),e.callbackEnter&&"function"==typeof e.callbackEnter&&e.callbackEnter(n,t[0]),n.visible=!0,n.userData.BosArrowExt.enterState="enter","fixed"!==e.materialsUpdate&&e.materialObject[1]?n.material=e.materialObject[1]:"fixed"===e.materialsUpdate||e.materialObject[1]||(n.material=e.materialObject.default)),n.translateX(i+r),void n.updateMatrixWorld()}var a=n.position.distanceTo(t[n.pathOrder].startingPoint);a>t[n.pathOrder].length-e.geometricModelLength&&!1!==n.visible&&(n.visible=!1,e.callbackOut&&"function"==typeof e.callbackOut&&e.callbackOut(n,t[n.pathOrder])),!1===n.visible&&(n.pathOrder+1===e.pathNumb?t[n.pathOrder].length>a||(r=a-t[n.pathOrder].length,n.pathOrder=0,n.position.copy(t[n.pathOrder].rotationComponent.position),n.scale.copy(t[n.pathOrder].rotationComponent.scale),n.setRotationFromQuaternion(t[n.pathOrder].rotationComponent.quaternion),"fixed"!==e.materialsUpdate&&e.materialObject[1]?n.material=e.materialObject[1]:"fixed"===e.materialsUpdate||e.materialObject[1]||(n.material=e.materialObject.default),e.callbackEnter&&"function"==typeof e.callbackEnter&&e.callbackEnter(n,t[n.pathOrder]),n.visible=!0):t[n.pathOrder].length>a||(r=a-t[n.pathOrder].length,n.pathOrder+=1,n.position.copy(t[n.pathOrder].rotationComponent.position),n.scale.copy(t[n.pathOrder].rotationComponent.scale),n.setRotationFromQuaternion(t[n.pathOrder].rotationComponent.quaternion),"fixed"!==e.materialsUpdate&&e.materialObject[n.pathOrder+1]?n.material=e.materialObject[n.pathOrder+1]:"fixed"===e.materialsUpdate||e.materialObject[n.pathOrder+1]||(n.material=e.materialObject.default),n.visible=!0,e.callbackEnter&&"function"==typeof e.callbackEnter&&e.callbackEnter(n,t[n.pathOrder]))),n.translateX(i+r),n.updateMatrixWorld()}})),this.viewer.render()}},{key:SB,value:function(){this.requestAnimationFrameID=requestAnimationFrame(this[SB].bind(this)),this.updatePosition()}},{key:"startFlow",value:function(){if(this.isFlowing)return{code:"003",message:"Do not open repeatedly"};this.isFlowing=!0,this.requestAnimationFrameID=requestAnimationFrame(this[SB].bind(this))}},{key:"stopFlow",value:function(){cancelAnimationFrame(this.requestAnimationFrameID),this.isFlowing=!1}},{key:"hide",value:function(){this.viewer.removeExternalObjectByName(this.meshGroupId)}},{key:"show",value:function(){this.hide(),this.viewer.addExternalObject(this.meshGroupId,this.meshGroup)}},{key:"clear",value:function(){this.hide(),this.meshGroup.children=[],this.arrowArray=[]}}]),e}(),kB=function(){function e(t){ru(this,e),this.curves={},this.viewer=t.viewer3D,this.modelKey=t.modelKey}return au(e,[{key:"getCurve",value:function(e){return this.curves[e]}},{key:"_setCurve",value:function(e,t){this.curves[e]=t}},{key:"_rmCurve",value:function(e){delete this.curves[e]}},{key:"genTHREELine",value:function(e){var t=e.closed,i=new Pl(e.points,void 0!==t&&t,e.curveType,e.tension),n=wp.createUUID();return this._setCurve(n,{curve:i}),n}},{key:"rmCurve",value:function(e){this._rmCurve(e)}},{key:"rmAllCurve",value:function(){var e=this;Object.keys(this.curves).forEach((function(t){return e.rmCurve(t)}))}}]),e}(),DB=function(){function e(t){ru(this,e),this.viewer=t.viewer3D,this.cptKeyList=t.cptKeyList.reverse(),this.cptInfo=[],this.edgeLength=0,this.boxLength=1e4,this.lineManager=new kB({viewer3D:t.viewer3D,debug:t.debug,modelKey:t.modelKey}),this.isCustom=t.isCustom||!1,this.overallOffset=t.overallOffset||{status:!1,position:{x:0,y:0,z:0}},this.callback=t.callbackFunc||void 0,this.isPlaying=!1,this.zDistance=t.zDiztance||2e4,this.init()}return au(e,[{key:"_customInit",value:function(e,t){for(var i=t,n=1,r=0;e>r;r+=1){var o=this.cptKeyList[r],a=this.handlerOriginCoordinate(o.cptKey),s=new Ke;o.offset&&s.set(o.offset.x,o.offset.y,o.offset.z);var l=new Ke;l.addVectors(a,s);var c=new Ke;o.showPoint?c.set(o.showPoint.x,o.showPoint.y,o.showPoint.z):t>n?(c.set(n*this.boxLength,0,i*this.boxLength+this.zDistance),n+=1):c.set((n=0)*this.boxLength,0,(i-=1)*this.boxLength+this.zDistance),this.cptInfo.push({cptKey:o.cptKey,showPosition:c,originPoint:a,resetVector:l,currentPosition:a})}}},{key:"_defaultInit",value:function(e,t){for(var i=t,n=0,r=0;e>r;r+=1){var o=this.cptKeyList[r],a=new Ke,s=this.handlerOriginCoordinate(o.cptKey);if(t>n?(a.set(n*this.boxLength,0,i*this.boxLength+this.zDistance),n+=1):a.set((n=0)*this.boxLength,0,(i-=1)*this.boxLength+this.zDistance),this.overallOffset.status){if(!this.overallOffset.position||"number"!=typeof this.overallOffset.position.x||"number"!=typeof this.overallOffset.position.y||"number"!=typeof this.overallOffset.position.z)throw new Error("请检查overallOffset对象中position是否符合格式");a.set(s.x+this.overallOffset.position.x,s.y+this.overallOffset.position.y,s.z+this.overallOffset.position.z)}this.cptInfo.push({cptKey:o.cptKey,showPosition:a,originPoint:s,resetVector:s,currentPosition:s})}}},{key:"init",value:function(){var e=this.cptKeyList.length,t=Math.ceil(Math.sqrt(e));this.edgeLength=t,this.isCustom?this._customInit(e,t):this._defaultInit(e,t)}},{key:"reset",value:function(){this.pause(),this.lineManager.rmAllCurve();var e,t=vu(this.cptInfo);try{for(t.s();!(e=t.n()).done;){var i=e.value,n=new yt;n.elements[12]=i.originPoint.x-i.currentPosition.x,n.elements[13]=i.originPoint.y-i.currentPosition.y,n.elements[14]=i.originPoint.z-i.currentPosition.z,this.viewer.componentApplyMatrix(i.cptKey,n),i.currentPosition=i.originPoint}}catch(e){t.e(e)}finally{t.f()}this.viewer.render(),this.viewer.viewerImpl.rotateCameraByViewCubeSide(3)}},{key:"show",value:function(){var e=this;if(!this.cptInfo.length)throw new Error("初始化失败!");this.reset();var t=this.cptInfo.filter((function(e){var t=e.currentPosition,i=e.showPosition;return t.x!==i.x&&t.y!==i.y&&t.z!==i.z}));this.isPlaying=!0;var i,n=[],r=vu(t);try{for(r.s();!(i=r.n()).done;){var o=i.value;o.currentPosition=o.originPoint;var a=this._assemble({cptItem:o,pointFn:null,show:!0});n.push(a)}}catch(e){r.e(e)}finally{r.f()}Promise.all(n).then((function(){e.isPlaying=!1}))}},{key:"addPath",value:function(e){return this.lineManager.genTHREELine(e)}},{key:"handleScaleTime",value:function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:1500,i=this.viewer.getBoxByComponentsKey(e),n=i.min,r=i.max;return t/Math.max(r.x-n.x,r.y-n.y,r.z-n.z)}},{key:"handleCurrentPosition",value:function(e,t){var i,n=vu(this.cptInfo);try{for(n.s();!(i=n.n()).done;){var r=i.value;r.cptKey===e&&(r.currentPosition=t)}}catch(e){n.e(e)}finally{n.f()}return null}},{key:"handlerOriginCoordinate",value:function(e){var t=this.viewer.getBoxByComponentsKey(e),i=t.min,n=t.max;return(new Ke).addVectors(i,n).divideScalar(2)}},{key:"_assemble",value:function(e){var t=this,i=e.cptItem,n=e.pointFn,r=e.show,o=void 0!==r&&r,a=this,s=i.currentPosition,l=i.resetVector,c=i.showPosition;return new Promise((function(e,r){try{var h=new yt,d=l;o&&(d=c);var u=t.addPath({points:[s,d]}),p=t.lineManager.getCurve(u).curve.getPoint(0),g=i.currentPosition;h.elements[12]=p.x-g.x,h.elements[13]=p.y-g.y,h.elements[14]=p.z-g.z,a.viewer.componentApplyMatrix(i.cptKey,h);var f=0,m=new Ke(0,0,0).clone().normalize(),A=function r(o){var s,l=t.lineManager.getCurve(u).curve.getPointAt(f-Math.trunc(f));s=1>o?t.lineManager.getCurve(u).curve.getPointAt(o-Math.trunc(o)):t.lineManager.getCurve(u).curve.getPointAt(1);var c=new yt;c.elements[12]=-l.x,c.elements[13]=-l.y,c.elements[14]=-l.z;var h=new Ge,d=new Ke(s.x-l.x,s.y-l.y,s.z-l.z).normalize();h.setFromUnitVectors(m,d),m.applyQuaternion(h);var p=(new yt).makeRotationFromQuaternion(h),g=new yt;g.elements[12]=s.x,g.elements[13]=s.y,g.elements[14]=s.z,t.viewer.componentApplyMatrix(i.cptKey,g.multiply(p).multiply(c)),a.handleCurrentPosition(i.cptKey,s),f=o,1>o?"function"==typeof n?requestAnimationFrame((function(){t.isPlaying&&r(n(u,o,s))})):requestAnimationFrame((function(){t.isPlaying&&r(parseFloat((o+.01).toFixed(2)))})):(t.lineManager.rmCurve(u),e({code:"success",pathId:u}))};"function"==typeof n?requestAnimationFrame((function(){A(n(u,0,p))})):requestAnimationFrame((function(){return A(.01)}))}catch(e){r(new Error(e))}}))}},{key:"singleAssemble",value:function(){var e=this;return this.isPlaying?new Error("正在组装..."):new Promise((function(t,i){try{e.isPlaying=!0;var n=e,r=e.cptInfo.filter((function(e){var t=e.currentPosition,i=e.originPoint;return t.x!==i.x&&t.y!==i.y&&t.z!==i.z}));o=r.map((function(t){return function(){return e._assemble({cptItem:t,pointFn:null})}})),a=function(){n.viewer.viewerImpl.rotateCameraByViewCubeSide(3),n.callback&&"function"==typeof n.callback&&n.callback(),t({code:"success"})},o.reduce((function(e,t){return e.then(t)}),Promise.resolve()).then(a)}catch(e){i(new Error(e))}var o,a}))}},{key:"assemble",value:function(){var e=this;return this.isPlaying?new Error("正在组装"):new Promise((function(t,i){e.cptInfo.length||i(new Error("初始化失败"));var n=e.cptInfo.filter((function(e){var t=e.currentPosition,i=e.originPoint;return t.x!==i.x&&t.y!==i.y&&t.z!==i.z}));e.isPlaying=!0;var r,o=[],a=vu(n);try{for(a.s();!(r=a.n()).done;){var s=e._assemble({cptItem:r.value,pointFn:null});o.push(s)}}catch(e){a.e(e)}finally{a.f()}Promise.all(o).then((function(){e.viewer.viewerImpl.rotateCameraByViewCubeSide(3),e.callback&&"function"==typeof e.callback&&e.callback(),t({code:"success"})}))}))}},{key:"pause",value:function(){this.isPlaying=!1}}]),e}();function TB(e,t){return e===t||e!=e&&t!=t}function RB(e,t){for(var i=e.length;i--;)if(TB(e[i][0],t))return i;return-1}var UB=Array.prototype.splice;function FB(e){var t=-1,i=null==e?0:e.length;for(this.clear();++t<i;){var n=e[t];this.set(n[0],n[1])}}FB.prototype.clear=function(){this.__data__=[],this.size=0},FB.prototype.delete=function(e){var t=this.__data__,i=RB(t,e);return i>=0&&(i==t.length-1?t.pop():UB.call(t,i,1),--this.size,!0)},FB.prototype.get=function(e){var t=this.__data__,i=RB(t,e);return 0>i?void 0:t[i][1]},FB.prototype.has=function(e){return RB(this.__data__,e)>-1},FB.prototype.set=function(e,t){var i=this.__data__,n=RB(i,e);return 0>n?(++this.size,i.push([e,t])):i[n][1]=t,this};var QB="object"==typeof global&&global&&global.Object===Object&&global,LB="object"==typeof self&&self&&self.Object===Object&&self,OB=QB||LB||Function("return this")(),NB=OB.Symbol,PB=Object.prototype,GB=PB.hasOwnProperty,KB=PB.toString,VB=NB?NB.toStringTag:void 0;var YB=Object.prototype.toString;var HB=NB?NB.toStringTag:void 0;function jB(e){return null==e?void 0===e?"[object Undefined]":"[object Null]":HB&&HB in Object(e)?function(e){var t=GB.call(e,VB),i=e[VB];try{e[VB]=void 0;var n=!0}catch(e){}var r=KB.call(e);return n&&(t?e[VB]=i:delete e[VB]),r}(e):function(e){return YB.call(e)}(e)}function WB(e){var t=typeof e;return null!=e&&("object"==t||"function"==t)}function JB(e){if(!WB(e))return!1;var t=jB(e);return"[object Function]"==t||"[object GeneratorFunction]"==t||"[object AsyncFunction]"==t||"[object Proxy]"==t}var zB,qB=OB["__core-js_shared__"],ZB=(zB=/[^.]+$/.exec(qB&&qB.keys&&qB.keys.IE_PROTO||""))?"Symbol(src)_1."+zB:"";var XB=Function.prototype.toString;function _B(e){if(null!=e){try{return XB.call(e)}catch(e){}try{return e+""}catch(e){}}return""}var $B=/^\[object .+?Constructor\]$/,eS=RegExp("^"+Function.prototype.toString.call(Object.prototype.hasOwnProperty).replace(/[\\^$.*+?()[\]{}|]/g,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$");function tS(e){return!(!WB(e)||(t=e,ZB&&ZB in t))&&(JB(e)?eS:$B).test(_B(e));var t}function iS(e,t){var i=function(e,t){return null==e?void 0:e[t]}(e,t);return tS(i)?i:void 0}var nS=iS(OB,"Map"),rS=iS(Object,"create");var oS=Object.prototype.hasOwnProperty;var aS=Object.prototype.hasOwnProperty;function sS(e){var t=-1,i=null==e?0:e.length;for(this.clear();++t<i;){var n=e[t];this.set(n[0],n[1])}}function lS(e,t){var i=e.__data__;return function(e){var t=typeof e;return"string"==t||"number"==t||"symbol"==t||"boolean"==t?"__proto__"!==e:null===e}(t)?i["string"==typeof t?"string":"hash"]:i.map}function cS(e){var t=-1,i=null==e?0:e.length;for(this.clear();++t<i;){var n=e[t];this.set(n[0],n[1])}}sS.prototype.clear=function(){this.__data__=rS?rS(null):{},this.size=0},sS.prototype.delete=function(e){var t=this.has(e)&&delete this.__data__[e];return this.size-=t?1:0,t},sS.prototype.get=function(e){var t=this.__data__;if(rS){var i=t[e];return"__lodash_hash_undefined__"===i?void 0:i}return oS.call(t,e)?t[e]:void 0},sS.prototype.has=function(e){var t=this.__data__;return rS?void 0!==t[e]:aS.call(t,e)},sS.prototype.set=function(e,t){var i=this.__data__;return this.size+=this.has(e)?0:1,i[e]=rS&&void 0===t?"__lodash_hash_undefined__":t,this},cS.prototype.clear=function(){this.size=0,this.__data__={hash:new sS,map:new(nS||FB),string:new sS}},cS.prototype.delete=function(e){var t=lS(this,e).delete(e);return this.size-=t?1:0,t},cS.prototype.get=function(e){return lS(this,e).get(e)},cS.prototype.has=function(e){return lS(this,e).has(e)},cS.prototype.set=function(e,t){var i=lS(this,e),n=i.size;return i.set(e,t),this.size+=i.size==n?0:1,this};function hS(e){var t=this.__data__=new FB(e);this.size=t.size}hS.prototype.clear=function(){this.__data__=new FB,this.size=0},hS.prototype.delete=function(e){var t=this.__data__,i=t.delete(e);return this.size=t.size,i},hS.prototype.get=function(e){return this.__data__.get(e)},hS.prototype.has=function(e){return this.__data__.has(e)},hS.prototype.set=function(e,t){var i=this.__data__;if(i instanceof FB){var n=i.__data__;if(!nS||199>n.length)return n.push([e,t]),this.size=++i.size,this;i=this.__data__=new cS(n)}return i.set(e,t),this.size=i.size,this};var dS=function(){try{var e=iS(Object,"defineProperty");return e({},"",{}),e}catch(e){}}();function uS(e,t,i){"__proto__"==t&&dS?dS(e,t,{configurable:!0,enumerable:!0,value:i,writable:!0}):e[t]=i}var pS=Object.prototype.hasOwnProperty;function gS(e,t,i){var n=e[t];pS.call(e,t)&&TB(n,i)&&(void 0!==i||t in e)||uS(e,t,i)}function fS(e,t,i,n){var r=!i;i||(i={});for(var o=-1,a=t.length;++o<a;){var s=t[o],l=n?n(i[s],e[s],s,i,e):void 0;void 0===l&&(l=e[s]),r?uS(i,s,l):gS(i,s,l)}return i}function mS(e){return null!=e&&"object"==typeof e}function AS(e){return mS(e)&&"[object Arguments]"==jB(e)}var yS=Object.prototype,vS=yS.hasOwnProperty,CS=yS.propertyIsEnumerable,IS=AS(function(){return arguments}())?AS:function(e){return mS(e)&&vS.call(e,"callee")&&!CS.call(e,"callee")},xS=Array.isArray;var wS="object"==typeof e&&e&&!e.nodeType&&e,MS=wS&&"object"==typeof module&&module&&!module.nodeType&&module,ES=MS&&MS.exports===wS?OB.Buffer:void 0,BS=(ES?ES.isBuffer:void 0)||function(){return!1},SS=/^(?:0|[1-9]\d*)$/;function bS(e,t){var i=typeof e;return!!(t=null==t?9007199254740991:t)&&("number"==i||"symbol"!=i&&SS.test(e))&&e>-1&&e%1==0&&t>e}function kS(e){return"number"==typeof e&&e>-1&&e%1==0&&9007199254740991>=e}var DS={};function TS(e){return function(t){return e(t)}}DS["[object Float32Array]"]=DS["[object Float64Array]"]=DS["[object Int8Array]"]=DS["[object Int16Array]"]=DS["[object Int32Array]"]=DS["[object Uint8Array]"]=DS["[object Uint8ClampedArray]"]=DS["[object Uint16Array]"]=DS["[object Uint32Array]"]=!0,DS["[object Arguments]"]=DS["[object Array]"]=DS["[object ArrayBuffer]"]=DS["[object Boolean]"]=DS["[object DataView]"]=DS["[object Date]"]=DS["[object Error]"]=DS["[object Function]"]=DS["[object Map]"]=DS["[object Number]"]=DS["[object Object]"]=DS["[object RegExp]"]=DS["[object Set]"]=DS["[object String]"]=DS["[object WeakMap]"]=!1;var RS="object"==typeof e&&e&&!e.nodeType&&e,US=RS&&"object"==typeof module&&module&&!module.nodeType&&module,FS=US&&US.exports===RS&&QB.process,QS=function(){try{var e=US&&US.require&&US.require("util").types;return e||FS&&FS.binding&&FS.binding("util")}catch(e){}}(),LS=QS&&QS.isTypedArray,OS=LS?TS(LS):function(e){return mS(e)&&kS(e.length)&&!!DS[jB(e)]},NS=Object.prototype.hasOwnProperty;function PS(e,t){var i=xS(e),n=!i&&IS(e),r=!i&&!n&&BS(e),o=!i&&!n&&!r&&OS(e),a=i||n||r||o,s=a?function(e,t){for(var i=-1,n=Array(e);++i<e;)n[i]=t(i);return n}(e.length,String):[],l=s.length;for(var c in e)!t&&!NS.call(e,c)||a&&("length"==c||r&&("offset"==c||"parent"==c)||o&&("buffer"==c||"byteLength"==c||"byteOffset"==c)||bS(c,l))||s.push(c);return s}var GS=Object.prototype;function KS(e){var t=e&&e.constructor;return e===("function"==typeof t&&t.prototype||GS)}function VS(e,t){return function(i){return e(t(i))}}var YS=VS(Object.keys,Object),HS=Object.prototype.hasOwnProperty;function jS(e){return null!=e&&kS(e.length)&&!JB(e)}function WS(e){return jS(e)?PS(e):function(e){if(!KS(e))return YS(e);var t=[];for(var i in Object(e))HS.call(e,i)&&"constructor"!=i&&t.push(i);return t}(e)}var JS=Object.prototype.hasOwnProperty;function zS(e){if(!WB(e))return function(e){var t=[];if(null!=e)for(var i in Object(e))t.push(i);return t}(e);var t=KS(e),i=[];for(var n in e)("constructor"!=n||!t&&JS.call(e,n))&&i.push(n);return i}function qS(e){return jS(e)?PS(e,!0):zS(e)}var ZS="object"==typeof e&&e&&!e.nodeType&&e,XS=ZS&&"object"==typeof module&&module&&!module.nodeType&&module,_S=XS&&XS.exports===ZS?OB.Buffer:void 0,$S=_S?_S.allocUnsafe:void 0;function eb(){return[]}var tb=Object.prototype.propertyIsEnumerable,ib=Object.getOwnPropertySymbols,nb=ib?function(e){return null==e?[]:(e=Object(e),function(e,t){for(var i=-1,n=null==e?0:e.length,r=0,o=[];++i<n;){var a=e[i];t(a,i,e)&&(o[r++]=a)}return o}(ib(e),(function(t){return tb.call(e,t)})))}:eb;function rb(e,t){for(var i=-1,n=t.length,r=e.length;++i<n;)e[r+i]=t[i];return e}var ob=VS(Object.getPrototypeOf,Object),ab=Object.getOwnPropertySymbols?function(e){for(var t=[];e;)rb(t,nb(e)),e=ob(e);return t}:eb;function sb(e,t,i){var n=t(e);return xS(e)?n:rb(n,i(e))}function lb(e){return sb(e,WS,nb)}function cb(e){return sb(e,qS,ab)}var hb=iS(OB,"DataView"),db=iS(OB,"Promise"),ub=iS(OB,"Set"),pb=iS(OB,"WeakMap"),gb="[object Map]",fb="[object Promise]",mb="[object Set]",Ab="[object WeakMap]",yb="[object DataView]",vb=_B(hb),Cb=_B(nS),Ib=_B(db),xb=_B(ub),wb=_B(pb),Mb=jB;(hb&&Mb(new hb(new ArrayBuffer(1)))!=yb||nS&&Mb(new nS)!=gb||db&&Mb(db.resolve())!=fb||ub&&Mb(new ub)!=mb||pb&&Mb(new pb)!=Ab)&&(Mb=function(e){var t=jB(e),i="[object Object]"==t?e.constructor:void 0,n=i?_B(i):"";if(n)switch(n){case vb:return yb;case Cb:return gb;case Ib:return fb;case xb:return mb;case wb:return Ab}return t});var Eb=Mb,Bb=Object.prototype.hasOwnProperty;var Sb=OB.Uint8Array;function bb(e){var t=new e.constructor(e.byteLength);return new Sb(t).set(new Sb(e)),t}var kb=/\w*$/;var Db=NB?NB.prototype:void 0,Tb=Db?Db.valueOf:void 0;function Rb(e,t,i){var n,r=e.constructor;switch(t){case"[object ArrayBuffer]":return bb(e);case"[object Boolean]":case"[object Date]":return new r(+e);case"[object DataView]":return function(e,t){var i=t?bb(e.buffer):e.buffer;return new e.constructor(i,e.byteOffset,e.byteLength)}(e,i);case"[object Float32Array]":case"[object Float64Array]":case"[object Int8Array]":case"[object Int16Array]":case"[object Int32Array]":case"[object Uint8Array]":case"[object Uint8ClampedArray]":case"[object Uint16Array]":case"[object Uint32Array]":return function(e,t){var i=t?bb(e.buffer):e.buffer;return new e.constructor(i,e.byteOffset,e.length)}(e,i);case"[object Map]":return new r;case"[object Number]":case"[object String]":return new r(e);case"[object RegExp]":return function(e){var t=new e.constructor(e.source,kb.exec(e));return t.lastIndex=e.lastIndex,t}(e);case"[object Set]":return new r;case"[object Symbol]":return n=e,Tb?Object(Tb.call(n)):{}}}var Ub=Object.create,Fb=function(){function e(){}return function(t){if(!WB(t))return{};if(Ub)return Ub(t);e.prototype=t;var i=new e;return e.prototype=void 0,i}}();var Qb=QS&&QS.isMap,Lb=Qb?TS(Qb):function(e){return mS(e)&&"[object Map]"==Eb(e)};var Ob=QS&&QS.isSet,Nb=Ob?TS(Ob):function(e){return mS(e)&&"[object Set]"==Eb(e)},Pb="[object Arguments]",Gb="[object Function]",Kb="[object Object]",Vb={};function Yb(e,t,i,n,r,o){var a,s=1&t,l=2&t,c=4&t;if(i&&(a=r?i(e,n,r,o):i(e)),void 0!==a)return a;if(!WB(e))return e;var h=xS(e);if(h){if(a=function(e){var t=e.length,i=new e.constructor(t);return t&&"string"==typeof e[0]&&Bb.call(e,"index")&&(i.index=e.index,i.input=e.input),i}(e),!s)return function(e,t){var i=-1,n=e.length;for(t||(t=Array(n));++i<n;)t[i]=e[i];return t}(e,a)}else{var d=Eb(e),u=d==Gb||"[object GeneratorFunction]"==d;if(BS(e))return function(e,t){if(t)return e.slice();var i=e.length,n=$S?$S(i):new e.constructor(i);return e.copy(n),n}(e,s);if(d==Kb||d==Pb||u&&!r){if(a=l||u?{}:function(e){return"function"!=typeof e.constructor||KS(e)?{}:Fb(ob(e))}(e),!s)return l?function(e,t){return fS(e,ab(e),t)}(e,function(e,t){return e&&fS(t,qS(t),e)}(a,e)):function(e,t){return fS(e,nb(e),t)}(e,function(e,t){return e&&fS(t,WS(t),e)}(a,e))}else{if(!Vb[d])return r?e:{};a=Rb(e,d,s)}}o||(o=new hS);var p=o.get(e);if(p)return p;o.set(e,a),Nb(e)?e.forEach((function(n){a.add(Yb(n,t,i,n,e,o))})):Lb(e)&&e.forEach((function(n,r){a.set(r,Yb(n,t,i,r,e,o))}));var g=h?void 0:(c?l?cb:lb:l?qS:WS)(e);return function(e,t){for(var i=-1,n=null==e?0:e.length;++i<n&&!1!==t(e[i],i,e););}(g||e,(function(n,r){g&&(n=e[r=n]),gS(a,r,Yb(n,t,i,r,e,o))})),a}Vb[Pb]=Vb["[object Array]"]=Vb["[object ArrayBuffer]"]=Vb["[object DataView]"]=Vb["[object Boolean]"]=Vb["[object Date]"]=Vb["[object Float32Array]"]=Vb["[object Float64Array]"]=Vb["[object Int8Array]"]=Vb["[object Int16Array]"]=Vb["[object Int32Array]"]=Vb["[object Map]"]=Vb["[object Number]"]=Vb[Kb]=Vb["[object RegExp]"]=Vb["[object Set]"]=Vb["[object String]"]=Vb["[object Symbol]"]=Vb["[object Uint8Array]"]=Vb["[object Uint8ClampedArray]"]=Vb["[object Uint16Array]"]=Vb["[object Uint32Array]"]=!0,Vb["[object Error]"]=Vb[Gb]=Vb["[object WeakMap]"]=!1;function Hb(e){return Yb(e,5)}var jb=function(){var e,t={defaultRadius:40,defaultRenderer:"canvas2d",defaultGradient:{.25:"rgb(0,0,255)",.55:"rgb(0,255,0)",.85:"yellow",1:"rgb(255,0,0)"},defaultMaxOpacity:1,defaultMinOpacity:0,defaultBlur:.85,defaultXField:"x",defaultYField:"y",defaultValueField:"value",plugins:{}},i=function(){var e=function(e){this._coordinator={},this._data=[],this._radi=[],this._min=10,this._max=1,this._xField=e.xField||e.defaultXField,this._yField=e.yField||e.defaultYField,this._valueField=e.valueField||e.defaultValueField,e.radius&&(this._cfgRadius=e.radius)},i=t.defaultRadius;return e.prototype={_organiseData:function(e,t){var n=e[this._xField],r=e[this._yField],o=this._radi,a=this._data,s=this._max,l=this._min,c=e[this._valueField]||1,h=e.radius||this._cfgRadius||i;a[n]||(a[n]=[],o[n]=[]),a[n][r]?a[n][r]+=c:(a[n][r]=c,o[n][r]=h);var d=a[n][r];return d>s?(t?this.setDataMax(d):this._max=d,!1):l>d?(t?this.setDataMin(d):this._min=d,!1):{x:n,y:r,value:c,radius:h,min:l,max:s}},_unOrganizeData:function(){var e=[],t=this._data,i=this._radi;for(var n in t)for(var r in t[n])e.push({x:n,y:r,radius:i[n][r],value:t[n][r]});return{min:this._min,max:this._max,data:e}},_onExtremaChange:function(){this._coordinator.emit("extremachange",{min:this._min,max:this._max})},addData:function(){if(arguments[0].length>0)for(var e=arguments[0],t=e.length;t--;)this.addData.call(this,e[t]);else{var i=this._organiseData(arguments[0],!0);i&&(0===this._data.length&&(this._min=this._max=i.value),this._coordinator.emit("renderpartial",{min:this._min,max:this._max,data:[i]}))}return this},setData:function(e){var t=e.data,i=t.length;this._data=[],this._radi=[];for(var n=0;i>n;n++)this._organiseData(t[n],!1);return this._max=e.max,this._min=e.min||0,this._onExtremaChange(),this._coordinator.emit("renderall",this._getInternalData()),this},removeData:function(){},setDataMax:function(e){return this._max=e,this._onExtremaChange(),this._coordinator.emit("renderall",this._getInternalData()),this},setDataMin:function(e){return this._min=e,this._onExtremaChange(),this._coordinator.emit("renderall",this._getInternalData()),this},setCoordinator:function(e){this._coordinator=e},_getInternalData:function(){return{max:this._max,min:this._min,data:this._data,radi:this._radi}},getData:function(){return this._unOrganizeData()}},e}(),n=function(){var e=function(e){var t=e.gradient||e.defaultGradient,i=document.createElement("canvas"),n=i.getContext("2d");i.width=256,i.height=1;var r=n.createLinearGradient(0,0,256,1);for(var o in t)r.addColorStop(o,t[o]);return n.fillStyle=r,n.fillRect(0,0,256,1),n.getImageData(0,0,256,1).data},t=function(e,t){var i=document.createElement("canvas"),n=i.getContext("2d"),r=e,o=e;if(i.width=i.height=2*e,1==t)n.beginPath(),n.arc(r,o,e,0,2*Math.PI,!1),n.fillStyle="rgba(0,0,0,1)",n.fill();else{var a=n.createRadialGradient(r,o,e*t,r,o,e);a.addColorStop(0,"rgba(0,0,0,1)"),a.addColorStop(1,"rgba(0,0,0,0)"),n.fillStyle=a,n.fillRect(0,0,2*e,2*e)}return i};function i(t){var i=t.container,n=this.shadowCanvas=document.createElement("canvas"),r=this.canvas=t.canvas||document.createElement("canvas");this._renderBoundaries=[1e4,1e4,0,0];var o=getComputedStyle(t.container)||{};r.className="heatmap-canvas",this._width=r.width=n.width=t.width||+o.width.replace(/px/,""),this._height=r.height=n.height=t.height||+o.height.replace(/px/,""),this.shadowCtx=n.getContext("2d"),this.ctx=r.getContext("2d"),r.style.cssText=n.style.cssText="position:absolute;left:0;top:0;",i.style.position="relative",i.appendChild(r),this._palette=e(t),this._templates={},this._setStyles(t)}return i.prototype={renderPartial:function(e){e.data.length>0&&(this._drawAlpha(e),this._colorize())},renderAll:function(e){this._clear(),e.data.length>0&&(this._drawAlpha(function(e){for(var t=[],i=e.min,n=e.max,r=e.radi,o=(e=e.data,Object.keys(e)),a=o.length;a--;)for(var s=o[a],l=Object.keys(e[s]),c=l.length;c--;){var h=l[c];t.push({x:s,y:h,value:e[s][h],radius:r[s][h]})}return{min:i,max:n,data:t}}(e)),this._colorize())},_updateGradient:function(t){this._palette=e(t)},updateConfig:function(e){e.gradient&&this._updateGradient(e),this._setStyles(e)},setDimensions:function(e,t){this._width=e,this._height=t,this.canvas.width=this.shadowCanvas.width=e,this.canvas.height=this.shadowCanvas.height=t},_clear:function(){this.shadowCtx.clearRect(0,0,this._width,this._height),this.ctx.clearRect(0,0,this._width,this._height)},_setStyles:function(e){this._blur=0==e.blur?0:e.blur||e.defaultBlur,e.backgroundColor&&(this.canvas.style.backgroundColor=e.backgroundColor),this._width=this.canvas.width=this.shadowCanvas.width=e.width||this._width,this._height=this.canvas.height=this.shadowCanvas.height=e.height||this._height,this._opacity=255*(e.opacity||0),this._maxOpacity=255*(e.maxOpacity||e.defaultMaxOpacity),this._minOpacity=255*(e.minOpacity||e.defaultMinOpacity),this._useGradientOpacity=!!e.useGradientOpacity},_drawAlpha:function(e){for(var i=this._min=e.min,n=this._max=e.max,r=(e=e.data||[]).length,o=1-this._blur;r--;){var a,s=e[r],l=s.x,c=s.y,h=s.radius,d=Math.min(s.value,n),u=l-h,p=c-h,g=this.shadowCtx;this._templates[h]?a=this._templates[h]:this._templates[h]=a=t(h,o);var f=(d-i)/(n-i);g.globalAlpha=.01>f?.01:f,g.drawImage(a,u,p),this._renderBoundaries[0]>u&&(this._renderBoundaries[0]=u),this._renderBoundaries[1]>p&&(this._renderBoundaries[1]=p),u+2*h>this._renderBoundaries[2]&&(this._renderBoundaries[2]=u+2*h),p+2*h>this._renderBoundaries[3]&&(this._renderBoundaries[3]=p+2*h)}},_colorize:function(){var e=this._renderBoundaries[0],t=this._renderBoundaries[1],i=this._renderBoundaries[2]-e,n=this._renderBoundaries[3]-t,r=this._width,o=this._height,a=this._opacity,s=this._maxOpacity,l=this._minOpacity,c=this._useGradientOpacity;0>e&&(e=0),0>t&&(t=0),e+i>r&&(i=r-e),t+n>o&&(n=o-t);for(var h=this.shadowCtx.getImageData(e,t,i,n),d=h.data,u=d.length,p=this._palette,g=3;u>g;g+=4){var f,m=d[g],A=4*m;if(A)f=a>0?a:s>m?l>m?l:m:s,d[g-3]=p[A],d[g-2]=p[A+1],d[g-1]=p[A+2],d[g]=c?p[A+3]:f}this.shadowCtx.putImageData(h,e,t),this.ctx.putImageData(h,e,t),this._renderBoundaries=[1e3,1e3,0,0]},getValueAt:function(e){var t=this.shadowCtx.getImageData(e.x,e.y,1,1).data[3];return Math.abs(this._max-this._min)*(t/255)>>0},getDataURL:function(){return this.canvas.toDataURL()}},i}(),r=(e=!1,"canvas2d"===t.defaultRenderer&&(e=n),e),o=function(){for(var e={},t=arguments.length,i=0;t>i;i++){var n=arguments[i];for(var r in n)e[r]=n[r]}return e},a=function(){var e=function(){function e(){this.cStore={}}return e.prototype={on:function(e,t,i){var n=this.cStore;n[e]||(n[e]=[]),n[e].push((function(e){return t.call(i,e)}))},emit:function(e,t){var i=this.cStore;if(i[e])for(var n=i[e].length,r=0;n>r;r++){(0,i[e][r])(t)}}},e}(),n=function(e){var t=e._renderer,i=e._coordinator,n=e._store;i.on("renderpartial",t.renderPartial,t),i.on("renderall",t.renderAll,t),i.on("extremachange",(function(t){e._config.onExtremaChange&&e._config.onExtremaChange({min:t.min,max:t.max,gradient:e._config.gradient||e._config.defaultGradient})})),n.setCoordinator(i)};function a(){var a=this._config=o(t,arguments[0]||{});if(this._coordinator=new e,a.plugin){var s=a.plugin;if(!t.plugins[s])throw new Error("Plugin '"+s+"' not found. Maybe it was not registered.");var l=t.plugins[s];this._renderer=new l.renderer(a),this._store=new l.store(a)}else this._renderer=new r(a),this._store=new i(a);n(this)}return a.prototype={addData:function(){return this._store.addData.apply(this._store,arguments),this},removeData:function(){return this._store.removeData&&this._store.removeData.apply(this._store,arguments),this},setData:function(){return this._store.setData.apply(this._store,arguments),this},setDataMax:function(){return this._store.setDataMax.apply(this._store,arguments),this},setDataMin:function(){return this._store.setDataMin.apply(this._store,arguments),this},configure:function(e){return this._config=o(this._config,e),this._renderer.updateConfig(this._config),this._coordinator.emit("renderall",this._store._getInternalData()),this},repaint:function(){return this._coordinator.emit("renderall",this._store._getInternalData()),this},getData:function(){return this._store.getData()},getDataURL:function(){return this._renderer.getDataURL()},getValueAt:function(e){return this._store.getValueAt?this._store.getValueAt(e):this._renderer.getValueAt?this._renderer.getValueAt(e):null}},a}();return{create:function(e){return new a(e)},register:function(e,i){t.plugins[e]=i}}}(),Wb=function(){function e(t){ru(this,e),this.viewer=t.viewer3D,this.id=t.id,this.boundary=[],this.quaternion=new Ge,this.xMin=1/0,this.yMax=-1/0,this.zoomRate=.05}return au(e,[{key:"createInstance",value:function(e,t){var i=document.createElement("div");i.id="heatmap-"+this.id||(new Date).getTime(),i.style.width="10px",i.style.height="10px",i.style.position="absolute",i.style.top="0",i.style.left="0",i.style.zIndex="-10",i.style.overflow="scroll";var n=document.createElement("div");n.style.width=e+"px",n.style.height=t+"px",i.appendChild(n),this.viewer.viewportDiv.appendChild(i),this.container=i,this.heatmap=jb.create({container:n})}},{key:"getHeatmap",value:function(){return this.heatmap}},{key:"isPlane",value:function(e){if(3>e.length)return!1;if(3===e.length)return!0;for(var t=!0,i=(new Ke).subVectors(e[0],e[1]),n=(new Ke).subVectors(e[1],e[2]),r=i.cross(n).normalize(),o=3;e.length>o;o++){var a=(new Ke).subVectors(e[o-1],e[o]).cross(n).normalize(),s=.001;if(Math.abs(Math.abs(r.x)-Math.abs(a.x))>s||Math.abs(Math.abs(r.y)-Math.abs(a.y))>s||Math.abs(Math.abs(r.z)-Math.abs(a.z))>s){t=!1;break}}return t}},{key:"addHeatmap",value:function(e,t){var i=Hb(t.boundary);if(t.data.data.forEach((function(e){i.push(e.point)})),this.isPlane(i)){this.boundary=Hb(t.boundary);var n=new Ge,r=(new Ke).subVectors(t.boundary[1],t.boundary[0]).cross((new Ke).subVectors(t.boundary[2],t.boundary[1]));n.setFromUnitVectors(r.normalize(),new Ke(0,0,1));var o=Hb(t.boundary).map((function(e){return e.applyQuaternion(n)}));this.quaternion=n.clone();var a=1/0,s=-1/0,l=1/0,c=-1/0;o.forEach((function(e){a>e.x&&(a=e.x),e.x>s&&(s=e.x),l>e.y&&(l=e.y),e.y>c&&(c=e.y)}));var h=s-a,d=c-l;this.xMin=a,this.yMax=c;var u=t.quality||.05;this.zoomRate=u,this.createInstance(Math.round(h*u),Math.round(d*u));var p=t.data.data.map((function(e){return e.point.applyQuaternion(n)})),g=[];t.data.data.forEach((function(e,t){var i=p[t];g.push({x:Math.round((i.x-a)*u),y:Math.round((c-i.y)*u),value:e.value,radius:(e.radius||1e3)*u})})),this.heatmap.setData({min:t.data.min,max:t.data.max,data:g});var f=new Uu(o),m=new Ja(this.container.querySelector("canvas")),A=new gi({map:m,side:2,transparent:!0,polygonOffset:!0,polygonOffsetFactor:-1,polygonOffsetUnits:-1}),y=new Bv(f,A);y.visible=!0;var v=new yt;v.elements[14]=o[0].z;var C=new yt;return C.makeRotationFromQuaternion(n.invert()),y.applyMatrix4(C.multiply(v)),this.viewer.addExternalObject(e,y),y.disPickable=!0,this.viewer.disableComponentsSelectionByKey(e),!0}return!1}},{key:"updateHeatmap",value:function(e){var t=this,i=Hb(this.boundary);if(e.data.data.forEach((function(e){i.push(e.point)})),this.isPlane(i)){var n=[],r=e.data.data.map((function(e){return new Ke(e.point.x,e.point.y,e.point.z).applyQuaternion(t.quaternion)})),o=this.zoomRate;return e.data.data.forEach((function(e,i){var a=r[i];n.push({x:Math.round((a.x-t.xMin)*o),y:Math.round((t.yMax-a.y)*o),value:e.value,radius:(e.radius||1e3)*o})})),this.heatmap.setData({min:e.data.min,max:e.data.max,data:n}),this.viewer.getExternalObjectByName(e.id).material.map.needsUpdate=!0,this.viewer.render(),!0}return!1}},{key:"removeHeatmap",value:function(e){this.viewer.removeExternalObjectByName(e),this.viewer.viewportDiv.removeChild(this.container)}}]),e}(),Jb=function(){function e(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:.1,i=arguments.length>1&&void 0!==arguments[1]?arguments[1]:6;ru(this,e),this.maxEdgeLength=t,this.maxIterations=i}return au(e,[{key:"modify",value:function(e){if(!0===e.isGeometry)return console.error("THREE.TessellateModifier no longer supports Geometry. Use BufferGeometry instead."),e;null!==e.index&&(e=e.toNonIndexed());var t=this.maxIterations,i=this.maxEdgeLength*this.maxEdgeLength,n=new Ke,r=new Ke,o=new Ke,a=new Ke,s=[n,r,o,a],l=new Ke,c=new Ke,h=new Ke,d=new Ke,u=[l,c,h,d],p=new pi,g=new pi,f=new pi,m=new pi,A=[p,g,f,m],y=new ke,v=new ke,C=new ke,I=new ke,x=[y,v,C,I],w=new ke,M=new ke,E=new ke,B=new ke,S=[w,M,E,B],b=e.attributes,k=void 0!==b.normal,D=void 0!==b.color,T=void 0!==b.uv,R=void 0!==b.uv2,U=b.position.array,F=k?b.normal.array:null,Q=D?b.color.array:null,L=T?b.uv.array:null,O=R?b.uv2.array:null,N=U,P=F,G=Q,K=L,V=O,Y=0,H=!0;function j(e,t,i){var n=s[e],r=s[t],o=s[i];if(N.push(n.x,n.y,n.z),N.push(r.x,r.y,r.z),N.push(o.x,o.y,o.z),k){var a=u[e],l=u[t],c=u[i];P.push(a.x,a.y,a.z),P.push(l.x,l.y,l.z),P.push(c.x,c.y,c.z)}if(D){var h=A[e],d=A[t],p=A[i];G.push(h.x,h.y,h.z),G.push(d.x,d.y,d.z),G.push(p.x,p.y,p.z)}if(T){var g=x[e],f=x[t],m=x[i];K.push(g.x,g.y),K.push(f.x,f.y),K.push(m.x,m.y)}if(R){var y=S[e],v=S[t],C=S[i];V.push(y.x,y.y),V.push(v.x,v.y),V.push(C.x,C.y)}}for(;H&&t>Y;){Y+=1,H=!1,U=N,N=[],k&&(F=P,P=[]),D&&(Q=G,G=[]),T&&(L=K,K=[]),R&&(O=V,V=[]);for(var W=0,J=0,z=U.length;z>W;W+=9,J+=6){n.fromArray(U,W+0),r.fromArray(U,W+3),o.fromArray(U,W+6),k&&(l.fromArray(F,W+0),c.fromArray(F,W+3),h.fromArray(F,W+6)),D&&(p.fromArray(Q,W+0),g.fromArray(Q,W+3),f.fromArray(Q,W+6)),T&&(y.fromArray(L,J+0),v.fromArray(L,J+2),C.fromArray(L,J+4)),R&&(w.fromArray(O,J+0),M.fromArray(O,J+2),E.fromArray(O,J+4));var q=n.distanceToSquared(r),Z=r.distanceToSquared(o),X=n.distanceToSquared(o);q>i||Z>i||X>i?(H=!0,Z>q||X>q?q>Z||X>Z?(a.lerpVectors(n,o,.5),k&&d.lerpVectors(l,h,.5),D&&m.lerpColors(p,f,.5),T&&I.lerpVectors(y,C,.5),R&&B.lerpVectors(w,E,.5),j(0,1,3),j(3,1,2)):(a.lerpVectors(r,o,.5),k&&d.lerpVectors(c,h,.5),D&&m.lerpColors(g,f,.5),T&&I.lerpVectors(v,C,.5),R&&B.lerpVectors(M,E,.5),j(0,1,3),j(3,2,0)):(a.lerpVectors(n,r,.5),k&&d.lerpVectors(l,c,.5),D&&m.lerpColors(p,g,.5),T&&I.lerpVectors(y,v,.5),R&&B.lerpVectors(w,M,.5),j(0,3,2),j(3,1,2))):j(0,1,2)}}var _=new Ni;return _.setAttribute("position",new Bi(N,3)),k&&_.setAttribute("normal",new Bi(P,3)),D&&_.setAttribute("color",new Bi(G,3)),T&&_.setAttribute("uv",new Bi(K,2)),R&&_.setAttribute("uv2",new Bi(V,2)),_}}]),e}(),zb=function(){function e(t){ru(this,e),this.viewer=t.viewer3D,this.id=t.id,this.boundary=[],this.quaternion=new Ge,this.xMin=1/0,this.yMax=-1/0,this.zoomRate=.05,this._canvasSize=new ke,this.detailFactor=.5,this._offsetToNagZ=!1,this._mesh=void 0,this._originalGeo=void 0,this._currentGeo=void 0}return au(e,[{key:"createInstance",value:function(e,t){var i=document.createElement("div");i.id="heatmap-"+this.id||(new Date).getTime(),i.style.width="10px",i.style.height="10px",i.style.position="absolute",i.style.top="0",i.style.left="0",i.style.zIndex="-10",i.style.overflow="scroll";var n=document.createElement("div");n.style.width=e+"px",n.style.height=t+"px",this._canvas=n,i.appendChild(n),this.viewer.viewportDiv.appendChild(i),this.container=i,this.heatmap=jb.create({container:n}),this._canvasSize.set(e,t)}},{key:"getHeatmap",value:function(){return this.heatmap}},{key:"isPlane",value:function(e){if(3>e.length)return!1;if(3===e.length)return!0;for(var t=!0,i=(new Ke).subVectors(e[0],e[1]),n=(new Ke).subVectors(e[1],e[2]),r=i.cross(n).normalize(),o=3;e.length>o;o+=1){var a=(new Ke).subVectors(e[o-1],e[o]).cross(n).normalize(),s=.001;if(Math.abs(Math.abs(r.x)-Math.abs(a.x))>s||Math.abs(Math.abs(r.y)-Math.abs(a.y))>s||Math.abs(Math.abs(r.z)-Math.abs(a.z))>s){t=!1;break}}return t}},{key:"addHeatmap",value:function(e,t){var i=Hb(t.boundary);if(t.data.data.forEach((function(e){i.push(e.point)})),this.isPlane(i)){this.boundary=Hb(t.boundary);var n=new Ge,r=(new Ke).subVectors(t.boundary[1],t.boundary[0]).cross((new Ke).subVectors(t.boundary[2],t.boundary[1]));n.setFromUnitVectors(r.normalize(),new Ke(0,0,1)),2*r.angleTo(new Ke(0,0,1))>Math.PI&&(this._offsetToNagZ=!0);var o=Hb(t.boundary).map((function(e){return e.applyQuaternion(n)}));this.quaternion=n.clone();var a=1/0,s=-1/0,l=1/0,c=-1/0;o.forEach((function(e){a>e.x&&(a=e.x),e.x>s&&(s=e.x),l>e.y&&(l=e.y),e.y>c&&(c=e.y)}));var h=s-a,d=c-l;this.xMin=a,this.yMax=c;var u=t.quality||.05;this.zoomRate=u,this.createInstance(Math.round(h*u),Math.round(d*u));var p=t.data.data.map((function(e){return e.point.applyQuaternion(n)})),g=[];t.data.data.forEach((function(e,t){var i=p[t];g.push({x:Math.round((i.x-a)*u),y:Math.round((c-i.y)*u),value:e.value,radius:(e.radius||1e3)*u})})),this.heatmap.setData({min:t.data.min,max:t.data.max,data:g});var f=new Uu(o);this._originalGeo=f.clone(),f=this._tessellateGeometry(f),this._offsetZ(f);var m=new Ja(this.container.querySelector("canvas")),A=new gi({map:m,transparent:!0,side:2,polygonOffset:!0,polygonOffsetFactor:-1,polygonOffsetUnits:-1,wireframe:!1}),y=new Bv(f,A);y.visible=!0;var v=new yt;v.elements[14]=o[0].z;var C=new yt;return C.makeRotationFromQuaternion(n.invert()),y.applyMatrix4(C.multiply(v)),this.viewer.addExternalObject(e,y),y.disPickable=!0,this.viewer.disableComponentsSelectionByKey(e),this._mesh=y,!0}return!1}},{key:"updateHeatmap",value:function(e){var t=this,i=Hb(this.boundary);if(e.data.data.forEach((function(e){i.push(e.point)})),this.isPlane(i)){var n=[],r=e.data.data.map((function(e){return new Ke(e.point.x,e.point.y,e.point.z).applyQuaternion(t.quaternion)})),o=this.zoomRate;e.data.data.forEach((function(e,i){var a=r[i];n.push({x:Math.round((a.x-t.xMin)*o),y:Math.round((t.yMax-a.y)*o),value:e.value,radius:(e.radius||1e3)*o})})),this.heatmap.setData({min:e.data.min,max:e.data.max,data:n});var a=this.viewer.getExternalObjectByName(e.id);if(a)return a.material.map.needsUpdate=!0,this.viewer.render(),!0}return!1}},{key:"removeHeatmap",value:function(e){this.viewer.removeExternalObjectByName(e),this.viewer.viewportDiv.removeChild(this.container)}},{key:"setDetailFactor",value:function(e){if(this.detailFactor!==e&&(this.detailFactor=e,this._originalGeo&&this._mesh)){var t=this._originalGeo.clone(),i=this._tessellateGeometry(t);this._offsetZ(i),this._mesh.geometry=i}}},{key:"_tessellateGeometry",value:function(e){for(var t=new Jb(100),i=10+Math.round(10*this.detailFactor),n=0;i>n;n+=1)t.modify(e);return e}},{key:"_easeInOutQuad",value:function(e){return 1-(1-e)*(1-e)}},{key:"_offsetZ",value:function(e){for(var t=e.getAttribute("uv").array,i=e.getAttribute("position").array,n=this.heatmap.getData(),r=0,o=t.length;o>r;r+=2){var a=(this.heatmap.getValueAt({x:t[r]*this._canvasSize.x,y:(1-t[r+1])*this._canvasSize.y})-n.min)/(n.max-n.min);a=this._easeInOutQuad(a),i[r/2*3+2]=1e3*a*(this._offsetToNagZ?-1:1)}e.getAttribute("position").needsUpdate=!0}}]),e}(),qb=function(){function e(t,i){ru(this,e),this.viewer=i,this.maxHeatValue=1/0,this.minHeatValue=-1/0,this._init(t)}return au(e,[{key:"show",value:function(e){var t=this;function i(e){if(0===e.uniforms.heatmapPoints.value.length)e.fragmentShader="#define HEATMAPPOINTSCOUNT "+t.shaderData.heatmapPoints.length+"\n"+e.fragmentShader,e.vertexShader="#define HEATMAPPOINTSCOUNT "+t.shaderData.heatmapPoints.length+"\n"+e.vertexShader;else{var i="#define HEATMAPPOINTSCOUNT "+e.uniforms.heatmapPoints.value.length;e.fragmentShader=e.fragmentShader.replace(i,"#define HEATMAPPOINTSCOUNT "+t.shaderData.heatmapPoints.length),e.vertexShader=e.vertexShader.replace(i,"#define HEATMAPPOINTSCOUNT "+t.shaderData.heatmapPoints.length)}e.uniforms.heatmapPoints.value=t.shaderData.heatmapPoints,e.uniforms.heatmapTexture.value=t.shaderData.heatmapTexture,e.needsUpdate=!0}if(e){if(!this.viewer.getViewerImpl().getModelByComponentKey(e))return;var n=this.viewer.getViewerImpl().modelManager.getComponent(e);if(n&&n.length>0)for(var r=n[0].mesh.material,o=0,a=r.length;a>o;o+=1)r[o]=r[o].clone(),i(r[o])}else this.shaderData.heatmapPoints&&this.shaderData.heatmapTexture&&(this.viewer.getViewerImpl().getModelManager().traverseModels((function(e){var t=e.materialManager.materials;for(var n in t){i(t[n])}})),this.viewer.syncRender())}},{key:"hide",value:function(){var e=this;this.shaderData.heatmapPoints&&this.shaderData.heatmapTexture&&(this.viewer.getViewerImpl().getModelManager().traverseModels((function(t){var i=t.materialManager.materials;for(var n in i){var r=i[n];if(r.uniforms.heatmapPoints.value.length>0){r.uniforms.heatmapPoints.value=[],r.uniforms.heatmapTexture.value=null;var o="#define HEATMAPPOINTSCOUNT "+e.shaderData.heatmapPoints.length;r.fragmentShader=r.fragmentShader.replace(o,""),r.vertexShader=r.vertexShader.replace(o,""),r.needsUpdate=!0}}})),this.viewer.render())}},{key:"removeHeatmap",value:function(){this.hide(),this.shaderData.heatmapPoints&&delete this.shaderData.heatmapPoints,this.shaderData.heatmapTexture&&delete this.shaderData.heatmapTexture}},{key:"updateHeatmap",value:function(e){var t=e.data;this.maxHeatValue=t.max?t.max:1/0,this.minHeatValue=t.min?t.min:-1/0,this.shaderData.heatmapPoints=this._createHeatmapBuffer(e.data),this.show()}},{key:"_init",value:function(e){var t=e.data;this.maxHeatValue=t.max?t.max:1/0,this.minHeatValue=t.min?t.min:-1/0,this.shaderData={heatmapPoints:this._createHeatmapBuffer(t),heatmapTexture:this._createHeatmapTexture()}}},{key:"_createHeatmapBuffer",value:function(e){if(e.data&&0!==e.data.length){if(this.maxHeatValue===1/0||this.minHeatValue===-1/0)for(var t=0,i=e.data.length;i>t;t+=1){var n=e.data[t];n.value>this.maxHeatValue&&(this.maxHeatValue=n.value),this.minHeatValue>n.value&&(this.minHeatValue=n.value)}for(var r=[],o=0,a=e.data.length;a>o;o+=1){var s=e.data[o],l=Math.max(this.minHeatValue,Math.min(s.value,this.maxHeatValue));r.push(s.point.x,s.point.y,s.point.z,(l-this.minHeatValue)/(this.maxHeatValue-this.minHeatValue),s.radius?s.radius:1e3)}return new Float32Array(r)}}},{key:"_createHeatmapTexture",value:function(){var e=document.createElement("canvas");e.width=256,e.height=1;var t=e.getContext("2d"),i=t.createLinearGradient(0,0,256,1),n={0:"#44f",.1:"#0ff",.2:"#0f0",.4:"#ff0",1:"#f00"};for(var r in n)i.addColorStop(r,n[r]);return t.fillStyle=i,t.fillRect(0,0,256,1),new Ja(e)}}]),e}(),Zb=function(){function e(t,i){ru(this,e),this.heatSpheres=[],this.viewer=i,this.maxHeatValue=1/0,this.minHeatValue=-1/0,this._animating=!1,this._lastAnimateTime=void 0,this._localTime=0,this._duration=2e3,this._init(t)}return au(e,[{key:"getColorIndexAndValueOfHeatValue",value:function(t){e.colorBoard||(e.colorBoard=this._createColorBoard());var i=(Math.max(this.minHeatValue,Math.min(t,this.maxHeatValue))-this.minHeatValue)/(this.maxHeatValue-this.minHeatValue)*255,n=4*(i=Math.round(i));return{color:new pi(e.colorBoard[n]/255,e.colorBoard[n+1]/255,e.colorBoard[n+2]/255),index:i}}},{key:"updateHeatmap",value:function(e){this.removeHeatmap(),this._init(e),this.startAnimation(this._duration)}},{key:"startAnimation",value:function(e){var t=this;this._animating||(this._animating=!0,e&&(this._duration=e),requestAnimationFrame((function(e){return t._animate(e)})))}},{key:"stopAnimation",value:function(){this._animating=!1,this._lastAnimateTime=void 0,this._localTime=0}},{key:"removeHeatmap",value:function(){var e=this;this.stopAnimation(),this.heatSpheres.forEach((function(t){e.viewer.removeExternalObjectByName(t.uuid)}))}},{key:"_animate",value:function(t){var i=this,n=this._lastAnimateTime?t-this._lastAnimateTime:0;if(!this._lastAnimateTime||n>100){this._localTime+=n/this._duration,1>this._localTime||(this._localTime=0);var r=this._easeOutSine(this._localTime);this.heatSpheres.forEach((function(t){t.scale.set(r,r,r),t.updateMatrixWorld(!0);var n=t.userData._heatColorIndex;n=4*Math.round(n*(1-i._localTime)),t.material.color.setRGB(e.colorBoard[n]/255,e.colorBoard[n+1]/255,e.colorBoard[n+2]/255),t.material.needsUpdate=!0})),this.viewer.render(),this._lastAnimateTime=t}this._animating&&requestAnimationFrame((function(e){return i._animate(e)}))}},{key:"_init",value:function(e){var t=e.data;if(this.maxHeatValue=t.max?t.max:1/0,this.minHeatValue=t.min?t.min:-1/0,this._sphereOpacity=t.alpha?t.alpha:.7,this.maxHeatValue===1/0||this.minHeatValue===-1/0)for(var i=0,n=t.data.length;n>i;i+=1){var r=t.data[i];r.value>this.maxHeatValue&&(this.maxHeatValue=r.value),this.minHeatValue>r.value&&(this.minHeatValue=r.value)}for(var o=0,a=t.data.length;a>o;o+=1)this._addHeatPoint(t.data[o])}},{key:"_addHeatPoint",value:function(e){var t=e,i=t.radius?t.radius:1e3,n=10*Math.log10(i),r=new Ks(i,n,n),o=this.getColorIndexAndValueOfHeatValue(t.value),a=o.index,s=new il({color:o.color,depthTest:!0,transparent:!0,opacity:this._sphereOpacity}),l=new nn(r,s);l.position.set(t.point.x,t.point.y,t.point.z),l.updateMatrixWorld(!0),l.userData._heatValue=t.value,l.userData._heatColorIndex=a,l.disPickable=!0,this.viewer.disableComponentsSelectionByKey(l.uuid),this.heatSpheres.push(l),this.viewer.addExternalObject(l.uuid,l)}},{key:"_createColorBoard",value:function(){var e=document.createElement("canvas");e.width=256,e.height=1;var t=e.getContext("2d"),i=t.createLinearGradient(0,0,256,1),n={0:"#44f",.1:"#0ff",.2:"#0f0",.4:"#ff0",1:"#f00"};for(var r in n)i.addColorStop(r,n[r]);return t.fillStyle=i,t.fillRect(0,0,256,1),t.getImageData(0,0,256,1).data}},{key:"_easeOutCubic",value:function(e){return 1-Math.pow(1-e,3)}},{key:"_easeOutSine",value:function(e){return Math.sin(e*Math.PI/2)}},{key:"_easeInCubic",value:function(e){return e*e*e}}]),e}(),Xb=function(){function e(t){ru(this,e),this.viewer=t.viewer3D,this.mapCollection={}}return au(e,[{key:"createHeatmap",value:function(e){var t=((new Date).getTime()*(Math.random()+1)).toString(36).slice(0,8),i=new Wb({viewer3D:this.viewer,id:t}),n=Hb(e);return n.data.data.forEach((function(e){e.point=new Ke(e.point.x,e.point.y,e.point.z)})),n.boundary=n.boundary.map((function(e){return new Ke(e.x,e.y,e.z)})),i.addHeatmap(t,n)?(this.mapCollection[t]=i,{code:"success",id:t}):{code:"error",message:"输入的点不共面"}}},{key:"updateHeatmap",value:function(e){var t=this.mapCollection[e.id];if(t&&t.updateHeatmap)return t.updateHeatmap(e)}},{key:"removeHeatmap",value:function(e){return!!this.mapCollection[e]&&(this.mapCollection[e].removeHeatmap(e),delete this.mapCollection[e],!0)}},{key:"createHeatmap3D",value:function(e){var t=((new Date).getTime()*(Math.random()+1)).toString(36).slice(0,8),i=new zb({viewer3D:this.viewer,id:t}),n=Hb(e);return n.data.data.forEach((function(e){e.point=new Ke(e.point.x,e.point.y,e.point.z)})),n.boundary=n.boundary.map((function(e){return new Ke(e.x,e.y,e.z)})),i.addHeatmap(t,n)?(this.mapCollection[t]=i,{code:"success",id:t,map:i}):{code:"error",message:"输入的点不共面"}}},{key:"createSphereHeatmap",value:function(e){if(e.data&&e.data.data){var t=((new Date).getTime()*(Math.random()+1)).toString(36).slice(0,8),i=new Zb(e,this.viewer);return i.startAnimation(5e3),this.mapCollection[t]=i,{code:"success",id:t,map:i}}return{code:"error",message:"参数错误"}}},{key:"createSphereColorOverrideHeatmap",value:function(e){if(e.data&&e.data.data){if(e.data.data.length>150)return{code:"error",message:"热力源个数不能超过150"};var t=new qb(e,this.viewer),i=((new Date).getTime()*(Math.random()+1)).toString(36).slice(0,8);return this.mapCollection[i]=t,t.show(),{code:"success",id:i,map:t}}return{code:"error",message:"参数错误"}}}]),e}(),_b=function(e){lu(i,e);var t=pu(i);function i(){var e;return ru(this,i),(e=t.call(this)).type="LineGeometry",e}return au(i,[{key:"setPositions",value:function(e){for(var t=e.length-3,n=new Float32Array(2*t),r=0;t>r;r+=3)n[2*r]=e[r],n[2*r+1]=e[r+1],n[2*r+2]=e[r+2],n[2*r+3]=e[r+3],n[2*r+4]=e[r+4],n[2*r+5]=e[r+5];return gu(cu(i.prototype),"setPositions",this).call(this,n),this}},{key:"setColors",value:function(e){for(var t=e.length-3,n=new Float32Array(2*t),r=0;t>r;r+=3)n[2*r]=e[r],n[2*r+1]=e[r+1],n[2*r+2]=e[r+2],n[2*r+3]=e[r+3],n[2*r+4]=e[r+4],n[2*r+5]=e[r+5];return gu(cu(i.prototype),"setColors",this).call(this,n),this}},{key:"fromLine",value:function(e){var t=e.geometry;if(!t.isGeometry)return t.isBufferGeometry&&this.setPositions(t.attributes.position.array),this;console.error("THREE.LineGeometry no longer supports Geometry. Use THREE.BufferGeometry instead.")}}]),i}(EM);_b.prototype.isLineGeometry=!0;var $b=function(e){lu(i,e);var t=pu(i);function i(){var e,n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:new _b,r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:new xM({color:16777215*Math.random()});return ru(this,i),(e=t.call(this,n,r)).type="Line2",e}return i}(NM);$b.prototype.isLine2=!0;var ek=function(e){lu(i,e);var t=pu(i);function i(){var e,n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};ru(this,i),e=t.call(this);var r=Wg(n.color,16711680),o=n.positions,a=Wg(n.lineWidth,2),s=new _b;s.setPositions(o);var l=new xM({color:r,linewidth:a,dashed:!1,depthTest:!1,depthWrite:!1}),c=new $b(s,l);return c.computeLineDistances(),e.addObject(c),e.line=c,e}return au(i,[{key:"color",get:function(){return this.line.material.color},set:function(e){this.line.material.color=e}},{key:"lineWidth",get:function(){return this.line.material.linewidth},set:function(e){void 0===e&&(e=2),this.line.material.linewidth=e}},{key:"updateFixedFrame",value:function(e){var t=e.bufferSize;this.line.material.resolution.set(t.width,t.height)}}]),i}(Jg),tk=be.EPSILON6;Ke.UNIT_X=Object.freeze(new Ke(1,0,0)),Ke.UNIT_Y=Object.freeze(new Ke(0,1,0)),Ke.UNIT_Z=Object.freeze(new Ke(0,0,1)),Ke.getMaxAbsComponent=function(e,t){var i="x";return Math.abs(e.y)>Math.abs(e.x)&&(i="y"),Math.abs(e.z)>Math.abs(e[i])&&(i="z"),i},Ke.equalsEps=function(e,t){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1e-5;return Math.abs(e.x-t.x)<i&&Math.abs(e.y-t.y)<i&&Math.abs(e.z-t.z)<i},Ke.prototype.equalXEPSILON6=function(e){return Math.abs(this.x-e.x)<tk},Ke.prototype.equalYEPSILON6=function(e){return Math.abs(this.y-e.y)<tk},Ke.prototype.equalZEPSILON6=function(e){return Math.abs(this.z-e.z)<tk};var ik=function(e){lu(i,e);var t=pu(i);function i(){var e,n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return ru(this,i),(e=t.call(this)).element=n.element,e.position.copy(Wg(n.position,new Ke)),e.pixelOffset=Wg(n.pixelOffset,new ke),e.screenPs={x:0,y:0},e.object=n.object,e.isUpdate=!1,e._visible=!0,e._originShow=!0,e}return au(i,[{key:"originShow",get:function(){return this._originShow},set:function(e){jg(this.element)&&(this.element.style.visibility=e?"visible":"hidden"),this._originShow=e}},{key:"visible",get:function(){return this._visible},set:function(e){jg(this.element)&&(this.element.style.visibility=e?"visible":"hidden"),this._visible=e,this._originShow=e}},{key:"setVisible",value:function(e){this.element.style.visibility=e?"visible":"hidden"}},{key:"updateFixedFrame",value:function(e){if(this.isUpdate&&this.visible){var t=e.viewerImpl,i=jg(this.object)?this.object.position:this.position,n=t.worldToCanvas(i);n.x===this.screenPs.x&&n.y===this.screenPs.y||(this.element.style.top=Math.floor(n.y-this.pixelOffset.y)+"px",this.element.style.left=Math.floor(n.x-this.pixelOffset.x)+"px",this.screenPs=n)}}}]),i}(Jg),nk=function(e){lu(i,e);var t=pu(i);function i(){var e,n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return ru(this,i),(e=t.call(this)).viewer=n.viewer,e.renderOrder=1,e.host=e.viewer.host,e.projectorKey=void 0,e.share=void 0,e.distanceUseServer=!1,e._circles=void 0,e._componentKey=void 0,e._direction1=void 0,e._direction2=void 0,e._direction3=void 0,e._directionLength=void 0,e._origin=void 0,e._origin2=void 0,e.circleCollection=new Jg,e.addObject(e.circleCollection),e.circleMap=new Map,e.lineCollection=new Jg,e.addObject(e.lineCollection),e.lineMap=new Map,e.targetSphereMap=new Map,e.targetSphereCollection=new Jg,e.addObject(e.targetSphereCollection),e.originMeshMap=new Map,e.originMeshCollection=new Jg,e.addObject(e.originMeshCollection),e.originMap=new Map,e.originMeshSize=Wg(n.originMeshSize,1),e._radius=50,e.originMeshColor=Wg(n.originMeshColor,new pi(13893887)),e.holeMeshColor=Wg(n.holeMeshColor,new pi(16711680)),e.targetMeshColor=Wg(n.targetMeshColor,new pi(16776960)),e.targetMeshSize=Wg(n.targetMeshSize,1),e.lineWidth=Wg(n.lineWidth,2),e.lineColor=Wg(n.lineColor,new pi(16195999)),e.referencePlaneCollection=new Jg,e.addObject(e.referencePlaneCollection),e.planeMesh1=void 0,e.plane1=new Jt,e.planeMesh2=void 0,e.plane2=new Jt,e.planeMesh3=void 0,e.plane3=new Jt,e._dirOffset1=void 0,e._dirOffset2=void 0,e._dirOffset3=void 0,e.middlePositionMap=new Map,e.distanceMap=new Map,e.lineEndPositionMap=new Map,e.axesDix=void 0,e.elementLength=4,e.holeElement=n.holeElement,jg(e.holeElement)||(e.holeElement=e.createHoleElement()),e.elements=n.elements,jg(e.elements)||(e.elements=e.createDomElements()),e.htmlMarkerCollection=new DE({isAvoid:!0}),e.addObject(e.htmlMarkerCollection),e.createHtmlMarker(),e}return au(i,[{key:"circles",get:function(){return this._circles}},{key:"componentKey",get:function(){return this._componentKey}},{key:"direction1",get:function(){return this._direction1}},{key:"direction2",get:function(){return this._direction2}},{key:"direction3",get:function(){return this._direction3}},{key:"directionLength",get:function(){return this._directionLength}},{key:"origin",get:function(){return this._origin}},{key:"origin2",get:function(){return this._origin2}},{key:"createDomElements",value:function(){for(var e=this.elementLength,t=[],i=0;e>i;i++){var n=document.createElement("div");n.style["border-radius"]="7px",n.style["background-color"]="rgb(255, 255, 255)",n.style.float="right",n.style["text-align"]="center",n.style["font-size"]="12px",n.style["line-height"]="26px",n.style.position="fixed",n.style["z-index"]="999",n.style.width="110px",n.style.height="26px",n.style["pointer-events"]="none",this.viewer.viewportDiv.appendChild(n),t.push(n)}return t[0].style.color="rgb(236, 69, 69)",t[1].style.color="rgb(69, 195, 69)",t[2].style.color="rgb(87, 87, 218)",t[3].style.color="rgb(218, 87, 196)",t}},{key:"createHoleElement",value:function(){var e=document.createElement("div");return e.style["border-radius"]="50%",e.style["background-color"]="rgb(255, 255, 0)",e.style.position="fixed",e.style["z-index"]="999",e.style.width="26px",e.style.height="26px",e.style["pointer-events"]="none",this.holeElement=e,this.viewer.viewportDiv.appendChild(e),e}},{key:"createHtmlMarker",value:function(){var e=this.holeElement,t=new ik({element:e,position:new Ke,pixelOffset:new ke(e.clientWidth/2,e.clientHeight/2)});t.isUpdate=!0,this.htmlMarkerCollection.addObject(t);for(var i=0;this.elementLength>i;i++){var n=this.elements[i],r=new ik({element:n,position:new Ke,pixelOffset:new ke(n.clientWidth/2,n.clientHeight/2)});r.isUpdate=!0,this.htmlMarkerCollection.addObject(r)}}},{key:"getMiddlePosition",value:function(e){return this.middlePositionMap.get(e)}},{key:"getDistance",value:function(e){return this.distanceMap.get(e)}},{key:"getOrigin",value:function(e){return this.originMap.get(e)}},{key:"computeMiddlePositionDistance",value:function(e){if(!jg(this.getMiddlePosition(e))){var t=this.getHoleInfo(e),i=(new Ke).set(t.center[0],t.center[1],t.center[2]),n=this.plane1.distanceToPoint(i),r=this.plane2.distanceToPoint(i),o=(new Ke).copy(i).add((new Ke).copy(this.direction2).multiplyScalar(n).multiplyScalar(-1)),a=(new Ke).copy(o).add(this._dirOffset2),s=(new Ke).copy(i).add((new Ke).copy(this.direction3).multiplyScalar(r).multiplyScalar(-1)),l=(new Ke).copy(s).add(this._dirOffset3);this.middlePositionMap.set(e,[(new Ke).addVectors(i,o).multiplyScalar(.5),(new Ke).addVectors(i,a).multiplyScalar(.5),(new Ke).addVectors(i,s).multiplyScalar(.5),(new Ke).addVectors(i,l).multiplyScalar(.5)]),this.lineEndPositionMap.set(e,[o,a,s,l]),this.distanceMap.set(e,[i.distanceTo(o),i.distanceTo(a),i.distanceTo(s),i.distanceTo(l)])}}},{key:"showOriginMesh",value:function(e){var t=1>=arguments.length||void 0===arguments[1]||arguments[1],i=this.originMeshMap.get(e),n=this.originMap.get(e);if(jg(i))for(var r=0,o=n.length;o>r;r++){var a=i[r];a.visible=t,a.position.copy(n[r]),a.updateMatrixWorld()}else{for(var s=[],l=0,c=n.length;c>l;l++){var h=this.createSphereMesh(this._radius*this.originMeshSize);this.originMeshCollection.addObject(h),h.position.copy(n[l]),h.updateMatrixWorld(),s.push(h)}this.originMeshMap.set(e,s)}}},{key:"createSphereMesh",value:function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this.originMeshColor,i=new Ks(e,32,32),n=new gi({color:t,depthTest:!1,side:2}),r=new nn(i,n);return r}},{key:"getHolesDataByComponentKey",value:function(e){var t=this;if(!jg(this.projectorKey)){var i=this.viewer.getViewerImpl().getModelByComponentKey(e);this.projectorKey=i.projectKey,this.share=""===i.shareKey?"":"&share="+i.shareKey}return this.fetchData(e).then((function(i){t.parse(i,e)}))}},{key:"fetchData",value:function(e){var t=this;return new Promise((function(i,n){var r="".concat(t.host,"/api/").concat(t.projectorKey,"/components/holes?componentKey=").concat(e).concat(t.share),o=new Bl;o.setResponseType("json"),o.load(r,(function(e){i(e)}))}))}},{key:"parse",value:function(e,t){if(jg(e=e.data)&&jg(e.circles)){this._componentKey=e.componentKey,this._direction1=(new Ke).fromArray(e.direction1),this._direction1.normalize(),this._direction2=(new Ke).fromArray(e.direction2),this._direction2.normalize(),this._direction3=(new Ke).fromArray(e.direction3),this._direction3.normalize(),this._directionLength=(new Ke).fromArray(e.directionLength);var i=(new Ke).fromArray(e.origin);if(!jg(this.axesDix)){var n=this.viewer.getViewerImpl().getModelByComponentKey(t).getBoundingBoxWorld().getCenter(new Ke);this.axesDix=new Ke(1,1,1),this.axesDix.x=Math.sign(n.x)*Math.sign(i.x),this.axesDix.y=Math.sign(n.y)*Math.sign(i.y),this.axesDix.z=Math.sign(n.z)*Math.sign(i.z)}var r=this.axesDix.x,o=this.axesDix.y,a=this.axesDix.z;this._circles=e.circles.map((function(e){return e})),i.x*=r,i.y*=o,i.y*=a;var s=(new Ke).copy(i),l=this.directionLength;this._dirOffset1=(new Ke).copy(this.direction1).multiplyScalar(l.x),this._dirOffset2=(new Ke).copy(this.direction2).multiplyScalar(Number(l.y)),this._dirOffset3=(new Ke).copy(this.direction3).multiplyScalar(Number(l.z)),s.add(this._dirOffset2),s.add(this._dirOffset3),this.originMap.set(t,[i,s]),this.parseReferencePlane(t)}else console.warn("当前构件无圆孔数据!")}},{key:"createCircle",value:function(e){var t=e.center,i=new qa(e.radius,32),n=new gi({color:this.holeMeshColor,depthTest:!1,side:2}),r=new nn(i,n);return r.position.set(t[0],t[1],t[2]),r.updateMatrixWorld(),this.circleCollection.addObject(r),r}},{key:"getHoleKeys",value:function(){return this.circles.map((function(e){return e.key}))}},{key:"getHoleInfo",value:function(e){return this.circles.find((function(t){return t.key===e}))}},{key:"getHoleCenter",value:function(e){var t=this.getHoleInfo(e);if(jg(t))return(new Ke).fromArray(t.center)}},{key:"showHoleByKey",value:function(e){var t=1>=arguments.length||void 0===arguments[1]||arguments[1];t?this._showHole(e):this._hideHole(e)}},{key:"removeHoleByKey",value:function(e){var t=this.circleMap.get(e);jg(t)&&(this.circleCollection.removeObject(t),this.circleMap.delete(e))}},{key:"_showHole",value:function(e){if(this.circleMap.has(e)){this.circleMap.get(e).visible=!0}else{var t=this.getHoleInfo(e);jg(t)||console.warn("未找到该圆孔信息");var i=this.createCircle(t);this.circleMap.set(e,i)}}},{key:"_hideHole",value:function(e){if(this.circleMap.has(e)){var t=this.circleMap.get(e);this.circleCollection.removeObject(t),this.circleMap.delete(e)}}},{key:"showAllHoles",value:function(){var e,t=0>=arguments.length||void 0===arguments[0]||arguments[0],i=this.getHoleKeys(),n=vu(i);try{for(n.s();!(e=n.n()).done;){var r=e.value;this.showHoleByKey(r,t)}}catch(e){n.e(e)}finally{n.f()}}},{key:"removeAllHoles",value:function(){var e,t=vu(this.getHoleKeys());try{for(t.s();!(e=t.n()).done;){this.removeHoleByKey(e.value,value)}}catch(e){t.e(e)}finally{t.f()}}},{key:"createPlaneByPointsAndNormal",value:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},t=e.points[0],i=e.points[1],n=e.normal,r=Wg(e.color,16711680),o=(new Ke).addVectors(t,i).multiplyScalar(.5),a=t.distanceTo(i),s=Wg(e.height,a),l=new In(a,s),c=new gi({color:r,depthTest:!1,side:2,transparent:!0,opacity:.6}),h=new nn(l,c);return h.lookAt(n),h.position.copy(o),h.position.z+=s/2,h.updateMatrixWorld(),this.referencePlaneCollection.addObject(h),h}},{key:"parseReferencePlane",value:function(e){var t=this.getOrigin(e)[0],i=(new Ke).copy(this._dirOffset2).normalize();this.plane1.setFromNormalAndCoplanarPoint(i,(new Ke).copy(t));var n=(new Ke).copy(this._dirOffset3).normalize();this.plane2.setFromNormalAndCoplanarPoint(n,(new Ke).copy(t)),this.plane3.setFromNormalAndCoplanarPoint((new Ke).copy(this.direction1),(new Ke).copy(t))}},{key:"createLineTargetPoint",value:function(e,t){var i=new ek({positions:[e.x,e.y,e.z,t.x,t.y,t.z],color:this.lineColor,lineWidth:this.lineWidth});return this.lineCollection.addObject(i),i}},{key:"createTargetSphere",value:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},t=e.radius,i=e.position,n=e.collection,r=this.createSphereMesh(t,this.targetMeshColor);return r.position.copy(i),r.updateMatrixWorld(),n.addObject(r),r}},{key:"showLineByKey",value:function(e){var t=1>=arguments.length||void 0===arguments[1]||arguments[1];if(jg(this.lineMap.get(e))){var i=this.lineMap.get(e),n=this.targetSphereMap.get(e);return i.forEach((function(e){e.visible=t})),void n.forEach((function(e){e.visible=t}))}if(t){var r=this.getHoleInfo(e);this.computeMiddlePositionDistance(e);for(var o=(new Ke).set(r.center[0],r.center[1],r.center[2]),a=this.lineEndPositionMap.get(e),s=[],l=[],c=0;4>c;c++){var h=a[c],d=this.createLineTargetPoint(o,h),u=this.createTargetSphere({radius:r.radius*this.targetMeshSize,position:h,collection:this.targetSphereCollection});s.push(d),l.push(u)}this.lineMap.set(e,s),this.targetSphereMap.set(e,l)}}},{key:"removeLineByKey",value:function(e){var t=this.lineMap.get(e);if(jg(t)){for(var i=0,n=t.length;n>i;i++)this.lineCollection.removeObject(t[i]);this.lineMap.delete(e)}}},{key:"removeTargetSphereByKey",value:function(e){var t=this.targetSphereMap.get(e);if(jg(t)){for(var i=0,n=t.length;n>i;i++)this.targetSphereCollection.removeObject(t[i]);this.targetSphereMap.delete(e)}}},{key:"showHoleObjectByKey",value:function(e){var t=1>=arguments.length||void 0===arguments[1]||arguments[1];if(this.showHoleByKey(e,t),this.showLineByKey(e,t),this.htmlMarkerCollection.visible=t,t){var i=this.getHoleInfo(e).center,n=this.htmlMarkerCollection.get(0);n.position.set(i[0],i[1],i[2]);for(var r=this.getDistance(e),o=this.getMiddlePosition(e),a=0;this.elementLength>a;a++){var s=this.htmlMarkerCollection.get(a+1);s.position.copy(o[a]),s.element.innerText=r[a].toFixed(2)+"mm"}}}},{key:"removeHoloObjectByKey",value:function(e){this.removeLineByKey(e),this.removeTargetSphereByKey(e),this.removeHoleByKey(e)}},{key:"removeAllHoloObjects",value:function(){for(var e=Array.from(this.circleMap.keys()),t=0,i=e.length;i>t;t++)this.removeHoloObjectByKey(e[t])}},{key:"updateLineWidthByKey",value:function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this.lineWidth,i=this.lineMap.get(e);if(jg(i))for(var n=0,r=i.length;r>n;n++)i[n].lineWidth=t}},{key:"updateLineColorByKey",value:function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this.lineColor,i=this.lineMap.get(e);if(jg(i))for(var n=0,r=i.length;r>n;n++)i[n].color=t}},{key:"updateHoleColorByKey",value:function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this.holeMeshColor,i=this.circleMap.get(e);jg(i)&&(i.material.color=t)}},{key:"updateOriginMeshSizeByComponentKey",value:function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this.originMeshSize,i=this.originMeshMap.get(e);if(jg(i)&&0!==i.length){var n,r=vu(i);try{for(r.s();!(n=r.n()).done;){var o=n.value;o.scale.set(t,t,t),o.updateMatrixWorld()}}catch(e){r.e(e)}finally{r.f()}}}},{key:"updateOriginMeshColorByComponentKey",value:function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this.originMeshColor,i=this.originMeshMap.get(e);if(jg(i)&&0!==i.length){var n,r=vu(i);try{for(r.s();!(n=r.n()).done;){var o=n.value;o.material.color=t}}catch(e){r.e(e)}finally{r.f()}}}},{key:"updateTargetMeshColorByKey",value:function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this.targetMeshColor,i=this.targetSphereMap.get(e);if(jg(i)&&0!==i.length){var n,r=vu(i);try{for(r.s();!(n=r.n()).done;){var o=n.value;o.material.color=t}}catch(e){r.e(e)}finally{r.f()}}}},{key:"updateTargetMeshSizeByKey",value:function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this.targetMeshSize,i=this.targetSphereMap.get(e);if(jg(i)&&0!==i.length){var n,r=vu(i);try{for(r.s();!(n=r.n()).done;){var o=n.value;o.scale.set(t,t,t),o.updateMatrixWorld()}}catch(e){r.e(e)}finally{r.f()}}}},{key:"updateFixedFrame",value:function(e,t){this.circleCollection.updateFixedFrame(e),this.lineCollection.updateFixedFrame(e),this.targetSphereCollection.updateFixedFrame(e),this.originMeshCollection.updateFixedFrame(e),this.referencePlaneCollection.updateFixedFrame(e),this.htmlMarkerCollection.updateFixedFrame(e)}}]),i}(Jg),rk=function(e){lu(i,e);var t=pu(i);function i(e,n){var r;return ru(this,i),(r=t.call(this,e,n)).pointIds=[],r}return i}(Ya);rk.prototype.raycast=function(){var e=new yt,t=new At,i=new ct;return function(n,r){var o=this,a=this.geometry,s=this.matrixWorld,l=this.size,c=n.camera||n._camera,h=n.viewportSize.height,d=this.pointIds;function u(t,i){var n=t.clone();return n.applyMatrix4(s),n.project(c),n.y+=i/h,n.unproject(c),n.applyMatrix4(e),n}e.copy(s).invert(),null===a.boundingSphere&&a.computeBoundingSphere(),i.copy(a.boundingSphere);var p=i.center,g=u(p,l),f=g.distanceToSquared(p);if(i.radius+=f,i.center.copy(g),i.applyMatrix4(s),!1!==n.ray.intersectsSphere(i)){t.copy(n.ray).applyMatrix4(e);var m=new Ke,A=l;if(a.isBufferGeometry){var y=a.index,v=a.attributes,C=v.position.array,I=!1,x=null;if(v.attrSize&&(I=!0,x=v.attrSize.array),null!==y)for(var w=y.array,M=0,E=w.length;E>M;M+=1){var B=w[M];m.fromArray(C,3*B),I&&(A=x[B]),k(m,A,B)}else{M=0;for(var S=C.length/3;S>M;M+=1)m.fromArray(C,3*M),I&&(A=x[M]),k(m,A,M)}}else{var b=a.vertices;for(M=0,S=b.length;S>M;M+=1)k(b[M],A,M)}}function k(e,i,a){var l=u(e,i),c=l.distanceToSquared(e),h=t.distanceSqToPoint(l);if(c>h){var p=t.closestPointToPoint(l,new Ke);p.applyMatrix4(s);var g=n.ray.origin.distanceTo(p);if(n.near>g||g>n.far)return;r.push({id:d[a],distance:g,distanceToRay:Math.sqrt(h),point:p.clone(),index:a,face:null,object:o})}}}}(),rk.prototype.setAttributeSize=function(e,t){var i=this.geometry.attributes;i.attrSize&&(i.attrSize.array[e]=t,i.attrSize.needsUpdate=!0)},rk.prototype.getAttributeSize=function(e){var t=this.geometry.attributes,i=this.size;return t.attrSize&&(i=t.attrSize.array[e]),i};var ok=["attribute vec3 customColor;","attribute float customOpacity;","attribute float customSize;","attribute float customAngle;","attribute float customVisible;","varying vec4 vColor;","varying float vAngle;","void main()","{","if ( customVisible > 0.5 )","vColor = vec4( customColor, customOpacity );","else","vColor = vec4(0.0, 0.0, 0.0, 0.0);","vAngle = customAngle;","vec4 mvPosition = modelViewMatrix * vec4( position, 1.0 );","gl_PointSize = customSize * ( 3000.0 / length( mvPosition.xyz ) );","gl_Position = projectionMatrix * mvPosition;","}"].join("\n"),ak=["uniform sampler2D texture;","varying vec4 vColor;","varying float vAngle;","void main()","{","gl_FragColor = vColor;","float c = cos(vAngle);","float s = sin(vAngle);","vec2 rotatedUV = vec2(c * (gl_PointCoord.x - 0.5) + s * (gl_PointCoord.y - 0.5) + 0.5,","c * (gl_PointCoord.y - 0.5) - s * (gl_PointCoord.x - 0.5) + 0.5);","vec4 rotatedTexture = texture2D( texture, rotatedUV );","gl_FragColor = gl_FragColor * rotatedTexture;","}"].join("\n");function sk(e,t){this.times=e||[],this.values=t||[]}function lk(){this.position=new Ke,this.velocity=new Ke,this.acceleration=new Ke,this.angle=0,this.angleVelocity=0,this.angleAcceleration=0,this.size=16,this.color=new pi,this.opacity=1,this.age=0,this.alive=0;var e=Math.random()>.5?-1*Math.random():Math.random(),t=Math.random()>.5?-1*Math.random():Math.random(),i=Math.random()>.65?-1*Math.random():Math.random();this.direction=new Ke(e,t,i).normalize()}function ck(){this.positionStyle=1,this.positionBase=new Ke,this.positionSpread=new Ke,this.positionRadius=0,this.velocityStyle=1,this.velocityBase=new Ke,this.velocitySpread=new Ke,this.speedBase=0,this.speedSpread=0,this.accelerationBase=new Ke,this.accelerationSpread=new Ke,this.angleBase=0,this.angleSpread=0,this.angleVelocityBase=0,this.angleVelocitySpread=0,this.angleAccelerationBase=0,this.angleAccelerationSpread=0,this.sizeBase=0,this.sizeSpread=0,this.sizeTween=new sk,this.colorBase=new Ke(0,1,.5),this.colorSpread=new Ke(0,0,0),this.colorTween=new sk,this.opacityBase=1,this.opacitySpread=0,this.opacityTween=new sk,this.blendStyle=1,this.particleArray=[],this.particlesPerSecond=100,this.particleDeathAge=1,this.emitterAge=0,this.emitterAlive=!0,this.emitterDeathAge=60,this.particleCount=this.particlesPerSecond*Math.min(this.particleDeathAge,this.emitterDeathAge)}sk.prototype.lerp=function(e,t){for(var i=0,n=this.times.length;n>i&&e>this.times[i];)i+=1;if(0===i)return this.values[0];if(i===n)return this.values[n-1];var r=(e-this.times[i-1])/(this.times[i]-this.times[i-1]);return this.values[0]instanceof Ke?this.values[i-1].clone().lerp(this.values[i],r):this.values[i-1]+r*(this.values[i]-this.values[i-1])},lk.prototype.update=function(e){var t=function(e){return e=e>1?1:e,1-Math.pow(1-e,3)}(this.age);if(1>t?(this.position.x+=500*this.direction.x*(1-t),this.position.y+=500*this.direction.y*(1-t),this.position.z+=300*this.direction.z*(1-t)):(this.position.x+=3*this.direction.x,this.position.y+=3*this.direction.y,this.position.z+=1.8*this.direction.z),this.angle+=.01745329251*this.angleVelocity*e,this.angleVelocity+=.01745329251*this.angleAcceleration*e,this.age+=e,this.sizeTween.times.length>0&&(this.size=this.sizeTween.lerp(this.age)),this.colorTween.times.length>0){var i=this.colorTween.lerp(this.age);this.color=(new pi).setHSL(i.x,i.y,i.z)}this.opacityTween.times.length>0&&(this.opacity=this.opacityTween.lerp(this.age))},ck.prototype.setValues=function(e){if(void 0!==e){for(var t in this.sizeTween=new sk,this.colorTween=new sk,this.opacityTween=new sk,e)this[t]=e[t];this.particleArray=[],this.emitterAlive=!0,this.particleCount=this.particlesPerSecond*Math.min(this.particleDeathAge,this.emitterDeathAge),this.particleGeometry=new Ni,this.particleMaterial=new cn({uniforms:{texture:{value:this.particleTexture}},vertexShader:ok,fragmentShader:ak,transparent:!0,blending:1,depthWrite:!1}),this.particleMesh=new rk,this.originSizeTween=new sk,this.originSizeTween.times=this.sizeTween.times.concat(),this.originSizeTween.values=this.sizeTween.values.concat()}},ck.prototype.randomValue=function(e,t){return e+t*(Math.random()-.5)},ck.prototype.randomVector3=function(e,t){var i=new Ke(Math.random()-.5,Math.random()-.5,Math.random()-.5);return(new Ke).addVectors(e,i.multiplyVectors(t,i))},ck.prototype.updateVector3=function(e,t,i){var n=new Ke(Math.random()-.5,Math.random()-.5,Math.random()-.5);e.set(0,0,0),e.addVectors(t,n.multiplyVectors(i,n))},ck.prototype.createParticle=function(){var e=new lk;if(1===this.positionStyle&&(e.position=this.randomVector3(this.positionBase,this.positionSpread)),2===this.positionStyle){var t=2*Math.random()-1,i=6.2832*Math.random(),n=Math.sqrt(1-t*t),r=new Ke(n*Math.cos(i),n*Math.sin(i),t);e.position=(new Ke).addVectors(this.positionBase,r.multiplyScalar(this.positionRadius))}if(1===this.velocityStyle&&(e.velocity=this.randomVector3(this.velocityBase,this.velocitySpread)),2===this.velocityStyle){var o=(new Ke).subVectors(e.position,this.positionBase),a=this.randomValue(this.speedBase,this.speedSpread);e.velocity=o.normalize().multiplyScalar(a)}e.acceleration=this.randomVector3(this.accelerationBase,this.accelerationSpread),e.angle=this.randomValue(this.angleBase,this.angleSpread),e.angleVelocity=this.randomValue(this.angleVelocityBase,this.angleVelocitySpread),e.angleAcceleration=this.randomValue(this.angleAccelerationBase,this.angleAccelerationSpread),e.size=this.randomValue(this.sizeBase,this.sizeSpread);var s=this.randomVector3(this.colorBase,this.colorSpread);return e.color=(new pi).setHSL(s.x,s.y,s.z),e.opacity=this.randomValue(this.opacityBase,this.opacitySpread),e.age=0,e.alive=0,e.sizeTween=this.sizeTween,e.colorTween=this.colorTween,e.opacityTween=this.opacityTween,e},ck.prototype.updateParticle=function(e){if(1===this.positionStyle&&this.updateVector3(e.position,this.positionBase,this.positionSpread),2===this.positionStyle){var t=2*Math.random()-1,i=6.2832*Math.random(),n=Math.sqrt(1-t*t),r=new Ke(n*Math.cos(i),n*Math.sin(i),t);e.position=(new Ke).addVectors(this.positionBase,r.multiplyScalar(this.positionRadius))}if(1===this.velocityStyle&&this.updateVector3(e.velocity,this.velocityBase,this.velocitySpread),2===this.velocityStyle){var o=(new Ke).subVectors(e.position,this.positionBase),a=this.randomValue(this.speedBase,this.speedSpread);e.velocity=o.normalize().multiplyScalar(a)}this.updateVector3(e.acceleration,this.accelerationBase,this.accelerationSpread),e.angle=this.randomValue(this.angleBase,this.angleSpread),e.angleVelocity=this.randomValue(this.angleVelocityBase,this.angleVelocitySpread),e.angleAcceleration=this.randomValue(this.angleAccelerationBase,this.angleAccelerationSpread),e.size=this.randomValue(this.sizeBase,this.sizeSpread);var s=this.randomVector3(this.colorBase,this.colorSpread);e.color=e.color.setHSL(s.x,s.y,s.z),e.opacity=this.randomValue(this.opacityBase,this.opacitySpread),e.age=0,e.alive=0},ck.prototype.initialize=function(){this.sortArray=[],this.positions=new Float32Array(3*this.particleCount),this.customVisible=new Float32Array(this.particleCount),this.customSize=new Float32Array(this.particleCount),this.customColor=new Float32Array(3*this.particleCount),this.customOpacity=new Float32Array(this.particleCount),this.maxSize=200,this.particleArray=[];for(var e=0;this.particleCount>e;e+=1)this.particleArray[e]=this.createParticle(),this.positions[3*e]=this.particleArray[e].position.x,this.positions[3*e+1]=this.particleArray[e].position.y,this.positions[3*e+2]=this.particleArray[e].position.z,this.customVisible[e]=this.particleArray[e].alive,this.customColor[3*e]=this.particleArray[e].color.r,this.customColor[3*e+1]=this.particleArray[e].color.g,this.customColor[3*e+2]=this.particleArray[e].color.b,this.customOpacity[e]=this.particleArray[e].opacity,this.customSize[e]=this.particleArray[e].size,this.maxSize=this.maxSize>this.customSize[e]?this.maxSize:this.customSize[e];this.particleMaterial.blending=this.blendStyle,this.particleGeometry.setAttribute("position",new Ai(this.positions,3)),this.particleGeometry.setAttribute("customColor",new Ai(this.customColor,3)),this.particleGeometry.setAttribute("customVisible",new Ai(this.customVisible,1)),this.particleGeometry.setAttribute("customSize",new Ai(this.customSize,1)),this.particleGeometry.setAttribute("customOpacity",new Ai(this.customOpacity,1)),this.particleMesh=new rk(this.particleGeometry,this.particleMaterial),this.particleMesh.dynamic=!0,this.particleMesh.size=this.maxSize,this.particleMesh.renderOrder=-1},ck.prototype.update=function(e){e=void 0===e?.015:e;for(var t=0;this.particleCount>t;t+=1)this.particleArray[t].alive&&(this.particleArray[t].update(e),this.particleArray[t].age>this.particleDeathAge&&(this.particleArray[t].alive=0),this.customVisible[t]=this.particleArray[t].alive,this.customOpacity[t]=this.particleArray[t].opacity,this.customSize[t]=this.particleArray[t].size,this.customColor[3*t]=this.particleArray[t].color.r,this.customColor[3*t+1]=this.particleArray[t].color.g,this.customColor[3*t+2]=this.particleArray[t].color.b,this.positions[3*t]=this.particleArray[t].position.x,this.positions[3*t+1]=this.particleArray[t].position.y,this.positions[3*t+2]=this.particleArray[t].position.z,this.maxSize=this.maxSize>this.customSize[t]?this.maxSize:this.customSize[t]);this.particleGeometry.getAttribute("customVisible").needsUpdate=!0,this.particleGeometry.getAttribute("customOpacity").needsUpdate=!0,this.particleGeometry.getAttribute("customSize").needsUpdate=!0,this.particleGeometry.getAttribute("customColor").needsUpdate=!0,this.particleGeometry.getAttribute("position").needsUpdate=!0},ck.prototype.setScale=function(e){for(var t=0,i=this.sizeTween.values.length;i>t;t+=1)this.sizeTween.values[t]=this.originSizeTween.values[t]*e;this.maxSize*=e},ck.prototype.setScaleValue=function(e,t){this.sizeTween.values=t.values.concat(),this.sizeTween.times=t.times.concat(),this.maxSize=e},ck.prototype.initializeSizetween=function(e){for(var t=0,i=this.sizeTween.values.length;i>t;t+=1)this.sizeTween.values[t]=this.sizeTween.values[t]*e;for(t=0;this.particleCount>t;t+=1)this.particleArray[t].size*=e,this.customSize[t]=this.particleArray[t].size,this.maxSize=this.maxSize>this.customSize[t]?this.maxSize:this.customSize[t];this.particleGeometry.getAttribute("customSize").needsUpdate=!0},ck.prototype.destroy=function(){},ck.prototype.setVisible=function(){this.particleArray.forEach((function(e){e.alive=1}))};var hk=["attribute vec3 customColor;","attribute float customOpacity;","attribute float customSize;","attribute float customAngle;","attribute float customVisible;","varying vec4 vColor;","varying float vAngle;","void main()","{","if ( customVisible > 0.5 )","vColor = vec4( customColor, customOpacity );","else","vColor = vec4(0.0, 0.0, 0.0, 0.0);","vAngle = customAngle;","vec4 mvPosition = modelViewMatrix * vec4( position, 1.0 );","gl_PointSize = customSize * ( 3000.0 / length( mvPosition.xyz ) );","gl_Position = projectionMatrix * mvPosition;","}"].join("\n"),dk=["uniform sampler2D texture;","varying vec4 vColor;","varying float vAngle;","void main()","{","gl_FragColor = vColor;","float c = cos(vAngle);","float s = sin(vAngle);","vec2 rotatedUV = vec2(c * (gl_PointCoord.x - 0.5) + s * (gl_PointCoord.y - 0.5) + 0.5,","c * (gl_PointCoord.y - 0.5) - s * (gl_PointCoord.x - 0.5) + 0.5);","vec4 rotatedTexture = texture2D( texture, rotatedUV );","gl_FragColor = gl_FragColor * rotatedTexture;","}"].join("\n");function uk(e,t){this.times=e||[],this.values=t||[]}function pk(){this.position=new Ke,this.velocity=new Ke,this.acceleration=new Ke,this.angle=0,this.angleVelocity=0,this.angleAcceleration=0,this.size=16,this.color=new pi,this.opacity=1,this.age=0,this.alive=0}function gk(){this.positionStyle=1,this.positionBase=new Ke,this.positionSpread=new Ke,this.positionRadius=0,this.velocityStyle=1,this.velocityBase=new Ke,this.velocitySpread=new Ke,this.speedBase=0,this.speedSpread=0,this.accelerationBase=new Ke,this.accelerationSpread=new Ke,this.angleBase=0,this.angleSpread=0,this.angleVelocityBase=0,this.angleVelocitySpread=0,this.angleAccelerationBase=0,this.angleAccelerationSpread=0,this.sizeBase=0,this.sizeSpread=0,this.sizeTween=new uk,this.colorBase=new Ke(0,1,.5),this.colorSpread=new Ke(0,0,0),this.colorTween=new uk,this.opacityBase=1,this.opacitySpread=0,this.opacityTween=new uk,this.blendStyle=1,this.particleArray=[],this.particlesPerSecond=100,this.particleDeathAge=1,this.emitterAge=0,this.emitterAlive=!0,this.emitterDeathAge=60,this.particleCount=this.particlesPerSecond*Math.min(this.particleDeathAge,this.emitterDeathAge)}uk.prototype.lerp=function(e){for(var t=0,i=this.times.length;i>t&&e>this.times[t];)t+=1;if(0===t)return this.values[0];if(t===i)return this.values[i-1];var n=(e-this.times[t-1])/(this.times[t]-this.times[t-1]);return this.values[0]instanceof Ke?this.values[t-1].clone().lerp(this.values[t],n):this.values[t-1]+n*(this.values[t]-this.values[t-1])},pk.prototype.update=function(e){if(this.position.add(this.velocity.clone().multiplyScalar(e)),this.velocity.add(this.acceleration.clone().multiplyScalar(e)),this.angle+=.01745329251*this.angleVelocity*e,this.angleVelocity+=.01745329251*this.angleAcceleration*e,this.age+=e,this.sizeTween.times.length>0&&(this.size=this.sizeTween.lerp(this.age)),this.colorTween.times.length>0){var t=this.colorTween.lerp(this.age);this.color=(new pi).setHSL(t.x,t.y,t.z)}this.opacityTween.times.length>0&&(this.opacity=this.opacityTween.lerp(this.age))},gk.prototype.setValues=function(e){if(void 0!==e){for(var t in this.sizeTween=new uk,this.colorTween=new uk,this.opacityTween=new uk,e)this[t]=e[t];this.particleArray=[],this.emitterAlive=!0,this.particleCount=this.particlesPerSecond*Math.min(this.particleDeathAge,this.emitterDeathAge),this.particleGeometry=new Ni,this.particleMaterial=new cn({uniforms:{texture:{value:this.particleTexture}},vertexShader:hk,fragmentShader:dk,transparent:!0,blending:1,depthWrite:!1}),this.particleMesh=new rk}},gk.prototype.randomValue=function(e,t){return e+t*(Math.random()-.5)},gk.prototype.randomVector3=function(e,t){var i=new Ke(Math.random()-.5,Math.random()-.5,Math.random()-.5);return(new Ke).addVectors(e,i.multiplyVectors(t,i))},gk.prototype.updateVector3=function(e,t,i){var n=new Ke(Math.random()-.5,Math.random()-.5,Math.random()-.5);e.set(0,0,0),e.addVectors(t,n.multiplyVectors(i,n))},gk.prototype.createParticle=function(){var e=new pk;if(1===this.positionStyle&&(e.position=this.randomVector3(this.positionBase,this.positionSpread)),2===this.positionStyle){var t=2*Math.random()-1,i=6.2832*Math.random(),n=Math.sqrt(1-t*t),r=new Ke(n*Math.cos(i),n*Math.sin(i),t);e.position=(new Ke).addVectors(this.positionBase,r.multiplyScalar(this.positionRadius))}if(1===this.velocityStyle&&(e.velocity=this.randomVector3(this.velocityBase,this.velocitySpread)),2===this.velocityStyle){var o=(new Ke).subVectors(e.position,this.positionBase),a=this.randomValue(this.speedBase,this.speedSpread);e.velocity=o.normalize().multiplyScalar(a)}e.acceleration=this.randomVector3(this.accelerationBase,this.accelerationSpread),e.angle=this.randomValue(this.angleBase,this.angleSpread),e.angleVelocity=this.randomValue(this.angleVelocityBase,this.angleVelocitySpread),e.angleAcceleration=this.randomValue(this.angleAccelerationBase,this.angleAccelerationSpread),e.size=this.randomValue(this.sizeBase,this.sizeSpread);var s=this.randomVector3(this.colorBase,this.colorSpread);return e.color=(new pi).setHSL(s.x,s.y,s.z),e.opacity=this.randomValue(this.opacityBase,this.opacitySpread),e.age=0,e.alive=0,e.sizeTween=this.sizeTween,e.colorTween=this.colorTween,e.opacityTween=this.opacityTween,e},gk.prototype.updateParticle=function(e){if(1===this.positionStyle&&this.updateVector3(e.position,this.positionBase,this.positionSpread),2===this.positionStyle){var t=2*Math.random()-1,i=6.2832*Math.random(),n=Math.sqrt(1-t*t),r=new Ke(n*Math.cos(i),n*Math.sin(i),t);e.position=(new Ke).addVectors(this.positionBase,r.multiplyScalar(this.positionRadius))}if(1===this.velocityStyle&&this.updateVector3(e.velocity,this.velocityBase,this.velocitySpread),2===this.velocityStyle){var o=(new Ke).subVectors(e.position,this.positionBase),a=this.randomValue(this.speedBase,this.speedSpread);e.velocity=o.normalize().multiplyScalar(a)}this.updateVector3(e.acceleration,this.accelerationBase,this.accelerationSpread),e.angle=this.randomValue(this.angleBase,this.angleSpread),e.angleVelocity=this.randomValue(this.angleVelocityBase,this.angleVelocitySpread),e.angleAcceleration=this.randomValue(this.angleAccelerationBase,this.angleAccelerationSpread),e.size=this.randomValue(this.sizeBase,this.sizeSpread);var s=this.randomVector3(this.colorBase,this.colorSpread);e.color=e.color.setHSL(s.x,s.y,s.z),e.opacity=this.randomValue(this.opacityBase,this.opacitySpread),e.age=0,e.alive=0},gk.prototype.initialize=function(){this.sortArray=[],this.positions=new Float32Array(3*this.particleCount),this.customVisible=new Float32Array(this.particleCount),this.customSize=new Float32Array(this.particleCount),this.customColor=new Float32Array(3*this.particleCount),this.customOpacity=new Float32Array(this.particleCount),this.maxSize=200;for(var e=0;this.particleCount>e;e+=1)this.particleArray[e]=this.createParticle(),this.positions[3*e]=this.particleArray[e].position.x,this.positions[3*e+1]=this.particleArray[e].position.y,this.positions[3*e+2]=this.particleArray[e].position.z,this.customVisible[e]=this.particleArray[e].alive,this.customColor[3*e]=this.particleArray[e].color.r,this.customColor[3*e+1]=this.particleArray[e].color.g,this.customColor[3*e+2]=this.particleArray[e].color.b,this.customOpacity[e]=this.particleArray[e].opacity,this.customSize[e]=this.particleArray[e].size,this.maxSize=this.maxSize>this.customSize[e]?this.maxSize:this.customSize[e];this.particleMaterial.blending=this.blendStyle,this.particleGeometry.setAttribute("position",new Ai(this.positions,3)),this.particleGeometry.setAttribute("customColor",new Ai(this.customColor,3)),this.particleGeometry.setAttribute("customVisible",new Ai(this.customVisible,1)),this.particleGeometry.setAttribute("customSize",new Ai(this.customSize,1)),this.particleGeometry.setAttribute("customOpacity",new Ai(this.customOpacity,1)),this.particleMesh=new rk(this.particleGeometry,this.particleMaterial),this.particleMesh.dynamic=!0,this.particleMesh.size=this.maxSize,this.particleMesh.renderOrder=-1},gk.prototype.update=function(e){if(this.particleMesh&&this.particleMesh.visible){e=void 0===e?.015:e;for(var t=[],i=0;this.particleCount>i;i+=1)this.particleArray[i].alive&&(this.particleArray[i].update(e),this.particleArray[i].age>this.particleDeathAge&&(this.particleArray[i].alive=0,t.push(i)),this.customVisible[i]=this.particleArray[i].alive,this.customOpacity[i]=this.particleArray[i].opacity,this.customSize[i]=this.particleArray[i].size,this.customColor[3*i]=this.particleArray[i].color.r,this.customColor[3*i+1]=this.particleArray[i].color.g,this.customColor[3*i+2]=this.particleArray[i].color.b,this.positions[3*i]=this.particleArray[i].position.x,this.positions[3*i+1]=this.particleArray[i].position.y,this.positions[3*i+2]=this.particleArray[i].position.z,this.maxSize=this.maxSize>this.customSize[i]?this.maxSize:this.customSize[i]);if(this.particleGeometry.getAttribute("customVisible").needsUpdate=!0,this.particleGeometry.getAttribute("customOpacity").needsUpdate=!0,this.particleGeometry.getAttribute("customSize").needsUpdate=!0,this.particleGeometry.getAttribute("customColor").needsUpdate=!0,this.particleGeometry.getAttribute("position").needsUpdate=!0,!this.emitterAlive)return;var n=Math.round(this.particlesPerSecond*(this.emitterAge+0)),r=Math.round(this.particlesPerSecond*(this.emitterAge+e));r>this.particleCount&&(r=this.particleCount);for(i=n;r>i;i+=1)this.particleArray[i].alive=1;for(var o=0;t.length>o;o+=1){this.updateParticle(this.particleArray[i=t[o]]),this.particleArray[i].alive=1,this.positions[3*i]=this.particleArray[i].position.x,this.positions[3*i+1]=this.particleArray[i].position.y,this.positions[3*i+2]=this.particleArray[i].position.z}this.emitterAge+=e}},gk.prototype.setScale=function(e){for(var t=0,i=this.sizeTween.values.length;i>t;t+=1)this.sizeTween.values[t]=this.sizeTween.values[t]*e;this.maxSize*=e},gk.prototype.setScaleValue=function(e,t){this.sizeTween.values=t.values.concat(),this.sizeTween.times=t.times.concat(),this.maxSize=e},gk.prototype.initializeSizetween=function(e){for(var t=0,i=this.sizeTween.values.length;i>t;t+=1)this.sizeTween.values[t]=this.sizeTween.values[t]*e;for(t=0;this.particleCount>t;t+=1)this.particleArray[t].size*=e,this.customSize[t]=this.particleArray[t].size,this.maxSize=this.maxSize>this.customSize[t]?this.maxSize:this.customSize[t];this.particleGeometry.getAttribute("customSize").needsUpdate=!0},gk.prototype.destroy=function(){};var fk=function(e){lu(i,e);var t=pu(i);function i(e){var n;ru(this,i),n=t.call(this);var r=wp.extend({},{position:{x:0,y:0,z:0},scale:1,fireScale:1,smokeScale:1,enableFire:!0,enableSmoke:!0},e);return n.groupPosition=r.position,n.position.set(n.groupPosition.x,n.groupPosition.y,n.groupPosition.z),n.groupScale=r.scale,n.fireScale=r.fireScale,n.smokeScale=r.smokeScale,n.type="fire",n.disPickable=!0,n.autoAnimation=!0,n._loadTexture(),n._initialize(),n.setOptions(r),n.originPosition=n.position.clone(),n}return i}(To);fk.prototype._initialize=function(){this.fire=new gk,this.fire.setValues({positionStyle:1,positionBase:new Ke(0,0,600),positionSpread:new Ke(1500,1500,600),velocityStyle:1,velocityBase:new Ke(0,0,4600),velocitySpread:new Ke(1e3,1e3,4600),accelerationBase:new Ke(0,0,2600),particleTexture:this.fireParticle,sizeTween:new uk([0,.1],[32,800]),opacityTween:new uk([.7,1],[.8,0]),colorBase:new Ke(.04,1,.4),blendStyle:2,particlesPerSecond:120,particleDeathAge:1.5}),this.fire.initialize(),this.smoke=new gk,this.smoke.setValues({positionStyle:1,positionBase:new Ke(0,0,2600),positionSpread:new Ke(1500,1500,600),velocityStyle:1,velocityBase:new Ke(0,0,3600),velocitySpread:new Ke(1800,1800,1100),accelerationBase:new Ke(0,0,2600),particleTexture:this.smokeParticle,sizeTween:new uk([0,1],[32,800]),opacityTween:new uk([.5,1,1.7],[0,.3,0]),colorTween:new uk([.4,1],[new Ke(0,0,0),new Ke(0,0,.2)]),blendStyle:1,particlesPerSecond:120,particleDeathAge:2}),this.smoke.initialize(),this.add(this.fire.particleMesh),this.add(this.smoke.particleMesh)},fk.prototype._initializeSizetween=function(e){this.fire.initializeSizetween(e),this.smoke.initializeSizetween(e)},fk.prototype.update=function(){this.fire.update(),this.smoke.update()},fk.prototype.getPosition=function(){return this.groupPosition},fk.prototype.setPosition=function(e){if(e)if("number"==typeof e.x)if("number"==typeof e.y)if("number"==typeof e.z){if(this.groupPosition=e,this.position.set(this.groupPosition.x,this.groupPosition.y,this.groupPosition.z),this.originPosition=this.position.clone(),this.updateMatrixWorld(),this.originBox){var t=this.originBox.clone();this.box=t.applyMatrix4(this.matrix),this.levelName=null}}else Bu.error("缺少参数 position.z");else Bu.error("缺少参数 position.y");else Bu.error("缺少参数 position.x");else Bu.error("缺少参数 position")},fk.prototype.getScale=function(){return this.groupScale},fk.prototype.setScale=function(e){0!==e?(this.scale.set(e,e,e),this.updateMatrixWorld(),this.groupScale*=e,this.setFireScale(e),this.setSmokeScale(e)):Bu.error("参数 scale 不能为0")},fk.prototype.setFireScale=function(e){0!==e?(this.fireScale*=e,this.fire.setScale(e)):Bu.error("参数 scale 不能为0")},fk.prototype.setSmokeScale=function(e){0!==e?(this.smokeScale*=e,this.smoke.setScale(e)):Bu.error("参数 scale 不能为0")},fk.prototype._loadTexture=function(){var e=new Dl;this.fireParticle=e.load(""),this.smokeParticle=e.load("")},fk.prototype.setOptions=function(e){e.position&&this.setPosition(e.position),"number"==typeof e.scale&&this.setScale(e.scale),"number"==typeof e.fireScale&&this.setFireScale(e.scale),"number"==typeof e.smokeScale&&this.setSmokeScale(e.scale),jg(e.enableFire)&&(this.fire.particleMesh.visible=e.enableFire),jg(e.enableSmoke)&&(this.smoke.particleMesh.visible=e.enableSmoke),this.update()},fk.prototype.getOptions=function(){var e={};return e.position=this.groupPosition,e.scale=this.groupScale,e.fireScale=this.fireScale,e.smokeScale=this.smokeScale,e.enableFire=this.fire.particleMesh.visible,e.enableSmoke=this.smoke.particleMesh.visible,e};var mk=function(e){lu(i,e);var t=pu(i);function i(){var e,n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return ru(this,i),(e=t.call(this,n)).isBlast=!0,e.firelifeAge=n.firelifeAge||6,e.fireParticles=n.fireParticles||300,e.fireOpacityTween=n.fireOpacityTween||{times:[.7,2.5],values:[.8,0]},e.smokelifeAge=n.smokelifeAge||8,e.smokeParticles=n.smokeParticles||160,e.smokeOpacityTween=n.smokeOpacityTween||{times:[0,2.5,8],values:[0,.1,0]},e.risingSpeed=n.risingSpeed||500,e.age=0,e.state=0,e.originPosition=e.position.clone(),e}return i}(fk);mk.prototype._initialize=function(){this.isBlast=!0,this.firelifeAge=6,this.fireParticles=300,this.fireOpacityTween={times:[.7,2.5],values:[.8,0]},this.smokelifeAge=8,this.smokeParticles=160,this.smokeOpacityTween={times:[0,2.5,8],values:[0,.1,0]},this.risingSpeed=500,this.age=0,this.state=0,this.originPosition=this.position.clone(),this.fire=new ck,this.fire.setValues({positionStyle:1,positionBase:new Ke(0,0,0),positionSpread:new Ke(0,0,0),velocityStyle:1,velocityBase:new Ke(0,0,4600),velocitySpread:new Ke(1e3,1e3,4600),accelerationBase:new Ke(0,0,2600),particleTexture:this.fireParticle,sizeTween:new sk([0,.1],[32,800]),opacityTween:new sk(this.fireOpacityTween.times,this.fireOpacityTween.values),colorBase:new Ke(.04,1,.4),blendStyle:2,particlesPerSecond:this.fireParticles,particleDeathAge:this.firelifeAge}),this.fire.initialize(),this.smoke=new ck,this.smoke.setValues({positionStyle:1,positionBase:new Ke(0,0,2600),positionSpread:new Ke(1500,1500,600),velocityStyle:1,velocityBase:new Ke(0,0,3600),velocitySpread:new Ke(1800,1800,1100),accelerationBase:new Ke(0,0,2600),particleTexture:this.smokeParticle,sizeTween:new sk([0,1],[32,2e3]),opacityTween:new sk(this.smokeOpacityTween.times,this.smokeOpacityTween.values),colorTween:new sk([.4,1],[new Ke(0,0,0),new Ke(0,0,.2)]),blendStyle:1,particlesPerSecond:this.smokeParticles,particleDeathAge:this.smokelifeAge}),this.smoke.initialize(),this.add(this.fire.particleMesh),this.add(this.smoke.particleMesh)},mk.prototype._initializeSizetween=function(e){this.fire.initializeSizetween(e),this.smoke.initializeSizetween(e)},mk.prototype.update=function(){if(0!==this.state&&-1!==this.state){var e=function(e){return e=e>1?1:e,1-Math.pow(1-e,3)}(this.age);this.position.z+=(1-(e=e>.95?.95:e))*this.risingSpeed,this.updateMatrixWorld(),this.fire.update(),this.smoke.update(),this.age+=.015}},mk.prototype.run=function(){this.age=0,-1!==this.state&&(this.position.copy(this.originPosition),this.fire.initialize(),this.fire.setVisible(),this.smoke.initialize(),this.smoke.setVisible(),this.state=1)},mk.prototype.runLoop=function(e,t,i){if(this.timerManager=e,this.loopId)return this.timerManager.removeTimerListener(this.loopId),void this.timerManager.registerTimerListener(this.run.bind(this),t,i);this.loopId=this.timerManager.registerTimerListener(this.run.bind(this),t,i)},mk.prototype.stop=function(){this.fire.initialize(),this.smoke.initialize(),this.state=0,this.loopId&&(this.timerManager.removeTimerListener(this.loopId),delete this.loopId)},mk.prototype.pause=function(){this.state=-1,this.loopId&&this.timerManager.pause(this.loopId)},mk.prototype.continue=function(){-1===this.state&&(this.state=1,this.loopId&&this.timerManager.continue(this.loopId))},mk.prototype._loadTexture=function(){var e=new Dl;this.fireParticle=e.load(""),this.smokeParticle=e.load("")};var Ak=function(e){lu(i,e);var t=pu(i);function i(e){var n;for(var r in ru(this,i),(n=t.call(this)).Position={x:0,y:0,z:0},n.scaleUnit=1,n.disPickable=!0,e)"values"!==r&&(n[r]=e[r]);return n._initialize(e),n}return i}(To);Ak.prototype._initialize=function(e){var t=this;this.names=[],e.values.forEach((function(e){t[e.name]=new gk,t[e.name].setValues(e),t[e.name].initialize(),t.add(t[e.name].particleMesh),t.names.push(e.name)}))},Ak.prototype._initializeSizetween=function(e,t){var i=this;t?this[t].initializeSizetween(e):this.names.forEach((function(t){i[t].initializeSizetween(e)}))},Ak.prototype.update=function(e){var t=this;e?this[e].update():this.names.forEach((function(e){t[e].update()}))},Ak.prototype.getPosition=function(){return this.position},Ak.prototype.setPosition=function(e){if(e)if("number"==typeof e.x)if("number"==typeof e.y)if("number"==typeof e.z){if(this.position.set(e.x,e.y,e.z),this.updateMatrixWorld(),this.originBox){var t=this.originBox.clone();this.box=t.applyMatrix4(this.matrix),this.levelName=null}}else Bu.error("缺少参数 position.z");else Bu.error("缺少参数 position.y");else Bu.error("缺少参数 position.x");else Bu.error("缺少参数 position")},Ak.prototype.getScale=function(){return this.scaleUnit},Ak.prototype.setScale=function(e){var t=this.scaleUnit*e,i=this;this.scale.set(t,t,t),this.updateMatrixWorld(),this.names.forEach((function(t){i[t].setScale(e)})),this.scaleUnit=t},Ak.prototype.setConsistence=function(e){var t=this;this.names.forEach((function(i){t[i].setScale(e)}))};var yk=function(){var e=0,t=document.createElement("div");function i(e){return t.appendChild(e.dom),e}function n(i){for(var n=0;t.children.length>n;n++)t.children[n].style.display=n===i?"block":"none";e=i}t.style.cssText="position:fixed;top:0;left:0;cursor:pointer;opacity:0.9;z-index:10000",t.addEventListener("click",(function(i){i.preventDefault(),n(++e%t.children.length)}),!1);var r=(performance||Date).now(),o=r,a=0,s=i(new yk.Panel("FPS","#0ff","#002")),l=i(new yk.Panel("MS","#0f0","#020"));if(self.performance&&self.performance.memory)var c=i(new yk.Panel("MB","#f08","#201"));return n(0),{REVISION:16,dom:t,addPanel:i,showPanel:n,begin:function(){r=(performance||Date).now()},end:function(){a++;var e=(performance||Date).now();if(l.update(e-r,200),e>=o+1e3&&(s.update(1e3*a/(e-o),100),o=e,a=0,c)){var t=performance.memory;c.update(t.usedJSHeapSize/1048576,t.jsHeapSizeLimit/1048576)}return e},update:function(){r=this.end()},domElement:t,setMode:n}};yk.Panel=function(e,t,i){var n=1/0,r=0,o=Math.round,a=o(window.devicePixelRatio||1),s=80*a,l=48*a,c=3*a,h=2*a,d=3*a,u=15*a,p=74*a,g=30*a,f=document.createElement("canvas");f.width=s,f.height=l,f.style.cssText="width:80px;height:48px";var m=f.getContext("2d");return m.font="bold "+9*a+"px Helvetica,Arial,sans-serif",m.textBaseline="top",m.fillStyle=i,m.fillRect(0,0,s,l),m.fillStyle=t,m.fillText(e,c,h),m.fillRect(d,u,p,g),m.fillStyle=i,m.globalAlpha=.9,m.fillRect(d,u,p,g),{dom:f,update:function(l,A){n=Math.min(n,l),r=Math.max(r,l),m.fillStyle=i,m.globalAlpha=1,m.fillRect(0,0,s,u),m.fillStyle=t,m.fillText(o(l)+" "+e+" ("+o(n)+"-"+o(r)+")",c,h),m.drawImage(f,d+a,u,p-a,g,d,u,p-a,g),m.fillRect(d+p-a,u,a,g),m.fillStyle=i,m.globalAlpha=.9,m.fillRect(d+p-a,u,a,o((1-l/A)*g))}}};var vk=function(e){this.viewer=e};vk.prototype={construtor:vk,destroy:function(){this.viewer=null},update:function(e){var t=this.getControl();t&&(t.update(e),this.viewer.render())},getControl:function(){for(var e=this.viewer.controlManager.tools,t=0;e.length>t;t+=1)if(e[t].getName()===Yd.CLIP_BY_BOX)return e[t];return null},setSectionBox:function(e,t){this.getControl().setSectionBox(e,t)},toggle:function(e,t){this.getControl().toggle(e,t)},setVisible:function(e){this.getControl().visible(e)},setRotatable:function(e){this.getControl().rotatable(e)},enablePick:function(e){this.getControl().enablePick=e},saveState:function(){return this.getControl().store()},loadState:function(e){this.getControl().restore(e)},reset:function(){this.viewer.getScene().resetClipPlanes()},recalculate:function(){return this.viewer.getFilter().getVisibleComponentsBbox()},setProcess:function(e,t){this.getControl().setProcess(e,t)},getProcess:function(e){return this.getControl().getProcess(e)}};var Ck=function(e){this.viewer=e,this.viewportDIV=e.viewerImpl.getRenderer().domElement.parentElement,this.creatSVG=function(){document.getElementById("svgid"+this.viewer.getViewerImpl().uuid)||(this.svg=document.createElementNS("http://www.w3.org/2000/svg","svg"),this.svg.setAttribute("id","svgid"+this.viewer.getViewerImpl().uuid),this.svg.setAttribute("style","width: 100%; height: 100%; position:absolute; left: 0; top:0;"),this.viewportDIV.appendChild(this.svg))},this.creatRect=function(e){var t=e.data.left,i=e.data.top,n=e.data.width,r=e.data.height,o=e.data.visible;this.deleteRect(),o&&(this.rect=document.createElementNS("http://www.w3.org/2000/svg","rect"),this.rect.setAttribute("id","rectid"+this.viewer.getViewerImpl().uuid),this.rect.setAttribute("x",t),this.rect.setAttribute("y",i),this.rect.setAttribute("width",n),this.rect.setAttribute("height",r),this.rect.setAttribute("style","fill:#0DFFB2;stroke-width:2;stroke:rgb(0,255,0);fill-opacity:0.1;stroke-opacity:0.9"),this.svg.appendChild(this.rect))},this.deleteRect=function(){var e=document.getElementById("rectid"+this.viewer.getViewerImpl().uuid);e&&this.svg.removeChild(e)},this.deleteSVG=function(){if(this.svg){var e=document.getElementById("rectid"+this.viewer.getViewerImpl().uuid);e&&this.svg.removeChild(e),this.viewportDIV.removeChild(this.svg)}},this.creatMoveCircle=function(e){var t=e.x,i=e.y;this.circleMov=document.createElementNS("http://www.w3.org/2000/svg","circle"),this.circleMov.setAttribute("id","circleMove"+this.viewer.getViewerImpl().uuid),this.circleMov.setAttribute("cx",t),this.circleMov.setAttribute("cy",i),this.circleMov.setAttribute("r","5"),this.circleMov.setAttribute("style","fill:#500A11;stroke-width:2;stroke:rgb(0,255,0);fill-opacity:0.9;stroke-opacity:0.9"),this.svg.appendChild(this.circleMov)},this.changeMoveCircleStyle=function(e){var t=document.getElementById("circleMove"+this.viewer.getViewerImpl().uuid);t.setAttribute("cx",e[0]),t.setAttribute("cy",e[1]),t.setAttribute("style","fill:#00ff00;stroke-width:1;stroke:rgb(60,240,240);fill-opacity:0.9;stroke-opacity:0.9")},this.deleteCircle=function(){var e=document.getElementById("circleMove"+this.viewer.getViewerImpl().uuid);e&&this.svg.removeChild(e)},this.createMoveLine=function(e,t){var i=e.x,n=e.y,r=t.x,o=t.y;this.deleteMoveLine(),this.moveline=document.createElementNS("http://www.w3.org/2000/svg","line"),this.moveline.setAttribute("id","moveLine"+this.viewer.getViewerImpl().uuid),this.moveline.setAttribute("class","moveLine"),this.moveline.setAttribute("x1",i),this.moveline.setAttribute("y1",n),this.moveline.setAttribute("x2",r),this.moveline.setAttribute("y2",o),this.moveline.setAttribute("stroke","#0AEA06"),this.moveline.setAttribute("stroke-width","2"),this.svg.appendChild(this.moveline)},this.deleteMoveLine=function(){var e=document.getElementById("moveLine"+this.viewer.getViewerImpl().uuid);e&&this.svg.removeChild(e)},this.creatPickCircle=function(e,t){var i=e.x,n=e.y;this.circlePic=document.createElementNS("http://www.w3.org/2000/svg","circle"),this.circlePic.setAttribute("id","circlePick"+this.viewer.getViewerImpl().uuid+t),this.circlePic.setAttribute("class","circlePick"),this.circlePic.setAttribute("cx",i),this.circlePic.setAttribute("cy",n),this.circlePic.setAttribute("r","5"),this.circlePic.setAttribute("style","fill:#00ff00;stroke-width:1;stroke:rgb(60,240,240);fill-opacity:0.9;stroke-opacity:0.9"),this.svg.appendChild(this.circlePic)},this.creatLine=function(e,t,i,n){var r=e.x,o=e.y,a=t.x,s=t.y;this.line=document.createElementNS("http://www.w3.org/2000/svg","line"),this.line.setAttribute("id","pickline"+this.viewer.getViewerImpl().uuid+n),this.line.setAttribute("class","pickline"),this.line.setAttribute("x1",r),this.line.setAttribute("y1",o),this.line.setAttribute("x2",a),this.line.setAttribute("y2",s),this.line.setAttribute("stroke",i),this.line.setAttribute("stroke-width","2"),this.svg.appendChild(this.line)},this.deleteLineAndCircle=function(){for(var e=this.svg.getElementsByClassName("pickline"),t=this.svg.getElementsByClassName("circlePick");e.length;)this.svg.removeChild(e[e.length-1]);for(;t.length;)this.svg.removeChild(t[t.length-1])}},Ik="\n\n#include <logdepthbuf_pars_vertex>\n\nvarying vec2 vUv;\n\nvoid main() {\n vec3 transformed = vec3( position );\n\n vec4 mvPosition = vec4( transformed, 1.0 );\n\n mvPosition = modelViewMatrix * mvPosition;\n \n gl_Position = projectionMatrix * mvPosition;\n vUv = uv;\n\n\t#include <logdepthbuf_vertex>\n}\n",xk="\nuniform vec3 color;\nuniform float opacity;\nuniform float imagePs;\nuniform sampler2D map;\n\nvarying vec2 vUv;\n\nvoid main(void){\n #include <logdepthbuf_fragment>\n\n vec2 cusUv = vec2(imagePs + vUv.x/2.0, vUv.y);\n\n vec4 color1 = texture2D(map, cusUv);\n\n gl_FragColor = color1;\n\n}\n\n",wk=0,Mk=.5,Ek=function(e){lu(i,e);var t=pu(i);function i(){var e,n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return ru(this,i),(e=t.call(this)).lights=!1,e.uniforms={color:{value:new pi(1,1,1)},opacity:{value:1},map:{value:new Fe},imagePs:{value:0}},e.vertexShader=Ik,e.fragmentShader=xk,e.setValues(n),e.isChangeMapMaterial=!0,e}return au(i,[{key:"map",get:function(){return this.uniforms.map.value},set:function(e){this.uniforms.map.value=e}},{key:"color",get:function(){return this.uniforms.color.value},set:function(e){this.uniforms.color.value.copy(e)}},{key:"imagePs",get:function(){return this.uniforms.imagePs.value},set:function(e){this.uniforms.imagePs.value=e}}]),i}(cn),Bk="",Sk="",bk="",kk="",Dk="",Tk="";var Rk=function(e,t){var i=this;this.viewer=e,this.preRotationHandle=t,this.mouseButtons={LEFT:n.LEFT,RIGHT:n.RIGHT},this.visible=!0,this.isAnimationFinish=!0,this.pickedColor=3779326,this.width=0,this.height=0,this.isDisable=!1;var r=new Map,o=new Map,a=new Map,s=6185057,l=null,c=null,h=60,d=function(e,t){var i=(e+t)/2;return[new Ke(i,-i,i),new Ke(i,-i,-i),new Ke(i,i,-i),new Ke(i,i,i),new Ke(-i,-i,i),new Ke(-i,-i,-i),new Ke(-i,i,-i),new Ke(-i,i,i)]}(h,5),u=function(e,t){return{"+Y":new Ke(0,e/2+t,0),"-Y":new Ke(0,-(e/2+t),0),"+X":new Ke(e/2+t,0,0),"-X":new Ke(-(e/2+t),0,0),"+Z":new Ke(0,0,e/2+t),"-Z":new Ke(0,0,-(e/2+t))}}(h,5),p=function(e){return{"01":(new Ke).lerpVectors(e[0],e[1],.5),12:(new Ke).lerpVectors(e[1],e[2],.5),23:(new Ke).lerpVectors(e[2],e[3],.5),30:(new Ke).lerpVectors(e[3],e[0],.5),45:(new Ke).lerpVectors(e[4],e[5],.5),56:(new Ke).lerpVectors(e[5],e[6],.5),67:(new Ke).lerpVectors(e[6],e[7],.5),74:(new Ke).lerpVectors(e[7],e[4],.5),"04":(new Ke).lerpVectors(e[0],e[4],.5),37:(new Ke).lerpVectors(e[3],e[7],.5),26:(new Ke).lerpVectors(e[2],e[6],.5),15:(new Ke).lerpVectors(e[1],e[5],.5)}}(d),g=0,f=1,m=2,A=220,y=150,v=80,C=1,I=2,x=5,w=6,M=3,E=4,B=1e-4,S=new Vo,b=new pc(-y/2,y/2,y/2,-y/2,-y/2,y/2),k=new Xp,D=new To,T=new To,R=new To;D.add(T),D.add(R);var U=new To;U.name="selectBoxGroup",D.add(U),this._cube=D;var F=!1,Q=!1,L=new ke,O=new ke,N=new ke,P=new ke,G=!1,K="",V=null,Y=-1,H=!1;this.uninit=function(){this.removeDomEventListeners(),l&&(l.removeChild(c.domElement),l=null)},this.enable=function(){l&&c&&!c.domElement.parentNode&&(l.appendChild(c.domElement),this.addDomEventListeners())},this.disable=function(){l&&c&&c.domElement.parentNode&&(this.removeDomEventListeners(),l.removeChild(c.domElement))};(function(){!function(){for(var e=new Dl,t=[{image:bk,position:u["+Y"],rotation:new bt(.5*Math.PI,Math.PI,0),name:"Back POSITIVE_Y",view:kd.Back},{image:kk,position:u["-Y"],rotation:new bt(.5*Math.PI,0,0),name:"Front NEGATIVE_Y",view:kd.Front},{image:Sk,position:u["-X"],rotation:new bt(-.5*Math.PI,-.5*Math.PI,Math.PI),name:"Left NEGATIVE_X",view:kd.Left},{image:Bk,position:u["+X"],rotation:new bt(-.5*Math.PI,.5*Math.PI,Math.PI),name:"Right POSITIVE_X",view:kd.Right},{image:Dk,position:u["+Z"],rotation:new bt(0,0,0),name:"Top POSITIVE_Z",view:kd.Top},{image:Tk,position:u["-Z"],rotation:new bt(Math.PI,0,Math.PI),name:"Bottom NEGATIVE_Z",view:kd.Bottom}],i=function(){var t=r[n];e.load(t.image,(function(e){var i=new nn(new In(h,h),new Ek({map:e,toneMapped:!1}));i.position.copy(t.position),i.rotation.copy(t.rotation),i.name=t.name,i.view=t.view,T.add(i),a.set(t.name,i)}))},n=0,r=t;r.length>n;n++)i()}(),function(){for(var e=["30","12","74","56","04","15","37","26","01","23","45","67"],t=["Top_Front","Bottom_Front","Top_Back","Bottom_Back","Top_Left","Bottom_Left","Top_Right","Bottom_Right","LeftFront","RightFront","LeftBack","RightBack"],i=[kd.TopFront,kd.BottomFront,kd.TopBack,kd.BottomBack,kd.TopLeft,kd.BottomLeft,kd.TopRight,kd.BottomRight,kd.FrontLeft,kd.FrontRight,kd.BackLeft,kd.BackRight],n=new on(5,h,5),r=new on(h,5,5),a=new on(5,5,h),l=[n,n,n,n,r,r,r,r,a,a,a,a],c=0;e.length>c;c++){var d=new nn(l[c],new gi({color:new pi(s)}));d.position.copy(p[e[c]]),d.name=t[c],d.view=i[c],T.add(d),o.set(t[c],d)}}(),function(){for(var e=[0,1,2,3,4,5,6,7],t=["Top_FrontLeft","Bottom_FrontLeft","Bottom_FrontRight","Top_FrontRight","Top_BackLeft","Bottom_BackLeft","Bottom_BackRight","Top_BackRight"],n=[kd.TopFrontLeft,kd.BottomFrontLeft,kd.BottomFrontRight,kd.TopFrontRight,kd.TopBackLeft,kd.BottomBackLeft,kd.BottomBackRight,kd.TopBackRight],o=new on(5,5,5),a=0;e.length>a;a++){var l=new nn(o,new gi({color:new pi(s)}));l.position.copy(d[e[a]]),l.name=t[a],l.view=n[a],R.add(l);var c=new on(10,10,10),h=new nn(c,new gi({transparent:!0,color:new pi(i.pickedColor),opacity:1}));h.position.copy(d[e[a]]),h.name=t[a],h.view=n[a],U.add(h),h.visible=!1,h.isBox=!0,r.set(t[a],h)}}()})(),S.add(D);var j=function(e){Q=e;for(var t=e?.8:1,i=D.children,n=0;i.length>n;n+=1)for(var r=i[n].children,o=0;r.length>o;o+=1)r[o].material.transparent=e,r[o].material.opacity=t};j(!1);var W=function(){V&&(V.material.color.set(V.currentColor),V.material.isChangeMapMaterial&&(V.material.imagePs=wk),V.isBox&&(V.visible=!1)),V=null},J=function(e){if(void 0!==l){var t=ag.getDomOffsetToClient(l),n=new ke;if(n.x=e.x-t.left,n.y=e.y-t.top,n.x>0&&i.width>n.x&&n.y>0&&i.height>n.y)return P.x=n.x/i.width*2-1,P.y=-n.y/i.height*2+1,!0}return!1},z=function(){var e=new Ke(P.x,P.y,.5);k.setFromCamera(e,b);var t,n=k.intersectObjects([U,T],!0,!1);n?V!==(t=n.object)&&(V&&(V.material.isChangeMapMaterial&&(V.material.imagePs=wk),V.isBox&&(V.visible=!1),V.material.color.set(V.currentColor)),(V=t).currentColor=V.material.color.clone(),""!==V.name&&(V.material.color.set(i.pickedColor),V.isBox&&(V.visible=!0),V.material.isChangeMapMaterial&&(V.material.imagePs=Mk))):W()};this.mouseUp=function(e){e.stopPropagation();var n=new ke(e.clientX,e.clientY),r=J(n);return F?(F=!1,O.set(n.x,n.y),N.subVectors(O,L),this.preRotationHandle&&!this.preRotationHandle()||(this.viewer.viewerImpl.rotateCamera(N),L.copy(O))):r&&e.button===i.mouseButtons.LEFT&&V&&(Y=-1,-1!==(Y=V.view)&&(t(Y),null!=Y&&i.viewer.viewerImpl.rotateCameraByViewCubeSide(Y))),r},this.mouseMove=function(e){e.stopPropagation();var t=!1,i=new ke(e.clientX,e.clientY),n=J(i);if(F)O.set(i.x,i.y),N.subVectors(O,L),this.preRotationHandle&&!this.preRotationHandle()||(this.viewer.viewerImpl.rotateCamera(N),L.copy(O));else if(n){if(Q&&(j(!1),t=!0),z(),V){if(""!==V.name){var r=V.name;K!==r&&(K=r,G=!0,t=!0)}}else""!==K&&(K="",G=!1,t=!0);t&&this.render(),H=!0}else H&&(H=!1,G&&(W(),G=!1,t=!0),t&&this.render());return n},this.mouseDown=function(e){e.preventDefault(),e.stopPropagation();var t=new ke(e.clientX,e.clientY),n=J(t);return n&&e.button===i.mouseButtons.LEFT&&(F=!1),n},this.onMouseDownBinded=this.mouseDown.bind(this),this.onMouseMoveBinded=this.mouseMove.bind(this),this.onMouseUpBinded=this.mouseUp.bind(this),this.addDomEventListeners=function(){l&&(l.addEventListener("contextmenu",(function(e){e.preventDefault()}),!1),l.addEventListener("mousedown",this.onMouseDownBinded,!1),window.addEventListener("mousemove",this.onMouseMoveBinded,!1),l.addEventListener("mouseup",this.onMouseUpBinded,!1))},this.removeDomEventListeners=function(){l&&(l.removeEventListener("contextmenu",(function(e){e.preventDefault()}),!1),l.removeEventListener("mousedown",this.onMouseDownBinded,!1),window.removeEventListener("mousemove",this.onMouseMoveBinded,!1),window.removeEventListener("mouseup",this.onMouseUpBinded,!1))};var q=function(e){switch(e){case g:i.width=A,i.height=A;break;case f:i.width=y,i.height=y;break;case m:default:i.width=v,i.height=v}l.style.width=i.width+"px",l.style.height=i.height+"px"};this.resize=function(e,t,i){q(200>e||i?m:f),c.setPixelRatio(window.devicePixelRatio||1),c.setSize(this.width,this.height)};this.init=function(e){(function(e){e.style.position="absolute",e.style.display="block",e.style.outline="0",e.style.right="52px",e.style.top="0px",e.style.opacity="1",e.style.display="flex",e.style.webkitTransition="opacity .2s ease",e.style.mozTransition="opacity .2s ease",e.style.msTransform="opacity .2s ease",e.style.oTransform="opacity .2s ease",e.style.transition="opacity .2s ease"})(l=document.createElement("div")),e.appendChild(l),c=new Oo({antialias:!0,alpha:!0,preserveDrawingBuffer:!0}),l.appendChild(c.domElement),this.resize(e.offsetWidth,e.offsetHeight,this.viewer.viewerImpl.isMobile),this.addDomEventListeners()};var Z=function(e,t,i){return e>t?i>=e-t:i>=t-e};this.render=function(){if(this.visible&&!this.isDisable&&c){var e=this.viewer.viewerImpl.getActiveCameraInfo(),t=e.quaternion.clone().invert();this._cube.quaternion.copy(t),-1===Y&&(Y=function(e,t){var i=e.clone();i.normalize();var n=t.clone();if(n.normalize(),Z(i.x,0,B)&&Z(i.y,-1,B)&&Z(i.z,0,B)&&Z(n.x,0,B)&&Z(n.y,0,B)&&Z(n.z,-1,B))return C;if(Z(i.x,0,B)&&Z(i.y,1,B)&&Z(i.z,0,B)){if(Z(n.x,0,B)&&Z(n.y,0,B)&&Z(n.z,1,B))return I;if(Z(n.x,1,B)&&Z(n.y,0,B)&&Z(n.z,0,B))return I}return Z(i.x,0,B)&&Z(i.y,0,B)&&Z(i.z,-1,B)&&Z(n.x,0,B)&&Z(n.y,1,B)&&Z(n.z,0,B)?x:Z(i.x,0,B)&&Z(i.y,0,B)&&Z(i.z,1,B)&&Z(n.x,0,B)&&Z(n.y,1,B)&&Z(n.z,0,B)?w:Z(i.x,-1,B)&&Z(i.y,0,B)&&Z(i.z,0,B)&&Z(n.x,0,B)&&Z(n.y,1,B)&&Z(n.z,0,B)?M:Z(i.x,1,B)&&Z(i.y,0,B)&&Z(i.z,0,B)&&Z(n.x,0,B)&&Z(n.y,1,B)&&Z(n.z,0,B)?E:-1}(e.dir,b.up)),c.autoClear=!0,c.render(S,b)}},this.destroy=function(){c.dispose(),this.disable()}},Uk=function(e){var t=window.performance.timing;Iu.PERFORMANCE>Bu.level||Bu.warn("页面加载时间:",t.domInteractive-t.navigationStart,"ms");var i=og.detectWebGL();if(1===i){xd.language=og.language(),Yt.DefaultUp.set(0,0,1);var n=wp.extend({},{host:"https://bos3d.bimwinner.com",viewport:""},e);this.host=n.host,this.viewerImpl=new xB;var r=document.getElementById(n.viewport);r.style.position="relative";var o=this;this.getViewerImpl().init(r),xd.EnableViewController&&!og.isMobileDevice()&&(this.viewController=new Rk(this,(function(){return!0})),this.viewController.init(this.getViewerImpl().getDomElement()),this.viewController.render(),this.getViewerImpl().addRenderFinishedListener((function(){o.viewController.render()}))),this.filter=this.getViewerImpl().filter,this.SVGRect=new Ck(this),this.SVGRect.creatSVG(),this.viewport=e.viewport,this.viewportDiv=document.getElementById(e.viewport),this.getViewerImpl().modelManager.addEventListener(Fd.ON_LOAD_CONFIG_FINISH,(function(e){Bu.time("模型".concat(e.modelKey,"加载时间"));var t=o.getViewerImpl().getBoundingBox(),i=o.getViewerImpl().getModel(e.modelKey),n=i.getConfig();n.type!==Xd.I_MODEL&&n.type!==Xd.OBJ||o.setLightIntensityFactor(1),py(i.dataVersion,"1.0");var r=t.getCenter(new Ke),a=t.getSize(new Ke),s=new Ke(r.x+a.x,r.y+a.y,r.z+a.z);xd.KeepViewState?o.originalView||o.defaultOriginalView||(o.viewerImpl.lookAt(s,r,o.viewerImpl.camera.up),o.setDefaultOriginalView(s,r,o.viewerImpl.camera.up)):xd.UserControlView||(o.originalView?o.viewerImpl.lookAt(o.originalView.position,o.originalView.target,o.originalView.up):(o.viewerImpl.lookAt(s,r,o.viewerImpl.camera.up),o.setDefaultOriginalView(s,r,o.viewerImpl.camera.up)))})),this.getViewerImpl().modelManager.addEventListener(Fd.ON_LOAD_PROGRESS,(function(e){Bu.log(e.progress)})),this.getViewerImpl().modelManager.addEventListener(Fd.ON_LOAD_COMPLETE,(function(e){Bu.log(e.modelKey," is load "),Bu.timeEnd("模型".concat(e.modelKey,"加载时间"));var t=o.getViewerImpl().getModel(e.modelKey);for(var i in o.rootScene.aabbCollection.updateFromModel(t.dataUrl.modelKey,t),t.floorManager&&xd.EnableCreateMiniMap&&(Bu.time("小地图生成"),t.floorManager.generateMiniMap(o.getViewerImpl()),Bu.timeEnd("小地图生成")),t&&t.getConfig()&&o.getViewerImpl().cameraControl.setSceneUnit(t.getConfig().lengthUnit),bd)if(t&&bd.hasOwnProperty(i)&&!0===bd[i]){var n=i,r=t.getComponentKeysByType(n),a=t.getConfig(),s=[];!a||a.type!==Xd.RVT&&a.type!==Xd.MERGE&&a.type!==Xd.ARRAY||(s=t.getComponentKeysByProperty("buildInCategory",n)),o.deactivateComponentsByKey(r.concat(s))}o.getViewerImpl().getBoundingBox().isEmpty()&&(o.getViewerImpl().zoomAll(),o.getViewerImpl().goToInitialView())})),this.getViewerImpl().modelManager.addEventListener(Fd.ON_CLICK_PICK,(function(e){if(e.intersectInfo){if(o.tempNode){for(var t=o.getComponentsByKey(o.tempNode.selectedObjectId),i=0,n=t.length;n>i;i+=1){var r=t[i];for(var a in r)for(var s=r[a],l=0,c=s.length;c>l;l+=1){var h=s[l],d=Yw(h.elementId,!0,!1,0);h.mesh.setInstanceColorAt(h.groupIndex,h.subInstanceIndex,d)}}if(o.tempNode.selectedObjectId!==e.intersectInfo.selectedObjectId){o.tempNode=e.intersectInfo;for(var u=o.getComponentsByKey(o.tempNode.selectedObjectId),p=0,g=u.length;g>p;p+=1){var f=u[p];for(var m in f)for(var A=f[m],y=0,v=A.length;v>y;y+=1){var C=A[y],I=Yw(C.elementId,!0,!1,1);C.mesh.setInstanceColorAt(C.groupIndex,C.subInstanceIndex,I)}}}else o.tempNode=null}else if(e.intersectInfo.object.isInstancedMeshEx){o.tempNode=e.intersectInfo;for(var x=o.getComponentsByKey(o.tempNode.selectedObjectId),w=0,M=x.length;M>w;w+=1){var E=x[w];for(var B in E)for(var S=E[B],b=0,k=S.length;k>b;b+=1){var D=S[b],T=Yw(D.elementId,!0,!1,1);D.mesh.setInstanceColorAt(D.groupIndex,D.subInstanceIndex,T)}}}Bu.log("构件key",e.intersectInfo.selectedObjectId);var R=e.intersectInfo.object;R&&Bu.log(R)}else if(o.tempNode){for(var U=o.getComponentsByKey(o.tempNode.selectedObjectId),F=0,Q=U.length;Q>F;F+=1){var L=U[F];for(var O in L)for(var N=L[O],P=0,G=N.length;G>P;P+=1){var K=N[P],V=Yw(K.elementId,!0,!1,0);K.mesh.setInstanceColorAt(K.groupIndex,K.subInstanceIndex,V)}}o.tempNode=null}})),this.getViewerImpl().getControlManager().addEventListener(Fd.ON_CONTROL_EXIST,(function(e){if(e.name===Yd.CLIP_BY_BOX)for(var t=o.getViewerImpl().modelManager.getModelKeys(),i=0,n=t.length;n>i;i+=1){var r=o.getViewerImpl().modelManager.getModel(t[i]);if(r)for(var a=0;6>a;a+=1){r._getNodeGroup("sectionFill_"+a).clear()}}})),this.viewerImpl.modelManager.addEventListener(Fd.ON_CONTROL_UPDATEUI,(function(e){o.SVGRect.creatRect(e)}));var a=document.createElement("div");a.setCss({width:"28px",height:"28px",backgroundImage:"url()",display:"none",backgroundSize:"cover",overflow:"hidden",position:"absolute"}),this.viewportDiv.appendChild(a),this._rotationCenterMouseDown=!1,this.registerControlEventListener(Fd.ON_CONTROL_BEGIN,(function(e){e.name===Vd.ORBIT&&(o._rotationCenterMouseDown=!0)})),this.registerControlEventListener(Fd.ON_CONTROL_MOUSEMOVE,(function(e){var t;if(o._rotationCenterMouseDown)if(t=o.getViewerImpl().getControlManager().userInputControl?o.getViewerImpl().getControlManager().userInputControl.orbitControl.rotatePivot:o.getViewerImpl().getControlManager().control.rotatePivot){var i=o.getScreenCoordFromSceneCoord(t);a.setCss({left:i[0]-14+"px",top:i[1]-14+"px",display:""})}else a.setCss({left:0,top:0,display:"none"});else a.setCss({left:0,top:0,display:"none"})})),this.registerControlEventListener(Fd.ON_CONTROL_END,(function(e){o._rotationCenterMouseDown=!1,a.setCss({left:0,top:0,display:"none"})}))}else og.showWebGLMessage(i)};Object.assign(Uk.prototype,hg.prototype),Object.assign(Uk.prototype,{constructor:Uk,addView:function(e,t,i,n){this.getViewerImpl().load({serverUrl:this.host,modelKey:e,dbName:t,token:i,share:n||"",notifyProgress:!0,type:e.startsWith("G")?"GIS":""})},addViews:function(e,t,i,n){xd.AutoMergeComponent=!1,xd.MergeComponent=!0,this.getViewerImpl().load({serverUrl:this.host,modelKey:e,modelKeys:t,dbName:i,token:n,notifyProgress:!0})},addTilesView:function(e,t,i){this.getViewerImpl().loadTiles({serverUrl:this.host,modelKey:e,dbName:t,token:i,notifyProgress:!0})},addTilesViewFromLocal:function(e){this.getViewerImpl().loadTiles({serverUrl:".",modelKey:e,dbName:"",token:"",notifyProgress:!0,offLine:!0})},getSSE:function(e){var t=this.getBoxByComponentsKey(e),i=this.viewerImpl.camera,n=t.getCenter(new Ke),r=t.getSize().length(),o=this.viewerImpl.getRenderer().domElement.width,a=i.fov;return r*o/(2*i.position.clone().sub(n).length()*Math.tan(a/2))},removeView:function(e){return this.getViewerImpl().unload(e)},removeAllView:function(){this.getViewerImpl().unloadAll()},addViewFromLocal:function(e){this.getViewerImpl().load({serverUrl:".",modelKey:e,dbName:"",notifyProgress:!0,offLine:!0})},loadComponents:function(e,t,i,n){Array.isArray(e)||(e=[e]),this.getViewerImpl().loadGeopkOnDemand(e,t,i,n)},unloadComponents:function(e,t){Array.isArray(e)||(e=[e]),this.getViewerImpl().unloadGeopkOnDemand(e,t)},getOriginalView:function(){return this.originalView||this.defaultOriginalView},getInitView:function(){var e=this.viewerImpl.modelManager.scene.getBoundingBox(),t=e.getCenter(new Ke),i=e.getSize(new Ke);return{position:new Ke(t.x+i.x,t.y+i.y,t.z+i.z),target:t,up:[0,0,1]}},setOriginalView:function(e,t,i){jg(e)&&jg(t)&&jg(i)?(this.originalView||(this.originalView={}),this.originalView.position=Array.isArray(e)?new Ke(e[0],e[1],e[2]):new Ke(e.x,e.y,e.z),this.originalView.target=Array.isArray(t)?new Ke(t[0],t[1],t[2]):new Ke(t.x,t.y,t.z),this.originalView.up=Array.isArray(i)?new Ke(i[0],i[1],i[2]):new Ke(i.x,i.y,i.z)):Bu.warn("视角非法")},setDefaultOriginalView:function(e,t,i){jg(e)&&jg(t)&&jg(i)?(this.defaultOriginalView||(this.defaultOriginalView={}),this.defaultOriginalView.position=Array.isArray(e)?new Ke(e[0],e[1],e[2]):new Ke(e.x,e.y,e.z),this.defaultOriginalView.target=Array.isArray(t)?new Ke(t[0],t[1],t[2]):new Ke(t.x,t.y,t.z),this.defaultOriginalView.up=Array.isArray(i)?new Ke(i[0],i[1],i[2]):new Ke(i.x,i.y,i.z)):Bu.warn("视角非法")},getViewerImpl:function(){return this.viewerImpl},getAllComponents:function(){return this.getViewerImpl().getModelManager().getAllComponents()},getAllComponentsKey:function(){return this.getViewerImpl().getModelManager().getAllComponentsKey()},getComponentsKeyByModelKey:function(e){return this.getViewerImpl().getModelManager().getComponentsKeyByModelKey(e)},getComponentKeysByName:function(e){return this.getViewerImpl().getModelManager().getComponentKeysByName(e)},getComponentKeysByType:function(e){return this.getViewerImpl().getModelManager().getComponentKeysByType(e)},getComponentKeysByProperty:function(e,t){return this.getViewerImpl().getModelManager().getComponentKeysByProperty(e,t)},pickByPoint:function(e){return this.getViewerImpl().pickByPoint(e)},calculateMinDistance:function(e,t){return this.getViewerImpl().calculateMinDistance(e,t)},otherObjectsInScene:function(e){},getComponentsByKey:function(e){Array.isArray(e)||(e=[e]);var t=[],i=this;return e.forEach((function(e){var n=i.getViewerImpl().modelManager.getComponent(e);if(n){var r={};r[e]=n,t.push(r)}})),t},getModelFloorMapsByKey:function(e,t){var i=this.getViewerImpl().getModel(e),n=t&&"function"==typeof t;if(!i){var r={msg:"没有此模型",data:null};return n&&t(r),r}var o=i.getConfig().type;if(o!==Xd.RVT&&o!==Xd.IFC&&o!==Xd.MERGE&&o!==Xd.SCENE){var a={msg:"该模型不支持小地图",data:null};return n&&t(a),a}if(!i.floorManager){var s={msg:"该模型不支持小地图",data:null};return n&&t(s),s}return this.getViewerImpl().getModelFloorMapsByKey(e,t)},showComponentsById:function(e,t){Array.isArray(e)||(e=[e]);for(var i=[],n=0;e.length>n;n+=1)i[n]=t+"_"+e[n];this.getViewerImpl().getFilter().showByIds(i),this.render()},showComponentsByKey:function(e){Array.isArray(e)||(e=[e]),this.getViewerImpl().getFilter().showByIds(e),this.render()},hideComponentsById:function(e,t){Array.isArray(e)||(e=[e]);for(var i=[],n=0;e.length>n;n+=1)i[n]=t+"_"+e[n];this.filter.hideByIds(i),this.render()},hideComponentsByKey:function(e){Array.isArray(e)||(e=[e]),this.filter.hideByIds(e),this.render()},getInvisibleComponentList:function(){return this.getViewerImpl().getFilter().getInvisibleComponentList()},getInactivatedComponentList:function(){return this.getViewerImpl().getFilter().getInactivatedComponentList()},activateComponentsByKey:function(e){Array.isArray(e)||(e=[e]),this.filter.activateByIds(e),this.render()},deactivateComponentsByKey:function(e){Array.isArray(e)||(e=[e]),this.filter.deactivateByIds(e),this.render()},hideAllComponents:function(){this.getViewerImpl().getFilter().hideAll(),this.render()},showAllComponents:function(){this.getViewerImpl().getFilter().showAll(),this.render()},highlightComponentsById:function(e,t){Array.isArray(e)||(e=[e]);for(var i=[],n=0;e.length>n;n+=1)i[n]=t+"_"+e[n];this.getViewerImpl().setSelection(i),this.render()},highlightComponentsByKey:function(e,t){Array.isArray(e)||(e=[e]),this.getViewerImpl().setSelection(e);var i=t;"boolean"!=typeof t&&(i=!0),i&&this.render()},addHighlightComponentsByKey:function(e){Array.isArray(e)||(e=[e]),this.getViewerImpl().addToSelection(e),this.render()},closeHighlightComponentsById:function(e,t){Array.isArray(e)||(e=[e]);for(var i=[],n=0;e.length>n;n+=1)i[n]=t+"_"+e[n];this.getViewerImpl().removeFromSelection(i),this.render()},closeHighlightComponentsByKey:function(e){Array.isArray(e)||(e=[e]),this.getViewerImpl().removeFromSelection(e),this.render()},getHighlightComponentsKey:function(){return this.getViewerImpl().getSelection()},clearHighlightList:function(){this.getViewerImpl().clearSelection(),this.render()},getHighlightComponents:function(){var e=this.getHighlightComponentsKey(),t=[],i=this;return e.forEach((function(e){var n=i.getViewerImpl().modelManager.getComponent(e);if(n){var r={};r[e]=n,t.push(r)}})),t},setComponentsOpacityState:function(e,t){Array.isArray(e)||(e=[e]),t===Gd.TRANSLUCENT?this.transparentComponentsByKey(e):t===Gd.OPAQUE&&this.closeTransparentComponentsByKey(e)},transparentComponentsById:function(e,t){Array.isArray(e)||(e=[e]);for(var i=[],n=0;e.length>n;n+=1)i[n]=t+"_"+e[n];this.getViewerImpl().getFilter().makeTranslucentByIds(i),this.render()},transparentComponentsByKey:function(e,t){Array.isArray(e)||(e=[e]);var i=this.getViewerImpl().getFilter();if(t){var n=this.getComponentsByKey(e);if(Array.isArray(e)&&n.length!==e.length){n=[];var r,o=vu(e);try{for(o.s();!(r=o.n()).done;){var a=this.getComponentsByKey(r.value);a.length>0&&n.push(a[0])}}catch(e){o.e(e)}finally{o.f()}}i.transparentComponentsByKey(this.getViewerImpl().getModelManager(),n,t)}else i.makeTranslucentByIds(e);this.render()},transparentOtherComponentsByKey:function(e){Array.isArray(e)||(e=[e]),this.getViewerImpl().getFilter().makeTranslucentOthersByIds(e),this.render()},transparentAllComponents:function(){this.getViewerImpl().getFilter().makeTranslucentOthersByIds([]),this.render()},closeTransparentComponentsById:function(e,t){Array.isArray(e)||(e=[e]);for(var i=[],n=0;e.length>n;n+=1)i[n]=t+"_"+e[n];this.getViewerImpl().getFilter().opaqueByIds(i),this.render()},closeTransparentComponentsByKey:function(e){Array.isArray(e)||(e=[e]),this.getViewerImpl().getFilter().opaqueByIds(e),this.render()},clearTransparentList:function(){this.clearComponentTransparentList(),this.clearModelTransparentList()},getTransparentComponentList:function(){return this.getViewerImpl().getFilter().getTransparentComponentList()},clearComponentTransparentList:function(){var e=this.getViewerImpl().getFilter();e.opaqueAll(),e.opaqueByIds([]),this.render()},colorfulComponentsById:function(e,t,i,n){Array.isArray(e)||(e=[e]);for(var r=[],o=0;e.length>o;o+=1)r[o]=t+"_"+e[o];var a=this.getViewerImpl().getFilter(),s={};s.color=i,"number"==typeof n&&(s.opacity=n),a.addToOverrideListByColor(r,s),this.render()},colorfulComponentsByKey:function(e,t,i){Array.isArray(e)||(e=[e]);var n=this.getViewerImpl().getFilter(),r={};r.color=t,"number"==typeof i&&(r.opacity=i),n.addToOverrideListByColor(e,r),this.render()},setComponentsMaterialByKey:function(e,t,i,n){var r=this.getComponentsByKey(e);if(Array.isArray(t)){var o,a=0,s=vu(t);try{for(s.s();!(o=s.n()).done;){var l=o.value;""===l.name&&(l.name="custMat_"+(new Date).getTime()+"_"+a,a+=1)}}catch(e){s.e(e)}finally{s.f()}}else""===t.name&&(t.name="custMat_"+(new Date).getTime());var c=this.getViewerImpl().getFilter().addToOverrideListByCustomerMaterial(this.getViewerImpl().getModelManager(),r,t,i,n);return this.render(),c},closeMaterialByKey:function(e){var t=this;Array.isArray(e)?e.forEach((function(e){var i=t.getComponentsByKey(e)[0][e][0];if(!i.isBatched&&!i.instanceOrNot&&!i.RenderTypeChange){var n=i.originMId;t.getComponentsByKey(e)[0][e][0].materialId=Array.isArray(n)?[].concat(n):n}t.closeColorfulComponentsByKey(e)})):this.closeColorfulComponentsByKey(e)},closeColorfulComponentsById:function(e,t){Array.isArray(e)||(e=[e]);for(var i=[],n=0;e.length>n;n+=1)i[n]=t+"_"+e[n];this.getViewerImpl().getFilter().addToOverrideListByColor(i,null),this.render()},closeColorfulComponentsByKey:function(e){Array.isArray(e)||(e=[e]),this.getViewerImpl().getFilter().addToOverrideListByColor(e,null),this.render()},clearColorfulList:function(){this.getViewerImpl().getFilter().clearAllOverrideList(),this.render()},wireFrameComponentsById:function(e,t){Array.isArray(e)||(e=[e]);for(var i=[],n=0;e.length>n;n+=1)i[n]=t+"_"+e[n];this.getViewerImpl().getFilter().addToWireframeByWireframe(i,{wireframe:!0}),this.render()},wireFrameComponentsByKey:function(e){Array.isArray(e)||(e=[e]);this.getViewerImpl().getFilter().addToWireframeByWireframe(e,{wireframe:!0}),this.render()},closeWireFrameComponentsById:function(e,t){Array.isArray(e)||(e=[e]);for(var i=[],n=0;e.length>n;n+=1)i[n]=t+"_"+e[n];this.getViewerImpl().getFilter().addToWireframeByWireframe(i,null),this.render()},closeWireFrameComponentsByKey:function(e){Array.isArray(e)||(e=[e]),this.getViewerImpl().getFilter().addToWireframeByWireframe(e,null),this.render()},clearWireframeList:function(){this.getViewerImpl().getFilter().clearAllWireframeList(),this.render()},isolateComponentsById:function(e,t,i){Array.isArray(e)||(e=[e]);for(var n=[],r=0;e.length>r;r+=1)n[r]=t+"_"+e[r];this.getViewerImpl().getFilter().setIsolateList(n,!1!==i),this.render()},isolateComponentsByKey:function(e,t){Array.isArray(e)||(e=[e]),this.getViewerImpl().getFilter().setIsolateList(e,!1!==t),this.render()},closeIsolateComponentsById:function(e,t){Array.isArray(e)||(e=[e]);for(var i=[],n=0;e.length>n;n+=1)i[n]=t+"_"+e[n];this.getViewerImpl().getFilter().removeFromIsolateList(i),this.render()},closeIsolateComponentsByKey:function(e){Array.isArray(e)||(e=[e]),this.getViewerImpl().getFilter().removeFromIsolateList(e),this.render()},clearIsolation:function(){this.getViewerImpl().getFilter().clearIsolation()},showModelsByKey:function(e){Array.isArray(e)||(e=[e]),this.getViewerImpl().getFilter().showModelByIds(e),this.render()},hideModelsByKey:function(e){Array.isArray(e)||(e=[e]),this.filter.hideModelByIds(e),this.render()},hideAllModels:function(){this.getViewerImpl().getFilter().hideAllModel(),this.render()},showAllModels:function(){this.getViewerImpl().getFilter().showAllModel(),this.render()},highlightModelsByKey:function(e){Array.isArray(e)||(e=[e]),this.getViewerImpl().setModelSelection(e),this.render()},addHighlightModelsByKey:function(e){Array.isArray(e)||(e=[e]),this.getViewerImpl().addToModelSelection(e),this.render()},closeHighlightModelsByKey:function(e){Array.isArray(e)||(e=[e]),this.getViewerImpl().removeFromModelSelection(e),this.render()},getHighlightModelsKey:function(){return this.getViewerImpl().getModelSelection()},clearModelHighlightList:function(){this.getViewerImpl().clearModelSelection(),this.render()},transparentModelsByKey:function(e,t,i){var n=this;Array.isArray(e)||(e=[e]),this.closeTransparentModelsByKey(e);var r=this.getViewerImpl().getFilter();t?e.forEach((function(e){r.transparentModelOrigMatByKey(n.getViewerImpl().getModelManager(),e,i)})):r.makeModelTranslucentByIds(e),this.render()},transparentOtherModelsByKey:function(e,t,i){Array.isArray(e)||(e=[e]);for(var n=[],r=0,o=Object.keys(this.viewerImpl.modelManager.models);o.length>r;r++){var a=o[r];e.includes(a)||n.push(a)}(this.closeTransparentModelsByKey(n),t)?this.transparentModelsByKey(n,t,i):this.getViewerImpl().getFilter().makeTranslucentOthersModelByIds(e);this.render()},transparentAllModels:function(e,t){if(this.clearModelTransparentList(),e){var i=Object.keys(this.viewerImpl.modelManager.models);this.transparentModelsByKey(i,e,t)}else{this.getViewerImpl().getFilter().makeTranslucentOthersModelByIds([])}this.render()},closeTransparentModelsByKey:function(e){var t=this,i=this.getViewerImpl().getFilter();Array.isArray(e)||(e=[e]),e.forEach((function(e){i.closeOrigMatModelTransparent(t.viewerImpl.modelManager,e)})),i.opaqueModelByIds(e),this.render()},clearModelTransparentList:function(){var e=this,t=this.getViewerImpl().getFilter();Object.keys(this.viewerImpl.modelManager.models).forEach((function(i){t.closeOrigMatModelTransparent(e.viewerImpl.modelManager,i)})),t.opaqueAllModel(),t.opaqueModelByIds([]),this.render()},colorfulModelsByKey:function(e,t,i){Array.isArray(e)||(e=[e]);var n=this.getViewerImpl().getFilter(),r={};r.color=t,"number"==typeof i&&(r.opacity=i),n.addToModelOverrideListByColor(e,r),this.render()},closeColorfulModelsByKey:function(e){Array.isArray(e)||(e=[e]),this.getViewerImpl().getFilter().addToModelOverrideListByColor(e,null),this.render()},clearModelColorfulList:function(){this.getViewerImpl().getFilter().clearModelAllOverrideList(),this.render()},isolateModelsByKey:function(e,t){Array.isArray(e)||(e=[e]),this.getViewerImpl().getFilter().setModelIsolateList(e,!1!==t),this.render()},closeIsolateModelsByKey:function(e){Array.isArray(e)||(e=[e]),this.getViewerImpl().getFilter().removeModelFromIsolateList(e),this.render()},clearModelIsolation:function(){this.getViewerImpl().getFilter().clearModelIsolation(),this.render()},setModelMatrix:function(e,t){this.getViewerImpl().setModelMatrix(t,e)},getModelMatrix:function(e){return this.getViewerImpl().getModelMatrix(e)},disableComponentsSelectionByKey:function(e){Array.isArray(e)||(e=[e]),this.filter.addToFrozenList(e)},enableComponentsSelectionByKey:function(e){Array.isArray(e)||(e=[e]),this.filter.removeFromFrozenList(e)},clearDisableSelectionList:function(){this.filter.clearFrozen()},overturnYAndZaxis:function(e){this.getViewerImpl().overturnYAndZaxis(e),this.render()},translateModel:function(e){this.getViewerImpl().translateModel(e)},rotateModel:function(e){this.getViewerImpl().rotateModel(e)},scaleModel:function(e){this.getViewerImpl().scaleModel(e)},modelsExplosion:function(e){for(var t={modelKey:[],coefficientX:1,coefficientY:1,coefficientZ:1,center:this.getViewerImpl().getScene().getBoundingBoxWorld().getCenter(new Ke).toArray()},i=wp.extend(!0,{},t,e),n=Array.isArray(i.modelKey)?i.modelKey:[i.modelKey],r=0;n.length>r;r+=1){var o=this.getViewerImpl().getModel(n[r]);o&&o.explosion(i)}this.getViewerImpl().getModelManager().updateSceneBoundingBox(),this.render()},closeModelsExplosion:function(e){var t=Array.isArray(e)?e:[e];this.modelsExplosion({modelKey:t}),this.render()},componentsExplosion:function(e){var t={componentKey:[],coefficientX:1,coefficientY:1,coefficientZ:1,offsetX:0,offsetY:0,offsetZ:0,center:this.getViewerImpl().getScene().getBoundingBoxWorld().getCenter(new Ke).toArray()},i=wp.extend(!0,{},t,e),n=this.getViewerImpl().getModelManager();n.componentsExplosion(i),n.updateSceneBoundingBox(),this.render()},closeComponentsExplosion:function(e){var t=Array.isArray(e)?e:[e];this.getViewerImpl().getModelManager().componentsExplosion({componentKey:t}),this.render()},canFloorExplosion:function(){return this.getViewerImpl().getModelManager().canFloorExplosion()},floorExplosion:function(e){return!!this.getViewerImpl().getModelManager().floorExplosion(e)&&(this.render(),!0)},closeFloorExplosion:function(){var e=this.getViewerImpl().getModelManager();e.closeFloorExplosion(),e.updateSceneBoundingBox(),this.render()},componentApplyMatrix:function(e,t){return!(!t||!t.isMatrix4)&&(this.getViewerImpl().componentApplyMatrix2(e,t),this.render(),!0)},getMatrix4FromEuler:function(e,t,i){var n=0,r=0,o=0;Array.isArray(e)?(n=e[0],r=e[1],o=e[2]):(n=e.x,r=e.y,o=e.z);var a=t||[0,0,0],s=0,l=0,c=0;Array.isArray(a)?(s=a[0],l=a[1],c=a[2]):(s=a.x,l=a.y,c=a.z);var h=new yt;h.setPosition(-s,-l,-c);var d=new yt,u=new bt(n,r,o,i||"XYZ");d.makeRotationFromEuler(u);var p=new yt;return p.setPosition(s,l,c),p.multiply(d).multiply(h),p},isolateComponentsByIdForJDS:function(e,t){Array.isArray(e)||(e=[e]);for(var i=[],n=0;e.length>n;n+=1)i[n]=t+"_"+e[n];this.filter.addToIsolateList(Pd.HIDDEN_OTHERS,i);for(var r=this.getViewerImpl().modelManager.getScene().pool._pool,o=0;r.length>o;o+=1){r[o].visible=!1;for(var a=0;i.length>a;a+=1)r[o].key===i[a]&&(r[o].visible=!0)}return this.render(),!0},sortComponentsById:function(e,t,i){Array.isArray(e)||(e=[e]);for(var n=this.getViewerImpl().getModel(t),r=[],o=0;e.length>o;o+=1)r[o]=t+"_"+e[o];return n?n.getComponentKeysByTypeFromList(r,i):[]},sortComponentsByKey:function(e,t){return Array.isArray(e)||(e=[e]),this.getViewerImpl().modelManager.getComponentKeysByTypeFromList(e,t)},conditionSortComponentsById:function(e,t,i,n,r){var o=this.filter.setConditions(e,t);Array.isArray(i)||(i=[i]);for(var a=[],s=0;i.length>s;s+=1)a[s]=n+"_"+i[s];var l=this.getComponentsByKey(a),c=[];if(null!==o)switch(e){case 0:for(var h=0;l.length>h;h+=1)o.match(l[h])&&c.push(l[h].key);this.isolateComponentsByKey(c);break;case 1:for(var d=0;l.length>d;d+=1)o.match(l[d])&&c.push(l[d].key);var u=this.otherObjectsInScene(c);this.transparentComponentsByKey(u,.5,!1);break;case 2:for(var p=0;l.length>p;p+=1)null!==o.getMatchItem(l[p])&&c.push(l[p].key);!0===r.highLight?this.highlightComponentsByKey(c):this.colorfulComponentsByKey(c,r.color)}return c},conditionSortComponentsByKey:function(e,t,i,n){var r=this.filter.setConditions(e,t);Array.isArray(i)||(i=[i]);var o=this.getComponentsByKey(i),a=[];if(null!==r)switch(e){case 0:for(var s=0;o.length>s;s+=1)r.match(o[s])&&a.push(o[s].key);this.isolateComponentsByKey(a);break;case 1:for(var l=0;o.length>l;l+=1)r.match(o[l])&&a.push(o[l].key);var c=this.otherObjectsInScene(a);this.transparentComponentsByKey(c,.5,!1);break;case 2:for(var h=0;o.length>h;h+=1)null!==r.getMatchItem(o[h])&&a.push(o[h].key);!0===n.highLight?this.highlightComponentsByKey(a):this.colorfulComponentsByKey(a,n.color)}return a},resetScene:function(e){var t=this;if(e=e||{},this.getViewerImpl().getModelManager().dispatchEvent({type:Fd.BEFORE_RESETSCENE,data:e}),wp.isEmptyObject(e))if(this.clearIsolation(),this.clearModelIsolation(),this.clearHighlightList(),this.clearModelHighlightList(),this.showAllComponents(),this.showAllModels(),this.clearWireframeList(),this.clearTransparentList(),this.clearModelTransparentList(),this.clearColorfulList(),this.clearModelColorfulList(),this.originalView)t.viewerImpl.lookAt(this.originalView.position,this.originalView.target,this.originalView.up);else if(this.defaultOriginalView)t.viewerImpl.lookAt(this.defaultOriginalView.position,this.defaultOriginalView.target,this.defaultOriginalView.up);else{var i=t.viewerImpl.modelManager.scene.getBoundingBox(),n=i.getCenter(new Ke),r=i.getSize(new Ke),o=new Ke(n.x+r.x,n.y+r.y,n.z+r.z);t.viewerImpl.lookAt(o,n,new Ke(0,0,1))}else if(e.visible&&(this.clearIsolation(),this.clearModelIsolation(),this.showAllComponents(),this.showAllModels()),e.selected&&(this.clearHighlightList(),this.clearModelHighlightList()),e.transparent&&(this.clearTransparentList(),this.clearModelTransparentList()),e.wireframed&&this.clearWireframeList(),e.colorfully&&(this.clearColorfulList(),this.clearModelColorfulList()),e.view)if(this.originalView)t.viewerImpl.lookAt(this.originalView.position,this.originalView.target,this.originalView.up);else if(this.defaultOriginalView)t.viewerImpl.lookAt(this.defaultOriginalView.position,this.defaultOriginalView.target,this.defaultOriginalView.up);else{var a=t.viewerImpl.modelManager.scene.getBoundingBox(),s=a.getCenter(new Ke),l=a.getSize(new Ke),c=new Ke(s.x+l.x,s.y+l.y,s.z+l.z);t.viewerImpl.lookAt(c,s,new Ke(0,0,1))}this.getViewerImpl().getModelManager().dispatchEvent({type:Fd.AFTER_RESETSCENE,data:e}),this.render()},getScreenCoordFromSceneCoord:function(e){return this.getViewerImpl().getScreenCoordFromSceneCoord(e)},getWorldPositionFromLocalPositionByModelKey:function(e,t){var i=this.getModelMatrix(t);if(i){if(e.isVector3){var n=e.clone();return n.applyMatrix4(i),n.toArray()}if(Array.isArray(e)){var r=(new Ke).fromArray(e);return r.applyMatrix4(i),r.toArray()}}else Bu.error("模型key无效")},getLocalPositionFromWorldPositionByModelKey:function(e,t){var i=this.getModelMatrix(t);if(i){var n=(new yt).copy(i).invert();if(e.isVector3){var r=e.clone();return r.applyMatrix4(n),r.toArray()}if(Array.isArray(e)){var o=(new Ke).fromArray(e);return o.applyMatrix4(n),o.toArray()}}else Bu.error("模型key无效")},getWorldPositionListFromLocalPositionListByModelKey:function(e,t){var i=this.getModelMatrix(t);if(i){for(var n=[],r=0,o=e.length;o>r;r+=1){var a=e[r];if(a.isVector3){var s=a.clone();s.applyMatrix4(i),n.push(s.toArray())}else if(Array.isArray(a)){var l=(new Ke).fromArray(a);l.applyMatrix4(i),n.push(l.toArray())}}return n}Bu.error("模型key无效")},getLocalPositionListFromWorldPositionListByModelKey:function(e,t){var i=this.getModelMatrix(t);if(i){for(var n=(new yt).copy(i).invert(),r=[],o=0,a=e.length;a>o;o+=1){var s=e[o];if(s.isVector3){var l=s.clone();l.applyMatrix4(n),r.push(l.toArray())}else if(Array.isArray(s)){var c=(new Ke).fromArray(s);c.applyMatrix4(n),r.push(c.toArray())}}return r}Bu.error("模型key无效")},getWorldPositionArrayFromLocalPositionArrayByModelKey:function(e,t){var i=this.getModelMatrix(t);if(i){for(var n=[],r=0,o=e.length;o>r;r+=3){var a=(new Ke).fromArray(e,r);a.applyMatrix4(i),n.push.apply(n,mu(a.toArray()))}return n}Bu.error("模型key无效")},getLocalPositionArrayFromWorldPositionArrayByModelKey:function(e,t){var i=this.getModelMatrix(t);if(i){for(var n=(new yt).copy(i).invert(),r=[],o=0,a=e.length;a>o;o+=3){var s=(new Ke).fromArray(e,o);s.applyMatrix4(n),r.push.apply(r,mu(s.toArray()))}return r}Bu.error("模型key无效")},render:function(){this.getViewerImpl().render()},syncRender:function(){this.getViewerImpl()._render()},resize:function(e,t){this.getViewerImpl().resize(e,t)},autoResize:function(){this.getViewerImpl().resize(window.innerWidth-5,window.innerHeight-5)},setSceneBackGroundColor:function(e,t){this.getViewerImpl().setBackgroundColor(new Du(e,t))},resetSceneBackgroundColor:function(){this.getViewerImpl().resetBackgroundColor()},getComponentsAttributeById:function(e,t,i){this.getComponentsAttributeByKey(t+"_"+e,i)},getComponentsAttributeByKey:function(e,t,i){var n=this.getViewerImpl().getModelByComponentKey(e)||this.getViewerImpl().getModel(i);if(n){if(n.offLine){if(n.attributes&&n.attributes[e])return void t({attribute:n.attributes[e]});t(null)}Yy({type:"GET",url:(n.loader.url.serverUrl||this.host)+"/api/"+n.projectKey+"/components?componentKey="+e+(""===n.shareKey?"":"&share="+n.shareKey),headers:{Authorization:n.accessToken},success:function(e){try{e=JSON.parse(e)}catch(e){Bu.log("解析属性失败")}t("SUCCESS"===e.code?e.data:null)},error:function(e){t(null)}})}else t(null)},mergeMesh:function(e,t){var i=this.getViewerImpl().modelManager.getModel(t);if(!i)return null;var n=new cm("mergeGroup");n.modelKey=t;for(var r=new Ni,o=[],a=[],s=[],l=[],c=[],h=[],d=i.cache,u=[],p=[],g=null,f=0,m=0;e.length>m;m+=1)if(i.cache.components.hasOwnProperty(e)){f+=1;var A={},y=a.length,v=o.length/3;A.start=y;var C=c.length,I=i.cache.components[e],x=d.geometries[I.geoId];if(!x)continue;var w=x.clone(),M=new yt;M.fromArray(I.matrix);var E=w.attributes;w.applyMatrix(M);for(var B=0;E.position.array.length>B;B+=1)o.push(E.position.array[B]);for(var S=0;E.normal.array.length>S;S+=1)l.push(E.normal.array[S]);if(E.uv)for(var b=0;E.uv.array.length>b;b+=1)s.push(E.uv.array[b]);for(var k=0;w.index.array.length>k;k+=1)a.push(w.index.array[k]+v);if(w.groups.length>0)for(var D=0;w.groups.length>D;D+=1){var T={};T.start=w.groups[D].start+y,T.count=w.groups[D].count,-1!==w.groups[D].materialIndex&&(T.materialIndex=w.groups[D].materialIndex+C),h.push(T)}else{var R={};R.start=y,R.count=w.index.count,R.materialIndex=C,h.push(R)}var U=d.materials[I.matId];if(!U)continue;for(k=0;U.materials.length>k;k+=1)c.push(U.materials[k]);if(A.end=a.length/3,A.guid=I.guid,f>xd.MaxMergeCount){if(f=0,r.setAttribute("position",new Ai(new Float32Array(o),3)),r.setAttribute("normal",new Ai(new Float32Array(l),3)),r.setAttribute("uv",new Ai(new Float32Array(s),2)),u=[],Array.fill)u=Array(o.length).fill(1);else for(var F=0;o.length>F;F+=1)u.push(1);p=new Float32Array(u),r.setAttribute("color",new Ai(p,3,!0)),r.setIndex(a),r.groups=h,g=new nn(r,c),n.add(g),r=new Ni,o=[],a=[],s=[],l=[],c=[],h=[]}}if(r.setAttribute("position",new Ai(new Float32Array(o),3)),r.setAttribute("normal",new Ai(new Float32Array(l),3)),r.setAttribute("uv",new Ai(new Float32Array(s),2)),u=[],Array.fill)u=Array(o.length).fill(1);else for(F=0;o.length>F;F+=1)u.push(1);return p=new Float32Array(u),r.setAttribute("color",new Ai(p,3,!0)),r.setIndex(a),r.groups=h,g=new nn(r,c),n.add(g),u=null,o=null,a=null,s=null,l=null,c=null,h=null,n},setComponentPositionByKey:function(e,t){this.getViewerImpl().setComponentPositionByKey(e,t),this.render()},setComponentPositionById:function(e,t,i){},getBoxByComponentsKey:function(e){return Array.isArray(e)||(e=[e]),this.getViewerImpl().getBoundingBoxByIds(e)},getAttributeByComponentKey:function(){},zoomToBox:function(e,t,i){this.getViewerImpl().zoomToBox(e,t,i)},zoomIn:function(e,t,i){this.getViewerImpl().zoomIn(e,t,i)},zoomOut:function(e,t,i){this.getViewerImpl().zoomOut(e,t,i)},flyToStandardView:function(e,t,i,n){this.getViewerImpl().setStandardView(e,t,i,n)},setStandardViewWithBox:function(e,t,i,n){this.getViewerImpl().setStandardViewWithBox(e,t,i,n)},adaptiveSize:function(){this.getViewerImpl().zoomToSelection()},adaptiveSizeByKey:function(e){Array.isArray(e)||(e=[e]);var t=this.getViewerImpl().getBoundingBoxByIds(e);t&&!t.isEmpty()&&this.getViewerImpl().zoomToBox(t)},flyTo:function(e,t){var i=this;this.getViewerImpl().animator.slerpFlyTo(e,this.viewerImpl,(function(e){i.viewerImpl.cameraControl.update(!0,!0)}),t)},linearFlyTo:function(e,t){var i=this;this.getViewerImpl().animator.linearFlyTo(e,this.viewerImpl,(function(e){i.viewerImpl.cameraControl.update(!0,!0)}),t)},slerpFlyTo:function(e,t){var i=this;this.getViewerImpl().animator.slerpFlyTo(e,this.viewerImpl,(function(e){i.viewerImpl.cameraControl.update(!0,!0)}),t)},setAnimatorDuration:function(e){var t=this.getViewerImpl().animator;return!(!t||"number"!=typeof e)&&(t.setDuration(e),!0)},getAnimatorDuration:function(){var e=this.getViewerImpl().animator;if(e)return e.getDuration()},enableViewController:function(){var e=this;return this.viewController?(this.viewController.enable(),!0):(this.viewController=new Rk(this.viewerImpl,(function(){return!0})),this.viewController.init(this.getViewerImpl().getDomElement()),this.viewController.render(),this.getViewerImpl().addRenderFinishedListener((function(){e.viewController.render()})),!0)},disableViewController:function(){return!!this.viewController&&(this.viewController.disable(),!0)},enabledCameraRotateOfVerticalPolarAngle:function(e){this.getViewerImpl().cameraControl.enabledPolar(e),Bu.warn("请改用 lockAxisZ 方法")},lockAxisZ:function(e,t){this.getViewerImpl().lockAxisZ(e,t)},setMinPolarAngle:function(e){this.getViewerImpl().cameraControl.setMinPolarAngle(e),Bu.warn("请改用 lockAxisZ 方法")},setMaxPolarAngle:function(e){this.getViewerImpl().cameraControl.setMaxPolarAngle(e),Bu.warn("请改用 lockAxisZ 方法")},getMinPolarAngle:function(){return this.getViewerImpl().cameraControl.getMinPolarAngle()},getMaxPolarAngle:function(){return this.getViewerImpl().cameraControl.getMaxPolarAngle()},enableRotate:function(e){return Kp.NoRotate=!e,!Kp.NoRotate},enablePan:function(e){return Kp.NoPan=!e,!Kp.NoPan},enableZoom:function(e){return Kp.NoZoom=!e,!Kp.NoZoom},setPointRotateMode:function(e){return this.getViewerImpl().setPointRotateMode(e),Kp.RotatePivotMode},rotateCamera:function(e,t){var i=new ke,n=new Ke;Array.isArray(e)?i.set(e[0],e[1]):i.set(e.x,e.y),t?Array.isArray(t)?n.fromArray(t):n.set(t.x,t.y,t.z):n=this.getViewerImpl().getScene().getBoundingBoxWorld().getCenter(n),this.getViewerImpl().rotateCamera(i,n)},requestPointerLock:function(){this.getViewerImpl().getControlManager().requestPointerLock()},initAdsorbControl:function(){this.controlManager.enableTool(this.viewerImpl,Yd.COMPONENT_TRANSFORM);var e=this.controlManager.componentTransformTool;e.transformControl.enabled=!1,this.adsorbControl.setTransformControl(e)},enableAdsorbControl:function(){var e=0>=arguments.length||void 0===arguments[0]||arguments[0];this.adsorbControl.enabled=e},getAdsorbControlEnableState:function(){return this.adsorbControl.enabled},translateComponentByKey:function(e,t,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{};this.getViewerImpl().translateComponentByKey(e,t,i),this.viewerImpl._setAdsorbSelectedObject(e,n.isAdsorb)},scaleComponentByKey:function(e,t,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{};this.getViewerImpl().scaleComponentByKey(e,t,i),this.viewerImpl._setAdsorbSelectedObject(e,n.isAdsorb)},rotateComponentByKey:function(e,t,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{};this.getViewerImpl().rotateComponentByKey(e,t,i),this.viewerImpl._setAdsorbSelectedObject(e,n.isAdsorb);var r=this.controlManager.getToolByName(Yd.COMPONENT_TRANSFORM);r.transformControl.rotateSpace=Wg(n.rotateSpace,zg.WORLD)},cancelTransformComponent:function(e){this.getViewerImpl().cancelTransformComponent(e)},restoreComponentTransform:function(){this.getViewerImpl().restoreComponentTransform()},getComponentLocalMatrixByKey:function(e){return this.getViewerImpl().getComponentLocalMatrixByKey(e)},getComponentWorldMatrixByKey:function(e){return this.getViewerImpl().getComponentWorldMatrixByKey(e)},setComponentLocalMatrixByKey:function(e,t){return this.getViewerImpl().setComponentLocalMatrixByKey(e,t)},resetComponentMatrix:function(e,t){return this.getViewerImpl().resetComponentMatrix(e,t)},increaseComponentTransformControlSize:function(){this.getViewerImpl().increaseComponentTransformControlSize()},decreaseComponentTransformControlSize:function(){this.getViewerImpl().decreaseComponentTransformControlSize()},setComponentTransformControlSize:function(e){this.getViewerImpl().setComponentTransformControlSize(e)},getComponentTransformControlSize:function(){return this.getViewerImpl().getComponentTransformControlSize()},setComponentTransformSpaceToLocalSpace:function(){this.getViewerImpl().setComponentTransformSpaceToLocalSpace()},setComponentTransformSpaceToWorldSpace:function(){this.getViewerImpl().setComponentTransformSpaceToWorldSpace()},switchComponentTransformSpaceBetweenLocalAndWorld:function(){this.getViewerImpl().switchComponentTransformSpaceBetweenLocalAndWorld()},showComponentTransformOnAxis:function(e){this.getViewerImpl().showComponentTransformOnAxis(e)},hideComponentTransformOnAxis:function(e){this.getViewerImpl().hideComponentTransformOnAxis(e)},disableComponentTransform:function(){this.getViewerImpl().disableComponentTransform()},enableComponentTransform:function(){this.getViewerImpl().enableComponentTransform()},enableSectionBox:function(){var e=this,t=this.getViewerImpl();t.controlManager.enableTool(t,Yd.CLIP_BY_BOX),e._sectionTool=new vk(t),e._sectionTool.toggle(!0,!0),e._sectionTool.setVisible(!0),e._sectionTool.reset(),e._isSection=!0,this.render()},disableSectionBox:function(){this.getViewerImpl().controlManager.disableTool(Yd.CLIP_BY_BOX),this._isSection=!1,this.render()},resetSectionBox:function(){this._isSection?(this.showSectionBox(),this.setSectionBoxMode(),this._sectionTool.reset("Rotate")):Bu.log(rg[xd.language].SectionBoxLockHint)},setSectionBoxMode:function(e){this._isSection?this._sectionTool.setRotatable("Rotate"===e):Bu.log(rg[xd.language].SectionBoxLockHint)},showSectionBox:function(){this._isSection?(this._sectionTool.setVisible(!0),this.render()):Bu.log(rg[xd.language].SectionBoxLockHint)},hideSectionBox:function(){this._isSection?(this._sectionTool.setVisible(!1),this.render()):Bu.log(rg[xd.language].SectionBoxLockHint)},setSectionBox:function(e){var t=this.getViewerImpl(),i=t.getScene().getClipPlanes(),n=t.worldToDrawing(e.min),r=t.worldToDrawing(e.max);this.enableSectionBox(),i.setSectionBox(n,r),this.hideSectionBox()},getSectionBoxState:function(){if(this._isSection)return this._sectionTool.saveState();Bu.log(rg[xd.language].SectionBoxLockHint)},setSectionBoxState:function(e){this._isSection?(this._sectionTool.loadState(e),this.render()):Bu.log(rg[xd.language].SectionBoxLockHint)},getSceneState:function(){return this.getViewerImpl().getSceneState()},setSceneState:function(e){this.getViewerImpl().setSceneState(e)},getScreenShot:function(e){var t,i,n,r;return e.color&&e.color instanceof Du&&(t=e.color.getRGBA()),e.width>0&&e.height>0&&(n=e.width,r=e.height),"function"==typeof e.callback&&(i=e.callback),this.getViewerImpl().canvas2image(t,n,r,i)},registerModelEventListener:function(e,t){this.getViewerImpl().registerEventListener(e,t)},unregisterModelEventListener:function(e,t){this.getViewerImpl().unregisterEventListener(e,t)},registerControlEventListener:function(e,t){this.getViewerImpl().registerDomEventListener(e,t)},unregisterControlEventListener:function(e,t){this.getViewerImpl().unregisterDomEventListener(e,t)},registerCameraEventListener:function(e,t){this.getViewerImpl().registerCameraEventListener(e,t)},unregisterCameraEventListener:function(e,t){this.getViewerImpl().unregisterCameraEventListener(e,t)},enableLogarithmicDepthBuffer:function(e){this.getViewerImpl().enableLogarithmicDepthBuffer(e)},setSkyBox:function(e,t,i,n){var r=this.getRootScene();r&&(e?r.setSkyBox(void 0,e,t,i,n):r.background=null)},setDrawingStyle:function(e){this.getViewerImpl().setDrawingStyle(e),this.render()},setExposure:function(e){this.getViewerImpl().setExposureShift(e),this.render()},getBoardlineColor:function(e){var t=this.getViewerImpl().getWireframeColor(e);return new Du(t,t.opacity)},setBoardlineColor:function(e,t){var i=null;i=e instanceof Du?e:new Du(e),this.getViewerImpl().setWireframeColor(i,t)},restoreBoardlineColor:function(e){this.getViewerImpl().restoreWireframeColor(e)},getSelectionBoardlineColor:function(){return this.getViewerImpl().getOutlineEdgeColor()||new Du},setSelectionBoardlineColor:function(e){var t=null;t=e instanceof Du?e:new Du(e),this.getViewerImpl().setOutlineEdgeColor(t)},restoreSelectionBoardlineColor:function(){this.getViewerImpl().restoreOutlineEdgeColor()},getSelectionColor:function(){return this.getViewerImpl().getSelectionColor()},setSelectionColor:function(e){var t=null;t=e instanceof Du?e:new Du(e),this.getViewerImpl().setSelectionColor(t)},restoreSelectionColor:function(){this.getViewerImpl().restoreSelectionColor()},setAxisNetColor:function(e,t){this.viewerImpl.setAxisNetColor(e,t)},showAxisNet:function(){this.viewerImpl.showAxisNet()},hideAxisNet:function(){this.viewerImpl.hideAxisNet()},enableAxisNetStayInFront:function(){this.viewerImpl.enableAxisNetStayInFront()},disableAxisNetStayInFront:function(){this.viewerImpl.disableAxisNetStayInFront()},getScene:function(){return this.getViewerImpl().getScene().getExternalScene()},getRootScene:function(){return this.getViewerImpl().getScene()},getMinDistanceByComponentKey:function(e,t){return this.getViewerImpl().calculateMinDistance(e,t)},updateSceneBoundingBox:function(){this.getExternalComponentManager().calculateBoundingBox(),this.getViewerImpl().modelManager.updateSceneBoundingBox()},getCurrentControlName:function(){return this.getViewerImpl().getCurrentControlName()},setControlMode:function(e){this.getViewerImpl().setControlMode(e),this.render()},setControlDefault:function(){this.setControlMode(Vd.PICK)},setZoomSpeed:function(e){this.getViewerImpl().cameraControl.setZoomSpeed(e)},getZoomSpeed:function(){return this.getViewerImpl().cameraControl.getZoomSpeed()},setZoomOutLimitRate:function(e){this.getViewerImpl().cameraControl.setZoomOutLimitRate(e)},getZoomOutLimitRate:function(){return this.getViewerImpl().cameraControl.getZoomOutLimitRate()},setLightIntensityFactor:function(e){this.getViewerImpl().setLightIntensityFactor(e)},enableShadow:function(e){this.getViewerImpl().enableShadow(e)},updateShadowLight:function(){this.getViewerImpl().updateShadowLight()},setShadowLightDir:function(e){var t;e?(t=Array.isArray(e)?(new Ke).fromArray(e):e.isVector3?e:new Ke(e.x,e.y,e.z),this.getViewerImpl().getScene().lightManager.shadowLightDir=t):Bu.error("无效参数")},getShadowLightDir:function(){return this.getViewerImpl().getScene().lightManager.shadowLightDir.clone()},getLightDirFromAltitudeAndAzimuth:function(e,t){if(void 0!==e&&void 0!==t)return this.getViewerImpl().getScene().lightManager.getLightDirFromAltitudeAndAzimuth(e,t);Bu.error("参数不合法")},getExternalComponentManager:function(){return this.getViewerImpl().getExternalComponentManager()},addExternalObject:function(e,t,i,n){this.getViewerImpl().addExternalObject(e,t,i,n)},addExternalObjects:function(e,t,i){return this.getViewerImpl().addExternalObjects(e,t,i)},removeExternalObjectByName:function(e){this.getViewerImpl().removeExternalObjectByName(e)},clearExternalObjects:function(){this.getViewerImpl().clearExternalObjects()},getExternalObjectByName:function(e){return this.getViewerImpl().getExternalObjectByName(e)},getAllExternalObjects:function(){return this.getViewerImpl().getAllExternalObjects()},showFPS:function(){this.fpsStats=new yk;var e=this;this.viewportDiv.appendChild(this.fpsStats.dom),this.fpsStats.listener=function(){e.fpsStats.update()},this.getViewerImpl().addRenderListener(this.fpsStats.listener)},hideFPS:function(){this.fpsStats&&(this.viewportDiv.removeChild(this.fpsStats.dom),this.getViewerImpl().removeRenderListener(this.fpsStats.listener)),this.fpsStats=null},cloneComponentByKey:function(e,t){var i=this.getViewerImpl().cloneComponent(e);return"translate"===t?this.translateComponentByKey(i.key):"scale"===t?this.scaleComponentByKey(i.key):"rotate"===t&&this.rotateComponentByKey(i.key),null!==i?{mesh:i,key:i.key}:null},getTimerManager:function(){return this.getViewerImpl().getTimerManager()},setCloneComponentMaterialsByKey:function(e,t,i){return this.getViewerImpl().getExternalComponentManager().setCloneComponentMaterialsByKey(e,t,i)},createSmoothCurve:function(e){return this.getViewerImpl().catmullRomCurve(e)},setBlinkByComponentKeys:function(e,t,i,n){Array.isArray(e)||(e=[e]),this.getViewerImpl().setComponentBlinkByComponentKeys(e,t,i,n)},closeBlinkByComponentKeys:function(e){Array.isArray(e)||(e=[e]),this.getViewerImpl().closeComponentBlinkByComponentKeys(e)},clearBlinkList:function(){this.getViewerImpl().clearBlinkList()},setShadowAttributes:function(e){if(e.position){var t=e.position;e.position=new Ke(t.x,t.y,t.z)}if(e.target){var i=e.target;e.target=new Ke(i.x,i.y,i.z)}this.getRootScene().lightManager.setShadowAttributes(e),this.getViewerImpl().getRenderer().shadowMap.needsUpdate=!0,this.getViewerImpl()._render(),this.getViewerImpl().rendererManager.renderer.setClearColor(0,0),this.getViewerImpl()._render()},resetShadowAttributes:function(){this.getRootScene().lightManager.resetShadowAttributes(),this.getViewerImpl().getRenderer().shadowMap.needsUpdate=!0,this.getViewerImpl()._render(),this.getViewerImpl().rendererManager.renderer.setClearColor(0,0),this.getViewerImpl()._render()},addToRootScene:function(e){e.isProjectorLight?this.rootScene.projectorLightCollection.addObject(e):this.rootScene.addObject(e)},removeFromRootScene:function(e){e.isProjectorLight?this.rootScene.projectorLightCollection.removeObject(e):this.rootScene.removeObject(e)},destroy:function(){this.getViewerImpl().destroy(),this.viewController&&(this.viewController.destroy(),this.viewController=null)},getCanvasSize:function(){return this.getViewerImpl().rendererManager.getRendererSize()}}),Object.defineProperties(Uk.prototype,{externalScene:{get:function(){return this.viewerImpl.scene.getExternalScene()}},adsorbControl:{get:function(){return this.rootScene.adsorbControl}},controlManager:{get:function(){return this.viewerImpl.controlManager}},rootScene:{get:function(){return this.viewerImpl.scene}},scene:{get:function(){return this.viewerImpl.scene}},rootSceneCamera:{get:function(){return this.viewerImpl.sceneCamera}}});var Fk=function(e){lu(i,e);var t=pu(i);function i(e){var n;ru(this,i);var r=du(n=t.call(this,e));return r.vertexShader=r.getVertexShader(),r.fragmentShader=r.getFragmentShader(),n}return i}(cn);SA(Fk,[{key:"getVertexShader",value:function(){return"\n attribute float size;\n attribute float alpha;\n attribute vec3 color;\n varying vec3 vColor;\n varying float vAlpha;\n #include <common>\n #include <logdepthbuf_pars_vertex>\n void main() {\n vAlpha= alpha;\n vColor = color;\n vec4 mvPosition = modelViewMatrix * vec4( position, 1.0 );\n gl_PointSize = size * ( 2400.0 / -mvPosition.z );\n gl_Position = projectionMatrix * mvPosition;\n #include <logdepthbuf_vertex>\n }"}},{key:"getFragmentShader",value:function(){return"mat2 rotate(float rad) {\n float c = cos(rad);\n float s = sin(rad);\n return mat2(c, s,-s, c);\n }\n uniform sampler2D pointTexture;\n uniform float repeatX;\n uniform float repeatY;\n varying vec3 vColor;\n varying float vAlpha;\n #include <logdepthbuf_pars_fragment>\n void main() {\n #include <logdepthbuf_fragment>\n vec2 pos = gl_PointCoord;\n float offsetX =(1.0-repeatX)/2.0;\n float offsetY =(1.0-repeatY)/2.0;\n if(pos.x-offsetX>repeatX || pos.x-offsetX<0.0 || pos.y-offsetY>repeatY || pos.y-offsetY<0.0) discard;\n vec4 img = texture2D(pointTexture, vec2((pos.x-offsetX)/repeatX, (pos.y-offsetY)/repeatY));\n vec4 color = vec4( vColor, vAlpha );\n gl_FragColor = vec4(color.xyz, color.w * img.w);\n }"}}]);var Qk=function(e){var t=this;t.size=e.size,t.alpha=e.alpha,t.visible=0,t.birth=e.birth,t.age=e.age,t.minimumParticleLife=e.minimumParticleLife,t.maximumParticleLife=e.maximumParticleLife,t.minimumSpeed=e.minimumSpeed,t.maximumSpeed=e.maximumSpeed,t.scaleAry=e.scaleAry,t.colorAry=e.colorAry,t.emitPosition=e.emitPosition,t.radius=e.radius,t.initSize=e.initSize,t.updateCallback=e.updateCallback,t.camera=e.camera,t.life=0,t.initVelocity=e.initVelocity,t.normalizedAge=0,t.originPitch=e.originPitch,t.birthplace={x:0,y:0,z:0},t.velocity={x:0,y:0,z:0},t.position={x:0,y:0,z:0},t.randomXY=e.randomXY,t.applyGravity=e.applyGravity,t.randomFrameNumber=e.randomFrameNumber,t.color=new pi};SA(Qk,[{key:"updateStatus",value:function(e){var t=this;if(null!==t.birth&&e!==t.birth)if(t.age=e-t.birth,t.age>t.life)t.visible=0;else{t.visible=1,t.randomFrameNumber&&(t.age+=50*(2*Math.random()-1),0>t.age&&(t.age=0),t.age>t.life&&(t.age=t.life)),t.normalizedAge=t.age/t.life;for(var i=0;t.scaleAry.length>i;i+=1)if(t.scaleAry[i].endAge>=t.normalizedAge){t.size=t.initSize*Yp.tweens(t.scaleAry[i].startScale,t.scaleAry[i].endScale,t.normalizedAge-t.scaleAry[i].startAge,t.scaleAry[i].endAge-t.scaleAry[i].startAge);break}for(i=0;t.colorAry.length>i;i+=1)if(t.colorAry[i].endAge>=t.normalizedAge){var n=t.normalizedAge-t.colorAry[i].startAge,r=t.colorAry[i].endAge-t.colorAry[i].startAge;t.color.setRGB(Yp.tweens(t.colorAry[i].startColor.x,t.colorAry[i].endColor.x,n,r),Yp.tweens(t.colorAry[i].startColor.y,t.colorAry[i].endColor.y,n,r),Yp.tweens(t.colorAry[i].startColor.z,t.colorAry[i].endColor.z,n,r)),t.alpha=Yp.tweens(t.colorAry[i].startColor.w,t.colorAry[i].endColor.w,n,r);break}t.position={x:t.birthplace.x+t.velocity.x*t.normalizedAge,y:t.birthplace.y+t.velocity.y*t.normalizedAge,z:t.birthplace.z+t.velocity.z*t.normalizedAge},wp.defined(t.applyGravity)&&(t.position.z=t.position.z-t.applyGravity*Math.pow(t.age/1e3,2)*1e3),wp.defined(t.updateCallback)&&t.updateCallback(t)}}},{key:"init",value:function(e){var t=this;t.birth=e,t.age=0,t.life=1e3*t.minimumParticleLife+Math.random()*(t.maximumParticleLife-t.minimumParticleLife)*1e3;var i=t.minimumSpeed+Math.random()*(t.maximumSpeed-t.minimumSpeed);t.normalizedAge=0,t.visible=1,wp.defined(t.scaleAry)&&(t.size=t.initSize*t.scaleAry[0].startScale),wp.defined(t.colorAry)&&(t.color.setRGB(t.colorAry[0].startColor.x,t.colorAry[0].startColor.y,t.colorAry[0].startColor.z),t.alpha=t.colorAry[0].startColor.w),t.velocity={x:t.initVelocity.x*i*t.life,y:t.initVelocity.y*i*t.life,z:t.initVelocity.z*i*t.life},wp.defined(t.randomXY)&&(t.velocity.x=t.velocity.x+i*t.life*t.randomXY*(2*Math.random()-1),t.velocity.y=t.velocity.y+i*t.life*t.randomXY*(2*Math.random()-1)),t.birthplace={x:t.emitPosition.x+(2*Math.random()-1)*t.radius,y:t.emitPosition.y+(2*Math.random()-1)*t.radius,z:t.emitPosition.z},t.position={x:t.birthplace.x,y:t.birthplace.y,z:t.birthplace.z}}},{key:"destroy",value:function(){var e=this;e.velocity=null,e.position=null,e.birthplace=null,e.emitPosition=null,e.color=null}}]);var Lk=function(e,t){var i=this;i.FPS=20,i.FPS_MS=1e3/i.FPS,i.particleSystem=e,i.particleList=[],i.initialOpts(t)};SA(Lk,[{key:"initialOpts",value:function(e){var t=this;t.setOpts(e);for(var i=0;t.count>i;i+=1)t.createParticle()}},{key:"createParticle",value:function(){var e=this,t=new Qk({initSize:e.size,initVelocity:e.initVelocity,emitPosition:e.emitPosition,scaleAry:e.scale,colorAry:e.color,minimumSpeed:e.minimumSpeed,maximumSpeed:e.maximumSpeed,minimumParticleLife:e.minimumParticleLife,maximumParticleLife:e.maximumParticleLife,originPitch:e.originPitch,radius:e.radius,updateCallback:e.updateCallback,applyGravity:e.applyGravity,randomFrameNumber:e.randomFrameNumber,randomXY:e.randomXY,camera:e.camera});e.particleList.push(t)}},{key:"setOpts",value:function(e){var t=this;wp.defined(e.emissionRate)&&(t.emissionRate=e.emissionRate),wp.defined(e.minimumParticleLife)&&(t.minimumParticleLife=e.minimumParticleLife),wp.defined(e.maximumParticleLife)&&(t.maximumParticleLife=e.maximumParticleLife),wp.defined(e.originYaw)&&(t.originYaw=e.originYaw),wp.defined(e.originPitch)&&(t.originPitch=e.originPitch),wp.defined(e.originYaw)&&(t.initVelocity={z:Math.cos(t.originPitch),x:Math.sin(t.originPitch)*Math.cos(t.originYaw),y:Math.sin(t.originPitch)*Math.sin(t.originYaw)}),wp.defined(e.size)&&(t.size=e.size),wp.defined(e.emitPosition)&&(t.emitPosition=e.emitPosition),wp.defined(e.scale)&&(t.scale=e.scale),wp.defined(e.color)&&(t.color=e.color),wp.defined(e.minimumSpeed)&&(t.minimumSpeed=e.minimumSpeed),wp.defined(e.maximumSpeed)&&(t.maximumSpeed=e.maximumSpeed),wp.defined(e.radius)&&(t.radius=e.radius),wp.defined(e.updateCallback)&&(t.updateCallback=e.updateCallback),wp.defined(e.applyGravity)&&(t.applyGravity=e.applyGravity),wp.defined(e.randomFrameNumber)&&(t.randomFrameNumber=e.randomFrameNumber),wp.defined(e.randomXY)&&(t.randomXY=e.randomXY),wp.defined(e.camera)&&(t.camera=e.camera),t.renderCount=Math.floor(t.FPS*t.maximumParticleLife),t.count=t.emissionRate*t.renderCount}},{key:"effectOpt",value:function(e){var t=this;if(t.setOpts(e),t.particleList.length>t.count)t.particleList.length=t.count;else if(t.count>t.particleList.length)for(var i=t.particleList.length;t.count>i;i+=1)t.createParticle();for(i=0;t.particleList.length>i;i+=1)t.particleList[i].initSize=t.size,t.particleList[i].initVelocity=t.initVelocity,t.particleList[i].emitPosition=t.emitPosition,t.particleList[i].scaleAry=t.scale,t.particleList[i].colorAry=t.color,t.particleList[i].minimumSpeed=t.minimumSpeed,t.particleList[i].maximumSpeed=t.maximumSpeed,t.particleList[i].minimumParticleLife=t.minimumParticleLife,t.particleList[i].maximumParticleLife=t.maximumParticleLife,t.particleList[i].originPitch=t.originPitch,t.particleList[i].radius=t.radius,t.particleList[i].updateCallback=t.updateCallback,t.particleList[i].applyGravity=t.applyGravity,t.particleList[i].randomFrameNumber=t.randomFrameNumber,t.particleList[i].randomXY=t.randomXY,t.particleList[i].camera=t.camera}},{key:"stop",value:function(){this.startTime=null}},{key:"play",value:function(){var e=this;e.startTime=(new Date).getTime(),e.renderTimes=0,e.loops=0}},{key:"render",value:function(){var e=this,t=(new Date).getTime();if(wp.defined(e.startTime)){var i=(t-e.startTime)%(1e3*e.maximumParticleLife),n=Math.floor((t-e.startTime)/(1e3*e.maximumParticleLife));for(n>e.loops?(e.loops=n,e.renderTimes=0):e.loops>n&&(e.loops=n);i>=e.renderTimes*e.FPS_MS;){for(var r=e.renderTimes*e.emissionRate;(e.renderTimes+1)*e.emissionRate>r;r+=1)e.particleList.length>r&&e.particleList[r].init(t-i+e.renderTimes*e.FPS_MS);e.renderTimes+=1}}var o={position:[],color:[],alpha:[],size:[]};for(r=0;e.count>r;r+=1)e.particleList[r].updateStatus(t),o.position.push(e.particleList[r].position.x),o.position.push(e.particleList[r].position.y),o.position.push(e.particleList[r].position.z),o.color.push(e.particleList[r].color.r),o.color.push(e.particleList[r].color.g),o.color.push(e.particleList[r].color.b),o.alpha.push(0===e.particleList[r].visible?0:e.particleList[r].alpha),o.size.push(e.particleList[r].size);o.angleNeedsUpdate=!0,o.sizeNeedsUpdate=!0,o.colorNeedsUpdate=!0,o.alphaNeedsUpdate=!0,o.positionNeedsUpdate=!0,e.particleSystem.update(o)}},{key:"destroy",value:function(){this.particleSystem=null,this.initVelocity=null}}]);var Ok=function(e){var t=this;t.showParticle=!0,t.particleSystemManager=new Lk(t,e),t.repeatX=1,t.repeatY=1,t.imgTexture=null,t.uniforms={pointTexture:{value:t.imgTexture},repeatX:{value:t.repeatX},repeatY:{value:t.repeatY}},t.setOpts(e),t.shaderMaterial=new Fk({uniforms:t.uniforms,blending:1,depthTest:!0,depthWrite:!1,transparent:!0}),t.geometry=new Ni,t.particleSystem=new Ya(t.geometry,t.shaderMaterial)};SA(Ok,[{key:"destroy",value:function(){this.particleSystemManager.destroy()}},{key:"stop",value:function(){this.particleSystemManager.stop()}},{key:"play",value:function(){this.particleSystemManager.play()}},{key:"render",value:function(){this.particleSystemManager.render()}},{key:"hide",value:function(){var e=this;e.showParticle=!1,null!=e.particleSystem&&(e.particleSystem.visible=e.show)}},{key:"show",value:function(){var e=this;e.showParticle=!0,null!=e.particleSystem&&(e.particleSystem.visible=e.show)}},{key:"setOpts",value:function(e){var t=this;null!=e.repeatX&&(t.repeatX=e.repeatX,t.uniforms.repeatX.value=t.repeatX),null!=e.repeatY&&(t.repeatY=e.repeatY,t.uniforms.repeatY.value=t.repeatY),null!=e.imgTexture&&t.imgTexture!=e.imgTexture&&(t.imgTexture=e.imgTexture,t.imgTexture.wrapS=f,t.imgTexture.wrapT=f,t.imgTexture.minFilter=A,t.uniforms.pointTexture.value=t.imgTexture)}},{key:"effectOpt",value:function(e){this.setOpts(e),this.particleSystemManager.effectOpt(e)}},{key:"update",value:function(e){var t=this;null==e.position||null!=t.geometry.attributes.position&&t.geometry.attributes.position.array.length==e.position.length||t.geometry.setAttribute("position",new Bi(e.position,3)),null==e.color||null!=t.geometry.attributes.color&&t.geometry.attributes.color.array.length==e.color.length||t.geometry.setAttribute("color",new Bi(e.color,3)),null==e.size||null!=t.geometry.attributes.size&&t.geometry.attributes.size.array.length==e.size.length||t.geometry.setAttribute("size",new Bi(e.size,1).setDynamic(!0)),null==e.alpha||null!=t.geometry.attributes.alpha&&t.geometry.attributes.alpha.array.length==e.alpha.length||t.geometry.setAttribute("alpha",new Bi(e.alpha,1).setDynamic(!0)),t.particleSystem.visible=t.showParticle;var i=t.geometry.attributes.size.array,n=t.geometry.attributes.color.array,r=t.geometry.attributes.alpha.array,o=t.geometry.attributes.position.array;if(null!=e.position)for(var a=0;e.position.length>a;a++)o[a]=e.position[a];if(null!=e.color)for(a=0;e.color.length>a;a++)n[a]=e.color[a];if(null!=e.alpha)for(a=0;e.alpha.length>a;a++)r[a]=e.alpha[a];if(null!=e.size)for(a=0;e.size.length>a;a++)i[a]=e.size[a];t.geometry.attributes.size.needsUpdate=e.sizeNeedsUpdate,t.geometry.attributes.color.needsUpdate=e.colorNeedsUpdate,t.geometry.attributes.alpha.needsUpdate=e.alphaNeedsUpdate,t.geometry.attributes.position.needsUpdate=e.positionNeedsUpdate}}]);var Nk=function(e){lu(i,e);var t=pu(i);function i(e){var n;ru(this,i);var r=du(n=t.call(this));r.scene=e.scene,r.CONST_G=4.9,r.disPickable=!0,r.autoAnimation=!0,r.color=new pi(1,1,1),r.originPosition=new Ke(0,0,0),r.originIntensity=.5,r.radius=2e4,r.originYaw=0,r.originPitch=0,r.particleScale=1,r.camera=e.camera,r.loader=new Dl,r.zoomGis=1,r.setOpts(e),n.time=e.time&&e.time>0||0,n.lastTime=(new Date).getTime(),r.particleOpt=[{baseScale:60,imageUrl:"",minimumSpeed:22,maximumSpeed:25,minimumParticleLife:3.5,maximumParticleLife:4.5,emissionRate:e.particleNumber,radius:1,color:[{startAge:0,endAge:.4,startColor:.1,endColor:.15},{startAge:.4,endAge:1,startColor:.15,endColor:0}],scale:[{startAge:0,endAge:.3,startScale:.3,endScale:.66},{startAge:.3,endAge:.9,startScale:.66,endScale:15},{startAge:.9,endAge:1,startScale:3,endScale:20}],applyGravity:r.CONST_G,randomXY:.09},{baseScale:50,imageUrl:"",minimumSpeed:22,maximumSpeed:25,minimumParticleLife:3.5,maximumParticleLife:4,emissionRate:e.particleNumber,radius:1,color:[{startAge:0,endAge:.7,startColor:1,endColor:.2},{startAge:.7,endAge:1,startColor:.2,endColor:0}],scale:[{startAge:0,endAge:.4,startScale:.1,endScale:.66},{startAge:.4,endAge:1,startScale:.66,endScale:3.5}],applyGravity:r.CONST_G,randomXY:.08},{baseScale:110,imageUrl:"",minimumSpeed:23,maximumSpeed:24,minimumParticleLife:1.2,maximumParticleLife:1.8,emissionRate:e.particleNumber,radius:.5,color:[{startAge:0,endAge:.8,startColor:1,endColor:.8},{startAge:.8,endAge:1,startColor:.8,endColor:0}],scale:[{startAge:0,endAge:1,startScale:.3,endScale:1}],applyGravity:r.CONST_G,randomFrameNumber:!0,repeatX:.3,randomXY:.04},{baseScale:120,imageUrl:"",minimumSpeed:23,maximumSpeed:24,minimumParticleLife:1,maximumParticleLife:1.3,emissionRate:e.particleNumber,radius:.5,color:[{startAge:0,endAge:1,startColor:.5,endColor:.4}],scale:[{startAge:0,endAge:1,startScale:.3,endScale:1}],randomFrameNumber:!0,applyGravity:r.CONST_G,repeatX:.8,randomXY:.04}],r.water=[];for(var o=0;r.particleOpt.length>o;o+=1){for(var a=[],s=0;r.particleOpt[o].color.length>s;s+=1)a.push({startAge:r.particleOpt[o].color[s].startAge,endAge:r.particleOpt[o].color[s].endAge,startColor:new Le(r.color.r,r.color.g,r.color.b,r.alpha*r.particleOpt[o].color[s].startColor),endColor:new Le(r.color.r,r.color.g,r.color.b,r.alpha*r.particleOpt[o].color[s].endColor)});var l=new Ok({emissionRate:Math.floor(r.particleOpt[o].emissionRate*(1+r.originIntensity)),emitPosition:new Ke(0,0,0),originYaw:r.originYaw,originPitch:r.originPitch,minimumSpeed:r.particleOpt[o].minimumSpeed*r.originIntensity/r.zoomGis,maximumSpeed:r.particleOpt[o].maximumSpeed*r.originIntensity/r.zoomGis,size:r.particleScale*r.particleOpt[o].baseScale/r.zoomGis,minimumParticleLife:r.particleOpt[o].minimumParticleLife*r.originIntensity/1.1,maximumParticleLife:r.particleOpt[o].maximumParticleLife*r.originIntensity/1.1,imgTexture:r.loader.load(r.particleOpt[o].imageUrl),color:a,scale:r.particleOpt[o].scale,updateCallback:r.particleOpt[o].updateCallback,applyGravity:null!==r.particleOpt[o].applyGravity?r.particleOpt[o].applyGravity/r.zoomGis:null,randomXY:r.particleOpt[o].randomXY*r.spread,repeatX:0===r.originPitch?r.particleOpt[o].repeatX:1,repeatY:r.particleOpt[o].repeatY,radius:r.particleOpt[o].radius*r.radius/r.zoomGis,camera:r.camera,randomFrameNumber:r.particleOpt[o].randomFrameNumber});r.water.push(l),r.add(l.particleSystem)}return n}return i}(To);SA(Nk,[{key:"destroy",value:function(){for(var e=this,t=0;e.water.length>t;t+=1)e.water[t].destroy(),e.remove(e.water[t].particleSystem);e.loader=null}},{key:"play",value:function(){for(var e=0;this.water.length>e;e+=1)this.water[e].play()}},{key:"stop",value:function(){for(var e=0;this.water.length>e;e+=1)this.water[e].stop()}},{key:"update",value:function(){if(this.time>0){if(0===this.lastTime)return void(this.lastTime=(new Date).getTime());var e=(new Date).getTime();if(this.time>e-this.lastTime)return;this.lastTime=e}for(var t=0;this.water.length>t;t+=1)this.water[t].render()}},{key:"effectOpt",value:function(e){var t=this;t.setOpts(e);for(var i=0;t.water.length>i;i+=1){for(var n,r=[],o=0;t.particleOpt[i].color.length>o;o+=1)r.push({startAge:t.particleOpt[i].color[o].startAge,endAge:t.particleOpt[i].color[o].endAge,startColor:new Le(t.color.r,t.color.g,t.color.b,t.alpha*t.particleOpt[i].color[o].startColor),endColor:new Le(t.color.r,t.color.g,t.color.b,t.alpha*t.particleOpt[i].color[o].endColor)});t.water[i].effectOpt((EA(n={size:t.particleScale*t.particleOpt[i].baseScale/t.zoomGis,repeatX:0===t.originPitch?t.particleOpt[i].repeatX:1,originPitch:t.originPitch,originYaw:t.originYaw,minimumParticleLife:t.particleOpt[i].minimumParticleLife*t.originIntensity/1.1,maximumParticleLife:t.particleOpt[i].maximumParticleLife*t.originIntensity/1.1,randomXY:t.particleOpt[i].randomXY*t.spread},"randomXY",t.particleOpt[i].randomXY*t.spread),EA(n,"minimumSpeed",t.particleOpt[i].minimumSpeed*t.originIntensity/t.zoomGis),EA(n,"maximumSpeed",t.particleOpt[i].maximumSpeed*t.originIntensity/t.zoomGis),EA(n,"color",r),EA(n,"radius",t.particleOpt[i].radius*t.radius/t.zoomGis),EA(n,"emissionRate",Math.floor(t.particleOpt[i].emissionRate*(1+t.originIntensity))),n))}}},{key:"hide",value:function(){for(var e=0;this.water.length>e;e+=1)this.water[e].hide()}},{key:"show",value:function(){for(var e=0;this.water.length>e;e+=1)this.water[e].show()}},{key:"setOpts",value:function(e){var t=this;e&&(null!=e.color&&(t.color=e.color),null!=e.alpha&&(t.alpha=e.alpha),null!=e.originPitch&&(t.originPitch=e.originPitch),null!=e.originYaw&&(t.originYaw=e.originYaw),null!=e.scale&&(t.particleScale=e.scale/5),null!=e.originPosition&&(t.originPosition=e.originPosition,t.position.set(t.originPosition.x,t.originPosition.y,t.originPosition.z),t.updateMatrixWorld()),null!=e.spread&&(t.spread=e.spread),null!=e.originRadius&&(t.radius=e.originRadius),null!=e.originIntensity&&(t.originIntensity=e.originIntensity+.1),null!==e.isGis&&!0===e.isGis&&(t.zoomGis=1e3))}},{key:"setTime",value:function(e){this.time=e}},{key:"setSpaceScale",value:function(e){this.scale.setScalar(e),this.updateMatrixWorld()}}]);var Pk=function(e){if(this.isViewerGIS=!1,e)if(e.color instanceof Du||console.log("ERROR::color should be instance of Color"),e.viewer){if(e.viewer instanceof Uk)this.isViewerGIS=!1;else{if(!(e.viewer instanceof Uk.ViewerGIS))return void console.log("ERROR::viewer must not be empty or viewer2d.");this.isViewerGIS=!0}this.objectTpye="sprayWater-",this.color=e.color,this.originPosition=e.originPosition,this.originPitch=e.originPitch,this.originYaw=e.originYaw,this.originRadius=e.originRadius,this.originIntensity=e.originIntensity,this.spread=e.spread,this.scale=e.scale,this.particleNumber=e.particleQuantity,this.id=wp.createUUID(),this.viewer3D=e.viewer,this.viewer=e.viewer.getViewerImpl(),this._updateParameter(),this.SprayWaterGroup=new Nk({color:this._color,alpha:this._alpha,originPosition:this.originPosition,scale:this._scale,originPitch:this.originPitch,originYaw:this.originYaw,originRadius:this._originRadius,originIntensity:this.originIntensity,spread:this.spread,camera:this.viewer.camera,isGis:this.isViewerGIS,scene:this.viewer.getScene(),particleNumber:this.particleNumber}),this._addSence(),this.SprayWaterGroup.play()}else console.log("ERROR::viewer must not be empty.");else console.log("ERROR::sprayWaterConfig must not be empty.")};SA(Pk,[{key:"_updateParameter",value:function(){this._color=new pi(this.color.red,this.color.green,this.color.blue),this._alpha=this.color.alpha,this.originIntensity>3&&(this.originIntensity=3),this._scale=this.isViewerGIS?10*this.scale:this.scale,this._originRadius=this.viewer.getScene().worldToDrawing({x:this.originRadius,y:0,z:0}).x}},{key:"_addSence",value:function(){this.extObjMngId=this.viewer3D.addExternalObject(this.objectTpye+this.id,this.SprayWaterGroup)}},{key:"destroy",value:function(){this.SprayWaterGroup.destroy(),this.extObjMngId&&this.viewer3D.removeExternalObjectByName(this.extObjMngId),this.SprayWaterGroup=null}},{key:"update",value:function(){this._updateParameter(),this.SprayWaterGroup.effectOpt({color:this._color,alpha:this._alpha,scale:this._scale,originPosition:this.originPosition,originPitch:this.originPitch,originYaw:this.originYaw,originRadius:this._originRadius,spread:this.spread,isGis:this.isViewerGIS,originIntensity:this.originIntensity})}},{key:"hide",value:function(){this.SprayWaterGroup.hide()}},{key:"show",value:function(){this.SprayWaterGroup.show()}},{key:"play",value:function(){this.SprayWaterGroup.play()}},{key:"stop",value:function(){this.SprayWaterGroup.stop()}},{key:"setAnimationInterval",value:function(e){this.SprayWaterGroup.setTime(e)}},{key:"setSpaceScale",value:function(e){this.SprayWaterGroup.setSpaceScale(e)}},{key:"getOptions",value:function(){return{color:this.color,originPosition:this.originPosition,originPitch:this.originPitch,originYaw:this.originYaw,originRadius:this.originRadius,originIntensity:this.originIntensity,spread:this.spread,scale:this.scale}}},{key:"setOptions",value:function(e){jg(e.color)&&(e.color instanceof Du?this.color=e.color:console.log("ERROR::color should be instance of BOS3D.Color")),jg(e.originPosition)&&(this.originPosition=e.originPosition),jg(e.originPitch)&&(this.originPitch=e.originPitch),jg(e.originYaw)&&(this.originYaw=e.originYaw),jg(e.originRadius)&&(this.originRadius=e.originRadius),jg(e.originIntensity)&&(this.originIntensity=e.originIntensity),jg(e.spread)&&(this.spread=e.spread),jg(e.scale)&&(this.scale=e.scale),this.update()}}]);function Gk(e){return"symbol"==typeof e||mS(e)&&"[object Symbol]"==jB(e)}var Kk=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,Vk=/^\w*$/;function Yk(e,t){if("function"!=typeof e||null!=t&&"function"!=typeof t)throw new TypeError("Expected a function");var i=function(){var n=arguments,r=t?t.apply(this,n):n[0],o=i.cache;if(o.has(r))return o.get(r);var a=e.apply(this,n);return i.cache=o.set(r,a)||o,a};return i.cache=new(Yk.Cache||cS),i}Yk.Cache=cS;var Hk=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,jk=/\\(\\)?/g,Wk=function(e){var t=Yk(e,(function(e){return 500===i.size&&i.clear(),e})),i=t.cache;return t}((function(e){var t=[];return 46===e.charCodeAt(0)&&t.push(""),e.replace(Hk,(function(e,i,n,r){t.push(n?r.replace(jk,"$1"):i||e)})),t}));function Jk(e,t){for(var i=-1,n=null==e?0:e.length,r=Array(n);++i<n;)r[i]=t(e[i],i,e);return r}var zk=NB?NB.prototype:void 0,qk=zk?zk.toString:void 0;function Zk(e){if("string"==typeof e)return e;if(xS(e))return Jk(e,Zk)+"";if(Gk(e))return qk?qk.call(e):"";var t=e+"";return"0"==t&&1/e==-Infinity?"-0":t}function Xk(e,t){return xS(e)?e:function(e,t){if(xS(e))return!1;var i=typeof e;return!("number"!=i&&"symbol"!=i&&"boolean"!=i&&null!=e&&!Gk(e))||Vk.test(e)||!Kk.test(e)||null!=t&&e in Object(t)}(e,t)?[e]:Wk(function(e){return null==e?"":Zk(e)}(e))}function _k(e){if("string"==typeof e||Gk(e))return e;var t=e+"";return"0"==t&&1/e==-Infinity?"-0":t}function $k(e,t,i){var n=null==e?void 0:function(e,t){for(var i=0,n=(t=Xk(t,e)).length;null!=e&&n>i;)e=e[_k(t[i++])];return i&&i==n?e:void 0}(e,t);return void 0===n?i:n}var eD={height:0,speed:1e3,frameTime:14},tD=new Tp,iD=function(){function e(t){ru(this,e),this.roadnet={},this.shortestPathLineMap={},this.roadNetLineMap={},this.roadNetPointMap={},this.roadNetInfoMap={},this.roadNetEdgeMap={},this.roadNetPointMap={},this.mapRoadNetListByModelKey={},this.mapModelKeyByRoadNetKey={},this.modelInfo={},this.viewer3D=t}return au(e,[{key:"_getRoadNetListByModelKey",value:function(e){var t=this,i=this;return new Promise((function(n,r){(function(e){var t=e.viewer3D.getViewerImpl().getModel(e.modelKey),i=$k(t,["loader","url","serverUrl"])||$k(e,["viewer3D","host"],""),n=t.projectKey,r=t.accessToken,o="";t.share&&(o="&share="+t.share);var a={url:"".concat(i,"/").concat(e.apiVersion||"api","/").concat(n,"/routes/list?modelKey=").concat(e.modelKey).concat(o)};return r&&(a.headers={Authorization:r}),Yy(a)})({viewer3D:t.viewer3D,modelKey:e}).then((function(t){var o,a=i.viewer3D.getViewerImpl().getModel(e);if(!a)return Bu.error(e+"模型不存在"),void r(e+"模型不存在");if(i.modelInfo[e]=a,"SUCCESS"===(o="string"==typeof t?JSON.parse(t):t).code){var s=i.mapRoadNetListByModelKey;s[e]={};for(var l=0,c=o.data.length;c>l;l+=1){var h=o.data[l],d=h.key;s[e][d]=h,i.roadNetInfoMap[d]=h,i.mapModelKeyByRoadNetKey[d]=e}n()}else r(o.message)})).catch((function(){Bu.error("获取模型路网列表失败"),r("获取模型路网列表失败")}))}))}},{key:"_getRoadNetDataByRouteKey",value:function(e,t,i){var n=this,r=this,o=[],a=this.mapModelKeyByRoadNetKey[e];if(a)return o.push(new Promise((function(t,i){(function(e){var t=e.viewer3D.getViewerImpl().getModel(e.modelKey),i=$k(t,["loader","url","serverUrl"])||$k(e,["viewer3D","host"],""),n=t.projectKey,r=t.accessToken,o="";t.share&&(o="&share="+t.share);var a={url:"".concat(i,"/").concat(e.apiVersion||"api","/").concat(n,"/routes/points?routeKey=").concat(e.routeKey).concat(o)};return r&&(a.headers={Authorization:r}),Yy(a)})({viewer3D:n.viewer3D,routeKey:e,modelKey:a}).then((function(n){var o;if("SUCCESS"===(o="string"==typeof n?JSON.parse(n):n).code){var a=r.roadNetPointMap;a[e]={};for(var s=0,l=o.data.length;l>s;s+=1){var c=o.data[s];a[e][c.key]=c}t()}else i(o.message)})).catch((function(){Bu.error("获取模型路网列表失败"),i("获取模型路网列表失败")}))}))),o.push(new Promise((function(t,i){(function(e){var t=e.viewer3D.getViewerImpl().getModel(e.modelKey),i=$k(t,["loader","url","serverUrl"])||$k(e,["viewer3D","host"],""),n=t.projectKey,r=t.accessToken,o="";t.share&&(o="&share="+t.share);var a={url:"".concat(i,"/").concat(e.apiVersion||"api","/").concat(n,"/routes/edges?routeKey=").concat(e.routeKey).concat(o)};return r&&(a.headers={Authorization:r}),Yy(a)})({viewer3D:n.viewer3D,routeKey:e,modelKey:a}).then((function(n){var o;"SUCCESS"===(o="string"==typeof n?JSON.parse(n):n).code?(r.roadNetEdgeMap[e]=o.data,t()):i(o.message)})).catch((function(){Bu.error("获取模型路网列表失败"),i("获取模型路网列表失败")}))}))),Promise.all(o);Bu.error("模型路网未初始化")}},{key:"initRoadNetByModelKey",value:function(e){var t=this;return new Promise((function(i,n){t._getRoadNetListByModelKey(e).then(i).catch(n)}))}},{key:"getRoadNetInfoListByModelKey",value:function(e){return this.mapRoadNetListByModelKey[e]}},{key:"addRoadNetByKey",value:function(e,t){var i=this,n=this,r=t.color,o=t.width,a=void 0===o?1:o,s=t.block,l=void 0===s||s;return new Promise((function(t,o){return r instanceof Du?"number"!=typeof a?(Bu.error("width 参数非法"),void o("width 参数非法")):void(n.roadNetLineMap[e]?t():i._getRoadNetDataByRouteKey(e).then((function(){for(var i=n.roadNetEdgeMap[e],s=n.roadNetPointMap[e],c=[],h=0,d=i.length;d>h;h+=1){var u=i[h],p=u._from.split("/")[1],g=u._to.split("/")[1],f=s[p].xyz;f||(Bu.error("点",p,"不存在"),o("点"+p+"不存在")),c.push.apply(c,mu(f));var m=s[g].xyz;m||(Bu.error("点",g,"不存在"),o("点"+g+"不存在")),c.push.apply(c,mu(m))}var A=new EM;A.setPositions(c);var y=new xM({color:r.getHex(),linewidth:a/1e3});l||(y.depthTest=!1,y.transparent=!0);var v=new NM(A,y);v.matrixAutoUpdate=!1;var C=n.mapModelKeyByRoadNetKey[e];if(!C)return Bu.error("模型路网未初始化"),void o("模型路网未初始化");var I=n.viewer3D.getModelMatrix(C);v.matrix.copy(I),n.viewer3D.getScene().add(v),v.updateMatrixWorld(!0),n.roadNetLineMap[e]=v,n.viewer3D.render(),t()})).catch((function(e){o(e)}))):(Bu.error("color 参数非法"),void o("color 参数非法"))}))}},{key:"removeRoadNetByKey",value:function(e){this.roadNetLineMap[e]?(this.viewer3D.getScene().remove(this.roadNetLineMap[e]),delete this.roadNetLineMap[e],this.viewer3D.render()):Bu.warn("路网",e,"不存在")}},{key:"showRoadNetByKey",value:function(e){this.roadNetLineMap[e]?(this.roadNetLineMap[e].visible=!0,this.viewer3D.render()):Bu.warn("路网",e,"不存在")}},{key:"hideRoadNetByKey",value:function(e){this.roadNetLineMap[e]?(this.roadNetLineMap[e].visible=!1,this.viewer3D.render()):Bu.warn("路网",e,"不存在")}},{key:"setRoadNetColorByKey",value:function(e,t){if(this.roadNetLineMap[e]){if(!(t instanceof Du))return void Bu.warn("color 参数非法");this.roadNetLineMap[e].material.color=t.getHex(),this.viewer3D.render()}else Bu.warn("路网",e,"不存在")}},{key:"setRoadNetBlockByKey",value:function(e,t){this.roadNetLineMap[e]?(t?(this.roadNetLineMap[e].material.depthTest=!0,this.roadNetLineMap[e].material.transparent=!1):(this.roadNetLineMap[e].material.depthTest=!1,this.roadNetLineMap[e].material.transparent=!0),this.viewer3D.render()):Bu.warn("路网",e,"不存在")}},{key:"setRoadNetLineWidthByKey",value:function(e,t){this.roadNetLineMap[e]?(this.roadNetLineMap[e].material.linewidth=t/1e3,this.viewer3D.render()):Bu.warn("路网",e,"不存在")}},{key:"update",value:function(){for(var e in this.roadNetLineMap)if(this.roadNetLineMap.hasOwnProperty(e)){var t=this.roadNetLineMap[e],i=this.viewer3D.getModelMatrix(this.mapModelKeyByRoadNetKey[e]);t.matrix.copy(i),t.updateMatrixWorld(!0)}for(var n in this.shortestPathLineMap)if(this.shortestPathLineMap.hasOwnProperty(n)){var r=this.shortestPathLineMap[n],o=this.viewer3D.getModelMatrix(r.userData.modelKey);r.matrix.copy(o),r.updateMatrixWorld(!0)}this.viewer3D.render()}},{key:"getShortestPath",value:function(e,t,i,n){var r=this,o=this;return new Promise((function(a,s){n||(n="topo"),r.roadNetInfoMap[e]||s({code:"error",detail:"路网".concat(e,"未初始化"),start:t,end:i});var l=r.mapModelKeyByRoadNetKey[e];if(!l)return Bu.error("模型路网未初始化"),void s("模型路网未初始化");(function(e){var t=e.viewer3D.getViewerImpl().getModel(e.modelKey),i=$k(t,["loader","url","serverUrl"])||$k(e,["viewer3D","host"],""),n=t.projectKey,r=t.accessToken,o="";t.share&&(o="&share="+t.share);var a={url:"".concat(i,"/").concat(e.apiVersion||"api","/").concat(n,"/routes/shortestPath?routeKey=").concat(e.routeKey,"&start=").concat(e.start.toString(),"&end=").concat(e.end.toString()).concat(o,"&type=").concat(e.type)};return r&&(a.headers={Authorization:r}),Yy(a)})({modelKey:l,viewer3D:o.viewer3D,routeKey:e,start:t,end:i,type:n}).then((function(n){var r;"SUCCESS"===(r="string"==typeof n?JSON.parse(n):n).code&&a({code:"success",data:{routeKey:e,points:r.data},start:t,end:i})})).catch((function(e){s({code:"error",detail:e,start:t,end:i})}))}))}},{key:"addShortestPathByPoints",value:function(e,t){var i=this,n=t.color,r=t.width,o=void 0===r?1:r,a=t.block,s=void 0===a||a;return new Promise((function(t,r){if(!e.routeKey)return Bu.error("缺少参数routeKey"),void r("缺少参数routeKey");if(!e.points)return Bu.error("缺少参数points"),void r("缺少参数points");if(!(n instanceof Du))return Bu.error("color 参数非法"),void r("color 参数非法");if("number"!=typeof o)return Bu.error("width 参数非法"),void r("width 参数非法");e.key||(e.key=wp.createUUID());for(var a=[],l=0,c=e.points.length;c>l;l+=1)a.push.apply(a,mu(e.points[l]));var h=new _b;h.setPositions(a);var d=new xM({color:n.getHex(),linewidth:o/1e3});s||(d.depthTest=!1,d.transparent=!0);var u=new $b(h,d);u.matrixAutoUpdate=!1;var p=i.mapModelKeyByRoadNetKey[e.routeKey];if(!p)return Bu.error("模型路网未初始化"),void r("模型路网未初始化");var g=i.viewer3D.getModelMatrix(p);u.matrix.copy(g),u.userData.modelKey=p,u.userData.routeKey=e.routeKey,i.viewer3D.getScene().add(u),u.updateMatrixWorld(!0),i.shortestPathLineMap[e.key]=u,i.viewer3D.render(),t(e)}))}},{key:"showShortestPathByKey",value:function(e){this.shortestPathLineMap[e]?(this.shortestPathLineMap[e].visible=!0,this.viewer3D.render()):Bu.warn("最短路径",e,"不存在")}},{key:"hideShortestPathByKey",value:function(e){this.shortestPathLineMap[e]?(this.shortestPathLineMap[e].visible=!1,this.viewer3D.render()):Bu.warn("最短路径",e,"不存在")}},{key:"removeShortestPathByKey",value:function(e){this.shortestPathLineMap[e]?(this.viewer3D.getScene().remove(this.shortestPathLineMap[e]),delete this.shortestPathLineMap[e],this.viewer3D.render()):Bu.warn("最短路径",e,"不存在")}},{key:"setShortestPathColorByKey",value:function(e,t){if(this.shortestPathLineMap[e]){if(!(t instanceof Du))return void Bu.warn("color 参数非法");this.shortestPathLineMap[e].material.color=t.getHex(),this.viewer3D.render()}else Bu.warn("最短路径",e,"不存在")}},{key:"setShortestPathBlockByKey",value:function(e,t){this.shortestPathLineMap[e]?(t?(this.shortestPathLineMap[e].material.depthTest=!0,this.shortestPathLineMap[e].material.transparent=!1):(this.shortestPathLineMap[e].material.depthTest=!1,this.shortestPathLineMap[e].material.transparent=!0),this.viewer3D.render()):Bu.warn("最短路径",e,"不存在")}},{key:"setShortestPathLineWidthByKey",value:function(e,t){this.shortestPathLineMap[e]?(this.shortestPathLineMap[e].material.linewidth=t/1e3,this.viewer3D.render()):Bu.warn("最短路径",e,"不存在")}},{key:"roamByShortestPathData",value:function(e,t){var i=this,n=wp.extend({},eD,t);if(e.routeKey)if(e.points)if(n.speed){var r=i.viewer3D.getModelMatrix(i.mapModelKeyByRoadNetKey[e.routeKey]);if(r){var o=this.viewer3D.getViewerImpl().camera;!function e(t,a){if(t.length-1>a){var s,l=new Ke(t[a][0],t[a][1],t[a][2]+n.height).applyMatrix4(r),c=new Ke(t[a+1][0],t[a+1][1],t[a+1][2]+n.height).applyMatrix4(r),h=new Ke(t[a+1][0],t[a+1][1],t[a+1][2]+n.height).applyMatrix4(r);if(a>t.length-3||(s=new Ke(t[a+2][0],t[a+2][1],t[a+2][2]+n.height).applyMatrix4(r)),a===t.length-2){var d=new Ke(t[a+1][0],t[a+1][1],t[a+1][2]+n.height).sub(new Ke(t[a][0],t[a][1],t[a][2]+n.height)).setLength(.1);s=new Ke(t[a+1][0],t[a+1][1],t[a+1][2]+n.height).add(d).applyMatrix4(r)}var u=l.distanceTo(h)/n.speed*1e3;i.viewer3D.getViewerImpl().getControlManager().setInteractiveState(!1),tD.from({animPosition:l,animTarget:c,animUp:o.up}).to({animPosition:h,animTarget:s,animUp:o.up},u).onUpdate((function(e){var t=e.animPosition;o.lookAtEXForTargetPositionUp(e.animTarget,t,o.up),i.viewer3D.getViewerImpl().cameraControl.update(!0,!0),n.callbackProcess&&n.callbackProcess(t)})).onComplete((function(){o.lookAtEXForTargetPositionUp(s,h,o.up),i.viewer3D.getViewerImpl().cameraControl.update(!0,!0),n.callbackProcess&&n.callbackProcess(h),n.callbackFinish&&n.callbackFinish(),i.viewer3D.getViewerImpl().getControlManager().setInteractiveState(!0),e(t,a+=1)})).start(n.frameTime,!0)}else n.callbackAllFinish&&n.callbackAllFinish()}(e.points,0)}else Bu.error("无法获取路径对应的模型矩阵")}else Bu.error("speed参数非法");else Bu.error("缺少参数points");else Bu.error("缺少参数routeKey")}}]),e}(),nD=function(){function e(){ru(this,e),this.name="漫游"}return au(e,null,[{key:"startRoam",value:function(e){if(!Object.keys(e).length)throw new Error("Viewer3D为空");var t=Vd.WALK;try{var i=e.viewerImpl;e.getViewerImpl().controlManager.setControlMode(i,t),e.getViewerImpl().controlManager.setFocus()}catch(e){throw new Error(e)}}},{key:"cancelRoam",value:function(e){if(!Object.keys(e).length)throw new Error("Viewer3D为空");e.viewerImpl.controlManager.setControlMode(e.viewerImpl,"pick")}},{key:"changeRoamConfig",value:function(e){var t=arguments.length>1&&void 0!==arguments[1]&&arguments[1],i=arguments.length>2?arguments[2]:void 0,n=arguments.length>3?arguments[3]:void 0;if(!Object.keys(e).length)throw new Error("Viewer3D为空");var r=e.getViewerImpl();switch(i){case"hit":xd.EnableHitDetection=t;break;case"gravity":xd.WalkingWithGravity=t;break;case"manHeight":e.getViewerImpl().cameraControl.getRealManHeight&&r.cameraControl.setRealManHeight(1e3*n.value);break;case"immersion":t&&e.requestPointerLock();break;case"viewLock":xd.WalkingWithViewLock=t}r.controlManager.setFocuse()}}]),e}(),rD=function(e){lu(i,e);var t=pu(i);function i(e){var n;return ru(this,i),(n=t.call(this,e)).name="自由漫游",n}return au(i,null,[{key:"startFreeRoam",value:function(e){gu(cu(i),"startRoam",this).call(this,e)}},{key:"cancelRoam",value:function(e){gu(cu(i),"cancelRoam",this).call(this,e)}}]),i}(nD),oD=function(e){this.name=e.name||"",this.id=e.id||"",this.keyFrameList=e.keyFrameList||[],this.roamTime=5,this.interpolateType=1,this.fps=50,this.parts=100,this.rotateSpeed=Math.PI/this.roamTime/this.fps/4,this.parameters={segments:this.roamTime*this.fps*this.parts,closed:!1,curveType:"centripetal",tension:.25},this.modificationId=0,this.mapDeltaAngle={},this.mapDeltaOffset={},this.allocateSegmentList=null,this.positionCurve=void 0,this.backupPerspectiveList=e.backupPerspectiveList||[],this.init(e)};oD.prototype.init=function(e){this.setKeyFrameList(e.keyFrameList),this.setParameters(e.parameters),this.setInterpolateType(e.type),this.setFps(e.fps),this.setRoamTime(e.roamTime)},oD.prototype.addKeyFrame=function(e){var t=new Ke(e.position.x,e.position.y,e.position.z),i=new Ke(e.target.x,e.target.y,e.target.z),n=new Ke(e.up.x,e.up.y,e.up.z),r=e.name||"视角",o=null;if(e.quaternion)o=new Ge(e.quaternion.x,e.quaternion.y,e.quaternion.z,e.quaternion.w);else{var a=new yt;a.lookAt(t,i,n),o=(new Ge).setFromRotationMatrix(a)}var s=e.control,l=s?{startPoint:s.startPoint,endPoint:s.endPoint,cubeList:s.cubeList.map((function(e){return{position:e.position}}))}:void 0;this.keyFrameList.push({position:t,target:i,up:n,id:e.id,name:r,quaternion:o,control:l,curve:e.curve,editor:e.editor||null}),this.modificationId+=1},oD.prototype.setKeyFrameList=function(e){this.keyFrameList=[];for(var t=0,i=e.length;i>t;t+=1)this.addKeyFrame(e[t]);this.calRotateSpeed()},oD.prototype.removeKeyFrame=function(e){e>=0&&this.keyFrameList.length>e&&(this.keyFrameList.splice(e,1),this.modificationId+=1)},oD.prototype.getKeyFrames=function(){return this.keyFrameList},oD.prototype.getKeyFrameCount=function(){return this.keyFrameList.length},oD.prototype.clearFrames=function(){this.keyFrameList=[]},oD.prototype.getJumpCounts=function(e){var t=e/(1e3/this.fps)*this.parts;return t=parseInt(t,0)},oD.prototype.setRoamTime=function(e){this.roamTime=e,this.setSegments(e*this.fps*this.parts),this.calRotateSpeed()},oD.prototype.calRotateSpeed=function(){var e=this.getKeyFrames().length;e>1&&(this.rotateSpeed=Math.PI*(e-1)/this.roamTime/this.fps/4)},oD.prototype.setInterpolateType=function(e){this.interpolateType=e||1,1===this.interpolateType&&this.setSplineTension(0)},oD.prototype.getInterpolateType=function(){return this.interpolateType},oD.prototype.setName=function(e){this.name=e},oD.prototype.getName=function(){return this.name},oD.prototype.getId=function(){return this.id},oD.prototype.getKeyFramePositions=function(){for(var e=[],t=0,i=this.keyFrameList.length;i>t;t+=1){e.push(this.keyFrameList[t].position)}return e},oD.prototype.getKeyFramePosition=function(e){return this.keyFrameList[e].position},oD.prototype.getKeyFrameDirection=function(e){var t=this.keyFrameList[e];return t.target.clone().sub(t.position)},oD.prototype.getKeyFrameTarget=function(e){return this.keyFrameList[e].target},oD.prototype.getKeyFrameUp=function(e){return this.keyFrameList[e].up},oD.prototype.allocateSegments=function(){for(var e=[],t=0,i=this.keyFrameList.length;i-1>t;t+=1){var n=this.keyFrameList[t].position;e.push(this.keyFrameList[t+1].position.clone().sub(n).length())}for(var r=0,o=0,a=e.length;a>o;o+=1)r+=e[o];for(var s=this.getSegments(),l=0,c=e.length;0!==r&&c>l;l+=1)e[l]/=r,e[l]*=this.getSegments(),e[l]=Math.floor(e[l]),s-=e[l];for(var h=0;s>h;h+=1)e[h]>0&&(e[h]+=1);this.allocateSegmentList=e},oD.prototype.getAllocateSegmentCount=function(e){return null===this.allocateSegmentList&&this.allocateSegments(),this.allocateSegmentList[e]},oD.prototype.getSplineParam=function(e,t){return null===this.allocateSegmentList&&this.allocateSegments(),(e+t/this.allocateSegmentList[e])/this.allocateSegmentList.length},oD.prototype.getDeltaAngle=function(e){return this.mapDeltaAngle[e]},oD.prototype.calculateDeltaAngle=function(){for(var e=this.allocateSegmentList,t=0;e.length>t;t+=1){var i=0;if(this.keyFrameList[t].quaternion&&this.keyFrameList[t+1].quaternion){var n=this.keyFrameList[t].quaternion,r=this.keyFrameList[t+1].quaternion,o=(new Ge).multiplyQuaternions(r,n.clone().invert());o.normalize(),i=2*Math.acos(o.w)}else{var a=this.getKeyFrameDirection(t),s=this.getKeyFrameDirection(t+1);i=a.angleTo(s)}var l=e[t];if(0===l){var c=Math.floor(i/this.rotateSpeed)*this.parts;e[t]=c,this.mapDeltaAngle[t]=i/c}else this.mapDeltaAngle[t]=i/l}},oD.prototype.getRotateAxis=function(e){var t=this.keyFrameList[e].quaternion,i=this.keyFrameList[e+1].quaternion;if(t&&i){var n=(new Ge).multiplyQuaternions(i,t.clone().invert());return n.normalize(),new Ke(n.x,n.y,n.z).normalize()}var r=this.getKeyFrameDirection(e),o=this.getKeyFrameDirection(e+1);return r.clone().cross(o.clone()).normalize()},oD.prototype.getDeltaOffset=function(e){return this.mapDeltaOffset[e]},oD.prototype.getPositionAtCurve=function(e,t){var i=this.keyFrameList[e+1];if(i&&i.curve)return i.curve.getPointAt(t)},oD.prototype.getPositionAtCurve=function(e,t){var i=this.keyFrameList[e+1];if(i&&i.curve)return i.curve.getPointAt(t)},oD.prototype.getLatestPositionAtCurve=function(e){var t=this.keyFrameList[e];if(t&&t.curve)return t.position},oD.prototype.calculateDeltaOffset=function(){for(var e=this.allocateSegmentList,t=this.getKeyFramePositions(),i=0;e.length>i;i+=1){var n=t[i],r=t[i+1],o=this.allocateSegmentList[i];this.mapDeltaOffset[i]=0===o?new Ke:r.clone().sub(n).divideScalar(o)}},oD.prototype.setSplineTension=function(e){0>e||e>1||(this.parameters.tension=e,this.modificationId+=1)},oD.prototype.setSegments=function(e){this.parameters.segments=e,this.modificationId+=1},oD.prototype.getSegments=function(){return this.parameters.segments},oD.prototype.setParameters=function(e){e&&(this.parameters=e,this.modificationId+=1)},oD.prototype.getParameters=function(){return this.parameters},oD.prototype.setFps=function(e){this.fps=e||50,this.calRotateSpeed(),this.modificationId+=1},oD.prototype.getFps=function(){return this.fps},oD.prototype.getModificationId=function(){return this.modificationId},oD.prototype.export=function(){return{name:this.name,id:this.id,fps:this.fps,roamTime:this.roamTime,type:this.interpolateType,keyFrameList:this.keyFrameList}};var aD=function(e){this.viewer=e.viewer,this.roam=null,this.bPause=!1,this.bContinue=!1,this.spline=null,this.reqid=0,this.playBinded=this._play.bind(this),this.recordId=-1,this.keyFrameIdx=0,this.count=-1,this.camera=this.viewer.cameraControl.camera,this.pausePlayCallback=[],this.stopPlayCallback=[],this.keyFrameCallback=[],this.timeRecorder={last:0,pause:0,deltaTime:0},this.setRoam(e.roamData)};aD.prototype.setRoam=function(e){this.roam=e,this.bPause=!1,this.recordId=-1,this.spline=null,this.keyFrameIdx=0,this.count=-1},aD.prototype.updateCamera=function(e,t,i){this.camera.position.add(e),this.camera.target.addVectors(this.camera.position,t),this.camera.up.copy(i)},aD.prototype.updateCameraToFrame=function(e){var t=this.roam.getKeyFramePosition(e),i=this.roam.getKeyFrameTarget(e),n=this.roam.getKeyFrameUp(e);this.camera.position.copy(t),this.camera.target.copy(i),this.camera.up.copy(n)},aD.prototype.reAllocate=function(){this.recordId!==this.roam.getModificationId()&&(this.roam.allocateSegments(),this.roam.calculateDeltaOffset(),this.roam.calculateDeltaAngle(),this.recordId=this.roam.getModificationId())},aD.prototype._play=function(){var e=new Ge,t=new Ge,i=new Ke,n=new Ke(0,1,0),r=new Ke;return function(){this.reqid=setTimeout(this.playBinded,this.roam.getFps()),!1===this.bContinue?(this.bContinue=!0,this.timeRecorder.deltaTime=this.timeRecorder.pause-this.timeRecorder.last):this.timeRecorder.deltaTime=performance.now()-this.timeRecorder.last,this.timeRecorder.last=performance.now();var o=this.roam.getJumpCounts(this.timeRecorder.deltaTime);if(this.reAllocate(),this.bPause)return this.timeRecorder.pause=performance.now(),clearTimeout(this.reqid),this.triggerPausePlayCallback(),this.bPause=!1,void(this.bContinue=!1);var a=this.roam.getKeyFrameCount(),s=this.roam.getAllocateSegmentCount(this.keyFrameIdx);if(0===s)this.keyFrameIdx+=1,this.triggerKeyFrameCallback(this.keyFrameIdx),this.count=-1;else if(this.keyFrameIdx===a-1)this.updateCameraToFrame(this.keyFrameIdx),this.stop();else if(-1===this.count)this.timeStart=performance.now(),0===this.keyFrameIdx&&this.triggerKeyFrameCallback(0),this.updateCameraToFrame(this.keyFrameIdx),this.count=0;else if(s>this.count){this.count+o>s&&(o=s-this.count);var l=this.count/s,c=this.roam.keyFrameList[this.keyFrameIdx].quaternion,h=this.roam.keyFrameList[this.keyFrameIdx+1].quaternion;e.copy(h),c.equals(h)||e.slerpQuaternions(c,h,l);var d=this.roam.keyFrameList[this.keyFrameIdx];i.subVectors(d.target,d.position),i.applyQuaternion(t.copy(c).invert()),i.applyQuaternion(e),n.set(0,1,0),n.applyQuaternion(e);var u=this.roam.getPositionAtCurve(this.keyFrameIdx,l);if(u)this.camera.position.copy(u);else{var p=this.roam.getDeltaOffset(this.keyFrameIdx);r.copy(p).multiplyScalar(o),this.camera.position.add(r)}if(this.camera.target.addVectors(this.camera.position,i),this.camera.up.copy(n),s>this.count+o)this.count+=o;else{this.keyFrameIdx+=1;var g=this.roam.getLatestPositionAtCurve(this.keyFrameIdx);g&&this.camera.position.copy(g),this.triggerKeyFrameCallback(this.keyFrameIdx),this.count=0}}this.camera.dirty=!0,this.viewer.render()}}(),aD.prototype.play=function(){this.bPause=!1,this._play()},aD.prototype.pause=function(){this.bPause=!0},aD.prototype.continue=function(){this.bContinue=!0,this.bPause=!1,this._play()},aD.prototype.stop=function(){this.bPause=!1,this.keyFrameIdx=0,this.count=-1,clearTimeout(this.reqid),this.triggerStopPlayCallback()},aD.prototype.startFrom=function(e){for(var t=this.roam,i=t.getKeyFrameCount(),n=t.getKeyFrames(),r=0;i>r;r+=1)if(n[r].id===e)return this.keyFrameIdx=r,void(this.count=-1)},aD.prototype.startFromByIndex=function(e){var t=this.roam.getKeyFrameCount();e>0&&t>e&&(this.keyFrameIdx=e,this.count=-1)},aD.prototype.addKeyFrameCallback=function(e){this.keyFrameCallback.push(e)},aD.prototype.addPausePlayCallback=function(e){this.pausePlayCallback.push(e)},aD.prototype.addStopPlayCallback=function(e){this.stopPlayCallback.push(e)},aD.prototype.triggerKeyFrameCallback=function(e){this.keyFrameCallback.forEach((function(t){t(e)}))},aD.prototype.triggerPausePlayCallback=function(){this.pausePlayCallback.forEach((function(e){e()}))},aD.prototype.triggerStopPlayCallback=function(){this.stopPlayCallback.forEach((function(e){e()}))},aD.prototype.updataSpline=function(){var e=this.roam.getKeyFramePositions(),t=this.roam.getParameters();this.spline=new Pl(e,t.closed,t.curveType,t.tension)};var sD=function(){this.roamList=[]};sD.prototype.clear=function(){this.roamList=[]},sD.prototype.add=function(e){this.roamList.push(e)},sD.prototype.remove=function(e){for(var t=0,i=this.roamList.length;i>t;t+=1){if(this.roamList[t].getName()===e)return void this.roamList.splice(t,1)}},sD.prototype.save=function(){return JSON.stringify(this.roamList)},sD.prototype.load=function(e){this.clear();for(var t=JSON.parse(e),i=0,n=t.length;n>i;i+=1){var r=new oD({name:t[i].name,keyFrameList:t[i].keyFrameList,parameters:t[i].parameters,roamTime:t[i].roamTime,type:t[i].type,fps:t[i].fps});this.add(r)}return this.roamList};var lD=".yjbos3dRecord",cD="⊗",hD="1.4.0",dD=["1.0","1.2.0","1.3.0","1.4.0"],uD=["文件格式错误"],pD=0,gD=function(e){var t=cD,i="".concat(hD).concat(t).concat(e.name).concat(t).concat(e.id).concat(t).concat(e.roamTime).concat(t).concat(e.fps).concat(t).concat(e.type).concat(t);return e.keyFrameList.forEach((function(e){if(i+="".concat(t).concat(e.id).concat(t).concat(e.position.x).concat(t).concat(e.position.y).concat(t).concat(e.position.z).concat(t).concat(e.target.x).concat(t).concat(e.target.y).concat(t).concat(e.target.z).concat(t).concat(e.up.x).concat(t).concat(e.up.y).concat(t).concat(e.up.z).concat(t).concat(e.quaternion.x).concat(t).concat(e.quaternion.y).concat(t).concat(e.quaternion.z).concat(t).concat(e.quaternion.w),e.curve){var n={curveType:e.curve.curveType,points:e.curve.points.map((function(e){return e.toArray()}))};i+="".concat(t).concat(btoa(JSON.stringify(n)))}else i+="".concat(t,"null");if(e.editor){var r={cubeList:e.editor.cubeList.map((function(e){return{position:e.position}})),startPoint:e.editor.startPoint,endPoint:e.editor.endPoint};i+="".concat(t).concat(btoa(JSON.stringify(r)))}else i+="".concat(t,"null");i+="".concat(t).concat(e.name)})),i},fD=Object.freeze({__proto__:null,json2yjbos3dRecord:gD,yjbos3dRecord2json:function(e){try{var t=fu(e.split("⊗⊗"),2),i=t[0],n=t[1],r=i.split("⊗")[0];if(r===hD)return function(e,t){var i=fu(e.split("⊗"),6),n=i[1],r=i[2],o=i[3],a=i[4],s=i[5];if(!(i[0]&&n&&r&&o&&a&&s))throw new Error(uD[pD]);var l={name:n,id:r,type:Number(s),roamTime:Number(o),fps:Number(a)},c=[],h=t.split("⊗"),d=h.length;if(d%17==0){for(var u=0;d>u;u+=17)c.push({id:h[u],position:{x:parseFloat(h[u+1]),y:parseFloat(h[u+2]),z:parseFloat(h[u+3])},target:{x:parseFloat(h[u+4]),y:parseFloat(h[u+5]),z:parseFloat(h[u+6])},up:{x:parseFloat(h[u+7]),y:parseFloat(h[u+8]),z:parseFloat(h[u+9])},quaternion:{x:parseFloat(h[u+10]),y:parseFloat(h[u+11]),z:parseFloat(h[u+12]),w:parseFloat(h[u+13])},curve:"null"===h[u+14]?null:JSON.parse(atob(h[u+14])),editor:"null"===h[u+15]?null:JSON.parse(atob(h[u+15])),name:h[u+16]});return{info:l,keyFrameList:c}}if(d%15==0){for(var p=0,g=1;d>p;p+=15,g+=1)c.push({id:h[p],position:{x:parseFloat(h[p+1]),y:parseFloat(h[p+2]),z:parseFloat(h[p+3])},target:{x:parseFloat(h[p+4]),y:parseFloat(h[p+5]),z:parseFloat(h[p+6])},up:{x:parseFloat(h[p+7]),y:parseFloat(h[p+8]),z:parseFloat(h[p+9])},quaternion:{x:parseFloat(h[p+10]),y:parseFloat(h[p+11]),z:parseFloat(h[p+12]),w:parseFloat(h[p+13])},curve:"null"===h[p+14]?null:JSON.parse(atob(h[p+14])),editor:null,name:"视角".concat(g)});return{info:l,keyFrameList:c}}throw new Error(uD[pD])}(i,n);switch(r){case dD[0]:return function(e,t){var i=fu(e.split("⊗"),6),n=i[1],r=i[2],o=i[3],a=i[4],s=i[5];if(!(i[0]&&n&&r&&o&&a&&s))throw new Error(uD[pD]);var l={name:n,id:r,roamTime:o,fps:a,type:s},c=[],h=t.split("⊗"),d=h.length;if(d%7==0){for(var u=0;d>u;u+=7)c.push({id:h[u],position:{x:parseFloat(h[u+1]),y:parseFloat(h[u+2]),z:parseFloat(h[u+3])},target:{x:parseFloat(h[u+4]),y:parseFloat(h[u+5]),z:parseFloat(h[u+6])}});return{info:l,keyFrameList:c}}throw new Error(uD[pD])}(i,n);case dD[1]:return function(e,t){var i=fu(e.split("⊗"),6),n=i[1],r=i[2],o=i[3],a=i[4],s=i[5];if(!(i[0]&&n&&r&&o&&a&&s))throw new Error(uD[pD]);var l={name:n,id:r,type:Number(s),roamTime:Number(o),fps:Number(a)},c=[],h=t.split("⊗"),d=h.length;if(d%10==0){for(var u=0;d>u;u+=10)c.push({id:h[u],position:{x:parseFloat(h[u+1]),y:parseFloat(h[u+2]),z:parseFloat(h[u+3])},target:{x:parseFloat(h[u+4]),y:parseFloat(h[u+5]),z:parseFloat(h[u+6])},up:{x:parseFloat(h[u+7]),y:parseFloat(h[u+8]),z:parseFloat(h[u+9])}});return{info:l,keyFrameList:c}}throw new Error(uD[pD])}(i,n);case dD[2]:return function(e,t){var i=fu(e.split("⊗"),6),n=i[1],r=i[2],o=i[3],a=i[4],s=i[5];if(!(i[0]&&n&&r&&o&&a&&s))throw new Error(uD[pD]);var l={name:n,id:r,type:Number(s),roamTime:Number(o),fps:Number(a)},c=[],h=t.split("⊗"),d=h.length;if(d%14==0){for(var u=0;d>u;u+=14)c.push({id:h[u],position:{x:parseFloat(h[u+1]),y:parseFloat(h[u+2]),z:parseFloat(h[u+3])},target:{x:parseFloat(h[u+4]),y:parseFloat(h[u+5]),z:parseFloat(h[u+6])},up:{x:parseFloat(h[u+7]),y:parseFloat(h[u+8]),z:parseFloat(h[u+9])},quaternion:{x:parseFloat(h[u+10]),y:parseFloat(h[u+11]),z:parseFloat(h[u+12]),w:parseFloat(h[u+13])}});return{info:l,keyFrameList:c}}throw new Error(uD[pD])}(i,n);default:throw new Error(uD[pD])}}catch(e){throw e}},EXT:lD}),mD=function(){return OB.Date.now()},AD=/\s/;var yD=/^\s+/;function vD(e){return e?e.slice(0,function(e){for(var t=e.length;t--&&AD.test(e.charAt(t)););return t}(e)+1).replace(yD,""):e}var CD=/^[-+]0x[0-9a-f]+$/i,ID=/^0b[01]+$/i,xD=/^0o[0-7]+$/i,wD=parseInt;function MD(e){if("number"==typeof e)return e;if(Gk(e))return NaN;if(WB(e)){var t="function"==typeof e.valueOf?e.valueOf():e;e=WB(t)?t+"":t}if("string"!=typeof e)return 0===e?e:+e;e=vD(e);var i=ID.test(e);return i||xD.test(e)?wD(e.slice(2),i?2:8):CD.test(e)?NaN:+e}var ED=Math.max,BD=Math.min;function SD(e,t,i){var n,r,o,a,s,l,c=0,h=!1,d=!1,u=!0;if("function"!=typeof e)throw new TypeError("Expected a function");function p(t){var i=n,o=r;return n=r=void 0,c=t,a=e.apply(o,i)}function g(e){return c=e,s=setTimeout(m,t),h?p(e):a}function f(e){var i=e-l;return void 0===l||i>=t||0>i||d&&e-c>=o}function m(){var e=mD();if(f(e))return A(e);s=setTimeout(m,function(e){var i=t-(e-l);return d?BD(i,o-(e-c)):i}(e))}function A(e){return s=void 0,u&&n?p(e):(n=r=void 0,a)}function y(){var e=mD(),i=f(e);if(n=arguments,r=this,l=e,i){if(void 0===s)return g(l);if(d)return clearTimeout(s),s=setTimeout(m,t),p(l)}return void 0===s&&(s=setTimeout(m,t)),a}return t=MD(t)||0,WB(i)&&(h=!!i.leading,o=(d="maxWait"in i)?ED(MD(i.maxWait)||0,t):o,u="trailing"in i?!!i.trailing:u),y.cancel=function(){void 0!==s&&clearTimeout(s),c=0,n=l=r=s=void 0},y.flush=function(){return void 0===s?a:A(mD())},y}function bD(e,t,i){var n=!0,r=!0;if("function"!=typeof e)throw new TypeError("Expected a function");return WB(i)&&(n="leading"in i?!!i.leading:n,r="trailing"in i?!!i.trailing:r),SD(e,t,{leading:n,maxWait:t,trailing:r})}function kD(e){return null==e?[]:function(e,t){return Jk(t,(function(t){return e[t]}))}(e,WS(e))}var DD=function(){function e(t){ru(this,e),this.coef=t.coef||.5,this.points=t.controlPoints||[],this.pointCountRecord=t.pointCountRecord,this.formatConPoints=[],this.matrix=[],this._points=[],this.controlPointsIndex=[],this.straightLineDistance=0,this.count=0,this.setCoef(this.coef),this._formatConPoints(),this._calCount(),this.update=!0}return au(e,[{key:"setControlPoints",value:function(e){this.points=e,this._formatConPoints(),this._calCount(),this._createPoints(),this.update=!0}},{key:"getPointAt",value:function(e){this.update&&this.getPoints();var t=Math.ceil(e*this.count);return this._points[t>this.count?this.count:t]}},{key:"getPoints",value:function(){return this.update&&this._createPoints(this.pointCountRecord),this._points}},{key:"setCoef",value:function(e){this.update=!0,this.matrix=[[-e,2-e,e-2,e],[2*e,e-3,3-2*e,-e],[-e,0,e,0],[0,1,0,0]]}},{key:"getPointsInfo",value:function(){return{points:this.getPoints(),controlPointsIndex:this.controlPointsIndex}}},{key:"clone",value:function(){var e,t=[],i=vu(this.points);try{for(i.s();!(e=i.n()).done;){t.push(e.value.clone())}}catch(e){i.e(e)}finally{i.f()}var n=new this.constructor({controlPoints:t,coef:this.coef});return n.getPoints(),n}},{key:"_formatConPoints",value:function(){var e=this.points;this.formatConPoints=[];for(var t=0,i=e.length;i>t;t+=1)0===t?this.formatConPoints.push(e[t].clone(),e[t].clone()):i>t+1?this.formatConPoints.push(e[t].clone()):this.formatConPoints.push(e[t].clone(),e[t].clone())}},{key:"_calCount",value:function(){var e,t,i=this,n=1/0;t=(e=i.points).length,i.straightLineDistance=e.reduce((function(e,i,r,o){if(t>r+1){var a=o[r].distanceTo(o[r+1]);n=a>n?n:a,e+=a}return e}),0),i.updateStraightLineDistance=!1;var r=Math.ceil(i.straightLineDistance/n)||0;this.count=r>100?r:100}},{key:"_createPoints",value:function(){var e=[],t=this.matrix;function i(i){e[0]=new Ke,e[1]=new Ke,e[2]=new Ke,e[3]=new Ke;var n=[];n[0]=[],n[1]=[],n[2]=[],n[3]=[],n[0][0]=i[0].clone().multiplyScalar(t[0][0]),n[0][1]=i[1].clone().multiplyScalar(t[0][1]),n[0][2]=i[2].clone().multiplyScalar(t[0][2]),n[0][3]=i[3].clone().multiplyScalar(t[0][3]),n[1][0]=i[0].clone().multiplyScalar(t[1][0]),n[1][1]=i[1].clone().multiplyScalar(t[1][1]),n[1][2]=i[2].clone().multiplyScalar(t[1][2]),n[1][3]=i[3].clone().multiplyScalar(t[1][3]),n[2][0]=i[0].clone().multiplyScalar(t[2][0]),n[2][1]=i[1].clone().multiplyScalar(t[2][1]),n[2][2]=i[2].clone().multiplyScalar(t[2][2]),n[2][3]=i[3].clone().multiplyScalar(t[2][3]),n[3][0]=i[0].clone().multiplyScalar(t[3][0]),n[3][1]=i[1].clone().multiplyScalar(t[3][1]),n[3][2]=i[2].clone().multiplyScalar(t[3][2]),n[3][3]=i[3].clone().multiplyScalar(t[3][3]);for(var r=0;4>r;r+=1)for(var o=0;4>o;o+=1)e[r].add(n[r][o])}function n(t){var i=t*t,n=i*t;return e[0].clone().multiplyScalar(n).add(e[1].clone().multiplyScalar(i)).add(e[2].clone().multiplyScalar(t)).add(e[3].clone())}for(var r=this.formatConPoints,o=this._points=[],a=this.controlPointsIndex=[],s=this.points,l=this.straightLineDistance,c=0,h=0,d=0,u=s.length-1;u>d;d+=1){var p=(c+=s[d].distanceTo(s[d+1]))/l*this.count-h;i([r[d],r[d+1],r[d+2],r[d+3]]),o.push(r[d+1]),a.push({j:r[d+1],order:h}),h+=1;for(var g=1;p>g;g+=1)o.push(n(g/p)),h+=1}o.push(s[s.length-1]),a.push({to:r[s.length-1],order:-1}),this.update=!1}}]),e}(),TD=function(){function e(){ru(this,e),this.init()}return au(e,[{key:"init",value:function(){this.procedure=[],this.pointer=0}},{key:"record",value:function(e,t){this.procedure.length>this.pointer&&(this.procedure=this.procedure.slice(0,this.pointer)),this.procedure.push({type:e,payload:t}),this.pointer+=1}},{key:"undo",value:function(e){this.canUndo()&&(this.pointer-=1,e(this.procedure[this.pointer]))}},{key:"canUndo",value:function(){return this.pointer>0}},{key:"redo",value:function(e){this.canRedo()&&(e(this.procedure[this.pointer]),this.pointer+=1)}},{key:"canRedo",value:function(){return this.procedure.length>this.pointer}}]),e}(),RD=function(){for(var e=[],t=0;256>t;t+=1)e[t]=(16>t?"0":"")+t.toString(16);return function(){var t=4294967295*Math.random()|0,i=4294967295*Math.random()|0,n=4294967295*Math.random()|0,r=4294967295*Math.random()|0;return"".concat(e[255&t]+e[t>>8&255]+e[t>>16&255]+e[t>>24&255],"-").concat(e[255&i]).concat(e[i>>8&255],"-").concat(e[i>>16&15|64]).concat(e[i>>24&255],"-").concat(e[63&n|128]).concat(e[n>>8&255],"-").concat(e[n>>16&255]).concat(e[n>>24&255]).concat(e[255&r]).concat(e[r>>8&255]).concat(e[r>>16&255]).concat(e[r>>24&255]).toUpperCase()}}(),UD="__bos3dui_line",FD="__bos3dui_cube",QD=new Image;QD.src="";var LD=function(){function e(t){ru(this,e),this.viewer3D=t.viewer3D,this.recorder=new TD,this.adding=!1,this.removing=!1,this.editKey="",this.editMeshInitPos=new Ke,this.lineObject=null,this.tmpCube=null,this.cubeList=t.cubeList||[],this.startPoint=t.startPoint||null,this.endPoint=t.endPoint||null,this.mousemoveFn=function(){},this.clickFn=this.clickToAddCube(),this.moveCubeFn=bD(this.moveCubeListener(),16),this.cameraChangeFn=bD(this.cameraChangeListener.bind(this),16),this.rmCubeFn=function(){},this.onUserDrag=t.onDrag||function(){},this.tag=document.createElement("div"),this.tag.style.display="none",this.tag.style.position="absolute",this.tag.style.color="red",this.tag.style.fontSize="16px",this.viewer3D.viewportDiv.appendChild(this.tag),this.curve={},this.models=kD(this.viewer3D.viewerImpl.modelManager.models)||[]}return au(e,[{key:"start",value:function(e,t){var i=this;e&&t?(this.startPoint=e,this.endPoint=t,this.lineObject=this.drawHelper(e,t)):(this.lineObject=this.drawHelper(this.startPoint,this.endPoint),this.updateLine(),this.cubeList.forEach((function(e){i.viewer3D.addExternalObject(e.key,e)}))),this.viewer3D.viewportDiv.addEventListener("mousemove",this.moveCubeFn),this.viewer3D.registerCameraEventListener(Fd.ON_CAMERA_CHANGE,this.cameraChangeFn)}},{key:"stop",value:function(e){var t=this;this.switchDragCube(""),e||(this.viewer3D.removeExternalObjectByName(FD),this.viewer3D.removeExternalObjectByName(UD),this.viewer3D.viewportDiv.removeEventListener("mousemove",this.moveCubeFn),this.viewer3D.unregisterCameraEventListener(Fd.ON_CAMERA_CHANGE,this.cameraChangeFn),this.adding&&(this.viewer3D.viewportDiv.style.cursor="")),this.cubeList.forEach((function(e){t.viewer3D.removeExternalObjectByName(e.key)})),this.adding=!1,this.removing=!1}},{key:"clearEdit",value:function(){this.switchDragCube("")}},{key:"addCube",value:function(e){return!this.adding&&(this.viewer3D.viewportDiv.removeEventListener("mousemove",this.mousemoveFn),this.adding=!0,this.switchDragCube(""),this.mousemoveFn=bD(this.hoverLineListener(),16),this.viewer3D.viewportDiv.addEventListener("mousemove",this.mousemoveFn),this.clickFn=this.clickToAddCube(e),this.viewer3D.viewportDiv.addEventListener("click",this.clickFn),this.viewer3D.viewportDiv.style.cursor="url(".concat(QD,") -12 -12, auto"),!0)}},{key:"rmCube",value:function(e,t){return!this.removing&&0!==this.cubeList.length&&(this.recorder.record("remove",{mesh:this.cubeList[e],index:e}),this._rmCube(this.cubeList[e],t),!0)}},{key:"_rmCube",value:function(e,t){var i=this;this.switchDragCube(""),this.cubeList.some((function(n,r){return n===e&&(i.viewer3D.removeExternalObjectByName(e.key),i.cubeList.splice(r,1),i.updateLine(),i.updateTag(),i.viewer3D.viewportDiv.removeEventListener("click",i.rmCubeFn),i.viewer3D.render(),i.removing=!1,t(r),!0)}))}},{key:"updateCubePosition",value:function(e,t){var i=this;this.cubeList.some((function(n){if(n.key===e){i.recorder.record("move",{key:e,from:n.position.clone(),to:n.position.clone().fromArray(t)});var r=new yt;return r.elements[12]=t[0]-n.position.x,r.elements[13]=t[1]-n.position.y,r.elements[14]=t[2]-n.position.z,i.viewer3D.componentApplyMatrix(e,r),i.updateLine(),i.editKey&&i.switchDragCube(""),i.viewer3D.render(),!0}return!1}))}},{key:"getList",value:function(){return Hb(this.cubeList.map((function(e){return{position:e.position.toArray(),key:e.uuid}})))}},{key:"getCurve",value:function(){var e=[this.startPoint.clone()];return this.cubeList.forEach((function(t){e.push(t.position.clone())})),e.push(this.endPoint.clone()),this.curve.setControlPoints(e),this.curve}},{key:"reset",value:function(){var e=this;this.switchDragCube(""),this.cubeList.forEach((function(t){e.viewer3D.removeExternalObjectByName(t.key)})),this.cubeList=[],this.updateLine(),this.recorder.init(),this.viewer3D.render()}},{key:"canUndo",value:function(){return this.recorder.canUndo()}},{key:"undo",value:function(){var e=this,t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:function(){};this.adding||this.removing||this.recorder.undo((function(i){switch(e.switchDragCube(""),i.type){case"add":e._rmCube(i.payload,t);break;case"remove":for(var n=e.cubeList.length-1;n>=i.payload.index;n-=1)e.cubeList[n+1]=e.cubeList[n];var r=i.payload.mesh;e.cubeList[i.payload.index]=r,e.updateLine(),e.viewer3D.addExternalObject(r.key,r),t(r.position.toArray());break;case"move":var o=e.viewer3D.getExternalObjectByName(i.payload.key),a=new yt;a.elements[12]=i.payload.from.x-o.position.x,a.elements[13]=i.payload.from.y-o.position.y,a.elements[14]=i.payload.from.z-o.position.z,e.viewer3D.componentApplyMatrix(o.key,a),e.updateLine(),e.viewer3D.render(),t()}}))}},{key:"canRedo",value:function(){return this.recorder.canRedo()}},{key:"redo",value:function(){var e=this,t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:function(){};this.adding||this.removing||this.recorder.redo((function(i){e.switchDragCube("");var n=e.curve.getPointsInfo().controlPointsIndex.findIndex((function(e){return e.order>i.payload.index}));switch(i.type){case"add":-1===n?e.cubeList.push(i.payload):e.cubeList.splice(n-1,0,i.payload),e.updateLine(),e.viewer3D.addExternalObject(i.payload.key,i.payload),t(i.payload.position.toArray());break;case"remove":e._rmCube(i.payload.mesh,t);break;case"move":var r=e.viewer3D.getExternalObjectByName(i.payload.key),o=new yt;o.elements[12]=i.payload.to.x-r.position.x,o.elements[13]=i.payload.to.y-r.position.y,o.elements[14]=i.payload.to.z-r.position.z,e.viewer3D.componentApplyMatrix(r.key,o),e.updateLine(),e.viewer3D.render(),t()}}))}},{key:"preview",value:function(e){this.switchDragCube(""),this.viewer3D.adaptiveSizeByKey(this.cubeList[e].key)}},{key:"clickToAddCube",value:function(){var e=this,t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:function(){};return function(){if(e.tmpCube){var i=e;e.viewer3D.viewportDiv.removeEventListener("mousemove",e.mousemoveFn),e.viewer3D.viewportDiv.removeEventListener("click",e.clickFn),e.viewer3D.viewportDiv.style.cursor="";var n=e.curve.getPointsInfo().controlPointsIndex.findIndex((function(e){return e.order>i.tmpCube.index}));-1===n?e.cubeList.push(e.tmpCube):e.cubeList.splice(n-1,0,e.tmpCube),e.updateLine(),e.recorder.record("add",e.tmpCube);var r=e.tmpCube.position.toArray();e.tmpCube=null,e.adding=!1,t(r)}}}},{key:"genCubeObject",value:function(e){var t=new il({color:16777215*Math.random()}),i=new on(200,200,200);this.models.length&&"m"===this.models[0].originalLengthUnit&&(i=new on(.2,.2,.2));var n=new nn(i,t);if(!e)throw new Error("need position");return n.position.copy(e),n}},{key:"drawHelper",value:function(e,t){var i=[];i.push(this.genCubeObject(e),this.genCubeObject(t)),this.curve=new DD({controlPoints:[e.clone(),t.clone()],coef:.3});for(var n=this.curve.getPoints(),r=[],o=0,a=n.length;a>o;o+=1)r.push(n[o].x),r.push(n[o].y),r.push(n[o].z);var s=new Ni;s.setAttribute("position",new Bi(r,3));var l=new Sa({color:5095679,transparent:!1}),c=new Ua(s,l);return this.viewer3D.addExternalObject(UD,c),this.viewer3D.addExternalObject(FD,i),c.updateMatrixWorld(!0),c}},{key:"updateLine",value:function(){for(var e=new Ni,t=this.getCurve().getPoints(),i=[],n=0,r=t.length;r>n;n+=1)i.push(t[n].x),i.push(t[n].y),i.push(t[n].z);e.setAttribute("position",new Bi(i,3)),e.attributes.position.needUpdate=!0,this.lineObject.geometry=e,this.lineObject.updateMatrixWorld(!0)}},{key:"updateTag",value:function(){var e=this;if(this.editKey){var t=0;this.cubeList.some((function(i,n){return i.key===e.editKey&&(t=n,!0)})),this.tag.innerText="帧".concat(t+1);var i=this.viewer3D.getBoxByComponentsKey(this.editKey),n=this.viewer3D.getScreenCoordFromSceneCoord(i.getCenter(new Ke)).map((function(e){return Math.round(e)-50}));this.tag.style.top="".concat(n[1],"px"),this.tag.style.left="".concat(n[0],"px"),this.tag.style.display="block"}else this.tag.style.display="none"}},{key:"switchDragCube",value:function(e){var t=this;if(this.editKey===e||""===e)this.viewer3D.cancelTransformComponent(),this.editKey="",this.editMeshInitPos.set(0,0,0),this.updateTag();else{this.viewer3D.translateComponentByKey(e,this._onRender(e),(function(){var i=t.viewer3D.getExternalObjectByName(e);if(i){var n=i.position;t.recorder.record("move",{key:e,from:t.editMeshInitPos.clone(),to:n.clone()}),t.editMeshInitPos.copy(i.position)}}));var i=this.viewer3D.getExternalObjectByName(e);this.editKey=e,this.editMeshInitPos.copy(i.position),this.updateTag()}}},{key:"_onRender",value:function(e){var t=this;return bD((function(i){e===i&&(t.updateLine(),t.adding||t.onUserDrag(),t.updateTag(),console.debug("line refresh"))}),16)}},{key:"hoverLineListener",value:function(){var e,t=this,i=new Xp,n=new ke,r=this.viewer3D.getViewerImpl().camera;return i.params.Line.threshold=100,this.models.length&&"m"===this.models[0].originalLengthUnit&&(i.params.Line.threshold=.1),function(o){t.viewer3D.getViewerImpl().cameraControl.mapWindowToViewport(o.clientX,o.clientY,n),i.setFromCamera(n,r),i.near=r.near,i.far=r.far;var a=i.intersectObject(t.lineObject);a?(e?e.position.copy(a.point):(e=t.genCubeObject(a.point),t.viewer3D.addExternalObject("".concat(FD,"_").concat(RD()),e)),e.visible=!0,e.updateMatrixWorld(),t.tmpCube=e,t.tmpCube.index=a.index,t.viewer3D.render()):e?(e.visible=!1,t.tmpCube=null,t.viewer3D.render()):(t.tmpCube=null,t.viewer3D.render())}}},{key:"moveCubeListener",value:function(){var e=this,t=new Xp,i=new ke,n=this.viewer3D.getViewerImpl().camera;return function(r){if(!e.adding&&!e.removing){e.viewer3D.getViewerImpl().cameraControl.mapWindowToViewport(r.clientX,r.clientY,i),t.setFromCamera(i,n),t.near=n.near,t.far=n.far;var o=t.intersectObjects(e.cubeList);o&&o.object.key!==e.editKey&&e.switchDragCube(o.object.key)}}}},{key:"rmCubeListener",value:function(){var e=this,t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:function(){},i=new Xp,n=new ke,r=this.viewer3D.getViewerImpl().camera;return i.params.Line.threshold=100,function(o){if(e.removing){e.viewer3D.getViewerImpl().cameraControl.mapWindowToViewport(o.clientX,o.clientY,n),i.setFromCamera(n,r),i.near=r.near,i.far=r.far;var a=i.intersectObjects(e.cubeList);a&&(e._rmCube(a.object,t),e.recorder.record("remove",a.object))}}}},{key:"cameraChangeListener",value:function(){this.editKey&&this.updateTag()}}]),e}(),OD=function(){function e(t){ru(this,e),this.position=t.position,this.target=t.target,this.up=t.up,this.quaternion=t.quaternion,this.id=t.id||(new Date).getTime().toString().slice(8),this.name=t.name||"视角".concat(t.perspNumber),this.circlePosition=t.circlePosition,this.curve=t.curve||null,this.editingFrameIndex=null,this.viewer=t.viewer,this.editing=!1,this.editor=t.editor||null,this.frameList=t.frameList||null}return au(e,[{key:"rename",value:function(e){this.name=e}},{key:"focus",value:function(){this.viewer.linearFlyTo(this)}},{key:"updatePosition",value:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null;this.editing||(this.position=this.viewer.viewerImpl.camera.position.clone(),this.target=this.viewer.viewerImpl.camera.target.clone(),this.up=this.viewer.viewerImpl.camera.up.clone(),this.quaternion=this.viewer.viewerImpl.camera.quaternion.clone(),this.circlePosition=this.viewer.getViewerImpl().cameraControl.projectPositionToBottom(this.position)),this.editing&&e&&"function"==typeof e&&e()}},{key:"editPerspective",value:function(e){var t={x:e[0]-this.position.x,y:e[1]-this.position.y,z:e[2]-this.position.z};this.viewer.getViewerImpl().camera.position.add(t),this.viewer.getViewerImpl().camera.target.add(t),this.viewer.render(),this.position.add(t),this.target.add(t)}},{key:"setEditingStatus",value:function(e){this.editing=e}},{key:"clone",value:function(){var e=new this.constructor({circlePosition:this.circlePosition&&this.circlePosition.clone(),curve:this.curve&&this.curve.clone(),editing:this.editing,editingFrameIndex:this.editingFrameIndex,editor:this.editor,id:this.id,name:this.name,position:this.position&&this.position.clone(),quaternion:this.quaternion&&this.quaternion.clone(),target:this.target&&this.target.clone(),up:this.up&&this.up.clone(),viewer:this.viewer});return e.editing=this.editing,e.frameList=e.curve,e}}]),e}(),ND={Roam:nD,FreeRoam:rD,RouteRoam:function(e){lu(i,e);var t=pu(i);function i(e){var n;return ru(this,i),(n=t.call(this,e)).Roam=oD,n.RoamPlayer=aD,n.Perspective=OD,n.viewer=e.viewer,n.routeObjList=[],n.roamPlayerList=[],n.initSpeedList=[],n.roamPlayingId=null,n.roamPauseId=null,n.tempRoute=[],n.perspectiveList=[],n.editingFrameIndex=0,n.perspectiveNumber=0,n.tempPlayer=null,n.backupPerspectiveEditor=null,n}return au(i,[{key:"getAllRoutes",value:function(){return this.routeObjList}},{key:"_getRoute",value:function(e){var t=-1,i=this.routeObjList.find((function(i,n){return i.getId()===e&&(t=n,!0)}));return{index:t,route:i}}},{key:"_getRoamPlayer",value:function(e){var t=-1,i=this.roamPlayerList.find((function(i,n){return i.roam.getId()===e&&(t=n,!0)}));return{index:t,player:i}}},{key:"createTempRoute",value:function(e){var t=this,i=new this.Roam(e),n=new this.RoamPlayer({roamData:i,viewer:this.viewer.getViewerImpl()});return n.addStopPlayCallback((function(){t.roamPlayingId=null})),n}},{key:"tempRoutePlay",value:function(e){var t=this.createTempRoute(e);this.tempPlayer=t,this.roamPlayingId||this.roamPauseId||("temp"===this.roamPauseId?t.continue():t.play(),this.roamPauseId=null,this.roamPlayingId="temp")}},{key:"tempLinearFlyTo",value:function(e,t){var i=this.viewer.getViewerImpl().camera;i.position.set(e.position.x,e.position.y,e.position.z),i.target.set(e.target.x,e.target.y,e.target.z),i.up.set(e.up.x,e.up.y,e.up.z),this.viewer.linearFlyTo(t)}},{key:"addRoute",value:function(e){for(var t=this,i=new this.Roam(e),n=-1,r=this.getAllRoutes(),o=0;r.length>o;o+=1)if(r[o].id===i.id){n=o;break}if(-1!==n){this.routeObjList.splice(n,1,i);var a=new this.RoamPlayer({roamData:i,viewer:this.viewer.getViewerImpl()});a.addStopPlayCallback((function(){t.roamPlayingId=null})),this.roamPlayerList.splice(n,1,a),this.initSpeedList.splice(n,1,e.roamTime)}else{this.routeObjList.push(i);var s=new this.RoamPlayer({roamData:i,viewer:this.viewer.getViewerImpl()});s.addStopPlayCallback((function(){t.roamPlayingId=null})),this.roamPlayerList.push(s),this.initSpeedList.push(e.roamTime)}return this.setPerspectiveList(),this.perspectiveNumber=0,this.editingFrameIndex=0,this.routeObjList}},{key:"rmRoam",value:function(e,t){var i=this._getRoute(e).index;if(i>=0){if(this.roamPlayingId===e||this.roamPauseId===e){if(!t)return!1;this.stopRoam(e)}return this.routeObjList.splice(i,1),this.roamPlayerList.splice(i,1),this.initSpeedList.splice(i,1),!0}return!1}},{key:"setSpeed",value:function(e,t){var i=this._getRoute(e),n=i.route;return!!n&&(n.setRoamTime(this.initSpeedList[i.index]/t),!0)}},{key:"getRoute",value:function(e){return this._getRoute(e).route}},{key:"getRoamPlayer",value:function(e){return this._getRoamPlayer(e).player}},{key:"getBlobData",value:function(e){var t=this.getRoute(e).export();return{fileName:"".concat(t.name).concat(lD),blob:new Blob([gD(t)])}}},{key:"startRoam",value:function(e,t){if(this.roamPlayingId||this.roamPauseId){if(!t)return!1;if(this.roamPlayingId)this.getRoamPlayer(this.roamPlayingId).stop();if(this.roamPauseId&&this.roamPauseId!==e)this.getRoamPlayer(this.roamPauseId).stop(),this.roamPauseId=null}var i=this.getRoamPlayer(e);return this.roamPauseId===e?i.continue():(i.stop(),i.play()),this.roamPauseId=null,this.roamPlayingId=e,!0}},{key:"pauseRoam",value:function(e){return e===this.roamPlayingId&&(this.getRoamPlayer(e).pause(),this.roamPlayingId=null,this.roamPauseId=e,!0)}},{key:"stopRoam",value:function(e){return e===(this.roamPauseId||this.roamPlayingId)&&(this.getRoamPlayer(e).stop(),this.roamPlayingId=null,this.roamPauseId=null,!0)}},{key:"setFrame",value:function(e,t){var i=this._getRoute(e),n=i.route,r=i.index;if(r>=0){var o=t>n.keyFrameList.length-1?n.keyFrameList.length-1:t;this.roamPlayerList[r].startFrom(n.keyFrameList[o].id),this.viewer.linearFlyTo(n.keyFrameList[o])}}},{key:"addPerspective",value:function(){var e=this._genPerspective();return this.perspectiveList.push(e),e}},{key:"reGenPerspective",value:function(e){var t=this,i=e.map((function(e){if(e.viewer=e.viewer||t.viewer,e.editor){var i=e.editor.cubeList.map((function(e){return e&&new Ke(e.position.x,e.position.y,e.position.z)})),n=new LD({viewer3D:t.viewer,startPoint:new Ke(e.editor.startPoint.x,e.editor.startPoint.y,e.editor.startPoint.z),endPoint:new Ke(e.editor.endPoint.x,e.editor.endPoint.y,e.editor.endPoint.z)});return e.editor=n,e.editor.cubeList=i.map((function(t){return t&&e.editor.genCubeObject(t)})),e.frameList=e.curve,new OD(e)}return new OD(e)}));return this.setPerspectiveList(i),i}},{key:"insertPerspective",value:function(e,t,i){var n=this._genPerspective();0===t?(this._clearFrameEditorAndFrameList(e),this.perspectiveList.splice(e,0,n)):(this._clearFrameEditorAndFrameList(e+1),this.perspectiveList.splice(e+1,0,n)),i&&"function"==typeof i&&i()}},{key:"getPerspectiveList",value:function(){return this.perspectiveList}},{key:"setPerspectiveList",value:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:[];this.perspectiveList=e}},{key:"editFrame",value:function(e){if(e){if(e===this.editingFrameIndex)return this.perspectiveList[e].editor&&this.perspectiveList[e].editor.stop(),this.editingFrameIndex=0,void(this.perspectiveList[e].editing=!1);if(0===this.editingFrameIndex){var t=!1,i=this.perspectiveList[e];this.editingFrameIndex=e,i.editing=!0,i.editor||(i.editor=new LD({viewer3D:this.viewer}),t=!0),i.editor.start(t?this.perspectiveList[e-1].position.clone():void 0,t?i.position.clone():void 0),this.backupPerspectiveEditor={cubeList:i.editor.cubeList.map((function(e){return{position:e.position}})),startPoint:i.editor.startPoint,endPoint:i.editor.endPoint}}}}},{key:"resetPerspectiveCubeList",value:function(e,t){if(!this.backupPerspectiveEditor&&t){var i=this.getRoute(t);return i.keyFrameList[e].editor=null,this.routeObjList.forEach((function(e){e.id===t&&(e=i)})),this.editingFrameIndex=0,void(this.backupPerspectiveEditor=null)}var n=this.backupPerspectiveEditor.cubeList.map((function(e){return e&&new Ke(e.position.x,e.position.y,e.position.z)})),r=new LD({viewer3D:this.viewer,startPoint:new Ke(this.backupPerspectiveEditor.startPoint.x,this.backupPerspectiveEditor.startPoint.y,this.backupPerspectiveEditor.startPoint.z),endPoint:new Ke(this.backupPerspectiveEditor.endPoint.x,this.backupPerspectiveEditor.endPoint.y,this.backupPerspectiveEditor.endPoint.z)});if(t){var o=this.getRoute(t);r.cubeList=n.map((function(e){return e&&r.genCubeObject(e)})),o.keyFrameList[e].editor=r,this.routeObjList.forEach((function(e){e.id===t&&(e=o)}))}this.editingFrameIndex=0,this.backupPerspectiveEditor=null}},{key:"getEditFrameStatus",value:function(){return this.editingFrameIndex}},{key:"saveEditFrameList",value:function(e,t){if(0!==e){var i=this.perspectiveList[e];t.points.length>2?(i.frameList=new DD({controlPoints:t.points,coef:t.coef}),i.frameList.getPoints(),i.editor.clearEdit()):(i.curve=null,i.frameList=null)}}},{key:"clearAllFrameData",value:function(){this.perspectiveList.forEach((function(e){e.editor=null,e.frameList=null}))}},{key:"removePerspective",value:function(e){this.perspectiveList[e+1]&&(this.perspectiveList[e+1].editor=null,this.perspectiveList[e+1].frameList=null),this.perspectiveList.splice(e,1)}},{key:"_genPerspective",value:function(){this.perspectiveNumber+=1;var e=this.viewer,t=e.viewerImpl.camera.position.clone();return new this.Perspective({position:t,target:e.viewerImpl.camera.target.clone(),up:e.viewerImpl.camera.up.clone(),quaternion:e.viewerImpl.camera.quaternion.clone(),perspNumber:this.perspectiveNumber,circlePosition:e.getViewerImpl().cameraControl.projectPositionToBottom(t),viewer:this.viewer})}},{key:"_clearFrameEditorAndFrameList",value:function(e){this.perspectiveList[e]&&(this.perspectiveList[e].editor=null,this.perspectiveList[e].frameList=null)}}],[{key:"startRouteRoam",value:function(e){gu(cu(i),"startRoam",this).call(this,e)}}]),i}(nD),fileParser:fD,LineEditor:LD},PD={fontSize:100,color:"#ff0000",opacity:1,side:2,transparent:!0},GD=function(){function e(){ru(this,e)}return au(e,[{key:"createMesh",value:function(e,t){var i=Object.assign({},PD,t),n=e.generateShapes(i.text,i.fontSize),r=new gi(i),o=new Gs(n),a=new nn(o,r);return i.position&&this.setPos(a,i.position),i.rotation&&this.setRotation(a,i.rotation),i.matrix&&this.setMat(a,i.matrix),a}},{key:"setPos",value:function(e,t){var i;(i=e.position).set.apply(i,mu(t)),e.updateMatrixWorld(!0)}},{key:"setMat",value:function(e,t){e.applyMatrix4(t),e.updateMatrixWorld(!0)}},{key:"setRotation",value:function(e,t){var i;(i=e.rotation).set.apply(i,mu(t)),e.updateMatrixWorld(!0)}}]),e}(),KD=function(){function e(t){ru(this,e),this.fonts={},this.host=t.host}return au(e,[{key:"loadFont",value:function(e,t){var i=this;return new Promise((function(n,r){Yy({type:"POST",url:"".concat(i.host,"/api/fonts"),headers:{"Content-type":"application/json;charset=UTF-8"},data:JSON.stringify({font:e,text:t}),responseType:"json",success:function(t){"success"===t.code.toLowerCase()?(i.fonts[e]?Object.assign(i.fonts[e].data.glyphs,t.data.glyphs):(i.fonts[e]={},i.fonts[e].data=t.data),i.fonts[e].font=new Dc(i.fonts[e].data),n(i.fonts[e].font)):r(t)},error:function(e,t){r(t)}})}))}},{key:"getFont",value:function(e,t){var i=this;return new Promise((function(n,r){if(i.fonts[e]){for(var o=t.length,a="",s=0;o>s;s+=1)i.fonts[e].data.glyphs[t[s]]||(a+=t[s]);a?i.loadFont(e,a).then(n).catch(r):n(i.fonts[e].font)}else i.loadFont(e,t).then(n).catch(r)}))}}]),e}(),VD=function(){function e(t){ru(this,e),this.viewer=t.viewer.getViewerImpl(),this.meshes={},this.fontLib=new KD({host:t.viewer.host}),this.text=new GD,this.draggingId=""}return au(e,[{key:"addText",value:function(e){var t=this;return this.fontLib.getFont(e.fontName,e.text).then((function(i){var n=t.text.createMesh(i,e),r=wp.createUUID();return t.meshes[r]=n,t.viewer.getScene().add(n),t.viewer.render(),{code:"success",id:r}})).catch((function(e){return{code:"error",err:e}}))}},{key:"removeText",value:function(e){if(this.draggingId!==e){var t=this.meshes[e];t&&(this.viewer.getScene().remove(t),delete this.meshes[e],this.viewer.render())}}},{key:"setPosition",value:function(e,t){if(this.draggingId!==e){var i=this.meshes[e];i&&(this.text.setPos(i,t),this.viewer.render())}}},{key:"setMatrix",value:function(e,t){if(this.draggingId!==e){var i=this.meshes[e];i&&(this.text.setMat(i,t),this.viewer.render())}}},{key:"setRotation",value:function(e,t){if(this.draggingId!==e){var i=this.meshes[e];i&&(this.text.setRotation(i,t),this.viewer.render())}}},{key:"getTextIDs",value:function(){return Object.keys(this.meshes)}},{key:"dragText",value:function(e){if(""===this.draggingId){var t=this.meshes[e];t&&(this.viewer.translateComponentByKey(t),this.draggingId=e)}}},{key:"saveDragText",value:function(){""!==this.draggingId&&(this.viewer.cancelTransformComponent(!1),this.draggingId="")}}]),e}(),YD=function(){function e(t){ru(this,e),this.curves={},this.viewer=t.viewer3D,this.modelKey=t.modelKey}return au(e,[{key:"getId",value:function(e){return xp(JSON.stringify(e)).slice(0,8)}},{key:"getCurve",value:function(e){return this.curves[e]}},{key:"_setCurve",value:function(e,t){this.curves[e]=t}},{key:"_rmCurve",value:function(e){delete this.curves[e]}},{key:"genTHREELine",value:function(e){for(var t=e.num,i=void 0===t?100:t,n=e.debug,r=void 0!==n&&n,o=new Pl(e.points,e.closed,e.curveType,e.tension),a=this.getId(e),s=new Ni,l=o.getSpacedPoints(i),c=[],h=0,d=l.length;d>h;h+=1)c.push(l[h].x),c.push(l[h].y),c.push(l[h].z);s.setAttribute("position",new Bi(c,3));var u=new Sa({color:e.color||16777215*Math.random(),linewidth:6.18,depthTest:!0,transparent:!1}),p=new Ua(s,u);r&&(this.viewer.getViewerImpl().modelManager.getModel(this.modelKey).group.add(p),p.updateMatrixWorld(),this.viewer.render());return this._setCurve(a,{curve:o,num:i,line:p}),a}},{key:"rmCurve",value:function(e){var t=this.getCurve(e).line;this.viewer.getViewerImpl().modelManager.getModel(this.modelKey).group.remove(t),t.updateMatrixWorld(),this.viewer.render(),this._rmCurve(e)}}]),e}(),HD=function(){function e(t){ru(this,e),this.trackSet={},this.lineManager=new YD(t),this.viewer=t.viewer3D}return au(e,[{key:"_genLine",value:function(e){return this.lineManager.genTHREELine(e)}},{key:"addTrack",value:function(e){var t=((new Date).getTime()*(Math.random()+1)).toString(36).slice(0,8),i=this._genLine(e);return this.trackSet[t]={componentKey:e.componentKey,lineId:[i]},t}},{key:"appendTrack",value:function(e){var t=this.trackSet[e.trackId];if(t){var i=this._genLine(e);t.lineId.push(i)}}},{key:"removeTrack",value:function(e){var t=this,i=this.trackSet[e];i&&(i.lineId.forEach((function(e){t.lineManager.rmCurve(e)})),delete this.trackSet[e])}},{key:"startMove",value:function(e){var t=this,i=e.trackId,n=e.startDir,r=e.pointFn;return new Promise((function(e,o){var a=t.trackSet[i];if(a){var s=a.lineId,l=a.componentKey,c=new yt,h=s.length,d=t.lineManager.getCurve(s[0]).curve.getPoint(0),u=t.viewer.getBoxByComponentsKey(l),p=u.min,g=u.max,f=(new Ke).addVectors(p,g).divideScalar(2);c.elements[12]=d.x-f.x,c.elements[13]=d.y-f.y,c.elements[14]=d.z-f.z,t.viewer.componentApplyMatrix(l,c);var m=0,A=new yt,y=n.clone().normalize(),v=function n(o){var a=t.lineManager.getCurve(s[Math.trunc(m)]).curve.getPoint(m-Math.trunc(m)),d=h>o?t.lineManager.getCurve(s[Math.trunc(o)]).curve.getPoint(o-Math.trunc(o)):t.lineManager.getCurve(s[h-1]).curve.getPoint(1),u=new yt;u.elements[12]=-a.x,u.elements[13]=-a.y,u.elements[14]=-a.z;var p=new Ge,g=new Ke(d.x-a.x,d.y-a.y,d.z-a.z).normalize();p.setFromUnitVectors(y,g),y.applyQuaternion(p);var f=(new yt).makeRotationFromQuaternion(p),v=new yt;v.elements[12]=d.x,v.elements[13]=d.y,v.elements[14]=d.z,c.elements=A.elements,t.viewer.componentApplyMatrix(l,v.multiply(f).multiply(u)),m=o,h>o?"function"==typeof r?requestAnimationFrame((function(){n(r(i,o,d))})):requestAnimationFrame((function(){return n(parseFloat((o+.01).toFixed(2)))})):e({code:"success",trackId:i})};"function"==typeof r?requestAnimationFrame((function(){v(r(i,0,d))})):requestAnimationFrame((function(){return v(.01)}))}else o({code:"error",message:"找不到指定轨迹"})}))}}]),e}(),jD=function(e,t){nn.call(this,e);var i=this,n=void 0!==(t=t||{}).textureWidth?t.textureWidth:512,r=void 0!==t.textureHeight?t.textureHeight:512,o=void 0!==t.clipBias?t.clipBias:0,a=void 0!==t.alpha?t.alpha:1,s=void 0!==t.time?t.time:0,l=void 0!==t.waterNormals?t.waterNormals:null,c=void 0!==t.sunDirection?t.sunDirection:new Ke(.70707,.70707,0),h=new pi(void 0!==t.sunColor?t.sunColor:16777215),d=new pi(void 0!==t.waterColor?t.waterColor:8355711),u=void 0!==t.eye?t.eye:new Ke(0,0,0),p=void 0!==t.distortionScale?t.distortionScale:20,g=void 0!==t.side?t.side:0,f=void 0!==t.fog&&t.fog,m=new Jt,A=new Ke,y=new Ke,v=new Ke,I=new yt,x=new Ke(0,0,-1),w=new Le,M=new Ke,E=new Ke,B=new Le,S=new yt,b=new dn,D=new Oe(n,r,{minFilter:C,magFilter:C,format:k,stencilBuffer:!1});be.isPowerOfTwo(n)&&be.isPowerOfTwo(r)||(D.texture.generateMipmaps=!1);var T={uniforms:ln.merge([wn.fog,wn.lights,{normalSampler:{value:null},mirrorSampler:{value:null},alpha:{value:1},time:{value:0},size:{value:1},distortionScale:{value:20},textureMatrix:{value:new yt},sunColor:{value:new pi(8355711)},sunDirection:{value:new Ke(.70707,.70707,0)},eye:{value:new Ke},waterColor:{value:new pi(5592405)}}]),vertexShader:["uniform mat4 textureMatrix;","uniform float time;","varying vec4 mirrorCoord;","varying vec4 worldPosition;",xn.fog_pars_vertex,xn.shadowmap_pars_vertex,"void main() {"," mirrorCoord = modelMatrix * vec4( position, 1.0 );"," worldPosition = mirrorCoord.xyzw;"," mirrorCoord = textureMatrix * mirrorCoord;"," vec4 mvPosition = modelViewMatrix * vec4( position, 1.0 );"," gl_Position = projectionMatrix * mvPosition;",xn.fog_vertex,xn.shadowmap_vertex,"}"].join("\n"),fragmentShader:["uniform sampler2D mirrorSampler;","uniform float alpha;","uniform float time;","uniform float size;","uniform float distortionScale;","uniform sampler2D normalSampler;","uniform vec3 sunColor;","uniform vec3 sunDirection;","uniform vec3 eye;","uniform vec3 waterColor;","varying vec4 mirrorCoord;","varying vec4 worldPosition;","vec4 getNoise( vec2 uv ) {"," vec2 uv0 = ( uv / 103.0 ) + vec2(time / 17.0, time / 29.0);"," vec2 uv1 = uv / 107.0-vec2( time / -19.0, time / 31.0 );"," vec2 uv2 = uv / vec2( 8907.0, 9803.0 ) + vec2( time / 101.0, time / 97.0 );"," vec2 uv3 = uv / vec2( 1091.0, 1027.0 ) - vec2( time / 109.0, time / -113.0 );"," vec4 noise = texture2D( normalSampler, uv0 ) +"," texture2D( normalSampler, uv1 ) +"," texture2D( normalSampler, uv2 ) +"," texture2D( normalSampler, uv3 );"," return noise * 0.5 - 1.0;","}","void sunLight( const vec3 surfaceNormal, const vec3 eyeDirection, float shiny, float spec, float diffuse, inout vec3 diffuseColor, inout vec3 specularColor ) {"," vec3 reflection = normalize( reflect( -sunDirection, surfaceNormal ) );"," float direction = max( 0.0, dot( eyeDirection, reflection ) );"," specularColor += pow( direction, shiny ) * sunColor * spec;"," diffuseColor += max( dot( sunDirection, surfaceNormal ), 0.0 ) * sunColor * diffuse;","}",xn.common,xn.packing,xn.bsdfs,xn.fog_pars_fragment,xn.lights_pars_begin,xn.shadowmap_pars_fragment,xn.shadowmask_pars_fragment,"void main() {"," vec4 noise = getNoise( worldPosition.xz * size );"," vec3 surfaceNormal = normalize( noise.xzy * vec3( 1.5, 1.0, 1.5 ) );"," vec3 diffuseLight = vec3(0.0);"," vec3 specularLight = vec3(0.0);"," vec3 worldToEye = eye-worldPosition.xyz;"," vec3 eyeDirection = normalize( worldToEye );"," sunLight( surfaceNormal, eyeDirection, 100.0, 2.0, 0.5, diffuseLight, specularLight );"," float distance = length(worldToEye);"," vec2 distortion = surfaceNormal.xz * ( 0.001 + 1.0 / distance ) * distortionScale;"," vec3 reflectionSample = vec3( texture2D( mirrorSampler, mirrorCoord.xy / mirrorCoord.w + distortion ) );"," float theta = max( dot( eyeDirection, surfaceNormal ), 0.0 );"," float rf0 = 0.3;"," float reflectance = rf0 + ( 1.0 - rf0 ) * pow( ( 1.0 - theta ), 5.0 );"," vec3 scatter = max( 0.0, dot( surfaceNormal, eyeDirection ) ) * waterColor;"," vec3 albedo = mix( ( sunColor * diffuseLight * 0.3 + scatter ) * getShadowMask(), ( vec3( 0.1 ) + reflectionSample * 0.9 + reflectionSample * specularLight ), reflectance);"," vec3 outgoingLight = albedo;"," gl_FragColor = vec4( outgoingLight, alpha );",xn.tonemapping_fragment,xn.fog_fragment,"}"].join("\n")},R=new cn({fragmentShader:T.fragmentShader,vertexShader:T.vertexShader,uniforms:ln.clone(T.uniforms),transparent:1>a,lights:!0,side:g,fog:f});R.uniforms.mirrorSampler.value=D.texture,R.uniforms.textureMatrix.value=S,R.uniforms.alpha.value=a,R.uniforms.time.value=s,R.uniforms.normalSampler.value=l,R.uniforms.sunColor.value=h,R.uniforms.waterColor.value=d,R.uniforms.sunDirection.value=c,R.uniforms.distortionScale.value=p,R.uniforms.eye.value=u,i.material=R,i.onBeforeRender=function(e,t,n){if(y.setFromMatrixPosition(i.matrixWorld),v.setFromMatrixPosition(n.matrixWorld),I.extractRotation(i.matrixWorld),A.set(0,0,1),A.applyMatrix4(I),M.subVectors(y,v),0>=M.dot(A)){M.reflect(A).negate(),M.add(y),I.extractRotation(n.matrixWorld),x.set(0,0,-1),x.applyMatrix4(I),x.add(v),E.subVectors(y,x),E.reflect(A).negate(),E.add(y),b.position.copy(M),b.up.set(0,1,0),b.up.applyMatrix4(I),b.up.reflect(A),b.lookAt(E),b.far=n.far,b.updateMatrixWorld(),b.projectionMatrix.copy(n.projectionMatrix),S.set(.5,0,0,.5,0,.5,0,.5,0,0,.5,.5,0,0,0,1),S.multiply(b.projectionMatrix),S.multiply(b.matrixWorldInverse),m.setFromNormalAndCoplanarPoint(A,y),m.applyMatrix4(b.matrixWorldInverse),w.set(m.normal.x,m.normal.y,m.normal.z,m.constant);var r=b.projectionMatrix;B.x=(Math.sign(w.x)+r.elements[8])/r.elements[0],B.y=(Math.sign(w.y)+r.elements[9])/r.elements[5],B.z=-1,B.w=(1+r.elements[10])/r.elements[14],w.multiplyScalar(2/w.dot(B)),r.elements[2]=w.x,r.elements[6]=w.y,r.elements[10]=w.z+1-o,r.elements[14]=w.w,u.setFromMatrixPosition(n.matrixWorld);var a=e.getRenderTarget(),s=e.xr.enabled,l=e.shadowMap.autoUpdate;i.visible=!1,e.xr.enabled=!1,e.shadowMap.autoUpdate=!1,e.setRenderTarget(D),e.clear(),e.render(t,b),i.visible=!0,e.xr.enabled=s,e.shadowMap.autoUpdate=l,e.setRenderTarget(a)}}};(jD.prototype=Object.create(nn.prototype)).constructor=jD;var WD=function(e,t){this.defaultSetting={colorRects:!0,picker:!0,colorCode:!0,hasOpacity:!0},this.color={hex:void 0,rgb:void 0,rgba:void 0,hsl:void 0},this.colorInputDom=e,this.element=this.create(t)};WD.prototype={constructor:WD,create:function(e){var t=this,i=t.defaultSetting;e&&(i=wp.extend(!0,t.defaultSetting,e));var n=document.createElement("div");return n.style.cssText+="width:190px;position:absolute;",i.colorRects&&n.appendChild(t.createRects(!!i.hasOpacity)),i.picker&&n.appendChild(t.createPicker(!!i.hasOpacity)),i.colorCode&&n.appendChild(t.createColorCode()),n.appendChild(t.createBtn()),t.element=n,n},createBtn:function(){var e=this,t=document.createElement("div"),i=document.createElement("button");i.className="btn-yes",i.innerHTML="确定",i.style.cssText+="display:inline-block;margin:10px;color:#000;background-color: #FFFFFF;border: 2px solid #FFFFFF;border-radius: 4px; width: 73px;height: 32px;",i.addEventListener("click",(function(){e.element.style.display="none"}));var n=document.createElement("button");return n.className="btn-no",n.innerHTML="取消",n.style.cssText+="display:inline-block;margin:10px;color:#000;background-color: #FFFFFF;border: 2px solid #FFFFFF;border-radius: 4px; width: 73px;height: 32px;",n.addEventListener("click",(function(){e.element.style.display="none"})),t.appendChild(i),t.appendChild(n),t},createRects:function(e){var t=this,i=document.createElement("div");i.className="rectFather",i.style.cssText+="width:180px;height:180px;margin-top:10px;margin-left:10px;display:flex;flex-wrap:wrap;align-items:flex-start;";for(var n=[],r=["00","55","AA","FF"],o=0,a=0,s=0,l="",c=0;64>c;)l="#"+r[o]+r[a]+r[s],n[c]=document.createElement("span"),n[c].className="spans"+c,n[c].style.cssText+="width:15px;height:15px;margin:1px 2px;border:1px solid #FFFFFF;background-color:"+l+";",n[c].setAttribute("color",l),i.appendChild(n[c]),(c+=1)%16==0?o+=1:c%4==0?(a+=1)>3&&(a=0):(s+=1)>3&&(s=0);var h=i.querySelectorAll("span");return ag.addEventListener(h,"click",(function(i){for(var n=0;h.length>n;n+=1)h[n].style.cssText+="border:1px solid #FFFFFF;";var r=i.target;r.style.cssText+="border:2px solid #000000;";var o=r.getAttribute("color");e?t.setColor(o,1):t.setColor(o),i.stopPropagation?i.stopPropagation():i.cancelBubble=!0})),i},createPicker:function(e){var t=this,i=document.createElement("div");i.style.cssText+="width:180px;margin-left:10px;";var n=document.createElement("span");n.className="colorShow",n.style.cssText+="display:block;width:170px;height:30px;border-radius:5px;margin-top:10px;margin-bottom:10px;background-color:#FFFFFF;",i.appendChild(n);var r=document.createElement("span");r.innerHTML="红 : ",r.style.color="#FF0000";var o=document.createElement("input");o.type="range",o.className="redRange",o.style.cssText+="background:linear-gradient(#FFFFFF, #FFFFFF) no-repeat, #FF0000;",o.setAttribute("step","1"),o.setAttribute("min","0"),o.setAttribute("max","255"),o.setAttribute("value","255");var a=document.createElement("div");a.appendChild(r),a.appendChild(o),i.appendChild(a);var s=document.createElement("span");s.innerHTML="绿 : ",s.style.color="#00FF00";var l=document.createElement("input");l.type="range",l.className="greenRange",l.style.cssText+="background:linear-gradient(#FFFFFF, #FFFFFF) no-repeat, #00FF00;",l.setAttribute("step","1"),l.setAttribute("min","0"),l.setAttribute("max","255"),l.setAttribute("value","255");var c=document.createElement("div");c.appendChild(s),c.appendChild(l),i.appendChild(c);var h=document.createElement("span");h.innerHTML="蓝 : ",h.style.color="#0000FF";var d=document.createElement("input");d.type="range",d.className="blueRange",d.style.cssText+="background:linear-gradient(#FFFFFF, #FFFFFF) no-repeat, #0000FF;",d.setAttribute("step","1"),d.setAttribute("min","0"),d.setAttribute("max","255"),d.setAttribute("value","255");var u=document.createElement("div");u.appendChild(h),u.appendChild(d),i.appendChild(u);var p=i.querySelector(".redRange"),g=i.querySelector(".greenRange"),f=i.querySelector(".blueRange"),m=null;if(p.addEventListener("input",(function(){var i="#"+((1<<24)+(Number(p.value)<<16)+(Number(g.value)<<8)+Number(f.value)).toString(16).slice(1);if(e){var n=Number(m.value);t.setColor(i,n)}else t.setColor(i)})),g.addEventListener("input",(function(){var i="#"+((1<<24)+(Number(p.value)<<16)+(Number(g.value)<<8)+Number(f.value)).toString(16).slice(1);if(e){var n=Number(m.value);t.setColor(i,n)}else t.setColor(i)})),f.addEventListener("input",(function(){var i="#"+((1<<24)+(Number(p.value)<<16)+(Number(g.value)<<8)+Number(f.value)).toString(16).slice(1);if(e){var n=Number(m.value);t.setColor(i,n)}else t.setColor(i)})),e){var A=document.createElement("span");A.innerHTML="透明度 : ",A.style.color="#FFFFFF";var y=document.createElement("input");y.type="range",y.className="opacityRange",y.style.cssText+="width:97px;background:linear-gradient(#FFFFFF, #FFFFFF) no-repeat, #FFFFFF;",y.setAttribute("step","0.01"),y.setAttribute("min","0"),y.setAttribute("max","1"),y.setAttribute("value","1");var v=document.createElement("div");v.appendChild(A),v.appendChild(y),i.appendChild(v),(m=i.querySelector(".opacityRange")).addEventListener("input",(function(){var e="#"+((1<<24)+(Number(p.value)<<16)+(Number(g.value)<<8)+Number(f.value)).toString(16).slice(1),i=Number(m.value);t.setColor(e,i)}))}return i},createColorCode:function(){var e=this,t=document.createElement("div");t.style.cssText+="width:180px;margin-left:10px;";var i=document.createElement("input");i.className="colorCode",i.type="text",i.style.cssText+="display:block;float:left;width:110px;margin:10px 10px 10px 0;padding-left:3px;",i.value="#ffffff",t.appendChild(i);var n=document.createElement("span");return n.className="colorCodeBtn",n.style.cssText+="display:block;float:left;width:38px;height:21px;border-radius:5px;margin-top:10px;background-color:#FFFFFF;font-size:13px;text-align:center;line-height:21px;cursor:default;",n.innerHTML="HEX",n.addEventListener("click",(function(t){var i=t.target.textContent,n=e.element.querySelector(".colorCode").value;if(e.element.querySelector(".opacityRange"))var r=Number(e.element.querySelector(".opacityRange").value);"HEX"===i?t.target.innerHTML="RGB":"RGB"===i&&(t.target.innerHTML="HEX"),e.setColor(n,r)})),t.appendChild(n),t},colorRgbToHex:function(e){if(e){var t=(e=e.toLowerCase()).replace(/rgba?\(/,"").replace(/\)/,"").replace(/[\s+]/g,"").split(","),i=parseFloat(t[3]||1),n=Math.floor(i*parseInt(t[0],0)+255*(1-i)),r=Math.floor(i*parseInt(t[1],0)+255*(1-i)),o=Math.floor(i*parseInt(t[2],0)+255*(1-i));return"#"+("0"+n.toString(16)).slice(-2)+("0"+r.toString(16)).slice(-2)+("0"+o.toString(16)).slice(-2)}return e},colorHexToRgb:function(e,t){var i=e.toLowerCase();if(i&&/^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/.test(i)){if(4===i.length){for(var n="#",r=1;4>r;r+=1)n+=i.slice(r,r+1).concat(i.slice(r,r+1));i=n}for(var o=[],a=1;7>a;a+=2)o.push(parseInt("0x"+i.slice(a,a+2),0));if(!isNaN(t)){var s=Number(t);return 0>s||s>1?i:"rgba("+o.join(",")+","+s+")"}return"rgb("+o.join(",")+")"}return i},checkColor:function(e){var t={};if(e){var i=e.toLowerCase();i&&/^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/.test(i)?(t.color=!0,t.hex=!0,t.rgb=!1,t.hsl=!1,t.hexLength=4===i.length?3:6):i&&/^rgb/.test(i)?(t.color=!0,t.hex=!1,t.rgb=!0,t.hsl=!1):i&&/^hsl/.test(i)?(t.color=!0,t.hex=!1,t.rgb=!1,t.hsl=!0):(t.color=!1,t.hex=!1,t.rgb=!1,t.hsl=!1)}else t.color=!1,t.hex=!1,t.rgb=!1,t.hsl=!1;return t},setColor:function(e,t){var i=this,n=i.defaultSetting;if(n.picker||n.colorCode){var r=i.checkColor(e);if(r.color){var o="",a="",s=e.toLowerCase();if(r.hex){if(3===r.hexLength){for(var l="#",c=1;4>c;c+=1)l+=s.slice(c,c+1).concat(s.slice(c,c+1));s=l}a=s,o=i.colorHexToRgb(e,t)}else r.rgb&&(a=i.colorRgbToHex(e),o=s);if(o){if(n.picker){ag.css(i.element.querySelector(".colorShow"),{"background-color":o});var h=i.getRgbNumber(a);3===h.length&&(i.element.querySelector(".redRange").value=h[0],i.element.querySelector(".greenRange").value=h[1],i.element.querySelector(".blueRange").value=h[2],t&&(i.element.querySelector(".opacityRange").value=t))}if(n.colorCode){var d=i.element.querySelector(".colorCode");d.value=a;var u=i.element.querySelector(".colorCodeBtn").textContent;"HEX"===u?d.value=a:"RGB"===u&&(d.value=o)}i.colorInputDom.value=o,ag.simulateEvent(i.colorInputDom,"change")}}}},getRgbNumber:function(e){var t=[],i=this.checkColor(e);if(i.color){var n=e.toLowerCase();if(i.hex){if(3===i.hexLength){for(var r="#",o=1;4>o;o+=1)r+=n.slice(o,o+1).concat(n.slice(o,o+1));n=r}for(var a=1;7>a;a+=2)t.push(parseInt("0x"+n.slice(a,a+2),0))}}return t}};var JD={};JD.fullScreen=function(e){if(!e)return!1;if(e.requestFullscreen)e.requestFullscreen();else if(e.mozRequestFullScreen)e.mozRequestFullScreen();else if(e.webkitRequestFullscreen)e.webkitRequestFullscreen();else{if(!e.msRequestFullscreen)return!1;e.msRequestFullscreen()}},JD.exitFullScreen=function(){document.exitFullscreen?document.exitFullscreen():document.mozCancelFullScreen?document.mozCancelFullScreen():document.webkitCancelFullScreen?document.webkitCancelFullScreen():document.msExitFullscreen&&document.msExitFullscreen()},JD.onFullScreenChanged=function(e){var t=function(){e&&e()};document.onfullscreenchange=t,document.onwebkitfullscreenchange=t,document.documentElement.onwebkitfullscreenchange=t,document.onmozfullscreenchange=t,document.onmsfullscreenchange=t},JD.inFullScreen=function(){return"webkitIsFullScreen"in document?Boolean(document.webkitIsFullScreen):"fullscreenElement"in document?Boolean(document.fullscreenElement):"mozFullScreenElement"in document?Boolean(document.mozFullScreenElement):"msFullscreenElement"in document?Boolean(document.msFullscreenElement):Boolean(document.querySelector(".viewer-fill-browser"))},JD.findFullScreenElement=function(){return document.fullscreenElement||document.mozFullScreenElement||document.webkitFullscreenElement||document.msFullscreenElement},JD.isFullScreenAvailable=function(e){return e.requestFullscreen||e.mozRequestFullScreen||e.webkitRequestFullscreen||e.msRequestFullscreen};var zD=JD,qD=function(e,t){this.coordinateSystem=e,this.viewer=e.viewer,this.drawingImpl=t,this.viewportOffset=this.viewer.domElement.getBoundingClientRect(),this.cameraControl=this.viewer.cameraControl,this.fillClipPlane=this.viewer.getScene().getFillClipPlane(),this.initialize()};qD.prototype.initialize=function(){this.arrowMouseDown=!1,this.circleXMouseDown=!1,this.circleYMouseDown=!1,this.firstClickDown=!0,this.firstRotate=!0,this.lineOut=!0,this.arrowOut=!0,this.translateStartPt=new ke,this.translateEndPt=new ke,this.rotateAngleA=0,this.rotateAngleB=0,this.config=this.coordinateSystem.config},qD.prototype.registerArrowEvents=function(){var e=this.drawingImpl.getDrawable("axisZ"),t=this,i=this.config.colors;e.onmouseover=function(){!0!==t.circleXMouseDown&&!0!==t.circleYMouseDown&&(t.drawingImpl.setColor("axisZ",i.highLight),t.drawingImpl.fill("arrow",i.highLight),t.drawingImpl.setColor("tipArcX",i.default),t.drawingImpl.fill("cubeX",i.default),t.drawingImpl.setColor("tipArcY",i.default),t.drawingImpl.fill("cubeY",i.default),t.lineOut=!1)},e.onmouseout=function(){!0!==t.circleXMouseDown&&!0!==t.circleYMouseDown&&!1===t.arrowMouseDown&&!0===t.arrowOut&&(t.drawingImpl.setColor("axisZ",i.arrow),t.drawingImpl.fill("arrow",i.arrow),t.drawingImpl.setColor("tipArcX",i.tipArcX),t.drawingImpl.fill("cubeX",i.cubeX),t.drawingImpl.setColor("tipArcY",i.tipArcY),t.drawingImpl.fill("cubeY",i.cubeY),t.lineOut=!0)},e.onmousedown=function(e){t.arrowMouseDown=!0,t.lineOut=!1;var i=t.config.colors;t.drawingImpl.setColor("axisZ",i.highLight),t.drawingImpl.fill("arrow",i.highLight),t.coordinateSystem.colorUpdate=!1,t.translateStartPt.set(e.clientX,e.clientY)};var n=this.drawingImpl.getDrawable("arrow");n.onmouseover=function(){if(!0!==t.circleXMouseDown&&!0!==t.circleYMouseDown){t.arrowOut=!1;var e=t.config.colors;t.drawingImpl.fill("arrow",e.highLight),t.drawingImpl.setColor("axisZ",e.highLight),t.drawingImpl.setColor("tipArcX",e.default),t.drawingImpl.fill("cubeX",e.default),t.drawingImpl.setColor("tipArcY",e.default),t.drawingImpl.fill("cubeY",e.default)}},n.onmouseout=function(){if(!0!==t.circleXMouseDown&&!0!==t.circleYMouseDown&&!1===t.arrowMouseDown&&!0===t.lineOut){t.arrowOut=!0;var e=t.config.colors;t.drawingImpl.setColor("axisZ",e.arrow),t.drawingImpl.fill("arrow",e.arrow),t.drawingImpl.setColor("tipArcX",e.tipArcX),t.drawingImpl.fill("cubeX",e.cubeX),t.drawingImpl.setColor("tipArcY",e.tipArcY),t.drawingImpl.fill("cubeY",e.cubeY)}},n.onmousedown=function(e){t.arrowMouseDown=!0,t.arrowOut=!1;var i=t.config.colors;t.drawingImpl.setColor("axisZ",i.highLight),t.drawingImpl.fill("arrow",i.highLight),t.translateStartPt.set(e.clientX,e.clientY)},document.onmousemove=function(e){if(!0===t.arrowMouseDown){if(!(e.clientX===t.translateStartPt.x&&e.clientY===t.translateStartPt.y)){var i=t.fillClipPlane.renderClipPlane,n=i.normal.clone();n.w=i.constant;var r=t.cameraControl.movePlane(n,e,t.translateStartPt,!1,t.fillClipPlane.position.clone());null!==r&&t.fillClipPlane.offset(r),t.translateStartPt.set(e.clientX,e.clientY),t.cameraControl.update(!0)}t.coordinateSystem.update();var o=t.config.colors;t.drawingImpl.setColor("axisZ",o.highLight),t.drawingImpl.fill("arrow",o.highLight),t.drawingImpl.setColor("tipArcX",o.default),t.drawingImpl.fill("cubeX",o.default),t.drawingImpl.setColor("tipArcY",o.default),t.drawingImpl.fill("cubeY",o.default),e.preventDefault(),e.stopPropagation()}},document.onmouseup=function(){if(!1!==t.arrowMouseDown){t.arrowMouseDown=!1,t.coordinateSystem.colorUpdate=!0;var e=t.config.colors;t.drawingImpl.setColor("axisZ",e.arrow),t.drawingImpl.fill("arrow",e.arrow),t.drawingImpl.setColor("tipArcX",e.tipArcX),t.drawingImpl.fill("cubeX",e.cubeX),t.drawingImpl.setColor("tipArcY",e.tipArcY),t.drawingImpl.fill("cubeY",e.cubeY),xd.ClippingCaps=!0,t.viewer.render()}}},qD.prototype.registerCircleXEvents=function(){var e=this,t=this.config.colors,i=this.drawingImpl.getDrawable("tipArcX");i.onmousedown=function(){e.circleXMouseDown=!0,e.drawingImpl.setColor("axisZ",t.default),e.drawingImpl.fill("arrow",t.default),e.enableCircleXMovement()},i.onmouseout=function(){!1===e.circleXMouseDown&&(e.drawingImpl.setColor("axisZ",t.arrow),e.drawingImpl.fill("arrow",t.arrow),e.drawingImpl.setColor("tipArcY",t.tipArcY),e.drawingImpl.fill("cubeY",t.cubeY),e.coordinateSystem.circleToArc("tipArcX"))},document.addEventListener("mouseup",(function(){!0===e.circleXMouseDown&&(xd.ClippingCaps=!0,e.viewer.render()),e.circleXMouseDown=!1,e.firstClickDown=!0,e.firstRotate=!1,e.lastRotateX=0,e.lastRotateY=0,e.drawingImpl.show("tipArcY",!0),e.drawingImpl.show("axisY",!0),e.drawingImpl.show("axisZ",!0),e.drawingImpl.show("cubeY",!0),e.coordinateSystem.update(),e.drawingImpl.show("dashLineX",!1),e.drawingImpl.setColor("axisZ",t.arrow),e.drawingImpl.fill("arrow",t.arrow)}))},qD.prototype.registerCircleYEvents=function(){var e=this,t=this.config.colors,i=this.drawingImpl.getDrawable("tipArcY");i.onmousedown=function(){e.circleYMouseDown=!0,e.drawingImpl.setColor("axisZ",t.default),e.drawingImpl.fill("arrow",t.default),e.enableCircleYMovement()},i.onmouseout=function(){!1===e.circleYMouseDown&&(e.drawingImpl.setColor("axisZ",t.arrow),e.drawingImpl.fill("arrow",t.arrow),e.coordinateSystem.circleToArc("tipArcY"),e.drawingImpl.setColor("tipArcX",t.tipArcX),e.drawingImpl.fill("cubeX",t.cubeX))},document.addEventListener("mouseup",(function(){!0===e.circleYMouseDown&&(xd.ClippingCaps=!0,e.viewer.render()),e.circleYMouseDown=!1,e.drawingImpl.show("tipArcX",!0),e.drawingImpl.show("cubeX",!0),e.coordinateSystem.update(),e.drawingImpl.show("dashLineY",!1),e.drawingImpl.setColor("axisZ",t.arrow),e.drawingImpl.fill("arrow",t.arrow)}))},qD.prototype.enableCircleXMovement=function(){var e=this,t=this.config.colors;document.addEventListener("mousemove",(function(i){if(!0===e.circleXMouseDown){e.drawingImpl.show("dashLineX",!0),e.drawingImpl.setColor("axisZ",t.default),e.drawingImpl.fill("arrow",t.default),xd.ClippingCaps=!1;var n=e.fillClipPlane.normalIndex,r=e.viewportOffset,o=new ke(i.clientX-r.left,i.clientY-r.top),a=e.calcRotateAngleIndex(o,e.coordinateSystem.discretePointsX);!0===e.firstClickDown&&(e.lastIndex=a);var s=2*(a-e.lastIndex);n>3&&(s=-s),e.drawingImpl.show("tipArcY",!1),e.coordinateSystem.updateAxisZ();var l=e.fillClipPlane.renderClipPlane.normal.clone(),c=e.coordinateSystem.getCoordinateAxis(),h=e.config.styles;e.coordinateSystem.drawClipPlaneCircle("tipArcZ",c.start.clone(),h.auxCircleRadius,e.coordinateSystem.dirX,l);var d=e.coordinateSystem.drawingToCanvas(c.start.clone()),u=e.coordinateSystem.drawingToCanvas(c.endY.clone());e.coordinateSystem.drawAxisY(d,u,t.highLight),e.coordinateSystem.drawCubeX("cubeX",u,h.cubeRadius),e.drawingImpl.show("cubeY",!1);var p="x";2>n&&(p="y"),e.fillClipPlane.rotateAngleOffset(s,p),e.coordinateSystem.backwardCoordinate(),!0===e.firstClickDown?e.firstClickDown=!1:e.lastIndex=a,e.translateStartPt.set(i.clientX,i.clientY),e.viewer.render(),i.preventDefault(),i.stopPropagation()}}))},qD.prototype.enableCircleYMovement=function(){var e=this,t=this.config.colors;document.addEventListener("mousemove",(function(i){if(!0===e.circleYMouseDown){e.drawingImpl.show("dashLineY",!0),e.drawingImpl.setColor("axisZ",t.default),e.drawingImpl.fill("arrow",t.default),xd.ClippingCaps=!1;var n=e.fillClipPlane.normalIndex,r=e.viewportOffset,o=new ke(i.clientX-r.left,i.clientY-r.top),a=e.calcRotateAngleIndex(o,e.coordinateSystem.discretePointsY);!0===e.firstClickDown&&(e.lastIndex=a);var s=2*(a-e.lastIndex);n>3&&(s=-s),e.drawingImpl.show("tipArcX",!1),e.coordinateSystem.updateAxisZ();var l=e.fillClipPlane.renderClipPlane.normal.clone(),c=e.coordinateSystem.getCoordinateAxis(),h=e.config.styles;e.coordinateSystem.drawClipPlaneCircle("tipArcZ",c.start.clone(),h.auxCircleRadius,e.coordinateSystem.dirX.clone(),l.clone());var d=e.coordinateSystem.drawingToCanvas(c.start.clone()),u=e.coordinateSystem.drawingToCanvas(c.endX.clone());e.coordinateSystem.drawAxisX(d,u,t.highLight),e.coordinateSystem.drawCubeY("cubeY",u,h.cubeRadius),e.drawingImpl.show("cubeX",!1);var p="z";n>3&&(p="y"),e.fillClipPlane.rotateAngleOffset(s,p),e.coordinateSystem.backwardCoordinate(),!0===e.firstClickDown?e.firstClickDown=!1:e.lastIndex=a,e.translateStartPt.set(i.clientX,i.clientY),e.viewer.render(),i.preventDefault(),i.stopPropagation()}}))},qD.prototype.registerTipArcXEvents=function(){var e=this,t=this.config.colors,i=this.drawingImpl.getDrawable("tipArcX");i.onmouseover=function(){!1===e.circleYMouseDown&&(e.coordinateSystem.arcToCircle("tipArcX"),e.drawingImpl.setColor("tipArcY",t.default),e.drawingImpl.fill("cubeY",t.default),e.drawingImpl.setColor("axisZ",t.default),e.drawingImpl.fill("arrow",t.default),e.registerCircleXEvents())},i.onmouseout=function(){!1===e.circleXMouseDown&&e.coordinateSystem.circleToArc("tipArcX")}},qD.prototype.registerTipArcYEvents=function(){var e=this,t=this.config.colors,i=this.drawingImpl.getDrawable("tipArcY");i.onmouseover=function(){!1===e.circleXMouseDown&&(e.coordinateSystem.arcToCircle("tipArcY"),e.drawingImpl.setColor("tipArcX",t.default),e.drawingImpl.fill("cubeX",t.default),e.drawingImpl.setColor("axisZ",t.default),e.drawingImpl.fill("arrow",t.default),e.registerCircleYEvents())},i.onmouseout=function(){!1===e.circleYMouseDown&&e.coordinateSystem.circleToArc("tipArcY")}},qD.prototype.calcRotateAngleIndex=function(e,t){for(var i=this.createLine(e,this.coordinateSystem.cOrigin),n=-1,r=Number.POSITIVE_INFINITY,o=0;90>o;o+=1){var a=t[o].clone(),s=this.disPointToLine(a,i);r>s&&(r=s,n=o)}var l=90+n,c=t[n].clone().distanceTo(e);return t[l].clone().distanceTo(e)>c?n:l},qD.prototype.createLine=function(e,t){var i={};if(e.x===t.x)i.A=1,i.B=0,i.C=-e.x;else{var n=(t.y-e.y)/(t.x-e.x),r=t.y-n*t.x;i.A=n,i.B=-1,i.C=r}return i},qD.prototype.disPointToLine=function(e,t){return Math.abs(t.A*e.x+t.B*e.y+t.C)/Math.sqrt(t.A*t.A+t.B*t.B)};var ZD=function(){return{colors:{tipArcX:"#0000FF",cubeX:"#0000FF",tipArcY:"#FF0000",cubeY:"#FF0000",highLight:"#FFFF00",tipLine:"#4dc0ff",arrow:"#4dc0ff",default:"#A9A9A9"},styles:{dashArray:"10 8",originRadius:5,auxCircleRadius:.1,tipLineLength:.1,cubeRadius:5,axisXWidth:2,axisYWidth:2,axisZWidth:3,axisXLength:.1,axisYLength:.1,axisZLength:.14,segments:180,tipArcLeftCounts:45,tipArcRightCounts:45}}},XD=function(e,t){this.coordinateSystem=e,this.viewer=t,this.container=this.viewer.domElement.querySelector("div:first-child"),this.mapDrawables={},this.initialize()};XD.prototype.initialize=function(){this.xmlns="http://www.w3.org/2000/svg";var e=document.createElement("div");e.style.left="0px",e.style.top="0px",e.style.width=this.container.offsetWidth+"px",e.style.height=this.container.offsetHeight+"px",e.style.position="absolute",this.group=document.createElementNS(this.xmlns,"svg"),this.group.setAttribute("width",String(this.container.offsetWidth)),this.group.setAttribute("height",String(this.container.offsetHeight)),e.appendChild(this.group),this.container.appendChild(e)},XD.prototype.makeCircle=function(e,t){var i=this.mapDrawables;void 0===i[e]&&(i[e]=document.createElementNS(this.xmlns,"circle"),this.group.appendChild(i[e]));var n=i[e];n.style.fill=t.color||"#FF0000",n.setAttribute("r",String(t.radius)),n.setAttribute("transform","translate("+t.center.x+","+t.center.y+")")},XD.prototype.show=function(e,t){var i=this.getDrawable(e);i&&(i.style.display=t?"block":"none")},XD.prototype.fill=function(e,t){this.getDrawable(e).style.fill=t?"block":"none"},XD.prototype.makeLine=function(e,t){var i=this.mapDrawables;void 0===i[e]&&(i[e]=document.createElementNS(this.xmlns,"line"),this.group.appendChild(i[e]));var n=i[e];n.setAttribute("stroke",t.color||"#000000"),n.setAttribute("stroke-width",t.width||3),n.setAttribute("x1",String(t.start.x)),n.setAttribute("y1",String(t.start.y)),n.setAttribute("x2",String(t.end.x)),n.setAttribute("y2",String(t.end.y))},XD.prototype.makeDashLine=function(e,t){this.makeLine(e,t),this.mapDrawables[e].setAttribute("stroke-dasharray",t.dashArray)},XD.prototype.makePolyline=function(e,t){var i=null,n=this.mapDrawables;void 0===n[e]&&(n[e]=document.createElementNS(this.xmlns,"polyline"),this.group.appendChild(n[e])),(i=n[e]).setAttribute("stroke",t.color||"#A9A9A9"),i.setAttribute("stroke-width",t.width||3),i.style.fill="none",i.setAttribute("points",t.points)},XD.prototype.makeDefs=function(e){var t=this.mapDrawables;void 0===t[e]&&(t[e]=document.createElementNS(this.xmlns,"defs"),void 0===t.marker&&(t.marker=this.makeMarker(),t[e].appendChild(t.marker)),this.group.appendChild(t[e]))},XD.prototype.makeMarker=function(){var e=document.createElementNS(this.xmlns,"marker");e.setAttribute("id","arrow"),e.setAttribute("viewBox","0 0 10 10"),e.setAttribute("refX","5"),e.setAttribute("refY","5"),e.setAttribute("markerWidth","6"),e.setAttribute("markerHeight","6"),e.setAttribute("orient","auto-start-reverse");var t=document.createElementNS(this.xmlns,"path");return t.setAttribute("d","M 0 0 L 10 5 L 0 10 z"),t.style.fill="#11DAB7",this.mapDrawables.arrow=t,e.appendChild(t),e},XD.prototype.getDrawable=function(e){return this.mapDrawables[e]},XD.prototype.attach=function(){this.getDrawable("axisZ").setAttribute("marker-end","url(#arrow)")},XD.prototype.setColor=function(e,t){this.getDrawable(e).setAttribute("stroke",t)},XD.prototype.fill=function(e,t){this.getDrawable(e).style.fill=t},XD.prototype.hideAll=function(e){this.group.style.display=!0===e?"none":"block"},XD.prototype.destroy=function(){for(var e=this.group.children,t=0;e.length>t;t+=1)this.group.removeChild(e[t]);this.group.parentNode.removeChild(this.group)};var _D=function(e){this.viewer=e,this.enable=!0,this.cameraControl=e.cameraControl,this.fillClipPlane=e.getScene().getFillClipPlane(),this.container=e.domElement.querySelector("div:first-child"),this.config=new ZD,this.drawingImpl=new XD(this,e),this.coordinateAction=new qD(this,this.drawingImpl),this.initialize()};_D.prototype.initialize=function(){this.enable=!0,this.boundingBox=new vh,this.bRegisterArrowEvent=!1,this.bRegisterAuxCircleEvent=!1,this.mapDrawableName={ORIGIN:"origin",AXISX:"axisX",AXISY:"axisY",CUBEX:"cubeX",CUBEY:"cubeY",AXISZ:"axisZ",ARROW:"arrow",DASHLINE:"dashLine",TIPARC_X:"tipArcX",TIPARC_Y:"tipArcY",TIPARC_Z:"tipArcZ",DASHLINE_X:"dashLineX",DASHLINE_Y:"dashLineY"}},_D.prototype.saveTransform=function(e){this.savedCamera=e.clone()},_D.prototype.drawingToCanvas=function(e){var t=Zp.drawingToCanvas(this.cameraControl.camera,e,this.container.offsetWidth,this.container.offsetHeight);return new ke(t.x,t.y)},_D.prototype.getCoordinateAxis=function(){var e=this.fillClipPlane.renderClipPlane.normal.clone(),t=this.fillClipPlane.getCoordinate(),i=t.axisY.clone(),n=e.clone().cross(i.clone());this.fillClipPlane.normalIndex>3&&(i=(n=t.axisX.clone()).clone().cross(e.clone()));var r=this.config.styles,o=this.fillClipPlane.position.clone(),a=this.cameraControl.getCamera().position.clone().sub(o).length(),s=o.clone().add(n.clone().multiplyScalar(r.axisXLength*a)),l=o.clone().add(i.clone().multiplyScalar(r.axisYLength*a)),c=o.clone().add(e.clone().multiplyScalar(r.axisZLength*a));return this.dirX=n,this.dirY=i,{start:o,endX:s,endY:l,endZ:c}},_D.prototype.drawOrigin=function(e,t){this.drawingImpl.makeCircle(this.mapDrawableName.ORIGIN,{center:e,radius:t,color:this.config.colors.default})},_D.prototype.drawAxisX=function(e,t,i){this.drawingImpl.makeLine(this.mapDrawableName.AXISX,{start:e,end:t,width:this.config.styles.axisXWidth,color:i||this.config.colors.default})},_D.prototype.drawAxisY=function(e,t,i){var n=this.config;this.drawingImpl.makeLine(this.mapDrawableName.AXISY,{start:e,end:t,width:n.styles.axisYWidth,color:i||n.colors.default})},_D.prototype.drawAxisZ=function(e,t){var i=this.config;this.drawingImpl.makeLine(this.mapDrawableName.AXISZ,{start:e,end:t,width:i.styles.axisZWidth,color:i.colors.arrow}),this.drawingImpl.attach(),!1===this.bRegisterArrowEvent&&(this.coordinateAction.registerArrowEvents(),this.bRegisterArrowEvent=!0)},_D.prototype.updateAxisZ=function(){var e=this.getCoordinateAxis(),t=this.drawingToCanvas(e.start.clone()),i=this.drawingToCanvas(e.endZ.clone());this.drawingImpl.makeLine(this.mapDrawableName.AXISZ,{start:t,end:i,color:this.config.colors.default})},_D.prototype.drawArrow=function(e,t){var i=this.mapDrawableName;this.drawingImpl.makeLine(i.AXISZ,{start:e,end:t}),this.drawingImpl.attach(),this.drawingImpl.setColor(i.AXISZ,this.config.colors.default),!1===this.bRegisterArrowEvent&&(this.coordinateAction.registerArrowEvents(),this.bRegisterArrowEvent=!0)},_D.prototype.drawClipPlaneCircle=function(e,t,i,n,r){for(var o={center:t.clone(),radius:i,normal:n.clone(),rotateAxis:r.clone()},a=this.config.styles.segments,s=this.discreteCircle(o,a),l="",c=0;a>c;c+=1)l+=s[c].x+","+s[c].y,l+=" ";l+=s[0].x+","+s[0].y,this.drawingImpl.makePolyline(e,{points:l+=" ",color:this.config.colors.default,width:2})},_D.prototype.drawTipArc=function(e,t,i,n,r){var o={center:t.clone(),radius:i,normal:n.clone(),rotateAxis:r.clone()},a=this.config.styles,s=a.tipArcRightCounts,l=a.tipArcLeftCounts,c=a.segments,h=this.discreteCircle(o,c);e===this.mapDrawableName.TIPARC_X?(this.discretePointsX=h,s=a.tipArcLeftCounts,l=a.tipArcRightCounts):this.discretePointsY=h;for(var d="",u=c-s-1;c>u;u+=1)d+=h[u].x+","+h[u].y,d+=" ";for(var p=0;l>=p;p+=1)d+=h[p].x+","+h[p].y,d+=" ";var g={points:d,color:this.config.colors.tipArcX};e===this.mapDrawableName.TIPARC_X?(this.drawingImpl.makePolyline(e,g),this.coordinateAction.registerTipArcXEvents()):e===this.mapDrawableName.TIPARC_Y&&(g.color=this.config.colors.tipArcY,this.drawingImpl.makePolyline(e,g),this.coordinateAction.registerTipArcYEvents())},_D.prototype.drawTipLine=function(e,t,i){var n=this.drawingToCanvas(t.clone()),r=this.drawingToCanvas(i.clone()),o=this.config;this.drawingImpl.makeDashLine(e,{start:n,end:r,color:o.colors.tipLine,dashArray:o.styles.dashArray}),this.drawingImpl.show(e,!1)},_D.prototype.drawCubeX=function(e,t,i){this.drawingImpl.makeCircle(e,{center:t,radius:i,color:this.config.colors.cubeX})},_D.prototype.drawCubeY=function(e,t,i,n){this.drawingImpl.makeCircle(e,{center:t,radius:i,color:n||this.config.colors.cubeY})},_D.prototype.discreteCircle=function(e,t){for(var i=e.center.clone(),n=e.radius,r=e.rotateAxis.clone(),o=e.normal.clone(),a=[],s=0;t>s;s+=1){o.applyAxisAngle(r,2*Math.PI/t);var l=i.clone().add(o.clone().multiplyScalar(n)),c=this.drawingToCanvas(l.clone());a.push(c)}return a},_D.prototype.arcToCircle=function(e){var t="",i=this.discretePointsX;e===this.mapDrawableName.TIPARC_Y&&(i=this.discretePointsY);for(var n=0,r=i.length;r>n;n+=1)t+=i[n].x+","+i[n].y,t+=" ";t+=i[0].x+","+i[0].y,this.drawingImpl.makePolyline(e,{points:t+=" ",color:this.config.colors.highLight})},_D.prototype.circleToArc=function(e){var t=this.config.styles,i=t.tipArcLeftCounts,n=t.tipArcRightCounts,r=t.segments,o=this.discretePointsX,a={color:this.config.colors.tipArcX};e===this.mapDrawableName.TIPARC_Y&&(o=this.discretePointsY,a.color=this.config.colors.tipArcY,i=t.tipArcRightCounts,n=t.tipArcLeftCounts);for(var s="",l=r-i-1;r>l;l+=1)s+=o[l].x+","+o[l].y,s+=" ";for(var c=0;n>=c;c+=1)s+=o[c].x+","+o[c].y,s+=" ";a.points=s,this.drawingImpl.makePolyline(e,a)},_D.prototype.update=function(){if(this.enable){var e=this.fillClipPlane.position.clone(),t=this.cameraControl.getCamera().position.clone().sub(e).length(),i=this.getCoordinateAxis(),n=this.drawingToCanvas(i.start.clone()),r=this.drawingToCanvas(i.endX.clone()),o=this.drawingToCanvas(i.endY.clone()),a=this.drawingToCanvas(i.endZ.clone());void 0===this.createRefs&&(this.drawingImpl.makeDefs("refs"),this.createRefs=!0),this.cOrigin=n.clone(),this.drawAxisZ(n,a),this.drawAxisX(n,r),this.drawAxisY(n,o);var s=this.config.styles,l=this.mapDrawableName,c=this.fillClipPlane.renderClipPlane.normal.clone();this.drawClipPlaneCircle(l.TIPARC_Z,i.start.clone(),s.auxCircleRadius*t,this.dirX,c),this.drawTipArc(l.TIPARC_X,i.start.clone(),s.auxCircleRadius*t,c,this.dirX),this.drawTipArc(l.TIPARC_Y,i.start.clone(),s.auxCircleRadius*t,c,this.dirY);var h=i.start.clone().add(this.dirX.clone().multiplyScalar(s.tipLineLength*t)),d=i.start.clone().sub(this.dirX.clone().multiplyScalar(s.tipLineLength*t));this.drawTipLine(l.DASHLINE_X,h,d);var u=i.start.clone().add(this.dirY.clone().multiplyScalar(s.tipLineLength*t)),p=i.start.clone().sub(this.dirY.clone().multiplyScalar(s.tipLineLength*t));this.drawTipLine(l.DASHLINE_Y,u,p),this.drawOrigin(n,s.originRadius);var g=this.discretePointsX[44].clone();this.drawCubeX(l.CUBEX,g,s.cubeRadius);var f=this.discretePointsY[134].clone();this.drawCubeY(l.CUBEY,f,s.cubeRadius),this.updateBbox()}else this.hide(!0)},_D.prototype.hide=function(e){this.drawingImpl.hideAll(e)},_D.prototype.enabled=function(e){this.enable=e},_D.prototype.destroy=function(){this.drawingImpl.destroy()},_D.prototype.updateBbox=function(){this.boundingBox.makeEmpty();for(var e=0;this.discretePointsX.length>e;e+=1){var t=this.discretePointsX[e].clone();this.boundingBox.expandByPoint(t)}for(e=0;this.discretePointsY.length>e;e+=1){t=this.discretePointsY[e].clone();this.boundingBox.expandByPoint(t)}var i=this.getCoordinateAxis(),n=this.drawingToCanvas(i.start.clone()),r=this.drawingToCanvas(i.endZ.clone());this.boundingBox.expandByPoint(n),this.boundingBox.expandByPoint(r),this.boundingBox.expandByScalar(5)},_D.prototype.insideBoundingBox=function(e){return this.boundingBox.containsPoint(e.clone())},_D.prototype.backwardCoordinate=function(){var e=this.cameraControl.camera.position,t=this.cameraControl.camera.target.clone().sub(e.clone()).normalize(),i=this.fillClipPlane.renderClipPlane.normal.clone();t.angleTo(i)};var $D={Forward:0,Reverse:1},eT={X:0,Y:4,Z:2},tT=function(e){var t=this,i=e.viewer;if(i){if(i._sectionBox&&i._sectionBox.exit(),i._sectionPlane)return i._sectionPlane;i._sectionPlane=this,t.id=e.id,t._opt=e,t.mode=e.mode,t._plane=e.plane,t._direction=e.direction,t._progress=e.progress,t.init(),t.setPlane(e.plane)}else Bu.log("domElement must not be empty.")};tT.prototype={init:function(){this.enableCoordinate=!og.isMobileDevice();var e=this._opt.viewer.getViewerImpl();this.coordinateSystem=new _D(e),e.controlManager.enableTool(e,Yd.CLIP_FILL),this._sectionTool=e.getScene().getFillClipPlane(),this._sectionTool.enable(!0,!0),this.hookEvens()},hookEvens:function(){var e=this,t=this.coordinateSystem,i=this._opt.viewer.getViewerImpl();i.getDomElement(),i.registerEventListener(Fd.ON_CLIP_HOVER,(function(i){if(!1!==e.enableCoordinate)if(i.onClipPlane)t.enable&&(t.update(),t.hide(!1));else{var n=new ke(i.event.clientX,i.event.clientY);t.insideBoundingBox(n)?t.hide(!1):t.hide(!0)}})),i.registerEventListener(Fd.ON_CLIP_MOUSE_DOWN,(function(e){})),i.registerEventListener(Fd.ON_CLIP_MOUSE_MOVE,(function(e){t.update()})),i.registerDomEventListener(Fd.ON_CONTROL_ZOOM,(function(e){t.update()}))},exit:function(){var e=this._opt.viewer.getViewerImpl(),t=e.getScene().getFillClipPlane();e.controlManager.disableTool(Yd.CLIP_FILL),t.enable(!1,!1),this.coordinateSystem.destroy(),this._sectionTool=null,this._opt.viewer._sectionPlane=null},setProgress:function(e){var t=1-e/50;this._progress=e,this._sectionTool.setProcess(t)},getProgress:function(){return 50*(1-this._sectionTool.getProcess())},setPlane:function(e){var t=$D[this._direction]+eT[e];this._plane=e,this._sectionTool.changeNormal(t),this.setProgress(this._opt.progress)},getPlane:function(){return this._plane},setDirection:function(e){var t=$D[e]+eT[this._plane];this._direction=e,this._sectionTool.changeNormal(t),this.setProgress(this._opt.progress)},getDirection:function(){return this._direction},setRotateAngle:function(e,t){this._sectionTool.setRotateAngle(e,t)},getRotateAngle:function(){return this._sectionTool.getRotateAngle()},hidePlane:function(){this._sectionTool.visible=!1,this.enableCoordinate=!1,this.coordinateSystem.hide(!0)},showPlane:function(){this._sectionTool.visible=!0,this.enableCoordinate=!0},reset:function(){var e=this;e.setPlane(e._opt.plane),e.setDirection(e._opt.direction),e.setProgress(e._opt.progress)},getState:function(){return this._sectionTool.store()},setState:function(e){this._sectionTool.restore(e)}};var iT=function(){};iT.prototype=wp.extend(!0,{},hg.prototype,{init:function(e){this.marks={},this.allOids=[],this.components={},this.SelectedMark={},this.mouse=new ke,this.lastX=0,this.lastY=0,this.active=!0,this.viewer=e,this.viewerImpl=e.getViewerImpl()},addObjectToScene:function(e,t){e&&e.id&&t&&(this.viewer.addExternalObject(e.id,t),this.components[e.id]=t,this.allOids.push(e.id),this.marks[e.id]=e)},enabled:function(){var e=this;this.mousedown=this.viewerImpl.domElement.addEventListener("mousedown",e.onMouseDown.bind(e),!1),this.mouseup=this.viewerImpl.domElement.addEventListener("mouseup",e.onMouseUp.bind(e),!1)},disabled:function(){var e=this;this.mousedown=this.viewerImpl.domElement.removeEventListener("mousedown",e.onMouseDown.bind(e),!1),this.mouseup=this.viewerImpl.domElement.removeEventListener("mouseup",e.onMouseUp.bind(e),!1)},touchEnabled:function(){var e=this;this.touchstart=document.getElementById(e.viewerImpl.uuid).addEventListener("touchstart",e.onTouchStart.bind(e),!1),this.touchend=document.getElementById(e.viewerImpl.uuid).addEventListener("touchend",e.onTouchEnd.bind(e),!1)},touchDisabled:function(){var e=this;this.touchstart=this.viewerImpl.domElement.removeEventListener("touchstart",e.onTouchStart.bind(e),!1),this.touchend=this.viewerImpl.domElement.removeEventListener("touchend",e.onTouchEnd.bind(e),!1)},onMouseDown:function(e){this.mouse.x=this.lastX=e.clientX,this.mouse.y=this.lastY=e.clientY},onMouseUp:function(e){var t=[e.clientX,e.clientY];(t[0]>this.lastX?5>t[0]-this.lastX:5>this.lastX-t[0])&&(t[1]>this.lastY?5>t[1]-this.lastY:5>this.lastY-t[1])&&(this.mouse.x=this.lastX=t[0],this.mouse.y=this.lastY=t[1],this.pick("pick"))},onTouchStart:function(e){this.mouse.x=this.lastX=e.changedTouches[0].clientX,this.mouse.y=this.lastY=e.changedTouches[0].clientY},onTouchEnd:function(e){(e.changedTouches[0].clientX>this.lastX?5>e.changedTouches[0].clientX-this.lastX:5>this.lastX-e.changedTouches[0].clientX)&&(e.changedTouches[0].clientY>this.lastY?5>e.changedTouches[0].clientY-this.lastY:5>this.lastY-e.changedTouches[0].clientY)&&(this.mouse.x=this.lastX=e.changedTouches[0].clientX,this.mouse.y=this.lastY=e.changedTouches[0].clientY,this.pick("pick"))},pick:function(){var e=this.viewerImpl.cameraControl.getIntersectContext(this.mouse),t=new Xp;t.setFromCamera(e.mouse,e.camera),t.camera=e.camera,t._camera=e.camera,t.viewportSize=e.viewportSize;var i=Object.values(this.components);for(var n in i)if(i.hasOwnProperty(n));var r=t.intersectObjects(i);r?this.SelectedMark!==r.object?(this.SelectedMark=r.object,this.dispatchEvent({type:"updated",added:{objects:this.SelectedMark}})):(this.dispatchEvent({type:"updated",removed:{objects:this.SelectedMark}}),this.SelectedMark={}):(this.SelectedMark={},this.dispatchEvent({type:"updated",removed:{objects:this.SelectedMark}}))},getClickCoordsWithinElement:function(e){var t=[0,0];if(e){for(var i=e.target,n=0,r=0;i.offsetParent;)n+=i.offsetLeft,r+=i.offsetTop,i=i.offsetParent;t[0]=e.pageX-n,t[1]=e.pageY-r}else e=window.event,t.x=e.x,t.y=e.y;return t},listentoSelectMarks:function(e){var t=this;this.addEventListener("updated",(function(i){i.added&&t.SelectedMark!=={}?e(t.SelectedMark.key,t.SelectedMark):e(null,null)}))},hasTheSameId:function(e){if(""!==e.id)for(var t=0;this.allOids.length>t;t+=1)if(e.id===this.allOids[t])return{data:"标签id重复"}},findMark:function(e){return this.components[e]},idsToArray:function(e){return null==e?{data:"未选中mark"}:(Array.isArray(e)||(e=[e]),e)},removeIdAndInfo:function(e){var t=this.allOids.indexOf(e);this.allOids.splice(t,1),delete this.marks[e],delete this.components[e]},remove:function(e){if(e=this.idsToArray(e),!Array.isArray(e))return e;for(var t=0;e.length>t;t+=1)this.removeIdAndInfo(e[t]),this.viewer.removeExternalObjectByName(e[t]);this.viewer.render()},hide:function(e){if(e=this.idsToArray(e),!Array.isArray(e))return e;for(var t=0;e.length>t;t+=1){this.findMark(e[t])&&this.viewer.hideComponentsByKey(e[t])}this.viewer.render()},show:function(e){var t=null;if(e){e=this.idsToArray(e);for(var i=0;e.length>i;i+=1)(t=this.findMark(e[i]))&&(t.visible=!0,this.viewer.showComponentsByKey(e[i]))}else for(var n in this.components)(t=this.components[n])&&this.viewer.showComponentsByKey(n);this.viewer.render()},isolation:function(e){if(this.allOids.length>0){e=this.idsToArray(e);this.show();for(var t=this.allOids.concat(),i=0;e.length>i;i+=1){var n=e[i];if(-1===this.allOids.indexOf(n))return{data:"mark不存在"};for(var r=0;t.length>r;r+=1)if(n===t[r]){t.splice(r,1);break}}var o=null;for(r=0;t.length>r;r+=1)(o=this.findMark(t[r]))&&(o.visible=!1);this.viewer.render()}}});var nT=function(e){this.defaultSettings={id:"",mode:"absolute",startPosition:[0,0,0],endPosition:[0,0],color:[255,0,0],colorLine:[0,0,0],offset:[0,0],draggable:!0,componentId:"",domElement:null,title:"标签",showPoint:!0,showLine:!0},this.initStartPos={};var t=e;if("function"==typeof e.getViewerImpl){this.viewerImpl=t.getViewerImpl(),this.dragging=!1,this.init(t),this.markState={};var i=this;this.showPoint=!0,this.showLine=!0,this.viewerImpl.cameraControl.addEventListener(Fd.ON_CAMERA_CHANGE,(function(){i._update()}))}else Bu.error("viewer 参数需要是BOS3D.Viewer的实例")};nT.prototype=wp.extend(!0,{},iT.prototype,{constructor:nT,add:function(e,t){var i=document.createElement("div"),n=Object.assign({},this.defaultSettings,e),r=this.hasTheSameId(n);if(r)return r;""===n.id&&(n.id=be.generateUUID()),i.id="label"+n.id,this.marks[n.id]=Object.assign({},n);var o=this.viewer.getScreenCoordFromSceneCoord(n.startPosition),a=n.offset,s=n.endPosition.concat(),l=[];("absolute"===n.mode?n.offset=[0,0]:(s=[o[0]+a[0],o[1]+a[1]],n.endPosition=[0,0]),Array.isArray(n.colorLine))&&(n.colorLine="rgb("+n.colorLine[0]+","+n.colorLine[1]+","+n.colorLine[2]+")");var c=document.createElement("div");(c.id="labelStart"+n.id,c.className="labelStart",c.style.cssText="border:2px solid red; border-radius:5px; -moz-border-radius:5px; height: 4px;width: 4px;position: absolute;margin-left: -3px;margin-top: -3px;top:"+o[1]+"px;left:"+o[0]+"px; background-color: red;",i.appendChild(c),this.showPoint&&n.showPoint||(c.style.display="none"),Array.isArray(n.color))&&(n.color="rgb("+n.color[0]+","+n.color[1]+","+n.color[2]+")");var h=document.createElement("div");h.id=n.id,h.className="labelingDiv",h.style.cssText="border:2px solid "+n.colorLine+";text-align:center;border-radius:5px;-moz-border-radius:5px;min-width: 66px;position: absolute;width:-webkit-fit-content;width: -moz-fit-content;background-color:"+n.color+";",i.appendChild(h);var d=document.createElement("span");d.id="labelTitle"+n.id,d.className="labelTitle",d.onmouseover=function(){d.style.cursor="move"},d.onmouseout=function(){d.style.cursor="auto"},d.style.cssText="display:block;padding:2%;text-align:center;color: #000000;white-space:nowrap",d.innerText=n.title,h.appendChild(d),0>s[0]&&(s[0]=5),0>s[1]&&(s[1]=5),s[0]>this.viewerImpl.domElement.offsetWidth-h.offsetWidth&&(s[0]=this.viewerImpl.domElement.offsetWidth-h.offsetWidth),s[1]>this.viewerImpl.domElement.offsetHeight-h.offsetHeight&&(s[1]=this.viewerImpl.domElement.offsetHeight-h.offsetHeight),h.style.cssText+="left:"+s[0]+"px; top:"+s[1]+"px",n.domElement&&h.appendChild(n.domElement),s[0]>o[0]?s[1]>o[1]?(l[0]=s[0],l[1]=s[1]):(l[0]=s[0],l[1]=s[1]+h.offsetHeight):s[1]>o[1]?(l[0]=s[0]+h.offsetWidth,l[1]=s[1]):(l[0]=s[0]+h.offsetWidth,l[1]=s[1]+h.offsetHeight);var u=o[0]-l[0],p=o[1]-l[1],g=Math.sqrt(u*u+p*p),f=Math.atan(p/u)/Math.PI*180;u>0||(p>0?f+=180:f-=180);var m=document.createElement("div");m.id="labelLine"+n.id,m.className="labelLine",m.style.cssText=" height: 2px;position: absolute;transform-origin: left center;width:"+g+"px;-ms-transform:rotateZ("+f+"deg);-moz-transform:rotateZ("+f+"deg);-webkit-transform:rotateZ("+f+"deg);-o-transform:rotateZ("+f+"deg);transform:rotateZ("+f+"deg);left:"+l[0]+"px;top:"+l[1]+"px;background-color:"+n.colorLine+";",i.appendChild(m),this.showLine&&n.showLine||(m.style.display="none"),this.viewerImpl.domElement.appendChild(i),n.draggable&&this._enableDrag(h),this.allOids.push(n.id),this.markState[n.id]={userHide:!1,outOfBoundary:!1},"function"==typeof t&&t(n.id)},enablePoint:function(e){this.showPoint=e,this._update()},enableLine:function(e){this.showLine=e,this._update()},_update:function(){for(var e in this.marks){var t=this.viewer.getScreenCoordFromSceneCoord(this.marks[e].startPosition),i=this.marks[e].endPosition.concat(),n=this.marks[e].offset;"relativeute"===this.marks[e].mode&&(0!==i[0]||0!==i[1]?(n=[i[0]-t[0],i[1]-t[1]],this.marks[e].endPosition=[0,0],this.marks[e].offset=n):i=[t[0]+n[0],t[1]+n[1]]);var r=[0,0],o=document.getElementById(e);i[0]>t[0]?i[1]>t[1]?(r[0]=i[0],r[1]=i[1]):(r[0]=i[0],r[1]=i[1]+o.offsetHeight):i[1]>t[1]?(r[0]=i[0]+o.offsetWidth,r[1]=i[1]):(r[0]=i[0]+o.offsetWidth,r[1]=i[1]+o.offsetHeight);var a=t[0]-r[0],s=t[1]-r[1],l=Math.sqrt(a*a+s*s),c=Math.atan(s/a)/Math.PI*180;a>0||(s>0?c+=180:c-=180);var h=getComputedStyle(this.viewerImpl.domElement),d=parseInt(h.width,10),u=parseInt(h.height,10);0>t[1]||t[1]>u||0>t[0]||t[0]>d?(this.markState[e].outOfBoundary=!0,document.getElementById("labelStart"+e).setCss({display:"none"}),document.getElementById("labelLine"+e).setCss({display:"none"}),document.getElementById(e).setCss({display:"none"})):(this.markState[e].outOfBoundary=!1,this.dragging||"relativeute"!==this.marks[e].mode||(document.getElementById(e).style.left=i[0]+"px",document.getElementById(e).style.top=i[1]+"px"),this.markState[e].userHide||(document.getElementById(e).setCss({display:"block"}),this.showPoint&&this.marks[e].showPoint?document.getElementById("labelStart"+e).style.cssText+=";display:block;top:"+t[1]+"px; left:"+t[0]+"px":document.getElementById("labelStart"+e).setCss({display:"none"}),this.showLine&&this.marks[e].showLine?document.getElementById("labelLine"+e).style.cssText+=";display:block;width:"+l+"px;transform-origin: left center;-ms-transform:rotateZ("+c+"deg);-moz-transform:rotateZ("+c+"deg);-webkit-transform:rotateZ("+c+"deg);-o-transform:rotateZ("+c+"deg);transform:rotateZ("+c+"deg);left:"+r[0]+"px; top:"+r[1]+"px":document.getElementById("labelLine"+e).setCss({display:"none"})))}},_enableDrag:function(e){var t=this,i=e,n=e.id,r=i.querySelector("#labelTitle"+n),o=this.viewerImpl.domElement,a=o.offsetLeft,s=o.offsetTop,l=this;r.addEventListener("mousedown",(function(e){e.preventDefault(),l.dragging=!0,i.setAttribute("offset-left",e.offsetX),i.setAttribute("offset-top",e.offsetY),i.setAttribute("allow-drag","true")})),document.addEventListener("mousemove",function(e){if("true"===i.getAttribute("allow-drag")){e.preventDefault();var t=e.clientX-parseInt(i.getAttribute("offset-left"),10)-parseInt(i.style.borderWidth,10)-a,r=e.clientY-parseInt(i.getAttribute("offset-top"),10)-parseInt(i.style.borderWidth,10)-s;0>r&&(r=5),r>o.offsetHeight-i.offsetHeight&&(r=o.offsetHeight-i.offsetHeight),0>t&&(t=5),t>o.offsetWidth-i.offsetWidth&&(t=o.offsetWidth-i.offsetWidth),i.style.cssText+=";left:"+t+"px;top:"+r+"px",this.marks[n].endPosition=[t,r],this._update()}}.bind(this)),document.addEventListener("mouseup",(function(e){"true"===i.getAttribute("allow-drag")&&(e.preventDefault(),i.setAttribute("allow-drag","false"),l.dragging=!1)})),r.addEventListener("touchstart",(function(e){e.preventDefault();var t=parseInt(i.style.left,10),n=parseInt(i.style.top,10),r=e.targetTouches[0].clientY;i.setAttribute("offset-left",e.targetTouches[0].clientX-t),i.setAttribute("offset-top",r-n),i.setAttribute("allow-drag","true")})),document.addEventListener("touchmove",(function(e){if("true"===i.getAttribute("allow-drag")){e.preventDefault();var r=e.targetTouches[0].clientX-parseInt(i.getAttribute("offset-left"),10)-parseInt(i.style.borderWidth,10)-a,o=e.targetTouches[0].clientY-parseInt(i.getAttribute("offset-top"),10)-parseInt(i.style.borderWidth,10)-s;0>o&&(o=5),o>t.viewerImpl.domElement.offsetHeight-i.offsetHeight&&(o=t.viewerImpl.domElement.offsetHeight-i.offsetHeight),0>r&&(r=5),r>t.viewerImpl.domElement.offsetWidth-i.offsetWidth&&(r=t.viewerImpl.domElement.offsetWidth-i.offsetWidth),i.style.cssText+=";left:"+r+"px;top:"+o+"px",t.marks[n].endPosition=[r,o],t._update()}})),document.addEventListener("touchend",(function(e){"true"===i.getAttribute("allow-drag")&&(e.preventDefault(),i.setAttribute("allow-drag","false"))}))},updateMark:function(e,t){if(!this.marks[e])return{id:e,data:"该标签不存在"};var i=Object.assign({},this.marks[e],t);this.marks[e]=Object.assign({},i);var n=this.viewer.getScreenCoordFromSceneCoord(i.startPosition),r=i.offset,o=i.endPosition.concat(),a=[];"relativeute"===i.mode?(o=[n[0]+r[0],n[1]+r[1]],i.endPosition=[0,0]):i.offset=[0,0],Array.isArray(i.colorLine)&&(i.colorLine="rgb("+i.colorLine[0]+","+i.colorLine[1]+","+i.colorLine[2]+")");var s=document.getElementById("labelStart"+e);s.style.cssText="border:2px solid red; border-radius:5px; -moz-border-radius:5px; height: 4px;width: 4px;position: absolute;margin-left: -3px;margin-top: -3px;top:"+n[1]+"px;left:"+n[0]+"px;background-color:"+i.colorLine+";",this.showPoint&&i.showPoint||(s.style.display="none"),Array.isArray(i.color)&&(i.color="rgb("+i.color[0]+","+i.color[1]+","+i.color[2]+")");var l=document.getElementById(e);l.style.cssText="border:2px solid "+i.colorLine+";text-align:center;border-radius:5px;-moz-border-radius:5px;min-width: 66px;position: absolute;width:-webkit-fit-content;width: -moz-fit-content;background-color:"+i.color+";";var c=document.getElementById("labelTitle"+e);c.innerText=i.title,0>o[0]&&(o[0]+=5),0>o[1]&&(o[1]+=5),o[0]>this.viewerImpl.domElement.offsetWidth-l.offsetWidth&&(o[0]=this.viewerImpl.domElement.offsetWidth-l.offsetWidth),o[1]>this.viewerImpl.domElement.offsetHeight-l.offsetHeight&&(o[1]=this.viewerImpl.domElement.offsetHeight-l.offsetHeight),l.style.cssText+="left:"+o[0]+"px; top:"+o[1]+"px";var h=c.nextElementSibling||c.nextSibling;h&&l.removeChild(h),i.domElement&&l.appendChild(i.domElement),i.draggable&&this._enableDrag(l),o[0]>n[0]?o[1]>n[1]?(a[0]=o[0],a[1]=o[1]):(a[0]=o[0],a[1]=o[1]+l.offsetHeight):o[1]>n[1]?(a[0]=o[0]+l.offsetWidth,a[1]=o[1]):(a[0]=o[0]+l.offsetWidth,a[1]=o[1]+l.offsetHeight);var d=n[0]-a[0],u=n[1]-a[1],p=Math.sqrt(d*d+u*u),g=Math.atan(u/d)/Math.PI*180;d>0||(u>0?g+=180:g-=180);var f=document.getElementById("labelLine"+e);f.style.cssText="height: 2px;position: absolute;transform-origin: left center;width:"+p+"px;-ms-transform:rotateZ("+g+"deg);-moz-transform:rotateZ("+g+"deg);-webkit-transform:rotateZ("+g+"deg);-o-transform:rotateZ("+g+"deg);transform:rotateZ("+g+"deg);left:"+a[0]+"px;top:"+a[1]+"px;background-color:"+i.colorLine+";",this.showLine&&i.showLine||(f.style.display="none")},updateColor:function(e,t){Array.isArray(e)||(e=[e]);for(var i=0;e.length>i;i+=1){var n=e[i];if(!this.marks[n])return{id:n,data:"该标签不存在"};Array.isArray(t)?document.getElementById(n).style.cssText+=";background-color:rgb("+t[0]+","+t[1]+","+t[2]+")":document.getElementById(n).style.cssText+=";background-color:"+t,this.marks[n].color=t}},updateTitle:function(e,t){Array.isArray(e)||(e=[e]);for(var i=0;e.length>i;i+=1){var n=e[i];if(!this.marks[n])return{id:n,data:"该标签不存在"};document.getElementById("labelTitle"+n).innerText=t,this.marks[n].title=t}},updateDomElement:function(e,t){if(this.marks[e]){var i=document.getElementById(e),n=i.querySelector(".labelTitle"),r=n.nextElementSibling||n.nextSibling;return r&&i.removeChild(r),t&&i.appendChild(t),this.marks[e].domElement=t,!0}return{id:e,data:"该标签不存在"}},remove:function(e){e=this.idsToArray(e);for(var t=0;e.length>t;t+=1){var i=e[t];if(!this.marks[i])return{id:i,data:"该标签不存在"};this.viewerImpl.domElement.removeChild(document.getElementById("label"+i)),delete this.marks[i],delete this.markState[i];var n=this.allOids.indexOf(i);this.allOids.splice(n,1)}},hide:function(e){e=this.idsToArray(e);for(var t=0;e.length>t;t+=1){var i=e[t];if(!this.marks[i])return{id:i,data:"该标签不存在"};this.markState[i].userHide=!0,this.markState[i].outOfBoundary||(document.getElementById("labelLine"+i).style.display="none",document.getElementById("labelStart"+i).style.display="none",document.getElementById(i).style.display="none")}},show:function(e){if(e){e=this.idsToArray(e);for(var t=0;e.length>t;t+=1){if(!this.marks[r=e[t]])return{id:r,data:"该标签不存在"};this.markState[r].userHide=!1,this.markState[r].outOfBoundary||(this.showPoint&&this.marks[r].showPoint&&(document.getElementById("labelStart"+r).style.display="block"),this.showLine&&this.marks[r].showLine&&(document.getElementById("labelLine"+r).style.display="block"),document.getElementById(r).style.display="block")}}else for(var i=this.allOids.concat(),n=0;i.length>n;n+=1){var r;this.markState[r=i[n]].userHide=!1,this.markState[r].outOfBoundary||(this.showPoint&&this.marks[r].showPoint&&(document.getElementById("labelStart"+r).style.display="block"),this.showLine&&this.marks[r].showLine&&(document.getElementById("labelLine"+r).style.display="block"),document.getElementById(r).style.display="block")}},isolation:function(e){if(this.allOids.length>0){e=this.idsToArray(e),this.show();for(var t=this.allOids.concat(),i=0;e.length>i;i+=1){var n=e[i];if(!this.marks[n])return{data:"mark不存在"};for(var r=0;t.length>r;r+=1)if(n===t[r]){t.splice(r,1);break}}for(var o=0;t.length>o;o+=1)document.getElementById("labelLine"+t[o]).style.display="none",document.getElementById("labelStart"+t[o]).style.display="none",document.getElementById(t[o]).style.display="none"}},addEventListener:function(e,t,i){document.getElementById(e).addEventListener(t,i)},removeEventListener:function(e,t,i){document.getElementById(e).removeEventListener(t,i)}});var rT=function(e){this.defaultSettings={id:"",URL:"",side:2,scale:1,width:1,height:1,opacity:1,transparent:!1,alwaysVisible:!1,useImageSize:!0,faceToCamera:!1,color:[1,1,1],emissive:[0,0,0],position:[0,0,0],face:"z",useFaceMatrix:!0,matrix:[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1]},this.faceMatrix={x:[0,1,0,0,0,0,1,0,1,0,0,0,0,0,0,1],y:[1,0,0,0,0,0,1,0,0,-1,0,0,0,0,0,1],z:[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1]},"function"==typeof e.getViewerImpl?(this.init(e),this.enabled()):Bu.error("viewer 参数需要是BOS3D.Viewer的实例")};rT.prototype=wp.extend(!0,{},iT.prototype,{constructor:rT,add:function(e,t){var i=this,n=iu(iu({},this.defaultSettings),e),r=this.hasTheSameId(n);if(r)return r;var o=1,a=1,s=(new Dl).load(n.URL,(function(e){i.viewer.render()}),(function(){}),(function(e){i.dispatchEvent({type:Qd.LOAD_TEXTURE_ERROR,data:"加载材质出错"})}));!0===n.alwaysVisible&&(n.transparent=!0);var l=new il({color:new pi(n.color[0],n.color[1],n.color[2]),emissive:new pi(n.emissive[0],n.emissive[1],n.emissive[2]),map:s,depthTest:!n.alwaysVisible,side:n.side,opacity:n.opacity,transparent:n.transparent});o=n.width?n.width:l.map.image.width,a=n.height?n.height:l.map.image.height;var c=new nn(new In(1,1,1,1),l),h=new yt;if(n.matrix&&(3===n.matrix.length?(h.elements[12]=n.matrix[0],h.elements[13]=n.matrix[1],h.elements[14]=n.matrix[2]):h.fromArray(n.matrix)),c.applyMatrix4(h),n.faceToCamera){var d=new Ke,u=new Ke,p=new Ge;c.onBeforeRender=function(){i.viewer.camera.matrixWorld.decompose(d,p,u),c.quaternion.copy(p),c.updateMatrixWorld(!0)}}return c.scale.set(n.scale*o,n.scale*a,1),c.updateMatrixWorld(!0),""!==n.id?c.key=n.id:(c.key=c.uuid,n.id=c.uuid),i.addObjectToScene(n,c),"function"==typeof t&&t(c.key),c.componentKey=n.componentKey&&Array.isArray(n.componentKey)?n.componentKey:n.componentKey?[n.componentKey]:[],c},updateMark:function(e,t){var i=this,n=this.findMark(e);if(n){n.applyMatrix4((new yt).copy(n.matrix).invert());var r=iu(iu({},i.marks[e]),t),o=new yt;if(r.matrix&&(3===r.matrix.length?(o.elements[12]=r.matrix[0],o.elements[13]=r.matrix[1],o.elements[14]=r.matrix[2]):o.fromArray(r.matrix)),n.applyMatrix4(o),r.faceToCamera){var a=new Ke,s=new Ke,l=new Ge;n.onBeforeRender=function(){i.viewer.camera.matrixWorld.decompose(a,l,s),n.quaternion.copy(l),n.updateMatrixWorld(!0)}}else delete n.onBeforeRender;if(n.scale.set(r.scale*r.width,r.scale*r.height,1),n.updateMatrixWorld(!0),n.componentKey=r.componentKey&&Array.isArray(r.componentKey)?r.componentKey:r.componentKey?[r.componentKey]:[],i.marks[e]=r,t.URL)(new Dl).load(r.URL,(function(e){!0===r.alwaysVisible&&(r.transparent=!0);var t=new il({color:new pi(r.color[0],r.color[1],r.color[2]),emissive:new pi(r.emissive[0],r.emissive[1],r.emissive[2]),map:e,depthTest:!r.alwaysVisible,side:r.side,opacity:r.opacity,transparent:r.transparent});n.material=t}));else!0===r.alwaysVisible&&(r.transparent=!0),n.material.depthTest=!r.alwaysVisible,n.material.transparent=r.transparent,n.material.opacity=r.opacity,n.material.side=r.side,n.material.emissive=new pi(r.emissive[0],r.emissive[1],r.emissive[2])}this.viewer.render()}});var oT=function(e){this.defaultSettings={id:"",url:"",width:1,height:1,scale:1,alwaysVisible:!1,position:[0,0,0],componentId:"",useImageSize:!0},"function"==typeof e.getViewerImpl?(this.init(e),this.enabled()):Bu.error("viewer 参数需要是BOS3D.Viewer的实例")};oT.prototype=wp.extend(!0,{},iT.prototype,{constructor:oT,add:function(e,t){var i=this;!e.url&&e.URL&&(e.url=e.URL);var n=Object.assign({},this.defaultSettings,e),r=this.hasTheSameId(n);if(r)return r;var o=1,a=1;(new Dl).load(n.URL||n.url,(function(e){var r=new Wo({map:e,color:16777215,depthTest:!n.alwaysVisible,transparent:n.alwaysVisible});o=n.useImageSize&&r.map&&r.map.image&&r.map.image.width?r.map.image.width:n.width,a=n.useImageSize&&r.map&&r.map.image&&r.map.image.width?r.map.image.height:n.height;var s=new aa(r);s.scale.set(n.scale*o,n.scale*a,1),n.position.isVector3?s.position.copy(n.position):s.position.set(n.position[0],n.position[1],n.position[2]),s.updateMatrixWorld(!0),""!==n.id?s.key=n.id:(s.key=s.uuid,n.id=s.uuid),i.addObjectToScene(n,s),"function"==typeof t&&t(s.key)}),(function(){}),(function(e){i.dispatchEvent({type:Qd.LOAD_TEXTURE_ERROR,data:"加载材质出错"})}))},updateMark:function(e,t,i){var n=this,r=this.findMark(e);if(r){var o=Object.assign({},n.marks[e],t),a=1,s=1;(new Dl).load(o.URL||o.url,(function(t){r._oriMaterial&&(r.material=r._oriMaterial),r.material.map=t,r.material.depthTest=!o.alwaysVisible;var l=r.material;a=o.useImageSize&&l.map&&l.map.image&&l.map.image.width?l.map.image.width:o.width,s=o.useImageSize&&l.map&&l.map.image&&l.map.image.width?l.map.image.height:o.height,r.material.needUpdate=!0,r.scale.set(o.scale*a,o.scale*s,1),o.position.isVector3?r.position.copy(o.position):r.position.set(o.position[0],o.position[1],o.position[2]),r.updateMatrixWorld(),n.viewer.render(),n.marks[e]=o,"function"==typeof i&&i(e)}),(function(){}),(function(e){n.dispatchEvent({type:Qd.LOAD_TEXTURE_ERROR,data:"加载材质出错"})}))}},resize:function(e,t,i){if(null==e)return{data:"未选中mark"};if(!t||!i)return{data:"未指定尺寸"};Array.isArray(e)||(e=[e]);for(var n=null,r=0;e.length>r;r+=1)(n=this.findMark(e[r]))&&(n.scale.set(t,i,1),n.updateMatrixWorld(),this.viewer.render())}});var aT=function(e){var t=this,i=e;if("function"==typeof e.getViewerImpl){var n=e.getViewerImpl();this.marks={},this.SelectedMark={},this.components={},this.allOids=[];var r={id:"",name:"mark",scale:20,alwaysVisible:!1,color:[99,99,99],wordColor:[0,0,0],position:[0,0,0]},o=new ke,a=0,s=0;this.active=!0,t.domElement=n.domElement,this.enabled=function(){this.mousedown=n.domElement.addEventListener("mousedown",h,!1),this.mouseup=n.domElement.addEventListener("mouseup",d,!1)},this.disabled=function(){this.mousedown=n.domElement.removeEventListener("mousedown",h,!1),this.mouseup=n.domElement.removeEventListener("mouseup",d,!1)},this.touchEnabled=function(){this.touchstart=n.domElement.addEventListener("touchstart",u,!1),this.touchend=n.domElement.addEventListener("touchend",p,!1)},this.touchDisabled=function(){this.touchstart=n.domElement.removeEventListener("touchstart",u,!1),this.touchend=n.domElement.removeEventListener("touchend",p,!1)},this.enabled(),this.add=function(e,i){var n=Object.assign({},r,e);if(""!==n.id)for(var o=0;t.allOids.length>o;o+=1)if(n.id===t.allOids[o])return{data:"标签id重复"};(n.position.isVector3||(n.position=new Ke(n.position[0],n.position[1],n.position[2])),Array.isArray(n.color))&&(n.color="rgb("+n.color[0]+","+n.color[1]+","+n.color[2]+")");Array.isArray(n.wordColor)&&(n.wordColor="rgb("+n.wordColor[0]+","+n.wordColor[1]+","+n.wordColor[2]+")");var a=document.createElement("canvas");a.width=28*n.name.length,a.height=150;var s=a.getContext("2d");s.fillStyle="rgba(255, 255, 255, 0)",s.lineWidth=2,s.strokeStyle=n.color,s.strokeRect(5,0,a.width-5,30),s.moveTo(5,141),s.lineTo(5,30),s.stroke(),s.fillStyle=n.color,s.beginPath(),s.arc(5,145,4,0,2*Math.PI),s.fill(),s.fillRect(10,5,a.width-15,20),s.font="bold 18px Arial",s.fillStyle=n.wordColor,s.textAlign="center",s.fillText(n.name,a.width/2,20);var l=new Fe(a);l.needsUpdate=!0;var c=new Wo({map:l,color:16777215,depthTest:n.alwaysVisible}),h=new aa(c);h.center.x=0,h.center.y=0,h.scale.set(n.scale*c.map.image.width,n.scale*c.map.image.height,1),h.position.copy(n.position),h.updateMatrixWorld(),h.key=""!==n.id?n.id:h.uuid,t.addObjectToScene(n,h),"function"==typeof i&&i(h.key)},this.addObjectToScene=function(e,t){e&&e.id&&t&&(this.components[e.id]=t,this.allOids.push(e.id),this.marks[e.id]=e,i.addExternalObject(e.id,t))},this.updateMark=function(e,n){if(t.marks[e]){var r=Object.assign({},t.marks[e],n),o=this.components[e];if(o){if(r.position.isVector3||(r.position=new Ke(r.position[0],r.position[1],r.position[2])),Array.isArray(r.color))r.color="rgb("+r.color[0]+","+r.color[1]+","+r.color[2]+")";if(Array.isArray(r.wordColor))r.wordColor="rgb("+r.color[0]+","+r.color[1]+","+r.color[2]+")";var a=document.createElement("canvas");a.width=28*r.name.length,a.height=150;var s=a.getContext("2d");s.fillStyle="rgba(255, 255, 255, 0)",s.lineWidth=2,s.strokeStyle=r.color,s.strokeRect(5,0,a.width-5,30),s.moveTo(5,141),s.lineTo(5,30),s.stroke(),s.fillStyle=r.color,s.beginPath(),s.arc(5,145,4,0,2*Math.PI),s.fill(),s.fillRect(10,5,a.width-15,20),s.font="bold 18px Arial",s.fillStyle=r.wordColor,s.textAlign="center",s.fillText(r.name,a.width/2,20);var l=new Fe(a);l.needsUpdate=!0;var c=new Wo({map:l,color:16777215,depthTest:r.alwaysVisible});o.material=c,o.scale.set(r.scale*o.material.map.image.width,r.scale*o.material.map.image.height,1),o.position.copy(r.position),o.updateMatrixWorld(),i.render(),t.marks[e]=r}}},this.remove=function(e){if(null==e)return{data:"未选中mark"};Array.isArray(e)||(e=[e]);for(var n=0;e.length>n;n+=1){var r=t.allOids.indexOf(e[n]);t.allOids.splice(r,1),delete t.components[e[n]],i.removeExternalObjectByName(e[n])}},this.hide=function(e){if(null==e)return{data:"未选中mark"};Array.isArray(e)||(e=[e]);for(var t=null,i=0;e.length>i;i+=1)(t=this.components[e[i]])&&(t.visible=!1)},this.show=function(e){var i=null;if(e){Array.isArray(e)||(e=[e]);for(var n=0;e.length>n;n+=1)(i=this.components[e[n]])&&(i.visible=!0)}else for(var r in t.components)(i=t.components[r])&&(i.visible=!0)},this.isolation=function(e){if(null==e)return{data:"未选中mark"};if(t.show(),t.allOids.length>0){var i=t.allOids.concat();Array.isArray(e)||(e=[e]);for(var n=0;e.length>n;n+=1){var r=e[n];if(-1===t.allOids.indexOf(r))return{data:"mark不存在"};for(var o=0;i.length>o;o+=1)if(r===i[o]){i.splice(o,1);break}}var a=null;for(o=0;i.length>o;o+=1)(a=t.components[i[o]])&&(a.visible=!1)}},this.listentoSelectMarks=function(e){t.addEventListener("updated",(function(){t.SelectedMark!=={}?e(t.SelectedMark.key?t.SelectedMark.key:t.SelectedMark.uuid,t.SelectedMark):e(null,null)}))}}else Bu.error("viewer 参数需要是BOS3D.Viewer的实例");function l(e){var t=[0,0];if(e){for(var i=e.target,n=0,r=0;i.offsetParent;)n+=i.offsetLeft,r+=i.offsetTop,i=i.offsetParent;t[0]=e.pageX-n,t[1]=e.pageY-r}else e=window.event,t.x=e.x,t.y=e.y;return t}function c(e){var i=new Xp,r=new Ke(o.x/n.domElement.clientWidth*2-1,-o.y/n.domElement.clientHeight*2+1,.5);i.setFromCamera(r,n.camera),i.camera=n.camera,i._camera=n.camera;var a=Object.values(t.components),s=i.intersectObjects(a);s&&s.length>0&&t.SelectedMark!==s[0].object?(t.SelectedMark=s[0].object,t.dispatchEvent("updated",{added:{objects:t.SelectedMark}})):(t.SelectedMark={},t.dispatchEvent("updated",{removed:{objects:t.SelectedMark}}))}function h(e){var t=l(e);o.x=a=t[0],o.y=s=t[1]}function d(e){var t=l(e);(t[0]>a?5>t[0]-a:5>a-t[0])&&(t[1]>s?5>t[1]-s:5>s-t[1])&&(o.x=a=t[0],o.y=s=t[1],c())}function u(e){o.x=a=e.changedTouches[0].clientX,o.y=s=e.changedTouches[0].clientY}function p(e){(e.changedTouches[0].clientX>a?5>e.changedTouches[0].clientX-a:5>a-e.changedTouches[0].clientX)&&(e.changedTouches[0].clientY>s?5>e.changedTouches[0].clientY-s:5>s-e.changedTouches[0].clientY)&&(o.x=a=e.changedTouches[0].clientX,o.y=s=e.changedTouches[0].clientY,c())}};Object.assign(aT.prototype,hg.prototype);var sT=function(e){var t=this;this.Marks=new Yt,e.modelManager.scene.add(t.Marks),this.SelectedMark={},this.components={},this.allOids=[];var i={id:"",name:"mark",scale:20,width:1,height:1,alwaysVisible:!1,useImageSize:!0,color:"#000000",position:[0,0,0]},n=new ke,r=0,o=0;function a(e){var t=[0,0];if(e){for(var i=e.target,n=0,r=0;i.offsetParent;)n+=i.offsetLeft,r+=i.offsetTop,i=i.offsetParent;t[0]=e.pageX-n,t[1]=e.pageY-r}else e=window.event,t.x=e.x,t.y=e.y;return t}function s(i){var r=new Xp,o=new Ke(n.x/e.domElement.clientWidth*2-1,-n.y/e.domElement.clientHeight*2+1,.5);r.setFromCamera(o,e.camera);var a=r.intersectObjects(t.Marks.children);a&&a.length>0&&t.SelectedMark!==a[0].object?(t.SelectedMark=a[0].object,t.dispatchEvent("updated",{added:{objects:t.SelectedMark}})):(t.SelectedMark={},t.dispatchEvent("updated",{removed:{objects:t.SelectedMark}}))}function l(e){var t=a(e);n.x=r=t[0],n.y=o=t[1]}function c(e){var t=a(e);(t[0]>r?5>t[0]-r:5>r-t[0])&&(t[1]>o?5>t[1]-o:5>o-t[1])&&(n.x=r=t[0],n.y=o=t[1],s())}function h(e){n.x=r=e.changedTouches[0].clientX,n.y=o=e.changedTouches[0].clientY}function d(e){(e.changedTouches[0].clientX>r?5>e.changedTouches[0].clientX-r:5>r-e.changedTouches[0].clientX)&&(e.changedTouches[0].clientY>o?5>e.changedTouches[0].clientY-o:5>o-e.changedTouches[0].clientY)&&(n.x=r=e.changedTouches[0].clientX,n.y=o=e.changedTouches[0].clientY,s())}this.active=!0,t.domElement=e.domElement,this.enabled=function(){this.mousedown=e.domElement.addEventListener("mousedown",l,!1),this.mouseup=e.domElement.addEventListener("mouseup",c,!1)},this.disabled=function(){this.mousedown=e.domElement.removeEventListener("mousedown",l,!1),this.mouseup=e.domElement.removeEventListener("mouseup",c,!1)},this.touchEnabled=function(){this.touchstart=e.domElement.addEventListener("touchstart",h,!1),this.touchend=e.domElement.addEventListener("touchend",d,!1)},this.touchDisabled=function(){this.touchstart=e.domElement.removeEventListener("touchstart",h,!1),this.touchend=e.domElement.removeEventListener("touchend",d,!1)},this.enabled(),this.add=function(n,r){var o=Object.assign({},i,n);if(""!==o.id)for(var a=0;t.allOids.length>a;a+=1)if(o.id===t.allOids[a])return{data:"标签id重复"};var s=document.createElement("canvas");s.width=24*o.name.length,s.height=32;var l=s.getContext("2d");l.lineWidth=3,l.strokeStyle="#0000FF",l.strokeRect(0,0,s.width,32),l.fillStyle="#FFFFFF",l.fillRect(3,3,s.width-6,26),l.font=" bold 24px Arial",l.fillStyle=o.color,l.textAlign="center",l.fillText(o.name,s.width/2,26),console.log(s.width);var c=new Fe(s);c.needsUpdate=!0;var h=new Wo({map:c,color:16777215,depthTest:o.alwaysVisible}),d=new aa(h);d.scale.set(o.scale*h.map.image.width,o.scale*h.map.image.height,1),o.position.isVector3?d.position.copy(o.position):d.position.set(o.position[0],o.position[1],o.position[2]),d.updateMatrixWorld(),t.Marks.add(d),e.render(),""!==o.id?(d.key=o.id,t.components[o.id]=d,t.allOids.push(o.id)):(d.key=d.uuid,t.components[d.uuid]=d,t.allOids.push(d.uuid)),"function"==typeof r&&r(d.key)},this.updateMark=function(n,r){var o=Object.assign({},i,r),a=null;if(t.components[n]){a=t.components[n];var s=document.createElement("canvas");s.width=24*o.name.length,s.height=32;var l=s.getContext("2d");l.lineWidth=3,l.strokeStyle="#0000FF",l.strokeRect(0,0,s.width,32),l.fillStyle="#FFFFFF",l.fillRect(3,3,s.width-6,26),l.font=" bold 24px Arial",l.fillStyle=o.color,l.textAlign="center",l.fillText(o.name,s.width/2,26);var c=new Fe(s);c.needsUpdate=!0;var h=new Wo({map:c,color:16777215,depthTest:o.alwaysVisible});a.material=h,a.scale.set(o.scale*a.material.map.image.width,o.scale*a.material.map.image.height,1),o.position.isVector3?a.position.copy(o.position):a.position.set(o.position[0],o.position[1],o.position[2]),a.updateMatrixWorld(),e.render()}},this.remove=function(e){if(null==e)return{data:"未选中mark"};Array.isArray(e)||(e=[e]);for(var i=null,n=0;e.length>n;n+=1){i=t.components[e[n]];var r=t.allOids.indexOf(e[n]);t.allOids.splice(r,1),t.Marks.remove(i)}},this.hide=function(e){if(null==e)return{data:"未选中mark"};Array.isArray(e)||(e=[e]);for(var i=null,n=0;e.length>n;n+=1)(i=t.components[e[n]])&&(i.visible=!1)},this.show=function(e){var i=null;if(e){Array.isArray(e)||(e=[e]);for(var n=0;e.length>n;n+=1)(i=t.components[e[n]])&&(i.visible=!0)}else for(var r in t.components)(i=t.components[r])&&(i.visible=!0)},this.isolation=function(e){if(null==e)return{data:"未选中mark"};if(t.show(),t.allOids.length>0){var i=t.allOids.concat();Array.isArray(e)||(e=[e]);for(var n=0;e.length>n;n+=1){var r=e[n];if(-1===t.allOids.indexOf(r))return{data:"mark不存在"};for(var o=0;i.length>o;o+=1)if(r===i[o]){i.splice(o,1);break}}var a=null;for(o=0;i.length>o;o+=1)(a=t.components[i[o]])&&(a.visible=!1)}},this.listentoSelectMarks=function(e){t.addEventListener("updated",(function(){t.SelectedMark!=={}?e(t.SelectedMark.key?t.SelectedMark.key:t.SelectedMark.uuid,t.SelectedMark):e(null,null)}))}};Object.assign(sT.prototype,hg.prototype);var lT=function e(){ru(this,e),this.type="circle",this.lineHeight=2,this.color="#ff0000",this.titleColor="#000000",this.titleBackgroundColor="#ff0000",this.lineTitleBackgroundColor="#ffffff"},cT=function(){function e(t,i,n,r,o,a){ru(this,e),this.lineTitle=i,this.icon=r,this.title=n,this.type=t.type,this.lineHeight=t.lineHeight,this.color=t.color,this.titleBackgroundColor=t.titleBackgroundColor,this.titleColor=t.titleColor,this.lineTitleBackgroundColor=t.lineTitleBackgroundColor,this.id=o,this.scenePoint=a,this.rootDiv=void 0,this.lineTitleDiv=void 0,this.contentDiv=void 0,this.lineStartPosition={x:0,y:0},this.lineEndPosition={x:100,y:100},this._iconSize=30,this._marginLeft=10,this._dragStart=this._dragStart.bind(this),this._dragMove=this._dragMove.bind(this),this._dragEnd=this._dragEnd.bind(this),this._lastDragPoint=void 0,this._init()}return au(e,[{key:"_init",value:function(){this.rootDiv=document.createElement("div"),this.rootDiv.style.cssText="position:absolute; left: 0px; top: 0px;-moz-user-select: none; -webkit-user-select: none; -ms-user-select: none; -khtml-user-select: none; user-select: none;";var e=document.createElementNS("http://www.w3.org/2000/svg","svg");e.setAttribute("xmlns","http://www.w3.org/2000/svg"),e.style.overflow="visible",this.svg=e;var t=document.createElementNS("http://www.w3.org/2000/svg","path");t.style.fill=this.color,this.arrow=t,this.svg.appendChild(t),this.rootDiv.appendChild(e);var i=document.createElement("div");i.style.position="absolute",i.style.backgroundColor="#ffffff",i.style.color=this.titleColor,i.innerText=this.lineTitle,this.lineTitleDiv=i,this.rootDiv.appendChild(i);var n=document.createElement("div");this.contentDiv=n,this.contentDiv.addEventListener("mousedown",this._dragStart);var r=document.createElement("div");if(this.titleDiv=r,r.style.display="inline-block",r.style.color=this.titleColor,r.style.whiteSpace="nowrap",r.style.overflow="hidden",r.style.textOverflow="ellipsis",r.style.maxWidth="150px",r.style.position="absolute",r.style.top="50%",this.icon?"circle"===this.type?(r.style.left="50%",r.style.transform="translate(-50%, 5px)"):(r.style.left="".concat(this._marginLeft+this._iconSize+5,"px"),r.style.transform="translate(0px, -50%)"):(r.style.left="50%",r.style.transform="translate(-50%, -50%)"),r.innerText=this.title,this.contentDiv.appendChild(r),this.icon){var o=document.createElement("img");o.style.width="".concat(this._iconSize,"px"),o.style.height="".concat(this._iconSize,"px"),o.style.position="absolute",o.style.pointerEvents="none","circle"===this.type?(o.style.left="50%",o.style.top="50%",o.style.transform="translate(-50%, -100%)"):(o.style.left="".concat(this._marginLeft,"px"),o.style.top="50%",o.style.transform="translate(0px, -50%)"),o.src=this.icon,this.contentDiv.appendChild(o)}this.rootDiv.appendChild(n)}},{key:"setLineStartPosition",value:function(e,t){this.lineStartPosition.x=e,this.lineStartPosition.y=t,this.update()}},{key:"setLineEndPosition",value:function(e,t){this.lineEndPosition.x=e,this.lineEndPosition.y=t,this.update()}},{key:"setLineStartAndEndPoint",value:function(e,t,i,n){this.lineStartPosition.x=e,this.lineStartPosition.y=t,this.lineEndPosition.x=i,this.lineEndPosition.y=n,this.update()}},{key:"update",value:function(){var e=this.titleDiv.getBoundingClientRect();e.width+=2*this._marginLeft,"rectangle"===this.type&&(this.icon&&(e.width+=this._iconSize,e.width+=5),e.height=40);var t=this.lineEndPosition.x-this.lineStartPosition.x,i=this.lineEndPosition.y-this.lineStartPosition.y,n=Math.atan2(i,t);n>0||(n+=2*Math.PI);var r=n/Math.PI*180,o=Math.sqrt(t*t+i*i);if("circle"===this.type)o-=e.width/2;else{var a=Math.tan(n);Math.abs(a)>e.height/e.width?o-=e.height/2/Math.abs(Math.sin(n)):o-=e.width/2/Math.abs(Math.cos(n))}o=Math.max(15,o);var s=0,l=0,c="M".concat(s," ").concat(l);c+="L".concat(s," ").concat(l-this.lineHeight/2),c+="L".concat(s+o-10," ").concat(l-this.lineHeight/2),c+="A".concat(20," ").concat(20," 0 0 0 ").concat(s+o-15," ").concat(l-this.lineHeight/2-10),c+="L".concat(s+o," ").concat(l),c+="L".concat(s+o-15," ").concat(l+this.lineHeight/2+10),c+="A".concat(20," ").concat(20," 0 0 0 ").concat(s+o-10," ").concat(l+this.lineHeight/2),c+="L".concat(s," ").concat(l+this.lineHeight/2,"Z"),this.arrow.setAttributeNS(null,"d",c);var h="translate(".concat(this.lineStartPosition.x,", ").concat(this.lineStartPosition.y,") rotate(").concat(r,")");this.arrow.setAttributeNS(null,"transform",h);var d=(this.lineStartPosition.y+this.lineEndPosition.y)/2,u="\n left:".concat((this.lineStartPosition.x+this.lineEndPosition.x)/2,"px;top:").concat(d,"px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n max-width:150px;\n position:absolute;\n transform:translate(-50%, -50%);\n background-color: ").concat(this.lineTitleBackgroundColor,";\n ");this.lineTitleDiv.style.cssText=u;var p=this.lineEndPosition.x,g=this.lineEndPosition.y;u="\n background-color:".concat(this.titleBackgroundColor,";\n position: absolute;\n left:").concat(p,"px;\n top:").concat(g,"px;\n transform:translate(-50%,-50%);\n width:").concat(e.width,"px;\n cursor: move;\n "),u+="circle"===this.type?"\n height:".concat(e.width,"px;\n border-radius:").concat(e.width,"px;\n "):"\n height:".concat(e.height,"px;\n border-radius:4px;\n "),this.contentDiv.style.cssText=u}},{key:"_dragStart",value:function(e){0===e.button&&(document.addEventListener("mousemove",this._dragMove),document.addEventListener("mouseup",this._dragEnd),this._lastDragPoint={x:e.clientX,y:e.clientY})}},{key:"_dragMove",value:function(e){if(this._lastDragPoint){var t=e.clientY-this._lastDragPoint.y;this.lineEndPosition.x+=e.clientX-this._lastDragPoint.x,this.lineEndPosition.y+=t,this.update(),this._lastDragPoint.x=e.clientX,this._lastDragPoint.y=e.clientY}else this._lastDragPoint={x:e.clientX,y:e.clientY}}},{key:"_dragEnd",value:function(e){this._lastDragPoint=void 0,document.removeEventListener("mousemove",this._dragMove),document.removeEventListener("mouseup",this._dragEnd)}}]),e}(),hT=function(){function e(t,i){ru(this,e),this.viewer3D=t,this.BOS3D=i,this.THREE=i.THREE,this.marks={},this.arrowConfig=new lT,this.flag=1,this.update=this.update.bind(this),t.registerCameraEventListener(this.BOS3D.EVENTS.ON_CAMERA_CHANGE,this.update)}return au(e,[{key:"testData",value:function(){return[{lineTitle:"测试1",title:"测试1胜利大街发",icon:"",type:"rectangle"},{lineTitle:"测试2",title:"测试2胜利大街发",icon:void 0,type:"rectangle"},{lineTitle:"测试3",title:"测试3胜利大街发",icon:void 0,type:"rectangle"},{lineTitle:"测试4",title:"测试4胜利大街发",icon:"",type:"circle"},{lineTitle:"测试5",title:"测试5胜利大街发",icon:void 0,type:"rectangle"},{lineTitle:"测试6",title:"测试6胜利大街发",icon:void 0,type:"circle"},{lineTitle:"测试7",title:"测试7胜利大街发",icon:"",type:"rectangle"}]}},{key:"addMarksAtComponent",value:function(e,t,i){var n=this.viewer3D.getBoxByComponentsKey(e),r=new this.THREE.Vector3;n.getCenter(r);var o=r.toArray(),a=this.viewer3D.getViewerImpl().domElement,s=a.getBoundingClientRect(),l=this.viewer3D.getScreenCoordFromSceneCoord(r),c=t||this.arrowConfig,h=c.type,d=0,u=[l[0]+250,l[1]],p=250,g=0,f=0;this.marks[e]||(this.marks[e]=[]);for(var m=0,A=i.length;A>m;m+=1){var y=i[m];c.type=y.type||h;var v=new cT(c,y.lineTitle,y.title,y.icon,this.flag,o);a.appendChild(v.rootDiv),v.setLineStartAndEndPoint(l[0],l[1],u[0],u[1]);var C=v.contentDiv.getBoundingClientRect();if(m>0){f+=2*Math.asin((C.height/2+d/2)/2/250),f+=.1;var I=Math.cos(f),x=Math.sin(f),w=p*I+g*-x+l[0],M=p*x+g*I+l[1];0>w?w=C.width/2:w>s.width&&(w=s.width-C.width/2),0>M?M=C.height/2:M>s.height&&(M=s.height-C.height/2),v.setLineEndPosition(w,M)}d=C.height,this.flag+=1,this.marks[e].push(v)}}},{key:"addMarkAt",value:function(e,t,i,n,r){var o=parseInt(e.x,10).toString()+"_"+parseInt(e.y,10).toString()+"_"+parseInt(e.z,10).toString(),a=new cT(r||this.arrowConfig,t,i,n,this.flag,e),s=this.viewer3D.getViewerImpl().domElement;s.appendChild(a.rootDiv);var l=s.getBoundingClientRect(),c=this.viewer3D.getScreenCoordFromSceneCoord(e),h=[c[0],c[1]];return c.x>l.width/2?h[0]-=250:h[0]+=250,a.setLineStartAndEndPoint(c[0],c[1],h[0],h[1]),this.flag+=1,this.marks[o]||(this.marks[o]=[]),this.marks[o].push(a),a}},{key:"update",value:function(){var e=this,t=(new Date).getTime();this._lastTime&&t-this._lastTime<25||(this._lastTime=t,Object.keys(this.marks).forEach((function(t){var i=e.marks[t],n=e.viewer3D.getScreenCoordFromSceneCoord(i[0].scenePoint);i.forEach((function(e){e.setLineStartPosition(n[0],n[1])}))})))}},{key:"destroy",value:function(){this.viewer3D.unregisterCameraEventListener(this.BOS3D.EVENTS.ON_CAMERA_CHANGE,this.update)}}]),e}(),dT=function(e){this.Measurement={pointMove:new Ke,pointPick:[],pointPickToScreen:[],pointAssist:[],pointAssistToScreen:[],needUpdatedObjects:[],pickLineP1:new Ke,pickLineP2:new Ke,planeSquare:{},planeVolume:{},measureWindow:{}},this.renderer=e.viewerImpl.modelManager.renderer,this.scene=e.viewerImpl.modelManager.scene,this.camera=e.viewerImpl.camera.cameraPerspective,this.cameraControl=e.viewerImpl.cameraControl,this.intersect=null,this.domElement=e.viewerImpl.domElement,this.viewer=e.viewerImpl,this.SVG=document.getElementById("svgid"+e.getViewerImpl().uuid),this.SVGRect=e.SVGRect;var t=this;function i(){t.updatePos()}function n(){var i=e.getScreenCoordFromSceneCoord(t.Measurement.pickLineP1),n=e.getScreenCoordFromSceneCoord(t.Measurement.pickLineP2),r=new ke(i[0],i[1]),o=new ke(n[0],n[1]);t.SVGRect.createMoveLine(r,o)}this.movePoint=function(i){if(i.pickLine||i.pickPlane||i.pickPoint){t.SVGRect.deleteCircle();var n=e.viewerImpl.cameraControl.screenToCanvas(i.event.clientX,i.event.clientY);t.SVGRect.creatMoveCircle(n);var r=t.cameraControl.getIntersectContext(new ke(i.event.clientX,i.event.clientY));if(t.cameraControl.intersector.pick(r,(function(i){for(var r=i.object.geometry,o=r.attributes.position.array,a=r.attributes.position.count,s=0;a>s;s+=1){var l=new Ke(o[3*s],o[3*s+1],o[3*s+2]);l.applyMatrix4(i.object.matrixWorld);var c=e.getScreenCoordFromSceneCoord(l);15>Math.sqrt((c[0]-n.x)*(c[0]-n.x)+(c[1]-n.y)*(c[1]-n.y))&&(t.Measurement.pointMove=l,t.SVGRect.changeMoveCircleStyle(c))}})),i.pickLine){t.Measurement.pickLineP1=i.pickLine[0],t.Measurement.pickLineP2=i.pickLine[1];var o=e.getScreenCoordFromSceneCoord(i.pickLine[0].clone()),a=e.getScreenCoordFromSceneCoord(i.pickLine[1].clone()),s=new ke(o[0],o[1]),l=new ke(a[0],a[1]);t.SVGRect.createMoveLine(s,l)}}},this.pickPoint=function(i){if(i.pickLine||i.pickPlane||i.pickPoint){1>t.Measurement.needUpdatedObjects.length||(t.SVGRect.deleteCircle(),t.SVGRect.deleteMoveLine(),t.SVGRect.deleteLineAndCircle(),t.Measurement.pointPick=[],t.Measurement.pointPickToScreen=[],t.Measurement.pointAssist=[],t.Measurement.pointAssistToScreen=[],t.Measurement.needUpdatedObjects=[],t.updatePos());new Ke,new Ke,new Ke,new Ke;var n=null,r=i.pickPoint,o=(new ke).fromArray(e.getScreenCoordFromSceneCoord(r));t.Measurement.pointPick.push(r),t.Measurement.pointPickToScreen.push(o);var a=t.Measurement.pointPickToScreen.length;if(t.SVGRect.creatPickCircle(o,a-1),a%2==0&&a>0){var s=new Ke(t.Measurement.pointPick[a-1].x,t.Measurement.pointPick[a-2].y,t.Measurement.pointPick[a-2].z),l=new Ke(t.Measurement.pointPick[a-1].x,t.Measurement.pointPick[a-2].y,t.Measurement.pointPick[a-1].z);t.Measurement.pointAssist.push(s),t.Measurement.pointAssist.push(l);var c=e.getScreenCoordFromSceneCoord(s),h=e.getScreenCoordFromSceneCoord(l),d=new ke(c[0],c[1]),u=new ke(h[0],h[1]);t.SVGRect.creatLine(t.Measurement.pointPickToScreen[a-2],d,"red","red"+(a-1)),t.SVGRect.creatLine(u,t.Measurement.pointPickToScreen[a-1],"green","green"+(a-1)),t.SVGRect.creatLine(d,u,"blue","blue"+(a-1)),t.SVGRect.creatLine(t.Measurement.pointPickToScreen[a-1],t.Measurement.pointPickToScreen[a-2],"yellow","yellow"+(a-1)),t.Measurement.needUpdatedObjects.push({point1:t.Measurement.pointPick[a-2],point2:t.Measurement.pointPick[a-1],asPot1:t.Measurement.pointAssist[a-2],asPot2:t.Measurement.pointAssist[a-1]});var p=Math.abs(t.Measurement.pointPick[a-1].x-t.Measurement.pointPick[a-2].x),g=Math.abs(t.Measurement.pointPick[a-1].y-t.Measurement.pointPick[a-2].y),f=Math.abs(t.Measurement.pointPick[a-1].z-t.Measurement.pointPick[a-2].z),m=t.Measurement.pointPick[a-1].distanceTo(t.Measurement.pointPick[a-2]);n={dx:p.toFixed(3),dy:g.toFixed(3),dz:f.toFixed(3),dis:m.toFixed(3)}}return n}},this.clear=function(){t.SVGRect.deleteCircle(),t.SVGRect.deleteMoveLine(),t.SVGRect.deleteLineAndCircle(),t.Measurement.pointPick=[],t.Measurement.pointPickToScreen=[],t.Measurement.pointAssist=[],t.Measurement.pointAssistToScreen=[],t.Measurement.needUpdatedObjects=[],t.cameraControl.removeEventListener(Fd.ON_CAMERA_CHANGE,i),t.cameraControl.removeEventListener(Fd.ON_CAMERA_CHANGE,n)},this.updatePos=function(){var i=t.Measurement.pointPick.length,n=t.Measurement.pointAssist.length,r=t.Measurement.needUpdatedObjects;if(n)for(var o=0;r.length>o;o+=1){var a=2*o,s=e.getScreenCoordFromSceneCoord(r[o].point1),l=e.getScreenCoordFromSceneCoord(r[o].point2),c=new ke(s[0],s[1]),h=new ke(l[0],l[1]);t.Measurement.pointPickToScreen[a]=c,t.Measurement.pointPickToScreen[a+1]=h;var d=e.getScreenCoordFromSceneCoord(r[o].asPot1),u=e.getScreenCoordFromSceneCoord(r[o].asPot2),p=new ke(d[0],d[1]),g=new ke(u[0],u[1]);t.Measurement.pointAssistToScreen[a]=p,t.Measurement.pointAssistToScreen[a+1]=g;var f=t.Measurement.pointPickToScreen[a].x,m=t.Measurement.pointPickToScreen[a].y,A=t.Measurement.pointPickToScreen[a+1].x,y=t.Measurement.pointPickToScreen[a+1].y,v=t.Measurement.pointAssistToScreen[a].x,C=t.Measurement.pointAssistToScreen[a].y,I=t.Measurement.pointAssistToScreen[a+1].x,x=t.Measurement.pointAssistToScreen[a+1].y,w=document.getElementById("circlePick"+e.getViewerImpl().uuid+a),M=document.getElementById("circlePick"+e.getViewerImpl().uuid+(a+1));w.setAttribute("cx",f),w.setAttribute("cy",m),M.setAttribute("cx",A),M.setAttribute("cy",y);var E=document.getElementById("pickline"+e.getViewerImpl().uuid+"red"+(a+1)),B=document.getElementById("pickline"+e.getViewerImpl().uuid+"green"+(a+1)),S=document.getElementById("pickline"+e.getViewerImpl().uuid+"blue"+(a+1)),b=document.getElementById("pickline"+e.getViewerImpl().uuid+"yellow"+(a+1));E.setAttribute("x1",f),E.setAttribute("y1",m),E.setAttribute("x2",v),E.setAttribute("y2",C),B.setAttribute("x1",I),B.setAttribute("y1",x),B.setAttribute("x2",A),B.setAttribute("y2",y),S.setAttribute("x1",v),S.setAttribute("y1",C),S.setAttribute("x2",I),S.setAttribute("y2",x),b.setAttribute("x1",f),b.setAttribute("y1",m),b.setAttribute("x2",A),b.setAttribute("y2",y)}if(i%2==1&&i!==n){var k=e.getScreenCoordFromSceneCoord(t.Measurement.pointPick[i-1]),D=new ke(k[0],k[1]);t.Measurement.pointPickToScreen[i-1]=D;f=D.x,m=D.y;(w=document.getElementById("circlePick"+e.getViewerImpl().uuid+(i-1))).setAttribute("cx",f),w.setAttribute("cy",m)}},this.addEventListener=function(){t.cameraControl.addEventListener(Fd.ON_CAMERA_CHANGE,i),t.cameraControl.addEventListener(Fd.ON_CAMERA_CHANGE,n)}};Object.assign(dT.prototype,hg.prototype);var uT=function(){function e(t){ru(this,e),this.coef=t.coef||.5,this.controlPoints=t.controlPoints||[],this.pointCountRecord=t.pointCountRecord,this.formatConPoints=[],this.matrix=[],this.update=!0,this.points=[],this.controlPointsIndex=[],this.straightLineDistance=0,this.curveLength=0,this.updateCurveLength=!0,this.updateList=[],this.setCoef(this.coef),this._forMatConPoints()}return au(e,[{key:"setControlPoints",value:function(e){this.controlPoints=e,this._forMatConPoints(),this.update=!0,this.updateList.push("controlPoints"),this.updateStraightLineDistance=!0}},{key:"getPoints",value:function(){return this.update&&this._createPoints(this.pointCountRecord),this.points}},{key:"setPointsCount",value:function(e){this.updateList.push("count"),this.update=!0,this.pointCountRecord=e}},{key:"getCurveLength",value:function(){return this.update?{info:"参数已修改,请先更新曲线",code:-1,updateList:this.updateList}:(this.updateCurveLength&&function(){var e=this.points,t=e.length;this.curveLength=e.reduce((function(e,i,n,r){return t>n+1&&(e+=r[n].distanceTo(r[n+1])),e}),0),this.updateCurveLength=!1}.bind(this)(),this.curveLength)}},{key:"getStraightLineDistance",value:function(){return this.updateStraightLineDistance&&function(){var e=this.controlPoints,t=e.length;this.straightLineDistance=e.reduce((function(e,i,n,r){return t>n+1&&(e+=r[n].distanceTo(r[n+1])),e}),0),this.updateStraightLineDistance=!1}.bind(this)(),this.straightLineDistance}},{key:"setCoef",value:function(e){this.updateList.push("coef"),this.update=!0,this.matrix=[[-e,2-e,e-2,e],[2*e,e-3,3-2*e,-e],[-e,0,e,0],[0,1,0,0]]}},{key:"updateCurve",value:function(){return this.getPoints()}},{key:"getPointsInfo",value:function(){return this.update?{info:"参数已修改,请先更新曲线",code:-1,updateList:this.updateList}:{points:this.getPoints(),controlPointsIndex:this.controlPointsIndex,curveLength:this.getCurveLength(),straightLineDistance:this.getStraightLineDistance()}}},{key:"_forMatConPoints",value:function(){var e=this.controlPoints;this.formatConPoints=[];for(var t=0,i=e.length;i>t;t+=1)0===t?this.formatConPoints.push(e[t].clone(),e[t].clone()):i>t+1?this.formatConPoints.push(e[t].clone()):this.formatConPoints.push(e[t].clone(),e[t].clone())}},{key:"_createPoints",value:function(e){var t=[],i=this.matrix;function n(e){t[0]=new Ke,t[1]=new Ke,t[2]=new Ke,t[3]=new Ke;var n=[];n[0]=[],n[1]=[],n[2]=[],n[3]=[],n[0][0]=e[0].clone().multiplyScalar(i[0][0]),n[0][1]=e[1].clone().multiplyScalar(i[0][1]),n[0][2]=e[2].clone().multiplyScalar(i[0][2]),n[0][3]=e[3].clone().multiplyScalar(i[0][3]),n[1][0]=e[0].clone().multiplyScalar(i[1][0]),n[1][1]=e[1].clone().multiplyScalar(i[1][1]),n[1][2]=e[2].clone().multiplyScalar(i[1][2]),n[1][3]=e[3].clone().multiplyScalar(i[1][3]),n[2][0]=e[0].clone().multiplyScalar(i[2][0]),n[2][1]=e[1].clone().multiplyScalar(i[2][1]),n[2][2]=e[2].clone().multiplyScalar(i[2][2]),n[2][3]=e[3].clone().multiplyScalar(i[2][3]),n[3][0]=e[0].clone().multiplyScalar(i[3][0]),n[3][1]=e[1].clone().multiplyScalar(i[3][1]),n[3][2]=e[2].clone().multiplyScalar(i[3][2]),n[3][3]=e[3].clone().multiplyScalar(i[3][3]);for(var r=0;4>r;r+=1)for(var o=0;4>o;o+=1)t[r].add(n[r][o])}function r(e){var i=e*e,n=i*e;return t[0].clone().multiplyScalar(n).add(t[1].clone().multiplyScalar(i)).add(t[2].clone().multiplyScalar(e)).add(t[3].clone())}var o=this.formatConPoints,a=this.points=[],s=this.controlPointsIndex=[],l=this.controlPoints;if(e){for(var c=this.getStraightLineDistance(),h=1/e,d=0,u=0,p=0,g=l.length-1;g>p;p+=1){d+=l[p].distanceTo(l[p+1]);var f=Math.floor(d/c/h)-u;n([o[p],o[p+1],o[p+2],o[p+3]]);for(var m=1/f,A=0;f>A;A+=1){a.push(r(m*A))}u+=f}a.push(l[l.length-1])}else for(var y=0,v=o.length;v>y;y+=1){var C=0===y?0:1;if(y+3>=v){a.push(o[y+2]),s.push({j:o[y+1],order:-1});break}a.push(o[y+1]),s.push({j:o[y+1],order:100*y+C}),n([o[y],o[y+1],o[y+2],o[y+3]]);for(var I=1;100>I;I+=1)a.push(r(I/100))}this.update=!1,this.updateCurveLength=!0,this.updateList=[]}}]),e}(),pT=function(){function e(t){return ru(this,e),e.shareInstance||(e.shareInstance=this,this.maxRequestCount=t||300,this.currentPendingCount=0,this._requests=[],this._requestDidLoad=this._requestDidLoad.bind(this),this._requestDidError=this._requestDidError.bind(this),this._requestDidAbort=this._requestDidAbort.bind(this),this._requestDidTimeout=this._requestDidTimeout.bind(this)),e.shareInstance}return au(e,[{key:"addRequest",value:function(e,t){e.addEventListener("load",this._requestDidLoad),e.addEventListener("error",this._requestDidError),e.addEventListener("abort",this._requestDidAbort),e.addEventListener("timeout",this._requestDidTimeout),this.maxRequestCount>this.currentPendingCount?(e.send(t),this.currentPendingCount+=1):this._requests.push({request:e,dataToSend:t})}},{key:"_sendNextRequest",value:function(){if(this._requests.length>0){var e=this._requests.shift();e.request.send(e.dataToSend),this.currentPendingCount+=1}}},{key:"_requestDidLoad",value:function(){this.currentPendingCount-=1,this._sendNextRequest()}},{key:"_requestDidError",value:function(){this.currentPendingCount-=1,this._sendNextRequest()}},{key:"_requestDidAbort",value:function(){this.currentPendingCount-=1,this._sendNextRequest()}},{key:"_requestDidTimeout",value:function(){this.currentPendingCount-=1,this._sendNextRequest()}}]),e}(),gT={group:"group",model:"model",component:"component",components:"components"};new Ke;var fT=function e(){ru(this,e),this.type=void 0,this.nodeId=void 0,this.matrix=void 0,this.center=void 0,this.modelKey=void 0,this.componentKey=void 0,this.componentsKey=void 0,this.children=void 0},mT=function(){function e(t,i,n,r){ru(this,e),this.host=t,this.projectUrl=i,this.accessToken=n,this._cachedComponents={},this._cachedMaterials={},this._cachedGeometries={},this._cachedFile={},this._requestQueue=new pT(r)}return au(e,[{key:"destroy",value:function(){delete this._cachedComponents,delete this._cachedMaterials,delete this._cachedGeometries,delete this._cachedFile}},{key:"getExternalObjectByModelKey",value:function(e){var t=this;return"string"!=typeof e?Promise.reject("参数不合法"):this._loadModelInfo(e).then((function(){return t._loadComponentsListIn(e)})).then((function(i){return t.getExternalObjectByComponentsKey(i,e)}))}},{key:"getExternalObjectByComponentKey",value:function(e){var t=this;if("string"!=typeof e)return Promise.reject("参数不合法");var i=this._cachedComponents[e];return i?Promise.resolve(this._createMesh(i,!0)):this._loadComponentsInfo([e]).then((function(e){return t._generateMeshByComponentInfo(e[0])})).then((function(e){return e}))}},{key:"getExternalObjectByComponentsKeyBackup",value:function(e){var t=this;if(e instanceof Array==!1)return Promise.reject("参数不合法");for(var i=[],n=[],r={},o=function(o,a){var s=t.getExternalObjectByComponentKey(e[o]).then((function(e){n.push(e)})).catch((function(t){r[e[o]]=t}));i.push(s)},a=0,s=e.length;s>a;a+=1)o(a);return Promise.all(i).then((function(){if(n.length>0){n.length!==e.length&&Bu.error(r);for(var t=new Jg,i=0,o=n.length;o>i;i+=1)t.add(n[i]);return t}return Promise.reject(r)}))}},{key:"getExternalObjectByComponentsKey",value:function(e,t){var i=this;if(e instanceof Array==!1)return Promise.reject("参数不合法");for(var n=[],r={},o=[],a=0,s=e.length;s>a;a+=1){var l=e[a],c=this._cachedComponents[l];c?n.push(this._createMesh(c,!0)):o.push(l)}if(o.length>0)return this._loadComponentsInfo(o).then((function(o){for(var a=[],s=0,l=o.length;l>s;s+=1){var c=i._generateMeshByComponentInfo(o[s]).then((function(e){n.push(e)})).catch((function(e){r[e.componentKey]=e.message}));a.push(c)}return Promise.all(a).then((function(){if(n.length>0){n.length!==e.length&&Bu.error(r);var i=new Jg;i.originPs=new Ke,i.userData.modelKey=t;for(var o=0,a=n.length;a>o;o+=1)i.add(n[o]);return i}return Promise.reject(r)}))}));var h=new Jg;h.userData.modelKey=t;for(var d=0,u=n.length;u>d;d+=1)h.add(n[d]);return h.originPs=new Ke,Promise.resolve(h)}},{key:"testData",value:function(){var e=new fT;e.type=gT.group;var t=new fT;t.type=gT.component,t.componentKey="M1577676674083_265272";var i=new fT;i.type=gT.component,i.componentKey="M1577676674083_265916";var n=new fT;n.type=gT.component,n.componentKey="M1577676674083_244449";var r=(new yt).makeTranslation(0,0,5e3);n.matrix=r.toArray();var o=new fT;o.type=gT.group;var a=new fT;a.type=gT.component,a.componentKey="M1577676674083_246705";var s=new fT;s.type=gT.component,s.componentKey="M1577676674083_247372",s.matrix=r.makeTranslation(0,0,7e3).toArray();var l=new fT;return l.type=gT.component,l.componentKey="M1577676674083_244910",e.children=[t,i,n,o],o.children=[a,s,l],e}},{key:"getExternalObjectByNodeInfo",value:function(e){var t=this,i=void 0;return e.type===gT.component&&e.componentKey?i=this.getExternalObjectByComponentKey(e.componentKey):e.type===gT.components&&e.componentsKey&&e.componentsKey instanceof Array&&e.componentsKey.length>0?i=this.getExternalObjectByComponentsKey(e.componentsKey):e.type===gT.model&&e.modelKey?i=this.getExternalObjectByModelKey(e.modelKey):e.type===gT.group&&e.children&&e.children.length>0?function(){for(var n=new To,r=[],o=function(i,o){var a=e.children[i],s=t.getExternalObjectByNodeInfo(a).then((function(e){n.add(e)})).catch((function(e){return Bu.error(a,e),e}));r.push(s)},a=0,s=e.children.length;s>a;a+=1)o(a);i=Promise.all(r).then((function(){return n}))}():i=Promise.reject("参数不合法"),i.then((function(t){if(e.matrix){var i=(new yt).fromArray(e.matrix);t.matrix.identity(),t.applyMatrix4(i),t.updateMatrixWorld(!0)}if(e.center){var n=(new He).setFromObject(t),r=new Ke;if(n.getCenter(r),parseInt(e.center[0],10)!==parseInt(r.x,10)||parseInt(e.center[1],10)!==parseInt(r.y,10)||parseInt(e.center[2],10)!==parseInt(r.z,10)){var o=(new Ke).fromArray(e.center).sub(r),a=(new yt).makeTranslation(o.x,o.y,o.z);t.applyMatrix4(a),t.updateMatrixWorld(!0)}}return t}))}},{key:"exportNodeInfoByComponents",value:function(e,t){if(t){var i=new fT;return 1===t.length?(i.type=gT.component,i.componentKey=t[0]):(i.type=gT.components,i.componentsKey=t),i.nodeId=e,i}}},{key:"exportNodeInfoByModelKey",value:function(e,t){if(t){var i=new fT;return i.type=gT.model,i.modelKey=t,i.nodeId=e,i}}},{key:"_loadModelInfo",value:function(e){return this._httpGet(this.host+"/api/"+this.projectUrl+"/models?modelKey="+e)}},{key:"_loadComponentsListIn",value:function(e){return this._httpGet(this.host+"/api/"+this.projectUrl+"/components/keys?modelKey="+e)}},{key:"_loadComponentsInfo",value:function(e,t,i){return this._httpPost(this.host+"/api/"+this.projectUrl+"/components/geometry",{components:e})}},{key:"_generateMeshByComponentInfo",value:function(e){var t=this;if(!e.geometry)return Promise.reject({componentKey:e.component,message:"几何为空"});var i={};if(i.componentKey=e.component,e.matrix){var n=(new yt).fromArray(e.matrix);i.matrix=n}var r=e.materials,o=[],a=[];if(e.materials.length>0)for(var s=function(i,n){o.push(t._loadMaterial(r[i]).then((function(e){a[i]=e})).catch((function(n){Bu.error(n,"用默认材质代替"),a[i]=t._loadMaterialByType(e.type)})))},l=0,c=r.length;c>l;l+=1)s(l);else{var h=this._loadMaterialByType(e.type);a.push(h),o.push(Promise.resolve(h))}return Promise.all(o).then((function(){return i.materials=a,t._loadGeometry(e.geometry)})).then((function(e){i.geometry=e;for(var n=0,r=i.materials.length;r>n;n+=1){var o=i.materials[n];if(o.aoMap||o.lightMap){i.geometry.setAttribute("uv2",new Ai(i.geometry.attributes.uv.array,2));break}}return t._cachedComponents[i.componentKey]=i,t._createMesh(i,!1)}))}},{key:"_loadMaterial",value:function(e){var t=this,i=this._cachedMaterials[e.key];if(i)return Promise.resolve(i.clone());var n=e.data;return this._loadAllTextures(n).then((function(i){var r=t._createMaterial(n,i);return t._cachedMaterials[e.key]=r,r}))}},{key:"_loadMaterialByType",value:function(e){var t=Jy[e]?Jy[e].color:void 0;t||(t=Jy.DEFAULT.color);var i=new pi(t[0],t[1],t[2]),n=i.getHexString()+"_"+t[3],r=this._cachedMaterials[n];return r||((r=cA.createStandardMaterial({color:i})).side=2,this._cachedMaterials[n]=r),r}},{key:"_loadGeometry",value:function(e){var t=this,i=this._cachedGeometries[e];return i?Promise.resolve(i):this._loadFile(e).then((function(i){try{var n=new TextDecoder("utf-8").decode(i),r=JSON.parse(n),o=t._createGeometry(r);return o?(t._cachedGeometries[e]=o,o):Promise.reject("几何为空")}catch(e){return Promise.reject(e.message)}}))}},{key:"_loadAllTextures",value:function(e){for(var t=this,i=[],n=this._getAllTextureFileKey(e),r={},o=function(e,o){var a=n[e];i.push(t._loadFile(a).then((function(e){var i=t._createTexture(e);r[a]=i})).catch((function(e){Bu.error(e)})))},a=0,s=n.length;s>a;a+=1)o(a);return i.length>0?new Promise((function(e,t){Promise.all(i).then((function(){Object.keys(r).length>0?e(r):t("加载纹理失败")}))})):Promise.resolve(r)}},{key:"_getAllTextureFileKey",value:function(e){var t={};return e.map&&(t[e.map]=!0),e.aoMap&&(t[e.aoMap]=!0),e.alphaMap&&(t[e.alphaMap]=!0),e.envMap&&(t[e.envMap]=!0),e.lightMap&&(t[e.lightMap]=!0),e.emissiveMap&&(t[e.emissiveMap]=!0),e.specularMap&&(t[e.specularMap]=!0),e.specularMap&&(t[e.specularMap]=!0),Object.keys(t)}},{key:"_createTexture",value:function(e){var t=new Fe,i=document.createElement("img");t.wrapS=t.wrapT=g,i.onerror=function(e){Bu.error("加载纹理出错")},i.onload=function(n){"string"!=typeof e&&window.URL.revokeObjectURL(i.src),t.image=i,t.needsUpdate=!0};var n=new Blob([e]);return i.src=window.URL.createObjectURL(n),t}},{key:"_createGeometry",value:function(e){if(e.positions&&0!==e.positions.length){var t=null;t=new Ni;var i=new Float32Array(e.positions);t.setAttribute("position",new Ai(i,3));var n=new Uint32Array(e.indices);if(t.setIndex(new Ai(n,1)),e.normals&&e.normals.length>0){var r=new Float32Array(e.normals);t.setAttribute("normal",new Ai(r,3))}else t.computeVertexNormals();if(e.uv&&e.uv.length>0){var o=new Float32Array(e.uv);t.setAttribute("uv",new Ai(o,2))}if(void 0!==e.materialIndices){for(var a=null,s=[],l=void 0,c=0;e.materialIndices.length>c;c+=1){var h=e.materialIndices[c];h!==l&&(l=h,null!=a&&(a.count=3*c-a.start,s.push(a)),a={start:3*c,materialIndex:l})}null!=a&&(a.count=3*e.materialIndices.length-a.start,s.push(a)),t.groups=s}return t}}},{key:"_createMaterial",value:function(e,t){return cA.createMaterialByMaterialBufferAndTexture(e,t)}},{key:"_createMesh",value:function(e,t){var i=null;if(t){i=[];for(var n=0,r=e.materials.length;r>n;n+=1)i.push(e.materials[n].clone())}else i=e.materials;var o=new Bv(e.geometry,i);return o.visible=!0,o.key=e.componentKey,e.matrix&&(o.applyMatrix4(e.matrix),o.updateMatrixWorld(!0)),o}},{key:"_loadFile",value:function(e){var t=this._cachedFile[e];return t?Promise.resolve(t):this._http("GET",this.host+"/api/"+this.projectUrl+"/files?fileKey="+e,"arraybuffer").then((function(e){return e}))}},{key:"_httpGet",value:function(e){return this._http("GET",e)}},{key:"_httpPost",value:function(e,t){return this._http("POST",e,void 0,t)}},{key:"_http",value:function(e,t,i,n){var r=this;return new Promise((function(o,a){var s={};"POST"===e&&(s["Content-type"]="application/json;charset=UTF-8"),r.accessToken&&(s.Authorization=r.accessToken),Yy({type:e,url:t,headers:s,data:JSON.stringify(n),responseType:i||"json",requestQueue:r._requestQueue,success:function(e){if(e)try{i&&"json"!==i?o(e):e.data?o(e.data):"success"!==e.code.toLowerCase()&&a(e.message?e.message:"未知错误")}catch(e){a(e.message)}else a("数据为空")},error:function(e,t){a(t)}})}))}}]),e}();Yt.prototype.allowPick=!0,Yt.prototype.boundingBox=new He,Yt.prototype.updateFixedFrame=function(e,t){for(var i=this.children,n=this.length,r=0;n>r;r+=1){var o=i[r];jg(o.updateFixedFrame)&&o.updateFixedFrame(e,t)}},Yt.prototype.updatePostRender=function(e){for(var t=this.children,i=this.length,n=0;i>n;n+=1){var r=t[n];jg(r.updatePostRender)&&r.updatePostRender(e)}},Yt.prototype.traverseMesh=function(e){if(!1!==this.isMesh){e(this);for(var t=this.children,i=0,n=t.length;n>i;i+=1)t[i].traverseMesh(e)}},Yt.prototype.addObject=function(e){if(e.isDestroyed())throw new ZM("This object was destroyed");return this.add(e),e._collection=this,e},Yt.prototype.removeObject=function(e){var t=1>=arguments.length||void 0===arguments[1]||arguments[1];return!!jg(e)&&(this.remove(e),t||this.destroyMeshs?(e.destroy(),e=null):void 0)},Yt.prototype.destroySelf=function(){jg(this.geometry)&&(this.geometry.dispose(),this.geometry=null);var e=this.material;jg(e)&&(jg(e.map)&&(e.map.dispose(),e.map=null),jg(e.aoMap)&&(e.aoMap.dispose(),e.aoMap=null),jg(e.lightMap)&&(e.lightMap.dispose(),e.lightMap=null),e.dispose(),e=null)},Yt.prototype.isDestroyed=function(){return!1},Yt.prototype.destroy=function(){return this.destroySelf(),this.traverse((function(e){(e.isMesh||e.isSprite)&&e.destroySelf()})),_M(this)},Yt.prototype.get=function(e){return this.children[e]},Yt.prototype.computeBoundingBox=function(){var e=this;this.updateMatrixWorld(!0),this.boundingBox.makeEmpty(),this.traverse((function(t){t.isMeshEx&&e.boundingBox.union(t.computeBoundingBox())})),this.boundingBox.applyMatrix4(this.matrixWorld)},Yt.prototype.getBoundingBoxCenter=function(e){return jg(e)||(e=new Vector3),this.boundingBox.getCenter(e)},Object.defineProperties(Yt.prototype,{length:{get:function(){return this.children.length}}}),e.common=xn.common,e.common=e.common.replace("struct IncidentLight {","struct IncidentLight { \nfloat alpha;"),xn.common=e.common,wn.lights.projectorLights={value:[{color:new pi,position:new Ke,projectorMatrix:new yt,near:1,distance:100,alpha:1,farPlane:new Le,shadow:!0,shadowBias:.1}],properties:{color:{},position:{},projectorMatrix:{},near:{},distance:{},alpha:{},farPlane:{},shadow:{},shadowBias:{}}},wn.lights.projectorTextures={value:[new Fe]},wn.lights.projectorAlphaTextures={value:[new Fe]},wn.lights.projectorShadowMap={value:[new Fe]},wn.lights.projectorShadowMatrix={value:[new yt]},wn.lights.farPlanes={value:[new Le]};var AT=new yt,yT=new Ke,vT=new Ke,CT=function(){function e(t){ru(this,e),this.camera=t,this._projScreenMatrix=AT,this.bias=0,this.normalBias=0,this.radius=1,this.mapSize=new ke(512,512),this.map=null,this.mapPass=null,this.matrix=new yt,this.autoUpdate=!0,this.needsUpdate=!1,this._frustum=new yn,this._frameExtents=new ke(1,1),this._viewportCount=1,this._viewports=[new Le(0,0,1,1)]}return au(e,[{key:"getViewportCount",value:function(){return this._viewportCount}},{key:"getFrustum",value:function(){return this._frustum}},{key:"updateMatrices",value:function(e){var t=this.camera,i=this.matrix;yT.setFromMatrixPosition(e.matrixWorld),t.position.copy(yT),vT.setFromMatrixPosition(e.target.matrixWorld),t.lookAt(vT),t.updateMatrixWorld(),AT.multiplyMatrices(t.projectionMatrix,t.matrixWorldInverse),this._frustum.setFromProjectionMatrix(AT),i.set(.5,0,0,.5,0,.5,0,.5,0,0,.5,.5,0,0,0,1),i.multiply(t.projectionMatrix),i.multiply(t.matrixWorldInverse)}},{key:"getViewport",value:function(e){return this._viewports[e]}},{key:"getFrameExtents",value:function(){return this._frameExtents}},{key:"dispose",value:function(){this.map&&this.map.dispose(),this.mapPass&&this.mapPass.dispose()}},{key:"copy",value:function(e){return this.camera=e.camera.clone(),this.bias=e.bias,this.radius=e.radius,this.mapSize.copy(e.mapSize),this}},{key:"clone",value:function(){return(new this.constructor).copy(this)}},{key:"toJSON",value: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}}]),e}();new pi;var IT=function(e){lu(i,e);var t=pu(i);function i(e){var n;return ru(this,i),(n=t.call(this,new dn(e.fov,e.aspect,e.near,e.distance))).light=e,n.bias=-15,n.viewer=e.viewer,n.scene=n.viewer.scene,n.shadowScene=new Vo,n.depthMaterial=new Mo({depthPacking:re,morphTargets:!1,side:2}),n._oldClearColor=new pi,n.oldClearAlpha=1,n.renderTarget=n.createRenderTarget(),n.isProjectorLightShadow=!0,n}return au(i,[{key:"createRenderTarget",value:function(){var e=this.mapSize;e.set(1024,1024);var t=new Oe(e.x,e.y);return t.texture.format=D,t.texture.minFilter=A,t.texture.magFilter=A,t.texture.generateMipmaps=!1,t.texture.name="projectorShadowMap",t}},{key:"update",value:function(){this.updateCamera(),this.updateShadowMatrix(),this.updateFrustumPlane(),this.updateRenderTarget()}},{key:"updateCamera",value:function(){var e=this.light,t=this.camera;(e.fov!==t.fov||e.aspect!==t.aspect||(e.distance||t.far)!==t.far||e.near!==t.near)&&(t.fov=e.fov,t.aspect=e.aspect,t.near=e.near,t.far=e.distance||t.far,t.updateProjectionMatrix()),t.position.copy(e.position),t.lookAt(e.target),t.rotateY(e.rotation.y),t.updateMatrixWorld(),t.updateMatrixWorld()}},{key:"updateShadowMatrix",value:function(){var e=this.matrix,t=this.camera;e.set(.5,0,0,.5,0,.5,0,.5,0,0,.5,.5,0,0,0,1),e.multiply(t.projectionMatrix),e.multiply(t.matrixWorldInverse)}},{key:"updateFrustumPlane",value:function(){var e=this.camera,t=this._projScreenMatrix;t.multiplyMatrices(e.projectionMatrix,e.matrixWorldInverse),this._frustum.setFromProjectionMatrix(t)}},{key:"updateRenderTarget",value:function(){if(this.light.enabledShadow){var e=this.viewer.viewerImpl.modelManager.models;for(var t in e){this.shadowScene.add(e[t].group)}var i=this.scene.renderer;i.getClearColor(this._oldClearColor),this.oldClearAlpha=i.getClearAlpha();var n=i.autoClear,r=i.getRenderTarget(),o=i.xr.enabled,a=i.shadowMap.autoUpdate;i.autoClear=!1,i.setClearColor(0,1),this.shadowScene.overrideMaterial=this.depthMaterial,i.setRenderTarget(this.renderTarget),i.clear(),i.render(this.shadowScene,this.camera),this.shadowScene.overrideMaterial=null,i.setClearColor(this._oldClearColor),i.setClearAlpha(this.oldClearAlpha),i.autoClear=n,i.xr.enabled=o,i.shadowMap.autoUpdate=a,i.setRenderTarget(r);for(var s=this.shadowScene.children,l=0,c=s.length;c>l;l+=1)this.scene.objectGroups.add(s[l])}}},{key:"updateMatrices",value:function(){}}]),i}(CT),xT=new yt,wT=new yt,MT=new Ge,ET=new Ke(1,1,1),BT=function(e){lu(i,e);var t=pu(i);function i(){var e,n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};if(ru(this,i),(e=t.call(this)).viewer=n.viewer,e.scene=e.viewer.scene,!jg(e.viewer))throw new ZM("options.viewer参数为undefined");return e.needUpdate=!0,e.type="ProjectorLight",e.position.copy(Yt.DefaultUp),e.updateMatrix(),e.target=Wg(n.target,new Ke),e._intensity=Wg(n.intensity,1),e._distance=Wg(n.distance,1e3),e._near=Wg(n.near,100),e._fov=Wg(n.fov,45),e._aspect=Wg(n.aspect,1),e._color=Wg(n.color,new pi(16777215)),e._enabledShadow=Wg(n.enabledShadow,!0),e._map=n.map,e._alphaMap=n.alphaMap,e._alpha=1,e._quaternion=MT,e._position=new Ke,e.shadow=new IT(du(e)),e._bias=Wg(n.bias,e.shadow.bias),e._uniforms={color:new pi,alpha:e._alpha,near:e.near,distance:e.distance,position:(new Ke).copy(e.position),projectorMatrix:new yt,projectorShadowMatrix:new yt,shadowMap:e.shadow.renderTarget.texture,shadow:!1,shadowBias:0,farPlane:new Le},e.isProjectorLight=!0,e}return au(i,[{key:"uniforms",get:function(){return this._uniforms}},{key:"enabledShadow",get:function(){return this._enabledShadow},set:function(e){if(this._enabledShadow!==e){var t=this.parent;jg(t)||console.warn("属性设置失败因为该对象未添加到viewer3D.rootScene.projectorLightCollection对象下"),this._enabledShadow=e,t._needsUpdate=!0}}},{key:"color",get:function(){return this._color},set:function(e){this._color.equals(e)||(this._color.copy(e),this.needUpdate=!0)}},{key:"distance",get:function(){return this._distance},set:function(e){this.distance!==e&&(this._distance=e,this.needUpdate=!0)}},{key:"near",get:function(){return this._near},set:function(e){this.near!==e&&(this._near=e,this.needUpdate=!0)}},{key:"intensity",get:function(){return this._intensity},set:function(e){this.intensity!==e&&(this._intensity=e,this.needUpdate=!0)}},{key:"fov",get:function(){return this._fov},set:function(e){this.fov!==e&&(this._fov=e,this.needUpdate=!0)}},{key:"aspect",get:function(){return this._aspect},set:function(e){this.aspect!==e&&(this._aspect=e,this.needUpdate=!0)}},{key:"alpha",get:function(){return this._alpha},set:function(e){this._alpha=e,this.needUpdate=!0}},{key:"map",get:function(){return this._map},set:function(e){this._map=e,this.needUpdate=!0}},{key:"alphaMap",get:function(){return this._alphaMap},set:function(e){jg(this.alphaMap)&&this.alphaMap.dispose(),this._alphaMap=e,this.needUpdate=!0}},{key:"shadowBias",get:function(){return this.shadow.bias},set:function(e){this.shadow.bias=e}},{key:"update",value:function(){this.visible&&this.updateUniforms()}},{key:"updateUniforms",value:function(){var e=this.shadow.camera,t=this.uniforms,i=this.viewer.rootSceneCamera;i.updateProjectionMatrix(),this.updateMatrixWorld(!0);var n=i.matrixWorldInverse;t.position.setFromMatrixPosition(this.matrixWorld),t.position.applyMatrix4(n),xT.lookAt(this.position,this.target,Ke.UNIT_Z),xT.multiply(wT.makeRotationFromEuler(this.rotation)),MT.setFromRotationMatrix(xT),xT.compose(this.position,MT,ET),wT.copy(xT).invert(),t.projectorMatrix.copy(e.projectionMatrix).multiply(wT).multiply(i.matrixWorld),t.color.copy(this.color).multiplyScalar(this.intensity),t.distance=this.distance,t.alpha=this.alpha,t.near=this.near,t.shadow=this.enabledShadow,t.shadow&&(t.shadowBias=this.shadow.bias,t.shadowMap=this.shadow.renderTarget.texture,t.projectorShadowMatrix.copy(this.shadow.matrix));var r=this.shadow._frustum.planes[4],o=r.normal;t.farPlane.set(o.x,o.y,o.z,r.constant)}},{key:"getView",value:function(){var e=[this.position,this.target,this.up],t=e[0],i=e[1],n=e[2];return{position:{x:t.x,y:t.y,z:t.z},target:{x:i.x,y:i.y,z:i.z},up:{x:n.x,y:n.y,z:n.z}}}},{key:"updateRenderTarget",value:function(){this.shadow.update(this)}},{key:"destroy",value:function(){this.map=this.map&&this.map.dispose(),this.alphaMap=this.alphaMap&&this.alphaMap.dispose(),this._uniforms=null;var e=this.shadow.renderTarget.texture;return e=e&&e.dispose(),_M(this)}}]),i}(Jg),ST=new Ke,bT=new hn;function kT(e,t,i,n,r,o,a){ST.set(r,o,a).unproject(n);var s=t[e];if(void 0!==s)for(var l=i.getAttribute("position"),c=0,h=s.length;h>c;c+=1)l.setXYZ(s[c],ST.x,ST.y,ST.z)}var DT=function(e){lu(i,e);var t=pu(i);function i(e){var n;ru(this,i);var r=e.shadow.camera,o=new Ni,a=new Sa({color:16777215,vertexColors:!0,toneMapped:!1}),s=[],l=[],c={},h=new pi(16755200),d=new pi(16711680),u=new pi(43775),p=new pi(16777215),g=new pi(3355443);function f(e,t){s.push(0,0,0),l.push(t.r,t.g,t.b),void 0===c[e]&&(c[e]=[]),c[e].push(s.length/3-1)}function m(e,t,i){f(e,i),f(t,i)}return m("n1","n2",h),m("n2","n4",h),m("n4","n3",h),m("n3","n1",h),m("f1","f2",h),m("f2","f4",h),m("f4","f3",h),m("f3","f1",h),m("n1","f1",h),m("n2","f2",h),m("n3","f3",h),m("n4","f4",h),m("p","n1",d),m("p","n2",d),m("p","n3",d),m("p","n4",d),m("u1","u2",u),m("u2","u3",u),m("u3","u1",u),m("c","t",p),m("p","c",g),m("cn1","cn2",g),m("cn3","cn4",g),m("cf1","cf2",g),m("cf3","cf4",g),o.setAttribute("position",new Bi(s,3)),o.setAttribute("color",new Bi(l,3)),(n=t.call(this,o,a)).isCamera=!0,n.type="CameraHelper",n.projectorLight=e,n.camera=r,n.camera.updateProjectionMatrix&&n.camera.updateProjectionMatrix(),n.matrix=r.matrixWorld,n.matrixAutoUpdate=!1,n.pointMap=c,n.update(),n}return au(i,[{key:"update",value:function(){var e=this.geometry,t=this.pointMap;bT.projectionMatrixInverse.copy(this.camera.projectionMatrixInverse),kT("c",t,e,bT,0,0,-1),kT("t",t,e,bT,0,0,1),kT("n1",t,e,bT,-1,-1,-1),kT("n2",t,e,bT,1,-1,-1),kT("n3",t,e,bT,-1,1,-1),kT("n4",t,e,bT,1,1,-1),kT("f1",t,e,bT,-1,-1,1),kT("f2",t,e,bT,1,-1,1),kT("f3",t,e,bT,-1,1,1),kT("f4",t,e,bT,1,1,1),kT("u1",t,e,bT,.7,1.1,-1),kT("u2",t,e,bT,-.7,1.1,-1),kT("u3",t,e,bT,0,2,-1),kT("cf1",t,e,bT,-1,0,1),kT("cf2",t,e,bT,1,0,1),kT("cf3",t,e,bT,0,-1,1),kT("cf4",t,e,bT,0,1,1),kT("cn1",t,e,bT,-1,0,-1),kT("cn2",t,e,bT,1,0,-1),kT("cn3",t,e,bT,0,-1,-1),kT("cn4",t,e,bT,0,1,-1),e.getAttribute("position").needsUpdate=!0}},{key:"updateFixedFrame",value:function(){this.visible&&(this.update(),this.lookAt(this.projectorLight.target),this.position.copy(this.projectorLight.position),this.quaternion.copy(this.projectorLight._quaternion),this.updateMatrix())}}]),i}(La),TT={};TT.ViewerConnector=eu,TT.RoadNetManager=iD,TT.Roam=ND,TT.TextLoader=VD,TT.TrackSimulator=HD,TT.Heatmap=Xb,TT.Fire=fk,TT.Smoke=function(e){e=e||{};var t=(new Dl).load("");return e.type="smoke",e.autoAnimation=!0,e.values=e.values||{},e.values=iu({name:"smoke",positionStyle:1,positionBase:new Ke(0,0,0),positionSpread:new Ke(1500,1500,600),velocityStyle:1,velocityBase:new Ke(0,0,0),velocitySpread:new Ke(1800,1800,1100),accelerationBase:new Ke(0,0,2600),particleTexture:t,sizeTween:new uk([0,1],[32,800]),opacityTween:new uk([.5,1,1.7],[0,1,0]),colorTween:new uk([.4,1],[new Ke(0,0,0),new Ke(0,0,.2)]),blendStyle:1,particlesPerSecond:120,particleDeathAge:2},e.values),e.values=[e.values],new Ak(e)},TT.Blast=mk,TT.SprayWater=Pk,TT.SprayWaterConfig=function(){this.color=new Du(231,254,255,1),this.originPosition={x:0,y:0,z:0},this.spread=1,this.scale=1,this.originPitch=0,this.originYaw=0,this.originRadius=500,this.originIntensity=.5,this.particleQuantity=1,this.viewer=null},TT.Water=jD,TT.WaterEffect=BB,TT.WaterEffectConfig=function(){this.boundary=[],this.color=new Du("#80FDFF",.8),this.scale=4,this.viewer=null,this.xDirection=1,this.yDirection=1,this.reflectivity=1,this.reflectorTexturePosition=new Ke,this.refractorTexturePosition=new Ke,this.height=0,this.geometry=null},TT.ArrowManager=bB,TT.Assemble=DB,TT.HolesAnalysis=nk;var RT={};RT.Line2=$b,RT.LineMaterial=xM,RT.LineGeometry=_b;for(var UT={},FT=Object.keys(Id),QT=0;FT.length>QT;QT+=1){var LT=FT[QT];Object.defineProperty(UT,LT,{value:Id[LT],enumerable:!0,configurable:!0,writable:!1})}e.Animation=Tp,e.ArrowDomMark=cT,e.ArrowDomMarkManager=hT,e.BOS3DMaterial=iA,e.BOSCatmullRomCurve3=uT,e.BOSCatmullRomCurve3ForFrameEdit=DD,e.BaseControl=um,e.CAMERATYPE=Md,e.Camera=Dp,e.CameraAnimator=Op,e.CameraControl=Kg,e.CameraInfo=Hp,e.CameraUtil=Zp,e.ClipPlaneService=vk,e.ClipPlanes=IM,e.ClipPlanesTool=Hg,e.CollisionDetection=function(e){this.cameraControl=e,this.intersector=e.intersector;var t=new Xp,i=new Xp,n=new Xp,r=new Xp,o=new Xp,a=new Xp;this.run=function(s,l){var c={},h=this.cameraControl.getIntersectContext(null);t.set(s,new Ke(0,0,1)),i.set(s,new Ke(0,0,-1)),o.set(s,l),a.set(s,new Ke(-l.x,-l.y,-l.z)),n.set(s,new Ke(-l.y,l.x,l.z)),r.set(s,new Ke(l.y,-l.x,l.z)),c.top=this.intersector.getIntersectByRay(h,t.ray),c.down=this.intersector.getIntersectByRay(h,i.ray),c.front=this.intersector.getIntersectByRay(h,o.ray),c.back=this.intersector.getIntersectByRay(h,a.ray),c.left=this.intersector.getIntersectByRay(h,n.ray),c.right=this.intersector.getIntersectByRay(h,r.ray);var d=new Ke(s.x,s.y,s.z-.8*e.manHeight),u=new Xp;u.set(d,l);var p=new Xp;p.set(d,new Ke(-l.x,-l.y,-l.z));var g=new Xp;g.set(d,new Ke(-l.y,l.x,l.z));var f=new Xp;return f.set(d,new Ke(l.y,-l.x,l.z)),c.frontMiddle=this.intersector.getIntersectByRay(h,u.ray),c.backMiddle=this.intersector.getIntersectByRay(h,p.ray),c.leftMiddle=this.intersector.getIntersectByRay(h,g.ray),c.rightMiddle=this.intersector.getIntersectByRay(h,f.ray),c}},e.Color=Du,e.ColorPicker=WD,e.ControlConfig=Kp,e.ControlManager=Im,e.ControlMode=Vd,e.DOMMark=nT,e.DefaultInvisibleComponentType=bd,e.DefaultMaterial=Jy,e.DeveloperError=ZM,e.DeviceTest=og,e.DomUtil=ag,e.DrawingStyle=jd,e.EVENTS=Fd,e.EasingFunction=kE,e.Edge=nf,e.EnumCesiumImageryLayerType={AUTO:0,BAIDU:1,GAODE:2,MAPBOX:3,ARCGIS:4,GOOGLE:5},e.EnumConditionType={HIDDEN_OTHERS:0,TRANSLUCENT_OTHERS:1,OVERRIDE:2,BORDERLINE:3},e.EnumDataProvider=zd,e.EnumFilterState=Zd,e.EnumIdBasedType=Od,e.EnumInstanceState=Wd,e.EnumIsolateState=Pd,e.EnumLengthlUnits=_d,e.EnumObjectState=Nd,e.EnumRenderType={RENDER:0,RENDER_FINISHED:1,RESIZE:2},e.EnumRendererType={AUTO:0,FULL:1,INCREMENT:2},e.EnumSceneState=Kd,e.EnumShaderColorState=Jd,e.EnumStandardView=kd,e.EnumTransparentState=Gd,e.EnumUserType={HIDDEN_DATA:0,OVERRIDE_DATA:1,WITH_BOARDLINE:2},e.EventDispatcher=hg,e.ExternalObjectConverter=mT,e.ExternalObjectNodeInfo=fT,e.ExternalObjectNodeInfoType=gT,e.ExternalScene=LE,e.FatLine=ek,e.FillClipPlane=jM,e.FillClipPlaneTool=tf,e.FilterResultMode=qd,e.FullScreen=zD,e.GLTFLoader=cM,e.GUI=XC,e.GeomUtil=by,e.GlobalData=xd,e.Group=cm,e.HTMLMarker=ik,e.HTMLMarkerCollection=DE,e.IDENTITYMATRIX3=Bd,e.IDENTITYMATRIX4=Ed,e.IntersectHelper=tg,e.KDNode=jy,e.LOADERROREVENTS=Qd,e.LightType=Dd,e.LineSegmentsEx=ov,e.LogLevels=Iu,e.MaterialEx=HE,e.MaterialUtil=cA,e.MathUtils=be,e.MeasureTool=em,e.MeasurementManager=dT,e.MeshEx=Bv,e.ModelType=Xd,e.MoveDirection=Hd,e.NodeItemType={SYMBOL:0,MESH:1,TUBE:2,PIPE:3,BOX:4,BOX_M:5,PIPE_M:6,MESH_REF:7,LINE:8},e.NoiseTextureType=nA,e.NormalControl=gm,e.OPSELECTIONTYPE=Td,e.Object3D=Yt,e.Object3DCollection=Jg,e.OrbitControl=mm,e.PICKABLETYPE=Rd,e.PhongLightingMaterial=ig,e.PickControl=fm,e.PickHelper=pf,e.PickUtil=rm,e.PlaneMark=rT,e.Plugins=TT,e.PrimitiveCount={vertexCount:0,triangleCount:0},e.ProjectorHelper=DT,e.ProjectorLight=BT,e.ProjectorLightCollection=CE,e.ProjectorLightShadow=IT,e.Raycaster=Xp,e.RectOpTool=om,e.RectPickTool=am,e.RectZoomTool=sm,e.Roam=oD,e.RoamManager=sD,e.RoamPlayer=aD,e.RotatePivotMode=Ld,e.RotationOrders=wd,e.SVGRect=Ck,e.Scene=KE,e.SceneStateHelper=VE,e.SectionPlane=tT,e.ShaderChunk=xn,e.SpriteMark=oT,e.StorageCache=_C,e.THREE=UT,e.THREEEX=RT,e.ThreeMark=aT,e.TimeConstants=EE,e.Tool=Yg,e.ToolMode=Yd,e.TransformMode={translate:0,rotate:1,scale:2},e.TransformSpace=zg,e.UI={},e.UniformsLib=wn,e.Utils=wp,e.Vector3=Ke,e.Version="5.0.0",e.ViewController=Rk,e.Viewer=Uk,e.ViewerImpl=xB,e.WalkControl=Cm,e.WordPlaneMark=sT,e.ajax=Yy,e.buildEdge=af,e.clone=IE,e.createNoiseTexture=lA,e.cubeTextureLoaderObject=xE,e.defaultValue=Wg,e.defined=jg,e.destroyObject=_M,e.fileLoaderObject=ME,e.getFaceIndex=sf,e.getScript=function(e,t){var i={};if(i[e])t&&t();else{var n=document.createElement("script");n.type="text/javascript",n.src=e,document.head.appendChild(n),i[e]=!0,n.readyState?n.onreadystatechange=function(){"loaded"!==n.readyState&&"complete"!==n.readyState||(n.onreadystatechange=null,t&&t())}:n.onload=function(){t&&t()}}},e.i18nMessage=rg,e.logger=Bu,e.projectorLight_fragment=Hm,e.projector_lights_pars_begin=Ym,e.removeDuplicateIndex=rf,e.removeDuplicateVertex=of,e.standardView={Keep:0,Home:135,Top:1,Bottom:2,Front:3,Back:4,Right:5,Left:6,TopFrontRight:135,TopFrontLeft:136,TopBackRight:145,TopBackLeft:146,BottomFrontRight:235,BottomFrontLeft:236,BottomBackRight:245,BottomBackLeft:246,TopFront:13,TopBack:14,TopRight:15,TopLeft:16,BottomFront:23,BottomBack:24,BottomRight:25,BottomLeft:26,FrontRight:35,FrontLeft:36,BackRight:45,BackLeft:46,TopToRight:105,TopToLeft:106,TopToFront:103,TopToBack:104,BottomToRight:205,BottomToLeft:206,BottomToFront:203,BottomToBack:204,FrontToTop:301,FrontToBottom:302,FrontToRight:305,FrontToLeft:306,BackToTop:401,BackToBottom:402,BackToRight:405,BackToLeft:406,RightToTop:501,RightToBottom:502,RightToFront:503,RightToBack:504,LeftToTop:601,LeftTopBottom:602,LeftTopFront:603,LeftTopBack:604},e.textureLoaderObject=wE,Object.defineProperty(e,"__esModule",{value:!0})}));
//# sourceMappingURL=BOS3D.min.js.map