gl-draw 0.4.6 → 0.4.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -3174,4 +3174,4 @@ void main() {
3174
3174
  gl_FragColor.a *= step(vCounters, visibility);
3175
3175
  `).concat(Me.fog_fragment,`
3176
3176
  }
3177
- `),xn=function(r){"use strict";fh(t,r);var e=ph(t);function t(){hh(this,t);var n;return n=e.call(this),n.isMeshLine=!0,n.type="MeshLine",n.positions=[],n.previous=[],n.next=[],n.side=[],n.width=[],n.indices_array=[],n.uvs=[],n.counters=[],n._points=[],n._geom=null,n.widthCallback=null,n.matrixWorld=new pe,Object.defineProperties(nl(n),{geometry:{enumerable:!0,get:function(){return this}},geom:{enumerable:!0,get:function(){return this._geom},set:function(s){this.setGeometry(s,this.widthCallback)}},points:{enumerable:!0,get:function(){return this._points},set:function(s){this.setPoints(s,this.widthCallback)}}}),n}return t}(ve);xn.prototype.setMatrixWorld=function(r){this.matrixWorld=r},xn.prototype.setGeometry=function(r,e){this._geometry=r,this.setPoints(r.getAttribute("position").array,e)},xn.prototype.setPoints=function(r,e){if(!(r instanceof Float32Array)&&!(r instanceof Array)){console.error("ERROR: The BufferArray of points is not instancied correctly.");return}if(this._points=r,this.widthCallback=e,this.positions=[],this.counters=[],r.length&&r[0]instanceof S)for(var t=0;t<r.length;t++){var n=r[t],i=t/r.length;this.positions.push(n.x,n.y,n.z),this.positions.push(n.x,n.y,n.z),this.counters.push(i),this.counters.push(i)}else for(var t=0;t<r.length;t+=3){var i=t/r.length;this.positions.push(r[t],r[t+1],r[t+2]),this.positions.push(r[t],r[t+1],r[t+2]),this.counters.push(i),this.counters.push(i)}this.process()};function Sy(r,e){var t=new pe,n=new Tn,i=new wn,s=new S,o=this.geometry;if(o.boundingSphere||o.computeBoundingSphere(),i.copy(o.boundingSphere),i.applyMatrix4(this.matrixWorld),r.ray.intersectSphere(i,s)!==!1){t.copy(this.matrixWorld).invert(),n.copy(r.ray).applyMatrix4(t);var a=new S,l=new S,c=new S,u=this instanceof fn?2:1,h=o.index,f=o.attributes;if(h!==null)for(var d=h.array,m=f.position.array,x=f.width.array,v=0,g=d.length-1;v<g;v+=u){var p=d[v],_=d[v+1];a.fromArray(m,p*3),l.fromArray(m,_*3);var y=x[Math.floor(v/3)]!==void 0?x[Math.floor(v/3)]:1,M=r.params.Line.threshold+this.material.lineWidth*y/2,w=M*M,A=n.distanceSqToSegment(a,l,s,c);if(!(A>w)){s.applyMatrix4(this.matrixWorld);var C=r.ray.origin.distanceTo(s);C<r.near||C>r.far||(e.push({distance:C,point:c.clone().applyMatrix4(this.matrixWorld),index:v,face:null,faceIndex:null,object:this}),v=g)}}}}xn.prototype.raycast=Sy,xn.prototype.compareV3=function(r,e){var t=r*6,n=e*6;return this.positions[t]===this.positions[n]&&this.positions[t+1]===this.positions[n+1]&&this.positions[t+2]===this.positions[n+2]},xn.prototype.copyV3=function(r){var e=r*6;return[this.positions[e],this.positions[e+1],this.positions[e+2]]},xn.prototype.process=function(){var r=this.positions.length/6;this.previous=[],this.next=[],this.side=[],this.width=[],this.indices_array=[],this.uvs=[];var e,t;this.compareV3(0,r-1)?t=this.copyV3(r-2):t=this.copyV3(0),this.previous.push(t[0],t[1],t[2]),this.previous.push(t[0],t[1],t[2]);for(var n=0;n<r;n++){if(this.side.push(1),this.side.push(-1),this.widthCallback?e=this.widthCallback(n/(r-1)):e=1,this.width.push(e),this.width.push(e),this.uvs.push(n/(r-1),0),this.uvs.push(n/(r-1),1),n<r-1){t=this.copyV3(n),this.previous.push(t[0],t[1],t[2]),this.previous.push(t[0],t[1],t[2]);var i=n*2;this.indices_array.push(i,i+1,i+2),this.indices_array.push(i+2,i+1,i+3)}n>0&&(t=this.copyV3(n),this.next.push(t[0],t[1],t[2]),this.next.push(t[0],t[1],t[2]))}this.compareV3(r-1,0)?t=this.copyV3(1):t=this.copyV3(r-1),this.next.push(t[0],t[1],t[2]),this.next.push(t[0],t[1],t[2]),!this._attributes||this._attributes.position.count!==this.positions.length?this._attributes={position:new ze(new Float32Array(this.positions),3),previous:new ze(new Float32Array(this.previous),3),next:new ze(new Float32Array(this.next),3),side:new ze(new Float32Array(this.side),1),width:new ze(new Float32Array(this.width),1),uv:new ze(new Float32Array(this.uvs),2),index:new ze(new Uint16Array(this.indices_array),1),counters:new ze(new Float32Array(this.counters),1)}:(this._attributes.position.copyArray(new Float32Array(this.positions)),this._attributes.position.needsUpdate=!0,this._attributes.previous.copyArray(new Float32Array(this.previous)),this._attributes.previous.needsUpdate=!0,this._attributes.next.copyArray(new Float32Array(this.next)),this._attributes.next.needsUpdate=!0,this._attributes.side.copyArray(new Float32Array(this.side)),this._attributes.side.needsUpdate=!0,this._attributes.width.copyArray(new Float32Array(this.width)),this._attributes.width.needsUpdate=!0,this._attributes.uv.copyArray(new Float32Array(this.uvs)),this._attributes.uv.needsUpdate=!0,this._attributes.index.copyArray(new Uint16Array(this.indices_array)),this._attributes.index.needsUpdate=!0),this.setAttribute("position",this._attributes.position),this.setAttribute("previous",this._attributes.previous),this.setAttribute("next",this._attributes.next),this.setAttribute("side",this._attributes.side),this.setAttribute("width",this._attributes.width),this.setAttribute("uv",this._attributes.uv),this.setAttribute("counters",this._attributes.counters),this.setIndex(this._attributes.index),this.computeBoundingSphere(),this.computeBoundingBox()};function sl(r,e,t,n,i){var s;if(r=r.subarray||r.slice?r:r.buffer,t=t.subarray||t.slice?t:t.buffer,r=e?r.subarray?r.subarray(e,i&&e+i):r.slice(e,i&&e+i):r,t.set)t.set(r,n);else for(s=0;s<r.length;s++)t[s+n]=r[s];return t}xn.prototype.advance=function(r){var e=this._attributes.position.array,t=this._attributes.previous.array,n=this._attributes.next.array,i=e.length;sl(e,0,t,0,i),sl(e,6,e,0,i-6),e[i-6]=r.x,e[i-5]=r.y,e[i-4]=r.z,e[i-3]=r.x,e[i-2]=r.y,e[i-1]=r.z,sl(e,6,n,0,i-6),n[i-6]=r.x,n[i-5]=r.y,n[i-4]=r.z,n[i-3]=r.x,n[i-2]=r.y,n[i-1]=r.z,this._attributes.position.needsUpdate=!0,this._attributes.previous.needsUpdate=!0,this._attributes.next.needsUpdate=!0},Me.meshline_vert=by,Me.meshline_frag=wy;var Ty=function(r){"use strict";fh(t,r);var e=ph(t);function t(n){hh(this,t);var i;return i=e.call(this,{uniforms:Object.assign({},oe.fog,{lineWidth:{value:1},map:{value:null},useMap:{value:0},alphaMap:{value:null},useAlphaMap:{value:0},color:{value:new le(16777215)},opacity:{value:1},resolution:{value:new q(1,1)},sizeAttenuation:{value:1},dashArray:{value:0},dashOffset:{value:0},dashRatio:{value:.5},useDash:{value:0},visibility:{value:1},alphaTest:{value:0},repeat:{value:new q(1,1)},offset:{value:new q(1,1)},lineLightAnimation:{value:1},time:{value:0},size:{value:300},speed:{value:.3},lightWidth:{value:.1},uCenter:{value:new q(0,0)},lightColor:{value:new le(16777215)}}),vertexShader:Me.meshline_vert,fragmentShader:Me.meshline_frag}),i.isMeshLineMaterial=!0,i.type="MeshLineMaterial",Object.defineProperties(nl(i),{lineWidth:{enumerable:!0,get:function(){return this.uniforms.lineWidth.value},set:function(o){this.uniforms.lineWidth.value=o}},lineLightAnimation:{enumerable:!0,get:function(){return this.uniforms.lineLightAnimation.value},set:function(o){this.uniforms.lineLightAnimation.value=o}},map:{enumerable:!0,get:function(){return this.uniforms.map.value},set:function(o){this.uniforms.map.value=o}},useMap:{enumerable:!0,get:function(){return this.uniforms.useMap.value},set:function(o){this.uniforms.useMap.value=o}},alphaMap:{enumerable:!0,get:function(){return this.uniforms.alphaMap.value},set:function(o){this.uniforms.alphaMap.value=o}},useAlphaMap:{enumerable:!0,get:function(){return this.uniforms.useAlphaMap.value},set:function(o){this.uniforms.useAlphaMap.value=o}},color:{enumerable:!0,get:function(){return this.uniforms.color.value},set:function(o){this.uniforms.color.value=o}},lightColor:{enumerable:!0,get:function(){return this.uniforms.lightColor.value},set:function(o){this.uniforms.lightColor.value=o}},time:{enumerable:!0,get:function(){return this.uniforms.time.value},set:function(o){this.uniforms.time.value=o}},uCenter:{enumerable:!0,get:function(){return this.uniforms.uCenter.value},set:function(o){this.uniforms.uCenter.value=o}},size:{enumerable:!0,get:function(){return this.uniforms.size.value},set:function(o){this.uniforms.size.value=o}},opacity:{enumerable:!0,get:function(){return this.uniforms.opacity.value},set:function(o){this.uniforms.opacity.value=o}},resolution:{enumerable:!0,get:function(){return this.uniforms.resolution.value},set:function(o){this.uniforms.resolution.value.copy(o)}},sizeAttenuation:{enumerable:!0,get:function(){return this.uniforms.sizeAttenuation.value},set:function(o){this.uniforms.sizeAttenuation.value=o}},dashArray:{enumerable:!0,get:function(){return this.uniforms.dashArray.value},set:function(o){this.uniforms.dashArray.value=o,this.useDash=o!==0?1:0}},dashOffset:{enumerable:!0,get:function(){return this.uniforms.dashOffset.value},set:function(o){this.uniforms.dashOffset.value=o}},dashRatio:{enumerable:!0,get:function(){return this.uniforms.dashRatio.value},set:function(o){this.uniforms.dashRatio.value=o}},useDash:{enumerable:!0,get:function(){return this.uniforms.useDash.value},set:function(o){this.uniforms.useDash.value=o}},visibility:{enumerable:!0,get:function(){return this.uniforms.visibility.value},set:function(o){this.uniforms.visibility.value=o}},alphaTest:{enumerable:!0,get:function(){return this.uniforms.alphaTest.value},set:function(o){this.uniforms.alphaTest.value=o}},repeat:{enumerable:!0,get:function(){return this.uniforms.repeat.value},set:function(o){this.uniforms.repeat.value.copy(o)}}}),i.setValues(n),i}return t}(Yt);Ty.prototype.copy=function(r){return Yt.prototype.copy.call(this,r),this.lineWidth=r.lineWidth,this.map=r.map,this.useMap=r.useMap,this.alphaMap=r.alphaMap,this.useAlphaMap=r.useAlphaMap,this.color.copy(r.color),this.opacity=r.opacity,this.resolution.copy(r.resolution),this.sizeAttenuation=r.sizeAttenuation,this.dashArray.copy(r.dashArray),this.dashOffset.copy(r.dashOffset),this.dashRatio.copy(r.dashRatio),this.useDash=r.useDash,this.visibility=r.visibility,this.alphaTest=r.alphaTest,this.repeat.copy(r.repeat),this};function Ey(r){var e=r.setPointWidth,t=r.nodes,n=new ve,i=new xn;return n.setFromPoints(t),i.setGeometry(n,e),i}function Ay(r){if(Array.isArray(r))return r}function Ly(){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 mh(r,e){return Ay(r)||tr(r,e)||Gr(r,e)||Ly()}var Je=1e-6,Cy=1e-12,Ne=Math.PI,Rt=Ne/2,gh=Ne/4,Ht=Ne*2,Ft=180/Ne,ut=Ne/180,st=Math.abs,xh=Math.atan,Br=Math.atan2,ot=Math.cos,GM=Math.ceil,Ry=Math.exp,VM=Math.floor,kM=Math.hypot,Py=Math.log,WM=Math.pow,et=Math.sin,Iy=Math.sign||function(r){return r>0?1:r<0?-1:0},go=Math.sqrt,Dy=Math.tan;function Fy(r){return r>1?0:r<-1?Ne:Math.acos(r)}function zr(r){return r>1?Rt:r<-1?-Rt:Math.asin(r)}function qM(r){return(r=et(r/2))*r}function ol(r,e){function t(n,i){return n=r(n,i),e(n[0],n[1])}return r.invert&&e.invert&&(t.invert=function(n,i){return n=e.invert(n,i),n&&r.invert(n[0],n[1])}),t}function al(r,e){return[st(r)>Ne?r+Math.round(-r/Ht)*Ht:r,e]}al.invert=al;function yh(r,e,t){return(r%=Ht)?e||t?ol(_h(r),Mh(e,t)):_h(r):e||t?Mh(e,t):al}function vh(r){return function(e,t){return e+=r,[e>Ne?e-Ht:e<-Ne?e+Ht:e,t]}}function _h(r){var e=vh(r);return e.invert=vh(-r),e}function Mh(r,e){var t=ot(r),n=et(r),i=ot(e),s=et(e);function o(a,l){var c=ot(l),u=ot(a)*c,h=et(a)*c,f=et(l),d=f*t+u*n;return[Br(h*i-d*s,u*t-f*n),zr(d*i+h*s)]}return o.invert=function(a,l){var c=ot(l),u=ot(a)*c,h=et(a)*c,f=et(l),d=f*i-h*s;return[Br(h*i+f*s,u*t+d*n),zr(d*t-u*n)]},o}function By(r){r=yh(r[0]*ut,r[1]*ut,r.length>2?r[2]*ut:0);function e(t){return t=r(t[0]*ut,t[1]*ut),t[0]*=Ft,t[1]*=Ft,t}return e.invert=function(t){return t=r.invert(t[0]*ut,t[1]*ut),t[0]*=Ft,t[1]*=Ft,t},e}function Nr(){}function bh(){var r=[],e;return{point:function(t,n,i){e.push([t,n,i])},lineStart:function(){r.push(e=[])},lineEnd:Nr,rejoin:function(){r.length>1&&r.push(r.pop().concat(r.shift()))},result:function(){var t=r;return r=[],e=null,t}}}function xo(r,e){return st(r[0]-e[0])<Je&&st(r[1]-e[1])<Je}function yo(r,e,t,n){this.x=r,this.z=e,this.o=t,this.e=n,this.v=!1,this.n=this.p=null}function wh(r,e,t,n,i){var s=[],o=[],a,l;if(r.forEach(function(m){if(!((x=m.length-1)<=0)){var x,v=m[0],g=m[x],p;if(xo(v,g)){if(!v[2]&&!g[2]){for(i.lineStart(),a=0;a<x;++a)i.point((v=m[a])[0],v[1]);i.lineEnd();return}g[0]+=2*Je}s.push(p=new yo(v,m,null,!0)),o.push(p.o=new yo(v,null,p,!1)),s.push(p=new yo(g,m,null,!1)),o.push(p.o=new yo(g,null,p,!0))}}),!!s.length){for(o.sort(e),Sh(s),Sh(o),a=0,l=o.length;a<l;++a)o[a].e=t=!t;for(var c=s[0],u,h;;){for(var f=c,d=!0;f.v;)if((f=f.n)===c)return;u=f.z,i.lineStart();do{if(f.v=f.o.v=!0,f.e){if(d)for(a=0,l=u.length;a<l;++a)i.point((h=u[a])[0],h[1]);else n(f.x,f.n.x,1,i);f=f.n}else{if(d)for(u=f.p.z,a=u.length-1;a>=0;--a)i.point((h=u[a])[0],h[1]);else n(f.x,f.p.x,-1,i);f=f.p}f=f.o,u=f.z,d=!d}while(!f.v);i.lineEnd()}}}function Sh(r){if(!!(e=r.length)){for(var e,t=0,n=r[0],i;++t<e;)n.n=i=r[t],i.p=n,n=i;n.n=i=r[0],i.p=n}}class ll{constructor(){this._partials=new Float64Array(32),this._n=0}add(e){const t=this._partials;let n=0;for(let i=0;i<this._n&&i<32;i++){const s=t[i],o=e+s,a=Math.abs(e)<Math.abs(s)?e-(o-s):s-(o-e);a&&(t[n++]=a),e=o}return t[n]=e,this._n=n+1,this}valueOf(){const e=this._partials;let t=this._n,n,i,s,o=0;if(t>0){for(o=e[--t];t>0&&(n=o,i=e[--t],o=n+i,s=i-(o-n),!s););t>0&&(s<0&&e[t-1]<0||s>0&&e[t-1]>0)&&(i=s*2,n=o+i,i==n-o&&(o=n))}return o}}function XM(r,e){const t=new ll;if(e===void 0)for(let n of r)(n=+n)&&t.add(n);else{let n=-1;for(let i of r)(i=+e(i,++n,r))&&t.add(i)}return+t}function YM(r,e){const t=new ll;let n=-1;return Float64Array.from(r,e===void 0?i=>t.add(+i||0):i=>t.add(+e(i,++n,r)||0))}function cl(r){return[Br(r[1],r[0]),zr(r[2])]}function ji(r){var e=r[0],t=r[1],n=ot(t);return[n*ot(e),n*et(e),et(t)]}function vo(r,e){return r[0]*e[0]+r[1]*e[1]+r[2]*e[2]}function _o(r,e){return[r[1]*e[2]-r[2]*e[1],r[2]*e[0]-r[0]*e[2],r[0]*e[1]-r[1]*e[0]]}function ul(r,e){r[0]+=e[0],r[1]+=e[1],r[2]+=e[2]}function Mo(r,e){return[r[0]*e,r[1]*e,r[2]*e]}function hl(r){var e=go(r[0]*r[0]+r[1]*r[1]+r[2]*r[2]);r[0]/=e,r[1]/=e,r[2]/=e}function fl(r){return st(r[0])<=Ne?r[0]:Iy(r[0])*((st(r[0])+Ne)%Ht-Ne)}function zy(r,e){var t=fl(e),n=e[1],i=et(n),s=[et(t),-ot(t),0],o=0,a=0,l=new ll;i===1?n=Rt+Je:i===-1&&(n=-Rt-Je);for(var c=0,u=r.length;c<u;++c)if(!!(f=(h=r[c]).length))for(var h,f,d=h[f-1],m=fl(d),x=d[1]/2+gh,v=et(x),g=ot(x),p=0;p<f;++p,m=y,v=w,g=A,d=_){var _=h[p],y=fl(_),M=_[1]/2+gh,w=et(M),A=ot(M),C=y-m,N=C>=0?1:-1,z=N*C,I=z>Ne,b=v*w;if(l.add(Br(b*N*et(z),g*A+b*ot(z))),o+=I?C+N*Ht:C,I^m>=t^y>=t){var T=_o(ji(d),ji(_));hl(T);var B=_o(s,T);hl(B);var R=(I^C>=0?-1:1)*zr(B[2]);(n>R||n===R&&(T[0]||T[1]))&&(a+=I^C>=0?1:-1)}}return(o<-Je||o<Je&&l<-Cy)^a&1}function*Ny(r){for(const e of r)yield*e}function Th(r){return Array.from(Ny(r))}function Eh(r,e,t,n){return function(i){var s=e(i),o=bh(),a=e(o),l=!1,c,u,h,f={point:d,lineStart:x,lineEnd:v,polygonStart:function(){f.point=g,f.lineStart=p,f.lineEnd=_,u=[],c=[]},polygonEnd:function(){f.point=d,f.lineStart=x,f.lineEnd=v,u=Th(u);var y=zy(c,n);u.length?(l||(i.polygonStart(),l=!0),wh(u,Oy,y,t,i)):y&&(l||(i.polygonStart(),l=!0),i.lineStart(),t(null,null,1,i),i.lineEnd()),l&&(i.polygonEnd(),l=!1),u=c=null},sphere:function(){i.polygonStart(),i.lineStart(),t(null,null,1,i),i.lineEnd(),i.polygonEnd()}};function d(y,M){r(y,M)&&i.point(y,M)}function m(y,M){s.point(y,M)}function x(){f.point=m,s.lineStart()}function v(){f.point=d,s.lineEnd()}function g(y,M){h.push([y,M]),a.point(y,M)}function p(){a.lineStart(),h=[]}function _(){g(h[0][0],h[0][1]),a.lineEnd();var y=a.clean(),M=o.result(),w,A=M.length,C,N,z;if(h.pop(),c.push(h),h=null,!!A){if(y&1){if(N=M[0],(C=N.length-1)>0){for(l||(i.polygonStart(),l=!0),i.lineStart(),w=0;w<C;++w)i.point((z=N[w])[0],z[1]);i.lineEnd()}return}A>1&&y&2&&M.push(M.pop().concat(M.shift())),u.push(M.filter(Uy))}}return f}}function Uy(r){return r.length>1}function Oy(r,e){return((r=r.x)[0]<0?r[1]-Rt-Je:Rt-r[1])-((e=e.x)[0]<0?e[1]-Rt-Je:Rt-e[1])}var Ah=Eh(function(){return!0},Hy,Vy,[-Ne,-Rt]);function Hy(r){var e=NaN,t=NaN,n=NaN,i;return{lineStart:function(){r.lineStart(),i=1},point:function(s,o){var a=s>0?Ne:-Ne,l=st(s-e);st(l-Ne)<Je?(r.point(e,t=(t+o)/2>0?Rt:-Rt),r.point(n,t),r.lineEnd(),r.lineStart(),r.point(a,t),r.point(s,t),i=0):n!==a&&l>=Ne&&(st(e-n)<Je&&(e-=n*Je),st(s-a)<Je&&(s-=a*Je),t=Gy(e,t,s,o),r.point(n,t),r.lineEnd(),r.lineStart(),r.point(a,t),i=0),r.point(e=s,t=o),n=a},lineEnd:function(){r.lineEnd(),e=t=NaN},clean:function(){return 2-i}}}function Gy(r,e,t,n){var i,s,o=et(r-t);return st(o)>Je?xh((et(e)*(s=ot(n))*et(t)-et(n)*(i=ot(e))*et(r))/(i*s*o)):(e+n)/2}function Vy(r,e,t,n){var i;if(r==null)i=t*Rt,n.point(-Ne,i),n.point(0,i),n.point(Ne,i),n.point(Ne,0),n.point(Ne,-i),n.point(0,-i),n.point(-Ne,-i),n.point(-Ne,0),n.point(-Ne,i);else if(st(r[0]-e[0])>Je){var s=r[0]<e[0]?Ne:-Ne;i=t*s/2,n.point(-s,i),n.point(0,i),n.point(s,i)}else n.point(e[0],e[1])}function Lh(r,e,t,n,i,s){if(!!t){var o=ot(e),a=et(e),l=n*t;i==null?(i=e+n*Ht,s=e-l/2):(i=Ch(o,i),s=Ch(o,s),(n>0?i<s:i>s)&&(i+=n*Ht));for(var c,u=i;n>0?u>s:u<s;u-=l)c=cl([o,-a*ot(u),-a*et(u)]),r.point(c[0],c[1])}}function Ch(r,e){e=ji(e),e[0]-=r,hl(e);var t=Fy(-e[1]);return((-e[2]<0?-t:t)+Ht-Je)%Ht}function JM(){var r=constant([0,0]),e=constant(90),t=constant(6),n,i,s={point:o};function o(l,c){n.push(l=i(l,c)),l[0]*=degrees,l[1]*=degrees}function a(){var l=r.apply(this,arguments),c=e.apply(this,arguments)*radians,u=t.apply(this,arguments)*radians;return n=[],i=rotateRadians(-l[0]*radians,-l[1]*radians,0).invert,Lh(s,c,u,1),l={type:"Polygon",coordinates:[n]},n=i=null,l}return a.center=function(l){return arguments.length?(r=typeof l=="function"?l:constant([+l[0],+l[1]]),a):r},a.radius=function(l){return arguments.length?(e=typeof l=="function"?l:constant(+l),a):e},a.precision=function(l){return arguments.length?(t=typeof l=="function"?l:constant(+l),a):t},a}function ky(r){var e=ot(r),t=6*ut,n=e>0,i=st(e)>Je;function s(u,h,f,d){Lh(d,r,t,f,u,h)}function o(u,h){return ot(u)*ot(h)>e}function a(u){var h,f,d,m,x;return{lineStart:function(){m=d=!1,x=1},point:function(v,g){var p=[v,g],_,y=o(v,g),M=n?y?0:c(v,g):y?c(v+(v<0?Ne:-Ne),g):0;if(!h&&(m=d=y)&&u.lineStart(),y!==d&&(_=l(h,p),(!_||xo(h,_)||xo(p,_))&&(p[2]=1)),y!==d)x=0,y?(u.lineStart(),_=l(p,h),u.point(_[0],_[1])):(_=l(h,p),u.point(_[0],_[1],2),u.lineEnd()),h=_;else if(i&&h&&n^y){var w;!(M&f)&&(w=l(p,h,!0))&&(x=0,n?(u.lineStart(),u.point(w[0][0],w[0][1]),u.point(w[1][0],w[1][1]),u.lineEnd()):(u.point(w[1][0],w[1][1]),u.lineEnd(),u.lineStart(),u.point(w[0][0],w[0][1],3)))}y&&(!h||!xo(h,p))&&u.point(p[0],p[1]),h=p,d=y,f=M},lineEnd:function(){d&&u.lineEnd(),h=null},clean:function(){return x|(m&&d)<<1}}}function l(u,h,f){var d=ji(u),m=ji(h),x=[1,0,0],v=_o(d,m),g=vo(v,v),p=v[0],_=g-p*p;if(!_)return!f&&u;var y=e*g/_,M=-e*p/_,w=_o(x,v),A=Mo(x,y),C=Mo(v,M);ul(A,C);var N=w,z=vo(A,N),I=vo(N,N),b=z*z-I*(vo(A,A)-1);if(!(b<0)){var T=go(b),B=Mo(N,(-z-T)/I);if(ul(B,A),B=cl(B),!f)return B;var R=u[0],F=h[0],U=u[1],Z=h[1],ee;F<R&&(ee=R,R=F,F=ee);var V=F-R,W=st(V-Ne)<Je,ne=W||V<Je;if(!W&&Z<U&&(ee=U,U=Z,Z=ee),ne?W?U+Z>0^B[1]<(st(B[0]-R)<Je?U:Z):U<=B[1]&&B[1]<=Z:V>Ne^(R<=B[0]&&B[0]<=F)){var K=Mo(N,(-z+T)/I);return ul(K,A),[B,cl(K)]}}}function c(u,h){var f=n?r:Ne-r,d=0;return u<-f?d|=1:u>f&&(d|=2),h<-f?d|=4:h>f&&(d|=8),d}return Eh(o,a,s,n?[0,-r]:[-Ne,r-Ne])}function Wy(r,e,t,n,i,s){var o=r[0],a=r[1],l=e[0],c=e[1],u=0,h=1,f=l-o,d=c-a,m;if(m=t-o,!(!f&&m>0)){if(m/=f,f<0){if(m<u)return;m<h&&(h=m)}else if(f>0){if(m>h)return;m>u&&(u=m)}if(m=i-o,!(!f&&m<0)){if(m/=f,f<0){if(m>h)return;m>u&&(u=m)}else if(f>0){if(m<u)return;m<h&&(h=m)}if(m=n-a,!(!d&&m>0)){if(m/=d,d<0){if(m<u)return;m<h&&(h=m)}else if(d>0){if(m>h)return;m>u&&(u=m)}if(m=s-a,!(!d&&m<0)){if(m/=d,d<0){if(m>h)return;m>u&&(u=m)}else if(d>0){if(m<u)return;m<h&&(h=m)}return u>0&&(r[0]=o+u*f,r[1]=a+u*d),h<1&&(e[0]=o+h*f,e[1]=a+h*d),!0}}}}}var Ur=1e9,bo=-Ur;function qy(r,e,t,n){function i(c,u){return r<=c&&c<=t&&e<=u&&u<=n}function s(c,u,h,f){var d=0,m=0;if(c==null||(d=o(c,h))!==(m=o(u,h))||l(c,u)<0^h>0)do f.point(d===0||d===3?r:t,d>1?n:e);while((d=(d+h+4)%4)!==m);else f.point(u[0],u[1])}function o(c,u){return st(c[0]-r)<Je?u>0?0:3:st(c[0]-t)<Je?u>0?2:1:st(c[1]-e)<Je?u>0?1:0:u>0?3:2}function a(c,u){return l(c.x,u.x)}function l(c,u){var h=o(c,1),f=o(u,1);return h!==f?h-f:h===0?u[1]-c[1]:h===1?c[0]-u[0]:h===2?c[1]-u[1]:u[0]-c[0]}return function(c){var u=c,h=bh(),f,d,m,x,v,g,p,_,y,M,w,A={point:C,lineStart:b,lineEnd:T,polygonStart:z,polygonEnd:I};function C(R,F){i(R,F)&&u.point(R,F)}function N(){for(var R=0,F=0,U=d.length;F<U;++F)for(var Z=d[F],ee=1,V=Z.length,W=Z[0],ne,K,he=W[0],be=W[1];ee<V;++ee)ne=he,K=be,W=Z[ee],he=W[0],be=W[1],K<=n?be>n&&(he-ne)*(n-K)>(be-K)*(r-ne)&&++R:be<=n&&(he-ne)*(n-K)<(be-K)*(r-ne)&&--R;return R}function z(){u=h,f=[],d=[],w=!0}function I(){var R=N(),F=w&&R,U=(f=Th(f)).length;(F||U)&&(c.polygonStart(),F&&(c.lineStart(),s(null,null,1,c),c.lineEnd()),U&&wh(f,a,R,s,c),c.polygonEnd()),u=c,f=d=m=null}function b(){A.point=B,d&&d.push(m=[]),M=!0,y=!1,p=_=NaN}function T(){f&&(B(x,v),g&&y&&h.rejoin(),f.push(h.result())),A.point=C,y&&u.lineEnd()}function B(R,F){var U=i(R,F);if(d&&m.push([R,F]),M)x=R,v=F,g=U,M=!1,U&&(u.lineStart(),u.point(R,F));else if(U&&y)u.point(R,F);else{var Z=[p=Math.max(bo,Math.min(Ur,p)),_=Math.max(bo,Math.min(Ur,_))],ee=[R=Math.max(bo,Math.min(Ur,R)),F=Math.max(bo,Math.min(Ur,F))];Wy(Z,ee,r,e,t,n)?(y||(u.lineStart(),u.point(Z[0],Z[1])),u.point(ee[0],ee[1]),U||u.lineEnd(),w=!1):U&&(u.lineStart(),u.point(R,F),w=!1)}p=R,_=F,y=U}return A}}var Rh=r=>r;function ZM(r){return{stream:wo(r)}}function wo(r){return function(e){var t=new dl;for(var n in r)t[n]=r[n];return t.stream=e,t}}function dl(){}dl.prototype={constructor:dl,point:function(r,e){this.stream.point(r,e)},sphere:function(){this.stream.sphere()},lineStart:function(){this.stream.lineStart()},lineEnd:function(){this.stream.lineEnd()},polygonStart:function(){this.stream.polygonStart()},polygonEnd:function(){this.stream.polygonEnd()}};function So(r,e){r&&Ih.hasOwnProperty(r.type)&&Ih[r.type](r,e)}var Ph={Feature:function(r,e){So(r.geometry,e)},FeatureCollection:function(r,e){for(var t=r.features,n=-1,i=t.length;++n<i;)So(t[n].geometry,e)}},Ih={Sphere:function(r,e){e.sphere()},Point:function(r,e){r=r.coordinates,e.point(r[0],r[1],r[2])},MultiPoint:function(r,e){for(var t=r.coordinates,n=-1,i=t.length;++n<i;)r=t[n],e.point(r[0],r[1],r[2])},LineString:function(r,e){pl(r.coordinates,e,0)},MultiLineString:function(r,e){for(var t=r.coordinates,n=-1,i=t.length;++n<i;)pl(t[n],e,0)},Polygon:function(r,e){Dh(r.coordinates,e)},MultiPolygon:function(r,e){for(var t=r.coordinates,n=-1,i=t.length;++n<i;)Dh(t[n],e)},GeometryCollection:function(r,e){for(var t=r.geometries,n=-1,i=t.length;++n<i;)So(t[n],e)}};function pl(r,e,t){var n=-1,i=r.length-t,s;for(e.lineStart();++n<i;)s=r[n],e.point(s[0],s[1],s[2]);e.lineEnd()}function Dh(r,e){var t=-1,n=r.length;for(e.polygonStart();++t<n;)pl(r[t],e,1);e.polygonEnd()}function Xy(r,e){r&&Ph.hasOwnProperty(r.type)?Ph[r.type](r,e):So(r,e)}var Qi=1/0,To=Qi,Or=-Qi,Eo=Or,Yy={point:Jy,lineStart:Nr,lineEnd:Nr,polygonStart:Nr,polygonEnd:Nr,result:function(){var r=[[Qi,To],[Or,Eo]];return Or=Eo=-(To=Qi=1/0),r}};function Jy(r,e){r<Qi&&(Qi=r),r>Or&&(Or=r),e<To&&(To=e),e>Eo&&(Eo=e)}var Fh=Yy;function ml(r,e,t){var n=r.clipExtent&&r.clipExtent();return r.scale(150).translate([0,0]),n!=null&&r.clipExtent(null),Xy(t,r.stream(Fh)),e(Fh.result()),n!=null&&r.clipExtent(n),r}function Bh(r,e,t){return ml(r,function(n){var i=e[1][0]-e[0][0],s=e[1][1]-e[0][1],o=Math.min(i/(n[1][0]-n[0][0]),s/(n[1][1]-n[0][1])),a=+e[0][0]+(i-o*(n[1][0]+n[0][0]))/2,l=+e[0][1]+(s-o*(n[1][1]+n[0][1]))/2;r.scale(150*o).translate([a,l])},t)}function Zy(r,e,t){return Bh(r,[[0,0],e],t)}function $y(r,e,t){return ml(r,function(n){var i=+e,s=i/(n[1][0]-n[0][0]),o=(i-s*(n[1][0]+n[0][0]))/2,a=-s*n[0][1];r.scale(150*s).translate([o,a])},t)}function jy(r,e,t){return ml(r,function(n){var i=+e,s=i/(n[1][1]-n[0][1]),o=-s*n[0][0],a=(i-s*(n[1][1]+n[0][1]))/2;r.scale(150*s).translate([o,a])},t)}var zh=16,Qy=ot(30*ut);function Nh(r,e){return+e?ev(r,e):Ky(r)}function Ky(r){return wo({point:function(e,t){e=r(e,t),this.stream.point(e[0],e[1])}})}function ev(r,e){function t(n,i,s,o,a,l,c,u,h,f,d,m,x,v){var g=c-n,p=u-i,_=g*g+p*p;if(_>4*e&&x--){var y=o+f,M=a+d,w=l+m,A=go(y*y+M*M+w*w),C=zr(w/=A),N=st(st(w)-1)<Je||st(s-h)<Je?(s+h)/2:Br(M,y),z=r(N,C),I=z[0],b=z[1],T=I-n,B=b-i,R=p*T-g*B;(R*R/_>e||st((g*T+p*B)/_-.5)>.3||o*f+a*d+l*m<Qy)&&(t(n,i,s,o,a,l,I,b,N,y/=A,M/=A,w,x,v),v.point(I,b),t(I,b,N,y,M,w,c,u,h,f,d,m,x,v))}}return function(n){var i,s,o,a,l,c,u,h,f,d,m,x,v={point:g,lineStart:p,lineEnd:y,polygonStart:function(){n.polygonStart(),v.lineStart=M},polygonEnd:function(){n.polygonEnd(),v.lineStart=p}};function g(C,N){C=r(C,N),n.point(C[0],C[1])}function p(){h=NaN,v.point=_,n.lineStart()}function _(C,N){var z=ji([C,N]),I=r(C,N);t(h,f,u,d,m,x,h=I[0],f=I[1],u=C,d=z[0],m=z[1],x=z[2],zh,n),n.point(h,f)}function y(){v.point=g,n.lineEnd()}function M(){p(),v.point=w,v.lineEnd=A}function w(C,N){_(i=C,N),s=h,o=f,a=d,l=m,c=x,v.point=_}function A(){t(h,f,u,d,m,x,s,o,i,a,l,c,zh,n),v.lineEnd=y,y()}return v}}var tv=wo({point:function(r,e){this.stream.point(r*ut,e*ut)}});function nv(r){return wo({point:function(e,t){var n=r(e,t);return this.stream.point(n[0],n[1])}})}function iv(r,e,t,n,i){function s(o,a){return o*=n,a*=i,[e+r*o,t-r*a]}return s.invert=function(o,a){return[(o-e)/r*n,(t-a)/r*i]},s}function Uh(r,e,t,n,i,s){if(!s)return iv(r,e,t,n,i);var o=ot(s),a=et(s),l=o*r,c=a*r,u=o/r,h=a/r,f=(a*t-o*e)/r,d=(a*e+o*t)/r;function m(x,v){return x*=n,v*=i,[l*x-c*v+e,t-c*x-l*v]}return m.invert=function(x,v){return[n*(u*x-h*v+f),i*(d-h*x-u*v)]},m}function rv(r){return sv(function(){return r})()}function sv(r){var e,t=150,n=480,i=250,s=0,o=0,a=0,l=0,c=0,u,h=0,f=1,d=1,m=null,x=Ah,v=null,g,p,_,y=Rh,M=.5,w,A,C,N,z;function I(R){return C(R[0]*ut,R[1]*ut)}function b(R){return R=C.invert(R[0],R[1]),R&&[R[0]*Ft,R[1]*Ft]}I.stream=function(R){return N&&z===R?N:N=tv(nv(u)(x(w(y(z=R)))))},I.preclip=function(R){return arguments.length?(x=R,m=void 0,B()):x},I.postclip=function(R){return arguments.length?(y=R,v=g=p=_=null,B()):y},I.clipAngle=function(R){return arguments.length?(x=+R?ky(m=R*ut):(m=null,Ah),B()):m*Ft},I.clipExtent=function(R){return arguments.length?(y=R==null?(v=g=p=_=null,Rh):qy(v=+R[0][0],g=+R[0][1],p=+R[1][0],_=+R[1][1]),B()):v==null?null:[[v,g],[p,_]]},I.scale=function(R){return arguments.length?(t=+R,T()):t},I.translate=function(R){return arguments.length?(n=+R[0],i=+R[1],T()):[n,i]},I.center=function(R){return arguments.length?(s=R[0]%360*ut,o=R[1]%360*ut,T()):[s*Ft,o*Ft]},I.rotate=function(R){return arguments.length?(a=R[0]%360*ut,l=R[1]%360*ut,c=R.length>2?R[2]%360*ut:0,T()):[a*Ft,l*Ft,c*Ft]},I.angle=function(R){return arguments.length?(h=R%360*ut,T()):h*Ft},I.reflectX=function(R){return arguments.length?(f=R?-1:1,T()):f<0},I.reflectY=function(R){return arguments.length?(d=R?-1:1,T()):d<0},I.precision=function(R){return arguments.length?(w=Nh(A,M=R*R),B()):go(M)},I.fitExtent=function(R,F){return Bh(I,R,F)},I.fitSize=function(R,F){return Zy(I,R,F)},I.fitWidth=function(R,F){return $y(I,R,F)},I.fitHeight=function(R,F){return jy(I,R,F)};function T(){var R=Uh(t,0,0,f,d,h).apply(null,e(s,o)),F=Uh(t,n-R[0],i-R[1],f,d,h);return u=yh(a,l,c),A=ol(e,F),C=ol(u,A),w=Nh(A,M),B()}function B(){return N=z=null,I}return function(){return e=r.apply(this,arguments),I.invert=e.invert&&b,T()}}function gl(r,e){return[r,Py(Dy((Rt+e)/2))]}gl.invert=function(r,e){return[r,2*xh(Ry(e))-Rt]};function ov(){return av(gl).scale(961/Ht)}function av(r){var e=rv(r),t=e.center,n=e.scale,i=e.translate,s=e.clipExtent,o=null,a,l,c;e.scale=function(h){return arguments.length?(n(h),u()):n()},e.translate=function(h){return arguments.length?(i(h),u()):i()},e.center=function(h){return arguments.length?(t(h),u()):t()},e.clipExtent=function(h){return arguments.length?(h==null?o=a=l=c=null:(o=+h[0][0],a=+h[0][1],l=+h[1][0],c=+h[1][1]),u()):o==null?null:[[o,a],[l,c]]};function u(){var h=Ne*n(),f=e(By(e.rotate()).invert([0,0]));return s(o==null?[[f[0]-h,f[1]-h],[f[0]+h,f[1]+h]]:r===gl?[[Math.max(f[0]-h,o),a],[Math.min(f[0]+h,l),c]]:[[o,Math.max(f[1]-h,a)],[l,Math.min(f[1]+h,c)]])}return u()}var lv=function(r){return ov().center(r.center).scale(r.scale).translate([0,0]).precision(.1)},cv=function(r,e){return e.map(function(t){var n=mh(t,2),i=n[0],s=n[1],o=mh(r([i,s]),2),a=o[0],l=o[1];return new S(a,-l,0)})};self.onmessage=function(r){var e=r.data,t=e.req,n=t.coordinatesArr,i=t.projection,s=e.uuid,o=lv({center:i.center,scale:i.scale}),a=n.map(function(h){return cv(o,h)}),l=xy(a.map(function(h){return Ey({nodes:h})}),!1),c={},u=[];nr(Object.keys(l.attributes)).concat(["index"]).forEach(function(h){var f=h==="index"?l.index:l.attributes[h];c[h]={array:f.array,itemSize:f.itemSize},u.push(f.array.buffer)}),self.postMessage({res:c,uuid:s},u),l.dispose()}})();
3177
+ `),xn=function(r){"use strict";fh(t,r);var e=ph(t);function t(){hh(this,t);var n;return n=e.call(this),n.isMeshLine=!0,n.type="MeshLine",n.positions=[],n.previous=[],n.next=[],n.side=[],n.width=[],n.indices_array=[],n.uvs=[],n.counters=[],n._points=[],n._geom=null,n.widthCallback=null,n.matrixWorld=new pe,Object.defineProperties(nl(n),{geometry:{enumerable:!0,get:function(){return this}},geom:{enumerable:!0,get:function(){return this._geom},set:function(s){this.setGeometry(s,this.widthCallback)}},points:{enumerable:!0,get:function(){return this._points},set:function(s){this.setPoints(s,this.widthCallback)}}}),n}return t}(ve);xn.prototype.setMatrixWorld=function(r){this.matrixWorld=r},xn.prototype.setGeometry=function(r,e){this._geometry=r,this.setPoints(r.getAttribute("position").array,e)},xn.prototype.setPoints=function(r,e){if(!(r instanceof Float32Array)&&!(r instanceof Array)){console.error("ERROR: The BufferArray of points is not instancied correctly.");return}if(this._points=r,this.widthCallback=e,this.positions=[],this.counters=[],r.length&&r[0]instanceof S)for(var t=0;t<r.length;t++){var n=r[t],i=t/r.length;this.positions.push(n.x,n.y,n.z),this.positions.push(n.x,n.y,n.z),this.counters.push(i),this.counters.push(i)}else for(var t=0;t<r.length;t+=3){var i=t/r.length;this.positions.push(r[t],r[t+1],r[t+2]),this.positions.push(r[t],r[t+1],r[t+2]),this.counters.push(i),this.counters.push(i)}this.process()};function Sy(r,e){var t=new pe,n=new Tn,i=new wn,s=new S,o=this.geometry;if(o.boundingSphere||o.computeBoundingSphere(),i.copy(o.boundingSphere),i.applyMatrix4(this.matrixWorld),r.ray.intersectSphere(i,s)!==!1){t.copy(this.matrixWorld).invert(),n.copy(r.ray).applyMatrix4(t);var a=new S,l=new S,c=new S,u=this instanceof fn?2:1,h=o.index,f=o.attributes;if(h!==null)for(var d=h.array,m=f.position.array,x=f.width.array,v=0,g=d.length-1;v<g;v+=u){var p=d[v],_=d[v+1];a.fromArray(m,p*3),l.fromArray(m,_*3);var y=x[Math.floor(v/3)]!==void 0?x[Math.floor(v/3)]:1,M=r.params.Line.threshold+this.material.lineWidth*y/2,w=M*M,A=n.distanceSqToSegment(a,l,s,c);if(!(A>w)){s.applyMatrix4(this.matrixWorld);var C=r.ray.origin.distanceTo(s);C<r.near||C>r.far||(e.push({distance:C,point:c.clone().applyMatrix4(this.matrixWorld),index:v,face:null,faceIndex:null,object:this}),v=g)}}}}xn.prototype.raycast=Sy,xn.prototype.compareV3=function(r,e){var t=r*6,n=e*6;return this.positions[t]===this.positions[n]&&this.positions[t+1]===this.positions[n+1]&&this.positions[t+2]===this.positions[n+2]},xn.prototype.copyV3=function(r){var e=r*6;return[this.positions[e],this.positions[e+1],this.positions[e+2]]},xn.prototype.process=function(){var r=this.positions.length/6;this.previous=[],this.next=[],this.side=[],this.width=[],this.indices_array=[],this.uvs=[];var e,t;this.compareV3(0,r-1)?t=this.copyV3(r-2):t=this.copyV3(0),this.previous.push(t[0],t[1],t[2]),this.previous.push(t[0],t[1],t[2]);for(var n=0;n<r;n++){if(this.side.push(1),this.side.push(-1),this.widthCallback?e=this.widthCallback(n/(r-1)):e=1,this.width.push(e),this.width.push(e),this.uvs.push(n/(r-1),0),this.uvs.push(n/(r-1),1),n<r-1){t=this.copyV3(n),this.previous.push(t[0],t[1],t[2]),this.previous.push(t[0],t[1],t[2]);var i=n*2;this.indices_array.push(i,i+1,i+2),this.indices_array.push(i+2,i+1,i+3)}n>0&&(t=this.copyV3(n),this.next.push(t[0],t[1],t[2]),this.next.push(t[0],t[1],t[2]))}this.compareV3(r-1,0)?t=this.copyV3(1):t=this.copyV3(r-1),this.next.push(t[0],t[1],t[2]),this.next.push(t[0],t[1],t[2]),!this._attributes||this._attributes.position.count!==this.positions.length?this._attributes={position:new ze(new Float32Array(this.positions),3),previous:new ze(new Float32Array(this.previous),3),next:new ze(new Float32Array(this.next),3),side:new ze(new Float32Array(this.side),1),width:new ze(new Float32Array(this.width),1),uv:new ze(new Float32Array(this.uvs),2),index:new ze(new Uint16Array(this.indices_array),1),counters:new ze(new Float32Array(this.counters),1)}:(this._attributes.position.copyArray(new Float32Array(this.positions)),this._attributes.position.needsUpdate=!0,this._attributes.previous.copyArray(new Float32Array(this.previous)),this._attributes.previous.needsUpdate=!0,this._attributes.next.copyArray(new Float32Array(this.next)),this._attributes.next.needsUpdate=!0,this._attributes.side.copyArray(new Float32Array(this.side)),this._attributes.side.needsUpdate=!0,this._attributes.width.copyArray(new Float32Array(this.width)),this._attributes.width.needsUpdate=!0,this._attributes.uv.copyArray(new Float32Array(this.uvs)),this._attributes.uv.needsUpdate=!0,this._attributes.index.copyArray(new Uint16Array(this.indices_array)),this._attributes.index.needsUpdate=!0),this.setAttribute("position",this._attributes.position),this.setAttribute("previous",this._attributes.previous),this.setAttribute("next",this._attributes.next),this.setAttribute("side",this._attributes.side),this.setAttribute("width",this._attributes.width),this.setAttribute("uv",this._attributes.uv),this.setAttribute("counters",this._attributes.counters),this.setIndex(this._attributes.index),this.computeBoundingSphere(),this.computeBoundingBox()};function sl(r,e,t,n,i){var s;if(r=r.subarray||r.slice?r:r.buffer,t=t.subarray||t.slice?t:t.buffer,r=e?r.subarray?r.subarray(e,i&&e+i):r.slice(e,i&&e+i):r,t.set)t.set(r,n);else for(s=0;s<r.length;s++)t[s+n]=r[s];return t}xn.prototype.advance=function(r){var e=this._attributes.position.array,t=this._attributes.previous.array,n=this._attributes.next.array,i=e.length;sl(e,0,t,0,i),sl(e,6,e,0,i-6),e[i-6]=r.x,e[i-5]=r.y,e[i-4]=r.z,e[i-3]=r.x,e[i-2]=r.y,e[i-1]=r.z,sl(e,6,n,0,i-6),n[i-6]=r.x,n[i-5]=r.y,n[i-4]=r.z,n[i-3]=r.x,n[i-2]=r.y,n[i-1]=r.z,this._attributes.position.needsUpdate=!0,this._attributes.previous.needsUpdate=!0,this._attributes.next.needsUpdate=!0},Me.meshline_vert=by,Me.meshline_frag=wy;var Ty=function(r){"use strict";fh(t,r);var e=ph(t);function t(n){hh(this,t);var i;return i=e.call(this,{uniforms:Object.assign({},oe.fog,{lineWidth:{value:1},map:{value:null},useMap:{value:0},alphaMap:{value:null},useAlphaMap:{value:0},color:{value:new le(16777215)},opacity:{value:1},resolution:{value:new q(1,1)},sizeAttenuation:{value:1},dashArray:{value:0},dashOffset:{value:0},dashRatio:{value:.5},useDash:{value:0},visibility:{value:1},alphaTest:{value:0},repeat:{value:new q(1,1)},offset:{value:new q(1,1)},lineLightAnimation:{value:1},time:{value:0},size:{value:300},speed:{value:.3},lightWidth:{value:.1},uCenter:{value:new q(0,0)},lightColor:{value:new le(16777215)}}),vertexShader:Me.meshline_vert,fragmentShader:Me.meshline_frag}),i.isMeshLineMaterial=!0,i.type="MeshLineMaterial",Object.defineProperties(nl(i),{lineWidth:{enumerable:!0,get:function(){return this.uniforms.lineWidth.value},set:function(o){this.uniforms.lineWidth.value=o}},lineLightAnimation:{enumerable:!0,get:function(){return this.uniforms.lineLightAnimation.value},set:function(o){this.uniforms.lineLightAnimation.value=o}},map:{enumerable:!0,get:function(){return this.uniforms.map.value},set:function(o){this.uniforms.map.value=o}},useMap:{enumerable:!0,get:function(){return this.uniforms.useMap.value},set:function(o){this.uniforms.useMap.value=o}},alphaMap:{enumerable:!0,get:function(){return this.uniforms.alphaMap.value},set:function(o){this.uniforms.alphaMap.value=o}},useAlphaMap:{enumerable:!0,get:function(){return this.uniforms.useAlphaMap.value},set:function(o){this.uniforms.useAlphaMap.value=o}},color:{enumerable:!0,get:function(){return this.uniforms.color.value},set:function(o){this.uniforms.color.value=o}},lightColor:{enumerable:!0,get:function(){return this.uniforms.lightColor.value},set:function(o){this.uniforms.lightColor.value=o}},time:{enumerable:!0,get:function(){return this.uniforms.time.value},set:function(o){this.uniforms.time.value=o}},uCenter:{enumerable:!0,get:function(){return this.uniforms.uCenter.value},set:function(o){this.uniforms.uCenter.value=o}},size:{enumerable:!0,get:function(){return this.uniforms.size.value},set:function(o){this.uniforms.size.value=o}},opacity:{enumerable:!0,get:function(){return this.uniforms.opacity.value},set:function(o){this.uniforms.opacity.value=o}},resolution:{enumerable:!0,get:function(){return this.uniforms.resolution.value},set:function(o){this.uniforms.resolution.value.copy(o)}},sizeAttenuation:{enumerable:!0,get:function(){return this.uniforms.sizeAttenuation.value},set:function(o){this.uniforms.sizeAttenuation.value=o}},dashArray:{enumerable:!0,get:function(){return this.uniforms.dashArray.value},set:function(o){this.uniforms.dashArray.value=o,this.useDash=o!==0?1:0}},dashOffset:{enumerable:!0,get:function(){return this.uniforms.dashOffset.value},set:function(o){this.uniforms.dashOffset.value=o}},dashRatio:{enumerable:!0,get:function(){return this.uniforms.dashRatio.value},set:function(o){this.uniforms.dashRatio.value=o}},useDash:{enumerable:!0,get:function(){return this.uniforms.useDash.value},set:function(o){this.uniforms.useDash.value=o}},visibility:{enumerable:!0,get:function(){return this.uniforms.visibility.value},set:function(o){this.uniforms.visibility.value=o}},alphaTest:{enumerable:!0,get:function(){return this.uniforms.alphaTest.value},set:function(o){this.uniforms.alphaTest.value=o}},repeat:{enumerable:!0,get:function(){return this.uniforms.repeat.value},set:function(o){this.uniforms.repeat.value.copy(o)}}}),i.setValues(n),i}return t}(Yt);Ty.prototype.copy=function(r){return Yt.prototype.copy.call(this,r),this.lineWidth=r.lineWidth,this.map=r.map,this.useMap=r.useMap,this.alphaMap=r.alphaMap,this.useAlphaMap=r.useAlphaMap,this.color.copy(r.color),this.opacity=r.opacity,this.resolution.copy(r.resolution),this.sizeAttenuation=r.sizeAttenuation,this.dashArray.copy(r.dashArray),this.dashOffset.copy(r.dashOffset),this.dashRatio.copy(r.dashRatio),this.useDash=r.useDash,this.visibility=r.visibility,this.alphaTest=r.alphaTest,this.repeat.copy(r.repeat),this};function Ey(r){var e=r.setPointWidth,t=r.nodes,n=new ve,i=new xn;return n.setFromPoints(t),i.setGeometry(n,e),i}function Ay(r){if(Array.isArray(r))return r}function Ly(){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 mh(r,e){return Ay(r)||tr(r,e)||Gr(r,e)||Ly()}var Je=1e-6,Cy=1e-12,Ne=Math.PI,Rt=Ne/2,gh=Ne/4,Ht=Ne*2,Ft=180/Ne,ut=Ne/180,st=Math.abs,xh=Math.atan,Br=Math.atan2,ot=Math.cos,GM=Math.ceil,Ry=Math.exp,VM=Math.floor,kM=Math.hypot,Py=Math.log,WM=Math.pow,et=Math.sin,Iy=Math.sign||function(r){return r>0?1:r<0?-1:0},go=Math.sqrt,Dy=Math.tan;function Fy(r){return r>1?0:r<-1?Ne:Math.acos(r)}function zr(r){return r>1?Rt:r<-1?-Rt:Math.asin(r)}function qM(r){return(r=et(r/2))*r}function ol(r,e){function t(n,i){return n=r(n,i),e(n[0],n[1])}return r.invert&&e.invert&&(t.invert=function(n,i){return n=e.invert(n,i),n&&r.invert(n[0],n[1])}),t}function al(r,e){return[st(r)>Ne?r+Math.round(-r/Ht)*Ht:r,e]}al.invert=al;function yh(r,e,t){return(r%=Ht)?e||t?ol(_h(r),Mh(e,t)):_h(r):e||t?Mh(e,t):al}function vh(r){return function(e,t){return e+=r,[e>Ne?e-Ht:e<-Ne?e+Ht:e,t]}}function _h(r){var e=vh(r);return e.invert=vh(-r),e}function Mh(r,e){var t=ot(r),n=et(r),i=ot(e),s=et(e);function o(a,l){var c=ot(l),u=ot(a)*c,h=et(a)*c,f=et(l),d=f*t+u*n;return[Br(h*i-d*s,u*t-f*n),zr(d*i+h*s)]}return o.invert=function(a,l){var c=ot(l),u=ot(a)*c,h=et(a)*c,f=et(l),d=f*i-h*s;return[Br(h*i+f*s,u*t+d*n),zr(d*t-u*n)]},o}function By(r){r=yh(r[0]*ut,r[1]*ut,r.length>2?r[2]*ut:0);function e(t){return t=r(t[0]*ut,t[1]*ut),t[0]*=Ft,t[1]*=Ft,t}return e.invert=function(t){return t=r.invert(t[0]*ut,t[1]*ut),t[0]*=Ft,t[1]*=Ft,t},e}function Nr(){}function bh(){var r=[],e;return{point:function(t,n,i){e.push([t,n,i])},lineStart:function(){r.push(e=[])},lineEnd:Nr,rejoin:function(){r.length>1&&r.push(r.pop().concat(r.shift()))},result:function(){var t=r;return r=[],e=null,t}}}function xo(r,e){return st(r[0]-e[0])<Je&&st(r[1]-e[1])<Je}function yo(r,e,t,n){this.x=r,this.z=e,this.o=t,this.e=n,this.v=!1,this.n=this.p=null}function wh(r,e,t,n,i){var s=[],o=[],a,l;if(r.forEach(function(m){if(!((x=m.length-1)<=0)){var x,v=m[0],g=m[x],p;if(xo(v,g)){if(!v[2]&&!g[2]){for(i.lineStart(),a=0;a<x;++a)i.point((v=m[a])[0],v[1]);i.lineEnd();return}g[0]+=2*Je}s.push(p=new yo(v,m,null,!0)),o.push(p.o=new yo(v,null,p,!1)),s.push(p=new yo(g,m,null,!1)),o.push(p.o=new yo(g,null,p,!0))}}),!!s.length){for(o.sort(e),Sh(s),Sh(o),a=0,l=o.length;a<l;++a)o[a].e=t=!t;for(var c=s[0],u,h;;){for(var f=c,d=!0;f.v;)if((f=f.n)===c)return;u=f.z,i.lineStart();do{if(f.v=f.o.v=!0,f.e){if(d)for(a=0,l=u.length;a<l;++a)i.point((h=u[a])[0],h[1]);else n(f.x,f.n.x,1,i);f=f.n}else{if(d)for(u=f.p.z,a=u.length-1;a>=0;--a)i.point((h=u[a])[0],h[1]);else n(f.x,f.p.x,-1,i);f=f.p}f=f.o,u=f.z,d=!d}while(!f.v);i.lineEnd()}}}function Sh(r){if(!!(e=r.length)){for(var e,t=0,n=r[0],i;++t<e;)n.n=i=r[t],i.p=n,n=i;n.n=i=r[0],i.p=n}}class ll{constructor(){this._partials=new Float64Array(32),this._n=0}add(e){const t=this._partials;let n=0;for(let i=0;i<this._n&&i<32;i++){const s=t[i],o=e+s,a=Math.abs(e)<Math.abs(s)?e-(o-s):s-(o-e);a&&(t[n++]=a),e=o}return t[n]=e,this._n=n+1,this}valueOf(){const e=this._partials;let t=this._n,n,i,s,o=0;if(t>0){for(o=e[--t];t>0&&(n=o,i=e[--t],o=n+i,s=i-(o-n),!s););t>0&&(s<0&&e[t-1]<0||s>0&&e[t-1]>0)&&(i=s*2,n=o+i,i==n-o&&(o=n))}return o}}function XM(r,e){const t=new ll;if(e===void 0)for(let n of r)(n=+n)&&t.add(n);else{let n=-1;for(let i of r)(i=+e(i,++n,r))&&t.add(i)}return+t}function YM(r,e){const t=new ll;let n=-1;return Float64Array.from(r,e===void 0?i=>t.add(+i||0):i=>t.add(+e(i,++n,r)||0))}function cl(r){return[Br(r[1],r[0]),zr(r[2])]}function ji(r){var e=r[0],t=r[1],n=ot(t);return[n*ot(e),n*et(e),et(t)]}function vo(r,e){return r[0]*e[0]+r[1]*e[1]+r[2]*e[2]}function _o(r,e){return[r[1]*e[2]-r[2]*e[1],r[2]*e[0]-r[0]*e[2],r[0]*e[1]-r[1]*e[0]]}function ul(r,e){r[0]+=e[0],r[1]+=e[1],r[2]+=e[2]}function Mo(r,e){return[r[0]*e,r[1]*e,r[2]*e]}function hl(r){var e=go(r[0]*r[0]+r[1]*r[1]+r[2]*r[2]);r[0]/=e,r[1]/=e,r[2]/=e}function fl(r){return st(r[0])<=Ne?r[0]:Iy(r[0])*((st(r[0])+Ne)%Ht-Ne)}function zy(r,e){var t=fl(e),n=e[1],i=et(n),s=[et(t),-ot(t),0],o=0,a=0,l=new ll;i===1?n=Rt+Je:i===-1&&(n=-Rt-Je);for(var c=0,u=r.length;c<u;++c)if(!!(f=(h=r[c]).length))for(var h,f,d=h[f-1],m=fl(d),x=d[1]/2+gh,v=et(x),g=ot(x),p=0;p<f;++p,m=y,v=w,g=A,d=_){var _=h[p],y=fl(_),M=_[1]/2+gh,w=et(M),A=ot(M),C=y-m,N=C>=0?1:-1,z=N*C,I=z>Ne,b=v*w;if(l.add(Br(b*N*et(z),g*A+b*ot(z))),o+=I?C+N*Ht:C,I^m>=t^y>=t){var T=_o(ji(d),ji(_));hl(T);var B=_o(s,T);hl(B);var R=(I^C>=0?-1:1)*zr(B[2]);(n>R||n===R&&(T[0]||T[1]))&&(a+=I^C>=0?1:-1)}}return(o<-Je||o<Je&&l<-Cy)^a&1}function*Ny(r){for(const e of r)yield*e}function Th(r){return Array.from(Ny(r))}function Eh(r,e,t,n){return function(i){var s=e(i),o=bh(),a=e(o),l=!1,c,u,h,f={point:d,lineStart:x,lineEnd:v,polygonStart:function(){f.point=g,f.lineStart=p,f.lineEnd=_,u=[],c=[]},polygonEnd:function(){f.point=d,f.lineStart=x,f.lineEnd=v,u=Th(u);var y=zy(c,n);u.length?(l||(i.polygonStart(),l=!0),wh(u,Oy,y,t,i)):y&&(l||(i.polygonStart(),l=!0),i.lineStart(),t(null,null,1,i),i.lineEnd()),l&&(i.polygonEnd(),l=!1),u=c=null},sphere:function(){i.polygonStart(),i.lineStart(),t(null,null,1,i),i.lineEnd(),i.polygonEnd()}};function d(y,M){r(y,M)&&i.point(y,M)}function m(y,M){s.point(y,M)}function x(){f.point=m,s.lineStart()}function v(){f.point=d,s.lineEnd()}function g(y,M){h.push([y,M]),a.point(y,M)}function p(){a.lineStart(),h=[]}function _(){g(h[0][0],h[0][1]),a.lineEnd();var y=a.clean(),M=o.result(),w,A=M.length,C,N,z;if(h.pop(),c.push(h),h=null,!!A){if(y&1){if(N=M[0],(C=N.length-1)>0){for(l||(i.polygonStart(),l=!0),i.lineStart(),w=0;w<C;++w)i.point((z=N[w])[0],z[1]);i.lineEnd()}return}A>1&&y&2&&M.push(M.pop().concat(M.shift())),u.push(M.filter(Uy))}}return f}}function Uy(r){return r.length>1}function Oy(r,e){return((r=r.x)[0]<0?r[1]-Rt-Je:Rt-r[1])-((e=e.x)[0]<0?e[1]-Rt-Je:Rt-e[1])}var Ah=Eh(function(){return!0},Hy,Vy,[-Ne,-Rt]);function Hy(r){var e=NaN,t=NaN,n=NaN,i;return{lineStart:function(){r.lineStart(),i=1},point:function(s,o){var a=s>0?Ne:-Ne,l=st(s-e);st(l-Ne)<Je?(r.point(e,t=(t+o)/2>0?Rt:-Rt),r.point(n,t),r.lineEnd(),r.lineStart(),r.point(a,t),r.point(s,t),i=0):n!==a&&l>=Ne&&(st(e-n)<Je&&(e-=n*Je),st(s-a)<Je&&(s-=a*Je),t=Gy(e,t,s,o),r.point(n,t),r.lineEnd(),r.lineStart(),r.point(a,t),i=0),r.point(e=s,t=o),n=a},lineEnd:function(){r.lineEnd(),e=t=NaN},clean:function(){return 2-i}}}function Gy(r,e,t,n){var i,s,o=et(r-t);return st(o)>Je?xh((et(e)*(s=ot(n))*et(t)-et(n)*(i=ot(e))*et(r))/(i*s*o)):(e+n)/2}function Vy(r,e,t,n){var i;if(r==null)i=t*Rt,n.point(-Ne,i),n.point(0,i),n.point(Ne,i),n.point(Ne,0),n.point(Ne,-i),n.point(0,-i),n.point(-Ne,-i),n.point(-Ne,0),n.point(-Ne,i);else if(st(r[0]-e[0])>Je){var s=r[0]<e[0]?Ne:-Ne;i=t*s/2,n.point(-s,i),n.point(0,i),n.point(s,i)}else n.point(e[0],e[1])}function Lh(r,e,t,n,i,s){if(!!t){var o=ot(e),a=et(e),l=n*t;i==null?(i=e+n*Ht,s=e-l/2):(i=Ch(o,i),s=Ch(o,s),(n>0?i<s:i>s)&&(i+=n*Ht));for(var c,u=i;n>0?u>s:u<s;u-=l)c=cl([o,-a*ot(u),-a*et(u)]),r.point(c[0],c[1])}}function Ch(r,e){e=ji(e),e[0]-=r,hl(e);var t=Fy(-e[1]);return((-e[2]<0?-t:t)+Ht-Je)%Ht}function JM(){var r=constant([0,0]),e=constant(90),t=constant(6),n,i,s={point:o};function o(l,c){n.push(l=i(l,c)),l[0]*=degrees,l[1]*=degrees}function a(){var l=r.apply(this,arguments),c=e.apply(this,arguments)*radians,u=t.apply(this,arguments)*radians;return n=[],i=rotateRadians(-l[0]*radians,-l[1]*radians,0).invert,Lh(s,c,u,1),l={type:"Polygon",coordinates:[n]},n=i=null,l}return a.center=function(l){return arguments.length?(r=typeof l=="function"?l:constant([+l[0],+l[1]]),a):r},a.radius=function(l){return arguments.length?(e=typeof l=="function"?l:constant(+l),a):e},a.precision=function(l){return arguments.length?(t=typeof l=="function"?l:constant(+l),a):t},a}function ky(r){var e=ot(r),t=6*ut,n=e>0,i=st(e)>Je;function s(u,h,f,d){Lh(d,r,t,f,u,h)}function o(u,h){return ot(u)*ot(h)>e}function a(u){var h,f,d,m,x;return{lineStart:function(){m=d=!1,x=1},point:function(v,g){var p=[v,g],_,y=o(v,g),M=n?y?0:c(v,g):y?c(v+(v<0?Ne:-Ne),g):0;if(!h&&(m=d=y)&&u.lineStart(),y!==d&&(_=l(h,p),(!_||xo(h,_)||xo(p,_))&&(p[2]=1)),y!==d)x=0,y?(u.lineStart(),_=l(p,h),u.point(_[0],_[1])):(_=l(h,p),u.point(_[0],_[1],2),u.lineEnd()),h=_;else if(i&&h&&n^y){var w;!(M&f)&&(w=l(p,h,!0))&&(x=0,n?(u.lineStart(),u.point(w[0][0],w[0][1]),u.point(w[1][0],w[1][1]),u.lineEnd()):(u.point(w[1][0],w[1][1]),u.lineEnd(),u.lineStart(),u.point(w[0][0],w[0][1],3)))}y&&(!h||!xo(h,p))&&u.point(p[0],p[1]),h=p,d=y,f=M},lineEnd:function(){d&&u.lineEnd(),h=null},clean:function(){return x|(m&&d)<<1}}}function l(u,h,f){var d=ji(u),m=ji(h),x=[1,0,0],v=_o(d,m),g=vo(v,v),p=v[0],_=g-p*p;if(!_)return!f&&u;var y=e*g/_,M=-e*p/_,w=_o(x,v),A=Mo(x,y),C=Mo(v,M);ul(A,C);var N=w,z=vo(A,N),I=vo(N,N),b=z*z-I*(vo(A,A)-1);if(!(b<0)){var T=go(b),B=Mo(N,(-z-T)/I);if(ul(B,A),B=cl(B),!f)return B;var R=u[0],F=h[0],U=u[1],Z=h[1],ee;F<R&&(ee=R,R=F,F=ee);var V=F-R,W=st(V-Ne)<Je,ne=W||V<Je;if(!W&&Z<U&&(ee=U,U=Z,Z=ee),ne?W?U+Z>0^B[1]<(st(B[0]-R)<Je?U:Z):U<=B[1]&&B[1]<=Z:V>Ne^(R<=B[0]&&B[0]<=F)){var K=Mo(N,(-z+T)/I);return ul(K,A),[B,cl(K)]}}}function c(u,h){var f=n?r:Ne-r,d=0;return u<-f?d|=1:u>f&&(d|=2),h<-f?d|=4:h>f&&(d|=8),d}return Eh(o,a,s,n?[0,-r]:[-Ne,r-Ne])}function Wy(r,e,t,n,i,s){var o=r[0],a=r[1],l=e[0],c=e[1],u=0,h=1,f=l-o,d=c-a,m;if(m=t-o,!(!f&&m>0)){if(m/=f,f<0){if(m<u)return;m<h&&(h=m)}else if(f>0){if(m>h)return;m>u&&(u=m)}if(m=i-o,!(!f&&m<0)){if(m/=f,f<0){if(m>h)return;m>u&&(u=m)}else if(f>0){if(m<u)return;m<h&&(h=m)}if(m=n-a,!(!d&&m>0)){if(m/=d,d<0){if(m<u)return;m<h&&(h=m)}else if(d>0){if(m>h)return;m>u&&(u=m)}if(m=s-a,!(!d&&m<0)){if(m/=d,d<0){if(m>h)return;m>u&&(u=m)}else if(d>0){if(m<u)return;m<h&&(h=m)}return u>0&&(r[0]=o+u*f,r[1]=a+u*d),h<1&&(e[0]=o+h*f,e[1]=a+h*d),!0}}}}}var Ur=1e9,bo=-Ur;function qy(r,e,t,n){function i(c,u){return r<=c&&c<=t&&e<=u&&u<=n}function s(c,u,h,f){var d=0,m=0;if(c==null||(d=o(c,h))!==(m=o(u,h))||l(c,u)<0^h>0)do f.point(d===0||d===3?r:t,d>1?n:e);while((d=(d+h+4)%4)!==m);else f.point(u[0],u[1])}function o(c,u){return st(c[0]-r)<Je?u>0?0:3:st(c[0]-t)<Je?u>0?2:1:st(c[1]-e)<Je?u>0?1:0:u>0?3:2}function a(c,u){return l(c.x,u.x)}function l(c,u){var h=o(c,1),f=o(u,1);return h!==f?h-f:h===0?u[1]-c[1]:h===1?c[0]-u[0]:h===2?c[1]-u[1]:u[0]-c[0]}return function(c){var u=c,h=bh(),f,d,m,x,v,g,p,_,y,M,w,A={point:C,lineStart:b,lineEnd:T,polygonStart:z,polygonEnd:I};function C(R,F){i(R,F)&&u.point(R,F)}function N(){for(var R=0,F=0,U=d.length;F<U;++F)for(var Z=d[F],ee=1,V=Z.length,W=Z[0],ne,K,he=W[0],be=W[1];ee<V;++ee)ne=he,K=be,W=Z[ee],he=W[0],be=W[1],K<=n?be>n&&(he-ne)*(n-K)>(be-K)*(r-ne)&&++R:be<=n&&(he-ne)*(n-K)<(be-K)*(r-ne)&&--R;return R}function z(){u=h,f=[],d=[],w=!0}function I(){var R=N(),F=w&&R,U=(f=Th(f)).length;(F||U)&&(c.polygonStart(),F&&(c.lineStart(),s(null,null,1,c),c.lineEnd()),U&&wh(f,a,R,s,c),c.polygonEnd()),u=c,f=d=m=null}function b(){A.point=B,d&&d.push(m=[]),M=!0,y=!1,p=_=NaN}function T(){f&&(B(x,v),g&&y&&h.rejoin(),f.push(h.result())),A.point=C,y&&u.lineEnd()}function B(R,F){var U=i(R,F);if(d&&m.push([R,F]),M)x=R,v=F,g=U,M=!1,U&&(u.lineStart(),u.point(R,F));else if(U&&y)u.point(R,F);else{var Z=[p=Math.max(bo,Math.min(Ur,p)),_=Math.max(bo,Math.min(Ur,_))],ee=[R=Math.max(bo,Math.min(Ur,R)),F=Math.max(bo,Math.min(Ur,F))];Wy(Z,ee,r,e,t,n)?(y||(u.lineStart(),u.point(Z[0],Z[1])),u.point(ee[0],ee[1]),U||u.lineEnd(),w=!1):U&&(u.lineStart(),u.point(R,F),w=!1)}p=R,_=F,y=U}return A}}var Rh=r=>r;function ZM(r){return{stream:wo(r)}}function wo(r){return function(e){var t=new dl;for(var n in r)t[n]=r[n];return t.stream=e,t}}function dl(){}dl.prototype={constructor:dl,point:function(r,e){this.stream.point(r,e)},sphere:function(){this.stream.sphere()},lineStart:function(){this.stream.lineStart()},lineEnd:function(){this.stream.lineEnd()},polygonStart:function(){this.stream.polygonStart()},polygonEnd:function(){this.stream.polygonEnd()}};function So(r,e){r&&Ih.hasOwnProperty(r.type)&&Ih[r.type](r,e)}var Ph={Feature:function(r,e){So(r.geometry,e)},FeatureCollection:function(r,e){for(var t=r.features,n=-1,i=t.length;++n<i;)So(t[n].geometry,e)}},Ih={Sphere:function(r,e){e.sphere()},Point:function(r,e){r=r.coordinates,e.point(r[0],r[1],r[2])},MultiPoint:function(r,e){for(var t=r.coordinates,n=-1,i=t.length;++n<i;)r=t[n],e.point(r[0],r[1],r[2])},LineString:function(r,e){pl(r.coordinates,e,0)},MultiLineString:function(r,e){for(var t=r.coordinates,n=-1,i=t.length;++n<i;)pl(t[n],e,0)},Polygon:function(r,e){Dh(r.coordinates,e)},MultiPolygon:function(r,e){for(var t=r.coordinates,n=-1,i=t.length;++n<i;)Dh(t[n],e)},GeometryCollection:function(r,e){for(var t=r.geometries,n=-1,i=t.length;++n<i;)So(t[n],e)}};function pl(r,e,t){var n=-1,i=r.length-t,s;for(e.lineStart();++n<i;)s=r[n],e.point(s[0],s[1],s[2]);e.lineEnd()}function Dh(r,e){var t=-1,n=r.length;for(e.polygonStart();++t<n;)pl(r[t],e,1);e.polygonEnd()}function Xy(r,e){r&&Ph.hasOwnProperty(r.type)?Ph[r.type](r,e):So(r,e)}var Qi=1/0,To=Qi,Or=-Qi,Eo=Or,Yy={point:Jy,lineStart:Nr,lineEnd:Nr,polygonStart:Nr,polygonEnd:Nr,result:function(){var r=[[Qi,To],[Or,Eo]];return Or=Eo=-(To=Qi=1/0),r}};function Jy(r,e){r<Qi&&(Qi=r),r>Or&&(Or=r),e<To&&(To=e),e>Eo&&(Eo=e)}var Fh=Yy;function ml(r,e,t){var n=r.clipExtent&&r.clipExtent();return r.scale(150).translate([0,0]),n!=null&&r.clipExtent(null),Xy(t,r.stream(Fh)),e(Fh.result()),n!=null&&r.clipExtent(n),r}function Bh(r,e,t){return ml(r,function(n){var i=e[1][0]-e[0][0],s=e[1][1]-e[0][1],o=Math.min(i/(n[1][0]-n[0][0]),s/(n[1][1]-n[0][1])),a=+e[0][0]+(i-o*(n[1][0]+n[0][0]))/2,l=+e[0][1]+(s-o*(n[1][1]+n[0][1]))/2;r.scale(150*o).translate([a,l])},t)}function Zy(r,e,t){return Bh(r,[[0,0],e],t)}function $y(r,e,t){return ml(r,function(n){var i=+e,s=i/(n[1][0]-n[0][0]),o=(i-s*(n[1][0]+n[0][0]))/2,a=-s*n[0][1];r.scale(150*s).translate([o,a])},t)}function jy(r,e,t){return ml(r,function(n){var i=+e,s=i/(n[1][1]-n[0][1]),o=-s*n[0][0],a=(i-s*(n[1][1]+n[0][1]))/2;r.scale(150*s).translate([o,a])},t)}var zh=16,Qy=ot(30*ut);function Nh(r,e){return+e?ev(r,e):Ky(r)}function Ky(r){return wo({point:function(e,t){e=r(e,t),this.stream.point(e[0],e[1])}})}function ev(r,e){function t(n,i,s,o,a,l,c,u,h,f,d,m,x,v){var g=c-n,p=u-i,_=g*g+p*p;if(_>4*e&&x--){var y=o+f,M=a+d,w=l+m,A=go(y*y+M*M+w*w),C=zr(w/=A),N=st(st(w)-1)<Je||st(s-h)<Je?(s+h)/2:Br(M,y),z=r(N,C),I=z[0],b=z[1],T=I-n,B=b-i,R=p*T-g*B;(R*R/_>e||st((g*T+p*B)/_-.5)>.3||o*f+a*d+l*m<Qy)&&(t(n,i,s,o,a,l,I,b,N,y/=A,M/=A,w,x,v),v.point(I,b),t(I,b,N,y,M,w,c,u,h,f,d,m,x,v))}}return function(n){var i,s,o,a,l,c,u,h,f,d,m,x,v={point:g,lineStart:p,lineEnd:y,polygonStart:function(){n.polygonStart(),v.lineStart=M},polygonEnd:function(){n.polygonEnd(),v.lineStart=p}};function g(C,N){C=r(C,N),n.point(C[0],C[1])}function p(){h=NaN,v.point=_,n.lineStart()}function _(C,N){var z=ji([C,N]),I=r(C,N);t(h,f,u,d,m,x,h=I[0],f=I[1],u=C,d=z[0],m=z[1],x=z[2],zh,n),n.point(h,f)}function y(){v.point=g,n.lineEnd()}function M(){p(),v.point=w,v.lineEnd=A}function w(C,N){_(i=C,N),s=h,o=f,a=d,l=m,c=x,v.point=_}function A(){t(h,f,u,d,m,x,s,o,i,a,l,c,zh,n),v.lineEnd=y,y()}return v}}var tv=wo({point:function(r,e){this.stream.point(r*ut,e*ut)}});function nv(r){return wo({point:function(e,t){var n=r(e,t);return this.stream.point(n[0],n[1])}})}function iv(r,e,t,n,i){function s(o,a){return o*=n,a*=i,[e+r*o,t-r*a]}return s.invert=function(o,a){return[(o-e)/r*n,(t-a)/r*i]},s}function Uh(r,e,t,n,i,s){if(!s)return iv(r,e,t,n,i);var o=ot(s),a=et(s),l=o*r,c=a*r,u=o/r,h=a/r,f=(a*t-o*e)/r,d=(a*e+o*t)/r;function m(x,v){return x*=n,v*=i,[l*x-c*v+e,t-c*x-l*v]}return m.invert=function(x,v){return[n*(u*x-h*v+f),i*(d-h*x-u*v)]},m}function rv(r){return sv(function(){return r})()}function sv(r){var e,t=150,n=480,i=250,s=0,o=0,a=0,l=0,c=0,u,h=0,f=1,d=1,m=null,x=Ah,v=null,g,p,_,y=Rh,M=.5,w,A,C,N,z;function I(R){return C(R[0]*ut,R[1]*ut)}function b(R){return R=C.invert(R[0],R[1]),R&&[R[0]*Ft,R[1]*Ft]}I.stream=function(R){return N&&z===R?N:N=tv(nv(u)(x(w(y(z=R)))))},I.preclip=function(R){return arguments.length?(x=R,m=void 0,B()):x},I.postclip=function(R){return arguments.length?(y=R,v=g=p=_=null,B()):y},I.clipAngle=function(R){return arguments.length?(x=+R?ky(m=R*ut):(m=null,Ah),B()):m*Ft},I.clipExtent=function(R){return arguments.length?(y=R==null?(v=g=p=_=null,Rh):qy(v=+R[0][0],g=+R[0][1],p=+R[1][0],_=+R[1][1]),B()):v==null?null:[[v,g],[p,_]]},I.scale=function(R){return arguments.length?(t=+R,T()):t},I.translate=function(R){return arguments.length?(n=+R[0],i=+R[1],T()):[n,i]},I.center=function(R){return arguments.length?(s=R[0]%360*ut,o=R[1]%360*ut,T()):[s*Ft,o*Ft]},I.rotate=function(R){return arguments.length?(a=R[0]%360*ut,l=R[1]%360*ut,c=R.length>2?R[2]%360*ut:0,T()):[a*Ft,l*Ft,c*Ft]},I.angle=function(R){return arguments.length?(h=R%360*ut,T()):h*Ft},I.reflectX=function(R){return arguments.length?(f=R?-1:1,T()):f<0},I.reflectY=function(R){return arguments.length?(d=R?-1:1,T()):d<0},I.precision=function(R){return arguments.length?(w=Nh(A,M=R*R),B()):go(M)},I.fitExtent=function(R,F){return Bh(I,R,F)},I.fitSize=function(R,F){return Zy(I,R,F)},I.fitWidth=function(R,F){return $y(I,R,F)},I.fitHeight=function(R,F){return jy(I,R,F)};function T(){var R=Uh(t,0,0,f,d,h).apply(null,e(s,o)),F=Uh(t,n-R[0],i-R[1],f,d,h);return u=yh(a,l,c),A=ol(e,F),C=ol(u,A),w=Nh(A,M),B()}function B(){return N=z=null,I}return function(){return e=r.apply(this,arguments),I.invert=e.invert&&b,T()}}function gl(r,e){return[r,Py(Dy((Rt+e)/2))]}gl.invert=function(r,e){return[r,2*xh(Ry(e))-Rt]};function ov(){return av(gl).scale(961/Ht)}function av(r){var e=rv(r),t=e.center,n=e.scale,i=e.translate,s=e.clipExtent,o=null,a,l,c;e.scale=function(h){return arguments.length?(n(h),u()):n()},e.translate=function(h){return arguments.length?(i(h),u()):i()},e.center=function(h){return arguments.length?(t(h),u()):t()},e.clipExtent=function(h){return arguments.length?(h==null?o=a=l=c=null:(o=+h[0][0],a=+h[0][1],l=+h[1][0],c=+h[1][1]),u()):o==null?null:[[o,a],[l,c]]};function u(){var h=Ne*n(),f=e(By(e.rotate()).invert([0,0]));return s(o==null?[[f[0]-h,f[1]-h],[f[0]+h,f[1]+h]]:r===gl?[[Math.max(f[0]-h,o),a],[Math.min(f[0]+h,l),c]]:[[o,Math.max(f[1]-h,a)],[l,Math.min(f[1]+h,c)]])}return u()}var lv=function(r){return ov().center(r.center).scale(r.scale).translate([0,0]).precision(.1)},cv=function(r,e){return e.map(function(t){var n=mh(t,2),i=n[0],s=n[1],o=mh(r([i,s]),2),a=o[0],l=o[1];return new S(a,-l,0)})};self.onmessage=function(r){var e=r.data,t=e.req,n=t.coordinatesArr,i=t.projection,s=e.uuid,o=lv({center:i.center,scale:i.scale}),a=n.map(function(h){return cv(o,h)}),l=xy(a.map(function(h){return Ey({nodes:h})}),!1),c={},u=[];nr(Object.keys(l.attributes)).concat(["index"]).forEach(function(h){var f=h==="index"?l.index:l.attributes[h];c[h]={array:f.array,itemSize:f.itemSize},u.push(f.array.buffer)}),self.postMessage({res:c,uuid:s},u),l.dispose()},module.exports=Lt})();
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "gl-draw",
3
- "version": "0.4.6",
3
+ "version": "0.4.7",
4
4
  "author": "gitplus <hstits@gmail.com>",
5
5
  "scripts": {
6
6
  "start": "PORT=3003 bundler-dev",