@esotericsoftware/spine-webgl 4.2.8 → 4.2.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/Mesh.js +19 -19
- package/dist/Shader.js +6 -6
- package/dist/SkeletonDebugRenderer.js +2 -2
- package/dist/SpineCanvas.js +2 -2
- package/dist/WebGL.d.ts +0 -1
- package/dist/iife/spine-webgl.js +13 -8
- package/dist/iife/spine-webgl.js.map +2 -2
- package/dist/iife/spine-webgl.min.js +3 -3
- package/package.json +2 -2
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
var spine=(()=>{var Vi=Object.defineProperty,Ss=e=>Vi(e,"__esModule",{value:!0}),Cs=(e,t)=>{Ss(e);for(var i in t)Vi(e,i,{get:t[i],enumerable:!0})},Ni={};Cs(Ni,{AlphaTimeline:()=>ii,Animation:()=>yt,AnimationState:()=>Hi,AnimationStateAdapter:()=>Ys,AnimationStateData:()=>ks,AssetManager:()=>hs,AssetManagerBase:()=>is,AtlasAttachmentLoader:()=>Xs,Attachment:()=>Wt,AttachmentTimeline:()=>Qe,BinaryInput:()=>as,BlendMode:()=>pe,Bone:()=>pi,BoneData:()=>wi,BoundingBoxAttachment:()=>It,CURRENT:()=>Ji,CameraController:()=>hr,ClippingAttachment:()=>xt,Color:()=>O,Color2Attribute:()=>fs,ColorAttribute:()=>Lt,ConstraintData:()=>Mt,CurveTimeline:()=>ke,CurveTimeline1:()=>Re,CurveTimeline2:()=>At,DebugUtils:()=>Ms,DeformTimeline:()=>ni,Downloader:()=>bi,DrawOrderTimeline:()=>$e,Event:()=>vi,EventData:()=>yi,EventQueue:()=>Zi,EventTimeline:()=>gt,EventType:()=>Ce,FIRST:()=>di,FakeTexture:()=>Rs,GLTexture:()=>wt,HOLD_FIRST:()=>Tt,HOLD_MIX:()=>Ki,HOLD_SUBSEQUENT:()=>fi,IkConstraint:()=>ss,IkConstraintData:()=>Ai,IkConstraintTimeline:()=>ai,Input:()=>ki,IntSet:()=>Ts,Interpolation:()=>Ui,LoadingScreen:()=>ur,M00:()=>D,M01:()=>_,M02:()=>q,M03:()=>V,M10:()=>G,M11:()=>N,M12:()=>H,M13:()=>U,M20:()=>j,M21:()=>Z,M22:()=>z,M23:()=>W,M30:()=>J,M31:()=>Q,M32:()=>$,M33:()=>K,ManagedWebGLRenderingContext:()=>ye,MathUtils:()=>R,Matrix4:()=>_e,Mesh:()=>Ri,MeshAttachment:()=>Ge,MixBlend:()=>ue,MixDirection:()=>Ne,OrthoCamera:()=>cs,PathAttachment:()=>tt,PathConstraint:()=>nt,PathConstraintData:()=>Si,PathConstraintMixTimeline:()=>ci,PathConstraintPositionTimeline:()=>oi,PathConstraintSpacingTimeline:()=>hi,PointAttachment:()=>xi,PolygonBatcher:()=>Xi,Pool:()=>ut,Position2Attribute:()=>Xt,Position3Attribute:()=>cr,PositionMode:()=>Fe,Pow:()=>zi,PowOut:()=>Is,RGB2Timeline:()=>ri,RGBA2Timeline:()=>si,RGBATimeline:()=>ei,RGBTimeline:()=>ti,RegionAttachment:()=>ne,ResizeMode:()=>ot,RotateMode:()=>He,RotateTimeline:()=>mt,SETUP:()=>ui,SUBSEQUENT:()=>Ct,ScaleTimeline:()=>jt,ScaleXTimeline:()=>Zt,ScaleYTimeline:()=>Kt,SceneRenderer:()=>ms,SequenceTimeline:()=>rt,Shader:()=>be,ShapeRenderer:()=>Li,ShapeType:()=>Ae,ShearTimeline:()=>Jt,ShearXTimeline:()=>Qt,ShearYTimeline:()=>$t,Skeleton:()=>Ls,SkeletonBinary:()=>Ps,SkeletonBounds:()=>ls,SkeletonClipping:()=>Yt,SkeletonData:()=>Ci,SkeletonDebugRenderer:()=>Bt,SkeletonJson:()=>nr,SkeletonRenderer:()=>Pi,Skin:()=>Et,SkinEntry:()=>Ti,Slot:()=>rs,SlotData:()=>Ii,SpacingMode:()=>xe,SpineCanvas:()=>xr,StringSet:()=>Ut,TexCoordAttribute:()=>Fi,Texture:()=>mi,TextureAtlas:()=>$i,TextureAtlasPage:()=>es,TextureAtlasRegion:()=>gi,TextureFilter:()=>we,TextureRegion:()=>Qi,TextureWrap:()=>et,TimeKeeper:()=>zt,Timeline:()=>me,Touch:()=>ds,TrackEntry:()=>ji,TransformConstraint:()=>ns,TransformConstraintData:()=>Mi,TransformConstraintTimeline:()=>li,TransformMode:()=>ge,TranslateTimeline:()=>qt,TranslateXTimeline:()=>Gt,TranslateYTimeline:()=>Ht,Triangulator:()=>Te,Utils:()=>B,Vector2:()=>Je,Vector3:()=>Ie,VertexAttachment:()=>Ye,VertexAttribute:()=>lt,VertexAttributeType:()=>je,WebGLBlendModeConverter:()=>Rt,WindowedMean:()=>Es});var Ts=class{constructor(){this.array=new Array}add(e){let t=this.contains(e);return this.array[e|0]=e|0,!t}contains(e){return this.array[e|0]!=null}remove(e){this.array[e|0]=void 0}clear(){this.array.length=0}},Ut=class{constructor(){this.entries={},this.size=0}add(e){let t=this.entries[e];return this.entries[e]=!0,t?!1:(this.size++,!0)}addAll(e){let t=this.size;for(var i=0,s=e.length;i<s;i++)this.add(e[i]);return t!=this.size}contains(e){return this.entries[e]}clear(){this.entries={},this.size=0}},Ke=class{constructor(e=0,t=0,i=0,s=0){this.r=e,this.g=t,this.b=i,this.a=s}set(e,t,i,s){return this.r=e,this.g=t,this.b=i,this.a=s,this.clamp()}setFromColor(e){return this.r=e.r,this.g=e.g,this.b=e.b,this.a=e.a,this}setFromString(e){return e=e.charAt(0)=="#"?e.substr(1):e,this.r=parseInt(e.substr(0,2),16)/255,this.g=parseInt(e.substr(2,2),16)/255,this.b=parseInt(e.substr(4,2),16)/255,this.a=e.length!=8?1:parseInt(e.substr(6,2),16)/255,this}add(e,t,i,s){return this.r+=e,this.g+=t,this.b+=i,this.a+=s,this.clamp()}clamp(){return this.r<0?this.r=0:this.r>1&&(this.r=1),this.g<0?this.g=0:this.g>1&&(this.g=1),this.b<0?this.b=0:this.b>1&&(this.b=1),this.a<0?this.a=0:this.a>1&&(this.a=1),this}static rgba8888ToColor(e,t){e.r=((t&4278190080)>>>24)/255,e.g=((t&16711680)>>>16)/255,e.b=((t&65280)>>>8)/255,e.a=(t&255)/255}static rgb888ToColor(e,t){e.r=((t&16711680)>>>16)/255,e.g=((t&65280)>>>8)/255,e.b=(t&255)/255}static fromString(e){return new Ke().setFromString(e)}},O=Ke;O.WHITE=new Ke(1,1,1,1),O.RED=new Ke(1,0,0,1),O.GREEN=new Ke(0,1,0,1),O.BLUE=new Ke(0,0,1,1),O.MAGENTA=new Ke(1,0,1,1);var Ve=class{static clamp(e,t,i){return e<t?t:e>i?i:e}static cosDeg(e){return Math.cos(e*Ve.degRad)}static sinDeg(e){return Math.sin(e*Ve.degRad)}static signum(e){return e>0?1:e<0?-1:0}static toInt(e){return e>0?Math.floor(e):Math.ceil(e)}static cbrt(e){let t=Math.pow(Math.abs(e),1/3);return e<0?-t:t}static randomTriangular(e,t){return Ve.randomTriangularWith(e,t,(e+t)*.5)}static randomTriangularWith(e,t,i){let s=Math.random(),n=t-e;return s<=(i-e)/n?e+Math.sqrt(s*n*(i-e)):t-Math.sqrt((1-s)*n*(t-i))}static isPowerOfTwo(e){return e&&(e&e-1)==0}},R=Ve;R.PI=3.1415927,R.PI2=Ve.PI*2,R.radiansToDegrees=180/Ve.PI,R.radDeg=Ve.radiansToDegrees,R.degreesToRadians=Ve.PI/180,R.degRad=Ve.degreesToRadians;var Ui=class{apply(e,t,i){return e+(t-e)*this.applyInternal(i)}},zi=class extends Ui{constructor(e){super();this.power=2,this.power=e}applyInternal(e){return e<=.5?Math.pow(e*2,this.power)/2:Math.pow((e-1)*2,this.power)/(this.power%2==0?-2:2)+1}},Is=class extends zi{constructor(e){super(e)}applyInternal(e){return Math.pow(e-1,this.power)*(this.power%2==0?-1:1)+1}},st=class{static arrayCopy(e,t,i,s,n){for(let c=t,a=s;c<t+n;c++,a++)i[a]=e[c]}static arrayFill(e,t,i,s){for(let n=t;n<i;n++)e[n]=s}static setArraySize(e,t,i=0){let s=e.length;if(s==t)return e;if(e.length=t,s<t)for(let n=s;n<t;n++)e[n]=i;return e}static ensureArrayCapacity(e,t,i=0){return e.length>=t?e:st.setArraySize(e,t,i)}static newArray(e,t){let i=new Array(e);for(let s=0;s<e;s++)i[s]=t;return i}static newFloatArray(e){if(st.SUPPORTS_TYPED_ARRAYS)return new Float32Array(e);{let t=new Array(e);for(let i=0;i<t.length;i++)t[i]=0;return t}}static newShortArray(e){if(st.SUPPORTS_TYPED_ARRAYS)return new Int16Array(e);{let t=new Array(e);for(let i=0;i<t.length;i++)t[i]=0;return t}}static toFloatArray(e){return st.SUPPORTS_TYPED_ARRAYS?new Float32Array(e):e}static toSinglePrecision(e){return st.SUPPORTS_TYPED_ARRAYS?Math.fround(e):e}static webkit602BugfixHelper(e,t){}static contains(e,t,i=!0){for(var s=0;s<e.length;s++)if(e[s]==t)return!0;return!1}static enumValue(e,t){return e[t[0].toUpperCase()+t.slice(1)]}},B=st;B.SUPPORTS_TYPED_ARRAYS=typeof Float32Array!="undefined";var Ms=class{static logBones(e){for(let t=0;t<e.bones.length;t++){let i=e.bones[t];console.log(i.data.name+", "+i.a+", "+i.b+", "+i.c+", "+i.d+", "+i.worldX+", "+i.worldY)}}},ut=class{constructor(e){this.items=new Array,this.instantiator=e}obtain(){return this.items.length>0?this.items.pop():this.instantiator()}free(e){e.reset&&e.reset(),this.items.push(e)}freeAll(e){for(let t=0;t<e.length;t++)this.free(e[t])}clear(){this.items.length=0}},Je=class{constructor(e=0,t=0){this.x=e,this.y=t}set(e,t){return this.x=e,this.y=t,this}length(){let e=this.x,t=this.y;return Math.sqrt(e*e+t*t)}normalize(){let e=this.length();return e!=0&&(this.x/=e,this.y/=e),this}},zt=class{constructor(){this.maxDelta=.064,this.framesPerSecond=0,this.delta=0,this.totalTime=0,this.lastTime=Date.now()/1e3,this.frameCount=0,this.frameTime=0}update(){let e=Date.now()/1e3;this.delta=e-this.lastTime,this.frameTime+=this.delta,this.totalTime+=this.delta,this.delta>this.maxDelta&&(this.delta=this.maxDelta),this.lastTime=e,this.frameCount++,this.frameTime>1&&(this.framesPerSecond=this.frameCount/this.frameTime,this.frameTime=0,this.frameCount=0)}},Es=class{constructor(e=32){this.addedValues=0,this.lastValue=0,this.mean=0,this.dirty=!0,this.values=new Array(e)}hasEnoughData(){return this.addedValues>=this.values.length}addValue(e){this.addedValues<this.values.length&&this.addedValues++,this.values[this.lastValue++]=e,this.lastValue>this.values.length-1&&(this.lastValue=0),this.dirty=!0}getMean(){if(this.hasEnoughData()){if(this.dirty){let e=0;for(let t=0;t<this.values.length;t++)e+=this.values[t];this.mean=e/this.values.length,this.dirty=!1}return this.mean}return 0}},Wt=class{constructor(e){if(!e)throw new Error("name cannot be null.");this.name=e}},Wi=class extends Wt{constructor(e){super(e);this.id=Wi.nextID++,this.bones=null,this.vertices=[],this.worldVerticesLength=0,this.timelineAttachment=this}computeWorldVertices(e,t,i,s,n,c){i=n+(i>>1)*c;let a=e.bone.skeleton,r=e.deform,o=this.vertices,l=this.bones;if(!l){r.length>0&&(o=r);let u=e.bone,m=u.worldX,x=u.worldY,b=u.a,v=u.b,g=u.c,w=u.d;for(let p=t,y=n;y<i;p+=2,y+=c){let S=o[p],A=o[p+1];s[y]=S*b+A*v+m,s[y+1]=S*g+A*w+x}return}let h=0,f=0;for(let u=0;u<t;u+=2){let m=l[h];h+=m+1,f+=m}let d=a.bones;if(r.length==0)for(let u=n,m=f*3;u<i;u+=c){let x=0,b=0,v=l[h++];for(v+=h;h<v;h++,m+=3){let g=d[l[h]],w=o[m],p=o[m+1],y=o[m+2];x+=(w*g.a+p*g.b+g.worldX)*y,b+=(w*g.c+p*g.d+g.worldY)*y}s[u]=x,s[u+1]=b}else{let u=r;for(let m=n,x=f*3,b=f<<1;m<i;m+=c){let v=0,g=0,w=l[h++];for(w+=h;h<w;h++,x+=3,b+=2){let p=d[l[h]],y=o[x]+u[b],S=o[x+1]+u[b+1],A=o[x+2];v+=(y*p.a+S*p.b+p.worldX)*A,g+=(y*p.c+S*p.d+p.worldY)*A}s[m]=v,s[m+1]=g}}}copyTo(e){this.bones?(e.bones=new Array(this.bones.length),B.arrayCopy(this.bones,0,e.bones,0,this.bones.length)):e.bones=null,this.vertices&&(e.vertices=B.newFloatArray(this.vertices.length),B.arrayCopy(this.vertices,0,e.vertices,0,this.vertices.length)),e.worldVerticesLength=this.worldVerticesLength,e.timelineAttachment=this.timelineAttachment}},Ye=Wi;Ye.nextID=0;var vt=class{constructor(e){this.id=vt.nextID(),this.start=0,this.digits=0,this.setupIndex=0,this.regions=new Array(e)}copy(){let e=new vt(this.regions.length);return B.arrayCopy(this.regions,0,e.regions,0,this.regions.length),e.start=this.start,e.digits=this.digits,e.setupIndex=this.setupIndex,e}apply(e,t){let i=e.sequenceIndex;i==-1&&(i=this.setupIndex),i>=this.regions.length&&(i=this.regions.length-1);let s=this.regions[i];t.region!=s&&(t.region=s,t.updateRegion())}getPath(e,t){let i=e,s=(this.start+t).toString();for(let n=this.digits-s.length;n>0;n--)i+="0";return i+=s,i}static nextID(){return vt._nextID++}},_t=vt;_t._nextID=0;var Oe;(function(e){e[e.hold=0]="hold",e[e.once=1]="once",e[e.loop=2]="loop",e[e.pingpong=3]="pingpong",e[e.onceReverse=4]="onceReverse",e[e.loopReverse=5]="loopReverse",e[e.pingpongReverse=6]="pingpongReverse"})(Oe||(Oe={}));var _i=[0,1,2,3,4,5,6],yt=class{constructor(e,t,i){if(this.timelines=[],this.timelineIds=new Ut,!e)throw new Error("name cannot be null.");this.name=e,this.setTimelines(t),this.duration=i}setTimelines(e){if(!e)throw new Error("timelines cannot be null.");this.timelines=e,this.timelineIds.clear();for(var t=0;t<e.length;t++)this.timelineIds.addAll(e[t].getPropertyIds())}hasTimeline(e){for(let t=0;t<e.length;t++)if(this.timelineIds.contains(e[t]))return!0;return!1}apply(e,t,i,s,n,c,a,r){if(!e)throw new Error("skeleton cannot be null.");s&&this.duration!=0&&(i%=this.duration,t>0&&(t%=this.duration));let o=this.timelines;for(let l=0,h=o.length;l<h;l++)o[l].apply(e,t,i,n,c,a,r)}},ue;(function(e){e[e.setup=0]="setup",e[e.first=1]="first",e[e.replace=2]="replace",e[e.add=3]="add"})(ue||(ue={}));var Ne;(function(e){e[e.mixIn=0]="mixIn",e[e.mixOut=1]="mixOut"})(Ne||(Ne={}));var ce={rotate:0,x:1,y:2,scaleX:3,scaleY:4,shearX:5,shearY:6,rgb:7,alpha:8,rgb2:9,attachment:10,deform:11,event:12,drawOrder:13,ikConstraint:14,transformConstraint:15,pathConstraintPosition:16,pathConstraintSpacing:17,pathConstraintMix:18,sequence:19},me=class{constructor(e,t){this.propertyIds=t,this.frames=B.newFloatArray(e*this.getFrameEntries())}getPropertyIds(){return this.propertyIds}getFrameEntries(){return 1}getFrameCount(){return this.frames.length/this.getFrameEntries()}getDuration(){return this.frames[this.frames.length-this.getFrameEntries()]}static search1(e,t){let i=e.length;for(let s=1;s<i;s++)if(e[s]>t)return s-1;return i-1}static search(e,t,i){let s=e.length;for(let n=i;n<s;n+=i)if(e[n]>t)return n-i;return s-i}},ke=class extends me{constructor(e,t,i){super(e,i);this.curves=B.newFloatArray(e+t*18),this.curves[e-1]=1}setLinear(e){this.curves[e]=0}setStepped(e){this.curves[e]=1}shrink(e){let t=this.getFrameCount()+e*18;if(this.curves.length>t){let i=B.newFloatArray(t);B.arrayCopy(this.curves,0,i,0,t),this.curves=i}}setBezier(e,t,i,s,n,c,a,r,o,l,h){let f=this.curves,d=this.getFrameCount()+e*18;i==0&&(f[t]=2+d);let u=(s-c*2+r)*.03,m=(n-a*2+o)*.03,x=((c-r)*3-s+l)*.006,b=((a-o)*3-n+h)*.006,v=u*2+x,g=m*2+b,w=(c-s)*.3+u+x*.16666667,p=(a-n)*.3+m+b*.16666667,y=s+w,S=n+p;for(let A=d+18;d<A;d+=2)f[d]=y,f[d+1]=S,w+=v,p+=g,v+=x,g+=b,y+=w,S+=p}getBezierValue(e,t,i,s){let n=this.curves;if(n[s]>e){let o=this.frames[t],l=this.frames[t+i];return l+(e-o)/(n[s]-o)*(n[s+1]-l)}let c=s+18;for(s+=2;s<c;s+=2)if(n[s]>=e){let o=n[s-2],l=n[s-1];return l+(e-o)/(n[s]-o)*(n[s+1]-l)}t+=this.getFrameEntries();let a=n[c-2],r=n[c-1];return r+(e-a)/(this.frames[t]-a)*(this.frames[t+i]-r)}},Re=class extends ke{constructor(e,t,i){super(e,t,[i])}getFrameEntries(){return 2}setFrame(e,t,i){e<<=1,this.frames[e]=t,this.frames[e+1]=i}getCurveValue(e){let t=this.frames,i=t.length-2;for(let n=2;n<=i;n+=2)if(t[n]>e){i=n-2;break}let s=this.curves[i>>1];switch(s){case 0:let n=t[i],c=t[i+1];return c+(e-n)/(t[i+2]-n)*(t[i+2+1]-c);case 1:return t[i+1]}return this.getBezierValue(e,i,1,s-2)}},At=class extends ke{constructor(e,t,i,s){super(e,t,[i,s])}getFrameEntries(){return 3}setFrame(e,t,i,s){e*=3,this.frames[e]=t,this.frames[e+1]=i,this.frames[e+2]=s}},mt=class extends Re{constructor(e,t,i){super(e,t,ce.rotate+"|"+i);this.boneIndex=0,this.boneIndex=i}apply(e,t,i,s,n,c,a){let r=e.bones[this.boneIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(c){case 0:r.rotation=r.data.rotation;return;case 1:r.rotation+=(r.data.rotation-r.rotation)*n}return}let l=this.getCurveValue(i);switch(c){case 0:r.rotation=r.data.rotation+l*n;break;case 1:case 2:l+=r.data.rotation-r.rotation;case 3:r.rotation+=l*n}}},qt=class extends At{constructor(e,t,i){super(e,t,ce.x+"|"+i,ce.y+"|"+i);this.boneIndex=0,this.boneIndex=i}apply(e,t,i,s,n,c,a){let r=e.bones[this.boneIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(c){case 0:r.x=r.data.x,r.y=r.data.y;return;case 1:r.x+=(r.data.x-r.x)*n,r.y+=(r.data.y-r.y)*n}return}let l=0,h=0,f=me.search(o,i,3),d=this.curves[f/3];switch(d){case 0:let u=o[f];l=o[f+1],h=o[f+2];let m=(i-u)/(o[f+3]-u);l+=(o[f+3+1]-l)*m,h+=(o[f+3+2]-h)*m;break;case 1:l=o[f+1],h=o[f+2];break;default:l=this.getBezierValue(i,f,1,d-2),h=this.getBezierValue(i,f,2,d+18-2)}switch(c){case 0:r.x=r.data.x+l*n,r.y=r.data.y+h*n;break;case 1:case 2:r.x+=(r.data.x+l-r.x)*n,r.y+=(r.data.y+h-r.y)*n;break;case 3:r.x+=l*n,r.y+=h*n}}},Gt=class extends Re{constructor(e,t,i){super(e,t,ce.x+"|"+i);this.boneIndex=0,this.boneIndex=i}apply(e,t,i,s,n,c,a){let r=e.bones[this.boneIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(c){case 0:r.x=r.data.x;return;case 1:r.x+=(r.data.x-r.x)*n}return}let l=this.getCurveValue(i);switch(c){case 0:r.x=r.data.x+l*n;break;case 1:case 2:r.x+=(r.data.x+l-r.x)*n;break;case 3:r.x+=l*n}}},Ht=class extends Re{constructor(e,t,i){super(e,t,ce.y+"|"+i);this.boneIndex=0,this.boneIndex=i}apply(e,t,i,s,n,c,a){let r=e.bones[this.boneIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(c){case 0:r.y=r.data.y;return;case 1:r.y+=(r.data.y-r.y)*n}return}let l=this.getCurveValue(i);switch(c){case 0:r.y=r.data.y+l*n;break;case 1:case 2:r.y+=(r.data.y+l-r.y)*n;break;case 3:r.y+=l*n}}},jt=class extends At{constructor(e,t,i){super(e,t,ce.scaleX+"|"+i,ce.scaleY+"|"+i);this.boneIndex=0,this.boneIndex=i}apply(e,t,i,s,n,c,a){let r=e.bones[this.boneIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(c){case 0:r.scaleX=r.data.scaleX,r.scaleY=r.data.scaleY;return;case 1:r.scaleX+=(r.data.scaleX-r.scaleX)*n,r.scaleY+=(r.data.scaleY-r.scaleY)*n}return}let l,h,f=me.search(o,i,3),d=this.curves[f/3];switch(d){case 0:let u=o[f];l=o[f+1],h=o[f+2];let m=(i-u)/(o[f+3]-u);l+=(o[f+3+1]-l)*m,h+=(o[f+3+2]-h)*m;break;case 1:l=o[f+1],h=o[f+2];break;default:l=this.getBezierValue(i,f,1,d-2),h=this.getBezierValue(i,f,2,d+18-2)}if(l*=r.data.scaleX,h*=r.data.scaleY,n==1)c==3?(r.scaleX+=l-r.data.scaleX,r.scaleY+=h-r.data.scaleY):(r.scaleX=l,r.scaleY=h);else{let u=0,m=0;if(a==1)switch(c){case 0:u=r.data.scaleX,m=r.data.scaleY,r.scaleX=u+(Math.abs(l)*R.signum(u)-u)*n,r.scaleY=m+(Math.abs(h)*R.signum(m)-m)*n;break;case 1:case 2:u=r.scaleX,m=r.scaleY,r.scaleX=u+(Math.abs(l)*R.signum(u)-u)*n,r.scaleY=m+(Math.abs(h)*R.signum(m)-m)*n;break;case 3:r.scaleX+=(l-r.data.scaleX)*n,r.scaleY+=(h-r.data.scaleY)*n}else switch(c){case 0:u=Math.abs(r.data.scaleX)*R.signum(l),m=Math.abs(r.data.scaleY)*R.signum(h),r.scaleX=u+(l-u)*n,r.scaleY=m+(h-m)*n;break;case 1:case 2:u=Math.abs(r.scaleX)*R.signum(l),m=Math.abs(r.scaleY)*R.signum(h),r.scaleX=u+(l-u)*n,r.scaleY=m+(h-m)*n;break;case 3:r.scaleX+=(l-r.data.scaleX)*n,r.scaleY+=(h-r.data.scaleY)*n}}}},Zt=class extends Re{constructor(e,t,i){super(e,t,ce.scaleX+"|"+i);this.boneIndex=0,this.boneIndex=i}apply(e,t,i,s,n,c,a){let r=e.bones[this.boneIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(c){case 0:r.scaleX=r.data.scaleX;return;case 1:r.scaleX+=(r.data.scaleX-r.scaleX)*n}return}let l=this.getCurveValue(i)*r.data.scaleX;if(n==1)c==3?r.scaleX+=l-r.data.scaleX:r.scaleX=l;else{let h=0;if(a==1)switch(c){case 0:h=r.data.scaleX,r.scaleX=h+(Math.abs(l)*R.signum(h)-h)*n;break;case 1:case 2:h=r.scaleX,r.scaleX=h+(Math.abs(l)*R.signum(h)-h)*n;break;case 3:r.scaleX+=(l-r.data.scaleX)*n}else switch(c){case 0:h=Math.abs(r.data.scaleX)*R.signum(l),r.scaleX=h+(l-h)*n;break;case 1:case 2:h=Math.abs(r.scaleX)*R.signum(l),r.scaleX=h+(l-h)*n;break;case 3:r.scaleX+=(l-r.data.scaleX)*n}}}},Kt=class extends Re{constructor(e,t,i){super(e,t,ce.scaleY+"|"+i);this.boneIndex=0,this.boneIndex=i}apply(e,t,i,s,n,c,a){let r=e.bones[this.boneIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(c){case 0:r.scaleY=r.data.scaleY;return;case 1:r.scaleY+=(r.data.scaleY-r.scaleY)*n}return}let l=this.getCurveValue(i)*r.data.scaleY;if(n==1)c==3?r.scaleY+=l-r.data.scaleY:r.scaleY=l;else{let h=0;if(a==1)switch(c){case 0:h=r.data.scaleY,r.scaleY=h+(Math.abs(l)*R.signum(h)-h)*n;break;case 1:case 2:h=r.scaleY,r.scaleY=h+(Math.abs(l)*R.signum(h)-h)*n;break;case 3:r.scaleY+=(l-r.data.scaleY)*n}else switch(c){case 0:h=Math.abs(r.data.scaleY)*R.signum(l),r.scaleY=h+(l-h)*n;break;case 1:case 2:h=Math.abs(r.scaleY)*R.signum(l),r.scaleY=h+(l-h)*n;break;case 3:r.scaleY+=(l-r.data.scaleY)*n}}}},Jt=class extends At{constructor(e,t,i){super(e,t,ce.shearX+"|"+i,ce.shearY+"|"+i);this.boneIndex=0,this.boneIndex=i}apply(e,t,i,s,n,c,a){let r=e.bones[this.boneIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(c){case 0:r.shearX=r.data.shearX,r.shearY=r.data.shearY;return;case 1:r.shearX+=(r.data.shearX-r.shearX)*n,r.shearY+=(r.data.shearY-r.shearY)*n}return}let l=0,h=0,f=me.search(o,i,3),d=this.curves[f/3];switch(d){case 0:let u=o[f];l=o[f+1],h=o[f+2];let m=(i-u)/(o[f+3]-u);l+=(o[f+3+1]-l)*m,h+=(o[f+3+2]-h)*m;break;case 1:l=o[f+1],h=o[f+2];break;default:l=this.getBezierValue(i,f,1,d-2),h=this.getBezierValue(i,f,2,d+18-2)}switch(c){case 0:r.shearX=r.data.shearX+l*n,r.shearY=r.data.shearY+h*n;break;case 1:case 2:r.shearX+=(r.data.shearX+l-r.shearX)*n,r.shearY+=(r.data.shearY+h-r.shearY)*n;break;case 3:r.shearX+=l*n,r.shearY+=h*n}}},Qt=class extends Re{constructor(e,t,i){super(e,t,ce.shearX+"|"+i);this.boneIndex=0,this.boneIndex=i}apply(e,t,i,s,n,c,a){let r=e.bones[this.boneIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(c){case 0:r.shearX=r.data.shearX;return;case 1:r.shearX+=(r.data.shearX-r.shearX)*n}return}let l=this.getCurveValue(i);switch(c){case 0:r.shearX=r.data.shearX+l*n;break;case 1:case 2:r.shearX+=(r.data.shearX+l-r.shearX)*n;break;case 3:r.shearX+=l*n}}},$t=class extends Re{constructor(e,t,i){super(e,t,ce.shearY+"|"+i);this.boneIndex=0,this.boneIndex=i}apply(e,t,i,s,n,c,a){let r=e.bones[this.boneIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(c){case 0:r.shearY=r.data.shearY;return;case 1:r.shearY+=(r.data.shearY-r.shearY)*n}return}let l=this.getCurveValue(i);switch(c){case 0:r.shearY=r.data.shearY+l*n;break;case 1:case 2:r.shearY+=(r.data.shearY+l-r.shearY)*n;break;case 3:r.shearY+=l*n}}},ei=class extends ke{constructor(e,t,i){super(e,t,[ce.rgb+"|"+i,ce.alpha+"|"+i]);this.slotIndex=0,this.slotIndex=i}getFrameEntries(){return 5}setFrame(e,t,i,s,n,c){e*=5,this.frames[e]=t,this.frames[e+1]=i,this.frames[e+2]=s,this.frames[e+3]=n,this.frames[e+4]=c}apply(e,t,i,s,n,c,a){let r=e.slots[this.slotIndex];if(!r.bone.active)return;let o=this.frames,l=r.color;if(i<o[0]){let b=r.data.color;switch(c){case 0:l.setFromColor(b);return;case 1:l.add((b.r-l.r)*n,(b.g-l.g)*n,(b.b-l.b)*n,(b.a-l.a)*n)}return}let h=0,f=0,d=0,u=0,m=me.search(o,i,5),x=this.curves[m/5];switch(x){case 0:let b=o[m];h=o[m+1],f=o[m+2],d=o[m+3],u=o[m+4];let v=(i-b)/(o[m+5]-b);h+=(o[m+5+1]-h)*v,f+=(o[m+5+2]-f)*v,d+=(o[m+5+3]-d)*v,u+=(o[m+5+4]-u)*v;break;case 1:h=o[m+1],f=o[m+2],d=o[m+3],u=o[m+4];break;default:h=this.getBezierValue(i,m,1,x-2),f=this.getBezierValue(i,m,2,x+18-2),d=this.getBezierValue(i,m,3,x+18*2-2),u=this.getBezierValue(i,m,4,x+18*3-2)}n==1?l.set(h,f,d,u):(c==0&&l.setFromColor(r.data.color),l.add((h-l.r)*n,(f-l.g)*n,(d-l.b)*n,(u-l.a)*n))}},ti=class extends ke{constructor(e,t,i){super(e,t,[ce.rgb+"|"+i]);this.slotIndex=0,this.slotIndex=i}getFrameEntries(){return 4}setFrame(e,t,i,s,n){e<<=2,this.frames[e]=t,this.frames[e+1]=i,this.frames[e+2]=s,this.frames[e+3]=n}apply(e,t,i,s,n,c,a){let r=e.slots[this.slotIndex];if(!r.bone.active)return;let o=this.frames,l=r.color;if(i<o[0]){let x=r.data.color;switch(c){case 0:l.r=x.r,l.g=x.g,l.b=x.b;return;case 1:l.r+=(x.r-l.r)*n,l.g+=(x.g-l.g)*n,l.b+=(x.b-l.b)*n}return}let h=0,f=0,d=0,u=me.search(o,i,4),m=this.curves[u>>2];switch(m){case 0:let x=o[u];h=o[u+1],f=o[u+2],d=o[u+3];let b=(i-x)/(o[u+4]-x);h+=(o[u+4+1]-h)*b,f+=(o[u+4+2]-f)*b,d+=(o[u+4+3]-d)*b;break;case 1:h=o[u+1],f=o[u+2],d=o[u+3];break;default:h=this.getBezierValue(i,u,1,m-2),f=this.getBezierValue(i,u,2,m+18-2),d=this.getBezierValue(i,u,3,m+18*2-2)}if(n==1)l.r=h,l.g=f,l.b=d;else{if(c==0){let x=r.data.color;l.r=x.r,l.g=x.g,l.b=x.b}l.r+=(h-l.r)*n,l.g+=(f-l.g)*n,l.b+=(d-l.b)*n}}},ii=class extends Re{constructor(e,t,i){super(e,t,ce.alpha+"|"+i);this.slotIndex=0,this.slotIndex=i}apply(e,t,i,s,n,c,a){let r=e.slots[this.slotIndex];if(!r.bone.active)return;let o=r.color;if(i<this.frames[0]){let h=r.data.color;switch(c){case 0:o.a=h.a;return;case 1:o.a+=(h.a-o.a)*n}return}let l=this.getCurveValue(i);n==1?o.a=l:(c==0&&(o.a=r.data.color.a),o.a+=(l-o.a)*n)}},si=class extends ke{constructor(e,t,i){super(e,t,[ce.rgb+"|"+i,ce.alpha+"|"+i,ce.rgb2+"|"+i]);this.slotIndex=0,this.slotIndex=i}getFrameEntries(){return 8}setFrame(e,t,i,s,n,c,a,r,o){e<<=3,this.frames[e]=t,this.frames[e+1]=i,this.frames[e+2]=s,this.frames[e+3]=n,this.frames[e+4]=c,this.frames[e+5]=a,this.frames[e+6]=r,this.frames[e+7]=o}apply(e,t,i,s,n,c,a){let r=e.slots[this.slotIndex];if(!r.bone.active)return;let o=this.frames,l=r.color,h=r.darkColor;if(i<o[0]){let p=r.data.color,y=r.data.darkColor;switch(c){case 0:l.setFromColor(p),h.r=y.r,h.g=y.g,h.b=y.b;return;case 1:l.add((p.r-l.r)*n,(p.g-l.g)*n,(p.b-l.b)*n,(p.a-l.a)*n),h.r+=(y.r-h.r)*n,h.g+=(y.g-h.g)*n,h.b+=(y.b-h.b)*n}return}let f=0,d=0,u=0,m=0,x=0,b=0,v=0,g=me.search(o,i,8),w=this.curves[g>>3];switch(w){case 0:let p=o[g];f=o[g+1],d=o[g+2],u=o[g+3],m=o[g+4],x=o[g+5],b=o[g+6],v=o[g+7];let y=(i-p)/(o[g+8]-p);f+=(o[g+8+1]-f)*y,d+=(o[g+8+2]-d)*y,u+=(o[g+8+3]-u)*y,m+=(o[g+8+4]-m)*y,x+=(o[g+8+5]-x)*y,b+=(o[g+8+6]-b)*y,v+=(o[g+8+7]-v)*y;break;case 1:f=o[g+1],d=o[g+2],u=o[g+3],m=o[g+4],x=o[g+5],b=o[g+6],v=o[g+7];break;default:f=this.getBezierValue(i,g,1,w-2),d=this.getBezierValue(i,g,2,w+18-2),u=this.getBezierValue(i,g,3,w+18*2-2),m=this.getBezierValue(i,g,4,w+18*3-2),x=this.getBezierValue(i,g,5,w+18*4-2),b=this.getBezierValue(i,g,6,w+18*5-2),v=this.getBezierValue(i,g,7,w+18*6-2)}if(n==1)l.set(f,d,u,m),h.r=x,h.g=b,h.b=v;else{if(c==0){l.setFromColor(r.data.color);let p=r.data.darkColor;h.r=p.r,h.g=p.g,h.b=p.b}l.add((f-l.r)*n,(d-l.g)*n,(u-l.b)*n,(m-l.a)*n),h.r+=(x-h.r)*n,h.g+=(b-h.g)*n,h.b+=(v-h.b)*n}}},ri=class extends ke{constructor(e,t,i){super(e,t,[ce.rgb+"|"+i,ce.rgb2+"|"+i]);this.slotIndex=0,this.slotIndex=i}getFrameEntries(){return 7}setFrame(e,t,i,s,n,c,a,r){e*=7,this.frames[e]=t,this.frames[e+1]=i,this.frames[e+2]=s,this.frames[e+3]=n,this.frames[e+4]=c,this.frames[e+5]=a,this.frames[e+6]=r}apply(e,t,i,s,n,c,a){let r=e.slots[this.slotIndex];if(!r.bone.active)return;let o=this.frames,l=r.color,h=r.darkColor;if(i<o[0]){let p=r.data.color,y=r.data.darkColor;switch(c){case 0:l.r=p.r,l.g=p.g,l.b=p.b,h.r=y.r,h.g=y.g,h.b=y.b;return;case 1:l.r+=(p.r-l.r)*n,l.g+=(p.g-l.g)*n,l.b+=(p.b-l.b)*n,h.r+=(y.r-h.r)*n,h.g+=(y.g-h.g)*n,h.b+=(y.b-h.b)*n}return}let f=0,d=0,u=0,m=0,x=0,b=0,v=0,g=me.search(o,i,7),w=this.curves[g/7];switch(w){case 0:let p=o[g];f=o[g+1],d=o[g+2],u=o[g+3],x=o[g+4],b=o[g+5],v=o[g+6];let y=(i-p)/(o[g+7]-p);f+=(o[g+7+1]-f)*y,d+=(o[g+7+2]-d)*y,u+=(o[g+7+3]-u)*y,x+=(o[g+7+4]-x)*y,b+=(o[g+7+5]-b)*y,v+=(o[g+7+6]-v)*y;break;case 1:f=o[g+1],d=o[g+2],u=o[g+3],x=o[g+4],b=o[g+5],v=o[g+6];break;default:f=this.getBezierValue(i,g,1,w-2),d=this.getBezierValue(i,g,2,w+18-2),u=this.getBezierValue(i,g,3,w+18*2-2),x=this.getBezierValue(i,g,4,w+18*3-2),b=this.getBezierValue(i,g,5,w+18*4-2),v=this.getBezierValue(i,g,6,w+18*5-2)}if(n==1)l.r=f,l.g=d,l.b=u,h.r=x,h.g=b,h.b=v;else{if(c==0){let p=r.data.color,y=r.data.darkColor;l.r=p.r,l.g=p.g,l.b=p.b,h.r=y.r,h.g=y.g,h.b=y.b}l.r+=(f-l.r)*n,l.g+=(d-l.g)*n,l.b+=(u-l.b)*n,h.r+=(x-h.r)*n,h.g+=(b-h.g)*n,h.b+=(v-h.b)*n}}},Qe=class extends me{constructor(e,t){super(e,[ce.attachment+"|"+t]);this.slotIndex=0,this.slotIndex=t,this.attachmentNames=new Array(e)}getFrameCount(){return this.frames.length}setFrame(e,t,i){this.frames[e]=t,this.attachmentNames[e]=i}apply(e,t,i,s,n,c,a){let r=e.slots[this.slotIndex];if(!!r.bone.active){if(a==1){c==0&&this.setAttachment(e,r,r.data.attachmentName);return}if(i<this.frames[0]){(c==0||c==1)&&this.setAttachment(e,r,r.data.attachmentName);return}this.setAttachment(e,r,this.attachmentNames[me.search1(this.frames,i)])}}setAttachment(e,t,i){t.setAttachment(i?e.getAttachment(this.slotIndex,i):null)}},ni=class extends ke{constructor(e,t,i,s){super(e,t,[ce.deform+"|"+i+"|"+s.id]);this.slotIndex=0,this.slotIndex=i,this.attachment=s,this.vertices=new Array(e)}getFrameCount(){return this.frames.length}setFrame(e,t,i){this.frames[e]=t,this.vertices[e]=i}setBezier(e,t,i,s,n,c,a,r,o,l,h){let f=this.curves,d=this.getFrameCount()+e*18;i==0&&(f[t]=2+d);let u=(s-c*2+r)*.03,m=o*.03-a*.06,x=((c-r)*3-s+l)*.006,b=(a-o+.33333333)*.018,v=u*2+x,g=m*2+b,w=(c-s)*.3+u+x*.16666667,p=a*.3+m+b*.16666667,y=s+w,S=p;for(let A=d+18;d<A;d+=2)f[d]=y,f[d+1]=S,w+=v,p+=g,v+=x,g+=b,y+=w,S+=p}getCurvePercent(e,t){let i=this.curves,s=i[t];switch(s){case 0:let r=this.frames[t];return(e-r)/(this.frames[t+this.getFrameEntries()]-r);case 1:return 0}if(s-=2,i[s]>e){let r=this.frames[t];return i[s+1]*(e-r)/(i[s]-r)}let n=s+18;for(s+=2;s<n;s+=2)if(i[s]>=e){let r=i[s-2],o=i[s-1];return o+(e-r)/(i[s]-r)*(i[s+1]-o)}let c=i[n-2],a=i[n-1];return a+(1-a)*(e-c)/(this.frames[t+this.getFrameEntries()]-c)}apply(e,t,i,s,n,c,a){let r=e.slots[this.slotIndex];if(!r.bone.active)return;let o=r.getAttachment();if(!o||!(o instanceof Ye)||o.timelineAttachment!=this.attachment)return;let l=r.deform;l.length==0&&(c=0);let h=this.vertices,f=h[0].length,d=this.frames;if(i<d[0]){switch(c){case 0:l.length=0;return;case 1:if(n==1){l.length=0;return}l.length=f;let g=o;if(g.bones){n=1-n;for(var u=0;u<f;u++)l[u]*=n}else{let w=g.vertices;for(var u=0;u<f;u++)l[u]+=(w[u]-l[u])*n}}return}if(l.length=f,i>=d[d.length-1]){let g=h[d.length-1];if(n==1)if(c==3){let w=o;if(w.bones)for(let p=0;p<f;p++)l[p]+=g[p];else{let p=w.vertices;for(let y=0;y<f;y++)l[y]+=g[y]-p[y]}}else B.arrayCopy(g,0,l,0,f);else switch(c){case 0:{let p=o;if(p.bones)for(let y=0;y<f;y++)l[y]=g[y]*n;else{let y=p.vertices;for(let S=0;S<f;S++){let A=y[S];l[S]=A+(g[S]-A)*n}}break}case 1:case 2:for(let p=0;p<f;p++)l[p]+=(g[p]-l[p])*n;break;case 3:let w=o;if(w.bones)for(let p=0;p<f;p++)l[p]+=g[p]*n;else{let p=w.vertices;for(let y=0;y<f;y++)l[y]+=(g[y]-p[y])*n}}return}let m=me.search1(d,i),x=this.getCurvePercent(i,m),b=h[m],v=h[m+1];if(n==1)if(c==3){let g=o;if(g.bones)for(let w=0;w<f;w++){let p=b[w];l[w]+=p+(v[w]-p)*x}else{let w=g.vertices;for(let p=0;p<f;p++){let y=b[p];l[p]+=y+(v[p]-y)*x-w[p]}}}else for(let g=0;g<f;g++){let w=b[g];l[g]=w+(v[g]-w)*x}else switch(c){case 0:{let w=o;if(w.bones)for(let p=0;p<f;p++){let y=b[p];l[p]=(y+(v[p]-y)*x)*n}else{let p=w.vertices;for(let y=0;y<f;y++){let S=b[y],A=p[y];l[y]=A+(S+(v[y]-S)*x-A)*n}}break}case 1:case 2:for(let w=0;w<f;w++){let p=b[w];l[w]+=(p+(v[w]-p)*x-l[w])*n}break;case 3:let g=o;if(g.bones)for(let w=0;w<f;w++){let p=b[w];l[w]+=(p+(v[w]-p)*x)*n}else{let w=g.vertices;for(let p=0;p<f;p++){let y=b[p];l[p]+=(y+(v[p]-y)*x-w[p])*n}}}}},qi=class extends me{constructor(e){super(e,qi.propertyIds);this.events=new Array(e)}getFrameCount(){return this.frames.length}setFrame(e,t){this.frames[e]=t.time,this.events[e]=t}apply(e,t,i,s,n,c,a){if(!s)return;let r=this.frames,o=this.frames.length;if(t>i)this.apply(e,t,Number.MAX_VALUE,s,n,c,a),t=-1;else if(t>=r[o-1])return;if(i<r[0])return;let l=0;if(t<r[0])l=0;else{l=me.search1(r,t)+1;let h=r[l];for(;l>0&&r[l-1]==h;)l--}for(;l<o&&i>=r[l];l++)s.push(this.events[l])}},gt=qi;gt.propertyIds=[""+ce.event];var Gi=class extends me{constructor(e){super(e,Gi.propertyIds);this.drawOrders=new Array(e)}getFrameCount(){return this.frames.length}setFrame(e,t,i){this.frames[e]=t,this.drawOrders[e]=i}apply(e,t,i,s,n,c,a){if(a==1){c==0&&B.arrayCopy(e.slots,0,e.drawOrder,0,e.slots.length);return}if(i<this.frames[0]){(c==0||c==1)&&B.arrayCopy(e.slots,0,e.drawOrder,0,e.slots.length);return}let r=me.search1(this.frames,i),o=this.drawOrders[r];if(!o)B.arrayCopy(e.slots,0,e.drawOrder,0,e.slots.length);else{let l=e.drawOrder,h=e.slots;for(let f=0,d=o.length;f<d;f++)l[f]=h[o[f]]}}},$e=Gi;$e.propertyIds=[""+ce.drawOrder];var ai=class extends ke{constructor(e,t,i){super(e,t,[ce.ikConstraint+"|"+i]);this.ikConstraintIndex=0,this.ikConstraintIndex=i}getFrameEntries(){return 6}setFrame(e,t,i,s,n,c,a){e*=6,this.frames[e]=t,this.frames[e+1]=i,this.frames[e+2]=s,this.frames[e+3]=n,this.frames[e+4]=c?1:0,this.frames[e+5]=a?1:0}apply(e,t,i,s,n,c,a){let r=e.ikConstraints[this.ikConstraintIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(c){case 0:r.mix=r.data.mix,r.softness=r.data.softness,r.bendDirection=r.data.bendDirection,r.compress=r.data.compress,r.stretch=r.data.stretch;return;case 1:r.mix+=(r.data.mix-r.mix)*n,r.softness+=(r.data.softness-r.softness)*n,r.bendDirection=r.data.bendDirection,r.compress=r.data.compress,r.stretch=r.data.stretch}return}let l=0,h=0,f=me.search(o,i,6),d=this.curves[f/6];switch(d){case 0:let u=o[f];l=o[f+1],h=o[f+2];let m=(i-u)/(o[f+6]-u);l+=(o[f+6+1]-l)*m,h+=(o[f+6+2]-h)*m;break;case 1:l=o[f+1],h=o[f+2];break;default:l=this.getBezierValue(i,f,1,d-2),h=this.getBezierValue(i,f,2,d+18-2)}c==0?(r.mix=r.data.mix+(l-r.data.mix)*n,r.softness=r.data.softness+(h-r.data.softness)*n,a==1?(r.bendDirection=r.data.bendDirection,r.compress=r.data.compress,r.stretch=r.data.stretch):(r.bendDirection=o[f+3],r.compress=o[f+4]!=0,r.stretch=o[f+5]!=0)):(r.mix+=(l-r.mix)*n,r.softness+=(h-r.softness)*n,a==0&&(r.bendDirection=o[f+3],r.compress=o[f+4]!=0,r.stretch=o[f+5]!=0))}},li=class extends ke{constructor(e,t,i){super(e,t,[ce.transformConstraint+"|"+i]);this.transformConstraintIndex=0,this.transformConstraintIndex=i}getFrameEntries(){return 7}setFrame(e,t,i,s,n,c,a,r){let o=this.frames;e*=7,o[e]=t,o[e+1]=i,o[e+2]=s,o[e+3]=n,o[e+4]=c,o[e+5]=a,o[e+6]=r}apply(e,t,i,s,n,c,a){let r=e.transformConstraints[this.transformConstraintIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){let v=r.data;switch(c){case 0:r.mixRotate=v.mixRotate,r.mixX=v.mixX,r.mixY=v.mixY,r.mixScaleX=v.mixScaleX,r.mixScaleY=v.mixScaleY,r.mixShearY=v.mixShearY;return;case 1:r.mixRotate+=(v.mixRotate-r.mixRotate)*n,r.mixX+=(v.mixX-r.mixX)*n,r.mixY+=(v.mixY-r.mixY)*n,r.mixScaleX+=(v.mixScaleX-r.mixScaleX)*n,r.mixScaleY+=(v.mixScaleY-r.mixScaleY)*n,r.mixShearY+=(v.mixShearY-r.mixShearY)*n}return}let l,h,f,d,u,m,x=me.search(o,i,7),b=this.curves[x/7];switch(b){case 0:let v=o[x];l=o[x+1],h=o[x+2],f=o[x+3],d=o[x+4],u=o[x+5],m=o[x+6];let g=(i-v)/(o[x+7]-v);l+=(o[x+7+1]-l)*g,h+=(o[x+7+2]-h)*g,f+=(o[x+7+3]-f)*g,d+=(o[x+7+4]-d)*g,u+=(o[x+7+5]-u)*g,m+=(o[x+7+6]-m)*g;break;case 1:l=o[x+1],h=o[x+2],f=o[x+3],d=o[x+4],u=o[x+5],m=o[x+6];break;default:l=this.getBezierValue(i,x,1,b-2),h=this.getBezierValue(i,x,2,b+18-2),f=this.getBezierValue(i,x,3,b+18*2-2),d=this.getBezierValue(i,x,4,b+18*3-2),u=this.getBezierValue(i,x,5,b+18*4-2),m=this.getBezierValue(i,x,6,b+18*5-2)}if(c==0){let v=r.data;r.mixRotate=v.mixRotate+(l-v.mixRotate)*n,r.mixX=v.mixX+(h-v.mixX)*n,r.mixY=v.mixY+(f-v.mixY)*n,r.mixScaleX=v.mixScaleX+(d-v.mixScaleX)*n,r.mixScaleY=v.mixScaleY+(u-v.mixScaleY)*n,r.mixShearY=v.mixShearY+(m-v.mixShearY)*n}else r.mixRotate+=(l-r.mixRotate)*n,r.mixX+=(h-r.mixX)*n,r.mixY+=(f-r.mixY)*n,r.mixScaleX+=(d-r.mixScaleX)*n,r.mixScaleY+=(u-r.mixScaleY)*n,r.mixShearY+=(m-r.mixShearY)*n}},oi=class extends Re{constructor(e,t,i){super(e,t,ce.pathConstraintPosition+"|"+i);this.pathConstraintIndex=0,this.pathConstraintIndex=i}apply(e,t,i,s,n,c,a){let r=e.pathConstraints[this.pathConstraintIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(c){case 0:r.position=r.data.position;return;case 1:r.position+=(r.data.position-r.position)*n}return}let l=this.getCurveValue(i);c==0?r.position=r.data.position+(l-r.data.position)*n:r.position+=(l-r.position)*n}},hi=class extends Re{constructor(e,t,i){super(e,t,ce.pathConstraintSpacing+"|"+i);this.pathConstraintIndex=0,this.pathConstraintIndex=i}apply(e,t,i,s,n,c,a){let r=e.pathConstraints[this.pathConstraintIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(c){case 0:r.spacing=r.data.spacing;return;case 1:r.spacing+=(r.data.spacing-r.spacing)*n}return}let l=this.getCurveValue(i);c==0?r.spacing=r.data.spacing+(l-r.data.spacing)*n:r.spacing+=(l-r.spacing)*n}},ci=class extends ke{constructor(e,t,i){super(e,t,[ce.pathConstraintMix+"|"+i]);this.pathConstraintIndex=0,this.pathConstraintIndex=i}getFrameEntries(){return 4}setFrame(e,t,i,s,n){let c=this.frames;e<<=2,c[e]=t,c[e+1]=i,c[e+2]=s,c[e+3]=n}apply(e,t,i,s,n,c,a){let r=e.pathConstraints[this.pathConstraintIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(c){case 0:r.mixRotate=r.data.mixRotate,r.mixX=r.data.mixX,r.mixY=r.data.mixY;return;case 1:r.mixRotate+=(r.data.mixRotate-r.mixRotate)*n,r.mixX+=(r.data.mixX-r.mixX)*n,r.mixY+=(r.data.mixY-r.mixY)*n}return}let l,h,f,d=me.search(o,i,4),u=this.curves[d>>2];switch(u){case 0:let m=o[d];l=o[d+1],h=o[d+2],f=o[d+3];let x=(i-m)/(o[d+4]-m);l+=(o[d+4+1]-l)*x,h+=(o[d+4+2]-h)*x,f+=(o[d+4+3]-f)*x;break;case 1:l=o[d+1],h=o[d+2],f=o[d+3];break;default:l=this.getBezierValue(i,d,1,u-2),h=this.getBezierValue(i,d,2,u+18-2),f=this.getBezierValue(i,d,3,u+18*2-2)}if(c==0){let m=r.data;r.mixRotate=m.mixRotate+(l-m.mixRotate)*n,r.mixX=m.mixX+(h-m.mixX)*n,r.mixY=m.mixY+(f-m.mixY)*n}else r.mixRotate+=(l-r.mixRotate)*n,r.mixX+=(h-r.mixX)*n,r.mixY+=(f-r.mixY)*n}},qe=class extends me{constructor(e,t,i){super(e,[ce.sequence+"|"+t+"|"+i.sequence.id]);this.slotIndex=t,this.attachment=i}getFrameEntries(){return qe.ENTRIES}getSlotIndex(){return this.slotIndex}getAttachment(){return this.attachment}setFrame(e,t,i,s,n){let c=this.frames;e*=qe.ENTRIES,c[e]=t,c[e+qe.MODE]=i|s<<4,c[e+qe.DELAY]=n}apply(e,t,i,s,n,c,a){let r=e.slots[this.slotIndex];if(!r.bone.active)return;let o=r.attachment,l=this.attachment;if(o!=l&&(!(o instanceof Ye)||o.timelineAttachment!=l))return;let h=this.frames;if(i<h[0]){(c==0||c==1)&&(r.sequenceIndex=-1);return}let f=me.search(h,i,qe.ENTRIES),d=h[f],u=h[f+qe.MODE],m=h[f+qe.DELAY];if(!this.attachment.sequence)return;let x=u>>4,b=this.attachment.sequence.regions.length,v=_i[u&15];if(v!=Oe.hold)switch(x+=(i-d)/m+1e-5|0,v){case Oe.once:x=Math.min(b-1,x);break;case Oe.loop:x%=b;break;case Oe.pingpong:{let g=(b<<1)-2;x=g==0?0:x%g,x>=b&&(x=g-x);break}case Oe.onceReverse:x=Math.max(b-1-x,0);break;case Oe.loopReverse:x=b-1-x%b;break;case Oe.pingpongReverse:{let g=(b<<1)-2;x=g==0?0:(x+b-1)%g,x>=b&&(x=g-x)}}r.sequenceIndex=x}},rt=qe;rt.ENTRIES=3,rt.MODE=1,rt.DELAY=2;var St=class{constructor(e){this.tracks=new Array,this.timeScale=1,this.unkeyedState=0,this.events=new Array,this.listeners=new Array,this.queue=new Zi(this),this.propertyIDs=new Ut,this.animationsChanged=!1,this.trackEntryPool=new ut(()=>new ji),this.data=e}static emptyAnimation(){return St._emptyAnimation}update(e){e*=this.timeScale;let t=this.tracks;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(!n)continue;n.animationLast=n.nextAnimationLast,n.trackLast=n.nextTrackLast;let c=e*n.timeScale;if(n.delay>0){if(n.delay-=c,n.delay>0)continue;c=-n.delay,n.delay=0}let a=n.next;if(a){let r=n.trackLast-a.delay;if(r>=0){for(a.delay=0,a.trackTime+=n.timeScale==0?0:(r/n.timeScale+e)*a.timeScale,n.trackTime+=c,this.setCurrent(i,a,!0);a.mixingFrom;)a.mixTime+=e,a=a.mixingFrom;continue}}else if(n.trackLast>=n.trackEnd&&!n.mixingFrom){t[i]=null,this.queue.end(n),this.clearNext(n);continue}if(n.mixingFrom&&this.updateMixingFrom(n,e)){let r=n.mixingFrom;for(n.mixingFrom=null,r&&(r.mixingTo=null);r;)this.queue.end(r),r=r.mixingFrom}n.trackTime+=c}this.queue.drain()}updateMixingFrom(e,t){let i=e.mixingFrom;if(!i)return!0;let s=this.updateMixingFrom(i,t);return i.animationLast=i.nextAnimationLast,i.trackLast=i.nextTrackLast,e.mixTime>0&&e.mixTime>=e.mixDuration?((i.totalAlpha==0||e.mixDuration==0)&&(e.mixingFrom=i.mixingFrom,i.mixingFrom&&(i.mixingFrom.mixingTo=e),e.interruptAlpha=i.interruptAlpha,this.queue.end(i)),s):(i.trackTime+=t*i.timeScale,e.mixTime+=t,!1)}apply(e){if(!e)throw new Error("skeleton cannot be null.");this.animationsChanged&&this._animationsChanged();let t=this.events,i=this.tracks,s=!1;for(let f=0,d=i.length;f<d;f++){let u=i[f];if(!u||u.delay>0)continue;s=!0;let m=f==0?ue.first:u.mixBlend,x=u.alpha;u.mixingFrom?x*=this.applyMixingFrom(u,e,m):u.trackTime>=u.trackEnd&&!u.next&&(x=0);let b=u.animationLast,v=u.getAnimationTime(),g=v,w=t;u.reverse&&(g=u.animation.duration-g,w=null);let p=u.animation.timelines,y=p.length;if(f==0&&x==1||m==ue.add)for(let S=0;S<y;S++){B.webkit602BugfixHelper(x,m);var n=p[S];n instanceof Qe?this.applyAttachmentTimeline(n,e,g,m,!0):n.apply(e,b,g,w,x,m,Ne.mixIn)}else{let S=u.timelineMode,A=u.shortestRotation,I=!A&&u.timelinesRotation.length!=y<<1;I&&(u.timelinesRotation.length=y<<1);for(let Y=0;Y<y;Y++){let k=p[Y],X=S[Y]==Ct?m:ue.setup;!A&&k instanceof mt?this.applyRotateTimeline(k,e,g,x,X,u.timelinesRotation,Y<<1,I):k instanceof Qe?this.applyAttachmentTimeline(k,e,g,m,!0):(B.webkit602BugfixHelper(x,m),k.apply(e,b,g,w,x,X,Ne.mixIn))}}this.queueEvents(u,v),t.length=0,u.nextAnimationLast=v,u.nextTrackLast=u.trackTime}for(var c=this.unkeyedState+ui,a=e.slots,r=0,o=e.slots.length;r<o;r++){var l=a[r];if(l.attachmentState==c){var h=l.data.attachmentName;l.setAttachment(h?e.getAttachment(l.data.index,h):null)}}return this.unkeyedState+=2,this.queue.drain(),s}applyMixingFrom(e,t,i){let s=e.mixingFrom;s.mixingFrom&&this.applyMixingFrom(s,t,i);let n=0;e.mixDuration==0?(n=1,i==ue.first&&(i=ue.setup)):(n=e.mixTime/e.mixDuration,n>1&&(n=1),i!=ue.first&&(i=s.mixBlend));let c=n<s.attachmentThreshold,a=n<s.drawOrderThreshold,r=s.animation.timelines,o=r.length,l=s.alpha*e.interruptAlpha,h=l*(1-n),f=s.animationLast,d=s.getAnimationTime(),u=d,m=null;if(s.reverse?u=s.animation.duration-u:n<s.eventThreshold&&(m=this.events),i==ue.add)for(let x=0;x<o;x++)r[x].apply(t,f,u,m,h,i,Ne.mixOut);else{let x=s.timelineMode,b=s.timelineHoldMix,v=s.shortestRotation,g=!v&&s.timelinesRotation.length!=o<<1;g&&(s.timelinesRotation.length=o<<1),s.totalAlpha=0;for(let w=0;w<o;w++){let p=r[w],y=Ne.mixOut,S,A=0;switch(x[w]){case Ct:if(!a&&p instanceof $e)continue;S=i,A=h;break;case di:S=ue.setup,A=h;break;case fi:S=i,A=l;break;case Tt:S=ue.setup,A=l;break;default:S=ue.setup;let I=b[w];A=l*Math.max(0,1-I.mixTime/I.mixDuration);break}s.totalAlpha+=A,!v&&p instanceof mt?this.applyRotateTimeline(p,t,u,A,S,s.timelinesRotation,w<<1,g):p instanceof Qe?this.applyAttachmentTimeline(p,t,u,S,c):(B.webkit602BugfixHelper(A,i),a&&p instanceof $e&&S==ue.setup&&(y=Ne.mixIn),p.apply(t,f,u,m,A,S,y))}}return e.mixDuration>0&&this.queueEvents(s,d),this.events.length=0,s.nextAnimationLast=d,s.nextTrackLast=s.trackTime,n}applyAttachmentTimeline(e,t,i,s,n){var c=t.slots[e.slotIndex];!c.bone.active||(i<e.frames[0]?(s==ue.setup||s==ue.first)&&this.setAttachment(t,c,c.data.attachmentName,n):this.setAttachment(t,c,e.attachmentNames[me.search1(e.frames,i)],n),c.attachmentState<=this.unkeyedState&&(c.attachmentState=this.unkeyedState+ui))}setAttachment(e,t,i,s){t.setAttachment(i?e.getAttachment(t.data.index,i):null),s&&(t.attachmentState=this.unkeyedState+Ji)}applyRotateTimeline(e,t,i,s,n,c,a,r){if(r&&(c[a]=0),s==1){e.apply(t,0,i,null,1,n,Ne.mixIn);return}let o=t.bones[e.boneIndex];if(!o.active)return;let l=e.frames,h=0,f=0;if(i<l[0])switch(n){case ue.setup:o.rotation=o.data.rotation;default:return;case ue.first:h=o.rotation,f=o.data.rotation}else h=n==ue.setup?o.data.rotation:o.rotation,f=o.data.rotation+e.getCurveValue(i);let d=0,u=f-h;if(u-=(16384-(16384.499999999996-u/360|0))*360,u==0)d=c[a];else{let m=0,x=0;r?(m=0,x=u):(m=c[a],x=c[a+1]);let b=u>0,v=m>=0;R.signum(x)!=R.signum(u)&&Math.abs(x)<=90&&(Math.abs(m)>180&&(m+=360*R.signum(m)),v=b),d=u+m-m%360,v!=b&&(d+=360*R.signum(m)),c[a]=d}c[a+1]=u,o.rotation=h+d*s}queueEvents(e,t){let i=e.animationStart,s=e.animationEnd,n=s-i,c=e.trackLast%n,a=this.events,r=0,o=a.length;for(;r<o;r++){let h=a[r];if(h.time<c)break;h.time>s||this.queue.event(e,h)}let l=!1;for(e.loop?l=n==0||c>e.trackTime%n:l=t>=s&&e.animationLast<s,l&&this.queue.complete(e);r<o;r++){let h=a[r];h.time<i||this.queue.event(e,h)}}clearTracks(){let e=this.queue.drainDisabled;this.queue.drainDisabled=!0;for(let t=0,i=this.tracks.length;t<i;t++)this.clearTrack(t);this.tracks.length=0,this.queue.drainDisabled=e,this.queue.drain()}clearTrack(e){if(e>=this.tracks.length)return;let t=this.tracks[e];if(!t)return;this.queue.end(t),this.clearNext(t);let i=t;for(;;){let s=i.mixingFrom;if(!s)break;this.queue.end(s),i.mixingFrom=null,i.mixingTo=null,i=s}this.tracks[t.trackIndex]=null,this.queue.drain()}setCurrent(e,t,i){let s=this.expandToIndex(e);this.tracks[e]=t,t.previous=null,s&&(i&&this.queue.interrupt(s),t.mixingFrom=s,s.mixingTo=t,t.mixTime=0,s.mixingFrom&&s.mixDuration>0&&(t.interruptAlpha*=Math.min(1,s.mixTime/s.mixDuration)),s.timelinesRotation.length=0),this.queue.start(t)}setAnimation(e,t,i=!1){let s=this.data.skeletonData.findAnimation(t);if(!s)throw new Error("Animation not found: "+t);return this.setAnimationWith(e,s,i)}setAnimationWith(e,t,i=!1){if(!t)throw new Error("animation cannot be null.");let s=!0,n=this.expandToIndex(e);n&&(n.nextTrackLast==-1?(this.tracks[e]=n.mixingFrom,this.queue.interrupt(n),this.queue.end(n),this.clearNext(n),n=n.mixingFrom,s=!1):this.clearNext(n));let c=this.trackEntry(e,t,i,n);return this.setCurrent(e,c,s),this.queue.drain(),c}addAnimation(e,t,i=!1,s=0){let n=this.data.skeletonData.findAnimation(t);if(!n)throw new Error("Animation not found: "+t);return this.addAnimationWith(e,n,i,s)}addAnimationWith(e,t,i=!1,s=0){if(!t)throw new Error("animation cannot be null.");let n=this.expandToIndex(e);if(n)for(;n.next;)n=n.next;let c=this.trackEntry(e,t,i,n);return n?(n.next=c,c.previous=n,s<=0&&(s+=n.getTrackComplete()-c.mixDuration)):(this.setCurrent(e,c,!0),this.queue.drain()),c.delay=s,c}setEmptyAnimation(e,t=0){let i=this.setAnimationWith(e,St.emptyAnimation(),!1);return i.mixDuration=t,i.trackEnd=t,i}addEmptyAnimation(e,t=0,i=0){let s=this.addAnimationWith(e,St.emptyAnimation(),!1,i);return i<=0&&(s.delay+=s.mixDuration-t),s.mixDuration=t,s.trackEnd=t,s}setEmptyAnimations(e=0){let t=this.queue.drainDisabled;this.queue.drainDisabled=!0;for(let i=0,s=this.tracks.length;i<s;i++){let n=this.tracks[i];n&&this.setEmptyAnimation(n.trackIndex,e)}this.queue.drainDisabled=t,this.queue.drain()}expandToIndex(e){return e<this.tracks.length?this.tracks[e]:(B.ensureArrayCapacity(this.tracks,e+1,null),this.tracks.length=e+1,null)}trackEntry(e,t,i,s){let n=this.trackEntryPool.obtain();return n.reset(),n.trackIndex=e,n.animation=t,n.loop=i,n.holdPrevious=!1,n.reverse=!1,n.shortestRotation=!1,n.eventThreshold=0,n.attachmentThreshold=0,n.drawOrderThreshold=0,n.animationStart=0,n.animationEnd=t.duration,n.animationLast=-1,n.nextAnimationLast=-1,n.delay=0,n.trackTime=0,n.trackLast=-1,n.nextTrackLast=-1,n.trackEnd=Number.MAX_VALUE,n.timeScale=1,n.alpha=1,n.mixTime=0,n.mixDuration=s?this.data.getMix(s.animation,t):0,n.interruptAlpha=1,n.totalAlpha=0,n.mixBlend=ue.replace,n}clearNext(e){let t=e.next;for(;t;)this.queue.dispose(t),t=t.next;e.next=null}_animationsChanged(){this.animationsChanged=!1,this.propertyIDs.clear();let e=this.tracks;for(let t=0,i=e.length;t<i;t++){let s=e[t];if(!!s){for(;s.mixingFrom;)s=s.mixingFrom;do(!s.mixingTo||s.mixBlend!=ue.add)&&this.computeHold(s),s=s.mixingTo;while(s)}}}computeHold(e){let t=e.mixingTo,i=e.animation.timelines,s=e.animation.timelines.length,n=e.timelineMode;n.length=s;let c=e.timelineHoldMix;c.length=0;let a=this.propertyIDs;if(t&&t.holdPrevious){for(let r=0;r<s;r++)n[r]=a.addAll(i[r].getPropertyIds())?Tt:fi;return}e:for(let r=0;r<s;r++){let o=i[r],l=o.getPropertyIds();if(!a.addAll(l))n[r]=Ct;else if(!t||o instanceof Qe||o instanceof $e||o instanceof gt||!t.animation.hasTimeline(l))n[r]=di;else{for(let h=t.mixingTo;h;h=h.mixingTo)if(!h.animation.hasTimeline(l)){if(e.mixDuration>0){n[r]=Ki,c[r]=h;continue e}break}n[r]=Tt}}}getCurrent(e){return e>=this.tracks.length?null:this.tracks[e]}addListener(e){if(!e)throw new Error("listener cannot be null.");this.listeners.push(e)}removeListener(e){let t=this.listeners.indexOf(e);t>=0&&this.listeners.splice(t,1)}clearListeners(){this.listeners.length=0}clearListenerNotifications(){this.queue.clear()}},Hi=St;Hi._emptyAnimation=new yt("<empty>",[],0);var ji=class{constructor(){this.animation=null,this.previous=null,this.next=null,this.mixingFrom=null,this.mixingTo=null,this.listener=null,this.trackIndex=0,this.loop=!1,this.holdPrevious=!1,this.reverse=!1,this.shortestRotation=!1,this.eventThreshold=0,this.attachmentThreshold=0,this.drawOrderThreshold=0,this.animationStart=0,this.animationEnd=0,this.animationLast=0,this.nextAnimationLast=0,this.delay=0,this.trackTime=0,this.trackLast=0,this.nextTrackLast=0,this.trackEnd=0,this.timeScale=0,this.alpha=0,this.mixTime=0,this.mixDuration=0,this.interruptAlpha=0,this.totalAlpha=0,this.mixBlend=ue.replace,this.timelineMode=new Array,this.timelineHoldMix=new Array,this.timelinesRotation=new Array}reset(){this.next=null,this.previous=null,this.mixingFrom=null,this.mixingTo=null,this.animation=null,this.listener=null,this.timelineMode.length=0,this.timelineHoldMix.length=0,this.timelinesRotation.length=0}getAnimationTime(){if(this.loop){let e=this.animationEnd-this.animationStart;return e==0?this.animationStart:this.trackTime%e+this.animationStart}return Math.min(this.trackTime+this.animationStart,this.animationEnd)}setAnimationLast(e){this.animationLast=e,this.nextAnimationLast=e}isComplete(){return this.trackTime>=this.animationEnd-this.animationStart}resetRotationDirections(){this.timelinesRotation.length=0}getTrackComplete(){let e=this.animationEnd-this.animationStart;if(e!=0){if(this.loop)return e*(1+(this.trackTime/e|0));if(this.trackTime<e)return e}return this.trackTime}},Zi=class{constructor(e){this.objects=[],this.drainDisabled=!1,this.animState=e}start(e){this.objects.push(Ce.start),this.objects.push(e),this.animState.animationsChanged=!0}interrupt(e){this.objects.push(Ce.interrupt),this.objects.push(e)}end(e){this.objects.push(Ce.end),this.objects.push(e),this.animState.animationsChanged=!0}dispose(e){this.objects.push(Ce.dispose),this.objects.push(e)}complete(e){this.objects.push(Ce.complete),this.objects.push(e)}event(e,t){this.objects.push(Ce.event),this.objects.push(e),this.objects.push(t)}drain(){if(this.drainDisabled)return;this.drainDisabled=!0;let e=this.objects,t=this.animState.listeners;for(let i=0;i<e.length;i+=2){let s=e[i],n=e[i+1];switch(s){case Ce.start:n.listener&&n.listener.start&&n.listener.start(n);for(let a=0;a<t.length;a++){let r=t[a];r.start&&r.start(n)}break;case Ce.interrupt:n.listener&&n.listener.interrupt&&n.listener.interrupt(n);for(let a=0;a<t.length;a++){let r=t[a];r.interrupt&&r.interrupt(n)}break;case Ce.end:n.listener&&n.listener.end&&n.listener.end(n);for(let a=0;a<t.length;a++){let r=t[a];r.end&&r.end(n)}case Ce.dispose:n.listener&&n.listener.dispose&&n.listener.dispose(n);for(let a=0;a<t.length;a++){let r=t[a];r.dispose&&r.dispose(n)}this.animState.trackEntryPool.free(n);break;case Ce.complete:n.listener&&n.listener.complete&&n.listener.complete(n);for(let a=0;a<t.length;a++){let r=t[a];r.complete&&r.complete(n)}break;case Ce.event:let c=e[i+++2];n.listener&&n.listener.event&&n.listener.event(n,c);for(let a=0;a<t.length;a++){let r=t[a];r.event&&r.event(n,c)}break}}this.clear(),this.drainDisabled=!1}clear(){this.objects.length=0}},Ce;(function(e){e[e.start=0]="start",e[e.interrupt=1]="interrupt",e[e.end=2]="end",e[e.dispose=3]="dispose",e[e.complete=4]="complete",e[e.event=5]="event"})(Ce||(Ce={}));var Ys=class{start(e){}interrupt(e){}end(e){}dispose(e){}complete(e){}event(e,t){}},Ct=0,di=1,fi=2,Tt=3,Ki=4,ui=1,Ji=2,ks=class{constructor(e){if(this.animationToMixTime={},this.defaultMix=0,!e)throw new Error("skeletonData cannot be null.");this.skeletonData=e}setMix(e,t,i){let s=this.skeletonData.findAnimation(e);if(!s)throw new Error("Animation not found: "+e);let n=this.skeletonData.findAnimation(t);if(!n)throw new Error("Animation not found: "+t);this.setMixWith(s,n,i)}setMixWith(e,t,i){if(!e)throw new Error("from cannot be null.");if(!t)throw new Error("to cannot be null.");let s=e.name+"."+t.name;this.animationToMixTime[s]=i}getMix(e,t){let i=e.name+"."+t.name,s=this.animationToMixTime[i];return s===void 0?this.defaultMix:s}},It=class extends Ye{constructor(e){super(e);this.color=new O(1,1,1,1)}copy(){let e=new It(this.name);return this.copyTo(e),e.color.setFromColor(this.color),e}},xt=class extends Ye{constructor(e){super(e);this.endSlot=null,this.color=new O(.2275,.2275,.8078,1)}copy(){let e=new xt(this.name);return this.copyTo(e),e.endSlot=this.endSlot,e.color.setFromColor(this.color),e}},mi=class{constructor(e){this._image=e}getImage(){return this._image}},we;(function(e){e[e.Nearest=9728]="Nearest",e[e.Linear=9729]="Linear",e[e.MipMap=9987]="MipMap",e[e.MipMapNearestNearest=9984]="MipMapNearestNearest",e[e.MipMapLinearNearest=9985]="MipMapLinearNearest",e[e.MipMapNearestLinear=9986]="MipMapNearestLinear",e[e.MipMapLinearLinear=9987]="MipMapLinearLinear"})(we||(we={}));var et;(function(e){e[e.MirroredRepeat=33648]="MirroredRepeat",e[e.ClampToEdge=33071]="ClampToEdge",e[e.Repeat=10497]="Repeat"})(et||(et={}));var Qi=class{constructor(){this.u=0,this.v=0,this.u2=0,this.v2=0,this.width=0,this.height=0,this.degrees=0,this.offsetX=0,this.offsetY=0,this.originalWidth=0,this.originalHeight=0}},Rs=class extends mi{setFilters(e,t){}setWraps(e,t){}dispose(){}},$i=class{constructor(e){this.pages=new Array,this.regions=new Array;let t=new Fs(e),i=new Array(4),s={};s.size=l=>{l.width=parseInt(i[1]),l.height=parseInt(i[2])},s.format=()=>{},s.filter=l=>{l.minFilter=B.enumValue(we,i[1]),l.magFilter=B.enumValue(we,i[2])},s.repeat=l=>{i[1].indexOf("x")!=-1&&(l.uWrap=et.Repeat),i[1].indexOf("y")!=-1&&(l.vWrap=et.Repeat)},s.pma=l=>{l.pma=i[1]=="true"};var n={};n.xy=l=>{l.x=parseInt(i[1]),l.y=parseInt(i[2])},n.size=l=>{l.width=parseInt(i[1]),l.height=parseInt(i[2])},n.bounds=l=>{l.x=parseInt(i[1]),l.y=parseInt(i[2]),l.width=parseInt(i[3]),l.height=parseInt(i[4])},n.offset=l=>{l.offsetX=parseInt(i[1]),l.offsetY=parseInt(i[2])},n.orig=l=>{l.originalWidth=parseInt(i[1]),l.originalHeight=parseInt(i[2])},n.offsets=l=>{l.offsetX=parseInt(i[1]),l.offsetY=parseInt(i[2]),l.originalWidth=parseInt(i[3]),l.originalHeight=parseInt(i[4])},n.rotate=l=>{let h=i[1];h=="true"?l.degrees=90:h!="false"&&(l.degrees=parseInt(h))},n.index=l=>{l.index=parseInt(i[1])};let c=t.readLine();for(;c&&c.trim().length==0;)c=t.readLine();for(;!(!c||c.trim().length==0||t.readEntry(i,c)==0);)c=t.readLine();let a=null,r=null,o=null;for(;c!==null;)if(c.trim().length==0)a=null,c=t.readLine();else if(a){let l=new gi(a,c);for(;;){let h=t.readEntry(i,c=t.readLine());if(h==0)break;let f=n[i[0]];if(f)f(l);else{r||(r=[]),o||(o=[]),r.push(i[0]);let d=[];for(let u=0;u<h;u++)d.push(parseInt(i[u+1]));o.push(d)}}l.originalWidth==0&&l.originalHeight==0&&(l.originalWidth=l.width,l.originalHeight=l.height),r&&r.length>0&&o&&o.length>0&&(l.names=r,l.values=o,r=null,o=null),l.u=l.x/a.width,l.v=l.y/a.height,l.degrees==90?(l.u2=(l.x+l.height)/a.width,l.v2=(l.y+l.width)/a.height):(l.u2=(l.x+l.width)/a.width,l.v2=(l.y+l.height)/a.height),this.regions.push(l)}else{for(a=new es(c.trim());t.readEntry(i,c=t.readLine())!=0;){let l=s[i[0]];l&&l(a)}this.pages.push(a)}}findRegion(e){for(let t=0;t<this.regions.length;t++)if(this.regions[t].name==e)return this.regions[t];return null}setTextures(e,t=""){for(let i of this.pages)i.setTexture(e.get(t+i.name))}dispose(){var e;for(let t=0;t<this.pages.length;t++)(e=this.pages[t].texture)==null||e.dispose()}},Fs=class{constructor(e){this.index=0,this.lines=e.split(/\r\n|\r|\n/)}readLine(){return this.index>=this.lines.length?null:this.lines[this.index++]}readEntry(e,t){if(!t||(t=t.trim(),t.length==0))return 0;let i=t.indexOf(":");if(i==-1)return 0;e[0]=t.substr(0,i).trim();for(let s=1,n=i+1;;s++){let c=t.indexOf(",",n);if(c==-1)return e[s]=t.substr(n).trim(),s;if(e[s]=t.substr(n,c-n).trim(),n=c+1,s==4)return 4}}},es=class{constructor(e){this.minFilter=we.Nearest,this.magFilter=we.Nearest,this.uWrap=et.ClampToEdge,this.vWrap=et.ClampToEdge,this.texture=null,this.width=0,this.height=0,this.pma=!1,this.name=e}setTexture(e){this.texture=e,e.setFilters(this.minFilter,this.magFilter),e.setWraps(this.uWrap,this.vWrap)}},gi=class extends Qi{constructor(e,t){super();this.x=0,this.y=0,this.offsetX=0,this.offsetY=0,this.originalWidth=0,this.originalHeight=0,this.index=0,this.degrees=0,this.names=null,this.values=null,this.page=e,this.name=t}},Ge=class extends Ye{constructor(e,t){super(e);this.region=null,this.regionUVs=[],this.uvs=[],this.triangles=[],this.color=new O(1,1,1,1),this.width=0,this.height=0,this.hullLength=0,this.edges=[],this.parentMesh=null,this.sequence=null,this.tempColor=new O(0,0,0,0),this.path=t}updateRegion(){if(!this.region)throw new Error("Region not set.");let e=this.regionUVs;(!this.uvs||this.uvs.length!=e.length)&&(this.uvs=B.newFloatArray(e.length));let t=this.uvs,i=this.uvs.length,s=this.region.u,n=this.region.v,c=0,a=0;if(this.region instanceof gi){let r=this.region,o=r.page.texture.getImage(),l=o.width,h=o.height;switch(r.degrees){case 90:s-=(r.originalHeight-r.offsetY-r.height)/l,n-=(r.originalWidth-r.offsetX-r.width)/h,c=r.originalHeight/l,a=r.originalWidth/h;for(let f=0;f<i;f+=2)t[f]=s+e[f+1]*c,t[f+1]=n+(1-e[f])*a;return;case 180:s-=(r.originalWidth-r.offsetX-r.width)/l,n-=r.offsetY/h,c=r.originalWidth/l,a=r.originalHeight/h;for(let f=0;f<i;f+=2)t[f]=s+(1-e[f])*c,t[f+1]=n+(1-e[f+1])*a;return;case 270:s-=r.offsetY/l,n-=r.offsetX/h,c=r.originalHeight/l,a=r.originalWidth/h;for(let f=0;f<i;f+=2)t[f]=s+(1-e[f+1])*c,t[f+1]=n+e[f]*a;return}s-=r.offsetX/l,n-=(r.originalHeight-r.offsetY-r.height)/h,c=r.originalWidth/l,a=r.originalHeight/h}else this.region?(c=this.region.u2-s,a=this.region.v2-n):(s=n=0,c=a=1);for(let r=0;r<i;r+=2)t[r]=s+e[r]*c,t[r+1]=n+e[r+1]*a}getParentMesh(){return this.parentMesh}setParentMesh(e){this.parentMesh=e,e&&(this.bones=e.bones,this.vertices=e.vertices,this.worldVerticesLength=e.worldVerticesLength,this.regionUVs=e.regionUVs,this.triangles=e.triangles,this.hullLength=e.hullLength,this.worldVerticesLength=e.worldVerticesLength)}copy(){if(this.parentMesh)return this.newLinkedMesh();let e=new Ge(this.name,this.path);return e.region=this.region,e.color.setFromColor(this.color),this.copyTo(e),e.regionUVs=new Array(this.regionUVs.length),B.arrayCopy(this.regionUVs,0,e.regionUVs,0,this.regionUVs.length),e.uvs=new Array(this.uvs.length),B.arrayCopy(this.uvs,0,e.uvs,0,this.uvs.length),e.triangles=new Array(this.triangles.length),B.arrayCopy(this.triangles,0,e.triangles,0,this.triangles.length),e.hullLength=this.hullLength,e.sequence=this.sequence!=null?this.sequence.copy():null,this.edges&&(e.edges=new Array(this.edges.length),B.arrayCopy(this.edges,0,e.edges,0,this.edges.length)),e.width=this.width,e.height=this.height,e}computeWorldVertices(e,t,i,s,n,c){this.sequence!=null&&this.sequence.apply(e,this),super.computeWorldVertices(e,t,i,s,n,c)}newLinkedMesh(){let e=new Ge(this.name,this.path);return e.region=this.region,e.color.setFromColor(this.color),e.timelineAttachment=this.timelineAttachment,e.setParentMesh(this.parentMesh?this.parentMesh:this),e.region!=null&&e.updateRegion(),e}},tt=class extends Ye{constructor(e){super(e);this.lengths=[],this.closed=!1,this.constantSpeed=!1,this.color=new O(1,1,1,1)}copy(){let e=new tt(this.name);return this.copyTo(e),e.lengths=new Array(this.lengths.length),B.arrayCopy(this.lengths,0,e.lengths,0,this.lengths.length),e.closed=closed,e.constantSpeed=this.constantSpeed,e.color.setFromColor(this.color),e}},xi=class extends Ye{constructor(e){super(e);this.x=0,this.y=0,this.rotation=0,this.color=new O(.38,.94,0,1)}computeWorldPosition(e,t){return t.x=this.x*e.a+this.y*e.b+e.worldX,t.y=this.x*e.c+this.y*e.d+e.worldY,t}computeWorldRotation(e){let t=R.cosDeg(this.rotation),i=R.sinDeg(this.rotation),s=t*e.a+i*e.b,n=t*e.c+i*e.d;return Math.atan2(n,s)*R.radDeg}copy(){let e=new xi(this.name);return e.x=this.x,e.y=this.y,e.rotation=this.rotation,e.color.setFromColor(this.color),e}},ts=class extends Wt{constructor(e,t){super(e);this.x=0,this.y=0,this.scaleX=1,this.scaleY=1,this.rotation=0,this.width=0,this.height=0,this.color=new O(1,1,1,1),this.rendererObject=null,this.region=null,this.sequence=null,this.offset=B.newFloatArray(8),this.uvs=B.newFloatArray(8),this.tempColor=new O(1,1,1,1),this.path=t}updateRegion(){if(!this.region)throw new Error("Region not set.");let e=this.region,t=this.uvs;if(e==null){t[0]=0,t[1]=0,t[2]=0,t[3]=1,t[4]=1,t[5]=1,t[6]=1,t[7]=0;return}let i=this.width/this.region.originalWidth*this.scaleX,s=this.height/this.region.originalHeight*this.scaleY,n=-this.width/2*this.scaleX+this.region.offsetX*i,c=-this.height/2*this.scaleY+this.region.offsetY*s,a=n+this.region.width*i,r=c+this.region.height*s,o=this.rotation*Math.PI/180,l=Math.cos(o),h=Math.sin(o),f=this.x,d=this.y,u=n*l+f,m=n*h,x=c*l+d,b=c*h,v=a*l+f,g=a*h,w=r*l+d,p=r*h,y=this.offset;y[0]=u-b,y[1]=x+m,y[2]=u-p,y[3]=w+m,y[4]=v-p,y[5]=w+g,y[6]=v-b,y[7]=x+g,e.degrees==90?(t[0]=e.u2,t[1]=e.v2,t[2]=e.u,t[3]=e.v2,t[4]=e.u,t[5]=e.v,t[6]=e.u2,t[7]=e.v):(t[0]=e.u,t[1]=e.v2,t[2]=e.u,t[3]=e.v,t[4]=e.u2,t[5]=e.v,t[6]=e.u2,t[7]=e.v2)}computeWorldVertices(e,t,i,s){this.sequence!=null&&this.sequence.apply(e,this);let n=e.bone,c=this.offset,a=n.worldX,r=n.worldY,o=n.a,l=n.b,h=n.c,f=n.d,d=0,u=0;d=c[0],u=c[1],t[i]=d*o+u*l+a,t[i+1]=d*h+u*f+r,i+=s,d=c[2],u=c[3],t[i]=d*o+u*l+a,t[i+1]=d*h+u*f+r,i+=s,d=c[4],u=c[5],t[i]=d*o+u*l+a,t[i+1]=d*h+u*f+r,i+=s,d=c[6],u=c[7],t[i]=d*o+u*l+a,t[i+1]=d*h+u*f+r}copy(){let e=new ts(this.name,this.path);return e.region=this.region,e.rendererObject=this.rendererObject,e.x=this.x,e.y=this.y,e.scaleX=this.scaleX,e.scaleY=this.scaleY,e.rotation=this.rotation,e.width=this.width,e.height=this.height,B.arrayCopy(this.uvs,0,e.uvs,0,8),B.arrayCopy(this.offset,0,e.offset,0,8),e.color.setFromColor(this.color),e.sequence=this.sequence!=null?this.sequence.copy():null,e}},ne=ts;ne.X1=0,ne.Y1=1,ne.C1R=2,ne.C1G=3,ne.C1B=4,ne.C1A=5,ne.U1=6,ne.V1=7,ne.X2=8,ne.Y2=9,ne.C2R=10,ne.C2G=11,ne.C2B=12,ne.C2A=13,ne.U2=14,ne.V2=15,ne.X3=16,ne.Y3=17,ne.C3R=18,ne.C3G=19,ne.C3B=20,ne.C3A=21,ne.U3=22,ne.V3=23,ne.X4=24,ne.Y4=25,ne.C4R=26,ne.C4G=27,ne.C4B=28,ne.C4A=29,ne.U4=30,ne.V4=31;var Xs=class{constructor(e){this.atlas=e}loadSequence(e,t,i){let s=i.regions;for(let n=0,c=s.length;n<c;n++){let a=i.getPath(t,n),r=this.atlas.findRegion(a);if(r==null)throw new Error("Region not found in atlas: "+a+" (sequence: "+e+")");s[n]=r,s[n].renderObject=s[n]}}newRegionAttachment(e,t,i,s){let n=new ne(t,i);if(s!=null)this.loadSequence(t,i,s);else{let c=this.atlas.findRegion(i);if(!c)throw new Error("Region not found in atlas: "+i+" (region attachment: "+t+")");c.renderObject=c,n.region=c}return n}newMeshAttachment(e,t,i,s){let n=new Ge(t,i);if(s!=null)this.loadSequence(t,i,s);else{let c=this.atlas.findRegion(i);if(!c)throw new Error("Region not found in atlas: "+i+" (mesh attachment: "+t+")");c.renderObject=c,n.region=c}return n}newBoundingBoxAttachment(e,t){return new It(t)}newPathAttachment(e,t){return new tt(t)}newPointAttachment(e,t){return new xi(t)}newClippingAttachment(e,t){return new xt(t)}},wi=class{constructor(e,t,i){if(this.index=0,this.parent=null,this.length=0,this.x=0,this.y=0,this.rotation=0,this.scaleX=1,this.scaleY=1,this.shearX=0,this.shearY=0,this.transformMode=ge.Normal,this.skinRequired=!1,this.color=new O,e<0)throw new Error("index must be >= 0.");if(!t)throw new Error("name cannot be null.");this.index=e,this.name=t,this.parent=i}},ge;(function(e){e[e.Normal=0]="Normal",e[e.OnlyTranslation=1]="OnlyTranslation",e[e.NoRotationOrReflection=2]="NoRotationOrReflection",e[e.NoScale=3]="NoScale",e[e.NoScaleOrReflection=4]="NoScaleOrReflection"})(ge||(ge={}));var pi=class{constructor(e,t,i){if(this.parent=null,this.children=new Array,this.x=0,this.y=0,this.rotation=0,this.scaleX=0,this.scaleY=0,this.shearX=0,this.shearY=0,this.ax=0,this.ay=0,this.arotation=0,this.ascaleX=0,this.ascaleY=0,this.ashearX=0,this.ashearY=0,this.a=0,this.b=0,this.c=0,this.d=0,this.worldY=0,this.worldX=0,this.sorted=!1,this.active=!1,!e)throw new Error("data cannot be null.");if(!t)throw new Error("skeleton cannot be null.");this.data=e,this.skeleton=t,this.parent=i,this.setToSetupPose()}isActive(){return this.active}update(){this.updateWorldTransformWith(this.ax,this.ay,this.arotation,this.ascaleX,this.ascaleY,this.ashearX,this.ashearY)}updateWorldTransform(){this.updateWorldTransformWith(this.x,this.y,this.rotation,this.scaleX,this.scaleY,this.shearX,this.shearY)}updateWorldTransformWith(e,t,i,s,n,c,a){this.ax=e,this.ay=t,this.arotation=i,this.ascaleX=s,this.ascaleY=n,this.ashearX=c,this.ashearY=a;let r=this.parent;if(!r){let d=this.skeleton,u=i+90+a,m=d.scaleX,x=d.scaleY;this.a=R.cosDeg(i+c)*s*m,this.b=R.cosDeg(u)*n*m,this.c=R.sinDeg(i+c)*s*x,this.d=R.sinDeg(u)*n*x,this.worldX=e*m+d.x,this.worldY=t*x+d.y;return}let o=r.a,l=r.b,h=r.c,f=r.d;switch(this.worldX=o*e+l*t+r.worldX,this.worldY=h*e+f*t+r.worldY,this.data.transformMode){case ge.Normal:{let d=i+90+a,u=R.cosDeg(i+c)*s,m=R.cosDeg(d)*n,x=R.sinDeg(i+c)*s,b=R.sinDeg(d)*n;this.a=o*u+l*x,this.b=o*m+l*b,this.c=h*u+f*x,this.d=h*m+f*b;return}case ge.OnlyTranslation:{let d=i+90+a;this.a=R.cosDeg(i+c)*s,this.b=R.cosDeg(d)*n,this.c=R.sinDeg(i+c)*s,this.d=R.sinDeg(d)*n;break}case ge.NoRotationOrReflection:{let d=o*o+h*h,u=0;d>1e-4?(d=Math.abs(o*f-l*h)/d,o/=this.skeleton.scaleX,h/=this.skeleton.scaleY,l=h*d,f=o*d,u=Math.atan2(h,o)*R.radDeg):(o=0,h=0,u=90-Math.atan2(f,l)*R.radDeg);let m=i+c-u,x=i+a-u+90,b=R.cosDeg(m)*s,v=R.cosDeg(x)*n,g=R.sinDeg(m)*s,w=R.sinDeg(x)*n;this.a=o*b-l*g,this.b=o*v-l*w,this.c=h*b+f*g,this.d=h*v+f*w;break}case ge.NoScale:case ge.NoScaleOrReflection:{let d=R.cosDeg(i),u=R.sinDeg(i),m=(o*d+l*u)/this.skeleton.scaleX,x=(h*d+f*u)/this.skeleton.scaleY,b=Math.sqrt(m*m+x*x);b>1e-5&&(b=1/b),m*=b,x*=b,b=Math.sqrt(m*m+x*x),this.data.transformMode==ge.NoScale&&o*f-l*h<0!=(this.skeleton.scaleX<0!=this.skeleton.scaleY<0)&&(b=-b);let v=Math.PI/2+Math.atan2(x,m),g=Math.cos(v)*b,w=Math.sin(v)*b,p=R.cosDeg(c)*s,y=R.cosDeg(90+a)*n,S=R.sinDeg(c)*s,A=R.sinDeg(90+a)*n;this.a=m*p+g*S,this.b=m*y+g*A,this.c=x*p+w*S,this.d=x*y+w*A;break}}this.a*=this.skeleton.scaleX,this.b*=this.skeleton.scaleX,this.c*=this.skeleton.scaleY,this.d*=this.skeleton.scaleY}setToSetupPose(){let e=this.data;this.x=e.x,this.y=e.y,this.rotation=e.rotation,this.scaleX=e.scaleX,this.scaleY=e.scaleY,this.shearX=e.shearX,this.shearY=e.shearY}getWorldRotationX(){return Math.atan2(this.c,this.a)*R.radDeg}getWorldRotationY(){return Math.atan2(this.d,this.b)*R.radDeg}getWorldScaleX(){return Math.sqrt(this.a*this.a+this.c*this.c)}getWorldScaleY(){return Math.sqrt(this.b*this.b+this.d*this.d)}updateAppliedTransform(){let e=this.parent;if(!e){this.ax=this.worldX-this.skeleton.x,this.ay=this.worldY-this.skeleton.y,this.arotation=Math.atan2(this.c,this.a)*R.radDeg,this.ascaleX=Math.sqrt(this.a*this.a+this.c*this.c),this.ascaleY=Math.sqrt(this.b*this.b+this.d*this.d),this.ashearX=0,this.ashearY=Math.atan2(this.a*this.b+this.c*this.d,this.a*this.d-this.b*this.c)*R.radDeg;return}let t=e.a,i=e.b,s=e.c,n=e.d,c=1/(t*n-i*s),a=n*c,r=i*c,o=s*c,l=t*c,h=this.worldX-e.worldX,f=this.worldY-e.worldY;this.ax=h*a-f*r,this.ay=f*l-h*o;let d,u,m,x;if(this.data.transformMode==ge.OnlyTranslation)d=this.a,u=this.b,m=this.c,x=this.d;else{switch(this.data.transformMode){case ge.NoRotationOrReflection:{let p=Math.abs(t*n-i*s)/(t*t+s*s),y=t/this.skeleton.scaleX;i=-(s/this.skeleton.scaleY)*p*this.skeleton.scaleX,n=y*p*this.skeleton.scaleY,c=1/(t*n-i*s),a=n*c,r=i*c;break}case ge.NoScale:case ge.NoScaleOrReflection:let b=R.cosDeg(this.rotation),v=R.sinDeg(this.rotation);t=(t*b+i*v)/this.skeleton.scaleX,s=(s*b+n*v)/this.skeleton.scaleY;let g=Math.sqrt(t*t+s*s);g>1e-5&&(g=1/g),t*=g,s*=g,g=Math.sqrt(t*t+s*s),this.data.transformMode==ge.NoScale&&c<0!=(this.skeleton.scaleX<0!=this.skeleton.scaleY<0)&&(g=-g);let w=R.PI/2+Math.atan2(s,t);i=Math.cos(w)*g,n=Math.sin(w)*g,c=1/(t*n-i*s),a=n*c,r=i*c,o=s*c,l=t*c}d=a*this.a-r*this.c,u=a*this.b-r*this.d,m=l*this.c-o*this.a,x=l*this.d-o*this.b}if(this.ashearX=0,this.ascaleX=Math.sqrt(d*d+m*m),this.ascaleX>1e-4){let b=d*x-u*m;this.ascaleY=b/this.ascaleX,this.ashearY=-Math.atan2(d*u+m*x,b)*R.radDeg,this.arotation=Math.atan2(m,d)*R.radDeg}else this.ascaleX=0,this.ascaleY=Math.sqrt(u*u+x*x),this.ashearY=0,this.arotation=90-Math.atan2(x,u)*R.radDeg}worldToLocal(e){let t=1/(this.a*this.d-this.b*this.c),i=e.x-this.worldX,s=e.y-this.worldY;return e.x=i*this.d*t-s*this.b*t,e.y=s*this.a*t-i*this.c*t,e}localToWorld(e){let t=e.x,i=e.y;return e.x=t*this.a+i*this.b+this.worldX,e.y=t*this.c+i*this.d+this.worldY,e}worldToLocalRotation(e){let t=R.sinDeg(e),i=R.cosDeg(e);return Math.atan2(this.a*t-this.c*i,this.d*i-this.b*t)*R.radDeg+this.rotation-this.shearX}localToWorldRotation(e){e-=this.rotation-this.shearX;let t=R.sinDeg(e),i=R.cosDeg(e);return Math.atan2(i*this.c+t*this.d,i*this.a+t*this.b)*R.radDeg}rotateWorld(e){let t=this.a,i=this.b,s=this.c,n=this.d,c=R.cosDeg(e),a=R.sinDeg(e);this.a=c*t-a*s,this.b=c*i-a*n,this.c=a*t+c*s,this.d=a*i+c*n}},Mt=class{constructor(e,t,i){this.name=e,this.order=t,this.skinRequired=i}},is=class{constructor(e,t="",i=new bi){this.pathPrefix="",this.assets={},this.errors={},this.toLoad=0,this.loaded=0,this.textureLoader=e,this.pathPrefix=t,this.downloader=i}start(e){return this.toLoad++,this.pathPrefix+e}success(e,t,i){this.toLoad--,this.loaded++,this.assets[t]=i,e&&e(t,i)}error(e,t,i){this.toLoad--,this.loaded++,this.errors[t]=i,e&&e(t,i)}loadAll(){return new Promise((t,i)=>{let s=()=>{if(this.isLoadingComplete()){this.hasErrors()?i(this.errors):t(this);return}requestAnimationFrame(s)};requestAnimationFrame(s)})}setRawDataURI(e,t){this.downloader.rawDataUris[this.pathPrefix+e]=t}loadBinary(e,t=()=>{},i=()=>{}){e=this.start(e),this.downloader.downloadBinary(e,s=>{this.success(t,e,s)},(s,n)=>{this.error(i,e,`Couldn't load binary ${e}: status ${s}, ${n}`)})}loadText(e,t=()=>{},i=()=>{}){e=this.start(e),this.downloader.downloadText(e,s=>{this.success(t,e,s)},(s,n)=>{this.error(i,e,`Couldn't load text ${e}: status ${s}, ${n}`)})}loadJson(e,t=()=>{},i=()=>{}){e=this.start(e),this.downloader.downloadJson(e,s=>{this.success(t,e,s)},(s,n)=>{this.error(i,e,`Couldn't load JSON ${e}: status ${s}, ${n}`)})}loadTexture(e,t=()=>{},i=()=>{}){if(e=this.start(e),!!!(typeof window!="undefined"&&typeof navigator!="undefined"&&window.document))fetch(e,{mode:"cors"}).then(c=>c.ok?c.blob():(this.error(i,e,`Couldn't load image: ${e}`),null)).then(c=>c?createImageBitmap(c,{premultiplyAlpha:"none",colorSpaceConversion:"none"}):null).then(c=>{c&&this.success(t,e,this.textureLoader(c))});else{let c=new Image;c.crossOrigin="anonymous",c.onload=()=>{this.success(t,e,this.textureLoader(c))},c.onerror=()=>{this.error(i,e,`Couldn't load image: ${e}`)},this.downloader.rawDataUris[e]&&(e=this.downloader.rawDataUris[e]),c.src=e}}loadTextureAtlas(e,t=()=>{},i=()=>{},s){let n=e.lastIndexOf("/"),c=n>=0?e.substring(0,n+1):"";e=this.start(e),this.downloader.downloadText(e,a=>{try{let r=new $i(a),o=r.pages.length,l=!1;for(let h of r.pages)this.loadTexture(s?s[h.name]:c+h.name,(f,d)=>{l||(h.setTexture(d),--o==0&&this.success(t,e,r))},(f,d)=>{l||this.error(i,e,`Couldn't load texture atlas ${e} page image: ${f}`),l=!0})}catch(r){this.error(i,e,`Couldn't parse texture atlas ${e}: ${r.message}`)}},(a,r)=>{this.error(i,e,`Couldn't load texture atlas ${e}: status ${a}, ${r}`)})}get(e){return this.assets[this.pathPrefix+e]}require(e){e=this.pathPrefix+e;let t=this.assets[e];if(t)return t;let i=this.errors[e];throw Error("Asset not found: "+e+(i?`
|
|
2
|
-
`+i:""))}remove(e){e=this.pathPrefix+e;let t=this.assets[e];return t.dispose&&t.dispose(),delete this.assets[e],t}removeAll(){for(let e in this.assets){let t=this.assets[e];t.dispose&&t.dispose()}this.assets={}}isLoadingComplete(){return this.toLoad==0}getToLoad(){return this.toLoad}getLoaded(){return this.loaded}dispose(){this.removeAll()}hasErrors(){return Object.keys(this.errors).length>0}getErrors(){return this.errors}},bi=class{constructor(){this.callbacks={},this.rawDataUris={}}dataUriToString(e){if(!e.startsWith("data:"))throw new Error("Not a data URI.");let t=e.indexOf("base64,");return t!=-1?(t+="base64,".length,atob(e.substr(t))):e.substr(e.indexOf(",")+1)}base64ToUint8Array(e){for(var t=window.atob(e),i=t.length,s=new Uint8Array(i),n=0;n<i;n++)s[n]=t.charCodeAt(n);return s}dataUriToUint8Array(e){if(!e.startsWith("data:"))throw new Error("Not a data URI.");let t=e.indexOf("base64,");if(t==-1)throw new Error("Not a binary data URI.");return t+="base64,".length,this.base64ToUint8Array(e.substr(t))}downloadText(e,t,i){if(this.start(e,t,i))return;if(this.rawDataUris[e]){try{let c=this.rawDataUris[e];this.finish(e,200,this.dataUriToString(c))}catch(c){this.finish(e,400,JSON.stringify(c))}return}let s=new XMLHttpRequest;s.overrideMimeType("text/html"),s.open("GET",e,!0);let n=()=>{this.finish(e,s.status,s.responseText)};s.onload=n,s.onerror=n,s.send()}downloadJson(e,t,i){this.downloadText(e,s=>{t(JSON.parse(s))},i)}downloadBinary(e,t,i){if(this.start(e,t,i))return;if(this.rawDataUris[e]){try{let c=this.rawDataUris[e];this.finish(e,200,this.dataUriToUint8Array(c))}catch(c){this.finish(e,400,JSON.stringify(c))}return}let s=new XMLHttpRequest;s.open("GET",e,!0),s.responseType="arraybuffer";let n=()=>{this.finish(e,s.status,s.response)};s.onload=()=>{s.status==200||s.status==0?this.finish(e,200,new Uint8Array(s.response)):n()},s.onerror=n,s.send()}start(e,t,i){let s=this.callbacks[e];try{if(s)return!0;this.callbacks[e]=s=[]}finally{s.push(t,i)}}finish(e,t,i){let s=this.callbacks[e];delete this.callbacks[e];let n=t==200||t==0?[i]:[t,i];for(let c=n.length-1,a=s.length;c<a;c+=2)s[c].apply(null,n)}},vi=class{constructor(e,t){if(this.intValue=0,this.floatValue=0,this.stringValue=null,this.time=0,this.volume=0,this.balance=0,!t)throw new Error("data cannot be null.");this.time=e,this.data=t}},yi=class{constructor(e){this.intValue=0,this.floatValue=0,this.stringValue=null,this.audioPath=null,this.volume=0,this.balance=0,this.name=e}},ss=class{constructor(e,t){if(this.bendDirection=0,this.compress=!1,this.stretch=!1,this.mix=1,this.softness=0,this.active=!1,!e)throw new Error("data cannot be null.");if(!t)throw new Error("skeleton cannot be null.");this.data=e,this.mix=e.mix,this.softness=e.softness,this.bendDirection=e.bendDirection,this.compress=e.compress,this.stretch=e.stretch,this.bones=new Array;for(let s=0;s<e.bones.length;s++){let n=t.findBone(e.bones[s].name);if(!n)throw new Error(`Couldn't find bone ${e.bones[s].name}`);this.bones.push(n)}let i=t.findBone(e.target.name);if(!i)throw new Error(`Couldn't find bone ${e.target.name}`);this.target=i}isActive(){return this.active}update(){if(this.mix==0)return;let e=this.target,t=this.bones;switch(t.length){case 1:this.apply1(t[0],e.worldX,e.worldY,this.compress,this.stretch,this.data.uniform,this.mix);break;case 2:this.apply2(t[0],t[1],e.worldX,e.worldY,this.bendDirection,this.stretch,this.data.uniform,this.softness,this.mix);break}}apply1(e,t,i,s,n,c,a){let r=e.parent;if(!r)throw new Error("IK bone must have parent.");let o=r.a,l=r.b,h=r.c,f=r.d,d=-e.ashearX-e.arotation,u=0,m=0;switch(e.data.transformMode){case ge.OnlyTranslation:u=t-e.worldX,m=i-e.worldY;break;case ge.NoRotationOrReflection:let v=Math.abs(o*f-l*h)/(o*o+h*h),g=o/e.skeleton.scaleX,w=h/e.skeleton.scaleY;l=-w*v*e.skeleton.scaleX,f=g*v*e.skeleton.scaleY,d+=Math.atan2(w,g)*R.radDeg;default:let p=t-r.worldX,y=i-r.worldY,S=o*f-l*h;u=(p*f-y*l)/S-e.ax,m=(y*o-p*h)/S-e.ay}d+=Math.atan2(m,u)*R.radDeg,e.ascaleX<0&&(d+=180),d>180?d-=360:d<-180&&(d+=360);let x=e.ascaleX,b=e.ascaleY;if(s||n){switch(e.data.transformMode){case ge.NoScale:case ge.NoScaleOrReflection:u=t-e.worldX,m=i-e.worldY}let v=e.data.length*x,g=Math.sqrt(u*u+m*m);if(s&&g<v||n&&g>v&&v>1e-4){let w=(g/v-1)*a+1;x*=w,c&&(b*=w)}}e.updateWorldTransformWith(e.ax,e.ay,e.arotation+d*a,x,b,e.ashearX,e.ashearY)}apply2(e,t,i,s,n,c,a,r,o){let l=e.ax,h=e.ay,f=e.ascaleX,d=e.ascaleY,u=f,m=d,x=t.ascaleX,b=0,v=0,g=0;f<0?(f=-f,b=180,g=-1):(b=0,g=1),d<0&&(d=-d,g=-g),x<0?(x=-x,v=180):v=0;let w=t.ax,p=0,y=0,S=0,A=e.a,I=e.b,Y=e.c,k=e.d,X=Math.abs(f-d)<=1e-4;!X||c?(p=0,y=A*w+e.worldX,S=Y*w+e.worldY):(p=t.ay,y=A*w+I*p+e.worldX,S=Y*w+k*p+e.worldY);let F=e.parent;if(!F)throw new Error("IK parent must itself have a parent.");A=F.a,I=F.b,Y=F.c,k=F.d;let L=1/(A*k-I*Y),T=y-F.worldX,M=S-F.worldY,P=(T*k-M*I)*L-l,ee=(M*A-T*Y)*L-h,te=Math.sqrt(P*P+ee*ee),le=t.data.length*x,se,he;if(te<1e-4){this.apply1(e,i,s,!1,c,!1,o),t.updateWorldTransformWith(w,p,0,t.ascaleX,t.ascaleY,t.ashearX,t.ashearY);return}T=i-F.worldX,M=s-F.worldY;let re=(T*k-M*I)*L-l,ie=(M*A-T*Y)*L-h,de=re*re+ie*ie;if(r!=0){r*=f*(x+1)*.5;let ve=Math.sqrt(de),Me=ve-te-le*f+r;if(Me>0){let Ee=Math.min(1,Me/(r*2))-1;Ee=(Me-r*(1-Ee*Ee))/ve,re-=Ee*re,ie-=Ee*ie,de=re*re+ie*ie}}e:if(X){le*=f;let ve=(de-te*te-le*le)/(2*te*le);ve<-1?(ve=-1,he=Math.PI*n):ve>1?(ve=1,he=0,c&&(A=(Math.sqrt(de)/(te+le)-1)*o+1,u*=A,a&&(m*=A))):he=Math.acos(ve)*n,A=te+le*ve,I=le*Math.sin(he),se=Math.atan2(ie*A-re*I,re*A+ie*I)}else{A=f*le,I=d*le;let ve=A*A,Me=I*I,Ee=Math.atan2(ie,re);Y=Me*te*te+ve*de-ve*Me;let Ze=-2*Me*te,ct=Me-ve;if(k=Ze*Ze-4*ct*Y,k>=0){let dt=Math.sqrt(k);Ze<0&&(dt=-dt),dt=-(Ze+dt)*.5;let ys=dt/ct,As=Y/dt,ft=Math.abs(ys)<Math.abs(As)?ys:As;if(ft*ft<=de){M=Math.sqrt(de-ft*ft)*n,se=Ee-Math.atan2(M,ft),he=Math.atan2(M/d,(ft-te)/f);break e}}let bt=R.PI,Vt=te-A,Oi=Vt*Vt,ps=0,bs=0,Nt=te+A,Di=Nt*Nt,vs=0;Y=-A*te/(ve-Me),Y>=-1&&Y<=1&&(Y=Math.acos(Y),T=A*Math.cos(Y)+te,M=I*Math.sin(Y),k=T*T+M*M,k<Oi&&(bt=Y,Oi=k,Vt=T,ps=M),k>Di&&(bs=Y,Di=k,Nt=T,vs=M)),de<=(Oi+Di)*.5?(se=Ee-Math.atan2(ps*n,Vt),he=bt*n):(se=Ee-Math.atan2(vs*n,Nt),he=bs*n)}let Se=Math.atan2(p,w)*g,Be=e.arotation;se=(se-Se)*R.radDeg+b-Be,se>180?se-=360:se<-180&&(se+=360),e.updateWorldTransformWith(l,h,Be+se*o,u,m,0,0),Be=t.arotation,he=((he+Se)*R.radDeg-t.ashearX)*g+v-Be,he>180?he-=360:he<-180&&(he+=360),t.updateWorldTransformWith(w,p,Be+he*o,t.ascaleX,t.ascaleY,t.ashearX,t.ashearY)}},Ai=class extends Mt{constructor(e){super(e,0,!1);this.bones=new Array,this._target=null,this.bendDirection=1,this.compress=!1,this.stretch=!1,this.uniform=!1,this.mix=1,this.softness=0}set target(e){this._target=e}get target(){if(this._target)return this._target;throw new Error("BoneData not set.")}},Si=class extends Mt{constructor(e){super(e,0,!1);this.bones=new Array,this._target=null,this.positionMode=Fe.Fixed,this.spacingMode=xe.Fixed,this.rotateMode=He.Chain,this.offsetRotation=0,this.position=0,this.spacing=0,this.mixRotate=0,this.mixX=0,this.mixY=0}set target(e){this._target=e}get target(){if(this._target)return this._target;throw new Error("SlotData not set.")}},Fe;(function(e){e[e.Fixed=0]="Fixed",e[e.Percent=1]="Percent"})(Fe||(Fe={}));var xe;(function(e){e[e.Length=0]="Length",e[e.Fixed=1]="Fixed",e[e.Percent=2]="Percent",e[e.Proportional=3]="Proportional"})(xe||(xe={}));var He;(function(e){e[e.Tangent=0]="Tangent",e[e.Chain=1]="Chain",e[e.ChainScale=2]="ChainScale"})(He||(He={}));var Ue=class{constructor(e,t){if(this.position=0,this.spacing=0,this.mixRotate=0,this.mixX=0,this.mixY=0,this.spaces=new Array,this.positions=new Array,this.world=new Array,this.curves=new Array,this.lengths=new Array,this.segments=new Array,this.active=!1,!e)throw new Error("data cannot be null.");if(!t)throw new Error("skeleton cannot be null.");this.data=e,this.bones=new Array;for(let s=0,n=e.bones.length;s<n;s++){let c=t.findBone(e.bones[s].name);if(!c)throw new Error(`Couldn't find bone ${e.bones[s].name}.`);this.bones.push(c)}let i=t.findSlot(e.target.name);if(!i)throw new Error(`Couldn't find target bone ${e.target.name}`);this.target=i,this.position=e.position,this.spacing=e.spacing,this.mixRotate=e.mixRotate,this.mixX=e.mixX,this.mixY=e.mixY}isActive(){return this.active}update(){let e=this.target.getAttachment();if(!(e instanceof tt))return;let t=this.mixRotate,i=this.mixX,s=this.mixY;if(t==0&&i==0&&s==0)return;let n=this.data,c=n.rotateMode==He.Tangent,a=n.rotateMode==He.ChainScale,r=this.bones,o=r.length,l=c?o:o+1,h=B.setArraySize(this.spaces,l),f=a?this.lengths=B.setArraySize(this.lengths,o):[],d=this.spacing;switch(n.spacingMode){case xe.Percent:if(a)for(let p=0,y=l-1;p<y;p++){let S=r[p],A=S.data.length;if(A<Ue.epsilon)f[p]=0;else{let I=A*S.a,Y=A*S.c;f[p]=Math.sqrt(I*I+Y*Y)}}B.arrayFill(h,1,l,d);break;case xe.Proportional:let g=0;for(let p=0,y=l-1;p<y;){let S=r[p],A=S.data.length;if(A<Ue.epsilon)a&&(f[p]=0),h[++p]=d;else{let I=A*S.a,Y=A*S.c,k=Math.sqrt(I*I+Y*Y);a&&(f[p]=k),h[++p]=k,g+=k}}if(g>0){g=l/g*d;for(let p=1;p<l;p++)h[p]*=g}break;default:let w=n.spacingMode==xe.Length;for(let p=0,y=l-1;p<y;){let S=r[p],A=S.data.length;if(A<Ue.epsilon)a&&(f[p]=0),h[++p]=d;else{let I=A*S.a,Y=A*S.c,k=Math.sqrt(I*I+Y*Y);a&&(f[p]=k),h[++p]=(w?A+d:d)*k/A}}}let u=this.computeWorldPositions(e,l,c),m=u[0],x=u[1],b=n.offsetRotation,v=!1;if(b==0)v=n.rotateMode==He.Chain;else{v=!1;let g=this.target.bone;b*=g.a*g.d-g.b*g.c>0?R.degRad:-R.degRad}for(let g=0,w=3;g<o;g++,w+=3){let p=r[g];p.worldX+=(m-p.worldX)*i,p.worldY+=(x-p.worldY)*s;let y=u[w],S=u[w+1],A=y-m,I=S-x;if(a){let Y=f[g];if(Y!=0){let k=(Math.sqrt(A*A+I*I)/Y-1)*t+1;p.a*=k,p.c*=k}}if(m=y,x=S,t>0){let Y=p.a,k=p.b,X=p.c,F=p.d,L=0,T=0,M=0;if(c?L=u[w-1]:h[g+1]==0?L=u[w+2]:L=Math.atan2(I,A),L-=Math.atan2(X,Y),v){T=Math.cos(L),M=Math.sin(L);let P=p.data.length;m+=(P*(T*Y-M*X)-A)*t,x+=(P*(M*Y+T*X)-I)*t}else L+=b;L>R.PI?L-=R.PI2:L<-R.PI&&(L+=R.PI2),L*=t,T=Math.cos(L),M=Math.sin(L),p.a=T*Y-M*X,p.b=T*k-M*F,p.c=M*Y+T*X,p.d=M*k+T*F}p.updateAppliedTransform()}}computeWorldPositions(e,t,i){let s=this.target,n=this.position,c=this.spaces,a=B.setArraySize(this.positions,t*3+2),r=this.world,o=e.closed,l=e.worldVerticesLength,h=l/6,f=Ue.NONE;if(!e.constantSpeed){let ee=e.lengths;h-=o?1:2;let te=ee[h];this.data.positionMode==Fe.Percent&&(n*=te);let le;switch(this.data.spacingMode){case xe.Percent:le=te;break;case xe.Proportional:le=te/t;break;default:le=1}r=B.setArraySize(this.world,8);for(let se=0,he=0,re=0;se<t;se++,he+=3){let ie=c[se]*le;n+=ie;let de=n;if(o)de%=te,de<0&&(de+=te),re=0;else if(de<0){f!=Ue.BEFORE&&(f=Ue.BEFORE,e.computeWorldVertices(s,2,4,r,0,2)),this.addBeforePosition(de,r,0,a,he);continue}else if(de>te){f!=Ue.AFTER&&(f=Ue.AFTER,e.computeWorldVertices(s,l-6,4,r,0,2)),this.addAfterPosition(de-te,r,0,a,he);continue}for(;;re++){let Se=ee[re];if(!(de>Se)){if(re==0)de/=Se;else{let Be=ee[re-1];de=(de-Be)/(Se-Be)}break}}re!=f&&(f=re,o&&re==h?(e.computeWorldVertices(s,l-4,4,r,0,2),e.computeWorldVertices(s,0,4,r,4,2)):e.computeWorldVertices(s,re*6+2,8,r,0,2)),this.addCurvePosition(de,r[0],r[1],r[2],r[3],r[4],r[5],r[6],r[7],a,he,i||se>0&&ie==0)}return a}o?(l+=2,r=B.setArraySize(this.world,l),e.computeWorldVertices(s,2,l-4,r,0,2),e.computeWorldVertices(s,0,2,r,l-4,2),r[l-2]=r[0],r[l-1]=r[1]):(h--,l-=4,r=B.setArraySize(this.world,l),e.computeWorldVertices(s,2,l,r,0,2));let d=B.setArraySize(this.curves,h),u=0,m=r[0],x=r[1],b=0,v=0,g=0,w=0,p=0,y=0,S=0,A=0,I=0,Y=0,k=0,X=0,F=0,L=0;for(let ee=0,te=2;ee<h;ee++,te+=6)b=r[te],v=r[te+1],g=r[te+2],w=r[te+3],p=r[te+4],y=r[te+5],S=(m-b*2+g)*.1875,A=(x-v*2+w)*.1875,I=((b-g)*3-m+p)*.09375,Y=((v-w)*3-x+y)*.09375,k=S*2+I,X=A*2+Y,F=(b-m)*.75+S+I*.16666667,L=(v-x)*.75+A+Y*.16666667,u+=Math.sqrt(F*F+L*L),F+=k,L+=X,k+=I,X+=Y,u+=Math.sqrt(F*F+L*L),F+=k,L+=X,u+=Math.sqrt(F*F+L*L),F+=k+I,L+=X+Y,u+=Math.sqrt(F*F+L*L),d[ee]=u,m=p,x=y;this.data.positionMode==Fe.Percent&&(n*=u);let T;switch(this.data.spacingMode){case xe.Percent:T=u;break;case xe.Proportional:T=u/t;break;default:T=1}let M=this.segments,P=0;for(let ee=0,te=0,le=0,se=0;ee<t;ee++,te+=3){let he=c[ee]*T;n+=he;let re=n;if(o)re%=u,re<0&&(re+=u),le=0;else if(re<0){this.addBeforePosition(re,r,0,a,te);continue}else if(re>u){this.addAfterPosition(re-u,r,l-4,a,te);continue}for(;;le++){let ie=d[le];if(!(re>ie)){if(le==0)re/=ie;else{let de=d[le-1];re=(re-de)/(ie-de)}break}}if(le!=f){f=le;let ie=le*6;for(m=r[ie],x=r[ie+1],b=r[ie+2],v=r[ie+3],g=r[ie+4],w=r[ie+5],p=r[ie+6],y=r[ie+7],S=(m-b*2+g)*.03,A=(x-v*2+w)*.03,I=((b-g)*3-m+p)*.006,Y=((v-w)*3-x+y)*.006,k=S*2+I,X=A*2+Y,F=(b-m)*.3+S+I*.16666667,L=(v-x)*.3+A+Y*.16666667,P=Math.sqrt(F*F+L*L),M[0]=P,ie=1;ie<8;ie++)F+=k,L+=X,k+=I,X+=Y,P+=Math.sqrt(F*F+L*L),M[ie]=P;F+=k,L+=X,P+=Math.sqrt(F*F+L*L),M[8]=P,F+=k+I,L+=X+Y,P+=Math.sqrt(F*F+L*L),M[9]=P,se=0}for(re*=P;;se++){let ie=M[se];if(!(re>ie)){if(se==0)re/=ie;else{let de=M[se-1];re=se+(re-de)/(ie-de)}break}}this.addCurvePosition(re*.1,m,x,b,v,g,w,p,y,a,te,i||ee>0&&he==0)}return a}addBeforePosition(e,t,i,s,n){let c=t[i],a=t[i+1],r=t[i+2]-c,o=t[i+3]-a,l=Math.atan2(o,r);s[n]=c+e*Math.cos(l),s[n+1]=a+e*Math.sin(l),s[n+2]=l}addAfterPosition(e,t,i,s,n){let c=t[i+2],a=t[i+3],r=c-t[i],o=a-t[i+1],l=Math.atan2(o,r);s[n]=c+e*Math.cos(l),s[n+1]=a+e*Math.sin(l),s[n+2]=l}addCurvePosition(e,t,i,s,n,c,a,r,o,l,h,f){if(e==0||isNaN(e)){l[h]=t,l[h+1]=i,l[h+2]=Math.atan2(n-i,s-t);return}let d=e*e,u=d*e,m=1-e,x=m*m,b=x*m,v=m*e,g=v*3,w=m*g,p=g*e,y=t*b+s*w+c*p+r*u,S=i*b+n*w+a*p+o*u;l[h]=y,l[h+1]=S,f&&(e<.001?l[h+2]=Math.atan2(n-i,s-t):l[h+2]=Math.atan2(S-(i*x+n*v*2+a*d),y-(t*x+s*v*2+c*d)))}},nt=Ue;nt.NONE=-1,nt.BEFORE=-2,nt.AFTER=-3,nt.epsilon=1e-5;var rs=class{constructor(e,t){if(this.darkColor=null,this.attachment=null,this.attachmentState=0,this.sequenceIndex=-1,this.deform=new Array,!e)throw new Error("data cannot be null.");if(!t)throw new Error("bone cannot be null.");this.data=e,this.bone=t,this.color=new O,this.darkColor=e.darkColor?new O:null,this.setToSetupPose()}getSkeleton(){return this.bone.skeleton}getAttachment(){return this.attachment}setAttachment(e){this.attachment!=e&&((!(e instanceof Ye)||!(this.attachment instanceof Ye)||e.timelineAttachment!=this.attachment.timelineAttachment)&&(this.deform.length=0),this.attachment=e,this.sequenceIndex=-1)}setToSetupPose(){this.color.setFromColor(this.data.color),this.darkColor&&this.darkColor.setFromColor(this.data.darkColor),this.data.attachmentName?(this.attachment=null,this.setAttachment(this.bone.skeleton.getAttachment(this.data.index,this.data.attachmentName))):this.attachment=null}},ns=class{constructor(e,t){if(this.mixRotate=0,this.mixX=0,this.mixY=0,this.mixScaleX=0,this.mixScaleY=0,this.mixShearY=0,this.temp=new Je,this.active=!1,!e)throw new Error("data cannot be null.");if(!t)throw new Error("skeleton cannot be null.");this.data=e,this.mixRotate=e.mixRotate,this.mixX=e.mixX,this.mixY=e.mixY,this.mixScaleX=e.mixScaleX,this.mixScaleY=e.mixScaleY,this.mixShearY=e.mixShearY,this.bones=new Array;for(let s=0;s<e.bones.length;s++){let n=t.findBone(e.bones[s].name);if(!n)throw new Error(`Couldn't find bone ${e.bones[s].name}.`);this.bones.push(n)}let i=t.findBone(e.target.name);if(!i)throw new Error(`Couldn't find target bone ${e.target.name}.`);this.target=i}isActive(){return this.active}update(){this.mixRotate==0&&this.mixX==0&&this.mixY==0&&this.mixScaleX==0&&this.mixScaleX==0&&this.mixShearY==0||(this.data.local?this.data.relative?this.applyRelativeLocal():this.applyAbsoluteLocal():this.data.relative?this.applyRelativeWorld():this.applyAbsoluteWorld())}applyAbsoluteWorld(){let e=this.mixRotate,t=this.mixX,i=this.mixY,s=this.mixScaleX,n=this.mixScaleY,c=this.mixShearY,a=t!=0||i!=0,r=this.target,o=r.a,l=r.b,h=r.c,f=r.d,d=o*f-l*h>0?R.degRad:-R.degRad,u=this.data.offsetRotation*d,m=this.data.offsetShearY*d,x=this.bones;for(let b=0,v=x.length;b<v;b++){let g=x[b];if(e!=0){let w=g.a,p=g.b,y=g.c,S=g.d,A=Math.atan2(h,o)-Math.atan2(y,w)+u;A>R.PI?A-=R.PI2:A<-R.PI&&(A+=R.PI2),A*=e;let I=Math.cos(A),Y=Math.sin(A);g.a=I*w-Y*y,g.b=I*p-Y*S,g.c=Y*w+I*y,g.d=Y*p+I*S}if(a){let w=this.temp;r.localToWorld(w.set(this.data.offsetX,this.data.offsetY)),g.worldX+=(w.x-g.worldX)*t,g.worldY+=(w.y-g.worldY)*i}if(s!=0){let w=Math.sqrt(g.a*g.a+g.c*g.c);w!=0&&(w=(w+(Math.sqrt(o*o+h*h)-w+this.data.offsetScaleX)*s)/w),g.a*=w,g.c*=w}if(n!=0){let w=Math.sqrt(g.b*g.b+g.d*g.d);w!=0&&(w=(w+(Math.sqrt(l*l+f*f)-w+this.data.offsetScaleY)*n)/w),g.b*=w,g.d*=w}if(c>0){let w=g.b,p=g.d,y=Math.atan2(p,w),S=Math.atan2(f,l)-Math.atan2(h,o)-(y-Math.atan2(g.c,g.a));S>R.PI?S-=R.PI2:S<-R.PI&&(S+=R.PI2),S=y+(S+m)*c;let A=Math.sqrt(w*w+p*p);g.b=Math.cos(S)*A,g.d=Math.sin(S)*A}g.updateAppliedTransform()}}applyRelativeWorld(){let e=this.mixRotate,t=this.mixX,i=this.mixY,s=this.mixScaleX,n=this.mixScaleY,c=this.mixShearY,a=t!=0||i!=0,r=this.target,o=r.a,l=r.b,h=r.c,f=r.d,d=o*f-l*h>0?R.degRad:-R.degRad,u=this.data.offsetRotation*d,m=this.data.offsetShearY*d,x=this.bones;for(let b=0,v=x.length;b<v;b++){let g=x[b];if(e!=0){let w=g.a,p=g.b,y=g.c,S=g.d,A=Math.atan2(h,o)+u;A>R.PI?A-=R.PI2:A<-R.PI&&(A+=R.PI2),A*=e;let I=Math.cos(A),Y=Math.sin(A);g.a=I*w-Y*y,g.b=I*p-Y*S,g.c=Y*w+I*y,g.d=Y*p+I*S}if(a){let w=this.temp;r.localToWorld(w.set(this.data.offsetX,this.data.offsetY)),g.worldX+=w.x*t,g.worldY+=w.y*i}if(s!=0){let w=(Math.sqrt(o*o+h*h)-1+this.data.offsetScaleX)*s+1;g.a*=w,g.c*=w}if(n!=0){let w=(Math.sqrt(l*l+f*f)-1+this.data.offsetScaleY)*n+1;g.b*=w,g.d*=w}if(c>0){let w=Math.atan2(f,l)-Math.atan2(h,o);w>R.PI?w-=R.PI2:w<-R.PI&&(w+=R.PI2);let p=g.b,y=g.d;w=Math.atan2(y,p)+(w-R.PI/2+m)*c;let S=Math.sqrt(p*p+y*y);g.b=Math.cos(w)*S,g.d=Math.sin(w)*S}g.updateAppliedTransform()}}applyAbsoluteLocal(){let e=this.mixRotate,t=this.mixX,i=this.mixY,s=this.mixScaleX,n=this.mixScaleY,c=this.mixShearY,a=this.target,r=this.bones;for(let o=0,l=r.length;o<l;o++){let h=r[o],f=h.arotation;if(e!=0){let v=a.arotation-f+this.data.offsetRotation;v-=(16384-(16384.499999999996-v/360|0))*360,f+=v*e}let d=h.ax,u=h.ay;d+=(a.ax-d+this.data.offsetX)*t,u+=(a.ay-u+this.data.offsetY)*i;let m=h.ascaleX,x=h.ascaleY;s!=0&&m!=0&&(m=(m+(a.ascaleX-m+this.data.offsetScaleX)*s)/m),n!=0&&x!=0&&(x=(x+(a.ascaleY-x+this.data.offsetScaleY)*n)/x);let b=h.ashearY;if(c!=0){let v=a.ashearY-b+this.data.offsetShearY;v-=(16384-(16384.499999999996-v/360|0))*360,b+=v*c}h.updateWorldTransformWith(d,u,f,m,x,h.ashearX,b)}}applyRelativeLocal(){let e=this.mixRotate,t=this.mixX,i=this.mixY,s=this.mixScaleX,n=this.mixScaleY,c=this.mixShearY,a=this.target,r=this.bones;for(let o=0,l=r.length;o<l;o++){let h=r[o],f=h.arotation+(a.arotation+this.data.offsetRotation)*e,d=h.ax+(a.ax+this.data.offsetX)*t,u=h.ay+(a.ay+this.data.offsetY)*i,m=h.ascaleX*((a.ascaleX-1+this.data.offsetScaleX)*s+1),x=h.ascaleY*((a.ascaleY-1+this.data.offsetScaleY)*n+1),b=h.ashearY+(a.ashearY+this.data.offsetShearY)*c;h.updateWorldTransformWith(d,u,f,m,x,h.ashearX,b)}}},Ls=class{constructor(e){if(this._updateCache=new Array,this.skin=null,this.scaleX=1,this.scaleY=1,this.x=0,this.y=0,!e)throw new Error("data cannot be null.");this.data=e,this.bones=new Array;for(let t=0;t<e.bones.length;t++){let i=e.bones[t],s;if(!i.parent)s=new pi(i,this,null);else{let n=this.bones[i.parent.index];s=new pi(i,this,n),n.children.push(s)}this.bones.push(s)}this.slots=new Array,this.drawOrder=new Array;for(let t=0;t<e.slots.length;t++){let i=e.slots[t],s=this.bones[i.boneData.index],n=new rs(i,s);this.slots.push(n),this.drawOrder.push(n)}this.ikConstraints=new Array;for(let t=0;t<e.ikConstraints.length;t++){let i=e.ikConstraints[t];this.ikConstraints.push(new ss(i,this))}this.transformConstraints=new Array;for(let t=0;t<e.transformConstraints.length;t++){let i=e.transformConstraints[t];this.transformConstraints.push(new ns(i,this))}this.pathConstraints=new Array;for(let t=0;t<e.pathConstraints.length;t++){let i=e.pathConstraints[t];this.pathConstraints.push(new nt(i,this))}this.color=new O(1,1,1,1),this.updateCache()}updateCache(){let e=this._updateCache;e.length=0;let t=this.bones;for(let l=0,h=t.length;l<h;l++){let f=t[l];f.sorted=f.data.skinRequired,f.active=!f.sorted}if(this.skin){let l=this.skin.bones;for(let h=0,f=this.skin.bones.length;h<f;h++){let d=this.bones[l[h].index];do d.sorted=!1,d.active=!0,d=d.parent;while(d)}}let i=this.ikConstraints,s=this.transformConstraints,n=this.pathConstraints,c=i.length,a=s.length,r=n.length,o=c+a+r;e:for(let l=0;l<o;l++){for(let h=0;h<c;h++){let f=i[h];if(f.data.order==l){this.sortIkConstraint(f);continue e}}for(let h=0;h<a;h++){let f=s[h];if(f.data.order==l){this.sortTransformConstraint(f);continue e}}for(let h=0;h<r;h++){let f=n[h];if(f.data.order==l){this.sortPathConstraint(f);continue e}}}for(let l=0,h=t.length;l<h;l++)this.sortBone(t[l])}sortIkConstraint(e){if(e.active=e.target.isActive()&&(!e.data.skinRequired||this.skin&&B.contains(this.skin.constraints,e.data,!0)),!e.active)return;let t=e.target;this.sortBone(t);let i=e.bones,s=i[0];if(this.sortBone(s),i.length==1)this._updateCache.push(e),this.sortReset(s.children);else{let n=i[i.length-1];this.sortBone(n),this._updateCache.push(e),this.sortReset(s.children),n.sorted=!0}}sortPathConstraint(e){if(e.active=e.target.bone.isActive()&&(!e.data.skinRequired||this.skin&&B.contains(this.skin.constraints,e.data,!0)),!e.active)return;let t=e.target,i=t.data.index,s=t.bone;this.skin&&this.sortPathConstraintAttachment(this.skin,i,s),this.data.defaultSkin&&this.data.defaultSkin!=this.skin&&this.sortPathConstraintAttachment(this.data.defaultSkin,i,s);for(let r=0,o=this.data.skins.length;r<o;r++)this.sortPathConstraintAttachment(this.data.skins[r],i,s);let n=t.getAttachment();n instanceof tt&&this.sortPathConstraintAttachmentWith(n,s);let c=e.bones,a=c.length;for(let r=0;r<a;r++)this.sortBone(c[r]);this._updateCache.push(e);for(let r=0;r<a;r++)this.sortReset(c[r].children);for(let r=0;r<a;r++)c[r].sorted=!0}sortTransformConstraint(e){if(e.active=e.target.isActive()&&(!e.data.skinRequired||this.skin&&B.contains(this.skin.constraints,e.data,!0)),!e.active)return;this.sortBone(e.target);let t=e.bones,i=t.length;if(e.data.local)for(let s=0;s<i;s++){let n=t[s];this.sortBone(n.parent),this.sortBone(n)}else for(let s=0;s<i;s++)this.sortBone(t[s]);this._updateCache.push(e);for(let s=0;s<i;s++)this.sortReset(t[s].children);for(let s=0;s<i;s++)t[s].sorted=!0}sortPathConstraintAttachment(e,t,i){let s=e.attachments[t];if(!!s)for(let n in s)this.sortPathConstraintAttachmentWith(s[n],i)}sortPathConstraintAttachmentWith(e,t){if(!(e instanceof tt))return;let i=e.bones;if(!i)this.sortBone(t);else{let s=this.bones;for(let n=0,c=i.length;n<c;){let a=i[n++];for(a+=n;n<a;)this.sortBone(s[i[n++]])}}}sortBone(e){if(!e||e.sorted)return;let t=e.parent;t&&this.sortBone(t),e.sorted=!0,this._updateCache.push(e)}sortReset(e){for(let t=0,i=e.length;t<i;t++){let s=e[t];!s.active||(s.sorted&&this.sortReset(s.children),s.sorted=!1)}}updateWorldTransform(){let e=this.bones;for(let i=0,s=e.length;i<s;i++){let n=e[i];n.ax=n.x,n.ay=n.y,n.arotation=n.rotation,n.ascaleX=n.scaleX,n.ascaleY=n.scaleY,n.ashearX=n.shearX,n.ashearY=n.shearY}let t=this._updateCache;for(let i=0,s=t.length;i<s;i++)t[i].update()}updateWorldTransformWith(e){let t=this.getRootBone();if(!t)throw new Error("Root bone must not be null.");let i=e.a,s=e.b,n=e.c,c=e.d;t.worldX=i*this.x+s*this.y+e.worldX,t.worldY=n*this.x+c*this.y+e.worldY;let a=t.rotation+90+t.shearY,r=R.cosDeg(t.rotation+t.shearX)*t.scaleX,o=R.cosDeg(a)*t.scaleY,l=R.sinDeg(t.rotation+t.shearX)*t.scaleX,h=R.sinDeg(a)*t.scaleY;t.a=(i*r+s*l)*this.scaleX,t.b=(i*o+s*h)*this.scaleX,t.c=(n*r+c*l)*this.scaleY,t.d=(n*o+c*h)*this.scaleY;let f=this._updateCache;for(let d=0,u=f.length;d<u;d++){let m=f[d];m!=t&&m.update()}}setToSetupPose(){this.setBonesToSetupPose(),this.setSlotsToSetupPose()}setBonesToSetupPose(){let e=this.bones;for(let n=0,c=e.length;n<c;n++)e[n].setToSetupPose();let t=this.ikConstraints;for(let n=0,c=t.length;n<c;n++){let a=t[n];a.mix=a.data.mix,a.softness=a.data.softness,a.bendDirection=a.data.bendDirection,a.compress=a.data.compress,a.stretch=a.data.stretch}let i=this.transformConstraints;for(let n=0,c=i.length;n<c;n++){let a=i[n],r=a.data;a.mixRotate=r.mixRotate,a.mixX=r.mixX,a.mixY=r.mixY,a.mixScaleX=r.mixScaleX,a.mixScaleY=r.mixScaleY,a.mixShearY=r.mixShearY}let s=this.pathConstraints;for(let n=0,c=s.length;n<c;n++){let a=s[n],r=a.data;a.position=r.position,a.spacing=r.spacing,a.mixRotate=r.mixRotate,a.mixX=r.mixX,a.mixY=r.mixY}}setSlotsToSetupPose(){let e=this.slots;B.arrayCopy(e,0,this.drawOrder,0,e.length);for(let t=0,i=e.length;t<i;t++)e[t].setToSetupPose()}getRootBone(){return this.bones.length==0?null:this.bones[0]}findBone(e){if(!e)throw new Error("boneName cannot be null.");let t=this.bones;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.data.name==e)return n}return null}findSlot(e){if(!e)throw new Error("slotName cannot be null.");let t=this.slots;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.data.name==e)return n}return null}setSkinByName(e){let t=this.data.findSkin(e);if(!t)throw new Error("Skin not found: "+e);this.setSkin(t)}setSkin(e){if(e!=this.skin){if(e)if(this.skin)e.attachAll(this,this.skin);else{let t=this.slots;for(let i=0,s=t.length;i<s;i++){let n=t[i],c=n.data.attachmentName;if(c){let a=e.getAttachment(i,c);a&&n.setAttachment(a)}}}this.skin=e,this.updateCache()}}getAttachmentByName(e,t){let i=this.data.findSlot(e);if(!i)throw new Error(`Can't find slot with name ${e}`);return this.getAttachment(i.index,t)}getAttachment(e,t){if(!t)throw new Error("attachmentName cannot be null.");if(this.skin){let i=this.skin.getAttachment(e,t);if(i)return i}return this.data.defaultSkin?this.data.defaultSkin.getAttachment(e,t):null}setAttachment(e,t){if(!e)throw new Error("slotName cannot be null.");let i=this.slots;for(let s=0,n=i.length;s<n;s++){let c=i[s];if(c.data.name==e){let a=null;if(t&&(a=this.getAttachment(s,t),!a))throw new Error("Attachment not found: "+t+", for slot: "+e);c.setAttachment(a);return}}throw new Error("Slot not found: "+e)}findIkConstraint(e){if(!e)throw new Error("constraintName cannot be null.");let t=this.ikConstraints;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.data.name==e)return n}return null}findTransformConstraint(e){if(!e)throw new Error("constraintName cannot be null.");let t=this.transformConstraints;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.data.name==e)return n}return null}findPathConstraint(e){if(!e)throw new Error("constraintName cannot be null.");let t=this.pathConstraints;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.data.name==e)return n}return null}getBoundsRect(){let e=new Je,t=new Je;return this.getBounds(e,t),{x:e.x,y:e.y,width:t.x,height:t.y}}getBounds(e,t,i=new Array(2)){if(!e)throw new Error("offset cannot be null.");if(!t)throw new Error("size cannot be null.");let s=this.drawOrder,n=Number.POSITIVE_INFINITY,c=Number.POSITIVE_INFINITY,a=Number.NEGATIVE_INFINITY,r=Number.NEGATIVE_INFINITY;for(let o=0,l=s.length;o<l;o++){let h=s[o];if(!h.bone.active)continue;let f=0,d=null,u=h.getAttachment();if(u instanceof ne)f=8,d=B.setArraySize(i,f,0),u.computeWorldVertices(h,d,0,2);else if(u instanceof Ge){let m=u;f=m.worldVerticesLength,d=B.setArraySize(i,f,0),m.computeWorldVertices(h,0,f,d,0,2)}if(d)for(let m=0,x=d.length;m<x;m+=2){let b=d[m],v=d[m+1];n=Math.min(n,b),c=Math.min(c,v),a=Math.max(a,b),r=Math.max(r,v)}}e.set(n,c),t.set(a-n,r-c)}},Ci=class{constructor(){this.name=null,this.bones=new Array,this.slots=new Array,this.skins=new Array,this.defaultSkin=null,this.events=new Array,this.animations=new Array,this.ikConstraints=new Array,this.transformConstraints=new Array,this.pathConstraints=new Array,this.x=0,this.y=0,this.width=0,this.height=0,this.version=null,this.hash=null,this.fps=0,this.imagesPath=null,this.audioPath=null}findBone(e){if(!e)throw new Error("boneName cannot be null.");let t=this.bones;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.name==e)return n}return null}findSlot(e){if(!e)throw new Error("slotName cannot be null.");let t=this.slots;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.name==e)return n}return null}findSkin(e){if(!e)throw new Error("skinName cannot be null.");let t=this.skins;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.name==e)return n}return null}findEvent(e){if(!e)throw new Error("eventDataName cannot be null.");let t=this.events;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.name==e)return n}return null}findAnimation(e){if(!e)throw new Error("animationName cannot be null.");let t=this.animations;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.name==e)return n}return null}findIkConstraint(e){if(!e)throw new Error("constraintName cannot be null.");let t=this.ikConstraints;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.name==e)return n}return null}findTransformConstraint(e){if(!e)throw new Error("constraintName cannot be null.");let t=this.transformConstraints;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.name==e)return n}return null}findPathConstraint(e){if(!e)throw new Error("constraintName cannot be null.");let t=this.pathConstraints;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.name==e)return n}return null}},Ti=class{constructor(e=0,t,i){this.slotIndex=e,this.name=t,this.attachment=i}},Et=class{constructor(e){if(this.attachments=new Array,this.bones=Array(),this.constraints=new Array,!e)throw new Error("name cannot be null.");this.name=e}setAttachment(e,t,i){if(!i)throw new Error("attachment cannot be null.");let s=this.attachments;e>=s.length&&(s.length=e+1),s[e]||(s[e]={}),s[e][t]=i}addSkin(e){for(let s=0;s<e.bones.length;s++){let n=e.bones[s],c=!1;for(let a=0;a<this.bones.length;a++)if(this.bones[a]==n){c=!0;break}c||this.bones.push(n)}for(let s=0;s<e.constraints.length;s++){let n=e.constraints[s],c=!1;for(let a=0;a<this.constraints.length;a++)if(this.constraints[a]==n){c=!0;break}c||this.constraints.push(n)}let t=e.getAttachments();for(let s=0;s<t.length;s++){var i=t[s];this.setAttachment(i.slotIndex,i.name,i.attachment)}}copySkin(e){for(let s=0;s<e.bones.length;s++){let n=e.bones[s],c=!1;for(let a=0;a<this.bones.length;a++)if(this.bones[a]==n){c=!0;break}c||this.bones.push(n)}for(let s=0;s<e.constraints.length;s++){let n=e.constraints[s],c=!1;for(let a=0;a<this.constraints.length;a++)if(this.constraints[a]==n){c=!0;break}c||this.constraints.push(n)}let t=e.getAttachments();for(let s=0;s<t.length;s++){var i=t[s];!i.attachment||(i.attachment instanceof Ge?(i.attachment=i.attachment.newLinkedMesh(),this.setAttachment(i.slotIndex,i.name,i.attachment)):(i.attachment=i.attachment.copy(),this.setAttachment(i.slotIndex,i.name,i.attachment)))}}getAttachment(e,t){let i=this.attachments[e];return i?i[t]:null}removeAttachment(e,t){let i=this.attachments[e];i&&delete i[t]}getAttachments(){let e=new Array;for(var t=0;t<this.attachments.length;t++){let i=this.attachments[t];if(i)for(let s in i){let n=i[s];n&&e.push(new Ti(t,s,n))}}return e}getAttachmentsForSlot(e,t){let i=this.attachments[e];if(i)for(let s in i){let n=i[s];n&&t.push(new Ti(e,s,n))}}clear(){this.attachments.length=0,this.bones.length=0,this.constraints.length=0}attachAll(e,t){let i=0;for(let s=0;s<e.slots.length;s++){let n=e.slots[s],c=n.getAttachment();if(c&&i<t.attachments.length){let a=t.attachments[i];for(let r in a){let o=a[r];if(c==o){let l=this.getAttachment(i,r);l&&n.setAttachment(l);break}}}i++}}},Ii=class{constructor(e,t,i){if(this.index=0,this.color=new O(1,1,1,1),this.darkColor=null,this.attachmentName=null,this.blendMode=pe.Normal,e<0)throw new Error("index must be >= 0.");if(!t)throw new Error("name cannot be null.");if(!i)throw new Error("boneData cannot be null.");this.index=e,this.name=t,this.boneData=i}},pe;(function(e){e[e.Normal=0]="Normal",e[e.Additive=1]="Additive",e[e.Multiply=2]="Multiply",e[e.Screen=3]="Screen"})(pe||(pe={}));var Mi=class extends Mt{constructor(e){super(e,0,!1);this.bones=new Array,this._target=null,this.mixRotate=0,this.mixX=0,this.mixY=0,this.mixScaleX=0,this.mixScaleY=0,this.mixShearY=0,this.offsetRotation=0,this.offsetX=0,this.offsetY=0,this.offsetScaleX=0,this.offsetScaleY=0,this.offsetShearY=0,this.relative=!1,this.local=!1}set target(e){this._target=e}get target(){if(this._target)return this._target;throw new Error("BoneData not set.")}},Ps=class{constructor(e){this.scale=1,this.linkedMeshes=new Array,this.attachmentLoader=e}readSkeletonData(e){let t=this.scale,i=new Ci;i.name="";let s=new as(e),n=s.readInt32(),c=s.readInt32();i.hash=c==0&&n==0?null:c.toString(16)+n.toString(16),i.version=s.readString(),i.x=s.readFloat(),i.y=s.readFloat(),i.width=s.readFloat(),i.height=s.readFloat();let a=s.readBoolean();a&&(i.fps=s.readFloat(),i.imagesPath=s.readString(),i.audioPath=s.readString());let r=0;r=s.readInt(!0);for(let l=0;l<r;l++){let h=s.readString();if(!h)throw new Error("String in string table must not be null.");s.strings.push(h)}r=s.readInt(!0);for(let l=0;l<r;l++){let h=s.readString();if(!h)throw new Error("Bone name must not be null.");let f=l==0?null:i.bones[s.readInt(!0)],d=new wi(l,h,f);d.rotation=s.readFloat(),d.x=s.readFloat()*t,d.y=s.readFloat()*t,d.scaleX=s.readFloat(),d.scaleY=s.readFloat(),d.shearX=s.readFloat(),d.shearY=s.readFloat(),d.length=s.readFloat()*t,d.transformMode=s.readInt(!0),d.skinRequired=s.readBoolean(),a&&O.rgba8888ToColor(d.color,s.readInt32()),i.bones.push(d)}r=s.readInt(!0);for(let l=0;l<r;l++){let h=s.readString();if(!h)throw new Error("Slot name must not be null.");let f=i.bones[s.readInt(!0)],d=new Ii(l,h,f);O.rgba8888ToColor(d.color,s.readInt32());let u=s.readInt32();u!=-1&&O.rgb888ToColor(d.darkColor=new O,u),d.attachmentName=s.readStringRef(),d.blendMode=s.readInt(!0),i.slots.push(d)}r=s.readInt(!0);for(let l=0,h;l<r;l++){let f=s.readString();if(!f)throw new Error("IK constraint data name must not be null.");let d=new Ai(f);d.order=s.readInt(!0),d.skinRequired=s.readBoolean(),h=s.readInt(!0);for(let u=0;u<h;u++)d.bones.push(i.bones[s.readInt(!0)]);d.target=i.bones[s.readInt(!0)],d.mix=s.readFloat(),d.softness=s.readFloat()*t,d.bendDirection=s.readByte(),d.compress=s.readBoolean(),d.stretch=s.readBoolean(),d.uniform=s.readBoolean(),i.ikConstraints.push(d)}r=s.readInt(!0);for(let l=0,h;l<r;l++){let f=s.readString();if(!f)throw new Error("Transform constraint data name must not be null.");let d=new Mi(f);d.order=s.readInt(!0),d.skinRequired=s.readBoolean(),h=s.readInt(!0);for(let u=0;u<h;u++)d.bones.push(i.bones[s.readInt(!0)]);d.target=i.bones[s.readInt(!0)],d.local=s.readBoolean(),d.relative=s.readBoolean(),d.offsetRotation=s.readFloat(),d.offsetX=s.readFloat()*t,d.offsetY=s.readFloat()*t,d.offsetScaleX=s.readFloat(),d.offsetScaleY=s.readFloat(),d.offsetShearY=s.readFloat(),d.mixRotate=s.readFloat(),d.mixX=s.readFloat(),d.mixY=s.readFloat(),d.mixScaleX=s.readFloat(),d.mixScaleY=s.readFloat(),d.mixShearY=s.readFloat(),i.transformConstraints.push(d)}r=s.readInt(!0);for(let l=0,h;l<r;l++){let f=s.readString();if(!f)throw new Error("Path constraint data name must not be null.");let d=new Si(f);d.order=s.readInt(!0),d.skinRequired=s.readBoolean(),h=s.readInt(!0);for(let u=0;u<h;u++)d.bones.push(i.bones[s.readInt(!0)]);d.target=i.slots[s.readInt(!0)],d.positionMode=s.readInt(!0),d.spacingMode=s.readInt(!0),d.rotateMode=s.readInt(!0),d.offsetRotation=s.readFloat(),d.position=s.readFloat(),d.positionMode==Fe.Fixed&&(d.position*=t),d.spacing=s.readFloat(),(d.spacingMode==xe.Length||d.spacingMode==xe.Fixed)&&(d.spacing*=t),d.mixRotate=s.readFloat(),d.mixX=s.readFloat(),d.mixY=s.readFloat(),i.pathConstraints.push(d)}let o=this.readSkin(s,i,!0,a);o&&(i.defaultSkin=o,i.skins.push(o));{let l=i.skins.length;for(B.setArraySize(i.skins,r=l+s.readInt(!0));l<r;l++){let h=this.readSkin(s,i,!1,a);if(!h)throw new Error("readSkin() should not have returned null.");i.skins[l]=h}}r=this.linkedMeshes.length;for(let l=0;l<r;l++){let h=this.linkedMeshes[l],f=h.skin?i.findSkin(h.skin):i.defaultSkin;if(!f)throw new Error("Not skin found for linked mesh.");if(!h.parent)throw new Error("Linked mesh parent must not be null");let d=f.getAttachment(h.slotIndex,h.parent);if(!d)throw new Error(`Parent mesh not found: ${h.parent}`);h.mesh.timelineAttachment=h.inheritTimeline?d:h.mesh,h.mesh.setParentMesh(d),h.mesh.region!=null&&h.mesh.updateRegion()}this.linkedMeshes.length=0,r=s.readInt(!0);for(let l=0;l<r;l++){let h=s.readStringRef();if(!h)throw new Error;let f=new yi(h);f.intValue=s.readInt(!1),f.floatValue=s.readFloat(),f.stringValue=s.readString(),f.audioPath=s.readString(),f.audioPath&&(f.volume=s.readFloat(),f.balance=s.readFloat()),i.events.push(f)}r=s.readInt(!0);for(let l=0;l<r;l++){let h=s.readString();if(!h)throw new Error("Animatio name must not be null.");i.animations.push(this.readAnimation(s,h,i))}return i}readSkin(e,t,i,s){let n=null,c=0;if(i){if(c=e.readInt(!0),c==0)return null;n=new Et("default")}else{let a=e.readStringRef();if(!a)throw new Error("Skin name must not be null.");n=new Et(a),n.bones.length=e.readInt(!0);for(let r=0,o=n.bones.length;r<o;r++)n.bones[r]=t.bones[e.readInt(!0)];for(let r=0,o=e.readInt(!0);r<o;r++)n.constraints.push(t.ikConstraints[e.readInt(!0)]);for(let r=0,o=e.readInt(!0);r<o;r++)n.constraints.push(t.transformConstraints[e.readInt(!0)]);for(let r=0,o=e.readInt(!0);r<o;r++)n.constraints.push(t.pathConstraints[e.readInt(!0)]);c=e.readInt(!0)}for(let a=0;a<c;a++){let r=e.readInt(!0);for(let o=0,l=e.readInt(!0);o<l;o++){let h=e.readStringRef();if(!h)throw new Error("Attachment name must not be null");let f=this.readAttachment(e,t,n,r,h,s);f&&n.setAttachment(r,h,f)}}return n}readAttachment(e,t,i,s,n,c){let a=this.scale,r=e.readStringRef();switch(r||(r=n),e.readByte()){case ze.Region:{let o=e.readStringRef(),l=e.readFloat(),h=e.readFloat(),f=e.readFloat(),d=e.readFloat(),u=e.readFloat(),m=e.readFloat(),x=e.readFloat(),b=e.readInt32(),v=this.readSequence(e);o||(o=r);let g=this.attachmentLoader.newRegionAttachment(i,r,o,v);return g?(g.path=o,g.x=h*a,g.y=f*a,g.scaleX=d,g.scaleY=u,g.rotation=l,g.width=m*a,g.height=x*a,O.rgba8888ToColor(g.color,b),g.sequence=v,v==null&&g.updateRegion(),g):null}case ze.BoundingBox:{let o=e.readInt(!0),l=this.readVertices(e,o),h=c?e.readInt32():0,f=this.attachmentLoader.newBoundingBoxAttachment(i,r);return f?(f.worldVerticesLength=o<<1,f.vertices=l.vertices,f.bones=l.bones,c&&O.rgba8888ToColor(f.color,h),f):null}case ze.Mesh:{let o=e.readStringRef(),l=e.readInt32(),h=e.readInt(!0),f=this.readFloatArray(e,h<<1,1),d=this.readShortArray(e),u=this.readVertices(e,h),m=e.readInt(!0),x=this.readSequence(e),b=[],v=0,g=0;c&&(b=this.readShortArray(e),v=e.readFloat(),g=e.readFloat()),o||(o=r);let w=this.attachmentLoader.newMeshAttachment(i,r,o,x);return w?(w.path=o,O.rgba8888ToColor(w.color,l),w.bones=u.bones,w.vertices=u.vertices,w.worldVerticesLength=h<<1,w.triangles=d,w.regionUVs=f,x==null&&w.updateRegion(),w.hullLength=m<<1,w.sequence=x,c&&(w.edges=b,w.width=v*a,w.height=g*a),w):null}case ze.LinkedMesh:{let o=e.readStringRef(),l=e.readInt32(),h=e.readStringRef(),f=e.readStringRef(),d=e.readBoolean(),u=this.readSequence(e),m=0,x=0;c&&(m=e.readFloat(),x=e.readFloat()),o||(o=r);let b=this.attachmentLoader.newMeshAttachment(i,r,o,u);return b?(b.path=o,O.rgba8888ToColor(b.color,l),b.sequence=u,c&&(b.width=m*a,b.height=x*a),this.linkedMeshes.push(new Bs(b,h,s,f,d)),b):null}case ze.Path:{let o=e.readBoolean(),l=e.readBoolean(),h=e.readInt(!0),f=this.readVertices(e,h),d=B.newArray(h/3,0);for(let x=0,b=d.length;x<b;x++)d[x]=e.readFloat()*a;let u=c?e.readInt32():0,m=this.attachmentLoader.newPathAttachment(i,r);return m?(m.closed=o,m.constantSpeed=l,m.worldVerticesLength=h<<1,m.vertices=f.vertices,m.bones=f.bones,m.lengths=d,c&&O.rgba8888ToColor(m.color,u),m):null}case ze.Point:{let o=e.readFloat(),l=e.readFloat(),h=e.readFloat(),f=c?e.readInt32():0,d=this.attachmentLoader.newPointAttachment(i,r);return d?(d.x=l*a,d.y=h*a,d.rotation=o,c&&O.rgba8888ToColor(d.color,f),d):null}case ze.Clipping:{let o=e.readInt(!0),l=e.readInt(!0),h=this.readVertices(e,l),f=c?e.readInt32():0,d=this.attachmentLoader.newClippingAttachment(i,r);return d?(d.endSlot=t.slots[o],d.worldVerticesLength=l<<1,d.vertices=h.vertices,d.bones=h.bones,c&&O.rgba8888ToColor(d.color,f),d):null}}return null}readSequence(e){if(!e.readBoolean())return null;let t=new _t(e.readInt(!0));return t.start=e.readInt(!0),t.digits=e.readInt(!0),t.setupIndex=e.readInt(!0),t}readVertices(e,t){let i=this.scale,s=t<<1,n=new Os;if(!e.readBoolean())return n.vertices=this.readFloatArray(e,s,i),n;let c=new Array,a=new Array;for(let r=0;r<t;r++){let o=e.readInt(!0);a.push(o);for(let l=0;l<o;l++)a.push(e.readInt(!0)),c.push(e.readFloat()*i),c.push(e.readFloat()*i),c.push(e.readFloat())}return n.vertices=B.toFloatArray(c),n.bones=a,n}readFloatArray(e,t,i){let s=new Array(t);if(i==1)for(let n=0;n<t;n++)s[n]=e.readFloat();else for(let n=0;n<t;n++)s[n]=e.readFloat()*i;return s}readShortArray(e){let t=e.readInt(!0),i=new Array(t);for(let s=0;s<t;s++)i[s]=e.readShort();return i}readAnimation(e,t,i){e.readInt(!0);let s=new Array,n=this.scale,c=new O,a=new O;for(let h=0,f=e.readInt(!0);h<f;h++){let d=e.readInt(!0);for(let u=0,m=e.readInt(!0);u<m;u++){let x=e.readByte(),b=e.readInt(!0),v=b-1;switch(x){case js:{let g=new Qe(b,d);for(let w=0;w<b;w++)g.setFrame(w,e.readFloat(),e.readStringRef());s.push(g);break}case Zs:{let g=e.readInt(!0),w=new ei(b,g,d),p=e.readFloat(),y=e.readUnsignedByte()/255,S=e.readUnsignedByte()/255,A=e.readUnsignedByte()/255,I=e.readUnsignedByte()/255;for(let Y=0,k=0;w.setFrame(Y,p,y,S,A,I),Y!=v;Y++){let X=e.readFloat(),F=e.readUnsignedByte()/255,L=e.readUnsignedByte()/255,T=e.readUnsignedByte()/255,M=e.readUnsignedByte()/255;switch(e.readByte()){case Xe:w.setStepped(Y);break;case Le:ae(e,w,k++,Y,0,p,X,y,F,1),ae(e,w,k++,Y,1,p,X,S,L,1),ae(e,w,k++,Y,2,p,X,A,T,1),ae(e,w,k++,Y,3,p,X,I,M,1)}p=X,y=F,S=L,A=T,I=M}s.push(w);break}case Ks:{let g=e.readInt(!0),w=new ti(b,g,d),p=e.readFloat(),y=e.readUnsignedByte()/255,S=e.readUnsignedByte()/255,A=e.readUnsignedByte()/255;for(let I=0,Y=0;w.setFrame(I,p,y,S,A),I!=v;I++){let k=e.readFloat(),X=e.readUnsignedByte()/255,F=e.readUnsignedByte()/255,L=e.readUnsignedByte()/255;switch(e.readByte()){case Xe:w.setStepped(I);break;case Le:ae(e,w,Y++,I,0,p,k,y,X,1),ae(e,w,Y++,I,1,p,k,S,F,1),ae(e,w,Y++,I,2,p,k,A,L,1)}p=k,y=X,S=F,A=L}s.push(w);break}case Js:{let g=e.readInt(!0),w=new si(b,g,d),p=e.readFloat(),y=e.readUnsignedByte()/255,S=e.readUnsignedByte()/255,A=e.readUnsignedByte()/255,I=e.readUnsignedByte()/255,Y=e.readUnsignedByte()/255,k=e.readUnsignedByte()/255,X=e.readUnsignedByte()/255;for(let F=0,L=0;w.setFrame(F,p,y,S,A,I,Y,k,X),F!=v;F++){let T=e.readFloat(),M=e.readUnsignedByte()/255,P=e.readUnsignedByte()/255,ee=e.readUnsignedByte()/255,te=e.readUnsignedByte()/255,le=e.readUnsignedByte()/255,se=e.readUnsignedByte()/255,he=e.readUnsignedByte()/255;switch(e.readByte()){case Xe:w.setStepped(F);break;case Le:ae(e,w,L++,F,0,p,T,y,M,1),ae(e,w,L++,F,1,p,T,S,P,1),ae(e,w,L++,F,2,p,T,A,ee,1),ae(e,w,L++,F,3,p,T,I,te,1),ae(e,w,L++,F,4,p,T,Y,le,1),ae(e,w,L++,F,5,p,T,k,se,1),ae(e,w,L++,F,6,p,T,X,he,1)}p=T,y=M,S=P,A=ee,I=te,Y=le,k=se,X=he}s.push(w);break}case Qs:{let g=e.readInt(!0),w=new ri(b,g,d),p=e.readFloat(),y=e.readUnsignedByte()/255,S=e.readUnsignedByte()/255,A=e.readUnsignedByte()/255,I=e.readUnsignedByte()/255,Y=e.readUnsignedByte()/255,k=e.readUnsignedByte()/255;for(let X=0,F=0;w.setFrame(X,p,y,S,A,I,Y,k),X!=v;X++){let L=e.readFloat(),T=e.readUnsignedByte()/255,M=e.readUnsignedByte()/255,P=e.readUnsignedByte()/255,ee=e.readUnsignedByte()/255,te=e.readUnsignedByte()/255,le=e.readUnsignedByte()/255;switch(e.readByte()){case Xe:w.setStepped(X);break;case Le:ae(e,w,F++,X,0,p,L,y,T,1),ae(e,w,F++,X,1,p,L,S,M,1),ae(e,w,F++,X,2,p,L,A,P,1),ae(e,w,F++,X,3,p,L,I,ee,1),ae(e,w,F++,X,4,p,L,Y,te,1),ae(e,w,F++,X,5,p,L,k,le,1)}p=L,y=T,S=M,A=P,I=ee,Y=te,k=le}s.push(w);break}case $s:{let g=new ii(b,e.readInt(!0),d),w=e.readFloat(),p=e.readUnsignedByte()/255;for(let y=0,S=0;g.setFrame(y,w,p),y!=v;y++){let A=e.readFloat(),I=e.readUnsignedByte()/255;switch(e.readByte()){case Xe:g.setStepped(y);break;case Le:ae(e,g,S++,y,0,w,A,p,I,1)}w=A,p=I}s.push(g)}}}}for(let h=0,f=e.readInt(!0);h<f;h++){let d=e.readInt(!0);for(let u=0,m=e.readInt(!0);u<m;u++){let x=e.readByte(),b=e.readInt(!0),v=e.readInt(!0);switch(x){case Ds:s.push(We(e,new mt(b,v,d),1));break;case Vs:s.push(Ei(e,new qt(b,v,d),n));break;case Ns:s.push(We(e,new Gt(b,v,d),n));break;case Us:s.push(We(e,new Ht(b,v,d),n));break;case zs:s.push(Ei(e,new jt(b,v,d),1));break;case Ws:s.push(We(e,new Zt(b,v,d),1));break;case _s:s.push(We(e,new Kt(b,v,d),1));break;case qs:s.push(Ei(e,new Jt(b,v,d),1));break;case Gs:s.push(We(e,new Qt(b,v,d),1));break;case Hs:s.push(We(e,new $t(b,v,d),1))}}}for(let h=0,f=e.readInt(!0);h<f;h++){let d=e.readInt(!0),u=e.readInt(!0),m=u-1,x=new ai(u,e.readInt(!0),d),b=e.readFloat(),v=e.readFloat(),g=e.readFloat()*n;for(let w=0,p=0;x.setFrame(w,b,v,g,e.readByte(),e.readBoolean(),e.readBoolean()),w!=m;w++){let y=e.readFloat(),S=e.readFloat(),A=e.readFloat()*n;switch(e.readByte()){case Xe:x.setStepped(w);break;case Le:ae(e,x,p++,w,0,b,y,v,S,1),ae(e,x,p++,w,1,b,y,g,A,n)}b=y,v=S,g=A}s.push(x)}for(let h=0,f=e.readInt(!0);h<f;h++){let d=e.readInt(!0),u=e.readInt(!0),m=u-1,x=new li(u,e.readInt(!0),d),b=e.readFloat(),v=e.readFloat(),g=e.readFloat(),w=e.readFloat(),p=e.readFloat(),y=e.readFloat(),S=e.readFloat();for(let A=0,I=0;x.setFrame(A,b,v,g,w,p,y,S),A!=m;A++){let Y=e.readFloat(),k=e.readFloat(),X=e.readFloat(),F=e.readFloat(),L=e.readFloat(),T=e.readFloat(),M=e.readFloat();switch(e.readByte()){case Xe:x.setStepped(A);break;case Le:ae(e,x,I++,A,0,b,Y,v,k,1),ae(e,x,I++,A,1,b,Y,g,X,1),ae(e,x,I++,A,2,b,Y,w,F,1),ae(e,x,I++,A,3,b,Y,p,L,1),ae(e,x,I++,A,4,b,Y,y,T,1),ae(e,x,I++,A,5,b,Y,S,M,1)}b=Y,v=k,g=X,w=F,p=L,y=T,S=M}s.push(x)}for(let h=0,f=e.readInt(!0);h<f;h++){let d=e.readInt(!0),u=i.pathConstraints[d];for(let m=0,x=e.readInt(!0);m<x;m++)switch(e.readByte()){case ir:s.push(We(e,new oi(e.readInt(!0),e.readInt(!0),d),u.positionMode==Fe.Fixed?n:1));break;case sr:s.push(We(e,new hi(e.readInt(!0),e.readInt(!0),d),u.spacingMode==xe.Length||u.spacingMode==xe.Fixed?n:1));break;case rr:let b=new ci(e.readInt(!0),e.readInt(!0),d),v=e.readFloat(),g=e.readFloat(),w=e.readFloat(),p=e.readFloat();for(let y=0,S=0,A=b.getFrameCount()-1;b.setFrame(y,v,g,w,p),y!=A;y++){let I=e.readFloat(),Y=e.readFloat(),k=e.readFloat(),X=e.readFloat();switch(e.readByte()){case Xe:b.setStepped(y);break;case Le:ae(e,b,S++,y,0,v,I,g,Y,1),ae(e,b,S++,y,1,v,I,w,k,1),ae(e,b,S++,y,2,v,I,p,X,1)}v=I,g=Y,w=k,p=X}s.push(b)}}for(let h=0,f=e.readInt(!0);h<f;h++){let d=i.skins[e.readInt(!0)];for(let u=0,m=e.readInt(!0);u<m;u++){let x=e.readInt(!0);for(let b=0,v=e.readInt(!0);b<v;b++){let g=e.readStringRef();if(!g)throw new Error("attachmentName must not be null.");let w=d.getAttachment(x,g),p=e.readByte(),y=e.readInt(!0),S=y-1;switch(p){case er:{let A=w,I=A.bones,Y=A.vertices,k=I?Y.length/3*2:Y.length,X=e.readInt(!0),F=new ni(y,X,x,A),L=e.readFloat();for(let T=0,M=0;;T++){let P,ee=e.readInt(!0);if(ee==0)P=I?B.newFloatArray(k):Y;else{P=B.newFloatArray(k);let le=e.readInt(!0);if(ee+=le,n==1)for(let se=le;se<ee;se++)P[se]=e.readFloat();else for(let se=le;se<ee;se++)P[se]=e.readFloat()*n;if(!I)for(let se=0,he=P.length;se<he;se++)P[se]+=Y[se]}if(F.setFrame(T,L,P),T==S)break;let te=e.readFloat();switch(e.readByte()){case Xe:F.setStepped(T);break;case Le:ae(e,F,M++,T,0,L,te,0,1,1)}L=te}s.push(F);break}case tr:{let A=new rt(y,x,w);for(let I=0;I<y;I++){let Y=e.readFloat(),k=e.readInt32();A.setFrame(I,Y,_i[k&15],k>>4,e.readFloat())}s.push(A);break}}}}}let r=e.readInt(!0);if(r>0){let h=new $e(r),f=i.slots.length;for(let d=0;d<r;d++){let u=e.readFloat(),m=e.readInt(!0),x=B.newArray(f,0);for(let w=f-1;w>=0;w--)x[w]=-1;let b=B.newArray(f-m,0),v=0,g=0;for(let w=0;w<m;w++){let p=e.readInt(!0);for(;v!=p;)b[g++]=v++;x[v+e.readInt(!0)]=v++}for(;v<f;)b[g++]=v++;for(let w=f-1;w>=0;w--)x[w]==-1&&(x[w]=b[--g]);h.setFrame(d,u,x)}s.push(h)}let o=e.readInt(!0);if(o>0){let h=new gt(o);for(let f=0;f<o;f++){let d=e.readFloat(),u=i.events[e.readInt(!0)],m=new vi(d,u);m.intValue=e.readInt(!1),m.floatValue=e.readFloat(),m.stringValue=e.readBoolean()?e.readString():u.stringValue,m.data.audioPath&&(m.volume=e.readFloat(),m.balance=e.readFloat()),h.setFrame(f,m)}s.push(h)}let l=0;for(let h=0,f=s.length;h<f;h++)l=Math.max(l,s[h].getDuration());return new yt(t,s,l)}},as=class{constructor(e,t=new Array,i=0,s=new DataView(e.buffer)){this.strings=t,this.index=i,this.buffer=s}readByte(){return this.buffer.getInt8(this.index++)}readUnsignedByte(){return this.buffer.getUint8(this.index++)}readShort(){let e=this.buffer.getInt16(this.index);return this.index+=2,e}readInt32(){let e=this.buffer.getInt32(this.index);return this.index+=4,e}readInt(e){let t=this.readByte(),i=t&127;return(t&128)!=0&&(t=this.readByte(),i|=(t&127)<<7,(t&128)!=0&&(t=this.readByte(),i|=(t&127)<<14,(t&128)!=0&&(t=this.readByte(),i|=(t&127)<<21,(t&128)!=0&&(t=this.readByte(),i|=(t&127)<<28)))),e?i:i>>>1^-(i&1)}readStringRef(){let e=this.readInt(!0);return e==0?null:this.strings[e-1]}readString(){let e=this.readInt(!0);switch(e){case 0:return null;case 1:return""}e--;let t="",i=0;for(let s=0;s<e;){let n=this.readUnsignedByte();switch(n>>4){case 12:case 13:t+=String.fromCharCode((n&31)<<6|this.readByte()&63),s+=2;break;case 14:t+=String.fromCharCode((n&15)<<12|(this.readByte()&63)<<6|this.readByte()&63),s+=3;break;default:t+=String.fromCharCode(n),s++}}return t}readFloat(){let e=this.buffer.getFloat32(this.index);return this.index+=4,e}readBoolean(){return this.readByte()!=0}},Bs=class{constructor(e,t,i,s,n){this.mesh=e,this.skin=t,this.slotIndex=i,this.parent=s,this.inheritTimeline=n}},Os=class{constructor(e=null,t=null){this.bones=e,this.vertices=t}},ze;(function(e){e[e.Region=0]="Region",e[e.BoundingBox=1]="BoundingBox",e[e.Mesh=2]="Mesh",e[e.LinkedMesh=3]="LinkedMesh",e[e.Path=4]="Path",e[e.Point=5]="Point",e[e.Clipping=6]="Clipping"})(ze||(ze={}));function We(e,t,i){let s=e.readFloat(),n=e.readFloat()*i;for(let c=0,a=0,r=t.getFrameCount()-1;t.setFrame(c,s,n),c!=r;c++){let o=e.readFloat(),l=e.readFloat()*i;switch(e.readByte()){case Xe:t.setStepped(c);break;case Le:ae(e,t,a++,c,0,s,o,n,l,i)}s=o,n=l}return t}function Ei(e,t,i){let s=e.readFloat(),n=e.readFloat()*i,c=e.readFloat()*i;for(let a=0,r=0,o=t.getFrameCount()-1;t.setFrame(a,s,n,c),a!=o;a++){let l=e.readFloat(),h=e.readFloat()*i,f=e.readFloat()*i;switch(e.readByte()){case Xe:t.setStepped(a);break;case Le:ae(e,t,r++,a,0,s,l,n,h,i),ae(e,t,r++,a,1,s,l,c,f,i)}s=l,n=h,c=f}return t}function ae(e,t,i,s,n,c,a,r,o,l){t.setBezier(i,s,n,c,r,e.readFloat(),e.readFloat()*l,e.readFloat(),e.readFloat()*l,a,o)}var Ds=0,Vs=1,Ns=2,Us=3,zs=4,Ws=5,_s=6,qs=7,Gs=8,Hs=9,js=0,Zs=1,Ks=2,Js=3,Qs=4,$s=5,er=0,tr=1,ir=0,sr=1,rr=2,Xe=1,Le=2,ls=class{constructor(){this.minX=0,this.minY=0,this.maxX=0,this.maxY=0,this.boundingBoxes=new Array,this.polygons=new Array,this.polygonPool=new ut(()=>B.newFloatArray(16))}update(e,t){if(!e)throw new Error("skeleton cannot be null.");let i=this.boundingBoxes,s=this.polygons,n=this.polygonPool,c=e.slots,a=c.length;i.length=0,n.freeAll(s),s.length=0;for(let r=0;r<a;r++){let o=c[r];if(!o.bone.active)continue;let l=o.getAttachment();if(l instanceof It){let h=l;i.push(h);let f=n.obtain();f.length!=h.worldVerticesLength&&(f=B.newFloatArray(h.worldVerticesLength)),s.push(f),h.computeWorldVertices(o,0,h.worldVerticesLength,f,0,2)}}t?this.aabbCompute():(this.minX=Number.POSITIVE_INFINITY,this.minY=Number.POSITIVE_INFINITY,this.maxX=Number.NEGATIVE_INFINITY,this.maxY=Number.NEGATIVE_INFINITY)}aabbCompute(){let e=Number.POSITIVE_INFINITY,t=Number.POSITIVE_INFINITY,i=Number.NEGATIVE_INFINITY,s=Number.NEGATIVE_INFINITY,n=this.polygons;for(let c=0,a=n.length;c<a;c++){let r=n[c],o=r;for(let l=0,h=r.length;l<h;l+=2){let f=o[l],d=o[l+1];e=Math.min(e,f),t=Math.min(t,d),i=Math.max(i,f),s=Math.max(s,d)}}this.minX=e,this.minY=t,this.maxX=i,this.maxY=s}aabbContainsPoint(e,t){return e>=this.minX&&e<=this.maxX&&t>=this.minY&&t<=this.maxY}aabbIntersectsSegment(e,t,i,s){let n=this.minX,c=this.minY,a=this.maxX,r=this.maxY;if(e<=n&&i<=n||t<=c&&s<=c||e>=a&&i>=a||t>=r&&s>=r)return!1;let o=(s-t)/(i-e),l=o*(n-e)+t;if(l>c&&l<r||(l=o*(a-e)+t,l>c&&l<r))return!0;let h=(c-t)/o+e;return!!(h>n&&h<a||(h=(r-t)/o+e,h>n&&h<a))}aabbIntersectsSkeleton(e){return this.minX<e.maxX&&this.maxX>e.minX&&this.minY<e.maxY&&this.maxY>e.minY}containsPoint(e,t){let i=this.polygons;for(let s=0,n=i.length;s<n;s++)if(this.containsPointPolygon(i[s],e,t))return this.boundingBoxes[s];return null}containsPointPolygon(e,t,i){let s=e,n=e.length,c=n-2,a=!1;for(let r=0;r<n;r+=2){let o=s[r+1],l=s[c+1];if(o<i&&l>=i||l<i&&o>=i){let h=s[r];h+(i-o)/(l-o)*(s[c]-h)<t&&(a=!a)}c=r}return a}intersectsSegment(e,t,i,s){let n=this.polygons;for(let c=0,a=n.length;c<a;c++)if(this.intersectsSegmentPolygon(n[c],e,t,i,s))return this.boundingBoxes[c];return null}intersectsSegmentPolygon(e,t,i,s,n){let c=e,a=e.length,r=t-s,o=i-n,l=t*n-i*s,h=c[a-2],f=c[a-1];for(let d=0;d<a;d+=2){let u=c[d],m=c[d+1],x=h*m-f*u,b=h-u,v=f-m,g=r*v-o*b,w=(l*b-r*x)/g;if((w>=h&&w<=u||w>=u&&w<=h)&&(w>=t&&w<=s||w>=s&&w<=t)){let p=(l*v-o*x)/g;if((p>=f&&p<=m||p>=m&&p<=f)&&(p>=i&&p<=n||p>=n&&p<=i))return!0}h=u,f=m}return!1}getPolygon(e){if(!e)throw new Error("boundingBox cannot be null.");let t=this.boundingBoxes.indexOf(e);return t==-1?null:this.polygons[t]}getWidth(){return this.maxX-this.minX}getHeight(){return this.maxY-this.minY}},Te=class{constructor(){this.convexPolygons=new Array,this.convexPolygonsIndices=new Array,this.indicesArray=new Array,this.isConcaveArray=new Array,this.triangles=new Array,this.polygonPool=new ut(()=>new Array),this.polygonIndicesPool=new ut(()=>new Array)}triangulate(e){let t=e,i=e.length>>1,s=this.indicesArray;s.length=0;for(let a=0;a<i;a++)s[a]=a;let n=this.isConcaveArray;n.length=0;for(let a=0,r=i;a<r;++a)n[a]=Te.isConcave(a,i,t,s);let c=this.triangles;for(c.length=0;i>3;){let a=i-1,r=0,o=1;for(;;){e:if(!n[r]){let f=s[a]<<1,d=s[r]<<1,u=s[o]<<1,m=t[f],x=t[f+1],b=t[d],v=t[d+1],g=t[u],w=t[u+1];for(let p=(o+1)%i;p!=a;p=(p+1)%i){if(!n[p])continue;let y=s[p]<<1,S=t[y],A=t[y+1];if(Te.positiveArea(g,w,m,x,S,A)&&Te.positiveArea(m,x,b,v,S,A)&&Te.positiveArea(b,v,g,w,S,A))break e}break}if(o==0){do{if(!n[r])break;r--}while(r>0);break}a=r,r=o,o=(o+1)%i}c.push(s[(i+r-1)%i]),c.push(s[r]),c.push(s[(r+1)%i]),s.splice(r,1),n.splice(r,1),i--;let l=(i+r-1)%i,h=r==i?0:r;n[l]=Te.isConcave(l,i,t,s),n[h]=Te.isConcave(h,i,t,s)}return i==3&&(c.push(s[2]),c.push(s[0]),c.push(s[1])),c}decompose(e,t){let i=e,s=this.convexPolygons;this.polygonPool.freeAll(s),s.length=0;let n=this.convexPolygonsIndices;this.polygonIndicesPool.freeAll(n),n.length=0;let c=this.polygonIndicesPool.obtain();c.length=0;let a=this.polygonPool.obtain();a.length=0;let r=-1,o=0;for(let l=0,h=t.length;l<h;l+=3){let f=t[l]<<1,d=t[l+1]<<1,u=t[l+2]<<1,m=i[f],x=i[f+1],b=i[d],v=i[d+1],g=i[u],w=i[u+1],p=!1;if(r==f){let y=a.length-4,S=Te.winding(a[y],a[y+1],a[y+2],a[y+3],g,w),A=Te.winding(g,w,a[0],a[1],a[2],a[3]);S==o&&A==o&&(a.push(g),a.push(w),c.push(u),p=!0)}p||(a.length>0?(s.push(a),n.push(c)):(this.polygonPool.free(a),this.polygonIndicesPool.free(c)),a=this.polygonPool.obtain(),a.length=0,a.push(m),a.push(x),a.push(b),a.push(v),a.push(g),a.push(w),c=this.polygonIndicesPool.obtain(),c.length=0,c.push(f),c.push(d),c.push(u),o=Te.winding(m,x,b,v,g,w),r=f)}a.length>0&&(s.push(a),n.push(c));for(let l=0,h=s.length;l<h;l++){if(c=n[l],c.length==0)continue;let f=c[0],d=c[c.length-1];a=s[l];let u=a.length-4,m=a[u],x=a[u+1],b=a[u+2],v=a[u+3],g=a[0],w=a[1],p=a[2],y=a[3],S=Te.winding(m,x,b,v,g,w);for(let A=0;A<h;A++){if(A==l)continue;let I=n[A];if(I.length!=3)continue;let Y=I[0],k=I[1],X=I[2],F=s[A],L=F[F.length-2],T=F[F.length-1];if(Y!=f||k!=d)continue;let M=Te.winding(m,x,b,v,L,T),P=Te.winding(L,T,g,w,p,y);M==S&&P==S&&(F.length=0,I.length=0,a.push(L),a.push(T),c.push(X),m=b,x=v,b=L,v=T,A=0)}}for(let l=s.length-1;l>=0;l--)a=s[l],a.length==0&&(s.splice(l,1),this.polygonPool.free(a),c=n[l],n.splice(l,1),this.polygonIndicesPool.free(c));return s}static isConcave(e,t,i,s){let n=s[(t+e-1)%t]<<1,c=s[e]<<1,a=s[(e+1)%t]<<1;return!this.positiveArea(i[n],i[n+1],i[c],i[c+1],i[a],i[a+1])}static positiveArea(e,t,i,s,n,c){return e*(c-s)+i*(t-c)+n*(s-t)>=0}static winding(e,t,i,s,n,c){let a=i-e,r=s-t;return n*r-c*a+a*t-e*r>=0?1:-1}},Yt=class{constructor(){this.triangulator=new Te,this.clippingPolygon=new Array,this.clipOutput=new Array,this.clippedVertices=new Array,this.clippedTriangles=new Array,this.scratch=new Array,this.clipAttachment=null,this.clippingPolygons=null}clipStart(e,t){if(this.clipAttachment)return 0;this.clipAttachment=t;let i=t.worldVerticesLength,s=B.setArraySize(this.clippingPolygon,i);t.computeWorldVertices(e,0,i,s,0,2);let n=this.clippingPolygon;Yt.makeClockwise(n);let c=this.clippingPolygons=this.triangulator.decompose(n,this.triangulator.triangulate(n));for(let a=0,r=c.length;a<r;a++){let o=c[a];Yt.makeClockwise(o),o.push(o[0]),o.push(o[1])}return c.length}clipEndWithSlot(e){this.clipAttachment&&this.clipAttachment.endSlot==e.data&&this.clipEnd()}clipEnd(){!this.clipAttachment||(this.clipAttachment=null,this.clippingPolygons=null,this.clippedVertices.length=0,this.clippedTriangles.length=0,this.clippingPolygon.length=0)}isClipping(){return this.clipAttachment!=null}clipTriangles(e,t,i,s,n,c,a,r){let o=this.clipOutput,l=this.clippedVertices,h=this.clippedTriangles,f=this.clippingPolygons,d=f.length,u=r?12:8,m=0;l.length=0,h.length=0;e:for(let x=0;x<s;x+=3){let b=i[x]<<1,v=e[b],g=e[b+1],w=n[b],p=n[b+1];b=i[x+1]<<1;let y=e[b],S=e[b+1],A=n[b],I=n[b+1];b=i[x+2]<<1;let Y=e[b],k=e[b+1],X=n[b],F=n[b+1];for(let L=0;L<d;L++){let T=l.length;if(this.clip(v,g,y,S,Y,k,f[L],o)){let M=o.length;if(M==0)continue;let P=S-k,ee=Y-y,te=v-Y,le=k-g,se=1/(P*te+ee*(g-k)),he=M>>1,re=this.clipOutput,ie=B.setArraySize(l,T+he*u);for(let Se=0;Se<M;Se+=2){let Be=re[Se],ve=re[Se+1];ie[T]=Be,ie[T+1]=ve,ie[T+2]=c.r,ie[T+3]=c.g,ie[T+4]=c.b,ie[T+5]=c.a;let Me=Be-Y,Ee=ve-k,Ze=(P*Me+ee*Ee)*se,ct=(le*Me+te*Ee)*se,bt=1-Ze-ct;ie[T+6]=w*Ze+A*ct+X*bt,ie[T+7]=p*Ze+I*ct+F*bt,r&&(ie[T+8]=a.r,ie[T+9]=a.g,ie[T+10]=a.b,ie[T+11]=a.a),T+=u}T=h.length;let de=B.setArraySize(h,T+3*(he-2));he--;for(let Se=1;Se<he;Se++)de[T]=m,de[T+1]=m+Se,de[T+2]=m+Se+1,T+=3;m+=he+1}else{let M=B.setArraySize(l,T+3*u);M[T]=v,M[T+1]=g,M[T+2]=c.r,M[T+3]=c.g,M[T+4]=c.b,M[T+5]=c.a,r?(M[T+6]=w,M[T+7]=p,M[T+8]=a.r,M[T+9]=a.g,M[T+10]=a.b,M[T+11]=a.a,M[T+12]=y,M[T+13]=S,M[T+14]=c.r,M[T+15]=c.g,M[T+16]=c.b,M[T+17]=c.a,M[T+18]=A,M[T+19]=I,M[T+20]=a.r,M[T+21]=a.g,M[T+22]=a.b,M[T+23]=a.a,M[T+24]=Y,M[T+25]=k,M[T+26]=c.r,M[T+27]=c.g,M[T+28]=c.b,M[T+29]=c.a,M[T+30]=X,M[T+31]=F,M[T+32]=a.r,M[T+33]=a.g,M[T+34]=a.b,M[T+35]=a.a):(M[T+6]=w,M[T+7]=p,M[T+8]=y,M[T+9]=S,M[T+10]=c.r,M[T+11]=c.g,M[T+12]=c.b,M[T+13]=c.a,M[T+14]=A,M[T+15]=I,M[T+16]=Y,M[T+17]=k,M[T+18]=c.r,M[T+19]=c.g,M[T+20]=c.b,M[T+21]=c.a,M[T+22]=X,M[T+23]=F),T=h.length;let P=B.setArraySize(h,T+3);P[T]=m,P[T+1]=m+1,P[T+2]=m+2,m+=3;continue e}}}}clip(e,t,i,s,n,c,a,r){let o=r,l=!1,h;a.length%4>=2?(h=r,r=this.scratch):h=this.scratch,h.length=0,h.push(e),h.push(t),h.push(i),h.push(s),h.push(n),h.push(c),h.push(e),h.push(t),r.length=0;let f=a,d=a.length-4;for(let u=0;;u+=2){let m=f[u],x=f[u+1],b=f[u+2],v=f[u+3],g=m-b,w=x-v,p=h,y=h.length-2,S=r.length;for(let I=0;I<y;I+=2){let Y=p[I],k=p[I+1],X=p[I+2],F=p[I+3],L=g*(F-v)-w*(X-b)>0;if(g*(k-v)-w*(Y-b)>0){if(L){r.push(X),r.push(F);continue}let T=F-k,M=X-Y,P=T*(b-m)-M*(v-x);if(Math.abs(P)>1e-6){let ee=(M*(x-k)-T*(m-Y))/P;r.push(m+(b-m)*ee),r.push(x+(v-x)*ee)}else r.push(m),r.push(x)}else if(L){let T=F-k,M=X-Y,P=T*(b-m)-M*(v-x);if(Math.abs(P)>1e-6){let ee=(M*(x-k)-T*(m-Y))/P;r.push(m+(b-m)*ee),r.push(x+(v-x)*ee)}else r.push(m),r.push(x);r.push(X),r.push(F)}l=!0}if(S==r.length)return o.length=0,!0;if(r.push(r[0]),r.push(r[1]),u==d)break;let A=r;r=h,r.length=0,h=A}if(o!=r){o.length=0;for(let u=0,m=r.length-2;u<m;u++)o[u]=r[u]}else o.length=o.length-2;return l}static makeClockwise(e){let t=e,i=e.length,s=t[i-2]*t[1]-t[0]*t[i-1],n=0,c=0,a=0,r=0;for(let o=0,l=i-3;o<l;o+=2)n=t[o],c=t[o+1],a=t[o+2],r=t[o+3],s+=n*r-a*c;if(!(s<0))for(let o=0,l=i-2,h=i>>1;o<h;o+=2){let f=t[o],d=t[o+1],u=l-o;t[o]=t[u],t[o+1]=t[u+1],t[u]=f,t[u+1]=d}}},nr=class{constructor(e){this.scale=1,this.linkedMeshes=new Array,this.attachmentLoader=e}readSkeletonData(e){let t=this.scale,i=new Ci,s=typeof e=="string"?JSON.parse(e):e,n=s.skeleton;if(n&&(i.hash=n.hash,i.version=n.spine,i.x=n.x,i.y=n.y,i.width=n.width,i.height=n.height,i.fps=n.fps,i.imagesPath=n.images),s.bones)for(let c=0;c<s.bones.length;c++){let a=s.bones[c],r=null,o=E(a,"parent",null);o&&(r=i.findBone(o));let l=new wi(i.bones.length,a.name,r);l.length=E(a,"length",0)*t,l.x=E(a,"x",0)*t,l.y=E(a,"y",0)*t,l.rotation=E(a,"rotation",0),l.scaleX=E(a,"scaleX",1),l.scaleY=E(a,"scaleY",1),l.shearX=E(a,"shearX",0),l.shearY=E(a,"shearY",0),l.transformMode=B.enumValue(ge,E(a,"transform","Normal")),l.skinRequired=E(a,"skin",!1);let h=E(a,"color",null);h&&l.color.setFromString(h),i.bones.push(l)}if(s.slots)for(let c=0;c<s.slots.length;c++){let a=s.slots[c],r=i.findBone(a.bone);if(!r)throw new Error(`Couldn't find bone ${a.bone} for slot ${a.name}`);let o=new Ii(i.slots.length,a.name,r),l=E(a,"color",null);l&&o.color.setFromString(l);let h=E(a,"dark",null);h&&(o.darkColor=O.fromString(h)),o.attachmentName=E(a,"attachment",null),o.blendMode=B.enumValue(pe,E(a,"blend","normal")),i.slots.push(o)}if(s.ik)for(let c=0;c<s.ik.length;c++){let a=s.ik[c],r=new Ai(a.name);r.order=E(a,"order",0),r.skinRequired=E(a,"skin",!1);for(let l=0;l<a.bones.length;l++){let h=i.findBone(a.bones[l]);if(!h)throw new Error(`Couldn't find bone ${a.bones[l]} for IK constraint ${a.name}.`);r.bones.push(h)}let o=i.findBone(a.target);if(!o)throw new Error(`Couldn't find target bone ${a.target} for IK constraint ${a.name}.`);r.target=o,r.mix=E(a,"mix",1),r.softness=E(a,"softness",0)*t,r.bendDirection=E(a,"bendPositive",!0)?1:-1,r.compress=E(a,"compress",!1),r.stretch=E(a,"stretch",!1),r.uniform=E(a,"uniform",!1),i.ikConstraints.push(r)}if(s.transform)for(let c=0;c<s.transform.length;c++){let a=s.transform[c],r=new Mi(a.name);r.order=E(a,"order",0),r.skinRequired=E(a,"skin",!1);for(let h=0;h<a.bones.length;h++){let f=a.bones[h],d=i.findBone(f);if(!d)throw new Error(`Couldn't find bone ${f} for transform constraint ${a.name}.`);r.bones.push(d)}let o=a.target,l=i.findBone(o);if(!l)throw new Error(`Couldn't find target bone ${o} for transform constraint ${a.name}.`);r.target=l,r.local=E(a,"local",!1),r.relative=E(a,"relative",!1),r.offsetRotation=E(a,"rotation",0),r.offsetX=E(a,"x",0)*t,r.offsetY=E(a,"y",0)*t,r.offsetScaleX=E(a,"scaleX",0),r.offsetScaleY=E(a,"scaleY",0),r.offsetShearY=E(a,"shearY",0),r.mixRotate=E(a,"mixRotate",1),r.mixX=E(a,"mixX",1),r.mixY=E(a,"mixY",r.mixX),r.mixScaleX=E(a,"mixScaleX",1),r.mixScaleY=E(a,"mixScaleY",r.mixScaleX),r.mixShearY=E(a,"mixShearY",1),i.transformConstraints.push(r)}if(s.path)for(let c=0;c<s.path.length;c++){let a=s.path[c],r=new Si(a.name);r.order=E(a,"order",0),r.skinRequired=E(a,"skin",!1);for(let h=0;h<a.bones.length;h++){let f=a.bones[h],d=i.findBone(f);if(!d)throw new Error(`Couldn't find bone ${f} for path constraint ${a.name}.`);r.bones.push(d)}let o=a.target,l=i.findSlot(o);if(!l)throw new Error(`Couldn't find target slot ${o} for path constraint ${a.name}.`);r.target=l,r.positionMode=B.enumValue(Fe,E(a,"positionMode","Percent")),r.spacingMode=B.enumValue(xe,E(a,"spacingMode","Length")),r.rotateMode=B.enumValue(He,E(a,"rotateMode","Tangent")),r.offsetRotation=E(a,"rotation",0),r.position=E(a,"position",0),r.positionMode==Fe.Fixed&&(r.position*=t),r.spacing=E(a,"spacing",0),(r.spacingMode==xe.Length||r.spacingMode==xe.Fixed)&&(r.spacing*=t),r.mixRotate=E(a,"mixRotate",1),r.mixX=E(a,"mixX",1),r.mixY=E(a,"mixY",r.mixX),i.pathConstraints.push(r)}if(s.skins)for(let c=0;c<s.skins.length;c++){let a=s.skins[c],r=new Et(a.name);if(a.bones)for(let o=0;o<a.bones.length;o++){let l=a.bones[o],h=i.findBone(l);if(!h)throw new Error(`Couldn't find bone ${l} for skin ${a.name}.`);r.bones.push(h)}if(a.ik)for(let o=0;o<a.ik.length;o++){let l=a.ik[o],h=i.findIkConstraint(l);if(!h)throw new Error(`Couldn't find IK constraint ${l} for skin ${a.name}.`);r.constraints.push(h)}if(a.transform)for(let o=0;o<a.transform.length;o++){let l=a.transform[o],h=i.findTransformConstraint(l);if(!h)throw new Error(`Couldn't find transform constraint ${l} for skin ${a.name}.`);r.constraints.push(h)}if(a.path)for(let o=0;o<a.path.length;o++){let l=a.path[o],h=i.findPathConstraint(l);if(!h)throw new Error(`Couldn't find path constraint ${l} for skin ${a.name}.`);r.constraints.push(h)}for(let o in a.attachments){let l=i.findSlot(o);if(!l)throw new Error(`Couldn't find slot ${o} for skin ${a.name}.`);let h=a.attachments[o];for(let f in h){let d=this.readAttachment(h[f],r,l.index,f,i);d&&r.setAttachment(l.index,f,d)}}i.skins.push(r),r.name=="default"&&(i.defaultSkin=r)}for(let c=0,a=this.linkedMeshes.length;c<a;c++){let r=this.linkedMeshes[c],o=r.skin?i.findSkin(r.skin):i.defaultSkin;if(!o)throw new Error(`Skin not found: ${r.skin}`);let l=o.getAttachment(r.slotIndex,r.parent);if(!l)throw new Error(`Parent mesh not found: ${r.parent}`);r.mesh.timelineAttachment=r.inheritTimeline?l:r.mesh,r.mesh.setParentMesh(l),r.mesh.region!=null&&r.mesh.updateRegion()}if(this.linkedMeshes.length=0,s.events)for(let c in s.events){let a=s.events[c],r=new yi(c);r.intValue=E(a,"int",0),r.floatValue=E(a,"float",0),r.stringValue=E(a,"string",""),r.audioPath=E(a,"audio",null),r.audioPath&&(r.volume=E(a,"volume",1),r.balance=E(a,"balance",0)),i.events.push(r)}if(s.animations)for(let c in s.animations){let a=s.animations[c];this.readAnimation(a,c,i)}return i}readAttachment(e,t,i,s,n){let c=this.scale;switch(s=E(e,"name",s),E(e,"type","region")){case"region":{let a=E(e,"path",s),r=this.readSequence(E(e,"sequence",null)),o=this.attachmentLoader.newRegionAttachment(t,s,a,r);if(!o)return null;o.path=a,o.x=E(e,"x",0)*c,o.y=E(e,"y",0)*c,o.scaleX=E(e,"scaleX",1),o.scaleY=E(e,"scaleY",1),o.rotation=E(e,"rotation",0),o.width=e.width*c,o.height=e.height*c,o.sequence=r;let l=E(e,"color",null);return l&&o.color.setFromString(l),o.region!=null&&o.updateRegion(),o}case"boundingbox":{let a=this.attachmentLoader.newBoundingBoxAttachment(t,s);if(!a)return null;this.readVertices(e,a,e.vertexCount<<1);let r=E(e,"color",null);return r&&a.color.setFromString(r),a}case"mesh":case"linkedmesh":{let a=E(e,"path",s),r=this.readSequence(E(e,"sequence",null)),o=this.attachmentLoader.newMeshAttachment(t,s,a,r);if(!o)return null;o.path=a;let l=E(e,"color",null);l&&o.color.setFromString(l),o.width=E(e,"width",0)*c,o.height=E(e,"height",0)*c,o.sequence=r;let h=E(e,"parent",null);if(h)return this.linkedMeshes.push(new ar(o,E(e,"skin",null),i,h,E(e,"timelines",!0))),o;let f=e.uvs;return this.readVertices(e,o,f.length),o.triangles=e.triangles,o.regionUVs=f,o.region!=null&&o.updateRegion(),o.edges=E(e,"edges",null),o.hullLength=E(e,"hull",0)*2,o}case"path":{let a=this.attachmentLoader.newPathAttachment(t,s);if(!a)return null;a.closed=E(e,"closed",!1),a.constantSpeed=E(e,"constantSpeed",!0);let r=e.vertexCount;this.readVertices(e,a,r<<1);let o=B.newArray(r/3,0);for(let h=0;h<e.lengths.length;h++)o[h]=e.lengths[h]*c;a.lengths=o;let l=E(e,"color",null);return l&&a.color.setFromString(l),a}case"point":{let a=this.attachmentLoader.newPointAttachment(t,s);if(!a)return null;a.x=E(e,"x",0)*c,a.y=E(e,"y",0)*c,a.rotation=E(e,"rotation",0);let r=E(e,"color",null);return r&&a.color.setFromString(r),a}case"clipping":{let a=this.attachmentLoader.newClippingAttachment(t,s);if(!a)return null;let r=E(e,"end",null);r&&(a.endSlot=n.findSlot(r));let o=e.vertexCount;this.readVertices(e,a,o<<1);let l=E(e,"color",null);return l&&a.color.setFromString(l),a}}return null}readSequence(e){if(e==null)return null;let t=new _t(E(e,"count",0));return t.start=E(e,"start",1),t.digits=E(e,"digits",0),t.setupIndex=E(e,"setup",0),t}readVertices(e,t,i){let s=this.scale;t.worldVerticesLength=i;let n=e.vertices;if(i==n.length){let r=B.toFloatArray(n);if(s!=1)for(let o=0,l=n.length;o<l;o++)r[o]*=s;t.vertices=r;return}let c=new Array,a=new Array;for(let r=0,o=n.length;r<o;){let l=n[r++];a.push(l);for(let h=r+l*4;r<h;r+=4)a.push(n[r]),c.push(n[r+1]*s),c.push(n[r+2]*s),c.push(n[r+3])}t.bones=a,t.vertices=B.toFloatArray(c)}readAnimation(e,t,i){let s=this.scale,n=new Array;if(e.slots)for(let a in e.slots){let r=e.slots[a],o=i.findSlot(a);if(!o)throw new Error("Slot not found: "+a);let l=o.index;for(let h in r){let f=r[h];if(!f)continue;let d=f.length;if(h=="attachment"){let u=new Qe(d,l);for(let m=0;m<d;m++){let x=f[m];u.setFrame(m,E(x,"time",0),E(x,"name",null))}n.push(u)}else if(h=="rgba"){let u=new ei(d,d<<2,l),m=f[0],x=E(m,"time",0),b=O.fromString(m.color);for(let v=0,g=0;;v++){u.setFrame(v,x,b.r,b.g,b.b,b.a);let w=f[v+1];if(!w){u.shrink(g);break}let p=E(w,"time",0),y=O.fromString(w.color),S=m.curve;S&&(g=oe(S,u,g,v,0,x,p,b.r,y.r,1),g=oe(S,u,g,v,1,x,p,b.g,y.g,1),g=oe(S,u,g,v,2,x,p,b.b,y.b,1),g=oe(S,u,g,v,3,x,p,b.a,y.a,1)),x=p,b=y,m=w}n.push(u)}else if(h=="rgb"){let u=new ti(d,d*3,l),m=f[0],x=E(m,"time",0),b=O.fromString(m.color);for(let v=0,g=0;;v++){u.setFrame(v,x,b.r,b.g,b.b);let w=f[v+1];if(!w){u.shrink(g);break}let p=E(w,"time",0),y=O.fromString(w.color),S=m.curve;S&&(g=oe(S,u,g,v,0,x,p,b.r,y.r,1),g=oe(S,u,g,v,1,x,p,b.g,y.g,1),g=oe(S,u,g,v,2,x,p,b.b,y.b,1)),x=p,b=y,m=w}n.push(u)}else if(h=="alpha")n.push(De(f,new ii(d,d,l),0,1));else if(h=="rgba2"){let u=new si(d,d*7,l),m=f[0],x=E(m,"time",0),b=O.fromString(m.light),v=O.fromString(m.dark);for(let g=0,w=0;;g++){u.setFrame(g,x,b.r,b.g,b.b,b.a,v.r,v.g,v.b);let p=f[g+1];if(!p){u.shrink(w);break}let y=E(p,"time",0),S=O.fromString(p.light),A=O.fromString(p.dark),I=m.curve;I&&(w=oe(I,u,w,g,0,x,y,b.r,S.r,1),w=oe(I,u,w,g,1,x,y,b.g,S.g,1),w=oe(I,u,w,g,2,x,y,b.b,S.b,1),w=oe(I,u,w,g,3,x,y,b.a,S.a,1),w=oe(I,u,w,g,4,x,y,v.r,A.r,1),w=oe(I,u,w,g,5,x,y,v.g,A.g,1),w=oe(I,u,w,g,6,x,y,v.b,A.b,1)),x=y,b=S,v=A,m=p}n.push(u)}else if(h=="rgb2"){let u=new ri(d,d*6,l),m=f[0],x=E(m,"time",0),b=O.fromString(m.light),v=O.fromString(m.dark);for(let g=0,w=0;;g++){u.setFrame(g,x,b.r,b.g,b.b,v.r,v.g,v.b);let p=f[g+1];if(!p){u.shrink(w);break}let y=E(p,"time",0),S=O.fromString(p.light),A=O.fromString(p.dark),I=m.curve;I&&(w=oe(I,u,w,g,0,x,y,b.r,S.r,1),w=oe(I,u,w,g,1,x,y,b.g,S.g,1),w=oe(I,u,w,g,2,x,y,b.b,S.b,1),w=oe(I,u,w,g,3,x,y,v.r,A.r,1),w=oe(I,u,w,g,4,x,y,v.g,A.g,1),w=oe(I,u,w,g,5,x,y,v.b,A.b,1)),x=y,b=S,v=A,m=p}n.push(u)}}}if(e.bones)for(let a in e.bones){let r=e.bones[a],o=i.findBone(a);if(!o)throw new Error("Bone not found: "+a);let l=o.index;for(let h in r){let f=r[h],d=f.length;if(d!=0){if(h==="rotate")n.push(De(f,new mt(d,d,l),0,1));else if(h==="translate"){let u=new qt(d,d<<1,l);n.push(Yi(f,u,"x","y",0,s))}else if(h==="translatex"){let u=new Gt(d,d,l);n.push(De(f,u,0,s))}else if(h==="translatey"){let u=new Ht(d,d,l);n.push(De(f,u,0,s))}else if(h==="scale"){let u=new jt(d,d<<1,l);n.push(Yi(f,u,"x","y",1,1))}else if(h==="scalex"){let u=new Zt(d,d,l);n.push(De(f,u,1,1))}else if(h==="scaley"){let u=new Kt(d,d,l);n.push(De(f,u,1,1))}else if(h==="shear"){let u=new Jt(d,d<<1,l);n.push(Yi(f,u,"x","y",0,1))}else if(h==="shearx"){let u=new Qt(d,d,l);n.push(De(f,u,0,1))}else if(h==="sheary"){let u=new $t(d,d,l);n.push(De(f,u,0,1))}}}}if(e.ik)for(let a in e.ik){let r=e.ik[a],o=r[0];if(!o)continue;let l=i.findIkConstraint(a);if(!l)throw new Error("IK Constraint not found: "+a);let h=i.ikConstraints.indexOf(l),f=new ai(r.length,r.length<<1,h),d=E(o,"time",0),u=E(o,"mix",1),m=E(o,"softness",0)*s;for(let x=0,b=0;;x++){f.setFrame(x,d,u,m,E(o,"bendPositive",!0)?1:-1,E(o,"compress",!1),E(o,"stretch",!1));let v=r[x+1];if(!v){f.shrink(b);break}let g=E(v,"time",0),w=E(v,"mix",1),p=E(v,"softness",0)*s,y=o.curve;y&&(b=oe(y,f,b,x,0,d,g,u,w,1),b=oe(y,f,b,x,1,d,g,m,p,s)),d=g,u=w,m=p,o=v}n.push(f)}if(e.transform)for(let a in e.transform){let r=e.transform[a],o=r[0];if(!o)continue;let l=i.findTransformConstraint(a);if(!l)throw new Error("Transform constraint not found: "+a);let h=i.transformConstraints.indexOf(l),f=new li(r.length,r.length*6,h),d=E(o,"time",0),u=E(o,"mixRotate",1),m=E(o,"mixX",1),x=E(o,"mixY",m),b=E(o,"mixScaleX",1),v=E(o,"mixScaleY",b),g=E(o,"mixShearY",1);for(let w=0,p=0;;w++){f.setFrame(w,d,u,m,x,b,v,g);let y=r[w+1];if(!y){f.shrink(p);break}let S=E(y,"time",0),A=E(y,"mixRotate",1),I=E(y,"mixX",1),Y=E(y,"mixY",I),k=E(y,"mixScaleX",1),X=E(y,"mixScaleY",k),F=E(y,"mixShearY",1),L=o.curve;L&&(p=oe(L,f,p,w,0,d,S,u,A,1),p=oe(L,f,p,w,1,d,S,m,I,1),p=oe(L,f,p,w,2,d,S,x,Y,1),p=oe(L,f,p,w,3,d,S,b,k,1),p=oe(L,f,p,w,4,d,S,v,X,1),p=oe(L,f,p,w,5,d,S,g,F,1)),d=S,u=A,m=I,x=Y,b=k,v=X,b=k,o=y}n.push(f)}if(e.path)for(let a in e.path){let r=e.path[a],o=i.findPathConstraint(a);if(!o)throw new Error("Path constraint not found: "+a);let l=i.pathConstraints.indexOf(o);for(let h in r){let f=r[h],d=f[0];if(!d)continue;let u=f.length;if(h==="position"){let m=new oi(u,u,l);n.push(De(f,m,0,o.positionMode==Fe.Fixed?s:1))}else if(h==="spacing"){let m=new hi(u,u,l);n.push(De(f,m,0,o.spacingMode==xe.Length||o.spacingMode==xe.Fixed?s:1))}else if(h==="mix"){let m=new ci(u,u*3,l),x=E(d,"time",0),b=E(d,"mixRotate",1),v=E(d,"mixX",1),g=E(d,"mixY",v);for(let w=0,p=0;;w++){m.setFrame(w,x,b,v,g);let y=f[w+1];if(!y){m.shrink(p);break}let S=E(y,"time",0),A=E(y,"mixRotate",1),I=E(y,"mixX",1),Y=E(y,"mixY",I),k=d.curve;k&&(p=oe(k,m,p,w,0,x,S,b,A,1),p=oe(k,m,p,w,1,x,S,v,I,1),p=oe(k,m,p,w,2,x,S,g,Y,1)),x=S,b=A,v=I,g=Y,d=y}n.push(m)}}}if(e.attachments)for(let a in e.attachments){let r=e.attachments[a],o=i.findSkin(a);if(!o)throw new Error("Skin not found: "+a);for(let l in r){let h=r[l],f=i.findSlot(l);if(!f)throw new Error("Slot not found: "+l);let d=f.index;for(let u in h){let m=h[u],x=o.getAttachment(d,u);for(let b in m){let v=m[b],g=v[0];if(!!g){if(b=="deform"){let w=x.bones,p=x.vertices,y=w?p.length/3*2:p.length,S=new ni(v.length,v.length,d,x),A=E(g,"time",0);for(let I=0,Y=0;;I++){let k,X=E(g,"vertices",null);if(!X)k=w?B.newFloatArray(y):p;else{k=B.newFloatArray(y);let M=E(g,"offset",0);if(B.arrayCopy(X,0,k,M,X.length),s!=1)for(let P=M,ee=P+X.length;P<ee;P++)k[P]*=s;if(!w)for(let P=0;P<y;P++)k[P]+=p[P]}S.setFrame(I,A,k);let F=v[I+1];if(!F){S.shrink(Y);break}let L=E(F,"time",0),T=g.curve;T&&(Y=oe(T,S,Y,I,0,A,L,0,1,1)),A=L,g=F}n.push(S)}else if(b=="sequence"){let w=new rt(v.length,d,x),p=0;for(let y=0;y<v.length;y++){let S=E(g,"delay",p),A=E(g,"time",0),I=Oe[E(g,"mode","hold")],Y=E(g,"index",0);w.setFrame(y,A,I,Y,S),p=S,g=v[y+1]}n.push(w)}}}}}}if(e.drawOrder){let a=new $e(e.drawOrder.length),r=i.slots.length,o=0;for(let l=0;l<e.drawOrder.length;l++,o++){let h=e.drawOrder[l],f=null,d=E(h,"offsets",null);if(d){f=B.newArray(r,-1);let u=B.newArray(r-d.length,0),m=0,x=0;for(let b=0;b<d.length;b++){let v=d[b],g=i.findSlot(v.slot);if(!g)throw new Error("Slot not found: "+g);let w=g.index;for(;m!=w;)u[x++]=m++;f[m+v.offset]=m++}for(;m<r;)u[x++]=m++;for(let b=r-1;b>=0;b--)f[b]==-1&&(f[b]=u[--x])}a.setFrame(o,E(h,"time",0),f)}n.push(a)}if(e.events){let a=new gt(e.events.length),r=0;for(let o=0;o<e.events.length;o++,r++){let l=e.events[o],h=i.findEvent(l.name);if(!h)throw new Error("Event not found: "+l.name);let f=new vi(B.toSinglePrecision(E(l,"time",0)),h);f.intValue=E(l,"int",h.intValue),f.floatValue=E(l,"float",h.floatValue),f.stringValue=E(l,"string",h.stringValue),f.data.audioPath&&(f.volume=E(l,"volume",1),f.balance=E(l,"balance",0)),a.setFrame(r,f)}n.push(a)}let c=0;for(let a=0,r=n.length;a<r;a++)c=Math.max(c,n[a].getDuration());i.animations.push(new yt(t,n,c))}},ar=class{constructor(e,t,i,s,n){this.mesh=e,this.skin=t,this.slotIndex=i,this.parent=s,this.inheritTimeline=n}};function De(e,t,i,s){let n=e[0],c=E(n,"time",0),a=E(n,"value",i)*s,r=0;for(let o=0;;o++){t.setFrame(o,c,a);let l=e[o+1];if(!l)return t.shrink(r),t;let h=E(l,"time",0),f=E(l,"value",i)*s;n.curve&&(r=oe(n.curve,t,r,o,0,c,h,a,f,s)),c=h,a=f,n=l}}function Yi(e,t,i,s,n,c){let a=e[0],r=E(a,"time",0),o=E(a,i,n)*c,l=E(a,s,n)*c,h=0;for(let f=0;;f++){t.setFrame(f,r,o,l);let d=e[f+1];if(!d)return t.shrink(h),t;let u=E(d,"time",0),m=E(d,i,n)*c,x=E(d,s,n)*c,b=a.curve;b&&(h=oe(b,t,h,f,0,r,u,o,m,c),h=oe(b,t,h,f,1,r,u,l,x,c)),r=u,o=m,l=x,a=d}}function oe(e,t,i,s,n,c,a,r,o,l){if(e=="stepped")return t.setStepped(s),i;let h=n<<2,f=e[h],d=e[h+1]*l,u=e[h+2],m=e[h+3]*l;return t.setBezier(i,s,n,c,r,f,d,u,m,a,o),i+1}function E(e,t,i){return e[t]!==void 0?e[t]:i}(()=>{typeof Math.fround=="undefined"&&(Math.fround=function(e){return function(t){return e[0]=t,e[0]}}(new Float32Array(1)))})();var ye=class{constructor(e,t={alpha:"true"}){if(this.restorables=new Array,e instanceof WebGLRenderingContext||typeof WebGL2RenderingContext!="undefined"&&e instanceof WebGL2RenderingContext)this.gl=e,this.canvas=this.gl.canvas;else{let i=e;this.gl=i.getContext("webgl2",t)||i.getContext("webgl",t),this.canvas=i,i.addEventListener("webglcontextlost",s=>{let n=s;s&&s.preventDefault()}),i.addEventListener("webglcontextrestored",s=>{for(let n=0,c=this.restorables.length;n<c;n++)this.restorables[n].restore()})}}addRestorable(e){this.restorables.push(e)}removeRestorable(e){let t=this.restorables.indexOf(e);t>-1&&this.restorables.splice(t,1)}},at=1,lr=769,os=770,kt=771,or=774,Rt=class{static getDestGLBlendMode(e){switch(e){case pe.Normal:return kt;case pe.Additive:return at;case pe.Multiply:return kt;case pe.Screen:return kt;default:throw new Error("Unknown blend mode: "+e)}}static getSourceColorGLBlendMode(e,t=!1){switch(e){case pe.Normal:return t?at:os;case pe.Additive:return t?at:os;case pe.Multiply:return or;case pe.Screen:return at;default:throw new Error("Unknown blend mode: "+e)}}static getSourceAlphaGLBlendMode(e){switch(e){case pe.Normal:return at;case pe.Additive:return at;case pe.Multiply:return kt;case pe.Screen:return lr;default:throw new Error("Unknown blend mode: "+e)}}},Ft=class extends mi{constructor(e,t,i=!1){super(t);this.texture=null,this.boundUnit=0,this.useMipMaps=!1,this.context=e instanceof ye?e:new ye(e),this.useMipMaps=i,this.restore(),this.context.addRestorable(this)}setFilters(e,t){let i=this.context.gl;this.bind(),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_MIN_FILTER,e),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_MAG_FILTER,Ft.validateMagFilter(t)),this.useMipMaps=Ft.usesMipMaps(e),this.useMipMaps&&i.generateMipmap(i.TEXTURE_2D)}static validateMagFilter(e){switch(e){case we.MipMap:case we.MipMapLinearLinear:case we.MipMapLinearNearest:case we.MipMapNearestLinear:case we.MipMapNearestNearest:return we.Linear;default:return e}}static usesMipMaps(e){switch(e){case we.MipMap:case we.MipMapLinearLinear:case we.MipMapLinearNearest:case we.MipMapNearestLinear:case we.MipMapNearestNearest:return!0;default:return!1}}setWraps(e,t){let i=this.context.gl;this.bind(),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_WRAP_S,e),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_WRAP_T,t)}update(e){let t=this.context.gl;this.texture||(this.texture=this.context.gl.createTexture()),this.bind(),Ft.DISABLE_UNPACK_PREMULTIPLIED_ALPHA_WEBGL&&t.pixelStorei(t.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1),t.texImage2D(t.TEXTURE_2D,0,t.RGBA,t.RGBA,t.UNSIGNED_BYTE,this._image),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_MAG_FILTER,t.LINEAR),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_MIN_FILTER,e?t.LINEAR_MIPMAP_LINEAR:t.LINEAR),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_WRAP_S,t.CLAMP_TO_EDGE),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_WRAP_T,t.CLAMP_TO_EDGE),e&&t.generateMipmap(t.TEXTURE_2D)}restore(){this.texture=null,this.update(this.useMipMaps)}bind(e=0){let t=this.context.gl;this.boundUnit=e,t.activeTexture(t.TEXTURE0+e),t.bindTexture(t.TEXTURE_2D,this.texture)}unbind(){let e=this.context.gl;e.activeTexture(e.TEXTURE0+this.boundUnit),e.bindTexture(e.TEXTURE_2D,null)}dispose(){this.context.removeRestorable(this),this.context.gl.deleteTexture(this.texture)}},wt=Ft;wt.DISABLE_UNPACK_PREMULTIPLIED_ALPHA_WEBGL=!1;var hs=class extends is{constructor(e,t="",i=new bi){super(s=>new wt(e,s),t,i)}},Ie=class{constructor(e=0,t=0,i=0){this.x=0,this.y=0,this.z=0,this.x=e,this.y=t,this.z=i}setFrom(e){return this.x=e.x,this.y=e.y,this.z=e.z,this}set(e,t,i){return this.x=e,this.y=t,this.z=i,this}add(e){return this.x+=e.x,this.y+=e.y,this.z+=e.z,this}sub(e){return this.x-=e.x,this.y-=e.y,this.z-=e.z,this}scale(e){return this.x*=e,this.y*=e,this.z*=e,this}normalize(){let e=this.length();return e==0?this:(e=1/e,this.x*=e,this.y*=e,this.z*=e,this)}cross(e){return this.set(this.y*e.z-this.z*e.y,this.z*e.x-this.x*e.z,this.x*e.y-this.y*e.x)}multiply(e){let t=e.values;return this.set(this.x*t[D]+this.y*t[_]+this.z*t[q]+t[V],this.x*t[G]+this.y*t[N]+this.z*t[H]+t[U],this.x*t[j]+this.y*t[Z]+this.z*t[z]+t[W])}project(e){let t=e.values,i=1/(this.x*t[J]+this.y*t[Q]+this.z*t[$]+t[K]);return this.set((this.x*t[D]+this.y*t[_]+this.z*t[q]+t[V])*i,(this.x*t[G]+this.y*t[N]+this.z*t[H]+t[U])*i,(this.x*t[j]+this.y*t[Z]+this.z*t[z]+t[W])*i)}dot(e){return this.x*e.x+this.y*e.y+this.z*e.z}length(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z)}distance(e){let t=e.x-this.x,i=e.y-this.y,s=e.z-this.z;return Math.sqrt(t*t+i*i+s*s)}},D=0,_=4,q=8,V=12,G=1,N=5,H=9,U=13,j=2,Z=6,z=10,W=14,J=3,Q=7,$=11,K=15,Pe=class{constructor(){this.temp=new Float32Array(16),this.values=new Float32Array(16);let e=this.values;e[D]=1,e[N]=1,e[z]=1,e[K]=1}set(e){return this.values.set(e),this}transpose(){let e=this.temp,t=this.values;return e[D]=t[D],e[_]=t[G],e[q]=t[j],e[V]=t[J],e[G]=t[_],e[N]=t[N],e[H]=t[Z],e[U]=t[Q],e[j]=t[q],e[Z]=t[H],e[z]=t[z],e[W]=t[$],e[J]=t[V],e[Q]=t[U],e[$]=t[W],e[K]=t[K],this.set(e)}identity(){let e=this.values;return e[D]=1,e[_]=0,e[q]=0,e[V]=0,e[G]=0,e[N]=1,e[H]=0,e[U]=0,e[j]=0,e[Z]=0,e[z]=1,e[W]=0,e[J]=0,e[Q]=0,e[$]=0,e[K]=1,this}invert(){let e=this.values,t=this.temp,i=e[J]*e[Z]*e[H]*e[V]-e[j]*e[Q]*e[H]*e[V]-e[J]*e[N]*e[z]*e[V]+e[G]*e[Q]*e[z]*e[V]+e[j]*e[N]*e[$]*e[V]-e[G]*e[Z]*e[$]*e[V]-e[J]*e[Z]*e[q]*e[U]+e[j]*e[Q]*e[q]*e[U]+e[J]*e[_]*e[z]*e[U]-e[D]*e[Q]*e[z]*e[U]-e[j]*e[_]*e[$]*e[U]+e[D]*e[Z]*e[$]*e[U]+e[J]*e[N]*e[q]*e[W]-e[G]*e[Q]*e[q]*e[W]-e[J]*e[_]*e[H]*e[W]+e[D]*e[Q]*e[H]*e[W]+e[G]*e[_]*e[$]*e[W]-e[D]*e[N]*e[$]*e[W]-e[j]*e[N]*e[q]*e[K]+e[G]*e[Z]*e[q]*e[K]+e[j]*e[_]*e[H]*e[K]-e[D]*e[Z]*e[H]*e[K]-e[G]*e[_]*e[z]*e[K]+e[D]*e[N]*e[z]*e[K];if(i==0)throw new Error("non-invertible matrix");let s=1/i;return t[D]=e[H]*e[W]*e[Q]-e[U]*e[z]*e[Q]+e[U]*e[Z]*e[$]-e[N]*e[W]*e[$]-e[H]*e[Z]*e[K]+e[N]*e[z]*e[K],t[_]=e[V]*e[z]*e[Q]-e[q]*e[W]*e[Q]-e[V]*e[Z]*e[$]+e[_]*e[W]*e[$]+e[q]*e[Z]*e[K]-e[_]*e[z]*e[K],t[q]=e[q]*e[U]*e[Q]-e[V]*e[H]*e[Q]+e[V]*e[N]*e[$]-e[_]*e[U]*e[$]-e[q]*e[N]*e[K]+e[_]*e[H]*e[K],t[V]=e[V]*e[H]*e[Z]-e[q]*e[U]*e[Z]-e[V]*e[N]*e[z]+e[_]*e[U]*e[z]+e[q]*e[N]*e[W]-e[_]*e[H]*e[W],t[G]=e[U]*e[z]*e[J]-e[H]*e[W]*e[J]-e[U]*e[j]*e[$]+e[G]*e[W]*e[$]+e[H]*e[j]*e[K]-e[G]*e[z]*e[K],t[N]=e[q]*e[W]*e[J]-e[V]*e[z]*e[J]+e[V]*e[j]*e[$]-e[D]*e[W]*e[$]-e[q]*e[j]*e[K]+e[D]*e[z]*e[K],t[H]=e[V]*e[H]*e[J]-e[q]*e[U]*e[J]-e[V]*e[G]*e[$]+e[D]*e[U]*e[$]+e[q]*e[G]*e[K]-e[D]*e[H]*e[K],t[U]=e[q]*e[U]*e[j]-e[V]*e[H]*e[j]+e[V]*e[G]*e[z]-e[D]*e[U]*e[z]-e[q]*e[G]*e[W]+e[D]*e[H]*e[W],t[j]=e[N]*e[W]*e[J]-e[U]*e[Z]*e[J]+e[U]*e[j]*e[Q]-e[G]*e[W]*e[Q]-e[N]*e[j]*e[K]+e[G]*e[Z]*e[K],t[Z]=e[V]*e[Z]*e[J]-e[_]*e[W]*e[J]-e[V]*e[j]*e[Q]+e[D]*e[W]*e[Q]+e[_]*e[j]*e[K]-e[D]*e[Z]*e[K],t[z]=e[_]*e[U]*e[J]-e[V]*e[N]*e[J]+e[V]*e[G]*e[Q]-e[D]*e[U]*e[Q]-e[_]*e[G]*e[K]+e[D]*e[N]*e[K],t[W]=e[V]*e[N]*e[j]-e[_]*e[U]*e[j]-e[V]*e[G]*e[Z]+e[D]*e[U]*e[Z]+e[_]*e[G]*e[W]-e[D]*e[N]*e[W],t[J]=e[H]*e[Z]*e[J]-e[N]*e[z]*e[J]-e[H]*e[j]*e[Q]+e[G]*e[z]*e[Q]+e[N]*e[j]*e[$]-e[G]*e[Z]*e[$],t[Q]=e[_]*e[z]*e[J]-e[q]*e[Z]*e[J]+e[q]*e[j]*e[Q]-e[D]*e[z]*e[Q]-e[_]*e[j]*e[$]+e[D]*e[Z]*e[$],t[$]=e[q]*e[N]*e[J]-e[_]*e[H]*e[J]-e[q]*e[G]*e[Q]+e[D]*e[H]*e[Q]+e[_]*e[G]*e[$]-e[D]*e[N]*e[$],t[K]=e[_]*e[H]*e[j]-e[q]*e[N]*e[j]+e[q]*e[G]*e[Z]-e[D]*e[H]*e[Z]-e[_]*e[G]*e[z]+e[D]*e[N]*e[z],e[D]=t[D]*s,e[_]=t[_]*s,e[q]=t[q]*s,e[V]=t[V]*s,e[G]=t[G]*s,e[N]=t[N]*s,e[H]=t[H]*s,e[U]=t[U]*s,e[j]=t[j]*s,e[Z]=t[Z]*s,e[z]=t[z]*s,e[W]=t[W]*s,e[J]=t[J]*s,e[Q]=t[Q]*s,e[$]=t[$]*s,e[K]=t[K]*s,this}determinant(){let e=this.values;return e[J]*e[Z]*e[H]*e[V]-e[j]*e[Q]*e[H]*e[V]-e[J]*e[N]*e[z]*e[V]+e[G]*e[Q]*e[z]*e[V]+e[j]*e[N]*e[$]*e[V]-e[G]*e[Z]*e[$]*e[V]-e[J]*e[Z]*e[q]*e[U]+e[j]*e[Q]*e[q]*e[U]+e[J]*e[_]*e[z]*e[U]-e[D]*e[Q]*e[z]*e[U]-e[j]*e[_]*e[$]*e[U]+e[D]*e[Z]*e[$]*e[U]+e[J]*e[N]*e[q]*e[W]-e[G]*e[Q]*e[q]*e[W]-e[J]*e[_]*e[H]*e[W]+e[D]*e[Q]*e[H]*e[W]+e[G]*e[_]*e[$]*e[W]-e[D]*e[N]*e[$]*e[W]-e[j]*e[N]*e[q]*e[K]+e[G]*e[Z]*e[q]*e[K]+e[j]*e[_]*e[H]*e[K]-e[D]*e[Z]*e[H]*e[K]-e[G]*e[_]*e[z]*e[K]+e[D]*e[N]*e[z]*e[K]}translate(e,t,i){let s=this.values;return s[V]+=e,s[U]+=t,s[W]+=i,this}copy(){return new Pe().set(this.values)}projection(e,t,i,s){this.identity();let n=1/Math.tan(i*(Math.PI/180)/2),c=(t+e)/(e-t),a=2*t*e/(e-t),r=this.values;return r[D]=n/s,r[G]=0,r[j]=0,r[J]=0,r[_]=0,r[N]=n,r[Z]=0,r[Q]=0,r[q]=0,r[H]=0,r[z]=c,r[$]=-1,r[V]=0,r[U]=0,r[W]=a,r[K]=0,this}ortho2d(e,t,i,s){return this.ortho(e,e+i,t,t+s,0,1)}ortho(e,t,i,s,n,c){this.identity();let a=2/(t-e),r=2/(s-i),o=-2/(c-n),l=-(t+e)/(t-e),h=-(s+i)/(s-i),f=-(c+n)/(c-n),d=this.values;return d[D]=a,d[G]=0,d[j]=0,d[J]=0,d[_]=0,d[N]=r,d[Z]=0,d[Q]=0,d[q]=0,d[H]=0,d[z]=o,d[$]=0,d[V]=l,d[U]=h,d[W]=f,d[K]=1,this}multiply(e){let t=this.temp,i=this.values,s=e.values;return t[D]=i[D]*s[D]+i[_]*s[G]+i[q]*s[j]+i[V]*s[J],t[_]=i[D]*s[_]+i[_]*s[N]+i[q]*s[Z]+i[V]*s[Q],t[q]=i[D]*s[q]+i[_]*s[H]+i[q]*s[z]+i[V]*s[$],t[V]=i[D]*s[V]+i[_]*s[U]+i[q]*s[W]+i[V]*s[K],t[G]=i[G]*s[D]+i[N]*s[G]+i[H]*s[j]+i[U]*s[J],t[N]=i[G]*s[_]+i[N]*s[N]+i[H]*s[Z]+i[U]*s[Q],t[H]=i[G]*s[q]+i[N]*s[H]+i[H]*s[z]+i[U]*s[$],t[U]=i[G]*s[V]+i[N]*s[U]+i[H]*s[W]+i[U]*s[K],t[j]=i[j]*s[D]+i[Z]*s[G]+i[z]*s[j]+i[W]*s[J],t[Z]=i[j]*s[_]+i[Z]*s[N]+i[z]*s[Z]+i[W]*s[Q],t[z]=i[j]*s[q]+i[Z]*s[H]+i[z]*s[z]+i[W]*s[$],t[W]=i[j]*s[V]+i[Z]*s[U]+i[z]*s[W]+i[W]*s[K],t[J]=i[J]*s[D]+i[Q]*s[G]+i[$]*s[j]+i[K]*s[J],t[Q]=i[J]*s[_]+i[Q]*s[N]+i[$]*s[Z]+i[K]*s[Q],t[$]=i[J]*s[q]+i[Q]*s[H]+i[$]*s[z]+i[K]*s[$],t[K]=i[J]*s[V]+i[Q]*s[U]+i[$]*s[W]+i[K]*s[K],this.set(this.temp)}multiplyLeft(e){let t=this.temp,i=this.values,s=e.values;return t[D]=s[D]*i[D]+s[_]*i[G]+s[q]*i[j]+s[V]*i[J],t[_]=s[D]*i[_]+s[_]*i[N]+s[q]*i[Z]+s[V]*i[Q],t[q]=s[D]*i[q]+s[_]*i[H]+s[q]*i[z]+s[V]*i[$],t[V]=s[D]*i[V]+s[_]*i[U]+s[q]*i[W]+s[V]*i[K],t[G]=s[G]*i[D]+s[N]*i[G]+s[H]*i[j]+s[U]*i[J],t[N]=s[G]*i[_]+s[N]*i[N]+s[H]*i[Z]+s[U]*i[Q],t[H]=s[G]*i[q]+s[N]*i[H]+s[H]*i[z]+s[U]*i[$],t[U]=s[G]*i[V]+s[N]*i[U]+s[H]*i[W]+s[U]*i[K],t[j]=s[j]*i[D]+s[Z]*i[G]+s[z]*i[j]+s[W]*i[J],t[Z]=s[j]*i[_]+s[Z]*i[N]+s[z]*i[Z]+s[W]*i[Q],t[z]=s[j]*i[q]+s[Z]*i[H]+s[z]*i[z]+s[W]*i[$],t[W]=s[j]*i[V]+s[Z]*i[U]+s[z]*i[W]+s[W]*i[K],t[J]=s[J]*i[D]+s[Q]*i[G]+s[$]*i[j]+s[K]*i[J],t[Q]=s[J]*i[_]+s[Q]*i[N]+s[$]*i[Z]+s[K]*i[Q],t[$]=s[J]*i[q]+s[Q]*i[H]+s[$]*i[z]+s[K]*i[$],t[K]=s[J]*i[V]+s[Q]*i[U]+s[$]*i[W]+s[K]*i[K],this.set(this.temp)}lookAt(e,t,i){let s=Pe.xAxis,n=Pe.yAxis,c=Pe.zAxis;c.setFrom(t).normalize(),s.setFrom(t).normalize(),s.cross(i).normalize(),n.setFrom(s).cross(c).normalize(),this.identity();let a=this.values;return a[D]=s.x,a[_]=s.y,a[q]=s.z,a[G]=n.x,a[N]=n.y,a[H]=n.z,a[j]=-c.x,a[Z]=-c.y,a[z]=-c.z,Pe.tmpMatrix.identity(),Pe.tmpMatrix.values[V]=-e.x,Pe.tmpMatrix.values[U]=-e.y,Pe.tmpMatrix.values[W]=-e.z,this.multiply(Pe.tmpMatrix),this}},_e=Pe;_e.xAxis=new Ie,_e.yAxis=new Ie,_e.zAxis=new Ie,_e.tmpMatrix=new Pe;var cs=class{constructor(e,t){this.position=new Ie(0,0,0),this.direction=new Ie(0,0,-1),this.up=new Ie(0,1,0),this.near=0,this.far=100,this.zoom=1,this.viewportWidth=0,this.viewportHeight=0,this.projectionView=new _e,this.inverseProjectionView=new _e,this.projection=new _e,this.view=new _e,this.viewportWidth=e,this.viewportHeight=t,this.update()}update(){let e=this.projection,t=this.view,i=this.projectionView,s=this.inverseProjectionView,n=this.zoom,c=this.viewportWidth,a=this.viewportHeight;e.ortho(n*(-c/2),n*(c/2),n*(-a/2),n*(a/2),this.near,this.far),t.lookAt(this.position,this.direction,this.up),i.set(e.values),i.multiply(t),s.set(i.values).invert()}screenToWorld(e,t,i){let s=e.x,n=i-e.y-1;return e.x=2*s/t-1,e.y=2*n/i-1,e.z=2*e.z-1,e.project(this.inverseProjectionView),e}worldToScreen(e,t,i){return e.project(this.projectionView),e.x=t*(e.x+1)/2,e.y=i*(e.y+1)/2,e.z=(e.z+1)/2,e}setViewport(e,t){this.viewportWidth=e,this.viewportHeight=t}},ki=class{constructor(e){this.mouseX=0,this.mouseY=0,this.buttonDown=!1,this.touch0=null,this.touch1=null,this.initialPinchDistance=0,this.listeners=new Array,this.eventListeners=[],this.element=e,this.setupCallbacks(e)}setupCallbacks(e){let t=a=>{if(a instanceof MouseEvent){let r=e.getBoundingClientRect();this.mouseX=a.clientX-r.left,this.mouseY=a.clientY-r.top,this.buttonDown=!0,this.listeners.map(o=>{o.down&&o.down(this.mouseX,this.mouseY)}),document.addEventListener("mousemove",i),document.addEventListener("mouseup",s)}},i=a=>{if(a instanceof MouseEvent){let r=e.getBoundingClientRect();this.mouseX=a.clientX-r.left,this.mouseY=a.clientY-r.top,this.listeners.map(o=>{this.buttonDown?o.dragged&&o.dragged(this.mouseX,this.mouseY):o.moved&&o.moved(this.mouseX,this.mouseY)})}},s=a=>{if(a instanceof MouseEvent){let r=e.getBoundingClientRect();this.mouseX=a.clientX-r.left,this.mouseY=a.clientY-r.top,this.buttonDown=!1,this.listeners.map(o=>{o.up&&o.up(this.mouseX,this.mouseY)}),document.removeEventListener("mousemove",i),document.removeEventListener("mouseup",s)}},n=a=>{a.preventDefault();let r=a.deltaY;a.deltaMode==WheelEvent.DOM_DELTA_LINE&&(r*=8),a.deltaMode==WheelEvent.DOM_DELTA_PAGE&&(r*=24),this.listeners.map(o=>{o.wheel&&o.wheel(a.deltaY)})};e.addEventListener("mousedown",t,!0),e.addEventListener("mousemove",i,!0),e.addEventListener("mouseup",s,!0),e.addEventListener("wheel",n,!0),e.addEventListener("touchstart",a=>{if(!this.touch0||!this.touch1){var r=a.changedTouches;let o=r.item(0);if(!o)return;let l=e.getBoundingClientRect(),h=o.clientX-l.left,f=o.clientY-l.top,d=new ds(o.identifier,h,f);if(this.mouseX=h,this.mouseY=f,this.buttonDown=!0,!this.touch0)this.touch0=d,this.listeners.map(u=>{u.down&&u.down(d.x,d.y)});else if(!this.touch1){this.touch1=d;let u=this.touch1.x-this.touch0.x,m=this.touch1.x-this.touch0.x;this.initialPinchDistance=Math.sqrt(u*u+m*m),this.listeners.map(x=>{x.zoom&&x.zoom(this.initialPinchDistance,this.initialPinchDistance)})}}a.preventDefault()},!1),e.addEventListener("touchmove",a=>{if(this.touch0){var r=a.changedTouches;let h=e.getBoundingClientRect();for(var o=0;o<r.length;o++){var l=r[o];let f=l.clientX-h.left,d=l.clientY-h.top;this.touch0.identifier===l.identifier&&(this.touch0.x=this.mouseX=f,this.touch0.y=this.mouseY=d,this.listeners.map(u=>{u.dragged&&u.dragged(f,d)})),this.touch1&&this.touch1.identifier===l.identifier&&(this.touch1.x=this.mouseX=f,this.touch1.y=this.mouseY=d)}if(this.touch0&&this.touch1){let f=this.touch1.x-this.touch0.x,d=this.touch1.x-this.touch0.x,u=Math.sqrt(f*f+d*d);this.listeners.map(m=>{m.zoom&&m.zoom(this.initialPinchDistance,u)})}}a.preventDefault()},!1);let c=a=>{if(this.touch0){var r=a.changedTouches;let h=e.getBoundingClientRect();for(var o=0;o<r.length;o++){var l=r[o];let f=l.clientX-h.left,d=l.clientY-h.top;if(this.touch0.identifier===l.identifier)if(this.touch0=null,this.mouseX=f,this.mouseY=d,this.listeners.map(u=>{u.up&&u.up(f,d)}),this.touch1)this.touch0=this.touch1,this.touch1=null,this.mouseX=this.touch0.x,this.mouseX=this.touch0.x,this.buttonDown=!0,this.listeners.map(u=>{u.down&&u.down(this.touch0.x,this.touch0.y)});else{this.buttonDown=!1;break}this.touch1&&this.touch1.identifier&&(this.touch1=null)}}a.preventDefault()};e.addEventListener("touchend",c,!1),e.addEventListener("touchcancel",c)}addListener(e){this.listeners.push(e)}removeListener(e){let t=this.listeners.indexOf(e);t>-1&&this.listeners.splice(t,1)}},ds=class{constructor(e,t,i){this.identifier=e,this.x=t,this.y=i}},hr=class{constructor(e,t){this.canvas=e,this.camera=t;let i=0,s=0,n=0,c=0,a=0,r=0,o=0,l=0;new ki(e).addListener({down:(h,f)=>{i=t.position.x,s=t.position.y,c=r=h,a=o=f,l=t.zoom},dragged:(h,f)=>{let d=h-c,u=f-a,m=t.screenToWorld(new Ie(0,0),e.clientWidth,e.clientHeight),x=t.screenToWorld(new Ie(d,u),e.clientWidth,e.clientHeight).sub(m);t.position.set(i-x.x,s-x.y,0),t.update(),r=h,o=f},wheel:h=>{let f=h/200*t.zoom,d=t.zoom+f;if(d>0){let u=0,m=0;if(h<0)u=r,m=o;else{let v=new Ie(e.clientWidth/2+15,e.clientHeight/2),g=r-v.x,w=e.clientHeight-1-o-v.y;u=v.x-g,m=e.clientHeight-1-v.y+w}let x=t.screenToWorld(new Ie(u,m),e.clientWidth,e.clientHeight);t.zoom=d,t.update();let b=t.screenToWorld(new Ie(u,m),e.clientWidth,e.clientHeight);t.position.add(x.sub(b)),t.update()}},zoom:(h,f)=>{let d=h/f;t.zoom=l*d},up:(h,f)=>{r=h,o=f},moved:(h,f)=>{r=h,o=f}})}},fe=class{constructor(e,t,i){this.vertexShader=t,this.fragmentShader=i,this.vs=null,this.fs=null,this.program=null,this.tmp2x2=new Float32Array(2*2),this.tmp3x3=new Float32Array(3*3),this.tmp4x4=new Float32Array(4*4),this.vsSource=t,this.fsSource=i,this.context=e instanceof ye?e:new ye(e),this.context.addRestorable(this),this.compile()}getProgram(){return this.program}getVertexShader(){return this.vertexShader}getFragmentShader(){return this.fragmentShader}getVertexShaderSource(){return this.vsSource}getFragmentSource(){return this.fsSource}compile(){let e=this.context.gl;try{if(this.vs=this.compileShader(e.VERTEX_SHADER,this.vertexShader),!this.vs)throw new Error("Couldn't compile vertex shader.");if(this.fs=this.compileShader(e.FRAGMENT_SHADER,this.fragmentShader),!this.fs)throw new Error("Couldn#t compile fragment shader.");this.program=this.compileProgram(this.vs,this.fs)}catch(t){throw this.dispose(),t}}compileShader(e,t){let i=this.context.gl,s=i.createShader(e);if(!s)throw new Error("Couldn't create shader.");if(i.shaderSource(s,t),i.compileShader(s),!i.getShaderParameter(s,i.COMPILE_STATUS)){let n="Couldn't compile shader: "+i.getShaderInfoLog(s);if(i.deleteShader(s),!i.isContextLost())throw new Error(n)}return s}compileProgram(e,t){let i=this.context.gl,s=i.createProgram();if(!s)throw new Error("Couldn't compile program.");if(i.attachShader(s,e),i.attachShader(s,t),i.linkProgram(s),!i.getProgramParameter(s,i.LINK_STATUS)){let n="Couldn't compile shader program: "+i.getProgramInfoLog(s);if(i.deleteProgram(s),!i.isContextLost())throw new Error(n)}return s}restore(){this.compile()}bind(){this.context.gl.useProgram(this.program)}unbind(){this.context.gl.useProgram(null)}setUniformi(e,t){this.context.gl.uniform1i(this.getUniformLocation(e),t)}setUniformf(e,t){this.context.gl.uniform1f(this.getUniformLocation(e),t)}setUniform2f(e,t,i){this.context.gl.uniform2f(this.getUniformLocation(e),t,i)}setUniform3f(e,t,i,s){this.context.gl.uniform3f(this.getUniformLocation(e),t,i,s)}setUniform4f(e,t,i,s,n){this.context.gl.uniform4f(this.getUniformLocation(e),t,i,s,n)}setUniform2x2f(e,t){let i=this.context.gl;this.tmp2x2.set(t),i.uniformMatrix2fv(this.getUniformLocation(e),!1,this.tmp2x2)}setUniform3x3f(e,t){let i=this.context.gl;this.tmp3x3.set(t),i.uniformMatrix3fv(this.getUniformLocation(e),!1,this.tmp3x3)}setUniform4x4f(e,t){let i=this.context.gl;this.tmp4x4.set(t),i.uniformMatrix4fv(this.getUniformLocation(e),!1,this.tmp4x4)}getUniformLocation(e){let t=this.context.gl;if(!this.program)throw new Error("Shader not compiled.");let i=t.getUniformLocation(this.program,e);if(!i&&!t.isContextLost())throw new Error(`Couldn't find location for uniform ${e}`);return i}getAttributeLocation(e){let t=this.context.gl;if(!this.program)throw new Error("Shader not compiled.");let i=t.getAttribLocation(this.program,e);if(i==-1&&!t.isContextLost())throw new Error(`Couldn't find location for attribute ${e}`);return i}dispose(){this.context.removeRestorable(this);let e=this.context.gl;this.vs&&(e.deleteShader(this.vs),this.vs=null),this.fs&&(e.deleteShader(this.fs),this.fs=null),this.program&&(e.deleteProgram(this.program),this.program=null)}static newColoredTextured(e){let t=`
|
|
1
|
+
var spine=(()=>{var Vi=Object.defineProperty,Ss=e=>Vi(e,"__esModule",{value:!0}),Cs=(e,t)=>{Ss(e);for(var i in t)Vi(e,i,{get:t[i],enumerable:!0})},Ni={};Cs(Ni,{AlphaTimeline:()=>ti,Animation:()=>yt,AnimationState:()=>Hi,AnimationStateAdapter:()=>Es,AnimationStateData:()=>ks,AssetManager:()=>hs,AssetManagerBase:()=>is,AtlasAttachmentLoader:()=>Xs,Attachment:()=>zt,AttachmentTimeline:()=>Qe,BinaryInput:()=>as,BlendMode:()=>pe,Bone:()=>wi,BoneData:()=>xi,BoundingBoxAttachment:()=>It,CURRENT:()=>Ji,CameraController:()=>hr,ClippingAttachment:()=>xt,Color:()=>O,Color2Attribute:()=>fs,ColorAttribute:()=>Lt,ConstraintData:()=>Mt,CurveTimeline:()=>ke,CurveTimeline1:()=>Re,CurveTimeline2:()=>At,DebugUtils:()=>Ms,DeformTimeline:()=>ri,Downloader:()=>pi,DrawOrderTimeline:()=>$e,Event:()=>bi,EventData:()=>vi,EventQueue:()=>Zi,EventTimeline:()=>gt,EventType:()=>Ce,FIRST:()=>ci,FakeTexture:()=>Rs,GLTexture:()=>wt,HOLD_FIRST:()=>Tt,HOLD_MIX:()=>Ki,HOLD_SUBSEQUENT:()=>di,IkConstraint:()=>ss,IkConstraintData:()=>yi,IkConstraintTimeline:()=>ni,Input:()=>Ei,IntSet:()=>Ts,Interpolation:()=>Ui,LoadingScreen:()=>ur,M00:()=>D,M01:()=>_,M02:()=>q,M03:()=>V,M10:()=>G,M11:()=>N,M12:()=>H,M13:()=>U,M20:()=>j,M21:()=>Z,M22:()=>z,M23:()=>W,M30:()=>J,M31:()=>Q,M32:()=>$,M33:()=>K,ManagedWebGLRenderingContext:()=>ye,MathUtils:()=>R,Matrix4:()=>_e,Mesh:()=>ki,MeshAttachment:()=>Ge,MixBlend:()=>ue,MixDirection:()=>Ne,OrthoCamera:()=>cs,PathAttachment:()=>tt,PathConstraint:()=>nt,PathConstraintData:()=>Ai,PathConstraintMixTimeline:()=>hi,PathConstraintPositionTimeline:()=>li,PathConstraintSpacingTimeline:()=>oi,PointAttachment:()=>gi,PolygonBatcher:()=>Fi,Pool:()=>ut,Position2Attribute:()=>Xt,Position3Attribute:()=>cr,PositionMode:()=>Fe,Pow:()=>zi,PowOut:()=>Is,RGB2Timeline:()=>si,RGBA2Timeline:()=>ii,RGBATimeline:()=>$t,RGBTimeline:()=>ei,RegionAttachment:()=>ne,ResizeMode:()=>ot,RotateMode:()=>He,RotateTimeline:()=>mt,SETUP:()=>fi,SUBSEQUENT:()=>Ct,ScaleTimeline:()=>Ht,ScaleXTimeline:()=>jt,ScaleYTimeline:()=>Zt,SceneRenderer:()=>ms,SequenceTimeline:()=>rt,Shader:()=>be,ShapeRenderer:()=>Xi,ShapeType:()=>Ae,ShearTimeline:()=>Kt,ShearXTimeline:()=>Jt,ShearYTimeline:()=>Qt,Skeleton:()=>Ls,SkeletonBinary:()=>Ps,SkeletonBounds:()=>ls,SkeletonClipping:()=>Et,SkeletonData:()=>Si,SkeletonDebugRenderer:()=>Pt,SkeletonJson:()=>nr,SkeletonRenderer:()=>Pi,Skin:()=>Yt,SkinEntry:()=>Ci,Slot:()=>rs,SlotData:()=>Ti,SpacingMode:()=>xe,SpineCanvas:()=>xr,StringSet:()=>Nt,TexCoordAttribute:()=>Ri,Texture:()=>ui,TextureAtlas:()=>$i,TextureAtlasPage:()=>es,TextureAtlasRegion:()=>mi,TextureFilter:()=>we,TextureRegion:()=>Qi,TextureWrap:()=>et,TimeKeeper:()=>Ut,Timeline:()=>me,Touch:()=>ds,TrackEntry:()=>ji,TransformConstraint:()=>ns,TransformConstraintData:()=>Ii,TransformConstraintTimeline:()=>ai,TransformMode:()=>ge,TranslateTimeline:()=>_t,TranslateXTimeline:()=>qt,TranslateYTimeline:()=>Gt,Triangulator:()=>Te,Utils:()=>B,Vector2:()=>Je,Vector3:()=>Ie,VertexAttachment:()=>Ee,VertexAttribute:()=>lt,VertexAttributeType:()=>je,WebGLBlendModeConverter:()=>Rt,WindowedMean:()=>Ys});var Ts=class{constructor(){this.array=new Array}add(e){let t=this.contains(e);return this.array[e|0]=e|0,!t}contains(e){return this.array[e|0]!=null}remove(e){this.array[e|0]=void 0}clear(){this.array.length=0}},Nt=class{constructor(){this.entries={},this.size=0}add(e){let t=this.entries[e];return this.entries[e]=!0,t?!1:(this.size++,!0)}addAll(e){let t=this.size;for(var i=0,s=e.length;i<s;i++)this.add(e[i]);return t!=this.size}contains(e){return this.entries[e]}clear(){this.entries={},this.size=0}},Ke=class{constructor(e=0,t=0,i=0,s=0){this.r=e,this.g=t,this.b=i,this.a=s}set(e,t,i,s){return this.r=e,this.g=t,this.b=i,this.a=s,this.clamp()}setFromColor(e){return this.r=e.r,this.g=e.g,this.b=e.b,this.a=e.a,this}setFromString(e){return e=e.charAt(0)=="#"?e.substr(1):e,this.r=parseInt(e.substr(0,2),16)/255,this.g=parseInt(e.substr(2,2),16)/255,this.b=parseInt(e.substr(4,2),16)/255,this.a=e.length!=8?1:parseInt(e.substr(6,2),16)/255,this}add(e,t,i,s){return this.r+=e,this.g+=t,this.b+=i,this.a+=s,this.clamp()}clamp(){return this.r<0?this.r=0:this.r>1&&(this.r=1),this.g<0?this.g=0:this.g>1&&(this.g=1),this.b<0?this.b=0:this.b>1&&(this.b=1),this.a<0?this.a=0:this.a>1&&(this.a=1),this}static rgba8888ToColor(e,t){e.r=((t&4278190080)>>>24)/255,e.g=((t&16711680)>>>16)/255,e.b=((t&65280)>>>8)/255,e.a=(t&255)/255}static rgb888ToColor(e,t){e.r=((t&16711680)>>>16)/255,e.g=((t&65280)>>>8)/255,e.b=(t&255)/255}static fromString(e){return new Ke().setFromString(e)}},O=Ke;O.WHITE=new Ke(1,1,1,1),O.RED=new Ke(1,0,0,1),O.GREEN=new Ke(0,1,0,1),O.BLUE=new Ke(0,0,1,1),O.MAGENTA=new Ke(1,0,1,1);var Ve=class{static clamp(e,t,i){return e<t?t:e>i?i:e}static cosDeg(e){return Math.cos(e*Ve.degRad)}static sinDeg(e){return Math.sin(e*Ve.degRad)}static signum(e){return e>0?1:e<0?-1:0}static toInt(e){return e>0?Math.floor(e):Math.ceil(e)}static cbrt(e){let t=Math.pow(Math.abs(e),1/3);return e<0?-t:t}static randomTriangular(e,t){return Ve.randomTriangularWith(e,t,(e+t)*.5)}static randomTriangularWith(e,t,i){let s=Math.random(),n=t-e;return s<=(i-e)/n?e+Math.sqrt(s*n*(i-e)):t-Math.sqrt((1-s)*n*(t-i))}static isPowerOfTwo(e){return e&&(e&e-1)==0}},R=Ve;R.PI=3.1415927,R.PI2=Ve.PI*2,R.radiansToDegrees=180/Ve.PI,R.radDeg=Ve.radiansToDegrees,R.degreesToRadians=Ve.PI/180,R.degRad=Ve.degreesToRadians;var Ui=class{apply(e,t,i){return e+(t-e)*this.applyInternal(i)}},zi=class extends Ui{constructor(e){super();this.power=2,this.power=e}applyInternal(e){return e<=.5?Math.pow(e*2,this.power)/2:Math.pow((e-1)*2,this.power)/(this.power%2==0?-2:2)+1}},Is=class extends zi{constructor(e){super(e)}applyInternal(e){return Math.pow(e-1,this.power)*(this.power%2==0?-1:1)+1}},st=class{static arrayCopy(e,t,i,s,n){for(let c=t,a=s;c<t+n;c++,a++)i[a]=e[c]}static arrayFill(e,t,i,s){for(let n=t;n<i;n++)e[n]=s}static setArraySize(e,t,i=0){let s=e.length;if(s==t)return e;if(e.length=t,s<t)for(let n=s;n<t;n++)e[n]=i;return e}static ensureArrayCapacity(e,t,i=0){return e.length>=t?e:st.setArraySize(e,t,i)}static newArray(e,t){let i=new Array(e);for(let s=0;s<e;s++)i[s]=t;return i}static newFloatArray(e){if(st.SUPPORTS_TYPED_ARRAYS)return new Float32Array(e);{let t=new Array(e);for(let i=0;i<t.length;i++)t[i]=0;return t}}static newShortArray(e){if(st.SUPPORTS_TYPED_ARRAYS)return new Int16Array(e);{let t=new Array(e);for(let i=0;i<t.length;i++)t[i]=0;return t}}static toFloatArray(e){return st.SUPPORTS_TYPED_ARRAYS?new Float32Array(e):e}static toSinglePrecision(e){return st.SUPPORTS_TYPED_ARRAYS?Math.fround(e):e}static webkit602BugfixHelper(e,t){}static contains(e,t,i=!0){for(var s=0;s<e.length;s++)if(e[s]==t)return!0;return!1}static enumValue(e,t){return e[t[0].toUpperCase()+t.slice(1)]}},B=st;B.SUPPORTS_TYPED_ARRAYS=typeof Float32Array!="undefined";var Ms=class{static logBones(e){for(let t=0;t<e.bones.length;t++){let i=e.bones[t];console.log(i.data.name+", "+i.a+", "+i.b+", "+i.c+", "+i.d+", "+i.worldX+", "+i.worldY)}}},ut=class{constructor(e){this.items=new Array,this.instantiator=e}obtain(){return this.items.length>0?this.items.pop():this.instantiator()}free(e){e.reset&&e.reset(),this.items.push(e)}freeAll(e){for(let t=0;t<e.length;t++)this.free(e[t])}clear(){this.items.length=0}},Je=class{constructor(e=0,t=0){this.x=e,this.y=t}set(e,t){return this.x=e,this.y=t,this}length(){let e=this.x,t=this.y;return Math.sqrt(e*e+t*t)}normalize(){let e=this.length();return e!=0&&(this.x/=e,this.y/=e),this}},Ut=class{constructor(){this.maxDelta=.064,this.framesPerSecond=0,this.delta=0,this.totalTime=0,this.lastTime=Date.now()/1e3,this.frameCount=0,this.frameTime=0}update(){let e=Date.now()/1e3;this.delta=e-this.lastTime,this.frameTime+=this.delta,this.totalTime+=this.delta,this.delta>this.maxDelta&&(this.delta=this.maxDelta),this.lastTime=e,this.frameCount++,this.frameTime>1&&(this.framesPerSecond=this.frameCount/this.frameTime,this.frameTime=0,this.frameCount=0)}},Ys=class{constructor(e=32){this.addedValues=0,this.lastValue=0,this.mean=0,this.dirty=!0,this.values=new Array(e)}hasEnoughData(){return this.addedValues>=this.values.length}addValue(e){this.addedValues<this.values.length&&this.addedValues++,this.values[this.lastValue++]=e,this.lastValue>this.values.length-1&&(this.lastValue=0),this.dirty=!0}getMean(){if(this.hasEnoughData()){if(this.dirty){let e=0;for(let t=0;t<this.values.length;t++)e+=this.values[t];this.mean=e/this.values.length,this.dirty=!1}return this.mean}return 0}},zt=class{constructor(e){if(!e)throw new Error("name cannot be null.");this.name=e}},Wi=class extends zt{constructor(e){super(e);this.id=Wi.nextID++,this.bones=null,this.vertices=[],this.worldVerticesLength=0,this.timelineAttachment=this}computeWorldVertices(e,t,i,s,n,c){i=n+(i>>1)*c;let a=e.bone.skeleton,r=e.deform,o=this.vertices,l=this.bones;if(!l){r.length>0&&(o=r);let u=e.bone,m=u.worldX,x=u.worldY,b=u.a,v=u.b,g=u.c,w=u.d;for(let p=t,y=n;y<i;p+=2,y+=c){let S=o[p],A=o[p+1];s[y]=S*b+A*v+m,s[y+1]=S*g+A*w+x}return}let h=0,f=0;for(let u=0;u<t;u+=2){let m=l[h];h+=m+1,f+=m}let d=a.bones;if(r.length==0)for(let u=n,m=f*3;u<i;u+=c){let x=0,b=0,v=l[h++];for(v+=h;h<v;h++,m+=3){let g=d[l[h]],w=o[m],p=o[m+1],y=o[m+2];x+=(w*g.a+p*g.b+g.worldX)*y,b+=(w*g.c+p*g.d+g.worldY)*y}s[u]=x,s[u+1]=b}else{let u=r;for(let m=n,x=f*3,b=f<<1;m<i;m+=c){let v=0,g=0,w=l[h++];for(w+=h;h<w;h++,x+=3,b+=2){let p=d[l[h]],y=o[x]+u[b],S=o[x+1]+u[b+1],A=o[x+2];v+=(y*p.a+S*p.b+p.worldX)*A,g+=(y*p.c+S*p.d+p.worldY)*A}s[m]=v,s[m+1]=g}}}copyTo(e){this.bones?(e.bones=new Array(this.bones.length),B.arrayCopy(this.bones,0,e.bones,0,this.bones.length)):e.bones=null,this.vertices&&(e.vertices=B.newFloatArray(this.vertices.length),B.arrayCopy(this.vertices,0,e.vertices,0,this.vertices.length)),e.worldVerticesLength=this.worldVerticesLength,e.timelineAttachment=this.timelineAttachment}},Ee=Wi;Ee.nextID=0;var vt=class{constructor(e){this.id=vt.nextID(),this.start=0,this.digits=0,this.setupIndex=0,this.regions=new Array(e)}copy(){let e=new vt(this.regions.length);return B.arrayCopy(this.regions,0,e.regions,0,this.regions.length),e.start=this.start,e.digits=this.digits,e.setupIndex=this.setupIndex,e}apply(e,t){let i=e.sequenceIndex;i==-1&&(i=this.setupIndex),i>=this.regions.length&&(i=this.regions.length-1);let s=this.regions[i];t.region!=s&&(t.region=s,t.updateRegion())}getPath(e,t){let i=e,s=(this.start+t).toString();for(let n=this.digits-s.length;n>0;n--)i+="0";return i+=s,i}static nextID(){return vt._nextID++}},Wt=vt;Wt._nextID=0;var Oe;(function(e){e[e.hold=0]="hold",e[e.once=1]="once",e[e.loop=2]="loop",e[e.pingpong=3]="pingpong",e[e.onceReverse=4]="onceReverse",e[e.loopReverse=5]="loopReverse",e[e.pingpongReverse=6]="pingpongReverse"})(Oe||(Oe={}));var _i=[0,1,2,3,4,5,6],yt=class{constructor(e,t,i){if(this.timelines=[],this.timelineIds=new Nt,!e)throw new Error("name cannot be null.");this.name=e,this.setTimelines(t),this.duration=i}setTimelines(e){if(!e)throw new Error("timelines cannot be null.");this.timelines=e,this.timelineIds.clear();for(var t=0;t<e.length;t++)this.timelineIds.addAll(e[t].getPropertyIds())}hasTimeline(e){for(let t=0;t<e.length;t++)if(this.timelineIds.contains(e[t]))return!0;return!1}apply(e,t,i,s,n,c,a,r){if(!e)throw new Error("skeleton cannot be null.");s&&this.duration!=0&&(i%=this.duration,t>0&&(t%=this.duration));let o=this.timelines;for(let l=0,h=o.length;l<h;l++)o[l].apply(e,t,i,n,c,a,r)}},ue;(function(e){e[e.setup=0]="setup",e[e.first=1]="first",e[e.replace=2]="replace",e[e.add=3]="add"})(ue||(ue={}));var Ne;(function(e){e[e.mixIn=0]="mixIn",e[e.mixOut=1]="mixOut"})(Ne||(Ne={}));var ce={rotate:0,x:1,y:2,scaleX:3,scaleY:4,shearX:5,shearY:6,rgb:7,alpha:8,rgb2:9,attachment:10,deform:11,event:12,drawOrder:13,ikConstraint:14,transformConstraint:15,pathConstraintPosition:16,pathConstraintSpacing:17,pathConstraintMix:18,sequence:19},me=class{constructor(e,t){this.propertyIds=t,this.frames=B.newFloatArray(e*this.getFrameEntries())}getPropertyIds(){return this.propertyIds}getFrameEntries(){return 1}getFrameCount(){return this.frames.length/this.getFrameEntries()}getDuration(){return this.frames[this.frames.length-this.getFrameEntries()]}static search1(e,t){let i=e.length;for(let s=1;s<i;s++)if(e[s]>t)return s-1;return i-1}static search(e,t,i){let s=e.length;for(let n=i;n<s;n+=i)if(e[n]>t)return n-i;return s-i}},ke=class extends me{constructor(e,t,i){super(e,i);this.curves=B.newFloatArray(e+t*18),this.curves[e-1]=1}setLinear(e){this.curves[e]=0}setStepped(e){this.curves[e]=1}shrink(e){let t=this.getFrameCount()+e*18;if(this.curves.length>t){let i=B.newFloatArray(t);B.arrayCopy(this.curves,0,i,0,t),this.curves=i}}setBezier(e,t,i,s,n,c,a,r,o,l,h){let f=this.curves,d=this.getFrameCount()+e*18;i==0&&(f[t]=2+d);let u=(s-c*2+r)*.03,m=(n-a*2+o)*.03,x=((c-r)*3-s+l)*.006,b=((a-o)*3-n+h)*.006,v=u*2+x,g=m*2+b,w=(c-s)*.3+u+x*.16666667,p=(a-n)*.3+m+b*.16666667,y=s+w,S=n+p;for(let A=d+18;d<A;d+=2)f[d]=y,f[d+1]=S,w+=v,p+=g,v+=x,g+=b,y+=w,S+=p}getBezierValue(e,t,i,s){let n=this.curves;if(n[s]>e){let o=this.frames[t],l=this.frames[t+i];return l+(e-o)/(n[s]-o)*(n[s+1]-l)}let c=s+18;for(s+=2;s<c;s+=2)if(n[s]>=e){let o=n[s-2],l=n[s-1];return l+(e-o)/(n[s]-o)*(n[s+1]-l)}t+=this.getFrameEntries();let a=n[c-2],r=n[c-1];return r+(e-a)/(this.frames[t]-a)*(this.frames[t+i]-r)}},Re=class extends ke{constructor(e,t,i){super(e,t,[i])}getFrameEntries(){return 2}setFrame(e,t,i){e<<=1,this.frames[e]=t,this.frames[e+1]=i}getCurveValue(e){let t=this.frames,i=t.length-2;for(let n=2;n<=i;n+=2)if(t[n]>e){i=n-2;break}let s=this.curves[i>>1];switch(s){case 0:let n=t[i],c=t[i+1];return c+(e-n)/(t[i+2]-n)*(t[i+2+1]-c);case 1:return t[i+1]}return this.getBezierValue(e,i,1,s-2)}},At=class extends ke{constructor(e,t,i,s){super(e,t,[i,s])}getFrameEntries(){return 3}setFrame(e,t,i,s){e*=3,this.frames[e]=t,this.frames[e+1]=i,this.frames[e+2]=s}},mt=class extends Re{constructor(e,t,i){super(e,t,ce.rotate+"|"+i);this.boneIndex=0,this.boneIndex=i}apply(e,t,i,s,n,c,a){let r=e.bones[this.boneIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(c){case 0:r.rotation=r.data.rotation;return;case 1:r.rotation+=(r.data.rotation-r.rotation)*n}return}let l=this.getCurveValue(i);switch(c){case 0:r.rotation=r.data.rotation+l*n;break;case 1:case 2:l+=r.data.rotation-r.rotation;case 3:r.rotation+=l*n}}},_t=class extends At{constructor(e,t,i){super(e,t,ce.x+"|"+i,ce.y+"|"+i);this.boneIndex=0,this.boneIndex=i}apply(e,t,i,s,n,c,a){let r=e.bones[this.boneIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(c){case 0:r.x=r.data.x,r.y=r.data.y;return;case 1:r.x+=(r.data.x-r.x)*n,r.y+=(r.data.y-r.y)*n}return}let l=0,h=0,f=me.search(o,i,3),d=this.curves[f/3];switch(d){case 0:let u=o[f];l=o[f+1],h=o[f+2];let m=(i-u)/(o[f+3]-u);l+=(o[f+3+1]-l)*m,h+=(o[f+3+2]-h)*m;break;case 1:l=o[f+1],h=o[f+2];break;default:l=this.getBezierValue(i,f,1,d-2),h=this.getBezierValue(i,f,2,d+18-2)}switch(c){case 0:r.x=r.data.x+l*n,r.y=r.data.y+h*n;break;case 1:case 2:r.x+=(r.data.x+l-r.x)*n,r.y+=(r.data.y+h-r.y)*n;break;case 3:r.x+=l*n,r.y+=h*n}}},qt=class extends Re{constructor(e,t,i){super(e,t,ce.x+"|"+i);this.boneIndex=0,this.boneIndex=i}apply(e,t,i,s,n,c,a){let r=e.bones[this.boneIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(c){case 0:r.x=r.data.x;return;case 1:r.x+=(r.data.x-r.x)*n}return}let l=this.getCurveValue(i);switch(c){case 0:r.x=r.data.x+l*n;break;case 1:case 2:r.x+=(r.data.x+l-r.x)*n;break;case 3:r.x+=l*n}}},Gt=class extends Re{constructor(e,t,i){super(e,t,ce.y+"|"+i);this.boneIndex=0,this.boneIndex=i}apply(e,t,i,s,n,c,a){let r=e.bones[this.boneIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(c){case 0:r.y=r.data.y;return;case 1:r.y+=(r.data.y-r.y)*n}return}let l=this.getCurveValue(i);switch(c){case 0:r.y=r.data.y+l*n;break;case 1:case 2:r.y+=(r.data.y+l-r.y)*n;break;case 3:r.y+=l*n}}},Ht=class extends At{constructor(e,t,i){super(e,t,ce.scaleX+"|"+i,ce.scaleY+"|"+i);this.boneIndex=0,this.boneIndex=i}apply(e,t,i,s,n,c,a){let r=e.bones[this.boneIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(c){case 0:r.scaleX=r.data.scaleX,r.scaleY=r.data.scaleY;return;case 1:r.scaleX+=(r.data.scaleX-r.scaleX)*n,r.scaleY+=(r.data.scaleY-r.scaleY)*n}return}let l,h,f=me.search(o,i,3),d=this.curves[f/3];switch(d){case 0:let u=o[f];l=o[f+1],h=o[f+2];let m=(i-u)/(o[f+3]-u);l+=(o[f+3+1]-l)*m,h+=(o[f+3+2]-h)*m;break;case 1:l=o[f+1],h=o[f+2];break;default:l=this.getBezierValue(i,f,1,d-2),h=this.getBezierValue(i,f,2,d+18-2)}if(l*=r.data.scaleX,h*=r.data.scaleY,n==1)c==3?(r.scaleX+=l-r.data.scaleX,r.scaleY+=h-r.data.scaleY):(r.scaleX=l,r.scaleY=h);else{let u=0,m=0;if(a==1)switch(c){case 0:u=r.data.scaleX,m=r.data.scaleY,r.scaleX=u+(Math.abs(l)*R.signum(u)-u)*n,r.scaleY=m+(Math.abs(h)*R.signum(m)-m)*n;break;case 1:case 2:u=r.scaleX,m=r.scaleY,r.scaleX=u+(Math.abs(l)*R.signum(u)-u)*n,r.scaleY=m+(Math.abs(h)*R.signum(m)-m)*n;break;case 3:r.scaleX+=(l-r.data.scaleX)*n,r.scaleY+=(h-r.data.scaleY)*n}else switch(c){case 0:u=Math.abs(r.data.scaleX)*R.signum(l),m=Math.abs(r.data.scaleY)*R.signum(h),r.scaleX=u+(l-u)*n,r.scaleY=m+(h-m)*n;break;case 1:case 2:u=Math.abs(r.scaleX)*R.signum(l),m=Math.abs(r.scaleY)*R.signum(h),r.scaleX=u+(l-u)*n,r.scaleY=m+(h-m)*n;break;case 3:r.scaleX+=(l-r.data.scaleX)*n,r.scaleY+=(h-r.data.scaleY)*n}}}},jt=class extends Re{constructor(e,t,i){super(e,t,ce.scaleX+"|"+i);this.boneIndex=0,this.boneIndex=i}apply(e,t,i,s,n,c,a){let r=e.bones[this.boneIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(c){case 0:r.scaleX=r.data.scaleX;return;case 1:r.scaleX+=(r.data.scaleX-r.scaleX)*n}return}let l=this.getCurveValue(i)*r.data.scaleX;if(n==1)c==3?r.scaleX+=l-r.data.scaleX:r.scaleX=l;else{let h=0;if(a==1)switch(c){case 0:h=r.data.scaleX,r.scaleX=h+(Math.abs(l)*R.signum(h)-h)*n;break;case 1:case 2:h=r.scaleX,r.scaleX=h+(Math.abs(l)*R.signum(h)-h)*n;break;case 3:r.scaleX+=(l-r.data.scaleX)*n}else switch(c){case 0:h=Math.abs(r.data.scaleX)*R.signum(l),r.scaleX=h+(l-h)*n;break;case 1:case 2:h=Math.abs(r.scaleX)*R.signum(l),r.scaleX=h+(l-h)*n;break;case 3:r.scaleX+=(l-r.data.scaleX)*n}}}},Zt=class extends Re{constructor(e,t,i){super(e,t,ce.scaleY+"|"+i);this.boneIndex=0,this.boneIndex=i}apply(e,t,i,s,n,c,a){let r=e.bones[this.boneIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(c){case 0:r.scaleY=r.data.scaleY;return;case 1:r.scaleY+=(r.data.scaleY-r.scaleY)*n}return}let l=this.getCurveValue(i)*r.data.scaleY;if(n==1)c==3?r.scaleY+=l-r.data.scaleY:r.scaleY=l;else{let h=0;if(a==1)switch(c){case 0:h=r.data.scaleY,r.scaleY=h+(Math.abs(l)*R.signum(h)-h)*n;break;case 1:case 2:h=r.scaleY,r.scaleY=h+(Math.abs(l)*R.signum(h)-h)*n;break;case 3:r.scaleY+=(l-r.data.scaleY)*n}else switch(c){case 0:h=Math.abs(r.data.scaleY)*R.signum(l),r.scaleY=h+(l-h)*n;break;case 1:case 2:h=Math.abs(r.scaleY)*R.signum(l),r.scaleY=h+(l-h)*n;break;case 3:r.scaleY+=(l-r.data.scaleY)*n}}}},Kt=class extends At{constructor(e,t,i){super(e,t,ce.shearX+"|"+i,ce.shearY+"|"+i);this.boneIndex=0,this.boneIndex=i}apply(e,t,i,s,n,c,a){let r=e.bones[this.boneIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(c){case 0:r.shearX=r.data.shearX,r.shearY=r.data.shearY;return;case 1:r.shearX+=(r.data.shearX-r.shearX)*n,r.shearY+=(r.data.shearY-r.shearY)*n}return}let l=0,h=0,f=me.search(o,i,3),d=this.curves[f/3];switch(d){case 0:let u=o[f];l=o[f+1],h=o[f+2];let m=(i-u)/(o[f+3]-u);l+=(o[f+3+1]-l)*m,h+=(o[f+3+2]-h)*m;break;case 1:l=o[f+1],h=o[f+2];break;default:l=this.getBezierValue(i,f,1,d-2),h=this.getBezierValue(i,f,2,d+18-2)}switch(c){case 0:r.shearX=r.data.shearX+l*n,r.shearY=r.data.shearY+h*n;break;case 1:case 2:r.shearX+=(r.data.shearX+l-r.shearX)*n,r.shearY+=(r.data.shearY+h-r.shearY)*n;break;case 3:r.shearX+=l*n,r.shearY+=h*n}}},Jt=class extends Re{constructor(e,t,i){super(e,t,ce.shearX+"|"+i);this.boneIndex=0,this.boneIndex=i}apply(e,t,i,s,n,c,a){let r=e.bones[this.boneIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(c){case 0:r.shearX=r.data.shearX;return;case 1:r.shearX+=(r.data.shearX-r.shearX)*n}return}let l=this.getCurveValue(i);switch(c){case 0:r.shearX=r.data.shearX+l*n;break;case 1:case 2:r.shearX+=(r.data.shearX+l-r.shearX)*n;break;case 3:r.shearX+=l*n}}},Qt=class extends Re{constructor(e,t,i){super(e,t,ce.shearY+"|"+i);this.boneIndex=0,this.boneIndex=i}apply(e,t,i,s,n,c,a){let r=e.bones[this.boneIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(c){case 0:r.shearY=r.data.shearY;return;case 1:r.shearY+=(r.data.shearY-r.shearY)*n}return}let l=this.getCurveValue(i);switch(c){case 0:r.shearY=r.data.shearY+l*n;break;case 1:case 2:r.shearY+=(r.data.shearY+l-r.shearY)*n;break;case 3:r.shearY+=l*n}}},$t=class extends ke{constructor(e,t,i){super(e,t,[ce.rgb+"|"+i,ce.alpha+"|"+i]);this.slotIndex=0,this.slotIndex=i}getFrameEntries(){return 5}setFrame(e,t,i,s,n,c){e*=5,this.frames[e]=t,this.frames[e+1]=i,this.frames[e+2]=s,this.frames[e+3]=n,this.frames[e+4]=c}apply(e,t,i,s,n,c,a){let r=e.slots[this.slotIndex];if(!r.bone.active)return;let o=this.frames,l=r.color;if(i<o[0]){let b=r.data.color;switch(c){case 0:l.setFromColor(b);return;case 1:l.add((b.r-l.r)*n,(b.g-l.g)*n,(b.b-l.b)*n,(b.a-l.a)*n)}return}let h=0,f=0,d=0,u=0,m=me.search(o,i,5),x=this.curves[m/5];switch(x){case 0:let b=o[m];h=o[m+1],f=o[m+2],d=o[m+3],u=o[m+4];let v=(i-b)/(o[m+5]-b);h+=(o[m+5+1]-h)*v,f+=(o[m+5+2]-f)*v,d+=(o[m+5+3]-d)*v,u+=(o[m+5+4]-u)*v;break;case 1:h=o[m+1],f=o[m+2],d=o[m+3],u=o[m+4];break;default:h=this.getBezierValue(i,m,1,x-2),f=this.getBezierValue(i,m,2,x+18-2),d=this.getBezierValue(i,m,3,x+18*2-2),u=this.getBezierValue(i,m,4,x+18*3-2)}n==1?l.set(h,f,d,u):(c==0&&l.setFromColor(r.data.color),l.add((h-l.r)*n,(f-l.g)*n,(d-l.b)*n,(u-l.a)*n))}},ei=class extends ke{constructor(e,t,i){super(e,t,[ce.rgb+"|"+i]);this.slotIndex=0,this.slotIndex=i}getFrameEntries(){return 4}setFrame(e,t,i,s,n){e<<=2,this.frames[e]=t,this.frames[e+1]=i,this.frames[e+2]=s,this.frames[e+3]=n}apply(e,t,i,s,n,c,a){let r=e.slots[this.slotIndex];if(!r.bone.active)return;let o=this.frames,l=r.color;if(i<o[0]){let x=r.data.color;switch(c){case 0:l.r=x.r,l.g=x.g,l.b=x.b;return;case 1:l.r+=(x.r-l.r)*n,l.g+=(x.g-l.g)*n,l.b+=(x.b-l.b)*n}return}let h=0,f=0,d=0,u=me.search(o,i,4),m=this.curves[u>>2];switch(m){case 0:let x=o[u];h=o[u+1],f=o[u+2],d=o[u+3];let b=(i-x)/(o[u+4]-x);h+=(o[u+4+1]-h)*b,f+=(o[u+4+2]-f)*b,d+=(o[u+4+3]-d)*b;break;case 1:h=o[u+1],f=o[u+2],d=o[u+3];break;default:h=this.getBezierValue(i,u,1,m-2),f=this.getBezierValue(i,u,2,m+18-2),d=this.getBezierValue(i,u,3,m+18*2-2)}if(n==1)l.r=h,l.g=f,l.b=d;else{if(c==0){let x=r.data.color;l.r=x.r,l.g=x.g,l.b=x.b}l.r+=(h-l.r)*n,l.g+=(f-l.g)*n,l.b+=(d-l.b)*n}}},ti=class extends Re{constructor(e,t,i){super(e,t,ce.alpha+"|"+i);this.slotIndex=0,this.slotIndex=i}apply(e,t,i,s,n,c,a){let r=e.slots[this.slotIndex];if(!r.bone.active)return;let o=r.color;if(i<this.frames[0]){let h=r.data.color;switch(c){case 0:o.a=h.a;return;case 1:o.a+=(h.a-o.a)*n}return}let l=this.getCurveValue(i);n==1?o.a=l:(c==0&&(o.a=r.data.color.a),o.a+=(l-o.a)*n)}},ii=class extends ke{constructor(e,t,i){super(e,t,[ce.rgb+"|"+i,ce.alpha+"|"+i,ce.rgb2+"|"+i]);this.slotIndex=0,this.slotIndex=i}getFrameEntries(){return 8}setFrame(e,t,i,s,n,c,a,r,o){e<<=3,this.frames[e]=t,this.frames[e+1]=i,this.frames[e+2]=s,this.frames[e+3]=n,this.frames[e+4]=c,this.frames[e+5]=a,this.frames[e+6]=r,this.frames[e+7]=o}apply(e,t,i,s,n,c,a){let r=e.slots[this.slotIndex];if(!r.bone.active)return;let o=this.frames,l=r.color,h=r.darkColor;if(i<o[0]){let p=r.data.color,y=r.data.darkColor;switch(c){case 0:l.setFromColor(p),h.r=y.r,h.g=y.g,h.b=y.b;return;case 1:l.add((p.r-l.r)*n,(p.g-l.g)*n,(p.b-l.b)*n,(p.a-l.a)*n),h.r+=(y.r-h.r)*n,h.g+=(y.g-h.g)*n,h.b+=(y.b-h.b)*n}return}let f=0,d=0,u=0,m=0,x=0,b=0,v=0,g=me.search(o,i,8),w=this.curves[g>>3];switch(w){case 0:let p=o[g];f=o[g+1],d=o[g+2],u=o[g+3],m=o[g+4],x=o[g+5],b=o[g+6],v=o[g+7];let y=(i-p)/(o[g+8]-p);f+=(o[g+8+1]-f)*y,d+=(o[g+8+2]-d)*y,u+=(o[g+8+3]-u)*y,m+=(o[g+8+4]-m)*y,x+=(o[g+8+5]-x)*y,b+=(o[g+8+6]-b)*y,v+=(o[g+8+7]-v)*y;break;case 1:f=o[g+1],d=o[g+2],u=o[g+3],m=o[g+4],x=o[g+5],b=o[g+6],v=o[g+7];break;default:f=this.getBezierValue(i,g,1,w-2),d=this.getBezierValue(i,g,2,w+18-2),u=this.getBezierValue(i,g,3,w+18*2-2),m=this.getBezierValue(i,g,4,w+18*3-2),x=this.getBezierValue(i,g,5,w+18*4-2),b=this.getBezierValue(i,g,6,w+18*5-2),v=this.getBezierValue(i,g,7,w+18*6-2)}if(n==1)l.set(f,d,u,m),h.r=x,h.g=b,h.b=v;else{if(c==0){l.setFromColor(r.data.color);let p=r.data.darkColor;h.r=p.r,h.g=p.g,h.b=p.b}l.add((f-l.r)*n,(d-l.g)*n,(u-l.b)*n,(m-l.a)*n),h.r+=(x-h.r)*n,h.g+=(b-h.g)*n,h.b+=(v-h.b)*n}}},si=class extends ke{constructor(e,t,i){super(e,t,[ce.rgb+"|"+i,ce.rgb2+"|"+i]);this.slotIndex=0,this.slotIndex=i}getFrameEntries(){return 7}setFrame(e,t,i,s,n,c,a,r){e*=7,this.frames[e]=t,this.frames[e+1]=i,this.frames[e+2]=s,this.frames[e+3]=n,this.frames[e+4]=c,this.frames[e+5]=a,this.frames[e+6]=r}apply(e,t,i,s,n,c,a){let r=e.slots[this.slotIndex];if(!r.bone.active)return;let o=this.frames,l=r.color,h=r.darkColor;if(i<o[0]){let p=r.data.color,y=r.data.darkColor;switch(c){case 0:l.r=p.r,l.g=p.g,l.b=p.b,h.r=y.r,h.g=y.g,h.b=y.b;return;case 1:l.r+=(p.r-l.r)*n,l.g+=(p.g-l.g)*n,l.b+=(p.b-l.b)*n,h.r+=(y.r-h.r)*n,h.g+=(y.g-h.g)*n,h.b+=(y.b-h.b)*n}return}let f=0,d=0,u=0,m=0,x=0,b=0,v=0,g=me.search(o,i,7),w=this.curves[g/7];switch(w){case 0:let p=o[g];f=o[g+1],d=o[g+2],u=o[g+3],x=o[g+4],b=o[g+5],v=o[g+6];let y=(i-p)/(o[g+7]-p);f+=(o[g+7+1]-f)*y,d+=(o[g+7+2]-d)*y,u+=(o[g+7+3]-u)*y,x+=(o[g+7+4]-x)*y,b+=(o[g+7+5]-b)*y,v+=(o[g+7+6]-v)*y;break;case 1:f=o[g+1],d=o[g+2],u=o[g+3],x=o[g+4],b=o[g+5],v=o[g+6];break;default:f=this.getBezierValue(i,g,1,w-2),d=this.getBezierValue(i,g,2,w+18-2),u=this.getBezierValue(i,g,3,w+18*2-2),x=this.getBezierValue(i,g,4,w+18*3-2),b=this.getBezierValue(i,g,5,w+18*4-2),v=this.getBezierValue(i,g,6,w+18*5-2)}if(n==1)l.r=f,l.g=d,l.b=u,h.r=x,h.g=b,h.b=v;else{if(c==0){let p=r.data.color,y=r.data.darkColor;l.r=p.r,l.g=p.g,l.b=p.b,h.r=y.r,h.g=y.g,h.b=y.b}l.r+=(f-l.r)*n,l.g+=(d-l.g)*n,l.b+=(u-l.b)*n,h.r+=(x-h.r)*n,h.g+=(b-h.g)*n,h.b+=(v-h.b)*n}}},Qe=class extends me{constructor(e,t){super(e,[ce.attachment+"|"+t]);this.slotIndex=0,this.slotIndex=t,this.attachmentNames=new Array(e)}getFrameCount(){return this.frames.length}setFrame(e,t,i){this.frames[e]=t,this.attachmentNames[e]=i}apply(e,t,i,s,n,c,a){let r=e.slots[this.slotIndex];if(!!r.bone.active){if(a==1){c==0&&this.setAttachment(e,r,r.data.attachmentName);return}if(i<this.frames[0]){(c==0||c==1)&&this.setAttachment(e,r,r.data.attachmentName);return}this.setAttachment(e,r,this.attachmentNames[me.search1(this.frames,i)])}}setAttachment(e,t,i){t.setAttachment(i?e.getAttachment(this.slotIndex,i):null)}},ri=class extends ke{constructor(e,t,i,s){super(e,t,[ce.deform+"|"+i+"|"+s.id]);this.slotIndex=0,this.slotIndex=i,this.attachment=s,this.vertices=new Array(e)}getFrameCount(){return this.frames.length}setFrame(e,t,i){this.frames[e]=t,this.vertices[e]=i}setBezier(e,t,i,s,n,c,a,r,o,l,h){let f=this.curves,d=this.getFrameCount()+e*18;i==0&&(f[t]=2+d);let u=(s-c*2+r)*.03,m=o*.03-a*.06,x=((c-r)*3-s+l)*.006,b=(a-o+.33333333)*.018,v=u*2+x,g=m*2+b,w=(c-s)*.3+u+x*.16666667,p=a*.3+m+b*.16666667,y=s+w,S=p;for(let A=d+18;d<A;d+=2)f[d]=y,f[d+1]=S,w+=v,p+=g,v+=x,g+=b,y+=w,S+=p}getCurvePercent(e,t){let i=this.curves,s=i[t];switch(s){case 0:let r=this.frames[t];return(e-r)/(this.frames[t+this.getFrameEntries()]-r);case 1:return 0}if(s-=2,i[s]>e){let r=this.frames[t];return i[s+1]*(e-r)/(i[s]-r)}let n=s+18;for(s+=2;s<n;s+=2)if(i[s]>=e){let r=i[s-2],o=i[s-1];return o+(e-r)/(i[s]-r)*(i[s+1]-o)}let c=i[n-2],a=i[n-1];return a+(1-a)*(e-c)/(this.frames[t+this.getFrameEntries()]-c)}apply(e,t,i,s,n,c,a){let r=e.slots[this.slotIndex];if(!r.bone.active)return;let o=r.getAttachment();if(!o||!(o instanceof Ee)||o.timelineAttachment!=this.attachment)return;let l=r.deform;l.length==0&&(c=0);let h=this.vertices,f=h[0].length,d=this.frames;if(i<d[0]){switch(c){case 0:l.length=0;return;case 1:if(n==1){l.length=0;return}l.length=f;let g=o;if(g.bones){n=1-n;for(var u=0;u<f;u++)l[u]*=n}else{let w=g.vertices;for(var u=0;u<f;u++)l[u]+=(w[u]-l[u])*n}}return}if(l.length=f,i>=d[d.length-1]){let g=h[d.length-1];if(n==1)if(c==3){let w=o;if(w.bones)for(let p=0;p<f;p++)l[p]+=g[p];else{let p=w.vertices;for(let y=0;y<f;y++)l[y]+=g[y]-p[y]}}else B.arrayCopy(g,0,l,0,f);else switch(c){case 0:{let p=o;if(p.bones)for(let y=0;y<f;y++)l[y]=g[y]*n;else{let y=p.vertices;for(let S=0;S<f;S++){let A=y[S];l[S]=A+(g[S]-A)*n}}break}case 1:case 2:for(let p=0;p<f;p++)l[p]+=(g[p]-l[p])*n;break;case 3:let w=o;if(w.bones)for(let p=0;p<f;p++)l[p]+=g[p]*n;else{let p=w.vertices;for(let y=0;y<f;y++)l[y]+=(g[y]-p[y])*n}}return}let m=me.search1(d,i),x=this.getCurvePercent(i,m),b=h[m],v=h[m+1];if(n==1)if(c==3){let g=o;if(g.bones)for(let w=0;w<f;w++){let p=b[w];l[w]+=p+(v[w]-p)*x}else{let w=g.vertices;for(let p=0;p<f;p++){let y=b[p];l[p]+=y+(v[p]-y)*x-w[p]}}}else for(let g=0;g<f;g++){let w=b[g];l[g]=w+(v[g]-w)*x}else switch(c){case 0:{let w=o;if(w.bones)for(let p=0;p<f;p++){let y=b[p];l[p]=(y+(v[p]-y)*x)*n}else{let p=w.vertices;for(let y=0;y<f;y++){let S=b[y],A=p[y];l[y]=A+(S+(v[y]-S)*x-A)*n}}break}case 1:case 2:for(let w=0;w<f;w++){let p=b[w];l[w]+=(p+(v[w]-p)*x-l[w])*n}break;case 3:let g=o;if(g.bones)for(let w=0;w<f;w++){let p=b[w];l[w]+=(p+(v[w]-p)*x)*n}else{let w=g.vertices;for(let p=0;p<f;p++){let y=b[p];l[p]+=(y+(v[p]-y)*x-w[p])*n}}}}},qi=class extends me{constructor(e){super(e,qi.propertyIds);this.events=new Array(e)}getFrameCount(){return this.frames.length}setFrame(e,t){this.frames[e]=t.time,this.events[e]=t}apply(e,t,i,s,n,c,a){if(!s)return;let r=this.frames,o=this.frames.length;if(t>i)this.apply(e,t,Number.MAX_VALUE,s,n,c,a),t=-1;else if(t>=r[o-1])return;if(i<r[0])return;let l=0;if(t<r[0])l=0;else{l=me.search1(r,t)+1;let h=r[l];for(;l>0&&r[l-1]==h;)l--}for(;l<o&&i>=r[l];l++)s.push(this.events[l])}},gt=qi;gt.propertyIds=[""+ce.event];var Gi=class extends me{constructor(e){super(e,Gi.propertyIds);this.drawOrders=new Array(e)}getFrameCount(){return this.frames.length}setFrame(e,t,i){this.frames[e]=t,this.drawOrders[e]=i}apply(e,t,i,s,n,c,a){if(a==1){c==0&&B.arrayCopy(e.slots,0,e.drawOrder,0,e.slots.length);return}if(i<this.frames[0]){(c==0||c==1)&&B.arrayCopy(e.slots,0,e.drawOrder,0,e.slots.length);return}let r=me.search1(this.frames,i),o=this.drawOrders[r];if(!o)B.arrayCopy(e.slots,0,e.drawOrder,0,e.slots.length);else{let l=e.drawOrder,h=e.slots;for(let f=0,d=o.length;f<d;f++)l[f]=h[o[f]]}}},$e=Gi;$e.propertyIds=[""+ce.drawOrder];var ni=class extends ke{constructor(e,t,i){super(e,t,[ce.ikConstraint+"|"+i]);this.ikConstraintIndex=0,this.ikConstraintIndex=i}getFrameEntries(){return 6}setFrame(e,t,i,s,n,c,a){e*=6,this.frames[e]=t,this.frames[e+1]=i,this.frames[e+2]=s,this.frames[e+3]=n,this.frames[e+4]=c?1:0,this.frames[e+5]=a?1:0}apply(e,t,i,s,n,c,a){let r=e.ikConstraints[this.ikConstraintIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(c){case 0:r.mix=r.data.mix,r.softness=r.data.softness,r.bendDirection=r.data.bendDirection,r.compress=r.data.compress,r.stretch=r.data.stretch;return;case 1:r.mix+=(r.data.mix-r.mix)*n,r.softness+=(r.data.softness-r.softness)*n,r.bendDirection=r.data.bendDirection,r.compress=r.data.compress,r.stretch=r.data.stretch}return}let l=0,h=0,f=me.search(o,i,6),d=this.curves[f/6];switch(d){case 0:let u=o[f];l=o[f+1],h=o[f+2];let m=(i-u)/(o[f+6]-u);l+=(o[f+6+1]-l)*m,h+=(o[f+6+2]-h)*m;break;case 1:l=o[f+1],h=o[f+2];break;default:l=this.getBezierValue(i,f,1,d-2),h=this.getBezierValue(i,f,2,d+18-2)}c==0?(r.mix=r.data.mix+(l-r.data.mix)*n,r.softness=r.data.softness+(h-r.data.softness)*n,a==1?(r.bendDirection=r.data.bendDirection,r.compress=r.data.compress,r.stretch=r.data.stretch):(r.bendDirection=o[f+3],r.compress=o[f+4]!=0,r.stretch=o[f+5]!=0)):(r.mix+=(l-r.mix)*n,r.softness+=(h-r.softness)*n,a==0&&(r.bendDirection=o[f+3],r.compress=o[f+4]!=0,r.stretch=o[f+5]!=0))}},ai=class extends ke{constructor(e,t,i){super(e,t,[ce.transformConstraint+"|"+i]);this.transformConstraintIndex=0,this.transformConstraintIndex=i}getFrameEntries(){return 7}setFrame(e,t,i,s,n,c,a,r){let o=this.frames;e*=7,o[e]=t,o[e+1]=i,o[e+2]=s,o[e+3]=n,o[e+4]=c,o[e+5]=a,o[e+6]=r}apply(e,t,i,s,n,c,a){let r=e.transformConstraints[this.transformConstraintIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){let v=r.data;switch(c){case 0:r.mixRotate=v.mixRotate,r.mixX=v.mixX,r.mixY=v.mixY,r.mixScaleX=v.mixScaleX,r.mixScaleY=v.mixScaleY,r.mixShearY=v.mixShearY;return;case 1:r.mixRotate+=(v.mixRotate-r.mixRotate)*n,r.mixX+=(v.mixX-r.mixX)*n,r.mixY+=(v.mixY-r.mixY)*n,r.mixScaleX+=(v.mixScaleX-r.mixScaleX)*n,r.mixScaleY+=(v.mixScaleY-r.mixScaleY)*n,r.mixShearY+=(v.mixShearY-r.mixShearY)*n}return}let l,h,f,d,u,m,x=me.search(o,i,7),b=this.curves[x/7];switch(b){case 0:let v=o[x];l=o[x+1],h=o[x+2],f=o[x+3],d=o[x+4],u=o[x+5],m=o[x+6];let g=(i-v)/(o[x+7]-v);l+=(o[x+7+1]-l)*g,h+=(o[x+7+2]-h)*g,f+=(o[x+7+3]-f)*g,d+=(o[x+7+4]-d)*g,u+=(o[x+7+5]-u)*g,m+=(o[x+7+6]-m)*g;break;case 1:l=o[x+1],h=o[x+2],f=o[x+3],d=o[x+4],u=o[x+5],m=o[x+6];break;default:l=this.getBezierValue(i,x,1,b-2),h=this.getBezierValue(i,x,2,b+18-2),f=this.getBezierValue(i,x,3,b+18*2-2),d=this.getBezierValue(i,x,4,b+18*3-2),u=this.getBezierValue(i,x,5,b+18*4-2),m=this.getBezierValue(i,x,6,b+18*5-2)}if(c==0){let v=r.data;r.mixRotate=v.mixRotate+(l-v.mixRotate)*n,r.mixX=v.mixX+(h-v.mixX)*n,r.mixY=v.mixY+(f-v.mixY)*n,r.mixScaleX=v.mixScaleX+(d-v.mixScaleX)*n,r.mixScaleY=v.mixScaleY+(u-v.mixScaleY)*n,r.mixShearY=v.mixShearY+(m-v.mixShearY)*n}else r.mixRotate+=(l-r.mixRotate)*n,r.mixX+=(h-r.mixX)*n,r.mixY+=(f-r.mixY)*n,r.mixScaleX+=(d-r.mixScaleX)*n,r.mixScaleY+=(u-r.mixScaleY)*n,r.mixShearY+=(m-r.mixShearY)*n}},li=class extends Re{constructor(e,t,i){super(e,t,ce.pathConstraintPosition+"|"+i);this.pathConstraintIndex=0,this.pathConstraintIndex=i}apply(e,t,i,s,n,c,a){let r=e.pathConstraints[this.pathConstraintIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(c){case 0:r.position=r.data.position;return;case 1:r.position+=(r.data.position-r.position)*n}return}let l=this.getCurveValue(i);c==0?r.position=r.data.position+(l-r.data.position)*n:r.position+=(l-r.position)*n}},oi=class extends Re{constructor(e,t,i){super(e,t,ce.pathConstraintSpacing+"|"+i);this.pathConstraintIndex=0,this.pathConstraintIndex=i}apply(e,t,i,s,n,c,a){let r=e.pathConstraints[this.pathConstraintIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(c){case 0:r.spacing=r.data.spacing;return;case 1:r.spacing+=(r.data.spacing-r.spacing)*n}return}let l=this.getCurveValue(i);c==0?r.spacing=r.data.spacing+(l-r.data.spacing)*n:r.spacing+=(l-r.spacing)*n}},hi=class extends ke{constructor(e,t,i){super(e,t,[ce.pathConstraintMix+"|"+i]);this.pathConstraintIndex=0,this.pathConstraintIndex=i}getFrameEntries(){return 4}setFrame(e,t,i,s,n){let c=this.frames;e<<=2,c[e]=t,c[e+1]=i,c[e+2]=s,c[e+3]=n}apply(e,t,i,s,n,c,a){let r=e.pathConstraints[this.pathConstraintIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(c){case 0:r.mixRotate=r.data.mixRotate,r.mixX=r.data.mixX,r.mixY=r.data.mixY;return;case 1:r.mixRotate+=(r.data.mixRotate-r.mixRotate)*n,r.mixX+=(r.data.mixX-r.mixX)*n,r.mixY+=(r.data.mixY-r.mixY)*n}return}let l,h,f,d=me.search(o,i,4),u=this.curves[d>>2];switch(u){case 0:let m=o[d];l=o[d+1],h=o[d+2],f=o[d+3];let x=(i-m)/(o[d+4]-m);l+=(o[d+4+1]-l)*x,h+=(o[d+4+2]-h)*x,f+=(o[d+4+3]-f)*x;break;case 1:l=o[d+1],h=o[d+2],f=o[d+3];break;default:l=this.getBezierValue(i,d,1,u-2),h=this.getBezierValue(i,d,2,u+18-2),f=this.getBezierValue(i,d,3,u+18*2-2)}if(c==0){let m=r.data;r.mixRotate=m.mixRotate+(l-m.mixRotate)*n,r.mixX=m.mixX+(h-m.mixX)*n,r.mixY=m.mixY+(f-m.mixY)*n}else r.mixRotate+=(l-r.mixRotate)*n,r.mixX+=(h-r.mixX)*n,r.mixY+=(f-r.mixY)*n}},qe=class extends me{constructor(e,t,i){super(e,[ce.sequence+"|"+t+"|"+i.sequence.id]);this.slotIndex=t,this.attachment=i}getFrameEntries(){return qe.ENTRIES}getSlotIndex(){return this.slotIndex}getAttachment(){return this.attachment}setFrame(e,t,i,s,n){let c=this.frames;e*=qe.ENTRIES,c[e]=t,c[e+qe.MODE]=i|s<<4,c[e+qe.DELAY]=n}apply(e,t,i,s,n,c,a){let r=e.slots[this.slotIndex];if(!r.bone.active)return;let o=r.attachment,l=this.attachment;if(o!=l&&(!(o instanceof Ee)||o.timelineAttachment!=l))return;let h=this.frames;if(i<h[0]){(c==0||c==1)&&(r.sequenceIndex=-1);return}let f=me.search(h,i,qe.ENTRIES),d=h[f],u=h[f+qe.MODE],m=h[f+qe.DELAY];if(!this.attachment.sequence)return;let x=u>>4,b=this.attachment.sequence.regions.length,v=_i[u&15];if(v!=Oe.hold)switch(x+=(i-d)/m+1e-5|0,v){case Oe.once:x=Math.min(b-1,x);break;case Oe.loop:x%=b;break;case Oe.pingpong:{let g=(b<<1)-2;x=g==0?0:x%g,x>=b&&(x=g-x);break}case Oe.onceReverse:x=Math.max(b-1-x,0);break;case Oe.loopReverse:x=b-1-x%b;break;case Oe.pingpongReverse:{let g=(b<<1)-2;x=g==0?0:(x+b-1)%g,x>=b&&(x=g-x)}}r.sequenceIndex=x}},rt=qe;rt.ENTRIES=3,rt.MODE=1,rt.DELAY=2;var St=class{constructor(e){this.tracks=new Array,this.timeScale=1,this.unkeyedState=0,this.events=new Array,this.listeners=new Array,this.queue=new Zi(this),this.propertyIDs=new Nt,this.animationsChanged=!1,this.trackEntryPool=new ut(()=>new ji),this.data=e}static emptyAnimation(){return St._emptyAnimation}update(e){e*=this.timeScale;let t=this.tracks;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(!n)continue;n.animationLast=n.nextAnimationLast,n.trackLast=n.nextTrackLast;let c=e*n.timeScale;if(n.delay>0){if(n.delay-=c,n.delay>0)continue;c=-n.delay,n.delay=0}let a=n.next;if(a){let r=n.trackLast-a.delay;if(r>=0){for(a.delay=0,a.trackTime+=n.timeScale==0?0:(r/n.timeScale+e)*a.timeScale,n.trackTime+=c,this.setCurrent(i,a,!0);a.mixingFrom;)a.mixTime+=e,a=a.mixingFrom;continue}}else if(n.trackLast>=n.trackEnd&&!n.mixingFrom){t[i]=null,this.queue.end(n),this.clearNext(n);continue}if(n.mixingFrom&&this.updateMixingFrom(n,e)){let r=n.mixingFrom;for(n.mixingFrom=null,r&&(r.mixingTo=null);r;)this.queue.end(r),r=r.mixingFrom}n.trackTime+=c}this.queue.drain()}updateMixingFrom(e,t){let i=e.mixingFrom;if(!i)return!0;let s=this.updateMixingFrom(i,t);return i.animationLast=i.nextAnimationLast,i.trackLast=i.nextTrackLast,e.mixTime>0&&e.mixTime>=e.mixDuration?((i.totalAlpha==0||e.mixDuration==0)&&(e.mixingFrom=i.mixingFrom,i.mixingFrom&&(i.mixingFrom.mixingTo=e),e.interruptAlpha=i.interruptAlpha,this.queue.end(i)),s):(i.trackTime+=t*i.timeScale,e.mixTime+=t,!1)}apply(e){if(!e)throw new Error("skeleton cannot be null.");this.animationsChanged&&this._animationsChanged();let t=this.events,i=this.tracks,s=!1;for(let f=0,d=i.length;f<d;f++){let u=i[f];if(!u||u.delay>0)continue;s=!0;let m=f==0?ue.first:u.mixBlend,x=u.alpha;u.mixingFrom?x*=this.applyMixingFrom(u,e,m):u.trackTime>=u.trackEnd&&!u.next&&(x=0);let b=u.animationLast,v=u.getAnimationTime(),g=v,w=t;u.reverse&&(g=u.animation.duration-g,w=null);let p=u.animation.timelines,y=p.length;if(f==0&&x==1||m==ue.add)for(let S=0;S<y;S++){B.webkit602BugfixHelper(x,m);var n=p[S];n instanceof Qe?this.applyAttachmentTimeline(n,e,g,m,!0):n.apply(e,b,g,w,x,m,Ne.mixIn)}else{let S=u.timelineMode,A=u.shortestRotation,I=!A&&u.timelinesRotation.length!=y<<1;I&&(u.timelinesRotation.length=y<<1);for(let E=0;E<y;E++){let k=p[E],X=S[E]==Ct?m:ue.setup;!A&&k instanceof mt?this.applyRotateTimeline(k,e,g,x,X,u.timelinesRotation,E<<1,I):k instanceof Qe?this.applyAttachmentTimeline(k,e,g,m,!0):(B.webkit602BugfixHelper(x,m),k.apply(e,b,g,w,x,X,Ne.mixIn))}}this.queueEvents(u,v),t.length=0,u.nextAnimationLast=v,u.nextTrackLast=u.trackTime}for(var c=this.unkeyedState+fi,a=e.slots,r=0,o=e.slots.length;r<o;r++){var l=a[r];if(l.attachmentState==c){var h=l.data.attachmentName;l.setAttachment(h?e.getAttachment(l.data.index,h):null)}}return this.unkeyedState+=2,this.queue.drain(),s}applyMixingFrom(e,t,i){let s=e.mixingFrom;s.mixingFrom&&this.applyMixingFrom(s,t,i);let n=0;e.mixDuration==0?(n=1,i==ue.first&&(i=ue.setup)):(n=e.mixTime/e.mixDuration,n>1&&(n=1),i!=ue.first&&(i=s.mixBlend));let c=n<s.attachmentThreshold,a=n<s.drawOrderThreshold,r=s.animation.timelines,o=r.length,l=s.alpha*e.interruptAlpha,h=l*(1-n),f=s.animationLast,d=s.getAnimationTime(),u=d,m=null;if(s.reverse?u=s.animation.duration-u:n<s.eventThreshold&&(m=this.events),i==ue.add)for(let x=0;x<o;x++)r[x].apply(t,f,u,m,h,i,Ne.mixOut);else{let x=s.timelineMode,b=s.timelineHoldMix,v=s.shortestRotation,g=!v&&s.timelinesRotation.length!=o<<1;g&&(s.timelinesRotation.length=o<<1),s.totalAlpha=0;for(let w=0;w<o;w++){let p=r[w],y=Ne.mixOut,S,A=0;switch(x[w]){case Ct:if(!a&&p instanceof $e)continue;S=i,A=h;break;case ci:S=ue.setup,A=h;break;case di:S=i,A=l;break;case Tt:S=ue.setup,A=l;break;default:S=ue.setup;let I=b[w];A=l*Math.max(0,1-I.mixTime/I.mixDuration);break}s.totalAlpha+=A,!v&&p instanceof mt?this.applyRotateTimeline(p,t,u,A,S,s.timelinesRotation,w<<1,g):p instanceof Qe?this.applyAttachmentTimeline(p,t,u,S,c):(B.webkit602BugfixHelper(A,i),a&&p instanceof $e&&S==ue.setup&&(y=Ne.mixIn),p.apply(t,f,u,m,A,S,y))}}return e.mixDuration>0&&this.queueEvents(s,d),this.events.length=0,s.nextAnimationLast=d,s.nextTrackLast=s.trackTime,n}applyAttachmentTimeline(e,t,i,s,n){var c=t.slots[e.slotIndex];!c.bone.active||(i<e.frames[0]?(s==ue.setup||s==ue.first)&&this.setAttachment(t,c,c.data.attachmentName,n):this.setAttachment(t,c,e.attachmentNames[me.search1(e.frames,i)],n),c.attachmentState<=this.unkeyedState&&(c.attachmentState=this.unkeyedState+fi))}setAttachment(e,t,i,s){t.setAttachment(i?e.getAttachment(t.data.index,i):null),s&&(t.attachmentState=this.unkeyedState+Ji)}applyRotateTimeline(e,t,i,s,n,c,a,r){if(r&&(c[a]=0),s==1){e.apply(t,0,i,null,1,n,Ne.mixIn);return}let o=t.bones[e.boneIndex];if(!o.active)return;let l=e.frames,h=0,f=0;if(i<l[0])switch(n){case ue.setup:o.rotation=o.data.rotation;default:return;case ue.first:h=o.rotation,f=o.data.rotation}else h=n==ue.setup?o.data.rotation:o.rotation,f=o.data.rotation+e.getCurveValue(i);let d=0,u=f-h;if(u-=(16384-(16384.499999999996-u/360|0))*360,u==0)d=c[a];else{let m=0,x=0;r?(m=0,x=u):(m=c[a],x=c[a+1]);let b=m-m%360;d=u+b;let v=u>=0,g=m>=0;Math.abs(x)<=90&&R.signum(x)!=R.signum(u)&&(Math.abs(m-b)>180?(d+=360*R.signum(m),g=v):b!=0?d-=360*R.signum(m):g=v),g!=v&&(d+=360*R.signum(m)),c[a]=d}c[a+1]=u,o.rotation=h+d*s}queueEvents(e,t){let i=e.animationStart,s=e.animationEnd,n=s-i,c=e.trackLast%n,a=this.events,r=0,o=a.length;for(;r<o;r++){let h=a[r];if(h.time<c)break;h.time>s||this.queue.event(e,h)}let l=!1;for(e.loop?l=n==0||c>e.trackTime%n:l=t>=s&&e.animationLast<s,l&&this.queue.complete(e);r<o;r++){let h=a[r];h.time<i||this.queue.event(e,h)}}clearTracks(){let e=this.queue.drainDisabled;this.queue.drainDisabled=!0;for(let t=0,i=this.tracks.length;t<i;t++)this.clearTrack(t);this.tracks.length=0,this.queue.drainDisabled=e,this.queue.drain()}clearTrack(e){if(e>=this.tracks.length)return;let t=this.tracks[e];if(!t)return;this.queue.end(t),this.clearNext(t);let i=t;for(;;){let s=i.mixingFrom;if(!s)break;this.queue.end(s),i.mixingFrom=null,i.mixingTo=null,i=s}this.tracks[t.trackIndex]=null,this.queue.drain()}setCurrent(e,t,i){let s=this.expandToIndex(e);this.tracks[e]=t,t.previous=null,s&&(i&&this.queue.interrupt(s),t.mixingFrom=s,s.mixingTo=t,t.mixTime=0,s.mixingFrom&&s.mixDuration>0&&(t.interruptAlpha*=Math.min(1,s.mixTime/s.mixDuration)),s.timelinesRotation.length=0),this.queue.start(t)}setAnimation(e,t,i=!1){let s=this.data.skeletonData.findAnimation(t);if(!s)throw new Error("Animation not found: "+t);return this.setAnimationWith(e,s,i)}setAnimationWith(e,t,i=!1){if(!t)throw new Error("animation cannot be null.");let s=!0,n=this.expandToIndex(e);n&&(n.nextTrackLast==-1?(this.tracks[e]=n.mixingFrom,this.queue.interrupt(n),this.queue.end(n),this.clearNext(n),n=n.mixingFrom,s=!1):this.clearNext(n));let c=this.trackEntry(e,t,i,n);return this.setCurrent(e,c,s),this.queue.drain(),c}addAnimation(e,t,i=!1,s=0){let n=this.data.skeletonData.findAnimation(t);if(!n)throw new Error("Animation not found: "+t);return this.addAnimationWith(e,n,i,s)}addAnimationWith(e,t,i=!1,s=0){if(!t)throw new Error("animation cannot be null.");let n=this.expandToIndex(e);if(n)for(;n.next;)n=n.next;let c=this.trackEntry(e,t,i,n);return n?(n.next=c,c.previous=n,s<=0&&(s+=n.getTrackComplete()-c.mixDuration)):(this.setCurrent(e,c,!0),this.queue.drain()),c.delay=s,c}setEmptyAnimation(e,t=0){let i=this.setAnimationWith(e,St.emptyAnimation(),!1);return i.mixDuration=t,i.trackEnd=t,i}addEmptyAnimation(e,t=0,i=0){let s=this.addAnimationWith(e,St.emptyAnimation(),!1,i);return i<=0&&(s.delay+=s.mixDuration-t),s.mixDuration=t,s.trackEnd=t,s}setEmptyAnimations(e=0){let t=this.queue.drainDisabled;this.queue.drainDisabled=!0;for(let i=0,s=this.tracks.length;i<s;i++){let n=this.tracks[i];n&&this.setEmptyAnimation(n.trackIndex,e)}this.queue.drainDisabled=t,this.queue.drain()}expandToIndex(e){return e<this.tracks.length?this.tracks[e]:(B.ensureArrayCapacity(this.tracks,e+1,null),this.tracks.length=e+1,null)}trackEntry(e,t,i,s){let n=this.trackEntryPool.obtain();return n.reset(),n.trackIndex=e,n.animation=t,n.loop=i,n.holdPrevious=!1,n.reverse=!1,n.shortestRotation=!1,n.eventThreshold=0,n.attachmentThreshold=0,n.drawOrderThreshold=0,n.animationStart=0,n.animationEnd=t.duration,n.animationLast=-1,n.nextAnimationLast=-1,n.delay=0,n.trackTime=0,n.trackLast=-1,n.nextTrackLast=-1,n.trackEnd=Number.MAX_VALUE,n.timeScale=1,n.alpha=1,n.mixTime=0,n.mixDuration=s?this.data.getMix(s.animation,t):0,n.interruptAlpha=1,n.totalAlpha=0,n.mixBlend=ue.replace,n}clearNext(e){let t=e.next;for(;t;)this.queue.dispose(t),t=t.next;e.next=null}_animationsChanged(){this.animationsChanged=!1,this.propertyIDs.clear();let e=this.tracks;for(let t=0,i=e.length;t<i;t++){let s=e[t];if(!!s){for(;s.mixingFrom;)s=s.mixingFrom;do(!s.mixingTo||s.mixBlend!=ue.add)&&this.computeHold(s),s=s.mixingTo;while(s)}}}computeHold(e){let t=e.mixingTo,i=e.animation.timelines,s=e.animation.timelines.length,n=e.timelineMode;n.length=s;let c=e.timelineHoldMix;c.length=0;let a=this.propertyIDs;if(t&&t.holdPrevious){for(let r=0;r<s;r++)n[r]=a.addAll(i[r].getPropertyIds())?Tt:di;return}e:for(let r=0;r<s;r++){let o=i[r],l=o.getPropertyIds();if(!a.addAll(l))n[r]=Ct;else if(!t||o instanceof Qe||o instanceof $e||o instanceof gt||!t.animation.hasTimeline(l))n[r]=ci;else{for(let h=t.mixingTo;h;h=h.mixingTo)if(!h.animation.hasTimeline(l)){if(e.mixDuration>0){n[r]=Ki,c[r]=h;continue e}break}n[r]=Tt}}}getCurrent(e){return e>=this.tracks.length?null:this.tracks[e]}addListener(e){if(!e)throw new Error("listener cannot be null.");this.listeners.push(e)}removeListener(e){let t=this.listeners.indexOf(e);t>=0&&this.listeners.splice(t,1)}clearListeners(){this.listeners.length=0}clearListenerNotifications(){this.queue.clear()}},Hi=St;Hi._emptyAnimation=new yt("<empty>",[],0);var ji=class{constructor(){this.animation=null,this.previous=null,this.next=null,this.mixingFrom=null,this.mixingTo=null,this.listener=null,this.trackIndex=0,this.loop=!1,this.holdPrevious=!1,this.reverse=!1,this.shortestRotation=!1,this.eventThreshold=0,this.attachmentThreshold=0,this.drawOrderThreshold=0,this.animationStart=0,this.animationEnd=0,this.animationLast=0,this.nextAnimationLast=0,this.delay=0,this.trackTime=0,this.trackLast=0,this.nextTrackLast=0,this.trackEnd=0,this.timeScale=0,this.alpha=0,this.mixTime=0,this.mixDuration=0,this.interruptAlpha=0,this.totalAlpha=0,this.mixBlend=ue.replace,this.timelineMode=new Array,this.timelineHoldMix=new Array,this.timelinesRotation=new Array}reset(){this.next=null,this.previous=null,this.mixingFrom=null,this.mixingTo=null,this.animation=null,this.listener=null,this.timelineMode.length=0,this.timelineHoldMix.length=0,this.timelinesRotation.length=0}getAnimationTime(){if(this.loop){let e=this.animationEnd-this.animationStart;return e==0?this.animationStart:this.trackTime%e+this.animationStart}return Math.min(this.trackTime+this.animationStart,this.animationEnd)}setAnimationLast(e){this.animationLast=e,this.nextAnimationLast=e}isComplete(){return this.trackTime>=this.animationEnd-this.animationStart}resetRotationDirections(){this.timelinesRotation.length=0}getTrackComplete(){let e=this.animationEnd-this.animationStart;if(e!=0){if(this.loop)return e*(1+(this.trackTime/e|0));if(this.trackTime<e)return e}return this.trackTime}},Zi=class{constructor(e){this.objects=[],this.drainDisabled=!1,this.animState=e}start(e){this.objects.push(Ce.start),this.objects.push(e),this.animState.animationsChanged=!0}interrupt(e){this.objects.push(Ce.interrupt),this.objects.push(e)}end(e){this.objects.push(Ce.end),this.objects.push(e),this.animState.animationsChanged=!0}dispose(e){this.objects.push(Ce.dispose),this.objects.push(e)}complete(e){this.objects.push(Ce.complete),this.objects.push(e)}event(e,t){this.objects.push(Ce.event),this.objects.push(e),this.objects.push(t)}drain(){if(this.drainDisabled)return;this.drainDisabled=!0;let e=this.objects,t=this.animState.listeners;for(let i=0;i<e.length;i+=2){let s=e[i],n=e[i+1];switch(s){case Ce.start:n.listener&&n.listener.start&&n.listener.start(n);for(let a=0;a<t.length;a++){let r=t[a];r.start&&r.start(n)}break;case Ce.interrupt:n.listener&&n.listener.interrupt&&n.listener.interrupt(n);for(let a=0;a<t.length;a++){let r=t[a];r.interrupt&&r.interrupt(n)}break;case Ce.end:n.listener&&n.listener.end&&n.listener.end(n);for(let a=0;a<t.length;a++){let r=t[a];r.end&&r.end(n)}case Ce.dispose:n.listener&&n.listener.dispose&&n.listener.dispose(n);for(let a=0;a<t.length;a++){let r=t[a];r.dispose&&r.dispose(n)}this.animState.trackEntryPool.free(n);break;case Ce.complete:n.listener&&n.listener.complete&&n.listener.complete(n);for(let a=0;a<t.length;a++){let r=t[a];r.complete&&r.complete(n)}break;case Ce.event:let c=e[i+++2];n.listener&&n.listener.event&&n.listener.event(n,c);for(let a=0;a<t.length;a++){let r=t[a];r.event&&r.event(n,c)}break}}this.clear(),this.drainDisabled=!1}clear(){this.objects.length=0}},Ce;(function(e){e[e.start=0]="start",e[e.interrupt=1]="interrupt",e[e.end=2]="end",e[e.dispose=3]="dispose",e[e.complete=4]="complete",e[e.event=5]="event"})(Ce||(Ce={}));var Es=class{start(e){}interrupt(e){}end(e){}dispose(e){}complete(e){}event(e,t){}},Ct=0,ci=1,di=2,Tt=3,Ki=4,fi=1,Ji=2,ks=class{constructor(e){if(this.animationToMixTime={},this.defaultMix=0,!e)throw new Error("skeletonData cannot be null.");this.skeletonData=e}setMix(e,t,i){let s=this.skeletonData.findAnimation(e);if(!s)throw new Error("Animation not found: "+e);let n=this.skeletonData.findAnimation(t);if(!n)throw new Error("Animation not found: "+t);this.setMixWith(s,n,i)}setMixWith(e,t,i){if(!e)throw new Error("from cannot be null.");if(!t)throw new Error("to cannot be null.");let s=e.name+"."+t.name;this.animationToMixTime[s]=i}getMix(e,t){let i=e.name+"."+t.name,s=this.animationToMixTime[i];return s===void 0?this.defaultMix:s}},It=class extends Ee{constructor(e){super(e);this.color=new O(1,1,1,1)}copy(){let e=new It(this.name);return this.copyTo(e),e.color.setFromColor(this.color),e}},xt=class extends Ee{constructor(e){super(e);this.endSlot=null,this.color=new O(.2275,.2275,.8078,1)}copy(){let e=new xt(this.name);return this.copyTo(e),e.endSlot=this.endSlot,e.color.setFromColor(this.color),e}},ui=class{constructor(e){this._image=e}getImage(){return this._image}},we;(function(e){e[e.Nearest=9728]="Nearest",e[e.Linear=9729]="Linear",e[e.MipMap=9987]="MipMap",e[e.MipMapNearestNearest=9984]="MipMapNearestNearest",e[e.MipMapLinearNearest=9985]="MipMapLinearNearest",e[e.MipMapNearestLinear=9986]="MipMapNearestLinear",e[e.MipMapLinearLinear=9987]="MipMapLinearLinear"})(we||(we={}));var et;(function(e){e[e.MirroredRepeat=33648]="MirroredRepeat",e[e.ClampToEdge=33071]="ClampToEdge",e[e.Repeat=10497]="Repeat"})(et||(et={}));var Qi=class{constructor(){this.u=0,this.v=0,this.u2=0,this.v2=0,this.width=0,this.height=0,this.degrees=0,this.offsetX=0,this.offsetY=0,this.originalWidth=0,this.originalHeight=0}},Rs=class extends ui{setFilters(e,t){}setWraps(e,t){}dispose(){}},$i=class{constructor(e){this.pages=new Array,this.regions=new Array;let t=new Fs(e),i=new Array(4),s={};s.size=l=>{l.width=parseInt(i[1]),l.height=parseInt(i[2])},s.format=()=>{},s.filter=l=>{l.minFilter=B.enumValue(we,i[1]),l.magFilter=B.enumValue(we,i[2])},s.repeat=l=>{i[1].indexOf("x")!=-1&&(l.uWrap=et.Repeat),i[1].indexOf("y")!=-1&&(l.vWrap=et.Repeat)},s.pma=l=>{l.pma=i[1]=="true"};var n={};n.xy=l=>{l.x=parseInt(i[1]),l.y=parseInt(i[2])},n.size=l=>{l.width=parseInt(i[1]),l.height=parseInt(i[2])},n.bounds=l=>{l.x=parseInt(i[1]),l.y=parseInt(i[2]),l.width=parseInt(i[3]),l.height=parseInt(i[4])},n.offset=l=>{l.offsetX=parseInt(i[1]),l.offsetY=parseInt(i[2])},n.orig=l=>{l.originalWidth=parseInt(i[1]),l.originalHeight=parseInt(i[2])},n.offsets=l=>{l.offsetX=parseInt(i[1]),l.offsetY=parseInt(i[2]),l.originalWidth=parseInt(i[3]),l.originalHeight=parseInt(i[4])},n.rotate=l=>{let h=i[1];h=="true"?l.degrees=90:h!="false"&&(l.degrees=parseInt(h))},n.index=l=>{l.index=parseInt(i[1])};let c=t.readLine();for(;c&&c.trim().length==0;)c=t.readLine();for(;!(!c||c.trim().length==0||t.readEntry(i,c)==0);)c=t.readLine();let a=null,r=null,o=null;for(;c!==null;)if(c.trim().length==0)a=null,c=t.readLine();else if(a){let l=new mi(a,c);for(;;){let h=t.readEntry(i,c=t.readLine());if(h==0)break;let f=n[i[0]];if(f)f(l);else{r||(r=[]),o||(o=[]),r.push(i[0]);let d=[];for(let u=0;u<h;u++)d.push(parseInt(i[u+1]));o.push(d)}}l.originalWidth==0&&l.originalHeight==0&&(l.originalWidth=l.width,l.originalHeight=l.height),r&&r.length>0&&o&&o.length>0&&(l.names=r,l.values=o,r=null,o=null),l.u=l.x/a.width,l.v=l.y/a.height,l.degrees==90?(l.u2=(l.x+l.height)/a.width,l.v2=(l.y+l.width)/a.height):(l.u2=(l.x+l.width)/a.width,l.v2=(l.y+l.height)/a.height),this.regions.push(l)}else{for(a=new es(c.trim());t.readEntry(i,c=t.readLine())!=0;){let l=s[i[0]];l&&l(a)}this.pages.push(a)}}findRegion(e){for(let t=0;t<this.regions.length;t++)if(this.regions[t].name==e)return this.regions[t];return null}setTextures(e,t=""){for(let i of this.pages)i.setTexture(e.get(t+i.name))}dispose(){var e;for(let t=0;t<this.pages.length;t++)(e=this.pages[t].texture)==null||e.dispose()}},Fs=class{constructor(e){this.index=0,this.lines=e.split(/\r\n|\r|\n/)}readLine(){return this.index>=this.lines.length?null:this.lines[this.index++]}readEntry(e,t){if(!t||(t=t.trim(),t.length==0))return 0;let i=t.indexOf(":");if(i==-1)return 0;e[0]=t.substr(0,i).trim();for(let s=1,n=i+1;;s++){let c=t.indexOf(",",n);if(c==-1)return e[s]=t.substr(n).trim(),s;if(e[s]=t.substr(n,c-n).trim(),n=c+1,s==4)return 4}}},es=class{constructor(e){this.minFilter=we.Nearest,this.magFilter=we.Nearest,this.uWrap=et.ClampToEdge,this.vWrap=et.ClampToEdge,this.texture=null,this.width=0,this.height=0,this.pma=!1,this.name=e}setTexture(e){this.texture=e,e.setFilters(this.minFilter,this.magFilter),e.setWraps(this.uWrap,this.vWrap)}},mi=class extends Qi{constructor(e,t){super();this.x=0,this.y=0,this.offsetX=0,this.offsetY=0,this.originalWidth=0,this.originalHeight=0,this.index=0,this.degrees=0,this.names=null,this.values=null,this.page=e,this.name=t}},Ge=class extends Ee{constructor(e,t){super(e);this.region=null,this.regionUVs=[],this.uvs=[],this.triangles=[],this.color=new O(1,1,1,1),this.width=0,this.height=0,this.hullLength=0,this.edges=[],this.parentMesh=null,this.sequence=null,this.tempColor=new O(0,0,0,0),this.path=t}updateRegion(){if(!this.region)throw new Error("Region not set.");let e=this.regionUVs;(!this.uvs||this.uvs.length!=e.length)&&(this.uvs=B.newFloatArray(e.length));let t=this.uvs,i=this.uvs.length,s=this.region.u,n=this.region.v,c=0,a=0;if(this.region instanceof mi){let r=this.region,o=r.page.texture.getImage(),l=o.width,h=o.height;switch(r.degrees){case 90:s-=(r.originalHeight-r.offsetY-r.height)/l,n-=(r.originalWidth-r.offsetX-r.width)/h,c=r.originalHeight/l,a=r.originalWidth/h;for(let f=0;f<i;f+=2)t[f]=s+e[f+1]*c,t[f+1]=n+(1-e[f])*a;return;case 180:s-=(r.originalWidth-r.offsetX-r.width)/l,n-=r.offsetY/h,c=r.originalWidth/l,a=r.originalHeight/h;for(let f=0;f<i;f+=2)t[f]=s+(1-e[f])*c,t[f+1]=n+(1-e[f+1])*a;return;case 270:s-=r.offsetY/l,n-=r.offsetX/h,c=r.originalHeight/l,a=r.originalWidth/h;for(let f=0;f<i;f+=2)t[f]=s+(1-e[f+1])*c,t[f+1]=n+e[f]*a;return}s-=r.offsetX/l,n-=(r.originalHeight-r.offsetY-r.height)/h,c=r.originalWidth/l,a=r.originalHeight/h}else this.region?(c=this.region.u2-s,a=this.region.v2-n):(s=n=0,c=a=1);for(let r=0;r<i;r+=2)t[r]=s+e[r]*c,t[r+1]=n+e[r+1]*a}getParentMesh(){return this.parentMesh}setParentMesh(e){this.parentMesh=e,e&&(this.bones=e.bones,this.vertices=e.vertices,this.worldVerticesLength=e.worldVerticesLength,this.regionUVs=e.regionUVs,this.triangles=e.triangles,this.hullLength=e.hullLength,this.worldVerticesLength=e.worldVerticesLength)}copy(){if(this.parentMesh)return this.newLinkedMesh();let e=new Ge(this.name,this.path);return e.region=this.region,e.color.setFromColor(this.color),this.copyTo(e),e.regionUVs=new Array(this.regionUVs.length),B.arrayCopy(this.regionUVs,0,e.regionUVs,0,this.regionUVs.length),e.uvs=new Array(this.uvs.length),B.arrayCopy(this.uvs,0,e.uvs,0,this.uvs.length),e.triangles=new Array(this.triangles.length),B.arrayCopy(this.triangles,0,e.triangles,0,this.triangles.length),e.hullLength=this.hullLength,e.sequence=this.sequence!=null?this.sequence.copy():null,this.edges&&(e.edges=new Array(this.edges.length),B.arrayCopy(this.edges,0,e.edges,0,this.edges.length)),e.width=this.width,e.height=this.height,e}computeWorldVertices(e,t,i,s,n,c){this.sequence!=null&&this.sequence.apply(e,this),super.computeWorldVertices(e,t,i,s,n,c)}newLinkedMesh(){let e=new Ge(this.name,this.path);return e.region=this.region,e.color.setFromColor(this.color),e.timelineAttachment=this.timelineAttachment,e.setParentMesh(this.parentMesh?this.parentMesh:this),e.region!=null&&e.updateRegion(),e}},tt=class extends Ee{constructor(e){super(e);this.lengths=[],this.closed=!1,this.constantSpeed=!1,this.color=new O(1,1,1,1)}copy(){let e=new tt(this.name);return this.copyTo(e),e.lengths=new Array(this.lengths.length),B.arrayCopy(this.lengths,0,e.lengths,0,this.lengths.length),e.closed=closed,e.constantSpeed=this.constantSpeed,e.color.setFromColor(this.color),e}},gi=class extends Ee{constructor(e){super(e);this.x=0,this.y=0,this.rotation=0,this.color=new O(.38,.94,0,1)}computeWorldPosition(e,t){return t.x=this.x*e.a+this.y*e.b+e.worldX,t.y=this.x*e.c+this.y*e.d+e.worldY,t}computeWorldRotation(e){let t=R.cosDeg(this.rotation),i=R.sinDeg(this.rotation),s=t*e.a+i*e.b,n=t*e.c+i*e.d;return Math.atan2(n,s)*R.radDeg}copy(){let e=new gi(this.name);return e.x=this.x,e.y=this.y,e.rotation=this.rotation,e.color.setFromColor(this.color),e}},ts=class extends zt{constructor(e,t){super(e);this.x=0,this.y=0,this.scaleX=1,this.scaleY=1,this.rotation=0,this.width=0,this.height=0,this.color=new O(1,1,1,1),this.rendererObject=null,this.region=null,this.sequence=null,this.offset=B.newFloatArray(8),this.uvs=B.newFloatArray(8),this.tempColor=new O(1,1,1,1),this.path=t}updateRegion(){if(!this.region)throw new Error("Region not set.");let e=this.region,t=this.uvs;if(e==null){t[0]=0,t[1]=0,t[2]=0,t[3]=1,t[4]=1,t[5]=1,t[6]=1,t[7]=0;return}let i=this.width/this.region.originalWidth*this.scaleX,s=this.height/this.region.originalHeight*this.scaleY,n=-this.width/2*this.scaleX+this.region.offsetX*i,c=-this.height/2*this.scaleY+this.region.offsetY*s,a=n+this.region.width*i,r=c+this.region.height*s,o=this.rotation*Math.PI/180,l=Math.cos(o),h=Math.sin(o),f=this.x,d=this.y,u=n*l+f,m=n*h,x=c*l+d,b=c*h,v=a*l+f,g=a*h,w=r*l+d,p=r*h,y=this.offset;y[0]=u-b,y[1]=x+m,y[2]=u-p,y[3]=w+m,y[4]=v-p,y[5]=w+g,y[6]=v-b,y[7]=x+g,e.degrees==90?(t[0]=e.u2,t[1]=e.v2,t[2]=e.u,t[3]=e.v2,t[4]=e.u,t[5]=e.v,t[6]=e.u2,t[7]=e.v):(t[0]=e.u,t[1]=e.v2,t[2]=e.u,t[3]=e.v,t[4]=e.u2,t[5]=e.v,t[6]=e.u2,t[7]=e.v2)}computeWorldVertices(e,t,i,s){this.sequence!=null&&this.sequence.apply(e,this);let n=e.bone,c=this.offset,a=n.worldX,r=n.worldY,o=n.a,l=n.b,h=n.c,f=n.d,d=0,u=0;d=c[0],u=c[1],t[i]=d*o+u*l+a,t[i+1]=d*h+u*f+r,i+=s,d=c[2],u=c[3],t[i]=d*o+u*l+a,t[i+1]=d*h+u*f+r,i+=s,d=c[4],u=c[5],t[i]=d*o+u*l+a,t[i+1]=d*h+u*f+r,i+=s,d=c[6],u=c[7],t[i]=d*o+u*l+a,t[i+1]=d*h+u*f+r}copy(){let e=new ts(this.name,this.path);return e.region=this.region,e.rendererObject=this.rendererObject,e.x=this.x,e.y=this.y,e.scaleX=this.scaleX,e.scaleY=this.scaleY,e.rotation=this.rotation,e.width=this.width,e.height=this.height,B.arrayCopy(this.uvs,0,e.uvs,0,8),B.arrayCopy(this.offset,0,e.offset,0,8),e.color.setFromColor(this.color),e.sequence=this.sequence!=null?this.sequence.copy():null,e}},ne=ts;ne.X1=0,ne.Y1=1,ne.C1R=2,ne.C1G=3,ne.C1B=4,ne.C1A=5,ne.U1=6,ne.V1=7,ne.X2=8,ne.Y2=9,ne.C2R=10,ne.C2G=11,ne.C2B=12,ne.C2A=13,ne.U2=14,ne.V2=15,ne.X3=16,ne.Y3=17,ne.C3R=18,ne.C3G=19,ne.C3B=20,ne.C3A=21,ne.U3=22,ne.V3=23,ne.X4=24,ne.Y4=25,ne.C4R=26,ne.C4G=27,ne.C4B=28,ne.C4A=29,ne.U4=30,ne.V4=31;var Xs=class{constructor(e){this.atlas=e}loadSequence(e,t,i){let s=i.regions;for(let n=0,c=s.length;n<c;n++){let a=i.getPath(t,n),r=this.atlas.findRegion(a);if(r==null)throw new Error("Region not found in atlas: "+a+" (sequence: "+e+")");s[n]=r,s[n].renderObject=s[n]}}newRegionAttachment(e,t,i,s){let n=new ne(t,i);if(s!=null)this.loadSequence(t,i,s);else{let c=this.atlas.findRegion(i);if(!c)throw new Error("Region not found in atlas: "+i+" (region attachment: "+t+")");c.renderObject=c,n.region=c}return n}newMeshAttachment(e,t,i,s){let n=new Ge(t,i);if(s!=null)this.loadSequence(t,i,s);else{let c=this.atlas.findRegion(i);if(!c)throw new Error("Region not found in atlas: "+i+" (mesh attachment: "+t+")");c.renderObject=c,n.region=c}return n}newBoundingBoxAttachment(e,t){return new It(t)}newPathAttachment(e,t){return new tt(t)}newPointAttachment(e,t){return new gi(t)}newClippingAttachment(e,t){return new xt(t)}},xi=class{constructor(e,t,i){if(this.index=0,this.parent=null,this.length=0,this.x=0,this.y=0,this.rotation=0,this.scaleX=1,this.scaleY=1,this.shearX=0,this.shearY=0,this.transformMode=ge.Normal,this.skinRequired=!1,this.color=new O,e<0)throw new Error("index must be >= 0.");if(!t)throw new Error("name cannot be null.");this.index=e,this.name=t,this.parent=i}},ge;(function(e){e[e.Normal=0]="Normal",e[e.OnlyTranslation=1]="OnlyTranslation",e[e.NoRotationOrReflection=2]="NoRotationOrReflection",e[e.NoScale=3]="NoScale",e[e.NoScaleOrReflection=4]="NoScaleOrReflection"})(ge||(ge={}));var wi=class{constructor(e,t,i){if(this.parent=null,this.children=new Array,this.x=0,this.y=0,this.rotation=0,this.scaleX=0,this.scaleY=0,this.shearX=0,this.shearY=0,this.ax=0,this.ay=0,this.arotation=0,this.ascaleX=0,this.ascaleY=0,this.ashearX=0,this.ashearY=0,this.a=0,this.b=0,this.c=0,this.d=0,this.worldY=0,this.worldX=0,this.sorted=!1,this.active=!1,!e)throw new Error("data cannot be null.");if(!t)throw new Error("skeleton cannot be null.");this.data=e,this.skeleton=t,this.parent=i,this.setToSetupPose()}isActive(){return this.active}update(){this.updateWorldTransformWith(this.ax,this.ay,this.arotation,this.ascaleX,this.ascaleY,this.ashearX,this.ashearY)}updateWorldTransform(){this.updateWorldTransformWith(this.x,this.y,this.rotation,this.scaleX,this.scaleY,this.shearX,this.shearY)}updateWorldTransformWith(e,t,i,s,n,c,a){this.ax=e,this.ay=t,this.arotation=i,this.ascaleX=s,this.ascaleY=n,this.ashearX=c,this.ashearY=a;let r=this.parent;if(!r){let d=this.skeleton,u=i+90+a,m=d.scaleX,x=d.scaleY;this.a=R.cosDeg(i+c)*s*m,this.b=R.cosDeg(u)*n*m,this.c=R.sinDeg(i+c)*s*x,this.d=R.sinDeg(u)*n*x,this.worldX=e*m+d.x,this.worldY=t*x+d.y;return}let o=r.a,l=r.b,h=r.c,f=r.d;switch(this.worldX=o*e+l*t+r.worldX,this.worldY=h*e+f*t+r.worldY,this.data.transformMode){case ge.Normal:{let d=i+90+a,u=R.cosDeg(i+c)*s,m=R.cosDeg(d)*n,x=R.sinDeg(i+c)*s,b=R.sinDeg(d)*n;this.a=o*u+l*x,this.b=o*m+l*b,this.c=h*u+f*x,this.d=h*m+f*b;return}case ge.OnlyTranslation:{let d=i+90+a;this.a=R.cosDeg(i+c)*s,this.b=R.cosDeg(d)*n,this.c=R.sinDeg(i+c)*s,this.d=R.sinDeg(d)*n;break}case ge.NoRotationOrReflection:{let d=o*o+h*h,u=0;d>1e-4?(d=Math.abs(o*f-l*h)/d,o/=this.skeleton.scaleX,h/=this.skeleton.scaleY,l=h*d,f=o*d,u=Math.atan2(h,o)*R.radDeg):(o=0,h=0,u=90-Math.atan2(f,l)*R.radDeg);let m=i+c-u,x=i+a-u+90,b=R.cosDeg(m)*s,v=R.cosDeg(x)*n,g=R.sinDeg(m)*s,w=R.sinDeg(x)*n;this.a=o*b-l*g,this.b=o*v-l*w,this.c=h*b+f*g,this.d=h*v+f*w;break}case ge.NoScale:case ge.NoScaleOrReflection:{let d=R.cosDeg(i),u=R.sinDeg(i),m=(o*d+l*u)/this.skeleton.scaleX,x=(h*d+f*u)/this.skeleton.scaleY,b=Math.sqrt(m*m+x*x);b>1e-5&&(b=1/b),m*=b,x*=b,b=Math.sqrt(m*m+x*x),this.data.transformMode==ge.NoScale&&o*f-l*h<0!=(this.skeleton.scaleX<0!=this.skeleton.scaleY<0)&&(b=-b);let v=Math.PI/2+Math.atan2(x,m),g=Math.cos(v)*b,w=Math.sin(v)*b,p=R.cosDeg(c)*s,y=R.cosDeg(90+a)*n,S=R.sinDeg(c)*s,A=R.sinDeg(90+a)*n;this.a=m*p+g*S,this.b=m*y+g*A,this.c=x*p+w*S,this.d=x*y+w*A;break}}this.a*=this.skeleton.scaleX,this.b*=this.skeleton.scaleX,this.c*=this.skeleton.scaleY,this.d*=this.skeleton.scaleY}setToSetupPose(){let e=this.data;this.x=e.x,this.y=e.y,this.rotation=e.rotation,this.scaleX=e.scaleX,this.scaleY=e.scaleY,this.shearX=e.shearX,this.shearY=e.shearY}getWorldRotationX(){return Math.atan2(this.c,this.a)*R.radDeg}getWorldRotationY(){return Math.atan2(this.d,this.b)*R.radDeg}getWorldScaleX(){return Math.sqrt(this.a*this.a+this.c*this.c)}getWorldScaleY(){return Math.sqrt(this.b*this.b+this.d*this.d)}updateAppliedTransform(){let e=this.parent;if(!e){this.ax=this.worldX-this.skeleton.x,this.ay=this.worldY-this.skeleton.y,this.arotation=Math.atan2(this.c,this.a)*R.radDeg,this.ascaleX=Math.sqrt(this.a*this.a+this.c*this.c),this.ascaleY=Math.sqrt(this.b*this.b+this.d*this.d),this.ashearX=0,this.ashearY=Math.atan2(this.a*this.b+this.c*this.d,this.a*this.d-this.b*this.c)*R.radDeg;return}let t=e.a,i=e.b,s=e.c,n=e.d,c=1/(t*n-i*s),a=n*c,r=i*c,o=s*c,l=t*c,h=this.worldX-e.worldX,f=this.worldY-e.worldY;this.ax=h*a-f*r,this.ay=f*l-h*o;let d,u,m,x;if(this.data.transformMode==ge.OnlyTranslation)d=this.a,u=this.b,m=this.c,x=this.d;else{switch(this.data.transformMode){case ge.NoRotationOrReflection:{let p=Math.abs(t*n-i*s)/(t*t+s*s),y=t/this.skeleton.scaleX;i=-(s/this.skeleton.scaleY)*p*this.skeleton.scaleX,n=y*p*this.skeleton.scaleY,c=1/(t*n-i*s),a=n*c,r=i*c;break}case ge.NoScale:case ge.NoScaleOrReflection:let b=R.cosDeg(this.rotation),v=R.sinDeg(this.rotation);t=(t*b+i*v)/this.skeleton.scaleX,s=(s*b+n*v)/this.skeleton.scaleY;let g=Math.sqrt(t*t+s*s);g>1e-5&&(g=1/g),t*=g,s*=g,g=Math.sqrt(t*t+s*s),this.data.transformMode==ge.NoScale&&c<0!=(this.skeleton.scaleX<0!=this.skeleton.scaleY<0)&&(g=-g);let w=R.PI/2+Math.atan2(s,t);i=Math.cos(w)*g,n=Math.sin(w)*g,c=1/(t*n-i*s),a=n*c,r=i*c,o=s*c,l=t*c}d=a*this.a-r*this.c,u=a*this.b-r*this.d,m=l*this.c-o*this.a,x=l*this.d-o*this.b}if(this.ashearX=0,this.ascaleX=Math.sqrt(d*d+m*m),this.ascaleX>1e-4){let b=d*x-u*m;this.ascaleY=b/this.ascaleX,this.ashearY=-Math.atan2(d*u+m*x,b)*R.radDeg,this.arotation=Math.atan2(m,d)*R.radDeg}else this.ascaleX=0,this.ascaleY=Math.sqrt(u*u+x*x),this.ashearY=0,this.arotation=90-Math.atan2(x,u)*R.radDeg}worldToLocal(e){let t=1/(this.a*this.d-this.b*this.c),i=e.x-this.worldX,s=e.y-this.worldY;return e.x=i*this.d*t-s*this.b*t,e.y=s*this.a*t-i*this.c*t,e}localToWorld(e){let t=e.x,i=e.y;return e.x=t*this.a+i*this.b+this.worldX,e.y=t*this.c+i*this.d+this.worldY,e}worldToLocalRotation(e){let t=R.sinDeg(e),i=R.cosDeg(e);return Math.atan2(this.a*t-this.c*i,this.d*i-this.b*t)*R.radDeg+this.rotation-this.shearX}localToWorldRotation(e){e-=this.rotation-this.shearX;let t=R.sinDeg(e),i=R.cosDeg(e);return Math.atan2(i*this.c+t*this.d,i*this.a+t*this.b)*R.radDeg}rotateWorld(e){let t=this.a,i=this.b,s=this.c,n=this.d,c=R.cosDeg(e),a=R.sinDeg(e);this.a=c*t-a*s,this.b=c*i-a*n,this.c=a*t+c*s,this.d=a*i+c*n}},Mt=class{constructor(e,t,i){this.name=e,this.order=t,this.skinRequired=i}},is=class{constructor(e,t="",i=new pi){this.pathPrefix="",this.assets={},this.errors={},this.toLoad=0,this.loaded=0,this.textureLoader=e,this.pathPrefix=t,this.downloader=i}start(e){return this.toLoad++,this.pathPrefix+e}success(e,t,i){this.toLoad--,this.loaded++,this.assets[t]=i,e&&e(t,i)}error(e,t,i){this.toLoad--,this.loaded++,this.errors[t]=i,e&&e(t,i)}loadAll(){return new Promise((t,i)=>{let s=()=>{if(this.isLoadingComplete()){this.hasErrors()?i(this.errors):t(this);return}requestAnimationFrame(s)};requestAnimationFrame(s)})}setRawDataURI(e,t){this.downloader.rawDataUris[this.pathPrefix+e]=t}loadBinary(e,t=()=>{},i=()=>{}){e=this.start(e),this.downloader.downloadBinary(e,s=>{this.success(t,e,s)},(s,n)=>{this.error(i,e,`Couldn't load binary ${e}: status ${s}, ${n}`)})}loadText(e,t=()=>{},i=()=>{}){e=this.start(e),this.downloader.downloadText(e,s=>{this.success(t,e,s)},(s,n)=>{this.error(i,e,`Couldn't load text ${e}: status ${s}, ${n}`)})}loadJson(e,t=()=>{},i=()=>{}){e=this.start(e),this.downloader.downloadJson(e,s=>{this.success(t,e,s)},(s,n)=>{this.error(i,e,`Couldn't load JSON ${e}: status ${s}, ${n}`)})}loadTexture(e,t=()=>{},i=()=>{}){if(e=this.start(e),!!!(typeof window!="undefined"&&typeof navigator!="undefined"&&window.document))fetch(e,{mode:"cors"}).then(c=>c.ok?c.blob():(this.error(i,e,`Couldn't load image: ${e}`),null)).then(c=>c?createImageBitmap(c,{premultiplyAlpha:"none",colorSpaceConversion:"none"}):null).then(c=>{c&&this.success(t,e,this.textureLoader(c))});else{let c=new Image;c.crossOrigin="anonymous",c.onload=()=>{this.success(t,e,this.textureLoader(c))},c.onerror=()=>{this.error(i,e,`Couldn't load image: ${e}`)},this.downloader.rawDataUris[e]&&(e=this.downloader.rawDataUris[e]),c.src=e}}loadTextureAtlas(e,t=()=>{},i=()=>{},s){let n=e.lastIndexOf("/"),c=n>=0?e.substring(0,n+1):"";e=this.start(e),this.downloader.downloadText(e,a=>{try{let r=new $i(a),o=r.pages.length,l=!1;for(let h of r.pages)this.loadTexture(s?s[h.name]:c+h.name,(f,d)=>{l||(h.setTexture(d),--o==0&&this.success(t,e,r))},(f,d)=>{l||this.error(i,e,`Couldn't load texture atlas ${e} page image: ${f}`),l=!0})}catch(r){this.error(i,e,`Couldn't parse texture atlas ${e}: ${r.message}`)}},(a,r)=>{this.error(i,e,`Couldn't load texture atlas ${e}: status ${a}, ${r}`)})}get(e){return this.assets[this.pathPrefix+e]}require(e){e=this.pathPrefix+e;let t=this.assets[e];if(t)return t;let i=this.errors[e];throw Error("Asset not found: "+e+(i?`
|
|
2
|
+
`+i:""))}remove(e){e=this.pathPrefix+e;let t=this.assets[e];return t.dispose&&t.dispose(),delete this.assets[e],t}removeAll(){for(let e in this.assets){let t=this.assets[e];t.dispose&&t.dispose()}this.assets={}}isLoadingComplete(){return this.toLoad==0}getToLoad(){return this.toLoad}getLoaded(){return this.loaded}dispose(){this.removeAll()}hasErrors(){return Object.keys(this.errors).length>0}getErrors(){return this.errors}},pi=class{constructor(){this.callbacks={},this.rawDataUris={}}dataUriToString(e){if(!e.startsWith("data:"))throw new Error("Not a data URI.");let t=e.indexOf("base64,");return t!=-1?(t+="base64,".length,atob(e.substr(t))):e.substr(e.indexOf(",")+1)}base64ToUint8Array(e){for(var t=window.atob(e),i=t.length,s=new Uint8Array(i),n=0;n<i;n++)s[n]=t.charCodeAt(n);return s}dataUriToUint8Array(e){if(!e.startsWith("data:"))throw new Error("Not a data URI.");let t=e.indexOf("base64,");if(t==-1)throw new Error("Not a binary data URI.");return t+="base64,".length,this.base64ToUint8Array(e.substr(t))}downloadText(e,t,i){if(this.start(e,t,i))return;if(this.rawDataUris[e]){try{let c=this.rawDataUris[e];this.finish(e,200,this.dataUriToString(c))}catch(c){this.finish(e,400,JSON.stringify(c))}return}let s=new XMLHttpRequest;s.overrideMimeType("text/html"),s.open("GET",e,!0);let n=()=>{this.finish(e,s.status,s.responseText)};s.onload=n,s.onerror=n,s.send()}downloadJson(e,t,i){this.downloadText(e,s=>{t(JSON.parse(s))},i)}downloadBinary(e,t,i){if(this.start(e,t,i))return;if(this.rawDataUris[e]){try{let c=this.rawDataUris[e];this.finish(e,200,this.dataUriToUint8Array(c))}catch(c){this.finish(e,400,JSON.stringify(c))}return}let s=new XMLHttpRequest;s.open("GET",e,!0),s.responseType="arraybuffer";let n=()=>{this.finish(e,s.status,s.response)};s.onload=()=>{s.status==200||s.status==0?this.finish(e,200,new Uint8Array(s.response)):n()},s.onerror=n,s.send()}start(e,t,i){let s=this.callbacks[e];try{if(s)return!0;this.callbacks[e]=s=[]}finally{s.push(t,i)}}finish(e,t,i){let s=this.callbacks[e];delete this.callbacks[e];let n=t==200||t==0?[i]:[t,i];for(let c=n.length-1,a=s.length;c<a;c+=2)s[c].apply(null,n)}},bi=class{constructor(e,t){if(this.intValue=0,this.floatValue=0,this.stringValue=null,this.time=0,this.volume=0,this.balance=0,!t)throw new Error("data cannot be null.");this.time=e,this.data=t}},vi=class{constructor(e){this.intValue=0,this.floatValue=0,this.stringValue=null,this.audioPath=null,this.volume=0,this.balance=0,this.name=e}},ss=class{constructor(e,t){if(this.bendDirection=0,this.compress=!1,this.stretch=!1,this.mix=1,this.softness=0,this.active=!1,!e)throw new Error("data cannot be null.");if(!t)throw new Error("skeleton cannot be null.");this.data=e,this.mix=e.mix,this.softness=e.softness,this.bendDirection=e.bendDirection,this.compress=e.compress,this.stretch=e.stretch,this.bones=new Array;for(let s=0;s<e.bones.length;s++){let n=t.findBone(e.bones[s].name);if(!n)throw new Error(`Couldn't find bone ${e.bones[s].name}`);this.bones.push(n)}let i=t.findBone(e.target.name);if(!i)throw new Error(`Couldn't find bone ${e.target.name}`);this.target=i}isActive(){return this.active}update(){if(this.mix==0)return;let e=this.target,t=this.bones;switch(t.length){case 1:this.apply1(t[0],e.worldX,e.worldY,this.compress,this.stretch,this.data.uniform,this.mix);break;case 2:this.apply2(t[0],t[1],e.worldX,e.worldY,this.bendDirection,this.stretch,this.data.uniform,this.softness,this.mix);break}}apply1(e,t,i,s,n,c,a){let r=e.parent;if(!r)throw new Error("IK bone must have parent.");let o=r.a,l=r.b,h=r.c,f=r.d,d=-e.ashearX-e.arotation,u=0,m=0;switch(e.data.transformMode){case ge.OnlyTranslation:u=t-e.worldX,m=i-e.worldY;break;case ge.NoRotationOrReflection:let v=Math.abs(o*f-l*h)/(o*o+h*h),g=o/e.skeleton.scaleX,w=h/e.skeleton.scaleY;l=-w*v*e.skeleton.scaleX,f=g*v*e.skeleton.scaleY,d+=Math.atan2(w,g)*R.radDeg;default:let p=t-r.worldX,y=i-r.worldY,S=o*f-l*h;u=(p*f-y*l)/S-e.ax,m=(y*o-p*h)/S-e.ay}d+=Math.atan2(m,u)*R.radDeg,e.ascaleX<0&&(d+=180),d>180?d-=360:d<-180&&(d+=360);let x=e.ascaleX,b=e.ascaleY;if(s||n){switch(e.data.transformMode){case ge.NoScale:case ge.NoScaleOrReflection:u=t-e.worldX,m=i-e.worldY}let v=e.data.length*x,g=Math.sqrt(u*u+m*m);if(s&&g<v||n&&g>v&&v>1e-4){let w=(g/v-1)*a+1;x*=w,c&&(b*=w)}}e.updateWorldTransformWith(e.ax,e.ay,e.arotation+d*a,x,b,e.ashearX,e.ashearY)}apply2(e,t,i,s,n,c,a,r,o){let l=e.ax,h=e.ay,f=e.ascaleX,d=e.ascaleY,u=f,m=d,x=t.ascaleX,b=0,v=0,g=0;f<0?(f=-f,b=180,g=-1):(b=0,g=1),d<0&&(d=-d,g=-g),x<0?(x=-x,v=180):v=0;let w=t.ax,p=0,y=0,S=0,A=e.a,I=e.b,E=e.c,k=e.d,X=Math.abs(f-d)<=1e-4;!X||c?(p=0,y=A*w+e.worldX,S=E*w+e.worldY):(p=t.ay,y=A*w+I*p+e.worldX,S=E*w+k*p+e.worldY);let F=e.parent;if(!F)throw new Error("IK parent must itself have a parent.");A=F.a,I=F.b,E=F.c,k=F.d;let L=1/(A*k-I*E),T=y-F.worldX,M=S-F.worldY,P=(T*k-M*I)*L-l,ee=(M*A-T*E)*L-h,te=Math.sqrt(P*P+ee*ee),le=t.data.length*x,se,he;if(te<1e-4){this.apply1(e,i,s,!1,c,!1,o),t.updateWorldTransformWith(w,p,0,t.ascaleX,t.ascaleY,t.ashearX,t.ashearY);return}T=i-F.worldX,M=s-F.worldY;let re=(T*k-M*I)*L-l,ie=(M*A-T*E)*L-h,de=re*re+ie*ie;if(r!=0){r*=f*(x+1)*.5;let ve=Math.sqrt(de),Me=ve-te-le*f+r;if(Me>0){let Ye=Math.min(1,Me/(r*2))-1;Ye=(Me-r*(1-Ye*Ye))/ve,re-=Ye*re,ie-=Ye*ie,de=re*re+ie*ie}}e:if(X){le*=f;let ve=(de-te*te-le*le)/(2*te*le);ve<-1?(ve=-1,he=Math.PI*n):ve>1?(ve=1,he=0,c&&(A=(Math.sqrt(de)/(te+le)-1)*o+1,u*=A,a&&(m*=A))):he=Math.acos(ve)*n,A=te+le*ve,I=le*Math.sin(he),se=Math.atan2(ie*A-re*I,re*A+ie*I)}else{A=f*le,I=d*le;let ve=A*A,Me=I*I,Ye=Math.atan2(ie,re);E=Me*te*te+ve*de-ve*Me;let Ze=-2*Me*te,ct=Me-ve;if(k=Ze*Ze-4*ct*E,k>=0){let dt=Math.sqrt(k);Ze<0&&(dt=-dt),dt=-(Ze+dt)*.5;let ys=dt/ct,As=E/dt,ft=Math.abs(ys)<Math.abs(As)?ys:As;if(ft*ft<=de){M=Math.sqrt(de-ft*ft)*n,se=Ye-Math.atan2(M,ft),he=Math.atan2(M/d,(ft-te)/f);break e}}let bt=R.PI,Dt=te-A,Oi=Dt*Dt,ps=0,bs=0,Vt=te+A,Di=Vt*Vt,vs=0;E=-A*te/(ve-Me),E>=-1&&E<=1&&(E=Math.acos(E),T=A*Math.cos(E)+te,M=I*Math.sin(E),k=T*T+M*M,k<Oi&&(bt=E,Oi=k,Dt=T,ps=M),k>Di&&(bs=E,Di=k,Vt=T,vs=M)),de<=(Oi+Di)*.5?(se=Ye-Math.atan2(ps*n,Dt),he=bt*n):(se=Ye-Math.atan2(vs*n,Vt),he=bs*n)}let Se=Math.atan2(p,w)*g,Be=e.arotation;se=(se-Se)*R.radDeg+b-Be,se>180?se-=360:se<-180&&(se+=360),e.updateWorldTransformWith(l,h,Be+se*o,u,m,0,0),Be=t.arotation,he=((he+Se)*R.radDeg-t.ashearX)*g+v-Be,he>180?he-=360:he<-180&&(he+=360),t.updateWorldTransformWith(w,p,Be+he*o,t.ascaleX,t.ascaleY,t.ashearX,t.ashearY)}},yi=class extends Mt{constructor(e){super(e,0,!1);this.bones=new Array,this._target=null,this.bendDirection=1,this.compress=!1,this.stretch=!1,this.uniform=!1,this.mix=1,this.softness=0}set target(e){this._target=e}get target(){if(this._target)return this._target;throw new Error("BoneData not set.")}},Ai=class extends Mt{constructor(e){super(e,0,!1);this.bones=new Array,this._target=null,this.positionMode=Fe.Fixed,this.spacingMode=xe.Fixed,this.rotateMode=He.Chain,this.offsetRotation=0,this.position=0,this.spacing=0,this.mixRotate=0,this.mixX=0,this.mixY=0}set target(e){this._target=e}get target(){if(this._target)return this._target;throw new Error("SlotData not set.")}},Fe;(function(e){e[e.Fixed=0]="Fixed",e[e.Percent=1]="Percent"})(Fe||(Fe={}));var xe;(function(e){e[e.Length=0]="Length",e[e.Fixed=1]="Fixed",e[e.Percent=2]="Percent",e[e.Proportional=3]="Proportional"})(xe||(xe={}));var He;(function(e){e[e.Tangent=0]="Tangent",e[e.Chain=1]="Chain",e[e.ChainScale=2]="ChainScale"})(He||(He={}));var Ue=class{constructor(e,t){if(this.position=0,this.spacing=0,this.mixRotate=0,this.mixX=0,this.mixY=0,this.spaces=new Array,this.positions=new Array,this.world=new Array,this.curves=new Array,this.lengths=new Array,this.segments=new Array,this.active=!1,!e)throw new Error("data cannot be null.");if(!t)throw new Error("skeleton cannot be null.");this.data=e,this.bones=new Array;for(let s=0,n=e.bones.length;s<n;s++){let c=t.findBone(e.bones[s].name);if(!c)throw new Error(`Couldn't find bone ${e.bones[s].name}.`);this.bones.push(c)}let i=t.findSlot(e.target.name);if(!i)throw new Error(`Couldn't find target bone ${e.target.name}`);this.target=i,this.position=e.position,this.spacing=e.spacing,this.mixRotate=e.mixRotate,this.mixX=e.mixX,this.mixY=e.mixY}isActive(){return this.active}update(){let e=this.target.getAttachment();if(!(e instanceof tt))return;let t=this.mixRotate,i=this.mixX,s=this.mixY;if(t==0&&i==0&&s==0)return;let n=this.data,c=n.rotateMode==He.Tangent,a=n.rotateMode==He.ChainScale,r=this.bones,o=r.length,l=c?o:o+1,h=B.setArraySize(this.spaces,l),f=a?this.lengths=B.setArraySize(this.lengths,o):[],d=this.spacing;switch(n.spacingMode){case xe.Percent:if(a)for(let p=0,y=l-1;p<y;p++){let S=r[p],A=S.data.length;if(A<Ue.epsilon)f[p]=0;else{let I=A*S.a,E=A*S.c;f[p]=Math.sqrt(I*I+E*E)}}B.arrayFill(h,1,l,d);break;case xe.Proportional:let g=0;for(let p=0,y=l-1;p<y;){let S=r[p],A=S.data.length;if(A<Ue.epsilon)a&&(f[p]=0),h[++p]=d;else{let I=A*S.a,E=A*S.c,k=Math.sqrt(I*I+E*E);a&&(f[p]=k),h[++p]=k,g+=k}}if(g>0){g=l/g*d;for(let p=1;p<l;p++)h[p]*=g}break;default:let w=n.spacingMode==xe.Length;for(let p=0,y=l-1;p<y;){let S=r[p],A=S.data.length;if(A<Ue.epsilon)a&&(f[p]=0),h[++p]=d;else{let I=A*S.a,E=A*S.c,k=Math.sqrt(I*I+E*E);a&&(f[p]=k),h[++p]=(w?A+d:d)*k/A}}}let u=this.computeWorldPositions(e,l,c),m=u[0],x=u[1],b=n.offsetRotation,v=!1;if(b==0)v=n.rotateMode==He.Chain;else{v=!1;let g=this.target.bone;b*=g.a*g.d-g.b*g.c>0?R.degRad:-R.degRad}for(let g=0,w=3;g<o;g++,w+=3){let p=r[g];p.worldX+=(m-p.worldX)*i,p.worldY+=(x-p.worldY)*s;let y=u[w],S=u[w+1],A=y-m,I=S-x;if(a){let E=f[g];if(E!=0){let k=(Math.sqrt(A*A+I*I)/E-1)*t+1;p.a*=k,p.c*=k}}if(m=y,x=S,t>0){let E=p.a,k=p.b,X=p.c,F=p.d,L=0,T=0,M=0;if(c?L=u[w-1]:h[g+1]==0?L=u[w+2]:L=Math.atan2(I,A),L-=Math.atan2(X,E),v){T=Math.cos(L),M=Math.sin(L);let P=p.data.length;m+=(P*(T*E-M*X)-A)*t,x+=(P*(M*E+T*X)-I)*t}else L+=b;L>R.PI?L-=R.PI2:L<-R.PI&&(L+=R.PI2),L*=t,T=Math.cos(L),M=Math.sin(L),p.a=T*E-M*X,p.b=T*k-M*F,p.c=M*E+T*X,p.d=M*k+T*F}p.updateAppliedTransform()}}computeWorldPositions(e,t,i){let s=this.target,n=this.position,c=this.spaces,a=B.setArraySize(this.positions,t*3+2),r=this.world,o=e.closed,l=e.worldVerticesLength,h=l/6,f=Ue.NONE;if(!e.constantSpeed){let ee=e.lengths;h-=o?1:2;let te=ee[h];this.data.positionMode==Fe.Percent&&(n*=te);let le;switch(this.data.spacingMode){case xe.Percent:le=te;break;case xe.Proportional:le=te/t;break;default:le=1}r=B.setArraySize(this.world,8);for(let se=0,he=0,re=0;se<t;se++,he+=3){let ie=c[se]*le;n+=ie;let de=n;if(o)de%=te,de<0&&(de+=te),re=0;else if(de<0){f!=Ue.BEFORE&&(f=Ue.BEFORE,e.computeWorldVertices(s,2,4,r,0,2)),this.addBeforePosition(de,r,0,a,he);continue}else if(de>te){f!=Ue.AFTER&&(f=Ue.AFTER,e.computeWorldVertices(s,l-6,4,r,0,2)),this.addAfterPosition(de-te,r,0,a,he);continue}for(;;re++){let Se=ee[re];if(!(de>Se)){if(re==0)de/=Se;else{let Be=ee[re-1];de=(de-Be)/(Se-Be)}break}}re!=f&&(f=re,o&&re==h?(e.computeWorldVertices(s,l-4,4,r,0,2),e.computeWorldVertices(s,0,4,r,4,2)):e.computeWorldVertices(s,re*6+2,8,r,0,2)),this.addCurvePosition(de,r[0],r[1],r[2],r[3],r[4],r[5],r[6],r[7],a,he,i||se>0&&ie==0)}return a}o?(l+=2,r=B.setArraySize(this.world,l),e.computeWorldVertices(s,2,l-4,r,0,2),e.computeWorldVertices(s,0,2,r,l-4,2),r[l-2]=r[0],r[l-1]=r[1]):(h--,l-=4,r=B.setArraySize(this.world,l),e.computeWorldVertices(s,2,l,r,0,2));let d=B.setArraySize(this.curves,h),u=0,m=r[0],x=r[1],b=0,v=0,g=0,w=0,p=0,y=0,S=0,A=0,I=0,E=0,k=0,X=0,F=0,L=0;for(let ee=0,te=2;ee<h;ee++,te+=6)b=r[te],v=r[te+1],g=r[te+2],w=r[te+3],p=r[te+4],y=r[te+5],S=(m-b*2+g)*.1875,A=(x-v*2+w)*.1875,I=((b-g)*3-m+p)*.09375,E=((v-w)*3-x+y)*.09375,k=S*2+I,X=A*2+E,F=(b-m)*.75+S+I*.16666667,L=(v-x)*.75+A+E*.16666667,u+=Math.sqrt(F*F+L*L),F+=k,L+=X,k+=I,X+=E,u+=Math.sqrt(F*F+L*L),F+=k,L+=X,u+=Math.sqrt(F*F+L*L),F+=k+I,L+=X+E,u+=Math.sqrt(F*F+L*L),d[ee]=u,m=p,x=y;this.data.positionMode==Fe.Percent&&(n*=u);let T;switch(this.data.spacingMode){case xe.Percent:T=u;break;case xe.Proportional:T=u/t;break;default:T=1}let M=this.segments,P=0;for(let ee=0,te=0,le=0,se=0;ee<t;ee++,te+=3){let he=c[ee]*T;n+=he;let re=n;if(o)re%=u,re<0&&(re+=u),le=0;else if(re<0){this.addBeforePosition(re,r,0,a,te);continue}else if(re>u){this.addAfterPosition(re-u,r,l-4,a,te);continue}for(;;le++){let ie=d[le];if(!(re>ie)){if(le==0)re/=ie;else{let de=d[le-1];re=(re-de)/(ie-de)}break}}if(le!=f){f=le;let ie=le*6;for(m=r[ie],x=r[ie+1],b=r[ie+2],v=r[ie+3],g=r[ie+4],w=r[ie+5],p=r[ie+6],y=r[ie+7],S=(m-b*2+g)*.03,A=(x-v*2+w)*.03,I=((b-g)*3-m+p)*.006,E=((v-w)*3-x+y)*.006,k=S*2+I,X=A*2+E,F=(b-m)*.3+S+I*.16666667,L=(v-x)*.3+A+E*.16666667,P=Math.sqrt(F*F+L*L),M[0]=P,ie=1;ie<8;ie++)F+=k,L+=X,k+=I,X+=E,P+=Math.sqrt(F*F+L*L),M[ie]=P;F+=k,L+=X,P+=Math.sqrt(F*F+L*L),M[8]=P,F+=k+I,L+=X+E,P+=Math.sqrt(F*F+L*L),M[9]=P,se=0}for(re*=P;;se++){let ie=M[se];if(!(re>ie)){if(se==0)re/=ie;else{let de=M[se-1];re=se+(re-de)/(ie-de)}break}}this.addCurvePosition(re*.1,m,x,b,v,g,w,p,y,a,te,i||ee>0&&he==0)}return a}addBeforePosition(e,t,i,s,n){let c=t[i],a=t[i+1],r=t[i+2]-c,o=t[i+3]-a,l=Math.atan2(o,r);s[n]=c+e*Math.cos(l),s[n+1]=a+e*Math.sin(l),s[n+2]=l}addAfterPosition(e,t,i,s,n){let c=t[i+2],a=t[i+3],r=c-t[i],o=a-t[i+1],l=Math.atan2(o,r);s[n]=c+e*Math.cos(l),s[n+1]=a+e*Math.sin(l),s[n+2]=l}addCurvePosition(e,t,i,s,n,c,a,r,o,l,h,f){if(e==0||isNaN(e)){l[h]=t,l[h+1]=i,l[h+2]=Math.atan2(n-i,s-t);return}let d=e*e,u=d*e,m=1-e,x=m*m,b=x*m,v=m*e,g=v*3,w=m*g,p=g*e,y=t*b+s*w+c*p+r*u,S=i*b+n*w+a*p+o*u;l[h]=y,l[h+1]=S,f&&(e<.001?l[h+2]=Math.atan2(n-i,s-t):l[h+2]=Math.atan2(S-(i*x+n*v*2+a*d),y-(t*x+s*v*2+c*d)))}},nt=Ue;nt.NONE=-1,nt.BEFORE=-2,nt.AFTER=-3,nt.epsilon=1e-5;var rs=class{constructor(e,t){if(this.darkColor=null,this.attachment=null,this.attachmentState=0,this.sequenceIndex=-1,this.deform=new Array,!e)throw new Error("data cannot be null.");if(!t)throw new Error("bone cannot be null.");this.data=e,this.bone=t,this.color=new O,this.darkColor=e.darkColor?new O:null,this.setToSetupPose()}getSkeleton(){return this.bone.skeleton}getAttachment(){return this.attachment}setAttachment(e){this.attachment!=e&&((!(e instanceof Ee)||!(this.attachment instanceof Ee)||e.timelineAttachment!=this.attachment.timelineAttachment)&&(this.deform.length=0),this.attachment=e,this.sequenceIndex=-1)}setToSetupPose(){this.color.setFromColor(this.data.color),this.darkColor&&this.darkColor.setFromColor(this.data.darkColor),this.data.attachmentName?(this.attachment=null,this.setAttachment(this.bone.skeleton.getAttachment(this.data.index,this.data.attachmentName))):this.attachment=null}},ns=class{constructor(e,t){if(this.mixRotate=0,this.mixX=0,this.mixY=0,this.mixScaleX=0,this.mixScaleY=0,this.mixShearY=0,this.temp=new Je,this.active=!1,!e)throw new Error("data cannot be null.");if(!t)throw new Error("skeleton cannot be null.");this.data=e,this.mixRotate=e.mixRotate,this.mixX=e.mixX,this.mixY=e.mixY,this.mixScaleX=e.mixScaleX,this.mixScaleY=e.mixScaleY,this.mixShearY=e.mixShearY,this.bones=new Array;for(let s=0;s<e.bones.length;s++){let n=t.findBone(e.bones[s].name);if(!n)throw new Error(`Couldn't find bone ${e.bones[s].name}.`);this.bones.push(n)}let i=t.findBone(e.target.name);if(!i)throw new Error(`Couldn't find target bone ${e.target.name}.`);this.target=i}isActive(){return this.active}update(){this.mixRotate==0&&this.mixX==0&&this.mixY==0&&this.mixScaleX==0&&this.mixScaleX==0&&this.mixShearY==0||(this.data.local?this.data.relative?this.applyRelativeLocal():this.applyAbsoluteLocal():this.data.relative?this.applyRelativeWorld():this.applyAbsoluteWorld())}applyAbsoluteWorld(){let e=this.mixRotate,t=this.mixX,i=this.mixY,s=this.mixScaleX,n=this.mixScaleY,c=this.mixShearY,a=t!=0||i!=0,r=this.target,o=r.a,l=r.b,h=r.c,f=r.d,d=o*f-l*h>0?R.degRad:-R.degRad,u=this.data.offsetRotation*d,m=this.data.offsetShearY*d,x=this.bones;for(let b=0,v=x.length;b<v;b++){let g=x[b];if(e!=0){let w=g.a,p=g.b,y=g.c,S=g.d,A=Math.atan2(h,o)-Math.atan2(y,w)+u;A>R.PI?A-=R.PI2:A<-R.PI&&(A+=R.PI2),A*=e;let I=Math.cos(A),E=Math.sin(A);g.a=I*w-E*y,g.b=I*p-E*S,g.c=E*w+I*y,g.d=E*p+I*S}if(a){let w=this.temp;r.localToWorld(w.set(this.data.offsetX,this.data.offsetY)),g.worldX+=(w.x-g.worldX)*t,g.worldY+=(w.y-g.worldY)*i}if(s!=0){let w=Math.sqrt(g.a*g.a+g.c*g.c);w!=0&&(w=(w+(Math.sqrt(o*o+h*h)-w+this.data.offsetScaleX)*s)/w),g.a*=w,g.c*=w}if(n!=0){let w=Math.sqrt(g.b*g.b+g.d*g.d);w!=0&&(w=(w+(Math.sqrt(l*l+f*f)-w+this.data.offsetScaleY)*n)/w),g.b*=w,g.d*=w}if(c>0){let w=g.b,p=g.d,y=Math.atan2(p,w),S=Math.atan2(f,l)-Math.atan2(h,o)-(y-Math.atan2(g.c,g.a));S>R.PI?S-=R.PI2:S<-R.PI&&(S+=R.PI2),S=y+(S+m)*c;let A=Math.sqrt(w*w+p*p);g.b=Math.cos(S)*A,g.d=Math.sin(S)*A}g.updateAppliedTransform()}}applyRelativeWorld(){let e=this.mixRotate,t=this.mixX,i=this.mixY,s=this.mixScaleX,n=this.mixScaleY,c=this.mixShearY,a=t!=0||i!=0,r=this.target,o=r.a,l=r.b,h=r.c,f=r.d,d=o*f-l*h>0?R.degRad:-R.degRad,u=this.data.offsetRotation*d,m=this.data.offsetShearY*d,x=this.bones;for(let b=0,v=x.length;b<v;b++){let g=x[b];if(e!=0){let w=g.a,p=g.b,y=g.c,S=g.d,A=Math.atan2(h,o)+u;A>R.PI?A-=R.PI2:A<-R.PI&&(A+=R.PI2),A*=e;let I=Math.cos(A),E=Math.sin(A);g.a=I*w-E*y,g.b=I*p-E*S,g.c=E*w+I*y,g.d=E*p+I*S}if(a){let w=this.temp;r.localToWorld(w.set(this.data.offsetX,this.data.offsetY)),g.worldX+=w.x*t,g.worldY+=w.y*i}if(s!=0){let w=(Math.sqrt(o*o+h*h)-1+this.data.offsetScaleX)*s+1;g.a*=w,g.c*=w}if(n!=0){let w=(Math.sqrt(l*l+f*f)-1+this.data.offsetScaleY)*n+1;g.b*=w,g.d*=w}if(c>0){let w=Math.atan2(f,l)-Math.atan2(h,o);w>R.PI?w-=R.PI2:w<-R.PI&&(w+=R.PI2);let p=g.b,y=g.d;w=Math.atan2(y,p)+(w-R.PI/2+m)*c;let S=Math.sqrt(p*p+y*y);g.b=Math.cos(w)*S,g.d=Math.sin(w)*S}g.updateAppliedTransform()}}applyAbsoluteLocal(){let e=this.mixRotate,t=this.mixX,i=this.mixY,s=this.mixScaleX,n=this.mixScaleY,c=this.mixShearY,a=this.target,r=this.bones;for(let o=0,l=r.length;o<l;o++){let h=r[o],f=h.arotation;if(e!=0){let v=a.arotation-f+this.data.offsetRotation;v-=(16384-(16384.499999999996-v/360|0))*360,f+=v*e}let d=h.ax,u=h.ay;d+=(a.ax-d+this.data.offsetX)*t,u+=(a.ay-u+this.data.offsetY)*i;let m=h.ascaleX,x=h.ascaleY;s!=0&&m!=0&&(m=(m+(a.ascaleX-m+this.data.offsetScaleX)*s)/m),n!=0&&x!=0&&(x=(x+(a.ascaleY-x+this.data.offsetScaleY)*n)/x);let b=h.ashearY;if(c!=0){let v=a.ashearY-b+this.data.offsetShearY;v-=(16384-(16384.499999999996-v/360|0))*360,b+=v*c}h.updateWorldTransformWith(d,u,f,m,x,h.ashearX,b)}}applyRelativeLocal(){let e=this.mixRotate,t=this.mixX,i=this.mixY,s=this.mixScaleX,n=this.mixScaleY,c=this.mixShearY,a=this.target,r=this.bones;for(let o=0,l=r.length;o<l;o++){let h=r[o],f=h.arotation+(a.arotation+this.data.offsetRotation)*e,d=h.ax+(a.ax+this.data.offsetX)*t,u=h.ay+(a.ay+this.data.offsetY)*i,m=h.ascaleX*((a.ascaleX-1+this.data.offsetScaleX)*s+1),x=h.ascaleY*((a.ascaleY-1+this.data.offsetScaleY)*n+1),b=h.ashearY+(a.ashearY+this.data.offsetShearY)*c;h.updateWorldTransformWith(d,u,f,m,x,h.ashearX,b)}}},Ls=class{constructor(e){if(this._updateCache=new Array,this.skin=null,this.scaleX=1,this.scaleY=1,this.x=0,this.y=0,!e)throw new Error("data cannot be null.");this.data=e,this.bones=new Array;for(let t=0;t<e.bones.length;t++){let i=e.bones[t],s;if(!i.parent)s=new wi(i,this,null);else{let n=this.bones[i.parent.index];s=new wi(i,this,n),n.children.push(s)}this.bones.push(s)}this.slots=new Array,this.drawOrder=new Array;for(let t=0;t<e.slots.length;t++){let i=e.slots[t],s=this.bones[i.boneData.index],n=new rs(i,s);this.slots.push(n),this.drawOrder.push(n)}this.ikConstraints=new Array;for(let t=0;t<e.ikConstraints.length;t++){let i=e.ikConstraints[t];this.ikConstraints.push(new ss(i,this))}this.transformConstraints=new Array;for(let t=0;t<e.transformConstraints.length;t++){let i=e.transformConstraints[t];this.transformConstraints.push(new ns(i,this))}this.pathConstraints=new Array;for(let t=0;t<e.pathConstraints.length;t++){let i=e.pathConstraints[t];this.pathConstraints.push(new nt(i,this))}this.color=new O(1,1,1,1),this.updateCache()}updateCache(){let e=this._updateCache;e.length=0;let t=this.bones;for(let l=0,h=t.length;l<h;l++){let f=t[l];f.sorted=f.data.skinRequired,f.active=!f.sorted}if(this.skin){let l=this.skin.bones;for(let h=0,f=this.skin.bones.length;h<f;h++){let d=this.bones[l[h].index];do d.sorted=!1,d.active=!0,d=d.parent;while(d)}}let i=this.ikConstraints,s=this.transformConstraints,n=this.pathConstraints,c=i.length,a=s.length,r=n.length,o=c+a+r;e:for(let l=0;l<o;l++){for(let h=0;h<c;h++){let f=i[h];if(f.data.order==l){this.sortIkConstraint(f);continue e}}for(let h=0;h<a;h++){let f=s[h];if(f.data.order==l){this.sortTransformConstraint(f);continue e}}for(let h=0;h<r;h++){let f=n[h];if(f.data.order==l){this.sortPathConstraint(f);continue e}}}for(let l=0,h=t.length;l<h;l++)this.sortBone(t[l])}sortIkConstraint(e){if(e.active=e.target.isActive()&&(!e.data.skinRequired||this.skin&&B.contains(this.skin.constraints,e.data,!0)),!e.active)return;let t=e.target;this.sortBone(t);let i=e.bones,s=i[0];if(this.sortBone(s),i.length==1)this._updateCache.push(e),this.sortReset(s.children);else{let n=i[i.length-1];this.sortBone(n),this._updateCache.push(e),this.sortReset(s.children),n.sorted=!0}}sortPathConstraint(e){if(e.active=e.target.bone.isActive()&&(!e.data.skinRequired||this.skin&&B.contains(this.skin.constraints,e.data,!0)),!e.active)return;let t=e.target,i=t.data.index,s=t.bone;this.skin&&this.sortPathConstraintAttachment(this.skin,i,s),this.data.defaultSkin&&this.data.defaultSkin!=this.skin&&this.sortPathConstraintAttachment(this.data.defaultSkin,i,s);for(let r=0,o=this.data.skins.length;r<o;r++)this.sortPathConstraintAttachment(this.data.skins[r],i,s);let n=t.getAttachment();n instanceof tt&&this.sortPathConstraintAttachmentWith(n,s);let c=e.bones,a=c.length;for(let r=0;r<a;r++)this.sortBone(c[r]);this._updateCache.push(e);for(let r=0;r<a;r++)this.sortReset(c[r].children);for(let r=0;r<a;r++)c[r].sorted=!0}sortTransformConstraint(e){if(e.active=e.target.isActive()&&(!e.data.skinRequired||this.skin&&B.contains(this.skin.constraints,e.data,!0)),!e.active)return;this.sortBone(e.target);let t=e.bones,i=t.length;if(e.data.local)for(let s=0;s<i;s++){let n=t[s];this.sortBone(n.parent),this.sortBone(n)}else for(let s=0;s<i;s++)this.sortBone(t[s]);this._updateCache.push(e);for(let s=0;s<i;s++)this.sortReset(t[s].children);for(let s=0;s<i;s++)t[s].sorted=!0}sortPathConstraintAttachment(e,t,i){let s=e.attachments[t];if(!!s)for(let n in s)this.sortPathConstraintAttachmentWith(s[n],i)}sortPathConstraintAttachmentWith(e,t){if(!(e instanceof tt))return;let i=e.bones;if(!i)this.sortBone(t);else{let s=this.bones;for(let n=0,c=i.length;n<c;){let a=i[n++];for(a+=n;n<a;)this.sortBone(s[i[n++]])}}}sortBone(e){if(!e||e.sorted)return;let t=e.parent;t&&this.sortBone(t),e.sorted=!0,this._updateCache.push(e)}sortReset(e){for(let t=0,i=e.length;t<i;t++){let s=e[t];!s.active||(s.sorted&&this.sortReset(s.children),s.sorted=!1)}}updateWorldTransform(){let e=this.bones;for(let i=0,s=e.length;i<s;i++){let n=e[i];n.ax=n.x,n.ay=n.y,n.arotation=n.rotation,n.ascaleX=n.scaleX,n.ascaleY=n.scaleY,n.ashearX=n.shearX,n.ashearY=n.shearY}let t=this._updateCache;for(let i=0,s=t.length;i<s;i++)t[i].update()}updateWorldTransformWith(e){let t=this.getRootBone();if(!t)throw new Error("Root bone must not be null.");let i=e.a,s=e.b,n=e.c,c=e.d;t.worldX=i*this.x+s*this.y+e.worldX,t.worldY=n*this.x+c*this.y+e.worldY;let a=t.rotation+90+t.shearY,r=R.cosDeg(t.rotation+t.shearX)*t.scaleX,o=R.cosDeg(a)*t.scaleY,l=R.sinDeg(t.rotation+t.shearX)*t.scaleX,h=R.sinDeg(a)*t.scaleY;t.a=(i*r+s*l)*this.scaleX,t.b=(i*o+s*h)*this.scaleX,t.c=(n*r+c*l)*this.scaleY,t.d=(n*o+c*h)*this.scaleY;let f=this._updateCache;for(let d=0,u=f.length;d<u;d++){let m=f[d];m!=t&&m.update()}}setToSetupPose(){this.setBonesToSetupPose(),this.setSlotsToSetupPose()}setBonesToSetupPose(){let e=this.bones;for(let n=0,c=e.length;n<c;n++)e[n].setToSetupPose();let t=this.ikConstraints;for(let n=0,c=t.length;n<c;n++){let a=t[n];a.mix=a.data.mix,a.softness=a.data.softness,a.bendDirection=a.data.bendDirection,a.compress=a.data.compress,a.stretch=a.data.stretch}let i=this.transformConstraints;for(let n=0,c=i.length;n<c;n++){let a=i[n],r=a.data;a.mixRotate=r.mixRotate,a.mixX=r.mixX,a.mixY=r.mixY,a.mixScaleX=r.mixScaleX,a.mixScaleY=r.mixScaleY,a.mixShearY=r.mixShearY}let s=this.pathConstraints;for(let n=0,c=s.length;n<c;n++){let a=s[n],r=a.data;a.position=r.position,a.spacing=r.spacing,a.mixRotate=r.mixRotate,a.mixX=r.mixX,a.mixY=r.mixY}}setSlotsToSetupPose(){let e=this.slots;B.arrayCopy(e,0,this.drawOrder,0,e.length);for(let t=0,i=e.length;t<i;t++)e[t].setToSetupPose()}getRootBone(){return this.bones.length==0?null:this.bones[0]}findBone(e){if(!e)throw new Error("boneName cannot be null.");let t=this.bones;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.data.name==e)return n}return null}findSlot(e){if(!e)throw new Error("slotName cannot be null.");let t=this.slots;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.data.name==e)return n}return null}setSkinByName(e){let t=this.data.findSkin(e);if(!t)throw new Error("Skin not found: "+e);this.setSkin(t)}setSkin(e){if(e!=this.skin){if(e)if(this.skin)e.attachAll(this,this.skin);else{let t=this.slots;for(let i=0,s=t.length;i<s;i++){let n=t[i],c=n.data.attachmentName;if(c){let a=e.getAttachment(i,c);a&&n.setAttachment(a)}}}this.skin=e,this.updateCache()}}getAttachmentByName(e,t){let i=this.data.findSlot(e);if(!i)throw new Error(`Can't find slot with name ${e}`);return this.getAttachment(i.index,t)}getAttachment(e,t){if(!t)throw new Error("attachmentName cannot be null.");if(this.skin){let i=this.skin.getAttachment(e,t);if(i)return i}return this.data.defaultSkin?this.data.defaultSkin.getAttachment(e,t):null}setAttachment(e,t){if(!e)throw new Error("slotName cannot be null.");let i=this.slots;for(let s=0,n=i.length;s<n;s++){let c=i[s];if(c.data.name==e){let a=null;if(t&&(a=this.getAttachment(s,t),!a))throw new Error("Attachment not found: "+t+", for slot: "+e);c.setAttachment(a);return}}throw new Error("Slot not found: "+e)}findIkConstraint(e){if(!e)throw new Error("constraintName cannot be null.");let t=this.ikConstraints;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.data.name==e)return n}return null}findTransformConstraint(e){if(!e)throw new Error("constraintName cannot be null.");let t=this.transformConstraints;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.data.name==e)return n}return null}findPathConstraint(e){if(!e)throw new Error("constraintName cannot be null.");let t=this.pathConstraints;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.data.name==e)return n}return null}getBoundsRect(){let e=new Je,t=new Je;return this.getBounds(e,t),{x:e.x,y:e.y,width:t.x,height:t.y}}getBounds(e,t,i=new Array(2)){if(!e)throw new Error("offset cannot be null.");if(!t)throw new Error("size cannot be null.");let s=this.drawOrder,n=Number.POSITIVE_INFINITY,c=Number.POSITIVE_INFINITY,a=Number.NEGATIVE_INFINITY,r=Number.NEGATIVE_INFINITY;for(let o=0,l=s.length;o<l;o++){let h=s[o];if(!h.bone.active)continue;let f=0,d=null,u=h.getAttachment();if(u instanceof ne)f=8,d=B.setArraySize(i,f,0),u.computeWorldVertices(h,d,0,2);else if(u instanceof Ge){let m=u;f=m.worldVerticesLength,d=B.setArraySize(i,f,0),m.computeWorldVertices(h,0,f,d,0,2)}if(d)for(let m=0,x=d.length;m<x;m+=2){let b=d[m],v=d[m+1];n=Math.min(n,b),c=Math.min(c,v),a=Math.max(a,b),r=Math.max(r,v)}}e.set(n,c),t.set(a-n,r-c)}},Si=class{constructor(){this.name=null,this.bones=new Array,this.slots=new Array,this.skins=new Array,this.defaultSkin=null,this.events=new Array,this.animations=new Array,this.ikConstraints=new Array,this.transformConstraints=new Array,this.pathConstraints=new Array,this.x=0,this.y=0,this.width=0,this.height=0,this.version=null,this.hash=null,this.fps=0,this.imagesPath=null,this.audioPath=null}findBone(e){if(!e)throw new Error("boneName cannot be null.");let t=this.bones;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.name==e)return n}return null}findSlot(e){if(!e)throw new Error("slotName cannot be null.");let t=this.slots;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.name==e)return n}return null}findSkin(e){if(!e)throw new Error("skinName cannot be null.");let t=this.skins;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.name==e)return n}return null}findEvent(e){if(!e)throw new Error("eventDataName cannot be null.");let t=this.events;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.name==e)return n}return null}findAnimation(e){if(!e)throw new Error("animationName cannot be null.");let t=this.animations;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.name==e)return n}return null}findIkConstraint(e){if(!e)throw new Error("constraintName cannot be null.");let t=this.ikConstraints;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.name==e)return n}return null}findTransformConstraint(e){if(!e)throw new Error("constraintName cannot be null.");let t=this.transformConstraints;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.name==e)return n}return null}findPathConstraint(e){if(!e)throw new Error("constraintName cannot be null.");let t=this.pathConstraints;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.name==e)return n}return null}},Ci=class{constructor(e=0,t,i){this.slotIndex=e,this.name=t,this.attachment=i}},Yt=class{constructor(e){if(this.attachments=new Array,this.bones=Array(),this.constraints=new Array,!e)throw new Error("name cannot be null.");this.name=e}setAttachment(e,t,i){if(!i)throw new Error("attachment cannot be null.");let s=this.attachments;e>=s.length&&(s.length=e+1),s[e]||(s[e]={}),s[e][t]=i}addSkin(e){for(let s=0;s<e.bones.length;s++){let n=e.bones[s],c=!1;for(let a=0;a<this.bones.length;a++)if(this.bones[a]==n){c=!0;break}c||this.bones.push(n)}for(let s=0;s<e.constraints.length;s++){let n=e.constraints[s],c=!1;for(let a=0;a<this.constraints.length;a++)if(this.constraints[a]==n){c=!0;break}c||this.constraints.push(n)}let t=e.getAttachments();for(let s=0;s<t.length;s++){var i=t[s];this.setAttachment(i.slotIndex,i.name,i.attachment)}}copySkin(e){for(let s=0;s<e.bones.length;s++){let n=e.bones[s],c=!1;for(let a=0;a<this.bones.length;a++)if(this.bones[a]==n){c=!0;break}c||this.bones.push(n)}for(let s=0;s<e.constraints.length;s++){let n=e.constraints[s],c=!1;for(let a=0;a<this.constraints.length;a++)if(this.constraints[a]==n){c=!0;break}c||this.constraints.push(n)}let t=e.getAttachments();for(let s=0;s<t.length;s++){var i=t[s];!i.attachment||(i.attachment instanceof Ge?(i.attachment=i.attachment.newLinkedMesh(),this.setAttachment(i.slotIndex,i.name,i.attachment)):(i.attachment=i.attachment.copy(),this.setAttachment(i.slotIndex,i.name,i.attachment)))}}getAttachment(e,t){let i=this.attachments[e];return i?i[t]:null}removeAttachment(e,t){let i=this.attachments[e];i&&delete i[t]}getAttachments(){let e=new Array;for(var t=0;t<this.attachments.length;t++){let i=this.attachments[t];if(i)for(let s in i){let n=i[s];n&&e.push(new Ci(t,s,n))}}return e}getAttachmentsForSlot(e,t){let i=this.attachments[e];if(i)for(let s in i){let n=i[s];n&&t.push(new Ci(e,s,n))}}clear(){this.attachments.length=0,this.bones.length=0,this.constraints.length=0}attachAll(e,t){let i=0;for(let s=0;s<e.slots.length;s++){let n=e.slots[s],c=n.getAttachment();if(c&&i<t.attachments.length){let a=t.attachments[i];for(let r in a){let o=a[r];if(c==o){let l=this.getAttachment(i,r);l&&n.setAttachment(l);break}}}i++}}},Ti=class{constructor(e,t,i){if(this.index=0,this.color=new O(1,1,1,1),this.darkColor=null,this.attachmentName=null,this.blendMode=pe.Normal,e<0)throw new Error("index must be >= 0.");if(!t)throw new Error("name cannot be null.");if(!i)throw new Error("boneData cannot be null.");this.index=e,this.name=t,this.boneData=i}},pe;(function(e){e[e.Normal=0]="Normal",e[e.Additive=1]="Additive",e[e.Multiply=2]="Multiply",e[e.Screen=3]="Screen"})(pe||(pe={}));var Ii=class extends Mt{constructor(e){super(e,0,!1);this.bones=new Array,this._target=null,this.mixRotate=0,this.mixX=0,this.mixY=0,this.mixScaleX=0,this.mixScaleY=0,this.mixShearY=0,this.offsetRotation=0,this.offsetX=0,this.offsetY=0,this.offsetScaleX=0,this.offsetScaleY=0,this.offsetShearY=0,this.relative=!1,this.local=!1}set target(e){this._target=e}get target(){if(this._target)return this._target;throw new Error("BoneData not set.")}},Ps=class{constructor(e){this.scale=1,this.linkedMeshes=new Array,this.attachmentLoader=e}readSkeletonData(e){let t=this.scale,i=new Si;i.name="";let s=new as(e),n=s.readInt32(),c=s.readInt32();i.hash=c==0&&n==0?null:c.toString(16)+n.toString(16),i.version=s.readString(),i.x=s.readFloat(),i.y=s.readFloat(),i.width=s.readFloat(),i.height=s.readFloat();let a=s.readBoolean();a&&(i.fps=s.readFloat(),i.imagesPath=s.readString(),i.audioPath=s.readString());let r=0;r=s.readInt(!0);for(let l=0;l<r;l++){let h=s.readString();if(!h)throw new Error("String in string table must not be null.");s.strings.push(h)}r=s.readInt(!0);for(let l=0;l<r;l++){let h=s.readString();if(!h)throw new Error("Bone name must not be null.");let f=l==0?null:i.bones[s.readInt(!0)],d=new xi(l,h,f);d.rotation=s.readFloat(),d.x=s.readFloat()*t,d.y=s.readFloat()*t,d.scaleX=s.readFloat(),d.scaleY=s.readFloat(),d.shearX=s.readFloat(),d.shearY=s.readFloat(),d.length=s.readFloat()*t,d.transformMode=s.readInt(!0),d.skinRequired=s.readBoolean(),a&&O.rgba8888ToColor(d.color,s.readInt32()),i.bones.push(d)}r=s.readInt(!0);for(let l=0;l<r;l++){let h=s.readString();if(!h)throw new Error("Slot name must not be null.");let f=i.bones[s.readInt(!0)],d=new Ti(l,h,f);O.rgba8888ToColor(d.color,s.readInt32());let u=s.readInt32();u!=-1&&O.rgb888ToColor(d.darkColor=new O,u),d.attachmentName=s.readStringRef(),d.blendMode=s.readInt(!0),i.slots.push(d)}r=s.readInt(!0);for(let l=0,h;l<r;l++){let f=s.readString();if(!f)throw new Error("IK constraint data name must not be null.");let d=new yi(f);d.order=s.readInt(!0),d.skinRequired=s.readBoolean(),h=s.readInt(!0);for(let u=0;u<h;u++)d.bones.push(i.bones[s.readInt(!0)]);d.target=i.bones[s.readInt(!0)],d.mix=s.readFloat(),d.softness=s.readFloat()*t,d.bendDirection=s.readByte(),d.compress=s.readBoolean(),d.stretch=s.readBoolean(),d.uniform=s.readBoolean(),i.ikConstraints.push(d)}r=s.readInt(!0);for(let l=0,h;l<r;l++){let f=s.readString();if(!f)throw new Error("Transform constraint data name must not be null.");let d=new Ii(f);d.order=s.readInt(!0),d.skinRequired=s.readBoolean(),h=s.readInt(!0);for(let u=0;u<h;u++)d.bones.push(i.bones[s.readInt(!0)]);d.target=i.bones[s.readInt(!0)],d.local=s.readBoolean(),d.relative=s.readBoolean(),d.offsetRotation=s.readFloat(),d.offsetX=s.readFloat()*t,d.offsetY=s.readFloat()*t,d.offsetScaleX=s.readFloat(),d.offsetScaleY=s.readFloat(),d.offsetShearY=s.readFloat(),d.mixRotate=s.readFloat(),d.mixX=s.readFloat(),d.mixY=s.readFloat(),d.mixScaleX=s.readFloat(),d.mixScaleY=s.readFloat(),d.mixShearY=s.readFloat(),i.transformConstraints.push(d)}r=s.readInt(!0);for(let l=0,h;l<r;l++){let f=s.readString();if(!f)throw new Error("Path constraint data name must not be null.");let d=new Ai(f);d.order=s.readInt(!0),d.skinRequired=s.readBoolean(),h=s.readInt(!0);for(let u=0;u<h;u++)d.bones.push(i.bones[s.readInt(!0)]);d.target=i.slots[s.readInt(!0)],d.positionMode=s.readInt(!0),d.spacingMode=s.readInt(!0),d.rotateMode=s.readInt(!0),d.offsetRotation=s.readFloat(),d.position=s.readFloat(),d.positionMode==Fe.Fixed&&(d.position*=t),d.spacing=s.readFloat(),(d.spacingMode==xe.Length||d.spacingMode==xe.Fixed)&&(d.spacing*=t),d.mixRotate=s.readFloat(),d.mixX=s.readFloat(),d.mixY=s.readFloat(),i.pathConstraints.push(d)}let o=this.readSkin(s,i,!0,a);o&&(i.defaultSkin=o,i.skins.push(o));{let l=i.skins.length;for(B.setArraySize(i.skins,r=l+s.readInt(!0));l<r;l++){let h=this.readSkin(s,i,!1,a);if(!h)throw new Error("readSkin() should not have returned null.");i.skins[l]=h}}r=this.linkedMeshes.length;for(let l=0;l<r;l++){let h=this.linkedMeshes[l],f=h.skin?i.findSkin(h.skin):i.defaultSkin;if(!f)throw new Error("Not skin found for linked mesh.");if(!h.parent)throw new Error("Linked mesh parent must not be null");let d=f.getAttachment(h.slotIndex,h.parent);if(!d)throw new Error(`Parent mesh not found: ${h.parent}`);h.mesh.timelineAttachment=h.inheritTimeline?d:h.mesh,h.mesh.setParentMesh(d),h.mesh.region!=null&&h.mesh.updateRegion()}this.linkedMeshes.length=0,r=s.readInt(!0);for(let l=0;l<r;l++){let h=s.readStringRef();if(!h)throw new Error;let f=new vi(h);f.intValue=s.readInt(!1),f.floatValue=s.readFloat(),f.stringValue=s.readString(),f.audioPath=s.readString(),f.audioPath&&(f.volume=s.readFloat(),f.balance=s.readFloat()),i.events.push(f)}r=s.readInt(!0);for(let l=0;l<r;l++){let h=s.readString();if(!h)throw new Error("Animatio name must not be null.");i.animations.push(this.readAnimation(s,h,i))}return i}readSkin(e,t,i,s){let n=null,c=0;if(i){if(c=e.readInt(!0),c==0)return null;n=new Yt("default")}else{let a=e.readStringRef();if(!a)throw new Error("Skin name must not be null.");n=new Yt(a),n.bones.length=e.readInt(!0);for(let r=0,o=n.bones.length;r<o;r++)n.bones[r]=t.bones[e.readInt(!0)];for(let r=0,o=e.readInt(!0);r<o;r++)n.constraints.push(t.ikConstraints[e.readInt(!0)]);for(let r=0,o=e.readInt(!0);r<o;r++)n.constraints.push(t.transformConstraints[e.readInt(!0)]);for(let r=0,o=e.readInt(!0);r<o;r++)n.constraints.push(t.pathConstraints[e.readInt(!0)]);c=e.readInt(!0)}for(let a=0;a<c;a++){let r=e.readInt(!0);for(let o=0,l=e.readInt(!0);o<l;o++){let h=e.readStringRef();if(!h)throw new Error("Attachment name must not be null");let f=this.readAttachment(e,t,n,r,h,s);f&&n.setAttachment(r,h,f)}}return n}readAttachment(e,t,i,s,n,c){let a=this.scale,r=e.readStringRef();switch(r||(r=n),e.readByte()){case ze.Region:{let o=e.readStringRef(),l=e.readFloat(),h=e.readFloat(),f=e.readFloat(),d=e.readFloat(),u=e.readFloat(),m=e.readFloat(),x=e.readFloat(),b=e.readInt32(),v=this.readSequence(e);o||(o=r);let g=this.attachmentLoader.newRegionAttachment(i,r,o,v);return g?(g.path=o,g.x=h*a,g.y=f*a,g.scaleX=d,g.scaleY=u,g.rotation=l,g.width=m*a,g.height=x*a,O.rgba8888ToColor(g.color,b),g.sequence=v,v==null&&g.updateRegion(),g):null}case ze.BoundingBox:{let o=e.readInt(!0),l=this.readVertices(e,o),h=c?e.readInt32():0,f=this.attachmentLoader.newBoundingBoxAttachment(i,r);return f?(f.worldVerticesLength=o<<1,f.vertices=l.vertices,f.bones=l.bones,c&&O.rgba8888ToColor(f.color,h),f):null}case ze.Mesh:{let o=e.readStringRef(),l=e.readInt32(),h=e.readInt(!0),f=this.readFloatArray(e,h<<1,1),d=this.readShortArray(e),u=this.readVertices(e,h),m=e.readInt(!0),x=this.readSequence(e),b=[],v=0,g=0;c&&(b=this.readShortArray(e),v=e.readFloat(),g=e.readFloat()),o||(o=r);let w=this.attachmentLoader.newMeshAttachment(i,r,o,x);return w?(w.path=o,O.rgba8888ToColor(w.color,l),w.bones=u.bones,w.vertices=u.vertices,w.worldVerticesLength=h<<1,w.triangles=d,w.regionUVs=f,x==null&&w.updateRegion(),w.hullLength=m<<1,w.sequence=x,c&&(w.edges=b,w.width=v*a,w.height=g*a),w):null}case ze.LinkedMesh:{let o=e.readStringRef(),l=e.readInt32(),h=e.readStringRef(),f=e.readStringRef(),d=e.readBoolean(),u=this.readSequence(e),m=0,x=0;c&&(m=e.readFloat(),x=e.readFloat()),o||(o=r);let b=this.attachmentLoader.newMeshAttachment(i,r,o,u);return b?(b.path=o,O.rgba8888ToColor(b.color,l),b.sequence=u,c&&(b.width=m*a,b.height=x*a),this.linkedMeshes.push(new Bs(b,h,s,f,d)),b):null}case ze.Path:{let o=e.readBoolean(),l=e.readBoolean(),h=e.readInt(!0),f=this.readVertices(e,h),d=B.newArray(h/3,0);for(let x=0,b=d.length;x<b;x++)d[x]=e.readFloat()*a;let u=c?e.readInt32():0,m=this.attachmentLoader.newPathAttachment(i,r);return m?(m.closed=o,m.constantSpeed=l,m.worldVerticesLength=h<<1,m.vertices=f.vertices,m.bones=f.bones,m.lengths=d,c&&O.rgba8888ToColor(m.color,u),m):null}case ze.Point:{let o=e.readFloat(),l=e.readFloat(),h=e.readFloat(),f=c?e.readInt32():0,d=this.attachmentLoader.newPointAttachment(i,r);return d?(d.x=l*a,d.y=h*a,d.rotation=o,c&&O.rgba8888ToColor(d.color,f),d):null}case ze.Clipping:{let o=e.readInt(!0),l=e.readInt(!0),h=this.readVertices(e,l),f=c?e.readInt32():0,d=this.attachmentLoader.newClippingAttachment(i,r);return d?(d.endSlot=t.slots[o],d.worldVerticesLength=l<<1,d.vertices=h.vertices,d.bones=h.bones,c&&O.rgba8888ToColor(d.color,f),d):null}}return null}readSequence(e){if(!e.readBoolean())return null;let t=new Wt(e.readInt(!0));return t.start=e.readInt(!0),t.digits=e.readInt(!0),t.setupIndex=e.readInt(!0),t}readVertices(e,t){let i=this.scale,s=t<<1,n=new Os;if(!e.readBoolean())return n.vertices=this.readFloatArray(e,s,i),n;let c=new Array,a=new Array;for(let r=0;r<t;r++){let o=e.readInt(!0);a.push(o);for(let l=0;l<o;l++)a.push(e.readInt(!0)),c.push(e.readFloat()*i),c.push(e.readFloat()*i),c.push(e.readFloat())}return n.vertices=B.toFloatArray(c),n.bones=a,n}readFloatArray(e,t,i){let s=new Array(t);if(i==1)for(let n=0;n<t;n++)s[n]=e.readFloat();else for(let n=0;n<t;n++)s[n]=e.readFloat()*i;return s}readShortArray(e){let t=e.readInt(!0),i=new Array(t);for(let s=0;s<t;s++)i[s]=e.readShort();return i}readAnimation(e,t,i){e.readInt(!0);let s=new Array,n=this.scale,c=new O,a=new O;for(let h=0,f=e.readInt(!0);h<f;h++){let d=e.readInt(!0);for(let u=0,m=e.readInt(!0);u<m;u++){let x=e.readByte(),b=e.readInt(!0),v=b-1;switch(x){case js:{let g=new Qe(b,d);for(let w=0;w<b;w++)g.setFrame(w,e.readFloat(),e.readStringRef());s.push(g);break}case Zs:{let g=e.readInt(!0),w=new $t(b,g,d),p=e.readFloat(),y=e.readUnsignedByte()/255,S=e.readUnsignedByte()/255,A=e.readUnsignedByte()/255,I=e.readUnsignedByte()/255;for(let E=0,k=0;w.setFrame(E,p,y,S,A,I),E!=v;E++){let X=e.readFloat(),F=e.readUnsignedByte()/255,L=e.readUnsignedByte()/255,T=e.readUnsignedByte()/255,M=e.readUnsignedByte()/255;switch(e.readByte()){case Xe:w.setStepped(E);break;case Le:ae(e,w,k++,E,0,p,X,y,F,1),ae(e,w,k++,E,1,p,X,S,L,1),ae(e,w,k++,E,2,p,X,A,T,1),ae(e,w,k++,E,3,p,X,I,M,1)}p=X,y=F,S=L,A=T,I=M}s.push(w);break}case Ks:{let g=e.readInt(!0),w=new ei(b,g,d),p=e.readFloat(),y=e.readUnsignedByte()/255,S=e.readUnsignedByte()/255,A=e.readUnsignedByte()/255;for(let I=0,E=0;w.setFrame(I,p,y,S,A),I!=v;I++){let k=e.readFloat(),X=e.readUnsignedByte()/255,F=e.readUnsignedByte()/255,L=e.readUnsignedByte()/255;switch(e.readByte()){case Xe:w.setStepped(I);break;case Le:ae(e,w,E++,I,0,p,k,y,X,1),ae(e,w,E++,I,1,p,k,S,F,1),ae(e,w,E++,I,2,p,k,A,L,1)}p=k,y=X,S=F,A=L}s.push(w);break}case Js:{let g=e.readInt(!0),w=new ii(b,g,d),p=e.readFloat(),y=e.readUnsignedByte()/255,S=e.readUnsignedByte()/255,A=e.readUnsignedByte()/255,I=e.readUnsignedByte()/255,E=e.readUnsignedByte()/255,k=e.readUnsignedByte()/255,X=e.readUnsignedByte()/255;for(let F=0,L=0;w.setFrame(F,p,y,S,A,I,E,k,X),F!=v;F++){let T=e.readFloat(),M=e.readUnsignedByte()/255,P=e.readUnsignedByte()/255,ee=e.readUnsignedByte()/255,te=e.readUnsignedByte()/255,le=e.readUnsignedByte()/255,se=e.readUnsignedByte()/255,he=e.readUnsignedByte()/255;switch(e.readByte()){case Xe:w.setStepped(F);break;case Le:ae(e,w,L++,F,0,p,T,y,M,1),ae(e,w,L++,F,1,p,T,S,P,1),ae(e,w,L++,F,2,p,T,A,ee,1),ae(e,w,L++,F,3,p,T,I,te,1),ae(e,w,L++,F,4,p,T,E,le,1),ae(e,w,L++,F,5,p,T,k,se,1),ae(e,w,L++,F,6,p,T,X,he,1)}p=T,y=M,S=P,A=ee,I=te,E=le,k=se,X=he}s.push(w);break}case Qs:{let g=e.readInt(!0),w=new si(b,g,d),p=e.readFloat(),y=e.readUnsignedByte()/255,S=e.readUnsignedByte()/255,A=e.readUnsignedByte()/255,I=e.readUnsignedByte()/255,E=e.readUnsignedByte()/255,k=e.readUnsignedByte()/255;for(let X=0,F=0;w.setFrame(X,p,y,S,A,I,E,k),X!=v;X++){let L=e.readFloat(),T=e.readUnsignedByte()/255,M=e.readUnsignedByte()/255,P=e.readUnsignedByte()/255,ee=e.readUnsignedByte()/255,te=e.readUnsignedByte()/255,le=e.readUnsignedByte()/255;switch(e.readByte()){case Xe:w.setStepped(X);break;case Le:ae(e,w,F++,X,0,p,L,y,T,1),ae(e,w,F++,X,1,p,L,S,M,1),ae(e,w,F++,X,2,p,L,A,P,1),ae(e,w,F++,X,3,p,L,I,ee,1),ae(e,w,F++,X,4,p,L,E,te,1),ae(e,w,F++,X,5,p,L,k,le,1)}p=L,y=T,S=M,A=P,I=ee,E=te,k=le}s.push(w);break}case $s:{let g=new ti(b,e.readInt(!0),d),w=e.readFloat(),p=e.readUnsignedByte()/255;for(let y=0,S=0;g.setFrame(y,w,p),y!=v;y++){let A=e.readFloat(),I=e.readUnsignedByte()/255;switch(e.readByte()){case Xe:g.setStepped(y);break;case Le:ae(e,g,S++,y,0,w,A,p,I,1)}w=A,p=I}s.push(g)}}}}for(let h=0,f=e.readInt(!0);h<f;h++){let d=e.readInt(!0);for(let u=0,m=e.readInt(!0);u<m;u++){let x=e.readByte(),b=e.readInt(!0),v=e.readInt(!0);switch(x){case Ds:s.push(We(e,new mt(b,v,d),1));break;case Vs:s.push(Mi(e,new _t(b,v,d),n));break;case Ns:s.push(We(e,new qt(b,v,d),n));break;case Us:s.push(We(e,new Gt(b,v,d),n));break;case zs:s.push(Mi(e,new Ht(b,v,d),1));break;case Ws:s.push(We(e,new jt(b,v,d),1));break;case _s:s.push(We(e,new Zt(b,v,d),1));break;case qs:s.push(Mi(e,new Kt(b,v,d),1));break;case Gs:s.push(We(e,new Jt(b,v,d),1));break;case Hs:s.push(We(e,new Qt(b,v,d),1))}}}for(let h=0,f=e.readInt(!0);h<f;h++){let d=e.readInt(!0),u=e.readInt(!0),m=u-1,x=new ni(u,e.readInt(!0),d),b=e.readFloat(),v=e.readFloat(),g=e.readFloat()*n;for(let w=0,p=0;x.setFrame(w,b,v,g,e.readByte(),e.readBoolean(),e.readBoolean()),w!=m;w++){let y=e.readFloat(),S=e.readFloat(),A=e.readFloat()*n;switch(e.readByte()){case Xe:x.setStepped(w);break;case Le:ae(e,x,p++,w,0,b,y,v,S,1),ae(e,x,p++,w,1,b,y,g,A,n)}b=y,v=S,g=A}s.push(x)}for(let h=0,f=e.readInt(!0);h<f;h++){let d=e.readInt(!0),u=e.readInt(!0),m=u-1,x=new ai(u,e.readInt(!0),d),b=e.readFloat(),v=e.readFloat(),g=e.readFloat(),w=e.readFloat(),p=e.readFloat(),y=e.readFloat(),S=e.readFloat();for(let A=0,I=0;x.setFrame(A,b,v,g,w,p,y,S),A!=m;A++){let E=e.readFloat(),k=e.readFloat(),X=e.readFloat(),F=e.readFloat(),L=e.readFloat(),T=e.readFloat(),M=e.readFloat();switch(e.readByte()){case Xe:x.setStepped(A);break;case Le:ae(e,x,I++,A,0,b,E,v,k,1),ae(e,x,I++,A,1,b,E,g,X,1),ae(e,x,I++,A,2,b,E,w,F,1),ae(e,x,I++,A,3,b,E,p,L,1),ae(e,x,I++,A,4,b,E,y,T,1),ae(e,x,I++,A,5,b,E,S,M,1)}b=E,v=k,g=X,w=F,p=L,y=T,S=M}s.push(x)}for(let h=0,f=e.readInt(!0);h<f;h++){let d=e.readInt(!0),u=i.pathConstraints[d];for(let m=0,x=e.readInt(!0);m<x;m++)switch(e.readByte()){case ir:s.push(We(e,new li(e.readInt(!0),e.readInt(!0),d),u.positionMode==Fe.Fixed?n:1));break;case sr:s.push(We(e,new oi(e.readInt(!0),e.readInt(!0),d),u.spacingMode==xe.Length||u.spacingMode==xe.Fixed?n:1));break;case rr:let b=new hi(e.readInt(!0),e.readInt(!0),d),v=e.readFloat(),g=e.readFloat(),w=e.readFloat(),p=e.readFloat();for(let y=0,S=0,A=b.getFrameCount()-1;b.setFrame(y,v,g,w,p),y!=A;y++){let I=e.readFloat(),E=e.readFloat(),k=e.readFloat(),X=e.readFloat();switch(e.readByte()){case Xe:b.setStepped(y);break;case Le:ae(e,b,S++,y,0,v,I,g,E,1),ae(e,b,S++,y,1,v,I,w,k,1),ae(e,b,S++,y,2,v,I,p,X,1)}v=I,g=E,w=k,p=X}s.push(b)}}for(let h=0,f=e.readInt(!0);h<f;h++){let d=i.skins[e.readInt(!0)];for(let u=0,m=e.readInt(!0);u<m;u++){let x=e.readInt(!0);for(let b=0,v=e.readInt(!0);b<v;b++){let g=e.readStringRef();if(!g)throw new Error("attachmentName must not be null.");let w=d.getAttachment(x,g),p=e.readByte(),y=e.readInt(!0),S=y-1;switch(p){case er:{let A=w,I=A.bones,E=A.vertices,k=I?E.length/3*2:E.length,X=e.readInt(!0),F=new ri(y,X,x,A),L=e.readFloat();for(let T=0,M=0;;T++){let P,ee=e.readInt(!0);if(ee==0)P=I?B.newFloatArray(k):E;else{P=B.newFloatArray(k);let le=e.readInt(!0);if(ee+=le,n==1)for(let se=le;se<ee;se++)P[se]=e.readFloat();else for(let se=le;se<ee;se++)P[se]=e.readFloat()*n;if(!I)for(let se=0,he=P.length;se<he;se++)P[se]+=E[se]}if(F.setFrame(T,L,P),T==S)break;let te=e.readFloat();switch(e.readByte()){case Xe:F.setStepped(T);break;case Le:ae(e,F,M++,T,0,L,te,0,1,1)}L=te}s.push(F);break}case tr:{let A=new rt(y,x,w);for(let I=0;I<y;I++){let E=e.readFloat(),k=e.readInt32();A.setFrame(I,E,_i[k&15],k>>4,e.readFloat())}s.push(A);break}}}}}let r=e.readInt(!0);if(r>0){let h=new $e(r),f=i.slots.length;for(let d=0;d<r;d++){let u=e.readFloat(),m=e.readInt(!0),x=B.newArray(f,0);for(let w=f-1;w>=0;w--)x[w]=-1;let b=B.newArray(f-m,0),v=0,g=0;for(let w=0;w<m;w++){let p=e.readInt(!0);for(;v!=p;)b[g++]=v++;x[v+e.readInt(!0)]=v++}for(;v<f;)b[g++]=v++;for(let w=f-1;w>=0;w--)x[w]==-1&&(x[w]=b[--g]);h.setFrame(d,u,x)}s.push(h)}let o=e.readInt(!0);if(o>0){let h=new gt(o);for(let f=0;f<o;f++){let d=e.readFloat(),u=i.events[e.readInt(!0)],m=new bi(d,u);m.intValue=e.readInt(!1),m.floatValue=e.readFloat(),m.stringValue=e.readBoolean()?e.readString():u.stringValue,m.data.audioPath&&(m.volume=e.readFloat(),m.balance=e.readFloat()),h.setFrame(f,m)}s.push(h)}let l=0;for(let h=0,f=s.length;h<f;h++)l=Math.max(l,s[h].getDuration());return new yt(t,s,l)}},as=class{constructor(e,t=new Array,i=0,s=new DataView(e.buffer)){this.strings=t,this.index=i,this.buffer=s}readByte(){return this.buffer.getInt8(this.index++)}readUnsignedByte(){return this.buffer.getUint8(this.index++)}readShort(){let e=this.buffer.getInt16(this.index);return this.index+=2,e}readInt32(){let e=this.buffer.getInt32(this.index);return this.index+=4,e}readInt(e){let t=this.readByte(),i=t&127;return(t&128)!=0&&(t=this.readByte(),i|=(t&127)<<7,(t&128)!=0&&(t=this.readByte(),i|=(t&127)<<14,(t&128)!=0&&(t=this.readByte(),i|=(t&127)<<21,(t&128)!=0&&(t=this.readByte(),i|=(t&127)<<28)))),e?i:i>>>1^-(i&1)}readStringRef(){let e=this.readInt(!0);return e==0?null:this.strings[e-1]}readString(){let e=this.readInt(!0);switch(e){case 0:return null;case 1:return""}e--;let t="",i=0;for(let s=0;s<e;){let n=this.readUnsignedByte();switch(n>>4){case 12:case 13:t+=String.fromCharCode((n&31)<<6|this.readByte()&63),s+=2;break;case 14:t+=String.fromCharCode((n&15)<<12|(this.readByte()&63)<<6|this.readByte()&63),s+=3;break;default:t+=String.fromCharCode(n),s++}}return t}readFloat(){let e=this.buffer.getFloat32(this.index);return this.index+=4,e}readBoolean(){return this.readByte()!=0}},Bs=class{constructor(e,t,i,s,n){this.mesh=e,this.skin=t,this.slotIndex=i,this.parent=s,this.inheritTimeline=n}},Os=class{constructor(e=null,t=null){this.bones=e,this.vertices=t}},ze;(function(e){e[e.Region=0]="Region",e[e.BoundingBox=1]="BoundingBox",e[e.Mesh=2]="Mesh",e[e.LinkedMesh=3]="LinkedMesh",e[e.Path=4]="Path",e[e.Point=5]="Point",e[e.Clipping=6]="Clipping"})(ze||(ze={}));function We(e,t,i){let s=e.readFloat(),n=e.readFloat()*i;for(let c=0,a=0,r=t.getFrameCount()-1;t.setFrame(c,s,n),c!=r;c++){let o=e.readFloat(),l=e.readFloat()*i;switch(e.readByte()){case Xe:t.setStepped(c);break;case Le:ae(e,t,a++,c,0,s,o,n,l,i)}s=o,n=l}return t}function Mi(e,t,i){let s=e.readFloat(),n=e.readFloat()*i,c=e.readFloat()*i;for(let a=0,r=0,o=t.getFrameCount()-1;t.setFrame(a,s,n,c),a!=o;a++){let l=e.readFloat(),h=e.readFloat()*i,f=e.readFloat()*i;switch(e.readByte()){case Xe:t.setStepped(a);break;case Le:ae(e,t,r++,a,0,s,l,n,h,i),ae(e,t,r++,a,1,s,l,c,f,i)}s=l,n=h,c=f}return t}function ae(e,t,i,s,n,c,a,r,o,l){t.setBezier(i,s,n,c,r,e.readFloat(),e.readFloat()*l,e.readFloat(),e.readFloat()*l,a,o)}var Ds=0,Vs=1,Ns=2,Us=3,zs=4,Ws=5,_s=6,qs=7,Gs=8,Hs=9,js=0,Zs=1,Ks=2,Js=3,Qs=4,$s=5,er=0,tr=1,ir=0,sr=1,rr=2,Xe=1,Le=2,ls=class{constructor(){this.minX=0,this.minY=0,this.maxX=0,this.maxY=0,this.boundingBoxes=new Array,this.polygons=new Array,this.polygonPool=new ut(()=>B.newFloatArray(16))}update(e,t){if(!e)throw new Error("skeleton cannot be null.");let i=this.boundingBoxes,s=this.polygons,n=this.polygonPool,c=e.slots,a=c.length;i.length=0,n.freeAll(s),s.length=0;for(let r=0;r<a;r++){let o=c[r];if(!o.bone.active)continue;let l=o.getAttachment();if(l instanceof It){let h=l;i.push(h);let f=n.obtain();f.length!=h.worldVerticesLength&&(f=B.newFloatArray(h.worldVerticesLength)),s.push(f),h.computeWorldVertices(o,0,h.worldVerticesLength,f,0,2)}}t?this.aabbCompute():(this.minX=Number.POSITIVE_INFINITY,this.minY=Number.POSITIVE_INFINITY,this.maxX=Number.NEGATIVE_INFINITY,this.maxY=Number.NEGATIVE_INFINITY)}aabbCompute(){let e=Number.POSITIVE_INFINITY,t=Number.POSITIVE_INFINITY,i=Number.NEGATIVE_INFINITY,s=Number.NEGATIVE_INFINITY,n=this.polygons;for(let c=0,a=n.length;c<a;c++){let r=n[c],o=r;for(let l=0,h=r.length;l<h;l+=2){let f=o[l],d=o[l+1];e=Math.min(e,f),t=Math.min(t,d),i=Math.max(i,f),s=Math.max(s,d)}}this.minX=e,this.minY=t,this.maxX=i,this.maxY=s}aabbContainsPoint(e,t){return e>=this.minX&&e<=this.maxX&&t>=this.minY&&t<=this.maxY}aabbIntersectsSegment(e,t,i,s){let n=this.minX,c=this.minY,a=this.maxX,r=this.maxY;if(e<=n&&i<=n||t<=c&&s<=c||e>=a&&i>=a||t>=r&&s>=r)return!1;let o=(s-t)/(i-e),l=o*(n-e)+t;if(l>c&&l<r||(l=o*(a-e)+t,l>c&&l<r))return!0;let h=(c-t)/o+e;return!!(h>n&&h<a||(h=(r-t)/o+e,h>n&&h<a))}aabbIntersectsSkeleton(e){return this.minX<e.maxX&&this.maxX>e.minX&&this.minY<e.maxY&&this.maxY>e.minY}containsPoint(e,t){let i=this.polygons;for(let s=0,n=i.length;s<n;s++)if(this.containsPointPolygon(i[s],e,t))return this.boundingBoxes[s];return null}containsPointPolygon(e,t,i){let s=e,n=e.length,c=n-2,a=!1;for(let r=0;r<n;r+=2){let o=s[r+1],l=s[c+1];if(o<i&&l>=i||l<i&&o>=i){let h=s[r];h+(i-o)/(l-o)*(s[c]-h)<t&&(a=!a)}c=r}return a}intersectsSegment(e,t,i,s){let n=this.polygons;for(let c=0,a=n.length;c<a;c++)if(this.intersectsSegmentPolygon(n[c],e,t,i,s))return this.boundingBoxes[c];return null}intersectsSegmentPolygon(e,t,i,s,n){let c=e,a=e.length,r=t-s,o=i-n,l=t*n-i*s,h=c[a-2],f=c[a-1];for(let d=0;d<a;d+=2){let u=c[d],m=c[d+1],x=h*m-f*u,b=h-u,v=f-m,g=r*v-o*b,w=(l*b-r*x)/g;if((w>=h&&w<=u||w>=u&&w<=h)&&(w>=t&&w<=s||w>=s&&w<=t)){let p=(l*v-o*x)/g;if((p>=f&&p<=m||p>=m&&p<=f)&&(p>=i&&p<=n||p>=n&&p<=i))return!0}h=u,f=m}return!1}getPolygon(e){if(!e)throw new Error("boundingBox cannot be null.");let t=this.boundingBoxes.indexOf(e);return t==-1?null:this.polygons[t]}getWidth(){return this.maxX-this.minX}getHeight(){return this.maxY-this.minY}},Te=class{constructor(){this.convexPolygons=new Array,this.convexPolygonsIndices=new Array,this.indicesArray=new Array,this.isConcaveArray=new Array,this.triangles=new Array,this.polygonPool=new ut(()=>new Array),this.polygonIndicesPool=new ut(()=>new Array)}triangulate(e){let t=e,i=e.length>>1,s=this.indicesArray;s.length=0;for(let a=0;a<i;a++)s[a]=a;let n=this.isConcaveArray;n.length=0;for(let a=0,r=i;a<r;++a)n[a]=Te.isConcave(a,i,t,s);let c=this.triangles;for(c.length=0;i>3;){let a=i-1,r=0,o=1;for(;;){e:if(!n[r]){let f=s[a]<<1,d=s[r]<<1,u=s[o]<<1,m=t[f],x=t[f+1],b=t[d],v=t[d+1],g=t[u],w=t[u+1];for(let p=(o+1)%i;p!=a;p=(p+1)%i){if(!n[p])continue;let y=s[p]<<1,S=t[y],A=t[y+1];if(Te.positiveArea(g,w,m,x,S,A)&&Te.positiveArea(m,x,b,v,S,A)&&Te.positiveArea(b,v,g,w,S,A))break e}break}if(o==0){do{if(!n[r])break;r--}while(r>0);break}a=r,r=o,o=(o+1)%i}c.push(s[(i+r-1)%i]),c.push(s[r]),c.push(s[(r+1)%i]),s.splice(r,1),n.splice(r,1),i--;let l=(i+r-1)%i,h=r==i?0:r;n[l]=Te.isConcave(l,i,t,s),n[h]=Te.isConcave(h,i,t,s)}return i==3&&(c.push(s[2]),c.push(s[0]),c.push(s[1])),c}decompose(e,t){let i=e,s=this.convexPolygons;this.polygonPool.freeAll(s),s.length=0;let n=this.convexPolygonsIndices;this.polygonIndicesPool.freeAll(n),n.length=0;let c=this.polygonIndicesPool.obtain();c.length=0;let a=this.polygonPool.obtain();a.length=0;let r=-1,o=0;for(let l=0,h=t.length;l<h;l+=3){let f=t[l]<<1,d=t[l+1]<<1,u=t[l+2]<<1,m=i[f],x=i[f+1],b=i[d],v=i[d+1],g=i[u],w=i[u+1],p=!1;if(r==f){let y=a.length-4,S=Te.winding(a[y],a[y+1],a[y+2],a[y+3],g,w),A=Te.winding(g,w,a[0],a[1],a[2],a[3]);S==o&&A==o&&(a.push(g),a.push(w),c.push(u),p=!0)}p||(a.length>0?(s.push(a),n.push(c)):(this.polygonPool.free(a),this.polygonIndicesPool.free(c)),a=this.polygonPool.obtain(),a.length=0,a.push(m),a.push(x),a.push(b),a.push(v),a.push(g),a.push(w),c=this.polygonIndicesPool.obtain(),c.length=0,c.push(f),c.push(d),c.push(u),o=Te.winding(m,x,b,v,g,w),r=f)}a.length>0&&(s.push(a),n.push(c));for(let l=0,h=s.length;l<h;l++){if(c=n[l],c.length==0)continue;let f=c[0],d=c[c.length-1];a=s[l];let u=a.length-4,m=a[u],x=a[u+1],b=a[u+2],v=a[u+3],g=a[0],w=a[1],p=a[2],y=a[3],S=Te.winding(m,x,b,v,g,w);for(let A=0;A<h;A++){if(A==l)continue;let I=n[A];if(I.length!=3)continue;let E=I[0],k=I[1],X=I[2],F=s[A],L=F[F.length-2],T=F[F.length-1];if(E!=f||k!=d)continue;let M=Te.winding(m,x,b,v,L,T),P=Te.winding(L,T,g,w,p,y);M==S&&P==S&&(F.length=0,I.length=0,a.push(L),a.push(T),c.push(X),m=b,x=v,b=L,v=T,A=0)}}for(let l=s.length-1;l>=0;l--)a=s[l],a.length==0&&(s.splice(l,1),this.polygonPool.free(a),c=n[l],n.splice(l,1),this.polygonIndicesPool.free(c));return s}static isConcave(e,t,i,s){let n=s[(t+e-1)%t]<<1,c=s[e]<<1,a=s[(e+1)%t]<<1;return!this.positiveArea(i[n],i[n+1],i[c],i[c+1],i[a],i[a+1])}static positiveArea(e,t,i,s,n,c){return e*(c-s)+i*(t-c)+n*(s-t)>=0}static winding(e,t,i,s,n,c){let a=i-e,r=s-t;return n*r-c*a+a*t-e*r>=0?1:-1}},Et=class{constructor(){this.triangulator=new Te,this.clippingPolygon=new Array,this.clipOutput=new Array,this.clippedVertices=new Array,this.clippedTriangles=new Array,this.scratch=new Array,this.clipAttachment=null,this.clippingPolygons=null}clipStart(e,t){if(this.clipAttachment)return 0;this.clipAttachment=t;let i=t.worldVerticesLength,s=B.setArraySize(this.clippingPolygon,i);t.computeWorldVertices(e,0,i,s,0,2);let n=this.clippingPolygon;Et.makeClockwise(n);let c=this.clippingPolygons=this.triangulator.decompose(n,this.triangulator.triangulate(n));for(let a=0,r=c.length;a<r;a++){let o=c[a];Et.makeClockwise(o),o.push(o[0]),o.push(o[1])}return c.length}clipEndWithSlot(e){this.clipAttachment&&this.clipAttachment.endSlot==e.data&&this.clipEnd()}clipEnd(){!this.clipAttachment||(this.clipAttachment=null,this.clippingPolygons=null,this.clippedVertices.length=0,this.clippedTriangles.length=0,this.clippingPolygon.length=0)}isClipping(){return this.clipAttachment!=null}clipTriangles(e,t,i,s,n,c,a,r){let o=this.clipOutput,l=this.clippedVertices,h=this.clippedTriangles,f=this.clippingPolygons,d=f.length,u=r?12:8,m=0;l.length=0,h.length=0;e:for(let x=0;x<s;x+=3){let b=i[x]<<1,v=e[b],g=e[b+1],w=n[b],p=n[b+1];b=i[x+1]<<1;let y=e[b],S=e[b+1],A=n[b],I=n[b+1];b=i[x+2]<<1;let E=e[b],k=e[b+1],X=n[b],F=n[b+1];for(let L=0;L<d;L++){let T=l.length;if(this.clip(v,g,y,S,E,k,f[L],o)){let M=o.length;if(M==0)continue;let P=S-k,ee=E-y,te=v-E,le=k-g,se=1/(P*te+ee*(g-k)),he=M>>1,re=this.clipOutput,ie=B.setArraySize(l,T+he*u);for(let Se=0;Se<M;Se+=2){let Be=re[Se],ve=re[Se+1];ie[T]=Be,ie[T+1]=ve,ie[T+2]=c.r,ie[T+3]=c.g,ie[T+4]=c.b,ie[T+5]=c.a;let Me=Be-E,Ye=ve-k,Ze=(P*Me+ee*Ye)*se,ct=(le*Me+te*Ye)*se,bt=1-Ze-ct;ie[T+6]=w*Ze+A*ct+X*bt,ie[T+7]=p*Ze+I*ct+F*bt,r&&(ie[T+8]=a.r,ie[T+9]=a.g,ie[T+10]=a.b,ie[T+11]=a.a),T+=u}T=h.length;let de=B.setArraySize(h,T+3*(he-2));he--;for(let Se=1;Se<he;Se++)de[T]=m,de[T+1]=m+Se,de[T+2]=m+Se+1,T+=3;m+=he+1}else{let M=B.setArraySize(l,T+3*u);M[T]=v,M[T+1]=g,M[T+2]=c.r,M[T+3]=c.g,M[T+4]=c.b,M[T+5]=c.a,r?(M[T+6]=w,M[T+7]=p,M[T+8]=a.r,M[T+9]=a.g,M[T+10]=a.b,M[T+11]=a.a,M[T+12]=y,M[T+13]=S,M[T+14]=c.r,M[T+15]=c.g,M[T+16]=c.b,M[T+17]=c.a,M[T+18]=A,M[T+19]=I,M[T+20]=a.r,M[T+21]=a.g,M[T+22]=a.b,M[T+23]=a.a,M[T+24]=E,M[T+25]=k,M[T+26]=c.r,M[T+27]=c.g,M[T+28]=c.b,M[T+29]=c.a,M[T+30]=X,M[T+31]=F,M[T+32]=a.r,M[T+33]=a.g,M[T+34]=a.b,M[T+35]=a.a):(M[T+6]=w,M[T+7]=p,M[T+8]=y,M[T+9]=S,M[T+10]=c.r,M[T+11]=c.g,M[T+12]=c.b,M[T+13]=c.a,M[T+14]=A,M[T+15]=I,M[T+16]=E,M[T+17]=k,M[T+18]=c.r,M[T+19]=c.g,M[T+20]=c.b,M[T+21]=c.a,M[T+22]=X,M[T+23]=F),T=h.length;let P=B.setArraySize(h,T+3);P[T]=m,P[T+1]=m+1,P[T+2]=m+2,m+=3;continue e}}}}clip(e,t,i,s,n,c,a,r){let o=r,l=!1,h;a.length%4>=2?(h=r,r=this.scratch):h=this.scratch,h.length=0,h.push(e),h.push(t),h.push(i),h.push(s),h.push(n),h.push(c),h.push(e),h.push(t),r.length=0;let f=a,d=a.length-4;for(let u=0;;u+=2){let m=f[u],x=f[u+1],b=f[u+2],v=f[u+3],g=m-b,w=x-v,p=h,y=h.length-2,S=r.length;for(let I=0;I<y;I+=2){let E=p[I],k=p[I+1],X=p[I+2],F=p[I+3],L=g*(F-v)-w*(X-b)>0;if(g*(k-v)-w*(E-b)>0){if(L){r.push(X),r.push(F);continue}let T=F-k,M=X-E,P=T*(b-m)-M*(v-x);if(Math.abs(P)>1e-6){let ee=(M*(x-k)-T*(m-E))/P;r.push(m+(b-m)*ee),r.push(x+(v-x)*ee)}else r.push(m),r.push(x)}else if(L){let T=F-k,M=X-E,P=T*(b-m)-M*(v-x);if(Math.abs(P)>1e-6){let ee=(M*(x-k)-T*(m-E))/P;r.push(m+(b-m)*ee),r.push(x+(v-x)*ee)}else r.push(m),r.push(x);r.push(X),r.push(F)}l=!0}if(S==r.length)return o.length=0,!0;if(r.push(r[0]),r.push(r[1]),u==d)break;let A=r;r=h,r.length=0,h=A}if(o!=r){o.length=0;for(let u=0,m=r.length-2;u<m;u++)o[u]=r[u]}else o.length=o.length-2;return l}static makeClockwise(e){let t=e,i=e.length,s=t[i-2]*t[1]-t[0]*t[i-1],n=0,c=0,a=0,r=0;for(let o=0,l=i-3;o<l;o+=2)n=t[o],c=t[o+1],a=t[o+2],r=t[o+3],s+=n*r-a*c;if(!(s<0))for(let o=0,l=i-2,h=i>>1;o<h;o+=2){let f=t[o],d=t[o+1],u=l-o;t[o]=t[u],t[o+1]=t[u+1],t[u]=f,t[u+1]=d}}},nr=class{constructor(e){this.scale=1,this.linkedMeshes=new Array,this.attachmentLoader=e}readSkeletonData(e){let t=this.scale,i=new Si,s=typeof e=="string"?JSON.parse(e):e,n=s.skeleton;if(n&&(i.hash=n.hash,i.version=n.spine,i.x=n.x,i.y=n.y,i.width=n.width,i.height=n.height,i.fps=n.fps,i.imagesPath=n.images),s.bones)for(let c=0;c<s.bones.length;c++){let a=s.bones[c],r=null,o=Y(a,"parent",null);o&&(r=i.findBone(o));let l=new xi(i.bones.length,a.name,r);l.length=Y(a,"length",0)*t,l.x=Y(a,"x",0)*t,l.y=Y(a,"y",0)*t,l.rotation=Y(a,"rotation",0),l.scaleX=Y(a,"scaleX",1),l.scaleY=Y(a,"scaleY",1),l.shearX=Y(a,"shearX",0),l.shearY=Y(a,"shearY",0),l.transformMode=B.enumValue(ge,Y(a,"transform","Normal")),l.skinRequired=Y(a,"skin",!1);let h=Y(a,"color",null);h&&l.color.setFromString(h),i.bones.push(l)}if(s.slots)for(let c=0;c<s.slots.length;c++){let a=s.slots[c],r=i.findBone(a.bone);if(!r)throw new Error(`Couldn't find bone ${a.bone} for slot ${a.name}`);let o=new Ti(i.slots.length,a.name,r),l=Y(a,"color",null);l&&o.color.setFromString(l);let h=Y(a,"dark",null);h&&(o.darkColor=O.fromString(h)),o.attachmentName=Y(a,"attachment",null),o.blendMode=B.enumValue(pe,Y(a,"blend","normal")),i.slots.push(o)}if(s.ik)for(let c=0;c<s.ik.length;c++){let a=s.ik[c],r=new yi(a.name);r.order=Y(a,"order",0),r.skinRequired=Y(a,"skin",!1);for(let l=0;l<a.bones.length;l++){let h=i.findBone(a.bones[l]);if(!h)throw new Error(`Couldn't find bone ${a.bones[l]} for IK constraint ${a.name}.`);r.bones.push(h)}let o=i.findBone(a.target);if(!o)throw new Error(`Couldn't find target bone ${a.target} for IK constraint ${a.name}.`);r.target=o,r.mix=Y(a,"mix",1),r.softness=Y(a,"softness",0)*t,r.bendDirection=Y(a,"bendPositive",!0)?1:-1,r.compress=Y(a,"compress",!1),r.stretch=Y(a,"stretch",!1),r.uniform=Y(a,"uniform",!1),i.ikConstraints.push(r)}if(s.transform)for(let c=0;c<s.transform.length;c++){let a=s.transform[c],r=new Ii(a.name);r.order=Y(a,"order",0),r.skinRequired=Y(a,"skin",!1);for(let h=0;h<a.bones.length;h++){let f=a.bones[h],d=i.findBone(f);if(!d)throw new Error(`Couldn't find bone ${f} for transform constraint ${a.name}.`);r.bones.push(d)}let o=a.target,l=i.findBone(o);if(!l)throw new Error(`Couldn't find target bone ${o} for transform constraint ${a.name}.`);r.target=l,r.local=Y(a,"local",!1),r.relative=Y(a,"relative",!1),r.offsetRotation=Y(a,"rotation",0),r.offsetX=Y(a,"x",0)*t,r.offsetY=Y(a,"y",0)*t,r.offsetScaleX=Y(a,"scaleX",0),r.offsetScaleY=Y(a,"scaleY",0),r.offsetShearY=Y(a,"shearY",0),r.mixRotate=Y(a,"mixRotate",1),r.mixX=Y(a,"mixX",1),r.mixY=Y(a,"mixY",r.mixX),r.mixScaleX=Y(a,"mixScaleX",1),r.mixScaleY=Y(a,"mixScaleY",r.mixScaleX),r.mixShearY=Y(a,"mixShearY",1),i.transformConstraints.push(r)}if(s.path)for(let c=0;c<s.path.length;c++){let a=s.path[c],r=new Ai(a.name);r.order=Y(a,"order",0),r.skinRequired=Y(a,"skin",!1);for(let h=0;h<a.bones.length;h++){let f=a.bones[h],d=i.findBone(f);if(!d)throw new Error(`Couldn't find bone ${f} for path constraint ${a.name}.`);r.bones.push(d)}let o=a.target,l=i.findSlot(o);if(!l)throw new Error(`Couldn't find target slot ${o} for path constraint ${a.name}.`);r.target=l,r.positionMode=B.enumValue(Fe,Y(a,"positionMode","Percent")),r.spacingMode=B.enumValue(xe,Y(a,"spacingMode","Length")),r.rotateMode=B.enumValue(He,Y(a,"rotateMode","Tangent")),r.offsetRotation=Y(a,"rotation",0),r.position=Y(a,"position",0),r.positionMode==Fe.Fixed&&(r.position*=t),r.spacing=Y(a,"spacing",0),(r.spacingMode==xe.Length||r.spacingMode==xe.Fixed)&&(r.spacing*=t),r.mixRotate=Y(a,"mixRotate",1),r.mixX=Y(a,"mixX",1),r.mixY=Y(a,"mixY",r.mixX),i.pathConstraints.push(r)}if(s.skins)for(let c=0;c<s.skins.length;c++){let a=s.skins[c],r=new Yt(a.name);if(a.bones)for(let o=0;o<a.bones.length;o++){let l=a.bones[o],h=i.findBone(l);if(!h)throw new Error(`Couldn't find bone ${l} for skin ${a.name}.`);r.bones.push(h)}if(a.ik)for(let o=0;o<a.ik.length;o++){let l=a.ik[o],h=i.findIkConstraint(l);if(!h)throw new Error(`Couldn't find IK constraint ${l} for skin ${a.name}.`);r.constraints.push(h)}if(a.transform)for(let o=0;o<a.transform.length;o++){let l=a.transform[o],h=i.findTransformConstraint(l);if(!h)throw new Error(`Couldn't find transform constraint ${l} for skin ${a.name}.`);r.constraints.push(h)}if(a.path)for(let o=0;o<a.path.length;o++){let l=a.path[o],h=i.findPathConstraint(l);if(!h)throw new Error(`Couldn't find path constraint ${l} for skin ${a.name}.`);r.constraints.push(h)}for(let o in a.attachments){let l=i.findSlot(o);if(!l)throw new Error(`Couldn't find slot ${o} for skin ${a.name}.`);let h=a.attachments[o];for(let f in h){let d=this.readAttachment(h[f],r,l.index,f,i);d&&r.setAttachment(l.index,f,d)}}i.skins.push(r),r.name=="default"&&(i.defaultSkin=r)}for(let c=0,a=this.linkedMeshes.length;c<a;c++){let r=this.linkedMeshes[c],o=r.skin?i.findSkin(r.skin):i.defaultSkin;if(!o)throw new Error(`Skin not found: ${r.skin}`);let l=o.getAttachment(r.slotIndex,r.parent);if(!l)throw new Error(`Parent mesh not found: ${r.parent}`);r.mesh.timelineAttachment=r.inheritTimeline?l:r.mesh,r.mesh.setParentMesh(l),r.mesh.region!=null&&r.mesh.updateRegion()}if(this.linkedMeshes.length=0,s.events)for(let c in s.events){let a=s.events[c],r=new vi(c);r.intValue=Y(a,"int",0),r.floatValue=Y(a,"float",0),r.stringValue=Y(a,"string",""),r.audioPath=Y(a,"audio",null),r.audioPath&&(r.volume=Y(a,"volume",1),r.balance=Y(a,"balance",0)),i.events.push(r)}if(s.animations)for(let c in s.animations){let a=s.animations[c];this.readAnimation(a,c,i)}return i}readAttachment(e,t,i,s,n){let c=this.scale;switch(s=Y(e,"name",s),Y(e,"type","region")){case"region":{let a=Y(e,"path",s),r=this.readSequence(Y(e,"sequence",null)),o=this.attachmentLoader.newRegionAttachment(t,s,a,r);if(!o)return null;o.path=a,o.x=Y(e,"x",0)*c,o.y=Y(e,"y",0)*c,o.scaleX=Y(e,"scaleX",1),o.scaleY=Y(e,"scaleY",1),o.rotation=Y(e,"rotation",0),o.width=e.width*c,o.height=e.height*c,o.sequence=r;let l=Y(e,"color",null);return l&&o.color.setFromString(l),o.region!=null&&o.updateRegion(),o}case"boundingbox":{let a=this.attachmentLoader.newBoundingBoxAttachment(t,s);if(!a)return null;this.readVertices(e,a,e.vertexCount<<1);let r=Y(e,"color",null);return r&&a.color.setFromString(r),a}case"mesh":case"linkedmesh":{let a=Y(e,"path",s),r=this.readSequence(Y(e,"sequence",null)),o=this.attachmentLoader.newMeshAttachment(t,s,a,r);if(!o)return null;o.path=a;let l=Y(e,"color",null);l&&o.color.setFromString(l),o.width=Y(e,"width",0)*c,o.height=Y(e,"height",0)*c,o.sequence=r;let h=Y(e,"parent",null);if(h)return this.linkedMeshes.push(new ar(o,Y(e,"skin",null),i,h,Y(e,"timelines",!0))),o;let f=e.uvs;return this.readVertices(e,o,f.length),o.triangles=e.triangles,o.regionUVs=f,o.region!=null&&o.updateRegion(),o.edges=Y(e,"edges",null),o.hullLength=Y(e,"hull",0)*2,o}case"path":{let a=this.attachmentLoader.newPathAttachment(t,s);if(!a)return null;a.closed=Y(e,"closed",!1),a.constantSpeed=Y(e,"constantSpeed",!0);let r=e.vertexCount;this.readVertices(e,a,r<<1);let o=B.newArray(r/3,0);for(let h=0;h<e.lengths.length;h++)o[h]=e.lengths[h]*c;a.lengths=o;let l=Y(e,"color",null);return l&&a.color.setFromString(l),a}case"point":{let a=this.attachmentLoader.newPointAttachment(t,s);if(!a)return null;a.x=Y(e,"x",0)*c,a.y=Y(e,"y",0)*c,a.rotation=Y(e,"rotation",0);let r=Y(e,"color",null);return r&&a.color.setFromString(r),a}case"clipping":{let a=this.attachmentLoader.newClippingAttachment(t,s);if(!a)return null;let r=Y(e,"end",null);r&&(a.endSlot=n.findSlot(r));let o=e.vertexCount;this.readVertices(e,a,o<<1);let l=Y(e,"color",null);return l&&a.color.setFromString(l),a}}return null}readSequence(e){if(e==null)return null;let t=new Wt(Y(e,"count",0));return t.start=Y(e,"start",1),t.digits=Y(e,"digits",0),t.setupIndex=Y(e,"setup",0),t}readVertices(e,t,i){let s=this.scale;t.worldVerticesLength=i;let n=e.vertices;if(i==n.length){let r=B.toFloatArray(n);if(s!=1)for(let o=0,l=n.length;o<l;o++)r[o]*=s;t.vertices=r;return}let c=new Array,a=new Array;for(let r=0,o=n.length;r<o;){let l=n[r++];a.push(l);for(let h=r+l*4;r<h;r+=4)a.push(n[r]),c.push(n[r+1]*s),c.push(n[r+2]*s),c.push(n[r+3])}t.bones=a,t.vertices=B.toFloatArray(c)}readAnimation(e,t,i){let s=this.scale,n=new Array;if(e.slots)for(let a in e.slots){let r=e.slots[a],o=i.findSlot(a);if(!o)throw new Error("Slot not found: "+a);let l=o.index;for(let h in r){let f=r[h];if(!f)continue;let d=f.length;if(h=="attachment"){let u=new Qe(d,l);for(let m=0;m<d;m++){let x=f[m];u.setFrame(m,Y(x,"time",0),Y(x,"name",null))}n.push(u)}else if(h=="rgba"){let u=new $t(d,d<<2,l),m=f[0],x=Y(m,"time",0),b=O.fromString(m.color);for(let v=0,g=0;;v++){u.setFrame(v,x,b.r,b.g,b.b,b.a);let w=f[v+1];if(!w){u.shrink(g);break}let p=Y(w,"time",0),y=O.fromString(w.color),S=m.curve;S&&(g=oe(S,u,g,v,0,x,p,b.r,y.r,1),g=oe(S,u,g,v,1,x,p,b.g,y.g,1),g=oe(S,u,g,v,2,x,p,b.b,y.b,1),g=oe(S,u,g,v,3,x,p,b.a,y.a,1)),x=p,b=y,m=w}n.push(u)}else if(h=="rgb"){let u=new ei(d,d*3,l),m=f[0],x=Y(m,"time",0),b=O.fromString(m.color);for(let v=0,g=0;;v++){u.setFrame(v,x,b.r,b.g,b.b);let w=f[v+1];if(!w){u.shrink(g);break}let p=Y(w,"time",0),y=O.fromString(w.color),S=m.curve;S&&(g=oe(S,u,g,v,0,x,p,b.r,y.r,1),g=oe(S,u,g,v,1,x,p,b.g,y.g,1),g=oe(S,u,g,v,2,x,p,b.b,y.b,1)),x=p,b=y,m=w}n.push(u)}else if(h=="alpha")n.push(De(f,new ti(d,d,l),0,1));else if(h=="rgba2"){let u=new ii(d,d*7,l),m=f[0],x=Y(m,"time",0),b=O.fromString(m.light),v=O.fromString(m.dark);for(let g=0,w=0;;g++){u.setFrame(g,x,b.r,b.g,b.b,b.a,v.r,v.g,v.b);let p=f[g+1];if(!p){u.shrink(w);break}let y=Y(p,"time",0),S=O.fromString(p.light),A=O.fromString(p.dark),I=m.curve;I&&(w=oe(I,u,w,g,0,x,y,b.r,S.r,1),w=oe(I,u,w,g,1,x,y,b.g,S.g,1),w=oe(I,u,w,g,2,x,y,b.b,S.b,1),w=oe(I,u,w,g,3,x,y,b.a,S.a,1),w=oe(I,u,w,g,4,x,y,v.r,A.r,1),w=oe(I,u,w,g,5,x,y,v.g,A.g,1),w=oe(I,u,w,g,6,x,y,v.b,A.b,1)),x=y,b=S,v=A,m=p}n.push(u)}else if(h=="rgb2"){let u=new si(d,d*6,l),m=f[0],x=Y(m,"time",0),b=O.fromString(m.light),v=O.fromString(m.dark);for(let g=0,w=0;;g++){u.setFrame(g,x,b.r,b.g,b.b,v.r,v.g,v.b);let p=f[g+1];if(!p){u.shrink(w);break}let y=Y(p,"time",0),S=O.fromString(p.light),A=O.fromString(p.dark),I=m.curve;I&&(w=oe(I,u,w,g,0,x,y,b.r,S.r,1),w=oe(I,u,w,g,1,x,y,b.g,S.g,1),w=oe(I,u,w,g,2,x,y,b.b,S.b,1),w=oe(I,u,w,g,3,x,y,v.r,A.r,1),w=oe(I,u,w,g,4,x,y,v.g,A.g,1),w=oe(I,u,w,g,5,x,y,v.b,A.b,1)),x=y,b=S,v=A,m=p}n.push(u)}}}if(e.bones)for(let a in e.bones){let r=e.bones[a],o=i.findBone(a);if(!o)throw new Error("Bone not found: "+a);let l=o.index;for(let h in r){let f=r[h],d=f.length;if(d!=0){if(h==="rotate")n.push(De(f,new mt(d,d,l),0,1));else if(h==="translate"){let u=new _t(d,d<<1,l);n.push(Yi(f,u,"x","y",0,s))}else if(h==="translatex"){let u=new qt(d,d,l);n.push(De(f,u,0,s))}else if(h==="translatey"){let u=new Gt(d,d,l);n.push(De(f,u,0,s))}else if(h==="scale"){let u=new Ht(d,d<<1,l);n.push(Yi(f,u,"x","y",1,1))}else if(h==="scalex"){let u=new jt(d,d,l);n.push(De(f,u,1,1))}else if(h==="scaley"){let u=new Zt(d,d,l);n.push(De(f,u,1,1))}else if(h==="shear"){let u=new Kt(d,d<<1,l);n.push(Yi(f,u,"x","y",0,1))}else if(h==="shearx"){let u=new Jt(d,d,l);n.push(De(f,u,0,1))}else if(h==="sheary"){let u=new Qt(d,d,l);n.push(De(f,u,0,1))}}}}if(e.ik)for(let a in e.ik){let r=e.ik[a],o=r[0];if(!o)continue;let l=i.findIkConstraint(a);if(!l)throw new Error("IK Constraint not found: "+a);let h=i.ikConstraints.indexOf(l),f=new ni(r.length,r.length<<1,h),d=Y(o,"time",0),u=Y(o,"mix",1),m=Y(o,"softness",0)*s;for(let x=0,b=0;;x++){f.setFrame(x,d,u,m,Y(o,"bendPositive",!0)?1:-1,Y(o,"compress",!1),Y(o,"stretch",!1));let v=r[x+1];if(!v){f.shrink(b);break}let g=Y(v,"time",0),w=Y(v,"mix",1),p=Y(v,"softness",0)*s,y=o.curve;y&&(b=oe(y,f,b,x,0,d,g,u,w,1),b=oe(y,f,b,x,1,d,g,m,p,s)),d=g,u=w,m=p,o=v}n.push(f)}if(e.transform)for(let a in e.transform){let r=e.transform[a],o=r[0];if(!o)continue;let l=i.findTransformConstraint(a);if(!l)throw new Error("Transform constraint not found: "+a);let h=i.transformConstraints.indexOf(l),f=new ai(r.length,r.length*6,h),d=Y(o,"time",0),u=Y(o,"mixRotate",1),m=Y(o,"mixX",1),x=Y(o,"mixY",m),b=Y(o,"mixScaleX",1),v=Y(o,"mixScaleY",b),g=Y(o,"mixShearY",1);for(let w=0,p=0;;w++){f.setFrame(w,d,u,m,x,b,v,g);let y=r[w+1];if(!y){f.shrink(p);break}let S=Y(y,"time",0),A=Y(y,"mixRotate",1),I=Y(y,"mixX",1),E=Y(y,"mixY",I),k=Y(y,"mixScaleX",1),X=Y(y,"mixScaleY",k),F=Y(y,"mixShearY",1),L=o.curve;L&&(p=oe(L,f,p,w,0,d,S,u,A,1),p=oe(L,f,p,w,1,d,S,m,I,1),p=oe(L,f,p,w,2,d,S,x,E,1),p=oe(L,f,p,w,3,d,S,b,k,1),p=oe(L,f,p,w,4,d,S,v,X,1),p=oe(L,f,p,w,5,d,S,g,F,1)),d=S,u=A,m=I,x=E,b=k,v=X,b=k,o=y}n.push(f)}if(e.path)for(let a in e.path){let r=e.path[a],o=i.findPathConstraint(a);if(!o)throw new Error("Path constraint not found: "+a);let l=i.pathConstraints.indexOf(o);for(let h in r){let f=r[h],d=f[0];if(!d)continue;let u=f.length;if(h==="position"){let m=new li(u,u,l);n.push(De(f,m,0,o.positionMode==Fe.Fixed?s:1))}else if(h==="spacing"){let m=new oi(u,u,l);n.push(De(f,m,0,o.spacingMode==xe.Length||o.spacingMode==xe.Fixed?s:1))}else if(h==="mix"){let m=new hi(u,u*3,l),x=Y(d,"time",0),b=Y(d,"mixRotate",1),v=Y(d,"mixX",1),g=Y(d,"mixY",v);for(let w=0,p=0;;w++){m.setFrame(w,x,b,v,g);let y=f[w+1];if(!y){m.shrink(p);break}let S=Y(y,"time",0),A=Y(y,"mixRotate",1),I=Y(y,"mixX",1),E=Y(y,"mixY",I),k=d.curve;k&&(p=oe(k,m,p,w,0,x,S,b,A,1),p=oe(k,m,p,w,1,x,S,v,I,1),p=oe(k,m,p,w,2,x,S,g,E,1)),x=S,b=A,v=I,g=E,d=y}n.push(m)}}}if(e.attachments)for(let a in e.attachments){let r=e.attachments[a],o=i.findSkin(a);if(!o)throw new Error("Skin not found: "+a);for(let l in r){let h=r[l],f=i.findSlot(l);if(!f)throw new Error("Slot not found: "+l);let d=f.index;for(let u in h){let m=h[u],x=o.getAttachment(d,u);for(let b in m){let v=m[b],g=v[0];if(!!g){if(b=="deform"){let w=x.bones,p=x.vertices,y=w?p.length/3*2:p.length,S=new ri(v.length,v.length,d,x),A=Y(g,"time",0);for(let I=0,E=0;;I++){let k,X=Y(g,"vertices",null);if(!X)k=w?B.newFloatArray(y):p;else{k=B.newFloatArray(y);let M=Y(g,"offset",0);if(B.arrayCopy(X,0,k,M,X.length),s!=1)for(let P=M,ee=P+X.length;P<ee;P++)k[P]*=s;if(!w)for(let P=0;P<y;P++)k[P]+=p[P]}S.setFrame(I,A,k);let F=v[I+1];if(!F){S.shrink(E);break}let L=Y(F,"time",0),T=g.curve;T&&(E=oe(T,S,E,I,0,A,L,0,1,1)),A=L,g=F}n.push(S)}else if(b=="sequence"){let w=new rt(v.length,d,x),p=0;for(let y=0;y<v.length;y++){let S=Y(g,"delay",p),A=Y(g,"time",0),I=Oe[Y(g,"mode","hold")],E=Y(g,"index",0);w.setFrame(y,A,I,E,S),p=S,g=v[y+1]}n.push(w)}}}}}}if(e.drawOrder){let a=new $e(e.drawOrder.length),r=i.slots.length,o=0;for(let l=0;l<e.drawOrder.length;l++,o++){let h=e.drawOrder[l],f=null,d=Y(h,"offsets",null);if(d){f=B.newArray(r,-1);let u=B.newArray(r-d.length,0),m=0,x=0;for(let b=0;b<d.length;b++){let v=d[b],g=i.findSlot(v.slot);if(!g)throw new Error("Slot not found: "+g);let w=g.index;for(;m!=w;)u[x++]=m++;f[m+v.offset]=m++}for(;m<r;)u[x++]=m++;for(let b=r-1;b>=0;b--)f[b]==-1&&(f[b]=u[--x])}a.setFrame(o,Y(h,"time",0),f)}n.push(a)}if(e.events){let a=new gt(e.events.length),r=0;for(let o=0;o<e.events.length;o++,r++){let l=e.events[o],h=i.findEvent(l.name);if(!h)throw new Error("Event not found: "+l.name);let f=new bi(B.toSinglePrecision(Y(l,"time",0)),h);f.intValue=Y(l,"int",h.intValue),f.floatValue=Y(l,"float",h.floatValue),f.stringValue=Y(l,"string",h.stringValue),f.data.audioPath&&(f.volume=Y(l,"volume",1),f.balance=Y(l,"balance",0)),a.setFrame(r,f)}n.push(a)}let c=0;for(let a=0,r=n.length;a<r;a++)c=Math.max(c,n[a].getDuration());i.animations.push(new yt(t,n,c))}},ar=class{constructor(e,t,i,s,n){this.mesh=e,this.skin=t,this.slotIndex=i,this.parent=s,this.inheritTimeline=n}};function De(e,t,i,s){let n=e[0],c=Y(n,"time",0),a=Y(n,"value",i)*s,r=0;for(let o=0;;o++){t.setFrame(o,c,a);let l=e[o+1];if(!l)return t.shrink(r),t;let h=Y(l,"time",0),f=Y(l,"value",i)*s;n.curve&&(r=oe(n.curve,t,r,o,0,c,h,a,f,s)),c=h,a=f,n=l}}function Yi(e,t,i,s,n,c){let a=e[0],r=Y(a,"time",0),o=Y(a,i,n)*c,l=Y(a,s,n)*c,h=0;for(let f=0;;f++){t.setFrame(f,r,o,l);let d=e[f+1];if(!d)return t.shrink(h),t;let u=Y(d,"time",0),m=Y(d,i,n)*c,x=Y(d,s,n)*c,b=a.curve;b&&(h=oe(b,t,h,f,0,r,u,o,m,c),h=oe(b,t,h,f,1,r,u,l,x,c)),r=u,o=m,l=x,a=d}}function oe(e,t,i,s,n,c,a,r,o,l){if(e=="stepped")return t.setStepped(s),i;let h=n<<2,f=e[h],d=e[h+1]*l,u=e[h+2],m=e[h+3]*l;return t.setBezier(i,s,n,c,r,f,d,u,m,a,o),i+1}function Y(e,t,i){return e[t]!==void 0?e[t]:i}(()=>{typeof Math.fround=="undefined"&&(Math.fround=function(e){return function(t){return e[0]=t,e[0]}}(new Float32Array(1)))})();var ye=class{constructor(e,t={alpha:"true"}){if(this.restorables=new Array,e instanceof WebGLRenderingContext||typeof WebGL2RenderingContext!="undefined"&&e instanceof WebGL2RenderingContext)this.gl=e,this.canvas=this.gl.canvas;else{let i=e;this.gl=i.getContext("webgl2",t)||i.getContext("webgl",t),this.canvas=i,i.addEventListener("webglcontextlost",s=>{let n=s;s&&s.preventDefault()}),i.addEventListener("webglcontextrestored",s=>{for(let n=0,c=this.restorables.length;n<c;n++)this.restorables[n].restore()})}}addRestorable(e){this.restorables.push(e)}removeRestorable(e){let t=this.restorables.indexOf(e);t>-1&&this.restorables.splice(t,1)}},at=1,lr=769,os=770,kt=771,or=774,Rt=class{static getDestGLBlendMode(e){switch(e){case pe.Normal:return kt;case pe.Additive:return at;case pe.Multiply:return kt;case pe.Screen:return kt;default:throw new Error("Unknown blend mode: "+e)}}static getSourceColorGLBlendMode(e,t=!1){switch(e){case pe.Normal:return t?at:os;case pe.Additive:return t?at:os;case pe.Multiply:return or;case pe.Screen:return at;default:throw new Error("Unknown blend mode: "+e)}}static getSourceAlphaGLBlendMode(e){switch(e){case pe.Normal:return at;case pe.Additive:return at;case pe.Multiply:return kt;case pe.Screen:return lr;default:throw new Error("Unknown blend mode: "+e)}}},Ft=class extends ui{constructor(e,t,i=!1){super(t);this.texture=null,this.boundUnit=0,this.useMipMaps=!1,this.context=e instanceof ye?e:new ye(e),this.useMipMaps=i,this.restore(),this.context.addRestorable(this)}setFilters(e,t){let i=this.context.gl;this.bind(),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_MIN_FILTER,e),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_MAG_FILTER,Ft.validateMagFilter(t)),this.useMipMaps=Ft.usesMipMaps(e),this.useMipMaps&&i.generateMipmap(i.TEXTURE_2D)}static validateMagFilter(e){switch(e){case we.MipMap:case we.MipMapLinearLinear:case we.MipMapLinearNearest:case we.MipMapNearestLinear:case we.MipMapNearestNearest:return we.Linear;default:return e}}static usesMipMaps(e){switch(e){case we.MipMap:case we.MipMapLinearLinear:case we.MipMapLinearNearest:case we.MipMapNearestLinear:case we.MipMapNearestNearest:return!0;default:return!1}}setWraps(e,t){let i=this.context.gl;this.bind(),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_WRAP_S,e),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_WRAP_T,t)}update(e){let t=this.context.gl;this.texture||(this.texture=this.context.gl.createTexture()),this.bind(),Ft.DISABLE_UNPACK_PREMULTIPLIED_ALPHA_WEBGL&&t.pixelStorei(t.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1),t.texImage2D(t.TEXTURE_2D,0,t.RGBA,t.RGBA,t.UNSIGNED_BYTE,this._image),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_MAG_FILTER,t.LINEAR),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_MIN_FILTER,e?t.LINEAR_MIPMAP_LINEAR:t.LINEAR),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_WRAP_S,t.CLAMP_TO_EDGE),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_WRAP_T,t.CLAMP_TO_EDGE),e&&t.generateMipmap(t.TEXTURE_2D)}restore(){this.texture=null,this.update(this.useMipMaps)}bind(e=0){let t=this.context.gl;this.boundUnit=e,t.activeTexture(t.TEXTURE0+e),t.bindTexture(t.TEXTURE_2D,this.texture)}unbind(){let e=this.context.gl;e.activeTexture(e.TEXTURE0+this.boundUnit),e.bindTexture(e.TEXTURE_2D,null)}dispose(){this.context.removeRestorable(this),this.context.gl.deleteTexture(this.texture)}},wt=Ft;wt.DISABLE_UNPACK_PREMULTIPLIED_ALPHA_WEBGL=!1;var hs=class extends is{constructor(e,t="",i=new pi){super(s=>new wt(e,s),t,i)}},Ie=class{constructor(e=0,t=0,i=0){this.x=0,this.y=0,this.z=0,this.x=e,this.y=t,this.z=i}setFrom(e){return this.x=e.x,this.y=e.y,this.z=e.z,this}set(e,t,i){return this.x=e,this.y=t,this.z=i,this}add(e){return this.x+=e.x,this.y+=e.y,this.z+=e.z,this}sub(e){return this.x-=e.x,this.y-=e.y,this.z-=e.z,this}scale(e){return this.x*=e,this.y*=e,this.z*=e,this}normalize(){let e=this.length();return e==0?this:(e=1/e,this.x*=e,this.y*=e,this.z*=e,this)}cross(e){return this.set(this.y*e.z-this.z*e.y,this.z*e.x-this.x*e.z,this.x*e.y-this.y*e.x)}multiply(e){let t=e.values;return this.set(this.x*t[D]+this.y*t[_]+this.z*t[q]+t[V],this.x*t[G]+this.y*t[N]+this.z*t[H]+t[U],this.x*t[j]+this.y*t[Z]+this.z*t[z]+t[W])}project(e){let t=e.values,i=1/(this.x*t[J]+this.y*t[Q]+this.z*t[$]+t[K]);return this.set((this.x*t[D]+this.y*t[_]+this.z*t[q]+t[V])*i,(this.x*t[G]+this.y*t[N]+this.z*t[H]+t[U])*i,(this.x*t[j]+this.y*t[Z]+this.z*t[z]+t[W])*i)}dot(e){return this.x*e.x+this.y*e.y+this.z*e.z}length(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z)}distance(e){let t=e.x-this.x,i=e.y-this.y,s=e.z-this.z;return Math.sqrt(t*t+i*i+s*s)}},D=0,_=4,q=8,V=12,G=1,N=5,H=9,U=13,j=2,Z=6,z=10,W=14,J=3,Q=7,$=11,K=15,Pe=class{constructor(){this.temp=new Float32Array(16),this.values=new Float32Array(16);let e=this.values;e[D]=1,e[N]=1,e[z]=1,e[K]=1}set(e){return this.values.set(e),this}transpose(){let e=this.temp,t=this.values;return e[D]=t[D],e[_]=t[G],e[q]=t[j],e[V]=t[J],e[G]=t[_],e[N]=t[N],e[H]=t[Z],e[U]=t[Q],e[j]=t[q],e[Z]=t[H],e[z]=t[z],e[W]=t[$],e[J]=t[V],e[Q]=t[U],e[$]=t[W],e[K]=t[K],this.set(e)}identity(){let e=this.values;return e[D]=1,e[_]=0,e[q]=0,e[V]=0,e[G]=0,e[N]=1,e[H]=0,e[U]=0,e[j]=0,e[Z]=0,e[z]=1,e[W]=0,e[J]=0,e[Q]=0,e[$]=0,e[K]=1,this}invert(){let e=this.values,t=this.temp,i=e[J]*e[Z]*e[H]*e[V]-e[j]*e[Q]*e[H]*e[V]-e[J]*e[N]*e[z]*e[V]+e[G]*e[Q]*e[z]*e[V]+e[j]*e[N]*e[$]*e[V]-e[G]*e[Z]*e[$]*e[V]-e[J]*e[Z]*e[q]*e[U]+e[j]*e[Q]*e[q]*e[U]+e[J]*e[_]*e[z]*e[U]-e[D]*e[Q]*e[z]*e[U]-e[j]*e[_]*e[$]*e[U]+e[D]*e[Z]*e[$]*e[U]+e[J]*e[N]*e[q]*e[W]-e[G]*e[Q]*e[q]*e[W]-e[J]*e[_]*e[H]*e[W]+e[D]*e[Q]*e[H]*e[W]+e[G]*e[_]*e[$]*e[W]-e[D]*e[N]*e[$]*e[W]-e[j]*e[N]*e[q]*e[K]+e[G]*e[Z]*e[q]*e[K]+e[j]*e[_]*e[H]*e[K]-e[D]*e[Z]*e[H]*e[K]-e[G]*e[_]*e[z]*e[K]+e[D]*e[N]*e[z]*e[K];if(i==0)throw new Error("non-invertible matrix");let s=1/i;return t[D]=e[H]*e[W]*e[Q]-e[U]*e[z]*e[Q]+e[U]*e[Z]*e[$]-e[N]*e[W]*e[$]-e[H]*e[Z]*e[K]+e[N]*e[z]*e[K],t[_]=e[V]*e[z]*e[Q]-e[q]*e[W]*e[Q]-e[V]*e[Z]*e[$]+e[_]*e[W]*e[$]+e[q]*e[Z]*e[K]-e[_]*e[z]*e[K],t[q]=e[q]*e[U]*e[Q]-e[V]*e[H]*e[Q]+e[V]*e[N]*e[$]-e[_]*e[U]*e[$]-e[q]*e[N]*e[K]+e[_]*e[H]*e[K],t[V]=e[V]*e[H]*e[Z]-e[q]*e[U]*e[Z]-e[V]*e[N]*e[z]+e[_]*e[U]*e[z]+e[q]*e[N]*e[W]-e[_]*e[H]*e[W],t[G]=e[U]*e[z]*e[J]-e[H]*e[W]*e[J]-e[U]*e[j]*e[$]+e[G]*e[W]*e[$]+e[H]*e[j]*e[K]-e[G]*e[z]*e[K],t[N]=e[q]*e[W]*e[J]-e[V]*e[z]*e[J]+e[V]*e[j]*e[$]-e[D]*e[W]*e[$]-e[q]*e[j]*e[K]+e[D]*e[z]*e[K],t[H]=e[V]*e[H]*e[J]-e[q]*e[U]*e[J]-e[V]*e[G]*e[$]+e[D]*e[U]*e[$]+e[q]*e[G]*e[K]-e[D]*e[H]*e[K],t[U]=e[q]*e[U]*e[j]-e[V]*e[H]*e[j]+e[V]*e[G]*e[z]-e[D]*e[U]*e[z]-e[q]*e[G]*e[W]+e[D]*e[H]*e[W],t[j]=e[N]*e[W]*e[J]-e[U]*e[Z]*e[J]+e[U]*e[j]*e[Q]-e[G]*e[W]*e[Q]-e[N]*e[j]*e[K]+e[G]*e[Z]*e[K],t[Z]=e[V]*e[Z]*e[J]-e[_]*e[W]*e[J]-e[V]*e[j]*e[Q]+e[D]*e[W]*e[Q]+e[_]*e[j]*e[K]-e[D]*e[Z]*e[K],t[z]=e[_]*e[U]*e[J]-e[V]*e[N]*e[J]+e[V]*e[G]*e[Q]-e[D]*e[U]*e[Q]-e[_]*e[G]*e[K]+e[D]*e[N]*e[K],t[W]=e[V]*e[N]*e[j]-e[_]*e[U]*e[j]-e[V]*e[G]*e[Z]+e[D]*e[U]*e[Z]+e[_]*e[G]*e[W]-e[D]*e[N]*e[W],t[J]=e[H]*e[Z]*e[J]-e[N]*e[z]*e[J]-e[H]*e[j]*e[Q]+e[G]*e[z]*e[Q]+e[N]*e[j]*e[$]-e[G]*e[Z]*e[$],t[Q]=e[_]*e[z]*e[J]-e[q]*e[Z]*e[J]+e[q]*e[j]*e[Q]-e[D]*e[z]*e[Q]-e[_]*e[j]*e[$]+e[D]*e[Z]*e[$],t[$]=e[q]*e[N]*e[J]-e[_]*e[H]*e[J]-e[q]*e[G]*e[Q]+e[D]*e[H]*e[Q]+e[_]*e[G]*e[$]-e[D]*e[N]*e[$],t[K]=e[_]*e[H]*e[j]-e[q]*e[N]*e[j]+e[q]*e[G]*e[Z]-e[D]*e[H]*e[Z]-e[_]*e[G]*e[z]+e[D]*e[N]*e[z],e[D]=t[D]*s,e[_]=t[_]*s,e[q]=t[q]*s,e[V]=t[V]*s,e[G]=t[G]*s,e[N]=t[N]*s,e[H]=t[H]*s,e[U]=t[U]*s,e[j]=t[j]*s,e[Z]=t[Z]*s,e[z]=t[z]*s,e[W]=t[W]*s,e[J]=t[J]*s,e[Q]=t[Q]*s,e[$]=t[$]*s,e[K]=t[K]*s,this}determinant(){let e=this.values;return e[J]*e[Z]*e[H]*e[V]-e[j]*e[Q]*e[H]*e[V]-e[J]*e[N]*e[z]*e[V]+e[G]*e[Q]*e[z]*e[V]+e[j]*e[N]*e[$]*e[V]-e[G]*e[Z]*e[$]*e[V]-e[J]*e[Z]*e[q]*e[U]+e[j]*e[Q]*e[q]*e[U]+e[J]*e[_]*e[z]*e[U]-e[D]*e[Q]*e[z]*e[U]-e[j]*e[_]*e[$]*e[U]+e[D]*e[Z]*e[$]*e[U]+e[J]*e[N]*e[q]*e[W]-e[G]*e[Q]*e[q]*e[W]-e[J]*e[_]*e[H]*e[W]+e[D]*e[Q]*e[H]*e[W]+e[G]*e[_]*e[$]*e[W]-e[D]*e[N]*e[$]*e[W]-e[j]*e[N]*e[q]*e[K]+e[G]*e[Z]*e[q]*e[K]+e[j]*e[_]*e[H]*e[K]-e[D]*e[Z]*e[H]*e[K]-e[G]*e[_]*e[z]*e[K]+e[D]*e[N]*e[z]*e[K]}translate(e,t,i){let s=this.values;return s[V]+=e,s[U]+=t,s[W]+=i,this}copy(){return new Pe().set(this.values)}projection(e,t,i,s){this.identity();let n=1/Math.tan(i*(Math.PI/180)/2),c=(t+e)/(e-t),a=2*t*e/(e-t),r=this.values;return r[D]=n/s,r[G]=0,r[j]=0,r[J]=0,r[_]=0,r[N]=n,r[Z]=0,r[Q]=0,r[q]=0,r[H]=0,r[z]=c,r[$]=-1,r[V]=0,r[U]=0,r[W]=a,r[K]=0,this}ortho2d(e,t,i,s){return this.ortho(e,e+i,t,t+s,0,1)}ortho(e,t,i,s,n,c){this.identity();let a=2/(t-e),r=2/(s-i),o=-2/(c-n),l=-(t+e)/(t-e),h=-(s+i)/(s-i),f=-(c+n)/(c-n),d=this.values;return d[D]=a,d[G]=0,d[j]=0,d[J]=0,d[_]=0,d[N]=r,d[Z]=0,d[Q]=0,d[q]=0,d[H]=0,d[z]=o,d[$]=0,d[V]=l,d[U]=h,d[W]=f,d[K]=1,this}multiply(e){let t=this.temp,i=this.values,s=e.values;return t[D]=i[D]*s[D]+i[_]*s[G]+i[q]*s[j]+i[V]*s[J],t[_]=i[D]*s[_]+i[_]*s[N]+i[q]*s[Z]+i[V]*s[Q],t[q]=i[D]*s[q]+i[_]*s[H]+i[q]*s[z]+i[V]*s[$],t[V]=i[D]*s[V]+i[_]*s[U]+i[q]*s[W]+i[V]*s[K],t[G]=i[G]*s[D]+i[N]*s[G]+i[H]*s[j]+i[U]*s[J],t[N]=i[G]*s[_]+i[N]*s[N]+i[H]*s[Z]+i[U]*s[Q],t[H]=i[G]*s[q]+i[N]*s[H]+i[H]*s[z]+i[U]*s[$],t[U]=i[G]*s[V]+i[N]*s[U]+i[H]*s[W]+i[U]*s[K],t[j]=i[j]*s[D]+i[Z]*s[G]+i[z]*s[j]+i[W]*s[J],t[Z]=i[j]*s[_]+i[Z]*s[N]+i[z]*s[Z]+i[W]*s[Q],t[z]=i[j]*s[q]+i[Z]*s[H]+i[z]*s[z]+i[W]*s[$],t[W]=i[j]*s[V]+i[Z]*s[U]+i[z]*s[W]+i[W]*s[K],t[J]=i[J]*s[D]+i[Q]*s[G]+i[$]*s[j]+i[K]*s[J],t[Q]=i[J]*s[_]+i[Q]*s[N]+i[$]*s[Z]+i[K]*s[Q],t[$]=i[J]*s[q]+i[Q]*s[H]+i[$]*s[z]+i[K]*s[$],t[K]=i[J]*s[V]+i[Q]*s[U]+i[$]*s[W]+i[K]*s[K],this.set(this.temp)}multiplyLeft(e){let t=this.temp,i=this.values,s=e.values;return t[D]=s[D]*i[D]+s[_]*i[G]+s[q]*i[j]+s[V]*i[J],t[_]=s[D]*i[_]+s[_]*i[N]+s[q]*i[Z]+s[V]*i[Q],t[q]=s[D]*i[q]+s[_]*i[H]+s[q]*i[z]+s[V]*i[$],t[V]=s[D]*i[V]+s[_]*i[U]+s[q]*i[W]+s[V]*i[K],t[G]=s[G]*i[D]+s[N]*i[G]+s[H]*i[j]+s[U]*i[J],t[N]=s[G]*i[_]+s[N]*i[N]+s[H]*i[Z]+s[U]*i[Q],t[H]=s[G]*i[q]+s[N]*i[H]+s[H]*i[z]+s[U]*i[$],t[U]=s[G]*i[V]+s[N]*i[U]+s[H]*i[W]+s[U]*i[K],t[j]=s[j]*i[D]+s[Z]*i[G]+s[z]*i[j]+s[W]*i[J],t[Z]=s[j]*i[_]+s[Z]*i[N]+s[z]*i[Z]+s[W]*i[Q],t[z]=s[j]*i[q]+s[Z]*i[H]+s[z]*i[z]+s[W]*i[$],t[W]=s[j]*i[V]+s[Z]*i[U]+s[z]*i[W]+s[W]*i[K],t[J]=s[J]*i[D]+s[Q]*i[G]+s[$]*i[j]+s[K]*i[J],t[Q]=s[J]*i[_]+s[Q]*i[N]+s[$]*i[Z]+s[K]*i[Q],t[$]=s[J]*i[q]+s[Q]*i[H]+s[$]*i[z]+s[K]*i[$],t[K]=s[J]*i[V]+s[Q]*i[U]+s[$]*i[W]+s[K]*i[K],this.set(this.temp)}lookAt(e,t,i){let s=Pe.xAxis,n=Pe.yAxis,c=Pe.zAxis;c.setFrom(t).normalize(),s.setFrom(t).normalize(),s.cross(i).normalize(),n.setFrom(s).cross(c).normalize(),this.identity();let a=this.values;return a[D]=s.x,a[_]=s.y,a[q]=s.z,a[G]=n.x,a[N]=n.y,a[H]=n.z,a[j]=-c.x,a[Z]=-c.y,a[z]=-c.z,Pe.tmpMatrix.identity(),Pe.tmpMatrix.values[V]=-e.x,Pe.tmpMatrix.values[U]=-e.y,Pe.tmpMatrix.values[W]=-e.z,this.multiply(Pe.tmpMatrix),this}},_e=Pe;_e.xAxis=new Ie,_e.yAxis=new Ie,_e.zAxis=new Ie,_e.tmpMatrix=new Pe;var cs=class{constructor(e,t){this.position=new Ie(0,0,0),this.direction=new Ie(0,0,-1),this.up=new Ie(0,1,0),this.near=0,this.far=100,this.zoom=1,this.viewportWidth=0,this.viewportHeight=0,this.projectionView=new _e,this.inverseProjectionView=new _e,this.projection=new _e,this.view=new _e,this.viewportWidth=e,this.viewportHeight=t,this.update()}update(){let e=this.projection,t=this.view,i=this.projectionView,s=this.inverseProjectionView,n=this.zoom,c=this.viewportWidth,a=this.viewportHeight;e.ortho(n*(-c/2),n*(c/2),n*(-a/2),n*(a/2),this.near,this.far),t.lookAt(this.position,this.direction,this.up),i.set(e.values),i.multiply(t),s.set(i.values).invert()}screenToWorld(e,t,i){let s=e.x,n=i-e.y-1;return e.x=2*s/t-1,e.y=2*n/i-1,e.z=2*e.z-1,e.project(this.inverseProjectionView),e}worldToScreen(e,t,i){return e.project(this.projectionView),e.x=t*(e.x+1)/2,e.y=i*(e.y+1)/2,e.z=(e.z+1)/2,e}setViewport(e,t){this.viewportWidth=e,this.viewportHeight=t}},Ei=class{constructor(e){this.mouseX=0,this.mouseY=0,this.buttonDown=!1,this.touch0=null,this.touch1=null,this.initialPinchDistance=0,this.listeners=new Array,this.eventListeners=[],this.element=e,this.setupCallbacks(e)}setupCallbacks(e){let t=a=>{if(a instanceof MouseEvent){let r=e.getBoundingClientRect();this.mouseX=a.clientX-r.left,this.mouseY=a.clientY-r.top,this.buttonDown=!0,this.listeners.map(o=>{o.down&&o.down(this.mouseX,this.mouseY)}),document.addEventListener("mousemove",i),document.addEventListener("mouseup",s)}},i=a=>{if(a instanceof MouseEvent){let r=e.getBoundingClientRect();this.mouseX=a.clientX-r.left,this.mouseY=a.clientY-r.top,this.listeners.map(o=>{this.buttonDown?o.dragged&&o.dragged(this.mouseX,this.mouseY):o.moved&&o.moved(this.mouseX,this.mouseY)})}},s=a=>{if(a instanceof MouseEvent){let r=e.getBoundingClientRect();this.mouseX=a.clientX-r.left,this.mouseY=a.clientY-r.top,this.buttonDown=!1,this.listeners.map(o=>{o.up&&o.up(this.mouseX,this.mouseY)}),document.removeEventListener("mousemove",i),document.removeEventListener("mouseup",s)}},n=a=>{a.preventDefault();let r=a.deltaY;a.deltaMode==WheelEvent.DOM_DELTA_LINE&&(r*=8),a.deltaMode==WheelEvent.DOM_DELTA_PAGE&&(r*=24),this.listeners.map(o=>{o.wheel&&o.wheel(a.deltaY)})};e.addEventListener("mousedown",t,!0),e.addEventListener("mousemove",i,!0),e.addEventListener("mouseup",s,!0),e.addEventListener("wheel",n,!0),e.addEventListener("touchstart",a=>{if(!this.touch0||!this.touch1){var r=a.changedTouches;let o=r.item(0);if(!o)return;let l=e.getBoundingClientRect(),h=o.clientX-l.left,f=o.clientY-l.top,d=new ds(o.identifier,h,f);if(this.mouseX=h,this.mouseY=f,this.buttonDown=!0,!this.touch0)this.touch0=d,this.listeners.map(u=>{u.down&&u.down(d.x,d.y)});else if(!this.touch1){this.touch1=d;let u=this.touch1.x-this.touch0.x,m=this.touch1.x-this.touch0.x;this.initialPinchDistance=Math.sqrt(u*u+m*m),this.listeners.map(x=>{x.zoom&&x.zoom(this.initialPinchDistance,this.initialPinchDistance)})}}a.preventDefault()},!1),e.addEventListener("touchmove",a=>{if(this.touch0){var r=a.changedTouches;let h=e.getBoundingClientRect();for(var o=0;o<r.length;o++){var l=r[o];let f=l.clientX-h.left,d=l.clientY-h.top;this.touch0.identifier===l.identifier&&(this.touch0.x=this.mouseX=f,this.touch0.y=this.mouseY=d,this.listeners.map(u=>{u.dragged&&u.dragged(f,d)})),this.touch1&&this.touch1.identifier===l.identifier&&(this.touch1.x=this.mouseX=f,this.touch1.y=this.mouseY=d)}if(this.touch0&&this.touch1){let f=this.touch1.x-this.touch0.x,d=this.touch1.x-this.touch0.x,u=Math.sqrt(f*f+d*d);this.listeners.map(m=>{m.zoom&&m.zoom(this.initialPinchDistance,u)})}}a.preventDefault()},!1);let c=a=>{if(this.touch0){var r=a.changedTouches;let h=e.getBoundingClientRect();for(var o=0;o<r.length;o++){var l=r[o];let f=l.clientX-h.left,d=l.clientY-h.top;if(this.touch0.identifier===l.identifier)if(this.touch0=null,this.mouseX=f,this.mouseY=d,this.listeners.map(u=>{u.up&&u.up(f,d)}),this.touch1)this.touch0=this.touch1,this.touch1=null,this.mouseX=this.touch0.x,this.mouseX=this.touch0.x,this.buttonDown=!0,this.listeners.map(u=>{u.down&&u.down(this.touch0.x,this.touch0.y)});else{this.buttonDown=!1;break}this.touch1&&this.touch1.identifier&&(this.touch1=null)}}a.preventDefault()};e.addEventListener("touchend",c,!1),e.addEventListener("touchcancel",c)}addListener(e){this.listeners.push(e)}removeListener(e){let t=this.listeners.indexOf(e);t>-1&&this.listeners.splice(t,1)}},ds=class{constructor(e,t,i){this.identifier=e,this.x=t,this.y=i}},hr=class{constructor(e,t){this.canvas=e,this.camera=t;let i=0,s=0,n=0,c=0,a=0,r=0,o=0,l=0;new Ei(e).addListener({down:(h,f)=>{i=t.position.x,s=t.position.y,c=r=h,a=o=f,l=t.zoom},dragged:(h,f)=>{let d=h-c,u=f-a,m=t.screenToWorld(new Ie(0,0),e.clientWidth,e.clientHeight),x=t.screenToWorld(new Ie(d,u),e.clientWidth,e.clientHeight).sub(m);t.position.set(i-x.x,s-x.y,0),t.update(),r=h,o=f},wheel:h=>{let f=h/200*t.zoom,d=t.zoom+f;if(d>0){let u=0,m=0;if(h<0)u=r,m=o;else{let v=new Ie(e.clientWidth/2+15,e.clientHeight/2),g=r-v.x,w=e.clientHeight-1-o-v.y;u=v.x-g,m=e.clientHeight-1-v.y+w}let x=t.screenToWorld(new Ie(u,m),e.clientWidth,e.clientHeight);t.zoom=d,t.update();let b=t.screenToWorld(new Ie(u,m),e.clientWidth,e.clientHeight);t.position.add(x.sub(b)),t.update()}},zoom:(h,f)=>{let d=h/f;t.zoom=l*d},up:(h,f)=>{r=h,o=f},moved:(h,f)=>{r=h,o=f}})}},fe=class{constructor(e,t,i){this.vertexShader=t,this.fragmentShader=i,this.vs=null,this.fs=null,this.program=null,this.tmp2x2=new Float32Array(2*2),this.tmp3x3=new Float32Array(3*3),this.tmp4x4=new Float32Array(4*4),this.vsSource=t,this.fsSource=i,this.context=e instanceof ye?e:new ye(e),this.context.addRestorable(this),this.compile()}getProgram(){return this.program}getVertexShader(){return this.vertexShader}getFragmentShader(){return this.fragmentShader}getVertexShaderSource(){return this.vsSource}getFragmentSource(){return this.fsSource}compile(){let e=this.context.gl;try{if(this.vs=this.compileShader(e.VERTEX_SHADER,this.vertexShader),!this.vs)throw new Error("Couldn't compile vertex shader.");if(this.fs=this.compileShader(e.FRAGMENT_SHADER,this.fragmentShader),!this.fs)throw new Error("Couldn#t compile fragment shader.");this.program=this.compileProgram(this.vs,this.fs)}catch(t){throw this.dispose(),t}}compileShader(e,t){let i=this.context.gl,s=i.createShader(e);if(!s)throw new Error("Couldn't create shader.");if(i.shaderSource(s,t),i.compileShader(s),!i.getShaderParameter(s,i.COMPILE_STATUS)){let n="Couldn't compile shader: "+i.getShaderInfoLog(s);if(i.deleteShader(s),!i.isContextLost())throw new Error(n)}return s}compileProgram(e,t){let i=this.context.gl,s=i.createProgram();if(!s)throw new Error("Couldn't compile program.");if(i.attachShader(s,e),i.attachShader(s,t),i.linkProgram(s),!i.getProgramParameter(s,i.LINK_STATUS)){let n="Couldn't compile shader program: "+i.getProgramInfoLog(s);if(i.deleteProgram(s),!i.isContextLost())throw new Error(n)}return s}restore(){this.compile()}bind(){this.context.gl.useProgram(this.program)}unbind(){this.context.gl.useProgram(null)}setUniformi(e,t){this.context.gl.uniform1i(this.getUniformLocation(e),t)}setUniformf(e,t){this.context.gl.uniform1f(this.getUniformLocation(e),t)}setUniform2f(e,t,i){this.context.gl.uniform2f(this.getUniformLocation(e),t,i)}setUniform3f(e,t,i,s){this.context.gl.uniform3f(this.getUniformLocation(e),t,i,s)}setUniform4f(e,t,i,s,n){this.context.gl.uniform4f(this.getUniformLocation(e),t,i,s,n)}setUniform2x2f(e,t){let i=this.context.gl;this.tmp2x2.set(t),i.uniformMatrix2fv(this.getUniformLocation(e),!1,this.tmp2x2)}setUniform3x3f(e,t){let i=this.context.gl;this.tmp3x3.set(t),i.uniformMatrix3fv(this.getUniformLocation(e),!1,this.tmp3x3)}setUniform4x4f(e,t){let i=this.context.gl;this.tmp4x4.set(t),i.uniformMatrix4fv(this.getUniformLocation(e),!1,this.tmp4x4)}getUniformLocation(e){let t=this.context.gl;if(!this.program)throw new Error("Shader not compiled.");let i=t.getUniformLocation(this.program,e);if(!i&&!t.isContextLost())throw new Error(`Couldn't find location for uniform ${e}`);return i}getAttributeLocation(e){let t=this.context.gl;if(!this.program)throw new Error("Shader not compiled.");let i=t.getAttribLocation(this.program,e);if(i==-1&&!t.isContextLost())throw new Error(`Couldn't find location for attribute ${e}`);return i}dispose(){this.context.removeRestorable(this);let e=this.context.gl;this.vs&&(e.deleteShader(this.vs),this.vs=null),this.fs&&(e.deleteShader(this.fs),this.fs=null),this.program&&(e.deleteProgram(this.program),this.program=null)}static newColoredTextured(e){let t=`
|
|
3
3
|
attribute vec4 ${fe.POSITION};
|
|
4
4
|
attribute vec4 ${fe.COLOR};
|
|
5
5
|
attribute vec2 ${fe.TEXCOORDS};
|
|
@@ -81,4 +81,4 @@ var spine=(()=>{var Vi=Object.defineProperty,Ss=e=>Vi(e,"__esModule",{value:!0})
|
|
|
81
81
|
void main () {
|
|
82
82
|
gl_FragColor = v_color;
|
|
83
83
|
}
|
|
84
|
-
`;return new fe(e,t,i)}},be=fe;be.MVP_MATRIX="u_projTrans",be.POSITION="a_position",be.COLOR="a_color",be.COLOR2="a_color2",be.TEXCOORDS="a_texCoords",be.SAMPLER="u_texture";var Ri=class{constructor(e,t,i,s){this.attributes=t,this.verticesBuffer=null,this.verticesLength=0,this.dirtyVertices=!1,this.indicesBuffer=null,this.indicesLength=0,this.dirtyIndices=!1,this.elementsPerVertex=0,this.context=e instanceof ye?e:new ye(e),this.elementsPerVertex=0;for(let n=0;n<t.length;n++)this.elementsPerVertex+=t[n].numElements;this.vertices=new Float32Array(i*this.elementsPerVertex),this.indices=new Uint16Array(s),this.context.addRestorable(this)}getAttributes(){return this.attributes}maxVertices(){return this.vertices.length/this.elementsPerVertex}numVertices(){return this.verticesLength/this.elementsPerVertex}setVerticesLength(e){this.dirtyVertices=!0,this.verticesLength=e}getVertices(){return this.vertices}maxIndices(){return this.indices.length}numIndices(){return this.indicesLength}setIndicesLength(e){this.dirtyIndices=!0,this.indicesLength=e}getIndices(){return this.indices}getVertexSizeInFloats(){let e=0;for(var t=0;t<this.attributes.length;t++)e+=this.attributes[t].numElements;return e}setVertices(e){if(this.dirtyVertices=!0,e.length>this.vertices.length)throw Error("Mesh can't store more than "+this.maxVertices()+" vertices");this.vertices.set(e,0),this.verticesLength=e.length}setIndices(e){if(this.dirtyIndices=!0,e.length>this.indices.length)throw Error("Mesh can't store more than "+this.maxIndices()+" indices");this.indices.set(e,0),this.indicesLength=e.length}draw(e,t){this.drawWithOffset(e,t,0,this.indicesLength>0?this.indicesLength:this.verticesLength/this.elementsPerVertex)}drawWithOffset(e,t,i,s){let n=this.context.gl;(this.dirtyVertices||this.dirtyIndices)&&this.update(),this.bind(e),this.indicesLength>0?n.drawElements(t,s,n.UNSIGNED_SHORT,i*2):n.drawArrays(t,i,s),this.unbind(e)}bind(e){let t=this.context.gl;t.bindBuffer(t.ARRAY_BUFFER,this.verticesBuffer);let i=0;for(let s=0;s<this.attributes.length;s++){let n=this.attributes[s],c=e.getAttributeLocation(n.name);t.enableVertexAttribArray(c),t.vertexAttribPointer(c,n.numElements,t.FLOAT,!1,this.elementsPerVertex*4,i*4),i+=n.numElements}this.indicesLength>0&&t.bindBuffer(t.ELEMENT_ARRAY_BUFFER,this.indicesBuffer)}unbind(e){let t=this.context.gl;for(let i=0;i<this.attributes.length;i++){let s=this.attributes[i],n=e.getAttributeLocation(s.name);t.disableVertexAttribArray(n)}t.bindBuffer(t.ARRAY_BUFFER,null),this.indicesLength>0&&t.bindBuffer(t.ELEMENT_ARRAY_BUFFER,null)}update(){let e=this.context.gl;this.dirtyVertices&&(this.verticesBuffer||(this.verticesBuffer=e.createBuffer()),e.bindBuffer(e.ARRAY_BUFFER,this.verticesBuffer),e.bufferData(e.ARRAY_BUFFER,this.vertices.subarray(0,this.verticesLength),e.DYNAMIC_DRAW),this.dirtyVertices=!1),this.dirtyIndices&&(this.indicesBuffer||(this.indicesBuffer=e.createBuffer()),e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,this.indicesBuffer),e.bufferData(e.ELEMENT_ARRAY_BUFFER,this.indices.subarray(0,this.indicesLength),e.DYNAMIC_DRAW),this.dirtyIndices=!1)}restore(){this.verticesBuffer=null,this.indicesBuffer=null,this.update()}dispose(){this.context.removeRestorable(this);let e=this.context.gl;e.deleteBuffer(this.verticesBuffer),e.deleteBuffer(this.indicesBuffer)}},lt=class{constructor(e,t,i){this.name=e,this.type=t,this.numElements=i}},Xt=class extends lt{constructor(){super(be.POSITION,je.Float,2)}},cr=class extends lt{constructor(){super(be.POSITION,je.Float,3)}},Fi=class extends lt{constructor(e=0){super(be.TEXCOORDS+(e==0?"":e),je.Float,2)}},Lt=class extends lt{constructor(){super(be.COLOR,je.Float,4)}},fs=class extends lt{constructor(){super(be.COLOR2,je.Float,4)}},je;(function(e){e[e.Float=0]="Float"})(je||(je={}));var Xi=class{constructor(e,t=!0,i=10920){if(this.drawCalls=0,this.isDrawing=!1,this.shader=null,this.lastTexture=null,this.verticesLength=0,this.indicesLength=0,this.cullWasEnabled=!1,i>10920)throw new Error("Can't have more than 10920 triangles per batch: "+i);this.context=e instanceof ye?e:new ye(e);let s=t?[new Xt,new Lt,new Fi,new fs]:[new Xt,new Lt,new Fi];this.mesh=new Ri(e,s,i,i*3);let n=this.context.gl;this.srcColorBlend=n.SRC_ALPHA,this.srcAlphaBlend=n.ONE,this.dstBlend=n.ONE_MINUS_SRC_ALPHA}begin(e){if(this.isDrawing)throw new Error("PolygonBatch is already drawing. Call PolygonBatch.end() before calling PolygonBatch.begin()");this.drawCalls=0,this.shader=e,this.lastTexture=null,this.isDrawing=!0;let t=this.context.gl;t.enable(t.BLEND),t.blendFuncSeparate(this.srcColorBlend,this.dstBlend,this.srcAlphaBlend,this.dstBlend),this.cullWasEnabled=t.isEnabled(t.CULL_FACE),this.cullWasEnabled&&t.disable(t.CULL_FACE)}setBlendMode(e,t,i){this.srcColorBlend==e&&this.srcAlphaBlend==t&&this.dstBlend==i||(this.srcColorBlend=e,this.srcAlphaBlend=t,this.dstBlend=i,this.isDrawing&&(this.flush(),this.context.gl.blendFuncSeparate(e,i,t,i)))}draw(e,t,i){e!=this.lastTexture?(this.flush(),this.lastTexture=e):(this.verticesLength+t.length>this.mesh.getVertices().length||this.indicesLength+i.length>this.mesh.getIndices().length)&&this.flush();let s=this.mesh.numVertices();this.mesh.getVertices().set(t,this.verticesLength),this.verticesLength+=t.length,this.mesh.setVerticesLength(this.verticesLength);let n=this.mesh.getIndices();for(let c=this.indicesLength,a=0;a<i.length;c++,a++)n[c]=i[a]+s;this.indicesLength+=i.length,this.mesh.setIndicesLength(this.indicesLength)}flush(){if(this.verticesLength!=0){if(!this.lastTexture)throw new Error("No texture set.");if(!this.shader)throw new Error("No shader set.");this.lastTexture.bind(),this.mesh.draw(this.shader,this.context.gl.TRIANGLES),this.verticesLength=0,this.indicesLength=0,this.mesh.setVerticesLength(0),this.mesh.setIndicesLength(0),this.drawCalls++}}end(){if(!this.isDrawing)throw new Error("PolygonBatch is not drawing. Call PolygonBatch.begin() before calling PolygonBatch.end()");(this.verticesLength>0||this.indicesLength>0)&&this.flush(),this.shader=null,this.lastTexture=null,this.isDrawing=!1;let e=this.context.gl;e.disable(e.BLEND),this.cullWasEnabled&&e.enable(e.CULL_FACE)}getDrawCalls(){return this.drawCalls}dispose(){this.mesh.dispose()}},Li=class{constructor(e,t=10920){if(this.isDrawing=!1,this.shapeType=Ae.Filled,this.color=new O(1,1,1,1),this.shader=null,this.vertexIndex=0,this.tmp=new Je,t>10920)throw new Error("Can't have more than 10920 triangles per batch: "+t);this.context=e instanceof ye?e:new ye(e),this.mesh=new Ri(e,[new Xt,new Lt],t,0);let i=this.context.gl;this.srcColorBlend=i.SRC_ALPHA,this.srcAlphaBlend=i.ONE,this.dstBlend=i.ONE_MINUS_SRC_ALPHA}begin(e){if(this.isDrawing)throw new Error("ShapeRenderer.begin() has already been called");this.shader=e,this.vertexIndex=0,this.isDrawing=!0;let t=this.context.gl;t.enable(t.BLEND),t.blendFuncSeparate(this.srcColorBlend,this.dstBlend,this.srcAlphaBlend,this.dstBlend)}setBlendMode(e,t,i){this.srcColorBlend=e,this.srcAlphaBlend=t,this.dstBlend=i,this.isDrawing&&(this.flush(),this.context.gl.blendFuncSeparate(e,i,t,i))}setColor(e){this.color.setFromColor(e)}setColorWith(e,t,i,s){this.color.set(e,t,i,s)}point(e,t,i){this.check(Ae.Point,1),i||(i=this.color),this.vertex(e,t,i)}line(e,t,i,s,n){this.check(Ae.Line,2);let c=this.mesh.getVertices(),a=this.vertexIndex;n||(n=this.color),this.vertex(e,t,n),this.vertex(i,s,n)}triangle(e,t,i,s,n,c,a,r,o,l){this.check(e?Ae.Filled:Ae.Line,3);let h=this.mesh.getVertices(),f=this.vertexIndex;r||(r=this.color),o||(o=this.color),l||(l=this.color),e?(this.vertex(t,i,r),this.vertex(s,n,o),this.vertex(c,a,l)):(this.vertex(t,i,r),this.vertex(s,n,o),this.vertex(s,n,r),this.vertex(c,a,o),this.vertex(c,a,r),this.vertex(t,i,o))}quad(e,t,i,s,n,c,a,r,o,l,h,f,d){this.check(e?Ae.Filled:Ae.Line,3);let u=this.mesh.getVertices(),m=this.vertexIndex;l||(l=this.color),h||(h=this.color),f||(f=this.color),d||(d=this.color),e?(this.vertex(t,i,l),this.vertex(s,n,h),this.vertex(c,a,f),this.vertex(c,a,f),this.vertex(r,o,d),this.vertex(t,i,l)):(this.vertex(t,i,l),this.vertex(s,n,h),this.vertex(s,n,h),this.vertex(c,a,f),this.vertex(c,a,f),this.vertex(r,o,d),this.vertex(r,o,d),this.vertex(t,i,l))}rect(e,t,i,s,n,c){this.quad(e,t,i,t+s,i,t+s,i+n,t,i+n,c,c,c,c)}rectLine(e,t,i,s,n,c,a){this.check(e?Ae.Filled:Ae.Line,8),a||(a=this.color);let r=this.tmp.set(n-i,t-s);r.normalize(),c*=.5;let o=r.x*c,l=r.y*c;e?(this.vertex(t+o,i+l,a),this.vertex(t-o,i-l,a),this.vertex(s+o,n+l,a),this.vertex(s-o,n-l,a),this.vertex(s+o,n+l,a),this.vertex(t-o,i-l,a)):(this.vertex(t+o,i+l,a),this.vertex(t-o,i-l,a),this.vertex(s+o,n+l,a),this.vertex(s-o,n-l,a),this.vertex(s+o,n+l,a),this.vertex(t+o,i+l,a),this.vertex(s-o,n-l,a),this.vertex(t-o,i-l,a))}x(e,t,i){this.line(e-i,t-i,e+i,t+i),this.line(e-i,t+i,e+i,t-i)}polygon(e,t,i,s){if(i<3)throw new Error("Polygon must contain at least 3 vertices");this.check(Ae.Line,i*2),s||(s=this.color);let n=this.mesh.getVertices(),c=this.vertexIndex;t<<=1,i<<=1;let a=e[t],r=e[t+1],o=t+i;for(let l=t,h=t+i-2;l<h;l+=2){let f=e[l],d=e[l+1],u=0,m=0;l+2>=o?(u=a,m=r):(u=e[l+2],m=e[l+3]),this.vertex(f,d,s),this.vertex(u,m,s)}}circle(e,t,i,s,n,c=0){if(c==0&&(c=Math.max(1,6*R.cbrt(s)|0)),c<=0)throw new Error("segments must be > 0.");n||(n=this.color);let a=2*R.PI/c,r=Math.cos(a),o=Math.sin(a),l=s,h=0;if(e){this.check(Ae.Filled,c*3+3),c--;for(let d=0;d<c;d++){this.vertex(t,i,n),this.vertex(t+l,i+h,n);let u=l;l=r*l-o*h,h=o*u+r*h,this.vertex(t+l,i+h,n)}this.vertex(t,i,n),this.vertex(t+l,i+h,n)}else{this.check(Ae.Line,c*2+2);for(let d=0;d<c;d++){this.vertex(t+l,i+h,n);let u=l;l=r*l-o*h,h=o*u+r*h,this.vertex(t+l,i+h,n)}this.vertex(t+l,i+h,n)}let f=l;l=s,h=0,this.vertex(t+l,i+h,n)}curve(e,t,i,s,n,c,a,r,o,l){this.check(Ae.Line,o*2+2),l||(l=this.color);let h=1/o,f=h*h,d=h*h*h,u=3*h,m=3*f,x=6*f,b=6*d,v=e-i*2+n,g=t-s*2+c,w=(i-n)*3-e+a,p=(s-c)*3-t+r,y=e,S=t,A=(i-e)*u+v*m+w*d,I=(s-t)*u+g*m+p*d,Y=v*x+w*b,k=g*x+p*b,X=w*b,F=p*b;for(;o-- >0;)this.vertex(y,S,l),y+=A,S+=I,A+=Y,I+=k,Y+=X,k+=F,this.vertex(y,S,l);this.vertex(y,S,l),this.vertex(a,r,l)}vertex(e,t,i){let s=this.vertexIndex,n=this.mesh.getVertices();n[s++]=e,n[s++]=t,n[s++]=i.r,n[s++]=i.g,n[s++]=i.b,n[s++]=i.a,this.vertexIndex=s}end(){if(!this.isDrawing)throw new Error("ShapeRenderer.begin() has not been called");this.flush();let e=this.context.gl;e.disable(e.BLEND),this.isDrawing=!1}flush(){if(this.vertexIndex!=0){if(!this.shader)throw new Error("No shader set.");this.mesh.setVerticesLength(this.vertexIndex),this.mesh.draw(this.shader,this.shapeType),this.vertexIndex=0}}check(e,t){if(!this.isDrawing)throw new Error("ShapeRenderer.begin() has not been called");if(this.shapeType==e)if(this.mesh.maxVertices()-this.mesh.numVertices()<t)this.flush();else return;else this.flush(),this.shapeType=e}dispose(){this.mesh.dispose()}},Ae;(function(e){e[e.Point=0]="Point",e[e.Line=1]="Line",e[e.Filled=4]="Filled"})(Ae||(Ae={}));var Pt=class{constructor(e){this.boneLineColor=new O(1,0,0,1),this.boneOriginColor=new O(0,1,0,1),this.attachmentLineColor=new O(0,0,1,.5),this.triangleLineColor=new O(1,.64,0,.5),this.pathColor=new O().setFromString("FF7F00"),this.clipColor=new O(.8,0,0,2),this.aabbColor=new O(0,1,0,.5),this.drawBones=!0,this.drawRegionAttachments=!0,this.drawBoundingBoxes=!0,this.drawMeshHull=!0,this.drawMeshTriangles=!0,this.drawPaths=!0,this.drawSkeletonXY=!1,this.drawClipping=!0,this.premultipliedAlpha=!1,this.scale=1,this.boneWidth=2,this.bounds=new ls,this.temp=new Array,this.vertices=B.newFloatArray(2*1024),this.context=e instanceof ye?e:new ye(e)}draw(e,t,i){let s=t.x,n=t.y,c=this.context.gl,a=this.premultipliedAlpha?c.ONE:c.SRC_ALPHA;e.setBlendMode(a,c.ONE,c.ONE_MINUS_SRC_ALPHA);let r=t.bones;if(this.drawBones){e.setColor(this.boneLineColor);for(let o=0,l=r.length;o<l;o++){let h=r[o];if(i&&i.indexOf(h.data.name)>-1||!h.parent)continue;let f=h.data.length*h.a+h.worldX,d=h.data.length*h.c+h.worldY;e.rectLine(!0,h.worldX,h.worldY,f,d,this.boneWidth*this.scale)}this.drawSkeletonXY&&e.x(s,n,4*this.scale)}if(this.drawRegionAttachments){e.setColor(this.attachmentLineColor);let o=t.slots;for(let l=0,h=o.length;l<h;l++){let f=o[l],d=f.getAttachment();if(d instanceof ne){let u=d,m=this.vertices;u.computeWorldVertices(f,m,0,2),e.line(m[0],m[1],m[2],m[3]),e.line(m[2],m[3],m[4],m[5]),e.line(m[4],m[5],m[6],m[7]),e.line(m[6],m[7],m[0],m[1])}}}if(this.drawMeshHull||this.drawMeshTriangles){let o=t.slots;for(let l=0,h=o.length;l<h;l++){let f=o[l];if(!f.bone.active)continue;let d=f.getAttachment();if(!(d instanceof Ge))continue;let u=d,m=this.vertices;u.computeWorldVertices(f,0,u.worldVerticesLength,m,0,2);let x=u.triangles,b=u.hullLength;if(this.drawMeshTriangles){e.setColor(this.triangleLineColor);for(let v=0,g=x.length;v<g;v+=3){let w=x[v]*2,p=x[v+1]*2,y=x[v+2]*2;e.triangle(!1,m[w],m[w+1],m[p],m[p+1],m[y],m[y+1])}}if(this.drawMeshHull&&b>0){e.setColor(this.attachmentLineColor),b=(b>>1)*2;let v=m[b-2],g=m[b-1];for(let w=0,p=b;w<p;w+=2){let y=m[w],S=m[w+1];e.line(y,S,v,g),v=y,g=S}}}}if(this.drawBoundingBoxes){let o=this.bounds;o.update(t,!0),e.setColor(this.aabbColor),e.rect(!1,o.minX,o.minY,o.getWidth(),o.getHeight());let l=o.polygons,h=o.boundingBoxes;for(let f=0,d=l.length;f<d;f++){let u=l[f];e.setColor(h[f].color),e.polygon(u,0,u.length)}}if(this.drawPaths){let o=t.slots;for(let l=0,h=o.length;l<h;l++){let f=o[l];if(!f.bone.active)continue;let d=f.getAttachment();if(!(d instanceof tt))continue;let u=d,m=u.worldVerticesLength,x=this.temp=B.setArraySize(this.temp,m,0);u.computeWorldVertices(f,0,m,x,0,2);let b=this.pathColor,v=x[2],g=x[3],w=0,p=0;if(u.closed){e.setColor(b);let y=x[0],S=x[1],A=x[m-2],I=x[m-1];w=x[m-4],p=x[m-3],e.curve(v,g,y,S,A,I,w,p,32),e.setColor(Pt.LIGHT_GRAY),e.line(v,g,y,S),e.line(w,p,A,I)}m-=4;for(let y=4;y<m;y+=6){let S=x[y],A=x[y+1],I=x[y+2],Y=x[y+3];w=x[y+4],p=x[y+5],e.setColor(b),e.curve(v,g,S,A,I,Y,w,p,32),e.setColor(Pt.LIGHT_GRAY),e.line(v,g,S,A),e.line(w,p,I,Y),v=w,g=p}}}if(this.drawBones){e.setColor(this.boneOriginColor);for(let o=0,l=r.length;o<l;o++){let h=r[o];i&&i.indexOf(h.data.name)>-1||e.circle(!0,h.worldX,h.worldY,3*this.scale,Pt.GREEN,8)}}if(this.drawClipping){let o=t.slots;e.setColor(this.clipColor);for(let l=0,h=o.length;l<h;l++){let f=o[l];if(!f.bone.active)continue;let d=f.getAttachment();if(!(d instanceof xt))continue;let u=d,m=u.worldVerticesLength,x=this.temp=B.setArraySize(this.temp,m,0);u.computeWorldVertices(f,0,m,x,0,2);for(let b=0,v=x.length;b<v;b+=2){let g=x[b],w=x[b+1],p=x[(b+2)%x.length],y=x[(b+3)%x.length];e.line(g,w,p,y)}}}}dispose(){}},Bt=Pt;Bt.LIGHT_GRAY=new O(192/255,192/255,192/255,1),Bt.GREEN=new O(0,1,0,1);var dr=class{constructor(e,t,i){this.vertices=e,this.numVertices=t,this.numFloats=i}},us=class{constructor(e,t=!0){this.premultipliedAlpha=!1,this.tempColor=new O,this.tempColor2=new O,this.vertexSize=2+2+4,this.twoColorTint=!1,this.renderable=new dr([],0,0),this.clipper=new Yt,this.temp=new Je,this.temp2=new Je,this.temp3=new O,this.temp4=new O,this.twoColorTint=t,t&&(this.vertexSize+=4),this.vertices=B.newFloatArray(this.vertexSize*1024)}draw(e,t,i=-1,s=-1){let n=this.clipper,c=this.premultipliedAlpha,a=this.twoColorTint,r=null,o=this.temp,l=this.temp2,h=this.temp3,f=this.temp4,d=this.renderable,u,m,x=t.drawOrder,b,v=t.color,g=a?12:8,w=!1;i==-1&&(w=!0);for(let p=0,y=x.length;p<y;p++){let S=n.isClipping()?2:g,A=x[p];if(!A.bone.active){n.clipEndWithSlot(A);continue}if(i>=0&&i==A.data.index&&(w=!0),!w){n.clipEndWithSlot(A);continue}s>=0&&s==A.data.index&&(w=!1);let I=A.getAttachment(),Y;if(I instanceof ne){let k=I;d.vertices=this.vertices,d.numVertices=4,d.numFloats=S<<2,k.computeWorldVertices(A,d.vertices,0,S),m=us.QUAD_TRIANGLES,u=k.uvs,Y=k.region.renderObject.page.texture,b=k.color}else if(I instanceof Ge){let k=I;d.vertices=this.vertices,d.numVertices=k.worldVerticesLength>>1,d.numFloats=d.numVertices*S,d.numFloats>d.vertices.length&&(d.vertices=this.vertices=B.newFloatArray(d.numFloats)),k.computeWorldVertices(A,0,k.worldVerticesLength,d.vertices,0,S),m=k.triangles,Y=k.region.renderObject.page.texture,u=k.uvs,b=k.color}else if(I instanceof xt){let k=I;n.clipStart(A,k);continue}else{n.clipEndWithSlot(A);continue}if(Y){let k=A.color,X=this.tempColor;X.r=v.r*k.r*b.r,X.g=v.g*k.g*b.g,X.b=v.b*k.b*b.b,X.a=v.a*k.a*b.a,c&&(X.r*=X.a,X.g*=X.a,X.b*=X.a);let F=this.tempColor2;A.darkColor?(c?(F.r=A.darkColor.r*X.a,F.g=A.darkColor.g*X.a,F.b=A.darkColor.b*X.a):F.setFromColor(A.darkColor),F.a=c?1:0):F.set(0,0,0,1);let L=A.data.blendMode;if(L!=r&&(r=L,e.setBlendMode(Rt.getSourceColorGLBlendMode(r,c),Rt.getSourceAlphaGLBlendMode(r),Rt.getDestGLBlendMode(r))),n.isClipping()){n.clipTriangles(d.vertices,d.numFloats,m,m.length,u,X,F,a);let T=new Float32Array(n.clippedVertices),M=n.clippedTriangles;e.draw(Y,T,M)}else{let T=d.vertices;if(a)for(let P=2,ee=0,te=d.numFloats;P<te;P+=g,ee+=2)T[P]=X.r,T[P+1]=X.g,T[P+2]=X.b,T[P+3]=X.a,T[P+4]=u[ee],T[P+5]=u[ee+1],T[P+6]=F.r,T[P+7]=F.g,T[P+8]=F.b,T[P+9]=F.a;else for(let P=2,ee=0,te=d.numFloats;P<te;P+=g,ee+=2)T[P]=X.r,T[P+1]=X.g,T[P+2]=X.b,T[P+3]=X.a,T[P+4]=u[ee],T[P+5]=u[ee+1];let M=d.vertices.subarray(0,d.numFloats);e.draw(Y,M,m)}}n.clipEndWithSlot(A)}n.clipEnd()}},Pi=us;Pi.QUAD_TRIANGLES=[0,1,2,2,3,0];var C=[0,0,1,1,1,1,0,0,0,0,1,1,1,1,0,0,0,0,1,1,1,1,0,0,0,0,1,1,1,1,0,0],Ot=[0,1,2,2,3,0],Dt=new O(1,1,1,1),ms=class{constructor(e,t,i=!0){this.twoColorTint=!1,this.activeRenderer=null,this.canvas=e,this.context=t instanceof ye?t:new ye(t),this.twoColorTint=i,this.camera=new cs(e.width,e.height),this.batcherShader=i?be.newTwoColoredTextured(this.context):be.newColoredTextured(this.context),this.batcher=new Xi(this.context,i),this.shapesShader=be.newColored(this.context),this.shapes=new Li(this.context),this.skeletonRenderer=new Pi(this.context,i),this.skeletonDebugRenderer=new Bt(this.context)}dispose(){this.batcher.dispose(),this.batcherShader.dispose(),this.shapes.dispose(),this.shapesShader.dispose(),this.skeletonDebugRenderer.dispose()}begin(){this.camera.update(),this.enableRenderer(this.batcher)}drawSkeleton(e,t=!1,i=-1,s=-1){this.enableRenderer(this.batcher),this.skeletonRenderer.premultipliedAlpha=t,this.skeletonRenderer.draw(this.batcher,e,i,s)}drawSkeletonDebug(e,t=!1,i){this.enableRenderer(this.shapes),this.skeletonDebugRenderer.premultipliedAlpha=t,this.skeletonDebugRenderer.draw(this.shapes,e,i)}drawTexture(e,t,i,s,n,c){this.enableRenderer(this.batcher),c||(c=Dt);var a=0;C[a++]=t,C[a++]=i,C[a++]=c.r,C[a++]=c.g,C[a++]=c.b,C[a++]=c.a,C[a++]=0,C[a++]=1,this.twoColorTint&&(C[a++]=0,C[a++]=0,C[a++]=0,C[a++]=0),C[a++]=t+s,C[a++]=i,C[a++]=c.r,C[a++]=c.g,C[a++]=c.b,C[a++]=c.a,C[a++]=1,C[a++]=1,this.twoColorTint&&(C[a++]=0,C[a++]=0,C[a++]=0,C[a++]=0),C[a++]=t+s,C[a++]=i+n,C[a++]=c.r,C[a++]=c.g,C[a++]=c.b,C[a++]=c.a,C[a++]=1,C[a++]=0,this.twoColorTint&&(C[a++]=0,C[a++]=0,C[a++]=0,C[a++]=0),C[a++]=t,C[a++]=i+n,C[a++]=c.r,C[a++]=c.g,C[a++]=c.b,C[a++]=c.a,C[a++]=0,C[a++]=0,this.twoColorTint&&(C[a++]=0,C[a++]=0,C[a++]=0,C[a]=0),this.batcher.draw(e,C,Ot)}drawTextureUV(e,t,i,s,n,c,a,r,o,l){this.enableRenderer(this.batcher),l||(l=Dt);var h=0;C[h++]=t,C[h++]=i,C[h++]=l.r,C[h++]=l.g,C[h++]=l.b,C[h++]=l.a,C[h++]=c,C[h++]=a,this.twoColorTint&&(C[h++]=0,C[h++]=0,C[h++]=0,C[h++]=0),C[h++]=t+s,C[h++]=i,C[h++]=l.r,C[h++]=l.g,C[h++]=l.b,C[h++]=l.a,C[h++]=r,C[h++]=a,this.twoColorTint&&(C[h++]=0,C[h++]=0,C[h++]=0,C[h++]=0),C[h++]=t+s,C[h++]=i+n,C[h++]=l.r,C[h++]=l.g,C[h++]=l.b,C[h++]=l.a,C[h++]=r,C[h++]=o,this.twoColorTint&&(C[h++]=0,C[h++]=0,C[h++]=0,C[h++]=0),C[h++]=t,C[h++]=i+n,C[h++]=l.r,C[h++]=l.g,C[h++]=l.b,C[h++]=l.a,C[h++]=c,C[h++]=o,this.twoColorTint&&(C[h++]=0,C[h++]=0,C[h++]=0,C[h]=0),this.batcher.draw(e,C,Ot)}drawTextureRotated(e,t,i,s,n,c,a,r,o){this.enableRenderer(this.batcher),o||(o=Dt);let l=t+c,h=i+a,f=-c,d=-a,u=s-c,m=n-a,x=f,b=d,v=f,g=m,w=u,p=m,y=u,S=d,A=0,I=0,Y=0,k=0,X=0,F=0,L=0,T=0;if(r!=0){let P=R.cosDeg(r),ee=R.sinDeg(r);A=P*x-ee*b,I=ee*x+P*b,L=P*v-ee*g,T=ee*v+P*g,X=P*w-ee*p,F=ee*w+P*p,Y=X+(A-L),k=F+(I-T)}else A=x,I=b,L=v,T=g,X=w,F=p,Y=y,k=S;A+=l,I+=h,Y+=l,k+=h,X+=l,F+=h,L+=l,T+=h;var M=0;C[M++]=A,C[M++]=I,C[M++]=o.r,C[M++]=o.g,C[M++]=o.b,C[M++]=o.a,C[M++]=0,C[M++]=1,this.twoColorTint&&(C[M++]=0,C[M++]=0,C[M++]=0,C[M++]=0),C[M++]=Y,C[M++]=k,C[M++]=o.r,C[M++]=o.g,C[M++]=o.b,C[M++]=o.a,C[M++]=1,C[M++]=1,this.twoColorTint&&(C[M++]=0,C[M++]=0,C[M++]=0,C[M++]=0),C[M++]=X,C[M++]=F,C[M++]=o.r,C[M++]=o.g,C[M++]=o.b,C[M++]=o.a,C[M++]=1,C[M++]=0,this.twoColorTint&&(C[M++]=0,C[M++]=0,C[M++]=0,C[M++]=0),C[M++]=L,C[M++]=T,C[M++]=o.r,C[M++]=o.g,C[M++]=o.b,C[M++]=o.a,C[M++]=0,C[M++]=0,this.twoColorTint&&(C[M++]=0,C[M++]=0,C[M++]=0,C[M]=0),this.batcher.draw(e,C,Ot)}drawRegion(e,t,i,s,n,c){this.enableRenderer(this.batcher),c||(c=Dt);var a=0;C[a++]=t,C[a++]=i,C[a++]=c.r,C[a++]=c.g,C[a++]=c.b,C[a++]=c.a,C[a++]=e.u,C[a++]=e.v2,this.twoColorTint&&(C[a++]=0,C[a++]=0,C[a++]=0,C[a++]=0),C[a++]=t+s,C[a++]=i,C[a++]=c.r,C[a++]=c.g,C[a++]=c.b,C[a++]=c.a,C[a++]=e.u2,C[a++]=e.v2,this.twoColorTint&&(C[a++]=0,C[a++]=0,C[a++]=0,C[a++]=0),C[a++]=t+s,C[a++]=i+n,C[a++]=c.r,C[a++]=c.g,C[a++]=c.b,C[a++]=c.a,C[a++]=e.u2,C[a++]=e.v,this.twoColorTint&&(C[a++]=0,C[a++]=0,C[a++]=0,C[a++]=0),C[a++]=t,C[a++]=i+n,C[a++]=c.r,C[a++]=c.g,C[a++]=c.b,C[a++]=c.a,C[a++]=e.u,C[a++]=e.v,this.twoColorTint&&(C[a++]=0,C[a++]=0,C[a++]=0,C[a]=0),this.batcher.draw(e.page.texture,C,Ot)}line(e,t,i,s,n,c){this.enableRenderer(this.shapes),this.shapes.line(e,t,i,s,n)}triangle(e,t,i,s,n,c,a,r,o,l){this.enableRenderer(this.shapes),this.shapes.triangle(e,t,i,s,n,c,a,r,o,l)}quad(e,t,i,s,n,c,a,r,o,l,h,f,d){this.enableRenderer(this.shapes),this.shapes.quad(e,t,i,s,n,c,a,r,o,l,h,f,d)}rect(e,t,i,s,n,c){this.enableRenderer(this.shapes),this.shapes.rect(e,t,i,s,n,c)}rectLine(e,t,i,s,n,c,a){this.enableRenderer(this.shapes),this.shapes.rectLine(e,t,i,s,n,c,a)}polygon(e,t,i,s){this.enableRenderer(this.shapes),this.shapes.polygon(e,t,i,s)}circle(e,t,i,s,n,c=0){this.enableRenderer(this.shapes),this.shapes.circle(e,t,i,s,n,c)}curve(e,t,i,s,n,c,a,r,o,l){this.enableRenderer(this.shapes),this.shapes.curve(e,t,i,s,n,c,a,r,o,l)}end(){this.activeRenderer===this.batcher?this.batcher.end():this.activeRenderer===this.shapes&&this.shapes.end(),this.activeRenderer=null}resize(e){let t=this.canvas;var i=window.devicePixelRatio||1,s=Math.round(t.clientWidth*i),n=Math.round(t.clientHeight*i);if((t.width!=s||t.height!=n)&&(t.width=s,t.height=n),this.context.gl.viewport(0,0,t.width,t.height),e===ot.Expand)this.camera.setViewport(s,n);else if(e===ot.Fit){let c=t.width,a=t.height,r=this.camera.viewportWidth,o=this.camera.viewportHeight,l=o/r,h=a/c,f=l<h?r/c:o/a;this.camera.setViewport(c*f,a*f)}this.camera.update()}enableRenderer(e){this.activeRenderer!==e&&(this.end(),e instanceof Xi?(this.batcherShader.bind(),this.batcherShader.setUniform4x4f(be.MVP_MATRIX,this.camera.projectionView.values),this.batcherShader.setUniformi("u_texture",0),this.batcher.begin(this.batcherShader),this.activeRenderer=this.batcher):e instanceof Li?(this.shapesShader.bind(),this.shapesShader.setUniform4x4f(be.MVP_MATRIX,this.camera.projectionView.values),this.shapes.begin(this.shapesShader),this.activeRenderer=this.shapes):this.activeRenderer=this.skeletonDebugRenderer)}},ot;(function(e){e[e.Stretch=0]="Stretch",e[e.Expand=1]="Expand",e[e.Fit=2]="Fit"})(ot||(ot={}));var pt,ht,gs=0,fr=1,Bi=1,xs=165,ws=108,it=163,ur=class{constructor(e){if(this.logo=null,this.spinner=null,this.angle=0,this.fadeOut=0,this.fadeIn=0,this.timeKeeper=new zt,this.backgroundColor=new O(.135,.135,.135,1),this.tempColor=new O,this.renderer=e,this.timeKeeper.maxDelta=9,!ht){let t=navigator.userAgent.indexOf("Safari")>-1,i=()=>gs++;ht=new Image,ht.src=gr,t||(ht.crossOrigin="anonymous"),ht.onload=i,pt=new Image,pt.src=mr,t||(pt.crossOrigin="anonymous"),pt.onload=i}}dispose(){var e,t;(e=this.logo)==null||e.dispose(),(t=this.spinner)==null||t.dispose()}draw(e=!1){if(gs<2||e&&this.fadeOut>Bi)return;this.timeKeeper.update();let t=Math.abs(Math.sin(this.timeKeeper.totalTime+.25));this.angle-=this.timeKeeper.delta*200*(1+1.5*Math.pow(t,5));let i=this.tempColor,s=this.renderer,n=s.canvas,c=s.context.gl;if(s.resize(ot.Expand),s.camera.position.set(n.width/2,n.height/2,0),s.batcher.setBlendMode(c.ONE,c.ONE,c.ONE_MINUS_SRC_ALPHA),e){if(this.fadeOut+=this.timeKeeper.delta*(this.timeKeeper.totalTime<1?2:1),this.fadeOut>Bi)return;i.setFromColor(this.backgroundColor),t=1-this.fadeOut/Bi,t=1-(t-1)*(t-1),i.a*=t,i.a>0&&(s.camera.zoom=1,s.begin(),s.quad(!0,0,0,n.width,0,n.width,n.height,0,n.height,i,i,i,i),s.end())}else this.fadeIn+=this.timeKeeper.delta,this.backgroundColor.a>0&&(c.clearColor(this.backgroundColor.r,this.backgroundColor.g,this.backgroundColor.b,this.backgroundColor.a),c.clear(c.COLOR_BUFFER_BIT)),t=1;t*=Math.min(this.fadeIn/fr,1),i.set(t,t,t,t),this.logo||(this.logo=new wt(s.context,ht),this.spinner=new wt(s.context,pt)),s.camera.zoom=Math.max(1,it/n.height),s.begin(),s.drawTexture(this.logo,(n.width-xs)/2,(n.height-ws)/2,xs,ws,i),this.spinner&&s.drawTextureRotated(this.spinner,(n.width-it)/2,(n.height-it)/2,it,it,it/2,it/2,this.angle,i),s.end()}},mr="data:image/png;base64,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",gr="data:image/png;base64,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",xr=class{constructor(e,t){this.time=new zt,t.pathPrefix||(t.pathPrefix=""),t.app||(t.app={loadAssets:()=>{},initialize:()=>{},update:()=>{},render:()=>{},error:()=>{}}),t.webglConfig&&(t.webglConfig={alpha:!0}),this.htmlCanvas=e,this.context=new ye(e,t.webglConfig),this.renderer=new ms(e,this.context),this.gl=this.context.gl,this.assetManager=new hs(this.context,t.pathPrefix),this.input=new ki(e),t.app.loadAssets&&t.app.loadAssets(this);let i=()=>{requestAnimationFrame(i),this.time.update(),t.app.update&&t.app.update(this,this.time.delta),t.app.render&&t.app.render(this)},s=()=>{if(this.assetManager.isLoadingComplete()){this.assetManager.hasErrors()?t.app.error&&t.app.error(this,this.assetManager.getErrors()):(t.app.initialize&&t.app.initialize(this),i());return}requestAnimationFrame(s)};requestAnimationFrame(s)}clear(e,t,i,s){this.gl.clearColor(e,t,i,s),this.gl.clear(this.gl.COLOR_BUFFER_BIT)}};return Ni})();
|
|
84
|
+
`;return new fe(e,t,i)}},be=fe;be.MVP_MATRIX="u_projTrans",be.POSITION="a_position",be.COLOR="a_color",be.COLOR2="a_color2",be.TEXCOORDS="a_texCoords",be.SAMPLER="u_texture";var ki=class{constructor(e,t,i,s){this.attributes=t,this.verticesBuffer=null,this.verticesLength=0,this.dirtyVertices=!1,this.indicesBuffer=null,this.indicesLength=0,this.dirtyIndices=!1,this.elementsPerVertex=0,this.context=e instanceof ye?e:new ye(e),this.elementsPerVertex=0;for(let n=0;n<t.length;n++)this.elementsPerVertex+=t[n].numElements;this.vertices=new Float32Array(i*this.elementsPerVertex),this.indices=new Uint16Array(s),this.context.addRestorable(this)}getAttributes(){return this.attributes}maxVertices(){return this.vertices.length/this.elementsPerVertex}numVertices(){return this.verticesLength/this.elementsPerVertex}setVerticesLength(e){this.dirtyVertices=!0,this.verticesLength=e}getVertices(){return this.vertices}maxIndices(){return this.indices.length}numIndices(){return this.indicesLength}setIndicesLength(e){this.dirtyIndices=!0,this.indicesLength=e}getIndices(){return this.indices}getVertexSizeInFloats(){let e=0;for(var t=0;t<this.attributes.length;t++)e+=this.attributes[t].numElements;return e}setVertices(e){if(this.dirtyVertices=!0,e.length>this.vertices.length)throw Error("Mesh can't store more than "+this.maxVertices()+" vertices");this.vertices.set(e,0),this.verticesLength=e.length}setIndices(e){if(this.dirtyIndices=!0,e.length>this.indices.length)throw Error("Mesh can't store more than "+this.maxIndices()+" indices");this.indices.set(e,0),this.indicesLength=e.length}draw(e,t){this.drawWithOffset(e,t,0,this.indicesLength>0?this.indicesLength:this.verticesLength/this.elementsPerVertex)}drawWithOffset(e,t,i,s){let n=this.context.gl;(this.dirtyVertices||this.dirtyIndices)&&this.update(),this.bind(e),this.indicesLength>0?n.drawElements(t,s,n.UNSIGNED_SHORT,i*2):n.drawArrays(t,i,s),this.unbind(e)}bind(e){let t=this.context.gl;t.bindBuffer(t.ARRAY_BUFFER,this.verticesBuffer);let i=0;for(let s=0;s<this.attributes.length;s++){let n=this.attributes[s],c=e.getAttributeLocation(n.name);t.enableVertexAttribArray(c),t.vertexAttribPointer(c,n.numElements,t.FLOAT,!1,this.elementsPerVertex*4,i*4),i+=n.numElements}this.indicesLength>0&&t.bindBuffer(t.ELEMENT_ARRAY_BUFFER,this.indicesBuffer)}unbind(e){let t=this.context.gl;for(let i=0;i<this.attributes.length;i++){let s=this.attributes[i],n=e.getAttributeLocation(s.name);t.disableVertexAttribArray(n)}t.bindBuffer(t.ARRAY_BUFFER,null),this.indicesLength>0&&t.bindBuffer(t.ELEMENT_ARRAY_BUFFER,null)}update(){let e=this.context.gl;this.dirtyVertices&&(this.verticesBuffer||(this.verticesBuffer=e.createBuffer()),e.bindBuffer(e.ARRAY_BUFFER,this.verticesBuffer),e.bufferData(e.ARRAY_BUFFER,this.vertices.subarray(0,this.verticesLength),e.DYNAMIC_DRAW),this.dirtyVertices=!1),this.dirtyIndices&&(this.indicesBuffer||(this.indicesBuffer=e.createBuffer()),e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,this.indicesBuffer),e.bufferData(e.ELEMENT_ARRAY_BUFFER,this.indices.subarray(0,this.indicesLength),e.DYNAMIC_DRAW),this.dirtyIndices=!1)}restore(){this.verticesBuffer=null,this.indicesBuffer=null,this.update()}dispose(){this.context.removeRestorable(this);let e=this.context.gl;e.deleteBuffer(this.verticesBuffer),e.deleteBuffer(this.indicesBuffer)}},lt=class{constructor(e,t,i){this.name=e,this.type=t,this.numElements=i}},Xt=class extends lt{constructor(){super(be.POSITION,je.Float,2)}},cr=class extends lt{constructor(){super(be.POSITION,je.Float,3)}},Ri=class extends lt{constructor(e=0){super(be.TEXCOORDS+(e==0?"":e),je.Float,2)}},Lt=class extends lt{constructor(){super(be.COLOR,je.Float,4)}},fs=class extends lt{constructor(){super(be.COLOR2,je.Float,4)}},je;(function(e){e[e.Float=0]="Float"})(je||(je={}));var Fi=class{constructor(e,t=!0,i=10920){if(this.drawCalls=0,this.isDrawing=!1,this.shader=null,this.lastTexture=null,this.verticesLength=0,this.indicesLength=0,this.cullWasEnabled=!1,i>10920)throw new Error("Can't have more than 10920 triangles per batch: "+i);this.context=e instanceof ye?e:new ye(e);let s=t?[new Xt,new Lt,new Ri,new fs]:[new Xt,new Lt,new Ri];this.mesh=new ki(e,s,i,i*3);let n=this.context.gl;this.srcColorBlend=n.SRC_ALPHA,this.srcAlphaBlend=n.ONE,this.dstBlend=n.ONE_MINUS_SRC_ALPHA}begin(e){if(this.isDrawing)throw new Error("PolygonBatch is already drawing. Call PolygonBatch.end() before calling PolygonBatch.begin()");this.drawCalls=0,this.shader=e,this.lastTexture=null,this.isDrawing=!0;let t=this.context.gl;t.enable(t.BLEND),t.blendFuncSeparate(this.srcColorBlend,this.dstBlend,this.srcAlphaBlend,this.dstBlend),this.cullWasEnabled=t.isEnabled(t.CULL_FACE),this.cullWasEnabled&&t.disable(t.CULL_FACE)}setBlendMode(e,t,i){this.srcColorBlend==e&&this.srcAlphaBlend==t&&this.dstBlend==i||(this.srcColorBlend=e,this.srcAlphaBlend=t,this.dstBlend=i,this.isDrawing&&(this.flush(),this.context.gl.blendFuncSeparate(e,i,t,i)))}draw(e,t,i){e!=this.lastTexture?(this.flush(),this.lastTexture=e):(this.verticesLength+t.length>this.mesh.getVertices().length||this.indicesLength+i.length>this.mesh.getIndices().length)&&this.flush();let s=this.mesh.numVertices();this.mesh.getVertices().set(t,this.verticesLength),this.verticesLength+=t.length,this.mesh.setVerticesLength(this.verticesLength);let n=this.mesh.getIndices();for(let c=this.indicesLength,a=0;a<i.length;c++,a++)n[c]=i[a]+s;this.indicesLength+=i.length,this.mesh.setIndicesLength(this.indicesLength)}flush(){if(this.verticesLength!=0){if(!this.lastTexture)throw new Error("No texture set.");if(!this.shader)throw new Error("No shader set.");this.lastTexture.bind(),this.mesh.draw(this.shader,this.context.gl.TRIANGLES),this.verticesLength=0,this.indicesLength=0,this.mesh.setVerticesLength(0),this.mesh.setIndicesLength(0),this.drawCalls++}}end(){if(!this.isDrawing)throw new Error("PolygonBatch is not drawing. Call PolygonBatch.begin() before calling PolygonBatch.end()");(this.verticesLength>0||this.indicesLength>0)&&this.flush(),this.shader=null,this.lastTexture=null,this.isDrawing=!1;let e=this.context.gl;e.disable(e.BLEND),this.cullWasEnabled&&e.enable(e.CULL_FACE)}getDrawCalls(){return this.drawCalls}dispose(){this.mesh.dispose()}},Xi=class{constructor(e,t=10920){if(this.isDrawing=!1,this.shapeType=Ae.Filled,this.color=new O(1,1,1,1),this.shader=null,this.vertexIndex=0,this.tmp=new Je,t>10920)throw new Error("Can't have more than 10920 triangles per batch: "+t);this.context=e instanceof ye?e:new ye(e),this.mesh=new ki(e,[new Xt,new Lt],t,0);let i=this.context.gl;this.srcColorBlend=i.SRC_ALPHA,this.srcAlphaBlend=i.ONE,this.dstBlend=i.ONE_MINUS_SRC_ALPHA}begin(e){if(this.isDrawing)throw new Error("ShapeRenderer.begin() has already been called");this.shader=e,this.vertexIndex=0,this.isDrawing=!0;let t=this.context.gl;t.enable(t.BLEND),t.blendFuncSeparate(this.srcColorBlend,this.dstBlend,this.srcAlphaBlend,this.dstBlend)}setBlendMode(e,t,i){this.srcColorBlend=e,this.srcAlphaBlend=t,this.dstBlend=i,this.isDrawing&&(this.flush(),this.context.gl.blendFuncSeparate(e,i,t,i))}setColor(e){this.color.setFromColor(e)}setColorWith(e,t,i,s){this.color.set(e,t,i,s)}point(e,t,i){this.check(Ae.Point,1),i||(i=this.color),this.vertex(e,t,i)}line(e,t,i,s,n){this.check(Ae.Line,2);let c=this.mesh.getVertices(),a=this.vertexIndex;n||(n=this.color),this.vertex(e,t,n),this.vertex(i,s,n)}triangle(e,t,i,s,n,c,a,r,o,l){this.check(e?Ae.Filled:Ae.Line,3);let h=this.mesh.getVertices(),f=this.vertexIndex;r||(r=this.color),o||(o=this.color),l||(l=this.color),e?(this.vertex(t,i,r),this.vertex(s,n,o),this.vertex(c,a,l)):(this.vertex(t,i,r),this.vertex(s,n,o),this.vertex(s,n,r),this.vertex(c,a,o),this.vertex(c,a,r),this.vertex(t,i,o))}quad(e,t,i,s,n,c,a,r,o,l,h,f,d){this.check(e?Ae.Filled:Ae.Line,3);let u=this.mesh.getVertices(),m=this.vertexIndex;l||(l=this.color),h||(h=this.color),f||(f=this.color),d||(d=this.color),e?(this.vertex(t,i,l),this.vertex(s,n,h),this.vertex(c,a,f),this.vertex(c,a,f),this.vertex(r,o,d),this.vertex(t,i,l)):(this.vertex(t,i,l),this.vertex(s,n,h),this.vertex(s,n,h),this.vertex(c,a,f),this.vertex(c,a,f),this.vertex(r,o,d),this.vertex(r,o,d),this.vertex(t,i,l))}rect(e,t,i,s,n,c){this.quad(e,t,i,t+s,i,t+s,i+n,t,i+n,c,c,c,c)}rectLine(e,t,i,s,n,c,a){this.check(e?Ae.Filled:Ae.Line,8),a||(a=this.color);let r=this.tmp.set(n-i,t-s);r.normalize(),c*=.5;let o=r.x*c,l=r.y*c;e?(this.vertex(t+o,i+l,a),this.vertex(t-o,i-l,a),this.vertex(s+o,n+l,a),this.vertex(s-o,n-l,a),this.vertex(s+o,n+l,a),this.vertex(t-o,i-l,a)):(this.vertex(t+o,i+l,a),this.vertex(t-o,i-l,a),this.vertex(s+o,n+l,a),this.vertex(s-o,n-l,a),this.vertex(s+o,n+l,a),this.vertex(t+o,i+l,a),this.vertex(s-o,n-l,a),this.vertex(t-o,i-l,a))}x(e,t,i){this.line(e-i,t-i,e+i,t+i),this.line(e-i,t+i,e+i,t-i)}polygon(e,t,i,s){if(i<3)throw new Error("Polygon must contain at least 3 vertices");this.check(Ae.Line,i*2),s||(s=this.color);let n=this.mesh.getVertices(),c=this.vertexIndex;t<<=1,i<<=1;let a=e[t],r=e[t+1],o=t+i;for(let l=t,h=t+i-2;l<h;l+=2){let f=e[l],d=e[l+1],u=0,m=0;l+2>=o?(u=a,m=r):(u=e[l+2],m=e[l+3]),this.vertex(f,d,s),this.vertex(u,m,s)}}circle(e,t,i,s,n,c=0){if(c==0&&(c=Math.max(1,6*R.cbrt(s)|0)),c<=0)throw new Error("segments must be > 0.");n||(n=this.color);let a=2*R.PI/c,r=Math.cos(a),o=Math.sin(a),l=s,h=0;if(e){this.check(Ae.Filled,c*3+3),c--;for(let d=0;d<c;d++){this.vertex(t,i,n),this.vertex(t+l,i+h,n);let u=l;l=r*l-o*h,h=o*u+r*h,this.vertex(t+l,i+h,n)}this.vertex(t,i,n),this.vertex(t+l,i+h,n)}else{this.check(Ae.Line,c*2+2);for(let d=0;d<c;d++){this.vertex(t+l,i+h,n);let u=l;l=r*l-o*h,h=o*u+r*h,this.vertex(t+l,i+h,n)}this.vertex(t+l,i+h,n)}let f=l;l=s,h=0,this.vertex(t+l,i+h,n)}curve(e,t,i,s,n,c,a,r,o,l){this.check(Ae.Line,o*2+2),l||(l=this.color);let h=1/o,f=h*h,d=h*h*h,u=3*h,m=3*f,x=6*f,b=6*d,v=e-i*2+n,g=t-s*2+c,w=(i-n)*3-e+a,p=(s-c)*3-t+r,y=e,S=t,A=(i-e)*u+v*m+w*d,I=(s-t)*u+g*m+p*d,E=v*x+w*b,k=g*x+p*b,X=w*b,F=p*b;for(;o-- >0;)this.vertex(y,S,l),y+=A,S+=I,A+=E,I+=k,E+=X,k+=F,this.vertex(y,S,l);this.vertex(y,S,l),this.vertex(a,r,l)}vertex(e,t,i){let s=this.vertexIndex,n=this.mesh.getVertices();n[s++]=e,n[s++]=t,n[s++]=i.r,n[s++]=i.g,n[s++]=i.b,n[s++]=i.a,this.vertexIndex=s}end(){if(!this.isDrawing)throw new Error("ShapeRenderer.begin() has not been called");this.flush();let e=this.context.gl;e.disable(e.BLEND),this.isDrawing=!1}flush(){if(this.vertexIndex!=0){if(!this.shader)throw new Error("No shader set.");this.mesh.setVerticesLength(this.vertexIndex),this.mesh.draw(this.shader,this.shapeType),this.vertexIndex=0}}check(e,t){if(!this.isDrawing)throw new Error("ShapeRenderer.begin() has not been called");if(this.shapeType==e)if(this.mesh.maxVertices()-this.mesh.numVertices()<t)this.flush();else return;else this.flush(),this.shapeType=e}dispose(){this.mesh.dispose()}},Ae;(function(e){e[e.Point=0]="Point",e[e.Line=1]="Line",e[e.Filled=4]="Filled"})(Ae||(Ae={}));var Li=class{constructor(e){this.boneLineColor=new O(1,0,0,1),this.boneOriginColor=new O(0,1,0,1),this.attachmentLineColor=new O(0,0,1,.5),this.triangleLineColor=new O(1,.64,0,.5),this.pathColor=new O().setFromString("FF7F00"),this.clipColor=new O(.8,0,0,2),this.aabbColor=new O(0,1,0,.5),this.drawBones=!0,this.drawRegionAttachments=!0,this.drawBoundingBoxes=!0,this.drawMeshHull=!0,this.drawMeshTriangles=!0,this.drawPaths=!0,this.drawSkeletonXY=!1,this.drawClipping=!0,this.premultipliedAlpha=!1,this.scale=1,this.boneWidth=2,this.bounds=new ls,this.temp=new Array,this.vertices=B.newFloatArray(2*1024),this.context=e instanceof ye?e:new ye(e)}draw(e,t,i){let s=t.x,n=t.y,c=this.context.gl,a=this.premultipliedAlpha?c.ONE:c.SRC_ALPHA;e.setBlendMode(a,c.ONE,c.ONE_MINUS_SRC_ALPHA);let r=t.bones;if(this.drawBones){e.setColor(this.boneLineColor);for(let o=0,l=r.length;o<l;o++){let h=r[o];if(i&&i.indexOf(h.data.name)>-1||!h.parent)continue;let f=h.data.length*h.a+h.worldX,d=h.data.length*h.c+h.worldY;e.rectLine(!0,h.worldX,h.worldY,f,d,this.boneWidth*this.scale)}this.drawSkeletonXY&&e.x(s,n,4*this.scale)}if(this.drawRegionAttachments){e.setColor(this.attachmentLineColor);let o=t.slots;for(let l=0,h=o.length;l<h;l++){let f=o[l],d=f.getAttachment();if(d instanceof ne){let u=d,m=this.vertices;u.computeWorldVertices(f,m,0,2),e.line(m[0],m[1],m[2],m[3]),e.line(m[2],m[3],m[4],m[5]),e.line(m[4],m[5],m[6],m[7]),e.line(m[6],m[7],m[0],m[1])}}}if(this.drawMeshHull||this.drawMeshTriangles){let o=t.slots;for(let l=0,h=o.length;l<h;l++){let f=o[l];if(!f.bone.active)continue;let d=f.getAttachment();if(!(d instanceof Ge))continue;let u=d,m=this.vertices;u.computeWorldVertices(f,0,u.worldVerticesLength,m,0,2);let x=u.triangles,b=u.hullLength;if(this.drawMeshTriangles){e.setColor(this.triangleLineColor);for(let v=0,g=x.length;v<g;v+=3){let w=x[v]*2,p=x[v+1]*2,y=x[v+2]*2;e.triangle(!1,m[w],m[w+1],m[p],m[p+1],m[y],m[y+1])}}if(this.drawMeshHull&&b>0){e.setColor(this.attachmentLineColor),b=(b>>1)*2;let v=m[b-2],g=m[b-1];for(let w=0,p=b;w<p;w+=2){let y=m[w],S=m[w+1];e.line(y,S,v,g),v=y,g=S}}}}if(this.drawBoundingBoxes){let o=this.bounds;o.update(t,!0),e.setColor(this.aabbColor),e.rect(!1,o.minX,o.minY,o.getWidth(),o.getHeight());let l=o.polygons,h=o.boundingBoxes;for(let f=0,d=l.length;f<d;f++){let u=l[f];e.setColor(h[f].color),e.polygon(u,0,u.length)}}if(this.drawPaths){let o=t.slots;for(let l=0,h=o.length;l<h;l++){let f=o[l];if(!f.bone.active)continue;let d=f.getAttachment();if(!(d instanceof tt))continue;let u=d,m=u.worldVerticesLength,x=this.temp=B.setArraySize(this.temp,m,0);u.computeWorldVertices(f,0,m,x,0,2);let b=this.pathColor,v=x[2],g=x[3],w=0,p=0;if(u.closed){e.setColor(b);let y=x[0],S=x[1],A=x[m-2],I=x[m-1];w=x[m-4],p=x[m-3],e.curve(v,g,y,S,A,I,w,p,32),e.setColor(Li.LIGHT_GRAY),e.line(v,g,y,S),e.line(w,p,A,I)}m-=4;for(let y=4;y<m;y+=6){let S=x[y],A=x[y+1],I=x[y+2],E=x[y+3];w=x[y+4],p=x[y+5],e.setColor(b),e.curve(v,g,S,A,I,E,w,p,32),e.setColor(Li.LIGHT_GRAY),e.line(v,g,S,A),e.line(w,p,I,E),v=w,g=p}}}if(this.drawBones){e.setColor(this.boneOriginColor);for(let o=0,l=r.length;o<l;o++){let h=r[o];i&&i.indexOf(h.data.name)>-1||e.circle(!0,h.worldX,h.worldY,3*this.scale,this.boneOriginColor,8)}}if(this.drawClipping){let o=t.slots;e.setColor(this.clipColor);for(let l=0,h=o.length;l<h;l++){let f=o[l];if(!f.bone.active)continue;let d=f.getAttachment();if(!(d instanceof xt))continue;let u=d,m=u.worldVerticesLength,x=this.temp=B.setArraySize(this.temp,m,0);u.computeWorldVertices(f,0,m,x,0,2);for(let b=0,v=x.length;b<v;b+=2){let g=x[b],w=x[b+1],p=x[(b+2)%x.length],y=x[(b+3)%x.length];e.line(g,w,p,y)}}}}dispose(){}},Pt=Li;Pt.LIGHT_GRAY=new O(192/255,192/255,192/255,1),Pt.GREEN=new O(0,1,0,1);var dr=class{constructor(e,t,i){this.vertices=e,this.numVertices=t,this.numFloats=i}},us=class{constructor(e,t=!0){this.premultipliedAlpha=!1,this.tempColor=new O,this.tempColor2=new O,this.vertexSize=2+2+4,this.twoColorTint=!1,this.renderable=new dr([],0,0),this.clipper=new Et,this.temp=new Je,this.temp2=new Je,this.temp3=new O,this.temp4=new O,this.twoColorTint=t,t&&(this.vertexSize+=4),this.vertices=B.newFloatArray(this.vertexSize*1024)}draw(e,t,i=-1,s=-1){let n=this.clipper,c=this.premultipliedAlpha,a=this.twoColorTint,r=null,o=this.temp,l=this.temp2,h=this.temp3,f=this.temp4,d=this.renderable,u,m,x=t.drawOrder,b,v=t.color,g=a?12:8,w=!1;i==-1&&(w=!0);for(let p=0,y=x.length;p<y;p++){let S=n.isClipping()?2:g,A=x[p];if(!A.bone.active){n.clipEndWithSlot(A);continue}if(i>=0&&i==A.data.index&&(w=!0),!w){n.clipEndWithSlot(A);continue}s>=0&&s==A.data.index&&(w=!1);let I=A.getAttachment(),E;if(I instanceof ne){let k=I;d.vertices=this.vertices,d.numVertices=4,d.numFloats=S<<2,k.computeWorldVertices(A,d.vertices,0,S),m=us.QUAD_TRIANGLES,u=k.uvs,E=k.region.renderObject.page.texture,b=k.color}else if(I instanceof Ge){let k=I;d.vertices=this.vertices,d.numVertices=k.worldVerticesLength>>1,d.numFloats=d.numVertices*S,d.numFloats>d.vertices.length&&(d.vertices=this.vertices=B.newFloatArray(d.numFloats)),k.computeWorldVertices(A,0,k.worldVerticesLength,d.vertices,0,S),m=k.triangles,E=k.region.renderObject.page.texture,u=k.uvs,b=k.color}else if(I instanceof xt){let k=I;n.clipStart(A,k);continue}else{n.clipEndWithSlot(A);continue}if(E){let k=A.color,X=this.tempColor;X.r=v.r*k.r*b.r,X.g=v.g*k.g*b.g,X.b=v.b*k.b*b.b,X.a=v.a*k.a*b.a,c&&(X.r*=X.a,X.g*=X.a,X.b*=X.a);let F=this.tempColor2;A.darkColor?(c?(F.r=A.darkColor.r*X.a,F.g=A.darkColor.g*X.a,F.b=A.darkColor.b*X.a):F.setFromColor(A.darkColor),F.a=c?1:0):F.set(0,0,0,1);let L=A.data.blendMode;if(L!=r&&(r=L,e.setBlendMode(Rt.getSourceColorGLBlendMode(r,c),Rt.getSourceAlphaGLBlendMode(r),Rt.getDestGLBlendMode(r))),n.isClipping()){n.clipTriangles(d.vertices,d.numFloats,m,m.length,u,X,F,a);let T=new Float32Array(n.clippedVertices),M=n.clippedTriangles;e.draw(E,T,M)}else{let T=d.vertices;if(a)for(let P=2,ee=0,te=d.numFloats;P<te;P+=g,ee+=2)T[P]=X.r,T[P+1]=X.g,T[P+2]=X.b,T[P+3]=X.a,T[P+4]=u[ee],T[P+5]=u[ee+1],T[P+6]=F.r,T[P+7]=F.g,T[P+8]=F.b,T[P+9]=F.a;else for(let P=2,ee=0,te=d.numFloats;P<te;P+=g,ee+=2)T[P]=X.r,T[P+1]=X.g,T[P+2]=X.b,T[P+3]=X.a,T[P+4]=u[ee],T[P+5]=u[ee+1];let M=d.vertices.subarray(0,d.numFloats);e.draw(E,M,m)}}n.clipEndWithSlot(A)}n.clipEnd()}},Pi=us;Pi.QUAD_TRIANGLES=[0,1,2,2,3,0];var C=[0,0,1,1,1,1,0,0,0,0,1,1,1,1,0,0,0,0,1,1,1,1,0,0,0,0,1,1,1,1,0,0],Bt=[0,1,2,2,3,0],Ot=new O(1,1,1,1),ms=class{constructor(e,t,i=!0){this.twoColorTint=!1,this.activeRenderer=null,this.canvas=e,this.context=t instanceof ye?t:new ye(t),this.twoColorTint=i,this.camera=new cs(e.width,e.height),this.batcherShader=i?be.newTwoColoredTextured(this.context):be.newColoredTextured(this.context),this.batcher=new Fi(this.context,i),this.shapesShader=be.newColored(this.context),this.shapes=new Xi(this.context),this.skeletonRenderer=new Pi(this.context,i),this.skeletonDebugRenderer=new Pt(this.context)}dispose(){this.batcher.dispose(),this.batcherShader.dispose(),this.shapes.dispose(),this.shapesShader.dispose(),this.skeletonDebugRenderer.dispose()}begin(){this.camera.update(),this.enableRenderer(this.batcher)}drawSkeleton(e,t=!1,i=-1,s=-1){this.enableRenderer(this.batcher),this.skeletonRenderer.premultipliedAlpha=t,this.skeletonRenderer.draw(this.batcher,e,i,s)}drawSkeletonDebug(e,t=!1,i){this.enableRenderer(this.shapes),this.skeletonDebugRenderer.premultipliedAlpha=t,this.skeletonDebugRenderer.draw(this.shapes,e,i)}drawTexture(e,t,i,s,n,c){this.enableRenderer(this.batcher),c||(c=Ot);var a=0;C[a++]=t,C[a++]=i,C[a++]=c.r,C[a++]=c.g,C[a++]=c.b,C[a++]=c.a,C[a++]=0,C[a++]=1,this.twoColorTint&&(C[a++]=0,C[a++]=0,C[a++]=0,C[a++]=0),C[a++]=t+s,C[a++]=i,C[a++]=c.r,C[a++]=c.g,C[a++]=c.b,C[a++]=c.a,C[a++]=1,C[a++]=1,this.twoColorTint&&(C[a++]=0,C[a++]=0,C[a++]=0,C[a++]=0),C[a++]=t+s,C[a++]=i+n,C[a++]=c.r,C[a++]=c.g,C[a++]=c.b,C[a++]=c.a,C[a++]=1,C[a++]=0,this.twoColorTint&&(C[a++]=0,C[a++]=0,C[a++]=0,C[a++]=0),C[a++]=t,C[a++]=i+n,C[a++]=c.r,C[a++]=c.g,C[a++]=c.b,C[a++]=c.a,C[a++]=0,C[a++]=0,this.twoColorTint&&(C[a++]=0,C[a++]=0,C[a++]=0,C[a]=0),this.batcher.draw(e,C,Bt)}drawTextureUV(e,t,i,s,n,c,a,r,o,l){this.enableRenderer(this.batcher),l||(l=Ot);var h=0;C[h++]=t,C[h++]=i,C[h++]=l.r,C[h++]=l.g,C[h++]=l.b,C[h++]=l.a,C[h++]=c,C[h++]=a,this.twoColorTint&&(C[h++]=0,C[h++]=0,C[h++]=0,C[h++]=0),C[h++]=t+s,C[h++]=i,C[h++]=l.r,C[h++]=l.g,C[h++]=l.b,C[h++]=l.a,C[h++]=r,C[h++]=a,this.twoColorTint&&(C[h++]=0,C[h++]=0,C[h++]=0,C[h++]=0),C[h++]=t+s,C[h++]=i+n,C[h++]=l.r,C[h++]=l.g,C[h++]=l.b,C[h++]=l.a,C[h++]=r,C[h++]=o,this.twoColorTint&&(C[h++]=0,C[h++]=0,C[h++]=0,C[h++]=0),C[h++]=t,C[h++]=i+n,C[h++]=l.r,C[h++]=l.g,C[h++]=l.b,C[h++]=l.a,C[h++]=c,C[h++]=o,this.twoColorTint&&(C[h++]=0,C[h++]=0,C[h++]=0,C[h]=0),this.batcher.draw(e,C,Bt)}drawTextureRotated(e,t,i,s,n,c,a,r,o){this.enableRenderer(this.batcher),o||(o=Ot);let l=t+c,h=i+a,f=-c,d=-a,u=s-c,m=n-a,x=f,b=d,v=f,g=m,w=u,p=m,y=u,S=d,A=0,I=0,E=0,k=0,X=0,F=0,L=0,T=0;if(r!=0){let P=R.cosDeg(r),ee=R.sinDeg(r);A=P*x-ee*b,I=ee*x+P*b,L=P*v-ee*g,T=ee*v+P*g,X=P*w-ee*p,F=ee*w+P*p,E=X+(A-L),k=F+(I-T)}else A=x,I=b,L=v,T=g,X=w,F=p,E=y,k=S;A+=l,I+=h,E+=l,k+=h,X+=l,F+=h,L+=l,T+=h;var M=0;C[M++]=A,C[M++]=I,C[M++]=o.r,C[M++]=o.g,C[M++]=o.b,C[M++]=o.a,C[M++]=0,C[M++]=1,this.twoColorTint&&(C[M++]=0,C[M++]=0,C[M++]=0,C[M++]=0),C[M++]=E,C[M++]=k,C[M++]=o.r,C[M++]=o.g,C[M++]=o.b,C[M++]=o.a,C[M++]=1,C[M++]=1,this.twoColorTint&&(C[M++]=0,C[M++]=0,C[M++]=0,C[M++]=0),C[M++]=X,C[M++]=F,C[M++]=o.r,C[M++]=o.g,C[M++]=o.b,C[M++]=o.a,C[M++]=1,C[M++]=0,this.twoColorTint&&(C[M++]=0,C[M++]=0,C[M++]=0,C[M++]=0),C[M++]=L,C[M++]=T,C[M++]=o.r,C[M++]=o.g,C[M++]=o.b,C[M++]=o.a,C[M++]=0,C[M++]=0,this.twoColorTint&&(C[M++]=0,C[M++]=0,C[M++]=0,C[M]=0),this.batcher.draw(e,C,Bt)}drawRegion(e,t,i,s,n,c){this.enableRenderer(this.batcher),c||(c=Ot);var a=0;C[a++]=t,C[a++]=i,C[a++]=c.r,C[a++]=c.g,C[a++]=c.b,C[a++]=c.a,C[a++]=e.u,C[a++]=e.v2,this.twoColorTint&&(C[a++]=0,C[a++]=0,C[a++]=0,C[a++]=0),C[a++]=t+s,C[a++]=i,C[a++]=c.r,C[a++]=c.g,C[a++]=c.b,C[a++]=c.a,C[a++]=e.u2,C[a++]=e.v2,this.twoColorTint&&(C[a++]=0,C[a++]=0,C[a++]=0,C[a++]=0),C[a++]=t+s,C[a++]=i+n,C[a++]=c.r,C[a++]=c.g,C[a++]=c.b,C[a++]=c.a,C[a++]=e.u2,C[a++]=e.v,this.twoColorTint&&(C[a++]=0,C[a++]=0,C[a++]=0,C[a++]=0),C[a++]=t,C[a++]=i+n,C[a++]=c.r,C[a++]=c.g,C[a++]=c.b,C[a++]=c.a,C[a++]=e.u,C[a++]=e.v,this.twoColorTint&&(C[a++]=0,C[a++]=0,C[a++]=0,C[a]=0),this.batcher.draw(e.page.texture,C,Bt)}line(e,t,i,s,n,c){this.enableRenderer(this.shapes),this.shapes.line(e,t,i,s,n)}triangle(e,t,i,s,n,c,a,r,o,l){this.enableRenderer(this.shapes),this.shapes.triangle(e,t,i,s,n,c,a,r,o,l)}quad(e,t,i,s,n,c,a,r,o,l,h,f,d){this.enableRenderer(this.shapes),this.shapes.quad(e,t,i,s,n,c,a,r,o,l,h,f,d)}rect(e,t,i,s,n,c){this.enableRenderer(this.shapes),this.shapes.rect(e,t,i,s,n,c)}rectLine(e,t,i,s,n,c,a){this.enableRenderer(this.shapes),this.shapes.rectLine(e,t,i,s,n,c,a)}polygon(e,t,i,s){this.enableRenderer(this.shapes),this.shapes.polygon(e,t,i,s)}circle(e,t,i,s,n,c=0){this.enableRenderer(this.shapes),this.shapes.circle(e,t,i,s,n,c)}curve(e,t,i,s,n,c,a,r,o,l){this.enableRenderer(this.shapes),this.shapes.curve(e,t,i,s,n,c,a,r,o,l)}end(){this.activeRenderer===this.batcher?this.batcher.end():this.activeRenderer===this.shapes&&this.shapes.end(),this.activeRenderer=null}resize(e){let t=this.canvas;var i=window.devicePixelRatio||1,s=Math.round(t.clientWidth*i),n=Math.round(t.clientHeight*i);if((t.width!=s||t.height!=n)&&(t.width=s,t.height=n),this.context.gl.viewport(0,0,t.width,t.height),e===ot.Expand)this.camera.setViewport(s,n);else if(e===ot.Fit){let c=t.width,a=t.height,r=this.camera.viewportWidth,o=this.camera.viewportHeight,l=o/r,h=a/c,f=l<h?r/c:o/a;this.camera.setViewport(c*f,a*f)}this.camera.update()}enableRenderer(e){this.activeRenderer!==e&&(this.end(),e instanceof Fi?(this.batcherShader.bind(),this.batcherShader.setUniform4x4f(be.MVP_MATRIX,this.camera.projectionView.values),this.batcherShader.setUniformi("u_texture",0),this.batcher.begin(this.batcherShader),this.activeRenderer=this.batcher):e instanceof Xi?(this.shapesShader.bind(),this.shapesShader.setUniform4x4f(be.MVP_MATRIX,this.camera.projectionView.values),this.shapes.begin(this.shapesShader),this.activeRenderer=this.shapes):this.activeRenderer=this.skeletonDebugRenderer)}},ot;(function(e){e[e.Stretch=0]="Stretch",e[e.Expand=1]="Expand",e[e.Fit=2]="Fit"})(ot||(ot={}));var pt,ht,gs=0,fr=1,Bi=1,xs=165,ws=108,it=163,ur=class{constructor(e){if(this.logo=null,this.spinner=null,this.angle=0,this.fadeOut=0,this.fadeIn=0,this.timeKeeper=new Ut,this.backgroundColor=new O(.135,.135,.135,1),this.tempColor=new O,this.renderer=e,this.timeKeeper.maxDelta=9,!ht){let t=navigator.userAgent.indexOf("Safari")>-1,i=()=>gs++;ht=new Image,ht.src=gr,t||(ht.crossOrigin="anonymous"),ht.onload=i,pt=new Image,pt.src=mr,t||(pt.crossOrigin="anonymous"),pt.onload=i}}dispose(){var e,t;(e=this.logo)==null||e.dispose(),(t=this.spinner)==null||t.dispose()}draw(e=!1){if(gs<2||e&&this.fadeOut>Bi)return;this.timeKeeper.update();let t=Math.abs(Math.sin(this.timeKeeper.totalTime+.25));this.angle-=this.timeKeeper.delta*200*(1+1.5*Math.pow(t,5));let i=this.tempColor,s=this.renderer,n=s.canvas,c=s.context.gl;if(s.resize(ot.Expand),s.camera.position.set(n.width/2,n.height/2,0),s.batcher.setBlendMode(c.ONE,c.ONE,c.ONE_MINUS_SRC_ALPHA),e){if(this.fadeOut+=this.timeKeeper.delta*(this.timeKeeper.totalTime<1?2:1),this.fadeOut>Bi)return;i.setFromColor(this.backgroundColor),t=1-this.fadeOut/Bi,t=1-(t-1)*(t-1),i.a*=t,i.a>0&&(s.camera.zoom=1,s.begin(),s.quad(!0,0,0,n.width,0,n.width,n.height,0,n.height,i,i,i,i),s.end())}else this.fadeIn+=this.timeKeeper.delta,this.backgroundColor.a>0&&(c.clearColor(this.backgroundColor.r,this.backgroundColor.g,this.backgroundColor.b,this.backgroundColor.a),c.clear(c.COLOR_BUFFER_BIT)),t=1;t*=Math.min(this.fadeIn/fr,1),i.set(t,t,t,t),this.logo||(this.logo=new wt(s.context,ht),this.spinner=new wt(s.context,pt)),s.camera.zoom=Math.max(1,it/n.height),s.begin(),s.drawTexture(this.logo,(n.width-xs)/2,(n.height-ws)/2,xs,ws,i),this.spinner&&s.drawTextureRotated(this.spinner,(n.width-it)/2,(n.height-it)/2,it,it,it/2,it/2,this.angle,i),s.end()}},mr="data:image/png;base64,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",gr="data:image/png;base64,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",xr=class{constructor(e,t){this.time=new Ut,t.pathPrefix||(t.pathPrefix=""),t.app||(t.app={loadAssets:()=>{},initialize:()=>{},update:()=>{},render:()=>{},error:()=>{}}),t.webglConfig||(t.webglConfig={alpha:!0}),this.htmlCanvas=e,this.context=new ye(e,t.webglConfig),this.renderer=new ms(e,this.context),this.gl=this.context.gl,this.assetManager=new hs(this.context,t.pathPrefix),this.input=new Ei(e),t.app.loadAssets&&t.app.loadAssets(this);let i=()=>{requestAnimationFrame(i),this.time.update(),t.app.update&&t.app.update(this,this.time.delta),t.app.render&&t.app.render(this)},s=()=>{if(this.assetManager.isLoadingComplete()){this.assetManager.hasErrors()?t.app.error&&t.app.error(this,this.assetManager.getErrors()):(t.app.initialize&&t.app.initialize(this),i());return}requestAnimationFrame(s)};requestAnimationFrame(s)}clear(e,t,i,s){this.gl.clearColor(e,t,i,s),this.gl.clear(this.gl.COLOR_BUFFER_BIT)}};return Ni})();
|