@esotericsoftware/spine-webgl 4.2.17 → 4.2.19

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.
@@ -1,16 +1,16 @@
1
- "use strict";var spine=(()=>{var Oe=Object.defineProperty,Is=Object.getOwnPropertyDescriptor,Ms=Object.getOwnPropertyNames,Ys=Object.prototype.hasOwnProperty,Es=(t,e)=>{for(var i in e)Oe(t,i,{get:e[i],enumerable:!0})},ks=(t,e,i,s)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of Ms(e))!Ys.call(t,n)&&n!==i&&Oe(t,n,{get:()=>e[n],enumerable:!(s=Is(e,n))||s.enumerable});return t},Rs=t=>ks(Oe({},"__esModule",{value:!0}),t),Di={};Es(Di,{AlphaTimeline:()=>ti,Animation:()=>fe,AnimationState:()=>Hi,AnimationStateAdapter:()=>Bs,AnimationStateData:()=>Ds,AssetManager:()=>fs,AssetManagerBase:()=>ss,AtlasAttachmentLoader:()=>Ns,Attachment:()=>Ue,AttachmentTimeline:()=>zt,BinaryInput:()=>hs,BlendMode:()=>Te,Bone:()=>xi,BoneData:()=>gi,BoundingBoxAttachment:()=>we,CURRENT:()=>Ji,CameraController:()=>gr,ClippingAttachment:()=>ae,Color:()=>O,Color2Attribute:()=>gs,ColorAttribute:()=>Re,ConstraintData:()=>ve,CurveTimeline:()=>Tt,CurveTimeline1:()=>It,CurveTimeline2:()=>ue,DebugUtils:()=>Ls,DeformTimeline:()=>si,Downloader:()=>wi,DrawOrderTimeline:()=>Wt,Event:()=>bi,EventData:()=>pi,EventQueue:()=>Zi,EventTimeline:()=>ne,EventType:()=>pt,FIRST:()=>hi,FakeTexture:()=>Os,GLTexture:()=>le,HOLD_FIRST:()=>xe,HOLD_MIX:()=>Ki,HOLD_SUBSEQUENT:()=>ci,IkConstraint:()=>rs,IkConstraintData:()=>vi,IkConstraintTimeline:()=>ri,Input:()=>Yi,IntSet:()=>Fs,Interpolation:()=>Oi,LoadingScreen:()=>pr,M00:()=>V,M01:()=>q,M02:()=>G,M03:()=>N,M10:()=>H,M11:()=>U,M12:()=>j,M13:()=>z,M20:()=>Z,M21:()=>K,M22:()=>W,M23:()=>_,M30:()=>Q,M31:()=>$,M32:()=>tt,M33:()=>J,ManagedWebGLRenderingContext:()=>xt,MathUtils:()=>X,Matrix4:()=>Pt,Mesh:()=>Ei,MeshAttachment:()=>Dt,MixBlend:()=>Wi,MixDirection:()=>_i,OrthoCamera:()=>us,PathAttachment:()=>_t,PathConstraint:()=>Zt,PathConstraintData:()=>yi,PathConstraintMixTimeline:()=>oi,PathConstraintPositionTimeline:()=>ai,PathConstraintSpacingTimeline:()=>li,PointAttachment:()=>mi,PolygonBatcher:()=>oe,Pool:()=>se,Position2Attribute:()=>ke,Position3Attribute:()=>xr,PositionMode:()=>ye,Pow:()=>Vi,PowOut:()=>Xs,RGB2Timeline:()=>ii,RGBA2Timeline:()=>ei,RGBATimeline:()=>Qe,RGBTimeline:()=>$e,RegionAttachment:()=>at,ResizeMode:()=>Pe,RotateMode:()=>Ce,RotateTimeline:()=>re,SETUP:()=>di,SUBSEQUENT:()=>ge,ScaleTimeline:()=>Ge,ScaleXTimeline:()=>He,ScaleYTimeline:()=>je,SceneRenderer:()=>ws,SequenceTimeline:()=>jt,Shader:()=>mt,ShapeRenderer:()=>Ri,ShapeType:()=>bt,ShearTimeline:()=>Ze,ShearXTimeline:()=>Ke,ShearYTimeline:()=>Je,Skeleton:()=>os,SkeletonBinary:()=>Us,SkeletonBounds:()=>cs,SkeletonClipping:()=>Ie,SkeletonData:()=>Ai,SkeletonDebugRenderer:()=>Fe,SkeletonJson:()=>dr,SkeletonRenderer:()=>Xi,Skin:()=>Se,SkinEntry:()=>Ci,Slot:()=>ns,SlotData:()=>Si,SpacingMode:()=>Ae,SpineCanvas:()=>Ar,StringSet:()=>Ve,TexCoordAttribute:()=>ki,Texture:()=>fi,TextureAtlas:()=>ts,TextureAtlasPage:()=>es,TextureAtlasRegion:()=>ui,TextureFilter:()=>be,TextureRegion:()=>$i,TextureWrap:()=>Qi,TimeKeeper:()=>Ne,Timeline:()=>ut,Touch:()=>ms,TrackEntry:()=>ji,TransformConstraint:()=>as,TransformConstraintData:()=>Ti,TransformConstraintTimeline:()=>ni,TransformMode:()=>pe,TranslateTimeline:()=>We,TranslateXTimeline:()=>_e,TranslateYTimeline:()=>qe,Triangulator:()=>vt,Utils:()=>P,Vector2:()=>Ut,Vector3:()=>yt,VertexAttachment:()=>St,VertexAttribute:()=>Jt,VertexAttributeType:()=>qt,WebGLBlendModeConverter:()=>Ye,WindowedMean:()=>Ps});var Fs=class{constructor(){this.array=new Array}add(t){let e=this.contains(t);return this.array[t|0]=t|0,!e}contains(t){return this.array[t|0]!=null}remove(t){this.array[t|0]=void 0}clear(){this.array.length=0}},Ve=class{constructor(){this.entries={},this.size=0}add(t){let e=this.entries[t];return this.entries[t]=!0,e?!1:(this.size++,!0)}addAll(t){let e=this.size;for(var i=0,s=t.length;i<s;i++)this.add(t[i]);return e!=this.size}contains(t){return this.entries[t]}clear(){this.entries={},this.size=0}},Nt=class{constructor(t=0,e=0,i=0,s=0){this.r=t,this.g=e,this.b=i,this.a=s}set(t,e,i,s){return this.r=t,this.g=e,this.b=i,this.a=s,this.clamp()}setFromColor(t){return this.r=t.r,this.g=t.g,this.b=t.b,this.a=t.a,this}setFromString(t){return t=t.charAt(0)=="#"?t.substr(1):t,this.r=parseInt(t.substr(0,2),16)/255,this.g=parseInt(t.substr(2,2),16)/255,this.b=parseInt(t.substr(4,2),16)/255,this.a=t.length!=8?1:parseInt(t.substr(6,2),16)/255,this}add(t,e,i,s){return this.r+=t,this.g+=e,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(t,e){t.r=((e&4278190080)>>>24)/255,t.g=((e&16711680)>>>16)/255,t.b=((e&65280)>>>8)/255,t.a=(e&255)/255}static rgb888ToColor(t,e){t.r=((e&16711680)>>>16)/255,t.g=((e&65280)>>>8)/255,t.b=(e&255)/255}static fromString(t){return new Nt().setFromString(t)}},O=Nt;O.WHITE=new Nt(1,1,1,1),O.RED=new Nt(1,0,0,1),O.GREEN=new Nt(0,1,0,1),O.BLUE=new Nt(0,0,1,1),O.MAGENTA=new Nt(1,0,1,1);var Ft=class{static clamp(t,e,i){return t<e?e:t>i?i:t}static cosDeg(t){return Math.cos(t*Ft.degRad)}static sinDeg(t){return Math.sin(t*Ft.degRad)}static signum(t){return t>0?1:t<0?-1:0}static toInt(t){return t>0?Math.floor(t):Math.ceil(t)}static cbrt(t){let e=Math.pow(Math.abs(t),.3333333333333333);return t<0?-e:e}static randomTriangular(t,e){return Ft.randomTriangularWith(t,e,(t+e)*.5)}static randomTriangularWith(t,e,i){let s=Math.random(),n=e-t;return s<=(i-t)/n?t+Math.sqrt(s*n*(i-t)):e-Math.sqrt((1-s)*n*(e-i))}static isPowerOfTwo(t){return t&&(t&t-1)===0}},X=Ft;X.PI=3.1415927,X.PI2=Ft.PI*2,X.radiansToDegrees=180/Ft.PI,X.radDeg=Ft.radiansToDegrees,X.degreesToRadians=Ft.PI/180,X.degRad=Ft.degreesToRadians;var Oi=class{apply(t,e,i){return t+(e-t)*this.applyInternal(i)}},Vi=class extends Oi{constructor(t){super(),this.power=2,this.power=t}applyInternal(t){return t<=.5?Math.pow(t*2,this.power)/2:Math.pow((t-1)*2,this.power)/(this.power%2==0?-2:2)+1}},Xs=class extends Vi{constructor(t){super(t)}applyInternal(t){return Math.pow(t-1,this.power)*(this.power%2==0?-1:1)+1}},Ht=class{static arrayCopy(t,e,i,s,n){for(let c=e,a=s;c<e+n;c++,a++)i[a]=t[c]}static arrayFill(t,e,i,s){for(let n=e;n<i;n++)t[n]=s}static setArraySize(t,e,i=0){let s=t.length;if(s==e)return t;if(t.length=e,s<e)for(let n=s;n<e;n++)t[n]=i;return t}static ensureArrayCapacity(t,e,i=0){return t.length>=e?t:Ht.setArraySize(t,e,i)}static newArray(t,e){let i=new Array(t);for(let s=0;s<t;s++)i[s]=e;return i}static newFloatArray(t){if(Ht.SUPPORTS_TYPED_ARRAYS)return new Float32Array(t);{let e=new Array(t);for(let i=0;i<e.length;i++)e[i]=0;return e}}static newShortArray(t){if(Ht.SUPPORTS_TYPED_ARRAYS)return new Int16Array(t);{let e=new Array(t);for(let i=0;i<e.length;i++)e[i]=0;return e}}static toFloatArray(t){return Ht.SUPPORTS_TYPED_ARRAYS?new Float32Array(t):t}static toSinglePrecision(t){return Ht.SUPPORTS_TYPED_ARRAYS?Math.fround(t):t}static webkit602BugfixHelper(t,e){}static contains(t,e,i=!0){for(var s=0;s<t.length;s++)if(t[s]==e)return!0;return!1}static enumValue(t,e){return t[e[0].toUpperCase()+e.slice(1)]}},P=Ht;P.SUPPORTS_TYPED_ARRAYS=typeof Float32Array!="undefined";var Ls=class{static logBones(t){for(let e=0;e<t.bones.length;e++){let i=t.bones[e];console.log(i.data.name+", "+i.a+", "+i.b+", "+i.c+", "+i.d+", "+i.worldX+", "+i.worldY)}}},se=class{constructor(t){this.items=new Array,this.instantiator=t}obtain(){return this.items.length>0?this.items.pop():this.instantiator()}free(t){t.reset&&t.reset(),this.items.push(t)}freeAll(t){for(let e=0;e<t.length;e++)this.free(t[e])}clear(){this.items.length=0}},Ut=class{constructor(t=0,e=0){this.x=t,this.y=e}set(t,e){return this.x=t,this.y=e,this}length(){let t=this.x,e=this.y;return Math.sqrt(t*t+e*e)}normalize(){let t=this.length();return t!=0&&(this.x/=t,this.y/=t),this}},Ne=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 t=Date.now()/1e3;this.delta=t-this.lastTime,this.frameTime+=this.delta,this.totalTime+=this.delta,this.delta>this.maxDelta&&(this.delta=this.maxDelta),this.lastTime=t,this.frameCount++,this.frameTime>1&&(this.framesPerSecond=this.frameCount/this.frameTime,this.frameTime=0,this.frameCount=0)}},Ps=class{constructor(t=32){this.addedValues=0,this.lastValue=0,this.mean=0,this.dirty=!0,this.values=new Array(t)}hasEnoughData(){return this.addedValues>=this.values.length}addValue(t){this.addedValues<this.values.length&&this.addedValues++,this.values[this.lastValue++]=t,this.lastValue>this.values.length-1&&(this.lastValue=0),this.dirty=!0}getMean(){if(this.hasEnoughData()){if(this.dirty){let t=0;for(let e=0;e<this.values.length;e++)t+=this.values[e];this.mean=t/this.values.length,this.dirty=!1}return this.mean}return 0}},Ue=class{constructor(t){if(!t)throw new Error("name cannot be null.");this.name=t}},Ni=class extends Ue{constructor(t){super(t),this.id=Ni.nextID++,this.bones=null,this.vertices=[],this.worldVerticesLength=0,this.timelineAttachment=this}computeWorldVertices(t,e,i,s,n,c){i=n+(i>>1)*c;let a=t.bone.skeleton,r=t.deform,o=this.vertices,l=this.bones;if(!l){r.length>0&&(o=r);let u=t.bone,m=u.worldX,x=u.worldY,p=u.a,v=u.b,g=u.c,w=u.d;for(let b=e,y=n;y<i;b+=2,y+=c){let A=o[b],C=o[b+1];s[y]=A*p+C*v+m,s[y+1]=A*g+C*w+x}return}let h=0,d=0;for(let u=0;u<e;u+=2){let m=l[h];h+=m+1,d+=m}let f=a.bones;if(r.length==0)for(let u=n,m=d*3;u<i;u+=c){let x=0,p=0,v=l[h++];for(v+=h;h<v;h++,m+=3){let g=f[l[h]],w=o[m],b=o[m+1],y=o[m+2];x+=(w*g.a+b*g.b+g.worldX)*y,p+=(w*g.c+b*g.d+g.worldY)*y}s[u]=x,s[u+1]=p}else{let u=r;for(let m=n,x=d*3,p=d<<1;m<i;m+=c){let v=0,g=0,w=l[h++];for(w+=h;h<w;h++,x+=3,p+=2){let b=f[l[h]],y=o[x]+u[p],A=o[x+1]+u[p+1],C=o[x+2];v+=(y*b.a+A*b.b+b.worldX)*C,g+=(y*b.c+A*b.d+b.worldY)*C}s[m]=v,s[m+1]=g}}}copyTo(t){this.bones?(t.bones=new Array(this.bones.length),P.arrayCopy(this.bones,0,t.bones,0,this.bones.length)):t.bones=null,this.vertices&&(t.vertices=P.newFloatArray(this.vertices.length),P.arrayCopy(this.vertices,0,t.vertices,0,this.vertices.length)),t.worldVerticesLength=this.worldVerticesLength,t.timelineAttachment=this.timelineAttachment}},St=Ni;St.nextID=0;var de=class{constructor(t){this.id=de.nextID(),this.start=0,this.digits=0,this.setupIndex=0,this.regions=new Array(t)}copy(){let t=new de(this.regions.length);return P.arrayCopy(this.regions,0,t.regions,0,this.regions.length),t.start=this.start,t.digits=this.digits,t.setupIndex=this.setupIndex,t}apply(t,e){let i=t.sequenceIndex;i==-1&&(i=this.setupIndex),i>=this.regions.length&&(i=this.regions.length-1);let s=this.regions[i];e.region!=s&&(e.region=s,e.updateRegion())}getPath(t,e){let i=t,s=(this.start+e).toString();for(let n=this.digits-s.length;n>0;n--)i+="0";return i+=s,i}static nextID(){return de._nextID++}},ze=de;ze._nextID=0;var Ui=(t=>(t[t.hold=0]="hold",t[t.once=1]="once",t[t.loop=2]="loop",t[t.pingpong=3]="pingpong",t[t.onceReverse=4]="onceReverse",t[t.loopReverse=5]="loopReverse",t[t.pingpongReverse=6]="pingpongReverse",t))(Ui||{}),zi=[0,1,2,3,4,5,6],fe=class{constructor(t,e,i){if(this.timelines=[],this.timelineIds=new Ve,!t)throw new Error("name cannot be null.");this.name=t,this.setTimelines(e),this.duration=i}setTimelines(t){if(!t)throw new Error("timelines cannot be null.");this.timelines=t,this.timelineIds.clear();for(var e=0;e<t.length;e++)this.timelineIds.addAll(t[e].getPropertyIds())}hasTimeline(t){for(let e=0;e<t.length;e++)if(this.timelineIds.contains(t[e]))return!0;return!1}apply(t,e,i,s,n,c,a,r){if(!t)throw new Error("skeleton cannot be null.");s&&this.duration!=0&&(i%=this.duration,e>0&&(e%=this.duration));let o=this.timelines;for(let l=0,h=o.length;l<h;l++)o[l].apply(t,e,i,n,c,a,r)}},Wi=(t=>(t[t.setup=0]="setup",t[t.first=1]="first",t[t.replace=2]="replace",t[t.add=3]="add",t))(Wi||{}),_i=(t=>(t[t.mixIn=0]="mixIn",t[t.mixOut=1]="mixOut",t))(_i||{}),ct={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},ut=class{constructor(t,e){this.propertyIds=e,this.frames=P.newFloatArray(t*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(t,e){let i=t.length;for(let s=1;s<i;s++)if(t[s]>e)return s-1;return i-1}static search(t,e,i){let s=t.length;for(let n=i;n<s;n+=i)if(t[n]>e)return n-i;return s-i}},Tt=class extends ut{constructor(t,e,i){super(t,i),this.curves=P.newFloatArray(t+e*18),this.curves[t-1]=1}setLinear(t){this.curves[t]=0}setStepped(t){this.curves[t]=1}shrink(t){let e=this.getFrameCount()+t*18;if(this.curves.length>e){let i=P.newFloatArray(e);P.arrayCopy(this.curves,0,i,0,e),this.curves=i}}setBezier(t,e,i,s,n,c,a,r,o,l,h){let d=this.curves,f=this.getFrameCount()+t*18;i==0&&(d[e]=2+f);let u=(s-c*2+r)*.03,m=(n-a*2+o)*.03,x=((c-r)*3-s+l)*.006,p=((a-o)*3-n+h)*.006,v=u*2+x,g=m*2+p,w=(c-s)*.3+u+x*.16666667,b=(a-n)*.3+m+p*.16666667,y=s+w,A=n+b;for(let C=f+18;f<C;f+=2)d[f]=y,d[f+1]=A,w+=v,b+=g,v+=x,g+=p,y+=w,A+=b}getBezierValue(t,e,i,s){let n=this.curves;if(n[s]>t){let o=this.frames[e],l=this.frames[e+i];return l+(t-o)/(n[s]-o)*(n[s+1]-l)}let c=s+18;for(s+=2;s<c;s+=2)if(n[s]>=t){let o=n[s-2],l=n[s-1];return l+(t-o)/(n[s]-o)*(n[s+1]-l)}e+=this.getFrameEntries();let a=n[c-2],r=n[c-1];return r+(t-a)/(this.frames[e]-a)*(this.frames[e+i]-r)}},It=class extends Tt{constructor(t,e,i){super(t,e,[i])}getFrameEntries(){return 2}setFrame(t,e,i){t<<=1,this.frames[t]=e,this.frames[t+1]=i}getCurveValue(t){let e=this.frames,i=e.length-2;for(let n=2;n<=i;n+=2)if(e[n]>t){i=n-2;break}let s=this.curves[i>>1];switch(s){case 0:let n=e[i],c=e[i+1];return c+(t-n)/(e[i+2]-n)*(e[i+2+1]-c);case 1:return e[i+1]}return this.getBezierValue(t,i,1,s-2)}},ue=class extends Tt{constructor(t,e,i,s){super(t,e,[i,s])}getFrameEntries(){return 3}setFrame(t,e,i,s){t*=3,this.frames[t]=e,this.frames[t+1]=i,this.frames[t+2]=s}},re=class extends It{constructor(t,e,i){super(t,e,ct.rotate+"|"+i),this.boneIndex=0,this.boneIndex=i}apply(t,e,i,s,n,c,a){let r=t.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}}},We=class extends ue{constructor(t,e,i){super(t,e,ct.x+"|"+i,ct.y+"|"+i),this.boneIndex=0,this.boneIndex=i}apply(t,e,i,s,n,c,a){let r=t.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,d=ut.search(o,i,3),f=this.curves[d/3];switch(f){case 0:let u=o[d];l=o[d+1],h=o[d+2];let m=(i-u)/(o[d+3]-u);l+=(o[d+3+1]-l)*m,h+=(o[d+3+2]-h)*m;break;case 1:l=o[d+1],h=o[d+2];break;default:l=this.getBezierValue(i,d,1,f-2),h=this.getBezierValue(i,d,2,f+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}}},_e=class extends It{constructor(t,e,i){super(t,e,ct.x+"|"+i),this.boneIndex=0,this.boneIndex=i}apply(t,e,i,s,n,c,a){let r=t.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}}},qe=class extends It{constructor(t,e,i){super(t,e,ct.y+"|"+i),this.boneIndex=0,this.boneIndex=i}apply(t,e,i,s,n,c,a){let r=t.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}}},Ge=class extends ue{constructor(t,e,i){super(t,e,ct.scaleX+"|"+i,ct.scaleY+"|"+i),this.boneIndex=0,this.boneIndex=i}apply(t,e,i,s,n,c,a){let r=t.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,d=ut.search(o,i,3),f=this.curves[d/3];switch(f){case 0:let u=o[d];l=o[d+1],h=o[d+2];let m=(i-u)/(o[d+3]-u);l+=(o[d+3+1]-l)*m,h+=(o[d+3+2]-h)*m;break;case 1:l=o[d+1],h=o[d+2];break;default:l=this.getBezierValue(i,d,1,f-2),h=this.getBezierValue(i,d,2,f+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)*X.signum(u)-u)*n,r.scaleY=m+(Math.abs(h)*X.signum(m)-m)*n;break;case 1:case 2:u=r.scaleX,m=r.scaleY,r.scaleX=u+(Math.abs(l)*X.signum(u)-u)*n,r.scaleY=m+(Math.abs(h)*X.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)*X.signum(l),m=Math.abs(r.data.scaleY)*X.signum(h),r.scaleX=u+(l-u)*n,r.scaleY=m+(h-m)*n;break;case 1:case 2:u=Math.abs(r.scaleX)*X.signum(l),m=Math.abs(r.scaleY)*X.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}}}},He=class extends It{constructor(t,e,i){super(t,e,ct.scaleX+"|"+i),this.boneIndex=0,this.boneIndex=i}apply(t,e,i,s,n,c,a){let r=t.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)*X.signum(h)-h)*n;break;case 1:case 2:h=r.scaleX,r.scaleX=h+(Math.abs(l)*X.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)*X.signum(l),r.scaleX=h+(l-h)*n;break;case 1:case 2:h=Math.abs(r.scaleX)*X.signum(l),r.scaleX=h+(l-h)*n;break;case 3:r.scaleX+=(l-r.data.scaleX)*n}}}},je=class extends It{constructor(t,e,i){super(t,e,ct.scaleY+"|"+i),this.boneIndex=0,this.boneIndex=i}apply(t,e,i,s,n,c,a){let r=t.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)*X.signum(h)-h)*n;break;case 1:case 2:h=r.scaleY,r.scaleY=h+(Math.abs(l)*X.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)*X.signum(l),r.scaleY=h+(l-h)*n;break;case 1:case 2:h=Math.abs(r.scaleY)*X.signum(l),r.scaleY=h+(l-h)*n;break;case 3:r.scaleY+=(l-r.data.scaleY)*n}}}},Ze=class extends ue{constructor(t,e,i){super(t,e,ct.shearX+"|"+i,ct.shearY+"|"+i),this.boneIndex=0,this.boneIndex=i}apply(t,e,i,s,n,c,a){let r=t.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,d=ut.search(o,i,3),f=this.curves[d/3];switch(f){case 0:let u=o[d];l=o[d+1],h=o[d+2];let m=(i-u)/(o[d+3]-u);l+=(o[d+3+1]-l)*m,h+=(o[d+3+2]-h)*m;break;case 1:l=o[d+1],h=o[d+2];break;default:l=this.getBezierValue(i,d,1,f-2),h=this.getBezierValue(i,d,2,f+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}}},Ke=class extends It{constructor(t,e,i){super(t,e,ct.shearX+"|"+i),this.boneIndex=0,this.boneIndex=i}apply(t,e,i,s,n,c,a){let r=t.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}}},Je=class extends It{constructor(t,e,i){super(t,e,ct.shearY+"|"+i),this.boneIndex=0,this.boneIndex=i}apply(t,e,i,s,n,c,a){let r=t.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}}},Qe=class extends Tt{constructor(t,e,i){super(t,e,[ct.rgb+"|"+i,ct.alpha+"|"+i]),this.slotIndex=0,this.slotIndex=i}getFrameEntries(){return 5}setFrame(t,e,i,s,n,c){t*=5,this.frames[t]=e,this.frames[t+1]=i,this.frames[t+2]=s,this.frames[t+3]=n,this.frames[t+4]=c}apply(t,e,i,s,n,c,a){let r=t.slots[this.slotIndex];if(!r.bone.active)return;let o=this.frames,l=r.color;if(i<o[0]){let p=r.data.color;switch(c){case 0:l.setFromColor(p);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)}return}let h=0,d=0,f=0,u=0,m=ut.search(o,i,5),x=this.curves[m/5];switch(x){case 0:let p=o[m];h=o[m+1],d=o[m+2],f=o[m+3],u=o[m+4];let v=(i-p)/(o[m+5]-p);h+=(o[m+5+1]-h)*v,d+=(o[m+5+2]-d)*v,f+=(o[m+5+3]-f)*v,u+=(o[m+5+4]-u)*v;break;case 1:h=o[m+1],d=o[m+2],f=o[m+3],u=o[m+4];break;default:h=this.getBezierValue(i,m,1,x-2),d=this.getBezierValue(i,m,2,x+18-2),f=this.getBezierValue(i,m,3,x+18*2-2),u=this.getBezierValue(i,m,4,x+18*3-2)}n==1?l.set(h,d,f,u):(c==0&&l.setFromColor(r.data.color),l.add((h-l.r)*n,(d-l.g)*n,(f-l.b)*n,(u-l.a)*n))}},$e=class extends Tt{constructor(t,e,i){super(t,e,[ct.rgb+"|"+i]),this.slotIndex=0,this.slotIndex=i}getFrameEntries(){return 4}setFrame(t,e,i,s,n){t<<=2,this.frames[t]=e,this.frames[t+1]=i,this.frames[t+2]=s,this.frames[t+3]=n}apply(t,e,i,s,n,c,a){let r=t.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,d=0,f=0,u=ut.search(o,i,4),m=this.curves[u>>2];switch(m){case 0:let x=o[u];h=o[u+1],d=o[u+2],f=o[u+3];let p=(i-x)/(o[u+4]-x);h+=(o[u+4+1]-h)*p,d+=(o[u+4+2]-d)*p,f+=(o[u+4+3]-f)*p;break;case 1:h=o[u+1],d=o[u+2],f=o[u+3];break;default:h=this.getBezierValue(i,u,1,m-2),d=this.getBezierValue(i,u,2,m+18-2),f=this.getBezierValue(i,u,3,m+18*2-2)}if(n==1)l.r=h,l.g=d,l.b=f;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+=(d-l.g)*n,l.b+=(f-l.b)*n}}},ti=class extends It{constructor(t,e,i){super(t,e,ct.alpha+"|"+i),this.slotIndex=0,this.slotIndex=i}apply(t,e,i,s,n,c,a){let r=t.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)}},ei=class extends Tt{constructor(t,e,i){super(t,e,[ct.rgb+"|"+i,ct.alpha+"|"+i,ct.rgb2+"|"+i]),this.slotIndex=0,this.slotIndex=i}getFrameEntries(){return 8}setFrame(t,e,i,s,n,c,a,r,o){t<<=3,this.frames[t]=e,this.frames[t+1]=i,this.frames[t+2]=s,this.frames[t+3]=n,this.frames[t+4]=c,this.frames[t+5]=a,this.frames[t+6]=r,this.frames[t+7]=o}apply(t,e,i,s,n,c,a){let r=t.slots[this.slotIndex];if(!r.bone.active)return;let o=this.frames,l=r.color,h=r.darkColor;if(i<o[0]){let b=r.data.color,y=r.data.darkColor;switch(c){case 0:l.setFromColor(b),h.r=y.r,h.g=y.g,h.b=y.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),h.r+=(y.r-h.r)*n,h.g+=(y.g-h.g)*n,h.b+=(y.b-h.b)*n}return}let d=0,f=0,u=0,m=0,x=0,p=0,v=0,g=ut.search(o,i,8),w=this.curves[g>>3];switch(w){case 0:let b=o[g];d=o[g+1],f=o[g+2],u=o[g+3],m=o[g+4],x=o[g+5],p=o[g+6],v=o[g+7];let y=(i-b)/(o[g+8]-b);d+=(o[g+8+1]-d)*y,f+=(o[g+8+2]-f)*y,u+=(o[g+8+3]-u)*y,m+=(o[g+8+4]-m)*y,x+=(o[g+8+5]-x)*y,p+=(o[g+8+6]-p)*y,v+=(o[g+8+7]-v)*y;break;case 1:d=o[g+1],f=o[g+2],u=o[g+3],m=o[g+4],x=o[g+5],p=o[g+6],v=o[g+7];break;default:d=this.getBezierValue(i,g,1,w-2),f=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),p=this.getBezierValue(i,g,6,w+18*5-2),v=this.getBezierValue(i,g,7,w+18*6-2)}if(n==1)l.set(d,f,u,m),h.r=x,h.g=p,h.b=v;else{if(c==0){l.setFromColor(r.data.color);let b=r.data.darkColor;h.r=b.r,h.g=b.g,h.b=b.b}l.add((d-l.r)*n,(f-l.g)*n,(u-l.b)*n,(m-l.a)*n),h.r+=(x-h.r)*n,h.g+=(p-h.g)*n,h.b+=(v-h.b)*n}}},ii=class extends Tt{constructor(t,e,i){super(t,e,[ct.rgb+"|"+i,ct.rgb2+"|"+i]),this.slotIndex=0,this.slotIndex=i}getFrameEntries(){return 7}setFrame(t,e,i,s,n,c,a,r){t*=7,this.frames[t]=e,this.frames[t+1]=i,this.frames[t+2]=s,this.frames[t+3]=n,this.frames[t+4]=c,this.frames[t+5]=a,this.frames[t+6]=r}apply(t,e,i,s,n,c,a){let r=t.slots[this.slotIndex];if(!r.bone.active)return;let o=this.frames,l=r.color,h=r.darkColor;if(i<o[0]){let b=r.data.color,y=r.data.darkColor;switch(c){case 0:l.r=b.r,l.g=b.g,l.b=b.b,h.r=y.r,h.g=y.g,h.b=y.b;return;case 1:l.r+=(b.r-l.r)*n,l.g+=(b.g-l.g)*n,l.b+=(b.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 d=0,f=0,u=0,m=0,x=0,p=0,v=0,g=ut.search(o,i,7),w=this.curves[g/7];switch(w){case 0:let b=o[g];d=o[g+1],f=o[g+2],u=o[g+3],x=o[g+4],p=o[g+5],v=o[g+6];let y=(i-b)/(o[g+7]-b);d+=(o[g+7+1]-d)*y,f+=(o[g+7+2]-f)*y,u+=(o[g+7+3]-u)*y,x+=(o[g+7+4]-x)*y,p+=(o[g+7+5]-p)*y,v+=(o[g+7+6]-v)*y;break;case 1:d=o[g+1],f=o[g+2],u=o[g+3],x=o[g+4],p=o[g+5],v=o[g+6];break;default:d=this.getBezierValue(i,g,1,w-2),f=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),p=this.getBezierValue(i,g,5,w+18*4-2),v=this.getBezierValue(i,g,6,w+18*5-2)}if(n==1)l.r=d,l.g=f,l.b=u,h.r=x,h.g=p,h.b=v;else{if(c==0){let b=r.data.color,y=r.data.darkColor;l.r=b.r,l.g=b.g,l.b=b.b,h.r=y.r,h.g=y.g,h.b=y.b}l.r+=(d-l.r)*n,l.g+=(f-l.g)*n,l.b+=(u-l.b)*n,h.r+=(x-h.r)*n,h.g+=(p-h.g)*n,h.b+=(v-h.b)*n}}},zt=class extends ut{constructor(t,e){super(t,[ct.attachment+"|"+e]),this.slotIndex=0,this.slotIndex=e,this.attachmentNames=new Array(t)}getFrameCount(){return this.frames.length}setFrame(t,e,i){this.frames[t]=e,this.attachmentNames[t]=i}apply(t,e,i,s,n,c,a){let r=t.slots[this.slotIndex];if(r.bone.active){if(a==1){c==0&&this.setAttachment(t,r,r.data.attachmentName);return}if(i<this.frames[0]){(c==0||c==1)&&this.setAttachment(t,r,r.data.attachmentName);return}this.setAttachment(t,r,this.attachmentNames[ut.search1(this.frames,i)])}}setAttachment(t,e,i){e.setAttachment(i?t.getAttachment(this.slotIndex,i):null)}},si=class extends Tt{constructor(t,e,i,s){super(t,e,[ct.deform+"|"+i+"|"+s.id]),this.slotIndex=0,this.slotIndex=i,this.attachment=s,this.vertices=new Array(t)}getFrameCount(){return this.frames.length}setFrame(t,e,i){this.frames[t]=e,this.vertices[t]=i}setBezier(t,e,i,s,n,c,a,r,o,l,h){let d=this.curves,f=this.getFrameCount()+t*18;i==0&&(d[e]=2+f);let u=(s-c*2+r)*.03,m=o*.03-a*.06,x=((c-r)*3-s+l)*.006,p=(a-o+.33333333)*.018,v=u*2+x,g=m*2+p,w=(c-s)*.3+u+x*.16666667,b=a*.3+m+p*.16666667,y=s+w,A=b;for(let C=f+18;f<C;f+=2)d[f]=y,d[f+1]=A,w+=v,b+=g,v+=x,g+=p,y+=w,A+=b}getCurvePercent(t,e){let i=this.curves,s=i[e];switch(s){case 0:let r=this.frames[e];return(t-r)/(this.frames[e+this.getFrameEntries()]-r);case 1:return 0}if(s-=2,i[s]>t){let r=this.frames[e];return i[s+1]*(t-r)/(i[s]-r)}let n=s+18;for(s+=2;s<n;s+=2)if(i[s]>=t){let r=i[s-2],o=i[s-1];return o+(t-r)/(i[s]-r)*(i[s+1]-o)}let c=i[n-2],a=i[n-1];return a+(1-a)*(t-c)/(this.frames[e+this.getFrameEntries()]-c)}apply(t,e,i,s,n,c,a){let r=t.slots[this.slotIndex];if(!r.bone.active)return;let o=r.getAttachment();if(!o||!(o instanceof St)||o.timelineAttachment!=this.attachment)return;let l=r.deform;l.length==0&&(c=0);let h=this.vertices,d=h[0].length,f=this.frames;if(i<f[0]){switch(c){case 0:l.length=0;return;case 1:if(n==1){l.length=0;return}l.length=d;let g=o;if(g.bones){n=1-n;for(var u=0;u<d;u++)l[u]*=n}else{let w=g.vertices;for(var u=0;u<d;u++)l[u]+=(w[u]-l[u])*n}}return}if(l.length=d,i>=f[f.length-1]){let g=h[f.length-1];if(n==1)if(c==3){let w=o;if(w.bones)for(let b=0;b<d;b++)l[b]+=g[b];else{let b=w.vertices;for(let y=0;y<d;y++)l[y]+=g[y]-b[y]}}else P.arrayCopy(g,0,l,0,d);else switch(c){case 0:{let b=o;if(b.bones)for(let y=0;y<d;y++)l[y]=g[y]*n;else{let y=b.vertices;for(let A=0;A<d;A++){let C=y[A];l[A]=C+(g[A]-C)*n}}break}case 1:case 2:for(let b=0;b<d;b++)l[b]+=(g[b]-l[b])*n;break;case 3:let w=o;if(w.bones)for(let b=0;b<d;b++)l[b]+=g[b]*n;else{let b=w.vertices;for(let y=0;y<d;y++)l[y]+=(g[y]-b[y])*n}}return}let m=ut.search1(f,i),x=this.getCurvePercent(i,m),p=h[m],v=h[m+1];if(n==1)if(c==3){let g=o;if(g.bones)for(let w=0;w<d;w++){let b=p[w];l[w]+=b+(v[w]-b)*x}else{let w=g.vertices;for(let b=0;b<d;b++){let y=p[b];l[b]+=y+(v[b]-y)*x-w[b]}}}else for(let g=0;g<d;g++){let w=p[g];l[g]=w+(v[g]-w)*x}else switch(c){case 0:{let w=o;if(w.bones)for(let b=0;b<d;b++){let y=p[b];l[b]=(y+(v[b]-y)*x)*n}else{let b=w.vertices;for(let y=0;y<d;y++){let A=p[y],C=b[y];l[y]=C+(A+(v[y]-A)*x-C)*n}}break}case 1:case 2:for(let w=0;w<d;w++){let b=p[w];l[w]+=(b+(v[w]-b)*x-l[w])*n}break;case 3:let g=o;if(g.bones)for(let w=0;w<d;w++){let b=p[w];l[w]+=(b+(v[w]-b)*x)*n}else{let w=g.vertices;for(let b=0;b<d;b++){let y=p[b];l[b]+=(y+(v[b]-y)*x-w[b])*n}}}}},qi=class extends ut{constructor(t){super(t,qi.propertyIds),this.events=new Array(t)}getFrameCount(){return this.frames.length}setFrame(t,e){this.frames[t]=e.time,this.events[t]=e}apply(t,e,i,s,n,c,a){if(!s)return;let r=this.frames,o=this.frames.length;if(e>i)this.apply(t,e,Number.MAX_VALUE,s,n,c,a),e=-1;else if(e>=r[o-1])return;if(i<r[0])return;let l=0;if(e<r[0])l=0;else{l=ut.search1(r,e)+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])}},ne=qi;ne.propertyIds=[""+ct.event];var Gi=class extends ut{constructor(t){super(t,Gi.propertyIds),this.drawOrders=new Array(t)}getFrameCount(){return this.frames.length}setFrame(t,e,i){this.frames[t]=e,this.drawOrders[t]=i}apply(t,e,i,s,n,c,a){if(a==1){c==0&&P.arrayCopy(t.slots,0,t.drawOrder,0,t.slots.length);return}if(i<this.frames[0]){(c==0||c==1)&&P.arrayCopy(t.slots,0,t.drawOrder,0,t.slots.length);return}let r=ut.search1(this.frames,i),o=this.drawOrders[r];if(!o)P.arrayCopy(t.slots,0,t.drawOrder,0,t.slots.length);else{let l=t.drawOrder,h=t.slots;for(let d=0,f=o.length;d<f;d++)l[d]=h[o[d]]}}},Wt=Gi;Wt.propertyIds=[""+ct.drawOrder];var ri=class extends Tt{constructor(t,e,i){super(t,e,[ct.ikConstraint+"|"+i]),this.ikConstraintIndex=0,this.ikConstraintIndex=i}getFrameEntries(){return 6}setFrame(t,e,i,s,n,c,a){t*=6,this.frames[t]=e,this.frames[t+1]=i,this.frames[t+2]=s,this.frames[t+3]=n,this.frames[t+4]=c?1:0,this.frames[t+5]=a?1:0}apply(t,e,i,s,n,c,a){let r=t.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,d=ut.search(o,i,6),f=this.curves[d/6];switch(f){case 0:let u=o[d];l=o[d+1],h=o[d+2];let m=(i-u)/(o[d+6]-u);l+=(o[d+6+1]-l)*m,h+=(o[d+6+2]-h)*m;break;case 1:l=o[d+1],h=o[d+2];break;default:l=this.getBezierValue(i,d,1,f-2),h=this.getBezierValue(i,d,2,f+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[d+3],r.compress=o[d+4]!=0,r.stretch=o[d+5]!=0)):(r.mix+=(l-r.mix)*n,r.softness+=(h-r.softness)*n,a==0&&(r.bendDirection=o[d+3],r.compress=o[d+4]!=0,r.stretch=o[d+5]!=0))}},ni=class extends Tt{constructor(t,e,i){super(t,e,[ct.transformConstraint+"|"+i]),this.transformConstraintIndex=0,this.transformConstraintIndex=i}getFrameEntries(){return 7}setFrame(t,e,i,s,n,c,a,r){let o=this.frames;t*=7,o[t]=e,o[t+1]=i,o[t+2]=s,o[t+3]=n,o[t+4]=c,o[t+5]=a,o[t+6]=r}apply(t,e,i,s,n,c,a){let r=t.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,d,f,u,m,x=ut.search(o,i,7),p=this.curves[x/7];switch(p){case 0:let v=o[x];l=o[x+1],h=o[x+2],d=o[x+3],f=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,d+=(o[x+7+3]-d)*g,f+=(o[x+7+4]-f)*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],d=o[x+3],f=o[x+4],u=o[x+5],m=o[x+6];break;default:l=this.getBezierValue(i,x,1,p-2),h=this.getBezierValue(i,x,2,p+18-2),d=this.getBezierValue(i,x,3,p+18*2-2),f=this.getBezierValue(i,x,4,p+18*3-2),u=this.getBezierValue(i,x,5,p+18*4-2),m=this.getBezierValue(i,x,6,p+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+(d-v.mixY)*n,r.mixScaleX=v.mixScaleX+(f-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+=(d-r.mixY)*n,r.mixScaleX+=(f-r.mixScaleX)*n,r.mixScaleY+=(u-r.mixScaleY)*n,r.mixShearY+=(m-r.mixShearY)*n}},ai=class extends It{constructor(t,e,i){super(t,e,ct.pathConstraintPosition+"|"+i),this.pathConstraintIndex=0,this.pathConstraintIndex=i}apply(t,e,i,s,n,c,a){let r=t.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}},li=class extends It{constructor(t,e,i){super(t,e,ct.pathConstraintSpacing+"|"+i),this.pathConstraintIndex=0,this.pathConstraintIndex=i}apply(t,e,i,s,n,c,a){let r=t.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}},oi=class extends Tt{constructor(t,e,i){super(t,e,[ct.pathConstraintMix+"|"+i]),this.pathConstraintIndex=0,this.pathConstraintIndex=i}getFrameEntries(){return 4}setFrame(t,e,i,s,n){let c=this.frames;t<<=2,c[t]=e,c[t+1]=i,c[t+2]=s,c[t+3]=n}apply(t,e,i,s,n,c,a){let r=t.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,d,f=ut.search(o,i,4),u=this.curves[f>>2];switch(u){case 0:let m=o[f];l=o[f+1],h=o[f+2],d=o[f+3];let x=(i-m)/(o[f+4]-m);l+=(o[f+4+1]-l)*x,h+=(o[f+4+2]-h)*x,d+=(o[f+4+3]-d)*x;break;case 1:l=o[f+1],h=o[f+2],d=o[f+3];break;default:l=this.getBezierValue(i,f,1,u-2),h=this.getBezierValue(i,f,2,u+18-2),d=this.getBezierValue(i,f,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+(d-m.mixY)*n}else r.mixRotate+=(l-r.mixRotate)*n,r.mixX+=(h-r.mixX)*n,r.mixY+=(d-r.mixY)*n}},Bt=class extends ut{constructor(t,e,i){super(t,[ct.sequence+"|"+e+"|"+i.sequence.id]),this.slotIndex=e,this.attachment=i}getFrameEntries(){return Bt.ENTRIES}getSlotIndex(){return this.slotIndex}getAttachment(){return this.attachment}setFrame(t,e,i,s,n){let c=this.frames;t*=Bt.ENTRIES,c[t]=e,c[t+Bt.MODE]=i|s<<4,c[t+Bt.DELAY]=n}apply(t,e,i,s,n,c,a){let r=t.slots[this.slotIndex];if(!r.bone.active)return;let o=r.attachment,l=this.attachment;if(o!=l&&(!(o instanceof St)||o.timelineAttachment!=l))return;let h=this.frames;if(i<h[0]){(c==0||c==1)&&(r.sequenceIndex=-1);return}let d=ut.search(h,i,Bt.ENTRIES),f=h[d],u=h[d+Bt.MODE],m=h[d+Bt.DELAY];if(!this.attachment.sequence)return;let x=u>>4,p=this.attachment.sequence.regions.length,v=zi[u&15];if(v!=0)switch(x+=(i-f)/m+1e-5|0,v){case 1:x=Math.min(p-1,x);break;case 2:x%=p;break;case 3:{let g=(p<<1)-2;x=g==0?0:x%g,x>=p&&(x=g-x);break}case 4:x=Math.max(p-1-x,0);break;case 5:x=p-1-x%p;break;case 6:{let g=(p<<1)-2;x=g==0?0:(x+p-1)%g,x>=p&&(x=g-x)}}r.sequenceIndex=x}},jt=Bt;jt.ENTRIES=3,jt.MODE=1,jt.DELAY=2;var me=class{constructor(t){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 Ve,this.animationsChanged=!1,this.trackEntryPool=new se(()=>new ji),this.data=t}static emptyAnimation(){return me._emptyAnimation}update(t){t*=this.timeScale;let e=this.tracks;for(let i=0,s=e.length;i<s;i++){let n=e[i];if(!n)continue;n.animationLast=n.nextAnimationLast,n.trackLast=n.nextTrackLast;let c=t*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+t)*a.timeScale,n.trackTime+=c,this.setCurrent(i,a,!0);a.mixingFrom;)a.mixTime+=t,a=a.mixingFrom;continue}}else if(n.trackLast>=n.trackEnd&&!n.mixingFrom){e[i]=null,this.queue.end(n),this.clearNext(n);continue}if(n.mixingFrom&&this.updateMixingFrom(n,t)){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(t,e){let i=t.mixingFrom;if(!i)return!0;let s=this.updateMixingFrom(i,e);return i.animationLast=i.nextAnimationLast,i.trackLast=i.nextTrackLast,t.mixTime>0&&t.mixTime>=t.mixDuration?((i.totalAlpha==0||t.mixDuration==0)&&(t.mixingFrom=i.mixingFrom,i.mixingFrom&&(i.mixingFrom.mixingTo=t),t.interruptAlpha=i.interruptAlpha,this.queue.end(i)),s):(i.trackTime+=e*i.timeScale,t.mixTime+=e,!1)}apply(t){if(!t)throw new Error("skeleton cannot be null.");this.animationsChanged&&this._animationsChanged();let e=this.events,i=this.tracks,s=!1;for(let d=0,f=i.length;d<f;d++){let u=i[d];if(!u||u.delay>0)continue;s=!0;let m=d==0?1:u.mixBlend,x=u.alpha;u.mixingFrom?x*=this.applyMixingFrom(u,t,m):u.trackTime>=u.trackEnd&&!u.next&&(x=0);let p=u.animationLast,v=u.getAnimationTime(),g=v,w=e;u.reverse&&(g=u.animation.duration-g,w=null);let b=u.animation.timelines,y=b.length;if(d==0&&x==1||m==3)for(let A=0;A<y;A++){P.webkit602BugfixHelper(x,m);var n=b[A];n instanceof zt?this.applyAttachmentTimeline(n,t,g,m,!0):n.apply(t,p,g,w,x,m,0)}else{let A=u.timelineMode,C=u.shortestRotation,I=!C&&u.timelinesRotation.length!=y<<1;I&&(u.timelinesRotation.length=y<<1);for(let E=0;E<y;E++){let R=b[E],L=A[E]==ge?m:0;!C&&R instanceof re?this.applyRotateTimeline(R,t,g,x,L,u.timelinesRotation,E<<1,I):R instanceof zt?this.applyAttachmentTimeline(R,t,g,m,!0):(P.webkit602BugfixHelper(x,m),R.apply(t,p,g,w,x,L,0))}}this.queueEvents(u,v),e.length=0,u.nextAnimationLast=v,u.nextTrackLast=u.trackTime}for(var c=this.unkeyedState+di,a=t.slots,r=0,o=t.slots.length;r<o;r++){var l=a[r];if(l.attachmentState==c){var h=l.data.attachmentName;l.setAttachment(h?t.getAttachment(l.data.index,h):null)}}return this.unkeyedState+=2,this.queue.drain(),s}applyMixingFrom(t,e,i){let s=t.mixingFrom;s.mixingFrom&&this.applyMixingFrom(s,e,i);let n=0;t.mixDuration==0?(n=1,i==1&&(i=0)):(n=t.mixTime/t.mixDuration,n>1&&(n=1),i!=1&&(i=s.mixBlend));let c=n<s.attachmentThreshold,a=n<s.drawOrderThreshold,r=s.animation.timelines,o=r.length,l=s.alpha*t.interruptAlpha,h=l*(1-n),d=s.animationLast,f=s.getAnimationTime(),u=f,m=null;if(s.reverse?u=s.animation.duration-u:n<s.eventThreshold&&(m=this.events),i==3)for(let x=0;x<o;x++)r[x].apply(e,d,u,m,h,i,1);else{let x=s.timelineMode,p=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 b=r[w],y=1,A,C=0;switch(x[w]){case ge:if(!a&&b instanceof Wt)continue;A=i,C=h;break;case hi:A=0,C=h;break;case ci:A=i,C=l;break;case xe:A=0,C=l;break;default:A=0;let I=p[w];C=l*Math.max(0,1-I.mixTime/I.mixDuration);break}s.totalAlpha+=C,!v&&b instanceof re?this.applyRotateTimeline(b,e,u,C,A,s.timelinesRotation,w<<1,g):b instanceof zt?this.applyAttachmentTimeline(b,e,u,A,c):(P.webkit602BugfixHelper(C,i),a&&b instanceof Wt&&A==0&&(y=0),b.apply(e,d,u,m,C,A,y))}}return t.mixDuration>0&&this.queueEvents(s,f),this.events.length=0,s.nextAnimationLast=f,s.nextTrackLast=s.trackTime,n}applyAttachmentTimeline(t,e,i,s,n){var c=e.slots[t.slotIndex];c.bone.active&&(i<t.frames[0]?(s==0||s==1)&&this.setAttachment(e,c,c.data.attachmentName,n):this.setAttachment(e,c,t.attachmentNames[ut.search1(t.frames,i)],n),c.attachmentState<=this.unkeyedState&&(c.attachmentState=this.unkeyedState+di))}setAttachment(t,e,i,s){e.setAttachment(i?t.getAttachment(e.data.index,i):null),s&&(e.attachmentState=this.unkeyedState+Ji)}applyRotateTimeline(t,e,i,s,n,c,a,r){if(r&&(c[a]=0),s==1){t.apply(e,0,i,null,1,n,0);return}let o=e.bones[t.boneIndex];if(!o.active)return;let l=t.frames,h=0,d=0;if(i<l[0])switch(n){case 0:o.rotation=o.data.rotation;default:return;case 1:h=o.rotation,d=o.data.rotation}else h=n==0?o.data.rotation:o.rotation,d=o.data.rotation+t.getCurveValue(i);let f=0,u=d-h;if(u-=(16384-(16384.499999999996-u/360|0))*360,u==0)f=c[a];else{let m=0,x=0;r?(m=0,x=u):(m=c[a],x=c[a+1]);let p=m-m%360;f=u+p;let v=u>=0,g=m>=0;Math.abs(x)<=90&&X.signum(x)!=X.signum(u)&&(Math.abs(m-p)>180?(f+=360*X.signum(m),g=v):p!=0?f-=360*X.signum(m):g=v),g!=v&&(f+=360*X.signum(m)),c[a]=f}c[a+1]=u,o.rotation=h+f*s}queueEvents(t,e){let i=t.animationStart,s=t.animationEnd,n=s-i,c=t.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(t,h)}let l=!1;for(t.loop?l=n==0||c>t.trackTime%n:l=e>=s&&t.animationLast<s,l&&this.queue.complete(t);r<o;r++){let h=a[r];h.time<i||this.queue.event(t,h)}}clearTracks(){let t=this.queue.drainDisabled;this.queue.drainDisabled=!0;for(let e=0,i=this.tracks.length;e<i;e++)this.clearTrack(e);this.tracks.length=0,this.queue.drainDisabled=t,this.queue.drain()}clearTrack(t){if(t>=this.tracks.length)return;let e=this.tracks[t];if(!e)return;this.queue.end(e),this.clearNext(e);let i=e;for(;;){let s=i.mixingFrom;if(!s)break;this.queue.end(s),i.mixingFrom=null,i.mixingTo=null,i=s}this.tracks[e.trackIndex]=null,this.queue.drain()}setCurrent(t,e,i){let s=this.expandToIndex(t);this.tracks[t]=e,e.previous=null,s&&(i&&this.queue.interrupt(s),e.mixingFrom=s,s.mixingTo=e,e.mixTime=0,s.mixingFrom&&s.mixDuration>0&&(e.interruptAlpha*=Math.min(1,s.mixTime/s.mixDuration)),s.timelinesRotation.length=0),this.queue.start(e)}setAnimation(t,e,i=!1){let s=this.data.skeletonData.findAnimation(e);if(!s)throw new Error("Animation not found: "+e);return this.setAnimationWith(t,s,i)}setAnimationWith(t,e,i=!1){if(!e)throw new Error("animation cannot be null.");let s=!0,n=this.expandToIndex(t);n&&(n.nextTrackLast==-1?(this.tracks[t]=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(t,e,i,n);return this.setCurrent(t,c,s),this.queue.drain(),c}addAnimation(t,e,i=!1,s=0){let n=this.data.skeletonData.findAnimation(e);if(!n)throw new Error("Animation not found: "+e);return this.addAnimationWith(t,n,i,s)}addAnimationWith(t,e,i=!1,s=0){if(!e)throw new Error("animation cannot be null.");let n=this.expandToIndex(t);if(n)for(;n.next;)n=n.next;let c=this.trackEntry(t,e,i,n);return n?(n.next=c,c.previous=n,s<=0&&(s+=n.getTrackComplete()-c.mixDuration)):(this.setCurrent(t,c,!0),this.queue.drain()),c.delay=s,c}setEmptyAnimation(t,e=0){let i=this.setAnimationWith(t,me.emptyAnimation(),!1);return i.mixDuration=e,i.trackEnd=e,i}addEmptyAnimation(t,e=0,i=0){let s=this.addAnimationWith(t,me.emptyAnimation(),!1,i);return i<=0&&(s.delay+=s.mixDuration-e),s.mixDuration=e,s.trackEnd=e,s}setEmptyAnimations(t=0){let e=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,t)}this.queue.drainDisabled=e,this.queue.drain()}expandToIndex(t){return t<this.tracks.length?this.tracks[t]:(P.ensureArrayCapacity(this.tracks,t+1,null),this.tracks.length=t+1,null)}trackEntry(t,e,i,s){let n=this.trackEntryPool.obtain();return n.reset(),n.trackIndex=t,n.animation=e,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=e.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,e):0,n.interruptAlpha=1,n.totalAlpha=0,n.mixBlend=2,n}clearNext(t){let e=t.next;for(;e;)this.queue.dispose(e),e=e.next;t.next=null}_animationsChanged(){this.animationsChanged=!1,this.propertyIDs.clear();let t=this.tracks;for(let e=0,i=t.length;e<i;e++){let s=t[e];if(s){for(;s.mixingFrom;)s=s.mixingFrom;do(!s.mixingTo||s.mixBlend!=3)&&this.computeHold(s),s=s.mixingTo;while(s)}}}computeHold(t){let e=t.mixingTo,i=t.animation.timelines,s=t.animation.timelines.length,n=t.timelineMode;n.length=s;let c=t.timelineHoldMix;c.length=0;let a=this.propertyIDs;if(e&&e.holdPrevious){for(let r=0;r<s;r++)n[r]=a.addAll(i[r].getPropertyIds())?xe:ci;return}t:for(let r=0;r<s;r++){let o=i[r],l=o.getPropertyIds();if(!a.addAll(l))n[r]=ge;else if(!e||o instanceof zt||o instanceof Wt||o instanceof ne||!e.animation.hasTimeline(l))n[r]=hi;else{for(let h=e.mixingTo;h;h=h.mixingTo)if(!h.animation.hasTimeline(l)){if(t.mixDuration>0){n[r]=Ki,c[r]=h;continue t}break}n[r]=xe}}}getCurrent(t){return t>=this.tracks.length?null:this.tracks[t]}addListener(t){if(!t)throw new Error("listener cannot be null.");this.listeners.push(t)}removeListener(t){let e=this.listeners.indexOf(t);e>=0&&this.listeners.splice(e,1)}clearListeners(){this.listeners.length=0}clearListenerNotifications(){this.queue.clear()}},Hi=me;Hi._emptyAnimation=new fe("<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=2,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 t=this.animationEnd-this.animationStart;return t==0?this.animationStart:this.trackTime%t+this.animationStart}return Math.min(this.trackTime+this.animationStart,this.animationEnd)}setAnimationLast(t){this.animationLast=t,this.nextAnimationLast=t}isComplete(){return this.trackTime>=this.animationEnd-this.animationStart}resetRotationDirections(){this.timelinesRotation.length=0}getTrackComplete(){let t=this.animationEnd-this.animationStart;if(t!=0){if(this.loop)return t*(1+(this.trackTime/t|0));if(this.trackTime<t)return t}return this.trackTime}},Zi=class{constructor(t){this.objects=[],this.drainDisabled=!1,this.animState=t}start(t){this.objects.push(pt.start),this.objects.push(t),this.animState.animationsChanged=!0}interrupt(t){this.objects.push(pt.interrupt),this.objects.push(t)}end(t){this.objects.push(pt.end),this.objects.push(t),this.animState.animationsChanged=!0}dispose(t){this.objects.push(pt.dispose),this.objects.push(t)}complete(t){this.objects.push(pt.complete),this.objects.push(t)}event(t,e){this.objects.push(pt.event),this.objects.push(t),this.objects.push(e)}drain(){if(this.drainDisabled)return;this.drainDisabled=!0;let t=this.objects,e=this.animState.listeners;for(let i=0;i<t.length;i+=2){let s=t[i],n=t[i+1];switch(s){case pt.start:n.listener&&n.listener.start&&n.listener.start(n);for(let a=0;a<e.length;a++){let r=e[a];r.start&&r.start(n)}break;case pt.interrupt:n.listener&&n.listener.interrupt&&n.listener.interrupt(n);for(let a=0;a<e.length;a++){let r=e[a];r.interrupt&&r.interrupt(n)}break;case pt.end:n.listener&&n.listener.end&&n.listener.end(n);for(let a=0;a<e.length;a++){let r=e[a];r.end&&r.end(n)}case pt.dispose:n.listener&&n.listener.dispose&&n.listener.dispose(n);for(let a=0;a<e.length;a++){let r=e[a];r.dispose&&r.dispose(n)}this.animState.trackEntryPool.free(n);break;case pt.complete:n.listener&&n.listener.complete&&n.listener.complete(n);for(let a=0;a<e.length;a++){let r=e[a];r.complete&&r.complete(n)}break;case pt.event:let c=t[i+++2];n.listener&&n.listener.event&&n.listener.event(n,c);for(let a=0;a<e.length;a++){let r=e[a];r.event&&r.event(n,c)}break}}this.clear(),this.drainDisabled=!1}clear(){this.objects.length=0}},pt=(t=>(t[t.start=0]="start",t[t.interrupt=1]="interrupt",t[t.end=2]="end",t[t.dispose=3]="dispose",t[t.complete=4]="complete",t[t.event=5]="event",t))(pt||{}),Bs=class{start(t){}interrupt(t){}end(t){}dispose(t){}complete(t){}event(t,e){}},ge=0,hi=1,ci=2,xe=3,Ki=4,di=1,Ji=2,Ds=class{constructor(t){if(this.animationToMixTime={},this.defaultMix=0,!t)throw new Error("skeletonData cannot be null.");this.skeletonData=t}setMix(t,e,i){let s=this.skeletonData.findAnimation(t);if(!s)throw new Error("Animation not found: "+t);let n=this.skeletonData.findAnimation(e);if(!n)throw new Error("Animation not found: "+e);this.setMixWith(s,n,i)}setMixWith(t,e,i){if(!t)throw new Error("from cannot be null.");if(!e)throw new Error("to cannot be null.");let s=t.name+"."+e.name;this.animationToMixTime[s]=i}getMix(t,e){let i=t.name+"."+e.name,s=this.animationToMixTime[i];return s===void 0?this.defaultMix:s}},we=class extends St{constructor(t){super(t),this.color=new O(1,1,1,1)}copy(){let t=new we(this.name);return this.copyTo(t),t.color.setFromColor(this.color),t}},ae=class extends St{constructor(t){super(t),this.endSlot=null,this.color=new O(.2275,.2275,.8078,1)}copy(){let t=new ae(this.name);return this.copyTo(t),t.endSlot=this.endSlot,t.color.setFromColor(this.color),t}},fi=class{constructor(t){this._image=t}getImage(){return this._image}},be=(t=>(t[t.Nearest=9728]="Nearest",t[t.Linear=9729]="Linear",t[t.MipMap=9987]="MipMap",t[t.MipMapNearestNearest=9984]="MipMapNearestNearest",t[t.MipMapLinearNearest=9985]="MipMapLinearNearest",t[t.MipMapNearestLinear=9986]="MipMapNearestLinear",t[t.MipMapLinearLinear=9987]="MipMapLinearLinear",t))(be||{}),Qi=(t=>(t[t.MirroredRepeat=33648]="MirroredRepeat",t[t.ClampToEdge=33071]="ClampToEdge",t[t.Repeat=10497]="Repeat",t))(Qi||{}),$i=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}},Os=class extends fi{setFilters(t,e){}setWraps(t,e){}dispose(){}},ts=class{constructor(t){this.pages=new Array,this.regions=new Array;let e=new Vs(t),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=P.enumValue(be,i[1]),l.magFilter=P.enumValue(be,i[2])},s.repeat=l=>{i[1].indexOf("x")!=-1&&(l.uWrap=10497),i[1].indexOf("y")!=-1&&(l.vWrap=10497)},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=e.readLine();for(;c&&c.trim().length==0;)c=e.readLine();for(;!(!c||c.trim().length==0||e.readEntry(i,c)==0);)c=e.readLine();let a=null,r=null,o=null;for(;c!==null;)if(c.trim().length==0)a=null,c=e.readLine();else if(a){let l=new ui(a,c);for(;;){let h=e.readEntry(i,c=e.readLine());if(h==0)break;let d=n[i[0]];if(d)d(l);else{r||(r=[]),o||(o=[]),r.push(i[0]);let f=[];for(let u=0;u<h;u++)f.push(parseInt(i[u+1]));o.push(f)}}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());e.readEntry(i,c=e.readLine())!=0;){let l=s[i[0]];l&&l(a)}this.pages.push(a)}}findRegion(t){for(let e=0;e<this.regions.length;e++)if(this.regions[e].name==t)return this.regions[e];return null}setTextures(t,e=""){for(let i of this.pages)i.setTexture(t.get(e+i.name))}dispose(){var t;for(let e=0;e<this.pages.length;e++)(t=this.pages[e].texture)==null||t.dispose()}},Vs=class{constructor(t){this.index=0,this.lines=t.split(/\r\n|\r|\n/)}readLine(){return this.index>=this.lines.length?null:this.lines[this.index++]}readEntry(t,e){if(!e||(e=e.trim(),e.length==0))return 0;let i=e.indexOf(":");if(i==-1)return 0;t[0]=e.substr(0,i).trim();for(let s=1,n=i+1;;s++){let c=e.indexOf(",",n);if(c==-1)return t[s]=e.substr(n).trim(),s;if(t[s]=e.substr(n,c-n).trim(),n=c+1,s==4)return 4}}},es=class{constructor(t){this.minFilter=9728,this.magFilter=9728,this.uWrap=33071,this.vWrap=33071,this.texture=null,this.width=0,this.height=0,this.pma=!1,this.regions=new Array,this.name=t}setTexture(t){this.texture=t,t.setFilters(this.minFilter,this.magFilter),t.setWraps(this.uWrap,this.vWrap);for(let e of this.regions)e.texture=t}},ui=class extends $i{constructor(t,e){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=t,this.name=e,t.regions.push(this)}},Dt=class extends St{constructor(t,e){super(t),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=e}updateRegion(){if(!this.region)throw new Error("Region not set.");let t=this.regionUVs;(!this.uvs||this.uvs.length!=t.length)&&(this.uvs=P.newFloatArray(t.length));let e=this.uvs,i=this.uvs.length,s=this.region.u,n=this.region.v,c=0,a=0;if(this.region instanceof ui){let r=this.region,o=r.page,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 d=0;d<i;d+=2)e[d]=s+t[d+1]*c,e[d+1]=n+(1-t[d])*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 d=0;d<i;d+=2)e[d]=s+(1-t[d])*c,e[d+1]=n+(1-t[d+1])*a;return;case 270:s-=r.offsetY/l,n-=r.offsetX/h,c=r.originalHeight/l,a=r.originalWidth/h;for(let d=0;d<i;d+=2)e[d]=s+(1-t[d+1])*c,e[d+1]=n+t[d]*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)e[r]=s+t[r]*c,e[r+1]=n+t[r+1]*a}getParentMesh(){return this.parentMesh}setParentMesh(t){this.parentMesh=t,t&&(this.bones=t.bones,this.vertices=t.vertices,this.worldVerticesLength=t.worldVerticesLength,this.regionUVs=t.regionUVs,this.triangles=t.triangles,this.hullLength=t.hullLength,this.worldVerticesLength=t.worldVerticesLength)}copy(){if(this.parentMesh)return this.newLinkedMesh();let t=new Dt(this.name,this.path);return t.region=this.region,t.color.setFromColor(this.color),this.copyTo(t),t.regionUVs=new Array(this.regionUVs.length),P.arrayCopy(this.regionUVs,0,t.regionUVs,0,this.regionUVs.length),t.uvs=new Array(this.uvs.length),P.arrayCopy(this.uvs,0,t.uvs,0,this.uvs.length),t.triangles=new Array(this.triangles.length),P.arrayCopy(this.triangles,0,t.triangles,0,this.triangles.length),t.hullLength=this.hullLength,t.sequence=this.sequence!=null?this.sequence.copy():null,this.edges&&(t.edges=new Array(this.edges.length),P.arrayCopy(this.edges,0,t.edges,0,this.edges.length)),t.width=this.width,t.height=this.height,t}computeWorldVertices(t,e,i,s,n,c){this.sequence!=null&&this.sequence.apply(t,this),super.computeWorldVertices(t,e,i,s,n,c)}newLinkedMesh(){let t=new Dt(this.name,this.path);return t.region=this.region,t.color.setFromColor(this.color),t.timelineAttachment=this.timelineAttachment,t.setParentMesh(this.parentMesh?this.parentMesh:this),t.region!=null&&t.updateRegion(),t}},_t=class extends St{constructor(t){super(t),this.lengths=[],this.closed=!1,this.constantSpeed=!1,this.color=new O(1,1,1,1)}copy(){let t=new _t(this.name);return this.copyTo(t),t.lengths=new Array(this.lengths.length),P.arrayCopy(this.lengths,0,t.lengths,0,this.lengths.length),t.closed=closed,t.constantSpeed=this.constantSpeed,t.color.setFromColor(this.color),t}},mi=class extends St{constructor(t){super(t),this.x=0,this.y=0,this.rotation=0,this.color=new O(.38,.94,0,1)}computeWorldPosition(t,e){return e.x=this.x*t.a+this.y*t.b+t.worldX,e.y=this.x*t.c+this.y*t.d+t.worldY,e}computeWorldRotation(t){let e=X.cosDeg(this.rotation),i=X.sinDeg(this.rotation),s=e*t.a+i*t.b,n=e*t.c+i*t.d;return Math.atan2(n,s)*X.radDeg}copy(){let t=new mi(this.name);return t.x=this.x,t.y=this.y,t.rotation=this.rotation,t.color.setFromColor(this.color),t}},is=class extends Ue{constructor(t,e){super(t),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.region=null,this.sequence=null,this.offset=P.newFloatArray(8),this.uvs=P.newFloatArray(8),this.tempColor=new O(1,1,1,1),this.path=e}updateRegion(){if(!this.region)throw new Error("Region not set.");let t=this.region,e=this.uvs;if(t==null){e[0]=0,e[1]=0,e[2]=0,e[3]=1,e[4]=1,e[5]=1,e[6]=1,e[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),d=this.x,f=this.y,u=n*l+d,m=n*h,x=c*l+f,p=c*h,v=a*l+d,g=a*h,w=r*l+f,b=r*h,y=this.offset;y[0]=u-p,y[1]=x+m,y[2]=u-b,y[3]=w+m,y[4]=v-b,y[5]=w+g,y[6]=v-p,y[7]=x+g,t.degrees==90?(e[0]=t.u2,e[1]=t.v2,e[2]=t.u,e[3]=t.v2,e[4]=t.u,e[5]=t.v,e[6]=t.u2,e[7]=t.v):(e[0]=t.u,e[1]=t.v2,e[2]=t.u,e[3]=t.v,e[4]=t.u2,e[5]=t.v,e[6]=t.u2,e[7]=t.v2)}computeWorldVertices(t,e,i,s){this.sequence!=null&&this.sequence.apply(t,this);let n=t.bone,c=this.offset,a=n.worldX,r=n.worldY,o=n.a,l=n.b,h=n.c,d=n.d,f=0,u=0;f=c[0],u=c[1],e[i]=f*o+u*l+a,e[i+1]=f*h+u*d+r,i+=s,f=c[2],u=c[3],e[i]=f*o+u*l+a,e[i+1]=f*h+u*d+r,i+=s,f=c[4],u=c[5],e[i]=f*o+u*l+a,e[i+1]=f*h+u*d+r,i+=s,f=c[6],u=c[7],e[i]=f*o+u*l+a,e[i+1]=f*h+u*d+r}copy(){let t=new is(this.name,this.path);return t.region=this.region,t.x=this.x,t.y=this.y,t.scaleX=this.scaleX,t.scaleY=this.scaleY,t.rotation=this.rotation,t.width=this.width,t.height=this.height,P.arrayCopy(this.uvs,0,t.uvs,0,8),P.arrayCopy(this.offset,0,t.offset,0,8),t.color.setFromColor(this.color),t.sequence=this.sequence!=null?this.sequence.copy():null,t}},at=is;at.X1=0,at.Y1=1,at.C1R=2,at.C1G=3,at.C1B=4,at.C1A=5,at.U1=6,at.V1=7,at.X2=8,at.Y2=9,at.C2R=10,at.C2G=11,at.C2B=12,at.C2A=13,at.U2=14,at.V2=15,at.X3=16,at.Y3=17,at.C3R=18,at.C3G=19,at.C3B=20,at.C3A=21,at.U3=22,at.V3=23,at.X4=24,at.Y4=25,at.C4R=26,at.C4G=27,at.C4B=28,at.C4A=29,at.U4=30,at.V4=31;var Ns=class{constructor(t){this.atlas=t}loadSequence(t,e,i){let s=i.regions;for(let n=0,c=s.length;n<c;n++){let a=i.getPath(e,n),r=this.atlas.findRegion(a);if(r==null)throw new Error("Region not found in atlas: "+a+" (sequence: "+t+")");s[n]=r}}newRegionAttachment(t,e,i,s){let n=new at(e,i);if(s!=null)this.loadSequence(e,i,s);else{let c=this.atlas.findRegion(i);if(!c)throw new Error("Region not found in atlas: "+i+" (region attachment: "+e+")");n.region=c}return n}newMeshAttachment(t,e,i,s){let n=new Dt(e,i);if(s!=null)this.loadSequence(e,i,s);else{let c=this.atlas.findRegion(i);if(!c)throw new Error("Region not found in atlas: "+i+" (mesh attachment: "+e+")");n.region=c}return n}newBoundingBoxAttachment(t,e){return new we(e)}newPathAttachment(t,e){return new _t(e)}newPointAttachment(t,e){return new mi(e)}newClippingAttachment(t,e){return new ae(e)}},gi=class{constructor(t,e,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=pe.Normal,this.skinRequired=!1,this.color=new O,t<0)throw new Error("index must be >= 0.");if(!e)throw new Error("name cannot be null.");this.index=t,this.name=e,this.parent=i}},pe=(t=>(t[t.Normal=0]="Normal",t[t.OnlyTranslation=1]="OnlyTranslation",t[t.NoRotationOrReflection=2]="NoRotationOrReflection",t[t.NoScale=3]="NoScale",t[t.NoScaleOrReflection=4]="NoScaleOrReflection",t))(pe||{}),xi=class{constructor(t,e,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,!t)throw new Error("data cannot be null.");if(!e)throw new Error("skeleton cannot be null.");this.data=t,this.skeleton=e,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(t,e,i,s,n,c,a){this.ax=t,this.ay=e,this.arotation=i,this.ascaleX=s,this.ascaleY=n,this.ashearX=c,this.ashearY=a;let r=this.parent;if(!r){let f=this.skeleton,u=i+90+a,m=f.scaleX,x=f.scaleY;this.a=X.cosDeg(i+c)*s*m,this.b=X.cosDeg(u)*n*m,this.c=X.sinDeg(i+c)*s*x,this.d=X.sinDeg(u)*n*x,this.worldX=t*m+f.x,this.worldY=e*x+f.y;return}let o=r.a,l=r.b,h=r.c,d=r.d;switch(this.worldX=o*t+l*e+r.worldX,this.worldY=h*t+d*e+r.worldY,this.data.transformMode){case 0:{let f=i+90+a,u=X.cosDeg(i+c)*s,m=X.cosDeg(f)*n,x=X.sinDeg(i+c)*s,p=X.sinDeg(f)*n;this.a=o*u+l*x,this.b=o*m+l*p,this.c=h*u+d*x,this.d=h*m+d*p;return}case 1:{let f=i+90+a;this.a=X.cosDeg(i+c)*s,this.b=X.cosDeg(f)*n,this.c=X.sinDeg(i+c)*s,this.d=X.sinDeg(f)*n;break}case 2:{let f=o*o+h*h,u=0;f>1e-4?(f=Math.abs(o*d-l*h)/f,o/=this.skeleton.scaleX,h/=this.skeleton.scaleY,l=h*f,d=o*f,u=Math.atan2(h,o)*X.radDeg):(o=0,h=0,u=90-Math.atan2(d,l)*X.radDeg);let m=i+c-u,x=i+a-u+90,p=X.cosDeg(m)*s,v=X.cosDeg(x)*n,g=X.sinDeg(m)*s,w=X.sinDeg(x)*n;this.a=o*p-l*g,this.b=o*v-l*w,this.c=h*p+d*g,this.d=h*v+d*w;break}case 3:case 4:{let f=X.cosDeg(i),u=X.sinDeg(i),m=(o*f+l*u)/this.skeleton.scaleX,x=(h*f+d*u)/this.skeleton.scaleY,p=Math.sqrt(m*m+x*x);p>1e-5&&(p=1/p),m*=p,x*=p,p=Math.sqrt(m*m+x*x),this.data.transformMode==3&&o*d-l*h<0!=(this.skeleton.scaleX<0!=this.skeleton.scaleY<0)&&(p=-p);let v=Math.PI/2+Math.atan2(x,m),g=Math.cos(v)*p,w=Math.sin(v)*p,b=X.cosDeg(c)*s,y=X.cosDeg(90+a)*n,A=X.sinDeg(c)*s,C=X.sinDeg(90+a)*n;this.a=m*b+g*A,this.b=m*y+g*C,this.c=x*b+w*A,this.d=x*y+w*C;break}}this.a*=this.skeleton.scaleX,this.b*=this.skeleton.scaleX,this.c*=this.skeleton.scaleY,this.d*=this.skeleton.scaleY}setToSetupPose(){let t=this.data;this.x=t.x,this.y=t.y,this.rotation=t.rotation,this.scaleX=t.scaleX,this.scaleY=t.scaleY,this.shearX=t.shearX,this.shearY=t.shearY}getWorldRotationX(){return Math.atan2(this.c,this.a)*X.radDeg}getWorldRotationY(){return Math.atan2(this.d,this.b)*X.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 t=this.parent;if(!t){this.ax=this.worldX-this.skeleton.x,this.ay=this.worldY-this.skeleton.y,this.arotation=Math.atan2(this.c,this.a)*X.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)*X.radDeg;return}let e=t.a,i=t.b,s=t.c,n=t.d,c=1/(e*n-i*s),a=n*c,r=i*c,o=s*c,l=e*c,h=this.worldX-t.worldX,d=this.worldY-t.worldY;this.ax=h*a-d*r,this.ay=d*l-h*o;let f,u,m,x;if(this.data.transformMode==1)f=this.a,u=this.b,m=this.c,x=this.d;else{switch(this.data.transformMode){case 2:{let b=Math.abs(e*n-i*s)/(e*e+s*s),y=e/this.skeleton.scaleX;i=-(s/this.skeleton.scaleY)*b*this.skeleton.scaleX,n=y*b*this.skeleton.scaleY,c=1/(e*n-i*s),a=n*c,r=i*c;break}case 3:case 4:let p=X.cosDeg(this.rotation),v=X.sinDeg(this.rotation);e=(e*p+i*v)/this.skeleton.scaleX,s=(s*p+n*v)/this.skeleton.scaleY;let g=Math.sqrt(e*e+s*s);g>1e-5&&(g=1/g),e*=g,s*=g,g=Math.sqrt(e*e+s*s),this.data.transformMode==3&&c<0!=(this.skeleton.scaleX<0!=this.skeleton.scaleY<0)&&(g=-g);let w=X.PI/2+Math.atan2(s,e);i=Math.cos(w)*g,n=Math.sin(w)*g,c=1/(e*n-i*s),a=n*c,r=i*c,o=s*c,l=e*c}f=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(f*f+m*m),this.ascaleX>1e-4){let p=f*x-u*m;this.ascaleY=p/this.ascaleX,this.ashearY=-Math.atan2(f*u+m*x,p)*X.radDeg,this.arotation=Math.atan2(m,f)*X.radDeg}else this.ascaleX=0,this.ascaleY=Math.sqrt(u*u+x*x),this.ashearY=0,this.arotation=90-Math.atan2(x,u)*X.radDeg}worldToLocal(t){let e=1/(this.a*this.d-this.b*this.c),i=t.x-this.worldX,s=t.y-this.worldY;return t.x=i*this.d*e-s*this.b*e,t.y=s*this.a*e-i*this.c*e,t}localToWorld(t){let e=t.x,i=t.y;return t.x=e*this.a+i*this.b+this.worldX,t.y=e*this.c+i*this.d+this.worldY,t}worldToLocalRotation(t){let e=X.sinDeg(t),i=X.cosDeg(t);return Math.atan2(this.a*e-this.c*i,this.d*i-this.b*e)*X.radDeg+this.rotation-this.shearX}localToWorldRotation(t){t-=this.rotation-this.shearX;let e=X.sinDeg(t),i=X.cosDeg(t);return Math.atan2(i*this.c+e*this.d,i*this.a+e*this.b)*X.radDeg}rotateWorld(t){let e=this.a,i=this.b,s=this.c,n=this.d,c=X.cosDeg(t),a=X.sinDeg(t);this.a=c*e-a*s,this.b=c*i-a*n,this.c=a*e+c*s,this.d=a*i+c*n}},ve=class{constructor(t,e,i){this.name=t,this.order=e,this.skinRequired=i}},ss=class{constructor(t,e="",i=new wi){this.pathPrefix="",this.assets={},this.errors={},this.toLoad=0,this.loaded=0,this.textureLoader=t,this.pathPrefix=e,this.downloader=i}start(t){return this.toLoad++,this.pathPrefix+t}success(t,e,i){this.toLoad--,this.loaded++,this.assets[e]=i,t&&t(e,i)}error(t,e,i){this.toLoad--,this.loaded++,this.errors[e]=i,t&&t(e,i)}loadAll(){return new Promise((e,i)=>{let s=()=>{if(this.isLoadingComplete()){this.hasErrors()?i(this.errors):e(this);return}requestAnimationFrame(s)};requestAnimationFrame(s)})}setRawDataURI(t,e){this.downloader.rawDataUris[this.pathPrefix+t]=e}loadBinary(t,e=()=>{},i=()=>{}){t=this.start(t),this.downloader.downloadBinary(t,s=>{this.success(e,t,s)},(s,n)=>{this.error(i,t,`Couldn't load binary ${t}: status ${s}, ${n}`)})}loadText(t,e=()=>{},i=()=>{}){t=this.start(t),this.downloader.downloadText(t,s=>{this.success(e,t,s)},(s,n)=>{this.error(i,t,`Couldn't load text ${t}: status ${s}, ${n}`)})}loadJson(t,e=()=>{},i=()=>{}){t=this.start(t),this.downloader.downloadJson(t,s=>{this.success(e,t,s)},(s,n)=>{this.error(i,t,`Couldn't load JSON ${t}: status ${s}, ${n}`)})}loadTexture(t,e=()=>{},i=()=>{}){if(t=this.start(t),!!!(typeof window!="undefined"&&typeof navigator!="undefined"&&window.document))fetch(t,{mode:"cors"}).then(c=>c.ok?c.blob():(this.error(i,t,`Couldn't load image: ${t}`),null)).then(c=>c?createImageBitmap(c,{premultiplyAlpha:"none",colorSpaceConversion:"none"}):null).then(c=>{c&&this.success(e,t,this.textureLoader(c))});else{let c=new Image;c.crossOrigin="anonymous",c.onload=()=>{this.success(e,t,this.textureLoader(c))},c.onerror=()=>{this.error(i,t,`Couldn't load image: ${t}`)},this.downloader.rawDataUris[t]&&(t=this.downloader.rawDataUris[t]),c.src=t}}loadTextureAtlas(t,e=()=>{},i=()=>{},s){let n=t.lastIndexOf("/"),c=n>=0?t.substring(0,n+1):"";t=this.start(t),this.downloader.downloadText(t,a=>{try{let r=new ts(a),o=r.pages.length,l=!1;for(let h of r.pages)this.loadTexture(s?s[h.name]:c+h.name,(d,f)=>{l||(h.setTexture(f),--o==0&&this.success(e,t,r))},(d,f)=>{l||this.error(i,t,`Couldn't load texture atlas ${t} page image: ${d}`),l=!0})}catch(r){this.error(i,t,`Couldn't parse texture atlas ${t}: ${r.message}`)}},(a,r)=>{this.error(i,t,`Couldn't load texture atlas ${t}: status ${a}, ${r}`)})}get(t){return this.assets[this.pathPrefix+t]}require(t){t=this.pathPrefix+t;let e=this.assets[t];if(e)return e;let i=this.errors[t];throw Error("Asset not found: "+t+(i?`
2
- `+i:""))}remove(t){t=this.pathPrefix+t;let e=this.assets[t];return e.dispose&&e.dispose(),delete this.assets[t],e}removeAll(){for(let t in this.assets){let e=this.assets[t];e.dispose&&e.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}},wi=class{constructor(){this.callbacks={},this.rawDataUris={}}dataUriToString(t){if(!t.startsWith("data:"))throw new Error("Not a data URI.");let e=t.indexOf("base64,");return e!=-1?(e+=7,atob(t.substr(e))):t.substr(t.indexOf(",")+1)}base64ToUint8Array(t){for(var e=window.atob(t),i=e.length,s=new Uint8Array(i),n=0;n<i;n++)s[n]=e.charCodeAt(n);return s}dataUriToUint8Array(t){if(!t.startsWith("data:"))throw new Error("Not a data URI.");let e=t.indexOf("base64,");if(e==-1)throw new Error("Not a binary data URI.");return e+=7,this.base64ToUint8Array(t.substr(e))}downloadText(t,e,i){if(this.start(t,e,i))return;if(this.rawDataUris[t]){try{let c=this.rawDataUris[t];this.finish(t,200,this.dataUriToString(c))}catch(c){this.finish(t,400,JSON.stringify(c))}return}let s=new XMLHttpRequest;s.overrideMimeType("text/html"),s.open("GET",t,!0);let n=()=>{this.finish(t,s.status,s.responseText)};s.onload=n,s.onerror=n,s.send()}downloadJson(t,e,i){this.downloadText(t,s=>{e(JSON.parse(s))},i)}downloadBinary(t,e,i){if(this.start(t,e,i))return;if(this.rawDataUris[t]){try{let c=this.rawDataUris[t];this.finish(t,200,this.dataUriToUint8Array(c))}catch(c){this.finish(t,400,JSON.stringify(c))}return}let s=new XMLHttpRequest;s.open("GET",t,!0),s.responseType="arraybuffer";let n=()=>{this.finish(t,s.status,s.response)};s.onload=()=>{s.status==200||s.status==0?this.finish(t,200,new Uint8Array(s.response)):n()},s.onerror=n,s.send()}start(t,e,i){let s=this.callbacks[t];try{if(s)return!0;this.callbacks[t]=s=[]}finally{s.push(e,i)}}finish(t,e,i){let s=this.callbacks[t];delete this.callbacks[t];let n=e==200||e==0?[i]:[e,i];for(let c=n.length-1,a=s.length;c<a;c+=2)s[c].apply(null,n)}},bi=class{constructor(t,e){if(this.intValue=0,this.floatValue=0,this.stringValue=null,this.time=0,this.volume=0,this.balance=0,!e)throw new Error("data cannot be null.");this.time=t,this.data=e}},pi=class{constructor(t){this.intValue=0,this.floatValue=0,this.stringValue=null,this.audioPath=null,this.volume=0,this.balance=0,this.name=t}},rs=class{constructor(t,e){if(this.bendDirection=0,this.compress=!1,this.stretch=!1,this.mix=1,this.softness=0,this.active=!1,!t)throw new Error("data cannot be null.");if(!e)throw new Error("skeleton cannot be null.");this.data=t,this.mix=t.mix,this.softness=t.softness,this.bendDirection=t.bendDirection,this.compress=t.compress,this.stretch=t.stretch,this.bones=new Array;for(let s=0;s<t.bones.length;s++){let n=e.findBone(t.bones[s].name);if(!n)throw new Error(`Couldn't find bone ${t.bones[s].name}`);this.bones.push(n)}let i=e.findBone(t.target.name);if(!i)throw new Error(`Couldn't find bone ${t.target.name}`);this.target=i}isActive(){return this.active}update(){if(this.mix==0)return;let t=this.target,e=this.bones;switch(e.length){case 1:this.apply1(e[0],t.worldX,t.worldY,this.compress,this.stretch,this.data.uniform,this.mix);break;case 2:this.apply2(e[0],e[1],t.worldX,t.worldY,this.bendDirection,this.stretch,this.data.uniform,this.softness,this.mix);break}}apply1(t,e,i,s,n,c,a){let r=t.parent;if(!r)throw new Error("IK bone must have parent.");let o=r.a,l=r.b,h=r.c,d=r.d,f=-t.ashearX-t.arotation,u=0,m=0;switch(t.data.transformMode){case 1:u=e-t.worldX,m=i-t.worldY;break;case 2:let v=Math.abs(o*d-l*h)/Math.max(1e-4,o*o+h*h),g=o/t.skeleton.scaleX,w=h/t.skeleton.scaleY;l=-w*v*t.skeleton.scaleX,d=g*v*t.skeleton.scaleY,f+=Math.atan2(w,g)*X.radDeg;default:let b=e-r.worldX,y=i-r.worldY,A=o*d-l*h;Math.abs(A)<=1e-4?(u=0,m=0):(u=(b*d-y*l)/A-t.ax,m=(y*o-b*h)/A-t.ay)}f+=Math.atan2(m,u)*X.radDeg,t.ascaleX<0&&(f+=180),f>180?f-=360:f<-180&&(f+=360);let x=t.ascaleX,p=t.ascaleY;if(s||n){switch(t.data.transformMode){case 3:case 4:u=e-t.worldX,m=i-t.worldY}let v=t.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&&(p*=w)}}t.updateWorldTransformWith(t.ax,t.ay,t.arotation+f*a,x,p,t.ashearX,t.ashearY)}apply2(t,e,i,s,n,c,a,r,o){let l=t.ax,h=t.ay,d=t.ascaleX,f=t.ascaleY,u=d,m=f,x=e.ascaleX,p=0,v=0,g=0;d<0?(d=-d,p=180,g=-1):(p=0,g=1),f<0&&(f=-f,g=-g),x<0?(x=-x,v=180):v=0;let w=e.ax,b=0,y=0,A=0,C=t.a,I=t.b,E=t.c,R=t.d,L=Math.abs(d-f)<=1e-4;!L||c?(b=0,y=C*w+t.worldX,A=E*w+t.worldY):(b=e.ay,y=C*w+I*b+t.worldX,A=E*w+R*b+t.worldY);let k=t.parent;if(!k)throw new Error("IK parent must itself have a parent.");C=k.a,I=k.b,E=k.c,R=k.d;let F=C*R-I*E,Y=y-k.worldX,T=A-k.worldY;F=Math.abs(F)<=1e-4?0:1/F;let D=(Y*R-T*I)*F-l,B=(T*C-Y*E)*F-h,et=Math.sqrt(D*D+B*B),rt=e.data.length*x,st,ht;if(et<1e-4){this.apply1(t,i,s,!1,c,!1,o),e.updateWorldTransformWith(w,b,0,e.ascaleX,e.ascaleY,e.ashearX,e.ashearY);return}Y=i-k.worldX,T=s-k.worldY;let nt=(Y*R-T*I)*F-l,it=(T*C-Y*E)*F-h,dt=nt*nt+it*it;if(r!=0){r*=d*(x+1)*.5;let gt=Math.sqrt(dt),At=gt-et-rt*d+r;if(At>0){let Ct=Math.min(1,At/(r*2))-1;Ct=(At-r*(1-Ct*Ct))/gt,nt-=Ct*nt,it-=Ct*it,dt=nt*nt+it*it}}t:if(L){rt*=d;let gt=(dt-et*et-rt*rt)/(2*et*rt);gt<-1?(gt=-1,ht=Math.PI*n):gt>1?(gt=1,ht=0,c&&(C=(Math.sqrt(dt)/(et+rt)-1)*o+1,u*=C,a&&(m*=C))):ht=Math.acos(gt)*n,C=et+rt*gt,I=rt*Math.sin(ht),st=Math.atan2(it*C-nt*I,nt*C+it*I)}else{C=d*rt,I=f*rt;let gt=C*C,At=I*I,Ct=Math.atan2(it,nt);E=At*et*et+gt*dt-gt*At;let Vt=-2*At*et,te=At-gt;if(R=Vt*Vt-4*te*E,R>=0){let ee=Math.sqrt(R);Vt<0&&(ee=-ee),ee=-(Vt+ee)*.5;let Ss=ee/te,Ts=E/ee,ie=Math.abs(Ss)<Math.abs(Ts)?Ss:Ts;if(ie*ie<=dt){T=Math.sqrt(dt-ie*ie)*n,st=Ct-Math.atan2(T,ie),ht=Math.atan2(T/f,(ie-et)/d);break t}}let ce=X.PI,Be=et-C,Pi=Be*Be,ys=0,As=0,De=et+C,Bi=De*De,Cs=0;E=-C*et/(gt-At),E>=-1&&E<=1&&(E=Math.acos(E),Y=C*Math.cos(E)+et,T=I*Math.sin(E),R=Y*Y+T*T,R<Pi&&(ce=E,Pi=R,Be=Y,ys=T),R>Bi&&(As=E,Bi=R,De=Y,Cs=T)),dt<=(Pi+Bi)*.5?(st=Ct-Math.atan2(ys*n,Be),ht=ce*n):(st=Ct-Math.atan2(Cs*n,De),ht=As*n)}let wt=Math.atan2(b,w)*g,kt=t.arotation;st=(st-wt)*X.radDeg+p-kt,st>180?st-=360:st<-180&&(st+=360),t.updateWorldTransformWith(l,h,kt+st*o,u,m,0,0),kt=e.arotation,ht=((ht+wt)*X.radDeg-e.ashearX)*g+v-kt,ht>180?ht-=360:ht<-180&&(ht+=360),e.updateWorldTransformWith(w,b,kt+ht*o,e.ascaleX,e.ascaleY,e.ashearX,e.ashearY)}},vi=class extends ve{constructor(t){super(t,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(t){this._target=t}get target(){if(this._target)return this._target;throw new Error("BoneData not set.")}},yi=class extends ve{constructor(t){super(t,0,!1),this.bones=new Array,this._target=null,this.positionMode=ye.Fixed,this.spacingMode=Ae.Fixed,this.rotateMode=Ce.Chain,this.offsetRotation=0,this.position=0,this.spacing=0,this.mixRotate=0,this.mixX=0,this.mixY=0}set target(t){this._target=t}get target(){if(this._target)return this._target;throw new Error("SlotData not set.")}},ye=(t=>(t[t.Fixed=0]="Fixed",t[t.Percent=1]="Percent",t))(ye||{}),Ae=(t=>(t[t.Length=0]="Length",t[t.Fixed=1]="Fixed",t[t.Percent=2]="Percent",t[t.Proportional=3]="Proportional",t))(Ae||{}),Ce=(t=>(t[t.Tangent=0]="Tangent",t[t.Chain=1]="Chain",t[t.ChainScale=2]="ChainScale",t))(Ce||{}),Xt=class{constructor(t,e){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,!t)throw new Error("data cannot be null.");if(!e)throw new Error("skeleton cannot be null.");this.data=t,this.bones=new Array;for(let s=0,n=t.bones.length;s<n;s++){let c=e.findBone(t.bones[s].name);if(!c)throw new Error(`Couldn't find bone ${t.bones[s].name}.`);this.bones.push(c)}let i=e.findSlot(t.target.name);if(!i)throw new Error(`Couldn't find target bone ${t.target.name}`);this.target=i,this.position=t.position,this.spacing=t.spacing,this.mixRotate=t.mixRotate,this.mixX=t.mixX,this.mixY=t.mixY}isActive(){return this.active}update(){let t=this.target.getAttachment();if(!(t instanceof _t))return;let e=this.mixRotate,i=this.mixX,s=this.mixY;if(e==0&&i==0&&s==0)return;let n=this.data,c=n.rotateMode==0,a=n.rotateMode==2,r=this.bones,o=r.length,l=c?o:o+1,h=P.setArraySize(this.spaces,l),d=a?this.lengths=P.setArraySize(this.lengths,o):[],f=this.spacing;switch(n.spacingMode){case 2:if(a)for(let b=0,y=l-1;b<y;b++){let A=r[b],C=A.data.length;if(C<Xt.epsilon)d[b]=0;else{let I=C*A.a,E=C*A.c;d[b]=Math.sqrt(I*I+E*E)}}P.arrayFill(h,1,l,f);break;case 3:let g=0;for(let b=0,y=l-1;b<y;){let A=r[b],C=A.data.length;if(C<Xt.epsilon)a&&(d[b]=0),h[++b]=f;else{let I=C*A.a,E=C*A.c,R=Math.sqrt(I*I+E*E);a&&(d[b]=R),h[++b]=R,g+=R}}if(g>0){g=l/g*f;for(let b=1;b<l;b++)h[b]*=g}break;default:let w=n.spacingMode==0;for(let b=0,y=l-1;b<y;){let A=r[b],C=A.data.length;if(C<Xt.epsilon)a&&(d[b]=0),h[++b]=f;else{let I=C*A.a,E=C*A.c,R=Math.sqrt(I*I+E*E);a&&(d[b]=R),h[++b]=(w?C+f:f)*R/C}}}let u=this.computeWorldPositions(t,l,c),m=u[0],x=u[1],p=n.offsetRotation,v=!1;if(p==0)v=n.rotateMode==1;else{v=!1;let g=this.target.bone;p*=g.a*g.d-g.b*g.c>0?X.degRad:-X.degRad}for(let g=0,w=3;g<o;g++,w+=3){let b=r[g];b.worldX+=(m-b.worldX)*i,b.worldY+=(x-b.worldY)*s;let y=u[w],A=u[w+1],C=y-m,I=A-x;if(a){let E=d[g];if(E!=0){let R=(Math.sqrt(C*C+I*I)/E-1)*e+1;b.a*=R,b.c*=R}}if(m=y,x=A,e>0){let E=b.a,R=b.b,L=b.c,k=b.d,F=0,Y=0,T=0;if(c?F=u[w-1]:h[g+1]==0?F=u[w+2]:F=Math.atan2(I,C),F-=Math.atan2(L,E),v){Y=Math.cos(F),T=Math.sin(F);let D=b.data.length;m+=(D*(Y*E-T*L)-C)*e,x+=(D*(T*E+Y*L)-I)*e}else F+=p;F>X.PI?F-=X.PI2:F<-X.PI&&(F+=X.PI2),F*=e,Y=Math.cos(F),T=Math.sin(F),b.a=Y*E-T*L,b.b=Y*R-T*k,b.c=T*E+Y*L,b.d=T*R+Y*k}b.updateAppliedTransform()}}computeWorldPositions(t,e,i){let s=this.target,n=this.position,c=this.spaces,a=P.setArraySize(this.positions,e*3+2),r=this.world,o=t.closed,l=t.worldVerticesLength,h=l/6,d=Xt.NONE;if(!t.constantSpeed){let B=t.lengths;h-=o?1:2;let et=B[h];this.data.positionMode==1&&(n*=et);let rt;switch(this.data.spacingMode){case 2:rt=et;break;case 3:rt=et/e;break;default:rt=1}r=P.setArraySize(this.world,8);for(let st=0,ht=0,nt=0;st<e;st++,ht+=3){let it=c[st]*rt;n+=it;let dt=n;if(o)dt%=et,dt<0&&(dt+=et),nt=0;else if(dt<0){d!=Xt.BEFORE&&(d=Xt.BEFORE,t.computeWorldVertices(s,2,4,r,0,2)),this.addBeforePosition(dt,r,0,a,ht);continue}else if(dt>et){d!=Xt.AFTER&&(d=Xt.AFTER,t.computeWorldVertices(s,l-6,4,r,0,2)),this.addAfterPosition(dt-et,r,0,a,ht);continue}for(;;nt++){let wt=B[nt];if(!(dt>wt)){if(nt==0)dt/=wt;else{let kt=B[nt-1];dt=(dt-kt)/(wt-kt)}break}}nt!=d&&(d=nt,o&&nt==h?(t.computeWorldVertices(s,l-4,4,r,0,2),t.computeWorldVertices(s,0,4,r,4,2)):t.computeWorldVertices(s,nt*6+2,8,r,0,2)),this.addCurvePosition(dt,r[0],r[1],r[2],r[3],r[4],r[5],r[6],r[7],a,ht,i||st>0&&it==0)}return a}o?(l+=2,r=P.setArraySize(this.world,l),t.computeWorldVertices(s,2,l-4,r,0,2),t.computeWorldVertices(s,0,2,r,l-4,2),r[l-2]=r[0],r[l-1]=r[1]):(h--,l-=4,r=P.setArraySize(this.world,l),t.computeWorldVertices(s,2,l,r,0,2));let f=P.setArraySize(this.curves,h),u=0,m=r[0],x=r[1],p=0,v=0,g=0,w=0,b=0,y=0,A=0,C=0,I=0,E=0,R=0,L=0,k=0,F=0;for(let B=0,et=2;B<h;B++,et+=6)p=r[et],v=r[et+1],g=r[et+2],w=r[et+3],b=r[et+4],y=r[et+5],A=(m-p*2+g)*.1875,C=(x-v*2+w)*.1875,I=((p-g)*3-m+b)*.09375,E=((v-w)*3-x+y)*.09375,R=A*2+I,L=C*2+E,k=(p-m)*.75+A+I*.16666667,F=(v-x)*.75+C+E*.16666667,u+=Math.sqrt(k*k+F*F),k+=R,F+=L,R+=I,L+=E,u+=Math.sqrt(k*k+F*F),k+=R,F+=L,u+=Math.sqrt(k*k+F*F),k+=R+I,F+=L+E,u+=Math.sqrt(k*k+F*F),f[B]=u,m=b,x=y;this.data.positionMode==1&&(n*=u);let Y;switch(this.data.spacingMode){case 2:Y=u;break;case 3:Y=u/e;break;default:Y=1}let T=this.segments,D=0;for(let B=0,et=0,rt=0,st=0;B<e;B++,et+=3){let ht=c[B]*Y;n+=ht;let nt=n;if(o)nt%=u,nt<0&&(nt+=u),rt=0;else if(nt<0){this.addBeforePosition(nt,r,0,a,et);continue}else if(nt>u){this.addAfterPosition(nt-u,r,l-4,a,et);continue}for(;;rt++){let it=f[rt];if(!(nt>it)){if(rt==0)nt/=it;else{let dt=f[rt-1];nt=(nt-dt)/(it-dt)}break}}if(rt!=d){d=rt;let it=rt*6;for(m=r[it],x=r[it+1],p=r[it+2],v=r[it+3],g=r[it+4],w=r[it+5],b=r[it+6],y=r[it+7],A=(m-p*2+g)*.03,C=(x-v*2+w)*.03,I=((p-g)*3-m+b)*.006,E=((v-w)*3-x+y)*.006,R=A*2+I,L=C*2+E,k=(p-m)*.3+A+I*.16666667,F=(v-x)*.3+C+E*.16666667,D=Math.sqrt(k*k+F*F),T[0]=D,it=1;it<8;it++)k+=R,F+=L,R+=I,L+=E,D+=Math.sqrt(k*k+F*F),T[it]=D;k+=R,F+=L,D+=Math.sqrt(k*k+F*F),T[8]=D,k+=R+I,F+=L+E,D+=Math.sqrt(k*k+F*F),T[9]=D,st=0}for(nt*=D;;st++){let it=T[st];if(!(nt>it)){if(st==0)nt/=it;else{let dt=T[st-1];nt=st+(nt-dt)/(it-dt)}break}}this.addCurvePosition(nt*.1,m,x,p,v,g,w,b,y,a,et,i||B>0&&ht==0)}return a}addBeforePosition(t,e,i,s,n){let c=e[i],a=e[i+1],r=e[i+2]-c,o=e[i+3]-a,l=Math.atan2(o,r);s[n]=c+t*Math.cos(l),s[n+1]=a+t*Math.sin(l),s[n+2]=l}addAfterPosition(t,e,i,s,n){let c=e[i+2],a=e[i+3],r=c-e[i],o=a-e[i+1],l=Math.atan2(o,r);s[n]=c+t*Math.cos(l),s[n+1]=a+t*Math.sin(l),s[n+2]=l}addCurvePosition(t,e,i,s,n,c,a,r,o,l,h,d){if(t==0||isNaN(t)){l[h]=e,l[h+1]=i,l[h+2]=Math.atan2(n-i,s-e);return}let f=t*t,u=f*t,m=1-t,x=m*m,p=x*m,v=m*t,g=v*3,w=m*g,b=g*t,y=e*p+s*w+c*b+r*u,A=i*p+n*w+a*b+o*u;l[h]=y,l[h+1]=A,d&&(t<.001?l[h+2]=Math.atan2(n-i,s-e):l[h+2]=Math.atan2(A-(i*x+n*v*2+a*f),y-(e*x+s*v*2+c*f)))}},Zt=Xt;Zt.NONE=-1,Zt.BEFORE=-2,Zt.AFTER=-3,Zt.epsilon=1e-5;var ns=class{constructor(t,e){if(this.darkColor=null,this.attachment=null,this.attachmentState=0,this.sequenceIndex=-1,this.deform=new Array,!t)throw new Error("data cannot be null.");if(!e)throw new Error("bone cannot be null.");this.data=t,this.bone=e,this.color=new O,this.darkColor=t.darkColor?new O:null,this.setToSetupPose()}getSkeleton(){return this.bone.skeleton}getAttachment(){return this.attachment}setAttachment(t){this.attachment!=t&&((!(t instanceof St)||!(this.attachment instanceof St)||t.timelineAttachment!=this.attachment.timelineAttachment)&&(this.deform.length=0),this.attachment=t,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}},as=class{constructor(t,e){if(this.mixRotate=0,this.mixX=0,this.mixY=0,this.mixScaleX=0,this.mixScaleY=0,this.mixShearY=0,this.temp=new Ut,this.active=!1,!t)throw new Error("data cannot be null.");if(!e)throw new Error("skeleton cannot be null.");this.data=t,this.mixRotate=t.mixRotate,this.mixX=t.mixX,this.mixY=t.mixY,this.mixScaleX=t.mixScaleX,this.mixScaleY=t.mixScaleY,this.mixShearY=t.mixShearY,this.bones=new Array;for(let s=0;s<t.bones.length;s++){let n=e.findBone(t.bones[s].name);if(!n)throw new Error(`Couldn't find bone ${t.bones[s].name}.`);this.bones.push(n)}let i=e.findBone(t.target.name);if(!i)throw new Error(`Couldn't find target bone ${t.target.name}.`);this.target=i}isActive(){return this.active}update(){this.mixRotate==0&&this.mixX==0&&this.mixY==0&&this.mixScaleX==0&&this.mixScaleY==0&&this.mixShearY==0||(this.data.local?this.data.relative?this.applyRelativeLocal():this.applyAbsoluteLocal():this.data.relative?this.applyRelativeWorld():this.applyAbsoluteWorld())}applyAbsoluteWorld(){let t=this.mixRotate,e=this.mixX,i=this.mixY,s=this.mixScaleX,n=this.mixScaleY,c=this.mixShearY,a=e!=0||i!=0,r=this.target,o=r.a,l=r.b,h=r.c,d=r.d,f=o*d-l*h>0?X.degRad:-X.degRad,u=this.data.offsetRotation*f,m=this.data.offsetShearY*f,x=this.bones;for(let p=0,v=x.length;p<v;p++){let g=x[p];if(t!=0){let w=g.a,b=g.b,y=g.c,A=g.d,C=Math.atan2(h,o)-Math.atan2(y,w)+u;C>X.PI?C-=X.PI2:C<-X.PI&&(C+=X.PI2),C*=t;let I=Math.cos(C),E=Math.sin(C);g.a=I*w-E*y,g.b=I*b-E*A,g.c=E*w+I*y,g.d=E*b+I*A}if(a){let w=this.temp;r.localToWorld(w.set(this.data.offsetX,this.data.offsetY)),g.worldX+=(w.x-g.worldX)*e,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+d*d)-w+this.data.offsetScaleY)*n)/w),g.b*=w,g.d*=w}if(c>0){let w=g.b,b=g.d,y=Math.atan2(b,w),A=Math.atan2(d,l)-Math.atan2(h,o)-(y-Math.atan2(g.c,g.a));A>X.PI?A-=X.PI2:A<-X.PI&&(A+=X.PI2),A=y+(A+m)*c;let C=Math.sqrt(w*w+b*b);g.b=Math.cos(A)*C,g.d=Math.sin(A)*C}g.updateAppliedTransform()}}applyRelativeWorld(){let t=this.mixRotate,e=this.mixX,i=this.mixY,s=this.mixScaleX,n=this.mixScaleY,c=this.mixShearY,a=e!=0||i!=0,r=this.target,o=r.a,l=r.b,h=r.c,d=r.d,f=o*d-l*h>0?X.degRad:-X.degRad,u=this.data.offsetRotation*f,m=this.data.offsetShearY*f,x=this.bones;for(let p=0,v=x.length;p<v;p++){let g=x[p];if(t!=0){let w=g.a,b=g.b,y=g.c,A=g.d,C=Math.atan2(h,o)+u;C>X.PI?C-=X.PI2:C<-X.PI&&(C+=X.PI2),C*=t;let I=Math.cos(C),E=Math.sin(C);g.a=I*w-E*y,g.b=I*b-E*A,g.c=E*w+I*y,g.d=E*b+I*A}if(a){let w=this.temp;r.localToWorld(w.set(this.data.offsetX,this.data.offsetY)),g.worldX+=w.x*e,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+d*d)-1+this.data.offsetScaleY)*n+1;g.b*=w,g.d*=w}if(c>0){let w=Math.atan2(d,l)-Math.atan2(h,o);w>X.PI?w-=X.PI2:w<-X.PI&&(w+=X.PI2);let b=g.b,y=g.d;w=Math.atan2(y,b)+(w-X.PI/2+m)*c;let A=Math.sqrt(b*b+y*y);g.b=Math.cos(w)*A,g.d=Math.sin(w)*A}g.updateAppliedTransform()}}applyAbsoluteLocal(){let t=this.mixRotate,e=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],d=h.arotation;if(t!=0){let v=a.arotation-d+this.data.offsetRotation;v-=(16384-(16384.499999999996-v/360|0))*360,d+=v*t}let f=h.ax,u=h.ay;f+=(a.ax-f+this.data.offsetX)*e,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 p=h.ashearY;if(c!=0){let v=a.ashearY-p+this.data.offsetShearY;v-=(16384-(16384.499999999996-v/360|0))*360,p+=v*c}h.updateWorldTransformWith(f,u,d,m,x,h.ashearX,p)}}applyRelativeLocal(){let t=this.mixRotate,e=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],d=h.arotation+(a.arotation+this.data.offsetRotation)*t,f=h.ax+(a.ax+this.data.offsetX)*e,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),p=h.ashearY+(a.ashearY+this.data.offsetShearY)*c;h.updateWorldTransformWith(f,u,d,m,x,h.ashearX,p)}}},ls=class{constructor(t){if(this._updateCache=new Array,this.skin=null,this.scaleX=1,this._scaleY=1,this.x=0,this.y=0,!t)throw new Error("data cannot be null.");this.data=t,this.bones=new Array;for(let e=0;e<t.bones.length;e++){let i=t.bones[e],s;if(!i.parent)s=new xi(i,this,null);else{let n=this.bones[i.parent.index];s=new xi(i,this,n),n.children.push(s)}this.bones.push(s)}this.slots=new Array,this.drawOrder=new Array;for(let e=0;e<t.slots.length;e++){let i=t.slots[e],s=this.bones[i.boneData.index],n=new ns(i,s);this.slots.push(n),this.drawOrder.push(n)}this.ikConstraints=new Array;for(let e=0;e<t.ikConstraints.length;e++){let i=t.ikConstraints[e];this.ikConstraints.push(new rs(i,this))}this.transformConstraints=new Array;for(let e=0;e<t.transformConstraints.length;e++){let i=t.transformConstraints[e];this.transformConstraints.push(new as(i,this))}this.pathConstraints=new Array;for(let e=0;e<t.pathConstraints.length;e++){let i=t.pathConstraints[e];this.pathConstraints.push(new Zt(i,this))}this.color=new O(1,1,1,1),this.updateCache()}get scaleY(){return ls.yDown?-this._scaleY:this._scaleY}set scaleY(t){this._scaleY=t}updateCache(){let t=this._updateCache;t.length=0;let e=this.bones;for(let l=0,h=e.length;l<h;l++){let d=e[l];d.sorted=d.data.skinRequired,d.active=!d.sorted}if(this.skin){let l=this.skin.bones;for(let h=0,d=this.skin.bones.length;h<d;h++){let f=this.bones[l[h].index];do f.sorted=!1,f.active=!0,f=f.parent;while(f)}}let i=this.ikConstraints,s=this.transformConstraints,n=this.pathConstraints,c=i.length,a=s.length,r=n.length,o=c+a+r;t:for(let l=0;l<o;l++){for(let h=0;h<c;h++){let d=i[h];if(d.data.order==l){this.sortIkConstraint(d);continue t}}for(let h=0;h<a;h++){let d=s[h];if(d.data.order==l){this.sortTransformConstraint(d);continue t}}for(let h=0;h<r;h++){let d=n[h];if(d.data.order==l){this.sortPathConstraint(d);continue t}}}for(let l=0,h=e.length;l<h;l++)this.sortBone(e[l])}sortIkConstraint(t){if(t.active=t.target.isActive()&&(!t.data.skinRequired||this.skin&&P.contains(this.skin.constraints,t.data,!0)),!t.active)return;let e=t.target;this.sortBone(e);let i=t.bones,s=i[0];if(this.sortBone(s),i.length==1)this._updateCache.push(t),this.sortReset(s.children);else{let n=i[i.length-1];this.sortBone(n),this._updateCache.push(t),this.sortReset(s.children),n.sorted=!0}}sortPathConstraint(t){if(t.active=t.target.bone.isActive()&&(!t.data.skinRequired||this.skin&&P.contains(this.skin.constraints,t.data,!0)),!t.active)return;let e=t.target,i=e.data.index,s=e.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=e.getAttachment();n instanceof _t&&this.sortPathConstraintAttachmentWith(n,s);let c=t.bones,a=c.length;for(let r=0;r<a;r++)this.sortBone(c[r]);this._updateCache.push(t);for(let r=0;r<a;r++)this.sortReset(c[r].children);for(let r=0;r<a;r++)c[r].sorted=!0}sortTransformConstraint(t){if(t.active=t.target.isActive()&&(!t.data.skinRequired||this.skin&&P.contains(this.skin.constraints,t.data,!0)),!t.active)return;this.sortBone(t.target);let e=t.bones,i=e.length;if(t.data.local)for(let s=0;s<i;s++){let n=e[s];this.sortBone(n.parent),this.sortBone(n)}else for(let s=0;s<i;s++)this.sortBone(e[s]);this._updateCache.push(t);for(let s=0;s<i;s++)this.sortReset(e[s].children);for(let s=0;s<i;s++)e[s].sorted=!0}sortPathConstraintAttachment(t,e,i){let s=t.attachments[e];if(s)for(let n in s)this.sortPathConstraintAttachmentWith(s[n],i)}sortPathConstraintAttachmentWith(t,e){if(!(t instanceof _t))return;let i=t.bones;if(!i)this.sortBone(e);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(t){if(!t||t.sorted)return;let e=t.parent;e&&this.sortBone(e),t.sorted=!0,this._updateCache.push(t)}sortReset(t){for(let e=0,i=t.length;e<i;e++){let s=t[e];s.active&&(s.sorted&&this.sortReset(s.children),s.sorted=!1)}}updateWorldTransform(){let t=this.bones;for(let i=0,s=t.length;i<s;i++){let n=t[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 e=this._updateCache;for(let i=0,s=e.length;i<s;i++)e[i].update()}updateWorldTransformWith(t){let e=this.getRootBone();if(!e)throw new Error("Root bone must not be null.");let i=t.a,s=t.b,n=t.c,c=t.d;e.worldX=i*this.x+s*this.y+t.worldX,e.worldY=n*this.x+c*this.y+t.worldY;let a=e.rotation+90+e.shearY,r=X.cosDeg(e.rotation+e.shearX)*e.scaleX,o=X.cosDeg(a)*e.scaleY,l=X.sinDeg(e.rotation+e.shearX)*e.scaleX,h=X.sinDeg(a)*e.scaleY;e.a=(i*r+s*l)*this.scaleX,e.b=(i*o+s*h)*this.scaleX,e.c=(n*r+c*l)*this.scaleY,e.d=(n*o+c*h)*this.scaleY;let d=this._updateCache;for(let f=0,u=d.length;f<u;f++){let m=d[f];m!=e&&m.update()}}setToSetupPose(){this.setBonesToSetupPose(),this.setSlotsToSetupPose()}setBonesToSetupPose(){let t=this.bones;for(let n=0,c=t.length;n<c;n++)t[n].setToSetupPose();let e=this.ikConstraints;for(let n=0,c=e.length;n<c;n++){let a=e[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 t=this.slots;P.arrayCopy(t,0,this.drawOrder,0,t.length);for(let e=0,i=t.length;e<i;e++)t[e].setToSetupPose()}getRootBone(){return this.bones.length==0?null:this.bones[0]}findBone(t){if(!t)throw new Error("boneName cannot be null.");let e=this.bones;for(let i=0,s=e.length;i<s;i++){let n=e[i];if(n.data.name==t)return n}return null}findSlot(t){if(!t)throw new Error("slotName cannot be null.");let e=this.slots;for(let i=0,s=e.length;i<s;i++){let n=e[i];if(n.data.name==t)return n}return null}setSkinByName(t){let e=this.data.findSkin(t);if(!e)throw new Error("Skin not found: "+t);this.setSkin(e)}setSkin(t){if(t!=this.skin){if(t)if(this.skin)t.attachAll(this,this.skin);else{let e=this.slots;for(let i=0,s=e.length;i<s;i++){let n=e[i],c=n.data.attachmentName;if(c){let a=t.getAttachment(i,c);a&&n.setAttachment(a)}}}this.skin=t,this.updateCache()}}getAttachmentByName(t,e){let i=this.data.findSlot(t);if(!i)throw new Error(`Can't find slot with name ${t}`);return this.getAttachment(i.index,e)}getAttachment(t,e){if(!e)throw new Error("attachmentName cannot be null.");if(this.skin){let i=this.skin.getAttachment(t,e);if(i)return i}return this.data.defaultSkin?this.data.defaultSkin.getAttachment(t,e):null}setAttachment(t,e){if(!t)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==t){let a=null;if(e&&(a=this.getAttachment(s,e),!a))throw new Error("Attachment not found: "+e+", for slot: "+t);c.setAttachment(a);return}}throw new Error("Slot not found: "+t)}findIkConstraint(t){if(!t)throw new Error("constraintName cannot be null.");let e=this.ikConstraints;for(let i=0,s=e.length;i<s;i++){let n=e[i];if(n.data.name==t)return n}return null}findTransformConstraint(t){if(!t)throw new Error("constraintName cannot be null.");let e=this.transformConstraints;for(let i=0,s=e.length;i<s;i++){let n=e[i];if(n.data.name==t)return n}return null}findPathConstraint(t){if(!t)throw new Error("constraintName cannot be null.");let e=this.pathConstraints;for(let i=0,s=e.length;i<s;i++){let n=e[i];if(n.data.name==t)return n}return null}getBoundsRect(){let t=new Ut,e=new Ut;return this.getBounds(t,e),{x:t.x,y:t.y,width:e.x,height:e.y}}getBounds(t,e,i=new Array(2)){if(!t)throw new Error("offset cannot be null.");if(!e)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 d=0,f=null,u=h.getAttachment();if(u instanceof at)d=8,f=P.setArraySize(i,d,0),u.computeWorldVertices(h,f,0,2);else if(u instanceof Dt){let m=u;d=m.worldVerticesLength,f=P.setArraySize(i,d,0),m.computeWorldVertices(h,0,d,f,0,2)}if(f)for(let m=0,x=f.length;m<x;m+=2){let p=f[m],v=f[m+1];n=Math.min(n,p),c=Math.min(c,v),a=Math.max(a,p),r=Math.max(r,v)}}t.set(n,c),e.set(a-n,r-c)}},os=ls;os.yDown=!1;var Ai=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(t){if(!t)throw new Error("boneName cannot be null.");let e=this.bones;for(let i=0,s=e.length;i<s;i++){let n=e[i];if(n.name==t)return n}return null}findSlot(t){if(!t)throw new Error("slotName cannot be null.");let e=this.slots;for(let i=0,s=e.length;i<s;i++){let n=e[i];if(n.name==t)return n}return null}findSkin(t){if(!t)throw new Error("skinName cannot be null.");let e=this.skins;for(let i=0,s=e.length;i<s;i++){let n=e[i];if(n.name==t)return n}return null}findEvent(t){if(!t)throw new Error("eventDataName cannot be null.");let e=this.events;for(let i=0,s=e.length;i<s;i++){let n=e[i];if(n.name==t)return n}return null}findAnimation(t){if(!t)throw new Error("animationName cannot be null.");let e=this.animations;for(let i=0,s=e.length;i<s;i++){let n=e[i];if(n.name==t)return n}return null}findIkConstraint(t){if(!t)throw new Error("constraintName cannot be null.");let e=this.ikConstraints;for(let i=0,s=e.length;i<s;i++){let n=e[i];if(n.name==t)return n}return null}findTransformConstraint(t){if(!t)throw new Error("constraintName cannot be null.");let e=this.transformConstraints;for(let i=0,s=e.length;i<s;i++){let n=e[i];if(n.name==t)return n}return null}findPathConstraint(t){if(!t)throw new Error("constraintName cannot be null.");let e=this.pathConstraints;for(let i=0,s=e.length;i<s;i++){let n=e[i];if(n.name==t)return n}return null}},Ci=class{constructor(t=0,e,i){this.slotIndex=t,this.name=e,this.attachment=i}},Se=class{constructor(t){if(this.attachments=new Array,this.bones=Array(),this.constraints=new Array,!t)throw new Error("name cannot be null.");this.name=t}setAttachment(t,e,i){if(!i)throw new Error("attachment cannot be null.");let s=this.attachments;t>=s.length&&(s.length=t+1),s[t]||(s[t]={}),s[t][e]=i}addSkin(t){for(let s=0;s<t.bones.length;s++){let n=t.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<t.constraints.length;s++){let n=t.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 e=t.getAttachments();for(let s=0;s<e.length;s++){var i=e[s];this.setAttachment(i.slotIndex,i.name,i.attachment)}}copySkin(t){for(let s=0;s<t.bones.length;s++){let n=t.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<t.constraints.length;s++){let n=t.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 e=t.getAttachments();for(let s=0;s<e.length;s++){var i=e[s];i.attachment&&(i.attachment instanceof Dt?(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(t,e){let i=this.attachments[t];return i?i[e]:null}removeAttachment(t,e){let i=this.attachments[t];i&&delete i[e]}getAttachments(){let t=new Array;for(var e=0;e<this.attachments.length;e++){let i=this.attachments[e];if(i)for(let s in i){let n=i[s];n&&t.push(new Ci(e,s,n))}}return t}getAttachmentsForSlot(t,e){let i=this.attachments[t];if(i)for(let s in i){let n=i[s];n&&e.push(new Ci(t,s,n))}}clear(){this.attachments.length=0,this.bones.length=0,this.constraints.length=0}attachAll(t,e){let i=0;for(let s=0;s<t.slots.length;s++){let n=t.slots[s],c=n.getAttachment();if(c&&i<e.attachments.length){let a=e.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++}}},Si=class{constructor(t,e,i){if(this.index=0,this.color=new O(1,1,1,1),this.darkColor=null,this.attachmentName=null,this.blendMode=Te.Normal,t<0)throw new Error("index must be >= 0.");if(!e)throw new Error("name cannot be null.");if(!i)throw new Error("boneData cannot be null.");this.index=t,this.name=e,this.boneData=i}},Te=(t=>(t[t.Normal=0]="Normal",t[t.Additive=1]="Additive",t[t.Multiply=2]="Multiply",t[t.Screen=3]="Screen",t))(Te||{}),Ti=class extends ve{constructor(t){super(t,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(t){this._target=t}get target(){if(this._target)return this._target;throw new Error("BoneData not set.")}},Us=class{constructor(t){this.scale=1,this.linkedMeshes=new Array,this.attachmentLoader=t}readSkeletonData(t){let e=this.scale,i=new Ai;i.name="";let s=new hs(t),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 d=l==0?null:i.bones[s.readInt(!0)],f=new gi(l,h,d);f.rotation=s.readFloat(),f.x=s.readFloat()*e,f.y=s.readFloat()*e,f.scaleX=s.readFloat(),f.scaleY=s.readFloat(),f.shearX=s.readFloat(),f.shearY=s.readFloat(),f.length=s.readFloat()*e,f.transformMode=s.readInt(!0),f.skinRequired=s.readBoolean(),a&&O.rgba8888ToColor(f.color,s.readInt32()),i.bones.push(f)}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 d=i.bones[s.readInt(!0)],f=new Si(l,h,d);O.rgba8888ToColor(f.color,s.readInt32());let u=s.readInt32();u!=-1&&O.rgb888ToColor(f.darkColor=new O,u),f.attachmentName=s.readStringRef(),f.blendMode=s.readInt(!0),i.slots.push(f)}r=s.readInt(!0);for(let l=0,h;l<r;l++){let d=s.readString();if(!d)throw new Error("IK constraint data name must not be null.");let f=new vi(d);f.order=s.readInt(!0),f.skinRequired=s.readBoolean(),h=s.readInt(!0);for(let u=0;u<h;u++)f.bones.push(i.bones[s.readInt(!0)]);f.target=i.bones[s.readInt(!0)],f.mix=s.readFloat(),f.softness=s.readFloat()*e,f.bendDirection=s.readByte(),f.compress=s.readBoolean(),f.stretch=s.readBoolean(),f.uniform=s.readBoolean(),i.ikConstraints.push(f)}r=s.readInt(!0);for(let l=0,h;l<r;l++){let d=s.readString();if(!d)throw new Error("Transform constraint data name must not be null.");let f=new Ti(d);f.order=s.readInt(!0),f.skinRequired=s.readBoolean(),h=s.readInt(!0);for(let u=0;u<h;u++)f.bones.push(i.bones[s.readInt(!0)]);f.target=i.bones[s.readInt(!0)],f.local=s.readBoolean(),f.relative=s.readBoolean(),f.offsetRotation=s.readFloat(),f.offsetX=s.readFloat()*e,f.offsetY=s.readFloat()*e,f.offsetScaleX=s.readFloat(),f.offsetScaleY=s.readFloat(),f.offsetShearY=s.readFloat(),f.mixRotate=s.readFloat(),f.mixX=s.readFloat(),f.mixY=s.readFloat(),f.mixScaleX=s.readFloat(),f.mixScaleY=s.readFloat(),f.mixShearY=s.readFloat(),i.transformConstraints.push(f)}r=s.readInt(!0);for(let l=0,h;l<r;l++){let d=s.readString();if(!d)throw new Error("Path constraint data name must not be null.");let f=new yi(d);f.order=s.readInt(!0),f.skinRequired=s.readBoolean(),h=s.readInt(!0);for(let u=0;u<h;u++)f.bones.push(i.bones[s.readInt(!0)]);f.target=i.slots[s.readInt(!0)],f.positionMode=s.readInt(!0),f.spacingMode=s.readInt(!0),f.rotateMode=s.readInt(!0),f.offsetRotation=s.readFloat(),f.position=s.readFloat(),f.positionMode==0&&(f.position*=e),f.spacing=s.readFloat(),(f.spacingMode==0||f.spacingMode==1)&&(f.spacing*=e),f.mixRotate=s.readFloat(),f.mixX=s.readFloat(),f.mixY=s.readFloat(),i.pathConstraints.push(f)}let o=this.readSkin(s,i,!0,a);o&&(i.defaultSkin=o,i.skins.push(o));{let l=i.skins.length;for(P.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],d=h.skin?i.findSkin(h.skin):i.defaultSkin;if(!d)throw new Error("Not skin found for linked mesh.");if(!h.parent)throw new Error("Linked mesh parent must not be null");let f=d.getAttachment(h.slotIndex,h.parent);if(!f)throw new Error(`Parent mesh not found: ${h.parent}`);h.mesh.timelineAttachment=h.inheritTimeline?f:h.mesh,h.mesh.setParentMesh(f),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 d=new pi(h);d.intValue=s.readInt(!1),d.floatValue=s.readFloat(),d.stringValue=s.readString(),d.audioPath=s.readString(),d.audioPath&&(d.volume=s.readFloat(),d.balance=s.readFloat()),i.events.push(d)}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(t,e,i,s){let n=null,c=0;if(i){if(c=t.readInt(!0),c==0)return null;n=new Se("default")}else{let a=t.readStringRef();if(!a)throw new Error("Skin name must not be null.");n=new Se(a),n.bones.length=t.readInt(!0);for(let r=0,o=n.bones.length;r<o;r++)n.bones[r]=e.bones[t.readInt(!0)];for(let r=0,o=t.readInt(!0);r<o;r++)n.constraints.push(e.ikConstraints[t.readInt(!0)]);for(let r=0,o=t.readInt(!0);r<o;r++)n.constraints.push(e.transformConstraints[t.readInt(!0)]);for(let r=0,o=t.readInt(!0);r<o;r++)n.constraints.push(e.pathConstraints[t.readInt(!0)]);c=t.readInt(!0)}for(let a=0;a<c;a++){let r=t.readInt(!0);for(let o=0,l=t.readInt(!0);o<l;o++){let h=t.readStringRef();if(!h)throw new Error("Attachment name must not be null");let d=this.readAttachment(t,e,n,r,h,s);d&&n.setAttachment(r,h,d)}}return n}readAttachment(t,e,i,s,n,c){let a=this.scale,r=t.readStringRef();switch(r||(r=n),t.readByte()){case Ot.Region:{let o=t.readStringRef(),l=t.readFloat(),h=t.readFloat(),d=t.readFloat(),f=t.readFloat(),u=t.readFloat(),m=t.readFloat(),x=t.readFloat(),p=t.readInt32(),v=this.readSequence(t);o||(o=r);let g=this.attachmentLoader.newRegionAttachment(i,r,o,v);return g?(g.path=o,g.x=h*a,g.y=d*a,g.scaleX=f,g.scaleY=u,g.rotation=l,g.width=m*a,g.height=x*a,O.rgba8888ToColor(g.color,p),g.sequence=v,v==null&&g.updateRegion(),g):null}case Ot.BoundingBox:{let o=t.readInt(!0),l=this.readVertices(t,o),h=c?t.readInt32():0,d=this.attachmentLoader.newBoundingBoxAttachment(i,r);return d?(d.worldVerticesLength=o<<1,d.vertices=l.vertices,d.bones=l.bones,c&&O.rgba8888ToColor(d.color,h),d):null}case Ot.Mesh:{let o=t.readStringRef(),l=t.readInt32(),h=t.readInt(!0),d=this.readFloatArray(t,h<<1,1),f=this.readShortArray(t),u=this.readVertices(t,h),m=t.readInt(!0),x=this.readSequence(t),p=[],v=0,g=0;c&&(p=this.readShortArray(t),v=t.readFloat(),g=t.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=f,w.regionUVs=d,x==null&&w.updateRegion(),w.hullLength=m<<1,w.sequence=x,c&&(w.edges=p,w.width=v*a,w.height=g*a),w):null}case Ot.LinkedMesh:{let o=t.readStringRef(),l=t.readInt32(),h=t.readStringRef(),d=t.readStringRef(),f=t.readBoolean(),u=this.readSequence(t),m=0,x=0;c&&(m=t.readFloat(),x=t.readFloat()),o||(o=r);let p=this.attachmentLoader.newMeshAttachment(i,r,o,u);return p?(p.path=o,O.rgba8888ToColor(p.color,l),p.sequence=u,c&&(p.width=m*a,p.height=x*a),this.linkedMeshes.push(new zs(p,h,s,d,f)),p):null}case Ot.Path:{let o=t.readBoolean(),l=t.readBoolean(),h=t.readInt(!0),d=this.readVertices(t,h),f=P.newArray(h/3,0);for(let x=0,p=f.length;x<p;x++)f[x]=t.readFloat()*a;let u=c?t.readInt32():0,m=this.attachmentLoader.newPathAttachment(i,r);return m?(m.closed=o,m.constantSpeed=l,m.worldVerticesLength=h<<1,m.vertices=d.vertices,m.bones=d.bones,m.lengths=f,c&&O.rgba8888ToColor(m.color,u),m):null}case Ot.Point:{let o=t.readFloat(),l=t.readFloat(),h=t.readFloat(),d=c?t.readInt32():0,f=this.attachmentLoader.newPointAttachment(i,r);return f?(f.x=l*a,f.y=h*a,f.rotation=o,c&&O.rgba8888ToColor(f.color,d),f):null}case Ot.Clipping:{let o=t.readInt(!0),l=t.readInt(!0),h=this.readVertices(t,l),d=c?t.readInt32():0,f=this.attachmentLoader.newClippingAttachment(i,r);return f?(f.endSlot=e.slots[o],f.worldVerticesLength=l<<1,f.vertices=h.vertices,f.bones=h.bones,c&&O.rgba8888ToColor(f.color,d),f):null}}return null}readSequence(t){if(!t.readBoolean())return null;let e=new ze(t.readInt(!0));return e.start=t.readInt(!0),e.digits=t.readInt(!0),e.setupIndex=t.readInt(!0),e}readVertices(t,e){let i=this.scale,s=e<<1,n=new Ws;if(!t.readBoolean())return n.vertices=this.readFloatArray(t,s,i),n;let c=new Array,a=new Array;for(let r=0;r<e;r++){let o=t.readInt(!0);a.push(o);for(let l=0;l<o;l++)a.push(t.readInt(!0)),c.push(t.readFloat()*i),c.push(t.readFloat()*i),c.push(t.readFloat())}return n.vertices=P.toFloatArray(c),n.bones=a,n}readFloatArray(t,e,i){let s=new Array(e);if(i==1)for(let n=0;n<e;n++)s[n]=t.readFloat();else for(let n=0;n<e;n++)s[n]=t.readFloat()*i;return s}readShortArray(t){let e=t.readInt(!0),i=new Array(e);for(let s=0;s<e;s++)i[s]=t.readShort();return i}readAnimation(t,e,i){t.readInt(!0);let s=new Array,n=this.scale,c=new O,a=new O;for(let h=0,d=t.readInt(!0);h<d;h++){let f=t.readInt(!0);for(let u=0,m=t.readInt(!0);u<m;u++){let x=t.readByte(),p=t.readInt(!0),v=p-1;switch(x){case tr:{let g=new zt(p,f);for(let w=0;w<p;w++)g.setFrame(w,t.readFloat(),t.readStringRef());s.push(g);break}case er:{let g=t.readInt(!0),w=new Qe(p,g,f),b=t.readFloat(),y=t.readUnsignedByte()/255,A=t.readUnsignedByte()/255,C=t.readUnsignedByte()/255,I=t.readUnsignedByte()/255;for(let E=0,R=0;w.setFrame(E,b,y,A,C,I),E!=v;E++){let L=t.readFloat(),k=t.readUnsignedByte()/255,F=t.readUnsignedByte()/255,Y=t.readUnsignedByte()/255,T=t.readUnsignedByte()/255;switch(t.readByte()){case Mt:w.setStepped(E);break;case Yt:lt(t,w,R++,E,0,b,L,y,k,1),lt(t,w,R++,E,1,b,L,A,F,1),lt(t,w,R++,E,2,b,L,C,Y,1),lt(t,w,R++,E,3,b,L,I,T,1)}b=L,y=k,A=F,C=Y,I=T}s.push(w);break}case ir:{let g=t.readInt(!0),w=new $e(p,g,f),b=t.readFloat(),y=t.readUnsignedByte()/255,A=t.readUnsignedByte()/255,C=t.readUnsignedByte()/255;for(let I=0,E=0;w.setFrame(I,b,y,A,C),I!=v;I++){let R=t.readFloat(),L=t.readUnsignedByte()/255,k=t.readUnsignedByte()/255,F=t.readUnsignedByte()/255;switch(t.readByte()){case Mt:w.setStepped(I);break;case Yt:lt(t,w,E++,I,0,b,R,y,L,1),lt(t,w,E++,I,1,b,R,A,k,1),lt(t,w,E++,I,2,b,R,C,F,1)}b=R,y=L,A=k,C=F}s.push(w);break}case sr:{let g=t.readInt(!0),w=new ei(p,g,f),b=t.readFloat(),y=t.readUnsignedByte()/255,A=t.readUnsignedByte()/255,C=t.readUnsignedByte()/255,I=t.readUnsignedByte()/255,E=t.readUnsignedByte()/255,R=t.readUnsignedByte()/255,L=t.readUnsignedByte()/255;for(let k=0,F=0;w.setFrame(k,b,y,A,C,I,E,R,L),k!=v;k++){let Y=t.readFloat(),T=t.readUnsignedByte()/255,D=t.readUnsignedByte()/255,B=t.readUnsignedByte()/255,et=t.readUnsignedByte()/255,rt=t.readUnsignedByte()/255,st=t.readUnsignedByte()/255,ht=t.readUnsignedByte()/255;switch(t.readByte()){case Mt:w.setStepped(k);break;case Yt:lt(t,w,F++,k,0,b,Y,y,T,1),lt(t,w,F++,k,1,b,Y,A,D,1),lt(t,w,F++,k,2,b,Y,C,B,1),lt(t,w,F++,k,3,b,Y,I,et,1),lt(t,w,F++,k,4,b,Y,E,rt,1),lt(t,w,F++,k,5,b,Y,R,st,1),lt(t,w,F++,k,6,b,Y,L,ht,1)}b=Y,y=T,A=D,C=B,I=et,E=rt,R=st,L=ht}s.push(w);break}case rr:{let g=t.readInt(!0),w=new ii(p,g,f),b=t.readFloat(),y=t.readUnsignedByte()/255,A=t.readUnsignedByte()/255,C=t.readUnsignedByte()/255,I=t.readUnsignedByte()/255,E=t.readUnsignedByte()/255,R=t.readUnsignedByte()/255;for(let L=0,k=0;w.setFrame(L,b,y,A,C,I,E,R),L!=v;L++){let F=t.readFloat(),Y=t.readUnsignedByte()/255,T=t.readUnsignedByte()/255,D=t.readUnsignedByte()/255,B=t.readUnsignedByte()/255,et=t.readUnsignedByte()/255,rt=t.readUnsignedByte()/255;switch(t.readByte()){case Mt:w.setStepped(L);break;case Yt:lt(t,w,k++,L,0,b,F,y,Y,1),lt(t,w,k++,L,1,b,F,A,T,1),lt(t,w,k++,L,2,b,F,C,D,1),lt(t,w,k++,L,3,b,F,I,B,1),lt(t,w,k++,L,4,b,F,E,et,1),lt(t,w,k++,L,5,b,F,R,rt,1)}b=F,y=Y,A=T,C=D,I=B,E=et,R=rt}s.push(w);break}case nr:{let g=new ti(p,t.readInt(!0),f),w=t.readFloat(),b=t.readUnsignedByte()/255;for(let y=0,A=0;g.setFrame(y,w,b),y!=v;y++){let C=t.readFloat(),I=t.readUnsignedByte()/255;switch(t.readByte()){case Mt:g.setStepped(y);break;case Yt:lt(t,g,A++,y,0,w,C,b,I,1)}w=C,b=I}s.push(g)}}}}for(let h=0,d=t.readInt(!0);h<d;h++){let f=t.readInt(!0);for(let u=0,m=t.readInt(!0);u<m;u++){let x=t.readByte(),p=t.readInt(!0),v=t.readInt(!0);switch(x){case _s:s.push(Lt(t,new re(p,v,f),1));break;case qs:s.push(Ii(t,new We(p,v,f),n));break;case Gs:s.push(Lt(t,new _e(p,v,f),n));break;case Hs:s.push(Lt(t,new qe(p,v,f),n));break;case js:s.push(Ii(t,new Ge(p,v,f),1));break;case Zs:s.push(Lt(t,new He(p,v,f),1));break;case Ks:s.push(Lt(t,new je(p,v,f),1));break;case Js:s.push(Ii(t,new Ze(p,v,f),1));break;case Qs:s.push(Lt(t,new Ke(p,v,f),1));break;case $s:s.push(Lt(t,new Je(p,v,f),1))}}}for(let h=0,d=t.readInt(!0);h<d;h++){let f=t.readInt(!0),u=t.readInt(!0),m=u-1,x=new ri(u,t.readInt(!0),f),p=t.readFloat(),v=t.readFloat(),g=t.readFloat()*n;for(let w=0,b=0;x.setFrame(w,p,v,g,t.readByte(),t.readBoolean(),t.readBoolean()),w!=m;w++){let y=t.readFloat(),A=t.readFloat(),C=t.readFloat()*n;switch(t.readByte()){case Mt:x.setStepped(w);break;case Yt:lt(t,x,b++,w,0,p,y,v,A,1),lt(t,x,b++,w,1,p,y,g,C,n)}p=y,v=A,g=C}s.push(x)}for(let h=0,d=t.readInt(!0);h<d;h++){let f=t.readInt(!0),u=t.readInt(!0),m=u-1,x=new ni(u,t.readInt(!0),f),p=t.readFloat(),v=t.readFloat(),g=t.readFloat(),w=t.readFloat(),b=t.readFloat(),y=t.readFloat(),A=t.readFloat();for(let C=0,I=0;x.setFrame(C,p,v,g,w,b,y,A),C!=m;C++){let E=t.readFloat(),R=t.readFloat(),L=t.readFloat(),k=t.readFloat(),F=t.readFloat(),Y=t.readFloat(),T=t.readFloat();switch(t.readByte()){case Mt:x.setStepped(C);break;case Yt:lt(t,x,I++,C,0,p,E,v,R,1),lt(t,x,I++,C,1,p,E,g,L,1),lt(t,x,I++,C,2,p,E,w,k,1),lt(t,x,I++,C,3,p,E,b,F,1),lt(t,x,I++,C,4,p,E,y,Y,1),lt(t,x,I++,C,5,p,E,A,T,1)}p=E,v=R,g=L,w=k,b=F,y=Y,A=T}s.push(x)}for(let h=0,d=t.readInt(!0);h<d;h++){let f=t.readInt(!0),u=i.pathConstraints[f];for(let m=0,x=t.readInt(!0);m<x;m++)switch(t.readByte()){case or:s.push(Lt(t,new ai(t.readInt(!0),t.readInt(!0),f),u.positionMode==0?n:1));break;case hr:s.push(Lt(t,new li(t.readInt(!0),t.readInt(!0),f),u.spacingMode==0||u.spacingMode==1?n:1));break;case cr:let p=new oi(t.readInt(!0),t.readInt(!0),f),v=t.readFloat(),g=t.readFloat(),w=t.readFloat(),b=t.readFloat();for(let y=0,A=0,C=p.getFrameCount()-1;p.setFrame(y,v,g,w,b),y!=C;y++){let I=t.readFloat(),E=t.readFloat(),R=t.readFloat(),L=t.readFloat();switch(t.readByte()){case Mt:p.setStepped(y);break;case Yt:lt(t,p,A++,y,0,v,I,g,E,1),lt(t,p,A++,y,1,v,I,w,R,1),lt(t,p,A++,y,2,v,I,b,L,1)}v=I,g=E,w=R,b=L}s.push(p)}}for(let h=0,d=t.readInt(!0);h<d;h++){let f=i.skins[t.readInt(!0)];for(let u=0,m=t.readInt(!0);u<m;u++){let x=t.readInt(!0);for(let p=0,v=t.readInt(!0);p<v;p++){let g=t.readStringRef();if(!g)throw new Error("attachmentName must not be null.");let w=f.getAttachment(x,g),b=t.readByte(),y=t.readInt(!0),A=y-1;switch(b){case ar:{let C=w,I=C.bones,E=C.vertices,R=I?E.length/3*2:E.length,L=t.readInt(!0),k=new si(y,L,x,C),F=t.readFloat();for(let Y=0,T=0;;Y++){let D,B=t.readInt(!0);if(B==0)D=I?P.newFloatArray(R):E;else{D=P.newFloatArray(R);let rt=t.readInt(!0);if(B+=rt,n==1)for(let st=rt;st<B;st++)D[st]=t.readFloat();else for(let st=rt;st<B;st++)D[st]=t.readFloat()*n;if(!I)for(let st=0,ht=D.length;st<ht;st++)D[st]+=E[st]}if(k.setFrame(Y,F,D),Y==A)break;let et=t.readFloat();switch(t.readByte()){case Mt:k.setStepped(Y);break;case Yt:lt(t,k,T++,Y,0,F,et,0,1,1)}F=et}s.push(k);break}case lr:{let C=new jt(y,x,w);for(let I=0;I<y;I++){let E=t.readFloat(),R=t.readInt32();C.setFrame(I,E,zi[R&15],R>>4,t.readFloat())}s.push(C);break}}}}}let r=t.readInt(!0);if(r>0){let h=new Wt(r),d=i.slots.length;for(let f=0;f<r;f++){let u=t.readFloat(),m=t.readInt(!0),x=P.newArray(d,0);for(let w=d-1;w>=0;w--)x[w]=-1;let p=P.newArray(d-m,0),v=0,g=0;for(let w=0;w<m;w++){let b=t.readInt(!0);for(;v!=b;)p[g++]=v++;x[v+t.readInt(!0)]=v++}for(;v<d;)p[g++]=v++;for(let w=d-1;w>=0;w--)x[w]==-1&&(x[w]=p[--g]);h.setFrame(f,u,x)}s.push(h)}let o=t.readInt(!0);if(o>0){let h=new ne(o);for(let d=0;d<o;d++){let f=t.readFloat(),u=i.events[t.readInt(!0)],m=new bi(f,u);m.intValue=t.readInt(!1),m.floatValue=t.readFloat(),m.stringValue=t.readBoolean()?t.readString():u.stringValue,m.data.audioPath&&(m.volume=t.readFloat(),m.balance=t.readFloat()),h.setFrame(d,m)}s.push(h)}let l=0;for(let h=0,d=s.length;h<d;h++)l=Math.max(l,s[h].getDuration());return new fe(e,s,l)}},hs=class{constructor(t,e=new Array,i=0,s=new DataView(t.buffer)){this.strings=e,this.index=i,this.buffer=s}readByte(){return this.buffer.getInt8(this.index++)}readUnsignedByte(){return this.buffer.getUint8(this.index++)}readShort(){let t=this.buffer.getInt16(this.index);return this.index+=2,t}readInt32(){let t=this.buffer.getInt32(this.index);return this.index+=4,t}readInt(t){let e=this.readByte(),i=e&127;return e&128&&(e=this.readByte(),i|=(e&127)<<7,e&128&&(e=this.readByte(),i|=(e&127)<<14,e&128&&(e=this.readByte(),i|=(e&127)<<21,e&128&&(e=this.readByte(),i|=(e&127)<<28)))),t?i:i>>>1^-(i&1)}readStringRef(){let t=this.readInt(!0);return t==0?null:this.strings[t-1]}readString(){let t=this.readInt(!0);switch(t){case 0:return null;case 1:return""}t--;let e="",i=0;for(let s=0;s<t;){let n=this.readUnsignedByte();switch(n>>4){case 12:case 13:e+=String.fromCharCode((n&31)<<6|this.readByte()&63),s+=2;break;case 14:e+=String.fromCharCode((n&15)<<12|(this.readByte()&63)<<6|this.readByte()&63),s+=3;break;default:e+=String.fromCharCode(n),s++}}return e}readFloat(){let t=this.buffer.getFloat32(this.index);return this.index+=4,t}readBoolean(){return this.readByte()!=0}},zs=class{constructor(t,e,i,s,n){this.mesh=t,this.skin=e,this.slotIndex=i,this.parent=s,this.inheritTimeline=n}},Ws=class{constructor(t=null,e=null){this.bones=t,this.vertices=e}},Ot=(t=>(t[t.Region=0]="Region",t[t.BoundingBox=1]="BoundingBox",t[t.Mesh=2]="Mesh",t[t.LinkedMesh=3]="LinkedMesh",t[t.Path=4]="Path",t[t.Point=5]="Point",t[t.Clipping=6]="Clipping",t))(Ot||{});function Lt(t,e,i){let s=t.readFloat(),n=t.readFloat()*i;for(let c=0,a=0,r=e.getFrameCount()-1;e.setFrame(c,s,n),c!=r;c++){let o=t.readFloat(),l=t.readFloat()*i;switch(t.readByte()){case Mt:e.setStepped(c);break;case Yt:lt(t,e,a++,c,0,s,o,n,l,i)}s=o,n=l}return e}function Ii(t,e,i){let s=t.readFloat(),n=t.readFloat()*i,c=t.readFloat()*i;for(let a=0,r=0,o=e.getFrameCount()-1;e.setFrame(a,s,n,c),a!=o;a++){let l=t.readFloat(),h=t.readFloat()*i,d=t.readFloat()*i;switch(t.readByte()){case Mt:e.setStepped(a);break;case Yt:lt(t,e,r++,a,0,s,l,n,h,i),lt(t,e,r++,a,1,s,l,c,d,i)}s=l,n=h,c=d}return e}function lt(t,e,i,s,n,c,a,r,o,l){e.setBezier(i,s,n,c,r,t.readFloat(),t.readFloat()*l,t.readFloat(),t.readFloat()*l,a,o)}var _s=0,qs=1,Gs=2,Hs=3,js=4,Zs=5,Ks=6,Js=7,Qs=8,$s=9,tr=0,er=1,ir=2,sr=3,rr=4,nr=5,ar=0,lr=1,or=0,hr=1,cr=2,Mt=1,Yt=2,cs=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 se(()=>P.newFloatArray(16))}update(t,e){if(!t)throw new Error("skeleton cannot be null.");let i=this.boundingBoxes,s=this.polygons,n=this.polygonPool,c=t.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 we){let h=l;i.push(h);let d=n.obtain();d.length!=h.worldVerticesLength&&(d=P.newFloatArray(h.worldVerticesLength)),s.push(d),h.computeWorldVertices(o,0,h.worldVerticesLength,d,0,2)}}e?this.aabbCompute():(this.minX=Number.POSITIVE_INFINITY,this.minY=Number.POSITIVE_INFINITY,this.maxX=Number.NEGATIVE_INFINITY,this.maxY=Number.NEGATIVE_INFINITY)}aabbCompute(){let t=Number.POSITIVE_INFINITY,e=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 d=o[l],f=o[l+1];t=Math.min(t,d),e=Math.min(e,f),i=Math.max(i,d),s=Math.max(s,f)}}this.minX=t,this.minY=e,this.maxX=i,this.maxY=s}aabbContainsPoint(t,e){return t>=this.minX&&t<=this.maxX&&e>=this.minY&&e<=this.maxY}aabbIntersectsSegment(t,e,i,s){let n=this.minX,c=this.minY,a=this.maxX,r=this.maxY;if(t<=n&&i<=n||e<=c&&s<=c||t>=a&&i>=a||e>=r&&s>=r)return!1;let o=(s-e)/(i-t),l=o*(n-t)+e;if(l>c&&l<r||(l=o*(a-t)+e,l>c&&l<r))return!0;let h=(c-e)/o+t;return h>n&&h<a||(h=(r-e)/o+t,h>n&&h<a)}aabbIntersectsSkeleton(t){return this.minX<t.maxX&&this.maxX>t.minX&&this.minY<t.maxY&&this.maxY>t.minY}containsPoint(t,e){let i=this.polygons;for(let s=0,n=i.length;s<n;s++)if(this.containsPointPolygon(i[s],t,e))return this.boundingBoxes[s];return null}containsPointPolygon(t,e,i){let s=t,n=t.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)<e&&(a=!a)}c=r}return a}intersectsSegment(t,e,i,s){let n=this.polygons;for(let c=0,a=n.length;c<a;c++)if(this.intersectsSegmentPolygon(n[c],t,e,i,s))return this.boundingBoxes[c];return null}intersectsSegmentPolygon(t,e,i,s,n){let c=t,a=t.length,r=e-s,o=i-n,l=e*n-i*s,h=c[a-2],d=c[a-1];for(let f=0;f<a;f+=2){let u=c[f],m=c[f+1],x=h*m-d*u,p=h-u,v=d-m,g=r*v-o*p,w=(l*p-r*x)/g;if((w>=h&&w<=u||w>=u&&w<=h)&&(w>=e&&w<=s||w>=s&&w<=e)){let b=(l*v-o*x)/g;if((b>=d&&b<=m||b>=m&&b<=d)&&(b>=i&&b<=n||b>=n&&b<=i))return!0}h=u,d=m}return!1}getPolygon(t){if(!t)throw new Error("boundingBox cannot be null.");let e=this.boundingBoxes.indexOf(t);return e==-1?null:this.polygons[e]}getWidth(){return this.maxX-this.minX}getHeight(){return this.maxY-this.minY}},vt=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 se(()=>new Array),this.polygonIndicesPool=new se(()=>new Array)}triangulate(t){let e=t,i=t.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]=vt.isConcave(a,i,e,s);let c=this.triangles;for(c.length=0;i>3;){let a=i-1,r=0,o=1;for(;;){t:if(!n[r]){let d=s[a]<<1,f=s[r]<<1,u=s[o]<<1,m=e[d],x=e[d+1],p=e[f],v=e[f+1],g=e[u],w=e[u+1];for(let b=(o+1)%i;b!=a;b=(b+1)%i){if(!n[b])continue;let y=s[b]<<1,A=e[y],C=e[y+1];if(vt.positiveArea(g,w,m,x,A,C)&&vt.positiveArea(m,x,p,v,A,C)&&vt.positiveArea(p,v,g,w,A,C))break t}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]=vt.isConcave(l,i,e,s),n[h]=vt.isConcave(h,i,e,s)}return i==3&&(c.push(s[2]),c.push(s[0]),c.push(s[1])),c}decompose(t,e){let i=t,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=e.length;l<h;l+=3){let d=e[l]<<1,f=e[l+1]<<1,u=e[l+2]<<1,m=i[d],x=i[d+1],p=i[f],v=i[f+1],g=i[u],w=i[u+1],b=!1;if(r==d){let y=a.length-4,A=vt.winding(a[y],a[y+1],a[y+2],a[y+3],g,w),C=vt.winding(g,w,a[0],a[1],a[2],a[3]);A==o&&C==o&&(a.push(g),a.push(w),c.push(u),b=!0)}b||(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(p),a.push(v),a.push(g),a.push(w),c=this.polygonIndicesPool.obtain(),c.length=0,c.push(d),c.push(f),c.push(u),o=vt.winding(m,x,p,v,g,w),r=d)}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 d=c[0],f=c[c.length-1];a=s[l];let u=a.length-4,m=a[u],x=a[u+1],p=a[u+2],v=a[u+3],g=a[0],w=a[1],b=a[2],y=a[3],A=vt.winding(m,x,p,v,g,w);for(let C=0;C<h;C++){if(C==l)continue;let I=n[C];if(I.length!=3)continue;let E=I[0],R=I[1],L=I[2],k=s[C],F=k[k.length-2],Y=k[k.length-1];if(E!=d||R!=f)continue;let T=vt.winding(m,x,p,v,F,Y),D=vt.winding(F,Y,g,w,b,y);T==A&&D==A&&(k.length=0,I.length=0,a.push(F),a.push(Y),c.push(L),m=p,x=v,p=F,v=Y,C=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(t,e,i,s){let n=s[(e+t-1)%e]<<1,c=s[t]<<1,a=s[(t+1)%e]<<1;return!this.positiveArea(i[n],i[n+1],i[c],i[c+1],i[a],i[a+1])}static positiveArea(t,e,i,s,n,c){return t*(c-s)+i*(e-c)+n*(s-e)>=0}static winding(t,e,i,s,n,c){let a=i-t,r=s-e;return n*r-c*a+a*e-t*r>=0?1:-1}},Ie=class{constructor(){this.triangulator=new vt,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(t,e){if(this.clipAttachment)return 0;this.clipAttachment=e;let i=e.worldVerticesLength,s=P.setArraySize(this.clippingPolygon,i);e.computeWorldVertices(t,0,i,s,0,2);let n=this.clippingPolygon;Ie.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];Ie.makeClockwise(o),o.push(o[0]),o.push(o[1])}return c.length}clipEndWithSlot(t){this.clipAttachment&&this.clipAttachment.endSlot==t.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(t,e,i,s,n,c,a,r){let o=this.clipOutput,l=this.clippedVertices,h=this.clippedTriangles,d=this.clippingPolygons,f=d.length,u=r?12:8,m=0;l.length=0,h.length=0;t:for(let x=0;x<s;x+=3){let p=i[x]<<1,v=t[p],g=t[p+1],w=n[p],b=n[p+1];p=i[x+1]<<1;let y=t[p],A=t[p+1],C=n[p],I=n[p+1];p=i[x+2]<<1;let E=t[p],R=t[p+1],L=n[p],k=n[p+1];for(let F=0;F<f;F++){let Y=l.length;if(this.clip(v,g,y,A,E,R,d[F],o)){let T=o.length;if(T==0)continue;let D=A-R,B=E-y,et=v-E,rt=R-g,st=1/(D*et+B*(g-R)),ht=T>>1,nt=this.clipOutput,it=P.setArraySize(l,Y+ht*u);for(let wt=0;wt<T;wt+=2){let kt=nt[wt],gt=nt[wt+1];it[Y]=kt,it[Y+1]=gt,it[Y+2]=c.r,it[Y+3]=c.g,it[Y+4]=c.b,it[Y+5]=c.a;let At=kt-E,Ct=gt-R,Vt=(D*At+B*Ct)*st,te=(rt*At+et*Ct)*st,ce=1-Vt-te;it[Y+6]=w*Vt+C*te+L*ce,it[Y+7]=b*Vt+I*te+k*ce,r&&(it[Y+8]=a.r,it[Y+9]=a.g,it[Y+10]=a.b,it[Y+11]=a.a),Y+=u}Y=h.length;let dt=P.setArraySize(h,Y+3*(ht-2));ht--;for(let wt=1;wt<ht;wt++)dt[Y]=m,dt[Y+1]=m+wt,dt[Y+2]=m+wt+1,Y+=3;m+=ht+1}else{let T=P.setArraySize(l,Y+3*u);T[Y]=v,T[Y+1]=g,T[Y+2]=c.r,T[Y+3]=c.g,T[Y+4]=c.b,T[Y+5]=c.a,r?(T[Y+6]=w,T[Y+7]=b,T[Y+8]=a.r,T[Y+9]=a.g,T[Y+10]=a.b,T[Y+11]=a.a,T[Y+12]=y,T[Y+13]=A,T[Y+14]=c.r,T[Y+15]=c.g,T[Y+16]=c.b,T[Y+17]=c.a,T[Y+18]=C,T[Y+19]=I,T[Y+20]=a.r,T[Y+21]=a.g,T[Y+22]=a.b,T[Y+23]=a.a,T[Y+24]=E,T[Y+25]=R,T[Y+26]=c.r,T[Y+27]=c.g,T[Y+28]=c.b,T[Y+29]=c.a,T[Y+30]=L,T[Y+31]=k,T[Y+32]=a.r,T[Y+33]=a.g,T[Y+34]=a.b,T[Y+35]=a.a):(T[Y+6]=w,T[Y+7]=b,T[Y+8]=y,T[Y+9]=A,T[Y+10]=c.r,T[Y+11]=c.g,T[Y+12]=c.b,T[Y+13]=c.a,T[Y+14]=C,T[Y+15]=I,T[Y+16]=E,T[Y+17]=R,T[Y+18]=c.r,T[Y+19]=c.g,T[Y+20]=c.b,T[Y+21]=c.a,T[Y+22]=L,T[Y+23]=k),Y=h.length;let D=P.setArraySize(h,Y+3);D[Y]=m,D[Y+1]=m+1,D[Y+2]=m+2,m+=3;continue t}}}}clip(t,e,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(t),h.push(e),h.push(i),h.push(s),h.push(n),h.push(c),h.push(t),h.push(e),r.length=0;let d=a,f=a.length-4;for(let u=0;;u+=2){let m=d[u],x=d[u+1],p=d[u+2],v=d[u+3],g=m-p,w=x-v,b=h,y=h.length-2,A=r.length;for(let I=0;I<y;I+=2){let E=b[I],R=b[I+1],L=b[I+2],k=b[I+3],F=g*(k-v)-w*(L-p)>0;if(g*(R-v)-w*(E-p)>0){if(F){r.push(L),r.push(k);continue}let Y=k-R,T=L-E,D=Y*(p-m)-T*(v-x);if(Math.abs(D)>1e-6){let B=(T*(x-R)-Y*(m-E))/D;r.push(m+(p-m)*B),r.push(x+(v-x)*B)}else r.push(m),r.push(x)}else if(F){let Y=k-R,T=L-E,D=Y*(p-m)-T*(v-x);if(Math.abs(D)>1e-6){let B=(T*(x-R)-Y*(m-E))/D;r.push(m+(p-m)*B),r.push(x+(v-x)*B)}else r.push(m),r.push(x);r.push(L),r.push(k)}l=!0}if(A==r.length)return o.length=0,!0;if(r.push(r[0]),r.push(r[1]),u==f)break;let C=r;r=h,r.length=0,h=C}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(t){let e=t,i=t.length,s=e[i-2]*e[1]-e[0]*e[i-1],n=0,c=0,a=0,r=0;for(let o=0,l=i-3;o<l;o+=2)n=e[o],c=e[o+1],a=e[o+2],r=e[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 d=e[o],f=e[o+1],u=l-o;e[o]=e[u],e[o+1]=e[u+1],e[u]=d,e[u+1]=f}}},dr=class{constructor(t){this.scale=1,this.linkedMeshes=new Array,this.attachmentLoader=t}readSkeletonData(t){let e=this.scale,i=new Ai,s=typeof t=="string"?JSON.parse(t):t,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=M(a,"parent",null);o&&(r=i.findBone(o));let l=new gi(i.bones.length,a.name,r);l.length=M(a,"length",0)*e,l.x=M(a,"x",0)*e,l.y=M(a,"y",0)*e,l.rotation=M(a,"rotation",0),l.scaleX=M(a,"scaleX",1),l.scaleY=M(a,"scaleY",1),l.shearX=M(a,"shearX",0),l.shearY=M(a,"shearY",0),l.transformMode=P.enumValue(pe,M(a,"transform","Normal")),l.skinRequired=M(a,"skin",!1);let h=M(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 Si(i.slots.length,a.name,r),l=M(a,"color",null);l&&o.color.setFromString(l);let h=M(a,"dark",null);h&&(o.darkColor=O.fromString(h)),o.attachmentName=M(a,"attachment",null),o.blendMode=P.enumValue(Te,M(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 vi(a.name);r.order=M(a,"order",0),r.skinRequired=M(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=M(a,"mix",1),r.softness=M(a,"softness",0)*e,r.bendDirection=M(a,"bendPositive",!0)?1:-1,r.compress=M(a,"compress",!1),r.stretch=M(a,"stretch",!1),r.uniform=M(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 Ti(a.name);r.order=M(a,"order",0),r.skinRequired=M(a,"skin",!1);for(let h=0;h<a.bones.length;h++){let d=a.bones[h],f=i.findBone(d);if(!f)throw new Error(`Couldn't find bone ${d} for transform constraint ${a.name}.`);r.bones.push(f)}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=M(a,"local",!1),r.relative=M(a,"relative",!1),r.offsetRotation=M(a,"rotation",0),r.offsetX=M(a,"x",0)*e,r.offsetY=M(a,"y",0)*e,r.offsetScaleX=M(a,"scaleX",0),r.offsetScaleY=M(a,"scaleY",0),r.offsetShearY=M(a,"shearY",0),r.mixRotate=M(a,"mixRotate",1),r.mixX=M(a,"mixX",1),r.mixY=M(a,"mixY",r.mixX),r.mixScaleX=M(a,"mixScaleX",1),r.mixScaleY=M(a,"mixScaleY",r.mixScaleX),r.mixShearY=M(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 yi(a.name);r.order=M(a,"order",0),r.skinRequired=M(a,"skin",!1);for(let h=0;h<a.bones.length;h++){let d=a.bones[h],f=i.findBone(d);if(!f)throw new Error(`Couldn't find bone ${d} for path constraint ${a.name}.`);r.bones.push(f)}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=P.enumValue(ye,M(a,"positionMode","Percent")),r.spacingMode=P.enumValue(Ae,M(a,"spacingMode","Length")),r.rotateMode=P.enumValue(Ce,M(a,"rotateMode","Tangent")),r.offsetRotation=M(a,"rotation",0),r.position=M(a,"position",0),r.positionMode==0&&(r.position*=e),r.spacing=M(a,"spacing",0),(r.spacingMode==0||r.spacingMode==1)&&(r.spacing*=e),r.mixRotate=M(a,"mixRotate",1),r.mixX=M(a,"mixX",1),r.mixY=M(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 Se(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 d in h){let f=this.readAttachment(h[d],r,l.index,d,i);f&&r.setAttachment(l.index,d,f)}}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 pi(c);r.intValue=M(a,"int",0),r.floatValue=M(a,"float",0),r.stringValue=M(a,"string",""),r.audioPath=M(a,"audio",null),r.audioPath&&(r.volume=M(a,"volume",1),r.balance=M(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(t,e,i,s,n){let c=this.scale;switch(s=M(t,"name",s),M(t,"type","region")){case"region":{let a=M(t,"path",s),r=this.readSequence(M(t,"sequence",null)),o=this.attachmentLoader.newRegionAttachment(e,s,a,r);if(!o)return null;o.path=a,o.x=M(t,"x",0)*c,o.y=M(t,"y",0)*c,o.scaleX=M(t,"scaleX",1),o.scaleY=M(t,"scaleY",1),o.rotation=M(t,"rotation",0),o.width=t.width*c,o.height=t.height*c,o.sequence=r;let l=M(t,"color",null);return l&&o.color.setFromString(l),o.region!=null&&o.updateRegion(),o}case"boundingbox":{let a=this.attachmentLoader.newBoundingBoxAttachment(e,s);if(!a)return null;this.readVertices(t,a,t.vertexCount<<1);let r=M(t,"color",null);return r&&a.color.setFromString(r),a}case"mesh":case"linkedmesh":{let a=M(t,"path",s),r=this.readSequence(M(t,"sequence",null)),o=this.attachmentLoader.newMeshAttachment(e,s,a,r);if(!o)return null;o.path=a;let l=M(t,"color",null);l&&o.color.setFromString(l),o.width=M(t,"width",0)*c,o.height=M(t,"height",0)*c,o.sequence=r;let h=M(t,"parent",null);if(h)return this.linkedMeshes.push(new fr(o,M(t,"skin",null),i,h,M(t,"timelines",!0))),o;let d=t.uvs;return this.readVertices(t,o,d.length),o.triangles=t.triangles,o.regionUVs=d,o.region!=null&&o.updateRegion(),o.edges=M(t,"edges",null),o.hullLength=M(t,"hull",0)*2,o}case"path":{let a=this.attachmentLoader.newPathAttachment(e,s);if(!a)return null;a.closed=M(t,"closed",!1),a.constantSpeed=M(t,"constantSpeed",!0);let r=t.vertexCount;this.readVertices(t,a,r<<1);let o=P.newArray(r/3,0);for(let h=0;h<t.lengths.length;h++)o[h]=t.lengths[h]*c;a.lengths=o;let l=M(t,"color",null);return l&&a.color.setFromString(l),a}case"point":{let a=this.attachmentLoader.newPointAttachment(e,s);if(!a)return null;a.x=M(t,"x",0)*c,a.y=M(t,"y",0)*c,a.rotation=M(t,"rotation",0);let r=M(t,"color",null);return r&&a.color.setFromString(r),a}case"clipping":{let a=this.attachmentLoader.newClippingAttachment(e,s);if(!a)return null;let r=M(t,"end",null);r&&(a.endSlot=n.findSlot(r));let o=t.vertexCount;this.readVertices(t,a,o<<1);let l=M(t,"color",null);return l&&a.color.setFromString(l),a}}return null}readSequence(t){if(t==null)return null;let e=new ze(M(t,"count",0));return e.start=M(t,"start",1),e.digits=M(t,"digits",0),e.setupIndex=M(t,"setup",0),e}readVertices(t,e,i){let s=this.scale;e.worldVerticesLength=i;let n=t.vertices;if(i==n.length){let r=P.toFloatArray(n);if(s!=1)for(let o=0,l=n.length;o<l;o++)r[o]*=s;e.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])}e.bones=a,e.vertices=P.toFloatArray(c)}readAnimation(t,e,i){let s=this.scale,n=new Array;if(t.slots)for(let a in t.slots){let r=t.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 d=r[h];if(!d)continue;let f=d.length;if(h=="attachment"){let u=new zt(f,l);for(let m=0;m<f;m++){let x=d[m];u.setFrame(m,M(x,"time",0),M(x,"name",null))}n.push(u)}else if(h=="rgba"){let u=new Qe(f,f<<2,l),m=d[0],x=M(m,"time",0),p=O.fromString(m.color);for(let v=0,g=0;;v++){u.setFrame(v,x,p.r,p.g,p.b,p.a);let w=d[v+1];if(!w){u.shrink(g);break}let b=M(w,"time",0),y=O.fromString(w.color),A=m.curve;A&&(g=ot(A,u,g,v,0,x,b,p.r,y.r,1),g=ot(A,u,g,v,1,x,b,p.g,y.g,1),g=ot(A,u,g,v,2,x,b,p.b,y.b,1),g=ot(A,u,g,v,3,x,b,p.a,y.a,1)),x=b,p=y,m=w}n.push(u)}else if(h=="rgb"){let u=new $e(f,f*3,l),m=d[0],x=M(m,"time",0),p=O.fromString(m.color);for(let v=0,g=0;;v++){u.setFrame(v,x,p.r,p.g,p.b);let w=d[v+1];if(!w){u.shrink(g);break}let b=M(w,"time",0),y=O.fromString(w.color),A=m.curve;A&&(g=ot(A,u,g,v,0,x,b,p.r,y.r,1),g=ot(A,u,g,v,1,x,b,p.g,y.g,1),g=ot(A,u,g,v,2,x,b,p.b,y.b,1)),x=b,p=y,m=w}n.push(u)}else if(h=="alpha")n.push(Rt(d,new ti(f,f,l),0,1));else if(h=="rgba2"){let u=new ei(f,f*7,l),m=d[0],x=M(m,"time",0),p=O.fromString(m.light),v=O.fromString(m.dark);for(let g=0,w=0;;g++){u.setFrame(g,x,p.r,p.g,p.b,p.a,v.r,v.g,v.b);let b=d[g+1];if(!b){u.shrink(w);break}let y=M(b,"time",0),A=O.fromString(b.light),C=O.fromString(b.dark),I=m.curve;I&&(w=ot(I,u,w,g,0,x,y,p.r,A.r,1),w=ot(I,u,w,g,1,x,y,p.g,A.g,1),w=ot(I,u,w,g,2,x,y,p.b,A.b,1),w=ot(I,u,w,g,3,x,y,p.a,A.a,1),w=ot(I,u,w,g,4,x,y,v.r,C.r,1),w=ot(I,u,w,g,5,x,y,v.g,C.g,1),w=ot(I,u,w,g,6,x,y,v.b,C.b,1)),x=y,p=A,v=C,m=b}n.push(u)}else if(h=="rgb2"){let u=new ii(f,f*6,l),m=d[0],x=M(m,"time",0),p=O.fromString(m.light),v=O.fromString(m.dark);for(let g=0,w=0;;g++){u.setFrame(g,x,p.r,p.g,p.b,v.r,v.g,v.b);let b=d[g+1];if(!b){u.shrink(w);break}let y=M(b,"time",0),A=O.fromString(b.light),C=O.fromString(b.dark),I=m.curve;I&&(w=ot(I,u,w,g,0,x,y,p.r,A.r,1),w=ot(I,u,w,g,1,x,y,p.g,A.g,1),w=ot(I,u,w,g,2,x,y,p.b,A.b,1),w=ot(I,u,w,g,3,x,y,v.r,C.r,1),w=ot(I,u,w,g,4,x,y,v.g,C.g,1),w=ot(I,u,w,g,5,x,y,v.b,C.b,1)),x=y,p=A,v=C,m=b}n.push(u)}}}if(t.bones)for(let a in t.bones){let r=t.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 d=r[h],f=d.length;if(f!=0){if(h==="rotate")n.push(Rt(d,new re(f,f,l),0,1));else if(h==="translate"){let u=new We(f,f<<1,l);n.push(Mi(d,u,"x","y",0,s))}else if(h==="translatex"){let u=new _e(f,f,l);n.push(Rt(d,u,0,s))}else if(h==="translatey"){let u=new qe(f,f,l);n.push(Rt(d,u,0,s))}else if(h==="scale"){let u=new Ge(f,f<<1,l);n.push(Mi(d,u,"x","y",1,1))}else if(h==="scalex"){let u=new He(f,f,l);n.push(Rt(d,u,1,1))}else if(h==="scaley"){let u=new je(f,f,l);n.push(Rt(d,u,1,1))}else if(h==="shear"){let u=new Ze(f,f<<1,l);n.push(Mi(d,u,"x","y",0,1))}else if(h==="shearx"){let u=new Ke(f,f,l);n.push(Rt(d,u,0,1))}else if(h==="sheary"){let u=new Je(f,f,l);n.push(Rt(d,u,0,1))}}}}if(t.ik)for(let a in t.ik){let r=t.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),d=new ri(r.length,r.length<<1,h),f=M(o,"time",0),u=M(o,"mix",1),m=M(o,"softness",0)*s;for(let x=0,p=0;;x++){d.setFrame(x,f,u,m,M(o,"bendPositive",!0)?1:-1,M(o,"compress",!1),M(o,"stretch",!1));let v=r[x+1];if(!v){d.shrink(p);break}let g=M(v,"time",0),w=M(v,"mix",1),b=M(v,"softness",0)*s,y=o.curve;y&&(p=ot(y,d,p,x,0,f,g,u,w,1),p=ot(y,d,p,x,1,f,g,m,b,s)),f=g,u=w,m=b,o=v}n.push(d)}if(t.transform)for(let a in t.transform){let r=t.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),d=new ni(r.length,r.length*6,h),f=M(o,"time",0),u=M(o,"mixRotate",1),m=M(o,"mixX",1),x=M(o,"mixY",m),p=M(o,"mixScaleX",1),v=M(o,"mixScaleY",p),g=M(o,"mixShearY",1);for(let w=0,b=0;;w++){d.setFrame(w,f,u,m,x,p,v,g);let y=r[w+1];if(!y){d.shrink(b);break}let A=M(y,"time",0),C=M(y,"mixRotate",1),I=M(y,"mixX",1),E=M(y,"mixY",I),R=M(y,"mixScaleX",1),L=M(y,"mixScaleY",R),k=M(y,"mixShearY",1),F=o.curve;F&&(b=ot(F,d,b,w,0,f,A,u,C,1),b=ot(F,d,b,w,1,f,A,m,I,1),b=ot(F,d,b,w,2,f,A,x,E,1),b=ot(F,d,b,w,3,f,A,p,R,1),b=ot(F,d,b,w,4,f,A,v,L,1),b=ot(F,d,b,w,5,f,A,g,k,1)),f=A,u=C,m=I,x=E,p=R,v=L,p=R,o=y}n.push(d)}if(t.path)for(let a in t.path){let r=t.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 d=r[h],f=d[0];if(!f)continue;let u=d.length;if(h==="position"){let m=new ai(u,u,l);n.push(Rt(d,m,0,o.positionMode==0?s:1))}else if(h==="spacing"){let m=new li(u,u,l);n.push(Rt(d,m,0,o.spacingMode==0||o.spacingMode==1?s:1))}else if(h==="mix"){let m=new oi(u,u*3,l),x=M(f,"time",0),p=M(f,"mixRotate",1),v=M(f,"mixX",1),g=M(f,"mixY",v);for(let w=0,b=0;;w++){m.setFrame(w,x,p,v,g);let y=d[w+1];if(!y){m.shrink(b);break}let A=M(y,"time",0),C=M(y,"mixRotate",1),I=M(y,"mixX",1),E=M(y,"mixY",I),R=f.curve;R&&(b=ot(R,m,b,w,0,x,A,p,C,1),b=ot(R,m,b,w,1,x,A,v,I,1),b=ot(R,m,b,w,2,x,A,g,E,1)),x=A,p=C,v=I,g=E,f=y}n.push(m)}}}if(t.attachments)for(let a in t.attachments){let r=t.attachments[a],o=i.findSkin(a);if(!o)throw new Error("Skin not found: "+a);for(let l in r){let h=r[l],d=i.findSlot(l);if(!d)throw new Error("Slot not found: "+l);let f=d.index;for(let u in h){let m=h[u],x=o.getAttachment(f,u);for(let p in m){let v=m[p],g=v[0];if(g){if(p=="deform"){let w=x.bones,b=x.vertices,y=w?b.length/3*2:b.length,A=new si(v.length,v.length,f,x),C=M(g,"time",0);for(let I=0,E=0;;I++){let R,L=M(g,"vertices",null);if(!L)R=w?P.newFloatArray(y):b;else{R=P.newFloatArray(y);let T=M(g,"offset",0);if(P.arrayCopy(L,0,R,T,L.length),s!=1)for(let D=T,B=D+L.length;D<B;D++)R[D]*=s;if(!w)for(let D=0;D<y;D++)R[D]+=b[D]}A.setFrame(I,C,R);let k=v[I+1];if(!k){A.shrink(E);break}let F=M(k,"time",0),Y=g.curve;Y&&(E=ot(Y,A,E,I,0,C,F,0,1,1)),C=F,g=k}n.push(A)}else if(p=="sequence"){let w=new jt(v.length,f,x),b=0;for(let y=0;y<v.length;y++){let A=M(g,"delay",b),C=M(g,"time",0),I=Ui[M(g,"mode","hold")],E=M(g,"index",0);w.setFrame(y,C,I,E,A),b=A,g=v[y+1]}n.push(w)}}}}}}if(t.drawOrder){let a=new Wt(t.drawOrder.length),r=i.slots.length,o=0;for(let l=0;l<t.drawOrder.length;l++,o++){let h=t.drawOrder[l],d=null,f=M(h,"offsets",null);if(f){d=P.newArray(r,-1);let u=P.newArray(r-f.length,0),m=0,x=0;for(let p=0;p<f.length;p++){let v=f[p],g=i.findSlot(v.slot);if(!g)throw new Error("Slot not found: "+g);let w=g.index;for(;m!=w;)u[x++]=m++;d[m+v.offset]=m++}for(;m<r;)u[x++]=m++;for(let p=r-1;p>=0;p--)d[p]==-1&&(d[p]=u[--x])}a.setFrame(o,M(h,"time",0),d)}n.push(a)}if(t.events){let a=new ne(t.events.length),r=0;for(let o=0;o<t.events.length;o++,r++){let l=t.events[o],h=i.findEvent(l.name);if(!h)throw new Error("Event not found: "+l.name);let d=new bi(P.toSinglePrecision(M(l,"time",0)),h);d.intValue=M(l,"int",h.intValue),d.floatValue=M(l,"float",h.floatValue),d.stringValue=M(l,"string",h.stringValue),d.data.audioPath&&(d.volume=M(l,"volume",1),d.balance=M(l,"balance",0)),a.setFrame(r,d)}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 fe(e,n,c))}},fr=class{constructor(t,e,i,s,n){this.mesh=t,this.skin=e,this.slotIndex=i,this.parent=s,this.inheritTimeline=n}};function Rt(t,e,i,s){let n=t[0],c=M(n,"time",0),a=M(n,"value",i)*s,r=0;for(let o=0;;o++){e.setFrame(o,c,a);let l=t[o+1];if(!l)return e.shrink(r),e;let h=M(l,"time",0),d=M(l,"value",i)*s;n.curve&&(r=ot(n.curve,e,r,o,0,c,h,a,d,s)),c=h,a=d,n=l}}function Mi(t,e,i,s,n,c){let a=t[0],r=M(a,"time",0),o=M(a,i,n)*c,l=M(a,s,n)*c,h=0;for(let d=0;;d++){e.setFrame(d,r,o,l);let f=t[d+1];if(!f)return e.shrink(h),e;let u=M(f,"time",0),m=M(f,i,n)*c,x=M(f,s,n)*c,p=a.curve;p&&(h=ot(p,e,h,d,0,r,u,o,m,c),h=ot(p,e,h,d,1,r,u,l,x,c)),r=u,o=m,l=x,a=f}}function ot(t,e,i,s,n,c,a,r,o,l){if(t=="stepped")return e.setStepped(s),i;let h=n<<2,d=t[h],f=t[h+1]*l,u=t[h+2],m=t[h+3]*l;return e.setBezier(i,s,n,c,r,d,f,u,m,a,o),i+1}function M(t,e,i){return t[e]!==void 0?t[e]:i}typeof Math.fround=="undefined"&&(Math.fround=function(t){return function(e){return t[0]=e,t[0]}}(new Float32Array(1)));var xt=class{constructor(t,e={alpha:"true"}){if(this.restorables=new Array,t instanceof WebGLRenderingContext||typeof WebGL2RenderingContext!="undefined"&&t instanceof WebGL2RenderingContext)this.gl=t,this.canvas=this.gl.canvas;else{let i=t;this.gl=i.getContext("webgl2",e)||i.getContext("webgl",e),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(t){this.restorables.push(t)}removeRestorable(t){let e=this.restorables.indexOf(t);e>-1&&this.restorables.splice(e,1)}},Kt=1,ur=769,ds=770,Me=771,mr=774,Ye=class{static getDestGLBlendMode(t){switch(t){case 0:return Me;case 1:return Kt;case 2:return Me;case 3:return Me;default:throw new Error("Unknown blend mode: "+t)}}static getSourceColorGLBlendMode(t,e=!1){switch(t){case 0:return e?Kt:ds;case 1:return e?Kt:ds;case 2:return mr;case 3:return Kt;default:throw new Error("Unknown blend mode: "+t)}}static getSourceAlphaGLBlendMode(t){switch(t){case 0:return Kt;case 1:return Kt;case 2:return Me;case 3:return ur;default:throw new Error("Unknown blend mode: "+t)}}},Ee=class extends fi{constructor(t,e,i=!1){super(e),this.texture=null,this.boundUnit=0,this.useMipMaps=!1,this.context=t instanceof xt?t:new xt(t),this.useMipMaps=i,this.restore(),this.context.addRestorable(this)}setFilters(t,e){let i=this.context.gl;this.bind(),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_MIN_FILTER,t),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_MAG_FILTER,Ee.validateMagFilter(e)),this.useMipMaps=Ee.usesMipMaps(t),this.useMipMaps&&i.generateMipmap(i.TEXTURE_2D)}static validateMagFilter(t){switch(t){case 9987:case 9985:case 9986:case 9984:return 9729;default:return t}}static usesMipMaps(t){switch(t){case 9987:case 9985:case 9986:case 9984:return!0;default:return!1}}setWraps(t,e){let i=this.context.gl;this.bind(),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_WRAP_S,t),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_WRAP_T,e)}update(t){let e=this.context.gl;this.texture||(this.texture=this.context.gl.createTexture()),this.bind(),Ee.DISABLE_UNPACK_PREMULTIPLIED_ALPHA_WEBGL&&e.pixelStorei(e.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1),e.texImage2D(e.TEXTURE_2D,0,e.RGBA,e.RGBA,e.UNSIGNED_BYTE,this._image),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MAG_FILTER,e.LINEAR),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MIN_FILTER,t?e.LINEAR_MIPMAP_LINEAR:e.LINEAR),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_S,e.CLAMP_TO_EDGE),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_T,e.CLAMP_TO_EDGE),t&&e.generateMipmap(e.TEXTURE_2D)}restore(){this.texture=null,this.update(this.useMipMaps)}bind(t=0){let e=this.context.gl;this.boundUnit=t,e.activeTexture(e.TEXTURE0+t),e.bindTexture(e.TEXTURE_2D,this.texture)}unbind(){let t=this.context.gl;t.activeTexture(t.TEXTURE0+this.boundUnit),t.bindTexture(t.TEXTURE_2D,null)}dispose(){this.context.removeRestorable(this),this.context.gl.deleteTexture(this.texture)}},le=Ee;le.DISABLE_UNPACK_PREMULTIPLIED_ALPHA_WEBGL=!1;var fs=class extends ss{constructor(t,e="",i=new wi){super(s=>new le(t,s),e,i)}},yt=class{constructor(t=0,e=0,i=0){this.x=0,this.y=0,this.z=0,this.x=t,this.y=e,this.z=i}setFrom(t){return this.x=t.x,this.y=t.y,this.z=t.z,this}set(t,e,i){return this.x=t,this.y=e,this.z=i,this}add(t){return this.x+=t.x,this.y+=t.y,this.z+=t.z,this}sub(t){return this.x-=t.x,this.y-=t.y,this.z-=t.z,this}scale(t){return this.x*=t,this.y*=t,this.z*=t,this}normalize(){let t=this.length();return t==0?this:(t=1/t,this.x*=t,this.y*=t,this.z*=t,this)}cross(t){return this.set(this.y*t.z-this.z*t.y,this.z*t.x-this.x*t.z,this.x*t.y-this.y*t.x)}multiply(t){let e=t.values;return this.set(this.x*e[V]+this.y*e[q]+this.z*e[G]+e[N],this.x*e[H]+this.y*e[U]+this.z*e[j]+e[z],this.x*e[Z]+this.y*e[K]+this.z*e[W]+e[_])}project(t){let e=t.values,i=1/(this.x*e[Q]+this.y*e[$]+this.z*e[tt]+e[J]);return this.set((this.x*e[V]+this.y*e[q]+this.z*e[G]+e[N])*i,(this.x*e[H]+this.y*e[U]+this.z*e[j]+e[z])*i,(this.x*e[Z]+this.y*e[K]+this.z*e[W]+e[_])*i)}dot(t){return this.x*t.x+this.y*t.y+this.z*t.z}length(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z)}distance(t){let e=t.x-this.x,i=t.y-this.y,s=t.z-this.z;return Math.sqrt(e*e+i*i+s*s)}},V=0,q=4,G=8,N=12,H=1,U=5,j=9,z=13,Z=2,K=6,W=10,_=14,Q=3,$=7,tt=11,J=15,Et=class{constructor(){this.temp=new Float32Array(16),this.values=new Float32Array(16);let t=this.values;t[V]=1,t[U]=1,t[W]=1,t[J]=1}set(t){return this.values.set(t),this}transpose(){let t=this.temp,e=this.values;return t[V]=e[V],t[q]=e[H],t[G]=e[Z],t[N]=e[Q],t[H]=e[q],t[U]=e[U],t[j]=e[K],t[z]=e[$],t[Z]=e[G],t[K]=e[j],t[W]=e[W],t[_]=e[tt],t[Q]=e[N],t[$]=e[z],t[tt]=e[_],t[J]=e[J],this.set(t)}identity(){let t=this.values;return t[V]=1,t[q]=0,t[G]=0,t[N]=0,t[H]=0,t[U]=1,t[j]=0,t[z]=0,t[Z]=0,t[K]=0,t[W]=1,t[_]=0,t[Q]=0,t[$]=0,t[tt]=0,t[J]=1,this}invert(){let t=this.values,e=this.temp,i=t[Q]*t[K]*t[j]*t[N]-t[Z]*t[$]*t[j]*t[N]-t[Q]*t[U]*t[W]*t[N]+t[H]*t[$]*t[W]*t[N]+t[Z]*t[U]*t[tt]*t[N]-t[H]*t[K]*t[tt]*t[N]-t[Q]*t[K]*t[G]*t[z]+t[Z]*t[$]*t[G]*t[z]+t[Q]*t[q]*t[W]*t[z]-t[V]*t[$]*t[W]*t[z]-t[Z]*t[q]*t[tt]*t[z]+t[V]*t[K]*t[tt]*t[z]+t[Q]*t[U]*t[G]*t[_]-t[H]*t[$]*t[G]*t[_]-t[Q]*t[q]*t[j]*t[_]+t[V]*t[$]*t[j]*t[_]+t[H]*t[q]*t[tt]*t[_]-t[V]*t[U]*t[tt]*t[_]-t[Z]*t[U]*t[G]*t[J]+t[H]*t[K]*t[G]*t[J]+t[Z]*t[q]*t[j]*t[J]-t[V]*t[K]*t[j]*t[J]-t[H]*t[q]*t[W]*t[J]+t[V]*t[U]*t[W]*t[J];if(i==0)throw new Error("non-invertible matrix");let s=1/i;return e[V]=t[j]*t[_]*t[$]-t[z]*t[W]*t[$]+t[z]*t[K]*t[tt]-t[U]*t[_]*t[tt]-t[j]*t[K]*t[J]+t[U]*t[W]*t[J],e[q]=t[N]*t[W]*t[$]-t[G]*t[_]*t[$]-t[N]*t[K]*t[tt]+t[q]*t[_]*t[tt]+t[G]*t[K]*t[J]-t[q]*t[W]*t[J],e[G]=t[G]*t[z]*t[$]-t[N]*t[j]*t[$]+t[N]*t[U]*t[tt]-t[q]*t[z]*t[tt]-t[G]*t[U]*t[J]+t[q]*t[j]*t[J],e[N]=t[N]*t[j]*t[K]-t[G]*t[z]*t[K]-t[N]*t[U]*t[W]+t[q]*t[z]*t[W]+t[G]*t[U]*t[_]-t[q]*t[j]*t[_],e[H]=t[z]*t[W]*t[Q]-t[j]*t[_]*t[Q]-t[z]*t[Z]*t[tt]+t[H]*t[_]*t[tt]+t[j]*t[Z]*t[J]-t[H]*t[W]*t[J],e[U]=t[G]*t[_]*t[Q]-t[N]*t[W]*t[Q]+t[N]*t[Z]*t[tt]-t[V]*t[_]*t[tt]-t[G]*t[Z]*t[J]+t[V]*t[W]*t[J],e[j]=t[N]*t[j]*t[Q]-t[G]*t[z]*t[Q]-t[N]*t[H]*t[tt]+t[V]*t[z]*t[tt]+t[G]*t[H]*t[J]-t[V]*t[j]*t[J],e[z]=t[G]*t[z]*t[Z]-t[N]*t[j]*t[Z]+t[N]*t[H]*t[W]-t[V]*t[z]*t[W]-t[G]*t[H]*t[_]+t[V]*t[j]*t[_],e[Z]=t[U]*t[_]*t[Q]-t[z]*t[K]*t[Q]+t[z]*t[Z]*t[$]-t[H]*t[_]*t[$]-t[U]*t[Z]*t[J]+t[H]*t[K]*t[J],e[K]=t[N]*t[K]*t[Q]-t[q]*t[_]*t[Q]-t[N]*t[Z]*t[$]+t[V]*t[_]*t[$]+t[q]*t[Z]*t[J]-t[V]*t[K]*t[J],e[W]=t[q]*t[z]*t[Q]-t[N]*t[U]*t[Q]+t[N]*t[H]*t[$]-t[V]*t[z]*t[$]-t[q]*t[H]*t[J]+t[V]*t[U]*t[J],e[_]=t[N]*t[U]*t[Z]-t[q]*t[z]*t[Z]-t[N]*t[H]*t[K]+t[V]*t[z]*t[K]+t[q]*t[H]*t[_]-t[V]*t[U]*t[_],e[Q]=t[j]*t[K]*t[Q]-t[U]*t[W]*t[Q]-t[j]*t[Z]*t[$]+t[H]*t[W]*t[$]+t[U]*t[Z]*t[tt]-t[H]*t[K]*t[tt],e[$]=t[q]*t[W]*t[Q]-t[G]*t[K]*t[Q]+t[G]*t[Z]*t[$]-t[V]*t[W]*t[$]-t[q]*t[Z]*t[tt]+t[V]*t[K]*t[tt],e[tt]=t[G]*t[U]*t[Q]-t[q]*t[j]*t[Q]-t[G]*t[H]*t[$]+t[V]*t[j]*t[$]+t[q]*t[H]*t[tt]-t[V]*t[U]*t[tt],e[J]=t[q]*t[j]*t[Z]-t[G]*t[U]*t[Z]+t[G]*t[H]*t[K]-t[V]*t[j]*t[K]-t[q]*t[H]*t[W]+t[V]*t[U]*t[W],t[V]=e[V]*s,t[q]=e[q]*s,t[G]=e[G]*s,t[N]=e[N]*s,t[H]=e[H]*s,t[U]=e[U]*s,t[j]=e[j]*s,t[z]=e[z]*s,t[Z]=e[Z]*s,t[K]=e[K]*s,t[W]=e[W]*s,t[_]=e[_]*s,t[Q]=e[Q]*s,t[$]=e[$]*s,t[tt]=e[tt]*s,t[J]=e[J]*s,this}determinant(){let t=this.values;return t[Q]*t[K]*t[j]*t[N]-t[Z]*t[$]*t[j]*t[N]-t[Q]*t[U]*t[W]*t[N]+t[H]*t[$]*t[W]*t[N]+t[Z]*t[U]*t[tt]*t[N]-t[H]*t[K]*t[tt]*t[N]-t[Q]*t[K]*t[G]*t[z]+t[Z]*t[$]*t[G]*t[z]+t[Q]*t[q]*t[W]*t[z]-t[V]*t[$]*t[W]*t[z]-t[Z]*t[q]*t[tt]*t[z]+t[V]*t[K]*t[tt]*t[z]+t[Q]*t[U]*t[G]*t[_]-t[H]*t[$]*t[G]*t[_]-t[Q]*t[q]*t[j]*t[_]+t[V]*t[$]*t[j]*t[_]+t[H]*t[q]*t[tt]*t[_]-t[V]*t[U]*t[tt]*t[_]-t[Z]*t[U]*t[G]*t[J]+t[H]*t[K]*t[G]*t[J]+t[Z]*t[q]*t[j]*t[J]-t[V]*t[K]*t[j]*t[J]-t[H]*t[q]*t[W]*t[J]+t[V]*t[U]*t[W]*t[J]}translate(t,e,i){let s=this.values;return s[N]+=t,s[z]+=e,s[_]+=i,this}copy(){return new Et().set(this.values)}projection(t,e,i,s){this.identity();let n=1/Math.tan(i*(Math.PI/180)/2),c=(e+t)/(t-e),a=2*e*t/(t-e),r=this.values;return r[V]=n/s,r[H]=0,r[Z]=0,r[Q]=0,r[q]=0,r[U]=n,r[K]=0,r[$]=0,r[G]=0,r[j]=0,r[W]=c,r[tt]=-1,r[N]=0,r[z]=0,r[_]=a,r[J]=0,this}ortho2d(t,e,i,s){return this.ortho(t,t+i,e,e+s,0,1)}ortho(t,e,i,s,n,c){this.identity();let a=2/(e-t),r=2/(s-i),o=-2/(c-n),l=-(e+t)/(e-t),h=-(s+i)/(s-i),d=-(c+n)/(c-n),f=this.values;return f[V]=a,f[H]=0,f[Z]=0,f[Q]=0,f[q]=0,f[U]=r,f[K]=0,f[$]=0,f[G]=0,f[j]=0,f[W]=o,f[tt]=0,f[N]=l,f[z]=h,f[_]=d,f[J]=1,this}multiply(t){let e=this.temp,i=this.values,s=t.values;return e[V]=i[V]*s[V]+i[q]*s[H]+i[G]*s[Z]+i[N]*s[Q],e[q]=i[V]*s[q]+i[q]*s[U]+i[G]*s[K]+i[N]*s[$],e[G]=i[V]*s[G]+i[q]*s[j]+i[G]*s[W]+i[N]*s[tt],e[N]=i[V]*s[N]+i[q]*s[z]+i[G]*s[_]+i[N]*s[J],e[H]=i[H]*s[V]+i[U]*s[H]+i[j]*s[Z]+i[z]*s[Q],e[U]=i[H]*s[q]+i[U]*s[U]+i[j]*s[K]+i[z]*s[$],e[j]=i[H]*s[G]+i[U]*s[j]+i[j]*s[W]+i[z]*s[tt],e[z]=i[H]*s[N]+i[U]*s[z]+i[j]*s[_]+i[z]*s[J],e[Z]=i[Z]*s[V]+i[K]*s[H]+i[W]*s[Z]+i[_]*s[Q],e[K]=i[Z]*s[q]+i[K]*s[U]+i[W]*s[K]+i[_]*s[$],e[W]=i[Z]*s[G]+i[K]*s[j]+i[W]*s[W]+i[_]*s[tt],e[_]=i[Z]*s[N]+i[K]*s[z]+i[W]*s[_]+i[_]*s[J],e[Q]=i[Q]*s[V]+i[$]*s[H]+i[tt]*s[Z]+i[J]*s[Q],e[$]=i[Q]*s[q]+i[$]*s[U]+i[tt]*s[K]+i[J]*s[$],e[tt]=i[Q]*s[G]+i[$]*s[j]+i[tt]*s[W]+i[J]*s[tt],e[J]=i[Q]*s[N]+i[$]*s[z]+i[tt]*s[_]+i[J]*s[J],this.set(this.temp)}multiplyLeft(t){let e=this.temp,i=this.values,s=t.values;return e[V]=s[V]*i[V]+s[q]*i[H]+s[G]*i[Z]+s[N]*i[Q],e[q]=s[V]*i[q]+s[q]*i[U]+s[G]*i[K]+s[N]*i[$],e[G]=s[V]*i[G]+s[q]*i[j]+s[G]*i[W]+s[N]*i[tt],e[N]=s[V]*i[N]+s[q]*i[z]+s[G]*i[_]+s[N]*i[J],e[H]=s[H]*i[V]+s[U]*i[H]+s[j]*i[Z]+s[z]*i[Q],e[U]=s[H]*i[q]+s[U]*i[U]+s[j]*i[K]+s[z]*i[$],e[j]=s[H]*i[G]+s[U]*i[j]+s[j]*i[W]+s[z]*i[tt],e[z]=s[H]*i[N]+s[U]*i[z]+s[j]*i[_]+s[z]*i[J],e[Z]=s[Z]*i[V]+s[K]*i[H]+s[W]*i[Z]+s[_]*i[Q],e[K]=s[Z]*i[q]+s[K]*i[U]+s[W]*i[K]+s[_]*i[$],e[W]=s[Z]*i[G]+s[K]*i[j]+s[W]*i[W]+s[_]*i[tt],e[_]=s[Z]*i[N]+s[K]*i[z]+s[W]*i[_]+s[_]*i[J],e[Q]=s[Q]*i[V]+s[$]*i[H]+s[tt]*i[Z]+s[J]*i[Q],e[$]=s[Q]*i[q]+s[$]*i[U]+s[tt]*i[K]+s[J]*i[$],e[tt]=s[Q]*i[G]+s[$]*i[j]+s[tt]*i[W]+s[J]*i[tt],e[J]=s[Q]*i[N]+s[$]*i[z]+s[tt]*i[_]+s[J]*i[J],this.set(this.temp)}lookAt(t,e,i){let s=Et.xAxis,n=Et.yAxis,c=Et.zAxis;c.setFrom(e).normalize(),s.setFrom(e).normalize(),s.cross(i).normalize(),n.setFrom(s).cross(c).normalize(),this.identity();let a=this.values;return a[V]=s.x,a[q]=s.y,a[G]=s.z,a[H]=n.x,a[U]=n.y,a[j]=n.z,a[Z]=-c.x,a[K]=-c.y,a[W]=-c.z,Et.tmpMatrix.identity(),Et.tmpMatrix.values[N]=-t.x,Et.tmpMatrix.values[z]=-t.y,Et.tmpMatrix.values[_]=-t.z,this.multiply(Et.tmpMatrix),this}},Pt=Et;Pt.xAxis=new yt,Pt.yAxis=new yt,Pt.zAxis=new yt,Pt.tmpMatrix=new Et;var us=class{constructor(t,e){this.position=new yt(0,0,0),this.direction=new yt(0,0,-1),this.up=new yt(0,1,0),this.near=0,this.far=100,this.zoom=1,this.viewportWidth=0,this.viewportHeight=0,this.projectionView=new Pt,this.inverseProjectionView=new Pt,this.projection=new Pt,this.view=new Pt,this.viewportWidth=t,this.viewportHeight=e,this.update()}update(){let t=this.projection,e=this.view,i=this.projectionView,s=this.inverseProjectionView,n=this.zoom,c=this.viewportWidth,a=this.viewportHeight;t.ortho(n*(-c/2),n*(c/2),n*(-a/2),n*(a/2),this.near,this.far),e.lookAt(this.position,this.direction,this.up),i.set(t.values),i.multiply(e),s.set(i.values).invert()}screenToWorld(t,e,i){let s=t.x,n=i-t.y-1;return t.x=2*s/e-1,t.y=2*n/i-1,t.z=2*t.z-1,t.project(this.inverseProjectionView),t}worldToScreen(t,e,i){return t.project(this.projectionView),t.x=e*(t.x+1)/2,t.y=i*(t.y+1)/2,t.z=(t.z+1)/2,t}setViewport(t,e){this.viewportWidth=t,this.viewportHeight=e}},Yi=class{constructor(t){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=t,this.setupCallbacks(t)}setupCallbacks(t){let e=a=>{if(a instanceof MouseEvent){let r=t.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=t.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=t.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)})};t.addEventListener("mousedown",e,!0),t.addEventListener("mousemove",i,!0),t.addEventListener("mouseup",s,!0),t.addEventListener("wheel",n,!0),t.addEventListener("touchstart",a=>{if(!this.touch0||!this.touch1){var r=a.changedTouches;let o=r.item(0);if(!o)return;let l=t.getBoundingClientRect(),h=o.clientX-l.left,d=o.clientY-l.top,f=new ms(o.identifier,h,d);if(this.mouseX=h,this.mouseY=d,this.buttonDown=!0,!this.touch0)this.touch0=f,this.listeners.map(u=>{u.down&&u.down(f.x,f.y)});else if(!this.touch1){this.touch1=f;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),t.addEventListener("touchmove",a=>{if(this.touch0){var r=a.changedTouches;let h=t.getBoundingClientRect();for(var o=0;o<r.length;o++){var l=r[o];let d=l.clientX-h.left,f=l.clientY-h.top;this.touch0.identifier===l.identifier&&(this.touch0.x=this.mouseX=d,this.touch0.y=this.mouseY=f,this.listeners.map(u=>{u.dragged&&u.dragged(d,f)})),this.touch1&&this.touch1.identifier===l.identifier&&(this.touch1.x=this.mouseX=d,this.touch1.y=this.mouseY=f)}if(this.touch0&&this.touch1){let d=this.touch1.x-this.touch0.x,f=this.touch1.x-this.touch0.x,u=Math.sqrt(d*d+f*f);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=t.getBoundingClientRect();for(var o=0;o<r.length;o++){var l=r[o];let d=l.clientX-h.left,f=l.clientY-h.top;if(this.touch0.identifier===l.identifier)if(this.touch0=null,this.mouseX=d,this.mouseY=f,this.listeners.map(u=>{u.up&&u.up(d,f)}),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()};t.addEventListener("touchend",c,!1),t.addEventListener("touchcancel",c)}addListener(t){this.listeners.push(t)}removeListener(t){let e=this.listeners.indexOf(t);e>-1&&this.listeners.splice(e,1)}},ms=class{constructor(t,e,i){this.identifier=t,this.x=e,this.y=i}},gr=class{constructor(t,e){this.canvas=t,this.camera=e;let i=0,s=0,n=0,c=0,a=0,r=0,o=0,l=0;new Yi(t).addListener({down:(h,d)=>{i=e.position.x,s=e.position.y,c=r=h,a=o=d,l=e.zoom},dragged:(h,d)=>{let f=h-c,u=d-a,m=e.screenToWorld(new yt(0,0),t.clientWidth,t.clientHeight),x=e.screenToWorld(new yt(f,u),t.clientWidth,t.clientHeight).sub(m);e.position.set(i-x.x,s-x.y,0),e.update(),r=h,o=d},wheel:h=>{let d=h/200*e.zoom,f=e.zoom+d;if(f>0){let u=0,m=0;if(h<0)u=r,m=o;else{let v=new yt(t.clientWidth/2+15,t.clientHeight/2),g=r-v.x,w=t.clientHeight-1-o-v.y;u=v.x-g,m=t.clientHeight-1-v.y+w}let x=e.screenToWorld(new yt(u,m),t.clientWidth,t.clientHeight);e.zoom=f,e.update();let p=e.screenToWorld(new yt(u,m),t.clientWidth,t.clientHeight);e.position.add(x.sub(p)),e.update()}},zoom:(h,d)=>{let f=h/d;e.zoom=l*f},up:(h,d)=>{r=h,o=d},moved:(h,d)=>{r=h,o=d}})}},ft=class{constructor(t,e,i){this.vertexShader=e,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=e,this.fsSource=i,this.context=t instanceof xt?t:new xt(t),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 t=this.context.gl;try{if(this.vs=this.compileShader(t.VERTEX_SHADER,this.vertexShader),!this.vs)throw new Error("Couldn't compile vertex shader.");if(this.fs=this.compileShader(t.FRAGMENT_SHADER,this.fragmentShader),!this.fs)throw new Error("Couldn#t compile fragment shader.");this.program=this.compileProgram(this.vs,this.fs)}catch(e){throw this.dispose(),e}}compileShader(t,e){let i=this.context.gl,s=i.createShader(t);if(!s)throw new Error("Couldn't create shader.");if(i.shaderSource(s,e),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(t,e){let i=this.context.gl,s=i.createProgram();if(!s)throw new Error("Couldn't compile program.");if(i.attachShader(s,t),i.attachShader(s,e),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(t,e){this.context.gl.uniform1i(this.getUniformLocation(t),e)}setUniformf(t,e){this.context.gl.uniform1f(this.getUniformLocation(t),e)}setUniform2f(t,e,i){this.context.gl.uniform2f(this.getUniformLocation(t),e,i)}setUniform3f(t,e,i,s){this.context.gl.uniform3f(this.getUniformLocation(t),e,i,s)}setUniform4f(t,e,i,s,n){this.context.gl.uniform4f(this.getUniformLocation(t),e,i,s,n)}setUniform2x2f(t,e){let i=this.context.gl;this.tmp2x2.set(e),i.uniformMatrix2fv(this.getUniformLocation(t),!1,this.tmp2x2)}setUniform3x3f(t,e){let i=this.context.gl;this.tmp3x3.set(e),i.uniformMatrix3fv(this.getUniformLocation(t),!1,this.tmp3x3)}setUniform4x4f(t,e){let i=this.context.gl;this.tmp4x4.set(e),i.uniformMatrix4fv(this.getUniformLocation(t),!1,this.tmp4x4)}getUniformLocation(t){let e=this.context.gl;if(!this.program)throw new Error("Shader not compiled.");let i=e.getUniformLocation(this.program,t);if(!i&&!e.isContextLost())throw new Error(`Couldn't find location for uniform ${t}`);return i}getAttributeLocation(t){let e=this.context.gl;if(!this.program)throw new Error("Shader not compiled.");let i=e.getAttribLocation(this.program,t);if(i==-1&&!e.isContextLost())throw new Error(`Couldn't find location for attribute ${t}`);return i}dispose(){this.context.removeRestorable(this);let t=this.context.gl;this.vs&&(t.deleteShader(this.vs),this.vs=null),this.fs&&(t.deleteShader(this.fs),this.fs=null),this.program&&(t.deleteProgram(this.program),this.program=null)}static newColoredTextured(t){let e=`
3
- attribute vec4 ${ft.POSITION};
4
- attribute vec4 ${ft.COLOR};
5
- attribute vec2 ${ft.TEXCOORDS};
6
- uniform mat4 ${ft.MVP_MATRIX};
1
+ "use strict";var spine=(()=>{var Ve=Object.defineProperty,Is=Object.getOwnPropertyDescriptor,Ms=Object.getOwnPropertyNames,Ys=Object.prototype.hasOwnProperty,Es=(t,e)=>{for(var i in e)Ve(t,i,{get:e[i],enumerable:!0})},ks=(t,e,i,s)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of Ms(e))!Ys.call(t,n)&&n!==i&&Ve(t,n,{get:()=>e[n],enumerable:!(s=Is(e,n))||s.enumerable});return t},Rs=t=>ks(Ve({},"__esModule",{value:!0}),t),Oi={};Es(Oi,{AlphaTimeline:()=>ei,Animation:()=>ge,AnimationState:()=>ji,AnimationStateAdapter:()=>Ps,AnimationStateData:()=>Ds,AssetManager:()=>us,AssetManagerBase:()=>rs,AtlasAttachmentLoader:()=>Ns,Attachment:()=>_e,AttachmentTimeline:()=>Wt,BinaryInput:()=>cs,BlendMode:()=>Ye,Bone:()=>wi,BoneData:()=>xi,BoundingBoxAttachment:()=>ve,CURRENT:()=>Qi,CameraController:()=>gr,ClippingAttachment:()=>le,Color:()=>O,Color2Attribute:()=>gs,ColorAttribute:()=>Fe,ConstraintData:()=>Ce,CurveTimeline:()=>Tt,CurveTimeline1:()=>It,CurveTimeline2:()=>xe,DebugUtils:()=>Ls,DeformTimeline:()=>ri,Downloader:()=>bi,DrawOrderTimeline:()=>qt,Event:()=>pi,EventData:()=>vi,EventQueue:()=>Ki,EventTimeline:()=>ae,EventType:()=>pt,FIRST:()=>ci,FakeTexture:()=>Os,GLTexture:()=>ce,HOLD_FIRST:()=>pe,HOLD_MIX:()=>Ji,HOLD_SUBSEQUENT:()=>di,IkConstraint:()=>ns,IkConstraintData:()=>yi,IkConstraintTimeline:()=>ni,Input:()=>Ei,IntSet:()=>Fs,Interpolation:()=>Vi,LoadingScreen:()=>pr,M00:()=>V,M01:()=>q,M02:()=>G,M03:()=>N,M10:()=>H,M11:()=>U,M12:()=>j,M13:()=>_,M20:()=>Z,M21:()=>K,M22:()=>z,M23:()=>W,M30:()=>Q,M31:()=>$,M32:()=>tt,M33:()=>J,ManagedWebGLRenderingContext:()=>xt,MathUtils:()=>X,Matrix4:()=>Dt,Mesh:()=>ki,MeshAttachment:()=>Vt,MixBlend:()=>Wi,MixDirection:()=>qi,OrthoCamera:()=>fs,PathAttachment:()=>Gt,PathConstraint:()=>Jt,PathConstraintData:()=>Ai,PathConstraintMixTimeline:()=>hi,PathConstraintPositionTimeline:()=>li,PathConstraintSpacingTimeline:()=>oi,PointAttachment:()=>gi,PolygonBatcher:()=>de,Pool:()=>re,Position2Attribute:()=>Re,Position3Attribute:()=>xr,PositionMode:()=>Se,Pow:()=>Ni,PowOut:()=>Xs,RGB2Timeline:()=>si,RGBA2Timeline:()=>ii,RGBATimeline:()=>$e,RGBTimeline:()=>ti,RegionAttachment:()=>at,ResizeMode:()=>Pe,RotateMode:()=>Ie,RotateTimeline:()=>ne,SETUP:()=>ui,SUBSEQUENT:()=>be,ScaleTimeline:()=>He,ScaleXTimeline:()=>je,ScaleYTimeline:()=>Ze,SceneRenderer:()=>ws,SequenceTimeline:()=>Kt,Shader:()=>mt,ShapeRenderer:()=>Fi,ShapeType:()=>bt,ShearTimeline:()=>Ke,ShearXTimeline:()=>Je,ShearYTimeline:()=>Qe,Skeleton:()=>hs,SkeletonBinary:()=>Us,SkeletonBounds:()=>ds,SkeletonClipping:()=>Ee,SkeletonData:()=>Ci,SkeletonDebugRenderer:()=>Xe,SkeletonJson:()=>dr,SkeletonRenderer:()=>Li,Skin:()=>Me,SkinEntry:()=>Si,Slot:()=>as,SlotData:()=>Ti,SpacingMode:()=>Te,SpineCanvas:()=>Ar,StringSet:()=>Ne,TexCoordAttribute:()=>Ri,Texture:()=>fi,TextureAtlas:()=>es,TextureAtlasPage:()=>is,TextureAtlasRegion:()=>mi,TextureFilter:()=>ye,TextureRegion:()=>ts,TextureWrap:()=>$i,TimeKeeper:()=>Ue,Timeline:()=>ft,Touch:()=>ms,TrackEntry:()=>Zi,TransformConstraint:()=>ls,TransformConstraintData:()=>Ii,TransformConstraintTimeline:()=>ai,TransformMode:()=>Ae,TranslateTimeline:()=>We,TranslateXTimeline:()=>qe,TranslateYTimeline:()=>Ge,Triangulator:()=>vt,Utils:()=>B,Vector2:()=>zt,Vector3:()=>yt,VertexAttachment:()=>St,VertexAttribute:()=>Qt,VertexAttributeType:()=>Ht,WebGLBlendModeConverter:()=>he,WindowedMean:()=>Bs});var Fs=class{constructor(){this.array=new Array}add(t){let e=this.contains(t);return this.array[t|0]=t|0,!e}contains(t){return this.array[t|0]!=null}remove(t){this.array[t|0]=void 0}clear(){this.array.length=0}},Ne=class{constructor(){this.entries={},this.size=0}add(t){let e=this.entries[t];return this.entries[t]=!0,e?!1:(this.size++,!0)}addAll(t){let e=this.size;for(var i=0,s=t.length;i<s;i++)this.add(t[i]);return e!=this.size}contains(t){return this.entries[t]}clear(){this.entries={},this.size=0}},_t=class{constructor(t=0,e=0,i=0,s=0){this.r=t,this.g=e,this.b=i,this.a=s}set(t,e,i,s){return this.r=t,this.g=e,this.b=i,this.a=s,this.clamp()}setFromColor(t){return this.r=t.r,this.g=t.g,this.b=t.b,this.a=t.a,this}setFromString(t){return t=t.charAt(0)=="#"?t.substr(1):t,this.r=parseInt(t.substr(0,2),16)/255,this.g=parseInt(t.substr(2,2),16)/255,this.b=parseInt(t.substr(4,2),16)/255,this.a=t.length!=8?1:parseInt(t.substr(6,2),16)/255,this}add(t,e,i,s){return this.r+=t,this.g+=e,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(t,e){t.r=((e&4278190080)>>>24)/255,t.g=((e&16711680)>>>16)/255,t.b=((e&65280)>>>8)/255,t.a=(e&255)/255}static rgb888ToColor(t,e){t.r=((e&16711680)>>>16)/255,t.g=((e&65280)>>>8)/255,t.b=(e&255)/255}static fromString(t){return new _t().setFromString(t)}},O=_t;O.WHITE=new _t(1,1,1,1),O.RED=new _t(1,0,0,1),O.GREEN=new _t(0,1,0,1),O.BLUE=new _t(0,0,1,1),O.MAGENTA=new _t(1,0,1,1);var Xt=class{static clamp(t,e,i){return t<e?e:t>i?i:t}static cosDeg(t){return Math.cos(t*Xt.degRad)}static sinDeg(t){return Math.sin(t*Xt.degRad)}static signum(t){return t>0?1:t<0?-1:0}static toInt(t){return t>0?Math.floor(t):Math.ceil(t)}static cbrt(t){let e=Math.pow(Math.abs(t),.3333333333333333);return t<0?-e:e}static randomTriangular(t,e){return Xt.randomTriangularWith(t,e,(t+e)*.5)}static randomTriangularWith(t,e,i){let s=Math.random(),n=e-t;return s<=(i-t)/n?t+Math.sqrt(s*n*(i-t)):e-Math.sqrt((1-s)*n*(e-i))}static isPowerOfTwo(t){return t&&(t&t-1)===0}},X=Xt;X.PI=3.1415927,X.PI2=Xt.PI*2,X.radiansToDegrees=180/Xt.PI,X.radDeg=Xt.radiansToDegrees,X.degreesToRadians=Xt.PI/180,X.degRad=Xt.degreesToRadians;var Vi=class{apply(t,e,i){return t+(e-t)*this.applyInternal(i)}},Ni=class extends Vi{constructor(t){super(),this.power=2,this.power=t}applyInternal(t){return t<=.5?Math.pow(t*2,this.power)/2:Math.pow((t-1)*2,this.power)/(this.power%2==0?-2:2)+1}},Xs=class extends Ni{constructor(t){super(t)}applyInternal(t){return Math.pow(t-1,this.power)*(this.power%2==0?-1:1)+1}},Zt=class{static arrayCopy(t,e,i,s,n){for(let c=e,a=s;c<e+n;c++,a++)i[a]=t[c]}static arrayFill(t,e,i,s){for(let n=e;n<i;n++)t[n]=s}static setArraySize(t,e,i=0){let s=t.length;if(s==e)return t;if(t.length=e,s<e)for(let n=s;n<e;n++)t[n]=i;return t}static ensureArrayCapacity(t,e,i=0){return t.length>=e?t:Zt.setArraySize(t,e,i)}static newArray(t,e){let i=new Array(t);for(let s=0;s<t;s++)i[s]=e;return i}static newFloatArray(t){if(Zt.SUPPORTS_TYPED_ARRAYS)return new Float32Array(t);{let e=new Array(t);for(let i=0;i<e.length;i++)e[i]=0;return e}}static newShortArray(t){if(Zt.SUPPORTS_TYPED_ARRAYS)return new Int16Array(t);{let e=new Array(t);for(let i=0;i<e.length;i++)e[i]=0;return e}}static toFloatArray(t){return Zt.SUPPORTS_TYPED_ARRAYS?new Float32Array(t):t}static toSinglePrecision(t){return Zt.SUPPORTS_TYPED_ARRAYS?Math.fround(t):t}static webkit602BugfixHelper(t,e){}static contains(t,e,i=!0){for(var s=0;s<t.length;s++)if(t[s]==e)return!0;return!1}static enumValue(t,e){return t[e[0].toUpperCase()+e.slice(1)]}},B=Zt;B.SUPPORTS_TYPED_ARRAYS=typeof Float32Array!="undefined";var Ls=class{static logBones(t){for(let e=0;e<t.bones.length;e++){let i=t.bones[e];console.log(i.data.name+", "+i.a+", "+i.b+", "+i.c+", "+i.d+", "+i.worldX+", "+i.worldY)}}},re=class{constructor(t){this.items=new Array,this.instantiator=t}obtain(){return this.items.length>0?this.items.pop():this.instantiator()}free(t){t.reset&&t.reset(),this.items.push(t)}freeAll(t){for(let e=0;e<t.length;e++)this.free(t[e])}clear(){this.items.length=0}},zt=class{constructor(t=0,e=0){this.x=t,this.y=e}set(t,e){return this.x=t,this.y=e,this}length(){let t=this.x,e=this.y;return Math.sqrt(t*t+e*e)}normalize(){let t=this.length();return t!=0&&(this.x/=t,this.y/=t),this}},Ue=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 t=Date.now()/1e3;this.delta=t-this.lastTime,this.frameTime+=this.delta,this.totalTime+=this.delta,this.delta>this.maxDelta&&(this.delta=this.maxDelta),this.lastTime=t,this.frameCount++,this.frameTime>1&&(this.framesPerSecond=this.frameCount/this.frameTime,this.frameTime=0,this.frameCount=0)}},Bs=class{constructor(t=32){this.addedValues=0,this.lastValue=0,this.mean=0,this.dirty=!0,this.values=new Array(t)}hasEnoughData(){return this.addedValues>=this.values.length}addValue(t){this.addedValues<this.values.length&&this.addedValues++,this.values[this.lastValue++]=t,this.lastValue>this.values.length-1&&(this.lastValue=0),this.dirty=!0}getMean(){if(this.hasEnoughData()){if(this.dirty){let t=0;for(let e=0;e<this.values.length;e++)t+=this.values[e];this.mean=t/this.values.length,this.dirty=!1}return this.mean}return 0}},_e=class{constructor(t){if(!t)throw new Error("name cannot be null.");this.name=t}},Ui=class extends _e{constructor(t){super(t),this.id=Ui.nextID++,this.bones=null,this.vertices=[],this.worldVerticesLength=0,this.timelineAttachment=this}computeWorldVertices(t,e,i,s,n,c){i=n+(i>>1)*c;let a=t.bone.skeleton,r=t.deform,o=this.vertices,l=this.bones;if(!l){r.length>0&&(o=r);let f=t.bone,m=f.worldX,x=f.worldY,p=f.a,v=f.b,g=f.c,w=f.d;for(let b=e,y=n;y<i;b+=2,y+=c){let A=o[b],C=o[b+1];s[y]=A*p+C*v+m,s[y+1]=A*g+C*w+x}return}let h=0,d=0;for(let f=0;f<e;f+=2){let m=l[h];h+=m+1,d+=m}let u=a.bones;if(r.length==0)for(let f=n,m=d*3;f<i;f+=c){let x=0,p=0,v=l[h++];for(v+=h;h<v;h++,m+=3){let g=u[l[h]],w=o[m],b=o[m+1],y=o[m+2];x+=(w*g.a+b*g.b+g.worldX)*y,p+=(w*g.c+b*g.d+g.worldY)*y}s[f]=x,s[f+1]=p}else{let f=r;for(let m=n,x=d*3,p=d<<1;m<i;m+=c){let v=0,g=0,w=l[h++];for(w+=h;h<w;h++,x+=3,p+=2){let b=u[l[h]],y=o[x]+f[p],A=o[x+1]+f[p+1],C=o[x+2];v+=(y*b.a+A*b.b+b.worldX)*C,g+=(y*b.c+A*b.d+b.worldY)*C}s[m]=v,s[m+1]=g}}}copyTo(t){this.bones?(t.bones=new Array(this.bones.length),B.arrayCopy(this.bones,0,t.bones,0,this.bones.length)):t.bones=null,this.vertices&&(t.vertices=B.newFloatArray(this.vertices.length),B.arrayCopy(this.vertices,0,t.vertices,0,this.vertices.length)),t.worldVerticesLength=this.worldVerticesLength,t.timelineAttachment=this.timelineAttachment}},St=Ui;St.nextID=0;var me=class{constructor(t){this.id=me.nextID(),this.start=0,this.digits=0,this.setupIndex=0,this.regions=new Array(t)}copy(){let t=new me(this.regions.length);return B.arrayCopy(this.regions,0,t.regions,0,this.regions.length),t.start=this.start,t.digits=this.digits,t.setupIndex=this.setupIndex,t}apply(t,e){let i=t.sequenceIndex;i==-1&&(i=this.setupIndex),i>=this.regions.length&&(i=this.regions.length-1);let s=this.regions[i];e.region!=s&&(e.region=s,e.updateRegion())}getPath(t,e){let i=t,s=(this.start+e).toString();for(let n=this.digits-s.length;n>0;n--)i+="0";return i+=s,i}static nextID(){return me._nextID++}},ze=me;ze._nextID=0;var _i=(t=>(t[t.hold=0]="hold",t[t.once=1]="once",t[t.loop=2]="loop",t[t.pingpong=3]="pingpong",t[t.onceReverse=4]="onceReverse",t[t.loopReverse=5]="loopReverse",t[t.pingpongReverse=6]="pingpongReverse",t))(_i||{}),zi=[0,1,2,3,4,5,6],ge=class{constructor(t,e,i){if(this.timelines=[],this.timelineIds=new Ne,!t)throw new Error("name cannot be null.");this.name=t,this.setTimelines(e),this.duration=i}setTimelines(t){if(!t)throw new Error("timelines cannot be null.");this.timelines=t,this.timelineIds.clear();for(var e=0;e<t.length;e++)this.timelineIds.addAll(t[e].getPropertyIds())}hasTimeline(t){for(let e=0;e<t.length;e++)if(this.timelineIds.contains(t[e]))return!0;return!1}apply(t,e,i,s,n,c,a,r){if(!t)throw new Error("skeleton cannot be null.");s&&this.duration!=0&&(i%=this.duration,e>0&&(e%=this.duration));let o=this.timelines;for(let l=0,h=o.length;l<h;l++)o[l].apply(t,e,i,n,c,a,r)}},Wi=(t=>(t[t.setup=0]="setup",t[t.first=1]="first",t[t.replace=2]="replace",t[t.add=3]="add",t))(Wi||{}),qi=(t=>(t[t.mixIn=0]="mixIn",t[t.mixOut=1]="mixOut",t))(qi||{}),ct={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},ft=class{constructor(t,e){this.propertyIds=e,this.frames=B.newFloatArray(t*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(t,e){let i=t.length;for(let s=1;s<i;s++)if(t[s]>e)return s-1;return i-1}static search(t,e,i){let s=t.length;for(let n=i;n<s;n+=i)if(t[n]>e)return n-i;return s-i}},Tt=class extends ft{constructor(t,e,i){super(t,i),this.curves=B.newFloatArray(t+e*18),this.curves[t-1]=1}setLinear(t){this.curves[t]=0}setStepped(t){this.curves[t]=1}shrink(t){let e=this.getFrameCount()+t*18;if(this.curves.length>e){let i=B.newFloatArray(e);B.arrayCopy(this.curves,0,i,0,e),this.curves=i}}setBezier(t,e,i,s,n,c,a,r,o,l,h){let d=this.curves,u=this.getFrameCount()+t*18;i==0&&(d[e]=2+u);let f=(s-c*2+r)*.03,m=(n-a*2+o)*.03,x=((c-r)*3-s+l)*.006,p=((a-o)*3-n+h)*.006,v=f*2+x,g=m*2+p,w=(c-s)*.3+f+x*.16666667,b=(a-n)*.3+m+p*.16666667,y=s+w,A=n+b;for(let C=u+18;u<C;u+=2)d[u]=y,d[u+1]=A,w+=v,b+=g,v+=x,g+=p,y+=w,A+=b}getBezierValue(t,e,i,s){let n=this.curves;if(n[s]>t){let o=this.frames[e],l=this.frames[e+i];return l+(t-o)/(n[s]-o)*(n[s+1]-l)}let c=s+18;for(s+=2;s<c;s+=2)if(n[s]>=t){let o=n[s-2],l=n[s-1];return l+(t-o)/(n[s]-o)*(n[s+1]-l)}e+=this.getFrameEntries();let a=n[c-2],r=n[c-1];return r+(t-a)/(this.frames[e]-a)*(this.frames[e+i]-r)}},It=class extends Tt{constructor(t,e,i){super(t,e,[i])}getFrameEntries(){return 2}setFrame(t,e,i){t<<=1,this.frames[t]=e,this.frames[t+1]=i}getCurveValue(t){let e=this.frames,i=e.length-2;for(let n=2;n<=i;n+=2)if(e[n]>t){i=n-2;break}let s=this.curves[i>>1];switch(s){case 0:let n=e[i],c=e[i+1];return c+(t-n)/(e[i+2]-n)*(e[i+2+1]-c);case 1:return e[i+1]}return this.getBezierValue(t,i,1,s-2)}},xe=class extends Tt{constructor(t,e,i,s){super(t,e,[i,s])}getFrameEntries(){return 3}setFrame(t,e,i,s){t*=3,this.frames[t]=e,this.frames[t+1]=i,this.frames[t+2]=s}},ne=class extends It{constructor(t,e,i){super(t,e,ct.rotate+"|"+i),this.boneIndex=0,this.boneIndex=i}apply(t,e,i,s,n,c,a){let r=t.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}}},We=class extends xe{constructor(t,e,i){super(t,e,ct.x+"|"+i,ct.y+"|"+i),this.boneIndex=0,this.boneIndex=i}apply(t,e,i,s,n,c,a){let r=t.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,d=ft.search(o,i,3),u=this.curves[d/3];switch(u){case 0:let f=o[d];l=o[d+1],h=o[d+2];let m=(i-f)/(o[d+3]-f);l+=(o[d+3+1]-l)*m,h+=(o[d+3+2]-h)*m;break;case 1:l=o[d+1],h=o[d+2];break;default:l=this.getBezierValue(i,d,1,u-2),h=this.getBezierValue(i,d,2,u+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}}},qe=class extends It{constructor(t,e,i){super(t,e,ct.x+"|"+i),this.boneIndex=0,this.boneIndex=i}apply(t,e,i,s,n,c,a){let r=t.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}}},Ge=class extends It{constructor(t,e,i){super(t,e,ct.y+"|"+i),this.boneIndex=0,this.boneIndex=i}apply(t,e,i,s,n,c,a){let r=t.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}}},He=class extends xe{constructor(t,e,i){super(t,e,ct.scaleX+"|"+i,ct.scaleY+"|"+i),this.boneIndex=0,this.boneIndex=i}apply(t,e,i,s,n,c,a){let r=t.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,d=ft.search(o,i,3),u=this.curves[d/3];switch(u){case 0:let f=o[d];l=o[d+1],h=o[d+2];let m=(i-f)/(o[d+3]-f);l+=(o[d+3+1]-l)*m,h+=(o[d+3+2]-h)*m;break;case 1:l=o[d+1],h=o[d+2];break;default:l=this.getBezierValue(i,d,1,u-2),h=this.getBezierValue(i,d,2,u+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 f=0,m=0;if(a==1)switch(c){case 0:f=r.data.scaleX,m=r.data.scaleY,r.scaleX=f+(Math.abs(l)*X.signum(f)-f)*n,r.scaleY=m+(Math.abs(h)*X.signum(m)-m)*n;break;case 1:case 2:f=r.scaleX,m=r.scaleY,r.scaleX=f+(Math.abs(l)*X.signum(f)-f)*n,r.scaleY=m+(Math.abs(h)*X.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:f=Math.abs(r.data.scaleX)*X.signum(l),m=Math.abs(r.data.scaleY)*X.signum(h),r.scaleX=f+(l-f)*n,r.scaleY=m+(h-m)*n;break;case 1:case 2:f=Math.abs(r.scaleX)*X.signum(l),m=Math.abs(r.scaleY)*X.signum(h),r.scaleX=f+(l-f)*n,r.scaleY=m+(h-m)*n;break;case 3:r.scaleX+=(l-r.data.scaleX)*n,r.scaleY+=(h-r.data.scaleY)*n}}}},je=class extends It{constructor(t,e,i){super(t,e,ct.scaleX+"|"+i),this.boneIndex=0,this.boneIndex=i}apply(t,e,i,s,n,c,a){let r=t.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)*X.signum(h)-h)*n;break;case 1:case 2:h=r.scaleX,r.scaleX=h+(Math.abs(l)*X.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)*X.signum(l),r.scaleX=h+(l-h)*n;break;case 1:case 2:h=Math.abs(r.scaleX)*X.signum(l),r.scaleX=h+(l-h)*n;break;case 3:r.scaleX+=(l-r.data.scaleX)*n}}}},Ze=class extends It{constructor(t,e,i){super(t,e,ct.scaleY+"|"+i),this.boneIndex=0,this.boneIndex=i}apply(t,e,i,s,n,c,a){let r=t.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)*X.signum(h)-h)*n;break;case 1:case 2:h=r.scaleY,r.scaleY=h+(Math.abs(l)*X.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)*X.signum(l),r.scaleY=h+(l-h)*n;break;case 1:case 2:h=Math.abs(r.scaleY)*X.signum(l),r.scaleY=h+(l-h)*n;break;case 3:r.scaleY+=(l-r.data.scaleY)*n}}}},Ke=class extends xe{constructor(t,e,i){super(t,e,ct.shearX+"|"+i,ct.shearY+"|"+i),this.boneIndex=0,this.boneIndex=i}apply(t,e,i,s,n,c,a){let r=t.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,d=ft.search(o,i,3),u=this.curves[d/3];switch(u){case 0:let f=o[d];l=o[d+1],h=o[d+2];let m=(i-f)/(o[d+3]-f);l+=(o[d+3+1]-l)*m,h+=(o[d+3+2]-h)*m;break;case 1:l=o[d+1],h=o[d+2];break;default:l=this.getBezierValue(i,d,1,u-2),h=this.getBezierValue(i,d,2,u+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}}},Je=class extends It{constructor(t,e,i){super(t,e,ct.shearX+"|"+i),this.boneIndex=0,this.boneIndex=i}apply(t,e,i,s,n,c,a){let r=t.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}}},Qe=class extends It{constructor(t,e,i){super(t,e,ct.shearY+"|"+i),this.boneIndex=0,this.boneIndex=i}apply(t,e,i,s,n,c,a){let r=t.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}}},$e=class extends Tt{constructor(t,e,i){super(t,e,[ct.rgb+"|"+i,ct.alpha+"|"+i]),this.slotIndex=0,this.slotIndex=i}getFrameEntries(){return 5}setFrame(t,e,i,s,n,c){t*=5,this.frames[t]=e,this.frames[t+1]=i,this.frames[t+2]=s,this.frames[t+3]=n,this.frames[t+4]=c}apply(t,e,i,s,n,c,a){let r=t.slots[this.slotIndex];if(!r.bone.active)return;let o=this.frames,l=r.color;if(i<o[0]){let p=r.data.color;switch(c){case 0:l.setFromColor(p);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)}return}let h=0,d=0,u=0,f=0,m=ft.search(o,i,5),x=this.curves[m/5];switch(x){case 0:let p=o[m];h=o[m+1],d=o[m+2],u=o[m+3],f=o[m+4];let v=(i-p)/(o[m+5]-p);h+=(o[m+5+1]-h)*v,d+=(o[m+5+2]-d)*v,u+=(o[m+5+3]-u)*v,f+=(o[m+5+4]-f)*v;break;case 1:h=o[m+1],d=o[m+2],u=o[m+3],f=o[m+4];break;default:h=this.getBezierValue(i,m,1,x-2),d=this.getBezierValue(i,m,2,x+18-2),u=this.getBezierValue(i,m,3,x+18*2-2),f=this.getBezierValue(i,m,4,x+18*3-2)}n==1?l.set(h,d,u,f):(c==0&&l.setFromColor(r.data.color),l.add((h-l.r)*n,(d-l.g)*n,(u-l.b)*n,(f-l.a)*n))}},ti=class extends Tt{constructor(t,e,i){super(t,e,[ct.rgb+"|"+i]),this.slotIndex=0,this.slotIndex=i}getFrameEntries(){return 4}setFrame(t,e,i,s,n){t<<=2,this.frames[t]=e,this.frames[t+1]=i,this.frames[t+2]=s,this.frames[t+3]=n}apply(t,e,i,s,n,c,a){let r=t.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,d=0,u=0,f=ft.search(o,i,4),m=this.curves[f>>2];switch(m){case 0:let x=o[f];h=o[f+1],d=o[f+2],u=o[f+3];let p=(i-x)/(o[f+4]-x);h+=(o[f+4+1]-h)*p,d+=(o[f+4+2]-d)*p,u+=(o[f+4+3]-u)*p;break;case 1:h=o[f+1],d=o[f+2],u=o[f+3];break;default:h=this.getBezierValue(i,f,1,m-2),d=this.getBezierValue(i,f,2,m+18-2),u=this.getBezierValue(i,f,3,m+18*2-2)}if(n==1)l.r=h,l.g=d,l.b=u;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+=(d-l.g)*n,l.b+=(u-l.b)*n}}},ei=class extends It{constructor(t,e,i){super(t,e,ct.alpha+"|"+i),this.slotIndex=0,this.slotIndex=i}apply(t,e,i,s,n,c,a){let r=t.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 Tt{constructor(t,e,i){super(t,e,[ct.rgb+"|"+i,ct.alpha+"|"+i,ct.rgb2+"|"+i]),this.slotIndex=0,this.slotIndex=i}getFrameEntries(){return 8}setFrame(t,e,i,s,n,c,a,r,o){t<<=3,this.frames[t]=e,this.frames[t+1]=i,this.frames[t+2]=s,this.frames[t+3]=n,this.frames[t+4]=c,this.frames[t+5]=a,this.frames[t+6]=r,this.frames[t+7]=o}apply(t,e,i,s,n,c,a){let r=t.slots[this.slotIndex];if(!r.bone.active)return;let o=this.frames,l=r.color,h=r.darkColor;if(i<o[0]){let b=r.data.color,y=r.data.darkColor;switch(c){case 0:l.setFromColor(b),h.r=y.r,h.g=y.g,h.b=y.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),h.r+=(y.r-h.r)*n,h.g+=(y.g-h.g)*n,h.b+=(y.b-h.b)*n}return}let d=0,u=0,f=0,m=0,x=0,p=0,v=0,g=ft.search(o,i,8),w=this.curves[g>>3];switch(w){case 0:let b=o[g];d=o[g+1],u=o[g+2],f=o[g+3],m=o[g+4],x=o[g+5],p=o[g+6],v=o[g+7];let y=(i-b)/(o[g+8]-b);d+=(o[g+8+1]-d)*y,u+=(o[g+8+2]-u)*y,f+=(o[g+8+3]-f)*y,m+=(o[g+8+4]-m)*y,x+=(o[g+8+5]-x)*y,p+=(o[g+8+6]-p)*y,v+=(o[g+8+7]-v)*y;break;case 1:d=o[g+1],u=o[g+2],f=o[g+3],m=o[g+4],x=o[g+5],p=o[g+6],v=o[g+7];break;default:d=this.getBezierValue(i,g,1,w-2),u=this.getBezierValue(i,g,2,w+18-2),f=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),p=this.getBezierValue(i,g,6,w+18*5-2),v=this.getBezierValue(i,g,7,w+18*6-2)}if(n==1)l.set(d,u,f,m),h.r=x,h.g=p,h.b=v;else{if(c==0){l.setFromColor(r.data.color);let b=r.data.darkColor;h.r=b.r,h.g=b.g,h.b=b.b}l.add((d-l.r)*n,(u-l.g)*n,(f-l.b)*n,(m-l.a)*n),h.r+=(x-h.r)*n,h.g+=(p-h.g)*n,h.b+=(v-h.b)*n}}},si=class extends Tt{constructor(t,e,i){super(t,e,[ct.rgb+"|"+i,ct.rgb2+"|"+i]),this.slotIndex=0,this.slotIndex=i}getFrameEntries(){return 7}setFrame(t,e,i,s,n,c,a,r){t*=7,this.frames[t]=e,this.frames[t+1]=i,this.frames[t+2]=s,this.frames[t+3]=n,this.frames[t+4]=c,this.frames[t+5]=a,this.frames[t+6]=r}apply(t,e,i,s,n,c,a){let r=t.slots[this.slotIndex];if(!r.bone.active)return;let o=this.frames,l=r.color,h=r.darkColor;if(i<o[0]){let b=r.data.color,y=r.data.darkColor;switch(c){case 0:l.r=b.r,l.g=b.g,l.b=b.b,h.r=y.r,h.g=y.g,h.b=y.b;return;case 1:l.r+=(b.r-l.r)*n,l.g+=(b.g-l.g)*n,l.b+=(b.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 d=0,u=0,f=0,m=0,x=0,p=0,v=0,g=ft.search(o,i,7),w=this.curves[g/7];switch(w){case 0:let b=o[g];d=o[g+1],u=o[g+2],f=o[g+3],x=o[g+4],p=o[g+5],v=o[g+6];let y=(i-b)/(o[g+7]-b);d+=(o[g+7+1]-d)*y,u+=(o[g+7+2]-u)*y,f+=(o[g+7+3]-f)*y,x+=(o[g+7+4]-x)*y,p+=(o[g+7+5]-p)*y,v+=(o[g+7+6]-v)*y;break;case 1:d=o[g+1],u=o[g+2],f=o[g+3],x=o[g+4],p=o[g+5],v=o[g+6];break;default:d=this.getBezierValue(i,g,1,w-2),u=this.getBezierValue(i,g,2,w+18-2),f=this.getBezierValue(i,g,3,w+18*2-2),x=this.getBezierValue(i,g,4,w+18*3-2),p=this.getBezierValue(i,g,5,w+18*4-2),v=this.getBezierValue(i,g,6,w+18*5-2)}if(n==1)l.r=d,l.g=u,l.b=f,h.r=x,h.g=p,h.b=v;else{if(c==0){let b=r.data.color,y=r.data.darkColor;l.r=b.r,l.g=b.g,l.b=b.b,h.r=y.r,h.g=y.g,h.b=y.b}l.r+=(d-l.r)*n,l.g+=(u-l.g)*n,l.b+=(f-l.b)*n,h.r+=(x-h.r)*n,h.g+=(p-h.g)*n,h.b+=(v-h.b)*n}}},Wt=class extends ft{constructor(t,e){super(t,[ct.attachment+"|"+e]),this.slotIndex=0,this.slotIndex=e,this.attachmentNames=new Array(t)}getFrameCount(){return this.frames.length}setFrame(t,e,i){this.frames[t]=e,this.attachmentNames[t]=i}apply(t,e,i,s,n,c,a){let r=t.slots[this.slotIndex];if(r.bone.active){if(a==1){c==0&&this.setAttachment(t,r,r.data.attachmentName);return}if(i<this.frames[0]){(c==0||c==1)&&this.setAttachment(t,r,r.data.attachmentName);return}this.setAttachment(t,r,this.attachmentNames[ft.search1(this.frames,i)])}}setAttachment(t,e,i){e.setAttachment(i?t.getAttachment(this.slotIndex,i):null)}},ri=class extends Tt{constructor(t,e,i,s){super(t,e,[ct.deform+"|"+i+"|"+s.id]),this.slotIndex=0,this.slotIndex=i,this.attachment=s,this.vertices=new Array(t)}getFrameCount(){return this.frames.length}setFrame(t,e,i){this.frames[t]=e,this.vertices[t]=i}setBezier(t,e,i,s,n,c,a,r,o,l,h){let d=this.curves,u=this.getFrameCount()+t*18;i==0&&(d[e]=2+u);let f=(s-c*2+r)*.03,m=o*.03-a*.06,x=((c-r)*3-s+l)*.006,p=(a-o+.33333333)*.018,v=f*2+x,g=m*2+p,w=(c-s)*.3+f+x*.16666667,b=a*.3+m+p*.16666667,y=s+w,A=b;for(let C=u+18;u<C;u+=2)d[u]=y,d[u+1]=A,w+=v,b+=g,v+=x,g+=p,y+=w,A+=b}getCurvePercent(t,e){let i=this.curves,s=i[e];switch(s){case 0:let r=this.frames[e];return(t-r)/(this.frames[e+this.getFrameEntries()]-r);case 1:return 0}if(s-=2,i[s]>t){let r=this.frames[e];return i[s+1]*(t-r)/(i[s]-r)}let n=s+18;for(s+=2;s<n;s+=2)if(i[s]>=t){let r=i[s-2],o=i[s-1];return o+(t-r)/(i[s]-r)*(i[s+1]-o)}let c=i[n-2],a=i[n-1];return a+(1-a)*(t-c)/(this.frames[e+this.getFrameEntries()]-c)}apply(t,e,i,s,n,c,a){let r=t.slots[this.slotIndex];if(!r.bone.active)return;let o=r.getAttachment();if(!o||!(o instanceof St)||o.timelineAttachment!=this.attachment)return;let l=r.deform;l.length==0&&(c=0);let h=this.vertices,d=h[0].length,u=this.frames;if(i<u[0]){switch(c){case 0:l.length=0;return;case 1:if(n==1){l.length=0;return}l.length=d;let g=o;if(g.bones){n=1-n;for(var f=0;f<d;f++)l[f]*=n}else{let w=g.vertices;for(var f=0;f<d;f++)l[f]+=(w[f]-l[f])*n}}return}if(l.length=d,i>=u[u.length-1]){let g=h[u.length-1];if(n==1)if(c==3){let w=o;if(w.bones)for(let b=0;b<d;b++)l[b]+=g[b];else{let b=w.vertices;for(let y=0;y<d;y++)l[y]+=g[y]-b[y]}}else B.arrayCopy(g,0,l,0,d);else switch(c){case 0:{let b=o;if(b.bones)for(let y=0;y<d;y++)l[y]=g[y]*n;else{let y=b.vertices;for(let A=0;A<d;A++){let C=y[A];l[A]=C+(g[A]-C)*n}}break}case 1:case 2:for(let b=0;b<d;b++)l[b]+=(g[b]-l[b])*n;break;case 3:let w=o;if(w.bones)for(let b=0;b<d;b++)l[b]+=g[b]*n;else{let b=w.vertices;for(let y=0;y<d;y++)l[y]+=(g[y]-b[y])*n}}return}let m=ft.search1(u,i),x=this.getCurvePercent(i,m),p=h[m],v=h[m+1];if(n==1)if(c==3){let g=o;if(g.bones)for(let w=0;w<d;w++){let b=p[w];l[w]+=b+(v[w]-b)*x}else{let w=g.vertices;for(let b=0;b<d;b++){let y=p[b];l[b]+=y+(v[b]-y)*x-w[b]}}}else for(let g=0;g<d;g++){let w=p[g];l[g]=w+(v[g]-w)*x}else switch(c){case 0:{let w=o;if(w.bones)for(let b=0;b<d;b++){let y=p[b];l[b]=(y+(v[b]-y)*x)*n}else{let b=w.vertices;for(let y=0;y<d;y++){let A=p[y],C=b[y];l[y]=C+(A+(v[y]-A)*x-C)*n}}break}case 1:case 2:for(let w=0;w<d;w++){let b=p[w];l[w]+=(b+(v[w]-b)*x-l[w])*n}break;case 3:let g=o;if(g.bones)for(let w=0;w<d;w++){let b=p[w];l[w]+=(b+(v[w]-b)*x)*n}else{let w=g.vertices;for(let b=0;b<d;b++){let y=p[b];l[b]+=(y+(v[b]-y)*x-w[b])*n}}}}},Gi=class extends ft{constructor(t){super(t,Gi.propertyIds),this.events=new Array(t)}getFrameCount(){return this.frames.length}setFrame(t,e){this.frames[t]=e.time,this.events[t]=e}apply(t,e,i,s,n,c,a){if(!s)return;let r=this.frames,o=this.frames.length;if(e>i)this.apply(t,e,Number.MAX_VALUE,s,n,c,a),e=-1;else if(e>=r[o-1])return;if(i<r[0])return;let l=0;if(e<r[0])l=0;else{l=ft.search1(r,e)+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])}},ae=Gi;ae.propertyIds=[""+ct.event];var Hi=class extends ft{constructor(t){super(t,Hi.propertyIds),this.drawOrders=new Array(t)}getFrameCount(){return this.frames.length}setFrame(t,e,i){this.frames[t]=e,this.drawOrders[t]=i}apply(t,e,i,s,n,c,a){if(a==1){c==0&&B.arrayCopy(t.slots,0,t.drawOrder,0,t.slots.length);return}if(i<this.frames[0]){(c==0||c==1)&&B.arrayCopy(t.slots,0,t.drawOrder,0,t.slots.length);return}let r=ft.search1(this.frames,i),o=this.drawOrders[r];if(!o)B.arrayCopy(t.slots,0,t.drawOrder,0,t.slots.length);else{let l=t.drawOrder,h=t.slots;for(let d=0,u=o.length;d<u;d++)l[d]=h[o[d]]}}},qt=Hi;qt.propertyIds=[""+ct.drawOrder];var ni=class extends Tt{constructor(t,e,i){super(t,e,[ct.ikConstraint+"|"+i]),this.ikConstraintIndex=0,this.ikConstraintIndex=i}getFrameEntries(){return 6}setFrame(t,e,i,s,n,c,a){t*=6,this.frames[t]=e,this.frames[t+1]=i,this.frames[t+2]=s,this.frames[t+3]=n,this.frames[t+4]=c?1:0,this.frames[t+5]=a?1:0}apply(t,e,i,s,n,c,a){let r=t.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,d=ft.search(o,i,6),u=this.curves[d/6];switch(u){case 0:let f=o[d];l=o[d+1],h=o[d+2];let m=(i-f)/(o[d+6]-f);l+=(o[d+6+1]-l)*m,h+=(o[d+6+2]-h)*m;break;case 1:l=o[d+1],h=o[d+2];break;default:l=this.getBezierValue(i,d,1,u-2),h=this.getBezierValue(i,d,2,u+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[d+3],r.compress=o[d+4]!=0,r.stretch=o[d+5]!=0)):(r.mix+=(l-r.mix)*n,r.softness+=(h-r.softness)*n,a==0&&(r.bendDirection=o[d+3],r.compress=o[d+4]!=0,r.stretch=o[d+5]!=0))}},ai=class extends Tt{constructor(t,e,i){super(t,e,[ct.transformConstraint+"|"+i]),this.transformConstraintIndex=0,this.transformConstraintIndex=i}getFrameEntries(){return 7}setFrame(t,e,i,s,n,c,a,r){let o=this.frames;t*=7,o[t]=e,o[t+1]=i,o[t+2]=s,o[t+3]=n,o[t+4]=c,o[t+5]=a,o[t+6]=r}apply(t,e,i,s,n,c,a){let r=t.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,d,u,f,m,x=ft.search(o,i,7),p=this.curves[x/7];switch(p){case 0:let v=o[x];l=o[x+1],h=o[x+2],d=o[x+3],u=o[x+4],f=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,d+=(o[x+7+3]-d)*g,u+=(o[x+7+4]-u)*g,f+=(o[x+7+5]-f)*g,m+=(o[x+7+6]-m)*g;break;case 1:l=o[x+1],h=o[x+2],d=o[x+3],u=o[x+4],f=o[x+5],m=o[x+6];break;default:l=this.getBezierValue(i,x,1,p-2),h=this.getBezierValue(i,x,2,p+18-2),d=this.getBezierValue(i,x,3,p+18*2-2),u=this.getBezierValue(i,x,4,p+18*3-2),f=this.getBezierValue(i,x,5,p+18*4-2),m=this.getBezierValue(i,x,6,p+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+(d-v.mixY)*n,r.mixScaleX=v.mixScaleX+(u-v.mixScaleX)*n,r.mixScaleY=v.mixScaleY+(f-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+=(d-r.mixY)*n,r.mixScaleX+=(u-r.mixScaleX)*n,r.mixScaleY+=(f-r.mixScaleY)*n,r.mixShearY+=(m-r.mixShearY)*n}},li=class extends It{constructor(t,e,i){super(t,e,ct.pathConstraintPosition+"|"+i),this.pathConstraintIndex=0,this.pathConstraintIndex=i}apply(t,e,i,s,n,c,a){let r=t.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 It{constructor(t,e,i){super(t,e,ct.pathConstraintSpacing+"|"+i),this.pathConstraintIndex=0,this.pathConstraintIndex=i}apply(t,e,i,s,n,c,a){let r=t.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 Tt{constructor(t,e,i){super(t,e,[ct.pathConstraintMix+"|"+i]),this.pathConstraintIndex=0,this.pathConstraintIndex=i}getFrameEntries(){return 4}setFrame(t,e,i,s,n){let c=this.frames;t<<=2,c[t]=e,c[t+1]=i,c[t+2]=s,c[t+3]=n}apply(t,e,i,s,n,c,a){let r=t.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,d,u=ft.search(o,i,4),f=this.curves[u>>2];switch(f){case 0:let m=o[u];l=o[u+1],h=o[u+2],d=o[u+3];let x=(i-m)/(o[u+4]-m);l+=(o[u+4+1]-l)*x,h+=(o[u+4+2]-h)*x,d+=(o[u+4+3]-d)*x;break;case 1:l=o[u+1],h=o[u+2],d=o[u+3];break;default:l=this.getBezierValue(i,u,1,f-2),h=this.getBezierValue(i,u,2,f+18-2),d=this.getBezierValue(i,u,3,f+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+(d-m.mixY)*n}else r.mixRotate+=(l-r.mixRotate)*n,r.mixX+=(h-r.mixX)*n,r.mixY+=(d-r.mixY)*n}},Ot=class extends ft{constructor(t,e,i){super(t,[ct.sequence+"|"+e+"|"+i.sequence.id]),this.slotIndex=e,this.attachment=i}getFrameEntries(){return Ot.ENTRIES}getSlotIndex(){return this.slotIndex}getAttachment(){return this.attachment}setFrame(t,e,i,s,n){let c=this.frames;t*=Ot.ENTRIES,c[t]=e,c[t+Ot.MODE]=i|s<<4,c[t+Ot.DELAY]=n}apply(t,e,i,s,n,c,a){let r=t.slots[this.slotIndex];if(!r.bone.active)return;let o=r.attachment,l=this.attachment;if(o!=l&&(!(o instanceof St)||o.timelineAttachment!=l))return;let h=this.frames;if(i<h[0]){(c==0||c==1)&&(r.sequenceIndex=-1);return}let d=ft.search(h,i,Ot.ENTRIES),u=h[d],f=h[d+Ot.MODE],m=h[d+Ot.DELAY];if(!this.attachment.sequence)return;let x=f>>4,p=this.attachment.sequence.regions.length,v=zi[f&15];if(v!=0)switch(x+=(i-u)/m+1e-5|0,v){case 1:x=Math.min(p-1,x);break;case 2:x%=p;break;case 3:{let g=(p<<1)-2;x=g==0?0:x%g,x>=p&&(x=g-x);break}case 4:x=Math.max(p-1-x,0);break;case 5:x=p-1-x%p;break;case 6:{let g=(p<<1)-2;x=g==0?0:(x+p-1)%g,x>=p&&(x=g-x)}}r.sequenceIndex=x}},Kt=Ot;Kt.ENTRIES=3,Kt.MODE=1,Kt.DELAY=2;var we=class{constructor(t){this.tracks=new Array,this.timeScale=1,this.unkeyedState=0,this.events=new Array,this.listeners=new Array,this.queue=new Ki(this),this.propertyIDs=new Ne,this.animationsChanged=!1,this.trackEntryPool=new re(()=>new Zi),this.data=t}static emptyAnimation(){return we._emptyAnimation}update(t){t*=this.timeScale;let e=this.tracks;for(let i=0,s=e.length;i<s;i++){let n=e[i];if(!n)continue;n.animationLast=n.nextAnimationLast,n.trackLast=n.nextTrackLast;let c=t*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+t)*a.timeScale,n.trackTime+=c,this.setCurrent(i,a,!0);a.mixingFrom;)a.mixTime+=t,a=a.mixingFrom;continue}}else if(n.trackLast>=n.trackEnd&&!n.mixingFrom){e[i]=null,this.queue.end(n),this.clearNext(n);continue}if(n.mixingFrom&&this.updateMixingFrom(n,t)){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(t,e){let i=t.mixingFrom;if(!i)return!0;let s=this.updateMixingFrom(i,e);return i.animationLast=i.nextAnimationLast,i.trackLast=i.nextTrackLast,t.mixTime>0&&t.mixTime>=t.mixDuration?((i.totalAlpha==0||t.mixDuration==0)&&(t.mixingFrom=i.mixingFrom,i.mixingFrom&&(i.mixingFrom.mixingTo=t),t.interruptAlpha=i.interruptAlpha,this.queue.end(i)),s):(i.trackTime+=e*i.timeScale,t.mixTime+=e,!1)}apply(t){if(!t)throw new Error("skeleton cannot be null.");this.animationsChanged&&this._animationsChanged();let e=this.events,i=this.tracks,s=!1;for(let d=0,u=i.length;d<u;d++){let f=i[d];if(!f||f.delay>0)continue;s=!0;let m=d==0?1:f.mixBlend,x=f.alpha;f.mixingFrom?x*=this.applyMixingFrom(f,t,m):f.trackTime>=f.trackEnd&&!f.next&&(x=0);let p=f.animationLast,v=f.getAnimationTime(),g=v,w=e;f.reverse&&(g=f.animation.duration-g,w=null);let b=f.animation.timelines,y=b.length;if(d==0&&x==1||m==3)for(let A=0;A<y;A++){B.webkit602BugfixHelper(x,m);var n=b[A];n instanceof Wt?this.applyAttachmentTimeline(n,t,g,m,!0):n.apply(t,p,g,w,x,m,0)}else{let A=f.timelineMode,C=f.shortestRotation,I=!C&&f.timelinesRotation.length!=y<<1;I&&(f.timelinesRotation.length=y<<1);for(let E=0;E<y;E++){let R=b[E],L=A[E]==be?m:0;!C&&R instanceof ne?this.applyRotateTimeline(R,t,g,x,L,f.timelinesRotation,E<<1,I):R instanceof Wt?this.applyAttachmentTimeline(R,t,g,m,!0):(B.webkit602BugfixHelper(x,m),R.apply(t,p,g,w,x,L,0))}}this.queueEvents(f,v),e.length=0,f.nextAnimationLast=v,f.nextTrackLast=f.trackTime}for(var c=this.unkeyedState+ui,a=t.slots,r=0,o=t.slots.length;r<o;r++){var l=a[r];if(l.attachmentState==c){var h=l.data.attachmentName;l.setAttachment(h?t.getAttachment(l.data.index,h):null)}}return this.unkeyedState+=2,this.queue.drain(),s}applyMixingFrom(t,e,i){let s=t.mixingFrom;s.mixingFrom&&this.applyMixingFrom(s,e,i);let n=0;t.mixDuration==0?(n=1,i==1&&(i=0)):(n=t.mixTime/t.mixDuration,n>1&&(n=1),i!=1&&(i=s.mixBlend));let c=n<s.attachmentThreshold,a=n<s.drawOrderThreshold,r=s.animation.timelines,o=r.length,l=s.alpha*t.interruptAlpha,h=l*(1-n),d=s.animationLast,u=s.getAnimationTime(),f=u,m=null;if(s.reverse?f=s.animation.duration-f:n<s.eventThreshold&&(m=this.events),i==3)for(let x=0;x<o;x++)r[x].apply(e,d,f,m,h,i,1);else{let x=s.timelineMode,p=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 b=r[w],y=1,A,C=0;switch(x[w]){case be:if(!a&&b instanceof qt)continue;A=i,C=h;break;case ci:A=0,C=h;break;case di:A=i,C=l;break;case pe:A=0,C=l;break;default:A=0;let I=p[w];C=l*Math.max(0,1-I.mixTime/I.mixDuration);break}s.totalAlpha+=C,!v&&b instanceof ne?this.applyRotateTimeline(b,e,f,C,A,s.timelinesRotation,w<<1,g):b instanceof Wt?this.applyAttachmentTimeline(b,e,f,A,c):(B.webkit602BugfixHelper(C,i),a&&b instanceof qt&&A==0&&(y=0),b.apply(e,d,f,m,C,A,y))}}return t.mixDuration>0&&this.queueEvents(s,u),this.events.length=0,s.nextAnimationLast=u,s.nextTrackLast=s.trackTime,n}applyAttachmentTimeline(t,e,i,s,n){var c=e.slots[t.slotIndex];c.bone.active&&(i<t.frames[0]?(s==0||s==1)&&this.setAttachment(e,c,c.data.attachmentName,n):this.setAttachment(e,c,t.attachmentNames[ft.search1(t.frames,i)],n),c.attachmentState<=this.unkeyedState&&(c.attachmentState=this.unkeyedState+ui))}setAttachment(t,e,i,s){e.setAttachment(i?t.getAttachment(e.data.index,i):null),s&&(e.attachmentState=this.unkeyedState+Qi)}applyRotateTimeline(t,e,i,s,n,c,a,r){if(r&&(c[a]=0),s==1){t.apply(e,0,i,null,1,n,0);return}let o=e.bones[t.boneIndex];if(!o.active)return;let l=t.frames,h=0,d=0;if(i<l[0])switch(n){case 0:o.rotation=o.data.rotation;default:return;case 1:h=o.rotation,d=o.data.rotation}else h=n==0?o.data.rotation:o.rotation,d=o.data.rotation+t.getCurveValue(i);let u=0,f=d-h;if(f-=(16384-(16384.499999999996-f/360|0))*360,f==0)u=c[a];else{let m=0,x=0;r?(m=0,x=f):(m=c[a],x=c[a+1]);let p=m-m%360;u=f+p;let v=f>=0,g=m>=0;Math.abs(x)<=90&&X.signum(x)!=X.signum(f)&&(Math.abs(m-p)>180?(u+=360*X.signum(m),g=v):p!=0?u-=360*X.signum(m):g=v),g!=v&&(u+=360*X.signum(m)),c[a]=u}c[a+1]=f,o.rotation=h+u*s}queueEvents(t,e){let i=t.animationStart,s=t.animationEnd,n=s-i,c=t.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(t,h)}let l=!1;for(t.loop?l=n==0||c>t.trackTime%n:l=e>=s&&t.animationLast<s,l&&this.queue.complete(t);r<o;r++){let h=a[r];h.time<i||this.queue.event(t,h)}}clearTracks(){let t=this.queue.drainDisabled;this.queue.drainDisabled=!0;for(let e=0,i=this.tracks.length;e<i;e++)this.clearTrack(e);this.tracks.length=0,this.queue.drainDisabled=t,this.queue.drain()}clearTrack(t){if(t>=this.tracks.length)return;let e=this.tracks[t];if(!e)return;this.queue.end(e),this.clearNext(e);let i=e;for(;;){let s=i.mixingFrom;if(!s)break;this.queue.end(s),i.mixingFrom=null,i.mixingTo=null,i=s}this.tracks[e.trackIndex]=null,this.queue.drain()}setCurrent(t,e,i){let s=this.expandToIndex(t);this.tracks[t]=e,e.previous=null,s&&(i&&this.queue.interrupt(s),e.mixingFrom=s,s.mixingTo=e,e.mixTime=0,s.mixingFrom&&s.mixDuration>0&&(e.interruptAlpha*=Math.min(1,s.mixTime/s.mixDuration)),s.timelinesRotation.length=0),this.queue.start(e)}setAnimation(t,e,i=!1){let s=this.data.skeletonData.findAnimation(e);if(!s)throw new Error("Animation not found: "+e);return this.setAnimationWith(t,s,i)}setAnimationWith(t,e,i=!1){if(!e)throw new Error("animation cannot be null.");let s=!0,n=this.expandToIndex(t);n&&(n.nextTrackLast==-1?(this.tracks[t]=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(t,e,i,n);return this.setCurrent(t,c,s),this.queue.drain(),c}addAnimation(t,e,i=!1,s=0){let n=this.data.skeletonData.findAnimation(e);if(!n)throw new Error("Animation not found: "+e);return this.addAnimationWith(t,n,i,s)}addAnimationWith(t,e,i=!1,s=0){if(!e)throw new Error("animation cannot be null.");let n=this.expandToIndex(t);if(n)for(;n.next;)n=n.next;let c=this.trackEntry(t,e,i,n);return n?(n.next=c,c.previous=n,s<=0&&(s+=n.getTrackComplete()-c.mixDuration)):(this.setCurrent(t,c,!0),this.queue.drain()),c.delay=s,c}setEmptyAnimation(t,e=0){let i=this.setAnimationWith(t,we.emptyAnimation(),!1);return i.mixDuration=e,i.trackEnd=e,i}addEmptyAnimation(t,e=0,i=0){let s=this.addAnimationWith(t,we.emptyAnimation(),!1,i);return i<=0&&(s.delay+=s.mixDuration-e),s.mixDuration=e,s.trackEnd=e,s}setEmptyAnimations(t=0){let e=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,t)}this.queue.drainDisabled=e,this.queue.drain()}expandToIndex(t){return t<this.tracks.length?this.tracks[t]:(B.ensureArrayCapacity(this.tracks,t+1,null),this.tracks.length=t+1,null)}trackEntry(t,e,i,s){let n=this.trackEntryPool.obtain();return n.reset(),n.trackIndex=t,n.animation=e,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=e.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,e):0,n.interruptAlpha=1,n.totalAlpha=0,n.mixBlend=2,n}clearNext(t){let e=t.next;for(;e;)this.queue.dispose(e),e=e.next;t.next=null}_animationsChanged(){this.animationsChanged=!1,this.propertyIDs.clear();let t=this.tracks;for(let e=0,i=t.length;e<i;e++){let s=t[e];if(s){for(;s.mixingFrom;)s=s.mixingFrom;do(!s.mixingTo||s.mixBlend!=3)&&this.computeHold(s),s=s.mixingTo;while(s)}}}computeHold(t){let e=t.mixingTo,i=t.animation.timelines,s=t.animation.timelines.length,n=t.timelineMode;n.length=s;let c=t.timelineHoldMix;c.length=0;let a=this.propertyIDs;if(e&&e.holdPrevious){for(let r=0;r<s;r++)n[r]=a.addAll(i[r].getPropertyIds())?pe:di;return}t:for(let r=0;r<s;r++){let o=i[r],l=o.getPropertyIds();if(!a.addAll(l))n[r]=be;else if(!e||o instanceof Wt||o instanceof qt||o instanceof ae||!e.animation.hasTimeline(l))n[r]=ci;else{for(let h=e.mixingTo;h;h=h.mixingTo)if(!h.animation.hasTimeline(l)){if(t.mixDuration>0){n[r]=Ji,c[r]=h;continue t}break}n[r]=pe}}}getCurrent(t){return t>=this.tracks.length?null:this.tracks[t]}addListener(t){if(!t)throw new Error("listener cannot be null.");this.listeners.push(t)}removeListener(t){let e=this.listeners.indexOf(t);e>=0&&this.listeners.splice(e,1)}clearListeners(){this.listeners.length=0}clearListenerNotifications(){this.queue.clear()}},ji=we;ji._emptyAnimation=new ge("<empty>",[],0);var Zi=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=2,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 t=this.animationEnd-this.animationStart;return t==0?this.animationStart:this.trackTime%t+this.animationStart}return Math.min(this.trackTime+this.animationStart,this.animationEnd)}setAnimationLast(t){this.animationLast=t,this.nextAnimationLast=t}isComplete(){return this.trackTime>=this.animationEnd-this.animationStart}resetRotationDirections(){this.timelinesRotation.length=0}getTrackComplete(){let t=this.animationEnd-this.animationStart;if(t!=0){if(this.loop)return t*(1+(this.trackTime/t|0));if(this.trackTime<t)return t}return this.trackTime}},Ki=class{constructor(t){this.objects=[],this.drainDisabled=!1,this.animState=t}start(t){this.objects.push(pt.start),this.objects.push(t),this.animState.animationsChanged=!0}interrupt(t){this.objects.push(pt.interrupt),this.objects.push(t)}end(t){this.objects.push(pt.end),this.objects.push(t),this.animState.animationsChanged=!0}dispose(t){this.objects.push(pt.dispose),this.objects.push(t)}complete(t){this.objects.push(pt.complete),this.objects.push(t)}event(t,e){this.objects.push(pt.event),this.objects.push(t),this.objects.push(e)}drain(){if(this.drainDisabled)return;this.drainDisabled=!0;let t=this.objects,e=this.animState.listeners;for(let i=0;i<t.length;i+=2){let s=t[i],n=t[i+1];switch(s){case pt.start:n.listener&&n.listener.start&&n.listener.start(n);for(let a=0;a<e.length;a++){let r=e[a];r.start&&r.start(n)}break;case pt.interrupt:n.listener&&n.listener.interrupt&&n.listener.interrupt(n);for(let a=0;a<e.length;a++){let r=e[a];r.interrupt&&r.interrupt(n)}break;case pt.end:n.listener&&n.listener.end&&n.listener.end(n);for(let a=0;a<e.length;a++){let r=e[a];r.end&&r.end(n)}case pt.dispose:n.listener&&n.listener.dispose&&n.listener.dispose(n);for(let a=0;a<e.length;a++){let r=e[a];r.dispose&&r.dispose(n)}this.animState.trackEntryPool.free(n);break;case pt.complete:n.listener&&n.listener.complete&&n.listener.complete(n);for(let a=0;a<e.length;a++){let r=e[a];r.complete&&r.complete(n)}break;case pt.event:let c=t[i+++2];n.listener&&n.listener.event&&n.listener.event(n,c);for(let a=0;a<e.length;a++){let r=e[a];r.event&&r.event(n,c)}break}}this.clear(),this.drainDisabled=!1}clear(){this.objects.length=0}},pt=(t=>(t[t.start=0]="start",t[t.interrupt=1]="interrupt",t[t.end=2]="end",t[t.dispose=3]="dispose",t[t.complete=4]="complete",t[t.event=5]="event",t))(pt||{}),Ps=class{start(t){}interrupt(t){}end(t){}dispose(t){}complete(t){}event(t,e){}},be=0,ci=1,di=2,pe=3,Ji=4,ui=1,Qi=2,Ds=class{constructor(t){if(this.animationToMixTime={},this.defaultMix=0,!t)throw new Error("skeletonData cannot be null.");this.skeletonData=t}setMix(t,e,i){let s=this.skeletonData.findAnimation(t);if(!s)throw new Error("Animation not found: "+t);let n=this.skeletonData.findAnimation(e);if(!n)throw new Error("Animation not found: "+e);this.setMixWith(s,n,i)}setMixWith(t,e,i){if(!t)throw new Error("from cannot be null.");if(!e)throw new Error("to cannot be null.");let s=t.name+"."+e.name;this.animationToMixTime[s]=i}getMix(t,e){let i=t.name+"."+e.name,s=this.animationToMixTime[i];return s===void 0?this.defaultMix:s}},ve=class extends St{constructor(t){super(t),this.color=new O(1,1,1,1)}copy(){let t=new ve(this.name);return this.copyTo(t),t.color.setFromColor(this.color),t}},le=class extends St{constructor(t){super(t),this.endSlot=null,this.color=new O(.2275,.2275,.8078,1)}copy(){let t=new le(this.name);return this.copyTo(t),t.endSlot=this.endSlot,t.color.setFromColor(this.color),t}},fi=class{constructor(t){this._image=t}getImage(){return this._image}},ye=(t=>(t[t.Nearest=9728]="Nearest",t[t.Linear=9729]="Linear",t[t.MipMap=9987]="MipMap",t[t.MipMapNearestNearest=9984]="MipMapNearestNearest",t[t.MipMapLinearNearest=9985]="MipMapLinearNearest",t[t.MipMapNearestLinear=9986]="MipMapNearestLinear",t[t.MipMapLinearLinear=9987]="MipMapLinearLinear",t))(ye||{}),$i=(t=>(t[t.MirroredRepeat=33648]="MirroredRepeat",t[t.ClampToEdge=33071]="ClampToEdge",t[t.Repeat=10497]="Repeat",t))($i||{}),ts=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}},Os=class extends fi{setFilters(t,e){}setWraps(t,e){}dispose(){}},es=class{constructor(t){this.pages=new Array,this.regions=new Array;let e=new Vs(t),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(ye,i[1]),l.magFilter=B.enumValue(ye,i[2])},s.repeat=l=>{i[1].indexOf("x")!=-1&&(l.uWrap=10497),i[1].indexOf("y")!=-1&&(l.vWrap=10497)},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=e.readLine();for(;c&&c.trim().length==0;)c=e.readLine();for(;!(!c||c.trim().length==0||e.readEntry(i,c)==0);)c=e.readLine();let a=null,r=null,o=null;for(;c!==null;)if(c.trim().length==0)a=null,c=e.readLine();else if(a){let l=new mi(a,c);for(;;){let h=e.readEntry(i,c=e.readLine());if(h==0)break;let d=n[i[0]];if(d)d(l);else{r||(r=[]),o||(o=[]),r.push(i[0]);let u=[];for(let f=0;f<h;f++)u.push(parseInt(i[f+1]));o.push(u)}}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 is(c.trim());e.readEntry(i,c=e.readLine())!=0;){let l=s[i[0]];l&&l(a)}this.pages.push(a)}}findRegion(t){for(let e=0;e<this.regions.length;e++)if(this.regions[e].name==t)return this.regions[e];return null}setTextures(t,e=""){for(let i of this.pages)i.setTexture(t.get(e+i.name))}dispose(){var t;for(let e=0;e<this.pages.length;e++)(t=this.pages[e].texture)==null||t.dispose()}},Vs=class{constructor(t){this.index=0,this.lines=t.split(/\r\n|\r|\n/)}readLine(){return this.index>=this.lines.length?null:this.lines[this.index++]}readEntry(t,e){if(!e||(e=e.trim(),e.length==0))return 0;let i=e.indexOf(":");if(i==-1)return 0;t[0]=e.substr(0,i).trim();for(let s=1,n=i+1;;s++){let c=e.indexOf(",",n);if(c==-1)return t[s]=e.substr(n).trim(),s;if(t[s]=e.substr(n,c-n).trim(),n=c+1,s==4)return 4}}},is=class{constructor(t){this.minFilter=9728,this.magFilter=9728,this.uWrap=33071,this.vWrap=33071,this.texture=null,this.width=0,this.height=0,this.pma=!1,this.regions=new Array,this.name=t}setTexture(t){this.texture=t,t.setFilters(this.minFilter,this.magFilter),t.setWraps(this.uWrap,this.vWrap);for(let e of this.regions)e.texture=t}},mi=class extends ts{constructor(t,e){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=t,this.name=e,t.regions.push(this)}},Vt=class extends St{constructor(t,e){super(t),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=e}updateRegion(){if(!this.region)throw new Error("Region not set.");let t=this.regionUVs;(!this.uvs||this.uvs.length!=t.length)&&(this.uvs=B.newFloatArray(t.length));let e=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,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 d=0;d<i;d+=2)e[d]=s+t[d+1]*c,e[d+1]=n+(1-t[d])*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 d=0;d<i;d+=2)e[d]=s+(1-t[d])*c,e[d+1]=n+(1-t[d+1])*a;return;case 270:s-=r.offsetY/l,n-=r.offsetX/h,c=r.originalHeight/l,a=r.originalWidth/h;for(let d=0;d<i;d+=2)e[d]=s+(1-t[d+1])*c,e[d+1]=n+t[d]*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)e[r]=s+t[r]*c,e[r+1]=n+t[r+1]*a}getParentMesh(){return this.parentMesh}setParentMesh(t){this.parentMesh=t,t&&(this.bones=t.bones,this.vertices=t.vertices,this.worldVerticesLength=t.worldVerticesLength,this.regionUVs=t.regionUVs,this.triangles=t.triangles,this.hullLength=t.hullLength,this.worldVerticesLength=t.worldVerticesLength)}copy(){if(this.parentMesh)return this.newLinkedMesh();let t=new Vt(this.name,this.path);return t.region=this.region,t.color.setFromColor(this.color),this.copyTo(t),t.regionUVs=new Array(this.regionUVs.length),B.arrayCopy(this.regionUVs,0,t.regionUVs,0,this.regionUVs.length),t.uvs=new Array(this.uvs.length),B.arrayCopy(this.uvs,0,t.uvs,0,this.uvs.length),t.triangles=new Array(this.triangles.length),B.arrayCopy(this.triangles,0,t.triangles,0,this.triangles.length),t.hullLength=this.hullLength,t.sequence=this.sequence!=null?this.sequence.copy():null,this.edges&&(t.edges=new Array(this.edges.length),B.arrayCopy(this.edges,0,t.edges,0,this.edges.length)),t.width=this.width,t.height=this.height,t}computeWorldVertices(t,e,i,s,n,c){this.sequence!=null&&this.sequence.apply(t,this),super.computeWorldVertices(t,e,i,s,n,c)}newLinkedMesh(){let t=new Vt(this.name,this.path);return t.region=this.region,t.color.setFromColor(this.color),t.timelineAttachment=this.timelineAttachment,t.setParentMesh(this.parentMesh?this.parentMesh:this),t.region!=null&&t.updateRegion(),t}},Gt=class extends St{constructor(t){super(t),this.lengths=[],this.closed=!1,this.constantSpeed=!1,this.color=new O(1,1,1,1)}copy(){let t=new Gt(this.name);return this.copyTo(t),t.lengths=new Array(this.lengths.length),B.arrayCopy(this.lengths,0,t.lengths,0,this.lengths.length),t.closed=closed,t.constantSpeed=this.constantSpeed,t.color.setFromColor(this.color),t}},gi=class extends St{constructor(t){super(t),this.x=0,this.y=0,this.rotation=0,this.color=new O(.38,.94,0,1)}computeWorldPosition(t,e){return e.x=this.x*t.a+this.y*t.b+t.worldX,e.y=this.x*t.c+this.y*t.d+t.worldY,e}computeWorldRotation(t){let e=X.cosDeg(this.rotation),i=X.sinDeg(this.rotation),s=e*t.a+i*t.b,n=e*t.c+i*t.d;return Math.atan2(n,s)*X.radDeg}copy(){let t=new gi(this.name);return t.x=this.x,t.y=this.y,t.rotation=this.rotation,t.color.setFromColor(this.color),t}},ss=class extends _e{constructor(t,e){super(t),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.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=e}updateRegion(){if(!this.region)throw new Error("Region not set.");let t=this.region,e=this.uvs;if(t==null){e[0]=0,e[1]=0,e[2]=0,e[3]=1,e[4]=1,e[5]=1,e[6]=1,e[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),d=this.x,u=this.y,f=n*l+d,m=n*h,x=c*l+u,p=c*h,v=a*l+d,g=a*h,w=r*l+u,b=r*h,y=this.offset;y[0]=f-p,y[1]=x+m,y[2]=f-b,y[3]=w+m,y[4]=v-b,y[5]=w+g,y[6]=v-p,y[7]=x+g,t.degrees==90?(e[0]=t.u2,e[1]=t.v2,e[2]=t.u,e[3]=t.v2,e[4]=t.u,e[5]=t.v,e[6]=t.u2,e[7]=t.v):(e[0]=t.u,e[1]=t.v2,e[2]=t.u,e[3]=t.v,e[4]=t.u2,e[5]=t.v,e[6]=t.u2,e[7]=t.v2)}computeWorldVertices(t,e,i,s){this.sequence!=null&&this.sequence.apply(t,this);let n=t.bone,c=this.offset,a=n.worldX,r=n.worldY,o=n.a,l=n.b,h=n.c,d=n.d,u=0,f=0;u=c[0],f=c[1],e[i]=u*o+f*l+a,e[i+1]=u*h+f*d+r,i+=s,u=c[2],f=c[3],e[i]=u*o+f*l+a,e[i+1]=u*h+f*d+r,i+=s,u=c[4],f=c[5],e[i]=u*o+f*l+a,e[i+1]=u*h+f*d+r,i+=s,u=c[6],f=c[7],e[i]=u*o+f*l+a,e[i+1]=u*h+f*d+r}copy(){let t=new ss(this.name,this.path);return t.region=this.region,t.x=this.x,t.y=this.y,t.scaleX=this.scaleX,t.scaleY=this.scaleY,t.rotation=this.rotation,t.width=this.width,t.height=this.height,B.arrayCopy(this.uvs,0,t.uvs,0,8),B.arrayCopy(this.offset,0,t.offset,0,8),t.color.setFromColor(this.color),t.sequence=this.sequence!=null?this.sequence.copy():null,t}},at=ss;at.X1=0,at.Y1=1,at.C1R=2,at.C1G=3,at.C1B=4,at.C1A=5,at.U1=6,at.V1=7,at.X2=8,at.Y2=9,at.C2R=10,at.C2G=11,at.C2B=12,at.C2A=13,at.U2=14,at.V2=15,at.X3=16,at.Y3=17,at.C3R=18,at.C3G=19,at.C3B=20,at.C3A=21,at.U3=22,at.V3=23,at.X4=24,at.Y4=25,at.C4R=26,at.C4G=27,at.C4B=28,at.C4A=29,at.U4=30,at.V4=31;var Ns=class{constructor(t){this.atlas=t}loadSequence(t,e,i){let s=i.regions;for(let n=0,c=s.length;n<c;n++){let a=i.getPath(e,n),r=this.atlas.findRegion(a);if(r==null)throw new Error("Region not found in atlas: "+a+" (sequence: "+t+")");s[n]=r}}newRegionAttachment(t,e,i,s){let n=new at(e,i);if(s!=null)this.loadSequence(e,i,s);else{let c=this.atlas.findRegion(i);if(!c)throw new Error("Region not found in atlas: "+i+" (region attachment: "+e+")");n.region=c}return n}newMeshAttachment(t,e,i,s){let n=new Vt(e,i);if(s!=null)this.loadSequence(e,i,s);else{let c=this.atlas.findRegion(i);if(!c)throw new Error("Region not found in atlas: "+i+" (mesh attachment: "+e+")");n.region=c}return n}newBoundingBoxAttachment(t,e){return new ve(e)}newPathAttachment(t,e){return new Gt(e)}newPointAttachment(t,e){return new gi(e)}newClippingAttachment(t,e){return new le(e)}},xi=class{constructor(t,e,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=Ae.Normal,this.skinRequired=!1,this.color=new O,t<0)throw new Error("index must be >= 0.");if(!e)throw new Error("name cannot be null.");this.index=t,this.name=e,this.parent=i}},Ae=(t=>(t[t.Normal=0]="Normal",t[t.OnlyTranslation=1]="OnlyTranslation",t[t.NoRotationOrReflection=2]="NoRotationOrReflection",t[t.NoScale=3]="NoScale",t[t.NoScaleOrReflection=4]="NoScaleOrReflection",t))(Ae||{}),wi=class{constructor(t,e,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,!t)throw new Error("data cannot be null.");if(!e)throw new Error("skeleton cannot be null.");this.data=t,this.skeleton=e,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(t,e,i,s,n,c,a){this.ax=t,this.ay=e,this.arotation=i,this.ascaleX=s,this.ascaleY=n,this.ashearX=c,this.ashearY=a;let r=this.parent;if(!r){let u=this.skeleton,f=i+90+a,m=u.scaleX,x=u.scaleY;this.a=X.cosDeg(i+c)*s*m,this.b=X.cosDeg(f)*n*m,this.c=X.sinDeg(i+c)*s*x,this.d=X.sinDeg(f)*n*x,this.worldX=t*m+u.x,this.worldY=e*x+u.y;return}let o=r.a,l=r.b,h=r.c,d=r.d;switch(this.worldX=o*t+l*e+r.worldX,this.worldY=h*t+d*e+r.worldY,this.data.transformMode){case 0:{let u=i+90+a,f=X.cosDeg(i+c)*s,m=X.cosDeg(u)*n,x=X.sinDeg(i+c)*s,p=X.sinDeg(u)*n;this.a=o*f+l*x,this.b=o*m+l*p,this.c=h*f+d*x,this.d=h*m+d*p;return}case 1:{let u=i+90+a;this.a=X.cosDeg(i+c)*s,this.b=X.cosDeg(u)*n,this.c=X.sinDeg(i+c)*s,this.d=X.sinDeg(u)*n;break}case 2:{let u=o*o+h*h,f=0;u>1e-4?(u=Math.abs(o*d-l*h)/u,o/=this.skeleton.scaleX,h/=this.skeleton.scaleY,l=h*u,d=o*u,f=Math.atan2(h,o)*X.radDeg):(o=0,h=0,f=90-Math.atan2(d,l)*X.radDeg);let m=i+c-f,x=i+a-f+90,p=X.cosDeg(m)*s,v=X.cosDeg(x)*n,g=X.sinDeg(m)*s,w=X.sinDeg(x)*n;this.a=o*p-l*g,this.b=o*v-l*w,this.c=h*p+d*g,this.d=h*v+d*w;break}case 3:case 4:{let u=X.cosDeg(i),f=X.sinDeg(i),m=(o*u+l*f)/this.skeleton.scaleX,x=(h*u+d*f)/this.skeleton.scaleY,p=Math.sqrt(m*m+x*x);p>1e-5&&(p=1/p),m*=p,x*=p,p=Math.sqrt(m*m+x*x),this.data.transformMode==3&&o*d-l*h<0!=(this.skeleton.scaleX<0!=this.skeleton.scaleY<0)&&(p=-p);let v=Math.PI/2+Math.atan2(x,m),g=Math.cos(v)*p,w=Math.sin(v)*p,b=X.cosDeg(c)*s,y=X.cosDeg(90+a)*n,A=X.sinDeg(c)*s,C=X.sinDeg(90+a)*n;this.a=m*b+g*A,this.b=m*y+g*C,this.c=x*b+w*A,this.d=x*y+w*C;break}}this.a*=this.skeleton.scaleX,this.b*=this.skeleton.scaleX,this.c*=this.skeleton.scaleY,this.d*=this.skeleton.scaleY}setToSetupPose(){let t=this.data;this.x=t.x,this.y=t.y,this.rotation=t.rotation,this.scaleX=t.scaleX,this.scaleY=t.scaleY,this.shearX=t.shearX,this.shearY=t.shearY}getWorldRotationX(){return Math.atan2(this.c,this.a)*X.radDeg}getWorldRotationY(){return Math.atan2(this.d,this.b)*X.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 t=this.parent;if(!t){this.ax=this.worldX-this.skeleton.x,this.ay=this.worldY-this.skeleton.y,this.arotation=Math.atan2(this.c,this.a)*X.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)*X.radDeg;return}let e=t.a,i=t.b,s=t.c,n=t.d,c=1/(e*n-i*s),a=n*c,r=i*c,o=s*c,l=e*c,h=this.worldX-t.worldX,d=this.worldY-t.worldY;this.ax=h*a-d*r,this.ay=d*l-h*o;let u,f,m,x;if(this.data.transformMode==1)u=this.a,f=this.b,m=this.c,x=this.d;else{switch(this.data.transformMode){case 2:{let b=Math.abs(e*n-i*s)/(e*e+s*s),y=e/this.skeleton.scaleX;i=-(s/this.skeleton.scaleY)*b*this.skeleton.scaleX,n=y*b*this.skeleton.scaleY,c=1/(e*n-i*s),a=n*c,r=i*c;break}case 3:case 4:let p=X.cosDeg(this.rotation),v=X.sinDeg(this.rotation);e=(e*p+i*v)/this.skeleton.scaleX,s=(s*p+n*v)/this.skeleton.scaleY;let g=Math.sqrt(e*e+s*s);g>1e-5&&(g=1/g),e*=g,s*=g,g=Math.sqrt(e*e+s*s),this.data.transformMode==3&&c<0!=(this.skeleton.scaleX<0!=this.skeleton.scaleY<0)&&(g=-g);let w=X.PI/2+Math.atan2(s,e);i=Math.cos(w)*g,n=Math.sin(w)*g,c=1/(e*n-i*s),a=n*c,r=i*c,o=s*c,l=e*c}u=a*this.a-r*this.c,f=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(u*u+m*m),this.ascaleX>1e-4){let p=u*x-f*m;this.ascaleY=p/this.ascaleX,this.ashearY=-Math.atan2(u*f+m*x,p)*X.radDeg,this.arotation=Math.atan2(m,u)*X.radDeg}else this.ascaleX=0,this.ascaleY=Math.sqrt(f*f+x*x),this.ashearY=0,this.arotation=90-Math.atan2(x,f)*X.radDeg}worldToLocal(t){let e=1/(this.a*this.d-this.b*this.c),i=t.x-this.worldX,s=t.y-this.worldY;return t.x=i*this.d*e-s*this.b*e,t.y=s*this.a*e-i*this.c*e,t}localToWorld(t){let e=t.x,i=t.y;return t.x=e*this.a+i*this.b+this.worldX,t.y=e*this.c+i*this.d+this.worldY,t}worldToLocalRotation(t){let e=X.sinDeg(t),i=X.cosDeg(t);return Math.atan2(this.a*e-this.c*i,this.d*i-this.b*e)*X.radDeg+this.rotation-this.shearX}localToWorldRotation(t){t-=this.rotation-this.shearX;let e=X.sinDeg(t),i=X.cosDeg(t);return Math.atan2(i*this.c+e*this.d,i*this.a+e*this.b)*X.radDeg}rotateWorld(t){let e=this.a,i=this.b,s=this.c,n=this.d,c=X.cosDeg(t),a=X.sinDeg(t);this.a=c*e-a*s,this.b=c*i-a*n,this.c=a*e+c*s,this.d=a*i+c*n}},Ce=class{constructor(t,e,i){this.name=t,this.order=e,this.skinRequired=i}},rs=class{constructor(t,e="",i=new bi){this.pathPrefix="",this.assets={},this.errors={},this.toLoad=0,this.loaded=0,this.textureLoader=t,this.pathPrefix=e,this.downloader=i}start(t){return this.toLoad++,this.pathPrefix+t}success(t,e,i){this.toLoad--,this.loaded++,this.assets[e]=i,t&&t(e,i)}error(t,e,i){this.toLoad--,this.loaded++,this.errors[e]=i,t&&t(e,i)}loadAll(){return new Promise((e,i)=>{let s=()=>{if(this.isLoadingComplete()){this.hasErrors()?i(this.errors):e(this);return}requestAnimationFrame(s)};requestAnimationFrame(s)})}setRawDataURI(t,e){this.downloader.rawDataUris[this.pathPrefix+t]=e}loadBinary(t,e=()=>{},i=()=>{}){t=this.start(t),this.downloader.downloadBinary(t,s=>{this.success(e,t,s)},(s,n)=>{this.error(i,t,`Couldn't load binary ${t}: status ${s}, ${n}`)})}loadText(t,e=()=>{},i=()=>{}){t=this.start(t),this.downloader.downloadText(t,s=>{this.success(e,t,s)},(s,n)=>{this.error(i,t,`Couldn't load text ${t}: status ${s}, ${n}`)})}loadJson(t,e=()=>{},i=()=>{}){t=this.start(t),this.downloader.downloadJson(t,s=>{this.success(e,t,s)},(s,n)=>{this.error(i,t,`Couldn't load JSON ${t}: status ${s}, ${n}`)})}loadTexture(t,e=()=>{},i=()=>{}){if(t=this.start(t),!!!(typeof window!="undefined"&&typeof navigator!="undefined"&&window.document))fetch(t,{mode:"cors"}).then(c=>c.ok?c.blob():(this.error(i,t,`Couldn't load image: ${t}`),null)).then(c=>c?createImageBitmap(c,{premultiplyAlpha:"none",colorSpaceConversion:"none"}):null).then(c=>{c&&this.success(e,t,this.textureLoader(c))});else{let c=new Image;c.crossOrigin="anonymous",c.onload=()=>{this.success(e,t,this.textureLoader(c))},c.onerror=()=>{this.error(i,t,`Couldn't load image: ${t}`)},this.downloader.rawDataUris[t]&&(t=this.downloader.rawDataUris[t]),c.src=t}}loadTextureAtlas(t,e=()=>{},i=()=>{},s){let n=t.lastIndexOf("/"),c=n>=0?t.substring(0,n+1):"";t=this.start(t),this.downloader.downloadText(t,a=>{try{let r=new es(a),o=r.pages.length,l=!1;for(let h of r.pages)this.loadTexture(s?s[h.name]:c+h.name,(d,u)=>{l||(h.setTexture(u),--o==0&&this.success(e,t,r))},(d,u)=>{l||this.error(i,t,`Couldn't load texture atlas ${t} page image: ${d}`),l=!0})}catch(r){this.error(i,t,`Couldn't parse texture atlas ${t}: ${r.message}`)}},(a,r)=>{this.error(i,t,`Couldn't load texture atlas ${t}: status ${a}, ${r}`)})}get(t){return this.assets[this.pathPrefix+t]}require(t){t=this.pathPrefix+t;let e=this.assets[t];if(e)return e;let i=this.errors[t];throw Error("Asset not found: "+t+(i?`
2
+ `+i:""))}remove(t){t=this.pathPrefix+t;let e=this.assets[t];return e.dispose&&e.dispose(),delete this.assets[t],e}removeAll(){for(let t in this.assets){let e=this.assets[t];e.dispose&&e.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(t){if(!t.startsWith("data:"))throw new Error("Not a data URI.");let e=t.indexOf("base64,");return e!=-1?(e+=7,atob(t.substr(e))):t.substr(t.indexOf(",")+1)}base64ToUint8Array(t){for(var e=window.atob(t),i=e.length,s=new Uint8Array(i),n=0;n<i;n++)s[n]=e.charCodeAt(n);return s}dataUriToUint8Array(t){if(!t.startsWith("data:"))throw new Error("Not a data URI.");let e=t.indexOf("base64,");if(e==-1)throw new Error("Not a binary data URI.");return e+=7,this.base64ToUint8Array(t.substr(e))}downloadText(t,e,i){if(this.start(t,e,i))return;if(this.rawDataUris[t]){try{let c=this.rawDataUris[t];this.finish(t,200,this.dataUriToString(c))}catch(c){this.finish(t,400,JSON.stringify(c))}return}let s=new XMLHttpRequest;s.overrideMimeType("text/html"),s.open("GET",t,!0);let n=()=>{this.finish(t,s.status,s.responseText)};s.onload=n,s.onerror=n,s.send()}downloadJson(t,e,i){this.downloadText(t,s=>{e(JSON.parse(s))},i)}downloadBinary(t,e,i){if(this.start(t,e,i))return;if(this.rawDataUris[t]){try{let c=this.rawDataUris[t];this.finish(t,200,this.dataUriToUint8Array(c))}catch(c){this.finish(t,400,JSON.stringify(c))}return}let s=new XMLHttpRequest;s.open("GET",t,!0),s.responseType="arraybuffer";let n=()=>{this.finish(t,s.status,s.response)};s.onload=()=>{s.status==200||s.status==0?this.finish(t,200,new Uint8Array(s.response)):n()},s.onerror=n,s.send()}start(t,e,i){let s=this.callbacks[t];try{if(s)return!0;this.callbacks[t]=s=[]}finally{s.push(e,i)}}finish(t,e,i){let s=this.callbacks[t];delete this.callbacks[t];let n=e==200||e==0?[i]:[e,i];for(let c=n.length-1,a=s.length;c<a;c+=2)s[c].apply(null,n)}},pi=class{constructor(t,e){if(this.intValue=0,this.floatValue=0,this.stringValue=null,this.time=0,this.volume=0,this.balance=0,!e)throw new Error("data cannot be null.");this.time=t,this.data=e}},vi=class{constructor(t){this.intValue=0,this.floatValue=0,this.stringValue=null,this.audioPath=null,this.volume=0,this.balance=0,this.name=t}},ns=class{constructor(t,e){if(this.bendDirection=0,this.compress=!1,this.stretch=!1,this.mix=1,this.softness=0,this.active=!1,!t)throw new Error("data cannot be null.");if(!e)throw new Error("skeleton cannot be null.");this.data=t,this.mix=t.mix,this.softness=t.softness,this.bendDirection=t.bendDirection,this.compress=t.compress,this.stretch=t.stretch,this.bones=new Array;for(let s=0;s<t.bones.length;s++){let n=e.findBone(t.bones[s].name);if(!n)throw new Error(`Couldn't find bone ${t.bones[s].name}`);this.bones.push(n)}let i=e.findBone(t.target.name);if(!i)throw new Error(`Couldn't find bone ${t.target.name}`);this.target=i}isActive(){return this.active}update(){if(this.mix==0)return;let t=this.target,e=this.bones;switch(e.length){case 1:this.apply1(e[0],t.worldX,t.worldY,this.compress,this.stretch,this.data.uniform,this.mix);break;case 2:this.apply2(e[0],e[1],t.worldX,t.worldY,this.bendDirection,this.stretch,this.data.uniform,this.softness,this.mix);break}}apply1(t,e,i,s,n,c,a){let r=t.parent;if(!r)throw new Error("IK bone must have parent.");let o=r.a,l=r.b,h=r.c,d=r.d,u=-t.ashearX-t.arotation,f=0,m=0;switch(t.data.transformMode){case 1:f=e-t.worldX,m=i-t.worldY;break;case 2:let v=Math.abs(o*d-l*h)/Math.max(1e-4,o*o+h*h),g=o/t.skeleton.scaleX,w=h/t.skeleton.scaleY;l=-w*v*t.skeleton.scaleX,d=g*v*t.skeleton.scaleY,u+=Math.atan2(w,g)*X.radDeg;default:let b=e-r.worldX,y=i-r.worldY,A=o*d-l*h;Math.abs(A)<=1e-4?(f=0,m=0):(f=(b*d-y*l)/A-t.ax,m=(y*o-b*h)/A-t.ay)}u+=Math.atan2(m,f)*X.radDeg,t.ascaleX<0&&(u+=180),u>180?u-=360:u<-180&&(u+=360);let x=t.ascaleX,p=t.ascaleY;if(s||n){switch(t.data.transformMode){case 3:case 4:f=e-t.worldX,m=i-t.worldY}let v=t.data.length*x,g=Math.sqrt(f*f+m*m);if(s&&g<v||n&&g>v&&v>1e-4){let w=(g/v-1)*a+1;x*=w,c&&(p*=w)}}t.updateWorldTransformWith(t.ax,t.ay,t.arotation+u*a,x,p,t.ashearX,t.ashearY)}apply2(t,e,i,s,n,c,a,r,o){let l=t.ax,h=t.ay,d=t.ascaleX,u=t.ascaleY,f=d,m=u,x=e.ascaleX,p=0,v=0,g=0;d<0?(d=-d,p=180,g=-1):(p=0,g=1),u<0&&(u=-u,g=-g),x<0?(x=-x,v=180):v=0;let w=e.ax,b=0,y=0,A=0,C=t.a,I=t.b,E=t.c,R=t.d,L=Math.abs(d-u)<=1e-4;!L||c?(b=0,y=C*w+t.worldX,A=E*w+t.worldY):(b=e.ay,y=C*w+I*b+t.worldX,A=E*w+R*b+t.worldY);let k=t.parent;if(!k)throw new Error("IK parent must itself have a parent.");C=k.a,I=k.b,E=k.c,R=k.d;let F=C*R-I*E,Y=y-k.worldX,T=A-k.worldY;F=Math.abs(F)<=1e-4?0:1/F;let D=(Y*R-T*I)*F-l,P=(T*C-Y*E)*F-h,et=Math.sqrt(D*D+P*P),rt=e.data.length*x,st,ht;if(et<1e-4){this.apply1(t,i,s,!1,c,!1,o),e.updateWorldTransformWith(w,b,0,e.ascaleX,e.ascaleY,e.ashearX,e.ashearY);return}Y=i-k.worldX,T=s-k.worldY;let nt=(Y*R-T*I)*F-l,it=(T*C-Y*E)*F-h,dt=nt*nt+it*it;if(r!=0){r*=d*(x+1)*.5;let gt=Math.sqrt(dt),At=gt-et-rt*d+r;if(At>0){let Ct=Math.min(1,At/(r*2))-1;Ct=(At-r*(1-Ct*Ct))/gt,nt-=Ct*nt,it-=Ct*it,dt=nt*nt+it*it}}t:if(L){rt*=d;let gt=(dt-et*et-rt*rt)/(2*et*rt);gt<-1?(gt=-1,ht=Math.PI*n):gt>1?(gt=1,ht=0,c&&(C=(Math.sqrt(dt)/(et+rt)-1)*o+1,f*=C,a&&(m*=C))):ht=Math.acos(gt)*n,C=et+rt*gt,I=rt*Math.sin(ht),st=Math.atan2(it*C-nt*I,nt*C+it*I)}else{C=d*rt,I=u*rt;let gt=C*C,At=I*I,Ct=Math.atan2(it,nt);E=At*et*et+gt*dt-gt*At;let Ut=-2*At*et,ee=At-gt;if(R=Ut*Ut-4*ee*E,R>=0){let ie=Math.sqrt(R);Ut<0&&(ie=-ie),ie=-(Ut+ie)*.5;let Ss=ie/ee,Ts=E/ie,se=Math.abs(Ss)<Math.abs(Ts)?Ss:Ts;if(se*se<=dt){T=Math.sqrt(dt-se*se)*n,st=Ct-Math.atan2(T,se),ht=Math.atan2(T/u,(se-et)/d);break t}}let fe=X.PI,De=et-C,Pi=De*De,ys=0,As=0,Oe=et+C,Di=Oe*Oe,Cs=0;E=-C*et/(gt-At),E>=-1&&E<=1&&(E=Math.acos(E),Y=C*Math.cos(E)+et,T=I*Math.sin(E),R=Y*Y+T*T,R<Pi&&(fe=E,Pi=R,De=Y,ys=T),R>Di&&(As=E,Di=R,Oe=Y,Cs=T)),dt<=(Pi+Di)*.5?(st=Ct-Math.atan2(ys*n,De),ht=fe*n):(st=Ct-Math.atan2(Cs*n,Oe),ht=As*n)}let wt=Math.atan2(b,w)*g,kt=t.arotation;st=(st-wt)*X.radDeg+p-kt,st>180?st-=360:st<-180&&(st+=360),t.updateWorldTransformWith(l,h,kt+st*o,f,m,0,0),kt=e.arotation,ht=((ht+wt)*X.radDeg-e.ashearX)*g+v-kt,ht>180?ht-=360:ht<-180&&(ht+=360),e.updateWorldTransformWith(w,b,kt+ht*o,e.ascaleX,e.ascaleY,e.ashearX,e.ashearY)}},yi=class extends Ce{constructor(t){super(t,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(t){this._target=t}get target(){if(this._target)return this._target;throw new Error("BoneData not set.")}},Ai=class extends Ce{constructor(t){super(t,0,!1),this.bones=new Array,this._target=null,this.positionMode=Se.Fixed,this.spacingMode=Te.Fixed,this.rotateMode=Ie.Chain,this.offsetRotation=0,this.position=0,this.spacing=0,this.mixRotate=0,this.mixX=0,this.mixY=0}set target(t){this._target=t}get target(){if(this._target)return this._target;throw new Error("SlotData not set.")}},Se=(t=>(t[t.Fixed=0]="Fixed",t[t.Percent=1]="Percent",t))(Se||{}),Te=(t=>(t[t.Length=0]="Length",t[t.Fixed=1]="Fixed",t[t.Percent=2]="Percent",t[t.Proportional=3]="Proportional",t))(Te||{}),Ie=(t=>(t[t.Tangent=0]="Tangent",t[t.Chain=1]="Chain",t[t.ChainScale=2]="ChainScale",t))(Ie||{}),Lt=class{constructor(t,e){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,!t)throw new Error("data cannot be null.");if(!e)throw new Error("skeleton cannot be null.");this.data=t,this.bones=new Array;for(let s=0,n=t.bones.length;s<n;s++){let c=e.findBone(t.bones[s].name);if(!c)throw new Error(`Couldn't find bone ${t.bones[s].name}.`);this.bones.push(c)}let i=e.findSlot(t.target.name);if(!i)throw new Error(`Couldn't find target bone ${t.target.name}`);this.target=i,this.position=t.position,this.spacing=t.spacing,this.mixRotate=t.mixRotate,this.mixX=t.mixX,this.mixY=t.mixY}isActive(){return this.active}update(){let t=this.target.getAttachment();if(!(t instanceof Gt))return;let e=this.mixRotate,i=this.mixX,s=this.mixY;if(e==0&&i==0&&s==0)return;let n=this.data,c=n.rotateMode==0,a=n.rotateMode==2,r=this.bones,o=r.length,l=c?o:o+1,h=B.setArraySize(this.spaces,l),d=a?this.lengths=B.setArraySize(this.lengths,o):[],u=this.spacing;switch(n.spacingMode){case 2:if(a)for(let b=0,y=l-1;b<y;b++){let A=r[b],C=A.data.length;if(C<Lt.epsilon)d[b]=0;else{let I=C*A.a,E=C*A.c;d[b]=Math.sqrt(I*I+E*E)}}B.arrayFill(h,1,l,u);break;case 3:let g=0;for(let b=0,y=l-1;b<y;){let A=r[b],C=A.data.length;if(C<Lt.epsilon)a&&(d[b]=0),h[++b]=u;else{let I=C*A.a,E=C*A.c,R=Math.sqrt(I*I+E*E);a&&(d[b]=R),h[++b]=R,g+=R}}if(g>0){g=l/g*u;for(let b=1;b<l;b++)h[b]*=g}break;default:let w=n.spacingMode==0;for(let b=0,y=l-1;b<y;){let A=r[b],C=A.data.length;if(C<Lt.epsilon)a&&(d[b]=0),h[++b]=u;else{let I=C*A.a,E=C*A.c,R=Math.sqrt(I*I+E*E);a&&(d[b]=R),h[++b]=(w?C+u:u)*R/C}}}let f=this.computeWorldPositions(t,l,c),m=f[0],x=f[1],p=n.offsetRotation,v=!1;if(p==0)v=n.rotateMode==1;else{v=!1;let g=this.target.bone;p*=g.a*g.d-g.b*g.c>0?X.degRad:-X.degRad}for(let g=0,w=3;g<o;g++,w+=3){let b=r[g];b.worldX+=(m-b.worldX)*i,b.worldY+=(x-b.worldY)*s;let y=f[w],A=f[w+1],C=y-m,I=A-x;if(a){let E=d[g];if(E!=0){let R=(Math.sqrt(C*C+I*I)/E-1)*e+1;b.a*=R,b.c*=R}}if(m=y,x=A,e>0){let E=b.a,R=b.b,L=b.c,k=b.d,F=0,Y=0,T=0;if(c?F=f[w-1]:h[g+1]==0?F=f[w+2]:F=Math.atan2(I,C),F-=Math.atan2(L,E),v){Y=Math.cos(F),T=Math.sin(F);let D=b.data.length;m+=(D*(Y*E-T*L)-C)*e,x+=(D*(T*E+Y*L)-I)*e}else F+=p;F>X.PI?F-=X.PI2:F<-X.PI&&(F+=X.PI2),F*=e,Y=Math.cos(F),T=Math.sin(F),b.a=Y*E-T*L,b.b=Y*R-T*k,b.c=T*E+Y*L,b.d=T*R+Y*k}b.updateAppliedTransform()}}computeWorldPositions(t,e,i){let s=this.target,n=this.position,c=this.spaces,a=B.setArraySize(this.positions,e*3+2),r=this.world,o=t.closed,l=t.worldVerticesLength,h=l/6,d=Lt.NONE;if(!t.constantSpeed){let P=t.lengths;h-=o?1:2;let et=P[h];this.data.positionMode==1&&(n*=et);let rt;switch(this.data.spacingMode){case 2:rt=et;break;case 3:rt=et/e;break;default:rt=1}r=B.setArraySize(this.world,8);for(let st=0,ht=0,nt=0;st<e;st++,ht+=3){let it=c[st]*rt;n+=it;let dt=n;if(o)dt%=et,dt<0&&(dt+=et),nt=0;else if(dt<0){d!=Lt.BEFORE&&(d=Lt.BEFORE,t.computeWorldVertices(s,2,4,r,0,2)),this.addBeforePosition(dt,r,0,a,ht);continue}else if(dt>et){d!=Lt.AFTER&&(d=Lt.AFTER,t.computeWorldVertices(s,l-6,4,r,0,2)),this.addAfterPosition(dt-et,r,0,a,ht);continue}for(;;nt++){let wt=P[nt];if(!(dt>wt)){if(nt==0)dt/=wt;else{let kt=P[nt-1];dt=(dt-kt)/(wt-kt)}break}}nt!=d&&(d=nt,o&&nt==h?(t.computeWorldVertices(s,l-4,4,r,0,2),t.computeWorldVertices(s,0,4,r,4,2)):t.computeWorldVertices(s,nt*6+2,8,r,0,2)),this.addCurvePosition(dt,r[0],r[1],r[2],r[3],r[4],r[5],r[6],r[7],a,ht,i||st>0&&it==0)}return a}o?(l+=2,r=B.setArraySize(this.world,l),t.computeWorldVertices(s,2,l-4,r,0,2),t.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),t.computeWorldVertices(s,2,l,r,0,2));let u=B.setArraySize(this.curves,h),f=0,m=r[0],x=r[1],p=0,v=0,g=0,w=0,b=0,y=0,A=0,C=0,I=0,E=0,R=0,L=0,k=0,F=0;for(let P=0,et=2;P<h;P++,et+=6)p=r[et],v=r[et+1],g=r[et+2],w=r[et+3],b=r[et+4],y=r[et+5],A=(m-p*2+g)*.1875,C=(x-v*2+w)*.1875,I=((p-g)*3-m+b)*.09375,E=((v-w)*3-x+y)*.09375,R=A*2+I,L=C*2+E,k=(p-m)*.75+A+I*.16666667,F=(v-x)*.75+C+E*.16666667,f+=Math.sqrt(k*k+F*F),k+=R,F+=L,R+=I,L+=E,f+=Math.sqrt(k*k+F*F),k+=R,F+=L,f+=Math.sqrt(k*k+F*F),k+=R+I,F+=L+E,f+=Math.sqrt(k*k+F*F),u[P]=f,m=b,x=y;this.data.positionMode==1&&(n*=f);let Y;switch(this.data.spacingMode){case 2:Y=f;break;case 3:Y=f/e;break;default:Y=1}let T=this.segments,D=0;for(let P=0,et=0,rt=0,st=0;P<e;P++,et+=3){let ht=c[P]*Y;n+=ht;let nt=n;if(o)nt%=f,nt<0&&(nt+=f),rt=0;else if(nt<0){this.addBeforePosition(nt,r,0,a,et);continue}else if(nt>f){this.addAfterPosition(nt-f,r,l-4,a,et);continue}for(;;rt++){let it=u[rt];if(!(nt>it)){if(rt==0)nt/=it;else{let dt=u[rt-1];nt=(nt-dt)/(it-dt)}break}}if(rt!=d){d=rt;let it=rt*6;for(m=r[it],x=r[it+1],p=r[it+2],v=r[it+3],g=r[it+4],w=r[it+5],b=r[it+6],y=r[it+7],A=(m-p*2+g)*.03,C=(x-v*2+w)*.03,I=((p-g)*3-m+b)*.006,E=((v-w)*3-x+y)*.006,R=A*2+I,L=C*2+E,k=(p-m)*.3+A+I*.16666667,F=(v-x)*.3+C+E*.16666667,D=Math.sqrt(k*k+F*F),T[0]=D,it=1;it<8;it++)k+=R,F+=L,R+=I,L+=E,D+=Math.sqrt(k*k+F*F),T[it]=D;k+=R,F+=L,D+=Math.sqrt(k*k+F*F),T[8]=D,k+=R+I,F+=L+E,D+=Math.sqrt(k*k+F*F),T[9]=D,st=0}for(nt*=D;;st++){let it=T[st];if(!(nt>it)){if(st==0)nt/=it;else{let dt=T[st-1];nt=st+(nt-dt)/(it-dt)}break}}this.addCurvePosition(nt*.1,m,x,p,v,g,w,b,y,a,et,i||P>0&&ht==0)}return a}addBeforePosition(t,e,i,s,n){let c=e[i],a=e[i+1],r=e[i+2]-c,o=e[i+3]-a,l=Math.atan2(o,r);s[n]=c+t*Math.cos(l),s[n+1]=a+t*Math.sin(l),s[n+2]=l}addAfterPosition(t,e,i,s,n){let c=e[i+2],a=e[i+3],r=c-e[i],o=a-e[i+1],l=Math.atan2(o,r);s[n]=c+t*Math.cos(l),s[n+1]=a+t*Math.sin(l),s[n+2]=l}addCurvePosition(t,e,i,s,n,c,a,r,o,l,h,d){if(t==0||isNaN(t)){l[h]=e,l[h+1]=i,l[h+2]=Math.atan2(n-i,s-e);return}let u=t*t,f=u*t,m=1-t,x=m*m,p=x*m,v=m*t,g=v*3,w=m*g,b=g*t,y=e*p+s*w+c*b+r*f,A=i*p+n*w+a*b+o*f;l[h]=y,l[h+1]=A,d&&(t<.001?l[h+2]=Math.atan2(n-i,s-e):l[h+2]=Math.atan2(A-(i*x+n*v*2+a*u),y-(e*x+s*v*2+c*u)))}},Jt=Lt;Jt.NONE=-1,Jt.BEFORE=-2,Jt.AFTER=-3,Jt.epsilon=1e-5;var as=class{constructor(t,e){if(this.darkColor=null,this.attachment=null,this.attachmentState=0,this.sequenceIndex=-1,this.deform=new Array,!t)throw new Error("data cannot be null.");if(!e)throw new Error("bone cannot be null.");this.data=t,this.bone=e,this.color=new O,this.darkColor=t.darkColor?new O:null,this.setToSetupPose()}getSkeleton(){return this.bone.skeleton}getAttachment(){return this.attachment}setAttachment(t){this.attachment!=t&&((!(t instanceof St)||!(this.attachment instanceof St)||t.timelineAttachment!=this.attachment.timelineAttachment)&&(this.deform.length=0),this.attachment=t,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}},ls=class{constructor(t,e){if(this.mixRotate=0,this.mixX=0,this.mixY=0,this.mixScaleX=0,this.mixScaleY=0,this.mixShearY=0,this.temp=new zt,this.active=!1,!t)throw new Error("data cannot be null.");if(!e)throw new Error("skeleton cannot be null.");this.data=t,this.mixRotate=t.mixRotate,this.mixX=t.mixX,this.mixY=t.mixY,this.mixScaleX=t.mixScaleX,this.mixScaleY=t.mixScaleY,this.mixShearY=t.mixShearY,this.bones=new Array;for(let s=0;s<t.bones.length;s++){let n=e.findBone(t.bones[s].name);if(!n)throw new Error(`Couldn't find bone ${t.bones[s].name}.`);this.bones.push(n)}let i=e.findBone(t.target.name);if(!i)throw new Error(`Couldn't find target bone ${t.target.name}.`);this.target=i}isActive(){return this.active}update(){this.mixRotate==0&&this.mixX==0&&this.mixY==0&&this.mixScaleX==0&&this.mixScaleY==0&&this.mixShearY==0||(this.data.local?this.data.relative?this.applyRelativeLocal():this.applyAbsoluteLocal():this.data.relative?this.applyRelativeWorld():this.applyAbsoluteWorld())}applyAbsoluteWorld(){let t=this.mixRotate,e=this.mixX,i=this.mixY,s=this.mixScaleX,n=this.mixScaleY,c=this.mixShearY,a=e!=0||i!=0,r=this.target,o=r.a,l=r.b,h=r.c,d=r.d,u=o*d-l*h>0?X.degRad:-X.degRad,f=this.data.offsetRotation*u,m=this.data.offsetShearY*u,x=this.bones;for(let p=0,v=x.length;p<v;p++){let g=x[p];if(t!=0){let w=g.a,b=g.b,y=g.c,A=g.d,C=Math.atan2(h,o)-Math.atan2(y,w)+f;C>X.PI?C-=X.PI2:C<-X.PI&&(C+=X.PI2),C*=t;let I=Math.cos(C),E=Math.sin(C);g.a=I*w-E*y,g.b=I*b-E*A,g.c=E*w+I*y,g.d=E*b+I*A}if(a){let w=this.temp;r.localToWorld(w.set(this.data.offsetX,this.data.offsetY)),g.worldX+=(w.x-g.worldX)*e,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+d*d)-w+this.data.offsetScaleY)*n)/w),g.b*=w,g.d*=w}if(c>0){let w=g.b,b=g.d,y=Math.atan2(b,w),A=Math.atan2(d,l)-Math.atan2(h,o)-(y-Math.atan2(g.c,g.a));A>X.PI?A-=X.PI2:A<-X.PI&&(A+=X.PI2),A=y+(A+m)*c;let C=Math.sqrt(w*w+b*b);g.b=Math.cos(A)*C,g.d=Math.sin(A)*C}g.updateAppliedTransform()}}applyRelativeWorld(){let t=this.mixRotate,e=this.mixX,i=this.mixY,s=this.mixScaleX,n=this.mixScaleY,c=this.mixShearY,a=e!=0||i!=0,r=this.target,o=r.a,l=r.b,h=r.c,d=r.d,u=o*d-l*h>0?X.degRad:-X.degRad,f=this.data.offsetRotation*u,m=this.data.offsetShearY*u,x=this.bones;for(let p=0,v=x.length;p<v;p++){let g=x[p];if(t!=0){let w=g.a,b=g.b,y=g.c,A=g.d,C=Math.atan2(h,o)+f;C>X.PI?C-=X.PI2:C<-X.PI&&(C+=X.PI2),C*=t;let I=Math.cos(C),E=Math.sin(C);g.a=I*w-E*y,g.b=I*b-E*A,g.c=E*w+I*y,g.d=E*b+I*A}if(a){let w=this.temp;r.localToWorld(w.set(this.data.offsetX,this.data.offsetY)),g.worldX+=w.x*e,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+d*d)-1+this.data.offsetScaleY)*n+1;g.b*=w,g.d*=w}if(c>0){let w=Math.atan2(d,l)-Math.atan2(h,o);w>X.PI?w-=X.PI2:w<-X.PI&&(w+=X.PI2);let b=g.b,y=g.d;w=Math.atan2(y,b)+(w-X.PI/2+m)*c;let A=Math.sqrt(b*b+y*y);g.b=Math.cos(w)*A,g.d=Math.sin(w)*A}g.updateAppliedTransform()}}applyAbsoluteLocal(){let t=this.mixRotate,e=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],d=h.arotation;if(t!=0){let v=a.arotation-d+this.data.offsetRotation;v-=(16384-(16384.499999999996-v/360|0))*360,d+=v*t}let u=h.ax,f=h.ay;u+=(a.ax-u+this.data.offsetX)*e,f+=(a.ay-f+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 p=h.ashearY;if(c!=0){let v=a.ashearY-p+this.data.offsetShearY;v-=(16384-(16384.499999999996-v/360|0))*360,p+=v*c}h.updateWorldTransformWith(u,f,d,m,x,h.ashearX,p)}}applyRelativeLocal(){let t=this.mixRotate,e=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],d=h.arotation+(a.arotation+this.data.offsetRotation)*t,u=h.ax+(a.ax+this.data.offsetX)*e,f=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),p=h.ashearY+(a.ashearY+this.data.offsetShearY)*c;h.updateWorldTransformWith(u,f,d,m,x,h.ashearX,p)}}},os=class{constructor(t){if(this._updateCache=new Array,this.skin=null,this.scaleX=1,this._scaleY=1,this.x=0,this.y=0,!t)throw new Error("data cannot be null.");this.data=t,this.bones=new Array;for(let e=0;e<t.bones.length;e++){let i=t.bones[e],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 e=0;e<t.slots.length;e++){let i=t.slots[e],s=this.bones[i.boneData.index],n=new as(i,s);this.slots.push(n),this.drawOrder.push(n)}this.ikConstraints=new Array;for(let e=0;e<t.ikConstraints.length;e++){let i=t.ikConstraints[e];this.ikConstraints.push(new ns(i,this))}this.transformConstraints=new Array;for(let e=0;e<t.transformConstraints.length;e++){let i=t.transformConstraints[e];this.transformConstraints.push(new ls(i,this))}this.pathConstraints=new Array;for(let e=0;e<t.pathConstraints.length;e++){let i=t.pathConstraints[e];this.pathConstraints.push(new Jt(i,this))}this.color=new O(1,1,1,1),this.updateCache()}get scaleY(){return os.yDown?-this._scaleY:this._scaleY}set scaleY(t){this._scaleY=t}updateCache(){let t=this._updateCache;t.length=0;let e=this.bones;for(let l=0,h=e.length;l<h;l++){let d=e[l];d.sorted=d.data.skinRequired,d.active=!d.sorted}if(this.skin){let l=this.skin.bones;for(let h=0,d=this.skin.bones.length;h<d;h++){let u=this.bones[l[h].index];do u.sorted=!1,u.active=!0,u=u.parent;while(u)}}let i=this.ikConstraints,s=this.transformConstraints,n=this.pathConstraints,c=i.length,a=s.length,r=n.length,o=c+a+r;t:for(let l=0;l<o;l++){for(let h=0;h<c;h++){let d=i[h];if(d.data.order==l){this.sortIkConstraint(d);continue t}}for(let h=0;h<a;h++){let d=s[h];if(d.data.order==l){this.sortTransformConstraint(d);continue t}}for(let h=0;h<r;h++){let d=n[h];if(d.data.order==l){this.sortPathConstraint(d);continue t}}}for(let l=0,h=e.length;l<h;l++)this.sortBone(e[l])}sortIkConstraint(t){if(t.active=t.target.isActive()&&(!t.data.skinRequired||this.skin&&B.contains(this.skin.constraints,t.data,!0)),!t.active)return;let e=t.target;this.sortBone(e);let i=t.bones,s=i[0];if(this.sortBone(s),i.length==1)this._updateCache.push(t),this.sortReset(s.children);else{let n=i[i.length-1];this.sortBone(n),this._updateCache.push(t),this.sortReset(s.children),n.sorted=!0}}sortPathConstraint(t){if(t.active=t.target.bone.isActive()&&(!t.data.skinRequired||this.skin&&B.contains(this.skin.constraints,t.data,!0)),!t.active)return;let e=t.target,i=e.data.index,s=e.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=e.getAttachment();n instanceof Gt&&this.sortPathConstraintAttachmentWith(n,s);let c=t.bones,a=c.length;for(let r=0;r<a;r++)this.sortBone(c[r]);this._updateCache.push(t);for(let r=0;r<a;r++)this.sortReset(c[r].children);for(let r=0;r<a;r++)c[r].sorted=!0}sortTransformConstraint(t){if(t.active=t.target.isActive()&&(!t.data.skinRequired||this.skin&&B.contains(this.skin.constraints,t.data,!0)),!t.active)return;this.sortBone(t.target);let e=t.bones,i=e.length;if(t.data.local)for(let s=0;s<i;s++){let n=e[s];this.sortBone(n.parent),this.sortBone(n)}else for(let s=0;s<i;s++)this.sortBone(e[s]);this._updateCache.push(t);for(let s=0;s<i;s++)this.sortReset(e[s].children);for(let s=0;s<i;s++)e[s].sorted=!0}sortPathConstraintAttachment(t,e,i){let s=t.attachments[e];if(s)for(let n in s)this.sortPathConstraintAttachmentWith(s[n],i)}sortPathConstraintAttachmentWith(t,e){if(!(t instanceof Gt))return;let i=t.bones;if(!i)this.sortBone(e);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(t){if(!t||t.sorted)return;let e=t.parent;e&&this.sortBone(e),t.sorted=!0,this._updateCache.push(t)}sortReset(t){for(let e=0,i=t.length;e<i;e++){let s=t[e];s.active&&(s.sorted&&this.sortReset(s.children),s.sorted=!1)}}updateWorldTransform(){let t=this.bones;for(let i=0,s=t.length;i<s;i++){let n=t[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 e=this._updateCache;for(let i=0,s=e.length;i<s;i++)e[i].update()}updateWorldTransformWith(t){let e=this.getRootBone();if(!e)throw new Error("Root bone must not be null.");let i=t.a,s=t.b,n=t.c,c=t.d;e.worldX=i*this.x+s*this.y+t.worldX,e.worldY=n*this.x+c*this.y+t.worldY;let a=e.rotation+90+e.shearY,r=X.cosDeg(e.rotation+e.shearX)*e.scaleX,o=X.cosDeg(a)*e.scaleY,l=X.sinDeg(e.rotation+e.shearX)*e.scaleX,h=X.sinDeg(a)*e.scaleY;e.a=(i*r+s*l)*this.scaleX,e.b=(i*o+s*h)*this.scaleX,e.c=(n*r+c*l)*this.scaleY,e.d=(n*o+c*h)*this.scaleY;let d=this._updateCache;for(let u=0,f=d.length;u<f;u++){let m=d[u];m!=e&&m.update()}}setToSetupPose(){this.setBonesToSetupPose(),this.setSlotsToSetupPose()}setBonesToSetupPose(){let t=this.bones;for(let n=0,c=t.length;n<c;n++)t[n].setToSetupPose();let e=this.ikConstraints;for(let n=0,c=e.length;n<c;n++){let a=e[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 t=this.slots;B.arrayCopy(t,0,this.drawOrder,0,t.length);for(let e=0,i=t.length;e<i;e++)t[e].setToSetupPose()}getRootBone(){return this.bones.length==0?null:this.bones[0]}findBone(t){if(!t)throw new Error("boneName cannot be null.");let e=this.bones;for(let i=0,s=e.length;i<s;i++){let n=e[i];if(n.data.name==t)return n}return null}findSlot(t){if(!t)throw new Error("slotName cannot be null.");let e=this.slots;for(let i=0,s=e.length;i<s;i++){let n=e[i];if(n.data.name==t)return n}return null}setSkinByName(t){let e=this.data.findSkin(t);if(!e)throw new Error("Skin not found: "+t);this.setSkin(e)}setSkin(t){if(t!=this.skin){if(t)if(this.skin)t.attachAll(this,this.skin);else{let e=this.slots;for(let i=0,s=e.length;i<s;i++){let n=e[i],c=n.data.attachmentName;if(c){let a=t.getAttachment(i,c);a&&n.setAttachment(a)}}}this.skin=t,this.updateCache()}}getAttachmentByName(t,e){let i=this.data.findSlot(t);if(!i)throw new Error(`Can't find slot with name ${t}`);return this.getAttachment(i.index,e)}getAttachment(t,e){if(!e)throw new Error("attachmentName cannot be null.");if(this.skin){let i=this.skin.getAttachment(t,e);if(i)return i}return this.data.defaultSkin?this.data.defaultSkin.getAttachment(t,e):null}setAttachment(t,e){if(!t)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==t){let a=null;if(e&&(a=this.getAttachment(s,e),!a))throw new Error("Attachment not found: "+e+", for slot: "+t);c.setAttachment(a);return}}throw new Error("Slot not found: "+t)}findIkConstraint(t){if(!t)throw new Error("constraintName cannot be null.");let e=this.ikConstraints;for(let i=0,s=e.length;i<s;i++){let n=e[i];if(n.data.name==t)return n}return null}findTransformConstraint(t){if(!t)throw new Error("constraintName cannot be null.");let e=this.transformConstraints;for(let i=0,s=e.length;i<s;i++){let n=e[i];if(n.data.name==t)return n}return null}findPathConstraint(t){if(!t)throw new Error("constraintName cannot be null.");let e=this.pathConstraints;for(let i=0,s=e.length;i<s;i++){let n=e[i];if(n.data.name==t)return n}return null}getBoundsRect(){let t=new zt,e=new zt;return this.getBounds(t,e),{x:t.x,y:t.y,width:e.x,height:e.y}}getBounds(t,e,i=new Array(2)){if(!t)throw new Error("offset cannot be null.");if(!e)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 d=0,u=null,f=h.getAttachment();if(f instanceof at)d=8,u=B.setArraySize(i,d,0),f.computeWorldVertices(h,u,0,2);else if(f instanceof Vt){let m=f;d=m.worldVerticesLength,u=B.setArraySize(i,d,0),m.computeWorldVertices(h,0,d,u,0,2)}if(u)for(let m=0,x=u.length;m<x;m+=2){let p=u[m],v=u[m+1];n=Math.min(n,p),c=Math.min(c,v),a=Math.max(a,p),r=Math.max(r,v)}}t.set(n,c),e.set(a-n,r-c)}},hs=os;hs.yDown=!1;var 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(t){if(!t)throw new Error("boneName cannot be null.");let e=this.bones;for(let i=0,s=e.length;i<s;i++){let n=e[i];if(n.name==t)return n}return null}findSlot(t){if(!t)throw new Error("slotName cannot be null.");let e=this.slots;for(let i=0,s=e.length;i<s;i++){let n=e[i];if(n.name==t)return n}return null}findSkin(t){if(!t)throw new Error("skinName cannot be null.");let e=this.skins;for(let i=0,s=e.length;i<s;i++){let n=e[i];if(n.name==t)return n}return null}findEvent(t){if(!t)throw new Error("eventDataName cannot be null.");let e=this.events;for(let i=0,s=e.length;i<s;i++){let n=e[i];if(n.name==t)return n}return null}findAnimation(t){if(!t)throw new Error("animationName cannot be null.");let e=this.animations;for(let i=0,s=e.length;i<s;i++){let n=e[i];if(n.name==t)return n}return null}findIkConstraint(t){if(!t)throw new Error("constraintName cannot be null.");let e=this.ikConstraints;for(let i=0,s=e.length;i<s;i++){let n=e[i];if(n.name==t)return n}return null}findTransformConstraint(t){if(!t)throw new Error("constraintName cannot be null.");let e=this.transformConstraints;for(let i=0,s=e.length;i<s;i++){let n=e[i];if(n.name==t)return n}return null}findPathConstraint(t){if(!t)throw new Error("constraintName cannot be null.");let e=this.pathConstraints;for(let i=0,s=e.length;i<s;i++){let n=e[i];if(n.name==t)return n}return null}},Si=class{constructor(t=0,e,i){this.slotIndex=t,this.name=e,this.attachment=i}},Me=class{constructor(t){if(this.attachments=new Array,this.bones=Array(),this.constraints=new Array,!t)throw new Error("name cannot be null.");this.name=t}setAttachment(t,e,i){if(!i)throw new Error("attachment cannot be null.");let s=this.attachments;t>=s.length&&(s.length=t+1),s[t]||(s[t]={}),s[t][e]=i}addSkin(t){for(let s=0;s<t.bones.length;s++){let n=t.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<t.constraints.length;s++){let n=t.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 e=t.getAttachments();for(let s=0;s<e.length;s++){var i=e[s];this.setAttachment(i.slotIndex,i.name,i.attachment)}}copySkin(t){for(let s=0;s<t.bones.length;s++){let n=t.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<t.constraints.length;s++){let n=t.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 e=t.getAttachments();for(let s=0;s<e.length;s++){var i=e[s];i.attachment&&(i.attachment instanceof Vt?(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(t,e){let i=this.attachments[t];return i?i[e]:null}removeAttachment(t,e){let i=this.attachments[t];i&&delete i[e]}getAttachments(){let t=new Array;for(var e=0;e<this.attachments.length;e++){let i=this.attachments[e];if(i)for(let s in i){let n=i[s];n&&t.push(new Si(e,s,n))}}return t}getAttachmentsForSlot(t,e){let i=this.attachments[t];if(i)for(let s in i){let n=i[s];n&&e.push(new Si(t,s,n))}}clear(){this.attachments.length=0,this.bones.length=0,this.constraints.length=0}attachAll(t,e){let i=0;for(let s=0;s<t.slots.length;s++){let n=t.slots[s],c=n.getAttachment();if(c&&i<e.attachments.length){let a=e.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(t,e,i){if(this.index=0,this.color=new O(1,1,1,1),this.darkColor=null,this.attachmentName=null,this.blendMode=Ye.Normal,t<0)throw new Error("index must be >= 0.");if(!e)throw new Error("name cannot be null.");if(!i)throw new Error("boneData cannot be null.");this.index=t,this.name=e,this.boneData=i}},Ye=(t=>(t[t.Normal=0]="Normal",t[t.Additive=1]="Additive",t[t.Multiply=2]="Multiply",t[t.Screen=3]="Screen",t))(Ye||{}),Ii=class extends Ce{constructor(t){super(t,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(t){this._target=t}get target(){if(this._target)return this._target;throw new Error("BoneData not set.")}},Us=class{constructor(t){this.scale=1,this.linkedMeshes=new Array,this.attachmentLoader=t}readSkeletonData(t){let e=this.scale,i=new Ci;i.name="";let s=new cs(t),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 d=l==0?null:i.bones[s.readInt(!0)],u=new xi(l,h,d);u.rotation=s.readFloat(),u.x=s.readFloat()*e,u.y=s.readFloat()*e,u.scaleX=s.readFloat(),u.scaleY=s.readFloat(),u.shearX=s.readFloat(),u.shearY=s.readFloat(),u.length=s.readFloat()*e,u.transformMode=s.readInt(!0),u.skinRequired=s.readBoolean(),a&&O.rgba8888ToColor(u.color,s.readInt32()),i.bones.push(u)}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 d=i.bones[s.readInt(!0)],u=new Ti(l,h,d);O.rgba8888ToColor(u.color,s.readInt32());let f=s.readInt32();f!=-1&&O.rgb888ToColor(u.darkColor=new O,f),u.attachmentName=s.readStringRef(),u.blendMode=s.readInt(!0),i.slots.push(u)}r=s.readInt(!0);for(let l=0,h;l<r;l++){let d=s.readString();if(!d)throw new Error("IK constraint data name must not be null.");let u=new yi(d);u.order=s.readInt(!0),u.skinRequired=s.readBoolean(),h=s.readInt(!0);for(let f=0;f<h;f++)u.bones.push(i.bones[s.readInt(!0)]);u.target=i.bones[s.readInt(!0)],u.mix=s.readFloat(),u.softness=s.readFloat()*e,u.bendDirection=s.readByte(),u.compress=s.readBoolean(),u.stretch=s.readBoolean(),u.uniform=s.readBoolean(),i.ikConstraints.push(u)}r=s.readInt(!0);for(let l=0,h;l<r;l++){let d=s.readString();if(!d)throw new Error("Transform constraint data name must not be null.");let u=new Ii(d);u.order=s.readInt(!0),u.skinRequired=s.readBoolean(),h=s.readInt(!0);for(let f=0;f<h;f++)u.bones.push(i.bones[s.readInt(!0)]);u.target=i.bones[s.readInt(!0)],u.local=s.readBoolean(),u.relative=s.readBoolean(),u.offsetRotation=s.readFloat(),u.offsetX=s.readFloat()*e,u.offsetY=s.readFloat()*e,u.offsetScaleX=s.readFloat(),u.offsetScaleY=s.readFloat(),u.offsetShearY=s.readFloat(),u.mixRotate=s.readFloat(),u.mixX=s.readFloat(),u.mixY=s.readFloat(),u.mixScaleX=s.readFloat(),u.mixScaleY=s.readFloat(),u.mixShearY=s.readFloat(),i.transformConstraints.push(u)}r=s.readInt(!0);for(let l=0,h;l<r;l++){let d=s.readString();if(!d)throw new Error("Path constraint data name must not be null.");let u=new Ai(d);u.order=s.readInt(!0),u.skinRequired=s.readBoolean(),h=s.readInt(!0);for(let f=0;f<h;f++)u.bones.push(i.bones[s.readInt(!0)]);u.target=i.slots[s.readInt(!0)],u.positionMode=s.readInt(!0),u.spacingMode=s.readInt(!0),u.rotateMode=s.readInt(!0),u.offsetRotation=s.readFloat(),u.position=s.readFloat(),u.positionMode==0&&(u.position*=e),u.spacing=s.readFloat(),(u.spacingMode==0||u.spacingMode==1)&&(u.spacing*=e),u.mixRotate=s.readFloat(),u.mixX=s.readFloat(),u.mixY=s.readFloat(),i.pathConstraints.push(u)}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],d=h.skin?i.findSkin(h.skin):i.defaultSkin;if(!d)throw new Error("Not skin found for linked mesh.");if(!h.parent)throw new Error("Linked mesh parent must not be null");let u=d.getAttachment(h.slotIndex,h.parent);if(!u)throw new Error(`Parent mesh not found: ${h.parent}`);h.mesh.timelineAttachment=h.inheritTimeline?u:h.mesh,h.mesh.setParentMesh(u),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 d=new vi(h);d.intValue=s.readInt(!1),d.floatValue=s.readFloat(),d.stringValue=s.readString(),d.audioPath=s.readString(),d.audioPath&&(d.volume=s.readFloat(),d.balance=s.readFloat()),i.events.push(d)}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(t,e,i,s){let n=null,c=0;if(i){if(c=t.readInt(!0),c==0)return null;n=new Me("default")}else{let a=t.readStringRef();if(!a)throw new Error("Skin name must not be null.");n=new Me(a),n.bones.length=t.readInt(!0);for(let r=0,o=n.bones.length;r<o;r++)n.bones[r]=e.bones[t.readInt(!0)];for(let r=0,o=t.readInt(!0);r<o;r++)n.constraints.push(e.ikConstraints[t.readInt(!0)]);for(let r=0,o=t.readInt(!0);r<o;r++)n.constraints.push(e.transformConstraints[t.readInt(!0)]);for(let r=0,o=t.readInt(!0);r<o;r++)n.constraints.push(e.pathConstraints[t.readInt(!0)]);c=t.readInt(!0)}for(let a=0;a<c;a++){let r=t.readInt(!0);for(let o=0,l=t.readInt(!0);o<l;o++){let h=t.readStringRef();if(!h)throw new Error("Attachment name must not be null");let d=this.readAttachment(t,e,n,r,h,s);d&&n.setAttachment(r,h,d)}}return n}readAttachment(t,e,i,s,n,c){let a=this.scale,r=t.readStringRef();switch(r||(r=n),t.readByte()){case Nt.Region:{let o=t.readStringRef(),l=t.readFloat(),h=t.readFloat(),d=t.readFloat(),u=t.readFloat(),f=t.readFloat(),m=t.readFloat(),x=t.readFloat(),p=t.readInt32(),v=this.readSequence(t);o||(o=r);let g=this.attachmentLoader.newRegionAttachment(i,r,o,v);return g?(g.path=o,g.x=h*a,g.y=d*a,g.scaleX=u,g.scaleY=f,g.rotation=l,g.width=m*a,g.height=x*a,O.rgba8888ToColor(g.color,p),g.sequence=v,v==null&&g.updateRegion(),g):null}case Nt.BoundingBox:{let o=t.readInt(!0),l=this.readVertices(t,o),h=c?t.readInt32():0,d=this.attachmentLoader.newBoundingBoxAttachment(i,r);return d?(d.worldVerticesLength=o<<1,d.vertices=l.vertices,d.bones=l.bones,c&&O.rgba8888ToColor(d.color,h),d):null}case Nt.Mesh:{let o=t.readStringRef(),l=t.readInt32(),h=t.readInt(!0),d=this.readFloatArray(t,h<<1,1),u=this.readShortArray(t),f=this.readVertices(t,h),m=t.readInt(!0),x=this.readSequence(t),p=[],v=0,g=0;c&&(p=this.readShortArray(t),v=t.readFloat(),g=t.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=f.bones,w.vertices=f.vertices,w.worldVerticesLength=h<<1,w.triangles=u,w.regionUVs=d,x==null&&w.updateRegion(),w.hullLength=m<<1,w.sequence=x,c&&(w.edges=p,w.width=v*a,w.height=g*a),w):null}case Nt.LinkedMesh:{let o=t.readStringRef(),l=t.readInt32(),h=t.readStringRef(),d=t.readStringRef(),u=t.readBoolean(),f=this.readSequence(t),m=0,x=0;c&&(m=t.readFloat(),x=t.readFloat()),o||(o=r);let p=this.attachmentLoader.newMeshAttachment(i,r,o,f);return p?(p.path=o,O.rgba8888ToColor(p.color,l),p.sequence=f,c&&(p.width=m*a,p.height=x*a),this.linkedMeshes.push(new _s(p,h,s,d,u)),p):null}case Nt.Path:{let o=t.readBoolean(),l=t.readBoolean(),h=t.readInt(!0),d=this.readVertices(t,h),u=B.newArray(h/3,0);for(let x=0,p=u.length;x<p;x++)u[x]=t.readFloat()*a;let f=c?t.readInt32():0,m=this.attachmentLoader.newPathAttachment(i,r);return m?(m.closed=o,m.constantSpeed=l,m.worldVerticesLength=h<<1,m.vertices=d.vertices,m.bones=d.bones,m.lengths=u,c&&O.rgba8888ToColor(m.color,f),m):null}case Nt.Point:{let o=t.readFloat(),l=t.readFloat(),h=t.readFloat(),d=c?t.readInt32():0,u=this.attachmentLoader.newPointAttachment(i,r);return u?(u.x=l*a,u.y=h*a,u.rotation=o,c&&O.rgba8888ToColor(u.color,d),u):null}case Nt.Clipping:{let o=t.readInt(!0),l=t.readInt(!0),h=this.readVertices(t,l),d=c?t.readInt32():0,u=this.attachmentLoader.newClippingAttachment(i,r);return u?(u.endSlot=e.slots[o],u.worldVerticesLength=l<<1,u.vertices=h.vertices,u.bones=h.bones,c&&O.rgba8888ToColor(u.color,d),u):null}}return null}readSequence(t){if(!t.readBoolean())return null;let e=new ze(t.readInt(!0));return e.start=t.readInt(!0),e.digits=t.readInt(!0),e.setupIndex=t.readInt(!0),e}readVertices(t,e){let i=this.scale,s=e<<1,n=new zs;if(!t.readBoolean())return n.vertices=this.readFloatArray(t,s,i),n;let c=new Array,a=new Array;for(let r=0;r<e;r++){let o=t.readInt(!0);a.push(o);for(let l=0;l<o;l++)a.push(t.readInt(!0)),c.push(t.readFloat()*i),c.push(t.readFloat()*i),c.push(t.readFloat())}return n.vertices=B.toFloatArray(c),n.bones=a,n}readFloatArray(t,e,i){let s=new Array(e);if(i==1)for(let n=0;n<e;n++)s[n]=t.readFloat();else for(let n=0;n<e;n++)s[n]=t.readFloat()*i;return s}readShortArray(t){let e=t.readInt(!0),i=new Array(e);for(let s=0;s<e;s++)i[s]=t.readShort();return i}readAnimation(t,e,i){t.readInt(!0);let s=new Array,n=this.scale,c=new O,a=new O;for(let h=0,d=t.readInt(!0);h<d;h++){let u=t.readInt(!0);for(let f=0,m=t.readInt(!0);f<m;f++){let x=t.readByte(),p=t.readInt(!0),v=p-1;switch(x){case tr:{let g=new Wt(p,u);for(let w=0;w<p;w++)g.setFrame(w,t.readFloat(),t.readStringRef());s.push(g);break}case er:{let g=t.readInt(!0),w=new $e(p,g,u),b=t.readFloat(),y=t.readUnsignedByte()/255,A=t.readUnsignedByte()/255,C=t.readUnsignedByte()/255,I=t.readUnsignedByte()/255;for(let E=0,R=0;w.setFrame(E,b,y,A,C,I),E!=v;E++){let L=t.readFloat(),k=t.readUnsignedByte()/255,F=t.readUnsignedByte()/255,Y=t.readUnsignedByte()/255,T=t.readUnsignedByte()/255;switch(t.readByte()){case Mt:w.setStepped(E);break;case Yt:lt(t,w,R++,E,0,b,L,y,k,1),lt(t,w,R++,E,1,b,L,A,F,1),lt(t,w,R++,E,2,b,L,C,Y,1),lt(t,w,R++,E,3,b,L,I,T,1)}b=L,y=k,A=F,C=Y,I=T}s.push(w);break}case ir:{let g=t.readInt(!0),w=new ti(p,g,u),b=t.readFloat(),y=t.readUnsignedByte()/255,A=t.readUnsignedByte()/255,C=t.readUnsignedByte()/255;for(let I=0,E=0;w.setFrame(I,b,y,A,C),I!=v;I++){let R=t.readFloat(),L=t.readUnsignedByte()/255,k=t.readUnsignedByte()/255,F=t.readUnsignedByte()/255;switch(t.readByte()){case Mt:w.setStepped(I);break;case Yt:lt(t,w,E++,I,0,b,R,y,L,1),lt(t,w,E++,I,1,b,R,A,k,1),lt(t,w,E++,I,2,b,R,C,F,1)}b=R,y=L,A=k,C=F}s.push(w);break}case sr:{let g=t.readInt(!0),w=new ii(p,g,u),b=t.readFloat(),y=t.readUnsignedByte()/255,A=t.readUnsignedByte()/255,C=t.readUnsignedByte()/255,I=t.readUnsignedByte()/255,E=t.readUnsignedByte()/255,R=t.readUnsignedByte()/255,L=t.readUnsignedByte()/255;for(let k=0,F=0;w.setFrame(k,b,y,A,C,I,E,R,L),k!=v;k++){let Y=t.readFloat(),T=t.readUnsignedByte()/255,D=t.readUnsignedByte()/255,P=t.readUnsignedByte()/255,et=t.readUnsignedByte()/255,rt=t.readUnsignedByte()/255,st=t.readUnsignedByte()/255,ht=t.readUnsignedByte()/255;switch(t.readByte()){case Mt:w.setStepped(k);break;case Yt:lt(t,w,F++,k,0,b,Y,y,T,1),lt(t,w,F++,k,1,b,Y,A,D,1),lt(t,w,F++,k,2,b,Y,C,P,1),lt(t,w,F++,k,3,b,Y,I,et,1),lt(t,w,F++,k,4,b,Y,E,rt,1),lt(t,w,F++,k,5,b,Y,R,st,1),lt(t,w,F++,k,6,b,Y,L,ht,1)}b=Y,y=T,A=D,C=P,I=et,E=rt,R=st,L=ht}s.push(w);break}case rr:{let g=t.readInt(!0),w=new si(p,g,u),b=t.readFloat(),y=t.readUnsignedByte()/255,A=t.readUnsignedByte()/255,C=t.readUnsignedByte()/255,I=t.readUnsignedByte()/255,E=t.readUnsignedByte()/255,R=t.readUnsignedByte()/255;for(let L=0,k=0;w.setFrame(L,b,y,A,C,I,E,R),L!=v;L++){let F=t.readFloat(),Y=t.readUnsignedByte()/255,T=t.readUnsignedByte()/255,D=t.readUnsignedByte()/255,P=t.readUnsignedByte()/255,et=t.readUnsignedByte()/255,rt=t.readUnsignedByte()/255;switch(t.readByte()){case Mt:w.setStepped(L);break;case Yt:lt(t,w,k++,L,0,b,F,y,Y,1),lt(t,w,k++,L,1,b,F,A,T,1),lt(t,w,k++,L,2,b,F,C,D,1),lt(t,w,k++,L,3,b,F,I,P,1),lt(t,w,k++,L,4,b,F,E,et,1),lt(t,w,k++,L,5,b,F,R,rt,1)}b=F,y=Y,A=T,C=D,I=P,E=et,R=rt}s.push(w);break}case nr:{let g=new ei(p,t.readInt(!0),u),w=t.readFloat(),b=t.readUnsignedByte()/255;for(let y=0,A=0;g.setFrame(y,w,b),y!=v;y++){let C=t.readFloat(),I=t.readUnsignedByte()/255;switch(t.readByte()){case Mt:g.setStepped(y);break;case Yt:lt(t,g,A++,y,0,w,C,b,I,1)}w=C,b=I}s.push(g)}}}}for(let h=0,d=t.readInt(!0);h<d;h++){let u=t.readInt(!0);for(let f=0,m=t.readInt(!0);f<m;f++){let x=t.readByte(),p=t.readInt(!0),v=t.readInt(!0);switch(x){case Ws:s.push(Bt(t,new ne(p,v,u),1));break;case qs:s.push(Mi(t,new We(p,v,u),n));break;case Gs:s.push(Bt(t,new qe(p,v,u),n));break;case Hs:s.push(Bt(t,new Ge(p,v,u),n));break;case js:s.push(Mi(t,new He(p,v,u),1));break;case Zs:s.push(Bt(t,new je(p,v,u),1));break;case Ks:s.push(Bt(t,new Ze(p,v,u),1));break;case Js:s.push(Mi(t,new Ke(p,v,u),1));break;case Qs:s.push(Bt(t,new Je(p,v,u),1));break;case $s:s.push(Bt(t,new Qe(p,v,u),1))}}}for(let h=0,d=t.readInt(!0);h<d;h++){let u=t.readInt(!0),f=t.readInt(!0),m=f-1,x=new ni(f,t.readInt(!0),u),p=t.readFloat(),v=t.readFloat(),g=t.readFloat()*n;for(let w=0,b=0;x.setFrame(w,p,v,g,t.readByte(),t.readBoolean(),t.readBoolean()),w!=m;w++){let y=t.readFloat(),A=t.readFloat(),C=t.readFloat()*n;switch(t.readByte()){case Mt:x.setStepped(w);break;case Yt:lt(t,x,b++,w,0,p,y,v,A,1),lt(t,x,b++,w,1,p,y,g,C,n)}p=y,v=A,g=C}s.push(x)}for(let h=0,d=t.readInt(!0);h<d;h++){let u=t.readInt(!0),f=t.readInt(!0),m=f-1,x=new ai(f,t.readInt(!0),u),p=t.readFloat(),v=t.readFloat(),g=t.readFloat(),w=t.readFloat(),b=t.readFloat(),y=t.readFloat(),A=t.readFloat();for(let C=0,I=0;x.setFrame(C,p,v,g,w,b,y,A),C!=m;C++){let E=t.readFloat(),R=t.readFloat(),L=t.readFloat(),k=t.readFloat(),F=t.readFloat(),Y=t.readFloat(),T=t.readFloat();switch(t.readByte()){case Mt:x.setStepped(C);break;case Yt:lt(t,x,I++,C,0,p,E,v,R,1),lt(t,x,I++,C,1,p,E,g,L,1),lt(t,x,I++,C,2,p,E,w,k,1),lt(t,x,I++,C,3,p,E,b,F,1),lt(t,x,I++,C,4,p,E,y,Y,1),lt(t,x,I++,C,5,p,E,A,T,1)}p=E,v=R,g=L,w=k,b=F,y=Y,A=T}s.push(x)}for(let h=0,d=t.readInt(!0);h<d;h++){let u=t.readInt(!0),f=i.pathConstraints[u];for(let m=0,x=t.readInt(!0);m<x;m++)switch(t.readByte()){case or:s.push(Bt(t,new li(t.readInt(!0),t.readInt(!0),u),f.positionMode==0?n:1));break;case hr:s.push(Bt(t,new oi(t.readInt(!0),t.readInt(!0),u),f.spacingMode==0||f.spacingMode==1?n:1));break;case cr:let p=new hi(t.readInt(!0),t.readInt(!0),u),v=t.readFloat(),g=t.readFloat(),w=t.readFloat(),b=t.readFloat();for(let y=0,A=0,C=p.getFrameCount()-1;p.setFrame(y,v,g,w,b),y!=C;y++){let I=t.readFloat(),E=t.readFloat(),R=t.readFloat(),L=t.readFloat();switch(t.readByte()){case Mt:p.setStepped(y);break;case Yt:lt(t,p,A++,y,0,v,I,g,E,1),lt(t,p,A++,y,1,v,I,w,R,1),lt(t,p,A++,y,2,v,I,b,L,1)}v=I,g=E,w=R,b=L}s.push(p)}}for(let h=0,d=t.readInt(!0);h<d;h++){let u=i.skins[t.readInt(!0)];for(let f=0,m=t.readInt(!0);f<m;f++){let x=t.readInt(!0);for(let p=0,v=t.readInt(!0);p<v;p++){let g=t.readStringRef();if(!g)throw new Error("attachmentName must not be null.");let w=u.getAttachment(x,g),b=t.readByte(),y=t.readInt(!0),A=y-1;switch(b){case ar:{let C=w,I=C.bones,E=C.vertices,R=I?E.length/3*2:E.length,L=t.readInt(!0),k=new ri(y,L,x,C),F=t.readFloat();for(let Y=0,T=0;;Y++){let D,P=t.readInt(!0);if(P==0)D=I?B.newFloatArray(R):E;else{D=B.newFloatArray(R);let rt=t.readInt(!0);if(P+=rt,n==1)for(let st=rt;st<P;st++)D[st]=t.readFloat();else for(let st=rt;st<P;st++)D[st]=t.readFloat()*n;if(!I)for(let st=0,ht=D.length;st<ht;st++)D[st]+=E[st]}if(k.setFrame(Y,F,D),Y==A)break;let et=t.readFloat();switch(t.readByte()){case Mt:k.setStepped(Y);break;case Yt:lt(t,k,T++,Y,0,F,et,0,1,1)}F=et}s.push(k);break}case lr:{let C=new Kt(y,x,w);for(let I=0;I<y;I++){let E=t.readFloat(),R=t.readInt32();C.setFrame(I,E,zi[R&15],R>>4,t.readFloat())}s.push(C);break}}}}}let r=t.readInt(!0);if(r>0){let h=new qt(r),d=i.slots.length;for(let u=0;u<r;u++){let f=t.readFloat(),m=t.readInt(!0),x=B.newArray(d,0);for(let w=d-1;w>=0;w--)x[w]=-1;let p=B.newArray(d-m,0),v=0,g=0;for(let w=0;w<m;w++){let b=t.readInt(!0);for(;v!=b;)p[g++]=v++;x[v+t.readInt(!0)]=v++}for(;v<d;)p[g++]=v++;for(let w=d-1;w>=0;w--)x[w]==-1&&(x[w]=p[--g]);h.setFrame(u,f,x)}s.push(h)}let o=t.readInt(!0);if(o>0){let h=new ae(o);for(let d=0;d<o;d++){let u=t.readFloat(),f=i.events[t.readInt(!0)],m=new pi(u,f);m.intValue=t.readInt(!1),m.floatValue=t.readFloat(),m.stringValue=t.readBoolean()?t.readString():f.stringValue,m.data.audioPath&&(m.volume=t.readFloat(),m.balance=t.readFloat()),h.setFrame(d,m)}s.push(h)}let l=0;for(let h=0,d=s.length;h<d;h++)l=Math.max(l,s[h].getDuration());return new ge(e,s,l)}},cs=class{constructor(t,e=new Array,i=0,s=new DataView(t.buffer)){this.strings=e,this.index=i,this.buffer=s}readByte(){return this.buffer.getInt8(this.index++)}readUnsignedByte(){return this.buffer.getUint8(this.index++)}readShort(){let t=this.buffer.getInt16(this.index);return this.index+=2,t}readInt32(){let t=this.buffer.getInt32(this.index);return this.index+=4,t}readInt(t){let e=this.readByte(),i=e&127;return e&128&&(e=this.readByte(),i|=(e&127)<<7,e&128&&(e=this.readByte(),i|=(e&127)<<14,e&128&&(e=this.readByte(),i|=(e&127)<<21,e&128&&(e=this.readByte(),i|=(e&127)<<28)))),t?i:i>>>1^-(i&1)}readStringRef(){let t=this.readInt(!0);return t==0?null:this.strings[t-1]}readString(){let t=this.readInt(!0);switch(t){case 0:return null;case 1:return""}t--;let e="",i=0;for(let s=0;s<t;){let n=this.readUnsignedByte();switch(n>>4){case 12:case 13:e+=String.fromCharCode((n&31)<<6|this.readByte()&63),s+=2;break;case 14:e+=String.fromCharCode((n&15)<<12|(this.readByte()&63)<<6|this.readByte()&63),s+=3;break;default:e+=String.fromCharCode(n),s++}}return e}readFloat(){let t=this.buffer.getFloat32(this.index);return this.index+=4,t}readBoolean(){return this.readByte()!=0}},_s=class{constructor(t,e,i,s,n){this.mesh=t,this.skin=e,this.slotIndex=i,this.parent=s,this.inheritTimeline=n}},zs=class{constructor(t=null,e=null){this.bones=t,this.vertices=e}},Nt=(t=>(t[t.Region=0]="Region",t[t.BoundingBox=1]="BoundingBox",t[t.Mesh=2]="Mesh",t[t.LinkedMesh=3]="LinkedMesh",t[t.Path=4]="Path",t[t.Point=5]="Point",t[t.Clipping=6]="Clipping",t))(Nt||{});function Bt(t,e,i){let s=t.readFloat(),n=t.readFloat()*i;for(let c=0,a=0,r=e.getFrameCount()-1;e.setFrame(c,s,n),c!=r;c++){let o=t.readFloat(),l=t.readFloat()*i;switch(t.readByte()){case Mt:e.setStepped(c);break;case Yt:lt(t,e,a++,c,0,s,o,n,l,i)}s=o,n=l}return e}function Mi(t,e,i){let s=t.readFloat(),n=t.readFloat()*i,c=t.readFloat()*i;for(let a=0,r=0,o=e.getFrameCount()-1;e.setFrame(a,s,n,c),a!=o;a++){let l=t.readFloat(),h=t.readFloat()*i,d=t.readFloat()*i;switch(t.readByte()){case Mt:e.setStepped(a);break;case Yt:lt(t,e,r++,a,0,s,l,n,h,i),lt(t,e,r++,a,1,s,l,c,d,i)}s=l,n=h,c=d}return e}function lt(t,e,i,s,n,c,a,r,o,l){e.setBezier(i,s,n,c,r,t.readFloat(),t.readFloat()*l,t.readFloat(),t.readFloat()*l,a,o)}var Ws=0,qs=1,Gs=2,Hs=3,js=4,Zs=5,Ks=6,Js=7,Qs=8,$s=9,tr=0,er=1,ir=2,sr=3,rr=4,nr=5,ar=0,lr=1,or=0,hr=1,cr=2,Mt=1,Yt=2,ds=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 re(()=>B.newFloatArray(16))}update(t,e){if(!t)throw new Error("skeleton cannot be null.");let i=this.boundingBoxes,s=this.polygons,n=this.polygonPool,c=t.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 ve){let h=l;i.push(h);let d=n.obtain();d.length!=h.worldVerticesLength&&(d=B.newFloatArray(h.worldVerticesLength)),s.push(d),h.computeWorldVertices(o,0,h.worldVerticesLength,d,0,2)}}e?this.aabbCompute():(this.minX=Number.POSITIVE_INFINITY,this.minY=Number.POSITIVE_INFINITY,this.maxX=Number.NEGATIVE_INFINITY,this.maxY=Number.NEGATIVE_INFINITY)}aabbCompute(){let t=Number.POSITIVE_INFINITY,e=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 d=o[l],u=o[l+1];t=Math.min(t,d),e=Math.min(e,u),i=Math.max(i,d),s=Math.max(s,u)}}this.minX=t,this.minY=e,this.maxX=i,this.maxY=s}aabbContainsPoint(t,e){return t>=this.minX&&t<=this.maxX&&e>=this.minY&&e<=this.maxY}aabbIntersectsSegment(t,e,i,s){let n=this.minX,c=this.minY,a=this.maxX,r=this.maxY;if(t<=n&&i<=n||e<=c&&s<=c||t>=a&&i>=a||e>=r&&s>=r)return!1;let o=(s-e)/(i-t),l=o*(n-t)+e;if(l>c&&l<r||(l=o*(a-t)+e,l>c&&l<r))return!0;let h=(c-e)/o+t;return h>n&&h<a||(h=(r-e)/o+t,h>n&&h<a)}aabbIntersectsSkeleton(t){return this.minX<t.maxX&&this.maxX>t.minX&&this.minY<t.maxY&&this.maxY>t.minY}containsPoint(t,e){let i=this.polygons;for(let s=0,n=i.length;s<n;s++)if(this.containsPointPolygon(i[s],t,e))return this.boundingBoxes[s];return null}containsPointPolygon(t,e,i){let s=t,n=t.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)<e&&(a=!a)}c=r}return a}intersectsSegment(t,e,i,s){let n=this.polygons;for(let c=0,a=n.length;c<a;c++)if(this.intersectsSegmentPolygon(n[c],t,e,i,s))return this.boundingBoxes[c];return null}intersectsSegmentPolygon(t,e,i,s,n){let c=t,a=t.length,r=e-s,o=i-n,l=e*n-i*s,h=c[a-2],d=c[a-1];for(let u=0;u<a;u+=2){let f=c[u],m=c[u+1],x=h*m-d*f,p=h-f,v=d-m,g=r*v-o*p,w=(l*p-r*x)/g;if((w>=h&&w<=f||w>=f&&w<=h)&&(w>=e&&w<=s||w>=s&&w<=e)){let b=(l*v-o*x)/g;if((b>=d&&b<=m||b>=m&&b<=d)&&(b>=i&&b<=n||b>=n&&b<=i))return!0}h=f,d=m}return!1}getPolygon(t){if(!t)throw new Error("boundingBox cannot be null.");let e=this.boundingBoxes.indexOf(t);return e==-1?null:this.polygons[e]}getWidth(){return this.maxX-this.minX}getHeight(){return this.maxY-this.minY}},vt=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 re(()=>new Array),this.polygonIndicesPool=new re(()=>new Array)}triangulate(t){let e=t,i=t.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]=vt.isConcave(a,i,e,s);let c=this.triangles;for(c.length=0;i>3;){let a=i-1,r=0,o=1;for(;;){t:if(!n[r]){let d=s[a]<<1,u=s[r]<<1,f=s[o]<<1,m=e[d],x=e[d+1],p=e[u],v=e[u+1],g=e[f],w=e[f+1];for(let b=(o+1)%i;b!=a;b=(b+1)%i){if(!n[b])continue;let y=s[b]<<1,A=e[y],C=e[y+1];if(vt.positiveArea(g,w,m,x,A,C)&&vt.positiveArea(m,x,p,v,A,C)&&vt.positiveArea(p,v,g,w,A,C))break t}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]=vt.isConcave(l,i,e,s),n[h]=vt.isConcave(h,i,e,s)}return i==3&&(c.push(s[2]),c.push(s[0]),c.push(s[1])),c}decompose(t,e){let i=t,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=e.length;l<h;l+=3){let d=e[l]<<1,u=e[l+1]<<1,f=e[l+2]<<1,m=i[d],x=i[d+1],p=i[u],v=i[u+1],g=i[f],w=i[f+1],b=!1;if(r==d){let y=a.length-4,A=vt.winding(a[y],a[y+1],a[y+2],a[y+3],g,w),C=vt.winding(g,w,a[0],a[1],a[2],a[3]);A==o&&C==o&&(a.push(g),a.push(w),c.push(f),b=!0)}b||(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(p),a.push(v),a.push(g),a.push(w),c=this.polygonIndicesPool.obtain(),c.length=0,c.push(d),c.push(u),c.push(f),o=vt.winding(m,x,p,v,g,w),r=d)}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 d=c[0],u=c[c.length-1];a=s[l];let f=a.length-4,m=a[f],x=a[f+1],p=a[f+2],v=a[f+3],g=a[0],w=a[1],b=a[2],y=a[3],A=vt.winding(m,x,p,v,g,w);for(let C=0;C<h;C++){if(C==l)continue;let I=n[C];if(I.length!=3)continue;let E=I[0],R=I[1],L=I[2],k=s[C],F=k[k.length-2],Y=k[k.length-1];if(E!=d||R!=u)continue;let T=vt.winding(m,x,p,v,F,Y),D=vt.winding(F,Y,g,w,b,y);T==A&&D==A&&(k.length=0,I.length=0,a.push(F),a.push(Y),c.push(L),m=p,x=v,p=F,v=Y,C=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(t,e,i,s){let n=s[(e+t-1)%e]<<1,c=s[t]<<1,a=s[(t+1)%e]<<1;return!this.positiveArea(i[n],i[n+1],i[c],i[c+1],i[a],i[a+1])}static positiveArea(t,e,i,s,n,c){return t*(c-s)+i*(e-c)+n*(s-e)>=0}static winding(t,e,i,s,n,c){let a=i-t,r=s-e;return n*r-c*a+a*e-t*r>=0?1:-1}},Ee=class{constructor(){this.triangulator=new vt,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(t,e){if(this.clipAttachment)return 0;this.clipAttachment=e;let i=e.worldVerticesLength,s=B.setArraySize(this.clippingPolygon,i);e.computeWorldVertices(t,0,i,s,0,2);let n=this.clippingPolygon;Ee.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];Ee.makeClockwise(o),o.push(o[0]),o.push(o[1])}return c.length}clipEndWithSlot(t){this.clipAttachment&&this.clipAttachment.endSlot==t.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(t,e,i,s,n,c,a,r){let o=this.clipOutput,l=this.clippedVertices,h=this.clippedTriangles,d=this.clippingPolygons,u=d.length,f=r?12:8,m=0;l.length=0,h.length=0;t:for(let x=0;x<s;x+=3){let p=i[x]<<1,v=t[p],g=t[p+1],w=n[p],b=n[p+1];p=i[x+1]<<1;let y=t[p],A=t[p+1],C=n[p],I=n[p+1];p=i[x+2]<<1;let E=t[p],R=t[p+1],L=n[p],k=n[p+1];for(let F=0;F<u;F++){let Y=l.length;if(this.clip(v,g,y,A,E,R,d[F],o)){let T=o.length;if(T==0)continue;let D=A-R,P=E-y,et=v-E,rt=R-g,st=1/(D*et+P*(g-R)),ht=T>>1,nt=this.clipOutput,it=B.setArraySize(l,Y+ht*f);for(let wt=0;wt<T;wt+=2){let kt=nt[wt],gt=nt[wt+1];it[Y]=kt,it[Y+1]=gt,it[Y+2]=c.r,it[Y+3]=c.g,it[Y+4]=c.b,it[Y+5]=c.a;let At=kt-E,Ct=gt-R,Ut=(D*At+P*Ct)*st,ee=(rt*At+et*Ct)*st,fe=1-Ut-ee;it[Y+6]=w*Ut+C*ee+L*fe,it[Y+7]=b*Ut+I*ee+k*fe,r&&(it[Y+8]=a.r,it[Y+9]=a.g,it[Y+10]=a.b,it[Y+11]=a.a),Y+=f}Y=h.length;let dt=B.setArraySize(h,Y+3*(ht-2));ht--;for(let wt=1;wt<ht;wt++)dt[Y]=m,dt[Y+1]=m+wt,dt[Y+2]=m+wt+1,Y+=3;m+=ht+1}else{let T=B.setArraySize(l,Y+3*f);T[Y]=v,T[Y+1]=g,T[Y+2]=c.r,T[Y+3]=c.g,T[Y+4]=c.b,T[Y+5]=c.a,r?(T[Y+6]=w,T[Y+7]=b,T[Y+8]=a.r,T[Y+9]=a.g,T[Y+10]=a.b,T[Y+11]=a.a,T[Y+12]=y,T[Y+13]=A,T[Y+14]=c.r,T[Y+15]=c.g,T[Y+16]=c.b,T[Y+17]=c.a,T[Y+18]=C,T[Y+19]=I,T[Y+20]=a.r,T[Y+21]=a.g,T[Y+22]=a.b,T[Y+23]=a.a,T[Y+24]=E,T[Y+25]=R,T[Y+26]=c.r,T[Y+27]=c.g,T[Y+28]=c.b,T[Y+29]=c.a,T[Y+30]=L,T[Y+31]=k,T[Y+32]=a.r,T[Y+33]=a.g,T[Y+34]=a.b,T[Y+35]=a.a):(T[Y+6]=w,T[Y+7]=b,T[Y+8]=y,T[Y+9]=A,T[Y+10]=c.r,T[Y+11]=c.g,T[Y+12]=c.b,T[Y+13]=c.a,T[Y+14]=C,T[Y+15]=I,T[Y+16]=E,T[Y+17]=R,T[Y+18]=c.r,T[Y+19]=c.g,T[Y+20]=c.b,T[Y+21]=c.a,T[Y+22]=L,T[Y+23]=k),Y=h.length;let D=B.setArraySize(h,Y+3);D[Y]=m,D[Y+1]=m+1,D[Y+2]=m+2,m+=3;continue t}}}}clip(t,e,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(t),h.push(e),h.push(i),h.push(s),h.push(n),h.push(c),h.push(t),h.push(e),r.length=0;let d=a,u=a.length-4;for(let f=0;;f+=2){let m=d[f],x=d[f+1],p=d[f+2],v=d[f+3],g=m-p,w=x-v,b=h,y=h.length-2,A=r.length;for(let I=0;I<y;I+=2){let E=b[I],R=b[I+1],L=b[I+2],k=b[I+3],F=g*(k-v)-w*(L-p)>0;if(g*(R-v)-w*(E-p)>0){if(F){r.push(L),r.push(k);continue}let Y=k-R,T=L-E,D=Y*(p-m)-T*(v-x);if(Math.abs(D)>1e-6){let P=(T*(x-R)-Y*(m-E))/D;r.push(m+(p-m)*P),r.push(x+(v-x)*P)}else r.push(m),r.push(x)}else if(F){let Y=k-R,T=L-E,D=Y*(p-m)-T*(v-x);if(Math.abs(D)>1e-6){let P=(T*(x-R)-Y*(m-E))/D;r.push(m+(p-m)*P),r.push(x+(v-x)*P)}else r.push(m),r.push(x);r.push(L),r.push(k)}l=!0}if(A==r.length)return o.length=0,!0;if(r.push(r[0]),r.push(r[1]),f==u)break;let C=r;r=h,r.length=0,h=C}if(o!=r){o.length=0;for(let f=0,m=r.length-2;f<m;f++)o[f]=r[f]}else o.length=o.length-2;return l}static makeClockwise(t){let e=t,i=t.length,s=e[i-2]*e[1]-e[0]*e[i-1],n=0,c=0,a=0,r=0;for(let o=0,l=i-3;o<l;o+=2)n=e[o],c=e[o+1],a=e[o+2],r=e[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 d=e[o],u=e[o+1],f=l-o;e[o]=e[f],e[o+1]=e[f+1],e[f]=d,e[f+1]=u}}},dr=class{constructor(t){this.scale=1,this.linkedMeshes=new Array,this.attachmentLoader=t}readSkeletonData(t){let e=this.scale,i=new Ci,s=typeof t=="string"?JSON.parse(t):t,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=M(a,"parent",null);o&&(r=i.findBone(o));let l=new xi(i.bones.length,a.name,r);l.length=M(a,"length",0)*e,l.x=M(a,"x",0)*e,l.y=M(a,"y",0)*e,l.rotation=M(a,"rotation",0),l.scaleX=M(a,"scaleX",1),l.scaleY=M(a,"scaleY",1),l.shearX=M(a,"shearX",0),l.shearY=M(a,"shearY",0),l.transformMode=B.enumValue(Ae,M(a,"transform","Normal")),l.skinRequired=M(a,"skin",!1);let h=M(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=M(a,"color",null);l&&o.color.setFromString(l);let h=M(a,"dark",null);h&&(o.darkColor=O.fromString(h)),o.attachmentName=M(a,"attachment",null),o.blendMode=B.enumValue(Ye,M(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=M(a,"order",0),r.skinRequired=M(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=M(a,"mix",1),r.softness=M(a,"softness",0)*e,r.bendDirection=M(a,"bendPositive",!0)?1:-1,r.compress=M(a,"compress",!1),r.stretch=M(a,"stretch",!1),r.uniform=M(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=M(a,"order",0),r.skinRequired=M(a,"skin",!1);for(let h=0;h<a.bones.length;h++){let d=a.bones[h],u=i.findBone(d);if(!u)throw new Error(`Couldn't find bone ${d} for transform constraint ${a.name}.`);r.bones.push(u)}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=M(a,"local",!1),r.relative=M(a,"relative",!1),r.offsetRotation=M(a,"rotation",0),r.offsetX=M(a,"x",0)*e,r.offsetY=M(a,"y",0)*e,r.offsetScaleX=M(a,"scaleX",0),r.offsetScaleY=M(a,"scaleY",0),r.offsetShearY=M(a,"shearY",0),r.mixRotate=M(a,"mixRotate",1),r.mixX=M(a,"mixX",1),r.mixY=M(a,"mixY",r.mixX),r.mixScaleX=M(a,"mixScaleX",1),r.mixScaleY=M(a,"mixScaleY",r.mixScaleX),r.mixShearY=M(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=M(a,"order",0),r.skinRequired=M(a,"skin",!1);for(let h=0;h<a.bones.length;h++){let d=a.bones[h],u=i.findBone(d);if(!u)throw new Error(`Couldn't find bone ${d} for path constraint ${a.name}.`);r.bones.push(u)}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(Se,M(a,"positionMode","Percent")),r.spacingMode=B.enumValue(Te,M(a,"spacingMode","Length")),r.rotateMode=B.enumValue(Ie,M(a,"rotateMode","Tangent")),r.offsetRotation=M(a,"rotation",0),r.position=M(a,"position",0),r.positionMode==0&&(r.position*=e),r.spacing=M(a,"spacing",0),(r.spacingMode==0||r.spacingMode==1)&&(r.spacing*=e),r.mixRotate=M(a,"mixRotate",1),r.mixX=M(a,"mixX",1),r.mixY=M(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 Me(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 d in h){let u=this.readAttachment(h[d],r,l.index,d,i);u&&r.setAttachment(l.index,d,u)}}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=M(a,"int",0),r.floatValue=M(a,"float",0),r.stringValue=M(a,"string",""),r.audioPath=M(a,"audio",null),r.audioPath&&(r.volume=M(a,"volume",1),r.balance=M(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(t,e,i,s,n){let c=this.scale;switch(s=M(t,"name",s),M(t,"type","region")){case"region":{let a=M(t,"path",s),r=this.readSequence(M(t,"sequence",null)),o=this.attachmentLoader.newRegionAttachment(e,s,a,r);if(!o)return null;o.path=a,o.x=M(t,"x",0)*c,o.y=M(t,"y",0)*c,o.scaleX=M(t,"scaleX",1),o.scaleY=M(t,"scaleY",1),o.rotation=M(t,"rotation",0),o.width=t.width*c,o.height=t.height*c,o.sequence=r;let l=M(t,"color",null);return l&&o.color.setFromString(l),o.region!=null&&o.updateRegion(),o}case"boundingbox":{let a=this.attachmentLoader.newBoundingBoxAttachment(e,s);if(!a)return null;this.readVertices(t,a,t.vertexCount<<1);let r=M(t,"color",null);return r&&a.color.setFromString(r),a}case"mesh":case"linkedmesh":{let a=M(t,"path",s),r=this.readSequence(M(t,"sequence",null)),o=this.attachmentLoader.newMeshAttachment(e,s,a,r);if(!o)return null;o.path=a;let l=M(t,"color",null);l&&o.color.setFromString(l),o.width=M(t,"width",0)*c,o.height=M(t,"height",0)*c,o.sequence=r;let h=M(t,"parent",null);if(h)return this.linkedMeshes.push(new ur(o,M(t,"skin",null),i,h,M(t,"timelines",!0))),o;let d=t.uvs;return this.readVertices(t,o,d.length),o.triangles=t.triangles,o.regionUVs=d,o.region!=null&&o.updateRegion(),o.edges=M(t,"edges",null),o.hullLength=M(t,"hull",0)*2,o}case"path":{let a=this.attachmentLoader.newPathAttachment(e,s);if(!a)return null;a.closed=M(t,"closed",!1),a.constantSpeed=M(t,"constantSpeed",!0);let r=t.vertexCount;this.readVertices(t,a,r<<1);let o=B.newArray(r/3,0);for(let h=0;h<t.lengths.length;h++)o[h]=t.lengths[h]*c;a.lengths=o;let l=M(t,"color",null);return l&&a.color.setFromString(l),a}case"point":{let a=this.attachmentLoader.newPointAttachment(e,s);if(!a)return null;a.x=M(t,"x",0)*c,a.y=M(t,"y",0)*c,a.rotation=M(t,"rotation",0);let r=M(t,"color",null);return r&&a.color.setFromString(r),a}case"clipping":{let a=this.attachmentLoader.newClippingAttachment(e,s);if(!a)return null;let r=M(t,"end",null);r&&(a.endSlot=n.findSlot(r));let o=t.vertexCount;this.readVertices(t,a,o<<1);let l=M(t,"color",null);return l&&a.color.setFromString(l),a}}return null}readSequence(t){if(t==null)return null;let e=new ze(M(t,"count",0));return e.start=M(t,"start",1),e.digits=M(t,"digits",0),e.setupIndex=M(t,"setup",0),e}readVertices(t,e,i){let s=this.scale;e.worldVerticesLength=i;let n=t.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;e.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])}e.bones=a,e.vertices=B.toFloatArray(c)}readAnimation(t,e,i){let s=this.scale,n=new Array;if(t.slots)for(let a in t.slots){let r=t.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 d=r[h];if(!d)continue;let u=d.length;if(h=="attachment"){let f=new Wt(u,l);for(let m=0;m<u;m++){let x=d[m];f.setFrame(m,M(x,"time",0),M(x,"name",null))}n.push(f)}else if(h=="rgba"){let f=new $e(u,u<<2,l),m=d[0],x=M(m,"time",0),p=O.fromString(m.color);for(let v=0,g=0;;v++){f.setFrame(v,x,p.r,p.g,p.b,p.a);let w=d[v+1];if(!w){f.shrink(g);break}let b=M(w,"time",0),y=O.fromString(w.color),A=m.curve;A&&(g=ot(A,f,g,v,0,x,b,p.r,y.r,1),g=ot(A,f,g,v,1,x,b,p.g,y.g,1),g=ot(A,f,g,v,2,x,b,p.b,y.b,1),g=ot(A,f,g,v,3,x,b,p.a,y.a,1)),x=b,p=y,m=w}n.push(f)}else if(h=="rgb"){let f=new ti(u,u*3,l),m=d[0],x=M(m,"time",0),p=O.fromString(m.color);for(let v=0,g=0;;v++){f.setFrame(v,x,p.r,p.g,p.b);let w=d[v+1];if(!w){f.shrink(g);break}let b=M(w,"time",0),y=O.fromString(w.color),A=m.curve;A&&(g=ot(A,f,g,v,0,x,b,p.r,y.r,1),g=ot(A,f,g,v,1,x,b,p.g,y.g,1),g=ot(A,f,g,v,2,x,b,p.b,y.b,1)),x=b,p=y,m=w}n.push(f)}else if(h=="alpha")n.push(Rt(d,new ei(u,u,l),0,1));else if(h=="rgba2"){let f=new ii(u,u*7,l),m=d[0],x=M(m,"time",0),p=O.fromString(m.light),v=O.fromString(m.dark);for(let g=0,w=0;;g++){f.setFrame(g,x,p.r,p.g,p.b,p.a,v.r,v.g,v.b);let b=d[g+1];if(!b){f.shrink(w);break}let y=M(b,"time",0),A=O.fromString(b.light),C=O.fromString(b.dark),I=m.curve;I&&(w=ot(I,f,w,g,0,x,y,p.r,A.r,1),w=ot(I,f,w,g,1,x,y,p.g,A.g,1),w=ot(I,f,w,g,2,x,y,p.b,A.b,1),w=ot(I,f,w,g,3,x,y,p.a,A.a,1),w=ot(I,f,w,g,4,x,y,v.r,C.r,1),w=ot(I,f,w,g,5,x,y,v.g,C.g,1),w=ot(I,f,w,g,6,x,y,v.b,C.b,1)),x=y,p=A,v=C,m=b}n.push(f)}else if(h=="rgb2"){let f=new si(u,u*6,l),m=d[0],x=M(m,"time",0),p=O.fromString(m.light),v=O.fromString(m.dark);for(let g=0,w=0;;g++){f.setFrame(g,x,p.r,p.g,p.b,v.r,v.g,v.b);let b=d[g+1];if(!b){f.shrink(w);break}let y=M(b,"time",0),A=O.fromString(b.light),C=O.fromString(b.dark),I=m.curve;I&&(w=ot(I,f,w,g,0,x,y,p.r,A.r,1),w=ot(I,f,w,g,1,x,y,p.g,A.g,1),w=ot(I,f,w,g,2,x,y,p.b,A.b,1),w=ot(I,f,w,g,3,x,y,v.r,C.r,1),w=ot(I,f,w,g,4,x,y,v.g,C.g,1),w=ot(I,f,w,g,5,x,y,v.b,C.b,1)),x=y,p=A,v=C,m=b}n.push(f)}}}if(t.bones)for(let a in t.bones){let r=t.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 d=r[h],u=d.length;if(u!=0){if(h==="rotate")n.push(Rt(d,new ne(u,u,l),0,1));else if(h==="translate"){let f=new We(u,u<<1,l);n.push(Yi(d,f,"x","y",0,s))}else if(h==="translatex"){let f=new qe(u,u,l);n.push(Rt(d,f,0,s))}else if(h==="translatey"){let f=new Ge(u,u,l);n.push(Rt(d,f,0,s))}else if(h==="scale"){let f=new He(u,u<<1,l);n.push(Yi(d,f,"x","y",1,1))}else if(h==="scalex"){let f=new je(u,u,l);n.push(Rt(d,f,1,1))}else if(h==="scaley"){let f=new Ze(u,u,l);n.push(Rt(d,f,1,1))}else if(h==="shear"){let f=new Ke(u,u<<1,l);n.push(Yi(d,f,"x","y",0,1))}else if(h==="shearx"){let f=new Je(u,u,l);n.push(Rt(d,f,0,1))}else if(h==="sheary"){let f=new Qe(u,u,l);n.push(Rt(d,f,0,1))}}}}if(t.ik)for(let a in t.ik){let r=t.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),d=new ni(r.length,r.length<<1,h),u=M(o,"time",0),f=M(o,"mix",1),m=M(o,"softness",0)*s;for(let x=0,p=0;;x++){d.setFrame(x,u,f,m,M(o,"bendPositive",!0)?1:-1,M(o,"compress",!1),M(o,"stretch",!1));let v=r[x+1];if(!v){d.shrink(p);break}let g=M(v,"time",0),w=M(v,"mix",1),b=M(v,"softness",0)*s,y=o.curve;y&&(p=ot(y,d,p,x,0,u,g,f,w,1),p=ot(y,d,p,x,1,u,g,m,b,s)),u=g,f=w,m=b,o=v}n.push(d)}if(t.transform)for(let a in t.transform){let r=t.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),d=new ai(r.length,r.length*6,h),u=M(o,"time",0),f=M(o,"mixRotate",1),m=M(o,"mixX",1),x=M(o,"mixY",m),p=M(o,"mixScaleX",1),v=M(o,"mixScaleY",p),g=M(o,"mixShearY",1);for(let w=0,b=0;;w++){d.setFrame(w,u,f,m,x,p,v,g);let y=r[w+1];if(!y){d.shrink(b);break}let A=M(y,"time",0),C=M(y,"mixRotate",1),I=M(y,"mixX",1),E=M(y,"mixY",I),R=M(y,"mixScaleX",1),L=M(y,"mixScaleY",R),k=M(y,"mixShearY",1),F=o.curve;F&&(b=ot(F,d,b,w,0,u,A,f,C,1),b=ot(F,d,b,w,1,u,A,m,I,1),b=ot(F,d,b,w,2,u,A,x,E,1),b=ot(F,d,b,w,3,u,A,p,R,1),b=ot(F,d,b,w,4,u,A,v,L,1),b=ot(F,d,b,w,5,u,A,g,k,1)),u=A,f=C,m=I,x=E,p=R,v=L,p=R,o=y}n.push(d)}if(t.path)for(let a in t.path){let r=t.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 d=r[h],u=d[0];if(!u)continue;let f=d.length;if(h==="position"){let m=new li(f,f,l);n.push(Rt(d,m,0,o.positionMode==0?s:1))}else if(h==="spacing"){let m=new oi(f,f,l);n.push(Rt(d,m,0,o.spacingMode==0||o.spacingMode==1?s:1))}else if(h==="mix"){let m=new hi(f,f*3,l),x=M(u,"time",0),p=M(u,"mixRotate",1),v=M(u,"mixX",1),g=M(u,"mixY",v);for(let w=0,b=0;;w++){m.setFrame(w,x,p,v,g);let y=d[w+1];if(!y){m.shrink(b);break}let A=M(y,"time",0),C=M(y,"mixRotate",1),I=M(y,"mixX",1),E=M(y,"mixY",I),R=u.curve;R&&(b=ot(R,m,b,w,0,x,A,p,C,1),b=ot(R,m,b,w,1,x,A,v,I,1),b=ot(R,m,b,w,2,x,A,g,E,1)),x=A,p=C,v=I,g=E,u=y}n.push(m)}}}if(t.attachments)for(let a in t.attachments){let r=t.attachments[a],o=i.findSkin(a);if(!o)throw new Error("Skin not found: "+a);for(let l in r){let h=r[l],d=i.findSlot(l);if(!d)throw new Error("Slot not found: "+l);let u=d.index;for(let f in h){let m=h[f],x=o.getAttachment(u,f);for(let p in m){let v=m[p],g=v[0];if(g){if(p=="deform"){let w=x.bones,b=x.vertices,y=w?b.length/3*2:b.length,A=new ri(v.length,v.length,u,x),C=M(g,"time",0);for(let I=0,E=0;;I++){let R,L=M(g,"vertices",null);if(!L)R=w?B.newFloatArray(y):b;else{R=B.newFloatArray(y);let T=M(g,"offset",0);if(B.arrayCopy(L,0,R,T,L.length),s!=1)for(let D=T,P=D+L.length;D<P;D++)R[D]*=s;if(!w)for(let D=0;D<y;D++)R[D]+=b[D]}A.setFrame(I,C,R);let k=v[I+1];if(!k){A.shrink(E);break}let F=M(k,"time",0),Y=g.curve;Y&&(E=ot(Y,A,E,I,0,C,F,0,1,1)),C=F,g=k}n.push(A)}else if(p=="sequence"){let w=new Kt(v.length,u,x),b=0;for(let y=0;y<v.length;y++){let A=M(g,"delay",b),C=M(g,"time",0),I=_i[M(g,"mode","hold")],E=M(g,"index",0);w.setFrame(y,C,I,E,A),b=A,g=v[y+1]}n.push(w)}}}}}}if(t.drawOrder){let a=new qt(t.drawOrder.length),r=i.slots.length,o=0;for(let l=0;l<t.drawOrder.length;l++,o++){let h=t.drawOrder[l],d=null,u=M(h,"offsets",null);if(u){d=B.newArray(r,-1);let f=B.newArray(r-u.length,0),m=0,x=0;for(let p=0;p<u.length;p++){let v=u[p],g=i.findSlot(v.slot);if(!g)throw new Error("Slot not found: "+g);let w=g.index;for(;m!=w;)f[x++]=m++;d[m+v.offset]=m++}for(;m<r;)f[x++]=m++;for(let p=r-1;p>=0;p--)d[p]==-1&&(d[p]=f[--x])}a.setFrame(o,M(h,"time",0),d)}n.push(a)}if(t.events){let a=new ae(t.events.length),r=0;for(let o=0;o<t.events.length;o++,r++){let l=t.events[o],h=i.findEvent(l.name);if(!h)throw new Error("Event not found: "+l.name);let d=new pi(B.toSinglePrecision(M(l,"time",0)),h);d.intValue=M(l,"int",h.intValue),d.floatValue=M(l,"float",h.floatValue),d.stringValue=M(l,"string",h.stringValue),d.data.audioPath&&(d.volume=M(l,"volume",1),d.balance=M(l,"balance",0)),a.setFrame(r,d)}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 ge(e,n,c))}},ur=class{constructor(t,e,i,s,n){this.mesh=t,this.skin=e,this.slotIndex=i,this.parent=s,this.inheritTimeline=n}};function Rt(t,e,i,s){let n=t[0],c=M(n,"time",0),a=M(n,"value",i)*s,r=0;for(let o=0;;o++){e.setFrame(o,c,a);let l=t[o+1];if(!l)return e.shrink(r),e;let h=M(l,"time",0),d=M(l,"value",i)*s;n.curve&&(r=ot(n.curve,e,r,o,0,c,h,a,d,s)),c=h,a=d,n=l}}function Yi(t,e,i,s,n,c){let a=t[0],r=M(a,"time",0),o=M(a,i,n)*c,l=M(a,s,n)*c,h=0;for(let d=0;;d++){e.setFrame(d,r,o,l);let u=t[d+1];if(!u)return e.shrink(h),e;let f=M(u,"time",0),m=M(u,i,n)*c,x=M(u,s,n)*c,p=a.curve;p&&(h=ot(p,e,h,d,0,r,f,o,m,c),h=ot(p,e,h,d,1,r,f,l,x,c)),r=f,o=m,l=x,a=u}}function ot(t,e,i,s,n,c,a,r,o,l){if(t=="stepped")return e.setStepped(s),i;let h=n<<2,d=t[h],u=t[h+1]*l,f=t[h+2],m=t[h+3]*l;return e.setBezier(i,s,n,c,r,d,u,f,m,a,o),i+1}function M(t,e,i){return t[e]!==void 0?t[e]:i}typeof Math.fround=="undefined"&&(Math.fround=function(t){return function(e){return t[0]=e,t[0]}}(new Float32Array(1)));var xt=class{constructor(t,e={alpha:"true"}){if(this.restorables=new Array,t instanceof WebGLRenderingContext||typeof WebGL2RenderingContext!="undefined"&&t instanceof WebGL2RenderingContext)this.gl=t,this.canvas=this.gl.canvas;else{let i=t;this.gl=i.getContext("webgl2",e)||i.getContext("webgl",e),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(t){this.restorables.push(t)}removeRestorable(t){let e=this.restorables.indexOf(t);e>-1&&this.restorables.splice(e,1)}},Ft=1,fr=769,oe=770,Pt=771,mr=774,he=class{static getDestGLBlendMode(t){switch(t){case 0:return Pt;case 1:return Ft;case 2:return Pt;case 3:return Pt;default:throw new Error("Unknown blend mode: "+t)}}static getDestColorGLBlendMode(t){switch(t){case 0:return Pt;case 1:return Ft;case 2:return Pt;case 3:return fr;default:throw new Error("Unknown blend mode: "+t)}}static getDestAlphaGLBlendMode(t,e=!1){switch(t){case 0:return Pt;case 1:return e?Pt:Ft;case 2:return Pt;case 3:return Pt;default:throw new Error("Unknown blend mode: "+t)}}static getSourceColorGLBlendMode(t,e=!1){switch(t){case 0:return e?Ft:oe;case 1:return e?Ft:oe;case 2:return mr;case 3:return e?Ft:oe;default:throw new Error("Unknown blend mode: "+t)}}static getSourceAlphaGLBlendMode(t,e=!1){switch(t){case 0:return e?oe:Ft;case 1:return e?oe:Ft;case 2:return Ft;case 3:return Ft;default:throw new Error("Unknown blend mode: "+t)}}},ke=class extends fi{constructor(t,e,i=!1){super(e),this.texture=null,this.boundUnit=0,this.useMipMaps=!1,this.context=t instanceof xt?t:new xt(t),this.useMipMaps=i,this.restore(),this.context.addRestorable(this)}setFilters(t,e){let i=this.context.gl;this.bind(),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_MIN_FILTER,t),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_MAG_FILTER,ke.validateMagFilter(e)),this.useMipMaps=ke.usesMipMaps(t),this.useMipMaps&&i.generateMipmap(i.TEXTURE_2D)}static validateMagFilter(t){switch(t){case 9987:case 9985:case 9986:case 9984:return 9729;default:return t}}static usesMipMaps(t){switch(t){case 9987:case 9985:case 9986:case 9984:return!0;default:return!1}}setWraps(t,e){let i=this.context.gl;this.bind(),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_WRAP_S,t),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_WRAP_T,e)}update(t){let e=this.context.gl;this.texture||(this.texture=this.context.gl.createTexture()),this.bind(),ke.DISABLE_UNPACK_PREMULTIPLIED_ALPHA_WEBGL&&e.pixelStorei(e.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1),e.texImage2D(e.TEXTURE_2D,0,e.RGBA,e.RGBA,e.UNSIGNED_BYTE,this._image),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MAG_FILTER,e.LINEAR),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MIN_FILTER,t?e.LINEAR_MIPMAP_LINEAR:e.LINEAR),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_S,e.CLAMP_TO_EDGE),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_T,e.CLAMP_TO_EDGE),t&&e.generateMipmap(e.TEXTURE_2D)}restore(){this.texture=null,this.update(this.useMipMaps)}bind(t=0){let e=this.context.gl;this.boundUnit=t,e.activeTexture(e.TEXTURE0+t),e.bindTexture(e.TEXTURE_2D,this.texture)}unbind(){let t=this.context.gl;t.activeTexture(t.TEXTURE0+this.boundUnit),t.bindTexture(t.TEXTURE_2D,null)}dispose(){this.context.removeRestorable(this),this.context.gl.deleteTexture(this.texture)}},ce=ke;ce.DISABLE_UNPACK_PREMULTIPLIED_ALPHA_WEBGL=!1;var us=class extends rs{constructor(t,e="",i=new bi){super(s=>new ce(t,s),e,i)}},yt=class{constructor(t=0,e=0,i=0){this.x=0,this.y=0,this.z=0,this.x=t,this.y=e,this.z=i}setFrom(t){return this.x=t.x,this.y=t.y,this.z=t.z,this}set(t,e,i){return this.x=t,this.y=e,this.z=i,this}add(t){return this.x+=t.x,this.y+=t.y,this.z+=t.z,this}sub(t){return this.x-=t.x,this.y-=t.y,this.z-=t.z,this}scale(t){return this.x*=t,this.y*=t,this.z*=t,this}normalize(){let t=this.length();return t==0?this:(t=1/t,this.x*=t,this.y*=t,this.z*=t,this)}cross(t){return this.set(this.y*t.z-this.z*t.y,this.z*t.x-this.x*t.z,this.x*t.y-this.y*t.x)}multiply(t){let e=t.values;return this.set(this.x*e[V]+this.y*e[q]+this.z*e[G]+e[N],this.x*e[H]+this.y*e[U]+this.z*e[j]+e[_],this.x*e[Z]+this.y*e[K]+this.z*e[z]+e[W])}project(t){let e=t.values,i=1/(this.x*e[Q]+this.y*e[$]+this.z*e[tt]+e[J]);return this.set((this.x*e[V]+this.y*e[q]+this.z*e[G]+e[N])*i,(this.x*e[H]+this.y*e[U]+this.z*e[j]+e[_])*i,(this.x*e[Z]+this.y*e[K]+this.z*e[z]+e[W])*i)}dot(t){return this.x*t.x+this.y*t.y+this.z*t.z}length(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z)}distance(t){let e=t.x-this.x,i=t.y-this.y,s=t.z-this.z;return Math.sqrt(e*e+i*i+s*s)}},V=0,q=4,G=8,N=12,H=1,U=5,j=9,_=13,Z=2,K=6,z=10,W=14,Q=3,$=7,tt=11,J=15,Et=class{constructor(){this.temp=new Float32Array(16),this.values=new Float32Array(16);let t=this.values;t[V]=1,t[U]=1,t[z]=1,t[J]=1}set(t){return this.values.set(t),this}transpose(){let t=this.temp,e=this.values;return t[V]=e[V],t[q]=e[H],t[G]=e[Z],t[N]=e[Q],t[H]=e[q],t[U]=e[U],t[j]=e[K],t[_]=e[$],t[Z]=e[G],t[K]=e[j],t[z]=e[z],t[W]=e[tt],t[Q]=e[N],t[$]=e[_],t[tt]=e[W],t[J]=e[J],this.set(t)}identity(){let t=this.values;return t[V]=1,t[q]=0,t[G]=0,t[N]=0,t[H]=0,t[U]=1,t[j]=0,t[_]=0,t[Z]=0,t[K]=0,t[z]=1,t[W]=0,t[Q]=0,t[$]=0,t[tt]=0,t[J]=1,this}invert(){let t=this.values,e=this.temp,i=t[Q]*t[K]*t[j]*t[N]-t[Z]*t[$]*t[j]*t[N]-t[Q]*t[U]*t[z]*t[N]+t[H]*t[$]*t[z]*t[N]+t[Z]*t[U]*t[tt]*t[N]-t[H]*t[K]*t[tt]*t[N]-t[Q]*t[K]*t[G]*t[_]+t[Z]*t[$]*t[G]*t[_]+t[Q]*t[q]*t[z]*t[_]-t[V]*t[$]*t[z]*t[_]-t[Z]*t[q]*t[tt]*t[_]+t[V]*t[K]*t[tt]*t[_]+t[Q]*t[U]*t[G]*t[W]-t[H]*t[$]*t[G]*t[W]-t[Q]*t[q]*t[j]*t[W]+t[V]*t[$]*t[j]*t[W]+t[H]*t[q]*t[tt]*t[W]-t[V]*t[U]*t[tt]*t[W]-t[Z]*t[U]*t[G]*t[J]+t[H]*t[K]*t[G]*t[J]+t[Z]*t[q]*t[j]*t[J]-t[V]*t[K]*t[j]*t[J]-t[H]*t[q]*t[z]*t[J]+t[V]*t[U]*t[z]*t[J];if(i==0)throw new Error("non-invertible matrix");let s=1/i;return e[V]=t[j]*t[W]*t[$]-t[_]*t[z]*t[$]+t[_]*t[K]*t[tt]-t[U]*t[W]*t[tt]-t[j]*t[K]*t[J]+t[U]*t[z]*t[J],e[q]=t[N]*t[z]*t[$]-t[G]*t[W]*t[$]-t[N]*t[K]*t[tt]+t[q]*t[W]*t[tt]+t[G]*t[K]*t[J]-t[q]*t[z]*t[J],e[G]=t[G]*t[_]*t[$]-t[N]*t[j]*t[$]+t[N]*t[U]*t[tt]-t[q]*t[_]*t[tt]-t[G]*t[U]*t[J]+t[q]*t[j]*t[J],e[N]=t[N]*t[j]*t[K]-t[G]*t[_]*t[K]-t[N]*t[U]*t[z]+t[q]*t[_]*t[z]+t[G]*t[U]*t[W]-t[q]*t[j]*t[W],e[H]=t[_]*t[z]*t[Q]-t[j]*t[W]*t[Q]-t[_]*t[Z]*t[tt]+t[H]*t[W]*t[tt]+t[j]*t[Z]*t[J]-t[H]*t[z]*t[J],e[U]=t[G]*t[W]*t[Q]-t[N]*t[z]*t[Q]+t[N]*t[Z]*t[tt]-t[V]*t[W]*t[tt]-t[G]*t[Z]*t[J]+t[V]*t[z]*t[J],e[j]=t[N]*t[j]*t[Q]-t[G]*t[_]*t[Q]-t[N]*t[H]*t[tt]+t[V]*t[_]*t[tt]+t[G]*t[H]*t[J]-t[V]*t[j]*t[J],e[_]=t[G]*t[_]*t[Z]-t[N]*t[j]*t[Z]+t[N]*t[H]*t[z]-t[V]*t[_]*t[z]-t[G]*t[H]*t[W]+t[V]*t[j]*t[W],e[Z]=t[U]*t[W]*t[Q]-t[_]*t[K]*t[Q]+t[_]*t[Z]*t[$]-t[H]*t[W]*t[$]-t[U]*t[Z]*t[J]+t[H]*t[K]*t[J],e[K]=t[N]*t[K]*t[Q]-t[q]*t[W]*t[Q]-t[N]*t[Z]*t[$]+t[V]*t[W]*t[$]+t[q]*t[Z]*t[J]-t[V]*t[K]*t[J],e[z]=t[q]*t[_]*t[Q]-t[N]*t[U]*t[Q]+t[N]*t[H]*t[$]-t[V]*t[_]*t[$]-t[q]*t[H]*t[J]+t[V]*t[U]*t[J],e[W]=t[N]*t[U]*t[Z]-t[q]*t[_]*t[Z]-t[N]*t[H]*t[K]+t[V]*t[_]*t[K]+t[q]*t[H]*t[W]-t[V]*t[U]*t[W],e[Q]=t[j]*t[K]*t[Q]-t[U]*t[z]*t[Q]-t[j]*t[Z]*t[$]+t[H]*t[z]*t[$]+t[U]*t[Z]*t[tt]-t[H]*t[K]*t[tt],e[$]=t[q]*t[z]*t[Q]-t[G]*t[K]*t[Q]+t[G]*t[Z]*t[$]-t[V]*t[z]*t[$]-t[q]*t[Z]*t[tt]+t[V]*t[K]*t[tt],e[tt]=t[G]*t[U]*t[Q]-t[q]*t[j]*t[Q]-t[G]*t[H]*t[$]+t[V]*t[j]*t[$]+t[q]*t[H]*t[tt]-t[V]*t[U]*t[tt],e[J]=t[q]*t[j]*t[Z]-t[G]*t[U]*t[Z]+t[G]*t[H]*t[K]-t[V]*t[j]*t[K]-t[q]*t[H]*t[z]+t[V]*t[U]*t[z],t[V]=e[V]*s,t[q]=e[q]*s,t[G]=e[G]*s,t[N]=e[N]*s,t[H]=e[H]*s,t[U]=e[U]*s,t[j]=e[j]*s,t[_]=e[_]*s,t[Z]=e[Z]*s,t[K]=e[K]*s,t[z]=e[z]*s,t[W]=e[W]*s,t[Q]=e[Q]*s,t[$]=e[$]*s,t[tt]=e[tt]*s,t[J]=e[J]*s,this}determinant(){let t=this.values;return t[Q]*t[K]*t[j]*t[N]-t[Z]*t[$]*t[j]*t[N]-t[Q]*t[U]*t[z]*t[N]+t[H]*t[$]*t[z]*t[N]+t[Z]*t[U]*t[tt]*t[N]-t[H]*t[K]*t[tt]*t[N]-t[Q]*t[K]*t[G]*t[_]+t[Z]*t[$]*t[G]*t[_]+t[Q]*t[q]*t[z]*t[_]-t[V]*t[$]*t[z]*t[_]-t[Z]*t[q]*t[tt]*t[_]+t[V]*t[K]*t[tt]*t[_]+t[Q]*t[U]*t[G]*t[W]-t[H]*t[$]*t[G]*t[W]-t[Q]*t[q]*t[j]*t[W]+t[V]*t[$]*t[j]*t[W]+t[H]*t[q]*t[tt]*t[W]-t[V]*t[U]*t[tt]*t[W]-t[Z]*t[U]*t[G]*t[J]+t[H]*t[K]*t[G]*t[J]+t[Z]*t[q]*t[j]*t[J]-t[V]*t[K]*t[j]*t[J]-t[H]*t[q]*t[z]*t[J]+t[V]*t[U]*t[z]*t[J]}translate(t,e,i){let s=this.values;return s[N]+=t,s[_]+=e,s[W]+=i,this}copy(){return new Et().set(this.values)}projection(t,e,i,s){this.identity();let n=1/Math.tan(i*(Math.PI/180)/2),c=(e+t)/(t-e),a=2*e*t/(t-e),r=this.values;return r[V]=n/s,r[H]=0,r[Z]=0,r[Q]=0,r[q]=0,r[U]=n,r[K]=0,r[$]=0,r[G]=0,r[j]=0,r[z]=c,r[tt]=-1,r[N]=0,r[_]=0,r[W]=a,r[J]=0,this}ortho2d(t,e,i,s){return this.ortho(t,t+i,e,e+s,0,1)}ortho(t,e,i,s,n,c){this.identity();let a=2/(e-t),r=2/(s-i),o=-2/(c-n),l=-(e+t)/(e-t),h=-(s+i)/(s-i),d=-(c+n)/(c-n),u=this.values;return u[V]=a,u[H]=0,u[Z]=0,u[Q]=0,u[q]=0,u[U]=r,u[K]=0,u[$]=0,u[G]=0,u[j]=0,u[z]=o,u[tt]=0,u[N]=l,u[_]=h,u[W]=d,u[J]=1,this}multiply(t){let e=this.temp,i=this.values,s=t.values;return e[V]=i[V]*s[V]+i[q]*s[H]+i[G]*s[Z]+i[N]*s[Q],e[q]=i[V]*s[q]+i[q]*s[U]+i[G]*s[K]+i[N]*s[$],e[G]=i[V]*s[G]+i[q]*s[j]+i[G]*s[z]+i[N]*s[tt],e[N]=i[V]*s[N]+i[q]*s[_]+i[G]*s[W]+i[N]*s[J],e[H]=i[H]*s[V]+i[U]*s[H]+i[j]*s[Z]+i[_]*s[Q],e[U]=i[H]*s[q]+i[U]*s[U]+i[j]*s[K]+i[_]*s[$],e[j]=i[H]*s[G]+i[U]*s[j]+i[j]*s[z]+i[_]*s[tt],e[_]=i[H]*s[N]+i[U]*s[_]+i[j]*s[W]+i[_]*s[J],e[Z]=i[Z]*s[V]+i[K]*s[H]+i[z]*s[Z]+i[W]*s[Q],e[K]=i[Z]*s[q]+i[K]*s[U]+i[z]*s[K]+i[W]*s[$],e[z]=i[Z]*s[G]+i[K]*s[j]+i[z]*s[z]+i[W]*s[tt],e[W]=i[Z]*s[N]+i[K]*s[_]+i[z]*s[W]+i[W]*s[J],e[Q]=i[Q]*s[V]+i[$]*s[H]+i[tt]*s[Z]+i[J]*s[Q],e[$]=i[Q]*s[q]+i[$]*s[U]+i[tt]*s[K]+i[J]*s[$],e[tt]=i[Q]*s[G]+i[$]*s[j]+i[tt]*s[z]+i[J]*s[tt],e[J]=i[Q]*s[N]+i[$]*s[_]+i[tt]*s[W]+i[J]*s[J],this.set(this.temp)}multiplyLeft(t){let e=this.temp,i=this.values,s=t.values;return e[V]=s[V]*i[V]+s[q]*i[H]+s[G]*i[Z]+s[N]*i[Q],e[q]=s[V]*i[q]+s[q]*i[U]+s[G]*i[K]+s[N]*i[$],e[G]=s[V]*i[G]+s[q]*i[j]+s[G]*i[z]+s[N]*i[tt],e[N]=s[V]*i[N]+s[q]*i[_]+s[G]*i[W]+s[N]*i[J],e[H]=s[H]*i[V]+s[U]*i[H]+s[j]*i[Z]+s[_]*i[Q],e[U]=s[H]*i[q]+s[U]*i[U]+s[j]*i[K]+s[_]*i[$],e[j]=s[H]*i[G]+s[U]*i[j]+s[j]*i[z]+s[_]*i[tt],e[_]=s[H]*i[N]+s[U]*i[_]+s[j]*i[W]+s[_]*i[J],e[Z]=s[Z]*i[V]+s[K]*i[H]+s[z]*i[Z]+s[W]*i[Q],e[K]=s[Z]*i[q]+s[K]*i[U]+s[z]*i[K]+s[W]*i[$],e[z]=s[Z]*i[G]+s[K]*i[j]+s[z]*i[z]+s[W]*i[tt],e[W]=s[Z]*i[N]+s[K]*i[_]+s[z]*i[W]+s[W]*i[J],e[Q]=s[Q]*i[V]+s[$]*i[H]+s[tt]*i[Z]+s[J]*i[Q],e[$]=s[Q]*i[q]+s[$]*i[U]+s[tt]*i[K]+s[J]*i[$],e[tt]=s[Q]*i[G]+s[$]*i[j]+s[tt]*i[z]+s[J]*i[tt],e[J]=s[Q]*i[N]+s[$]*i[_]+s[tt]*i[W]+s[J]*i[J],this.set(this.temp)}lookAt(t,e,i){let s=Et.xAxis,n=Et.yAxis,c=Et.zAxis;c.setFrom(e).normalize(),s.setFrom(e).normalize(),s.cross(i).normalize(),n.setFrom(s).cross(c).normalize(),this.identity();let a=this.values;return a[V]=s.x,a[q]=s.y,a[G]=s.z,a[H]=n.x,a[U]=n.y,a[j]=n.z,a[Z]=-c.x,a[K]=-c.y,a[z]=-c.z,Et.tmpMatrix.identity(),Et.tmpMatrix.values[N]=-t.x,Et.tmpMatrix.values[_]=-t.y,Et.tmpMatrix.values[W]=-t.z,this.multiply(Et.tmpMatrix),this}},Dt=Et;Dt.xAxis=new yt,Dt.yAxis=new yt,Dt.zAxis=new yt,Dt.tmpMatrix=new Et;var fs=class{constructor(t,e){this.position=new yt(0,0,0),this.direction=new yt(0,0,-1),this.up=new yt(0,1,0),this.near=0,this.far=100,this.zoom=1,this.viewportWidth=0,this.viewportHeight=0,this.projectionView=new Dt,this.inverseProjectionView=new Dt,this.projection=new Dt,this.view=new Dt,this.viewportWidth=t,this.viewportHeight=e,this.update()}update(){let t=this.projection,e=this.view,i=this.projectionView,s=this.inverseProjectionView,n=this.zoom,c=this.viewportWidth,a=this.viewportHeight;t.ortho(n*(-c/2),n*(c/2),n*(-a/2),n*(a/2),this.near,this.far),e.lookAt(this.position,this.direction,this.up),i.set(t.values),i.multiply(e),s.set(i.values).invert()}screenToWorld(t,e,i){let s=t.x,n=i-t.y-1;return t.x=2*s/e-1,t.y=2*n/i-1,t.z=2*t.z-1,t.project(this.inverseProjectionView),t}worldToScreen(t,e,i){return t.project(this.projectionView),t.x=e*(t.x+1)/2,t.y=i*(t.y+1)/2,t.z=(t.z+1)/2,t}setViewport(t,e){this.viewportWidth=t,this.viewportHeight=e}},Ei=class{constructor(t){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=t,this.setupCallbacks(t)}setupCallbacks(t){let e=a=>{if(a instanceof MouseEvent){let r=t.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=t.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=t.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)})};t.addEventListener("mousedown",e,!0),t.addEventListener("mousemove",i,!0),t.addEventListener("mouseup",s,!0),t.addEventListener("wheel",n,!0),t.addEventListener("touchstart",a=>{if(!this.touch0||!this.touch1){var r=a.changedTouches;let o=r.item(0);if(!o)return;let l=t.getBoundingClientRect(),h=o.clientX-l.left,d=o.clientY-l.top,u=new ms(o.identifier,h,d);if(this.mouseX=h,this.mouseY=d,this.buttonDown=!0,!this.touch0)this.touch0=u,this.listeners.map(f=>{f.down&&f.down(u.x,u.y)});else if(!this.touch1){this.touch1=u;let f=this.touch1.x-this.touch0.x,m=this.touch1.x-this.touch0.x;this.initialPinchDistance=Math.sqrt(f*f+m*m),this.listeners.map(x=>{x.zoom&&x.zoom(this.initialPinchDistance,this.initialPinchDistance)})}}a.preventDefault()},!1),t.addEventListener("touchmove",a=>{if(this.touch0){var r=a.changedTouches;let h=t.getBoundingClientRect();for(var o=0;o<r.length;o++){var l=r[o];let d=l.clientX-h.left,u=l.clientY-h.top;this.touch0.identifier===l.identifier&&(this.touch0.x=this.mouseX=d,this.touch0.y=this.mouseY=u,this.listeners.map(f=>{f.dragged&&f.dragged(d,u)})),this.touch1&&this.touch1.identifier===l.identifier&&(this.touch1.x=this.mouseX=d,this.touch1.y=this.mouseY=u)}if(this.touch0&&this.touch1){let d=this.touch1.x-this.touch0.x,u=this.touch1.x-this.touch0.x,f=Math.sqrt(d*d+u*u);this.listeners.map(m=>{m.zoom&&m.zoom(this.initialPinchDistance,f)})}}a.preventDefault()},!1);let c=a=>{if(this.touch0){var r=a.changedTouches;let h=t.getBoundingClientRect();for(var o=0;o<r.length;o++){var l=r[o];let d=l.clientX-h.left,u=l.clientY-h.top;if(this.touch0.identifier===l.identifier)if(this.touch0=null,this.mouseX=d,this.mouseY=u,this.listeners.map(f=>{f.up&&f.up(d,u)}),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(f=>{f.down&&f.down(this.touch0.x,this.touch0.y)});else{this.buttonDown=!1;break}this.touch1&&this.touch1.identifier&&(this.touch1=null)}}a.preventDefault()};t.addEventListener("touchend",c,!1),t.addEventListener("touchcancel",c)}addListener(t){this.listeners.push(t)}removeListener(t){let e=this.listeners.indexOf(t);e>-1&&this.listeners.splice(e,1)}},ms=class{constructor(t,e,i){this.identifier=t,this.x=e,this.y=i}},gr=class{constructor(t,e){this.canvas=t,this.camera=e;let i=0,s=0,n=0,c=0,a=0,r=0,o=0,l=0;new Ei(t).addListener({down:(h,d)=>{i=e.position.x,s=e.position.y,c=r=h,a=o=d,l=e.zoom},dragged:(h,d)=>{let u=h-c,f=d-a,m=e.screenToWorld(new yt(0,0),t.clientWidth,t.clientHeight),x=e.screenToWorld(new yt(u,f),t.clientWidth,t.clientHeight).sub(m);e.position.set(i-x.x,s-x.y,0),e.update(),r=h,o=d},wheel:h=>{let d=h/200*e.zoom,u=e.zoom+d;if(u>0){let f=0,m=0;if(h<0)f=r,m=o;else{let v=new yt(t.clientWidth/2+15,t.clientHeight/2),g=r-v.x,w=t.clientHeight-1-o-v.y;f=v.x-g,m=t.clientHeight-1-v.y+w}let x=e.screenToWorld(new yt(f,m),t.clientWidth,t.clientHeight);e.zoom=u,e.update();let p=e.screenToWorld(new yt(f,m),t.clientWidth,t.clientHeight);e.position.add(x.sub(p)),e.update()}},zoom:(h,d)=>{let u=h/d;e.zoom=l*u},up:(h,d)=>{r=h,o=d},moved:(h,d)=>{r=h,o=d}})}},ut=class{constructor(t,e,i){this.vertexShader=e,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=e,this.fsSource=i,this.context=t instanceof xt?t:new xt(t),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 t=this.context.gl;try{if(this.vs=this.compileShader(t.VERTEX_SHADER,this.vertexShader),!this.vs)throw new Error("Couldn't compile vertex shader.");if(this.fs=this.compileShader(t.FRAGMENT_SHADER,this.fragmentShader),!this.fs)throw new Error("Couldn#t compile fragment shader.");this.program=this.compileProgram(this.vs,this.fs)}catch(e){throw this.dispose(),e}}compileShader(t,e){let i=this.context.gl,s=i.createShader(t);if(!s)throw new Error("Couldn't create shader.");if(i.shaderSource(s,e),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(t,e){let i=this.context.gl,s=i.createProgram();if(!s)throw new Error("Couldn't compile program.");if(i.attachShader(s,t),i.attachShader(s,e),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(t,e){this.context.gl.uniform1i(this.getUniformLocation(t),e)}setUniformf(t,e){this.context.gl.uniform1f(this.getUniformLocation(t),e)}setUniform2f(t,e,i){this.context.gl.uniform2f(this.getUniformLocation(t),e,i)}setUniform3f(t,e,i,s){this.context.gl.uniform3f(this.getUniformLocation(t),e,i,s)}setUniform4f(t,e,i,s,n){this.context.gl.uniform4f(this.getUniformLocation(t),e,i,s,n)}setUniform2x2f(t,e){let i=this.context.gl;this.tmp2x2.set(e),i.uniformMatrix2fv(this.getUniformLocation(t),!1,this.tmp2x2)}setUniform3x3f(t,e){let i=this.context.gl;this.tmp3x3.set(e),i.uniformMatrix3fv(this.getUniformLocation(t),!1,this.tmp3x3)}setUniform4x4f(t,e){let i=this.context.gl;this.tmp4x4.set(e),i.uniformMatrix4fv(this.getUniformLocation(t),!1,this.tmp4x4)}getUniformLocation(t){let e=this.context.gl;if(!this.program)throw new Error("Shader not compiled.");let i=e.getUniformLocation(this.program,t);if(!i&&!e.isContextLost())throw new Error(`Couldn't find location for uniform ${t}`);return i}getAttributeLocation(t){let e=this.context.gl;if(!this.program)throw new Error("Shader not compiled.");let i=e.getAttribLocation(this.program,t);if(i==-1&&!e.isContextLost())throw new Error(`Couldn't find location for attribute ${t}`);return i}dispose(){this.context.removeRestorable(this);let t=this.context.gl;this.vs&&(t.deleteShader(this.vs),this.vs=null),this.fs&&(t.deleteShader(this.fs),this.fs=null),this.program&&(t.deleteProgram(this.program),this.program=null)}static newColoredTextured(t){let e=`
3
+ attribute vec4 ${ut.POSITION};
4
+ attribute vec4 ${ut.COLOR};
5
+ attribute vec2 ${ut.TEXCOORDS};
6
+ uniform mat4 ${ut.MVP_MATRIX};
7
7
  varying vec4 v_color;
8
8
  varying vec2 v_texCoords;
9
9
 
10
10
  void main () {
11
- v_color = ${ft.COLOR};
12
- v_texCoords = ${ft.TEXCOORDS};
13
- gl_Position = ${ft.MVP_MATRIX} * ${ft.POSITION};
11
+ v_color = ${ut.COLOR};
12
+ v_texCoords = ${ut.TEXCOORDS};
13
+ gl_Position = ${ut.MVP_MATRIX} * ${ut.POSITION};
14
14
  }
15
15
  `,i=`
16
16
  #ifdef GL_ES
@@ -26,21 +26,21 @@ uniform sampler2D u_texture;
26
26
  void main () {
27
27
  gl_FragColor = v_color * texture2D(u_texture, v_texCoords);
28
28
  }
29
- `;return new ft(t,e,i)}static newTwoColoredTextured(t){let e=`
30
- attribute vec4 ${ft.POSITION};
31
- attribute vec4 ${ft.COLOR};
32
- attribute vec4 ${ft.COLOR2};
33
- attribute vec2 ${ft.TEXCOORDS};
34
- uniform mat4 ${ft.MVP_MATRIX};
29
+ `;return new ut(t,e,i)}static newTwoColoredTextured(t){let e=`
30
+ attribute vec4 ${ut.POSITION};
31
+ attribute vec4 ${ut.COLOR};
32
+ attribute vec4 ${ut.COLOR2};
33
+ attribute vec2 ${ut.TEXCOORDS};
34
+ uniform mat4 ${ut.MVP_MATRIX};
35
35
  varying vec4 v_light;
36
36
  varying vec4 v_dark;
37
37
  varying vec2 v_texCoords;
38
38
 
39
39
  void main () {
40
- v_light = ${ft.COLOR};
41
- v_dark = ${ft.COLOR2};
42
- v_texCoords = ${ft.TEXCOORDS};
43
- gl_Position = ${ft.MVP_MATRIX} * ${ft.POSITION};
40
+ v_light = ${ut.COLOR};
41
+ v_dark = ${ut.COLOR2};
42
+ v_texCoords = ${ut.TEXCOORDS};
43
+ gl_Position = ${ut.MVP_MATRIX} * ${ut.POSITION};
44
44
  }
45
45
  `,i=`
46
46
  #ifdef GL_ES
@@ -59,15 +59,15 @@ void main () {
59
59
  gl_FragColor.a = texColor.a * v_light.a;
60
60
  gl_FragColor.rgb = ((texColor.a - 1.0) * v_dark.a + 1.0 - texColor.rgb) * v_dark.rgb + texColor.rgb * v_light.rgb;
61
61
  }
62
- `;return new ft(t,e,i)}static newColored(t){let e=`
63
- attribute vec4 ${ft.POSITION};
64
- attribute vec4 ${ft.COLOR};
65
- uniform mat4 ${ft.MVP_MATRIX};
62
+ `;return new ut(t,e,i)}static newColored(t){let e=`
63
+ attribute vec4 ${ut.POSITION};
64
+ attribute vec4 ${ut.COLOR};
65
+ uniform mat4 ${ut.MVP_MATRIX};
66
66
  varying vec4 v_color;
67
67
 
68
68
  void main () {
69
- v_color = ${ft.COLOR};
70
- gl_Position = ${ft.MVP_MATRIX} * ${ft.POSITION};
69
+ v_color = ${ut.COLOR};
70
+ gl_Position = ${ut.MVP_MATRIX} * ${ut.POSITION};
71
71
  }
72
72
  `,i=`
73
73
  #ifdef GL_ES
@@ -81,4 +81,4 @@ varying LOWP vec4 v_color;
81
81
  void main () {
82
82
  gl_FragColor = v_color;
83
83
  }
84
- `;return new ft(t,e,i)}},mt=ft;mt.MVP_MATRIX="u_projTrans",mt.POSITION="a_position",mt.COLOR="a_color",mt.COLOR2="a_color2",mt.TEXCOORDS="a_texCoords",mt.SAMPLER="u_texture";var Ei=class{constructor(t,e,i,s){this.attributes=e,this.verticesBuffer=null,this.verticesLength=0,this.dirtyVertices=!1,this.indicesBuffer=null,this.indicesLength=0,this.dirtyIndices=!1,this.elementsPerVertex=0,this.context=t instanceof xt?t:new xt(t),this.elementsPerVertex=0;for(let n=0;n<e.length;n++)this.elementsPerVertex+=e[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(t){this.dirtyVertices=!0,this.verticesLength=t}getVertices(){return this.vertices}maxIndices(){return this.indices.length}numIndices(){return this.indicesLength}setIndicesLength(t){this.dirtyIndices=!0,this.indicesLength=t}getIndices(){return this.indices}getVertexSizeInFloats(){let t=0;for(var e=0;e<this.attributes.length;e++){let i=this.attributes[e];t+=i.numElements}return t}setVertices(t){if(this.dirtyVertices=!0,t.length>this.vertices.length)throw Error("Mesh can't store more than "+this.maxVertices()+" vertices");this.vertices.set(t,0),this.verticesLength=t.length}setIndices(t){if(this.dirtyIndices=!0,t.length>this.indices.length)throw Error("Mesh can't store more than "+this.maxIndices()+" indices");this.indices.set(t,0),this.indicesLength=t.length}draw(t,e){this.drawWithOffset(t,e,0,this.indicesLength>0?this.indicesLength:this.verticesLength/this.elementsPerVertex)}drawWithOffset(t,e,i,s){let n=this.context.gl;(this.dirtyVertices||this.dirtyIndices)&&this.update(),this.bind(t),this.indicesLength>0?n.drawElements(e,s,n.UNSIGNED_SHORT,i*2):n.drawArrays(e,i,s),this.unbind(t)}bind(t){let e=this.context.gl;e.bindBuffer(e.ARRAY_BUFFER,this.verticesBuffer);let i=0;for(let s=0;s<this.attributes.length;s++){let n=this.attributes[s],c=t.getAttributeLocation(n.name);e.enableVertexAttribArray(c),e.vertexAttribPointer(c,n.numElements,e.FLOAT,!1,this.elementsPerVertex*4,i*4),i+=n.numElements}this.indicesLength>0&&e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,this.indicesBuffer)}unbind(t){let e=this.context.gl;for(let i=0;i<this.attributes.length;i++){let s=this.attributes[i],n=t.getAttributeLocation(s.name);e.disableVertexAttribArray(n)}e.bindBuffer(e.ARRAY_BUFFER,null),this.indicesLength>0&&e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,null)}update(){let t=this.context.gl;this.dirtyVertices&&(this.verticesBuffer||(this.verticesBuffer=t.createBuffer()),t.bindBuffer(t.ARRAY_BUFFER,this.verticesBuffer),t.bufferData(t.ARRAY_BUFFER,this.vertices.subarray(0,this.verticesLength),t.DYNAMIC_DRAW),this.dirtyVertices=!1),this.dirtyIndices&&(this.indicesBuffer||(this.indicesBuffer=t.createBuffer()),t.bindBuffer(t.ELEMENT_ARRAY_BUFFER,this.indicesBuffer),t.bufferData(t.ELEMENT_ARRAY_BUFFER,this.indices.subarray(0,this.indicesLength),t.DYNAMIC_DRAW),this.dirtyIndices=!1)}restore(){this.verticesBuffer=null,this.indicesBuffer=null,this.update()}dispose(){this.context.removeRestorable(this);let t=this.context.gl;t.deleteBuffer(this.verticesBuffer),t.deleteBuffer(this.indicesBuffer)}},Jt=class{constructor(t,e,i){this.name=t,this.type=e,this.numElements=i}},ke=class extends Jt{constructor(){super(mt.POSITION,qt.Float,2)}},xr=class extends Jt{constructor(){super(mt.POSITION,qt.Float,3)}},ki=class extends Jt{constructor(t=0){super(mt.TEXCOORDS+(t==0?"":t),qt.Float,2)}},Re=class extends Jt{constructor(){super(mt.COLOR,qt.Float,4)}},gs=class extends Jt{constructor(){super(mt.COLOR2,qt.Float,4)}},qt=(t=>(t[t.Float=0]="Float",t))(qt||{}),Qt=class{constructor(t,e=!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=t instanceof xt?t:new xt(t);let s=e?[new ke,new Re,new ki,new gs]:[new ke,new Re,new ki];this.mesh=new Ei(t,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(t){if(this.isDrawing)throw new Error("PolygonBatch is already drawing. Call PolygonBatch.end() before calling PolygonBatch.begin()");this.drawCalls=0,this.shader=t,this.lastTexture=null,this.isDrawing=!0;let e=this.context.gl;e.enable(e.BLEND),e.blendFuncSeparate(this.srcColorBlend,this.dstBlend,this.srcAlphaBlend,this.dstBlend),Qt.disableCulling&&(this.cullWasEnabled=e.isEnabled(e.CULL_FACE),this.cullWasEnabled&&e.disable(e.CULL_FACE))}setBlendMode(t,e,i){this.srcColorBlend==t&&this.srcAlphaBlend==e&&this.dstBlend==i||(this.srcColorBlend=t,this.srcAlphaBlend=e,this.dstBlend=i,this.isDrawing&&(this.flush(),this.context.gl.blendFuncSeparate(t,i,e,i)))}draw(t,e,i){t!=this.lastTexture?(this.flush(),this.lastTexture=t):(this.verticesLength+e.length>this.mesh.getVertices().length||this.indicesLength+i.length>this.mesh.getIndices().length)&&this.flush();let s=this.mesh.numVertices();this.mesh.getVertices().set(e,this.verticesLength),this.verticesLength+=e.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++,Qt.globalDrawCalls++}}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 t=this.context.gl;t.disable(t.BLEND),Qt.disableCulling&&this.cullWasEnabled&&t.enable(t.CULL_FACE)}getDrawCalls(){return this.drawCalls}static getAndResetGlobalDrawCalls(){let t=Qt.globalDrawCalls;return Qt.globalDrawCalls=0,t}dispose(){this.mesh.dispose()}},oe=Qt;oe.disableCulling=!1,oe.globalDrawCalls=0;var Ri=class{constructor(t,e=10920){if(this.isDrawing=!1,this.shapeType=bt.Filled,this.color=new O(1,1,1,1),this.shader=null,this.vertexIndex=0,this.tmp=new Ut,e>10920)throw new Error("Can't have more than 10920 triangles per batch: "+e);this.context=t instanceof xt?t:new xt(t),this.mesh=new Ei(t,[new ke,new Re],e,0);let i=this.context.gl;this.srcColorBlend=i.SRC_ALPHA,this.srcAlphaBlend=i.ONE,this.dstBlend=i.ONE_MINUS_SRC_ALPHA}begin(t){if(this.isDrawing)throw new Error("ShapeRenderer.begin() has already been called");this.shader=t,this.vertexIndex=0,this.isDrawing=!0;let e=this.context.gl;e.enable(e.BLEND),e.blendFuncSeparate(this.srcColorBlend,this.dstBlend,this.srcAlphaBlend,this.dstBlend)}setBlendMode(t,e,i){this.srcColorBlend=t,this.srcAlphaBlend=e,this.dstBlend=i,this.isDrawing&&(this.flush(),this.context.gl.blendFuncSeparate(t,i,e,i))}setColor(t){this.color.setFromColor(t)}setColorWith(t,e,i,s){this.color.set(t,e,i,s)}point(t,e,i){this.check(bt.Point,1),i||(i=this.color),this.vertex(t,e,i)}line(t,e,i,s,n){this.check(bt.Line,2);let c=this.mesh.getVertices(),a=this.vertexIndex;n||(n=this.color),this.vertex(t,e,n),this.vertex(i,s,n)}triangle(t,e,i,s,n,c,a,r,o,l){this.check(t?bt.Filled:bt.Line,3);let h=this.mesh.getVertices(),d=this.vertexIndex;r||(r=this.color),o||(o=this.color),l||(l=this.color),t?(this.vertex(e,i,r),this.vertex(s,n,o),this.vertex(c,a,l)):(this.vertex(e,i,r),this.vertex(s,n,o),this.vertex(s,n,r),this.vertex(c,a,o),this.vertex(c,a,r),this.vertex(e,i,o))}quad(t,e,i,s,n,c,a,r,o,l,h,d,f){this.check(t?bt.Filled:bt.Line,3);let u=this.mesh.getVertices(),m=this.vertexIndex;l||(l=this.color),h||(h=this.color),d||(d=this.color),f||(f=this.color),t?(this.vertex(e,i,l),this.vertex(s,n,h),this.vertex(c,a,d),this.vertex(c,a,d),this.vertex(r,o,f),this.vertex(e,i,l)):(this.vertex(e,i,l),this.vertex(s,n,h),this.vertex(s,n,h),this.vertex(c,a,d),this.vertex(c,a,d),this.vertex(r,o,f),this.vertex(r,o,f),this.vertex(e,i,l))}rect(t,e,i,s,n,c){this.quad(t,e,i,e+s,i,e+s,i+n,e,i+n,c,c,c,c)}rectLine(t,e,i,s,n,c,a){this.check(t?bt.Filled:bt.Line,8),a||(a=this.color);let r=this.tmp.set(n-i,e-s);r.normalize(),c*=.5;let o=r.x*c,l=r.y*c;t?(this.vertex(e+o,i+l,a),this.vertex(e-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(e-o,i-l,a)):(this.vertex(e+o,i+l,a),this.vertex(e-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(e+o,i+l,a),this.vertex(s-o,n-l,a),this.vertex(e-o,i-l,a))}x(t,e,i){this.line(t-i,e-i,t+i,e+i),this.line(t-i,e+i,t+i,e-i)}polygon(t,e,i,s){if(i<3)throw new Error("Polygon must contain at least 3 vertices");this.check(bt.Line,i*2),s||(s=this.color);let n=this.mesh.getVertices(),c=this.vertexIndex;e<<=1,i<<=1;let a=t[e],r=t[e+1],o=e+i;for(let l=e,h=e+i-2;l<h;l+=2){let d=t[l],f=t[l+1],u=0,m=0;l+2>=o?(u=a,m=r):(u=t[l+2],m=t[l+3]),this.vertex(d,f,s),this.vertex(u,m,s)}}circle(t,e,i,s,n,c=0){if(c==0&&(c=Math.max(1,6*X.cbrt(s)|0)),c<=0)throw new Error("segments must be > 0.");n||(n=this.color);let a=2*X.PI/c,r=Math.cos(a),o=Math.sin(a),l=s,h=0;if(t){this.check(bt.Filled,c*3+3),c--;for(let f=0;f<c;f++){this.vertex(e,i,n),this.vertex(e+l,i+h,n);let u=l;l=r*l-o*h,h=o*u+r*h,this.vertex(e+l,i+h,n)}this.vertex(e,i,n),this.vertex(e+l,i+h,n)}else{this.check(bt.Line,c*2+2);for(let f=0;f<c;f++){this.vertex(e+l,i+h,n);let u=l;l=r*l-o*h,h=o*u+r*h,this.vertex(e+l,i+h,n)}this.vertex(e+l,i+h,n)}let d=l;l=s,h=0,this.vertex(e+l,i+h,n)}curve(t,e,i,s,n,c,a,r,o,l){this.check(bt.Line,o*2+2),l||(l=this.color);let h=1/o,d=h*h,f=h*h*h,u=3*h,m=3*d,x=6*d,p=6*f,v=t-i*2+n,g=e-s*2+c,w=(i-n)*3-t+a,b=(s-c)*3-e+r,y=t,A=e,C=(i-t)*u+v*m+w*f,I=(s-e)*u+g*m+b*f,E=v*x+w*p,R=g*x+b*p,L=w*p,k=b*p;for(;o-- >0;)this.vertex(y,A,l),y+=C,A+=I,C+=E,I+=R,E+=L,R+=k,this.vertex(y,A,l);this.vertex(y,A,l),this.vertex(a,r,l)}vertex(t,e,i){let s=this.vertexIndex,n=this.mesh.getVertices();n[s++]=t,n[s++]=e,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 t=this.context.gl;t.disable(t.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(t,e){if(!this.isDrawing)throw new Error("ShapeRenderer.begin() has not been called");if(this.shapeType==t)if(this.mesh.maxVertices()-this.mesh.numVertices()<e)this.flush();else return;else this.flush(),this.shapeType=t}dispose(){this.mesh.dispose()}},bt=(t=>(t[t.Point=0]="Point",t[t.Line=1]="Line",t[t.Filled=4]="Filled",t))(bt||{}),Fi=class{constructor(t){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 cs,this.temp=new Array,this.vertices=P.newFloatArray(2*1024),this.context=t instanceof xt?t:new xt(t)}draw(t,e,i){let s=e.x,n=e.y,c=this.context.gl,a=this.premultipliedAlpha?c.ONE:c.SRC_ALPHA;t.setBlendMode(a,c.ONE,c.ONE_MINUS_SRC_ALPHA);let r=e.bones;if(this.drawBones){t.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 d=h.data.length*h.a+h.worldX,f=h.data.length*h.c+h.worldY;t.rectLine(!0,h.worldX,h.worldY,d,f,this.boneWidth*this.scale)}this.drawSkeletonXY&&t.x(s,n,4*this.scale)}if(this.drawRegionAttachments){t.setColor(this.attachmentLineColor);let o=e.slots;for(let l=0,h=o.length;l<h;l++){let d=o[l],f=d.getAttachment();if(f instanceof at){let u=f,m=this.vertices;u.computeWorldVertices(d,m,0,2),t.line(m[0],m[1],m[2],m[3]),t.line(m[2],m[3],m[4],m[5]),t.line(m[4],m[5],m[6],m[7]),t.line(m[6],m[7],m[0],m[1])}}}if(this.drawMeshHull||this.drawMeshTriangles){let o=e.slots;for(let l=0,h=o.length;l<h;l++){let d=o[l];if(!d.bone.active)continue;let f=d.getAttachment();if(!(f instanceof Dt))continue;let u=f,m=this.vertices;u.computeWorldVertices(d,0,u.worldVerticesLength,m,0,2);let x=u.triangles,p=u.hullLength;if(this.drawMeshTriangles){t.setColor(this.triangleLineColor);for(let v=0,g=x.length;v<g;v+=3){let w=x[v]*2,b=x[v+1]*2,y=x[v+2]*2;t.triangle(!1,m[w],m[w+1],m[b],m[b+1],m[y],m[y+1])}}if(this.drawMeshHull&&p>0){t.setColor(this.attachmentLineColor),p=(p>>1)*2;let v=m[p-2],g=m[p-1];for(let w=0,b=p;w<b;w+=2){let y=m[w],A=m[w+1];t.line(y,A,v,g),v=y,g=A}}}}if(this.drawBoundingBoxes){let o=this.bounds;o.update(e,!0),t.setColor(this.aabbColor),t.rect(!1,o.minX,o.minY,o.getWidth(),o.getHeight());let l=o.polygons,h=o.boundingBoxes;for(let d=0,f=l.length;d<f;d++){let u=l[d];t.setColor(h[d].color),t.polygon(u,0,u.length)}}if(this.drawPaths){let o=e.slots;for(let l=0,h=o.length;l<h;l++){let d=o[l];if(!d.bone.active)continue;let f=d.getAttachment();if(!(f instanceof _t))continue;let u=f,m=u.worldVerticesLength,x=this.temp=P.setArraySize(this.temp,m,0);u.computeWorldVertices(d,0,m,x,0,2);let p=this.pathColor,v=x[2],g=x[3],w=0,b=0;if(u.closed){t.setColor(p);let y=x[0],A=x[1],C=x[m-2],I=x[m-1];w=x[m-4],b=x[m-3],t.curve(v,g,y,A,C,I,w,b,32),t.setColor(Fi.LIGHT_GRAY),t.line(v,g,y,A),t.line(w,b,C,I)}m-=4;for(let y=4;y<m;y+=6){let A=x[y],C=x[y+1],I=x[y+2],E=x[y+3];w=x[y+4],b=x[y+5],t.setColor(p),t.curve(v,g,A,C,I,E,w,b,32),t.setColor(Fi.LIGHT_GRAY),t.line(v,g,A,C),t.line(w,b,I,E),v=w,g=b}}}if(this.drawBones){t.setColor(this.boneOriginColor);for(let o=0,l=r.length;o<l;o++){let h=r[o];i&&i.indexOf(h.data.name)>-1||t.circle(!0,h.worldX,h.worldY,3*this.scale,this.boneOriginColor,8)}}if(this.drawClipping){let o=e.slots;t.setColor(this.clipColor);for(let l=0,h=o.length;l<h;l++){let d=o[l];if(!d.bone.active)continue;let f=d.getAttachment();if(!(f instanceof ae))continue;let u=f,m=u.worldVerticesLength,x=this.temp=P.setArraySize(this.temp,m,0);u.computeWorldVertices(d,0,m,x,0,2);for(let p=0,v=x.length;p<v;p+=2){let g=x[p],w=x[p+1],b=x[(p+2)%x.length],y=x[(p+3)%x.length];t.line(g,w,b,y)}}}}dispose(){}},Fe=Fi;Fe.LIGHT_GRAY=new O(.7529411764705882,.7529411764705882,.7529411764705882,1),Fe.GREEN=new O(0,1,0,1);var wr=class{constructor(t,e,i){this.vertices=t,this.numVertices=e,this.numFloats=i}},xs=class{constructor(t,e=!0){this.premultipliedAlpha=!1,this.tempColor=new O,this.tempColor2=new O,this.vertexSize=2+2+4,this.twoColorTint=!1,this.renderable=new wr([],0,0),this.clipper=new Ie,this.temp=new Ut,this.temp2=new Ut,this.temp3=new O,this.temp4=new O,this.twoColorTint=e,e&&(this.vertexSize+=4),this.vertices=P.newFloatArray(this.vertexSize*1024)}draw(t,e,i=-1,s=-1,n=null){let c=this.clipper,a=this.premultipliedAlpha,r=this.twoColorTint,o=null,l=this.temp,h=this.temp2,d=this.temp3,f=this.temp4,u=this.renderable,m,x,p=e.drawOrder,v,g=e.color,w=r?12:8,b=!1;i==-1&&(b=!0);for(let y=0,A=p.length;y<A;y++){let C=c.isClipping()?2:w,I=p[y];if(!I.bone.active){c.clipEndWithSlot(I);continue}if(i>=0&&i==I.data.index&&(b=!0),!b){c.clipEndWithSlot(I);continue}s>=0&&s==I.data.index&&(b=!1);let E=I.getAttachment(),R;if(E instanceof at){let L=E;u.vertices=this.vertices,u.numVertices=4,u.numFloats=C<<2,L.computeWorldVertices(I,u.vertices,0,C),x=xs.QUAD_TRIANGLES,m=L.uvs,R=L.region.texture,v=L.color}else if(E instanceof Dt){let L=E;u.vertices=this.vertices,u.numVertices=L.worldVerticesLength>>1,u.numFloats=u.numVertices*C,u.numFloats>u.vertices.length&&(u.vertices=this.vertices=P.newFloatArray(u.numFloats)),L.computeWorldVertices(I,0,L.worldVerticesLength,u.vertices,0,C),x=L.triangles,R=L.region.texture,m=L.uvs,v=L.color}else if(E instanceof ae){let L=E;c.clipStart(I,L);continue}else{c.clipEndWithSlot(I);continue}if(R){let L=I.color,k=this.tempColor;k.r=g.r*L.r*v.r,k.g=g.g*L.g*v.g,k.b=g.b*L.b*v.b,k.a=g.a*L.a*v.a,a&&(k.r*=k.a,k.g*=k.a,k.b*=k.a);let F=this.tempColor2;I.darkColor?(a?(F.r=I.darkColor.r*k.a,F.g=I.darkColor.g*k.a,F.b=I.darkColor.b*k.a):F.setFromColor(I.darkColor),F.a=a?1:0):F.set(0,0,0,1);let Y=I.data.blendMode;if(Y!=o&&(o=Y,t.setBlendMode(Ye.getSourceColorGLBlendMode(o,a),Ye.getSourceAlphaGLBlendMode(o),Ye.getDestGLBlendMode(o))),c.isClipping()){c.clipTriangles(u.vertices,u.numFloats,x,x.length,m,k,F,r);let T=new Float32Array(c.clippedVertices),D=c.clippedTriangles;n&&n(T,T.length,w),t.draw(R,T,D)}else{let T=u.vertices;if(r)for(let B=2,et=0,rt=u.numFloats;B<rt;B+=w,et+=2)T[B]=k.r,T[B+1]=k.g,T[B+2]=k.b,T[B+3]=k.a,T[B+4]=m[et],T[B+5]=m[et+1],T[B+6]=F.r,T[B+7]=F.g,T[B+8]=F.b,T[B+9]=F.a;else for(let B=2,et=0,rt=u.numFloats;B<rt;B+=w,et+=2)T[B]=k.r,T[B+1]=k.g,T[B+2]=k.b,T[B+3]=k.a,T[B+4]=m[et],T[B+5]=m[et+1];let D=u.vertices.subarray(0,u.numFloats);n&&n(u.vertices,u.numFloats,w),t.draw(R,D,x)}}c.clipEndWithSlot(I)}c.clipEnd()}},Xi=xs;Xi.QUAD_TRIANGLES=[0,1,2,2,3,0];var S=[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],Xe=[0,1,2,2,3,0],Le=new O(1,1,1,1),ws=class{constructor(t,e,i=!0){this.twoColorTint=!1,this.activeRenderer=null,this.canvas=t,this.context=e instanceof xt?e:new xt(e),this.twoColorTint=i,this.camera=new us(t.width,t.height),this.batcherShader=i?mt.newTwoColoredTextured(this.context):mt.newColoredTextured(this.context),this.batcher=new oe(this.context,i),this.shapesShader=mt.newColored(this.context),this.shapes=new Ri(this.context),this.skeletonRenderer=new Xi(this.context,i),this.skeletonDebugRenderer=new Fe(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(t,e=!1,i=-1,s=-1,n=null){this.enableRenderer(this.batcher),this.skeletonRenderer.premultipliedAlpha=e,this.skeletonRenderer.draw(this.batcher,t,i,s,n)}drawSkeletonDebug(t,e=!1,i){this.enableRenderer(this.shapes),this.skeletonDebugRenderer.premultipliedAlpha=e,this.skeletonDebugRenderer.draw(this.shapes,t,i)}drawTexture(t,e,i,s,n,c){this.enableRenderer(this.batcher),c||(c=Le);var a=0;S[a++]=e,S[a++]=i,S[a++]=c.r,S[a++]=c.g,S[a++]=c.b,S[a++]=c.a,S[a++]=0,S[a++]=1,this.twoColorTint&&(S[a++]=0,S[a++]=0,S[a++]=0,S[a++]=0),S[a++]=e+s,S[a++]=i,S[a++]=c.r,S[a++]=c.g,S[a++]=c.b,S[a++]=c.a,S[a++]=1,S[a++]=1,this.twoColorTint&&(S[a++]=0,S[a++]=0,S[a++]=0,S[a++]=0),S[a++]=e+s,S[a++]=i+n,S[a++]=c.r,S[a++]=c.g,S[a++]=c.b,S[a++]=c.a,S[a++]=1,S[a++]=0,this.twoColorTint&&(S[a++]=0,S[a++]=0,S[a++]=0,S[a++]=0),S[a++]=e,S[a++]=i+n,S[a++]=c.r,S[a++]=c.g,S[a++]=c.b,S[a++]=c.a,S[a++]=0,S[a++]=0,this.twoColorTint&&(S[a++]=0,S[a++]=0,S[a++]=0,S[a]=0),this.batcher.draw(t,S,Xe)}drawTextureUV(t,e,i,s,n,c,a,r,o,l){this.enableRenderer(this.batcher),l||(l=Le);var h=0;S[h++]=e,S[h++]=i,S[h++]=l.r,S[h++]=l.g,S[h++]=l.b,S[h++]=l.a,S[h++]=c,S[h++]=a,this.twoColorTint&&(S[h++]=0,S[h++]=0,S[h++]=0,S[h++]=0),S[h++]=e+s,S[h++]=i,S[h++]=l.r,S[h++]=l.g,S[h++]=l.b,S[h++]=l.a,S[h++]=r,S[h++]=a,this.twoColorTint&&(S[h++]=0,S[h++]=0,S[h++]=0,S[h++]=0),S[h++]=e+s,S[h++]=i+n,S[h++]=l.r,S[h++]=l.g,S[h++]=l.b,S[h++]=l.a,S[h++]=r,S[h++]=o,this.twoColorTint&&(S[h++]=0,S[h++]=0,S[h++]=0,S[h++]=0),S[h++]=e,S[h++]=i+n,S[h++]=l.r,S[h++]=l.g,S[h++]=l.b,S[h++]=l.a,S[h++]=c,S[h++]=o,this.twoColorTint&&(S[h++]=0,S[h++]=0,S[h++]=0,S[h]=0),this.batcher.draw(t,S,Xe)}drawTextureRotated(t,e,i,s,n,c,a,r,o){this.enableRenderer(this.batcher),o||(o=Le);let l=e+c,h=i+a,d=-c,f=-a,u=s-c,m=n-a,x=d,p=f,v=d,g=m,w=u,b=m,y=u,A=f,C=0,I=0,E=0,R=0,L=0,k=0,F=0,Y=0;if(r!=0){let D=X.cosDeg(r),B=X.sinDeg(r);C=D*x-B*p,I=B*x+D*p,F=D*v-B*g,Y=B*v+D*g,L=D*w-B*b,k=B*w+D*b,E=L+(C-F),R=k+(I-Y)}else C=x,I=p,F=v,Y=g,L=w,k=b,E=y,R=A;C+=l,I+=h,E+=l,R+=h,L+=l,k+=h,F+=l,Y+=h;var T=0;S[T++]=C,S[T++]=I,S[T++]=o.r,S[T++]=o.g,S[T++]=o.b,S[T++]=o.a,S[T++]=0,S[T++]=1,this.twoColorTint&&(S[T++]=0,S[T++]=0,S[T++]=0,S[T++]=0),S[T++]=E,S[T++]=R,S[T++]=o.r,S[T++]=o.g,S[T++]=o.b,S[T++]=o.a,S[T++]=1,S[T++]=1,this.twoColorTint&&(S[T++]=0,S[T++]=0,S[T++]=0,S[T++]=0),S[T++]=L,S[T++]=k,S[T++]=o.r,S[T++]=o.g,S[T++]=o.b,S[T++]=o.a,S[T++]=1,S[T++]=0,this.twoColorTint&&(S[T++]=0,S[T++]=0,S[T++]=0,S[T++]=0),S[T++]=F,S[T++]=Y,S[T++]=o.r,S[T++]=o.g,S[T++]=o.b,S[T++]=o.a,S[T++]=0,S[T++]=0,this.twoColorTint&&(S[T++]=0,S[T++]=0,S[T++]=0,S[T]=0),this.batcher.draw(t,S,Xe)}drawRegion(t,e,i,s,n,c){this.enableRenderer(this.batcher),c||(c=Le);var a=0;S[a++]=e,S[a++]=i,S[a++]=c.r,S[a++]=c.g,S[a++]=c.b,S[a++]=c.a,S[a++]=t.u,S[a++]=t.v2,this.twoColorTint&&(S[a++]=0,S[a++]=0,S[a++]=0,S[a++]=0),S[a++]=e+s,S[a++]=i,S[a++]=c.r,S[a++]=c.g,S[a++]=c.b,S[a++]=c.a,S[a++]=t.u2,S[a++]=t.v2,this.twoColorTint&&(S[a++]=0,S[a++]=0,S[a++]=0,S[a++]=0),S[a++]=e+s,S[a++]=i+n,S[a++]=c.r,S[a++]=c.g,S[a++]=c.b,S[a++]=c.a,S[a++]=t.u2,S[a++]=t.v,this.twoColorTint&&(S[a++]=0,S[a++]=0,S[a++]=0,S[a++]=0),S[a++]=e,S[a++]=i+n,S[a++]=c.r,S[a++]=c.g,S[a++]=c.b,S[a++]=c.a,S[a++]=t.u,S[a++]=t.v,this.twoColorTint&&(S[a++]=0,S[a++]=0,S[a++]=0,S[a]=0),this.batcher.draw(t.page.texture,S,Xe)}line(t,e,i,s,n,c){this.enableRenderer(this.shapes),this.shapes.line(t,e,i,s,n)}triangle(t,e,i,s,n,c,a,r,o,l){this.enableRenderer(this.shapes),this.shapes.triangle(t,e,i,s,n,c,a,r,o,l)}quad(t,e,i,s,n,c,a,r,o,l,h,d,f){this.enableRenderer(this.shapes),this.shapes.quad(t,e,i,s,n,c,a,r,o,l,h,d,f)}rect(t,e,i,s,n,c){this.enableRenderer(this.shapes),this.shapes.rect(t,e,i,s,n,c)}rectLine(t,e,i,s,n,c,a){this.enableRenderer(this.shapes),this.shapes.rectLine(t,e,i,s,n,c,a)}polygon(t,e,i,s){this.enableRenderer(this.shapes),this.shapes.polygon(t,e,i,s)}circle(t,e,i,s,n,c=0){this.enableRenderer(this.shapes),this.shapes.circle(t,e,i,s,n,c)}curve(t,e,i,s,n,c,a,r,o,l){this.enableRenderer(this.shapes),this.shapes.curve(t,e,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(t){let e=this.canvas;var i=window.devicePixelRatio||1,s=Math.round(e.clientWidth*i),n=Math.round(e.clientHeight*i);if((e.width!=s||e.height!=n)&&(e.width=s,e.height=n),this.context.gl.viewport(0,0,e.width,e.height),t===Pe.Expand)this.camera.setViewport(s,n);else if(t===Pe.Fit){let c=e.width,a=e.height,r=this.camera.viewportWidth,o=this.camera.viewportHeight,l=o/r,h=a/c,d=l<h?r/c:o/a;this.camera.setViewport(c*d,a*d)}this.camera.update()}enableRenderer(t){this.activeRenderer!==t&&(this.end(),t instanceof oe?(this.batcherShader.bind(),this.batcherShader.setUniform4x4f(mt.MVP_MATRIX,this.camera.projectionView.values),this.batcherShader.setUniformi("u_texture",0),this.batcher.begin(this.batcherShader),this.activeRenderer=this.batcher):t instanceof Ri?(this.shapesShader.bind(),this.shapesShader.setUniform4x4f(mt.MVP_MATRIX,this.camera.projectionView.values),this.shapes.begin(this.shapesShader),this.activeRenderer=this.shapes):this.activeRenderer=this.skeletonDebugRenderer)}},Pe=(t=>(t[t.Stretch=0]="Stretch",t[t.Expand=1]="Expand",t[t.Fit=2]="Fit",t))(Pe||{}),he,$t,bs=0,br=1,Li=1,ps=165,vs=108,Gt=163,pr=class{constructor(t){if(this.logo=null,this.spinner=null,this.angle=0,this.fadeOut=0,this.fadeIn=0,this.timeKeeper=new Ne,this.backgroundColor=new O(.135,.135,.135,1),this.tempColor=new O,this.renderer=t,this.timeKeeper.maxDelta=9,!$t){let e=navigator.userAgent.indexOf("Safari")>-1,i=()=>bs++;$t=new Image,$t.src=yr,e||($t.crossOrigin="anonymous"),$t.onload=i,he=new Image,he.src=vr,e||(he.crossOrigin="anonymous"),he.onload=i}}dispose(){var t,e;(t=this.logo)==null||t.dispose(),(e=this.spinner)==null||e.dispose()}draw(t=!1){if(bs<2||t&&this.fadeOut>Li)return;this.timeKeeper.update();let e=Math.abs(Math.sin(this.timeKeeper.totalTime+.25));this.angle-=this.timeKeeper.delta*200*(1+1.5*Math.pow(e,5));let i=this.tempColor,s=this.renderer,n=s.canvas,c=s.context.gl;if(s.resize(1),s.camera.position.set(n.width/2,n.height/2,0),s.batcher.setBlendMode(c.ONE,c.ONE,c.ONE_MINUS_SRC_ALPHA),t){if(this.fadeOut+=this.timeKeeper.delta*(this.timeKeeper.totalTime<1?2:1),this.fadeOut>Li)return;i.setFromColor(this.backgroundColor),e=1-this.fadeOut/Li,e=1-(e-1)*(e-1),i.a*=e,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)),e=1;e*=Math.min(this.fadeIn/br,1),i.set(e,e,e,e),this.logo||(this.logo=new le(s.context,$t),this.spinner=new le(s.context,he)),s.camera.zoom=Math.max(1,Gt/n.height),s.begin(),s.drawTexture(this.logo,(n.width-ps)/2,(n.height-vs)/2,ps,vs,i),this.spinner&&s.drawTextureRotated(this.spinner,(n.width-Gt)/2,(n.height-Gt)/2,Gt,Gt,Gt/2,Gt/2,this.angle,i),s.end()}},vr="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAKMAAACjCAYAAADmbK6AAAALKElEQVR42u2de2iW5R/GPzuqcwfnnKfNmafl5tTNHWzqNi3DEMQykcAoJSsySkspjSIk0iD/07Kf4R+FnVBDUTshZGpWUEJaaiWFgZlUFmXmIe3HNXthyebeZ77P9H13ffBG8Y8H7ut7vff93N/7fu4vGGPiFZiez/Qtw9lytJajfzfw9z/j+efPOv7cV8W+lUNY2a8T/ayTCRsWFLJA5rtUO1LLkV5p9LJeJizQiHeqnlOtmVFtdTGrrZkJCxYXsTgaI6r9MY4/UpNItW4mFDaXsTlaM6qVZlBq3UwofFrJp0HMWJ9DvXUzobCznJ1BzFjWlTLrZkJh/TDWBzFjTgo51s2EgnKI0Rrx+FiOWzNzVaym91Syx5qZsGBWb2ZFa0ZN6dbMhAWTcpkUrRmXD2K5NTNhgVbH0Zpxbl/mWjMTFvRIo0e0ZpzcncnWzISKtvmiMWNRJ4qslwmVXRXsas2Ix8ZwzFqZsGFREYtaM+Oaa1ljrUzYkJ9G/ok6TlzKjJWZVFor0y7c1Zu7WjLiqiGsskamXdHopyT4vALmzS9k/t19uHtKHlOSIMn6xAtARjIZ1sFcUSZ0Y4La+G6M18hS2IlCn4a+WoC0JNL0d/dUupdnUj40g6EJ2VEdMnhrOG/p5f/jUXz8SgmvaGU6KpNRNsLVQV0OdXf24s63h/P2gWoOrBjMCr2GJFQnnxnIM3q5P1PPmaYv+4ev4/C6UtbpV2gzXCkgL5W8Bwt48OIc6ul6Tp+s4+SyASxLiI4+PYCn1bHzDZxvaQW6vZzto7MYnQIpNkf7kp5EuozYUroqEjcNKHHd0Tl9mBPN1pk+hFeieGBnBtog7UXjsj9pWg+m6duecw2cay1OC/uxMC47KmP9OIYfoz1YoC20J/rzRG4quTZK2EAyJGs20qwUbYw0aNRmUxtvfUW/uEtNzc1NB1/X8LVyd15hh82F43AvD+VlXcsSJEZa1CQ3ejleAO7oxR3RDP0XN91X4+NXYb8nkv7UNTwV7e0YTdu7I3g33t7tuaEbNwSZpps2fSyvs4M2Tjhot+jb0Xzbltj8r5j/xVt/6Z1Ob93U1ZYO691EhhzchcHeXosVjcNZysyezLw4xRZt05R+fTeuj8vOj+zKyG0j2aZcVVs6v+QalnjrMFZASQYl2nBoSyz06e3j/Xk8rgWYmMvEICu2pm1HOTuc7okV8FgRj0XukwzanhvCc/F+72TjoQjdObN1OFuDLmh0xP+WHtxiI10ukJlCprb4guiv1fP+avZrS1C7NAkliHZjDtZwMMgqbukAltpMlwuMy2FcEBPqvfLLar5Uqi0hBdEwryy+Mv5n6zkbjTBa+dlMlwvUZFETZKGiFM7tvbhdJ3gSVRO0wzIjnxmvl/J6a6JsGMYGrahtpssFeqbR841S3mhN80OjOaSDEdqd6SjaMKgzgzRK7q1ib3PT9sYyNo7JZoyNFNvRcVMZmy7WOvIuryv/Zvdmdt90+nY0bRp3AvROohFwdwW7dTG7RFlbwlqdrbOBYg005NAQmZU0HWt1rXMBH1Xw0dQ8pmqzoaPmdhun7bHZjNVe9qP9eFQfO1VkUmHjhAVUZ1GtnKFSbjrkrPfy4i4UW5t/6ZxM54J0CqxFe81KpGsQyE4h23oYY4wxxhhjjDHGGGOMMcYYY4wxxhhjjDHGGGOMMcYYY4wxxhhjjDHGGGOMMcYYY4wxxhhjjLna+bdOy+IiFquIpGq16Pb79cNYv3IIK/X/ugx+Ui6TVKvYVU9Nc8gX8od8Ir/IN/KPfCQ/yVfyl/6/pfJvLChkQdD6wyqntquCXYuKWJSfRr6D0dEAxV3xlw/khyD+kd/ku/88cHo+09tS3LBpO1HHCVUqcIA6CqB4K+6X6x35L/JM2loXurlWmUmlA5XogOIcK8/If5HncrSWo7F6cKIWPjT/RXGOlWfkv8hzaWsN4uaaysE6WIkOKM6x8oz8F3kusXqo2vxC5jtYiQ4ozrH0TeS5qIZcrB7qkrwdA8U5Vp6R/yLPZV8V+2L14Cl5THGwEh1QnGPlGfkv8lyUlIzFQ1cNYVVHrcjZ0VCcFe9Y+Eb+izy3ceclUl43aFN52DXXssYpnY6a4qFS8ZcP2uIf+e7inRh6pdFrdTGrm8uiHx/L8T2V7NGWzvJBLJ/bl7mTuzO5qBNFDoiJID/IF/KHfCK/yDfyT3O7d/KbfNfS80hNIrU0g9L6HOq1x5iTQo6FNpeLfCQ/yVfyl3xmXYwxxhhjjDHGGGOMMcYYY4wxxhhjjDHGGGOMMcYYY4wxxhhjjDHGGGOMMcYYY4wxxhhjjDHNk9z4JwJ0SqKTdQkbyEwhU393T6V7zzR6pieR3tE1ITeVXImhe6BXDGZFdRbVeank2TBhcaEMr0rwbixj49IBLL2/L/ffmMuNHfqO9tFZjJYBd1ewO3Lx+IcVfKhqna5nHZYR6XFPH+5R3eeI5t9fx/fvjeC9Jdew5OKZKqFR/RDVKL6vL/f9PJafmyvHsL+a/ff24V6NmjZQbGchVbY6UM2BluqHv1rCqzVZ1KQlkZboepCdQvacPsz5bjTfXao+yMEaDt7Wk9tSIMVGig3TejCtJSM2bSpkPjWPqd1S6Zao+lORSYWmgkOjORRNwZqd5ezMSiHLRooNr5XwWjS6/1XHX9vL2T67N7M1iyXa9JCrYjVrS1gbpJyw6hBfsmiNCYT0P9/A+Wj1/6qGr5YNYFlJBiWJogEzezLz/ZG8/9s4fgtSyuvNYbyp1IONFBtu7sHNv4/j9yAxUHWrdaWsG9+N8XHd+YxkMpSy+aySz841cC5oXbmHCnnI74yxAgZ3YbDeB4PEQCOpBpFNZWwa2ZWRcdnxLsl00crtRB0n2lLg8JNRfDKoM4NsolgBSmw/UMADba1+qpmqfyf6x1u/0a/og3I+aEunP6/i86osqmygcGarF4p54dex/Bo0LqfqOfVwIQ/HW5/RSkwV1oN2WLlHTc82TljAwM4M1O5LWwYKZTjibYXNS0N5KcjKTe10PadfLObFuJwK4ozp+UzXDBTUjL+M5ZcBnRkQV53dMIwNQTu6bSTbVEzbi5awuVByd2E/FgaN0Tc1fKOzBHHV2aAdVSdv6s5NNkp7cSH/++xAng2yyHx+CM/H21YhfdPp+0U1X0TbSZnXx8faG9Aop0MS0cToh1p+iLcpOkLj9t/JOk5eqoPHxnDsyf486an5yqCDK7XZ1O4oZ4dWyy3FSXHUAYq47uyYbMZoGmhpG3DlEFb6uNiVBhpyaHhnBO8oJmfqOROJjzIiP43hJ8UxITqqX56S2Hur2KsOnq3nrE6PPNKPRwrSKbAZrjTQNZmuE7oxYXMZmxWbw9dxWFu4W4ezVedOE6qzI7oyYkY+M7TPeWsPbk2UX1qioSN+E3OZqOR2cReKE+qQRFN0Pi7y73g/UawU1KzezJpXwLz5hczX1ueUPKYkNb6GJQZ+j7/aAfRZREsv+quGsMoamXZBW2Gt5eU0alorEzYsKmJRa/m4NdeyxlqZsCGa84DKnVorEzboC7podis69DfIJmwufHMc7famvvmxZiYsKOtKWbRm1OcW1syEBboSJFozLh/EcmtmwgIluaM14/phrLdmJixYXMTiaM24p5I91syEBTphFOR7Y2tmwgJNvUFOr+tov3UzoaAv44KYUatv62ZCoemdhtG0+hzqrZsJBR08DWLG0gxKrZu50qvpxos3U5NItW4mFPp1ot+lPlpq2lYXs9qamVBZUMiC1ox4pJYjvlfStAu6GmTLcLboMtPIV4/6im5fFfuUi9QIap2MiWP+D96R1vPmsD/fAAAAAElFTkSuQmCC",yr="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAKUAAABsCAYAAAALzHKmAAAQ7klEQVR42u3da4xdVRUA4D0zd2Y6nZY59DVtZ1puS9+lzC0YAi2UQ8AAQczFpPgA9VIeIQbirRqJ0cBUBVGjDr/QCKSNRSMmpuODxAdxqhgwxkhFjf6Sxh/+UUNVNGJCzR7uTvas7LXX2q9zzp3em6y0gTN3Zu75utZe5+yztxC9V+/Ve5X9En1Vjd7J6SFbLNF7naPw+l2jh7YHMBWssqMHtlsRdim4qsLtIawaPiHEQOLoNrA9iIkQDnRrVA1qD2LZ8ISoxYqKo13sQAtBWBayQWZUAXGRQM9JjCngDVY0UqJNDbQrMcaGmArdUKpIjbYiQLsCZCyIMQBy8QwnilR4Q5AuCpxFYvRFmBLbEiwKwpsSaWycVQGZBKMrwBjA9BhxDe57u2L2hOoKNCbOrgAZitEVYUxoKSMErQvSxYIzCkguRg5EF4AUhqUlhy/YUKSxcRaKsioYOQhD4I0yYxkR3PcJBcuFysmgsXAWBTMJyBCMIQh9kGGxXIXvexCQXbHGAMrBWTbM2CCpMSMLIxehC77lSJwXGth7M0FzoVJIXXDWQnGmhOkL0ic7YhhtWdGGkAuPAjUWGoF4faCmwBkbZmyUqUCyMqMLRA4+E6IsdTjidUHKBYrh9CnpRcH0ypKxsyOGEYNIIeTCOz91OIJ1QYoB5eAMyZo+MFNnyVTZ0YiRC9EGEMOyAgshxErHsL2XK1gOUgwohtM1a5YNM7Rsu4K0ZkcbRm4mpPBRwFZ5hg9eCqkrUB+csWGGogzNkqEgrdnRhpGLkINudaLgwvVB6oqzCjCTZElb2Y4B0gUjBtEG0ARnDRLjjoG9DwcshtQGlIPTljVjwUySLWNkyRCQVHa0ZUUTRAwgF91a33BEy0VKAcVwwqwZC2bqbOlUurllOxQkJzNyINoAYqjWhYYjWg5SCiiG05Q1U8FMjTIoS8YE6YORi1BHtJ4KIcQEEtTXUWAxpK44YVlPBdO1jCdFWTZIE8bVGEYMIRPcZGBw4HKQcoBiOE1ZMzbMgVQwU6JMAdKEEcuIJogUvg1YCCE2gsCO42DlIIVAKZwpYJaSLVNnSU6XjYHUmxhTmXaFaMO3EYkLqMC+FsLlIoVAKZzMrEnBhJeLfLNlKMrYWRIDCbOkFSSVHbHM6AKRC6/ODUewNqQ+OLlZkxpjUmV8MBbMUJSxyzY3Q1IgTRgxiBRCHdem0KDAUkBh9sRwwjEnAXMMgTnKhFlUtiwkS5rGka4g9SaGgxFmRC7AzTCEEBcyA36dDSsXqAtOLkysjGMwY5XxVChjZ0kuSCo7YlkRQsQQYtDEFsegsLoCxUp7Kpgps2UslFGzJGccSYHUmxhOZqwzEZqAbfUMCisHKIZzgsCpl3MTzMwTpi1bYp2477gyFKUxS7qWbdjY2EBS2dGE0QQRA7gNCyHEdhjE8RhUDlBT9tzgmjWZMFNlSy+Urk1OzCyJlW0XkK4YOQh1cDtcgwBrQmoDWkdgboBZE8mYsJSHlnFbJ+5bwmOPJ7lZkirbC8aRsMvmgtTHjBhGE0QbwJ2egUE1ITVlUC5OmDVdYNrKuN70xM6WoShjlW4464dbtiFIWK6x7GjESEHUUe0iYncnbMdQSE0Z1ITTNOb0hRmjjLtmS9dmJ2rp1jtuKktyyrb6YLEMCUHq2dGG0QQRQ7f72kzc+cJecerne8Wvv7JNPHPvenEkz8Sh3UtFc92QyGt9Yko/HgOLAIUZlItTz5ouMF3KuE+2jFLCQ1D6lm6fLMkBacuOJowYRBUXyfjuHjF3NhdnsfjvAfH6E9vFt9XxKgikEKgJZyyYalzOLeMu2bLbULI6bh+QGwmQ+rgRlumdGEQAao+K56bEL2woVUwOiev0r8OAUjiJrMmFCbvykGxZRAmPitK1dHM7bohyMsuyi/I8f0+e57fJYIKEZXpXo9E4mOf5XTKyLLvCBLETF8uY2SKepkC+dpX4T02Ivepr4HvZcOZ5fmee54fyPL+DmTUhzAs6n4n8bN5dr9f3YdkSg8nsxG0lPBVKVpNjG0/aGhzfLDmRZdnumZmZp8+c+cdZPV555fSr7Xb7s0jJ3i5Pcue4MxKkPPkvvXTqz/B92u32l0wYOzG1fkhcd/py8Rcbyq/vFM/KY1WA95h/3zzP71bfU6JsNpsfgj+P/FlbrdaDGExYyuXvLz8H+DudODH700ajcSM3W6Yu4alQ1spCOTd38jcKocTZbh9+9NixY99XJ8AEUkcpo9W64yH197m5k7+bnZ19QT+J09NHntQhwji/Jg58qi6++ofLxJ8gSFneVw2Ka4QQDfh1Ok4dZavVmtZ/nrm5k7/Vf55O1tRhboUw5+ZOvqyOl5+R/FyOHj32PYVU/tloNG5IXcKrhJIzngwp3fNjomazea/64BuNxts646f50lWv169utw9/DmtqdJQyZFaSJVuV6nq9fqMEof5/vV6/CYBqgJDlee+yAbF/+4i4ZWqZeNfaIfHWzn+Hx0KcEuU9+s8jv3ej0bhVlXOZydX/k0iRMeb8P0D5e6tj8zy/Xb9UJIc56h/yqVOnXul8lmuZ2bJslKmbHG7XrbpCmCXFRLvdfqQD6jTS3Jiy5I4OykM6ADV+1Eu1DmV6evopBORexzDi1L+X/HnGxsb2w3Hm9PSRJ9QxWPOTZdmlKht2hi+w6dkox5bqffI8fye3hDteGqKaHVsHXihKl0tB+h0cY+lute54AGRKDCW89LNTRynHb7ChUWVVjetOnJh9EYBUyPZeNCoOtsbFQwdXi4/esELcd+tq8cCHJ8UXp+viy9efLz7AgamjlKXc1AA1m83DoIRDlFubzeb96hhZLVTlgJ24gttutx+ONa50bHZKRenaeTs1OfpAfnr6yOOdE7EZdNwmlKocntXLNkA5JTGq47Ds+Lf94lWsyfnXleLfnIwJUN4DOnNYwuUxh2A3Ln9XULrfK8t3J27Tu3BVwiOjXJqoAy8UZej1yclGo3GTLN+gu3w+z/P3YaWbQqk3Ne12e4ZC+c8rxWsYytcPiP9RpZxCqWDKnxOiBNlyAUpOnGsoh4tA2Rm8X9xqtT6md5wyZmYe+0YRKL+1S/wYQ3n8zctBl5SBUv5djivfjMOPduIzcizeiYfr9foVvUwZG+XCuzibZKnSceZ5/v4QlKp8y7ElhnJlTeTP7BI/kllRYfzrfvHqFy4UX1vaL/aVlSmROzwbwdS29T2UcEwZF+V8ozM2lu1VY812u/15akypGh3TmFJesJbHHD167IdUxz3YJy5bNySuX1mbvy55CbMLtzU6tjGlsdFptVqfUMc0Go23F4wy1l2dSnbfvpMwVPe9WWVLDsrOJaF9MFu2Wq1PqmNkGce67xiXhTjdNwdlvV6/BgxfbPfBfVCetxi6b9/rlCup65QzM48dl2OjLMv26CibzeZ96sTIzEFdpwQXz9U1yrtVlpR/Zll2Fec65Y6l4pbbx8XHH9kknvzJlPjlHy8Tp29eKT5ou0aJoIT3w3dBlLDzVpfAJEZ1XOdaJZxnOSlvPMjPzxFljIvng914RwebsjYO7uhMyHu46sOfnf3Oz2TXDW6vvYxdFoIXz3Wc8J5zs9n8iOn2IrxTc2BM3Glqdp7dI553uaOjxrhwcob+MyuUpjs6WZZdon8OcigjPx8V+u+GTWFTSWEx3WYcdJ225jNDSE4q0GHCzlueHOyujn6bUWYgeb9ZZUaQPe+GzQ+Gc8+oOGhC+c1d4gfI16n3XDAhQ7+9qE9l01E2Go132GYKyXE1NiFDTcpoNpv3LOYJGWXNErJNW9sEp63p2RKiVPMn1bS1DgxsyhoGdGpmizj+xtXiDYnx7/vFmce3iWdW1cTVGEY4hQ2ZW0nNq8Qm/M6XbXm3S100lwGedFybuvNOibLI+ZS2ceU4eAxiEuvCkfmU8ycToDxETe6FgCBQHeqyAbFvfEhcO7BwDuXFCEbTZF840XeHK0jYcbs2OIGle0mVJ/mmnClEPQqxyTY5I8/zFhif7fSZee4bnrPOU4AssnRXHaVTCTd14dRDY3UbTIiSeFhsN/aMjgnqthFx880rxX3yATL5p3y4LPXzOaBkUyBjZMlYpbtQlIOBD475ZEusjMNSvkXe6VEoJVDkeZ2dzIfIFsRzU+JF2OyM9M9fTC/6SUYOyFQPjQ2nWiUjxnPfw5EeHqMWIqAeIFsAU847lJM2JM6xsewt1OIDLs99P7ZFHNdB/upS8XtPiD7PfLuCXJNolYyyFiNI/Zit65ItrOVafFbHcFohY7hPTN21Tjz4uc3iqfsnxKdX1MTl1OoYRFaMsToGB6Trw2JFP/OdZC2hJZ7ZkrMoAbbSGmelDJ91hFKuJeS7jlBMkJnrAqqJlgMUZS/dArPlGHNdSg5M3xXXtvquuEatvIYtDRhpxbUJuIgqsU5lGWtUploK0KuEU9mSW8YpmFQ556xNuYW7NiW13B+FkMiKHIy+C6eGgBxJvMR0oSv5hi6+z4HJyZoU0M2RVvDlrOQbcxVfX5AhZbuqy0v7ZstYMLHlAVlLTF9ALLbvu9Y5Zylpn/XOsd0ibIvxr2KCLHpp6SCUIdnSZSF+WzfOhem6GD+1KwR3Z4jNjrtDpNoZwmWd8yrupZN6Hx3fbMmFSe0Swdq2ZIPjxk1112Duo8OBGLrBkw/IoncdK2XHsdC9dHz204m50xh3tzFq1zFqtzHXrfCw7OgDsqyNnZLszVijsmXgrmNcmGtS78lIoMX2aJz03fKO2sDJddPQSCDPiQ1DfWBycY6XtXstc2PQKuxgG2McmXTPb9/9vmuJYXKyJrWjbeg+3xPM4O73nWqvbyw7xgZZSJbEUBa157cNJjdr2vb+5iA1YV3HxYscj30PDCEHIgcjtfm8K8hSsmRotkwFk5s1TTghUAopB6xrjHMBBkI0YYTZ0dZlxwLpkiWDULpmy5gwqayZgZNkA7oKQQCxctByYg0XIIEQQuRitGVHblMTA2ShKGPDpC6wu+DEgJqg2rDGDBtAF4Q6RAojp1xXGmSMbImVcR+YWNY04eQCtUG1ofUJ2/uvcETIgUhhdAE5GAlkKShjwHTNmhhODKgJqQ2sC14uOgyfD0IbRF+MlQaZAiZWyn2yJsTJATqGnHQO2Jhh+xlsACFCG0QbRtdyzQFZCZSxYPpmTS7Q5cjJHYNBYIkZpu99HoUQ/o4QIYSIZUZfjJ4ZMjZI32wZBDMU5yhy8pZTULl4XYP5fagMyEVoy4oupTpGduwnkloSlKEwY+AcQU4MhRTD6ovXBRwFzwWgCSEF0QVjJUGmgEllTS5OLlCIlIN1mS9mx/cZ5eLDALpCTI2RAhkTZQqYoTgpoCPECbaBHQ2ETL3PUl98ECAXYijG0OyYAmQoTG7W5ODkAF1CnVgm2JQx4okPA+gCMTbGskBGgRmaOblAh5GTORIrfKFx4VH4EIAxIXIxlg2SBbMvECY3e7oApbDaIgQu5/2HmeEKEINYiwSRi7EQkLFgumZOCuggctKGI4ULZN/vMeSLj0AYMytWEqMLzFg4fYDaoKaC6wvOFR4FkIPQFaILxrJAOsHsc/zlfYDWXE8qF22s8Pz5KHxcgEVALBtjJXBSSEOwFhk1Zgy4hitCT4hVw+gFs8/zwxqIBbUgyK7fcyA0PD9XX4iVxhiC0xdof6STWCsoBmKF7+cVCWFXQYyBMxRpf+STX1b0x45AhN0OMSrOGEirhrY/dfQAdjvS7oy+WCF6r1RIFxXWvlTRg1YVqFWBmxZbD99ig9pt0YPQw9rD1nstVri9V+/Ve3XrS/wfim4P5fIFxLoAAAAASUVORK5CYII=",Ar=class{constructor(t,e){this.time=new Ne,e.pathPrefix||(e.pathPrefix=""),e.app||(e.app={loadAssets:()=>{},initialize:()=>{},update:()=>{},render:()=>{},error:()=>{}}),e.webglConfig||(e.webglConfig={alpha:!0}),this.htmlCanvas=t,this.context=new xt(t,e.webglConfig),this.renderer=new ws(t,this.context),this.gl=this.context.gl,this.assetManager=new fs(this.context,e.pathPrefix),this.input=new Yi(t),e.app.loadAssets&&e.app.loadAssets(this);let i=()=>{requestAnimationFrame(i),this.time.update(),e.app.update&&e.app.update(this,this.time.delta),e.app.render&&e.app.render(this)},s=()=>{if(this.assetManager.isLoadingComplete()){this.assetManager.hasErrors()?e.app.error&&e.app.error(this,this.assetManager.getErrors()):(e.app.initialize&&e.app.initialize(this),i());return}requestAnimationFrame(s)};requestAnimationFrame(s)}clear(t,e,i,s){this.gl.clearColor(t,e,i,s),this.gl.clear(this.gl.COLOR_BUFFER_BIT)}};return Rs(Di)})();
84
+ `;return new ut(t,e,i)}},mt=ut;mt.MVP_MATRIX="u_projTrans",mt.POSITION="a_position",mt.COLOR="a_color",mt.COLOR2="a_color2",mt.TEXCOORDS="a_texCoords",mt.SAMPLER="u_texture";var ki=class{constructor(t,e,i,s){this.attributes=e,this.verticesBuffer=null,this.verticesLength=0,this.dirtyVertices=!1,this.indicesBuffer=null,this.indicesLength=0,this.dirtyIndices=!1,this.elementsPerVertex=0,this.context=t instanceof xt?t:new xt(t),this.elementsPerVertex=0;for(let n=0;n<e.length;n++)this.elementsPerVertex+=e[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(t){this.dirtyVertices=!0,this.verticesLength=t}getVertices(){return this.vertices}maxIndices(){return this.indices.length}numIndices(){return this.indicesLength}setIndicesLength(t){this.dirtyIndices=!0,this.indicesLength=t}getIndices(){return this.indices}getVertexSizeInFloats(){let t=0;for(var e=0;e<this.attributes.length;e++){let i=this.attributes[e];t+=i.numElements}return t}setVertices(t){if(this.dirtyVertices=!0,t.length>this.vertices.length)throw Error("Mesh can't store more than "+this.maxVertices()+" vertices");this.vertices.set(t,0),this.verticesLength=t.length}setIndices(t){if(this.dirtyIndices=!0,t.length>this.indices.length)throw Error("Mesh can't store more than "+this.maxIndices()+" indices");this.indices.set(t,0),this.indicesLength=t.length}draw(t,e){this.drawWithOffset(t,e,0,this.indicesLength>0?this.indicesLength:this.verticesLength/this.elementsPerVertex)}drawWithOffset(t,e,i,s){let n=this.context.gl;(this.dirtyVertices||this.dirtyIndices)&&this.update(),this.bind(t),this.indicesLength>0?n.drawElements(e,s,n.UNSIGNED_SHORT,i*2):n.drawArrays(e,i,s),this.unbind(t)}bind(t){let e=this.context.gl;e.bindBuffer(e.ARRAY_BUFFER,this.verticesBuffer);let i=0;for(let s=0;s<this.attributes.length;s++){let n=this.attributes[s],c=t.getAttributeLocation(n.name);e.enableVertexAttribArray(c),e.vertexAttribPointer(c,n.numElements,e.FLOAT,!1,this.elementsPerVertex*4,i*4),i+=n.numElements}this.indicesLength>0&&e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,this.indicesBuffer)}unbind(t){let e=this.context.gl;for(let i=0;i<this.attributes.length;i++){let s=this.attributes[i],n=t.getAttributeLocation(s.name);e.disableVertexAttribArray(n)}e.bindBuffer(e.ARRAY_BUFFER,null),this.indicesLength>0&&e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,null)}update(){let t=this.context.gl;this.dirtyVertices&&(this.verticesBuffer||(this.verticesBuffer=t.createBuffer()),t.bindBuffer(t.ARRAY_BUFFER,this.verticesBuffer),t.bufferData(t.ARRAY_BUFFER,this.vertices.subarray(0,this.verticesLength),t.DYNAMIC_DRAW),this.dirtyVertices=!1),this.dirtyIndices&&(this.indicesBuffer||(this.indicesBuffer=t.createBuffer()),t.bindBuffer(t.ELEMENT_ARRAY_BUFFER,this.indicesBuffer),t.bufferData(t.ELEMENT_ARRAY_BUFFER,this.indices.subarray(0,this.indicesLength),t.DYNAMIC_DRAW),this.dirtyIndices=!1)}restore(){this.verticesBuffer=null,this.indicesBuffer=null,this.update()}dispose(){this.context.removeRestorable(this);let t=this.context.gl;t.deleteBuffer(this.verticesBuffer),t.deleteBuffer(this.indicesBuffer)}},Qt=class{constructor(t,e,i){this.name=t,this.type=e,this.numElements=i}},Re=class extends Qt{constructor(){super(mt.POSITION,Ht.Float,2)}},xr=class extends Qt{constructor(){super(mt.POSITION,Ht.Float,3)}},Ri=class extends Qt{constructor(t=0){super(mt.TEXCOORDS+(t==0?"":t),Ht.Float,2)}},Fe=class extends Qt{constructor(){super(mt.COLOR,Ht.Float,4)}},gs=class extends Qt{constructor(){super(mt.COLOR2,Ht.Float,4)}},Ht=(t=>(t[t.Float=0]="Float",t))(Ht||{}),$t=class{constructor(t,e=!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=t instanceof xt?t:new xt(t);let s=e?[new Re,new Fe,new Ri,new gs]:[new Re,new Fe,new Ri];this.mesh=new ki(t,s,i,i*3);let n=this.context.gl;this.srcColorBlend=n.SRC_ALPHA,this.srcAlphaBlend=n.ONE,this.dstColorBlend=n.ONE_MINUS_SRC_ALPHA,this.dstAlphaBlend=n.ONE_MINUS_SRC_ALPHA}begin(t){if(this.isDrawing)throw new Error("PolygonBatch is already drawing. Call PolygonBatch.end() before calling PolygonBatch.begin()");this.drawCalls=0,this.shader=t,this.lastTexture=null,this.isDrawing=!0;let e=this.context.gl;e.enable(e.BLEND),e.blendFuncSeparate(this.srcColorBlend,this.dstColorBlend,this.srcAlphaBlend,this.dstAlphaBlend),$t.disableCulling&&(this.cullWasEnabled=e.isEnabled(e.CULL_FACE),this.cullWasEnabled&&e.disable(e.CULL_FACE))}setBlendMode(t,e,i,s){this.srcColorBlend==t&&this.srcAlphaBlend==e&&this.dstColorBlend==i&&this.dstAlphaBlend==s||(this.srcColorBlend=t,this.srcAlphaBlend=e,this.dstColorBlend=i,this.dstAlphaBlend=s,this.isDrawing&&(this.flush(),this.context.gl.blendFuncSeparate(t,i,e,s)))}draw(t,e,i){t!=this.lastTexture?(this.flush(),this.lastTexture=t):(this.verticesLength+e.length>this.mesh.getVertices().length||this.indicesLength+i.length>this.mesh.getIndices().length)&&this.flush();let s=this.mesh.numVertices();this.mesh.getVertices().set(e,this.verticesLength),this.verticesLength+=e.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++,$t.globalDrawCalls++}}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 t=this.context.gl;t.disable(t.BLEND),$t.disableCulling&&this.cullWasEnabled&&t.enable(t.CULL_FACE)}getDrawCalls(){return this.drawCalls}static getAndResetGlobalDrawCalls(){let t=$t.globalDrawCalls;return $t.globalDrawCalls=0,t}dispose(){this.mesh.dispose()}},de=$t;de.disableCulling=!1,de.globalDrawCalls=0;var Fi=class{constructor(t,e=10920){if(this.isDrawing=!1,this.shapeType=bt.Filled,this.color=new O(1,1,1,1),this.shader=null,this.vertexIndex=0,this.tmp=new zt,e>10920)throw new Error("Can't have more than 10920 triangles per batch: "+e);this.context=t instanceof xt?t:new xt(t),this.mesh=new ki(t,[new Re,new Fe],e,0);let i=this.context.gl;this.srcColorBlend=i.SRC_ALPHA,this.srcAlphaBlend=i.ONE,this.dstColorBlend=i.ONE_MINUS_SRC_ALPHA,this.dstAlphaBlend=i.ONE_MINUS_SRC_ALPHA}begin(t){if(this.isDrawing)throw new Error("ShapeRenderer.begin() has already been called");this.shader=t,this.vertexIndex=0,this.isDrawing=!0;let e=this.context.gl;e.enable(e.BLEND),e.blendFuncSeparate(this.srcColorBlend,this.dstColorBlend,this.srcAlphaBlend,this.dstAlphaBlend)}setBlendMode(t,e,i,s){this.srcColorBlend=t,this.srcAlphaBlend=e,this.dstColorBlend=i,this.dstAlphaBlend=s,this.isDrawing&&(this.flush(),this.context.gl.blendFuncSeparate(t,i,e,s))}setColor(t){this.color.setFromColor(t)}setColorWith(t,e,i,s){this.color.set(t,e,i,s)}point(t,e,i){this.check(bt.Point,1),i||(i=this.color),this.vertex(t,e,i)}line(t,e,i,s,n){this.check(bt.Line,2);let c=this.mesh.getVertices(),a=this.vertexIndex;n||(n=this.color),this.vertex(t,e,n),this.vertex(i,s,n)}triangle(t,e,i,s,n,c,a,r,o,l){this.check(t?bt.Filled:bt.Line,3);let h=this.mesh.getVertices(),d=this.vertexIndex;r||(r=this.color),o||(o=this.color),l||(l=this.color),t?(this.vertex(e,i,r),this.vertex(s,n,o),this.vertex(c,a,l)):(this.vertex(e,i,r),this.vertex(s,n,o),this.vertex(s,n,r),this.vertex(c,a,o),this.vertex(c,a,r),this.vertex(e,i,o))}quad(t,e,i,s,n,c,a,r,o,l,h,d,u){this.check(t?bt.Filled:bt.Line,3);let f=this.mesh.getVertices(),m=this.vertexIndex;l||(l=this.color),h||(h=this.color),d||(d=this.color),u||(u=this.color),t?(this.vertex(e,i,l),this.vertex(s,n,h),this.vertex(c,a,d),this.vertex(c,a,d),this.vertex(r,o,u),this.vertex(e,i,l)):(this.vertex(e,i,l),this.vertex(s,n,h),this.vertex(s,n,h),this.vertex(c,a,d),this.vertex(c,a,d),this.vertex(r,o,u),this.vertex(r,o,u),this.vertex(e,i,l))}rect(t,e,i,s,n,c){this.quad(t,e,i,e+s,i,e+s,i+n,e,i+n,c,c,c,c)}rectLine(t,e,i,s,n,c,a){this.check(t?bt.Filled:bt.Line,8),a||(a=this.color);let r=this.tmp.set(n-i,e-s);r.normalize(),c*=.5;let o=r.x*c,l=r.y*c;t?(this.vertex(e+o,i+l,a),this.vertex(e-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(e-o,i-l,a)):(this.vertex(e+o,i+l,a),this.vertex(e-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(e+o,i+l,a),this.vertex(s-o,n-l,a),this.vertex(e-o,i-l,a))}x(t,e,i){this.line(t-i,e-i,t+i,e+i),this.line(t-i,e+i,t+i,e-i)}polygon(t,e,i,s){if(i<3)throw new Error("Polygon must contain at least 3 vertices");this.check(bt.Line,i*2),s||(s=this.color);let n=this.mesh.getVertices(),c=this.vertexIndex;e<<=1,i<<=1;let a=t[e],r=t[e+1],o=e+i;for(let l=e,h=e+i-2;l<h;l+=2){let d=t[l],u=t[l+1],f=0,m=0;l+2>=o?(f=a,m=r):(f=t[l+2],m=t[l+3]),this.vertex(d,u,s),this.vertex(f,m,s)}}circle(t,e,i,s,n,c=0){if(c==0&&(c=Math.max(1,6*X.cbrt(s)|0)),c<=0)throw new Error("segments must be > 0.");n||(n=this.color);let a=2*X.PI/c,r=Math.cos(a),o=Math.sin(a),l=s,h=0;if(t){this.check(bt.Filled,c*3+3),c--;for(let u=0;u<c;u++){this.vertex(e,i,n),this.vertex(e+l,i+h,n);let f=l;l=r*l-o*h,h=o*f+r*h,this.vertex(e+l,i+h,n)}this.vertex(e,i,n),this.vertex(e+l,i+h,n)}else{this.check(bt.Line,c*2+2);for(let u=0;u<c;u++){this.vertex(e+l,i+h,n);let f=l;l=r*l-o*h,h=o*f+r*h,this.vertex(e+l,i+h,n)}this.vertex(e+l,i+h,n)}let d=l;l=s,h=0,this.vertex(e+l,i+h,n)}curve(t,e,i,s,n,c,a,r,o,l){this.check(bt.Line,o*2+2),l||(l=this.color);let h=1/o,d=h*h,u=h*h*h,f=3*h,m=3*d,x=6*d,p=6*u,v=t-i*2+n,g=e-s*2+c,w=(i-n)*3-t+a,b=(s-c)*3-e+r,y=t,A=e,C=(i-t)*f+v*m+w*u,I=(s-e)*f+g*m+b*u,E=v*x+w*p,R=g*x+b*p,L=w*p,k=b*p;for(;o-- >0;)this.vertex(y,A,l),y+=C,A+=I,C+=E,I+=R,E+=L,R+=k,this.vertex(y,A,l);this.vertex(y,A,l),this.vertex(a,r,l)}vertex(t,e,i){let s=this.vertexIndex,n=this.mesh.getVertices();n[s++]=t,n[s++]=e,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 t=this.context.gl;t.disable(t.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(t,e){if(!this.isDrawing)throw new Error("ShapeRenderer.begin() has not been called");if(this.shapeType==t)if(this.mesh.maxVertices()-this.mesh.numVertices()<e)this.flush();else return;else this.flush(),this.shapeType=t}dispose(){this.mesh.dispose()}},bt=(t=>(t[t.Point=0]="Point",t[t.Line=1]="Line",t[t.Filled=4]="Filled",t))(bt||{}),Xi=class{constructor(t){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 ds,this.temp=new Array,this.vertices=B.newFloatArray(2*1024),this.context=t instanceof xt?t:new xt(t)}draw(t,e,i){let s=e.x,n=e.y,c=this.context.gl,a=this.premultipliedAlpha?c.ONE:c.SRC_ALPHA;t.setBlendMode(a,c.ONE,c.ONE_MINUS_SRC_ALPHA,c.ONE_MINUS_SRC_ALPHA);let r=e.bones;if(this.drawBones){t.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 d=h.data.length*h.a+h.worldX,u=h.data.length*h.c+h.worldY;t.rectLine(!0,h.worldX,h.worldY,d,u,this.boneWidth*this.scale)}this.drawSkeletonXY&&t.x(s,n,4*this.scale)}if(this.drawRegionAttachments){t.setColor(this.attachmentLineColor);let o=e.slots;for(let l=0,h=o.length;l<h;l++){let d=o[l],u=d.getAttachment();if(u instanceof at){let f=u,m=this.vertices;f.computeWorldVertices(d,m,0,2),t.line(m[0],m[1],m[2],m[3]),t.line(m[2],m[3],m[4],m[5]),t.line(m[4],m[5],m[6],m[7]),t.line(m[6],m[7],m[0],m[1])}}}if(this.drawMeshHull||this.drawMeshTriangles){let o=e.slots;for(let l=0,h=o.length;l<h;l++){let d=o[l];if(!d.bone.active)continue;let u=d.getAttachment();if(!(u instanceof Vt))continue;let f=u,m=this.vertices;f.computeWorldVertices(d,0,f.worldVerticesLength,m,0,2);let x=f.triangles,p=f.hullLength;if(this.drawMeshTriangles){t.setColor(this.triangleLineColor);for(let v=0,g=x.length;v<g;v+=3){let w=x[v]*2,b=x[v+1]*2,y=x[v+2]*2;t.triangle(!1,m[w],m[w+1],m[b],m[b+1],m[y],m[y+1])}}if(this.drawMeshHull&&p>0){t.setColor(this.attachmentLineColor),p=(p>>1)*2;let v=m[p-2],g=m[p-1];for(let w=0,b=p;w<b;w+=2){let y=m[w],A=m[w+1];t.line(y,A,v,g),v=y,g=A}}}}if(this.drawBoundingBoxes){let o=this.bounds;o.update(e,!0),t.setColor(this.aabbColor),t.rect(!1,o.minX,o.minY,o.getWidth(),o.getHeight());let l=o.polygons,h=o.boundingBoxes;for(let d=0,u=l.length;d<u;d++){let f=l[d];t.setColor(h[d].color),t.polygon(f,0,f.length)}}if(this.drawPaths){let o=e.slots;for(let l=0,h=o.length;l<h;l++){let d=o[l];if(!d.bone.active)continue;let u=d.getAttachment();if(!(u instanceof Gt))continue;let f=u,m=f.worldVerticesLength,x=this.temp=B.setArraySize(this.temp,m,0);f.computeWorldVertices(d,0,m,x,0,2);let p=this.pathColor,v=x[2],g=x[3],w=0,b=0;if(f.closed){t.setColor(p);let y=x[0],A=x[1],C=x[m-2],I=x[m-1];w=x[m-4],b=x[m-3],t.curve(v,g,y,A,C,I,w,b,32),t.setColor(Xi.LIGHT_GRAY),t.line(v,g,y,A),t.line(w,b,C,I)}m-=4;for(let y=4;y<m;y+=6){let A=x[y],C=x[y+1],I=x[y+2],E=x[y+3];w=x[y+4],b=x[y+5],t.setColor(p),t.curve(v,g,A,C,I,E,w,b,32),t.setColor(Xi.LIGHT_GRAY),t.line(v,g,A,C),t.line(w,b,I,E),v=w,g=b}}}if(this.drawBones){t.setColor(this.boneOriginColor);for(let o=0,l=r.length;o<l;o++){let h=r[o];i&&i.indexOf(h.data.name)>-1||t.circle(!0,h.worldX,h.worldY,3*this.scale,this.boneOriginColor,8)}}if(this.drawClipping){let o=e.slots;t.setColor(this.clipColor);for(let l=0,h=o.length;l<h;l++){let d=o[l];if(!d.bone.active)continue;let u=d.getAttachment();if(!(u instanceof le))continue;let f=u,m=f.worldVerticesLength,x=this.temp=B.setArraySize(this.temp,m,0);f.computeWorldVertices(d,0,m,x,0,2);for(let p=0,v=x.length;p<v;p+=2){let g=x[p],w=x[p+1],b=x[(p+2)%x.length],y=x[(p+3)%x.length];t.line(g,w,b,y)}}}}dispose(){}},Xe=Xi;Xe.LIGHT_GRAY=new O(.7529411764705882,.7529411764705882,.7529411764705882,1),Xe.GREEN=new O(0,1,0,1);var wr=class{constructor(t,e,i){this.vertices=t,this.numVertices=e,this.numFloats=i}},xs=class{constructor(t,e=!0){this.premultipliedAlpha=!1,this.tempColor=new O,this.tempColor2=new O,this.vertexSize=2+2+4,this.twoColorTint=!1,this.renderable=new wr([],0,0),this.clipper=new Ee,this.temp=new zt,this.temp2=new zt,this.temp3=new O,this.temp4=new O,this.twoColorTint=e,e&&(this.vertexSize+=4),this.vertices=B.newFloatArray(this.vertexSize*1024)}draw(t,e,i=-1,s=-1,n=null){let c=this.clipper,a=this.premultipliedAlpha,r=this.twoColorTint,o=null,l=this.temp,h=this.temp2,d=this.temp3,u=this.temp4,f=this.renderable,m,x,p=e.drawOrder,v,g=e.color,w=r?12:8,b=!1;i==-1&&(b=!0);for(let y=0,A=p.length;y<A;y++){let C=c.isClipping()?2:w,I=p[y];if(!I.bone.active){c.clipEndWithSlot(I);continue}if(i>=0&&i==I.data.index&&(b=!0),!b){c.clipEndWithSlot(I);continue}s>=0&&s==I.data.index&&(b=!1);let E=I.getAttachment(),R;if(E instanceof at){let L=E;f.vertices=this.vertices,f.numVertices=4,f.numFloats=C<<2,L.computeWorldVertices(I,f.vertices,0,C),x=xs.QUAD_TRIANGLES,m=L.uvs,R=L.region.texture,v=L.color}else if(E instanceof Vt){let L=E;f.vertices=this.vertices,f.numVertices=L.worldVerticesLength>>1,f.numFloats=f.numVertices*C,f.numFloats>f.vertices.length&&(f.vertices=this.vertices=B.newFloatArray(f.numFloats)),L.computeWorldVertices(I,0,L.worldVerticesLength,f.vertices,0,C),x=L.triangles,R=L.region.texture,m=L.uvs,v=L.color}else if(E instanceof le){let L=E;c.clipStart(I,L);continue}else{c.clipEndWithSlot(I);continue}if(R){let L=I.color,k=this.tempColor;k.r=g.r*L.r*v.r,k.g=g.g*L.g*v.g,k.b=g.b*L.b*v.b,k.a=g.a*L.a*v.a,a&&(k.r*=k.a,k.g*=k.a,k.b*=k.a);let F=this.tempColor2;I.darkColor?(a?(F.r=I.darkColor.r*k.a,F.g=I.darkColor.g*k.a,F.b=I.darkColor.b*k.a):F.setFromColor(I.darkColor),F.a=a?1:0):F.set(0,0,0,1);let Y=I.data.blendMode;if(Y!=o&&(o=Y,t.setBlendMode(he.getSourceColorGLBlendMode(o,a),he.getSourceAlphaGLBlendMode(o,a),he.getDestColorGLBlendMode(o),he.getDestAlphaGLBlendMode(o,a))),c.isClipping()){c.clipTriangles(f.vertices,f.numFloats,x,x.length,m,k,F,r);let T=new Float32Array(c.clippedVertices),D=c.clippedTriangles;n&&n(T,T.length,w),t.draw(R,T,D)}else{let T=f.vertices;if(r)for(let P=2,et=0,rt=f.numFloats;P<rt;P+=w,et+=2)T[P]=k.r,T[P+1]=k.g,T[P+2]=k.b,T[P+3]=k.a,T[P+4]=m[et],T[P+5]=m[et+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,et=0,rt=f.numFloats;P<rt;P+=w,et+=2)T[P]=k.r,T[P+1]=k.g,T[P+2]=k.b,T[P+3]=k.a,T[P+4]=m[et],T[P+5]=m[et+1];let D=f.vertices.subarray(0,f.numFloats);n&&n(f.vertices,f.numFloats,w),t.draw(R,D,x)}}c.clipEndWithSlot(I)}c.clipEnd()}},Li=xs;Li.QUAD_TRIANGLES=[0,1,2,2,3,0];var S=[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],Le=[0,1,2,2,3,0],Be=new O(1,1,1,1),ws=class{constructor(t,e,i=!0){this.twoColorTint=!1,this.activeRenderer=null,this.canvas=t,this.context=e instanceof xt?e:new xt(e),this.twoColorTint=i,this.camera=new fs(t.width,t.height),this.batcherShader=i?mt.newTwoColoredTextured(this.context):mt.newColoredTextured(this.context),this.batcher=new de(this.context,i),this.shapesShader=mt.newColored(this.context),this.shapes=new Fi(this.context),this.skeletonRenderer=new Li(this.context,i),this.skeletonDebugRenderer=new Xe(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(t,e=!1,i=-1,s=-1,n=null){this.enableRenderer(this.batcher),this.skeletonRenderer.premultipliedAlpha=e,this.skeletonRenderer.draw(this.batcher,t,i,s,n)}drawSkeletonDebug(t,e=!1,i){this.enableRenderer(this.shapes),this.skeletonDebugRenderer.premultipliedAlpha=e,this.skeletonDebugRenderer.draw(this.shapes,t,i)}drawTexture(t,e,i,s,n,c){this.enableRenderer(this.batcher),c||(c=Be);var a=0;S[a++]=e,S[a++]=i,S[a++]=c.r,S[a++]=c.g,S[a++]=c.b,S[a++]=c.a,S[a++]=0,S[a++]=1,this.twoColorTint&&(S[a++]=0,S[a++]=0,S[a++]=0,S[a++]=0),S[a++]=e+s,S[a++]=i,S[a++]=c.r,S[a++]=c.g,S[a++]=c.b,S[a++]=c.a,S[a++]=1,S[a++]=1,this.twoColorTint&&(S[a++]=0,S[a++]=0,S[a++]=0,S[a++]=0),S[a++]=e+s,S[a++]=i+n,S[a++]=c.r,S[a++]=c.g,S[a++]=c.b,S[a++]=c.a,S[a++]=1,S[a++]=0,this.twoColorTint&&(S[a++]=0,S[a++]=0,S[a++]=0,S[a++]=0),S[a++]=e,S[a++]=i+n,S[a++]=c.r,S[a++]=c.g,S[a++]=c.b,S[a++]=c.a,S[a++]=0,S[a++]=0,this.twoColorTint&&(S[a++]=0,S[a++]=0,S[a++]=0,S[a]=0),this.batcher.draw(t,S,Le)}drawTextureUV(t,e,i,s,n,c,a,r,o,l){this.enableRenderer(this.batcher),l||(l=Be);var h=0;S[h++]=e,S[h++]=i,S[h++]=l.r,S[h++]=l.g,S[h++]=l.b,S[h++]=l.a,S[h++]=c,S[h++]=a,this.twoColorTint&&(S[h++]=0,S[h++]=0,S[h++]=0,S[h++]=0),S[h++]=e+s,S[h++]=i,S[h++]=l.r,S[h++]=l.g,S[h++]=l.b,S[h++]=l.a,S[h++]=r,S[h++]=a,this.twoColorTint&&(S[h++]=0,S[h++]=0,S[h++]=0,S[h++]=0),S[h++]=e+s,S[h++]=i+n,S[h++]=l.r,S[h++]=l.g,S[h++]=l.b,S[h++]=l.a,S[h++]=r,S[h++]=o,this.twoColorTint&&(S[h++]=0,S[h++]=0,S[h++]=0,S[h++]=0),S[h++]=e,S[h++]=i+n,S[h++]=l.r,S[h++]=l.g,S[h++]=l.b,S[h++]=l.a,S[h++]=c,S[h++]=o,this.twoColorTint&&(S[h++]=0,S[h++]=0,S[h++]=0,S[h]=0),this.batcher.draw(t,S,Le)}drawTextureRotated(t,e,i,s,n,c,a,r,o){this.enableRenderer(this.batcher),o||(o=Be);let l=e+c,h=i+a,d=-c,u=-a,f=s-c,m=n-a,x=d,p=u,v=d,g=m,w=f,b=m,y=f,A=u,C=0,I=0,E=0,R=0,L=0,k=0,F=0,Y=0;if(r!=0){let D=X.cosDeg(r),P=X.sinDeg(r);C=D*x-P*p,I=P*x+D*p,F=D*v-P*g,Y=P*v+D*g,L=D*w-P*b,k=P*w+D*b,E=L+(C-F),R=k+(I-Y)}else C=x,I=p,F=v,Y=g,L=w,k=b,E=y,R=A;C+=l,I+=h,E+=l,R+=h,L+=l,k+=h,F+=l,Y+=h;var T=0;S[T++]=C,S[T++]=I,S[T++]=o.r,S[T++]=o.g,S[T++]=o.b,S[T++]=o.a,S[T++]=0,S[T++]=1,this.twoColorTint&&(S[T++]=0,S[T++]=0,S[T++]=0,S[T++]=0),S[T++]=E,S[T++]=R,S[T++]=o.r,S[T++]=o.g,S[T++]=o.b,S[T++]=o.a,S[T++]=1,S[T++]=1,this.twoColorTint&&(S[T++]=0,S[T++]=0,S[T++]=0,S[T++]=0),S[T++]=L,S[T++]=k,S[T++]=o.r,S[T++]=o.g,S[T++]=o.b,S[T++]=o.a,S[T++]=1,S[T++]=0,this.twoColorTint&&(S[T++]=0,S[T++]=0,S[T++]=0,S[T++]=0),S[T++]=F,S[T++]=Y,S[T++]=o.r,S[T++]=o.g,S[T++]=o.b,S[T++]=o.a,S[T++]=0,S[T++]=0,this.twoColorTint&&(S[T++]=0,S[T++]=0,S[T++]=0,S[T]=0),this.batcher.draw(t,S,Le)}drawRegion(t,e,i,s,n,c){this.enableRenderer(this.batcher),c||(c=Be);var a=0;S[a++]=e,S[a++]=i,S[a++]=c.r,S[a++]=c.g,S[a++]=c.b,S[a++]=c.a,S[a++]=t.u,S[a++]=t.v2,this.twoColorTint&&(S[a++]=0,S[a++]=0,S[a++]=0,S[a++]=0),S[a++]=e+s,S[a++]=i,S[a++]=c.r,S[a++]=c.g,S[a++]=c.b,S[a++]=c.a,S[a++]=t.u2,S[a++]=t.v2,this.twoColorTint&&(S[a++]=0,S[a++]=0,S[a++]=0,S[a++]=0),S[a++]=e+s,S[a++]=i+n,S[a++]=c.r,S[a++]=c.g,S[a++]=c.b,S[a++]=c.a,S[a++]=t.u2,S[a++]=t.v,this.twoColorTint&&(S[a++]=0,S[a++]=0,S[a++]=0,S[a++]=0),S[a++]=e,S[a++]=i+n,S[a++]=c.r,S[a++]=c.g,S[a++]=c.b,S[a++]=c.a,S[a++]=t.u,S[a++]=t.v,this.twoColorTint&&(S[a++]=0,S[a++]=0,S[a++]=0,S[a]=0),this.batcher.draw(t.page.texture,S,Le)}line(t,e,i,s,n,c){this.enableRenderer(this.shapes),this.shapes.line(t,e,i,s,n)}triangle(t,e,i,s,n,c,a,r,o,l){this.enableRenderer(this.shapes),this.shapes.triangle(t,e,i,s,n,c,a,r,o,l)}quad(t,e,i,s,n,c,a,r,o,l,h,d,u){this.enableRenderer(this.shapes),this.shapes.quad(t,e,i,s,n,c,a,r,o,l,h,d,u)}rect(t,e,i,s,n,c){this.enableRenderer(this.shapes),this.shapes.rect(t,e,i,s,n,c)}rectLine(t,e,i,s,n,c,a){this.enableRenderer(this.shapes),this.shapes.rectLine(t,e,i,s,n,c,a)}polygon(t,e,i,s){this.enableRenderer(this.shapes),this.shapes.polygon(t,e,i,s)}circle(t,e,i,s,n,c=0){this.enableRenderer(this.shapes),this.shapes.circle(t,e,i,s,n,c)}curve(t,e,i,s,n,c,a,r,o,l){this.enableRenderer(this.shapes),this.shapes.curve(t,e,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(t){let e=this.canvas;var i=window.devicePixelRatio||1,s=Math.round(e.clientWidth*i),n=Math.round(e.clientHeight*i);if((e.width!=s||e.height!=n)&&(e.width=s,e.height=n),this.context.gl.viewport(0,0,e.width,e.height),t===Pe.Expand)this.camera.setViewport(s,n);else if(t===Pe.Fit){let c=e.width,a=e.height,r=this.camera.viewportWidth,o=this.camera.viewportHeight,l=o/r,h=a/c,d=l<h?r/c:o/a;this.camera.setViewport(c*d,a*d)}this.camera.update()}enableRenderer(t){this.activeRenderer!==t&&(this.end(),t instanceof de?(this.batcherShader.bind(),this.batcherShader.setUniform4x4f(mt.MVP_MATRIX,this.camera.projectionView.values),this.batcherShader.setUniformi("u_texture",0),this.batcher.begin(this.batcherShader),this.activeRenderer=this.batcher):t instanceof Fi?(this.shapesShader.bind(),this.shapesShader.setUniform4x4f(mt.MVP_MATRIX,this.camera.projectionView.values),this.shapes.begin(this.shapesShader),this.activeRenderer=this.shapes):this.activeRenderer=this.skeletonDebugRenderer)}},Pe=(t=>(t[t.Stretch=0]="Stretch",t[t.Expand=1]="Expand",t[t.Fit=2]="Fit",t))(Pe||{}),ue,te,bs=0,br=1,Bi=1,ps=165,vs=108,jt=163,pr=class{constructor(t){if(this.logo=null,this.spinner=null,this.angle=0,this.fadeOut=0,this.fadeIn=0,this.timeKeeper=new Ue,this.backgroundColor=new O(.135,.135,.135,1),this.tempColor=new O,this.renderer=t,this.timeKeeper.maxDelta=9,!te){let e=navigator.userAgent.indexOf("Safari")>-1,i=()=>bs++;te=new Image,te.src=yr,e||(te.crossOrigin="anonymous"),te.onload=i,ue=new Image,ue.src=vr,e||(ue.crossOrigin="anonymous"),ue.onload=i}}dispose(){var t,e;(t=this.logo)==null||t.dispose(),(e=this.spinner)==null||e.dispose()}draw(t=!1){if(bs<2||t&&this.fadeOut>Bi)return;this.timeKeeper.update();let e=Math.abs(Math.sin(this.timeKeeper.totalTime+.25));this.angle-=this.timeKeeper.delta*200*(1+1.5*Math.pow(e,5));let i=this.tempColor,s=this.renderer,n=s.canvas,c=s.context.gl;if(s.resize(1),s.camera.position.set(n.width/2,n.height/2,0),s.batcher.setBlendMode(c.ONE,c.ONE,c.ONE_MINUS_SRC_ALPHA,c.ONE_MINUS_SRC_ALPHA),t){if(this.fadeOut+=this.timeKeeper.delta*(this.timeKeeper.totalTime<1?2:1),this.fadeOut>Bi)return;i.setFromColor(this.backgroundColor),e=1-this.fadeOut/Bi,e=1-(e-1)*(e-1),i.a*=e,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)),e=1;e*=Math.min(this.fadeIn/br,1),i.set(e,e,e,e),this.logo||(this.logo=new ce(s.context,te),this.spinner=new ce(s.context,ue)),s.camera.zoom=Math.max(1,jt/n.height),s.begin(),s.drawTexture(this.logo,(n.width-ps)/2,(n.height-vs)/2,ps,vs,i),this.spinner&&s.drawTextureRotated(this.spinner,(n.width-jt)/2,(n.height-jt)/2,jt,jt,jt/2,jt/2,this.angle,i),s.end()}},vr="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAKMAAACjCAYAAADmbK6AAAALKElEQVR42u2de2iW5R/GPzuqcwfnnKfNmafl5tTNHWzqNi3DEMQykcAoJSsySkspjSIk0iD/07Kf4R+FnVBDUTshZGpWUEJaaiWFgZlUFmXmIe3HNXthyebeZ77P9H13ffBG8Y8H7ut7vff93N/7fu4vGGPiFZiez/Qtw9lytJajfzfw9z/j+efPOv7cV8W+lUNY2a8T/ayTCRsWFLJA5rtUO1LLkV5p9LJeJizQiHeqnlOtmVFtdTGrrZkJCxYXsTgaI6r9MY4/UpNItW4mFDaXsTlaM6qVZlBq3UwofFrJp0HMWJ9DvXUzobCznJ1BzFjWlTLrZkJh/TDWBzFjTgo51s2EgnKI0Rrx+FiOWzNzVaym91Syx5qZsGBWb2ZFa0ZN6dbMhAWTcpkUrRmXD2K5NTNhgVbH0Zpxbl/mWjMTFvRIo0e0ZpzcncnWzISKtvmiMWNRJ4qslwmVXRXsas2Ix8ZwzFqZsGFREYtaM+Oaa1ljrUzYkJ9G/ok6TlzKjJWZVFor0y7c1Zu7WjLiqiGsskamXdHopyT4vALmzS9k/t19uHtKHlOSIMn6xAtARjIZ1sFcUSZ0Y4La+G6M18hS2IlCn4a+WoC0JNL0d/dUupdnUj40g6EJ2VEdMnhrOG/p5f/jUXz8SgmvaGU6KpNRNsLVQV0OdXf24s63h/P2gWoOrBjMCr2GJFQnnxnIM3q5P1PPmaYv+4ev4/C6UtbpV2gzXCkgL5W8Bwt48OIc6ul6Tp+s4+SyASxLiI4+PYCn1bHzDZxvaQW6vZzto7MYnQIpNkf7kp5EuozYUroqEjcNKHHd0Tl9mBPN1pk+hFeieGBnBtog7UXjsj9pWg+m6duecw2cay1OC/uxMC47KmP9OIYfoz1YoC20J/rzRG4quTZK2EAyJGs20qwUbYw0aNRmUxtvfUW/uEtNzc1NB1/X8LVyd15hh82F43AvD+VlXcsSJEZa1CQ3ejleAO7oxR3RDP0XN91X4+NXYb8nkv7UNTwV7e0YTdu7I3g33t7tuaEbNwSZpps2fSyvs4M2Tjhot+jb0Xzbltj8r5j/xVt/6Z1Ob93U1ZYO691EhhzchcHeXosVjcNZysyezLw4xRZt05R+fTeuj8vOj+zKyG0j2aZcVVs6v+QalnjrMFZASQYl2nBoSyz06e3j/Xk8rgWYmMvEICu2pm1HOTuc7okV8FgRj0XukwzanhvCc/F+72TjoQjdObN1OFuDLmh0xP+WHtxiI10ukJlCprb4guiv1fP+avZrS1C7NAkliHZjDtZwMMgqbukAltpMlwuMy2FcEBPqvfLLar5Uqi0hBdEwryy+Mv5n6zkbjTBa+dlMlwvUZFETZKGiFM7tvbhdJ3gSVRO0wzIjnxmvl/J6a6JsGMYGrahtpssFeqbR841S3mhN80OjOaSDEdqd6SjaMKgzgzRK7q1ib3PT9sYyNo7JZoyNFNvRcVMZmy7WOvIuryv/Zvdmdt90+nY0bRp3AvROohFwdwW7dTG7RFlbwlqdrbOBYg005NAQmZU0HWt1rXMBH1Xw0dQ8pmqzoaPmdhun7bHZjNVe9qP9eFQfO1VkUmHjhAVUZ1GtnKFSbjrkrPfy4i4UW5t/6ZxM54J0CqxFe81KpGsQyE4h23oYY4wxxhhjjDHGGGOMMcYYY4wxxhhjjDHGGGOMMcYYY4wxxhhjjDHGGGOMMcYYY4wxxhhjjLna+bdOy+IiFquIpGq16Pb79cNYv3IIK/X/ugx+Ui6TVKvYVU9Nc8gX8od8Ir/IN/KPfCQ/yVfyl/6/pfJvLChkQdD6wyqntquCXYuKWJSfRr6D0dEAxV3xlw/khyD+kd/ku/88cHo+09tS3LBpO1HHCVUqcIA6CqB4K+6X6x35L/JM2loXurlWmUmlA5XogOIcK8/If5HncrSWo7F6cKIWPjT/RXGOlWfkv8hzaWsN4uaaysE6WIkOKM6x8oz8F3kusXqo2vxC5jtYiQ4ozrH0TeS5qIZcrB7qkrwdA8U5Vp6R/yLPZV8V+2L14Cl5THGwEh1QnGPlGfkv8lyUlIzFQ1cNYVVHrcjZ0VCcFe9Y+Eb+izy3ceclUl43aFN52DXXssYpnY6a4qFS8ZcP2uIf+e7inRh6pdFrdTGrm8uiHx/L8T2V7NGWzvJBLJ/bl7mTuzO5qBNFDoiJID/IF/KHfCK/yDfyT3O7d/KbfNfS80hNIrU0g9L6HOq1x5iTQo6FNpeLfCQ/yVfyl3xmXYwxxhhjjDHGGGOMMcYYY4wxxhhjjDHGGGOMMcYYY4wxxhhjjDHGGGOMMcYYY4wxxhhjjDHNk9z4JwJ0SqKTdQkbyEwhU393T6V7zzR6pieR3tE1ITeVXImhe6BXDGZFdRbVeank2TBhcaEMr0rwbixj49IBLL2/L/ffmMuNHfqO9tFZjJYBd1ewO3Lx+IcVfKhqna5nHZYR6XFPH+5R3eeI5t9fx/fvjeC9Jdew5OKZKqFR/RDVKL6vL/f9PJafmyvHsL+a/ff24V6NmjZQbGchVbY6UM2BluqHv1rCqzVZ1KQlkZboepCdQvacPsz5bjTfXao+yMEaDt7Wk9tSIMVGig3TejCtJSM2bSpkPjWPqd1S6Zao+lORSYWmgkOjORRNwZqd5ezMSiHLRooNr5XwWjS6/1XHX9vL2T67N7M1iyXa9JCrYjVrS1gbpJyw6hBfsmiNCYT0P9/A+Wj1/6qGr5YNYFlJBiWJogEzezLz/ZG8/9s4fgtSyuvNYbyp1IONFBtu7sHNv4/j9yAxUHWrdaWsG9+N8XHd+YxkMpSy+aySz841cC5oXbmHCnnI74yxAgZ3YbDeB4PEQCOpBpFNZWwa2ZWRcdnxLsl00crtRB0n2lLg8JNRfDKoM4NsolgBSmw/UMADba1+qpmqfyf6x1u/0a/og3I+aEunP6/i86osqmygcGarF4p54dex/Bo0LqfqOfVwIQ/HW5/RSkwV1oN2WLlHTc82TljAwM4M1O5LWwYKZTjibYXNS0N5KcjKTe10PadfLObFuJwK4ozp+UzXDBTUjL+M5ZcBnRkQV53dMIwNQTu6bSTbVEzbi5awuVByd2E/FgaN0Tc1fKOzBHHV2aAdVSdv6s5NNkp7cSH/++xAng2yyHx+CM/H21YhfdPp+0U1X0TbSZnXx8faG9Aop0MS0cToh1p+iLcpOkLj9t/JOk5eqoPHxnDsyf486an5yqCDK7XZ1O4oZ4dWyy3FSXHUAYq47uyYbMZoGmhpG3DlEFb6uNiVBhpyaHhnBO8oJmfqOROJjzIiP43hJ8UxITqqX56S2Hur2KsOnq3nrE6PPNKPRwrSKbAZrjTQNZmuE7oxYXMZmxWbw9dxWFu4W4ezVedOE6qzI7oyYkY+M7TPeWsPbk2UX1qioSN+E3OZqOR2cReKE+qQRFN0Pi7y73g/UawU1KzezJpXwLz5hczX1ueUPKYkNb6GJQZ+j7/aAfRZREsv+quGsMoamXZBW2Gt5eU0alorEzYsKmJRa/m4NdeyxlqZsCGa84DKnVorEzboC7podis69DfIJmwufHMc7famvvmxZiYsKOtKWbRm1OcW1syEBboSJFozLh/EcmtmwgIluaM14/phrLdmJixYXMTiaM24p5I91syEBTphFOR7Y2tmwgJNvUFOr+tov3UzoaAv44KYUatv62ZCoemdhtG0+hzqrZsJBR08DWLG0gxKrZu50qvpxos3U5NItW4mFPp1ot+lPlpq2lYXs9qamVBZUMiC1ox4pJYjvlfStAu6GmTLcLboMtPIV4/6im5fFfuUi9QIap2MiWP+D96R1vPmsD/fAAAAAElFTkSuQmCC",yr="data:image/png;base64,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",Ar=class{constructor(t,e){this.time=new Ue,e.pathPrefix||(e.pathPrefix=""),e.app||(e.app={loadAssets:()=>{},initialize:()=>{},update:()=>{},render:()=>{},error:()=>{}}),e.webglConfig||(e.webglConfig={alpha:!0}),this.htmlCanvas=t,this.context=new xt(t,e.webglConfig),this.renderer=new ws(t,this.context),this.gl=this.context.gl,this.assetManager=new us(this.context,e.pathPrefix),this.input=new Ei(t),e.app.loadAssets&&e.app.loadAssets(this);let i=()=>{requestAnimationFrame(i),this.time.update(),e.app.update&&e.app.update(this,this.time.delta),e.app.render&&e.app.render(this)},s=()=>{if(this.assetManager.isLoadingComplete()){this.assetManager.hasErrors()?e.app.error&&e.app.error(this,this.assetManager.getErrors()):(e.app.initialize&&e.app.initialize(this),i());return}requestAnimationFrame(s)};requestAnimationFrame(s)}clear(t,e,i,s){this.gl.clearColor(t,e,i,s),this.gl.clear(this.gl.COLOR_BUFFER_BIT)}};return Rs(Oi)})();