@esotericsoftware/spine-canvaskit 4.2.81 → 4.2.83

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,2 +1,2 @@
1
- "use strict";var Ds=Object.defineProperty,Os=(e,t,s)=>t in e?Ds(e,t,{enumerable:!0,configurable:!0,writable:!0,value:s}):e[t]=s,B=(e,t,s)=>(Os(e,typeof t!="symbol"?t+"":t,s),s),qs=class{array=new Array;add(e){let t=this.contains(e);return this.array[e|0]=e|0,!t}contains(e){return this.array[e|0]!=null}remove(e){this.array[e|0]=void 0}clear(){this.array.length=0}},st=class{entries={};size=0;add(e){let t=this.entries[e];return this.entries[e]=!0,t?!1:(this.size++,!0)}addAll(e){let t=this.size;for(var s=0,r=e.length;s<r;s++)this.add(e[s]);return t!=this.size}contains(e){return this.entries[e]}clear(){this.entries={},this.size=0}},pe=class{constructor(e=0,t=0,s=0,r=0){this.r=e,this.g=t,this.b=s,this.a=r}set(e,t,s,r){return this.r=e,this.g=t,this.b=s,this.a=r,this.clamp()}setFromColor(e){return this.r=e.r,this.g=e.g,this.b=e.b,this.a=e.a,this}setFromString(e){return e=e.charAt(0)=="#"?e.substr(1):e,this.r=parseInt(e.substr(0,2),16)/255,this.g=parseInt(e.substr(2,2),16)/255,this.b=parseInt(e.substr(4,2),16)/255,this.a=e.length!=8?1:parseInt(e.substr(6,2),16)/255,this}add(e,t,s,r){return this.r+=e,this.g+=t,this.b+=s,this.a+=r,this.clamp()}clamp(){return this.r<0?this.r=0:this.r>1&&(this.r=1),this.g<0?this.g=0:this.g>1&&(this.g=1),this.b<0?this.b=0:this.b>1&&(this.b=1),this.a<0?this.a=0:this.a>1&&(this.a=1),this}static rgba8888ToColor(e,t){e.r=((t&4278190080)>>>24)/255,e.g=((t&16711680)>>>16)/255,e.b=((t&65280)>>>8)/255,e.a=(t&255)/255}static rgb888ToColor(e,t){e.r=((t&16711680)>>>16)/255,e.g=((t&65280)>>>8)/255,e.b=(t&255)/255}toRgb888(){const e=t=>("0"+(t*255).toString(16)).slice(-2);return Number("0x"+e(this.r)+e(this.g)+e(this.b))}static fromString(e){return new pe().setFromString(e)}},D=pe;B(D,"WHITE",new pe(1,1,1,1)),B(D,"RED",new pe(1,0,0,1)),B(D,"GREEN",new pe(0,1,0,1)),B(D,"BLUE",new pe(0,0,1,1)),B(D,"MAGENTA",new pe(1,0,1,1));var ae=class{static clamp(e,t,s){return e<t?t:e>s?s:e}static cosDeg(e){return Math.cos(e*ae.degRad)}static sinDeg(e){return Math.sin(e*ae.degRad)}static atan2Deg(e,t){return Math.atan2(e,t)*ae.degRad}static signum(e){return e>0?1:e<0?-1:0}static toInt(e){return e>0?Math.floor(e):Math.ceil(e)}static cbrt(e){let t=Math.pow(Math.abs(e),.3333333333333333);return e<0?-t:t}static randomTriangular(e,t){return ae.randomTriangularWith(e,t,(e+t)*.5)}static randomTriangularWith(e,t,s){let r=Math.random(),n=t-e;return r<=(s-e)/n?e+Math.sqrt(r*n*(s-e)):t-Math.sqrt((1-r)*n*(t-s))}static isPowerOfTwo(e){return e&&(e&e-1)===0}},F=ae;B(F,"PI",3.1415927),B(F,"PI2",ae.PI*2),B(F,"invPI2",1/ae.PI2),B(F,"radiansToDegrees",180/ae.PI),B(F,"radDeg",ae.radiansToDegrees),B(F,"degreesToRadians",ae.PI/180),B(F,"degRad",ae.degreesToRadians);var ns=class{apply(e,t,s){return e+(t-e)*this.applyInternal(s)}},as=class extends ns{power=2;constructor(e){super(),this.power=e}applyInternal(e){return e<=.5?Math.pow(e*2,this.power)/2:Math.pow((e-1)*2,this.power)/(this.power%2==0?-2:2)+1}},_s=class extends as{constructor(e){super(e)}applyInternal(e){return Math.pow(e-1,this.power)*(this.power%2==0?-1:1)+1}},Se=class{static arrayCopy(e,t,s,r,n){for(let h=t,o=r;h<t+n;h++,o++)s[o]=e[h]}static arrayFill(e,t,s,r){for(let n=t;n<s;n++)e[n]=r}static setArraySize(e,t,s=0){let r=e.length;if(r==t)return e;if(e.length=t,r<t)for(let n=r;n<t;n++)e[n]=s;return e}static ensureArrayCapacity(e,t,s=0){return e.length>=t?e:Se.setArraySize(e,t,s)}static newArray(e,t){let s=new Array(e);for(let r=0;r<e;r++)s[r]=t;return s}static newFloatArray(e){if(Se.SUPPORTS_TYPED_ARRAYS)return new Float32Array(e);{let t=new Array(e);for(let s=0;s<t.length;s++)t[s]=0;return t}}static newShortArray(e){if(Se.SUPPORTS_TYPED_ARRAYS)return new Int16Array(e);{let t=new Array(e);for(let s=0;s<t.length;s++)t[s]=0;return t}}static toFloatArray(e){return Se.SUPPORTS_TYPED_ARRAYS?new Float32Array(e):e}static toSinglePrecision(e){return Se.SUPPORTS_TYPED_ARRAYS?Math.fround(e):e}static webkit602BugfixHelper(e,t){}static contains(e,t,s=!0){for(var r=0;r<e.length;r++)if(e[r]==t)return!0;return!1}static enumValue(e,t){return e[t[0].toUpperCase()+t.slice(1)]}},R=Se;B(R,"SUPPORTS_TYPED_ARRAYS",typeof Float32Array<"u");var Ws=class{static logBones(e){for(let t=0;t<e.bones.length;t++){let s=e.bones[t];console.log(s.data.name+", "+s.a+", "+s.b+", "+s.c+", "+s.d+", "+s.worldX+", "+s.worldY)}}},Te=class{items=new Array;instantiator;constructor(e){this.instantiator=e}obtain(){return this.items.length>0?this.items.pop():this.instantiator()}free(e){e.reset&&e.reset(),this.items.push(e)}freeAll(e){for(let t=0;t<e.length;t++)this.free(e[t])}clear(){this.items.length=0}},Ne=class{constructor(e=0,t=0){this.x=e,this.y=t}set(e,t){return this.x=e,this.y=t,this}length(){let e=this.x,t=this.y;return Math.sqrt(e*e+t*t)}normalize(){let e=this.length();return e!=0&&(this.x/=e,this.y/=e),this}},Us=class{maxDelta=.064;framesPerSecond=0;delta=0;totalTime=0;lastTime=Date.now()/1e3;frameCount=0;frameTime=0;update(){let e=Date.now()/1e3;this.delta=e-this.lastTime,this.frameTime+=this.delta,this.totalTime+=this.delta,this.delta>this.maxDelta&&(this.delta=this.maxDelta),this.lastTime=e,this.frameCount++,this.frameTime>1&&(this.framesPerSecond=this.frameCount/this.frameTime,this.frameTime=0,this.frameCount=0)}},zs=class{values;addedValues=0;lastValue=0;mean=0;dirty=!0;constructor(e=32){this.values=new Array(e)}hasEnoughData(){return this.addedValues>=this.values.length}addValue(e){this.addedValues<this.values.length&&this.addedValues++,this.values[this.lastValue++]=e,this.lastValue>this.values.length-1&&(this.lastValue=0),this.dirty=!0}getMean(){if(this.hasEnoughData()){if(this.dirty){let e=0;for(let t=0;t<this.values.length;t++)e+=this.values[t];this.mean=e/this.values.length,this.dirty=!1}return this.mean}return 0}},it=class{name;constructor(e){if(!e)throw new Error("name cannot be null.");this.name=e}},ls=class extends it{id=ls.nextID++;bones=null;vertices=[];worldVerticesLength=0;timelineAttachment=this;constructor(e){super(e)}computeWorldVertices(e,t,s,r,n,h){s=n+(s>>1)*h;let o=e.bone.skeleton,i=e.deform,l=this.vertices,a=this.bones;if(!a){i.length>0&&(l=i);let f=e.bone,m=f.worldX,x=f.worldY,b=f.a,w=f.b,g=f.c,p=f.d;for(let v=t,y=n;y<s;v+=2,y+=h){let S=l[v],A=l[v+1];r[y]=S*b+A*w+m,r[y+1]=S*g+A*p+x}return}let c=0,u=0;for(let f=0;f<t;f+=2){let m=a[c];c+=m+1,u+=m}let d=o.bones;if(i.length==0)for(let f=n,m=u*3;f<s;f+=h){let x=0,b=0,w=a[c++];for(w+=c;c<w;c++,m+=3){let g=d[a[c]],p=l[m],v=l[m+1],y=l[m+2];x+=(p*g.a+v*g.b+g.worldX)*y,b+=(p*g.c+v*g.d+g.worldY)*y}r[f]=x,r[f+1]=b}else{let f=i;for(let m=n,x=u*3,b=u<<1;m<s;m+=h){let w=0,g=0,p=a[c++];for(p+=c;c<p;c++,x+=3,b+=2){let v=d[a[c]],y=l[x]+f[b],S=l[x+1]+f[b+1],A=l[x+2];w+=(y*v.a+S*v.b+v.worldX)*A,g+=(y*v.c+S*v.d+v.worldY)*A}r[m]=w,r[m+1]=g}}}copyTo(e){this.bones?(e.bones=new Array(this.bones.length),R.arrayCopy(this.bones,0,e.bones,0,this.bones.length)):e.bones=null,this.vertices&&(e.vertices=R.newFloatArray(this.vertices.length),R.arrayCopy(this.vertices,0,e.vertices,0,this.vertices.length)),e.worldVerticesLength=this.worldVerticesLength,e.timelineAttachment=this.timelineAttachment}},le=ls;B(le,"nextID",0);var De=class{id=De.nextID();regions;start=0;digits=0;setupIndex=0;constructor(e){this.regions=new Array(e)}copy(){let e=new De(this.regions.length);return R.arrayCopy(this.regions,0,e.regions,0,this.regions.length),e.start=this.start,e.digits=this.digits,e.setupIndex=this.setupIndex,e}apply(e,t){let s=e.sequenceIndex;s==-1&&(s=this.setupIndex),s>=this.regions.length&&(s=this.regions.length-1);let r=this.regions[s];t.region!=r&&(t.region=r,t.updateRegion())}getPath(e,t){let s=e,r=(this.start+t).toString();for(let n=this.digits-r.length;n>0;n--)s+="0";return s+=r,s}static nextID(){return De._nextID++}},rt=De;B(rt,"_nextID",0);var os=(e=>(e[e.hold=0]="hold",e[e.once=1]="once",e[e.loop=2]="loop",e[e.pingpong=3]="pingpong",e[e.onceReverse=4]="onceReverse",e[e.loopReverse=5]="loopReverse",e[e.pingpongReverse=6]="pingpongReverse",e))(os||{}),hs=[0,1,2,3,4,5,6],Oe=class{name;timelines=[];timelineIds=new st;duration;constructor(e,t,s){if(!e)throw new Error("name cannot be null.");this.name=e,this.setTimelines(t),this.duration=s}setTimelines(e){if(!e)throw new Error("timelines cannot be null.");this.timelines=e,this.timelineIds.clear();for(var t=0;t<e.length;t++)this.timelineIds.addAll(e[t].getPropertyIds())}hasTimeline(e){for(let t=0;t<e.length;t++)if(this.timelineIds.contains(e[t]))return!0;return!1}apply(e,t,s,r,n,h,o,i){if(!e)throw new Error("skeleton cannot be null.");r&&this.duration!=0&&(s%=this.duration,t>0&&(t%=this.duration));let l=this.timelines;for(let a=0,c=l.length;a<c;a++)l[a].apply(e,t,s,n,h,o,i)}},cs=(e=>(e[e.setup=0]="setup",e[e.first=1]="first",e[e.replace=2]="replace",e[e.add=3]="add",e))(cs||{}),ds=(e=>(e[e.mixIn=0]="mixIn",e[e.mixOut=1]="mixOut",e))(ds||{}),O={rotate:0,x:1,y:2,scaleX:3,scaleY:4,shearX:5,shearY:6,inherit:7,rgb:8,alpha:9,rgb2:10,attachment:11,deform:12,event:13,drawOrder:14,ikConstraint:15,transformConstraint:16,pathConstraintPosition:17,pathConstraintSpacing:18,pathConstraintMix:19,physicsConstraintInertia:20,physicsConstraintStrength:21,physicsConstraintDamping:22,physicsConstraintMass:23,physicsConstraintWind:24,physicsConstraintGravity:25,physicsConstraintMix:26,physicsConstraintReset:27,sequence:28},K=class{propertyIds;frames;constructor(e,t){this.propertyIds=t,this.frames=R.newFloatArray(e*this.getFrameEntries())}getPropertyIds(){return this.propertyIds}getFrameEntries(){return 1}getFrameCount(){return this.frames.length/this.getFrameEntries()}getDuration(){return this.frames[this.frames.length-this.getFrameEntries()]}static search1(e,t){let s=e.length;for(let r=1;r<s;r++)if(e[r]>t)return r-1;return s-1}static search(e,t,s){let r=e.length;for(let n=s;n<r;n+=s)if(e[n]>t)return n-s;return r-s}},oe=class extends K{curves;constructor(e,t,s){super(e,s),this.curves=R.newFloatArray(e+t*18),this.curves[e-1]=1}setLinear(e){this.curves[e]=0}setStepped(e){this.curves[e]=1}shrink(e){let t=this.getFrameCount()+e*18;if(this.curves.length>t){let s=R.newFloatArray(t);R.arrayCopy(this.curves,0,s,0,t),this.curves=s}}setBezier(e,t,s,r,n,h,o,i,l,a,c){let u=this.curves,d=this.getFrameCount()+e*18;s==0&&(u[t]=2+d);let f=(r-h*2+i)*.03,m=(n-o*2+l)*.03,x=((h-i)*3-r+a)*.006,b=((o-l)*3-n+c)*.006,w=f*2+x,g=m*2+b,p=(h-r)*.3+f+x*.16666667,v=(o-n)*.3+m+b*.16666667,y=r+p,S=n+v;for(let A=d+18;d<A;d+=2)u[d]=y,u[d+1]=S,p+=w,v+=g,w+=x,g+=b,y+=p,S+=v}getBezierValue(e,t,s,r){let n=this.curves;if(n[r]>e){let l=this.frames[t],a=this.frames[t+s];return a+(e-l)/(n[r]-l)*(n[r+1]-a)}let h=r+18;for(r+=2;r<h;r+=2)if(n[r]>=e){let l=n[r-2],a=n[r-1];return a+(e-l)/(n[r]-l)*(n[r+1]-a)}t+=this.getFrameEntries();let o=n[h-2],i=n[h-1];return i+(e-o)/(this.frames[t]-o)*(this.frames[t+s]-i)}},ne=class extends oe{constructor(e,t,s){super(e,t,[s])}getFrameEntries(){return 2}setFrame(e,t,s){e<<=1,this.frames[e]=t,this.frames[e+1]=s}getCurveValue(e){let t=this.frames,s=t.length-2;for(let n=2;n<=s;n+=2)if(t[n]>e){s=n-2;break}let r=this.curves[s>>1];switch(r){case 0:let n=t[s],h=t[s+1];return h+(e-n)/(t[s+2]-n)*(t[s+2+1]-h);case 1:return t[s+1]}return this.getBezierValue(e,s,1,r-2)}getRelativeValue(e,t,s,r,n){if(e<this.frames[0]){switch(s){case 0:return n;case 1:return r+(n-r)*t}return r}let h=this.getCurveValue(e);switch(s){case 0:return n+h*t;case 1:case 2:h+=n-r}return r+h*t}getAbsoluteValue(e,t,s,r,n){if(e<this.frames[0]){switch(s){case 0:return n;case 1:return r+(n-r)*t}return r}let h=this.getCurveValue(e);return s==0?n+(h-n)*t:r+(h-r)*t}getAbsoluteValue2(e,t,s,r,n,h){if(e<this.frames[0]){switch(s){case 0:return n;case 1:return r+(n-r)*t}return r}return s==0?n+(h-n)*t:r+(h-r)*t}getScaleValue(e,t,s,r,n,h){const o=this.frames;if(e<o[0]){switch(s){case 0:return h;case 1:return n+(h-n)*t}return n}let i=this.getCurveValue(e)*h;if(t==1)return s==3?n+i-h:i;if(r==1)switch(s){case 0:return h+(Math.abs(i)*F.signum(h)-h)*t;case 1:case 2:return n+(Math.abs(i)*F.signum(n)-n)*t}else{let l=0;switch(s){case 0:return l=Math.abs(h)*F.signum(i),l+(i-l)*t;case 1:case 2:return l=Math.abs(n)*F.signum(i),l+(i-l)*t}}return n+(i-h)*t}},qe=class extends oe{constructor(e,t,s,r){super(e,t,[s,r])}getFrameEntries(){return 3}setFrame(e,t,s,r){e*=3,this.frames[e]=t,this.frames[e+1]=s,this.frames[e+2]=r}},Xe=class extends ne{boneIndex=0;constructor(e,t,s){super(e,t,O.rotate+"|"+s),this.boneIndex=s}apply(e,t,s,r,n,h,o){let i=e.bones[this.boneIndex];i.active&&(i.rotation=this.getRelativeValue(s,n,h,i.rotation,i.data.rotation))}},nt=class extends qe{boneIndex=0;constructor(e,t,s){super(e,t,O.x+"|"+s,O.y+"|"+s),this.boneIndex=s}apply(e,t,s,r,n,h,o){let i=e.bones[this.boneIndex];if(!i.active)return;let l=this.frames;if(s<l[0]){switch(h){case 0:i.x=i.data.x,i.y=i.data.y;return;case 1:i.x+=(i.data.x-i.x)*n,i.y+=(i.data.y-i.y)*n}return}let a=0,c=0,u=K.search(l,s,3),d=this.curves[u/3];switch(d){case 0:let f=l[u];a=l[u+1],c=l[u+2];let m=(s-f)/(l[u+3]-f);a+=(l[u+3+1]-a)*m,c+=(l[u+3+2]-c)*m;break;case 1:a=l[u+1],c=l[u+2];break;default:a=this.getBezierValue(s,u,1,d-2),c=this.getBezierValue(s,u,2,d+18-2)}switch(h){case 0:i.x=i.data.x+a*n,i.y=i.data.y+c*n;break;case 1:case 2:i.x+=(i.data.x+a-i.x)*n,i.y+=(i.data.y+c-i.y)*n;break;case 3:i.x+=a*n,i.y+=c*n}}},at=class extends ne{boneIndex=0;constructor(e,t,s){super(e,t,O.x+"|"+s),this.boneIndex=s}apply(e,t,s,r,n,h,o){let i=e.bones[this.boneIndex];i.active&&(i.x=this.getRelativeValue(s,n,h,i.x,i.data.x))}},lt=class extends ne{boneIndex=0;constructor(e,t,s){super(e,t,O.y+"|"+s),this.boneIndex=s}apply(e,t,s,r,n,h,o){let i=e.bones[this.boneIndex];i.active&&(i.y=this.getRelativeValue(s,n,h,i.y,i.data.y))}},ot=class extends qe{boneIndex=0;constructor(e,t,s){super(e,t,O.scaleX+"|"+s,O.scaleY+"|"+s),this.boneIndex=s}apply(e,t,s,r,n,h,o){let i=e.bones[this.boneIndex];if(!i.active)return;let l=this.frames;if(s<l[0]){switch(h){case 0:i.scaleX=i.data.scaleX,i.scaleY=i.data.scaleY;return;case 1:i.scaleX+=(i.data.scaleX-i.scaleX)*n,i.scaleY+=(i.data.scaleY-i.scaleY)*n}return}let a,c,u=K.search(l,s,3),d=this.curves[u/3];switch(d){case 0:let f=l[u];a=l[u+1],c=l[u+2];let m=(s-f)/(l[u+3]-f);a+=(l[u+3+1]-a)*m,c+=(l[u+3+2]-c)*m;break;case 1:a=l[u+1],c=l[u+2];break;default:a=this.getBezierValue(s,u,1,d-2),c=this.getBezierValue(s,u,2,d+18-2)}if(a*=i.data.scaleX,c*=i.data.scaleY,n==1)h==3?(i.scaleX+=a-i.data.scaleX,i.scaleY+=c-i.data.scaleY):(i.scaleX=a,i.scaleY=c);else{let f=0,m=0;if(o==1)switch(h){case 0:f=i.data.scaleX,m=i.data.scaleY,i.scaleX=f+(Math.abs(a)*F.signum(f)-f)*n,i.scaleY=m+(Math.abs(c)*F.signum(m)-m)*n;break;case 1:case 2:f=i.scaleX,m=i.scaleY,i.scaleX=f+(Math.abs(a)*F.signum(f)-f)*n,i.scaleY=m+(Math.abs(c)*F.signum(m)-m)*n;break;case 3:i.scaleX+=(a-i.data.scaleX)*n,i.scaleY+=(c-i.data.scaleY)*n}else switch(h){case 0:f=Math.abs(i.data.scaleX)*F.signum(a),m=Math.abs(i.data.scaleY)*F.signum(c),i.scaleX=f+(a-f)*n,i.scaleY=m+(c-m)*n;break;case 1:case 2:f=Math.abs(i.scaleX)*F.signum(a),m=Math.abs(i.scaleY)*F.signum(c),i.scaleX=f+(a-f)*n,i.scaleY=m+(c-m)*n;break;case 3:i.scaleX+=(a-i.data.scaleX)*n,i.scaleY+=(c-i.data.scaleY)*n}}}},ht=class extends ne{boneIndex=0;constructor(e,t,s){super(e,t,O.scaleX+"|"+s),this.boneIndex=s}apply(e,t,s,r,n,h,o){let i=e.bones[this.boneIndex];i.active&&(i.scaleX=this.getScaleValue(s,n,h,o,i.scaleX,i.data.scaleX))}},ct=class extends ne{boneIndex=0;constructor(e,t,s){super(e,t,O.scaleY+"|"+s),this.boneIndex=s}apply(e,t,s,r,n,h,o){let i=e.bones[this.boneIndex];i.active&&(i.scaleY=this.getScaleValue(s,n,h,o,i.scaleY,i.data.scaleY))}},dt=class extends qe{boneIndex=0;constructor(e,t,s){super(e,t,O.shearX+"|"+s,O.shearY+"|"+s),this.boneIndex=s}apply(e,t,s,r,n,h,o){let i=e.bones[this.boneIndex];if(!i.active)return;let l=this.frames;if(s<l[0]){switch(h){case 0:i.shearX=i.data.shearX,i.shearY=i.data.shearY;return;case 1:i.shearX+=(i.data.shearX-i.shearX)*n,i.shearY+=(i.data.shearY-i.shearY)*n}return}let a=0,c=0,u=K.search(l,s,3),d=this.curves[u/3];switch(d){case 0:let f=l[u];a=l[u+1],c=l[u+2];let m=(s-f)/(l[u+3]-f);a+=(l[u+3+1]-a)*m,c+=(l[u+3+2]-c)*m;break;case 1:a=l[u+1],c=l[u+2];break;default:a=this.getBezierValue(s,u,1,d-2),c=this.getBezierValue(s,u,2,d+18-2)}switch(h){case 0:i.shearX=i.data.shearX+a*n,i.shearY=i.data.shearY+c*n;break;case 1:case 2:i.shearX+=(i.data.shearX+a-i.shearX)*n,i.shearY+=(i.data.shearY+c-i.shearY)*n;break;case 3:i.shearX+=a*n,i.shearY+=c*n}}},ft=class extends ne{boneIndex=0;constructor(e,t,s){super(e,t,O.shearX+"|"+s),this.boneIndex=s}apply(e,t,s,r,n,h,o){let i=e.bones[this.boneIndex];i.active&&(i.shearX=this.getRelativeValue(s,n,h,i.shearX,i.data.shearX))}},ut=class extends ne{boneIndex=0;constructor(e,t,s){super(e,t,O.shearY+"|"+s),this.boneIndex=s}apply(e,t,s,r,n,h,o){let i=e.bones[this.boneIndex];i.active&&(i.shearY=this.getRelativeValue(s,n,h,i.shearY,i.data.shearY))}},mt=class extends K{boneIndex=0;constructor(e,t){super(e,[O.inherit+"|"+t]),this.boneIndex=t}getFrameEntries(){return 2}setFrame(e,t,s){e*=2,this.frames[e]=t,this.frames[e+1]=s}apply(e,t,s,r,n,h,o){let i=e.bones[this.boneIndex];if(!i.active)return;if(o==1){h==0&&(i.inherit=i.data.inherit);return}let l=this.frames;if(s<l[0]){(h==0||h==1)&&(i.inherit=i.data.inherit);return}i.inherit=this.frames[K.search(l,s,2)+1]}},gt=class extends oe{slotIndex=0;constructor(e,t,s){super(e,t,[O.rgb+"|"+s,O.alpha+"|"+s]),this.slotIndex=s}getFrameEntries(){return 5}setFrame(e,t,s,r,n,h){e*=5,this.frames[e]=t,this.frames[e+1]=s,this.frames[e+2]=r,this.frames[e+3]=n,this.frames[e+4]=h}apply(e,t,s,r,n,h,o){let i=e.slots[this.slotIndex];if(!i.bone.active)return;let l=this.frames,a=i.color;if(s<l[0]){let b=i.data.color;switch(h){case 0:a.setFromColor(b);return;case 1:a.add((b.r-a.r)*n,(b.g-a.g)*n,(b.b-a.b)*n,(b.a-a.a)*n)}return}let c=0,u=0,d=0,f=0,m=K.search(l,s,5),x=this.curves[m/5];switch(x){case 0:let b=l[m];c=l[m+1],u=l[m+2],d=l[m+3],f=l[m+4];let w=(s-b)/(l[m+5]-b);c+=(l[m+5+1]-c)*w,u+=(l[m+5+2]-u)*w,d+=(l[m+5+3]-d)*w,f+=(l[m+5+4]-f)*w;break;case 1:c=l[m+1],u=l[m+2],d=l[m+3],f=l[m+4];break;default:c=this.getBezierValue(s,m,1,x-2),u=this.getBezierValue(s,m,2,x+18-2),d=this.getBezierValue(s,m,3,x+18*2-2),f=this.getBezierValue(s,m,4,x+18*3-2)}n==1?a.set(c,u,d,f):(h==0&&a.setFromColor(i.data.color),a.add((c-a.r)*n,(u-a.g)*n,(d-a.b)*n,(f-a.a)*n))}},xt=class extends oe{slotIndex=0;constructor(e,t,s){super(e,t,[O.rgb+"|"+s]),this.slotIndex=s}getFrameEntries(){return 4}setFrame(e,t,s,r,n){e<<=2,this.frames[e]=t,this.frames[e+1]=s,this.frames[e+2]=r,this.frames[e+3]=n}apply(e,t,s,r,n,h,o){let i=e.slots[this.slotIndex];if(!i.bone.active)return;let l=this.frames,a=i.color;if(s<l[0]){let x=i.data.color;switch(h){case 0:a.r=x.r,a.g=x.g,a.b=x.b;return;case 1:a.r+=(x.r-a.r)*n,a.g+=(x.g-a.g)*n,a.b+=(x.b-a.b)*n}return}let c=0,u=0,d=0,f=K.search(l,s,4),m=this.curves[f>>2];switch(m){case 0:let x=l[f];c=l[f+1],u=l[f+2],d=l[f+3];let b=(s-x)/(l[f+4]-x);c+=(l[f+4+1]-c)*b,u+=(l[f+4+2]-u)*b,d+=(l[f+4+3]-d)*b;break;case 1:c=l[f+1],u=l[f+2],d=l[f+3];break;default:c=this.getBezierValue(s,f,1,m-2),u=this.getBezierValue(s,f,2,m+18-2),d=this.getBezierValue(s,f,3,m+18*2-2)}if(n==1)a.r=c,a.g=u,a.b=d;else{if(h==0){let x=i.data.color;a.r=x.r,a.g=x.g,a.b=x.b}a.r+=(c-a.r)*n,a.g+=(u-a.g)*n,a.b+=(d-a.b)*n}}},pt=class extends ne{slotIndex=0;constructor(e,t,s){super(e,t,O.alpha+"|"+s),this.slotIndex=s}apply(e,t,s,r,n,h,o){let i=e.slots[this.slotIndex];if(!i.bone.active)return;let l=i.color;if(s<this.frames[0]){let c=i.data.color;switch(h){case 0:l.a=c.a;return;case 1:l.a+=(c.a-l.a)*n}return}let a=this.getCurveValue(s);n==1?l.a=a:(h==0&&(l.a=i.data.color.a),l.a+=(a-l.a)*n)}},wt=class extends oe{slotIndex=0;constructor(e,t,s){super(e,t,[O.rgb+"|"+s,O.alpha+"|"+s,O.rgb2+"|"+s]),this.slotIndex=s}getFrameEntries(){return 8}setFrame(e,t,s,r,n,h,o,i,l){e<<=3,this.frames[e]=t,this.frames[e+1]=s,this.frames[e+2]=r,this.frames[e+3]=n,this.frames[e+4]=h,this.frames[e+5]=o,this.frames[e+6]=i,this.frames[e+7]=l}apply(e,t,s,r,n,h,o){let i=e.slots[this.slotIndex];if(!i.bone.active)return;let l=this.frames,a=i.color,c=i.darkColor;if(s<l[0]){let v=i.data.color,y=i.data.darkColor;switch(h){case 0:a.setFromColor(v),c.r=y.r,c.g=y.g,c.b=y.b;return;case 1:a.add((v.r-a.r)*n,(v.g-a.g)*n,(v.b-a.b)*n,(v.a-a.a)*n),c.r+=(y.r-c.r)*n,c.g+=(y.g-c.g)*n,c.b+=(y.b-c.b)*n}return}let u=0,d=0,f=0,m=0,x=0,b=0,w=0,g=K.search(l,s,8),p=this.curves[g>>3];switch(p){case 0:let v=l[g];u=l[g+1],d=l[g+2],f=l[g+3],m=l[g+4],x=l[g+5],b=l[g+6],w=l[g+7];let y=(s-v)/(l[g+8]-v);u+=(l[g+8+1]-u)*y,d+=(l[g+8+2]-d)*y,f+=(l[g+8+3]-f)*y,m+=(l[g+8+4]-m)*y,x+=(l[g+8+5]-x)*y,b+=(l[g+8+6]-b)*y,w+=(l[g+8+7]-w)*y;break;case 1:u=l[g+1],d=l[g+2],f=l[g+3],m=l[g+4],x=l[g+5],b=l[g+6],w=l[g+7];break;default:u=this.getBezierValue(s,g,1,p-2),d=this.getBezierValue(s,g,2,p+18-2),f=this.getBezierValue(s,g,3,p+18*2-2),m=this.getBezierValue(s,g,4,p+18*3-2),x=this.getBezierValue(s,g,5,p+18*4-2),b=this.getBezierValue(s,g,6,p+18*5-2),w=this.getBezierValue(s,g,7,p+18*6-2)}if(n==1)a.set(u,d,f,m),c.r=x,c.g=b,c.b=w;else{if(h==0){a.setFromColor(i.data.color);let v=i.data.darkColor;c.r=v.r,c.g=v.g,c.b=v.b}a.add((u-a.r)*n,(d-a.g)*n,(f-a.b)*n,(m-a.a)*n),c.r+=(x-c.r)*n,c.g+=(b-c.g)*n,c.b+=(w-c.b)*n}}},bt=class extends oe{slotIndex=0;constructor(e,t,s){super(e,t,[O.rgb+"|"+s,O.rgb2+"|"+s]),this.slotIndex=s}getFrameEntries(){return 7}setFrame(e,t,s,r,n,h,o,i){e*=7,this.frames[e]=t,this.frames[e+1]=s,this.frames[e+2]=r,this.frames[e+3]=n,this.frames[e+4]=h,this.frames[e+5]=o,this.frames[e+6]=i}apply(e,t,s,r,n,h,o){let i=e.slots[this.slotIndex];if(!i.bone.active)return;let l=this.frames,a=i.color,c=i.darkColor;if(s<l[0]){let v=i.data.color,y=i.data.darkColor;switch(h){case 0:a.r=v.r,a.g=v.g,a.b=v.b,c.r=y.r,c.g=y.g,c.b=y.b;return;case 1:a.r+=(v.r-a.r)*n,a.g+=(v.g-a.g)*n,a.b+=(v.b-a.b)*n,c.r+=(y.r-c.r)*n,c.g+=(y.g-c.g)*n,c.b+=(y.b-c.b)*n}return}let u=0,d=0,f=0,m=0,x=0,b=0,w=0,g=K.search(l,s,7),p=this.curves[g/7];switch(p){case 0:let v=l[g];u=l[g+1],d=l[g+2],f=l[g+3],x=l[g+4],b=l[g+5],w=l[g+6];let y=(s-v)/(l[g+7]-v);u+=(l[g+7+1]-u)*y,d+=(l[g+7+2]-d)*y,f+=(l[g+7+3]-f)*y,x+=(l[g+7+4]-x)*y,b+=(l[g+7+5]-b)*y,w+=(l[g+7+6]-w)*y;break;case 1:u=l[g+1],d=l[g+2],f=l[g+3],x=l[g+4],b=l[g+5],w=l[g+6];break;default:u=this.getBezierValue(s,g,1,p-2),d=this.getBezierValue(s,g,2,p+18-2),f=this.getBezierValue(s,g,3,p+18*2-2),x=this.getBezierValue(s,g,4,p+18*3-2),b=this.getBezierValue(s,g,5,p+18*4-2),w=this.getBezierValue(s,g,6,p+18*5-2)}if(n==1)a.r=u,a.g=d,a.b=f,c.r=x,c.g=b,c.b=w;else{if(h==0){let v=i.data.color,y=i.data.darkColor;a.r=v.r,a.g=v.g,a.b=v.b,c.r=y.r,c.g=y.g,c.b=y.b}a.r+=(u-a.r)*n,a.g+=(d-a.g)*n,a.b+=(f-a.b)*n,c.r+=(x-c.r)*n,c.g+=(b-c.g)*n,c.b+=(w-c.b)*n}}},we=class extends K{slotIndex=0;attachmentNames;constructor(e,t){super(e,[O.attachment+"|"+t]),this.slotIndex=t,this.attachmentNames=new Array(e)}getFrameCount(){return this.frames.length}setFrame(e,t,s){this.frames[e]=t,this.attachmentNames[e]=s}apply(e,t,s,r,n,h,o){let i=e.slots[this.slotIndex];if(i.bone.active){if(o==1){h==0&&this.setAttachment(e,i,i.data.attachmentName);return}if(s<this.frames[0]){(h==0||h==1)&&this.setAttachment(e,i,i.data.attachmentName);return}this.setAttachment(e,i,this.attachmentNames[K.search1(this.frames,s)])}}setAttachment(e,t,s){t.setAttachment(s?e.getAttachment(this.slotIndex,s):null)}},yt=class extends oe{slotIndex=0;attachment;vertices;constructor(e,t,s,r){super(e,t,[O.deform+"|"+s+"|"+r.id]),this.slotIndex=s,this.attachment=r,this.vertices=new Array(e)}getFrameCount(){return this.frames.length}setFrame(e,t,s){this.frames[e]=t,this.vertices[e]=s}setBezier(e,t,s,r,n,h,o,i,l,a,c){let u=this.curves,d=this.getFrameCount()+e*18;s==0&&(u[t]=2+d);let f=(r-h*2+i)*.03,m=l*.03-o*.06,x=((h-i)*3-r+a)*.006,b=(o-l+.33333333)*.018,w=f*2+x,g=m*2+b,p=(h-r)*.3+f+x*.16666667,v=o*.3+m+b*.16666667,y=r+p,S=v;for(let A=d+18;d<A;d+=2)u[d]=y,u[d+1]=S,p+=w,v+=g,w+=x,g+=b,y+=p,S+=v}getCurvePercent(e,t){let s=this.curves,r=s[t];switch(r){case 0:let i=this.frames[t];return(e-i)/(this.frames[t+this.getFrameEntries()]-i);case 1:return 0}if(r-=2,s[r]>e){let i=this.frames[t];return s[r+1]*(e-i)/(s[r]-i)}let n=r+18;for(r+=2;r<n;r+=2)if(s[r]>=e){let i=s[r-2],l=s[r-1];return l+(e-i)/(s[r]-i)*(s[r+1]-l)}let h=s[n-2],o=s[n-1];return o+(1-o)*(e-h)/(this.frames[t+this.getFrameEntries()]-h)}apply(e,t,s,r,n,h,o){let i=e.slots[this.slotIndex];if(!i.bone.active)return;let l=i.getAttachment();if(!l||!(l instanceof le)||l.timelineAttachment!=this.attachment)return;let a=i.deform;a.length==0&&(h=0);let c=this.vertices,u=c[0].length,d=this.frames;if(s<d[0]){switch(h){case 0:a.length=0;return;case 1:if(n==1){a.length=0;return}a.length=u;let g=l;if(g.bones){n=1-n;for(var f=0;f<u;f++)a[f]*=n}else{let p=g.vertices;for(var f=0;f<u;f++)a[f]+=(p[f]-a[f])*n}}return}if(a.length=u,s>=d[d.length-1]){let g=c[d.length-1];if(n==1)if(h==3){let p=l;if(p.bones)for(let v=0;v<u;v++)a[v]+=g[v];else{let v=p.vertices;for(let y=0;y<u;y++)a[y]+=g[y]-v[y]}}else R.arrayCopy(g,0,a,0,u);else switch(h){case 0:{let v=l;if(v.bones)for(let y=0;y<u;y++)a[y]=g[y]*n;else{let y=v.vertices;for(let S=0;S<u;S++){let A=y[S];a[S]=A+(g[S]-A)*n}}break}case 1:case 2:for(let v=0;v<u;v++)a[v]+=(g[v]-a[v])*n;break;case 3:let p=l;if(p.bones)for(let v=0;v<u;v++)a[v]+=g[v]*n;else{let v=p.vertices;for(let y=0;y<u;y++)a[y]+=(g[y]-v[y])*n}}return}let m=K.search1(d,s),x=this.getCurvePercent(s,m),b=c[m],w=c[m+1];if(n==1)if(h==3){let g=l;if(g.bones)for(let p=0;p<u;p++){let v=b[p];a[p]+=v+(w[p]-v)*x}else{let p=g.vertices;for(let v=0;v<u;v++){let y=b[v];a[v]+=y+(w[v]-y)*x-p[v]}}}else for(let g=0;g<u;g++){let p=b[g];a[g]=p+(w[g]-p)*x}else switch(h){case 0:{let p=l;if(p.bones)for(let v=0;v<u;v++){let y=b[v];a[v]=(y+(w[v]-y)*x)*n}else{let v=p.vertices;for(let y=0;y<u;y++){let S=b[y],A=v[y];a[y]=A+(S+(w[y]-S)*x-A)*n}}break}case 1:case 2:for(let p=0;p<u;p++){let v=b[p];a[p]+=(v+(w[p]-v)*x-a[p])*n}break;case 3:let g=l;if(g.bones)for(let p=0;p<u;p++){let v=b[p];a[p]+=(v+(w[p]-v)*x)*n}else{let p=g.vertices;for(let v=0;v<u;v++){let y=b[v];a[v]+=(y+(w[v]-y)*x-p[v])*n}}}}},fs=class extends K{events;constructor(e){super(e,fs.propertyIds),this.events=new Array(e)}getFrameCount(){return this.frames.length}setFrame(e,t){this.frames[e]=t.time,this.events[e]=t}apply(e,t,s,r,n,h,o){if(!r)return;let i=this.frames,l=this.frames.length;if(t>s)this.apply(e,t,Number.MAX_VALUE,r,n,h,o),t=-1;else if(t>=i[l-1])return;if(s<i[0])return;let a=0;if(t<i[0])a=0;else{a=K.search1(i,t)+1;let c=i[a];for(;a>0&&i[a-1]==c;)a--}for(;a<l&&s>=i[a];a++)r.push(this.events[a])}},Fe=fs;B(Fe,"propertyIds",[""+O.event]);var us=class extends K{drawOrders;constructor(e){super(e,us.propertyIds),this.drawOrders=new Array(e)}getFrameCount(){return this.frames.length}setFrame(e,t,s){this.frames[e]=t,this.drawOrders[e]=s}apply(e,t,s,r,n,h,o){if(o==1){h==0&&R.arrayCopy(e.slots,0,e.drawOrder,0,e.slots.length);return}if(s<this.frames[0]){(h==0||h==1)&&R.arrayCopy(e.slots,0,e.drawOrder,0,e.slots.length);return}let i=K.search1(this.frames,s),l=this.drawOrders[i];if(!l)R.arrayCopy(e.slots,0,e.drawOrder,0,e.slots.length);else{let a=e.drawOrder,c=e.slots;for(let u=0,d=l.length;u<d;u++)a[u]=c[l[u]]}}},be=us;B(be,"propertyIds",[""+O.drawOrder]);var vt=class extends oe{constraintIndex=0;constructor(e,t,s){super(e,t,[O.ikConstraint+"|"+s]),this.constraintIndex=s}getFrameEntries(){return 6}setFrame(e,t,s,r,n,h,o){e*=6,this.frames[e]=t,this.frames[e+1]=s,this.frames[e+2]=r,this.frames[e+3]=n,this.frames[e+4]=h?1:0,this.frames[e+5]=o?1:0}apply(e,t,s,r,n,h,o){let i=e.ikConstraints[this.constraintIndex];if(!i.active)return;let l=this.frames;if(s<l[0]){switch(h){case 0:i.mix=i.data.mix,i.softness=i.data.softness,i.bendDirection=i.data.bendDirection,i.compress=i.data.compress,i.stretch=i.data.stretch;return;case 1:i.mix+=(i.data.mix-i.mix)*n,i.softness+=(i.data.softness-i.softness)*n,i.bendDirection=i.data.bendDirection,i.compress=i.data.compress,i.stretch=i.data.stretch}return}let a=0,c=0,u=K.search(l,s,6),d=this.curves[u/6];switch(d){case 0:let f=l[u];a=l[u+1],c=l[u+2];let m=(s-f)/(l[u+6]-f);a+=(l[u+6+1]-a)*m,c+=(l[u+6+2]-c)*m;break;case 1:a=l[u+1],c=l[u+2];break;default:a=this.getBezierValue(s,u,1,d-2),c=this.getBezierValue(s,u,2,d+18-2)}h==0?(i.mix=i.data.mix+(a-i.data.mix)*n,i.softness=i.data.softness+(c-i.data.softness)*n,o==1?(i.bendDirection=i.data.bendDirection,i.compress=i.data.compress,i.stretch=i.data.stretch):(i.bendDirection=l[u+3],i.compress=l[u+4]!=0,i.stretch=l[u+5]!=0)):(i.mix+=(a-i.mix)*n,i.softness+=(c-i.softness)*n,o==0&&(i.bendDirection=l[u+3],i.compress=l[u+4]!=0,i.stretch=l[u+5]!=0))}},St=class extends oe{constraintIndex=0;constructor(e,t,s){super(e,t,[O.transformConstraint+"|"+s]),this.constraintIndex=s}getFrameEntries(){return 7}setFrame(e,t,s,r,n,h,o,i){let l=this.frames;e*=7,l[e]=t,l[e+1]=s,l[e+2]=r,l[e+3]=n,l[e+4]=h,l[e+5]=o,l[e+6]=i}apply(e,t,s,r,n,h,o){let i=e.transformConstraints[this.constraintIndex];if(!i.active)return;let l=this.frames;if(s<l[0]){let w=i.data;switch(h){case 0:i.mixRotate=w.mixRotate,i.mixX=w.mixX,i.mixY=w.mixY,i.mixScaleX=w.mixScaleX,i.mixScaleY=w.mixScaleY,i.mixShearY=w.mixShearY;return;case 1:i.mixRotate+=(w.mixRotate-i.mixRotate)*n,i.mixX+=(w.mixX-i.mixX)*n,i.mixY+=(w.mixY-i.mixY)*n,i.mixScaleX+=(w.mixScaleX-i.mixScaleX)*n,i.mixScaleY+=(w.mixScaleY-i.mixScaleY)*n,i.mixShearY+=(w.mixShearY-i.mixShearY)*n}return}let a,c,u,d,f,m,x=K.search(l,s,7),b=this.curves[x/7];switch(b){case 0:let w=l[x];a=l[x+1],c=l[x+2],u=l[x+3],d=l[x+4],f=l[x+5],m=l[x+6];let g=(s-w)/(l[x+7]-w);a+=(l[x+7+1]-a)*g,c+=(l[x+7+2]-c)*g,u+=(l[x+7+3]-u)*g,d+=(l[x+7+4]-d)*g,f+=(l[x+7+5]-f)*g,m+=(l[x+7+6]-m)*g;break;case 1:a=l[x+1],c=l[x+2],u=l[x+3],d=l[x+4],f=l[x+5],m=l[x+6];break;default:a=this.getBezierValue(s,x,1,b-2),c=this.getBezierValue(s,x,2,b+18-2),u=this.getBezierValue(s,x,3,b+18*2-2),d=this.getBezierValue(s,x,4,b+18*3-2),f=this.getBezierValue(s,x,5,b+18*4-2),m=this.getBezierValue(s,x,6,b+18*5-2)}if(h==0){let w=i.data;i.mixRotate=w.mixRotate+(a-w.mixRotate)*n,i.mixX=w.mixX+(c-w.mixX)*n,i.mixY=w.mixY+(u-w.mixY)*n,i.mixScaleX=w.mixScaleX+(d-w.mixScaleX)*n,i.mixScaleY=w.mixScaleY+(f-w.mixScaleY)*n,i.mixShearY=w.mixShearY+(m-w.mixShearY)*n}else i.mixRotate+=(a-i.mixRotate)*n,i.mixX+=(c-i.mixX)*n,i.mixY+=(u-i.mixY)*n,i.mixScaleX+=(d-i.mixScaleX)*n,i.mixScaleY+=(f-i.mixScaleY)*n,i.mixShearY+=(m-i.mixShearY)*n}},At=class extends ne{constraintIndex=0;constructor(e,t,s){super(e,t,O.pathConstraintPosition+"|"+s),this.constraintIndex=s}apply(e,t,s,r,n,h,o){let i=e.pathConstraints[this.constraintIndex];i.active&&(i.position=this.getAbsoluteValue(s,n,h,i.position,i.data.position))}},It=class extends ne{constraintIndex=0;constructor(e,t,s){super(e,t,O.pathConstraintSpacing+"|"+s),this.constraintIndex=s}apply(e,t,s,r,n,h,o){let i=e.pathConstraints[this.constraintIndex];i.active&&(i.spacing=this.getAbsoluteValue(s,n,h,i.spacing,i.data.spacing))}},Ct=class extends oe{constraintIndex=0;constructor(e,t,s){super(e,t,[O.pathConstraintMix+"|"+s]),this.constraintIndex=s}getFrameEntries(){return 4}setFrame(e,t,s,r,n){let h=this.frames;e<<=2,h[e]=t,h[e+1]=s,h[e+2]=r,h[e+3]=n}apply(e,t,s,r,n,h,o){let i=e.pathConstraints[this.constraintIndex];if(!i.active)return;let l=this.frames;if(s<l[0]){switch(h){case 0:i.mixRotate=i.data.mixRotate,i.mixX=i.data.mixX,i.mixY=i.data.mixY;return;case 1:i.mixRotate+=(i.data.mixRotate-i.mixRotate)*n,i.mixX+=(i.data.mixX-i.mixX)*n,i.mixY+=(i.data.mixY-i.mixY)*n}return}let a,c,u,d=K.search(l,s,4),f=this.curves[d>>2];switch(f){case 0:let m=l[d];a=l[d+1],c=l[d+2],u=l[d+3];let x=(s-m)/(l[d+4]-m);a+=(l[d+4+1]-a)*x,c+=(l[d+4+2]-c)*x,u+=(l[d+4+3]-u)*x;break;case 1:a=l[d+1],c=l[d+2],u=l[d+3];break;default:a=this.getBezierValue(s,d,1,f-2),c=this.getBezierValue(s,d,2,f+18-2),u=this.getBezierValue(s,d,3,f+18*2-2)}if(h==0){let m=i.data;i.mixRotate=m.mixRotate+(a-m.mixRotate)*n,i.mixX=m.mixX+(c-m.mixX)*n,i.mixY=m.mixY+(u-m.mixY)*n}else i.mixRotate+=(a-i.mixRotate)*n,i.mixX+=(c-i.mixX)*n,i.mixY+=(u-i.mixY)*n}},ue=class extends ne{constraintIndex=0;constructor(e,t,s,r){super(e,t,r+"|"+s),this.constraintIndex=s}apply(e,t,s,r,n,h,o){let i;if(this.constraintIndex==-1){const l=s>=this.frames[0]?this.getCurveValue(s):0;for(const a of e.physicsConstraints)a.active&&this.global(a.data)&&this.set(a,this.getAbsoluteValue2(s,n,h,this.get(a),this.setup(a),l))}else i=e.physicsConstraints[this.constraintIndex],i.active&&this.set(i,this.getAbsoluteValue(s,n,h,this.get(i),this.setup(i)))}},kt=class extends ue{constructor(e,t,s){super(e,t,s,O.physicsConstraintInertia)}setup(e){return e.data.inertia}get(e){return e.inertia}set(e,t){e.inertia=t}global(e){return e.inertiaGlobal}},Mt=class extends ue{constructor(e,t,s){super(e,t,s,O.physicsConstraintStrength)}setup(e){return e.data.strength}get(e){return e.strength}set(e,t){e.strength=t}global(e){return e.strengthGlobal}},Yt=class extends ue{constructor(e,t,s){super(e,t,s,O.physicsConstraintDamping)}setup(e){return e.data.damping}get(e){return e.damping}set(e,t){e.damping=t}global(e){return e.dampingGlobal}},Tt=class extends ue{constructor(e,t,s){super(e,t,s,O.physicsConstraintMass)}setup(e){return 1/e.data.massInverse}get(e){return 1/e.massInverse}set(e,t){e.massInverse=1/t}global(e){return e.massGlobal}},Xt=class extends ue{constructor(e,t,s){super(e,t,s,O.physicsConstraintWind)}setup(e){return e.data.wind}get(e){return e.wind}set(e,t){e.wind=t}global(e){return e.windGlobal}},Ft=class extends ue{constructor(e,t,s){super(e,t,s,O.physicsConstraintGravity)}setup(e){return e.data.gravity}get(e){return e.gravity}set(e,t){e.gravity=t}global(e){return e.gravityGlobal}},Et=class extends ue{constructor(e,t,s){super(e,t,s,O.physicsConstraintMix)}setup(e){return e.data.mix}get(e){return e.mix}set(e,t){e.mix=t}global(e){return e.mixGlobal}},ms=class extends K{constraintIndex;constructor(e,t){super(e,ms.propertyIds),this.constraintIndex=t}getFrameCount(){return this.frames.length}setFrame(e,t){this.frames[e]=t}apply(e,t,s,r,n,h,o){let i;if(this.constraintIndex!=-1&&(i=e.physicsConstraints[this.constraintIndex],!i.active))return;const l=this.frames;if(t>s)this.apply(e,t,Number.MAX_VALUE,[],n,h,o),t=-1;else if(t>=l[l.length-1])return;if(!(s<l[0])&&(t<l[0]||s>=l[K.search1(l,t)+1]))if(i!=null)i.reset();else for(const a of e.physicsConstraints)a.active&&a.reset()}},_e=ms;B(_e,"propertyIds",[O.physicsConstraintReset.toString()]);var me=class extends K{slotIndex;attachment;constructor(e,t,s){super(e,[O.sequence+"|"+t+"|"+s.sequence.id]),this.slotIndex=t,this.attachment=s}getFrameEntries(){return me.ENTRIES}getSlotIndex(){return this.slotIndex}getAttachment(){return this.attachment}setFrame(e,t,s,r,n){let h=this.frames;e*=me.ENTRIES,h[e]=t,h[e+me.MODE]=s|r<<4,h[e+me.DELAY]=n}apply(e,t,s,r,n,h,o){let i=e.slots[this.slotIndex];if(!i.bone.active)return;let l=i.attachment,a=this.attachment;if(l!=a&&(!(l instanceof le)||l.timelineAttachment!=a))return;if(o==1){h==0&&(i.sequenceIndex=-1);return}let c=this.frames;if(s<c[0]){(h==0||h==1)&&(i.sequenceIndex=-1);return}let u=K.search(c,s,me.ENTRIES),d=c[u],f=c[u+me.MODE],m=c[u+me.DELAY];if(!this.attachment.sequence)return;let x=f>>4,b=this.attachment.sequence.regions.length,w=hs[f&15];if(w!=0)switch(x+=(s-d)/m+1e-5|0,w){case 1:x=Math.min(b-1,x);break;case 2:x%=b;break;case 3:{let g=(b<<1)-2;x=g==0?0:x%g,x>=b&&(x=g-x);break}case 4:x=Math.max(b-1-x,0);break;case 5:x=b-1-x%b;break;case 6:{let g=(b<<1)-2;x=g==0?0:(x+b-1)%g,x>=b&&(x=g-x)}}i.sequenceIndex=x}},Ae=me;B(Ae,"ENTRIES",3),B(Ae,"MODE",1),B(Ae,"DELAY",2);var We=class{static emptyAnimation(){return We._emptyAnimation}data;tracks=new Array;timeScale=1;unkeyedState=0;events=new Array;listeners=new Array;queue=new xs(this);propertyIDs=new st;animationsChanged=!1;trackEntryPool=new Te(()=>new gs);constructor(e){this.data=e}update(e){e*=this.timeScale;let t=this.tracks;for(let s=0,r=t.length;s<r;s++){let n=t[s];if(!n)continue;n.animationLast=n.nextAnimationLast,n.trackLast=n.nextTrackLast;let h=e*n.timeScale;if(n.delay>0){if(n.delay-=h,n.delay>0)continue;h=-n.delay,n.delay=0}let o=n.next;if(o){let i=n.trackLast-o.delay;if(i>=0){for(o.delay=0,o.trackTime+=n.timeScale==0?0:(i/n.timeScale+e)*o.timeScale,n.trackTime+=h,this.setCurrent(s,o,!0);o.mixingFrom;)o.mixTime+=e,o=o.mixingFrom;continue}}else if(n.trackLast>=n.trackEnd&&!n.mixingFrom){t[s]=null,this.queue.end(n),this.clearNext(n);continue}if(n.mixingFrom&&this.updateMixingFrom(n,e)){let i=n.mixingFrom;for(n.mixingFrom=null,i&&(i.mixingTo=null);i;)this.queue.end(i),i=i.mixingFrom}n.trackTime+=h}this.queue.drain()}updateMixingFrom(e,t){let s=e.mixingFrom;if(!s)return!0;let r=this.updateMixingFrom(s,t);return s.animationLast=s.nextAnimationLast,s.trackLast=s.nextTrackLast,e.nextTrackLast!=-1&&e.mixTime>=e.mixDuration?((s.totalAlpha==0||e.mixDuration==0)&&(e.mixingFrom=s.mixingFrom,s.mixingFrom!=null&&(s.mixingFrom.mixingTo=e),e.interruptAlpha=s.interruptAlpha,this.queue.end(s)),r):(s.trackTime+=t*s.timeScale,e.mixTime+=t,!1)}apply(e){if(!e)throw new Error("skeleton cannot be null.");this.animationsChanged&&this._animationsChanged();let t=this.events,s=this.tracks,r=!1;for(let u=0,d=s.length;u<d;u++){let f=s[u];if(!f||f.delay>0)continue;r=!0;let m=u==0?1:f.mixBlend,x=f.alpha;f.mixingFrom?x*=this.applyMixingFrom(f,e,m):f.trackTime>=f.trackEnd&&!f.next&&(x=0);let b=x>=f.alphaAttachmentThreshold,w=f.animationLast,g=f.getAnimationTime(),p=g,v=t;f.reverse&&(p=f.animation.duration-p,v=null);let y=f.animation.timelines,S=y.length;if(u==0&&x==1||m==3){u==0&&(b=!0);for(let A=0;A<S;A++){R.webkit602BugfixHelper(x,m);var n=y[A];n instanceof we?this.applyAttachmentTimeline(n,e,p,m,b):n.apply(e,w,p,v,x,m,0)}}else{let A=f.timelineMode,k=f.shortestRotation,Y=!k&&f.timelinesRotation.length!=S<<1;Y&&(f.timelinesRotation.length=S<<1);for(let M=0;M<S;M++){let E=y[M],X=A[M]==Ue?m:0;!k&&E instanceof Xe?this.applyRotateTimeline(E,e,p,x,X,f.timelinesRotation,M<<1,Y):E instanceof we?this.applyAttachmentTimeline(E,e,p,m,b):(R.webkit602BugfixHelper(x,m),E.apply(e,w,p,v,x,X,0))}}this.queueEvents(f,g),t.length=0,f.nextAnimationLast=g,f.nextTrackLast=f.trackTime}for(var h=this.unkeyedState+Vt,o=e.slots,i=0,l=e.slots.length;i<l;i++){var a=o[i];if(a.attachmentState==h){var c=a.data.attachmentName;a.setAttachment(c?e.getAttachment(a.data.index,c):null)}}return this.unkeyedState+=2,this.queue.drain(),r}applyMixingFrom(e,t,s){let r=e.mixingFrom;r.mixingFrom&&this.applyMixingFrom(r,t,s);let n=0;e.mixDuration==0?(n=1,s==1&&(s=0)):(n=e.mixTime/e.mixDuration,n>1&&(n=1),s!=1&&(s=r.mixBlend));let h=n<r.mixAttachmentThreshold,o=n<r.mixDrawOrderThreshold,i=r.animation.timelines,l=i.length,a=r.alpha*e.interruptAlpha,c=a*(1-n),u=r.animationLast,d=r.getAnimationTime(),f=d,m=null;if(r.reverse?f=r.animation.duration-f:n<r.eventThreshold&&(m=this.events),s==3)for(let x=0;x<l;x++)i[x].apply(t,u,f,m,c,s,1);else{let x=r.timelineMode,b=r.timelineHoldMix,w=r.shortestRotation,g=!w&&r.timelinesRotation.length!=l<<1;g&&(r.timelinesRotation.length=l<<1),r.totalAlpha=0;for(let p=0;p<l;p++){let v=i[p],y=1,S,A=0;switch(x[p]){case Ue:if(!o&&v instanceof be)continue;S=s,A=c;break;case Pt:S=0,A=c;break;case Bt:S=s,A=a;break;case ze:S=0,A=a;break;default:S=0;let k=b[p];A=a*Math.max(0,1-k.mixTime/k.mixDuration);break}r.totalAlpha+=A,!w&&v instanceof Xe?this.applyRotateTimeline(v,t,f,A,S,r.timelinesRotation,p<<1,g):v instanceof we?this.applyAttachmentTimeline(v,t,f,S,h&&A>=r.alphaAttachmentThreshold):(R.webkit602BugfixHelper(A,s),o&&v instanceof be&&S==0&&(y=0),v.apply(t,u,f,m,A,S,y))}}return e.mixDuration>0&&this.queueEvents(r,d),this.events.length=0,r.nextAnimationLast=d,r.nextTrackLast=r.trackTime,n}applyAttachmentTimeline(e,t,s,r,n){var h=t.slots[e.slotIndex];h.bone.active&&(s<e.frames[0]?(r==0||r==1)&&this.setAttachment(t,h,h.data.attachmentName,n):this.setAttachment(t,h,e.attachmentNames[K.search1(e.frames,s)],n),h.attachmentState<=this.unkeyedState&&(h.attachmentState=this.unkeyedState+Vt))}setAttachment(e,t,s,r){t.setAttachment(s?e.getAttachment(t.data.index,s):null),r&&(t.attachmentState=this.unkeyedState+ws)}applyRotateTimeline(e,t,s,r,n,h,o,i){if(i&&(h[o]=0),r==1){e.apply(t,0,s,null,1,n,0);return}let l=t.bones[e.boneIndex];if(!l.active)return;let a=e.frames,c=0,u=0;if(s<a[0])switch(n){case 0:l.rotation=l.data.rotation;default:return;case 1:c=l.rotation,u=l.data.rotation}else c=n==0?l.data.rotation:l.rotation,u=l.data.rotation+e.getCurveValue(s);let d=0,f=u-c;if(f-=Math.ceil(f/360-.5)*360,f==0)d=h[o];else{let m=0,x=0;i?(m=0,x=f):(m=h[o],x=h[o+1]);let b=m-m%360;d=f+b;let w=f>=0,g=m>=0;Math.abs(x)<=90&&F.signum(x)!=F.signum(f)&&(Math.abs(m-b)>180?(d+=360*F.signum(m),g=w):b!=0?d-=360*F.signum(m):g=w),g!=w&&(d+=360*F.signum(m)),h[o]=d}h[o+1]=f,l.rotation=c+d*r}queueEvents(e,t){let s=e.animationStart,r=e.animationEnd,n=r-s,h=e.trackLast%n,o=this.events,i=0,l=o.length;for(;i<l;i++){let c=o[i];if(c.time<h)break;c.time>r||this.queue.event(e,c)}let a=!1;if(e.loop)if(n==0)a=!0;else{const c=Math.floor(e.trackTime/n);a=c>0&&c>Math.floor(e.trackLast/n)}else a=t>=r&&e.animationLast<r;for(a&&this.queue.complete(e);i<l;i++){let c=o[i];c.time<s||this.queue.event(e,c)}}clearTracks(){let e=this.queue.drainDisabled;this.queue.drainDisabled=!0;for(let t=0,s=this.tracks.length;t<s;t++)this.clearTrack(t);this.tracks.length=0,this.queue.drainDisabled=e,this.queue.drain()}clearTrack(e){if(e>=this.tracks.length)return;let t=this.tracks[e];if(!t)return;this.queue.end(t),this.clearNext(t);let s=t;for(;;){let r=s.mixingFrom;if(!r)break;this.queue.end(r),s.mixingFrom=null,s.mixingTo=null,s=r}this.tracks[t.trackIndex]=null,this.queue.drain()}setCurrent(e,t,s){let r=this.expandToIndex(e);this.tracks[e]=t,t.previous=null,r&&(s&&this.queue.interrupt(r),t.mixingFrom=r,r.mixingTo=t,t.mixTime=0,r.mixingFrom&&r.mixDuration>0&&(t.interruptAlpha*=Math.min(1,r.mixTime/r.mixDuration)),r.timelinesRotation.length=0),this.queue.start(t)}setAnimation(e,t,s=!1){let r=this.data.skeletonData.findAnimation(t);if(!r)throw new Error("Animation not found: "+t);return this.setAnimationWith(e,r,s)}setAnimationWith(e,t,s=!1){if(!t)throw new Error("animation cannot be null.");let r=!0,n=this.expandToIndex(e);n&&(n.nextTrackLast==-1?(this.tracks[e]=n.mixingFrom,this.queue.interrupt(n),this.queue.end(n),this.clearNext(n),n=n.mixingFrom,r=!1):this.clearNext(n));let h=this.trackEntry(e,t,s,n);return this.setCurrent(e,h,r),this.queue.drain(),h}addAnimation(e,t,s=!1,r=0){let n=this.data.skeletonData.findAnimation(t);if(!n)throw new Error("Animation not found: "+t);return this.addAnimationWith(e,n,s,r)}addAnimationWith(e,t,s=!1,r=0){if(!t)throw new Error("animation cannot be null.");let n=this.expandToIndex(e);if(n)for(;n.next;)n=n.next;let h=this.trackEntry(e,t,s,n);return n?(n.next=h,h.previous=n,r<=0&&(r=Math.max(r+n.getTrackComplete()-h.mixDuration,0))):(this.setCurrent(e,h,!0),this.queue.drain(),r<0&&(r=0)),h.delay=r,h}setEmptyAnimation(e,t=0){let s=this.setAnimationWith(e,We.emptyAnimation(),!1);return s.mixDuration=t,s.trackEnd=t,s}addEmptyAnimation(e,t=0,s=0){let r=this.addAnimationWith(e,We.emptyAnimation(),!1,s);return s<=0&&(r.delay=Math.max(r.delay+r.mixDuration-t,0)),r.mixDuration=t,r.trackEnd=t,r}setEmptyAnimations(e=0){let t=this.queue.drainDisabled;this.queue.drainDisabled=!0;for(let s=0,r=this.tracks.length;s<r;s++){let n=this.tracks[s];n&&this.setEmptyAnimation(n.trackIndex,e)}this.queue.drainDisabled=t,this.queue.drain()}expandToIndex(e){return e<this.tracks.length?this.tracks[e]:(R.ensureArrayCapacity(this.tracks,e+1,null),this.tracks.length=e+1,null)}trackEntry(e,t,s,r){let n=this.trackEntryPool.obtain();return n.reset(),n.trackIndex=e,n.animation=t,n.loop=s,n.holdPrevious=!1,n.reverse=!1,n.shortestRotation=!1,n.eventThreshold=0,n.alphaAttachmentThreshold=0,n.mixAttachmentThreshold=0,n.mixDrawOrderThreshold=0,n.animationStart=0,n.animationEnd=t.duration,n.animationLast=-1,n.nextAnimationLast=-1,n.delay=0,n.trackTime=0,n.trackLast=-1,n.nextTrackLast=-1,n.trackEnd=Number.MAX_VALUE,n.timeScale=1,n.alpha=1,n.mixTime=0,n.mixDuration=r?this.data.getMix(r.animation,t):0,n.interruptAlpha=1,n.totalAlpha=0,n.mixBlend=2,n}clearNext(e){let t=e.next;for(;t;)this.queue.dispose(t),t=t.next;e.next=null}_animationsChanged(){this.animationsChanged=!1,this.propertyIDs.clear();let e=this.tracks;for(let t=0,s=e.length;t<s;t++){let r=e[t];if(r){for(;r.mixingFrom;)r=r.mixingFrom;do(!r.mixingTo||r.mixBlend!=3)&&this.computeHold(r),r=r.mixingTo;while(r)}}}computeHold(e){let t=e.mixingTo,s=e.animation.timelines,r=e.animation.timelines.length,n=e.timelineMode;n.length=r;let h=e.timelineHoldMix;h.length=0;let o=this.propertyIDs;if(t&&t.holdPrevious){for(let i=0;i<r;i++)n[i]=o.addAll(s[i].getPropertyIds())?ze:Bt;return}e:for(let i=0;i<r;i++){let l=s[i],a=l.getPropertyIds();if(!o.addAll(a))n[i]=Ue;else if(!t||l instanceof we||l instanceof be||l instanceof Fe||!t.animation.hasTimeline(a))n[i]=Pt;else{for(let c=t.mixingTo;c;c=c.mixingTo)if(!c.animation.hasTimeline(a)){if(e.mixDuration>0){n[i]=ps,h[i]=c;continue e}break}n[i]=ze}}}getCurrent(e){return e>=this.tracks.length?null:this.tracks[e]}addListener(e){if(!e)throw new Error("listener cannot be null.");this.listeners.push(e)}removeListener(e){let t=this.listeners.indexOf(e);t>=0&&this.listeners.splice(t,1)}clearListeners(){this.listeners.length=0}clearListenerNotifications(){this.queue.clear()}},Rt=We;B(Rt,"_emptyAnimation",new Oe("<empty>",[],0));var gs=class{animation=null;previous=null;next=null;mixingFrom=null;mixingTo=null;listener=null;trackIndex=0;loop=!1;holdPrevious=!1;reverse=!1;shortestRotation=!1;eventThreshold=0;mixAttachmentThreshold=0;alphaAttachmentThreshold=0;mixDrawOrderThreshold=0;animationStart=0;animationEnd=0;animationLast=0;nextAnimationLast=0;delay=0;trackTime=0;trackLast=0;nextTrackLast=0;trackEnd=0;timeScale=0;alpha=0;mixTime=0;_mixDuration=0;interruptAlpha=0;totalAlpha=0;get mixDuration(){return this._mixDuration}set mixDuration(e){this._mixDuration=e}setMixDurationWithDelay(e,t){this._mixDuration=e,t<=0&&(this.previous!=null?t=Math.max(t+this.previous.getTrackComplete()-e,0):t=0),this.delay=t}mixBlend=2;timelineMode=new Array;timelineHoldMix=new Array;timelinesRotation=new Array;reset(){this.next=null,this.previous=null,this.mixingFrom=null,this.mixingTo=null,this.animation=null,this.listener=null,this.timelineMode.length=0,this.timelineHoldMix.length=0,this.timelinesRotation.length=0}getAnimationTime(){if(this.loop){let e=this.animationEnd-this.animationStart;return e==0?this.animationStart:this.trackTime%e+this.animationStart}return Math.min(this.trackTime+this.animationStart,this.animationEnd)}setAnimationLast(e){this.animationLast=e,this.nextAnimationLast=e}isComplete(){return this.trackTime>=this.animationEnd-this.animationStart}resetRotationDirections(){this.timelinesRotation.length=0}getTrackComplete(){let e=this.animationEnd-this.animationStart;if(e!=0){if(this.loop)return e*(1+(this.trackTime/e|0));if(this.trackTime<e)return e}return this.trackTime}wasApplied(){return this.nextTrackLast!=-1}isNextReady(){return this.next!=null&&this.nextTrackLast-this.next.delay>=0}},xs=class{objects=[];drainDisabled=!1;animState;constructor(e){this.animState=e}start(e){this.objects.push(se.start),this.objects.push(e),this.animState.animationsChanged=!0}interrupt(e){this.objects.push(se.interrupt),this.objects.push(e)}end(e){this.objects.push(se.end),this.objects.push(e),this.animState.animationsChanged=!0}dispose(e){this.objects.push(se.dispose),this.objects.push(e)}complete(e){this.objects.push(se.complete),this.objects.push(e)}event(e,t){this.objects.push(se.event),this.objects.push(e),this.objects.push(t)}drain(){if(this.drainDisabled)return;this.drainDisabled=!0;let e=this.objects,t=this.animState.listeners;for(let s=0;s<e.length;s+=2){let r=e[s],n=e[s+1];switch(r){case se.start:n.listener&&n.listener.start&&n.listener.start(n);for(let o=0;o<t.length;o++){let i=t[o];i.start&&i.start(n)}break;case se.interrupt:n.listener&&n.listener.interrupt&&n.listener.interrupt(n);for(let o=0;o<t.length;o++){let i=t[o];i.interrupt&&i.interrupt(n)}break;case se.end:n.listener&&n.listener.end&&n.listener.end(n);for(let o=0;o<t.length;o++){let i=t[o];i.end&&i.end(n)}case se.dispose:n.listener&&n.listener.dispose&&n.listener.dispose(n);for(let o=0;o<t.length;o++){let i=t[o];i.dispose&&i.dispose(n)}this.animState.trackEntryPool.free(n);break;case se.complete:n.listener&&n.listener.complete&&n.listener.complete(n);for(let o=0;o<t.length;o++){let i=t[o];i.complete&&i.complete(n)}break;case se.event:let h=e[s+++2];n.listener&&n.listener.event&&n.listener.event(n,h);for(let o=0;o<t.length;o++){let i=t[o];i.event&&i.event(n,h)}break}}this.clear(),this.drainDisabled=!1}clear(){this.objects.length=0}},se=(e=>(e[e.start=0]="start",e[e.interrupt=1]="interrupt",e[e.end=2]="end",e[e.dispose=3]="dispose",e[e.complete=4]="complete",e[e.event=5]="event",e))(se||{}),Gs=class{start(e){}interrupt(e){}end(e){}dispose(e){}complete(e){}event(e,t){}},Ue=0,Pt=1,Bt=2,ze=3,ps=4,Vt=1,ws=2,bs=class{skeletonData;animationToMixTime={};defaultMix=0;constructor(e){if(!e)throw new Error("skeletonData cannot be null.");this.skeletonData=e}setMix(e,t,s){let r=this.skeletonData.findAnimation(e);if(!r)throw new Error("Animation not found: "+e);let n=this.skeletonData.findAnimation(t);if(!n)throw new Error("Animation not found: "+t);this.setMixWith(r,n,s)}setMixWith(e,t,s){if(!e)throw new Error("from cannot be null.");if(!t)throw new Error("to cannot be null.");let r=e.name+"."+t.name;this.animationToMixTime[r]=s}getMix(e,t){let s=e.name+"."+t.name,r=this.animationToMixTime[s];return r===void 0?this.defaultMix:r}},Ge=class extends le{color=new D(1,1,1,1);constructor(e){super(e)}copy(){let e=new Ge(this.name);return this.copyTo(e),e.color.setFromColor(this.color),e}},Ee=class extends le{endSlot=null;color=new D(.2275,.2275,.8078,1);constructor(e){super(e)}copy(){let e=new Ee(this.name);return this.copyTo(e),e.endSlot=this.endSlot,e.color.setFromColor(this.color),e}},Lt=class{_image;constructor(e){this._image=e}getImage(){return this._image}},He=(e=>(e[e.Nearest=9728]="Nearest",e[e.Linear=9729]="Linear",e[e.MipMap=9987]="MipMap",e[e.MipMapNearestNearest=9984]="MipMapNearestNearest",e[e.MipMapLinearNearest=9985]="MipMapLinearNearest",e[e.MipMapNearestLinear=9986]="MipMapNearestLinear",e[e.MipMapLinearLinear=9987]="MipMapLinearLinear",e))(He||{}),ys=(e=>(e[e.MirroredRepeat=33648]="MirroredRepeat",e[e.ClampToEdge=33071]="ClampToEdge",e[e.Repeat=10497]="Repeat",e))(ys||{}),vs=class{texture;u=0;v=0;u2=0;v2=0;width=0;height=0;degrees=0;offsetX=0;offsetY=0;originalWidth=0;originalHeight=0},Hs=class extends Lt{setFilters(e,t){}setWraps(e,t){}dispose(){}},Nt=class{pages=new Array;regions=new Array;constructor(e){let t=new $s(e),s=new Array(4),r={};r.size=a=>{a.width=parseInt(s[1]),a.height=parseInt(s[2])},r.format=()=>{},r.filter=a=>{a.minFilter=R.enumValue(He,s[1]),a.magFilter=R.enumValue(He,s[2])},r.repeat=a=>{s[1].indexOf("x")!=-1&&(a.uWrap=10497),s[1].indexOf("y")!=-1&&(a.vWrap=10497)},r.pma=a=>{a.pma=s[1]=="true"};var n={};n.xy=a=>{a.x=parseInt(s[1]),a.y=parseInt(s[2])},n.size=a=>{a.width=parseInt(s[1]),a.height=parseInt(s[2])},n.bounds=a=>{a.x=parseInt(s[1]),a.y=parseInt(s[2]),a.width=parseInt(s[3]),a.height=parseInt(s[4])},n.offset=a=>{a.offsetX=parseInt(s[1]),a.offsetY=parseInt(s[2])},n.orig=a=>{a.originalWidth=parseInt(s[1]),a.originalHeight=parseInt(s[2])},n.offsets=a=>{a.offsetX=parseInt(s[1]),a.offsetY=parseInt(s[2]),a.originalWidth=parseInt(s[3]),a.originalHeight=parseInt(s[4])},n.rotate=a=>{let c=s[1];c=="true"?a.degrees=90:c!="false"&&(a.degrees=parseInt(c))},n.index=a=>{a.index=parseInt(s[1])};let h=t.readLine();for(;h&&h.trim().length==0;)h=t.readLine();for(;!(!h||h.trim().length==0||t.readEntry(s,h)==0);)h=t.readLine();let o=null,i=null,l=null;for(;h!==null;)if(h.trim().length==0)o=null,h=t.readLine();else if(o){let a=new Dt(o,h);for(;;){let c=t.readEntry(s,h=t.readLine());if(c==0)break;let u=n[s[0]];if(u)u(a);else{i||(i=[]),l||(l=[]),i.push(s[0]);let d=[];for(let f=0;f<c;f++)d.push(parseInt(s[f+1]));l.push(d)}}a.originalWidth==0&&a.originalHeight==0&&(a.originalWidth=a.width,a.originalHeight=a.height),i&&i.length>0&&l&&l.length>0&&(a.names=i,a.values=l,i=null,l=null),a.u=a.x/o.width,a.v=a.y/o.height,a.degrees==90?(a.u2=(a.x+a.height)/o.width,a.v2=(a.y+a.width)/o.height):(a.u2=(a.x+a.width)/o.width,a.v2=(a.y+a.height)/o.height),this.regions.push(a)}else{for(o=new Ss(h.trim());t.readEntry(s,h=t.readLine())!=0;){let a=r[s[0]];a&&a(o)}this.pages.push(o)}}findRegion(e){for(let t=0;t<this.regions.length;t++)if(this.regions[t].name==e)return this.regions[t];return null}setTextures(e,t=""){for(let s of this.pages)s.setTexture(e.get(t+s.name))}dispose(){for(let e=0;e<this.pages.length;e++)this.pages[e].texture?.dispose()}},$s=class{lines;index=0;constructor(e){this.lines=e.split(/\r\n|\r|\n/)}readLine(){return this.index>=this.lines.length?null:this.lines[this.index++]}readEntry(e,t){if(!t||(t=t.trim(),t.length==0))return 0;let s=t.indexOf(":");if(s==-1)return 0;e[0]=t.substr(0,s).trim();for(let r=1,n=s+1;;r++){let h=t.indexOf(",",n);if(h==-1)return e[r]=t.substr(n).trim(),r;if(e[r]=t.substr(n,h-n).trim(),n=h+1,r==4)return 4}}},Ss=class{name;minFilter=9728;magFilter=9728;uWrap=33071;vWrap=33071;texture=null;width=0;height=0;pma=!1;regions=new Array;constructor(e){this.name=e}setTexture(e){this.texture=e,e.setFilters(this.minFilter,this.magFilter),e.setWraps(this.uWrap,this.vWrap);for(let t of this.regions)t.texture=e}},Dt=class extends vs{page;name;x=0;y=0;offsetX=0;offsetY=0;originalWidth=0;originalHeight=0;index=0;degrees=0;names=null;values=null;constructor(e,t){super(),this.page=e,this.name=t,e.regions.push(this)}},ye=class extends le{region=null;path;regionUVs=[];uvs=[];triangles=[];color=new D(1,1,1,1);width=0;height=0;hullLength=0;edges=[];parentMesh=null;sequence=null;tempColor=new D(0,0,0,0);constructor(e,t){super(e),this.path=t}updateRegion(){if(!this.region)throw new Error("Region not set.");let e=this.regionUVs;(!this.uvs||this.uvs.length!=e.length)&&(this.uvs=R.newFloatArray(e.length));let t=this.uvs,s=this.uvs.length,r=this.region.u,n=this.region.v,h=0,o=0;if(this.region instanceof Dt){let i=this.region,l=i.page,a=l.width,c=l.height;switch(i.degrees){case 90:r-=(i.originalHeight-i.offsetY-i.height)/a,n-=(i.originalWidth-i.offsetX-i.width)/c,h=i.originalHeight/a,o=i.originalWidth/c;for(let u=0;u<s;u+=2)t[u]=r+e[u+1]*h,t[u+1]=n+(1-e[u])*o;return;case 180:r-=(i.originalWidth-i.offsetX-i.width)/a,n-=i.offsetY/c,h=i.originalWidth/a,o=i.originalHeight/c;for(let u=0;u<s;u+=2)t[u]=r+(1-e[u])*h,t[u+1]=n+(1-e[u+1])*o;return;case 270:r-=i.offsetY/a,n-=i.offsetX/c,h=i.originalHeight/a,o=i.originalWidth/c;for(let u=0;u<s;u+=2)t[u]=r+(1-e[u+1])*h,t[u+1]=n+e[u]*o;return}r-=i.offsetX/a,n-=(i.originalHeight-i.offsetY-i.height)/c,h=i.originalWidth/a,o=i.originalHeight/c}else this.region?(h=this.region.u2-r,o=this.region.v2-n):(r=n=0,h=o=1);for(let i=0;i<s;i+=2)t[i]=r+e[i]*h,t[i+1]=n+e[i+1]*o}getParentMesh(){return this.parentMesh}setParentMesh(e){this.parentMesh=e,e&&(this.bones=e.bones,this.vertices=e.vertices,this.worldVerticesLength=e.worldVerticesLength,this.regionUVs=e.regionUVs,this.triangles=e.triangles,this.hullLength=e.hullLength,this.worldVerticesLength=e.worldVerticesLength)}copy(){if(this.parentMesh)return this.newLinkedMesh();let e=new ye(this.name,this.path);return e.region=this.region,e.color.setFromColor(this.color),this.copyTo(e),e.regionUVs=new Array(this.regionUVs.length),R.arrayCopy(this.regionUVs,0,e.regionUVs,0,this.regionUVs.length),e.uvs=new Array(this.uvs.length),R.arrayCopy(this.uvs,0,e.uvs,0,this.uvs.length),e.triangles=new Array(this.triangles.length),R.arrayCopy(this.triangles,0,e.triangles,0,this.triangles.length),e.hullLength=this.hullLength,e.sequence=this.sequence!=null?this.sequence.copy():null,this.edges&&(e.edges=new Array(this.edges.length),R.arrayCopy(this.edges,0,e.edges,0,this.edges.length)),e.width=this.width,e.height=this.height,e}computeWorldVertices(e,t,s,r,n,h){this.sequence!=null&&this.sequence.apply(e,this),super.computeWorldVertices(e,t,s,r,n,h)}newLinkedMesh(){let e=new ye(this.name,this.path);return e.region=this.region,e.color.setFromColor(this.color),e.timelineAttachment=this.timelineAttachment,e.setParentMesh(this.parentMesh?this.parentMesh:this),e.region!=null&&e.updateRegion(),e}},Ie=class extends le{lengths=[];closed=!1;constantSpeed=!1;color=new D(1,1,1,1);constructor(e){super(e)}copy(){let e=new Ie(this.name);return this.copyTo(e),e.lengths=new Array(this.lengths.length),R.arrayCopy(this.lengths,0,e.lengths,0,this.lengths.length),e.closed=closed,e.constantSpeed=this.constantSpeed,e.color.setFromColor(this.color),e}},Ot=class extends le{x=0;y=0;rotation=0;color=new D(.38,.94,0,1);constructor(e){super(e)}computeWorldPosition(e,t){return t.x=this.x*e.a+this.y*e.b+e.worldX,t.y=this.x*e.c+this.y*e.d+e.worldY,t}computeWorldRotation(e){const t=this.rotation*F.degRad,s=Math.cos(t),r=Math.sin(t),n=s*e.a+r*e.b,h=s*e.c+r*e.d;return F.atan2Deg(h,n)}copy(){let e=new Ot(this.name);return e.x=this.x,e.y=this.y,e.rotation=this.rotation,e.color.setFromColor(this.color),e}},As=class extends it{x=0;y=0;scaleX=1;scaleY=1;rotation=0;width=0;height=0;color=new D(1,1,1,1);path;region=null;sequence=null;offset=R.newFloatArray(8);uvs=R.newFloatArray(8);tempColor=new D(1,1,1,1);constructor(e,t){super(e),this.path=t}updateRegion(){if(!this.region)throw new Error("Region not set.");let e=this.region,t=this.uvs;if(e==null){t[0]=0,t[1]=0,t[2]=0,t[3]=1,t[4]=1,t[5]=1,t[6]=1,t[7]=0;return}let s=this.width/this.region.originalWidth*this.scaleX,r=this.height/this.region.originalHeight*this.scaleY,n=-this.width/2*this.scaleX+this.region.offsetX*s,h=-this.height/2*this.scaleY+this.region.offsetY*r,o=n+this.region.width*s,i=h+this.region.height*r,l=this.rotation*F.degRad,a=Math.cos(l),c=Math.sin(l),u=this.x,d=this.y,f=n*a+u,m=n*c,x=h*a+d,b=h*c,w=o*a+u,g=o*c,p=i*a+d,v=i*c,y=this.offset;y[0]=f-b,y[1]=x+m,y[2]=f-v,y[3]=p+m,y[4]=w-v,y[5]=p+g,y[6]=w-b,y[7]=x+g,e.degrees==90?(t[0]=e.u2,t[1]=e.v2,t[2]=e.u,t[3]=e.v2,t[4]=e.u,t[5]=e.v,t[6]=e.u2,t[7]=e.v):(t[0]=e.u,t[1]=e.v2,t[2]=e.u,t[3]=e.v,t[4]=e.u2,t[5]=e.v,t[6]=e.u2,t[7]=e.v2)}computeWorldVertices(e,t,s,r){this.sequence!=null&&this.sequence.apply(e,this);let n=e.bone,h=this.offset,o=n.worldX,i=n.worldY,l=n.a,a=n.b,c=n.c,u=n.d,d=0,f=0;d=h[0],f=h[1],t[s]=d*l+f*a+o,t[s+1]=d*c+f*u+i,s+=r,d=h[2],f=h[3],t[s]=d*l+f*a+o,t[s+1]=d*c+f*u+i,s+=r,d=h[4],f=h[5],t[s]=d*l+f*a+o,t[s+1]=d*c+f*u+i,s+=r,d=h[6],f=h[7],t[s]=d*l+f*a+o,t[s+1]=d*c+f*u+i}copy(){let e=new As(this.name,this.path);return e.region=this.region,e.x=this.x,e.y=this.y,e.scaleX=this.scaleX,e.scaleY=this.scaleY,e.rotation=this.rotation,e.width=this.width,e.height=this.height,R.arrayCopy(this.uvs,0,e.uvs,0,8),R.arrayCopy(this.offset,0,e.offset,0,8),e.color.setFromColor(this.color),e.sequence=this.sequence!=null?this.sequence.copy():null,e}},U=As;B(U,"X1",0),B(U,"Y1",1),B(U,"C1R",2),B(U,"C1G",3),B(U,"C1B",4),B(U,"C1A",5),B(U,"U1",6),B(U,"V1",7),B(U,"X2",8),B(U,"Y2",9),B(U,"C2R",10),B(U,"C2G",11),B(U,"C2B",12),B(U,"C2A",13),B(U,"U2",14),B(U,"V2",15),B(U,"X3",16),B(U,"Y3",17),B(U,"C3R",18),B(U,"C3G",19),B(U,"C3B",20),B(U,"C3A",21),B(U,"U3",22),B(U,"V3",23),B(U,"X4",24),B(U,"Y4",25),B(U,"C4R",26),B(U,"C4G",27),B(U,"C4B",28),B(U,"C4A",29),B(U,"U4",30),B(U,"V4",31);var Is=class{atlas;constructor(e){this.atlas=e}loadSequence(e,t,s){let r=s.regions;for(let n=0,h=r.length;n<h;n++){let o=s.getPath(t,n),i=this.atlas.findRegion(o);if(i==null)throw new Error("Region not found in atlas: "+o+" (sequence: "+e+")");r[n]=i}}newRegionAttachment(e,t,s,r){let n=new U(t,s);if(r!=null)this.loadSequence(t,s,r);else{let h=this.atlas.findRegion(s);if(!h)throw new Error("Region not found in atlas: "+s+" (region attachment: "+t+")");n.region=h}return n}newMeshAttachment(e,t,s,r){let n=new ye(t,s);if(r!=null)this.loadSequence(t,s,r);else{let h=this.atlas.findRegion(s);if(!h)throw new Error("Region not found in atlas: "+s+" (mesh attachment: "+t+")");n.region=h}return n}newBoundingBoxAttachment(e,t){return new Ge(t)}newPathAttachment(e,t){return new Ie(t)}newPointAttachment(e,t){return new Ot(t)}newClippingAttachment(e,t){return new Ee(t)}},qt=class{index=0;name;parent=null;length=0;x=0;y=0;rotation=0;scaleX=1;scaleY=1;shearX=0;shearY=0;inherit=Re.Normal;skinRequired=!1;color=new D;icon;visible=!1;constructor(e,t,s){if(e<0)throw new Error("index must be >= 0.");if(!t)throw new Error("name cannot be null.");this.index=e,this.name=t,this.parent=s}},Re=(e=>(e[e.Normal=0]="Normal",e[e.OnlyTranslation=1]="OnlyTranslation",e[e.NoRotationOrReflection=2]="NoRotationOrReflection",e[e.NoScale=3]="NoScale",e[e.NoScaleOrReflection=4]="NoScaleOrReflection",e))(Re||{}),_t=class{data;skeleton;parent=null;children=new Array;x=0;y=0;rotation=0;scaleX=0;scaleY=0;shearX=0;shearY=0;ax=0;ay=0;arotation=0;ascaleX=0;ascaleY=0;ashearX=0;ashearY=0;a=0;b=0;c=0;d=0;worldY=0;worldX=0;inherit=0;sorted=!1;active=!1;constructor(e,t,s){if(!e)throw new Error("data cannot be null.");if(!t)throw new Error("skeleton cannot be null.");this.data=e,this.skeleton=t,this.parent=s,this.setToSetupPose()}isActive(){return this.active}update(e){this.updateWorldTransformWith(this.ax,this.ay,this.arotation,this.ascaleX,this.ascaleY,this.ashearX,this.ashearY)}updateWorldTransform(){this.updateWorldTransformWith(this.x,this.y,this.rotation,this.scaleX,this.scaleY,this.shearX,this.shearY)}updateWorldTransformWith(e,t,s,r,n,h,o){this.ax=e,this.ay=t,this.arotation=s,this.ascaleX=r,this.ascaleY=n,this.ashearX=h,this.ashearY=o;let i=this.parent;if(!i){let d=this.skeleton;const f=d.scaleX,m=d.scaleY,x=(s+h)*F.degRad,b=(s+90+o)*F.degRad;this.a=Math.cos(x)*r*f,this.b=Math.cos(b)*n*f,this.c=Math.sin(x)*r*m,this.d=Math.sin(b)*n*m,this.worldX=e*f+d.x,this.worldY=t*m+d.y;return}let l=i.a,a=i.b,c=i.c,u=i.d;switch(this.worldX=l*e+a*t+i.worldX,this.worldY=c*e+u*t+i.worldY,this.inherit){case 0:{const d=(s+h)*F.degRad,f=(s+90+o)*F.degRad,m=Math.cos(d)*r,x=Math.cos(f)*n,b=Math.sin(d)*r,w=Math.sin(f)*n;this.a=l*m+a*b,this.b=l*x+a*w,this.c=c*m+u*b,this.d=c*x+u*w;return}case 1:{const d=(s+h)*F.degRad,f=(s+90+o)*F.degRad;this.a=Math.cos(d)*r,this.b=Math.cos(f)*n,this.c=Math.sin(d)*r,this.d=Math.sin(f)*n;break}case 2:{let d=1/this.skeleton.scaleX,f=1/this.skeleton.scaleY;l*=d,c*=f;let m=l*l+c*c,x=0;m>1e-4?(m=Math.abs(l*u*f-a*d*c)/m,a=c*m,u=l*m,x=Math.atan2(c,l)*F.radDeg):(l=0,c=0,x=90-Math.atan2(u,a)*F.radDeg);const b=(s+h-x)*F.degRad,w=(s+o-x+90)*F.degRad,g=Math.cos(b)*r,p=Math.cos(w)*n,v=Math.sin(b)*r,y=Math.sin(w)*n;this.a=l*g-a*v,this.b=l*p-a*y,this.c=c*g+u*v,this.d=c*p+u*y;break}case 3:case 4:{s*=F.degRad;const d=Math.cos(s),f=Math.sin(s);let m=(l*d+a*f)/this.skeleton.scaleX,x=(c*d+u*f)/this.skeleton.scaleY,b=Math.sqrt(m*m+x*x);b>1e-5&&(b=1/b),m*=b,x*=b,b=Math.sqrt(m*m+x*x),this.inherit==3&&l*u-a*c<0!=(this.skeleton.scaleX<0!=this.skeleton.scaleY<0)&&(b=-b),s=Math.PI/2+Math.atan2(x,m);const w=Math.cos(s)*b,g=Math.sin(s)*b;h*=F.degRad,o=(90+o)*F.degRad;const p=Math.cos(h)*r,v=Math.cos(o)*n,y=Math.sin(h)*r,S=Math.sin(o)*n;this.a=m*p+w*y,this.b=m*v+w*S,this.c=x*p+g*y,this.d=x*v+g*S;break}}this.a*=this.skeleton.scaleX,this.b*=this.skeleton.scaleX,this.c*=this.skeleton.scaleY,this.d*=this.skeleton.scaleY}setToSetupPose(){let e=this.data;this.x=e.x,this.y=e.y,this.rotation=e.rotation,this.scaleX=e.scaleX,this.scaleY=e.scaleY,this.shearX=e.shearX,this.shearY=e.shearY,this.inherit=e.inherit}updateAppliedTransform(){let e=this.parent;if(!e){this.ax=this.worldX-this.skeleton.x,this.ay=this.worldY-this.skeleton.y,this.arotation=Math.atan2(this.c,this.a)*F.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)*F.radDeg;return}let t=e.a,s=e.b,r=e.c,n=e.d,h=1/(t*n-s*r),o=n*h,i=s*h,l=r*h,a=t*h,c=this.worldX-e.worldX,u=this.worldY-e.worldY;this.ax=c*o-u*i,this.ay=u*a-c*l;let d,f,m,x;if(this.inherit==1)d=this.a,f=this.b,m=this.c,x=this.d;else{switch(this.inherit){case 2:{let v=Math.abs(t*n-s*r)/(t*t+r*r);s=-r*this.skeleton.scaleX*v/this.skeleton.scaleY,n=t*this.skeleton.scaleY*v/this.skeleton.scaleX,h=1/(t*n-s*r),o=n*h,i=s*h;break}case 3:case 4:let b=F.cosDeg(this.rotation),w=F.sinDeg(this.rotation);t=(t*b+s*w)/this.skeleton.scaleX,r=(r*b+n*w)/this.skeleton.scaleY;let g=Math.sqrt(t*t+r*r);g>1e-5&&(g=1/g),t*=g,r*=g,g=Math.sqrt(t*t+r*r),this.inherit==3&&h<0!=(this.skeleton.scaleX<0!=this.skeleton.scaleY<0)&&(g=-g);let p=F.PI/2+Math.atan2(r,t);s=Math.cos(p)*g,n=Math.sin(p)*g,h=1/(t*n-s*r),o=n*h,i=s*h,l=r*h,a=t*h}d=o*this.a-i*this.c,f=o*this.b-i*this.d,m=a*this.c-l*this.a,x=a*this.d-l*this.b}if(this.ashearX=0,this.ascaleX=Math.sqrt(d*d+m*m),this.ascaleX>1e-4){let b=d*x-f*m;this.ascaleY=b/this.ascaleX,this.ashearY=-Math.atan2(d*f+m*x,b)*F.radDeg,this.arotation=Math.atan2(m,d)*F.radDeg}else this.ascaleX=0,this.ascaleY=Math.sqrt(f*f+x*x),this.ashearY=0,this.arotation=90-Math.atan2(x,f)*F.radDeg}getWorldRotationX(){return Math.atan2(this.c,this.a)*F.radDeg}getWorldRotationY(){return Math.atan2(this.d,this.b)*F.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)}worldToLocal(e){let t=1/(this.a*this.d-this.b*this.c),s=e.x-this.worldX,r=e.y-this.worldY;return e.x=s*this.d*t-r*this.b*t,e.y=r*this.a*t-s*this.c*t,e}localToWorld(e){let t=e.x,s=e.y;return e.x=t*this.a+s*this.b+this.worldX,e.y=t*this.c+s*this.d+this.worldY,e}worldToParent(e){if(e==null)throw new Error("world cannot be null.");return this.parent==null?e:this.parent.worldToLocal(e)}parentToWorld(e){if(e==null)throw new Error("world cannot be null.");return this.parent==null?e:this.parent.localToWorld(e)}worldToLocalRotation(e){let t=F.sinDeg(e),s=F.cosDeg(e);return Math.atan2(this.a*t-this.c*s,this.d*s-this.b*t)*F.radDeg+this.rotation-this.shearX}localToWorldRotation(e){e-=this.rotation-this.shearX;let t=F.sinDeg(e),s=F.cosDeg(e);return Math.atan2(s*this.c+t*this.d,s*this.a+t*this.b)*F.radDeg}rotateWorld(e){e*=F.degRad;const t=Math.sin(e),s=Math.cos(e),r=this.a,n=this.b;this.a=s*r-t*this.c,this.b=s*n-t*this.d,this.c=t*r+s*this.c,this.d=t*n+s*this.d}},Pe=class{constructor(e,t,s){this.name=e,this.order=t,this.skinRequired=s}},js=class{pathPrefix="";textureLoader;downloader;assets={};errors={};toLoad=0;loaded=0;constructor(e,t="",s=new Cs){this.textureLoader=e,this.pathPrefix=t,this.downloader=s}start(e){return this.toLoad++,this.pathPrefix+e}success(e,t,s){this.toLoad--,this.loaded++,this.assets[t]=s,e&&e(t,s)}error(e,t,s){this.toLoad--,this.loaded++,this.errors[t]=s,e&&e(t,s)}loadAll(){return new Promise((t,s)=>{let r=()=>{if(this.isLoadingComplete()){this.hasErrors()?s(this.errors):t(this);return}requestAnimationFrame(r)};requestAnimationFrame(r)})}setRawDataURI(e,t){this.downloader.rawDataUris[this.pathPrefix+e]=t}loadBinary(e,t=()=>{},s=()=>{}){e=this.start(e),this.downloader.downloadBinary(e,r=>{this.success(t,e,r)},(r,n)=>{this.error(s,e,`Couldn't load binary ${e}: status ${r}, ${n}`)})}loadText(e,t=()=>{},s=()=>{}){e=this.start(e),this.downloader.downloadText(e,r=>{this.success(t,e,r)},(r,n)=>{this.error(s,e,`Couldn't load text ${e}: status ${r}, ${n}`)})}loadJson(e,t=()=>{},s=()=>{}){e=this.start(e),this.downloader.downloadJson(e,r=>{this.success(t,e,r)},(r,n)=>{this.error(s,e,`Couldn't load JSON ${e}: status ${r}, ${n}`)})}loadTexture(e,t=()=>{},s=()=>{}){if(e=this.start(e),!!!(typeof window<"u"&&typeof navigator<"u"&&window.document))fetch(e,{mode:"cors"}).then(h=>h.ok?h.blob():(this.error(s,e,`Couldn't load image: ${e}`),null)).then(h=>h?createImageBitmap(h,{premultiplyAlpha:"none",colorSpaceConversion:"none"}):null).then(h=>{h&&this.success(t,e,this.textureLoader(h))});else{let h=new Image;h.crossOrigin="anonymous",h.onload=()=>{this.success(t,e,this.textureLoader(h))},h.onerror=()=>{this.error(s,e,`Couldn't load image: ${e}`)},this.downloader.rawDataUris[e]&&(e=this.downloader.rawDataUris[e]),h.src=e}}loadTextureAtlas(e,t=()=>{},s=()=>{},r){let n=e.lastIndexOf("/"),h=n>=0?e.substring(0,n+1):"";e=this.start(e),this.downloader.downloadText(e,o=>{try{let i=new Nt(o),l=i.pages.length,a=!1;for(let c of i.pages)this.loadTexture(r?r[c.name]:h+c.name,(u,d)=>{a||(c.setTexture(d),--l==0&&this.success(t,e,i))},(u,d)=>{a||this.error(s,e,`Couldn't load texture atlas ${e} page image: ${u}`),a=!0})}catch(i){this.error(s,e,`Couldn't parse texture atlas ${e}: ${i.message}`)}},(o,i)=>{this.error(s,e,`Couldn't load texture atlas ${e}: status ${o}, ${i}`)})}get(e){return this.assets[this.pathPrefix+e]}require(e){e=this.pathPrefix+e;let t=this.assets[e];if(t)return t;let s=this.errors[e];throw Error("Asset not found: "+e+(s?`
2
- `+s:""))}remove(e){e=this.pathPrefix+e;let t=this.assets[e];return t.dispose&&t.dispose(),delete this.assets[e],t}removeAll(){for(let e in this.assets){let t=this.assets[e];t.dispose&&t.dispose()}this.assets={}}isLoadingComplete(){return this.toLoad==0}getToLoad(){return this.toLoad}getLoaded(){return this.loaded}dispose(){this.removeAll()}hasErrors(){return Object.keys(this.errors).length>0}getErrors(){return this.errors}},Cs=class{callbacks={};rawDataUris={};dataUriToString(e){if(!e.startsWith("data:"))throw new Error("Not a data URI.");let t=e.indexOf("base64,");return t!=-1?(t+=7,atob(e.substr(t))):e.substr(e.indexOf(",")+1)}base64ToUint8Array(e){for(var t=window.atob(e),s=t.length,r=new Uint8Array(s),n=0;n<s;n++)r[n]=t.charCodeAt(n);return r}dataUriToUint8Array(e){if(!e.startsWith("data:"))throw new Error("Not a data URI.");let t=e.indexOf("base64,");if(t==-1)throw new Error("Not a binary data URI.");return t+=7,this.base64ToUint8Array(e.substr(t))}downloadText(e,t,s){if(this.start(e,t,s))return;if(this.rawDataUris[e]){try{let h=this.rawDataUris[e];this.finish(e,200,this.dataUriToString(h))}catch(h){this.finish(e,400,JSON.stringify(h))}return}let r=new XMLHttpRequest;r.overrideMimeType("text/html"),r.open("GET",e,!0);let n=()=>{this.finish(e,r.status,r.responseText)};r.onload=n,r.onerror=n,r.send()}downloadJson(e,t,s){this.downloadText(e,r=>{t(JSON.parse(r))},s)}downloadBinary(e,t,s){if(this.start(e,t,s))return;if(this.rawDataUris[e]){try{let h=this.rawDataUris[e];this.finish(e,200,this.dataUriToUint8Array(h))}catch(h){this.finish(e,400,JSON.stringify(h))}return}let r=new XMLHttpRequest;r.open("GET",e,!0),r.responseType="arraybuffer";let n=()=>{this.finish(e,r.status,r.response)};r.onload=()=>{r.status==200||r.status==0?this.finish(e,200,new Uint8Array(r.response)):n()},r.onerror=n,r.send()}start(e,t,s){let r=this.callbacks[e];try{if(r)return!0;this.callbacks[e]=r=[]}finally{r.push(t,s)}}finish(e,t,s){let r=this.callbacks[e];delete this.callbacks[e];let n=t==200||t==0?[s]:[t,s];for(let h=n.length-1,o=r.length;h<o;h+=2)r[h].apply(null,n)}},Wt=class{data;intValue=0;floatValue=0;stringValue=null;time=0;volume=0;balance=0;constructor(e,t){if(!t)throw new Error("data cannot be null.");this.time=e,this.data=t}},Ut=class{name;intValue=0;floatValue=0;stringValue=null;audioPath=null;volume=0;balance=0;constructor(e){this.name=e}},ks=class{data;bones;target;bendDirection=0;compress=!1;stretch=!1;mix=1;softness=0;active=!1;constructor(e,t){if(!e)throw new Error("data cannot be null.");if(!t)throw new Error("skeleton cannot be null.");this.data=e,this.bones=new Array;for(let r=0;r<e.bones.length;r++){let n=t.findBone(e.bones[r].name);if(!n)throw new Error(`Couldn't find bone ${e.bones[r].name}`);this.bones.push(n)}let s=t.findBone(e.target.name);if(!s)throw new Error(`Couldn't find bone ${e.target.name}`);this.target=s,this.mix=e.mix,this.softness=e.softness,this.bendDirection=e.bendDirection,this.compress=e.compress,this.stretch=e.stretch}isActive(){return this.active}setToSetupPose(){const e=this.data;this.mix=e.mix,this.softness=e.softness,this.bendDirection=e.bendDirection,this.compress=e.compress,this.stretch=e.stretch}update(e){if(this.mix==0)return;let t=this.target,s=this.bones;switch(s.length){case 1:this.apply1(s[0],t.worldX,t.worldY,this.compress,this.stretch,this.data.uniform,this.mix);break;case 2:this.apply2(s[0],s[1],t.worldX,t.worldY,this.bendDirection,this.stretch,this.data.uniform,this.softness,this.mix);break}}apply1(e,t,s,r,n,h,o){let i=e.parent;if(!i)throw new Error("IK bone must have parent.");let l=i.a,a=i.b,c=i.c,u=i.d,d=-e.ashearX-e.arotation,f=0,m=0;switch(e.inherit){case 1:f=(t-e.worldX)*F.signum(e.skeleton.scaleX),m=(s-e.worldY)*F.signum(e.skeleton.scaleY);break;case 2:let w=Math.abs(l*u-a*c)/Math.max(1e-4,l*l+c*c),g=l/e.skeleton.scaleX,p=c/e.skeleton.scaleY;a=-p*w*e.skeleton.scaleX,u=g*w*e.skeleton.scaleY,d+=Math.atan2(p,g)*F.radDeg;default:let v=t-i.worldX,y=s-i.worldY,S=l*u-a*c;Math.abs(S)<=1e-4?(f=0,m=0):(f=(v*u-y*a)/S-e.ax,m=(y*l-v*c)/S-e.ay)}d+=Math.atan2(m,f)*F.radDeg,e.ascaleX<0&&(d+=180),d>180?d-=360:d<-180&&(d+=360);let x=e.ascaleX,b=e.ascaleY;if(r||n){switch(e.inherit){case 3:case 4:f=t-e.worldX,m=s-e.worldY}const w=e.data.length*x;if(w>1e-4){const g=f*f+m*m;if(r&&g<w*w||n&&g>w*w){const p=(Math.sqrt(g)/w-1)*o+1;x*=p,h&&(b*=p)}}}e.updateWorldTransformWith(e.ax,e.ay,e.arotation+d*o,x,b,e.ashearX,e.ashearY)}apply2(e,t,s,r,n,h,o,i,l){if(e.inherit!=0||t.inherit!=0)return;let a=e.ax,c=e.ay,u=e.ascaleX,d=e.ascaleY,f=u,m=d,x=t.ascaleX,b=0,w=0,g=0;u<0?(u=-u,b=180,g=-1):(b=0,g=1),d<0&&(d=-d,g=-g),x<0?(x=-x,w=180):w=0;let p=t.ax,v=0,y=0,S=0,A=e.a,k=e.b,Y=e.c,M=e.d,E=Math.abs(u-d)<=1e-4;!E||h?(v=0,y=A*p+e.worldX,S=Y*p+e.worldY):(v=t.ay,y=A*p+k*v+e.worldX,S=Y*p+M*v+e.worldY);let X=e.parent;if(!X)throw new Error("IK parent must itself have a parent.");A=X.a,k=X.b,Y=X.c,M=X.d;let C=A*M-k*Y,T=y-X.worldX,P=S-X.worldY;C=Math.abs(C)<=1e-4?0:1/C;let N=(T*M-P*k)*C-a,q=(P*A-T*Y)*C-c,L=Math.sqrt(N*N+q*q),G=t.data.length*x,$,j;if(L<1e-4){this.apply1(e,s,r,!1,h,!1,l),t.updateWorldTransformWith(p,v,0,t.ascaleX,t.ascaleY,t.ashearX,t.ashearY);return}T=s-X.worldX,P=r-X.worldY;let V=(T*M-P*k)*C-a,_=(P*A-T*Y)*C-c,W=V*V+_*_;if(i!=0){i*=u*(x+1)*.5;let J=Math.sqrt(W),Q=J-L-G*u+i;if(Q>0){let Z=Math.min(1,Q/(i*2))-1;Z=(Q-i*(1-Z*Z))/J,V-=Z*V,_-=Z*_,W=V*V+_*_}}e:if(E){G*=u;let J=(W-L*L-G*G)/(2*L*G);J<-1?(J=-1,j=Math.PI*n):J>1?(J=1,j=0,h&&(A=(Math.sqrt(W)/(L+G)-1)*l+1,f*=A,o&&(m*=A))):j=Math.acos(J)*n,A=L+G*J,k=G*Math.sin(j),$=Math.atan2(_*A-V*k,V*A+_*k)}else{A=u*G,k=d*G;let J=A*A,Q=k*k,Z=Math.atan2(_,V);Y=Q*L*L+J*W-J*Q;let fe=-2*Q*L,Me=Q-J;if(M=fe*fe-4*Me*Y,M>=0){let ve=Math.sqrt(M);fe<0&&(ve=-ve),ve=-(fe+ve)*.5;let Ye=ve/Me,rs=Y/ve,Le=Math.abs(Ye)<Math.abs(rs)?Ye:rs;if(Ye=W-Le*Le,Ye>=0){P=Math.sqrt(Ye)*n,$=Z-Math.atan2(P,Le),j=Math.atan2(P/d,(Le-L)/u);break e}}let es=F.PI,Be=L-A,et=Be*Be,ts=0,ss=0,Ve=L+A,tt=Ve*Ve,is=0;Y=-A*L/(J-Q),Y>=-1&&Y<=1&&(Y=Math.acos(Y),T=A*Math.cos(Y)+L,P=k*Math.sin(Y),M=T*T+P*P,M<et&&(es=Y,et=M,Be=T,ts=P),M>tt&&(ss=Y,tt=M,Ve=T,is=P)),W<=(et+tt)*.5?($=Z-Math.atan2(ts*n,Be),j=es*n):($=Z-Math.atan2(is*n,Ve),j=ss*n)}let re=Math.atan2(v,p)*g,te=e.arotation;$=($-re)*F.radDeg+b-te,$>180?$-=360:$<-180&&($+=360),e.updateWorldTransformWith(a,c,te+$*l,f,m,0,0),te=t.arotation,j=((j+re)*F.radDeg-t.ashearX)*g+w-te,j>180?j-=360:j<-180&&(j+=360),t.updateWorldTransformWith(p,v,te+j*l,t.ascaleX,t.ascaleY,t.ashearX,t.ashearY)}},zt=class extends Pe{bones=new Array;_target=null;set target(e){this._target=e}get target(){if(this._target)return this._target;throw new Error("BoneData not set.")}bendDirection=0;compress=!1;stretch=!1;uniform=!1;mix=0;softness=0;constructor(e){super(e,0,!1)}},Gt=class extends Pe{bones=new Array;_target=null;set target(e){this._target=e}get target(){if(this._target)return this._target;throw new Error("SlotData not set.")}positionMode=$e.Fixed;spacingMode=je.Fixed;rotateMode=Ke.Chain;offsetRotation=0;position=0;spacing=0;mixRotate=0;mixX=0;mixY=0;constructor(e){super(e,0,!1)}},$e=(e=>(e[e.Fixed=0]="Fixed",e[e.Percent=1]="Percent",e))($e||{}),je=(e=>(e[e.Length=0]="Length",e[e.Fixed=1]="Fixed",e[e.Percent=2]="Percent",e[e.Proportional=3]="Proportional",e))(je||{}),Ke=(e=>(e[e.Tangent=0]="Tangent",e[e.Chain=1]="Chain",e[e.ChainScale=2]="ChainScale",e))(Ke||{}),ge=class{data;bones;target;position=0;spacing=0;mixRotate=0;mixX=0;mixY=0;spaces=new Array;positions=new Array;world=new Array;curves=new Array;lengths=new Array;segments=new Array;active=!1;constructor(e,t){if(!e)throw new Error("data cannot be null.");if(!t)throw new Error("skeleton cannot be null.");this.data=e,this.bones=new Array;for(let r=0,n=e.bones.length;r<n;r++){let h=t.findBone(e.bones[r].name);if(!h)throw new Error(`Couldn't find bone ${e.bones[r].name}.`);this.bones.push(h)}let s=t.findSlot(e.target.name);if(!s)throw new Error(`Couldn't find target bone ${e.target.name}`);this.target=s,this.position=e.position,this.spacing=e.spacing,this.mixRotate=e.mixRotate,this.mixX=e.mixX,this.mixY=e.mixY}isActive(){return this.active}setToSetupPose(){const e=this.data;this.position=e.position,this.spacing=e.spacing,this.mixRotate=e.mixRotate,this.mixX=e.mixX,this.mixY=e.mixY}update(e){let t=this.target.getAttachment();if(!(t instanceof Ie))return;let s=this.mixRotate,r=this.mixX,n=this.mixY;if(s==0&&r==0&&n==0)return;let h=this.data,o=h.rotateMode==0,i=h.rotateMode==2,l=this.bones,a=l.length,c=o?a:a+1,u=R.setArraySize(this.spaces,c),d=i?this.lengths=R.setArraySize(this.lengths,a):[],f=this.spacing;switch(h.spacingMode){case 2:if(i)for(let y=0,S=c-1;y<S;y++){let A=l[y],k=A.data.length,Y=k*A.a,M=k*A.c;d[y]=Math.sqrt(Y*Y+M*M)}R.arrayFill(u,1,c,f);break;case 3:let p=0;for(let y=0,S=c-1;y<S;){let A=l[y],k=A.data.length;if(k<ge.epsilon)i&&(d[y]=0),u[++y]=f;else{let Y=k*A.a,M=k*A.c,E=Math.sqrt(Y*Y+M*M);i&&(d[y]=E),u[++y]=E,p+=E}}if(p>0){p=c/p*f;for(let y=1;y<c;y++)u[y]*=p}break;default:let v=h.spacingMode==0;for(let y=0,S=c-1;y<S;){let A=l[y],k=A.data.length;if(k<ge.epsilon)i&&(d[y]=0),u[++y]=f;else{let Y=k*A.a,M=k*A.c,E=Math.sqrt(Y*Y+M*M);i&&(d[y]=E),u[++y]=(v?k+f:f)*E/k}}}let m=this.computeWorldPositions(t,c,o),x=m[0],b=m[1],w=h.offsetRotation,g=!1;if(w==0)g=h.rotateMode==1;else{g=!1;let p=this.target.bone;w*=p.a*p.d-p.b*p.c>0?F.degRad:-F.degRad}for(let p=0,v=3;p<a;p++,v+=3){let y=l[p];y.worldX+=(x-y.worldX)*r,y.worldY+=(b-y.worldY)*n;let S=m[v],A=m[v+1],k=S-x,Y=A-b;if(i){let M=d[p];if(M!=0){let E=(Math.sqrt(k*k+Y*Y)/M-1)*s+1;y.a*=E,y.c*=E}}if(x=S,b=A,s>0){let M=y.a,E=y.b,X=y.c,C=y.d,T=0,P=0,N=0;if(o?T=m[v-1]:u[p+1]==0?T=m[v+2]:T=Math.atan2(Y,k),T-=Math.atan2(X,M),g){P=Math.cos(T),N=Math.sin(T);let q=y.data.length;x+=(q*(P*M-N*X)-k)*s,b+=(q*(N*M+P*X)-Y)*s}else T+=w;T>F.PI?T-=F.PI2:T<-F.PI&&(T+=F.PI2),T*=s,P=Math.cos(T),N=Math.sin(T),y.a=P*M-N*X,y.b=P*E-N*C,y.c=N*M+P*X,y.d=N*E+P*C}y.updateAppliedTransform()}}computeWorldPositions(e,t,s){let r=this.target,n=this.position,h=this.spaces,o=R.setArraySize(this.positions,t*3+2),i=this.world,l=e.closed,a=e.worldVerticesLength,c=a/6,u=ge.NONE;if(!e.constantSpeed){let q=e.lengths;c-=l?1:2;let L=q[c];this.data.positionMode==1&&(n*=L);let G;switch(this.data.spacingMode){case 2:G=L;break;case 3:G=L/t;break;default:G=1}i=R.setArraySize(this.world,8);for(let $=0,j=0,V=0;$<t;$++,j+=3){let _=h[$]*G;n+=_;let W=n;if(l)W%=L,W<0&&(W+=L),V=0;else if(W<0){u!=ge.BEFORE&&(u=ge.BEFORE,e.computeWorldVertices(r,2,4,i,0,2)),this.addBeforePosition(W,i,0,o,j);continue}else if(W>L){u!=ge.AFTER&&(u=ge.AFTER,e.computeWorldVertices(r,a-6,4,i,0,2)),this.addAfterPosition(W-L,i,0,o,j);continue}for(;;V++){let re=q[V];if(!(W>re)){if(V==0)W/=re;else{let te=q[V-1];W=(W-te)/(re-te)}break}}V!=u&&(u=V,l&&V==c?(e.computeWorldVertices(r,a-4,4,i,0,2),e.computeWorldVertices(r,0,4,i,4,2)):e.computeWorldVertices(r,V*6+2,8,i,0,2)),this.addCurvePosition(W,i[0],i[1],i[2],i[3],i[4],i[5],i[6],i[7],o,j,s||$>0&&_==0)}return o}l?(a+=2,i=R.setArraySize(this.world,a),e.computeWorldVertices(r,2,a-4,i,0,2),e.computeWorldVertices(r,0,2,i,a-4,2),i[a-2]=i[0],i[a-1]=i[1]):(c--,a-=4,i=R.setArraySize(this.world,a),e.computeWorldVertices(r,2,a,i,0,2));let d=R.setArraySize(this.curves,c),f=0,m=i[0],x=i[1],b=0,w=0,g=0,p=0,v=0,y=0,S=0,A=0,k=0,Y=0,M=0,E=0,X=0,C=0;for(let q=0,L=2;q<c;q++,L+=6)b=i[L],w=i[L+1],g=i[L+2],p=i[L+3],v=i[L+4],y=i[L+5],S=(m-b*2+g)*.1875,A=(x-w*2+p)*.1875,k=((b-g)*3-m+v)*.09375,Y=((w-p)*3-x+y)*.09375,M=S*2+k,E=A*2+Y,X=(b-m)*.75+S+k*.16666667,C=(w-x)*.75+A+Y*.16666667,f+=Math.sqrt(X*X+C*C),X+=M,C+=E,M+=k,E+=Y,f+=Math.sqrt(X*X+C*C),X+=M,C+=E,f+=Math.sqrt(X*X+C*C),X+=M+k,C+=E+Y,f+=Math.sqrt(X*X+C*C),d[q]=f,m=v,x=y;this.data.positionMode==1&&(n*=f);let T;switch(this.data.spacingMode){case 2:T=f;break;case 3:T=f/t;break;default:T=1}let P=this.segments,N=0;for(let q=0,L=0,G=0,$=0;q<t;q++,L+=3){let j=h[q]*T;n+=j;let V=n;if(l)V%=f,V<0&&(V+=f),G=0;else if(V<0){this.addBeforePosition(V,i,0,o,L);continue}else if(V>f){this.addAfterPosition(V-f,i,a-4,o,L);continue}for(;;G++){let _=d[G];if(!(V>_)){if(G==0)V/=_;else{let W=d[G-1];V=(V-W)/(_-W)}break}}if(G!=u){u=G;let _=G*6;for(m=i[_],x=i[_+1],b=i[_+2],w=i[_+3],g=i[_+4],p=i[_+5],v=i[_+6],y=i[_+7],S=(m-b*2+g)*.03,A=(x-w*2+p)*.03,k=((b-g)*3-m+v)*.006,Y=((w-p)*3-x+y)*.006,M=S*2+k,E=A*2+Y,X=(b-m)*.3+S+k*.16666667,C=(w-x)*.3+A+Y*.16666667,N=Math.sqrt(X*X+C*C),P[0]=N,_=1;_<8;_++)X+=M,C+=E,M+=k,E+=Y,N+=Math.sqrt(X*X+C*C),P[_]=N;X+=M,C+=E,N+=Math.sqrt(X*X+C*C),P[8]=N,X+=M+k,C+=E+Y,N+=Math.sqrt(X*X+C*C),P[9]=N,$=0}for(V*=N;;$++){let _=P[$];if(!(V>_)){if($==0)V/=_;else{let W=P[$-1];V=$+(V-W)/(_-W)}break}}this.addCurvePosition(V*.1,m,x,b,w,g,p,v,y,o,L,s||q>0&&j==0)}return o}addBeforePosition(e,t,s,r,n){let h=t[s],o=t[s+1],i=t[s+2]-h,l=t[s+3]-o,a=Math.atan2(l,i);r[n]=h+e*Math.cos(a),r[n+1]=o+e*Math.sin(a),r[n+2]=a}addAfterPosition(e,t,s,r,n){let h=t[s+2],o=t[s+3],i=h-t[s],l=o-t[s+1],a=Math.atan2(l,i);r[n]=h+e*Math.cos(a),r[n+1]=o+e*Math.sin(a),r[n+2]=a}addCurvePosition(e,t,s,r,n,h,o,i,l,a,c,u){if(e==0||isNaN(e)){a[c]=t,a[c+1]=s,a[c+2]=Math.atan2(n-s,r-t);return}let d=e*e,f=d*e,m=1-e,x=m*m,b=x*m,w=m*e,g=w*3,p=m*g,v=g*e,y=t*b+r*p+h*v+i*f,S=s*b+n*p+o*v+l*f;a[c]=y,a[c+1]=S,u&&(e<.001?a[c+2]=Math.atan2(n-s,r-t):a[c+2]=Math.atan2(S-(s*x+n*w*2+o*d),y-(t*x+r*w*2+h*d)))}},Ce=ge;B(Ce,"NONE",-1),B(Ce,"BEFORE",-2),B(Ce,"AFTER",-3),B(Ce,"epsilon",1e-5);var Ks=class{data;_bone=null;set bone(e){this._bone=e}get bone(){if(this._bone)return this._bone;throw new Error("Bone not set.")}inertia=0;strength=0;damping=0;massInverse=0;wind=0;gravity=0;mix=0;_reset=!0;ux=0;uy=0;cx=0;cy=0;tx=0;ty=0;xOffset=0;xVelocity=0;yOffset=0;yVelocity=0;rotateOffset=0;rotateVelocity=0;scaleOffset=0;scaleVelocity=0;active=!1;skeleton;remaining=0;lastTime=0;constructor(e,t){this.data=e,this.skeleton=t,this.bone=t.bones[e.bone.index],this.inertia=e.inertia,this.strength=e.strength,this.damping=e.damping,this.massInverse=e.massInverse,this.wind=e.wind,this.gravity=e.gravity,this.mix=e.mix}reset(){this.remaining=0,this.lastTime=this.skeleton.time,this._reset=!0,this.xOffset=0,this.xVelocity=0,this.yOffset=0,this.yVelocity=0,this.rotateOffset=0,this.rotateVelocity=0,this.scaleOffset=0,this.scaleVelocity=0}setToSetupPose(){const e=this.data;this.inertia=e.inertia,this.strength=e.strength,this.damping=e.damping,this.massInverse=e.massInverse,this.wind=e.wind,this.gravity=e.gravity,this.mix=e.mix}isActive(){return this.active}update(e){const t=this.mix;if(t==0)return;const s=this.data.x>0,r=this.data.y>0,n=this.data.rotate>0||this.data.shearX>0,h=this.data.scaleX>0,o=this.bone,i=o.data.length;switch(e){case 0:return;case 1:this.reset();case 2:const l=this.skeleton,a=Math.max(this.skeleton.time-this.lastTime,0);this.remaining+=a,this.lastTime=l.time;const c=o.worldX,u=o.worldY;if(this._reset)this._reset=!1,this.ux=c,this.uy=u;else{let d=this.remaining,f=this.inertia,m=this.data.step,x=this.skeleton.data.referenceScale,b=-1,w=this.data.limit*a,g=w*Math.abs(l.scaleY);if(w*=Math.abs(l.scaleX),s||r){if(s){const p=(this.ux-c)*f;this.xOffset+=p>w?w:p<-w?-w:p,this.ux=c}if(r){const p=(this.uy-u)*f;this.yOffset+=p>g?g:p<-g?-g:p,this.uy=u}if(d>=m){b=Math.pow(this.damping,60*m);const p=this.massInverse*m,v=this.strength,y=this.wind*x*l.scaleX,S=this.gravity*x*l.scaleY;do s&&(this.xVelocity+=(y-this.xOffset*v)*p,this.xOffset+=this.xVelocity*m,this.xVelocity*=b),r&&(this.yVelocity-=(S+this.yOffset*v)*p,this.yOffset+=this.yVelocity*m,this.yVelocity*=b),d-=m;while(d>=m)}s&&(o.worldX+=this.xOffset*t*this.data.x),r&&(o.worldY+=this.yOffset*t*this.data.y)}if(n||h){let p=Math.atan2(o.c,o.a),v=0,y=0,S=0,A=this.cx-o.worldX,k=this.cy-o.worldY;if(A>w?A=w:A<-w&&(A=-w),k>g?k=g:k<-g&&(k=-g),n){S=(this.data.rotate+this.data.shearX)*t;let Y=Math.atan2(k+this.ty,A+this.tx)-p-this.rotateOffset*S;this.rotateOffset+=(Y-Math.ceil(Y*F.invPI2-.5)*F.PI2)*f,Y=this.rotateOffset*S+p,v=Math.cos(Y),y=Math.sin(Y),h&&(Y=i*o.getWorldScaleX(),Y>0&&(this.scaleOffset+=(A*v+k*y)*f/Y))}else{v=Math.cos(p),y=Math.sin(p);const Y=i*o.getWorldScaleX();Y>0&&(this.scaleOffset+=(A*v+k*y)*f/Y)}if(d=this.remaining,d>=m){b==-1&&(b=Math.pow(this.damping,60*m));const Y=this.massInverse*m,M=this.strength,E=this.wind,X=ke.yDown?-this.gravity:this.gravity,C=i/x;for(;;)if(d-=m,h&&(this.scaleVelocity+=(E*v-X*y-this.scaleOffset*M)*Y,this.scaleOffset+=this.scaleVelocity*m,this.scaleVelocity*=b),n){if(this.rotateVelocity-=((E*y+X*v)*C+this.rotateOffset*M)*Y,this.rotateOffset+=this.rotateVelocity*m,this.rotateVelocity*=b,d<m)break;const T=this.rotateOffset*S+p;v=Math.cos(T),y=Math.sin(T)}else if(d<m)break}}this.remaining=d}this.cx=o.worldX,this.cy=o.worldY;break;case 3:s&&(o.worldX+=this.xOffset*t*this.data.x),r&&(o.worldY+=this.yOffset*t*this.data.y)}if(n){let l=this.rotateOffset*t,a=0,c=0,u=0;if(this.data.shearX>0){let d=0;this.data.rotate>0&&(d=l*this.data.rotate,a=Math.sin(d),c=Math.cos(d),u=o.b,o.b=c*u-a*o.d,o.d=a*u+c*o.d),d+=l*this.data.shearX,a=Math.sin(d),c=Math.cos(d),u=o.a,o.a=c*u-a*o.c,o.c=a*u+c*o.c}else l*=this.data.rotate,a=Math.sin(l),c=Math.cos(l),u=o.a,o.a=c*u-a*o.c,o.c=a*u+c*o.c,u=o.b,o.b=c*u-a*o.d,o.d=a*u+c*o.d}if(h){const l=1+this.scaleOffset*t*this.data.scaleX;o.a*=l,o.c*=l}e!=3&&(this.tx=i*o.a,this.ty=i*o.c),o.updateAppliedTransform()}translate(e,t){this.ux-=e,this.uy-=t,this.cx-=e,this.cy-=t}rotate(e,t,s){const r=s*F.degRad,n=Math.cos(r),h=Math.sin(r),o=this.cx-e,i=this.cy-t;this.translate(o*n-i*h-o,o*h+i*n-i)}},Ms=class{data;bone;color;darkColor=null;attachment=null;attachmentState=0;sequenceIndex=-1;deform=new Array;constructor(e,t){if(!e)throw new Error("data cannot be null.");if(!t)throw new Error("bone cannot be null.");this.data=e,this.bone=t,this.color=new D,this.darkColor=e.darkColor?new D:null,this.setToSetupPose()}getSkeleton(){return this.bone.skeleton}getAttachment(){return this.attachment}setAttachment(e){this.attachment!=e&&((!(e instanceof le)||!(this.attachment instanceof le)||e.timelineAttachment!=this.attachment.timelineAttachment)&&(this.deform.length=0),this.attachment=e,this.sequenceIndex=-1)}setToSetupPose(){this.color.setFromColor(this.data.color),this.darkColor&&this.darkColor.setFromColor(this.data.darkColor),this.data.attachmentName?(this.attachment=null,this.setAttachment(this.bone.skeleton.getAttachment(this.data.index,this.data.attachmentName))):this.attachment=null}},Ys=class{data;bones;target;mixRotate=0;mixX=0;mixY=0;mixScaleX=0;mixScaleY=0;mixShearY=0;temp=new Ne;active=!1;constructor(e,t){if(!e)throw new Error("data cannot be null.");if(!t)throw new Error("skeleton cannot be null.");this.data=e,this.bones=new Array;for(let r=0;r<e.bones.length;r++){let n=t.findBone(e.bones[r].name);if(!n)throw new Error(`Couldn't find bone ${e.bones[r].name}.`);this.bones.push(n)}let s=t.findBone(e.target.name);if(!s)throw new Error(`Couldn't find target bone ${e.target.name}.`);this.target=s,this.mixRotate=e.mixRotate,this.mixX=e.mixX,this.mixY=e.mixY,this.mixScaleX=e.mixScaleX,this.mixScaleY=e.mixScaleY,this.mixShearY=e.mixShearY}isActive(){return this.active}setToSetupPose(){const e=this.data;this.mixRotate=e.mixRotate,this.mixX=e.mixX,this.mixY=e.mixY,this.mixScaleX=e.mixScaleX,this.mixScaleY=e.mixScaleY,this.mixShearY=e.mixShearY}update(e){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 e=this.mixRotate,t=this.mixX,s=this.mixY,r=this.mixScaleX,n=this.mixScaleY,h=this.mixShearY,o=t!=0||s!=0,i=this.target,l=i.a,a=i.b,c=i.c,u=i.d,d=l*u-a*c>0?F.degRad:-F.degRad,f=this.data.offsetRotation*d,m=this.data.offsetShearY*d,x=this.bones;for(let b=0,w=x.length;b<w;b++){let g=x[b];if(e!=0){let p=g.a,v=g.b,y=g.c,S=g.d,A=Math.atan2(c,l)-Math.atan2(y,p)+f;A>F.PI?A-=F.PI2:A<-F.PI&&(A+=F.PI2),A*=e;let k=Math.cos(A),Y=Math.sin(A);g.a=k*p-Y*y,g.b=k*v-Y*S,g.c=Y*p+k*y,g.d=Y*v+k*S}if(o){let p=this.temp;i.localToWorld(p.set(this.data.offsetX,this.data.offsetY)),g.worldX+=(p.x-g.worldX)*t,g.worldY+=(p.y-g.worldY)*s}if(r!=0){let p=Math.sqrt(g.a*g.a+g.c*g.c);p!=0&&(p=(p+(Math.sqrt(l*l+c*c)-p+this.data.offsetScaleX)*r)/p),g.a*=p,g.c*=p}if(n!=0){let p=Math.sqrt(g.b*g.b+g.d*g.d);p!=0&&(p=(p+(Math.sqrt(a*a+u*u)-p+this.data.offsetScaleY)*n)/p),g.b*=p,g.d*=p}if(h>0){let p=g.b,v=g.d,y=Math.atan2(v,p),S=Math.atan2(u,a)-Math.atan2(c,l)-(y-Math.atan2(g.c,g.a));S>F.PI?S-=F.PI2:S<-F.PI&&(S+=F.PI2),S=y+(S+m)*h;let A=Math.sqrt(p*p+v*v);g.b=Math.cos(S)*A,g.d=Math.sin(S)*A}g.updateAppliedTransform()}}applyRelativeWorld(){let e=this.mixRotate,t=this.mixX,s=this.mixY,r=this.mixScaleX,n=this.mixScaleY,h=this.mixShearY,o=t!=0||s!=0,i=this.target,l=i.a,a=i.b,c=i.c,u=i.d,d=l*u-a*c>0?F.degRad:-F.degRad,f=this.data.offsetRotation*d,m=this.data.offsetShearY*d,x=this.bones;for(let b=0,w=x.length;b<w;b++){let g=x[b];if(e!=0){let p=g.a,v=g.b,y=g.c,S=g.d,A=Math.atan2(c,l)+f;A>F.PI?A-=F.PI2:A<-F.PI&&(A+=F.PI2),A*=e;let k=Math.cos(A),Y=Math.sin(A);g.a=k*p-Y*y,g.b=k*v-Y*S,g.c=Y*p+k*y,g.d=Y*v+k*S}if(o){let p=this.temp;i.localToWorld(p.set(this.data.offsetX,this.data.offsetY)),g.worldX+=p.x*t,g.worldY+=p.y*s}if(r!=0){let p=(Math.sqrt(l*l+c*c)-1+this.data.offsetScaleX)*r+1;g.a*=p,g.c*=p}if(n!=0){let p=(Math.sqrt(a*a+u*u)-1+this.data.offsetScaleY)*n+1;g.b*=p,g.d*=p}if(h>0){let p=Math.atan2(u,a)-Math.atan2(c,l);p>F.PI?p-=F.PI2:p<-F.PI&&(p+=F.PI2);let v=g.b,y=g.d;p=Math.atan2(y,v)+(p-F.PI/2+m)*h;let S=Math.sqrt(v*v+y*y);g.b=Math.cos(p)*S,g.d=Math.sin(p)*S}g.updateAppliedTransform()}}applyAbsoluteLocal(){let e=this.mixRotate,t=this.mixX,s=this.mixY,r=this.mixScaleX,n=this.mixScaleY,h=this.mixShearY,o=this.target,i=this.bones;for(let l=0,a=i.length;l<a;l++){let c=i[l],u=c.arotation;e!=0&&(u+=(o.arotation-u+this.data.offsetRotation)*e);let d=c.ax,f=c.ay;d+=(o.ax-d+this.data.offsetX)*t,f+=(o.ay-f+this.data.offsetY)*s;let m=c.ascaleX,x=c.ascaleY;r!=0&&m!=0&&(m=(m+(o.ascaleX-m+this.data.offsetScaleX)*r)/m),n!=0&&x!=0&&(x=(x+(o.ascaleY-x+this.data.offsetScaleY)*n)/x);let b=c.ashearY;h!=0&&(b+=(o.ashearY-b+this.data.offsetShearY)*h),c.updateWorldTransformWith(d,f,u,m,x,c.ashearX,b)}}applyRelativeLocal(){let e=this.mixRotate,t=this.mixX,s=this.mixY,r=this.mixScaleX,n=this.mixScaleY,h=this.mixShearY,o=this.target,i=this.bones;for(let l=0,a=i.length;l<a;l++){let c=i[l],u=c.arotation+(o.arotation+this.data.offsetRotation)*e,d=c.ax+(o.ax+this.data.offsetX)*t,f=c.ay+(o.ay+this.data.offsetY)*s,m=c.ascaleX*((o.ascaleX-1+this.data.offsetScaleX)*r+1),x=c.ascaleY*((o.ascaleY-1+this.data.offsetScaleY)*n+1),b=c.ashearY+(o.ashearY+this.data.offsetShearY)*h;c.updateWorldTransformWith(d,f,u,m,x,c.ashearX,b)}}},Ht=class{data;bones;slots;drawOrder;ikConstraints;transformConstraints;pathConstraints;physicsConstraints;_updateCache=new Array;skin=null;color;scaleX=1;_scaleY=1;get scaleY(){return Ht.yDown?-this._scaleY:this._scaleY}set scaleY(e){this._scaleY=e}x=0;y=0;time=0;constructor(e){if(!e)throw new Error("data cannot be null.");this.data=e,this.bones=new Array;for(let t=0;t<e.bones.length;t++){let s=e.bones[t],r;if(!s.parent)r=new _t(s,this,null);else{let n=this.bones[s.parent.index];r=new _t(s,this,n),n.children.push(r)}this.bones.push(r)}this.slots=new Array,this.drawOrder=new Array;for(let t=0;t<e.slots.length;t++){let s=e.slots[t],r=this.bones[s.boneData.index],n=new Ms(s,r);this.slots.push(n),this.drawOrder.push(n)}this.ikConstraints=new Array;for(let t=0;t<e.ikConstraints.length;t++){let s=e.ikConstraints[t];this.ikConstraints.push(new ks(s,this))}this.transformConstraints=new Array;for(let t=0;t<e.transformConstraints.length;t++){let s=e.transformConstraints[t];this.transformConstraints.push(new Ys(s,this))}this.pathConstraints=new Array;for(let t=0;t<e.pathConstraints.length;t++){let s=e.pathConstraints[t];this.pathConstraints.push(new Ce(s,this))}this.physicsConstraints=new Array;for(let t=0;t<e.physicsConstraints.length;t++){let s=e.physicsConstraints[t];this.physicsConstraints.push(new Ks(s,this))}this.color=new D(1,1,1,1),this.updateCache()}updateCache(){let e=this._updateCache;e.length=0;let t=this.bones;for(let u=0,d=t.length;u<d;u++){let f=t[u];f.sorted=f.data.skinRequired,f.active=!f.sorted}if(this.skin){let u=this.skin.bones;for(let d=0,f=this.skin.bones.length;d<f;d++){let m=this.bones[u[d].index];do m.sorted=!1,m.active=!0,m=m.parent;while(m)}}let s=this.ikConstraints,r=this.transformConstraints,n=this.pathConstraints,h=this.physicsConstraints,o=s.length,i=r.length,l=n.length,a=this.physicsConstraints.length,c=o+i+l+a;e:for(let u=0;u<c;u++){for(let d=0;d<o;d++){let f=s[d];if(f.data.order==u){this.sortIkConstraint(f);continue e}}for(let d=0;d<i;d++){let f=r[d];if(f.data.order==u){this.sortTransformConstraint(f);continue e}}for(let d=0;d<l;d++){let f=n[d];if(f.data.order==u){this.sortPathConstraint(f);continue e}}for(let d=0;d<a;d++){const f=h[d];if(f.data.order==u){this.sortPhysicsConstraint(f);continue e}}}for(let u=0,d=t.length;u<d;u++)this.sortBone(t[u])}sortIkConstraint(e){if(e.active=e.target.isActive()&&(!e.data.skinRequired||this.skin&&R.contains(this.skin.constraints,e.data,!0)),!e.active)return;let t=e.target;this.sortBone(t);let s=e.bones,r=s[0];if(this.sortBone(r),s.length==1)this._updateCache.push(e),this.sortReset(r.children);else{let n=s[s.length-1];this.sortBone(n),this._updateCache.push(e),this.sortReset(r.children),n.sorted=!0}}sortPathConstraint(e){if(e.active=e.target.bone.isActive()&&(!e.data.skinRequired||this.skin&&R.contains(this.skin.constraints,e.data,!0)),!e.active)return;let t=e.target,s=t.data.index,r=t.bone;this.skin&&this.sortPathConstraintAttachment(this.skin,s,r),this.data.defaultSkin&&this.data.defaultSkin!=this.skin&&this.sortPathConstraintAttachment(this.data.defaultSkin,s,r);for(let i=0,l=this.data.skins.length;i<l;i++)this.sortPathConstraintAttachment(this.data.skins[i],s,r);let n=t.getAttachment();n instanceof Ie&&this.sortPathConstraintAttachmentWith(n,r);let h=e.bones,o=h.length;for(let i=0;i<o;i++)this.sortBone(h[i]);this._updateCache.push(e);for(let i=0;i<o;i++)this.sortReset(h[i].children);for(let i=0;i<o;i++)h[i].sorted=!0}sortTransformConstraint(e){if(e.active=e.target.isActive()&&(!e.data.skinRequired||this.skin&&R.contains(this.skin.constraints,e.data,!0)),!e.active)return;this.sortBone(e.target);let t=e.bones,s=t.length;if(e.data.local)for(let r=0;r<s;r++){let n=t[r];this.sortBone(n.parent),this.sortBone(n)}else for(let r=0;r<s;r++)this.sortBone(t[r]);this._updateCache.push(e);for(let r=0;r<s;r++)this.sortReset(t[r].children);for(let r=0;r<s;r++)t[r].sorted=!0}sortPathConstraintAttachment(e,t,s){let r=e.attachments[t];if(r)for(let n in r)this.sortPathConstraintAttachmentWith(r[n],s)}sortPathConstraintAttachmentWith(e,t){if(!(e instanceof Ie))return;let s=e.bones;if(!s)this.sortBone(t);else{let r=this.bones;for(let n=0,h=s.length;n<h;){let o=s[n++];for(o+=n;n<o;)this.sortBone(r[s[n++]])}}}sortPhysicsConstraint(e){const t=e.bone;e.active=t.active&&(!e.data.skinRequired||this.skin!=null&&R.contains(this.skin.constraints,e.data,!0)),e.active&&(this.sortBone(t),this._updateCache.push(e),this.sortReset(t.children),t.sorted=!0)}sortBone(e){if(!e||e.sorted)return;let t=e.parent;t&&this.sortBone(t),e.sorted=!0,this._updateCache.push(e)}sortReset(e){for(let t=0,s=e.length;t<s;t++){let r=e[t];r.active&&(r.sorted&&this.sortReset(r.children),r.sorted=!1)}}updateWorldTransform(e){if(e==null)throw new Error("physics is undefined");let t=this.bones;for(let r=0,n=t.length;r<n;r++){let h=t[r];h.ax=h.x,h.ay=h.y,h.arotation=h.rotation,h.ascaleX=h.scaleX,h.ascaleY=h.scaleY,h.ashearX=h.shearX,h.ashearY=h.shearY}let s=this._updateCache;for(let r=0,n=s.length;r<n;r++)s[r].update(e)}updateWorldTransformWith(e,t){if(!t)throw new Error("parent cannot be null.");let s=this.bones;for(let x=1,b=s.length;x<b;x++){let w=s[x];w.ax=w.x,w.ay=w.y,w.arotation=w.rotation,w.ascaleX=w.scaleX,w.ascaleY=w.scaleY,w.ashearX=w.shearX,w.ashearY=w.shearY}let r=this.getRootBone();if(!r)throw new Error("Root bone must not be null.");let n=t.a,h=t.b,o=t.c,i=t.d;r.worldX=n*this.x+h*this.y+t.worldX,r.worldY=o*this.x+i*this.y+t.worldY;const l=(r.rotation+r.shearX)*F.degRad,a=(r.rotation+90+r.shearY)*F.degRad,c=Math.cos(l)*r.scaleX,u=Math.cos(a)*r.scaleY,d=Math.sin(l)*r.scaleX,f=Math.sin(a)*r.scaleY;r.a=(n*c+h*d)*this.scaleX,r.b=(n*u+h*f)*this.scaleX,r.c=(o*c+i*d)*this.scaleY,r.d=(o*u+i*f)*this.scaleY;let m=this._updateCache;for(let x=0,b=m.length;x<b;x++){let w=m[x];w!=r&&w.update(e)}}setToSetupPose(){this.setBonesToSetupPose(),this.setSlotsToSetupPose()}setBonesToSetupPose(){for(const e of this.bones)e.setToSetupPose();for(const e of this.ikConstraints)e.setToSetupPose();for(const e of this.transformConstraints)e.setToSetupPose();for(const e of this.pathConstraints)e.setToSetupPose();for(const e of this.physicsConstraints)e.setToSetupPose()}setSlotsToSetupPose(){let e=this.slots;R.arrayCopy(e,0,this.drawOrder,0,e.length);for(let t=0,s=e.length;t<s;t++)e[t].setToSetupPose()}getRootBone(){return this.bones.length==0?null:this.bones[0]}findBone(e){if(!e)throw new Error("boneName cannot be null.");let t=this.bones;for(let s=0,r=t.length;s<r;s++){let n=t[s];if(n.data.name==e)return n}return null}findSlot(e){if(!e)throw new Error("slotName cannot be null.");let t=this.slots;for(let s=0,r=t.length;s<r;s++){let n=t[s];if(n.data.name==e)return n}return null}setSkinByName(e){let t=this.data.findSkin(e);if(!t)throw new Error("Skin not found: "+e);this.setSkin(t)}setSkin(e){if(e!=this.skin){if(e)if(this.skin)e.attachAll(this,this.skin);else{let t=this.slots;for(let s=0,r=t.length;s<r;s++){let n=t[s],h=n.data.attachmentName;if(h){let o=e.getAttachment(s,h);o&&n.setAttachment(o)}}}this.skin=e,this.updateCache()}}getAttachmentByName(e,t){let s=this.data.findSlot(e);if(!s)throw new Error(`Can't find slot with name ${e}`);return this.getAttachment(s.index,t)}getAttachment(e,t){if(!t)throw new Error("attachmentName cannot be null.");if(this.skin){let s=this.skin.getAttachment(e,t);if(s)return s}return this.data.defaultSkin?this.data.defaultSkin.getAttachment(e,t):null}setAttachment(e,t){if(!e)throw new Error("slotName cannot be null.");let s=this.slots;for(let r=0,n=s.length;r<n;r++){let h=s[r];if(h.data.name==e){let o=null;if(t&&(o=this.getAttachment(r,t),!o))throw new Error("Attachment not found: "+t+", for slot: "+e);h.setAttachment(o);return}}throw new Error("Slot not found: "+e)}findIkConstraint(e){if(!e)throw new Error("constraintName cannot be null.");return this.ikConstraints.find(t=>t.data.name==e)??null}findTransformConstraint(e){if(!e)throw new Error("constraintName cannot be null.");return this.transformConstraints.find(t=>t.data.name==e)??null}findPathConstraint(e){if(!e)throw new Error("constraintName cannot be null.");return this.pathConstraints.find(t=>t.data.name==e)??null}findPhysicsConstraint(e){if(e==null)throw new Error("constraintName cannot be null.");return this.physicsConstraints.find(t=>t.data.name==e)??null}getBoundsRect(e){let t=new Ne,s=new Ne;return this.getBounds(t,s,void 0,e),{x:t.x,y:t.y,width:s.x,height:s.y}}getBounds(e,t,s=new Array(2),r=null){if(!e)throw new Error("offset cannot be null.");if(!t)throw new Error("size cannot be null.");let n=this.drawOrder,h=Number.POSITIVE_INFINITY,o=Number.POSITIVE_INFINITY,i=Number.NEGATIVE_INFINITY,l=Number.NEGATIVE_INFINITY;for(let a=0,c=n.length;a<c;a++){let u=n[a];if(!u.bone.active)continue;let d=0,f=null,m=null,x=u.getAttachment();if(x instanceof U)d=8,f=R.setArraySize(s,d,0),x.computeWorldVertices(u,f,0,2),m=Ht.quadTriangles;else if(x instanceof ye){let b=x;d=b.worldVerticesLength,f=R.setArraySize(s,d,0),b.computeWorldVertices(u,0,d,f,0,2),m=b.triangles}else if(x instanceof Ee&&r!=null){r.clipStart(u,x);continue}if(f&&m){r!=null&&r.isClipping()&&(r.clipTriangles(f,m,m.length),f=r.clippedVertices,d=r.clippedVertices.length);for(let b=0,w=f.length;b<w;b+=2){let g=f[b],p=f[b+1];h=Math.min(h,g),o=Math.min(o,p),i=Math.max(i,g),l=Math.max(l,p)}}r?.clipEndWithSlot(u)}r?.clipEnd(),e.set(h,o),t.set(i-h,l-o)}update(e){this.time+=e}physicsTranslate(e,t){const s=this.physicsConstraints;for(let r=0,n=s.length;r<n;r++)s[r].translate(e,t)}physicsRotate(e,t,s){const r=this.physicsConstraints;for(let n=0,h=r.length;n<h;n++)r[n].rotate(e,t,s)}},ke=Ht;B(ke,"quadTriangles",[0,1,2,2,3,0]),B(ke,"yDown",!1);var Ts=(e=>(e[e.none=0]="none",e[e.reset=1]="reset",e[e.update=2]="update",e[e.pose=3]="pose",e))(Ts||{}),Xs=class extends Pe{_bone=null;set bone(e){this._bone=e}get bone(){if(this._bone)return this._bone;throw new Error("BoneData not set.")}x=0;y=0;rotate=0;scaleX=0;shearX=0;limit=0;step=0;inertia=0;strength=0;damping=0;massInverse=0;wind=0;gravity=0;mix=0;inertiaGlobal=!1;strengthGlobal=!1;dampingGlobal=!1;massGlobal=!1;windGlobal=!1;gravityGlobal=!1;mixGlobal=!1;constructor(e){super(e,0,!1)}},$t=class{name=null;bones=new Array;slots=new Array;skins=new Array;defaultSkin=null;events=new Array;animations=new Array;ikConstraints=new Array;transformConstraints=new Array;pathConstraints=new Array;physicsConstraints=new Array;x=0;y=0;width=0;height=0;referenceScale=100;version=null;hash=null;fps=0;imagesPath=null;audioPath=null;findBone(e){if(!e)throw new Error("boneName cannot be null.");let t=this.bones;for(let s=0,r=t.length;s<r;s++){let n=t[s];if(n.name==e)return n}return null}findSlot(e){if(!e)throw new Error("slotName cannot be null.");let t=this.slots;for(let s=0,r=t.length;s<r;s++){let n=t[s];if(n.name==e)return n}return null}findSkin(e){if(!e)throw new Error("skinName cannot be null.");let t=this.skins;for(let s=0,r=t.length;s<r;s++){let n=t[s];if(n.name==e)return n}return null}findEvent(e){if(!e)throw new Error("eventDataName cannot be null.");let t=this.events;for(let s=0,r=t.length;s<r;s++){let n=t[s];if(n.name==e)return n}return null}findAnimation(e){if(!e)throw new Error("animationName cannot be null.");let t=this.animations;for(let s=0,r=t.length;s<r;s++){let n=t[s];if(n.name==e)return n}return null}findIkConstraint(e){if(!e)throw new Error("constraintName cannot be null.");const t=this.ikConstraints;for(let s=0,r=t.length;s<r;s++){const n=t[s];if(n.name==e)return n}return null}findTransformConstraint(e){if(!e)throw new Error("constraintName cannot be null.");const t=this.transformConstraints;for(let s=0,r=t.length;s<r;s++){const n=t[s];if(n.name==e)return n}return null}findPathConstraint(e){if(!e)throw new Error("constraintName cannot be null.");const t=this.pathConstraints;for(let s=0,r=t.length;s<r;s++){const n=t[s];if(n.name==e)return n}return null}findPhysicsConstraint(e){if(!e)throw new Error("constraintName cannot be null.");const t=this.physicsConstraints;for(let s=0,r=t.length;s<r;s++){const n=t[s];if(n.name==e)return n}return null}},jt=class{constructor(e=0,t,s){this.slotIndex=e,this.name=t,this.attachment=s}},Je=class{name;attachments=new Array;bones=Array();constraints=new Array;color=new D(.99607843,.61960787,.30980393,1);constructor(e){if(!e)throw new Error("name cannot be null.");this.name=e}setAttachment(e,t,s){if(!s)throw new Error("attachment cannot be null.");let r=this.attachments;e>=r.length&&(r.length=e+1),r[e]||(r[e]={}),r[e][t]=s}addSkin(e){for(let r=0;r<e.bones.length;r++){let n=e.bones[r],h=!1;for(let o=0;o<this.bones.length;o++)if(this.bones[o]==n){h=!0;break}h||this.bones.push(n)}for(let r=0;r<e.constraints.length;r++){let n=e.constraints[r],h=!1;for(let o=0;o<this.constraints.length;o++)if(this.constraints[o]==n){h=!0;break}h||this.constraints.push(n)}let t=e.getAttachments();for(let r=0;r<t.length;r++){var s=t[r];this.setAttachment(s.slotIndex,s.name,s.attachment)}}copySkin(e){for(let r=0;r<e.bones.length;r++){let n=e.bones[r],h=!1;for(let o=0;o<this.bones.length;o++)if(this.bones[o]==n){h=!0;break}h||this.bones.push(n)}for(let r=0;r<e.constraints.length;r++){let n=e.constraints[r],h=!1;for(let o=0;o<this.constraints.length;o++)if(this.constraints[o]==n){h=!0;break}h||this.constraints.push(n)}let t=e.getAttachments();for(let r=0;r<t.length;r++){var s=t[r];s.attachment&&(s.attachment instanceof ye?(s.attachment=s.attachment.newLinkedMesh(),this.setAttachment(s.slotIndex,s.name,s.attachment)):(s.attachment=s.attachment.copy(),this.setAttachment(s.slotIndex,s.name,s.attachment)))}}getAttachment(e,t){let s=this.attachments[e];return s?s[t]:null}removeAttachment(e,t){let s=this.attachments[e];s&&delete s[t]}getAttachments(){let e=new Array;for(var t=0;t<this.attachments.length;t++){let s=this.attachments[t];if(s)for(let r in s){let n=s[r];n&&e.push(new jt(t,r,n))}}return e}getAttachmentsForSlot(e,t){let s=this.attachments[e];if(s)for(let r in s){let n=s[r];n&&t.push(new jt(e,r,n))}}clear(){this.attachments.length=0,this.bones.length=0,this.constraints.length=0}attachAll(e,t){let s=0;for(let r=0;r<e.slots.length;r++){let n=e.slots[r],h=n.getAttachment();if(h&&s<t.attachments.length){let o=t.attachments[s];for(let i in o){let l=o[i];if(h==l){let a=this.getAttachment(s,i);a&&n.setAttachment(a);break}}}s++}}},Kt=class{index=0;name;boneData;color=new D(1,1,1,1);darkColor=null;attachmentName=null;blendMode=Qe.Normal;visible=!0;constructor(e,t,s){if(e<0)throw new Error("index must be >= 0.");if(!t)throw new Error("name cannot be null.");if(!s)throw new Error("boneData cannot be null.");this.index=e,this.name=t,this.boneData=s}},Qe=(e=>(e[e.Normal=0]="Normal",e[e.Additive=1]="Additive",e[e.Multiply=2]="Multiply",e[e.Screen=3]="Screen",e))(Qe||{}),Jt=class extends Pe{bones=new Array;_target=null;set target(e){this._target=e}get target(){if(this._target)return this._target;throw new Error("BoneData not set.")}mixRotate=0;mixX=0;mixY=0;mixScaleX=0;mixScaleY=0;mixShearY=0;offsetRotation=0;offsetX=0;offsetY=0;offsetScaleX=0;offsetScaleY=0;offsetShearY=0;relative=!1;local=!1;constructor(e){super(e,0,!1)}},Fs=class{scale=1;attachmentLoader;linkedMeshes=new Array;constructor(e){this.attachmentLoader=e}readSkeletonData(e){let t=this.scale,s=new $t;s.name="";let r=new Es(e),n=r.readInt32(),h=r.readInt32();s.hash=h==0&&n==0?null:h.toString(16)+n.toString(16),s.version=r.readString(),s.x=r.readFloat(),s.y=r.readFloat(),s.width=r.readFloat(),s.height=r.readFloat(),s.referenceScale=r.readFloat()*t;let o=r.readBoolean();o&&(s.fps=r.readFloat(),s.imagesPath=r.readString(),s.audioPath=r.readString());let i=0;i=r.readInt(!0);for(let a=0;a<i;a++){let c=r.readString();if(!c)throw new Error("String in string table must not be null.");r.strings.push(c)}i=r.readInt(!0);for(let a=0;a<i;a++){let c=r.readString();if(!c)throw new Error("Bone name must not be null.");let u=a==0?null:s.bones[r.readInt(!0)],d=new qt(a,c,u);d.rotation=r.readFloat(),d.x=r.readFloat()*t,d.y=r.readFloat()*t,d.scaleX=r.readFloat(),d.scaleY=r.readFloat(),d.shearX=r.readFloat(),d.shearY=r.readFloat(),d.length=r.readFloat()*t,d.inherit=r.readByte(),d.skinRequired=r.readBoolean(),o&&(D.rgba8888ToColor(d.color,r.readInt32()),d.icon=r.readString()??void 0,d.visible=r.readBoolean()),s.bones.push(d)}i=r.readInt(!0);for(let a=0;a<i;a++){let c=r.readString();if(!c)throw new Error("Slot name must not be null.");let u=s.bones[r.readInt(!0)],d=new Kt(a,c,u);D.rgba8888ToColor(d.color,r.readInt32());let f=r.readInt32();f!=-1&&D.rgb888ToColor(d.darkColor=new D,f),d.attachmentName=r.readStringRef(),d.blendMode=r.readInt(!0),o&&(d.visible=r.readBoolean()),s.slots.push(d)}i=r.readInt(!0);for(let a=0,c;a<i;a++){let u=r.readString();if(!u)throw new Error("IK constraint data name must not be null.");let d=new zt(u);d.order=r.readInt(!0),c=r.readInt(!0);for(let m=0;m<c;m++)d.bones.push(s.bones[r.readInt(!0)]);d.target=s.bones[r.readInt(!0)];let f=r.readByte();d.skinRequired=(f&1)!=0,d.bendDirection=f&2?1:-1,d.compress=(f&4)!=0,d.stretch=(f&8)!=0,d.uniform=(f&16)!=0,f&32&&(d.mix=f&64?r.readFloat():1),f&128&&(d.softness=r.readFloat()*t),s.ikConstraints.push(d)}i=r.readInt(!0);for(let a=0,c;a<i;a++){let u=r.readString();if(!u)throw new Error("Transform constraint data name must not be null.");let d=new Jt(u);d.order=r.readInt(!0),c=r.readInt(!0);for(let m=0;m<c;m++)d.bones.push(s.bones[r.readInt(!0)]);d.target=s.bones[r.readInt(!0)];let f=r.readByte();d.skinRequired=(f&1)!=0,d.local=(f&2)!=0,d.relative=(f&4)!=0,f&8&&(d.offsetRotation=r.readFloat()),f&16&&(d.offsetX=r.readFloat()*t),f&32&&(d.offsetY=r.readFloat()*t),f&64&&(d.offsetScaleX=r.readFloat()),f&128&&(d.offsetScaleY=r.readFloat()),f=r.readByte(),f&1&&(d.offsetShearY=r.readFloat()),f&2&&(d.mixRotate=r.readFloat()),f&4&&(d.mixX=r.readFloat()),f&8&&(d.mixY=r.readFloat()),f&16&&(d.mixScaleX=r.readFloat()),f&32&&(d.mixScaleY=r.readFloat()),f&64&&(d.mixShearY=r.readFloat()),s.transformConstraints.push(d)}i=r.readInt(!0);for(let a=0,c;a<i;a++){let u=r.readString();if(!u)throw new Error("Path constraint data name must not be null.");let d=new Gt(u);d.order=r.readInt(!0),d.skinRequired=r.readBoolean(),c=r.readInt(!0);for(let m=0;m<c;m++)d.bones.push(s.bones[r.readInt(!0)]);d.target=s.slots[r.readInt(!0)];const f=r.readByte();d.positionMode=f&1,d.spacingMode=f>>1&3,d.rotateMode=f>>3&3,f&128&&(d.offsetRotation=r.readFloat()),d.position=r.readFloat(),d.positionMode==0&&(d.position*=t),d.spacing=r.readFloat(),(d.spacingMode==0||d.spacingMode==1)&&(d.spacing*=t),d.mixRotate=r.readFloat(),d.mixX=r.readFloat(),d.mixY=r.readFloat(),s.pathConstraints.push(d)}i=r.readInt(!0);for(let a=0,c;a<i;a++){const u=r.readString();if(!u)throw new Error("Physics constraint data name must not be null.");const d=new Xs(u);d.order=r.readInt(!0),d.bone=s.bones[r.readInt(!0)];let f=r.readByte();d.skinRequired=(f&1)!=0,f&2&&(d.x=r.readFloat()),f&4&&(d.y=r.readFloat()),f&8&&(d.rotate=r.readFloat()),f&16&&(d.scaleX=r.readFloat()),f&32&&(d.shearX=r.readFloat()),d.limit=(f&64?r.readFloat():5e3)*t,d.step=1/r.readUnsignedByte(),d.inertia=r.readFloat(),d.strength=r.readFloat(),d.damping=r.readFloat(),d.massInverse=f&128?r.readFloat():1,d.wind=r.readFloat(),d.gravity=r.readFloat(),f=r.readByte(),f&1&&(d.inertiaGlobal=!0),f&2&&(d.strengthGlobal=!0),f&4&&(d.dampingGlobal=!0),f&8&&(d.massGlobal=!0),f&16&&(d.windGlobal=!0),f&32&&(d.gravityGlobal=!0),f&64&&(d.mixGlobal=!0),d.mix=f&128?r.readFloat():1,s.physicsConstraints.push(d)}let l=this.readSkin(r,s,!0,o);l&&(s.defaultSkin=l,s.skins.push(l));{let a=s.skins.length;for(R.setArraySize(s.skins,i=a+r.readInt(!0));a<i;a++){let c=this.readSkin(r,s,!1,o);if(!c)throw new Error("readSkin() should not have returned null.");s.skins[a]=c}}i=this.linkedMeshes.length;for(let a=0;a<i;a++){let c=this.linkedMeshes[a];const u=s.skins[c.skinIndex];if(!c.parent)throw new Error("Linked mesh parent must not be null");let d=u.getAttachment(c.slotIndex,c.parent);if(!d)throw new Error(`Parent mesh not found: ${c.parent}`);c.mesh.timelineAttachment=c.inheritTimeline?d:c.mesh,c.mesh.setParentMesh(d),c.mesh.region!=null&&c.mesh.updateRegion()}this.linkedMeshes.length=0,i=r.readInt(!0);for(let a=0;a<i;a++){let c=r.readString();if(!c)throw new Error("Event data name must not be null");let u=new Ut(c);u.intValue=r.readInt(!1),u.floatValue=r.readFloat(),u.stringValue=r.readString(),u.audioPath=r.readString(),u.audioPath&&(u.volume=r.readFloat(),u.balance=r.readFloat()),s.events.push(u)}i=r.readInt(!0);for(let a=0;a<i;a++){let c=r.readString();if(!c)throw new Error("Animatio name must not be null.");s.animations.push(this.readAnimation(r,c,s))}return s}readSkin(e,t,s,r){let n=null,h=0;if(s){if(h=e.readInt(!0),h==0)return null;n=new Je("default")}else{let o=e.readString();if(!o)throw new Error("Skin name must not be null.");n=new Je(o),r&&D.rgba8888ToColor(n.color,e.readInt32()),n.bones.length=e.readInt(!0);for(let i=0,l=n.bones.length;i<l;i++)n.bones[i]=t.bones[e.readInt(!0)];for(let i=0,l=e.readInt(!0);i<l;i++)n.constraints.push(t.ikConstraints[e.readInt(!0)]);for(let i=0,l=e.readInt(!0);i<l;i++)n.constraints.push(t.transformConstraints[e.readInt(!0)]);for(let i=0,l=e.readInt(!0);i<l;i++)n.constraints.push(t.pathConstraints[e.readInt(!0)]);for(let i=0,l=e.readInt(!0);i<l;i++)n.constraints.push(t.physicsConstraints[e.readInt(!0)]);h=e.readInt(!0)}for(let o=0;o<h;o++){let i=e.readInt(!0);for(let l=0,a=e.readInt(!0);l<a;l++){let c=e.readStringRef();if(!c)throw new Error("Attachment name must not be null");let u=this.readAttachment(e,t,n,i,c,r);u&&n.setAttachment(i,c,u)}}return n}readAttachment(e,t,s,r,n,h){let o=this.scale,i=e.readByte();const l=i&8?e.readStringRef():n;if(!l)throw new Error("Attachment name must not be null");switch(i&7){case xe.Region:{let a=i&16?e.readStringRef():null;const c=i&32?e.readInt32():4294967295,u=i&64?this.readSequence(e):null;let d=i&128?e.readFloat():0,f=e.readFloat(),m=e.readFloat(),x=e.readFloat(),b=e.readFloat(),w=e.readFloat(),g=e.readFloat();a||(a=l);let p=this.attachmentLoader.newRegionAttachment(s,l,a,u);return p?(p.path=a,p.x=f*o,p.y=m*o,p.scaleX=x,p.scaleY=b,p.rotation=d,p.width=w*o,p.height=g*o,D.rgba8888ToColor(p.color,c),p.sequence=u,u==null&&p.updateRegion(),p):null}case xe.BoundingBox:{let a=this.readVertices(e,(i&16)!=0),c=h?e.readInt32():0,u=this.attachmentLoader.newBoundingBoxAttachment(s,l);return u?(u.worldVerticesLength=a.length,u.vertices=a.vertices,u.bones=a.bones,h&&D.rgba8888ToColor(u.color,c),u):null}case xe.Mesh:{let a=i&16?e.readStringRef():l;const c=i&32?e.readInt32():4294967295,u=i&64?this.readSequence(e):null,d=e.readInt(!0),f=this.readVertices(e,(i&128)!=0),m=this.readFloatArray(e,f.length,1),x=this.readShortArray(e,(f.length-d-2)*3);let b=[],w=0,g=0;h&&(b=this.readShortArray(e,e.readInt(!0)),w=e.readFloat(),g=e.readFloat()),a||(a=l);let p=this.attachmentLoader.newMeshAttachment(s,l,a,u);return p?(p.path=a,D.rgba8888ToColor(p.color,c),p.bones=f.bones,p.vertices=f.vertices,p.worldVerticesLength=f.length,p.triangles=x,p.regionUVs=m,u==null&&p.updateRegion(),p.hullLength=d<<1,p.sequence=u,h&&(p.edges=b,p.width=w*o,p.height=g*o),p):null}case xe.LinkedMesh:{const a=i&16?e.readStringRef():l;if(a==null)throw new Error("Path of linked mesh must not be null");const c=i&32?e.readInt32():4294967295,u=i&64?this.readSequence(e):null,d=(i&128)!=0,f=e.readInt(!0),m=e.readStringRef();let x=0,b=0;h&&(x=e.readFloat(),b=e.readFloat());let w=this.attachmentLoader.newMeshAttachment(s,l,a,u);return w?(w.path=a,D.rgba8888ToColor(w.color,c),w.sequence=u,h&&(w.width=x*o,w.height=b*o),this.linkedMeshes.push(new Js(w,f,r,m,d)),w):null}case xe.Path:{const a=(i&16)!=0,c=(i&32)!=0,u=this.readVertices(e,(i&64)!=0),d=R.newArray(u.length/6,0);for(let x=0,b=d.length;x<b;x++)d[x]=e.readFloat()*o;const f=h?e.readInt32():0,m=this.attachmentLoader.newPathAttachment(s,l);return m?(m.closed=a,m.constantSpeed=c,m.worldVerticesLength=u.length,m.vertices=u.vertices,m.bones=u.bones,m.lengths=d,h&&D.rgba8888ToColor(m.color,f),m):null}case xe.Point:{const a=e.readFloat(),c=e.readFloat(),u=e.readFloat(),d=h?e.readInt32():0,f=this.attachmentLoader.newPointAttachment(s,l);return f?(f.x=c*o,f.y=u*o,f.rotation=a,h&&D.rgba8888ToColor(f.color,d),f):null}case xe.Clipping:{const a=e.readInt(!0),c=this.readVertices(e,(i&16)!=0);let u=h?e.readInt32():0,d=this.attachmentLoader.newClippingAttachment(s,l);return d?(d.endSlot=t.slots[a],d.worldVerticesLength=c.length,d.vertices=c.vertices,d.bones=c.bones,h&&D.rgba8888ToColor(d.color,u),d):null}}return null}readSequence(e){let t=new rt(e.readInt(!0));return t.start=e.readInt(!0),t.digits=e.readInt(!0),t.setupIndex=e.readInt(!0),t}readVertices(e,t){const s=this.scale,r=e.readInt(!0),n=new Qs;if(n.length=r<<1,!t)return n.vertices=this.readFloatArray(e,n.length,s),n;let h=new Array,o=new Array;for(let i=0;i<r;i++){let l=e.readInt(!0);o.push(l);for(let a=0;a<l;a++)o.push(e.readInt(!0)),h.push(e.readFloat()*s),h.push(e.readFloat()*s),h.push(e.readFloat())}return n.vertices=R.toFloatArray(h),n.bones=o,n}readFloatArray(e,t,s){let r=new Array(t);if(s==1)for(let n=0;n<t;n++)r[n]=e.readFloat();else for(let n=0;n<t;n++)r[n]=e.readFloat()*s;return r}readShortArray(e,t){let s=new Array(t);for(let r=0;r<t;r++)s[r]=e.readInt(!0);return s}readAnimation(e,t,s){e.readInt(!0);let r=new Array,n=this.scale;for(let l=0,a=e.readInt(!0);l<a;l++){let c=e.readInt(!0);for(let u=0,d=e.readInt(!0);u<d;u++){let f=e.readByte(),m=e.readInt(!0),x=m-1;switch(f){case ci:{let b=new we(m,c);for(let w=0;w<m;w++)b.setFrame(w,e.readFloat(),e.readStringRef());r.push(b);break}case di:{let b=e.readInt(!0),w=new gt(m,b,c),g=e.readFloat(),p=e.readUnsignedByte()/255,v=e.readUnsignedByte()/255,y=e.readUnsignedByte()/255,S=e.readUnsignedByte()/255;for(let A=0,k=0;w.setFrame(A,g,p,v,y,S),A!=x;A++){let Y=e.readFloat(),M=e.readUnsignedByte()/255,E=e.readUnsignedByte()/255,X=e.readUnsignedByte()/255,C=e.readUnsignedByte()/255;switch(e.readByte()){case ce:w.setStepped(A);break;case de:z(e,w,k++,A,0,g,Y,p,M,1),z(e,w,k++,A,1,g,Y,v,E,1),z(e,w,k++,A,2,g,Y,y,X,1),z(e,w,k++,A,3,g,Y,S,C,1)}g=Y,p=M,v=E,y=X,S=C}r.push(w);break}case fi:{let b=e.readInt(!0),w=new xt(m,b,c),g=e.readFloat(),p=e.readUnsignedByte()/255,v=e.readUnsignedByte()/255,y=e.readUnsignedByte()/255;for(let S=0,A=0;w.setFrame(S,g,p,v,y),S!=x;S++){let k=e.readFloat(),Y=e.readUnsignedByte()/255,M=e.readUnsignedByte()/255,E=e.readUnsignedByte()/255;switch(e.readByte()){case ce:w.setStepped(S);break;case de:z(e,w,A++,S,0,g,k,p,Y,1),z(e,w,A++,S,1,g,k,v,M,1),z(e,w,A++,S,2,g,k,y,E,1)}g=k,p=Y,v=M,y=E}r.push(w);break}case ui:{let b=e.readInt(!0),w=new wt(m,b,c),g=e.readFloat(),p=e.readUnsignedByte()/255,v=e.readUnsignedByte()/255,y=e.readUnsignedByte()/255,S=e.readUnsignedByte()/255,A=e.readUnsignedByte()/255,k=e.readUnsignedByte()/255,Y=e.readUnsignedByte()/255;for(let M=0,E=0;w.setFrame(M,g,p,v,y,S,A,k,Y),M!=x;M++){let X=e.readFloat(),C=e.readUnsignedByte()/255,T=e.readUnsignedByte()/255,P=e.readUnsignedByte()/255,N=e.readUnsignedByte()/255,q=e.readUnsignedByte()/255,L=e.readUnsignedByte()/255,G=e.readUnsignedByte()/255;switch(e.readByte()){case ce:w.setStepped(M);break;case de:z(e,w,E++,M,0,g,X,p,C,1),z(e,w,E++,M,1,g,X,v,T,1),z(e,w,E++,M,2,g,X,y,P,1),z(e,w,E++,M,3,g,X,S,N,1),z(e,w,E++,M,4,g,X,A,q,1),z(e,w,E++,M,5,g,X,k,L,1),z(e,w,E++,M,6,g,X,Y,G,1)}g=X,p=C,v=T,y=P,S=N,A=q,k=L,Y=G}r.push(w);break}case mi:{let b=e.readInt(!0),w=new bt(m,b,c),g=e.readFloat(),p=e.readUnsignedByte()/255,v=e.readUnsignedByte()/255,y=e.readUnsignedByte()/255,S=e.readUnsignedByte()/255,A=e.readUnsignedByte()/255,k=e.readUnsignedByte()/255;for(let Y=0,M=0;w.setFrame(Y,g,p,v,y,S,A,k),Y!=x;Y++){let E=e.readFloat(),X=e.readUnsignedByte()/255,C=e.readUnsignedByte()/255,T=e.readUnsignedByte()/255,P=e.readUnsignedByte()/255,N=e.readUnsignedByte()/255,q=e.readUnsignedByte()/255;switch(e.readByte()){case ce:w.setStepped(Y);break;case de:z(e,w,M++,Y,0,g,E,p,X,1),z(e,w,M++,Y,1,g,E,v,C,1),z(e,w,M++,Y,2,g,E,y,T,1),z(e,w,M++,Y,3,g,E,S,P,1),z(e,w,M++,Y,4,g,E,A,N,1),z(e,w,M++,Y,5,g,E,k,q,1)}g=E,p=X,v=C,y=T,S=P,A=N,k=q}r.push(w);break}case gi:{let b=new pt(m,e.readInt(!0),c),w=e.readFloat(),g=e.readUnsignedByte()/255;for(let p=0,v=0;b.setFrame(p,w,g),p!=x;p++){let y=e.readFloat(),S=e.readUnsignedByte()/255;switch(e.readByte()){case ce:b.setStepped(p);break;case de:z(e,b,v++,p,0,w,y,g,S,1)}w=y,g=S}r.push(b)}}}}for(let l=0,a=e.readInt(!0);l<a;l++){let c=e.readInt(!0);for(let u=0,d=e.readInt(!0);u<d;u++){let f=e.readByte(),m=e.readInt(!0);if(f==hi){let b=new mt(m,c);for(let w=0;w<m;w++)b.setFrame(w,e.readFloat(),e.readByte());r.push(b);continue}let x=e.readInt(!0);switch(f){case Zs:r.push(ee(e,new Xe(m,x,c),1));break;case ei:r.push(Qt(e,new nt(m,x,c),n));break;case ti:r.push(ee(e,new at(m,x,c),n));break;case si:r.push(ee(e,new lt(m,x,c),n));break;case ii:r.push(Qt(e,new ot(m,x,c),1));break;case ri:r.push(ee(e,new ht(m,x,c),1));break;case ni:r.push(ee(e,new ct(m,x,c),1));break;case ai:r.push(Qt(e,new dt(m,x,c),1));break;case li:r.push(ee(e,new ft(m,x,c),1));break;case oi:r.push(ee(e,new ut(m,x,c),1))}}}for(let l=0,a=e.readInt(!0);l<a;l++){let c=e.readInt(!0),u=e.readInt(!0),d=u-1,f=new vt(u,e.readInt(!0),c),m=e.readByte(),x=e.readFloat(),b=m&1?m&2?e.readFloat():1:0,w=m&4?e.readFloat()*n:0;for(let g=0,p=0;f.setFrame(g,x,b,w,m&8?1:-1,(m&16)!=0,(m&32)!=0),g!=d;g++){m=e.readByte();const v=e.readFloat(),y=m&1?m&2?e.readFloat():1:0,S=m&4?e.readFloat()*n:0;m&64?f.setStepped(g):m&128&&(z(e,f,p++,g,0,x,v,b,y,1),z(e,f,p++,g,1,x,v,w,S,n)),x=v,b=y,w=S}r.push(f)}for(let l=0,a=e.readInt(!0);l<a;l++){let c=e.readInt(!0),u=e.readInt(!0),d=u-1,f=new St(u,e.readInt(!0),c),m=e.readFloat(),x=e.readFloat(),b=e.readFloat(),w=e.readFloat(),g=e.readFloat(),p=e.readFloat(),v=e.readFloat();for(let y=0,S=0;f.setFrame(y,m,x,b,w,g,p,v),y!=d;y++){let A=e.readFloat(),k=e.readFloat(),Y=e.readFloat(),M=e.readFloat(),E=e.readFloat(),X=e.readFloat(),C=e.readFloat();switch(e.readByte()){case ce:f.setStepped(y);break;case de:z(e,f,S++,y,0,m,A,x,k,1),z(e,f,S++,y,1,m,A,b,Y,1),z(e,f,S++,y,2,m,A,w,M,1),z(e,f,S++,y,3,m,A,g,E,1),z(e,f,S++,y,4,m,A,p,X,1),z(e,f,S++,y,5,m,A,v,C,1)}m=A,x=k,b=Y,w=M,g=E,p=X,v=C}r.push(f)}for(let l=0,a=e.readInt(!0);l<a;l++){let c=e.readInt(!0),u=s.pathConstraints[c];for(let d=0,f=e.readInt(!0);d<f;d++){const m=e.readByte(),x=e.readInt(!0),b=e.readInt(!0);switch(m){case wi:r.push(ee(e,new At(x,b,c),u.positionMode==0?n:1));break;case bi:r.push(ee(e,new It(x,b,c),u.spacingMode==0||u.spacingMode==1?n:1));break;case yi:let w=new Ct(x,b,c),g=e.readFloat(),p=e.readFloat(),v=e.readFloat(),y=e.readFloat();for(let S=0,A=0,k=w.getFrameCount()-1;w.setFrame(S,g,p,v,y),S!=k;S++){let Y=e.readFloat(),M=e.readFloat(),E=e.readFloat(),X=e.readFloat();switch(e.readByte()){case ce:w.setStepped(S);break;case de:z(e,w,A++,S,0,g,Y,p,M,1),z(e,w,A++,S,1,g,Y,v,E,1),z(e,w,A++,S,2,g,Y,y,X,1)}g=Y,p=M,v=E,y=X}r.push(w)}}}for(let l=0,a=e.readInt(!0);l<a;l++){const c=e.readInt(!0)-1;for(let u=0,d=e.readInt(!0);u<d;u++){const f=e.readByte(),m=e.readInt(!0);if(f==Yi){const b=new _e(m,c);for(let w=0;w<m;w++)b.setFrame(w,e.readFloat());r.push(b);continue}const x=e.readInt(!0);switch(f){case vi:r.push(ee(e,new kt(m,x,c),1));break;case Si:r.push(ee(e,new Mt(m,x,c),1));break;case Ai:r.push(ee(e,new Yt(m,x,c),1));break;case Ii:r.push(ee(e,new Tt(m,x,c),1));break;case Ci:r.push(ee(e,new Xt(m,x,c),1));break;case ki:r.push(ee(e,new Ft(m,x,c),1));break;case Mi:r.push(ee(e,new Et(m,x,c),1))}}}for(let l=0,a=e.readInt(!0);l<a;l++){let c=s.skins[e.readInt(!0)];for(let u=0,d=e.readInt(!0);u<d;u++){let f=e.readInt(!0);for(let m=0,x=e.readInt(!0);m<x;m++){let b=e.readStringRef();if(!b)throw new Error("attachmentName must not be null.");let w=c.getAttachment(f,b),g=e.readByte(),p=e.readInt(!0),v=p-1;switch(g){case xi:{let y=w,S=y.bones,A=y.vertices,k=S?A.length/3*2:A.length,Y=e.readInt(!0),M=new yt(p,Y,f,y),E=e.readFloat();for(let X=0,C=0;;X++){let T,P=e.readInt(!0);if(P==0)T=S?R.newFloatArray(k):A;else{T=R.newFloatArray(k);let q=e.readInt(!0);if(P+=q,n==1)for(let L=q;L<P;L++)T[L]=e.readFloat();else for(let L=q;L<P;L++)T[L]=e.readFloat()*n;if(!S)for(let L=0,G=T.length;L<G;L++)T[L]+=A[L]}if(M.setFrame(X,E,T),X==v)break;let N=e.readFloat();switch(e.readByte()){case ce:M.setStepped(X);break;case de:z(e,M,C++,X,0,E,N,0,1,1)}E=N}r.push(M);break}case pi:{let y=new Ae(p,f,w);for(let S=0;S<p;S++){let A=e.readFloat(),k=e.readInt32();y.setFrame(S,A,hs[k&15],k>>4,e.readFloat())}r.push(y);break}}}}}let h=e.readInt(!0);if(h>0){let l=new be(h),a=s.slots.length;for(let c=0;c<h;c++){let u=e.readFloat(),d=e.readInt(!0),f=R.newArray(a,0);for(let w=a-1;w>=0;w--)f[w]=-1;let m=R.newArray(a-d,0),x=0,b=0;for(let w=0;w<d;w++){let g=e.readInt(!0);for(;x!=g;)m[b++]=x++;f[x+e.readInt(!0)]=x++}for(;x<a;)m[b++]=x++;for(let w=a-1;w>=0;w--)f[w]==-1&&(f[w]=m[--b]);l.setFrame(c,u,f)}r.push(l)}let o=e.readInt(!0);if(o>0){let l=new Fe(o);for(let a=0;a<o;a++){let c=e.readFloat(),u=s.events[e.readInt(!0)],d=new Wt(c,u);d.intValue=e.readInt(!1),d.floatValue=e.readFloat(),d.stringValue=e.readString(),d.stringValue==null&&(d.stringValue=u.stringValue),d.data.audioPath&&(d.volume=e.readFloat(),d.balance=e.readFloat()),l.setFrame(a,d)}r.push(l)}let i=0;for(let l=0,a=r.length;l<a;l++)i=Math.max(i,r[l].getDuration());return new Oe(t,r,i)}},Es=class{constructor(e,t=new Array,s=0,r=new DataView(e instanceof ArrayBuffer?e:e.buffer)){this.strings=t,this.index=s,this.buffer=r}readByte(){return this.buffer.getInt8(this.index++)}readUnsignedByte(){return this.buffer.getUint8(this.index++)}readShort(){let e=this.buffer.getInt16(this.index);return this.index+=2,e}readInt32(){let e=this.buffer.getInt32(this.index);return this.index+=4,e}readInt(e){let t=this.readByte(),s=t&127;return t&128&&(t=this.readByte(),s|=(t&127)<<7,t&128&&(t=this.readByte(),s|=(t&127)<<14,t&128&&(t=this.readByte(),s|=(t&127)<<21,t&128&&(t=this.readByte(),s|=(t&127)<<28)))),e?s:s>>>1^-(s&1)}readStringRef(){let e=this.readInt(!0);return e==0?null:this.strings[e-1]}readString(){let e=this.readInt(!0);switch(e){case 0:return null;case 1:return""}e--;let t="",s=0;for(let r=0;r<e;){let n=this.readUnsignedByte();switch(n>>4){case 12:case 13:t+=String.fromCharCode((n&31)<<6|this.readByte()&63),r+=2;break;case 14:t+=String.fromCharCode((n&15)<<12|(this.readByte()&63)<<6|this.readByte()&63),r+=3;break;default:t+=String.fromCharCode(n),r++}}return t}readFloat(){let e=this.buffer.getFloat32(this.index);return this.index+=4,e}readBoolean(){return this.readByte()!=0}},Js=class{parent;skinIndex;slotIndex;mesh;inheritTimeline;constructor(e,t,s,r,n){this.mesh=e,this.skinIndex=t,this.slotIndex=s,this.parent=r,this.inheritTimeline=n}},Qs=class{constructor(e=null,t=null,s=0){this.bones=e,this.vertices=t,this.length=s}},xe=(e=>(e[e.Region=0]="Region",e[e.BoundingBox=1]="BoundingBox",e[e.Mesh=2]="Mesh",e[e.LinkedMesh=3]="LinkedMesh",e[e.Path=4]="Path",e[e.Point=5]="Point",e[e.Clipping=6]="Clipping",e))(xe||{});function ee(e,t,s){let r=e.readFloat(),n=e.readFloat()*s;for(let h=0,o=0,i=t.getFrameCount()-1;t.setFrame(h,r,n),h!=i;h++){let l=e.readFloat(),a=e.readFloat()*s;switch(e.readByte()){case ce:t.setStepped(h);break;case de:z(e,t,o++,h,0,r,l,n,a,s)}r=l,n=a}return t}function Qt(e,t,s){let r=e.readFloat(),n=e.readFloat()*s,h=e.readFloat()*s;for(let o=0,i=0,l=t.getFrameCount()-1;t.setFrame(o,r,n,h),o!=l;o++){let a=e.readFloat(),c=e.readFloat()*s,u=e.readFloat()*s;switch(e.readByte()){case ce:t.setStepped(o);break;case de:z(e,t,i++,o,0,r,a,n,c,s),z(e,t,i++,o,1,r,a,h,u,s)}r=a,n=c,h=u}return t}function z(e,t,s,r,n,h,o,i,l,a){t.setBezier(s,r,n,h,i,e.readFloat(),e.readFloat()*a,e.readFloat(),e.readFloat()*a,o,l)}var Zs=0,ei=1,ti=2,si=3,ii=4,ri=5,ni=6,ai=7,li=8,oi=9,hi=10,ci=0,di=1,fi=2,ui=3,mi=4,gi=5,xi=0,pi=1,wi=0,bi=1,yi=2,vi=0,Si=1,Ai=2,Ii=4,Ci=5,ki=6,Mi=7,Yi=8,ce=1,de=2,Ti=class{minX=0;minY=0;maxX=0;maxY=0;boundingBoxes=new Array;polygons=new Array;polygonPool=new Te(()=>R.newFloatArray(16));update(e,t){if(!e)throw new Error("skeleton cannot be null.");let s=this.boundingBoxes,r=this.polygons,n=this.polygonPool,h=e.slots,o=h.length;s.length=0,n.freeAll(r),r.length=0;for(let i=0;i<o;i++){let l=h[i];if(!l.bone.active)continue;let a=l.getAttachment();if(a instanceof Ge){let c=a;s.push(c);let u=n.obtain();u.length!=c.worldVerticesLength&&(u=R.newFloatArray(c.worldVerticesLength)),r.push(u),c.computeWorldVertices(l,0,c.worldVerticesLength,u,0,2)}}t?this.aabbCompute():(this.minX=Number.POSITIVE_INFINITY,this.minY=Number.POSITIVE_INFINITY,this.maxX=Number.NEGATIVE_INFINITY,this.maxY=Number.NEGATIVE_INFINITY)}aabbCompute(){let e=Number.POSITIVE_INFINITY,t=Number.POSITIVE_INFINITY,s=Number.NEGATIVE_INFINITY,r=Number.NEGATIVE_INFINITY,n=this.polygons;for(let h=0,o=n.length;h<o;h++){let i=n[h],l=i;for(let a=0,c=i.length;a<c;a+=2){let u=l[a],d=l[a+1];e=Math.min(e,u),t=Math.min(t,d),s=Math.max(s,u),r=Math.max(r,d)}}this.minX=e,this.minY=t,this.maxX=s,this.maxY=r}aabbContainsPoint(e,t){return e>=this.minX&&e<=this.maxX&&t>=this.minY&&t<=this.maxY}aabbIntersectsSegment(e,t,s,r){let n=this.minX,h=this.minY,o=this.maxX,i=this.maxY;if(e<=n&&s<=n||t<=h&&r<=h||e>=o&&s>=o||t>=i&&r>=i)return!1;let l=(r-t)/(s-e),a=l*(n-e)+t;if(a>h&&a<i||(a=l*(o-e)+t,a>h&&a<i))return!0;let c=(h-t)/l+e;return c>n&&c<o||(c=(i-t)/l+e,c>n&&c<o)}aabbIntersectsSkeleton(e){return this.minX<e.maxX&&this.maxX>e.minX&&this.minY<e.maxY&&this.maxY>e.minY}containsPoint(e,t){let s=this.polygons;for(let r=0,n=s.length;r<n;r++)if(this.containsPointPolygon(s[r],e,t))return this.boundingBoxes[r];return null}containsPointPolygon(e,t,s){let r=e,n=e.length,h=n-2,o=!1;for(let i=0;i<n;i+=2){let l=r[i+1],a=r[h+1];if(l<s&&a>=s||a<s&&l>=s){let c=r[i];c+(s-l)/(a-l)*(r[h]-c)<t&&(o=!o)}h=i}return o}intersectsSegment(e,t,s,r){let n=this.polygons;for(let h=0,o=n.length;h<o;h++)if(this.intersectsSegmentPolygon(n[h],e,t,s,r))return this.boundingBoxes[h];return null}intersectsSegmentPolygon(e,t,s,r,n){let h=e,o=e.length,i=t-r,l=s-n,a=t*n-s*r,c=h[o-2],u=h[o-1];for(let d=0;d<o;d+=2){let f=h[d],m=h[d+1],x=c*m-u*f,b=c-f,w=u-m,g=i*w-l*b,p=(a*b-i*x)/g;if((p>=c&&p<=f||p>=f&&p<=c)&&(p>=t&&p<=r||p>=r&&p<=t)){let v=(a*w-l*x)/g;if((v>=u&&v<=m||v>=m&&v<=u)&&(v>=s&&v<=n||v>=n&&v<=s))return!0}c=f,u=m}return!1}getPolygon(e){if(!e)throw new Error("boundingBox cannot be null.");let t=this.boundingBoxes.indexOf(e);return t==-1?null:this.polygons[t]}getWidth(){return this.maxX-this.minX}getHeight(){return this.maxY-this.minY}},ie=class{convexPolygons=new Array;convexPolygonsIndices=new Array;indicesArray=new Array;isConcaveArray=new Array;triangles=new Array;polygonPool=new Te(()=>new Array);polygonIndicesPool=new Te(()=>new Array);triangulate(e){let t=e,s=e.length>>1,r=this.indicesArray;r.length=0;for(let o=0;o<s;o++)r[o]=o;let n=this.isConcaveArray;n.length=0;for(let o=0,i=s;o<i;++o)n[o]=ie.isConcave(o,s,t,r);let h=this.triangles;for(h.length=0;s>3;){let o=s-1,i=0,l=1;for(;;){e:if(!n[i]){let u=r[o]<<1,d=r[i]<<1,f=r[l]<<1,m=t[u],x=t[u+1],b=t[d],w=t[d+1],g=t[f],p=t[f+1];for(let v=(l+1)%s;v!=o;v=(v+1)%s){if(!n[v])continue;let y=r[v]<<1,S=t[y],A=t[y+1];if(ie.positiveArea(g,p,m,x,S,A)&&ie.positiveArea(m,x,b,w,S,A)&&ie.positiveArea(b,w,g,p,S,A))break e}break}if(l==0){do{if(!n[i])break;i--}while(i>0);break}o=i,i=l,l=(l+1)%s}h.push(r[(s+i-1)%s]),h.push(r[i]),h.push(r[(i+1)%s]),r.splice(i,1),n.splice(i,1),s--;let a=(s+i-1)%s,c=i==s?0:i;n[a]=ie.isConcave(a,s,t,r),n[c]=ie.isConcave(c,s,t,r)}return s==3&&(h.push(r[2]),h.push(r[0]),h.push(r[1])),h}decompose(e,t){let s=e,r=this.convexPolygons;this.polygonPool.freeAll(r),r.length=0;let n=this.convexPolygonsIndices;this.polygonIndicesPool.freeAll(n),n.length=0;let h=this.polygonIndicesPool.obtain();h.length=0;let o=this.polygonPool.obtain();o.length=0;let i=-1,l=0;for(let a=0,c=t.length;a<c;a+=3){let u=t[a]<<1,d=t[a+1]<<1,f=t[a+2]<<1,m=s[u],x=s[u+1],b=s[d],w=s[d+1],g=s[f],p=s[f+1],v=!1;if(i==u){let y=o.length-4,S=ie.winding(o[y],o[y+1],o[y+2],o[y+3],g,p),A=ie.winding(g,p,o[0],o[1],o[2],o[3]);S==l&&A==l&&(o.push(g),o.push(p),h.push(f),v=!0)}v||(o.length>0?(r.push(o),n.push(h)):(this.polygonPool.free(o),this.polygonIndicesPool.free(h)),o=this.polygonPool.obtain(),o.length=0,o.push(m),o.push(x),o.push(b),o.push(w),o.push(g),o.push(p),h=this.polygonIndicesPool.obtain(),h.length=0,h.push(u),h.push(d),h.push(f),l=ie.winding(m,x,b,w,g,p),i=u)}o.length>0&&(r.push(o),n.push(h));for(let a=0,c=r.length;a<c;a++){if(h=n[a],h.length==0)continue;let u=h[0],d=h[h.length-1];o=r[a];let f=o.length-4,m=o[f],x=o[f+1],b=o[f+2],w=o[f+3],g=o[0],p=o[1],v=o[2],y=o[3],S=ie.winding(m,x,b,w,g,p);for(let A=0;A<c;A++){if(A==a)continue;let k=n[A];if(k.length!=3)continue;let Y=k[0],M=k[1],E=k[2],X=r[A],C=X[X.length-2],T=X[X.length-1];if(Y!=u||M!=d)continue;let P=ie.winding(m,x,b,w,C,T),N=ie.winding(C,T,g,p,v,y);P==S&&N==S&&(X.length=0,k.length=0,o.push(C),o.push(T),h.push(E),m=b,x=w,b=C,w=T,A=0)}}for(let a=r.length-1;a>=0;a--)o=r[a],o.length==0&&(r.splice(a,1),this.polygonPool.free(o),h=n[a],n.splice(a,1),this.polygonIndicesPool.free(h));return r}static isConcave(e,t,s,r){let n=r[(t+e-1)%t]<<1,h=r[e]<<1,o=r[(e+1)%t]<<1;return!this.positiveArea(s[n],s[n+1],s[h],s[h+1],s[o],s[o+1])}static positiveArea(e,t,s,r,n,h){return e*(h-r)+s*(t-h)+n*(r-t)>=0}static winding(e,t,s,r,n,h){let o=s-e,i=r-t;return n*i-h*o+o*t-e*i>=0?1:-1}},Ze=class{triangulator=new ie;clippingPolygon=new Array;clipOutput=new Array;clippedVertices=new Array;clippedUVs=new Array;clippedTriangles=new Array;scratch=new Array;clipAttachment=null;clippingPolygons=null;clipStart(e,t){if(this.clipAttachment)return 0;this.clipAttachment=t;let s=t.worldVerticesLength,r=R.setArraySize(this.clippingPolygon,s);t.computeWorldVertices(e,0,s,r,0,2);let n=this.clippingPolygon;Ze.makeClockwise(n);let h=this.clippingPolygons=this.triangulator.decompose(n,this.triangulator.triangulate(n));for(let o=0,i=h.length;o<i;o++){let l=h[o];Ze.makeClockwise(l),l.push(l[0]),l.push(l[1])}return h.length}clipEndWithSlot(e){this.clipAttachment&&this.clipAttachment.endSlot==e.data&&this.clipEnd()}clipEnd(){this.clipAttachment&&(this.clipAttachment=null,this.clippingPolygons=null,this.clippedVertices.length=0,this.clippedTriangles.length=0,this.clippingPolygon.length=0)}isClipping(){return this.clipAttachment!=null}clipTriangles(e,t,s,r,n,h,o,i){let l,a,c,u,d,f;typeof t=="number"?(l=s,a=r,c=n,u=h,d=o,f=i):(l=t,a=s,c=r,u=n,d=h,f=o),c&&u&&d&&typeof f=="boolean"?this.clipTrianglesRender(e,l,a,c,u,d,f):this.clipTrianglesNoRender(e,l,a)}clipTrianglesNoRender(e,t,s){let r=this.clipOutput,n=this.clippedVertices,h=this.clippedTriangles,o=this.clippingPolygons,i=o.length,l=0;n.length=0,h.length=0;for(let a=0;a<s;a+=3){let c=t[a]<<1,u=e[c],d=e[c+1];c=t[a+1]<<1;let f=e[c],m=e[c+1];c=t[a+2]<<1;let x=e[c],b=e[c+1];for(let w=0;w<i;w++){let g=n.length;if(this.clip(u,d,f,m,x,b,o[w],r)){let p=r.length;if(p==0)continue;let v=p>>1,y=this.clipOutput,S=R.setArraySize(n,g+v*2);for(let k=0;k<p;k+=2,g+=2){let Y=y[k],M=y[k+1];S[g]=Y,S[g+1]=M}g=h.length;let A=R.setArraySize(h,g+3*(v-2));v--;for(let k=1;k<v;k++,g+=3)A[g]=l,A[g+1]=l+k,A[g+2]=l+k+1;l+=v+1}else{let p=R.setArraySize(n,g+6);p[g]=u,p[g+1]=d,p[g+2]=f,p[g+3]=m,p[g+4]=x,p[g+5]=b,g=h.length;let v=R.setArraySize(h,g+3);v[g]=l,v[g+1]=l+1,v[g+2]=l+2,l+=3;break}}}}clipTrianglesRender(e,t,s,r,n,h,o){let i=this.clipOutput,l=this.clippedVertices,a=this.clippedTriangles,c=this.clippingPolygons,u=c.length,d=o?12:8,f=0;l.length=0,a.length=0;for(let m=0;m<s;m+=3){let x=t[m]<<1,b=e[x],w=e[x+1],g=r[x],p=r[x+1];x=t[m+1]<<1;let v=e[x],y=e[x+1],S=r[x],A=r[x+1];x=t[m+2]<<1;let k=e[x],Y=e[x+1],M=r[x],E=r[x+1];for(let X=0;X<u;X++){let C=l.length;if(this.clip(b,w,v,y,k,Y,c[X],i)){let T=i.length;if(T==0)continue;let P=y-Y,N=k-v,q=b-k,L=Y-w,G=1/(P*q+N*(w-Y)),$=T>>1,j=this.clipOutput,V=R.setArraySize(l,C+$*d);for(let W=0;W<T;W+=2,C+=d){let re=j[W],te=j[W+1];V[C]=re,V[C+1]=te,V[C+2]=n.r,V[C+3]=n.g,V[C+4]=n.b,V[C+5]=n.a;let J=re-k,Q=te-Y,Z=(P*J+N*Q)*G,fe=(L*J+q*Q)*G,Me=1-Z-fe;V[C+6]=g*Z+S*fe+M*Me,V[C+7]=p*Z+A*fe+E*Me,o&&(V[C+8]=h.r,V[C+9]=h.g,V[C+10]=h.b,V[C+11]=h.a)}C=a.length;let _=R.setArraySize(a,C+3*($-2));$--;for(let W=1;W<$;W++,C+=3)_[C]=f,_[C+1]=f+W,_[C+2]=f+W+1;f+=$+1}else{let T=R.setArraySize(l,C+3*d);T[C]=b,T[C+1]=w,T[C+2]=n.r,T[C+3]=n.g,T[C+4]=n.b,T[C+5]=n.a,o?(T[C+6]=g,T[C+7]=p,T[C+8]=h.r,T[C+9]=h.g,T[C+10]=h.b,T[C+11]=h.a,T[C+12]=v,T[C+13]=y,T[C+14]=n.r,T[C+15]=n.g,T[C+16]=n.b,T[C+17]=n.a,T[C+18]=S,T[C+19]=A,T[C+20]=h.r,T[C+21]=h.g,T[C+22]=h.b,T[C+23]=h.a,T[C+24]=k,T[C+25]=Y,T[C+26]=n.r,T[C+27]=n.g,T[C+28]=n.b,T[C+29]=n.a,T[C+30]=M,T[C+31]=E,T[C+32]=h.r,T[C+33]=h.g,T[C+34]=h.b,T[C+35]=h.a):(T[C+6]=g,T[C+7]=p,T[C+8]=v,T[C+9]=y,T[C+10]=n.r,T[C+11]=n.g,T[C+12]=n.b,T[C+13]=n.a,T[C+14]=S,T[C+15]=A,T[C+16]=k,T[C+17]=Y,T[C+18]=n.r,T[C+19]=n.g,T[C+20]=n.b,T[C+21]=n.a,T[C+22]=M,T[C+23]=E),C=a.length;let P=R.setArraySize(a,C+3);P[C]=f,P[C+1]=f+1,P[C+2]=f+2,f+=3;break}}}}clipTrianglesUnpacked(e,t,s,r){let n=this.clipOutput,h=this.clippedVertices,o=this.clippedUVs,i=this.clippedTriangles,l=this.clippingPolygons,a=l.length,c=0;h.length=0,o.length=0,i.length=0;for(let u=0;u<s;u+=3){let d=t[u]<<1,f=e[d],m=e[d+1],x=r[d],b=r[d+1];d=t[u+1]<<1;let w=e[d],g=e[d+1],p=r[d],v=r[d+1];d=t[u+2]<<1;let y=e[d],S=e[d+1],A=r[d],k=r[d+1];for(let Y=0;Y<a;Y++){let M=h.length;if(this.clip(f,m,w,g,y,S,l[Y],n)){let E=n.length;if(E==0)continue;let X=g-S,C=y-w,T=f-y,P=S-m,N=1/(X*T+C*(m-S)),q=E>>1,L=this.clipOutput,G=R.setArraySize(h,M+q*2),$=R.setArraySize(o,M+q*2);for(let V=0;V<E;V+=2,M+=2){let _=L[V],W=L[V+1];G[M]=_,G[M+1]=W;let re=_-y,te=W-S,J=(X*re+C*te)*N,Q=(P*re+T*te)*N,Z=1-J-Q;$[M]=x*J+p*Q+A*Z,$[M+1]=b*J+v*Q+k*Z}M=i.length;let j=R.setArraySize(i,M+3*(q-2));q--;for(let V=1;V<q;V++,M+=3)j[M]=c,j[M+1]=c+V,j[M+2]=c+V+1;c+=q+1}else{let E=R.setArraySize(h,M+6);E[M]=f,E[M+1]=m,E[M+2]=w,E[M+3]=g,E[M+4]=y,E[M+5]=S;let X=R.setArraySize(o,M+3*2);X[M]=x,X[M+1]=b,X[M+2]=p,X[M+3]=v,X[M+4]=A,X[M+5]=k,M=i.length;let C=R.setArraySize(i,M+3);C[M]=c,C[M+1]=c+1,C[M+2]=c+2,c+=3;break}}}}clip(e,t,s,r,n,h,o,i){let l=i,a=!1,c;o.length%4>=2?(c=i,i=this.scratch):c=this.scratch,c.length=0,c.push(e),c.push(t),c.push(s),c.push(r),c.push(n),c.push(h),c.push(e),c.push(t),i.length=0;let u=o.length-4,d=o;for(let f=0;;f+=2){let m=d[f],x=d[f+1],b=m-d[f+2],w=x-d[f+3],g=i.length,p=c;for(let y=0,S=c.length-2;y<S;){let A=p[y],k=p[y+1];y+=2;let Y=p[y],M=p[y+1],E=w*(m-Y)>b*(x-M),X=w*(m-A)-b*(x-k);if(X>0){if(E){i.push(Y),i.push(M);continue}let C=Y-A,T=M-k,P=X/(C*w-T*b);if(P>=0&&P<=1)i.push(A+C*P),i.push(k+T*P);else{i.push(Y),i.push(M);continue}}else if(E){let C=Y-A,T=M-k,P=X/(C*w-T*b);if(P>=0&&P<=1)i.push(A+C*P),i.push(k+T*P),i.push(Y),i.push(M);else{i.push(Y),i.push(M);continue}}a=!0}if(g==i.length)return l.length=0,!0;if(i.push(i[0]),i.push(i[1]),f==u)break;let v=i;i=c,i.length=0,c=v}if(l!=i){l.length=0;for(let f=0,m=i.length-2;f<m;f++)l[f]=i[f]}else l.length=l.length-2;return a}static makeClockwise(e){let t=e,s=e.length,r=t[s-2]*t[1]-t[0]*t[s-1],n=0,h=0,o=0,i=0;for(let l=0,a=s-3;l<a;l+=2)n=t[l],h=t[l+1],o=t[l+2],i=t[l+3],r+=n*i-o*h;if(!(r<0))for(let l=0,a=s-2,c=s>>1;l<c;l+=2){let u=t[l],d=t[l+1],f=a-l;t[l]=t[f],t[l+1]=t[f+1],t[f]=u,t[f+1]=d}}},Rs=class{attachmentLoader;scale=1;linkedMeshes=new Array;constructor(e){this.attachmentLoader=e}readSkeletonData(e){let t=this.scale,s=new $t,r=typeof e=="string"?JSON.parse(e):e,n=r.skeleton;if(n&&(s.hash=n.hash,s.version=n.spine,s.x=n.x,s.y=n.y,s.width=n.width,s.height=n.height,s.referenceScale=I(n,"referenceScale",100)*t,s.fps=n.fps,s.imagesPath=n.images??null,s.audioPath=n.audio??null),r.bones)for(let h=0;h<r.bones.length;h++){let o=r.bones[h],i=null,l=I(o,"parent",null);l&&(i=s.findBone(l));let a=new qt(s.bones.length,o.name,i);a.length=I(o,"length",0)*t,a.x=I(o,"x",0)*t,a.y=I(o,"y",0)*t,a.rotation=I(o,"rotation",0),a.scaleX=I(o,"scaleX",1),a.scaleY=I(o,"scaleY",1),a.shearX=I(o,"shearX",0),a.shearY=I(o,"shearY",0),a.inherit=R.enumValue(Re,I(o,"inherit","Normal")),a.skinRequired=I(o,"skin",!1);let c=I(o,"color",null);c&&a.color.setFromString(c),s.bones.push(a)}if(r.slots)for(let h=0;h<r.slots.length;h++){let o=r.slots[h],i=o.name,l=s.findBone(o.bone);if(!l)throw new Error(`Couldn't find bone ${o.bone} for slot ${i}`);let a=new Kt(s.slots.length,i,l),c=I(o,"color",null);c&&a.color.setFromString(c);let u=I(o,"dark",null);u&&(a.darkColor=D.fromString(u)),a.attachmentName=I(o,"attachment",null),a.blendMode=R.enumValue(Qe,I(o,"blend","normal")),a.visible=I(o,"visible",!0),s.slots.push(a)}if(r.ik)for(let h=0;h<r.ik.length;h++){let o=r.ik[h],i=new zt(o.name);i.order=I(o,"order",0),i.skinRequired=I(o,"skin",!1);for(let a=0;a<o.bones.length;a++){let c=s.findBone(o.bones[a]);if(!c)throw new Error(`Couldn't find bone ${o.bones[a]} for IK constraint ${o.name}.`);i.bones.push(c)}let l=s.findBone(o.target);if(!l)throw new Error(`Couldn't find target bone ${o.target} for IK constraint ${o.name}.`);i.target=l,i.mix=I(o,"mix",1),i.softness=I(o,"softness",0)*t,i.bendDirection=I(o,"bendPositive",!0)?1:-1,i.compress=I(o,"compress",!1),i.stretch=I(o,"stretch",!1),i.uniform=I(o,"uniform",!1),s.ikConstraints.push(i)}if(r.transform)for(let h=0;h<r.transform.length;h++){let o=r.transform[h],i=new Jt(o.name);i.order=I(o,"order",0),i.skinRequired=I(o,"skin",!1);for(let c=0;c<o.bones.length;c++){let u=o.bones[c],d=s.findBone(u);if(!d)throw new Error(`Couldn't find bone ${u} for transform constraint ${o.name}.`);i.bones.push(d)}let l=o.target,a=s.findBone(l);if(!a)throw new Error(`Couldn't find target bone ${l} for transform constraint ${o.name}.`);i.target=a,i.local=I(o,"local",!1),i.relative=I(o,"relative",!1),i.offsetRotation=I(o,"rotation",0),i.offsetX=I(o,"x",0)*t,i.offsetY=I(o,"y",0)*t,i.offsetScaleX=I(o,"scaleX",0),i.offsetScaleY=I(o,"scaleY",0),i.offsetShearY=I(o,"shearY",0),i.mixRotate=I(o,"mixRotate",1),i.mixX=I(o,"mixX",1),i.mixY=I(o,"mixY",i.mixX),i.mixScaleX=I(o,"mixScaleX",1),i.mixScaleY=I(o,"mixScaleY",i.mixScaleX),i.mixShearY=I(o,"mixShearY",1),s.transformConstraints.push(i)}if(r.path)for(let h=0;h<r.path.length;h++){let o=r.path[h],i=new Gt(o.name);i.order=I(o,"order",0),i.skinRequired=I(o,"skin",!1);for(let c=0;c<o.bones.length;c++){let u=o.bones[c],d=s.findBone(u);if(!d)throw new Error(`Couldn't find bone ${u} for path constraint ${o.name}.`);i.bones.push(d)}let l=o.target,a=s.findSlot(l);if(!a)throw new Error(`Couldn't find target slot ${l} for path constraint ${o.name}.`);i.target=a,i.positionMode=R.enumValue($e,I(o,"positionMode","Percent")),i.spacingMode=R.enumValue(je,I(o,"spacingMode","Length")),i.rotateMode=R.enumValue(Ke,I(o,"rotateMode","Tangent")),i.offsetRotation=I(o,"rotation",0),i.position=I(o,"position",0),i.positionMode==0&&(i.position*=t),i.spacing=I(o,"spacing",0),(i.spacingMode==0||i.spacingMode==1)&&(i.spacing*=t),i.mixRotate=I(o,"mixRotate",1),i.mixX=I(o,"mixX",1),i.mixY=I(o,"mixY",i.mixX),s.pathConstraints.push(i)}if(r.physics)for(let h=0;h<r.physics.length;h++){const o=r.physics[h],i=new Xs(o.name);i.order=I(o,"order",0),i.skinRequired=I(o,"skin",!1);const l=o.bone,a=s.findBone(l);if(a==null)throw new Error("Physics bone not found: "+l);i.bone=a,i.x=I(o,"x",0),i.y=I(o,"y",0),i.rotate=I(o,"rotate",0),i.scaleX=I(o,"scaleX",0),i.shearX=I(o,"shearX",0),i.limit=I(o,"limit",5e3)*t,i.step=1/I(o,"fps",60),i.inertia=I(o,"inertia",1),i.strength=I(o,"strength",100),i.damping=I(o,"damping",1),i.massInverse=1/I(o,"mass",1),i.wind=I(o,"wind",0),i.gravity=I(o,"gravity",0),i.mix=I(o,"mix",1),i.inertiaGlobal=I(o,"inertiaGlobal",!1),i.strengthGlobal=I(o,"strengthGlobal",!1),i.dampingGlobal=I(o,"dampingGlobal",!1),i.massGlobal=I(o,"massGlobal",!1),i.windGlobal=I(o,"windGlobal",!1),i.gravityGlobal=I(o,"gravityGlobal",!1),i.mixGlobal=I(o,"mixGlobal",!1),s.physicsConstraints.push(i)}if(r.skins)for(let h=0;h<r.skins.length;h++){let o=r.skins[h],i=new Je(o.name);if(o.bones)for(let l=0;l<o.bones.length;l++){let a=o.bones[l],c=s.findBone(a);if(!c)throw new Error(`Couldn't find bone ${a} for skin ${o.name}.`);i.bones.push(c)}if(o.ik)for(let l=0;l<o.ik.length;l++){let a=o.ik[l],c=s.findIkConstraint(a);if(!c)throw new Error(`Couldn't find IK constraint ${a} for skin ${o.name}.`);i.constraints.push(c)}if(o.transform)for(let l=0;l<o.transform.length;l++){let a=o.transform[l],c=s.findTransformConstraint(a);if(!c)throw new Error(`Couldn't find transform constraint ${a} for skin ${o.name}.`);i.constraints.push(c)}if(o.path)for(let l=0;l<o.path.length;l++){let a=o.path[l],c=s.findPathConstraint(a);if(!c)throw new Error(`Couldn't find path constraint ${a} for skin ${o.name}.`);i.constraints.push(c)}if(o.physics)for(let l=0;l<o.physics.length;l++){let a=o.physics[l],c=s.findPhysicsConstraint(a);if(!c)throw new Error(`Couldn't find physics constraint ${a} for skin ${o.name}.`);i.constraints.push(c)}for(let l in o.attachments){let a=s.findSlot(l);if(!a)throw new Error(`Couldn't find slot ${l} for skin ${o.name}.`);let c=o.attachments[l];for(let u in c){let d=this.readAttachment(c[u],i,a.index,u,s);d&&i.setAttachment(a.index,u,d)}}s.skins.push(i),i.name=="default"&&(s.defaultSkin=i)}for(let h=0,o=this.linkedMeshes.length;h<o;h++){let i=this.linkedMeshes[h],l=i.skin?s.findSkin(i.skin):s.defaultSkin;if(!l)throw new Error(`Skin not found: ${i.skin}`);let a=l.getAttachment(i.slotIndex,i.parent);if(!a)throw new Error(`Parent mesh not found: ${i.parent}`);i.mesh.timelineAttachment=i.inheritTimeline?a:i.mesh,i.mesh.setParentMesh(a),i.mesh.region!=null&&i.mesh.updateRegion()}if(this.linkedMeshes.length=0,r.events)for(let h in r.events){let o=r.events[h],i=new Ut(h);i.intValue=I(o,"int",0),i.floatValue=I(o,"float",0),i.stringValue=I(o,"string",""),i.audioPath=I(o,"audio",null),i.audioPath&&(i.volume=I(o,"volume",1),i.balance=I(o,"balance",0)),s.events.push(i)}if(r.animations)for(let h in r.animations){let o=r.animations[h];this.readAnimation(o,h,s)}return s}readAttachment(e,t,s,r,n){let h=this.scale;switch(r=I(e,"name",r),I(e,"type","region")){case"region":{let o=I(e,"path",r),i=this.readSequence(I(e,"sequence",null)),l=this.attachmentLoader.newRegionAttachment(t,r,o,i);if(!l)return null;l.path=o,l.x=I(e,"x",0)*h,l.y=I(e,"y",0)*h,l.scaleX=I(e,"scaleX",1),l.scaleY=I(e,"scaleY",1),l.rotation=I(e,"rotation",0),l.width=e.width*h,l.height=e.height*h,l.sequence=i;let a=I(e,"color",null);return a&&l.color.setFromString(a),l.region!=null&&l.updateRegion(),l}case"boundingbox":{let o=this.attachmentLoader.newBoundingBoxAttachment(t,r);if(!o)return null;this.readVertices(e,o,e.vertexCount<<1);let i=I(e,"color",null);return i&&o.color.setFromString(i),o}case"mesh":case"linkedmesh":{let o=I(e,"path",r),i=this.readSequence(I(e,"sequence",null)),l=this.attachmentLoader.newMeshAttachment(t,r,o,i);if(!l)return null;l.path=o;let a=I(e,"color",null);a&&l.color.setFromString(a),l.width=I(e,"width",0)*h,l.height=I(e,"height",0)*h,l.sequence=i;let c=I(e,"parent",null);if(c)return this.linkedMeshes.push(new Xi(l,I(e,"skin",null),s,c,I(e,"timelines",!0))),l;let u=e.uvs;return this.readVertices(e,l,u.length),l.triangles=e.triangles,l.regionUVs=u,l.region!=null&&l.updateRegion(),l.edges=I(e,"edges",null),l.hullLength=I(e,"hull",0)*2,l}case"path":{let o=this.attachmentLoader.newPathAttachment(t,r);if(!o)return null;o.closed=I(e,"closed",!1),o.constantSpeed=I(e,"constantSpeed",!0);let i=e.vertexCount;this.readVertices(e,o,i<<1);let l=R.newArray(i/3,0);for(let c=0;c<e.lengths.length;c++)l[c]=e.lengths[c]*h;o.lengths=l;let a=I(e,"color",null);return a&&o.color.setFromString(a),o}case"point":{let o=this.attachmentLoader.newPointAttachment(t,r);if(!o)return null;o.x=I(e,"x",0)*h,o.y=I(e,"y",0)*h,o.rotation=I(e,"rotation",0);let i=I(e,"color",null);return i&&o.color.setFromString(i),o}case"clipping":{let o=this.attachmentLoader.newClippingAttachment(t,r);if(!o)return null;let i=I(e,"end",null);i&&(o.endSlot=n.findSlot(i));let l=e.vertexCount;this.readVertices(e,o,l<<1);let a=I(e,"color",null);return a&&o.color.setFromString(a),o}}return null}readSequence(e){if(e==null)return null;let t=new rt(I(e,"count",0));return t.start=I(e,"start",1),t.digits=I(e,"digits",0),t.setupIndex=I(e,"setup",0),t}readVertices(e,t,s){let r=this.scale;t.worldVerticesLength=s;let n=e.vertices;if(s==n.length){let i=R.toFloatArray(n);if(r!=1)for(let l=0,a=n.length;l<a;l++)i[l]*=r;t.vertices=i;return}let h=new Array,o=new Array;for(let i=0,l=n.length;i<l;){let a=n[i++];o.push(a);for(let c=i+a*4;i<c;i+=4)o.push(n[i]),h.push(n[i+1]*r),h.push(n[i+2]*r),h.push(n[i+3])}t.bones=o,t.vertices=R.toFloatArray(h)}readAnimation(e,t,s){let r=this.scale,n=new Array;if(e.slots)for(let o in e.slots){let i=e.slots[o],l=s.findSlot(o);if(!l)throw new Error("Slot not found: "+o);let a=l.index;for(let c in i){let u=i[c];if(!u)continue;let d=u.length;if(c=="attachment"){let f=new we(d,a);for(let m=0;m<d;m++){let x=u[m];f.setFrame(m,I(x,"time",0),I(x,"name",null))}n.push(f)}else if(c=="rgba"){let f=new gt(d,d<<2,a),m=u[0],x=I(m,"time",0),b=D.fromString(m.color);for(let w=0,g=0;;w++){f.setFrame(w,x,b.r,b.g,b.b,b.a);let p=u[w+1];if(!p){f.shrink(g);break}let v=I(p,"time",0),y=D.fromString(p.color),S=m.curve;S&&(g=H(S,f,g,w,0,x,v,b.r,y.r,1),g=H(S,f,g,w,1,x,v,b.g,y.g,1),g=H(S,f,g,w,2,x,v,b.b,y.b,1),g=H(S,f,g,w,3,x,v,b.a,y.a,1)),x=v,b=y,m=p}n.push(f)}else if(c=="rgb"){let f=new xt(d,d*3,a),m=u[0],x=I(m,"time",0),b=D.fromString(m.color);for(let w=0,g=0;;w++){f.setFrame(w,x,b.r,b.g,b.b);let p=u[w+1];if(!p){f.shrink(g);break}let v=I(p,"time",0),y=D.fromString(p.color),S=m.curve;S&&(g=H(S,f,g,w,0,x,v,b.r,y.r,1),g=H(S,f,g,w,1,x,v,b.g,y.g,1),g=H(S,f,g,w,2,x,v,b.b,y.b,1)),x=v,b=y,m=p}n.push(f)}else if(c=="alpha")n.push(he(u,new pt(d,d,a),0,1));else if(c=="rgba2"){let f=new wt(d,d*7,a),m=u[0],x=I(m,"time",0),b=D.fromString(m.light),w=D.fromString(m.dark);for(let g=0,p=0;;g++){f.setFrame(g,x,b.r,b.g,b.b,b.a,w.r,w.g,w.b);let v=u[g+1];if(!v){f.shrink(p);break}let y=I(v,"time",0),S=D.fromString(v.light),A=D.fromString(v.dark),k=m.curve;k&&(p=H(k,f,p,g,0,x,y,b.r,S.r,1),p=H(k,f,p,g,1,x,y,b.g,S.g,1),p=H(k,f,p,g,2,x,y,b.b,S.b,1),p=H(k,f,p,g,3,x,y,b.a,S.a,1),p=H(k,f,p,g,4,x,y,w.r,A.r,1),p=H(k,f,p,g,5,x,y,w.g,A.g,1),p=H(k,f,p,g,6,x,y,w.b,A.b,1)),x=y,b=S,w=A,m=v}n.push(f)}else if(c=="rgb2"){let f=new bt(d,d*6,a),m=u[0],x=I(m,"time",0),b=D.fromString(m.light),w=D.fromString(m.dark);for(let g=0,p=0;;g++){f.setFrame(g,x,b.r,b.g,b.b,w.r,w.g,w.b);let v=u[g+1];if(!v){f.shrink(p);break}let y=I(v,"time",0),S=D.fromString(v.light),A=D.fromString(v.dark),k=m.curve;k&&(p=H(k,f,p,g,0,x,y,b.r,S.r,1),p=H(k,f,p,g,1,x,y,b.g,S.g,1),p=H(k,f,p,g,2,x,y,b.b,S.b,1),p=H(k,f,p,g,3,x,y,w.r,A.r,1),p=H(k,f,p,g,4,x,y,w.g,A.g,1),p=H(k,f,p,g,5,x,y,w.b,A.b,1)),x=y,b=S,w=A,m=v}n.push(f)}}}if(e.bones)for(let o in e.bones){let i=e.bones[o],l=s.findBone(o);if(!l)throw new Error("Bone not found: "+o);let a=l.index;for(let c in i){let u=i[c],d=u.length;if(d!=0){if(c==="rotate")n.push(he(u,new Xe(d,d,a),0,1));else if(c==="translate"){let f=new nt(d,d<<1,a);n.push(Zt(u,f,"x","y",0,r))}else if(c==="translatex"){let f=new at(d,d,a);n.push(he(u,f,0,r))}else if(c==="translatey"){let f=new lt(d,d,a);n.push(he(u,f,0,r))}else if(c==="scale"){let f=new ot(d,d<<1,a);n.push(Zt(u,f,"x","y",1,1))}else if(c==="scalex"){let f=new ht(d,d,a);n.push(he(u,f,1,1))}else if(c==="scaley"){let f=new ct(d,d,a);n.push(he(u,f,1,1))}else if(c==="shear"){let f=new dt(d,d<<1,a);n.push(Zt(u,f,"x","y",0,1))}else if(c==="shearx"){let f=new ft(d,d,a);n.push(he(u,f,0,1))}else if(c==="sheary"){let f=new ut(d,d,a);n.push(he(u,f,0,1))}else if(c==="inherit"){let f=new mt(d,l.index);for(let m=0;m<u.length;m++){let x=u[m];f.setFrame(m,I(x,"time",0),R.enumValue(Re,I(x,"inherit","Normal")))}n.push(f)}}}}if(e.ik)for(let o in e.ik){let i=e.ik[o],l=i[0];if(!l)continue;let a=s.findIkConstraint(o);if(!a)throw new Error("IK Constraint not found: "+o);let c=s.ikConstraints.indexOf(a),u=new vt(i.length,i.length<<1,c),d=I(l,"time",0),f=I(l,"mix",1),m=I(l,"softness",0)*r;for(let x=0,b=0;;x++){u.setFrame(x,d,f,m,I(l,"bendPositive",!0)?1:-1,I(l,"compress",!1),I(l,"stretch",!1));let w=i[x+1];if(!w){u.shrink(b);break}let g=I(w,"time",0),p=I(w,"mix",1),v=I(w,"softness",0)*r,y=l.curve;y&&(b=H(y,u,b,x,0,d,g,f,p,1),b=H(y,u,b,x,1,d,g,m,v,r)),d=g,f=p,m=v,l=w}n.push(u)}if(e.transform)for(let o in e.transform){let i=e.transform[o],l=i[0];if(!l)continue;let a=s.findTransformConstraint(o);if(!a)throw new Error("Transform constraint not found: "+o);let c=s.transformConstraints.indexOf(a),u=new St(i.length,i.length*6,c),d=I(l,"time",0),f=I(l,"mixRotate",1),m=I(l,"mixX",1),x=I(l,"mixY",m),b=I(l,"mixScaleX",1),w=I(l,"mixScaleY",b),g=I(l,"mixShearY",1);for(let p=0,v=0;;p++){u.setFrame(p,d,f,m,x,b,w,g);let y=i[p+1];if(!y){u.shrink(v);break}let S=I(y,"time",0),A=I(y,"mixRotate",1),k=I(y,"mixX",1),Y=I(y,"mixY",k),M=I(y,"mixScaleX",1),E=I(y,"mixScaleY",M),X=I(y,"mixShearY",1),C=l.curve;C&&(v=H(C,u,v,p,0,d,S,f,A,1),v=H(C,u,v,p,1,d,S,m,k,1),v=H(C,u,v,p,2,d,S,x,Y,1),v=H(C,u,v,p,3,d,S,b,M,1),v=H(C,u,v,p,4,d,S,w,E,1),v=H(C,u,v,p,5,d,S,g,X,1)),d=S,f=A,m=k,x=Y,b=M,w=E,b=M,l=y}n.push(u)}if(e.path)for(let o in e.path){let i=e.path[o],l=s.findPathConstraint(o);if(!l)throw new Error("Path constraint not found: "+o);let a=s.pathConstraints.indexOf(l);for(let c in i){let u=i[c],d=u[0];if(!d)continue;let f=u.length;if(c==="position"){let m=new At(f,f,a);n.push(he(u,m,0,l.positionMode==0?r:1))}else if(c==="spacing"){let m=new It(f,f,a);n.push(he(u,m,0,l.spacingMode==0||l.spacingMode==1?r:1))}else if(c==="mix"){let m=new Ct(f,f*3,a),x=I(d,"time",0),b=I(d,"mixRotate",1),w=I(d,"mixX",1),g=I(d,"mixY",w);for(let p=0,v=0;;p++){m.setFrame(p,x,b,w,g);let y=u[p+1];if(!y){m.shrink(v);break}let S=I(y,"time",0),A=I(y,"mixRotate",1),k=I(y,"mixX",1),Y=I(y,"mixY",k),M=d.curve;M&&(v=H(M,m,v,p,0,x,S,b,A,1),v=H(M,m,v,p,1,x,S,w,k,1),v=H(M,m,v,p,2,x,S,g,Y,1)),x=S,b=A,w=k,g=Y,d=y}n.push(m)}}}if(e.physics)for(let o in e.physics){let i=e.physics[o],l=-1;if(o.length>0){let a=s.findPhysicsConstraint(o);if(!a)throw new Error("Physics constraint not found: "+o);l=s.physicsConstraints.indexOf(a)}for(let a in i){let c=i[a],u=c[0];if(!u)continue;let d=c.length;if(a=="reset"){const m=new _e(d,l);for(let x=0;u!=null;u=c[x+1],x++)m.setFrame(x,I(u,"time",0));n.push(m);continue}let f;if(a=="inertia")f=new kt(d,d,l);else if(a=="strength")f=new Mt(d,d,l);else if(a=="damping")f=new Yt(d,d,l);else if(a=="mass")f=new Tt(d,d,l);else if(a=="wind")f=new Xt(d,d,l);else if(a=="gravity")f=new Ft(d,d,l);else if(a=="mix")f=new Et(d,d,l);else continue;n.push(he(c,f,0,1))}}if(e.attachments)for(let o in e.attachments){let i=e.attachments[o],l=s.findSkin(o);if(!l)throw new Error("Skin not found: "+o);for(let a in i){let c=i[a],u=s.findSlot(a);if(!u)throw new Error("Slot not found: "+a);let d=u.index;for(let f in c){let m=c[f],x=l.getAttachment(d,f);for(let b in m){let w=m[b],g=w[0];if(g){if(b=="deform"){let p=x.bones,v=x.vertices,y=p?v.length/3*2:v.length,S=new yt(w.length,w.length,d,x),A=I(g,"time",0);for(let k=0,Y=0;;k++){let M,E=I(g,"vertices",null);if(!E)M=p?R.newFloatArray(y):v;else{M=R.newFloatArray(y);let P=I(g,"offset",0);if(R.arrayCopy(E,0,M,P,E.length),r!=1)for(let N=P,q=N+E.length;N<q;N++)M[N]*=r;if(!p)for(let N=0;N<y;N++)M[N]+=v[N]}S.setFrame(k,A,M);let X=w[k+1];if(!X){S.shrink(Y);break}let C=I(X,"time",0),T=g.curve;T&&(Y=H(T,S,Y,k,0,A,C,0,1,1)),A=C,g=X}n.push(S)}else if(b=="sequence"){let p=new Ae(w.length,d,x),v=0;for(let y=0;y<w.length;y++){let S=I(g,"delay",v),A=I(g,"time",0),k=os[I(g,"mode","hold")],Y=I(g,"index",0);p.setFrame(y,A,k,Y,S),v=S,g=w[y+1]}n.push(p)}}}}}}if(e.drawOrder){let o=new be(e.drawOrder.length),i=s.slots.length,l=0;for(let a=0;a<e.drawOrder.length;a++,l++){let c=e.drawOrder[a],u=null,d=I(c,"offsets",null);if(d){u=R.newArray(i,-1);let f=R.newArray(i-d.length,0),m=0,x=0;for(let b=0;b<d.length;b++){let w=d[b],g=s.findSlot(w.slot);if(!g)throw new Error("Slot not found: "+g);let p=g.index;for(;m!=p;)f[x++]=m++;u[m+w.offset]=m++}for(;m<i;)f[x++]=m++;for(let b=i-1;b>=0;b--)u[b]==-1&&(u[b]=f[--x])}o.setFrame(l,I(c,"time",0),u)}n.push(o)}if(e.events){let o=new Fe(e.events.length),i=0;for(let l=0;l<e.events.length;l++,i++){let a=e.events[l],c=s.findEvent(a.name);if(!c)throw new Error("Event not found: "+a.name);let u=new Wt(R.toSinglePrecision(I(a,"time",0)),c);u.intValue=I(a,"int",c.intValue),u.floatValue=I(a,"float",c.floatValue),u.stringValue=I(a,"string",c.stringValue),u.data.audioPath&&(u.volume=I(a,"volume",1),u.balance=I(a,"balance",0)),o.setFrame(i,u)}n.push(o)}let h=0;for(let o=0,i=n.length;o<i;o++)h=Math.max(h,n[o].getDuration());s.animations.push(new Oe(t,n,h))}},Xi=class{parent;skin;slotIndex;mesh;inheritTimeline;constructor(e,t,s,r,n){this.mesh=e,this.skin=t,this.slotIndex=s,this.parent=r,this.inheritTimeline=n}};function he(e,t,s,r){let n=e[0],h=I(n,"time",0),o=I(n,"value",s)*r,i=0;for(let l=0;;l++){t.setFrame(l,h,o);let a=e[l+1];if(!a)return t.shrink(i),t;let c=I(a,"time",0),u=I(a,"value",s)*r;n.curve&&(i=H(n.curve,t,i,l,0,h,c,o,u,r)),h=c,o=u,n=a}}function Zt(e,t,s,r,n,h){let o=e[0],i=I(o,"time",0),l=I(o,s,n)*h,a=I(o,r,n)*h,c=0;for(let u=0;;u++){t.setFrame(u,i,l,a);let d=e[u+1];if(!d)return t.shrink(c),t;let f=I(d,"time",0),m=I(d,s,n)*h,x=I(d,r,n)*h,b=o.curve;b&&(c=H(b,t,c,u,0,i,f,l,m,h),c=H(b,t,c,u,1,i,f,a,x,h)),i=f,l=m,a=x,o=d}}function H(e,t,s,r,n,h,o,i,l,a){if(e=="stepped")return t.setStepped(r),s;let c=n<<2,u=e[c],d=e[c+1]*a,f=e[c+2],m=e[c+3]*a;return t.setBezier(s,r,n,h,i,u,d,f,m,o,l),s+1}function I(e,t,s){return e[t]!==void 0?e[t]:s}typeof Math.fround>"u"&&(Math.fround=function(e){return function(t){return e[0]=t,e[0]}}(new Float32Array(1))),ke.yDown=!0;function Fi(e,t){switch(t){case 0:return e.BlendMode.SrcOver;case 1:return e.BlendMode.Plus;case 2:return e.BlendMode.SrcOver;case 3:return e.BlendMode.Screen;default:return e.BlendMode.SrcOver}}function Ps(e){if(typeof Buffer<"u")return e.toString("utf-8");if(typeof TextDecoder<"u")return new TextDecoder("utf-8").decode(e);throw new Error("Unsupported environment")}var Bs=class extends Lt{getImage(){return this._image}setFilters(e,t){}setWraps(e,t){}dispose(){const e=this._image;for(const t of e.paintPerBlendMode.values())t.delete();for(const t of e.shaders)t.delete();e.image.delete(),this._image=null}static async fromFile(e,t,s){const r=await s(t);if(!r)throw new Error(`Could not load image ${t}`);const n=e.MakeImageFromEncoded(r);if(!n)throw new Error(`Could not load image ${t}`);const h=new Map,o=[];for(const i of[0,1,2,3]){const l=new e.Paint,a=n.makeShaderOptions(e.TileMode.Clamp,e.TileMode.Clamp,e.FilterMode.Linear,e.MipmapMode.Linear);l.setShader(a),l.setBlendMode(Fi(e,i)),h.set(i,l),o.push(a)}return new Bs({shaders:o,paintPerBlendMode:h,image:n})}};async function Ei(e,t,s){const r=new Nt(Ps(await s(t))),n=t.lastIndexOf("/"),h=n>=0?t.substring(0,n+1):"";for(const o of r.pages){const i=await Bs.fromFile(e,h+o.name,s);o.setTexture(i)}return r}async function Ri(e,t,s,r=1){const n=new Is(t),h=e.endsWith(".json")?new Rs(n):new Fs(n);h.scale=r;let o=await s(e);return e.endsWith(".json")&&(o=Ps(o)),h.readSkeletonData(o)}var Vs=class{skeleton;animationState;constructor(e){this.skeleton=new ke(e),this.animationState=new Rt(new bs(e))}update(e,t=2){this.animationState.update(e),this.skeleton.update(e),this.animationState.apply(this.skeleton),this.skeleton.updateWorldTransform(t)}},Ls=class{constructor(e){this.ck=e}clipper=new Ze;tempColor=new D;tempColor2=new D;scratchPositions=R.newFloatArray(100);scratchColors=R.newFloatArray(100);scratchUVs=R.newFloatArray(100);render(e,t){t instanceof Vs&&(t=t.skeleton);let s=this.clipper,r=t.drawOrder,n=t.color;for(let h=0,o=r.length;h<o;h++){let i=r[h];if(!i.bone.active){s.clipEndWithSlot(i);continue}let l=i.getAttachment(),a=this.scratchPositions,c=this.scratchColors,u,d,f,m,x=0;if(l instanceof U){let b=l;a=a.length<8?R.newFloatArray(8):a,x=4,b.computeWorldVertices(i,a,0,2),f=Ls.QUAD_TRIANGLES,u=b.uvs,d=b.region?.texture,m=b.color}else if(l instanceof ye){let b=l;a=a.length<b.worldVerticesLength?R.newFloatArray(b.worldVerticesLength):a,x=b.worldVerticesLength>>1,b.computeWorldVertices(i,0,b.worldVerticesLength,a,0,2),f=b.triangles,d=b.region?.texture,u=b.uvs,m=b.color}else if(l instanceof Ee){let b=l;s.clipStart(i,b);continue}else{s.clipEndWithSlot(i);continue}if(d){s.isClipping()&&(s.clipTrianglesUnpacked(a,f,f.length,u),a=s.clippedVertices,u=s.clippedUVs,f=s.clippedTriangles);let b=i.color,w=this.tempColor;w.r=n.r*b.r*m.r,w.g=n.g*b.g*m.g,w.b=n.b*b.b*m.b,w.a=n.a*b.a*m.a,c.length/4<x&&(c=R.newFloatArray(x*4));for(let A=0,k=x*4;A<k;A+=4)c[A]=w.r,c[A+1]=w.g,c[A+2]=w.b,c[A+3]=w.a;const g=this.scratchUVs.length<u.length?R.newFloatArray(u.length):this.scratchUVs,p=d.getImage().image.width(),v=d.getImage().image.height();for(let A=0;A<u.length;A+=2)g[A]=u[A]*p,g[A+1]=u[A+1]*v;const y=i.data.blendMode,S=this.ck.MakeVertices(this.ck.VertexMode.Triangles,a,g,c,f,!1);e.drawVertices(S,this.ck.BlendMode.Modulate,d.getImage().paintPerBlendMode.get(y)),S.delete()}s.clipEndWithSlot(i)}s.clipEnd()}},Ns=Ls;B(Ns,"QUAD_TRIANGLES",[0,1,2,2,3,0]);export{pt as AlphaTimeline,Oe as Animation,Rt as AnimationState,Gs as AnimationStateAdapter,bs as AnimationStateData,js as AssetManagerBase,Is as AtlasAttachmentLoader,it as Attachment,we as AttachmentTimeline,Es as BinaryInput,Qe as BlendMode,_t as Bone,qt as BoneData,Ge as BoundingBoxAttachment,ws as CURRENT,Ee as ClippingAttachment,D as Color,Pe as ConstraintData,oe as CurveTimeline,ne as CurveTimeline1,qe as CurveTimeline2,Ws as DebugUtils,yt as DeformTimeline,Cs as Downloader,be as DrawOrderTimeline,Wt as Event,Ut as EventData,xs as EventQueue,Fe as EventTimeline,se as EventType,Pt as FIRST,Hs as FakeTexture,ze as HOLD_FIRST,ps as HOLD_MIX,Bt as HOLD_SUBSEQUENT,ks as IkConstraint,zt as IkConstraintData,vt as IkConstraintTimeline,Re as Inherit,mt as InheritTimeline,qs as IntSet,ns as Interpolation,F as MathUtils,ye as MeshAttachment,cs as MixBlend,ds as MixDirection,Ie as PathAttachment,Ce as PathConstraint,Gt as PathConstraintData,Ct as PathConstraintMixTimeline,At as PathConstraintPositionTimeline,It as PathConstraintSpacingTimeline,Ts as Physics,Yt as PhysicsConstraintDampingTimeline,Ft as PhysicsConstraintGravityTimeline,kt as PhysicsConstraintInertiaTimeline,Tt as PhysicsConstraintMassTimeline,Et as PhysicsConstraintMixTimeline,_e as PhysicsConstraintResetTimeline,Mt as PhysicsConstraintStrengthTimeline,ue as PhysicsConstraintTimeline,Xt as PhysicsConstraintWindTimeline,Ot as PointAttachment,Te as Pool,$e as PositionMode,as as Pow,_s as PowOut,bt as RGB2Timeline,wt as RGBA2Timeline,gt as RGBATimeline,xt as RGBTimeline,U as RegionAttachment,Ke as RotateMode,Xe as RotateTimeline,Vt as SETUP,Ue as SUBSEQUENT,ot as ScaleTimeline,ht as ScaleXTimeline,ct as ScaleYTimeline,Ae as SequenceTimeline,dt as ShearTimeline,ft as ShearXTimeline,ut as ShearYTimeline,ke as Skeleton,Fs as SkeletonBinary,Ti as SkeletonBounds,Ze as SkeletonClipping,$t as SkeletonData,Vs as SkeletonDrawable,Rs as SkeletonJson,Ns as SkeletonRenderer,Je as Skin,jt as SkinEntry,Ms as Slot,Kt as SlotData,je as SpacingMode,st as StringSet,Lt as Texture,Nt as TextureAtlas,Ss as TextureAtlasPage,Dt as TextureAtlasRegion,He as TextureFilter,vs as TextureRegion,ys as TextureWrap,Us as TimeKeeper,K as Timeline,gs as TrackEntry,Ys as TransformConstraint,Jt as TransformConstraintData,St as TransformConstraintTimeline,nt as TranslateTimeline,at as TranslateXTimeline,lt as TranslateYTimeline,ie as Triangulator,R as Utils,Ne as Vector2,le as VertexAttachment,zs as WindowedMean,Ri as loadSkeletonData,Ei as loadTextureAtlas};
1
+ "use strict";var Us=class{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}},Gt=class{entries={};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 s=0,r=t.length;s<r;s++)this.add(t[s]);return e!=this.size}contains(t){return this.entries[t]}clear(){this.entries={},this.size=0}},N=class mt{constructor(e=0,s=0,r=0,i=0){this.r=e,this.g=s,this.b=r,this.a=i}static WHITE=new mt(1,1,1,1);static RED=new mt(1,0,0,1);static GREEN=new mt(0,1,0,1);static BLUE=new mt(0,0,1,1);static MAGENTA=new mt(1,0,1,1);set(e,s,r,i){return this.r=e,this.g=s,this.b=r,this.a=i,this.clamp()}setFromColor(e){return this.r=e.r,this.g=e.g,this.b=e.b,this.a=e.a,this}setFromString(e){return e=e.charAt(0)=="#"?e.substr(1):e,this.r=parseInt(e.substr(0,2),16)/255,this.g=parseInt(e.substr(2,2),16)/255,this.b=parseInt(e.substr(4,2),16)/255,this.a=e.length!=8?1:parseInt(e.substr(6,2),16)/255,this}add(e,s,r,i){return this.r+=e,this.g+=s,this.b+=r,this.a+=i,this.clamp()}clamp(){return this.r<0?this.r=0:this.r>1&&(this.r=1),this.g<0?this.g=0:this.g>1&&(this.g=1),this.b<0?this.b=0:this.b>1&&(this.b=1),this.a<0?this.a=0:this.a>1&&(this.a=1),this}static rgba8888ToColor(e,s){e.r=((s&4278190080)>>>24)/255,e.g=((s&16711680)>>>16)/255,e.b=((s&65280)>>>8)/255,e.a=(s&255)/255}static rgb888ToColor(e,s){e.r=((s&16711680)>>>16)/255,e.g=((s&65280)>>>8)/255,e.b=(s&255)/255}toRgb888(){const e=s=>("0"+(s*255).toString(16)).slice(-2);return+("0x"+e(this.r)+e(this.g)+e(this.b))}static fromString(e,s=new mt){return s.setFromString(e)}},R=class at{static PI=3.1415927;static PI2=at.PI*2;static invPI2=1/at.PI2;static radiansToDegrees=180/at.PI;static radDeg=at.radiansToDegrees;static degreesToRadians=at.PI/180;static degRad=at.degreesToRadians;static clamp(e,s,r){return e<s?s:e>r?r:e}static cosDeg(e){return Math.cos(e*at.degRad)}static sinDeg(e){return Math.sin(e*at.degRad)}static atan2Deg(e,s){return Math.atan2(e,s)*at.degRad}static signum(e){return e>0?1:e<0?-1:0}static toInt(e){return e>0?Math.floor(e):Math.ceil(e)}static cbrt(e){let s=Math.pow(Math.abs(e),.3333333333333333);return e<0?-s:s}static randomTriangular(e,s){return at.randomTriangularWith(e,s,(e+s)*.5)}static randomTriangularWith(e,s,r){let i=Math.random(),h=s-e;return i<=(r-e)/h?e+Math.sqrt(i*h*(r-e)):s-Math.sqrt((1-i)*h*(s-r))}static isPowerOfTwo(e){return e&&(e&e-1)===0}},Ze=class{apply(t,e,s){return t+(e-t)*this.applyInternal(s)}},ts=class extends Ze{power=2;constructor(t){super(),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}},zs=class extends ts{constructor(t){super(t)}applyInternal(t){return Math.pow(t-1,this.power)*(this.power%2==0?-1:1)+1}},P=class pt{static SUPPORTS_TYPED_ARRAYS=typeof Float32Array<"u";static arrayCopy(e,s,r,i,h){for(let l=s,n=i;l<s+h;l++,n++)r[n]=e[l]}static arrayFill(e,s,r,i){for(let h=s;h<r;h++)e[h]=i}static setArraySize(e,s,r=0){let i=e.length;if(i==s)return e;if(e.length=s,i<s)for(let h=i;h<s;h++)e[h]=r;return e}static ensureArrayCapacity(e,s,r=0){return e.length>=s?e:pt.setArraySize(e,s,r)}static newArray(e,s){let r=new Array(e);for(let i=0;i<e;i++)r[i]=s;return r}static newFloatArray(e){if(pt.SUPPORTS_TYPED_ARRAYS)return new Float32Array(e);{let s=new Array(e);for(let r=0;r<s.length;r++)s[r]=0;return s}}static newShortArray(e){if(pt.SUPPORTS_TYPED_ARRAYS)return new Int16Array(e);{let s=new Array(e);for(let r=0;r<s.length;r++)s[r]=0;return s}}static toFloatArray(e){return pt.SUPPORTS_TYPED_ARRAYS?new Float32Array(e):e}static toSinglePrecision(e){return pt.SUPPORTS_TYPED_ARRAYS?Math.fround(e):e}static webkit602BugfixHelper(e,s){}static contains(e,s,r=!0){for(var i=0;i<e.length;i++)if(e[i]==s)return!0;return!1}static enumValue(e,s){return e[s[0].toUpperCase()+s.slice(1)]}},_s=class{static logBones(t){for(let e=0;e<t.bones.length;e++){let s=t.bones[e];console.log(s.data.name+", "+s.a+", "+s.b+", "+s.c+", "+s.d+", "+s.worldX+", "+s.worldY)}}},vt=class{items=new Array;instantiator;constructor(t){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}},Yt=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}},Gs=class{maxDelta=.064;framesPerSecond=0;delta=0;totalTime=0;lastTime=Date.now()/1e3;frameCount=0;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)}},$s=class{values;addedValues=0;lastValue=0;mean=0;dirty=!0;constructor(t=32){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}},$t=class{name;constructor(t){if(!t)throw new Error("name cannot be null.");this.name=t}},lt=class Es extends $t{static nextID=0;id=Es.nextID++;bones=null;vertices=[];worldVerticesLength=0;timelineAttachment=this;constructor(e){super(e)}computeWorldVertices(e,s,r,i,h,l){r=h+(r>>1)*l;let n=e.bone.skeleton,a=e.deform,o=this.vertices,c=this.bones;if(!c){a.length>0&&(o=a);let u=e.bone,w=u.worldX,b=u.worldY,p=u.a,g=u.b,x=u.c,y=u.d;for(let v=s,A=h;A<r;v+=2,A+=l){let S=o[v],C=o[v+1];i[A]=S*p+C*g+w,i[A+1]=S*x+C*y+b}return}let f=0,d=0;for(let u=0;u<s;u+=2){let w=c[f];f+=w+1,d+=w}let m=n.bones;if(a.length==0)for(let u=h,w=d*3;u<r;u+=l){let b=0,p=0,g=c[f++];for(g+=f;f<g;f++,w+=3){let x=m[c[f]],y=o[w],v=o[w+1],A=o[w+2];b+=(y*x.a+v*x.b+x.worldX)*A,p+=(y*x.c+v*x.d+x.worldY)*A}i[u]=b,i[u+1]=p}else{let u=a;for(let w=h,b=d*3,p=d<<1;w<r;w+=l){let g=0,x=0,y=c[f++];for(y+=f;f<y;f++,b+=3,p+=2){let v=m[c[f]],A=o[b]+u[p],S=o[b+1]+u[p+1],C=o[b+2];g+=(A*v.a+S*v.b+v.worldX)*C,x+=(A*v.c+S*v.d+v.worldY)*C}i[w]=g,i[w+1]=x}}}copyTo(e){this.bones?(e.bones=new Array(this.bones.length),P.arrayCopy(this.bones,0,e.bones,0,this.bones.length)):e.bones=null,this.vertices&&(e.vertices=P.newFloatArray(this.vertices.length),P.arrayCopy(this.vertices,0,e.vertices,0,this.vertices.length)),e.worldVerticesLength=this.worldVerticesLength,e.timelineAttachment=this.timelineAttachment}},es=class Wt{static _nextID=0;id=Wt.nextID();regions;start=0;digits=0;setupIndex=0;constructor(e){this.regions=new Array(e)}copy(){let e=new Wt(this.regions.length);return P.arrayCopy(this.regions,0,e.regions,0,this.regions.length),e.start=this.start,e.digits=this.digits,e.setupIndex=this.setupIndex,e}apply(e,s){let r=e.sequenceIndex;r==-1&&(r=this.setupIndex),r>=this.regions.length&&(r=this.regions.length-1);let i=this.regions[r];s.region!=i&&(s.region=i,s.updateRegion())}getPath(e,s){let r=e,i=(this.start+s).toString();for(let h=this.digits-i.length;h>0;h--)r+="0";return r+=i,r}static nextID(){return Wt._nextID++}},ss=(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))(ss||{}),is=[0,1,2,3,4,5,6],Xt=class{name;timelines=[];timelineIds=new Gt;duration;constructor(t,e,s){if(!t)throw new Error("name cannot be null.");this.name=t,this.setTimelines(e),this.duration=s}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,s,r,i,h,l,n){if(!t)throw new Error("skeleton cannot be null.");r&&this.duration!=0&&(s%=this.duration,e>0&&(e%=this.duration));let a=this.timelines;for(let o=0,c=a.length;o<c;o++)a[o].apply(t,e,s,i,h,l,n)}},rs=(t=>(t[t.setup=0]="setup",t[t.first=1]="first",t[t.replace=2]="replace",t[t.add=3]="add",t))(rs||{}),ns=(t=>(t[t.mixIn=0]="mixIn",t[t.mixOut=1]="mixOut",t))(ns||{}),q={rotate:0,x:1,y:2,scaleX:3,scaleY:4,shearX:5,shearY:6,inherit:7,rgb:8,alpha:9,rgb2:10,attachment:11,deform:12,event:13,drawOrder:14,ikConstraint:15,transformConstraint:16,pathConstraintPosition:17,pathConstraintSpacing:18,pathConstraintMix:19,physicsConstraintInertia:20,physicsConstraintStrength:21,physicsConstraintDamping:22,physicsConstraintMass:23,physicsConstraintWind:24,physicsConstraintGravity:25,physicsConstraintMix:26,physicsConstraintReset:27,sequence:28},H=class{propertyIds;frames;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 s=t.length;for(let r=1;r<s;r++)if(t[r]>e)return r-1;return s-1}static search(t,e,s){let r=t.length;for(let i=s;i<r;i+=s)if(t[i]>e)return i-s;return r-s}},rt=class extends H{curves;constructor(t,e,s){super(t,s),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 s=P.newFloatArray(e);P.arrayCopy(this.curves,0,s,0,e),this.curves=s}}setBezier(t,e,s,r,i,h,l,n,a,o,c){let f=this.curves,d=this.getFrameCount()+t*18;s==0&&(f[e]=2+d);let m=(r-h*2+n)*.03,u=(i-l*2+a)*.03,w=((h-n)*3-r+o)*.006,b=((l-a)*3-i+c)*.006,p=m*2+w,g=u*2+b,x=(h-r)*.3+m+w*.16666667,y=(l-i)*.3+u+b*.16666667,v=r+x,A=i+y;for(let S=d+18;d<S;d+=2)f[d]=v,f[d+1]=A,x+=p,y+=g,p+=w,g+=b,v+=x,A+=y}getBezierValue(t,e,s,r){let i=this.curves;if(i[r]>t){let a=this.frames[e],o=this.frames[e+s];return o+(t-a)/(i[r]-a)*(i[r+1]-o)}let h=r+18;for(r+=2;r<h;r+=2)if(i[r]>=t){let a=i[r-2],o=i[r-1];return o+(t-a)/(i[r]-a)*(i[r+1]-o)}e+=this.getFrameEntries();let l=i[h-2],n=i[h-1];return n+(t-l)/(this.frames[e]-l)*(this.frames[e+s]-n)}},st=class extends rt{constructor(t,e,s){super(t,e,[s])}getFrameEntries(){return 2}setFrame(t,e,s){t<<=1,this.frames[t]=e,this.frames[t+1]=s}getCurveValue(t){let e=this.frames,s=e.length-2;for(let i=2;i<=s;i+=2)if(e[i]>t){s=i-2;break}let r=this.curves[s>>1];switch(r){case 0:let i=e[s],h=e[s+1];return h+(t-i)/(e[s+2]-i)*(e[s+2+1]-h);case 1:return e[s+1]}return this.getBezierValue(t,s,1,r-2)}getRelativeValue(t,e,s,r,i){if(t<this.frames[0]){switch(s){case 0:return i;case 1:return r+(i-r)*e}return r}let h=this.getCurveValue(t);switch(s){case 0:return i+h*e;case 1:case 2:h+=i-r}return r+h*e}getAbsoluteValue(t,e,s,r,i){if(t<this.frames[0]){switch(s){case 0:return i;case 1:return r+(i-r)*e}return r}let h=this.getCurveValue(t);return s==0?i+(h-i)*e:r+(h-r)*e}getAbsoluteValue2(t,e,s,r,i,h){if(t<this.frames[0]){switch(s){case 0:return i;case 1:return r+(i-r)*e}return r}return s==0?i+(h-i)*e:r+(h-r)*e}getScaleValue(t,e,s,r,i,h){const l=this.frames;if(t<l[0]){switch(s){case 0:return h;case 1:return i+(h-i)*e}return i}let n=this.getCurveValue(t)*h;if(e==1)return s==3?i+n-h:n;if(r==1)switch(s){case 0:return h+(Math.abs(n)*R.signum(h)-h)*e;case 1:case 2:return i+(Math.abs(n)*R.signum(i)-i)*e}else{let a=0;switch(s){case 0:return a=Math.abs(h)*R.signum(n),a+(n-a)*e;case 1:case 2:return a=Math.abs(i)*R.signum(n),a+(n-a)*e}}return i+(n-h)*e}},Ft=class extends rt{constructor(t,e,s,r){super(t,e,[s,r])}getFrameEntries(){return 3}setFrame(t,e,s,r){t*=3,this.frames[t]=e,this.frames[t+1]=s,this.frames[t+2]=r}},At=class extends st{boneIndex=0;constructor(t,e,s){super(t,e,q.rotate+"|"+s),this.boneIndex=s}apply(t,e,s,r,i,h,l){let n=t.bones[this.boneIndex];n.active&&(n.rotation=this.getRelativeValue(s,i,h,n.rotation,n.data.rotation))}},Ht=class extends Ft{boneIndex=0;constructor(t,e,s){super(t,e,q.x+"|"+s,q.y+"|"+s),this.boneIndex=s}apply(t,e,s,r,i,h,l){let n=t.bones[this.boneIndex];if(!n.active)return;let a=this.frames;if(s<a[0]){switch(h){case 0:n.x=n.data.x,n.y=n.data.y;return;case 1:n.x+=(n.data.x-n.x)*i,n.y+=(n.data.y-n.y)*i}return}let o=0,c=0,f=H.search(a,s,3),d=this.curves[f/3];switch(d){case 0:let m=a[f];o=a[f+1],c=a[f+2];let u=(s-m)/(a[f+3]-m);o+=(a[f+3+1]-o)*u,c+=(a[f+3+2]-c)*u;break;case 1:o=a[f+1],c=a[f+2];break;default:o=this.getBezierValue(s,f,1,d-2),c=this.getBezierValue(s,f,2,d+18-2)}switch(h){case 0:n.x=n.data.x+o*i,n.y=n.data.y+c*i;break;case 1:case 2:n.x+=(n.data.x+o-n.x)*i,n.y+=(n.data.y+c-n.y)*i;break;case 3:n.x+=o*i,n.y+=c*i}}},jt=class extends st{boneIndex=0;constructor(t,e,s){super(t,e,q.x+"|"+s),this.boneIndex=s}apply(t,e,s,r,i,h,l){let n=t.bones[this.boneIndex];n.active&&(n.x=this.getRelativeValue(s,i,h,n.x,n.data.x))}},Jt=class extends st{boneIndex=0;constructor(t,e,s){super(t,e,q.y+"|"+s),this.boneIndex=s}apply(t,e,s,r,i,h,l){let n=t.bones[this.boneIndex];n.active&&(n.y=this.getRelativeValue(s,i,h,n.y,n.data.y))}},Kt=class extends Ft{boneIndex=0;constructor(t,e,s){super(t,e,q.scaleX+"|"+s,q.scaleY+"|"+s),this.boneIndex=s}apply(t,e,s,r,i,h,l){let n=t.bones[this.boneIndex];if(!n.active)return;let a=this.frames;if(s<a[0]){switch(h){case 0:n.scaleX=n.data.scaleX,n.scaleY=n.data.scaleY;return;case 1:n.scaleX+=(n.data.scaleX-n.scaleX)*i,n.scaleY+=(n.data.scaleY-n.scaleY)*i}return}let o,c,f=H.search(a,s,3),d=this.curves[f/3];switch(d){case 0:let m=a[f];o=a[f+1],c=a[f+2];let u=(s-m)/(a[f+3]-m);o+=(a[f+3+1]-o)*u,c+=(a[f+3+2]-c)*u;break;case 1:o=a[f+1],c=a[f+2];break;default:o=this.getBezierValue(s,f,1,d-2),c=this.getBezierValue(s,f,2,d+18-2)}if(o*=n.data.scaleX,c*=n.data.scaleY,i==1)h==3?(n.scaleX+=o-n.data.scaleX,n.scaleY+=c-n.data.scaleY):(n.scaleX=o,n.scaleY=c);else{let m=0,u=0;if(l==1)switch(h){case 0:m=n.data.scaleX,u=n.data.scaleY,n.scaleX=m+(Math.abs(o)*R.signum(m)-m)*i,n.scaleY=u+(Math.abs(c)*R.signum(u)-u)*i;break;case 1:case 2:m=n.scaleX,u=n.scaleY,n.scaleX=m+(Math.abs(o)*R.signum(m)-m)*i,n.scaleY=u+(Math.abs(c)*R.signum(u)-u)*i;break;case 3:n.scaleX+=(o-n.data.scaleX)*i,n.scaleY+=(c-n.data.scaleY)*i}else switch(h){case 0:m=Math.abs(n.data.scaleX)*R.signum(o),u=Math.abs(n.data.scaleY)*R.signum(c),n.scaleX=m+(o-m)*i,n.scaleY=u+(c-u)*i;break;case 1:case 2:m=Math.abs(n.scaleX)*R.signum(o),u=Math.abs(n.scaleY)*R.signum(c),n.scaleX=m+(o-m)*i,n.scaleY=u+(c-u)*i;break;case 3:n.scaleX+=(o-n.data.scaleX)*i,n.scaleY+=(c-n.data.scaleY)*i}}}},Qt=class extends st{boneIndex=0;constructor(t,e,s){super(t,e,q.scaleX+"|"+s),this.boneIndex=s}apply(t,e,s,r,i,h,l){let n=t.bones[this.boneIndex];n.active&&(n.scaleX=this.getScaleValue(s,i,h,l,n.scaleX,n.data.scaleX))}},Zt=class extends st{boneIndex=0;constructor(t,e,s){super(t,e,q.scaleY+"|"+s),this.boneIndex=s}apply(t,e,s,r,i,h,l){let n=t.bones[this.boneIndex];n.active&&(n.scaleY=this.getScaleValue(s,i,h,l,n.scaleY,n.data.scaleY))}},te=class extends Ft{boneIndex=0;constructor(t,e,s){super(t,e,q.shearX+"|"+s,q.shearY+"|"+s),this.boneIndex=s}apply(t,e,s,r,i,h,l){let n=t.bones[this.boneIndex];if(!n.active)return;let a=this.frames;if(s<a[0]){switch(h){case 0:n.shearX=n.data.shearX,n.shearY=n.data.shearY;return;case 1:n.shearX+=(n.data.shearX-n.shearX)*i,n.shearY+=(n.data.shearY-n.shearY)*i}return}let o=0,c=0,f=H.search(a,s,3),d=this.curves[f/3];switch(d){case 0:let m=a[f];o=a[f+1],c=a[f+2];let u=(s-m)/(a[f+3]-m);o+=(a[f+3+1]-o)*u,c+=(a[f+3+2]-c)*u;break;case 1:o=a[f+1],c=a[f+2];break;default:o=this.getBezierValue(s,f,1,d-2),c=this.getBezierValue(s,f,2,d+18-2)}switch(h){case 0:n.shearX=n.data.shearX+o*i,n.shearY=n.data.shearY+c*i;break;case 1:case 2:n.shearX+=(n.data.shearX+o-n.shearX)*i,n.shearY+=(n.data.shearY+c-n.shearY)*i;break;case 3:n.shearX+=o*i,n.shearY+=c*i}}},ee=class extends st{boneIndex=0;constructor(t,e,s){super(t,e,q.shearX+"|"+s),this.boneIndex=s}apply(t,e,s,r,i,h,l){let n=t.bones[this.boneIndex];n.active&&(n.shearX=this.getRelativeValue(s,i,h,n.shearX,n.data.shearX))}},se=class extends st{boneIndex=0;constructor(t,e,s){super(t,e,q.shearY+"|"+s),this.boneIndex=s}apply(t,e,s,r,i,h,l){let n=t.bones[this.boneIndex];n.active&&(n.shearY=this.getRelativeValue(s,i,h,n.shearY,n.data.shearY))}},ie=class extends H{boneIndex=0;constructor(t,e){super(t,[q.inherit+"|"+e]),this.boneIndex=e}getFrameEntries(){return 2}setFrame(t,e,s){t*=2,this.frames[t]=e,this.frames[t+1]=s}apply(t,e,s,r,i,h,l){let n=t.bones[this.boneIndex];if(!n.active)return;if(l==1){h==0&&(n.inherit=n.data.inherit);return}let a=this.frames;if(s<a[0]){(h==0||h==1)&&(n.inherit=n.data.inherit);return}n.inherit=this.frames[H.search(a,s,2)+1]}},re=class extends rt{slotIndex=0;constructor(t,e,s){super(t,e,[q.rgb+"|"+s,q.alpha+"|"+s]),this.slotIndex=s}getFrameEntries(){return 5}setFrame(t,e,s,r,i,h){t*=5,this.frames[t]=e,this.frames[t+1]=s,this.frames[t+2]=r,this.frames[t+3]=i,this.frames[t+4]=h}apply(t,e,s,r,i,h,l){let n=t.slots[this.slotIndex];if(!n.bone.active)return;let a=this.frames,o=n.color;if(s<a[0]){let b=n.data.color;switch(h){case 0:o.setFromColor(b);return;case 1:o.add((b.r-o.r)*i,(b.g-o.g)*i,(b.b-o.b)*i,(b.a-o.a)*i)}return}let c=0,f=0,d=0,m=0,u=H.search(a,s,5),w=this.curves[u/5];switch(w){case 0:let b=a[u];c=a[u+1],f=a[u+2],d=a[u+3],m=a[u+4];let p=(s-b)/(a[u+5]-b);c+=(a[u+5+1]-c)*p,f+=(a[u+5+2]-f)*p,d+=(a[u+5+3]-d)*p,m+=(a[u+5+4]-m)*p;break;case 1:c=a[u+1],f=a[u+2],d=a[u+3],m=a[u+4];break;default:c=this.getBezierValue(s,u,1,w-2),f=this.getBezierValue(s,u,2,w+18-2),d=this.getBezierValue(s,u,3,w+18*2-2),m=this.getBezierValue(s,u,4,w+18*3-2)}i==1?o.set(c,f,d,m):(h==0&&o.setFromColor(n.data.color),o.add((c-o.r)*i,(f-o.g)*i,(d-o.b)*i,(m-o.a)*i))}},ne=class extends rt{slotIndex=0;constructor(t,e,s){super(t,e,[q.rgb+"|"+s]),this.slotIndex=s}getFrameEntries(){return 4}setFrame(t,e,s,r,i){t<<=2,this.frames[t]=e,this.frames[t+1]=s,this.frames[t+2]=r,this.frames[t+3]=i}apply(t,e,s,r,i,h,l){let n=t.slots[this.slotIndex];if(!n.bone.active)return;let a=this.frames,o=n.color;if(s<a[0]){let w=n.data.color;switch(h){case 0:o.r=w.r,o.g=w.g,o.b=w.b;return;case 1:o.r+=(w.r-o.r)*i,o.g+=(w.g-o.g)*i,o.b+=(w.b-o.b)*i}return}let c=0,f=0,d=0,m=H.search(a,s,4),u=this.curves[m>>2];switch(u){case 0:let w=a[m];c=a[m+1],f=a[m+2],d=a[m+3];let b=(s-w)/(a[m+4]-w);c+=(a[m+4+1]-c)*b,f+=(a[m+4+2]-f)*b,d+=(a[m+4+3]-d)*b;break;case 1:c=a[m+1],f=a[m+2],d=a[m+3];break;default:c=this.getBezierValue(s,m,1,u-2),f=this.getBezierValue(s,m,2,u+18-2),d=this.getBezierValue(s,m,3,u+18*2-2)}if(i==1)o.r=c,o.g=f,o.b=d;else{if(h==0){let w=n.data.color;o.r=w.r,o.g=w.g,o.b=w.b}o.r+=(c-o.r)*i,o.g+=(f-o.g)*i,o.b+=(d-o.b)*i}}},ae=class extends st{slotIndex=0;constructor(t,e,s){super(t,e,q.alpha+"|"+s),this.slotIndex=s}apply(t,e,s,r,i,h,l){let n=t.slots[this.slotIndex];if(!n.bone.active)return;let a=n.color;if(s<this.frames[0]){let c=n.data.color;switch(h){case 0:a.a=c.a;return;case 1:a.a+=(c.a-a.a)*i}return}let o=this.getCurveValue(s);i==1?a.a=o:(h==0&&(a.a=n.data.color.a),a.a+=(o-a.a)*i)}},le=class extends rt{slotIndex=0;constructor(t,e,s){super(t,e,[q.rgb+"|"+s,q.alpha+"|"+s,q.rgb2+"|"+s]),this.slotIndex=s}getFrameEntries(){return 8}setFrame(t,e,s,r,i,h,l,n,a){t<<=3,this.frames[t]=e,this.frames[t+1]=s,this.frames[t+2]=r,this.frames[t+3]=i,this.frames[t+4]=h,this.frames[t+5]=l,this.frames[t+6]=n,this.frames[t+7]=a}apply(t,e,s,r,i,h,l){let n=t.slots[this.slotIndex];if(!n.bone.active)return;let a=this.frames,o=n.color,c=n.darkColor;if(s<a[0]){let y=n.data.color,v=n.data.darkColor;switch(h){case 0:o.setFromColor(y),c.r=v.r,c.g=v.g,c.b=v.b;return;case 1:o.add((y.r-o.r)*i,(y.g-o.g)*i,(y.b-o.b)*i,(y.a-o.a)*i),c.r+=(v.r-c.r)*i,c.g+=(v.g-c.g)*i,c.b+=(v.b-c.b)*i}return}let f=0,d=0,m=0,u=0,w=0,b=0,p=0,g=H.search(a,s,8),x=this.curves[g>>3];switch(x){case 0:let y=a[g];f=a[g+1],d=a[g+2],m=a[g+3],u=a[g+4],w=a[g+5],b=a[g+6],p=a[g+7];let v=(s-y)/(a[g+8]-y);f+=(a[g+8+1]-f)*v,d+=(a[g+8+2]-d)*v,m+=(a[g+8+3]-m)*v,u+=(a[g+8+4]-u)*v,w+=(a[g+8+5]-w)*v,b+=(a[g+8+6]-b)*v,p+=(a[g+8+7]-p)*v;break;case 1:f=a[g+1],d=a[g+2],m=a[g+3],u=a[g+4],w=a[g+5],b=a[g+6],p=a[g+7];break;default:f=this.getBezierValue(s,g,1,x-2),d=this.getBezierValue(s,g,2,x+18-2),m=this.getBezierValue(s,g,3,x+18*2-2),u=this.getBezierValue(s,g,4,x+18*3-2),w=this.getBezierValue(s,g,5,x+18*4-2),b=this.getBezierValue(s,g,6,x+18*5-2),p=this.getBezierValue(s,g,7,x+18*6-2)}if(i==1)o.set(f,d,m,u),c.r=w,c.g=b,c.b=p;else{if(h==0){o.setFromColor(n.data.color);let y=n.data.darkColor;c.r=y.r,c.g=y.g,c.b=y.b}o.add((f-o.r)*i,(d-o.g)*i,(m-o.b)*i,(u-o.a)*i),c.r+=(w-c.r)*i,c.g+=(b-c.g)*i,c.b+=(p-c.b)*i}}},oe=class extends rt{slotIndex=0;constructor(t,e,s){super(t,e,[q.rgb+"|"+s,q.rgb2+"|"+s]),this.slotIndex=s}getFrameEntries(){return 7}setFrame(t,e,s,r,i,h,l,n){t*=7,this.frames[t]=e,this.frames[t+1]=s,this.frames[t+2]=r,this.frames[t+3]=i,this.frames[t+4]=h,this.frames[t+5]=l,this.frames[t+6]=n}apply(t,e,s,r,i,h,l){let n=t.slots[this.slotIndex];if(!n.bone.active)return;let a=this.frames,o=n.color,c=n.darkColor;if(s<a[0]){let y=n.data.color,v=n.data.darkColor;switch(h){case 0:o.r=y.r,o.g=y.g,o.b=y.b,c.r=v.r,c.g=v.g,c.b=v.b;return;case 1:o.r+=(y.r-o.r)*i,o.g+=(y.g-o.g)*i,o.b+=(y.b-o.b)*i,c.r+=(v.r-c.r)*i,c.g+=(v.g-c.g)*i,c.b+=(v.b-c.b)*i}return}let f=0,d=0,m=0,u=0,w=0,b=0,p=0,g=H.search(a,s,7),x=this.curves[g/7];switch(x){case 0:let y=a[g];f=a[g+1],d=a[g+2],m=a[g+3],w=a[g+4],b=a[g+5],p=a[g+6];let v=(s-y)/(a[g+7]-y);f+=(a[g+7+1]-f)*v,d+=(a[g+7+2]-d)*v,m+=(a[g+7+3]-m)*v,w+=(a[g+7+4]-w)*v,b+=(a[g+7+5]-b)*v,p+=(a[g+7+6]-p)*v;break;case 1:f=a[g+1],d=a[g+2],m=a[g+3],w=a[g+4],b=a[g+5],p=a[g+6];break;default:f=this.getBezierValue(s,g,1,x-2),d=this.getBezierValue(s,g,2,x+18-2),m=this.getBezierValue(s,g,3,x+18*2-2),w=this.getBezierValue(s,g,4,x+18*3-2),b=this.getBezierValue(s,g,5,x+18*4-2),p=this.getBezierValue(s,g,6,x+18*5-2)}if(i==1)o.r=f,o.g=d,o.b=m,c.r=w,c.g=b,c.b=p;else{if(h==0){let y=n.data.color,v=n.data.darkColor;o.r=y.r,o.g=y.g,o.b=y.b,c.r=v.r,c.g=v.g,c.b=v.b}o.r+=(f-o.r)*i,o.g+=(d-o.g)*i,o.b+=(m-o.b)*i,c.r+=(w-c.r)*i,c.g+=(b-c.g)*i,c.b+=(p-c.b)*i}}},ut=class extends H{slotIndex=0;attachmentNames;constructor(t,e){super(t,[q.attachment+"|"+e]),this.slotIndex=e,this.attachmentNames=new Array(t)}getFrameCount(){return this.frames.length}setFrame(t,e,s){this.frames[t]=e,this.attachmentNames[t]=s}apply(t,e,s,r,i,h,l){let n=t.slots[this.slotIndex];if(n.bone.active){if(l==1){h==0&&this.setAttachment(t,n,n.data.attachmentName);return}if(s<this.frames[0]){(h==0||h==1)&&this.setAttachment(t,n,n.data.attachmentName);return}this.setAttachment(t,n,this.attachmentNames[H.search1(this.frames,s)])}}setAttachment(t,e,s){e.setAttachment(s?t.getAttachment(this.slotIndex,s):null)}},he=class extends rt{slotIndex=0;attachment;vertices;constructor(t,e,s,r){super(t,e,[q.deform+"|"+s+"|"+r.id]),this.slotIndex=s,this.attachment=r,this.vertices=new Array(t)}getFrameCount(){return this.frames.length}setFrame(t,e,s){this.frames[t]=e,this.vertices[t]=s}setBezier(t,e,s,r,i,h,l,n,a,o,c){let f=this.curves,d=this.getFrameCount()+t*18;s==0&&(f[e]=2+d);let m=(r-h*2+n)*.03,u=a*.03-l*.06,w=((h-n)*3-r+o)*.006,b=(l-a+.33333333)*.018,p=m*2+w,g=u*2+b,x=(h-r)*.3+m+w*.16666667,y=l*.3+u+b*.16666667,v=r+x,A=y;for(let S=d+18;d<S;d+=2)f[d]=v,f[d+1]=A,x+=p,y+=g,p+=w,g+=b,v+=x,A+=y}getCurvePercent(t,e){let s=this.curves,r=s[e];switch(r){case 0:let n=this.frames[e];return(t-n)/(this.frames[e+this.getFrameEntries()]-n);case 1:return 0}if(r-=2,s[r]>t){let n=this.frames[e];return s[r+1]*(t-n)/(s[r]-n)}let i=r+18;for(r+=2;r<i;r+=2)if(s[r]>=t){let n=s[r-2],a=s[r-1];return a+(t-n)/(s[r]-n)*(s[r+1]-a)}let h=s[i-2],l=s[i-1];return l+(1-l)*(t-h)/(this.frames[e+this.getFrameEntries()]-h)}apply(t,e,s,r,i,h,l){let n=t.slots[this.slotIndex];if(!n.bone.active)return;let a=n.getAttachment();if(!a||!(a instanceof lt)||a.timelineAttachment!=this.attachment)return;let o=n.deform;o.length==0&&(h=0);let c=this.vertices,f=c[0].length,d=this.frames;if(s<d[0]){switch(h){case 0:o.length=0;return;case 1:if(i==1){o.length=0;return}o.length=f;let g=a;if(g.bones){i=1-i;for(var m=0;m<f;m++)o[m]*=i}else{let x=g.vertices;for(var m=0;m<f;m++)o[m]+=(x[m]-o[m])*i}}return}if(o.length=f,s>=d[d.length-1]){let g=c[d.length-1];if(i==1)if(h==3){let x=a;if(x.bones)for(let y=0;y<f;y++)o[y]+=g[y];else{let y=x.vertices;for(let v=0;v<f;v++)o[v]+=g[v]-y[v]}}else P.arrayCopy(g,0,o,0,f);else switch(h){case 0:{let y=a;if(y.bones)for(let v=0;v<f;v++)o[v]=g[v]*i;else{let v=y.vertices;for(let A=0;A<f;A++){let S=v[A];o[A]=S+(g[A]-S)*i}}break}case 1:case 2:for(let y=0;y<f;y++)o[y]+=(g[y]-o[y])*i;break;case 3:let x=a;if(x.bones)for(let y=0;y<f;y++)o[y]+=g[y]*i;else{let y=x.vertices;for(let v=0;v<f;v++)o[v]+=(g[v]-y[v])*i}}return}let u=H.search1(d,s),w=this.getCurvePercent(s,u),b=c[u],p=c[u+1];if(i==1)if(h==3){let g=a;if(g.bones)for(let x=0;x<f;x++){let y=b[x];o[x]+=y+(p[x]-y)*w}else{let x=g.vertices;for(let y=0;y<f;y++){let v=b[y];o[y]+=v+(p[y]-v)*w-x[y]}}}else for(let g=0;g<f;g++){let x=b[g];o[g]=x+(p[g]-x)*w}else switch(h){case 0:{let x=a;if(x.bones)for(let y=0;y<f;y++){let v=b[y];o[y]=(v+(p[y]-v)*w)*i}else{let y=x.vertices;for(let v=0;v<f;v++){let A=b[v],S=y[v];o[v]=S+(A+(p[v]-A)*w-S)*i}}break}case 1:case 2:for(let x=0;x<f;x++){let y=b[x];o[x]+=(y+(p[x]-y)*w-o[x])*i}break;case 3:let g=a;if(g.bones)for(let x=0;x<f;x++){let y=b[x];o[x]+=(y+(p[x]-y)*w)*i}else{let x=g.vertices;for(let y=0;y<f;y++){let v=b[y];o[y]+=(v+(p[y]-v)*w-x[y])*i}}}}},Et=class Rs extends H{static propertyIds=[""+q.event];events;constructor(e){super(e,Rs.propertyIds),this.events=new Array(e)}getFrameCount(){return this.frames.length}setFrame(e,s){this.frames[e]=s.time,this.events[e]=s}apply(e,s,r,i,h,l,n){if(!i)return;let a=this.frames,o=this.frames.length;if(s>r)this.apply(e,s,Number.MAX_VALUE,i,h,l,n),s=-1;else if(s>=a[o-1])return;if(r<a[0])return;let c=0;if(s<a[0])c=0;else{c=H.search1(a,s)+1;let f=a[c];for(;c>0&&a[c-1]==f;)c--}for(;c<o&&r>=a[c];c++)i.push(this.events[c])}},wt=class Ps extends H{static propertyIds=[""+q.drawOrder];drawOrders;constructor(e){super(e,Ps.propertyIds),this.drawOrders=new Array(e)}getFrameCount(){return this.frames.length}setFrame(e,s,r){this.frames[e]=s,this.drawOrders[e]=r}apply(e,s,r,i,h,l,n){if(n==1){l==0&&P.arrayCopy(e.slots,0,e.drawOrder,0,e.slots.length);return}if(r<this.frames[0]){(l==0||l==1)&&P.arrayCopy(e.slots,0,e.drawOrder,0,e.slots.length);return}let a=H.search1(this.frames,r),o=this.drawOrders[a];if(!o)P.arrayCopy(e.slots,0,e.drawOrder,0,e.slots.length);else{let c=e.drawOrder,f=e.slots;for(let d=0,m=o.length;d<m;d++)c[d]=f[o[d]]}}},ce=class extends rt{constraintIndex=0;constructor(t,e,s){super(t,e,[q.ikConstraint+"|"+s]),this.constraintIndex=s}getFrameEntries(){return 6}setFrame(t,e,s,r,i,h,l){t*=6,this.frames[t]=e,this.frames[t+1]=s,this.frames[t+2]=r,this.frames[t+3]=i,this.frames[t+4]=h?1:0,this.frames[t+5]=l?1:0}apply(t,e,s,r,i,h,l){let n=t.ikConstraints[this.constraintIndex];if(!n.active)return;let a=this.frames;if(s<a[0]){switch(h){case 0:n.mix=n.data.mix,n.softness=n.data.softness,n.bendDirection=n.data.bendDirection,n.compress=n.data.compress,n.stretch=n.data.stretch;return;case 1:n.mix+=(n.data.mix-n.mix)*i,n.softness+=(n.data.softness-n.softness)*i,n.bendDirection=n.data.bendDirection,n.compress=n.data.compress,n.stretch=n.data.stretch}return}let o=0,c=0,f=H.search(a,s,6),d=this.curves[f/6];switch(d){case 0:let m=a[f];o=a[f+1],c=a[f+2];let u=(s-m)/(a[f+6]-m);o+=(a[f+6+1]-o)*u,c+=(a[f+6+2]-c)*u;break;case 1:o=a[f+1],c=a[f+2];break;default:o=this.getBezierValue(s,f,1,d-2),c=this.getBezierValue(s,f,2,d+18-2)}h==0?(n.mix=n.data.mix+(o-n.data.mix)*i,n.softness=n.data.softness+(c-n.data.softness)*i,l==1?(n.bendDirection=n.data.bendDirection,n.compress=n.data.compress,n.stretch=n.data.stretch):(n.bendDirection=a[f+3],n.compress=a[f+4]!=0,n.stretch=a[f+5]!=0)):(n.mix+=(o-n.mix)*i,n.softness+=(c-n.softness)*i,l==0&&(n.bendDirection=a[f+3],n.compress=a[f+4]!=0,n.stretch=a[f+5]!=0))}},de=class extends rt{constraintIndex=0;constructor(t,e,s){super(t,e,[q.transformConstraint+"|"+s]),this.constraintIndex=s}getFrameEntries(){return 7}setFrame(t,e,s,r,i,h,l,n){let a=this.frames;t*=7,a[t]=e,a[t+1]=s,a[t+2]=r,a[t+3]=i,a[t+4]=h,a[t+5]=l,a[t+6]=n}apply(t,e,s,r,i,h,l){let n=t.transformConstraints[this.constraintIndex];if(!n.active)return;let a=this.frames;if(s<a[0]){let p=n.data;switch(h){case 0:n.mixRotate=p.mixRotate,n.mixX=p.mixX,n.mixY=p.mixY,n.mixScaleX=p.mixScaleX,n.mixScaleY=p.mixScaleY,n.mixShearY=p.mixShearY;return;case 1:n.mixRotate+=(p.mixRotate-n.mixRotate)*i,n.mixX+=(p.mixX-n.mixX)*i,n.mixY+=(p.mixY-n.mixY)*i,n.mixScaleX+=(p.mixScaleX-n.mixScaleX)*i,n.mixScaleY+=(p.mixScaleY-n.mixScaleY)*i,n.mixShearY+=(p.mixShearY-n.mixShearY)*i}return}let o,c,f,d,m,u,w=H.search(a,s,7),b=this.curves[w/7];switch(b){case 0:let p=a[w];o=a[w+1],c=a[w+2],f=a[w+3],d=a[w+4],m=a[w+5],u=a[w+6];let g=(s-p)/(a[w+7]-p);o+=(a[w+7+1]-o)*g,c+=(a[w+7+2]-c)*g,f+=(a[w+7+3]-f)*g,d+=(a[w+7+4]-d)*g,m+=(a[w+7+5]-m)*g,u+=(a[w+7+6]-u)*g;break;case 1:o=a[w+1],c=a[w+2],f=a[w+3],d=a[w+4],m=a[w+5],u=a[w+6];break;default:o=this.getBezierValue(s,w,1,b-2),c=this.getBezierValue(s,w,2,b+18-2),f=this.getBezierValue(s,w,3,b+18*2-2),d=this.getBezierValue(s,w,4,b+18*3-2),m=this.getBezierValue(s,w,5,b+18*4-2),u=this.getBezierValue(s,w,6,b+18*5-2)}if(h==0){let p=n.data;n.mixRotate=p.mixRotate+(o-p.mixRotate)*i,n.mixX=p.mixX+(c-p.mixX)*i,n.mixY=p.mixY+(f-p.mixY)*i,n.mixScaleX=p.mixScaleX+(d-p.mixScaleX)*i,n.mixScaleY=p.mixScaleY+(m-p.mixScaleY)*i,n.mixShearY=p.mixShearY+(u-p.mixShearY)*i}else n.mixRotate+=(o-n.mixRotate)*i,n.mixX+=(c-n.mixX)*i,n.mixY+=(f-n.mixY)*i,n.mixScaleX+=(d-n.mixScaleX)*i,n.mixScaleY+=(m-n.mixScaleY)*i,n.mixShearY+=(u-n.mixShearY)*i}},fe=class extends st{constraintIndex=0;constructor(t,e,s){super(t,e,q.pathConstraintPosition+"|"+s),this.constraintIndex=s}apply(t,e,s,r,i,h,l){let n=t.pathConstraints[this.constraintIndex];n.active&&(n.position=this.getAbsoluteValue(s,i,h,n.position,n.data.position))}},ue=class extends st{constraintIndex=0;constructor(t,e,s){super(t,e,q.pathConstraintSpacing+"|"+s),this.constraintIndex=s}apply(t,e,s,r,i,h,l){let n=t.pathConstraints[this.constraintIndex];n.active&&(n.spacing=this.getAbsoluteValue(s,i,h,n.spacing,n.data.spacing))}},me=class extends rt{constraintIndex=0;constructor(t,e,s){super(t,e,[q.pathConstraintMix+"|"+s]),this.constraintIndex=s}getFrameEntries(){return 4}setFrame(t,e,s,r,i){let h=this.frames;t<<=2,h[t]=e,h[t+1]=s,h[t+2]=r,h[t+3]=i}apply(t,e,s,r,i,h,l){let n=t.pathConstraints[this.constraintIndex];if(!n.active)return;let a=this.frames;if(s<a[0]){switch(h){case 0:n.mixRotate=n.data.mixRotate,n.mixX=n.data.mixX,n.mixY=n.data.mixY;return;case 1:n.mixRotate+=(n.data.mixRotate-n.mixRotate)*i,n.mixX+=(n.data.mixX-n.mixX)*i,n.mixY+=(n.data.mixY-n.mixY)*i}return}let o,c,f,d=H.search(a,s,4),m=this.curves[d>>2];switch(m){case 0:let u=a[d];o=a[d+1],c=a[d+2],f=a[d+3];let w=(s-u)/(a[d+4]-u);o+=(a[d+4+1]-o)*w,c+=(a[d+4+2]-c)*w,f+=(a[d+4+3]-f)*w;break;case 1:o=a[d+1],c=a[d+2],f=a[d+3];break;default:o=this.getBezierValue(s,d,1,m-2),c=this.getBezierValue(s,d,2,m+18-2),f=this.getBezierValue(s,d,3,m+18*2-2)}if(h==0){let u=n.data;n.mixRotate=u.mixRotate+(o-u.mixRotate)*i,n.mixX=u.mixX+(c-u.mixX)*i,n.mixY=u.mixY+(f-u.mixY)*i}else n.mixRotate+=(o-n.mixRotate)*i,n.mixX+=(c-n.mixX)*i,n.mixY+=(f-n.mixY)*i}},ct=class extends st{constraintIndex=0;constructor(t,e,s,r){super(t,e,r+"|"+s),this.constraintIndex=s}apply(t,e,s,r,i,h,l){let n;if(this.constraintIndex==-1){const a=s>=this.frames[0]?this.getCurveValue(s):0;for(const o of t.physicsConstraints)o.active&&this.global(o.data)&&this.set(o,this.getAbsoluteValue2(s,i,h,this.get(o),this.setup(o),a))}else n=t.physicsConstraints[this.constraintIndex],n.active&&this.set(n,this.getAbsoluteValue(s,i,h,this.get(n),this.setup(n)))}},ge=class extends ct{constructor(t,e,s){super(t,e,s,q.physicsConstraintInertia)}setup(t){return t.data.inertia}get(t){return t.inertia}set(t,e){t.inertia=e}global(t){return t.inertiaGlobal}},xe=class extends ct{constructor(t,e,s){super(t,e,s,q.physicsConstraintStrength)}setup(t){return t.data.strength}get(t){return t.strength}set(t,e){t.strength=e}global(t){return t.strengthGlobal}},we=class extends ct{constructor(t,e,s){super(t,e,s,q.physicsConstraintDamping)}setup(t){return t.data.damping}get(t){return t.damping}set(t,e){t.damping=e}global(t){return t.dampingGlobal}},pe=class extends ct{constructor(t,e,s){super(t,e,s,q.physicsConstraintMass)}setup(t){return 1/t.data.massInverse}get(t){return 1/t.massInverse}set(t,e){t.massInverse=1/e}global(t){return t.massGlobal}},be=class extends ct{constructor(t,e,s){super(t,e,s,q.physicsConstraintWind)}setup(t){return t.data.wind}get(t){return t.wind}set(t,e){t.wind=e}global(t){return t.windGlobal}},ye=class extends ct{constructor(t,e,s){super(t,e,s,q.physicsConstraintGravity)}setup(t){return t.data.gravity}get(t){return t.gravity}set(t,e){t.gravity=e}global(t){return t.gravityGlobal}},ve=class extends ct{constructor(t,e,s){super(t,e,s,q.physicsConstraintMix)}setup(t){return t.data.mix}get(t){return t.mix}set(t,e){t.mix=e}global(t){return t.mixGlobal}},Ae=class Bs extends H{static propertyIds=[q.physicsConstraintReset.toString()];constraintIndex;constructor(e,s){super(e,Bs.propertyIds),this.constraintIndex=s}getFrameCount(){return this.frames.length}setFrame(e,s){this.frames[e]=s}apply(e,s,r,i,h,l,n){let a;if(this.constraintIndex!=-1&&(a=e.physicsConstraints[this.constraintIndex],!a.active))return;const o=this.frames;if(s>r)this.apply(e,s,Number.MAX_VALUE,[],h,l,n),s=-1;else if(s>=o[o.length-1])return;if(!(r<o[0])&&(s<o[0]||r>=o[H.search1(o,s)+1]))if(a!=null)a.reset();else for(const c of e.physicsConstraints)c.active&&c.reset()}},Se=class dt extends H{static ENTRIES=3;static MODE=1;static DELAY=2;slotIndex;attachment;constructor(e,s,r){super(e,[q.sequence+"|"+s+"|"+r.sequence.id]),this.slotIndex=s,this.attachment=r}getFrameEntries(){return dt.ENTRIES}getSlotIndex(){return this.slotIndex}getAttachment(){return this.attachment}setFrame(e,s,r,i,h){let l=this.frames;e*=dt.ENTRIES,l[e]=s,l[e+dt.MODE]=r|i<<4,l[e+dt.DELAY]=h}apply(e,s,r,i,h,l,n){let a=e.slots[this.slotIndex];if(!a.bone.active)return;let o=a.attachment,c=this.attachment;if(o!=c&&(!(o instanceof lt)||o.timelineAttachment!=c))return;if(n==1){l==0&&(a.sequenceIndex=-1);return}let f=this.frames;if(r<f[0]){(l==0||l==1)&&(a.sequenceIndex=-1);return}let d=H.search(f,r,dt.ENTRIES),m=f[d],u=f[d+dt.MODE],w=f[d+dt.DELAY];if(!this.attachment.sequence)return;let b=u>>4,p=this.attachment.sequence.regions.length,g=is[u&15];if(g!=0)switch(b+=(r-m)/w+1e-5|0,g){case 1:b=Math.min(p-1,b);break;case 2:b%=p;break;case 3:{let x=(p<<1)-2;b=x==0?0:b%x,b>=p&&(b=x-b);break}case 4:b=Math.max(p-1-b,0);break;case 5:b=p-1-b%p;break;case 6:{let x=(p<<1)-2;b=x==0?0:(b+p-1)%x,b>=p&&(b=x-b)}}a.sequenceIndex=b}},as=class Ut{static _emptyAnimation=new Xt("<empty>",[],0);static emptyAnimation(){return Ut._emptyAnimation}data;tracks=new Array;timeScale=1;unkeyedState=0;events=new Array;listeners=new Array;queue=new os(this);propertyIDs=new Gt;animationsChanged=!1;trackEntryPool=new vt(()=>new ls);constructor(e){this.data=e}update(e){e*=this.timeScale;let s=this.tracks;for(let r=0,i=s.length;r<i;r++){let h=s[r];if(!h)continue;h.animationLast=h.nextAnimationLast,h.trackLast=h.nextTrackLast;let l=e*h.timeScale;if(h.delay>0){if(h.delay-=l,h.delay>0)continue;l=-h.delay,h.delay=0}let n=h.next;if(n){let a=h.trackLast-n.delay;if(a>=0){for(n.delay=0,n.trackTime+=h.timeScale==0?0:(a/h.timeScale+e)*n.timeScale,h.trackTime+=l,this.setCurrent(r,n,!0);n.mixingFrom;)n.mixTime+=e,n=n.mixingFrom;continue}}else if(h.trackLast>=h.trackEnd&&!h.mixingFrom){s[r]=null,this.queue.end(h),this.clearNext(h);continue}if(h.mixingFrom&&this.updateMixingFrom(h,e)){let a=h.mixingFrom;for(h.mixingFrom=null,a&&(a.mixingTo=null);a;)this.queue.end(a),a=a.mixingFrom}h.trackTime+=l}this.queue.drain()}updateMixingFrom(e,s){let r=e.mixingFrom;if(!r)return!0;let i=this.updateMixingFrom(r,s);return r.animationLast=r.nextAnimationLast,r.trackLast=r.nextTrackLast,e.nextTrackLast!=-1&&e.mixTime>=e.mixDuration?((r.totalAlpha==0||e.mixDuration==0)&&(e.mixingFrom=r.mixingFrom,r.mixingFrom!=null&&(r.mixingFrom.mixingTo=e),e.interruptAlpha=r.interruptAlpha,this.queue.end(r)),i):(r.trackTime+=s*r.timeScale,e.mixTime+=s,!1)}apply(e){if(!e)throw new Error("skeleton cannot be null.");this.animationsChanged&&this._animationsChanged();let s=this.events,r=this.tracks,i=!1;for(let d=0,m=r.length;d<m;d++){let u=r[d];if(!u||u.delay>0)continue;i=!0;let w=d==0?1:u.mixBlend,b=u.alpha;u.mixingFrom?b*=this.applyMixingFrom(u,e,w):u.trackTime>=u.trackEnd&&!u.next&&(b=0);let p=b>=u.alphaAttachmentThreshold,g=u.animationLast,x=u.getAnimationTime(),y=x,v=s;u.reverse&&(y=u.animation.duration-y,v=null);let A=u.animation.timelines,S=A.length;if(d==0&&b==1||w==3){d==0&&(p=!0);for(let C=0;C<S;C++){P.webkit602BugfixHelper(b,w);var h=A[C];h instanceof ut?this.applyAttachmentTimeline(h,e,y,w,p):h.apply(e,g,y,v,b,w,0)}}else{let C=u.timelineMode,k=u.shortestRotation,Y=!k&&u.timelinesRotation.length!=S<<1;Y&&(u.timelinesRotation.length=S<<1);for(let M=0;M<S;M++){let F=A[M],E=C[M]==Rt?w:0;!k&&F instanceof At?this.applyRotateTimeline(F,e,y,b,E,u.timelinesRotation,M<<1,Y):F instanceof ut?this.applyAttachmentTimeline(F,e,y,w,p):(P.webkit602BugfixHelper(b,w),F.apply(e,g,y,v,b,E,0))}}this.queueEvents(u,x),s.length=0,u.nextAnimationLast=x,u.nextTrackLast=u.trackTime}for(var l=this.unkeyedState+ke,n=e.slots,a=0,o=e.slots.length;a<o;a++){var c=n[a];if(c.attachmentState==l){var f=c.data.attachmentName;c.setAttachment(f?e.getAttachment(c.data.index,f):null)}}return this.unkeyedState+=2,this.queue.drain(),i}applyMixingFrom(e,s,r){let i=e.mixingFrom;i.mixingFrom&&this.applyMixingFrom(i,s,r);let h=0;e.mixDuration==0?(h=1,r==1&&(r=0)):(h=e.mixTime/e.mixDuration,h>1&&(h=1),r!=1&&(r=i.mixBlend));let l=h<i.mixAttachmentThreshold,n=h<i.mixDrawOrderThreshold,a=i.animation.timelines,o=a.length,c=i.alpha*e.interruptAlpha,f=c*(1-h),d=i.animationLast,m=i.getAnimationTime(),u=m,w=null;if(i.reverse?u=i.animation.duration-u:h<i.eventThreshold&&(w=this.events),r==3)for(let b=0;b<o;b++)a[b].apply(s,d,u,w,f,r,1);else{let b=i.timelineMode,p=i.timelineHoldMix,g=i.shortestRotation,x=!g&&i.timelinesRotation.length!=o<<1;x&&(i.timelinesRotation.length=o<<1),i.totalAlpha=0;for(let y=0;y<o;y++){let v=a[y],A=1,S,C=0;switch(b[y]){case Rt:if(!n&&v instanceof wt)continue;S=r,C=f;break;case Ie:S=0,C=f;break;case Ce:S=r,C=c;break;case Pt:S=0,C=c;break;default:S=0;let k=p[y];C=c*Math.max(0,1-k.mixTime/k.mixDuration);break}i.totalAlpha+=C,!g&&v instanceof At?this.applyRotateTimeline(v,s,u,C,S,i.timelinesRotation,y<<1,x):v instanceof ut?this.applyAttachmentTimeline(v,s,u,S,l&&C>=i.alphaAttachmentThreshold):(P.webkit602BugfixHelper(C,r),n&&v instanceof wt&&S==0&&(A=0),v.apply(s,d,u,w,C,S,A))}}return e.mixDuration>0&&this.queueEvents(i,m),this.events.length=0,i.nextAnimationLast=m,i.nextTrackLast=i.trackTime,h}applyAttachmentTimeline(e,s,r,i,h){var l=s.slots[e.slotIndex];l.bone.active&&(r<e.frames[0]?(i==0||i==1)&&this.setAttachment(s,l,l.data.attachmentName,h):this.setAttachment(s,l,e.attachmentNames[H.search1(e.frames,r)],h),l.attachmentState<=this.unkeyedState&&(l.attachmentState=this.unkeyedState+ke))}setAttachment(e,s,r,i){s.setAttachment(r?e.getAttachment(s.data.index,r):null),i&&(s.attachmentState=this.unkeyedState+ds)}applyRotateTimeline(e,s,r,i,h,l,n,a){if(a&&(l[n]=0),i==1){e.apply(s,0,r,null,1,h,0);return}let o=s.bones[e.boneIndex];if(!o.active)return;let c=e.frames,f=0,d=0;if(r<c[0])switch(h){case 0:o.rotation=o.data.rotation;default:return;case 1:f=o.rotation,d=o.data.rotation}else f=h==0?o.data.rotation:o.rotation,d=o.data.rotation+e.getCurveValue(r);let m=0,u=d-f;if(u-=Math.ceil(u/360-.5)*360,u==0)m=l[n];else{let w=0,b=0;a?(w=0,b=u):(w=l[n],b=l[n+1]);let p=w-w%360;m=u+p;let g=u>=0,x=w>=0;Math.abs(b)<=90&&R.signum(b)!=R.signum(u)&&(Math.abs(w-p)>180?(m+=360*R.signum(w),x=g):p!=0?m-=360*R.signum(w):x=g),x!=g&&(m+=360*R.signum(w)),l[n]=m}l[n+1]=u,o.rotation=f+m*i}queueEvents(e,s){let r=e.animationStart,i=e.animationEnd,h=i-r,l=e.trackLast%h,n=this.events,a=0,o=n.length;for(;a<o;a++){let f=n[a];if(f.time<l)break;f.time>i||this.queue.event(e,f)}let c=!1;if(e.loop)if(h==0)c=!0;else{const f=Math.floor(e.trackTime/h);c=f>0&&f>Math.floor(e.trackLast/h)}else c=s>=i&&e.animationLast<i;for(c&&this.queue.complete(e);a<o;a++){let f=n[a];f.time<r||this.queue.event(e,f)}}clearTracks(){let e=this.queue.drainDisabled;this.queue.drainDisabled=!0;for(let s=0,r=this.tracks.length;s<r;s++)this.clearTrack(s);this.tracks.length=0,this.queue.drainDisabled=e,this.queue.drain()}clearTrack(e){if(e>=this.tracks.length)return;let s=this.tracks[e];if(!s)return;this.queue.end(s),this.clearNext(s);let r=s;for(;;){let i=r.mixingFrom;if(!i)break;this.queue.end(i),r.mixingFrom=null,r.mixingTo=null,r=i}this.tracks[s.trackIndex]=null,this.queue.drain()}setCurrent(e,s,r){let i=this.expandToIndex(e);this.tracks[e]=s,s.previous=null,i&&(r&&this.queue.interrupt(i),s.mixingFrom=i,i.mixingTo=s,s.mixTime=0,i.mixingFrom&&i.mixDuration>0&&(s.interruptAlpha*=Math.min(1,i.mixTime/i.mixDuration)),i.timelinesRotation.length=0),this.queue.start(s)}setAnimation(e,s,r=!1){let i=this.data.skeletonData.findAnimation(s);if(!i)throw new Error("Animation not found: "+s);return this.setAnimationWith(e,i,r)}setAnimationWith(e,s,r=!1){if(!s)throw new Error("animation cannot be null.");let i=!0,h=this.expandToIndex(e);h&&(h.nextTrackLast==-1?(this.tracks[e]=h.mixingFrom,this.queue.interrupt(h),this.queue.end(h),this.clearNext(h),h=h.mixingFrom,i=!1):this.clearNext(h));let l=this.trackEntry(e,s,r,h);return this.setCurrent(e,l,i),this.queue.drain(),l}addAnimation(e,s,r=!1,i=0){let h=this.data.skeletonData.findAnimation(s);if(!h)throw new Error("Animation not found: "+s);return this.addAnimationWith(e,h,r,i)}addAnimationWith(e,s,r=!1,i=0){if(!s)throw new Error("animation cannot be null.");let h=this.expandToIndex(e);if(h)for(;h.next;)h=h.next;let l=this.trackEntry(e,s,r,h);return h?(h.next=l,l.previous=h,i<=0&&(i=Math.max(i+h.getTrackComplete()-l.mixDuration,0))):(this.setCurrent(e,l,!0),this.queue.drain(),i<0&&(i=0)),l.delay=i,l}setEmptyAnimation(e,s=0){let r=this.setAnimationWith(e,Ut.emptyAnimation(),!1);return r.mixDuration=s,r.trackEnd=s,r}addEmptyAnimation(e,s=0,r=0){let i=this.addAnimationWith(e,Ut.emptyAnimation(),!1,r);return r<=0&&(i.delay=Math.max(i.delay+i.mixDuration-s,0)),i.mixDuration=s,i.trackEnd=s,i}setEmptyAnimations(e=0){let s=this.queue.drainDisabled;this.queue.drainDisabled=!0;for(let r=0,i=this.tracks.length;r<i;r++){let h=this.tracks[r];h&&this.setEmptyAnimation(h.trackIndex,e)}this.queue.drainDisabled=s,this.queue.drain()}expandToIndex(e){return e<this.tracks.length?this.tracks[e]:(P.ensureArrayCapacity(this.tracks,e+1,null),this.tracks.length=e+1,null)}trackEntry(e,s,r,i){let h=this.trackEntryPool.obtain();return h.reset(),h.trackIndex=e,h.animation=s,h.loop=r,h.holdPrevious=!1,h.reverse=!1,h.shortestRotation=!1,h.eventThreshold=0,h.alphaAttachmentThreshold=0,h.mixAttachmentThreshold=0,h.mixDrawOrderThreshold=0,h.animationStart=0,h.animationEnd=s.duration,h.animationLast=-1,h.nextAnimationLast=-1,h.delay=0,h.trackTime=0,h.trackLast=-1,h.nextTrackLast=-1,h.trackEnd=Number.MAX_VALUE,h.timeScale=1,h.alpha=1,h.mixTime=0,h.mixDuration=i?this.data.getMix(i.animation,s):0,h.interruptAlpha=1,h.totalAlpha=0,h.mixBlend=2,h}clearNext(e){let s=e.next;for(;s;)this.queue.dispose(s),s=s.next;e.next=null}_animationsChanged(){this.animationsChanged=!1,this.propertyIDs.clear();let e=this.tracks;for(let s=0,r=e.length;s<r;s++){let i=e[s];if(i){for(;i.mixingFrom;)i=i.mixingFrom;do(!i.mixingTo||i.mixBlend!=3)&&this.computeHold(i),i=i.mixingTo;while(i)}}}computeHold(e){let s=e.mixingTo,r=e.animation.timelines,i=e.animation.timelines.length,h=e.timelineMode;h.length=i;let l=e.timelineHoldMix;l.length=0;let n=this.propertyIDs;if(s&&s.holdPrevious){for(let a=0;a<i;a++)h[a]=n.addAll(r[a].getPropertyIds())?Pt:Ce;return}t:for(let a=0;a<i;a++){let o=r[a],c=o.getPropertyIds();if(!n.addAll(c))h[a]=Rt;else if(!s||o instanceof ut||o instanceof wt||o instanceof Et||!s.animation.hasTimeline(c))h[a]=Ie;else{for(let f=s.mixingTo;f;f=f.mixingTo)if(!f.animation.hasTimeline(c)){if(e.mixDuration>0){h[a]=cs,l[a]=f;continue t}break}h[a]=Pt}}}getCurrent(e){return e>=this.tracks.length?null:this.tracks[e]}addListener(e){if(!e)throw new Error("listener cannot be null.");this.listeners.push(e)}removeListener(e){let s=this.listeners.indexOf(e);s>=0&&this.listeners.splice(s,1)}clearListeners(){this.listeners.length=0}clearListenerNotifications(){this.queue.clear()}},ls=class{animation=null;previous=null;next=null;mixingFrom=null;mixingTo=null;listener=null;trackIndex=0;loop=!1;holdPrevious=!1;reverse=!1;shortestRotation=!1;eventThreshold=0;mixAttachmentThreshold=0;alphaAttachmentThreshold=0;mixDrawOrderThreshold=0;animationStart=0;animationEnd=0;animationLast=0;nextAnimationLast=0;delay=0;trackTime=0;trackLast=0;nextTrackLast=0;trackEnd=0;timeScale=0;alpha=0;mixTime=0;_mixDuration=0;interruptAlpha=0;totalAlpha=0;get mixDuration(){return this._mixDuration}set mixDuration(t){this._mixDuration=t}setMixDurationWithDelay(t,e){this._mixDuration=t,e<=0&&(this.previous!=null?e=Math.max(e+this.previous.getTrackComplete()-t,0):e=0),this.delay=e}mixBlend=2;timelineMode=new Array;timelineHoldMix=new Array;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}wasApplied(){return this.nextTrackLast!=-1}isNextReady(){return this.next!=null&&this.nextTrackLast-this.next.delay>=0}},os=class{objects=[];drainDisabled=!1;animState;constructor(t){this.animState=t}start(t){this.objects.push(0),this.objects.push(t),this.animState.animationsChanged=!0}interrupt(t){this.objects.push(1),this.objects.push(t)}end(t){this.objects.push(2),this.objects.push(t),this.animState.animationsChanged=!0}dispose(t){this.objects.push(3),this.objects.push(t)}complete(t){this.objects.push(4),this.objects.push(t)}event(t,e){this.objects.push(5),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 s=0;s<t.length;s+=2){let r=t[s],i=t[s+1];switch(r){case 0:i.listener&&i.listener.start&&i.listener.start(i);for(let l=0;l<e.length;l++){let n=e[l];n.start&&n.start(i)}break;case 1:i.listener&&i.listener.interrupt&&i.listener.interrupt(i);for(let l=0;l<e.length;l++){let n=e[l];n.interrupt&&n.interrupt(i)}break;case 2:i.listener&&i.listener.end&&i.listener.end(i);for(let l=0;l<e.length;l++){let n=e[l];n.end&&n.end(i)}case 3:i.listener&&i.listener.dispose&&i.listener.dispose(i);for(let l=0;l<e.length;l++){let n=e[l];n.dispose&&n.dispose(i)}this.animState.trackEntryPool.free(i);break;case 4:i.listener&&i.listener.complete&&i.listener.complete(i);for(let l=0;l<e.length;l++){let n=e[l];n.complete&&n.complete(i)}break;case 5:let h=t[s+++2];i.listener&&i.listener.event&&i.listener.event(i,h);for(let l=0;l<e.length;l++){let n=e[l];n.event&&n.event(i,h)}break}}this.clear(),this.drainDisabled=!1}clear(){this.objects.length=0}},hs=(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))(hs||{}),Hs=class{start(t){}interrupt(t){}end(t){}dispose(t){}complete(t){}event(t,e){}},Rt=0,Ie=1,Ce=2,Pt=3,cs=4,ke=1,ds=2,fs=class{skeletonData;animationToMixTime={};defaultMix=0;constructor(t){if(!t)throw new Error("skeletonData cannot be null.");this.skeletonData=t}setMix(t,e,s){let r=this.skeletonData.findAnimation(t);if(!r)throw new Error("Animation not found: "+t);let i=this.skeletonData.findAnimation(e);if(!i)throw new Error("Animation not found: "+e);this.setMixWith(r,i,s)}setMixWith(t,e,s){if(!t)throw new Error("from cannot be null.");if(!e)throw new Error("to cannot be null.");let r=t.name+"."+e.name;this.animationToMixTime[r]=s}getMix(t,e){let s=t.name+"."+e.name,r=this.animationToMixTime[s];return r===void 0?this.defaultMix:r}},Te=class Vs extends lt{color=new N(1,1,1,1);constructor(e){super(e)}copy(){let e=new Vs(this.name);return this.copyTo(e),e.color.setFromColor(this.color),e}},Bt=class Ls extends lt{endSlot=null;color=new N(.2275,.2275,.8078,1);constructor(e){super(e)}copy(){let e=new Ls(this.name);return this.copyTo(e),e.endSlot=this.endSlot,e.color.setFromColor(this.color),e}},Me=class{_image;constructor(t){this._image=t}getImage(){return this._image}},Vt=(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))(Vt||{}),us=(t=>(t[t.MirroredRepeat=33648]="MirroredRepeat",t[t.ClampToEdge=33071]="ClampToEdge",t[t.Repeat=10497]="Repeat",t))(us||{}),ms=class{texture;u=0;v=0;u2=0;v2=0;width=0;height=0;degrees=0;offsetX=0;offsetY=0;originalWidth=0;originalHeight=0},js=class extends Me{setFilters(t,e){}setWraps(t,e){}dispose(){}},Lt=class{pages=new Array;regions=new Array;constructor(t){let e=new Js(t),s=new Array(4),r={};r.size=o=>{o.width=parseInt(s[1]),o.height=parseInt(s[2])},r.format=()=>{},r.filter=o=>{o.minFilter=P.enumValue(Vt,s[1]),o.magFilter=P.enumValue(Vt,s[2])},r.repeat=o=>{s[1].indexOf("x")!=-1&&(o.uWrap=10497),s[1].indexOf("y")!=-1&&(o.vWrap=10497)},r.pma=o=>{o.pma=s[1]=="true"};var i={};i.xy=o=>{o.x=parseInt(s[1]),o.y=parseInt(s[2])},i.size=o=>{o.width=parseInt(s[1]),o.height=parseInt(s[2])},i.bounds=o=>{o.x=parseInt(s[1]),o.y=parseInt(s[2]),o.width=parseInt(s[3]),o.height=parseInt(s[4])},i.offset=o=>{o.offsetX=parseInt(s[1]),o.offsetY=parseInt(s[2])},i.orig=o=>{o.originalWidth=parseInt(s[1]),o.originalHeight=parseInt(s[2])},i.offsets=o=>{o.offsetX=parseInt(s[1]),o.offsetY=parseInt(s[2]),o.originalWidth=parseInt(s[3]),o.originalHeight=parseInt(s[4])},i.rotate=o=>{let c=s[1];c=="true"?o.degrees=90:c!="false"&&(o.degrees=parseInt(c))},i.index=o=>{o.index=parseInt(s[1])};let h=e.readLine();for(;h&&h.trim().length==0;)h=e.readLine();for(;!(!h||h.trim().length==0||e.readEntry(s,h)==0);)h=e.readLine();let l=null,n=null,a=null;for(;h!==null;)if(h.trim().length==0)l=null,h=e.readLine();else if(l){let o=new Ye(l,h);for(;;){let c=e.readEntry(s,h=e.readLine());if(c==0)break;let f=i[s[0]];if(f)f(o);else{n||(n=[]),a||(a=[]),n.push(s[0]);let d=[];for(let m=0;m<c;m++)d.push(parseInt(s[m+1]));a.push(d)}}o.originalWidth==0&&o.originalHeight==0&&(o.originalWidth=o.width,o.originalHeight=o.height),n&&n.length>0&&a&&a.length>0&&(o.names=n,o.values=a,n=null,a=null),o.u=o.x/l.width,o.v=o.y/l.height,o.degrees==90?(o.u2=(o.x+o.height)/l.width,o.v2=(o.y+o.width)/l.height):(o.u2=(o.x+o.width)/l.width,o.v2=(o.y+o.height)/l.height),this.regions.push(o)}else{for(l=new gs(h.trim());e.readEntry(s,h=e.readLine())!=0;){let o=r[s[0]];o&&o(l)}this.pages.push(l)}}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 s of this.pages)s.setTexture(t.get(e+s.name))}dispose(){for(let t=0;t<this.pages.length;t++)this.pages[t].texture?.dispose()}},Js=class{lines;index=0;constructor(t){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 s=e.indexOf(":");if(s==-1)return 0;t[0]=e.substr(0,s).trim();for(let r=1,i=s+1;;r++){let h=e.indexOf(",",i);if(h==-1)return t[r]=e.substr(i).trim(),r;if(t[r]=e.substr(i,h-i).trim(),i=h+1,r==4)return 4}}},gs=class{name;minFilter=9728;magFilter=9728;uWrap=33071;vWrap=33071;texture=null;width=0;height=0;pma=!1;regions=new Array;constructor(t){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}},Ye=class extends ms{page;name;x=0;y=0;offsetX=0;offsetY=0;originalWidth=0;originalHeight=0;index=0;degrees=0;names=null;values=null;constructor(t,e){super(),this.page=t,this.name=e,t.regions.push(this)}},St=class Ge extends lt{region=null;path;regionUVs=[];uvs=[];triangles=[];color=new N(1,1,1,1);width=0;height=0;hullLength=0;edges=[];parentMesh=null;sequence=null;tempColor=new N(0,0,0,0);constructor(e,s){super(e),this.path=s}updateRegion(){if(!this.region)throw new Error("Region not set.");let e=this.regionUVs;(!this.uvs||this.uvs.length!=e.length)&&(this.uvs=P.newFloatArray(e.length));let s=this.uvs,r=this.uvs.length,i=this.region.u,h=this.region.v,l=0,n=0;if(this.region instanceof Ye){let a=this.region,o=a.page,c=o.width,f=o.height;switch(a.degrees){case 90:i-=(a.originalHeight-a.offsetY-a.height)/c,h-=(a.originalWidth-a.offsetX-a.width)/f,l=a.originalHeight/c,n=a.originalWidth/f;for(let d=0;d<r;d+=2)s[d]=i+e[d+1]*l,s[d+1]=h+(1-e[d])*n;return;case 180:i-=(a.originalWidth-a.offsetX-a.width)/c,h-=a.offsetY/f,l=a.originalWidth/c,n=a.originalHeight/f;for(let d=0;d<r;d+=2)s[d]=i+(1-e[d])*l,s[d+1]=h+(1-e[d+1])*n;return;case 270:i-=a.offsetY/c,h-=a.offsetX/f,l=a.originalHeight/c,n=a.originalWidth/f;for(let d=0;d<r;d+=2)s[d]=i+(1-e[d+1])*l,s[d+1]=h+e[d]*n;return}i-=a.offsetX/c,h-=(a.originalHeight-a.offsetY-a.height)/f,l=a.originalWidth/c,n=a.originalHeight/f}else this.region?(l=this.region.u2-i,n=this.region.v2-h):(i=h=0,l=n=1);for(let a=0;a<r;a+=2)s[a]=i+e[a]*l,s[a+1]=h+e[a+1]*n}getParentMesh(){return this.parentMesh}setParentMesh(e){this.parentMesh=e,e&&(this.bones=e.bones,this.vertices=e.vertices,this.worldVerticesLength=e.worldVerticesLength,this.regionUVs=e.regionUVs,this.triangles=e.triangles,this.hullLength=e.hullLength,this.worldVerticesLength=e.worldVerticesLength)}copy(){if(this.parentMesh)return this.newLinkedMesh();let e=new Ge(this.name,this.path);return e.region=this.region,e.color.setFromColor(this.color),this.copyTo(e),e.regionUVs=new Array(this.regionUVs.length),P.arrayCopy(this.regionUVs,0,e.regionUVs,0,this.regionUVs.length),e.uvs=new Array(this.uvs.length),P.arrayCopy(this.uvs,0,e.uvs,0,this.uvs.length),e.triangles=new Array(this.triangles.length),P.arrayCopy(this.triangles,0,e.triangles,0,this.triangles.length),e.hullLength=this.hullLength,e.sequence=this.sequence!=null?this.sequence.copy():null,this.edges&&(e.edges=new Array(this.edges.length),P.arrayCopy(this.edges,0,e.edges,0,this.edges.length)),e.width=this.width,e.height=this.height,e}computeWorldVertices(e,s,r,i,h,l){this.sequence!=null&&this.sequence.apply(e,this),super.computeWorldVertices(e,s,r,i,h,l)}newLinkedMesh(){let e=new Ge(this.name,this.path);return e.region=this.region,e.color.setFromColor(this.color),e.timelineAttachment=this.timelineAttachment,e.setParentMesh(this.parentMesh?this.parentMesh:this),e.region!=null&&e.updateRegion(),e}},It=class Ns extends lt{lengths=[];closed=!1;constantSpeed=!1;color=new N(1,1,1,1);constructor(e){super(e)}copy(){let e=new Ns(this.name);return this.copyTo(e),e.lengths=new Array(this.lengths.length),P.arrayCopy(this.lengths,0,e.lengths,0,this.lengths.length),e.closed=closed,e.constantSpeed=this.constantSpeed,e.color.setFromColor(this.color),e}},xs=class Ds extends lt{x=0;y=0;rotation=0;color=new N(.38,.94,0,1);constructor(e){super(e)}computeWorldPosition(e,s){return s.x=this.x*e.a+this.y*e.b+e.worldX,s.y=this.x*e.c+this.y*e.d+e.worldY,s}computeWorldRotation(e){const s=this.rotation*R.degRad,r=Math.cos(s),i=Math.sin(s),h=r*e.a+i*e.b,l=r*e.c+i*e.d;return R.atan2Deg(l,h)}copy(){let e=new Ds(this.name);return e.x=this.x,e.y=this.y,e.rotation=this.rotation,e.color.setFromColor(this.color),e}},Nt=class Os extends $t{x=0;y=0;scaleX=1;scaleY=1;rotation=0;width=0;height=0;color=new N(1,1,1,1);path;region=null;sequence=null;offset=P.newFloatArray(8);uvs=P.newFloatArray(8);tempColor=new N(1,1,1,1);constructor(e,s){super(e),this.path=s}updateRegion(){if(!this.region)throw new Error("Region not set.");let e=this.region,s=this.uvs;if(e==null){s[0]=0,s[1]=0,s[2]=0,s[3]=1,s[4]=1,s[5]=1,s[6]=1,s[7]=0;return}let r=this.width/this.region.originalWidth*this.scaleX,i=this.height/this.region.originalHeight*this.scaleY,h=-this.width/2*this.scaleX+this.region.offsetX*r,l=-this.height/2*this.scaleY+this.region.offsetY*i,n=h+this.region.width*r,a=l+this.region.height*i,o=this.rotation*R.degRad,c=Math.cos(o),f=Math.sin(o),d=this.x,m=this.y,u=h*c+d,w=h*f,b=l*c+m,p=l*f,g=n*c+d,x=n*f,y=a*c+m,v=a*f,A=this.offset;A[0]=u-p,A[1]=b+w,A[2]=u-v,A[3]=y+w,A[4]=g-v,A[5]=y+x,A[6]=g-p,A[7]=b+x,e.degrees==90?(s[0]=e.u2,s[1]=e.v2,s[2]=e.u,s[3]=e.v2,s[4]=e.u,s[5]=e.v,s[6]=e.u2,s[7]=e.v):(s[0]=e.u,s[1]=e.v2,s[2]=e.u,s[3]=e.v,s[4]=e.u2,s[5]=e.v,s[6]=e.u2,s[7]=e.v2)}computeWorldVertices(e,s,r,i){this.sequence!=null&&this.sequence.apply(e,this);let h=e.bone,l=this.offset,n=h.worldX,a=h.worldY,o=h.a,c=h.b,f=h.c,d=h.d,m=0,u=0;m=l[0],u=l[1],s[r]=m*o+u*c+n,s[r+1]=m*f+u*d+a,r+=i,m=l[2],u=l[3],s[r]=m*o+u*c+n,s[r+1]=m*f+u*d+a,r+=i,m=l[4],u=l[5],s[r]=m*o+u*c+n,s[r+1]=m*f+u*d+a,r+=i,m=l[6],u=l[7],s[r]=m*o+u*c+n,s[r+1]=m*f+u*d+a}copy(){let e=new Os(this.name,this.path);return e.region=this.region,e.x=this.x,e.y=this.y,e.scaleX=this.scaleX,e.scaleY=this.scaleY,e.rotation=this.rotation,e.width=this.width,e.height=this.height,P.arrayCopy(this.uvs,0,e.uvs,0,8),P.arrayCopy(this.offset,0,e.offset,0,8),e.color.setFromColor(this.color),e.sequence=this.sequence!=null?this.sequence.copy():null,e}static X1=0;static Y1=1;static C1R=2;static C1G=3;static C1B=4;static C1A=5;static U1=6;static V1=7;static X2=8;static Y2=9;static C2R=10;static C2G=11;static C2B=12;static C2A=13;static U2=14;static V2=15;static X3=16;static Y3=17;static C3R=18;static C3G=19;static C3B=20;static C3A=21;static U3=22;static V3=23;static X4=24;static Y4=25;static C4R=26;static C4G=27;static C4B=28;static C4A=29;static U4=30;static V4=31},ws=class{atlas;constructor(t){this.atlas=t}loadSequence(t,e,s){let r=s.regions;for(let i=0,h=r.length;i<h;i++){let l=s.getPath(e,i),n=this.atlas.findRegion(l);if(n==null)throw new Error("Region not found in atlas: "+l+" (sequence: "+t+")");r[i]=n}}newRegionAttachment(t,e,s,r){let i=new Nt(e,s);if(r!=null)this.loadSequence(e,s,r);else{let h=this.atlas.findRegion(s);if(!h)throw new Error("Region not found in atlas: "+s+" (region attachment: "+e+")");i.region=h}return i}newMeshAttachment(t,e,s,r){let i=new St(e,s);if(r!=null)this.loadSequence(e,s,r);else{let h=this.atlas.findRegion(s);if(!h)throw new Error("Region not found in atlas: "+s+" (mesh attachment: "+e+")");i.region=h}return i}newBoundingBoxAttachment(t,e){return new Te(e)}newPathAttachment(t,e){return new It(e)}newPointAttachment(t,e){return new xs(e)}newClippingAttachment(t,e){return new Bt(e)}},Xe=class{index=0;name;parent=null;length=0;x=0;y=0;rotation=0;scaleX=1;scaleY=1;shearX=0;shearY=0;inherit=0;skinRequired=!1;color=new N;icon;visible=!1;constructor(t,e,s){if(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=s}},Dt=(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))(Dt||{}),Fe=class{data;skeleton;parent=null;children=new Array;x=0;y=0;rotation=0;scaleX=0;scaleY=0;shearX=0;shearY=0;ax=0;ay=0;arotation=0;ascaleX=0;ascaleY=0;ashearX=0;ashearY=0;a=0;b=0;c=0;d=0;worldY=0;worldX=0;inherit=0;sorted=!1;active=!1;constructor(t,e,s){if(!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=s,this.setToSetupPose()}isActive(){return this.active}update(t){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,s,r,i,h,l){this.ax=t,this.ay=e,this.arotation=s,this.ascaleX=r,this.ascaleY=i,this.ashearX=h,this.ashearY=l;let n=this.parent;if(!n){let d=this.skeleton;const m=d.scaleX,u=d.scaleY,w=(s+h)*R.degRad,b=(s+90+l)*R.degRad;this.a=Math.cos(w)*r*m,this.b=Math.cos(b)*i*m,this.c=Math.sin(w)*r*u,this.d=Math.sin(b)*i*u,this.worldX=t*m+d.x,this.worldY=e*u+d.y;return}let a=n.a,o=n.b,c=n.c,f=n.d;switch(this.worldX=a*t+o*e+n.worldX,this.worldY=c*t+f*e+n.worldY,this.inherit){case 0:{const d=(s+h)*R.degRad,m=(s+90+l)*R.degRad,u=Math.cos(d)*r,w=Math.cos(m)*i,b=Math.sin(d)*r,p=Math.sin(m)*i;this.a=a*u+o*b,this.b=a*w+o*p,this.c=c*u+f*b,this.d=c*w+f*p;return}case 1:{const d=(s+h)*R.degRad,m=(s+90+l)*R.degRad;this.a=Math.cos(d)*r,this.b=Math.cos(m)*i,this.c=Math.sin(d)*r,this.d=Math.sin(m)*i;break}case 2:{let d=1/this.skeleton.scaleX,m=1/this.skeleton.scaleY;a*=d,c*=m;let u=a*a+c*c,w=0;u>1e-4?(u=Math.abs(a*f*m-o*d*c)/u,o=c*u,f=a*u,w=Math.atan2(c,a)*R.radDeg):(a=0,c=0,w=90-Math.atan2(f,o)*R.radDeg);const b=(s+h-w)*R.degRad,p=(s+l-w+90)*R.degRad,g=Math.cos(b)*r,x=Math.cos(p)*i,y=Math.sin(b)*r,v=Math.sin(p)*i;this.a=a*g-o*y,this.b=a*x-o*v,this.c=c*g+f*y,this.d=c*x+f*v;break}case 3:case 4:{s*=R.degRad;const d=Math.cos(s),m=Math.sin(s);let u=(a*d+o*m)/this.skeleton.scaleX,w=(c*d+f*m)/this.skeleton.scaleY,b=Math.sqrt(u*u+w*w);b>1e-5&&(b=1/b),u*=b,w*=b,b=Math.sqrt(u*u+w*w),this.inherit==3&&a*f-o*c<0!=(this.skeleton.scaleX<0!=this.skeleton.scaleY<0)&&(b=-b),s=Math.PI/2+Math.atan2(w,u);const p=Math.cos(s)*b,g=Math.sin(s)*b;h*=R.degRad,l=(90+l)*R.degRad;const x=Math.cos(h)*r,y=Math.cos(l)*i,v=Math.sin(h)*r,A=Math.sin(l)*i;this.a=u*x+p*v,this.b=u*y+p*A,this.c=w*x+g*v,this.d=w*y+g*A;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,this.inherit=t.inherit}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)*R.radDeg,this.ascaleX=Math.sqrt(this.a*this.a+this.c*this.c),this.ascaleY=Math.sqrt(this.b*this.b+this.d*this.d),this.ashearX=0,this.ashearY=Math.atan2(this.a*this.b+this.c*this.d,this.a*this.d-this.b*this.c)*R.radDeg;return}let e=t.a,s=t.b,r=t.c,i=t.d,h=1/(e*i-s*r),l=i*h,n=s*h,a=r*h,o=e*h,c=this.worldX-t.worldX,f=this.worldY-t.worldY;this.ax=c*l-f*n,this.ay=f*o-c*a;let d,m,u,w;if(this.inherit==1)d=this.a,m=this.b,u=this.c,w=this.d;else{switch(this.inherit){case 2:{let y=Math.abs(e*i-s*r)/(e*e+r*r);s=-r*this.skeleton.scaleX*y/this.skeleton.scaleY,i=e*this.skeleton.scaleY*y/this.skeleton.scaleX,h=1/(e*i-s*r),l=i*h,n=s*h;break}case 3:case 4:let b=R.cosDeg(this.rotation),p=R.sinDeg(this.rotation);e=(e*b+s*p)/this.skeleton.scaleX,r=(r*b+i*p)/this.skeleton.scaleY;let g=Math.sqrt(e*e+r*r);g>1e-5&&(g=1/g),e*=g,r*=g,g=Math.sqrt(e*e+r*r),this.inherit==3&&h<0!=(this.skeleton.scaleX<0!=this.skeleton.scaleY<0)&&(g=-g);let x=R.PI/2+Math.atan2(r,e);s=Math.cos(x)*g,i=Math.sin(x)*g,h=1/(e*i-s*r),l=i*h,n=s*h,a=r*h,o=e*h}d=l*this.a-n*this.c,m=l*this.b-n*this.d,u=o*this.c-a*this.a,w=o*this.d-a*this.b}if(this.ashearX=0,this.ascaleX=Math.sqrt(d*d+u*u),this.ascaleX>1e-4){let b=d*w-m*u;this.ascaleY=b/this.ascaleX,this.ashearY=-Math.atan2(d*m+u*w,b)*R.radDeg,this.arotation=Math.atan2(u,d)*R.radDeg}else this.ascaleX=0,this.ascaleY=Math.sqrt(m*m+w*w),this.ashearY=0,this.arotation=90-Math.atan2(w,m)*R.radDeg}getWorldRotationX(){return Math.atan2(this.c,this.a)*R.radDeg}getWorldRotationY(){return Math.atan2(this.d,this.b)*R.radDeg}getWorldScaleX(){return Math.sqrt(this.a*this.a+this.c*this.c)}getWorldScaleY(){return Math.sqrt(this.b*this.b+this.d*this.d)}worldToLocal(t){let e=1/(this.a*this.d-this.b*this.c),s=t.x-this.worldX,r=t.y-this.worldY;return t.x=s*this.d*e-r*this.b*e,t.y=r*this.a*e-s*this.c*e,t}localToWorld(t){let e=t.x,s=t.y;return t.x=e*this.a+s*this.b+this.worldX,t.y=e*this.c+s*this.d+this.worldY,t}worldToParent(t){if(t==null)throw new Error("world cannot be null.");return this.parent==null?t:this.parent.worldToLocal(t)}parentToWorld(t){if(t==null)throw new Error("world cannot be null.");return this.parent==null?t:this.parent.localToWorld(t)}worldToLocalRotation(t){let e=R.sinDeg(t),s=R.cosDeg(t);return Math.atan2(this.a*e-this.c*s,this.d*s-this.b*e)*R.radDeg+this.rotation-this.shearX}localToWorldRotation(t){t-=this.rotation-this.shearX;let e=R.sinDeg(t),s=R.cosDeg(t);return Math.atan2(s*this.c+e*this.d,s*this.a+e*this.b)*R.radDeg}rotateWorld(t){t*=R.degRad;const e=Math.sin(t),s=Math.cos(t),r=this.a,i=this.b;this.a=s*r-e*this.c,this.b=s*i-e*this.d,this.c=e*r+s*this.c,this.d=e*i+s*this.d}},Ct=class{constructor(t,e,s){this.name=t,this.order=e,this.skinRequired=s}},Ks=class{pathPrefix="";textureLoader;downloader;assets={};assetsRefCount={};assetsLoaded={};errors={};toLoad=0;loaded=0;constructor(t,e="",s=new ps){this.textureLoader=t,this.pathPrefix=e,this.downloader=s}start(t){return this.toLoad++,this.pathPrefix+t}success(t,e,s){this.toLoad--,this.loaded++,this.assets[e]=s,this.assetsRefCount[e]=(this.assetsRefCount[e]||0)+1,t&&t(e,s)}error(t,e,s){this.toLoad--,this.loaded++,this.errors[e]=s,t&&t(e,s)}loadAll(){return new Promise((e,s)=>{let r=()=>{if(this.isLoadingComplete()){this.hasErrors()?s(this.errors):e(this);return}requestAnimationFrame(r)};requestAnimationFrame(r)})}setRawDataURI(t,e){this.downloader.rawDataUris[this.pathPrefix+t]=e}loadBinary(t,e=()=>{},s=()=>{}){t=this.start(t),!this.reuseAssets(t,e,s)&&(this.assetsLoaded[t]=new Promise((r,i)=>{this.downloader.downloadBinary(t,h=>{this.success(e,t,h),r(h)},(h,l)=>{const n=`Couldn't load binary ${t}: status ${h}, ${l}`;this.error(s,t,n),i(n)})}))}loadText(t,e=()=>{},s=()=>{}){t=this.start(t),this.downloader.downloadText(t,r=>{this.success(e,t,r)},(r,i)=>{this.error(s,t,`Couldn't load text ${t}: status ${r}, ${i}`)})}loadJson(t,e=()=>{},s=()=>{}){t=this.start(t),!this.reuseAssets(t,e,s)&&(this.assetsLoaded[t]=new Promise((r,i)=>{this.downloader.downloadJson(t,h=>{this.success(e,t,h),r(h)},(h,l)=>{const n=`Couldn't load JSON ${t}: status ${h}, ${l}`;this.error(s,t,n),i(n)})}))}reuseAssets(t,e=()=>{},s=()=>{}){const r=this.assetsLoaded[t],i=r!==void 0;return i&&r.then(h=>this.success(e,t,h)).catch(h=>this.error(s,t,h)),i}loadTexture(t,e=()=>{},s=()=>{}){t=this.start(t),!this.reuseAssets(t,e,s)&&(this.assetsLoaded[t]=new Promise((r,i)=>{if(!!!(typeof window<"u"&&typeof navigator<"u"&&window.document))fetch(t,{mode:"cors"}).then(n=>{if(n.ok)return n.blob();const a=`Couldn't load image: ${t}`;this.error(s,t,`Couldn't load image: ${t}`),i(a)}).then(n=>n?createImageBitmap(n,{premultiplyAlpha:"none",colorSpaceConversion:"none"}):null).then(n=>{if(n){const a=this.textureLoader(n);this.success(e,t,a),r(a)}});else{let n=new Image;n.crossOrigin="anonymous",n.onload=()=>{const a=this.textureLoader(n);this.success(e,t,a),r(a)},n.onerror=()=>{const a=`Couldn't load image: ${t}`;this.error(s,t,a),i(a)},this.downloader.rawDataUris[t]&&(t=this.downloader.rawDataUris[t]),n.src=t}}))}loadTextureAtlas(t,e=()=>{},s=()=>{},r){let i=t.lastIndexOf("/"),h=i>=0?t.substring(0,i+1):"";t=this.start(t),!this.reuseAssets(t,e,s)&&(this.assetsLoaded[t]=new Promise((l,n)=>{this.downloader.downloadText(t,a=>{try{let o=new Lt(a),c=o.pages.length,f=!1;for(let d of o.pages)this.loadTexture(r?r[d.name]:h+d.name,(m,u)=>{f||(d.setTexture(u),--c==0&&(this.success(e,t,o),l(o)))},(m,u)=>{if(!f){const w=`Couldn't load texture atlas ${t} page image: ${m}`;this.error(s,t,w),n(w)}f=!0})}catch(o){const c=`Couldn't parse texture atlas ${t}: ${o.message}`;this.error(s,t,c),n(c)}},(a,o)=>{const c=`Couldn't load texture atlas ${t}: status ${a}, ${o}`;this.error(s,t,c),n(c)})}))}loadTextureAtlasButNoTextures(t,e=()=>{},s=()=>{},r){t=this.start(t),!this.reuseAssets(t,e,s)&&(this.assetsLoaded[t]=new Promise((i,h)=>{this.downloader.downloadText(t,l=>{try{const n=new Lt(l);this.success(e,t,n),i(n)}catch(n){const a=`Couldn't parse texture atlas ${t}: ${n.message}`;this.error(s,t,a),h(a)}},(l,n)=>{const a=`Couldn't load texture atlas ${t}: status ${l}, ${n}`;this.error(s,t,a),h(a)})}))}async loadBinaryAsync(t){return new Promise((e,s)=>{this.loadBinary(t,(r,i)=>e(i),(r,i)=>s(i))})}async loadJsonAsync(t){return new Promise((e,s)=>{this.loadJson(t,(r,i)=>e(i),(r,i)=>s(i))})}async loadTextureAsync(t){return new Promise((e,s)=>{this.loadTexture(t,(r,i)=>e(i),(r,i)=>s(i))})}async loadTextureAtlasAsync(t){return new Promise((e,s)=>{this.loadTextureAtlas(t,(r,i)=>e(i),(r,i)=>s(i))})}async loadTextureAtlasButNoTexturesAsync(t){return new Promise((e,s)=>{this.loadTextureAtlasButNoTextures(t,(r,i)=>e(i),(r,i)=>s(i))})}get(t){return this.assets[this.pathPrefix+t]}require(t){t=this.pathPrefix+t;let e=this.assets[t];if(e)return e;let s=this.errors[t];throw Error("Asset not found: "+t+(s?`
2
+ `+s:""))}remove(t){t=this.pathPrefix+t;let e=this.assets[t];return e.dispose&&e.dispose(),delete this.assets[t],delete this.assetsRefCount[t],delete this.assetsLoaded[t],e}removeAll(){for(let t in this.assets){let e=this.assets[t];e.dispose&&e.dispose()}this.assets={},this.assetsLoaded={},this.assetsRefCount={}}isLoadingComplete(){return this.toLoad==0}getToLoad(){return this.toLoad}getLoaded(){return this.loaded}dispose(){this.removeAll()}disposeAsset(t){--this.assetsRefCount[t]===0&&this.remove(t)}hasErrors(){return Object.keys(this.errors).length>0}getErrors(){return this.errors}},ps=class{callbacks={};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),s=e.length,r=new Uint8Array(s),i=0;i<s;i++)r[i]=e.charCodeAt(i);return r}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,s){if(this.start(t,e,s))return;const r=this.rawDataUris[t];if(r&&!r.includes(".")){try{this.finish(t,200,this.dataUriToString(r))}catch(l){this.finish(t,400,JSON.stringify(l))}return}let i=new XMLHttpRequest;i.overrideMimeType("text/html"),i.open("GET",r||t,!0);let h=()=>{this.finish(t,i.status,i.responseText)};i.onload=h,i.onerror=h,i.send()}downloadJson(t,e,s){this.downloadText(t,r=>{e(JSON.parse(r))},s)}downloadBinary(t,e,s){if(this.start(t,e,s))return;const r=this.rawDataUris[t];if(r&&!r.includes(".")){try{this.finish(t,200,this.dataUriToUint8Array(r))}catch(l){this.finish(t,400,JSON.stringify(l))}return}let i=new XMLHttpRequest;i.open("GET",r||t,!0),i.responseType="arraybuffer";let h=()=>{this.finish(t,i.status,i.response)};i.onload=()=>{i.status==200||i.status==0?this.finish(t,200,new Uint8Array(i.response)):h()},i.onerror=h,i.send()}start(t,e,s){let r=this.callbacks[t];try{if(r)return!0;this.callbacks[t]=r=[]}finally{r.push(e,s)}}finish(t,e,s){let r=this.callbacks[t];delete this.callbacks[t];let i=e==200||e==0?[s]:[e,s];for(let h=i.length-1,l=r.length;h<l;h+=2)r[h].apply(null,i)}},Ee=class{data;intValue=0;floatValue=0;stringValue=null;time=0;volume=0;balance=0;constructor(t,e){if(!e)throw new Error("data cannot be null.");this.time=t,this.data=e}},Re=class{name;intValue=0;floatValue=0;stringValue=null;audioPath=null;volume=0;balance=0;constructor(t){this.name=t}},bs=class{data;bones;target;bendDirection=0;compress=!1;stretch=!1;mix=1;softness=0;active=!1;constructor(t,e){if(!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 r=0;r<t.bones.length;r++){let i=e.findBone(t.bones[r].name);if(!i)throw new Error(`Couldn't find bone ${t.bones[r].name}`);this.bones.push(i)}let s=e.findBone(t.target.name);if(!s)throw new Error(`Couldn't find bone ${t.target.name}`);this.target=s,this.mix=t.mix,this.softness=t.softness,this.bendDirection=t.bendDirection,this.compress=t.compress,this.stretch=t.stretch}isActive(){return this.active}setToSetupPose(){const t=this.data;this.mix=t.mix,this.softness=t.softness,this.bendDirection=t.bendDirection,this.compress=t.compress,this.stretch=t.stretch}update(t){if(this.mix==0)return;let e=this.target,s=this.bones;switch(s.length){case 1:this.apply1(s[0],e.worldX,e.worldY,this.compress,this.stretch,this.data.uniform,this.mix);break;case 2:this.apply2(s[0],s[1],e.worldX,e.worldY,this.bendDirection,this.stretch,this.data.uniform,this.softness,this.mix);break}}apply1(t,e,s,r,i,h,l){let n=t.parent;if(!n)throw new Error("IK bone must have parent.");let a=n.a,o=n.b,c=n.c,f=n.d,d=-t.ashearX-t.arotation,m=0,u=0;switch(t.inherit){case 1:m=(e-t.worldX)*R.signum(t.skeleton.scaleX),u=(s-t.worldY)*R.signum(t.skeleton.scaleY);break;case 2:let p=Math.abs(a*f-o*c)/Math.max(1e-4,a*a+c*c),g=a/t.skeleton.scaleX,x=c/t.skeleton.scaleY;o=-x*p*t.skeleton.scaleX,f=g*p*t.skeleton.scaleY,d+=Math.atan2(x,g)*R.radDeg;default:let y=e-n.worldX,v=s-n.worldY,A=a*f-o*c;Math.abs(A)<=1e-4?(m=0,u=0):(m=(y*f-v*o)/A-t.ax,u=(v*a-y*c)/A-t.ay)}d+=Math.atan2(u,m)*R.radDeg,t.ascaleX<0&&(d+=180),d>180?d-=360:d<-180&&(d+=360);let w=t.ascaleX,b=t.ascaleY;if(r||i){switch(t.inherit){case 3:case 4:m=e-t.worldX,u=s-t.worldY}const p=t.data.length*w;if(p>1e-4){const g=m*m+u*u;if(r&&g<p*p||i&&g>p*p){const x=(Math.sqrt(g)/p-1)*l+1;w*=x,h&&(b*=x)}}}t.updateWorldTransformWith(t.ax,t.ay,t.arotation+d*l,w,b,t.ashearX,t.ashearY)}apply2(t,e,s,r,i,h,l,n,a){if(t.inherit!=0||e.inherit!=0)return;let o=t.ax,c=t.ay,f=t.ascaleX,d=t.ascaleY,m=f,u=d,w=e.ascaleX,b=0,p=0,g=0;f<0?(f=-f,b=180,g=-1):(b=0,g=1),d<0&&(d=-d,g=-g),w<0?(w=-w,p=180):p=0;let x=e.ax,y=0,v=0,A=0,S=t.a,C=t.b,k=t.c,Y=t.d,M=Math.abs(f-d)<=1e-4;!M||h?(y=0,v=S*x+t.worldX,A=k*x+t.worldY):(y=e.ay,v=S*x+C*y+t.worldX,A=k*x+Y*y+t.worldY);let F=t.parent;if(!F)throw new Error("IK parent must itself have a parent.");S=F.a,C=F.b,k=F.c,Y=F.d;let E=S*Y-C*k,T=v-F.worldX,X=A-F.worldY;E=Math.abs(E)<=1e-4?0:1/E;let V=(T*Y-X*C)*E-o,D=(X*S-T*k)*E-c,L=Math.sqrt(V*V+D*D),O=e.data.length*w,$,z;if(L<1e-4){this.apply1(t,s,r,!1,h,!1,a),e.updateWorldTransformWith(x,y,0,e.ascaleX,e.ascaleY,e.ashearX,e.ashearY);return}T=s-F.worldX,X=r-F.worldY;let j=(T*Y-X*C)*E-o,B=(X*S-T*k)*E-c,W=j*j+B*B;if(n!=0){n*=f*(w+1)*.5;let J=Math.sqrt(W),K=J-L-O*f+n;if(K>0){let Q=Math.min(1,K/(n*2))-1;Q=(K-n*(1-Q*Q))/J,j-=Q*j,B-=Q*B,W=j*j+B*B}}t:if(M){O*=f;let J=(W-L*L-O*O)/(2*L*O);J<-1?(J=-1,z=Math.PI*i):J>1?(J=1,z=0,h&&(S=(Math.sqrt(W)/(L+O)-1)*a+1,m*=S,l&&(u*=S))):z=Math.acos(J)*i,S=L+O*J,C=O*Math.sin(z),$=Math.atan2(B*S-j*C,j*S+B*C)}else{S=f*O,C=d*O;let J=S*S,K=C*C,Q=Math.atan2(B,j);k=K*L*L+J*W-J*K;let it=-2*K*L,gt=K-J;if(Y=it*it-4*gt*k,Y>=0){let xt=Math.sqrt(Y);it<0&&(xt=-xt),xt=-(it+xt)*.5;let yt=xt/gt,Qe=k/xt,Mt=Math.abs(yt)<Math.abs(Qe)?yt:Qe;if(yt=W-Mt*Mt,yt>=0){X=Math.sqrt(yt)*i,$=Q-Math.atan2(X,Mt),z=Math.atan2(X/d,(Mt-L)/f);break t}}let bt=R.PI,kt=L-S,zt=kt*kt,je=0,Je=0,Tt=L+S,_t=Tt*Tt,Ke=0;k=-S*L/(J-K),k>=-1&&k<=1&&(k=Math.acos(k),T=S*Math.cos(k)+L,X=C*Math.sin(k),Y=T*T+X*X,Y<zt&&(bt=k,zt=Y,kt=T,je=X),Y>_t&&(Je=k,_t=Y,Tt=T,Ke=X)),W<=(zt+_t)*.5?($=Q-Math.atan2(je*i,kt),z=bt*i):($=Q-Math.atan2(Ke*i,Tt),z=Je*i)}let G=Math.atan2(y,x)*g,tt=t.arotation;$=($-G)*R.radDeg+b-tt,$>180?$-=360:$<-180&&($+=360),t.updateWorldTransformWith(o,c,tt+$*a,m,u,0,0),tt=e.arotation,z=((z+G)*R.radDeg-e.ashearX)*g+p-tt,z>180?z-=360:z<-180&&(z+=360),e.updateWorldTransformWith(x,y,tt+z*a,e.ascaleX,e.ascaleY,e.ashearX,e.ashearY)}},Pe=class extends Ct{bones=new Array;_target=null;set target(t){this._target=t}get target(){if(this._target)return this._target;throw new Error("BoneData not set.")}bendDirection=0;compress=!1;stretch=!1;uniform=!1;mix=0;softness=0;constructor(t){super(t,0,!1)}},Be=class extends Ct{bones=new Array;_target=null;set target(t){this._target=t}get target(){if(this._target)return this._target;throw new Error("SlotData not set.")}positionMode=0;spacingMode=1;rotateMode=1;offsetRotation=0;position=0;spacing=0;mixRotate=0;mixX=0;mixY=0;constructor(t){super(t,0,!1)}},Ve=(t=>(t[t.Fixed=0]="Fixed",t[t.Percent=1]="Percent",t))(Ve||{}),Le=(t=>(t[t.Length=0]="Length",t[t.Fixed=1]="Fixed",t[t.Percent=2]="Percent",t[t.Proportional=3]="Proportional",t))(Le||{}),Ne=(t=>(t[t.Tangent=0]="Tangent",t[t.Chain=1]="Chain",t[t.ChainScale=2]="ChainScale",t))(Ne||{}),ys=class ft{static NONE=-1;static BEFORE=-2;static AFTER=-3;static epsilon=1e-5;data;bones;target;position=0;spacing=0;mixRotate=0;mixX=0;mixY=0;spaces=new Array;positions=new Array;world=new Array;curves=new Array;lengths=new Array;segments=new Array;active=!1;constructor(e,s){if(!e)throw new Error("data cannot be null.");if(!s)throw new Error("skeleton cannot be null.");this.data=e,this.bones=new Array;for(let i=0,h=e.bones.length;i<h;i++){let l=s.findBone(e.bones[i].name);if(!l)throw new Error(`Couldn't find bone ${e.bones[i].name}.`);this.bones.push(l)}let r=s.findSlot(e.target.name);if(!r)throw new Error(`Couldn't find target bone ${e.target.name}`);this.target=r,this.position=e.position,this.spacing=e.spacing,this.mixRotate=e.mixRotate,this.mixX=e.mixX,this.mixY=e.mixY}isActive(){return this.active}setToSetupPose(){const e=this.data;this.position=e.position,this.spacing=e.spacing,this.mixRotate=e.mixRotate,this.mixX=e.mixX,this.mixY=e.mixY}update(e){let s=this.target.getAttachment();if(!(s instanceof It))return;let r=this.mixRotate,i=this.mixX,h=this.mixY;if(r==0&&i==0&&h==0)return;let l=this.data,n=l.rotateMode==0,a=l.rotateMode==2,o=this.bones,c=o.length,f=n?c:c+1,d=P.setArraySize(this.spaces,f),m=a?this.lengths=P.setArraySize(this.lengths,c):[],u=this.spacing;switch(l.spacingMode){case 2:if(a)for(let A=0,S=f-1;A<S;A++){let C=o[A],k=C.data.length,Y=k*C.a,M=k*C.c;m[A]=Math.sqrt(Y*Y+M*M)}P.arrayFill(d,1,f,u);break;case 3:let y=0;for(let A=0,S=f-1;A<S;){let C=o[A],k=C.data.length;if(k<ft.epsilon)a&&(m[A]=0),d[++A]=u;else{let Y=k*C.a,M=k*C.c,F=Math.sqrt(Y*Y+M*M);a&&(m[A]=F),d[++A]=F,y+=F}}if(y>0){y=f/y*u;for(let A=1;A<f;A++)d[A]*=y}break;default:let v=l.spacingMode==0;for(let A=0,S=f-1;A<S;){let C=o[A],k=C.data.length;if(k<ft.epsilon)a&&(m[A]=0),d[++A]=u;else{let Y=k*C.a,M=k*C.c,F=Math.sqrt(Y*Y+M*M);a&&(m[A]=F),d[++A]=(v?k+u:u)*F/k}}}let w=this.computeWorldPositions(s,f,n),b=w[0],p=w[1],g=l.offsetRotation,x=!1;if(g==0)x=l.rotateMode==1;else{x=!1;let y=this.target.bone;g*=y.a*y.d-y.b*y.c>0?R.degRad:-R.degRad}for(let y=0,v=3;y<c;y++,v+=3){let A=o[y];A.worldX+=(b-A.worldX)*i,A.worldY+=(p-A.worldY)*h;let S=w[v],C=w[v+1],k=S-b,Y=C-p;if(a){let M=m[y];if(M!=0){let F=(Math.sqrt(k*k+Y*Y)/M-1)*r+1;A.a*=F,A.c*=F}}if(b=S,p=C,r>0){let M=A.a,F=A.b,E=A.c,T=A.d,X=0,V=0,D=0;if(n?X=w[v-1]:d[y+1]==0?X=w[v+2]:X=Math.atan2(Y,k),X-=Math.atan2(E,M),x){V=Math.cos(X),D=Math.sin(X);let L=A.data.length;b+=(L*(V*M-D*E)-k)*r,p+=(L*(D*M+V*E)-Y)*r}else X+=g;X>R.PI?X-=R.PI2:X<-R.PI&&(X+=R.PI2),X*=r,V=Math.cos(X),D=Math.sin(X),A.a=V*M-D*E,A.b=V*F-D*T,A.c=D*M+V*E,A.d=D*F+V*T}A.updateAppliedTransform()}}computeWorldPositions(e,s,r){let i=this.target,h=this.position,l=this.spaces,n=P.setArraySize(this.positions,s*3+2),a=this.world,o=e.closed,c=e.worldVerticesLength,f=c/6,d=ft.NONE;if(!e.constantSpeed){let L=e.lengths;f-=o?1:2;let O=L[f];this.data.positionMode==1&&(h*=O);let $;switch(this.data.spacingMode){case 2:$=O;break;case 3:$=O/s;break;default:$=1}a=P.setArraySize(this.world,8);for(let z=0,j=0,B=0;z<s;z++,j+=3){let W=l[z]*$;h+=W;let G=h;if(o)G%=O,G<0&&(G+=O),B=0;else if(G<0){d!=ft.BEFORE&&(d=ft.BEFORE,e.computeWorldVertices(i,2,4,a,0,2)),this.addBeforePosition(G,a,0,n,j);continue}else if(G>O){d!=ft.AFTER&&(d=ft.AFTER,e.computeWorldVertices(i,c-6,4,a,0,2)),this.addAfterPosition(G-O,a,0,n,j);continue}for(;;B++){let tt=L[B];if(!(G>tt)){if(B==0)G/=tt;else{let J=L[B-1];G=(G-J)/(tt-J)}break}}B!=d&&(d=B,o&&B==f?(e.computeWorldVertices(i,c-4,4,a,0,2),e.computeWorldVertices(i,0,4,a,4,2)):e.computeWorldVertices(i,B*6+2,8,a,0,2)),this.addCurvePosition(G,a[0],a[1],a[2],a[3],a[4],a[5],a[6],a[7],n,j,r||z>0&&W==0)}return n}o?(c+=2,a=P.setArraySize(this.world,c),e.computeWorldVertices(i,2,c-4,a,0,2),e.computeWorldVertices(i,0,2,a,c-4,2),a[c-2]=a[0],a[c-1]=a[1]):(f--,c-=4,a=P.setArraySize(this.world,c),e.computeWorldVertices(i,2,c,a,0,2));let m=P.setArraySize(this.curves,f),u=0,w=a[0],b=a[1],p=0,g=0,x=0,y=0,v=0,A=0,S=0,C=0,k=0,Y=0,M=0,F=0,E=0,T=0;for(let L=0,O=2;L<f;L++,O+=6)p=a[O],g=a[O+1],x=a[O+2],y=a[O+3],v=a[O+4],A=a[O+5],S=(w-p*2+x)*.1875,C=(b-g*2+y)*.1875,k=((p-x)*3-w+v)*.09375,Y=((g-y)*3-b+A)*.09375,M=S*2+k,F=C*2+Y,E=(p-w)*.75+S+k*.16666667,T=(g-b)*.75+C+Y*.16666667,u+=Math.sqrt(E*E+T*T),E+=M,T+=F,M+=k,F+=Y,u+=Math.sqrt(E*E+T*T),E+=M,T+=F,u+=Math.sqrt(E*E+T*T),E+=M+k,T+=F+Y,u+=Math.sqrt(E*E+T*T),m[L]=u,w=v,b=A;this.data.positionMode==1&&(h*=u);let X;switch(this.data.spacingMode){case 2:X=u;break;case 3:X=u/s;break;default:X=1}let V=this.segments,D=0;for(let L=0,O=0,$=0,z=0;L<s;L++,O+=3){let j=l[L]*X;h+=j;let B=h;if(o)B%=u,B<0&&(B+=u),$=0;else if(B<0){this.addBeforePosition(B,a,0,n,O);continue}else if(B>u){this.addAfterPosition(B-u,a,c-4,n,O);continue}for(;;$++){let W=m[$];if(!(B>W)){if($==0)B/=W;else{let G=m[$-1];B=(B-G)/(W-G)}break}}if($!=d){d=$;let W=$*6;for(w=a[W],b=a[W+1],p=a[W+2],g=a[W+3],x=a[W+4],y=a[W+5],v=a[W+6],A=a[W+7],S=(w-p*2+x)*.03,C=(b-g*2+y)*.03,k=((p-x)*3-w+v)*.006,Y=((g-y)*3-b+A)*.006,M=S*2+k,F=C*2+Y,E=(p-w)*.3+S+k*.16666667,T=(g-b)*.3+C+Y*.16666667,D=Math.sqrt(E*E+T*T),V[0]=D,W=1;W<8;W++)E+=M,T+=F,M+=k,F+=Y,D+=Math.sqrt(E*E+T*T),V[W]=D;E+=M,T+=F,D+=Math.sqrt(E*E+T*T),V[8]=D,E+=M+k,T+=F+Y,D+=Math.sqrt(E*E+T*T),V[9]=D,z=0}for(B*=D;;z++){let W=V[z];if(!(B>W)){if(z==0)B/=W;else{let G=V[z-1];B=z+(B-G)/(W-G)}break}}this.addCurvePosition(B*.1,w,b,p,g,x,y,v,A,n,O,r||L>0&&j==0)}return n}addBeforePosition(e,s,r,i,h){let l=s[r],n=s[r+1],a=s[r+2]-l,o=s[r+3]-n,c=Math.atan2(o,a);i[h]=l+e*Math.cos(c),i[h+1]=n+e*Math.sin(c),i[h+2]=c}addAfterPosition(e,s,r,i,h){let l=s[r+2],n=s[r+3],a=l-s[r],o=n-s[r+1],c=Math.atan2(o,a);i[h]=l+e*Math.cos(c),i[h+1]=n+e*Math.sin(c),i[h+2]=c}addCurvePosition(e,s,r,i,h,l,n,a,o,c,f,d){if(e==0||isNaN(e)){c[f]=s,c[f+1]=r,c[f+2]=Math.atan2(h-r,i-s);return}let m=e*e,u=m*e,w=1-e,b=w*w,p=b*w,g=w*e,x=g*3,y=w*x,v=x*e,A=s*p+i*y+l*v+a*u,S=r*p+h*y+n*v+o*u;c[f]=A,c[f+1]=S,d&&(e<.001?c[f+2]=Math.atan2(h-r,i-s):c[f+2]=Math.atan2(S-(r*b+h*g*2+n*m),A-(s*b+i*g*2+l*m)))}},Qs=class{data;_bone=null;set bone(t){this._bone=t}get bone(){if(this._bone)return this._bone;throw new Error("Bone not set.")}inertia=0;strength=0;damping=0;massInverse=0;wind=0;gravity=0;mix=0;_reset=!0;ux=0;uy=0;cx=0;cy=0;tx=0;ty=0;xOffset=0;xVelocity=0;yOffset=0;yVelocity=0;rotateOffset=0;rotateVelocity=0;scaleOffset=0;scaleVelocity=0;active=!1;skeleton;remaining=0;lastTime=0;constructor(t,e){this.data=t,this.skeleton=e,this.bone=e.bones[t.bone.index],this.inertia=t.inertia,this.strength=t.strength,this.damping=t.damping,this.massInverse=t.massInverse,this.wind=t.wind,this.gravity=t.gravity,this.mix=t.mix}reset(){this.remaining=0,this.lastTime=this.skeleton.time,this._reset=!0,this.xOffset=0,this.xVelocity=0,this.yOffset=0,this.yVelocity=0,this.rotateOffset=0,this.rotateVelocity=0,this.scaleOffset=0,this.scaleVelocity=0}setToSetupPose(){const t=this.data;this.inertia=t.inertia,this.strength=t.strength,this.damping=t.damping,this.massInverse=t.massInverse,this.wind=t.wind,this.gravity=t.gravity,this.mix=t.mix}isActive(){return this.active}update(t){const e=this.mix;if(e==0)return;const s=this.data.x>0,r=this.data.y>0,i=this.data.rotate>0||this.data.shearX>0,h=this.data.scaleX>0,l=this.bone,n=l.data.length;switch(t){case 0:return;case 1:this.reset();case 2:const a=this.skeleton,o=Math.max(this.skeleton.time-this.lastTime,0);this.remaining+=o,this.lastTime=a.time;const c=l.worldX,f=l.worldY;if(this._reset)this._reset=!1,this.ux=c,this.uy=f;else{let d=this.remaining,m=this.inertia,u=this.data.step,w=this.skeleton.data.referenceScale,b=-1,p=this.data.limit*o,g=p*Math.abs(a.scaleY);if(p*=Math.abs(a.scaleX),s||r){if(s){const x=(this.ux-c)*m;this.xOffset+=x>p?p:x<-p?-p:x,this.ux=c}if(r){const x=(this.uy-f)*m;this.yOffset+=x>g?g:x<-g?-g:x,this.uy=f}if(d>=u){b=Math.pow(this.damping,60*u);const x=this.massInverse*u,y=this.strength,v=this.wind*w*a.scaleX,A=this.gravity*w*a.scaleY;do s&&(this.xVelocity+=(v-this.xOffset*y)*x,this.xOffset+=this.xVelocity*u,this.xVelocity*=b),r&&(this.yVelocity-=(A+this.yOffset*y)*x,this.yOffset+=this.yVelocity*u,this.yVelocity*=b),d-=u;while(d>=u)}s&&(l.worldX+=this.xOffset*e*this.data.x),r&&(l.worldY+=this.yOffset*e*this.data.y)}if(i||h){let x=Math.atan2(l.c,l.a),y=0,v=0,A=0,S=this.cx-l.worldX,C=this.cy-l.worldY;if(S>p?S=p:S<-p&&(S=-p),C>g?C=g:C<-g&&(C=-g),i){A=(this.data.rotate+this.data.shearX)*e;let k=Math.atan2(C+this.ty,S+this.tx)-x-this.rotateOffset*A;this.rotateOffset+=(k-Math.ceil(k*R.invPI2-.5)*R.PI2)*m,k=this.rotateOffset*A+x,y=Math.cos(k),v=Math.sin(k),h&&(k=n*l.getWorldScaleX(),k>0&&(this.scaleOffset+=(S*y+C*v)*m/k))}else{y=Math.cos(x),v=Math.sin(x);const k=n*l.getWorldScaleX();k>0&&(this.scaleOffset+=(S*y+C*v)*m/k)}if(d=this.remaining,d>=u){b==-1&&(b=Math.pow(this.damping,60*u));const k=this.massInverse*u,Y=this.strength,M=this.wind,F=Ot.yDown?-this.gravity:this.gravity,E=n/w;for(;;)if(d-=u,h&&(this.scaleVelocity+=(M*y-F*v-this.scaleOffset*Y)*k,this.scaleOffset+=this.scaleVelocity*u,this.scaleVelocity*=b),i){if(this.rotateVelocity-=((M*v+F*y)*E+this.rotateOffset*Y)*k,this.rotateOffset+=this.rotateVelocity*u,this.rotateVelocity*=b,d<u)break;const T=this.rotateOffset*A+x;y=Math.cos(T),v=Math.sin(T)}else if(d<u)break}}this.remaining=d}this.cx=l.worldX,this.cy=l.worldY;break;case 3:s&&(l.worldX+=this.xOffset*e*this.data.x),r&&(l.worldY+=this.yOffset*e*this.data.y)}if(i){let a=this.rotateOffset*e,o=0,c=0,f=0;if(this.data.shearX>0){let d=0;this.data.rotate>0&&(d=a*this.data.rotate,o=Math.sin(d),c=Math.cos(d),f=l.b,l.b=c*f-o*l.d,l.d=o*f+c*l.d),d+=a*this.data.shearX,o=Math.sin(d),c=Math.cos(d),f=l.a,l.a=c*f-o*l.c,l.c=o*f+c*l.c}else a*=this.data.rotate,o=Math.sin(a),c=Math.cos(a),f=l.a,l.a=c*f-o*l.c,l.c=o*f+c*l.c,f=l.b,l.b=c*f-o*l.d,l.d=o*f+c*l.d}if(h){const a=1+this.scaleOffset*e*this.data.scaleX;l.a*=a,l.c*=a}t!=3&&(this.tx=n*l.a,this.ty=n*l.c),l.updateAppliedTransform()}translate(t,e){this.ux-=t,this.uy-=e,this.cx-=t,this.cy-=e}rotate(t,e,s){const r=s*R.degRad,i=Math.cos(r),h=Math.sin(r),l=this.cx-t,n=this.cy-e;this.translate(l*i-n*h-l,l*h+n*i-n)}},vs=class{data;bone;color;darkColor=null;attachment=null;attachmentState=0;sequenceIndex=-1;deform=new Array;constructor(t,e){if(!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 N,this.darkColor=t.darkColor?new N:null,this.setToSetupPose()}getSkeleton(){return this.bone.skeleton}getAttachment(){return this.attachment}setAttachment(t){this.attachment!=t&&((!(t instanceof lt)||!(this.attachment instanceof lt)||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{data;bones;target;mixRotate=0;mixX=0;mixY=0;mixScaleX=0;mixScaleY=0;mixShearY=0;temp=new Yt;active=!1;constructor(t,e){if(!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 r=0;r<t.bones.length;r++){let i=e.findBone(t.bones[r].name);if(!i)throw new Error(`Couldn't find bone ${t.bones[r].name}.`);this.bones.push(i)}let s=e.findBone(t.target.name);if(!s)throw new Error(`Couldn't find target bone ${t.target.name}.`);this.target=s,this.mixRotate=t.mixRotate,this.mixX=t.mixX,this.mixY=t.mixY,this.mixScaleX=t.mixScaleX,this.mixScaleY=t.mixScaleY,this.mixShearY=t.mixShearY}isActive(){return this.active}setToSetupPose(){const t=this.data;this.mixRotate=t.mixRotate,this.mixX=t.mixX,this.mixY=t.mixY,this.mixScaleX=t.mixScaleX,this.mixScaleY=t.mixScaleY,this.mixShearY=t.mixShearY}update(t){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,s=this.mixY,r=this.mixScaleX,i=this.mixScaleY,h=this.mixShearY,l=e!=0||s!=0,n=this.target,a=n.a,o=n.b,c=n.c,f=n.d,d=a*f-o*c>0?R.degRad:-R.degRad,m=this.data.offsetRotation*d,u=this.data.offsetShearY*d,w=this.bones;for(let b=0,p=w.length;b<p;b++){let g=w[b];if(t!=0){let x=g.a,y=g.b,v=g.c,A=g.d,S=Math.atan2(c,a)-Math.atan2(v,x)+m;S>R.PI?S-=R.PI2:S<-R.PI&&(S+=R.PI2),S*=t;let C=Math.cos(S),k=Math.sin(S);g.a=C*x-k*v,g.b=C*y-k*A,g.c=k*x+C*v,g.d=k*y+C*A}if(l){let x=this.temp;n.localToWorld(x.set(this.data.offsetX,this.data.offsetY)),g.worldX+=(x.x-g.worldX)*e,g.worldY+=(x.y-g.worldY)*s}if(r!=0){let x=Math.sqrt(g.a*g.a+g.c*g.c);x!=0&&(x=(x+(Math.sqrt(a*a+c*c)-x+this.data.offsetScaleX)*r)/x),g.a*=x,g.c*=x}if(i!=0){let x=Math.sqrt(g.b*g.b+g.d*g.d);x!=0&&(x=(x+(Math.sqrt(o*o+f*f)-x+this.data.offsetScaleY)*i)/x),g.b*=x,g.d*=x}if(h>0){let x=g.b,y=g.d,v=Math.atan2(y,x),A=Math.atan2(f,o)-Math.atan2(c,a)-(v-Math.atan2(g.c,g.a));A>R.PI?A-=R.PI2:A<-R.PI&&(A+=R.PI2),A=v+(A+u)*h;let S=Math.sqrt(x*x+y*y);g.b=Math.cos(A)*S,g.d=Math.sin(A)*S}g.updateAppliedTransform()}}applyRelativeWorld(){let t=this.mixRotate,e=this.mixX,s=this.mixY,r=this.mixScaleX,i=this.mixScaleY,h=this.mixShearY,l=e!=0||s!=0,n=this.target,a=n.a,o=n.b,c=n.c,f=n.d,d=a*f-o*c>0?R.degRad:-R.degRad,m=this.data.offsetRotation*d,u=this.data.offsetShearY*d,w=this.bones;for(let b=0,p=w.length;b<p;b++){let g=w[b];if(t!=0){let x=g.a,y=g.b,v=g.c,A=g.d,S=Math.atan2(c,a)+m;S>R.PI?S-=R.PI2:S<-R.PI&&(S+=R.PI2),S*=t;let C=Math.cos(S),k=Math.sin(S);g.a=C*x-k*v,g.b=C*y-k*A,g.c=k*x+C*v,g.d=k*y+C*A}if(l){let x=this.temp;n.localToWorld(x.set(this.data.offsetX,this.data.offsetY)),g.worldX+=x.x*e,g.worldY+=x.y*s}if(r!=0){let x=(Math.sqrt(a*a+c*c)-1+this.data.offsetScaleX)*r+1;g.a*=x,g.c*=x}if(i!=0){let x=(Math.sqrt(o*o+f*f)-1+this.data.offsetScaleY)*i+1;g.b*=x,g.d*=x}if(h>0){let x=Math.atan2(f,o)-Math.atan2(c,a);x>R.PI?x-=R.PI2:x<-R.PI&&(x+=R.PI2);let y=g.b,v=g.d;x=Math.atan2(v,y)+(x-R.PI/2+u)*h;let A=Math.sqrt(y*y+v*v);g.b=Math.cos(x)*A,g.d=Math.sin(x)*A}g.updateAppliedTransform()}}applyAbsoluteLocal(){let t=this.mixRotate,e=this.mixX,s=this.mixY,r=this.mixScaleX,i=this.mixScaleY,h=this.mixShearY,l=this.target,n=this.bones;for(let a=0,o=n.length;a<o;a++){let c=n[a],f=c.arotation;t!=0&&(f+=(l.arotation-f+this.data.offsetRotation)*t);let d=c.ax,m=c.ay;d+=(l.ax-d+this.data.offsetX)*e,m+=(l.ay-m+this.data.offsetY)*s;let u=c.ascaleX,w=c.ascaleY;r!=0&&u!=0&&(u=(u+(l.ascaleX-u+this.data.offsetScaleX)*r)/u),i!=0&&w!=0&&(w=(w+(l.ascaleY-w+this.data.offsetScaleY)*i)/w);let b=c.ashearY;h!=0&&(b+=(l.ashearY-b+this.data.offsetShearY)*h),c.updateWorldTransformWith(d,m,f,u,w,c.ashearX,b)}}applyRelativeLocal(){let t=this.mixRotate,e=this.mixX,s=this.mixY,r=this.mixScaleX,i=this.mixScaleY,h=this.mixShearY,l=this.target,n=this.bones;for(let a=0,o=n.length;a<o;a++){let c=n[a],f=c.arotation+(l.arotation+this.data.offsetRotation)*t,d=c.ax+(l.ax+this.data.offsetX)*e,m=c.ay+(l.ay+this.data.offsetY)*s,u=c.ascaleX*((l.ascaleX-1+this.data.offsetScaleX)*r+1),w=c.ascaleY*((l.ascaleY-1+this.data.offsetScaleY)*i+1),b=c.ashearY+(l.ashearY+this.data.offsetShearY)*h;c.updateWorldTransformWith(d,m,f,u,w,c.ashearX,b)}}},Ot=class $e{static quadTriangles=[0,1,2,2,3,0];static yDown=!1;data;bones;slots;drawOrder;ikConstraints;transformConstraints;pathConstraints;physicsConstraints;_updateCache=new Array;skin=null;color;scaleX=1;_scaleY=1;get scaleY(){return $e.yDown?-this._scaleY:this._scaleY}set scaleY(e){this._scaleY=e}x=0;y=0;time=0;constructor(e){if(!e)throw new Error("data cannot be null.");this.data=e,this.bones=new Array;for(let s=0;s<e.bones.length;s++){let r=e.bones[s],i;if(!r.parent)i=new Fe(r,this,null);else{let h=this.bones[r.parent.index];i=new Fe(r,this,h),h.children.push(i)}this.bones.push(i)}this.slots=new Array,this.drawOrder=new Array;for(let s=0;s<e.slots.length;s++){let r=e.slots[s],i=this.bones[r.boneData.index],h=new vs(r,i);this.slots.push(h),this.drawOrder.push(h)}this.ikConstraints=new Array;for(let s=0;s<e.ikConstraints.length;s++){let r=e.ikConstraints[s];this.ikConstraints.push(new bs(r,this))}this.transformConstraints=new Array;for(let s=0;s<e.transformConstraints.length;s++){let r=e.transformConstraints[s];this.transformConstraints.push(new As(r,this))}this.pathConstraints=new Array;for(let s=0;s<e.pathConstraints.length;s++){let r=e.pathConstraints[s];this.pathConstraints.push(new ys(r,this))}this.physicsConstraints=new Array;for(let s=0;s<e.physicsConstraints.length;s++){let r=e.physicsConstraints[s];this.physicsConstraints.push(new Qs(r,this))}this.color=new N(1,1,1,1),this.updateCache()}updateCache(){let e=this._updateCache;e.length=0;let s=this.bones;for(let d=0,m=s.length;d<m;d++){let u=s[d];u.sorted=u.data.skinRequired,u.active=!u.sorted}if(this.skin){let d=this.skin.bones;for(let m=0,u=this.skin.bones.length;m<u;m++){let w=this.bones[d[m].index];do w.sorted=!1,w.active=!0,w=w.parent;while(w)}}let r=this.ikConstraints,i=this.transformConstraints,h=this.pathConstraints,l=this.physicsConstraints,n=r.length,a=i.length,o=h.length,c=this.physicsConstraints.length,f=n+a+o+c;t:for(let d=0;d<f;d++){for(let m=0;m<n;m++){let u=r[m];if(u.data.order==d){this.sortIkConstraint(u);continue t}}for(let m=0;m<a;m++){let u=i[m];if(u.data.order==d){this.sortTransformConstraint(u);continue t}}for(let m=0;m<o;m++){let u=h[m];if(u.data.order==d){this.sortPathConstraint(u);continue t}}for(let m=0;m<c;m++){const u=l[m];if(u.data.order==d){this.sortPhysicsConstraint(u);continue t}}}for(let d=0,m=s.length;d<m;d++)this.sortBone(s[d])}sortIkConstraint(e){if(e.active=e.target.isActive()&&(!e.data.skinRequired||this.skin&&P.contains(this.skin.constraints,e.data,!0)),!e.active)return;let s=e.target;this.sortBone(s);let r=e.bones,i=r[0];if(this.sortBone(i),r.length==1)this._updateCache.push(e),this.sortReset(i.children);else{let h=r[r.length-1];this.sortBone(h),this._updateCache.push(e),this.sortReset(i.children),h.sorted=!0}}sortPathConstraint(e){if(e.active=e.target.bone.isActive()&&(!e.data.skinRequired||this.skin&&P.contains(this.skin.constraints,e.data,!0)),!e.active)return;let s=e.target,r=s.data.index,i=s.bone;this.skin&&this.sortPathConstraintAttachment(this.skin,r,i),this.data.defaultSkin&&this.data.defaultSkin!=this.skin&&this.sortPathConstraintAttachment(this.data.defaultSkin,r,i);for(let a=0,o=this.data.skins.length;a<o;a++)this.sortPathConstraintAttachment(this.data.skins[a],r,i);let h=s.getAttachment();h instanceof It&&this.sortPathConstraintAttachmentWith(h,i);let l=e.bones,n=l.length;for(let a=0;a<n;a++)this.sortBone(l[a]);this._updateCache.push(e);for(let a=0;a<n;a++)this.sortReset(l[a].children);for(let a=0;a<n;a++)l[a].sorted=!0}sortTransformConstraint(e){if(e.active=e.target.isActive()&&(!e.data.skinRequired||this.skin&&P.contains(this.skin.constraints,e.data,!0)),!e.active)return;this.sortBone(e.target);let s=e.bones,r=s.length;if(e.data.local)for(let i=0;i<r;i++){let h=s[i];this.sortBone(h.parent),this.sortBone(h)}else for(let i=0;i<r;i++)this.sortBone(s[i]);this._updateCache.push(e);for(let i=0;i<r;i++)this.sortReset(s[i].children);for(let i=0;i<r;i++)s[i].sorted=!0}sortPathConstraintAttachment(e,s,r){let i=e.attachments[s];if(i)for(let h in i)this.sortPathConstraintAttachmentWith(i[h],r)}sortPathConstraintAttachmentWith(e,s){if(!(e instanceof It))return;let r=e.bones;if(!r)this.sortBone(s);else{let i=this.bones;for(let h=0,l=r.length;h<l;){let n=r[h++];for(n+=h;h<n;)this.sortBone(i[r[h++]])}}}sortPhysicsConstraint(e){const s=e.bone;e.active=s.active&&(!e.data.skinRequired||this.skin!=null&&P.contains(this.skin.constraints,e.data,!0)),e.active&&(this.sortBone(s),this._updateCache.push(e),this.sortReset(s.children),s.sorted=!0)}sortBone(e){if(!e||e.sorted)return;let s=e.parent;s&&this.sortBone(s),e.sorted=!0,this._updateCache.push(e)}sortReset(e){for(let s=0,r=e.length;s<r;s++){let i=e[s];i.active&&(i.sorted&&this.sortReset(i.children),i.sorted=!1)}}updateWorldTransform(e){if(e==null)throw new Error("physics is undefined");let s=this.bones;for(let i=0,h=s.length;i<h;i++){let l=s[i];l.ax=l.x,l.ay=l.y,l.arotation=l.rotation,l.ascaleX=l.scaleX,l.ascaleY=l.scaleY,l.ashearX=l.shearX,l.ashearY=l.shearY}let r=this._updateCache;for(let i=0,h=r.length;i<h;i++)r[i].update(e)}updateWorldTransformWith(e,s){if(!s)throw new Error("parent cannot be null.");let r=this.bones;for(let b=1,p=r.length;b<p;b++){let g=r[b];g.ax=g.x,g.ay=g.y,g.arotation=g.rotation,g.ascaleX=g.scaleX,g.ascaleY=g.scaleY,g.ashearX=g.shearX,g.ashearY=g.shearY}let i=this.getRootBone();if(!i)throw new Error("Root bone must not be null.");let h=s.a,l=s.b,n=s.c,a=s.d;i.worldX=h*this.x+l*this.y+s.worldX,i.worldY=n*this.x+a*this.y+s.worldY;const o=(i.rotation+i.shearX)*R.degRad,c=(i.rotation+90+i.shearY)*R.degRad,f=Math.cos(o)*i.scaleX,d=Math.cos(c)*i.scaleY,m=Math.sin(o)*i.scaleX,u=Math.sin(c)*i.scaleY;i.a=(h*f+l*m)*this.scaleX,i.b=(h*d+l*u)*this.scaleX,i.c=(n*f+a*m)*this.scaleY,i.d=(n*d+a*u)*this.scaleY;let w=this._updateCache;for(let b=0,p=w.length;b<p;b++){let g=w[b];g!=i&&g.update(e)}}setToSetupPose(){this.setBonesToSetupPose(),this.setSlotsToSetupPose()}setBonesToSetupPose(){for(const e of this.bones)e.setToSetupPose();for(const e of this.ikConstraints)e.setToSetupPose();for(const e of this.transformConstraints)e.setToSetupPose();for(const e of this.pathConstraints)e.setToSetupPose();for(const e of this.physicsConstraints)e.setToSetupPose()}setSlotsToSetupPose(){let e=this.slots;P.arrayCopy(e,0,this.drawOrder,0,e.length);for(let s=0,r=e.length;s<r;s++)e[s].setToSetupPose()}getRootBone(){return this.bones.length==0?null:this.bones[0]}findBone(e){if(!e)throw new Error("boneName cannot be null.");let s=this.bones;for(let r=0,i=s.length;r<i;r++){let h=s[r];if(h.data.name==e)return h}return null}findSlot(e){if(!e)throw new Error("slotName cannot be null.");let s=this.slots;for(let r=0,i=s.length;r<i;r++){let h=s[r];if(h.data.name==e)return h}return null}setSkinByName(e){let s=this.data.findSkin(e);if(!s)throw new Error("Skin not found: "+e);this.setSkin(s)}setSkin(e){if(e!=this.skin){if(e)if(this.skin)e.attachAll(this,this.skin);else{let s=this.slots;for(let r=0,i=s.length;r<i;r++){let h=s[r],l=h.data.attachmentName;if(l){let n=e.getAttachment(r,l);n&&h.setAttachment(n)}}}this.skin=e,this.updateCache()}}getAttachmentByName(e,s){let r=this.data.findSlot(e);if(!r)throw new Error(`Can't find slot with name ${e}`);return this.getAttachment(r.index,s)}getAttachment(e,s){if(!s)throw new Error("attachmentName cannot be null.");if(this.skin){let r=this.skin.getAttachment(e,s);if(r)return r}return this.data.defaultSkin?this.data.defaultSkin.getAttachment(e,s):null}setAttachment(e,s){if(!e)throw new Error("slotName cannot be null.");let r=this.slots;for(let i=0,h=r.length;i<h;i++){let l=r[i];if(l.data.name==e){let n=null;if(s&&(n=this.getAttachment(i,s),!n))throw new Error("Attachment not found: "+s+", for slot: "+e);l.setAttachment(n);return}}throw new Error("Slot not found: "+e)}findIkConstraint(e){if(!e)throw new Error("constraintName cannot be null.");return this.ikConstraints.find(s=>s.data.name==e)??null}findTransformConstraint(e){if(!e)throw new Error("constraintName cannot be null.");return this.transformConstraints.find(s=>s.data.name==e)??null}findPathConstraint(e){if(!e)throw new Error("constraintName cannot be null.");return this.pathConstraints.find(s=>s.data.name==e)??null}findPhysicsConstraint(e){if(e==null)throw new Error("constraintName cannot be null.");return this.physicsConstraints.find(s=>s.data.name==e)??null}getBoundsRect(e){let s=new Yt,r=new Yt;return this.getBounds(s,r,void 0,e),{x:s.x,y:s.y,width:r.x,height:r.y}}getBounds(e,s,r=new Array(2),i=null){if(!e)throw new Error("offset cannot be null.");if(!s)throw new Error("size cannot be null.");let h=this.drawOrder,l=Number.POSITIVE_INFINITY,n=Number.POSITIVE_INFINITY,a=Number.NEGATIVE_INFINITY,o=Number.NEGATIVE_INFINITY;for(let c=0,f=h.length;c<f;c++){let d=h[c];if(!d.bone.active)continue;let m=0,u=null,w=null,b=d.getAttachment();if(b instanceof Nt)m=8,u=P.setArraySize(r,m,0),b.computeWorldVertices(d,u,0,2),w=$e.quadTriangles;else if(b instanceof St){let p=b;m=p.worldVerticesLength,u=P.setArraySize(r,m,0),p.computeWorldVertices(d,0,m,u,0,2),w=p.triangles}else if(b instanceof Bt&&i!=null){i.clipStart(d,b);continue}if(u&&w){i!=null&&i.isClipping()&&(i.clipTriangles(u,w,w.length),u=i.clippedVertices,m=i.clippedVertices.length);for(let p=0,g=u.length;p<g;p+=2){let x=u[p],y=u[p+1];l=Math.min(l,x),n=Math.min(n,y),a=Math.max(a,x),o=Math.max(o,y)}}i?.clipEndWithSlot(d)}i?.clipEnd(),e.set(l,n),s.set(a-l,o-n)}update(e){this.time+=e}physicsTranslate(e,s){const r=this.physicsConstraints;for(let i=0,h=r.length;i<h;i++)r[i].translate(e,s)}physicsRotate(e,s,r){const i=this.physicsConstraints;for(let h=0,l=i.length;h<l;h++)i[h].rotate(e,s,r)}},Ss=(t=>(t[t.none=0]="none",t[t.reset=1]="reset",t[t.update=2]="update",t[t.pose=3]="pose",t))(Ss||{}),Is=class extends Ct{_bone=null;set bone(t){this._bone=t}get bone(){if(this._bone)return this._bone;throw new Error("BoneData not set.")}x=0;y=0;rotate=0;scaleX=0;shearX=0;limit=0;step=0;inertia=0;strength=0;damping=0;massInverse=0;wind=0;gravity=0;mix=0;inertiaGlobal=!1;strengthGlobal=!1;dampingGlobal=!1;massGlobal=!1;windGlobal=!1;gravityGlobal=!1;mixGlobal=!1;constructor(t){super(t,0,!1)}},De=class{name=null;bones=new Array;slots=new Array;skins=new Array;defaultSkin=null;events=new Array;animations=new Array;ikConstraints=new Array;transformConstraints=new Array;pathConstraints=new Array;physicsConstraints=new Array;x=0;y=0;width=0;height=0;referenceScale=100;version=null;hash=null;fps=0;imagesPath=null;audioPath=null;findBone(t){if(!t)throw new Error("boneName cannot be null.");let e=this.bones;for(let s=0,r=e.length;s<r;s++){let i=e[s];if(i.name==t)return i}return null}findSlot(t){if(!t)throw new Error("slotName cannot be null.");let e=this.slots;for(let s=0,r=e.length;s<r;s++){let i=e[s];if(i.name==t)return i}return null}findSkin(t){if(!t)throw new Error("skinName cannot be null.");let e=this.skins;for(let s=0,r=e.length;s<r;s++){let i=e[s];if(i.name==t)return i}return null}findEvent(t){if(!t)throw new Error("eventDataName cannot be null.");let e=this.events;for(let s=0,r=e.length;s<r;s++){let i=e[s];if(i.name==t)return i}return null}findAnimation(t){if(!t)throw new Error("animationName cannot be null.");let e=this.animations;for(let s=0,r=e.length;s<r;s++){let i=e[s];if(i.name==t)return i}return null}findIkConstraint(t){if(!t)throw new Error("constraintName cannot be null.");const e=this.ikConstraints;for(let s=0,r=e.length;s<r;s++){const i=e[s];if(i.name==t)return i}return null}findTransformConstraint(t){if(!t)throw new Error("constraintName cannot be null.");const e=this.transformConstraints;for(let s=0,r=e.length;s<r;s++){const i=e[s];if(i.name==t)return i}return null}findPathConstraint(t){if(!t)throw new Error("constraintName cannot be null.");const e=this.pathConstraints;for(let s=0,r=e.length;s<r;s++){const i=e[s];if(i.name==t)return i}return null}findPhysicsConstraint(t){if(!t)throw new Error("constraintName cannot be null.");const e=this.physicsConstraints;for(let s=0,r=e.length;s<r;s++){const i=e[s];if(i.name==t)return i}return null}},Oe=class{constructor(t=0,e,s){this.slotIndex=t,this.name=e,this.attachment=s}},qt=class{name;attachments=new Array;bones=Array();constraints=new Array;color=new N(.99607843,.61960787,.30980393,1);constructor(t){if(!t)throw new Error("name cannot be null.");this.name=t}setAttachment(t,e,s){if(!s)throw new Error("attachment cannot be null.");let r=this.attachments;t>=r.length&&(r.length=t+1),r[t]||(r[t]={}),r[t][e]=s}addSkin(t){for(let r=0;r<t.bones.length;r++){let i=t.bones[r],h=!1;for(let l=0;l<this.bones.length;l++)if(this.bones[l]==i){h=!0;break}h||this.bones.push(i)}for(let r=0;r<t.constraints.length;r++){let i=t.constraints[r],h=!1;for(let l=0;l<this.constraints.length;l++)if(this.constraints[l]==i){h=!0;break}h||this.constraints.push(i)}let e=t.getAttachments();for(let r=0;r<e.length;r++){var s=e[r];this.setAttachment(s.slotIndex,s.name,s.attachment)}}copySkin(t){for(let r=0;r<t.bones.length;r++){let i=t.bones[r],h=!1;for(let l=0;l<this.bones.length;l++)if(this.bones[l]==i){h=!0;break}h||this.bones.push(i)}for(let r=0;r<t.constraints.length;r++){let i=t.constraints[r],h=!1;for(let l=0;l<this.constraints.length;l++)if(this.constraints[l]==i){h=!0;break}h||this.constraints.push(i)}let e=t.getAttachments();for(let r=0;r<e.length;r++){var s=e[r];s.attachment&&(s.attachment instanceof St?(s.attachment=s.attachment.newLinkedMesh(),this.setAttachment(s.slotIndex,s.name,s.attachment)):(s.attachment=s.attachment.copy(),this.setAttachment(s.slotIndex,s.name,s.attachment)))}}getAttachment(t,e){let s=this.attachments[t];return s?s[e]:null}removeAttachment(t,e){let s=this.attachments[t];s&&delete s[e]}getAttachments(){let t=new Array;for(var e=0;e<this.attachments.length;e++){let s=this.attachments[e];if(s)for(let r in s){let i=s[r];i&&t.push(new Oe(e,r,i))}}return t}getAttachmentsForSlot(t,e){let s=this.attachments[t];if(s)for(let r in s){let i=s[r];i&&e.push(new Oe(t,r,i))}}clear(){this.attachments.length=0,this.bones.length=0,this.constraints.length=0}attachAll(t,e){let s=0;for(let r=0;r<t.slots.length;r++){let i=t.slots[r],h=i.getAttachment();if(h&&s<e.attachments.length){let l=e.attachments[s];for(let n in l){let a=l[n];if(h==a){let o=this.getAttachment(s,n);o&&i.setAttachment(o);break}}}s++}}},qe=class{index=0;name;boneData;color=new N(1,1,1,1);darkColor=null;attachmentName=null;blendMode=0;visible=!0;constructor(t,e,s){if(t<0)throw new Error("index must be >= 0.");if(!e)throw new Error("name cannot be null.");if(!s)throw new Error("boneData cannot be null.");this.index=t,this.name=e,this.boneData=s}},We=(t=>(t[t.Normal=0]="Normal",t[t.Additive=1]="Additive",t[t.Multiply=2]="Multiply",t[t.Screen=3]="Screen",t))(We||{}),Ue=class extends Ct{bones=new Array;_target=null;set target(t){this._target=t}get target(){if(this._target)return this._target;throw new Error("BoneData not set.")}mixRotate=0;mixX=0;mixY=0;mixScaleX=0;mixScaleY=0;mixShearY=0;offsetRotation=0;offsetX=0;offsetY=0;offsetScaleX=0;offsetScaleY=0;offsetShearY=0;relative=!1;local=!1;constructor(t){super(t,0,!1)}},Cs=class{scale=1;attachmentLoader;linkedMeshes=new Array;constructor(t){this.attachmentLoader=t}readSkeletonData(t){let e=this.scale,s=new De;s.name="";let r=new ks(t),i=r.readInt32(),h=r.readInt32();s.hash=h==0&&i==0?null:h.toString(16)+i.toString(16),s.version=r.readString(),s.x=r.readFloat(),s.y=r.readFloat(),s.width=r.readFloat(),s.height=r.readFloat(),s.referenceScale=r.readFloat()*e;let l=r.readBoolean();l&&(s.fps=r.readFloat(),s.imagesPath=r.readString(),s.audioPath=r.readString());let n=0;n=r.readInt(!0);for(let o=0;o<n;o++){let c=r.readString();if(!c)throw new Error("String in string table must not be null.");r.strings.push(c)}n=r.readInt(!0);for(let o=0;o<n;o++){let c=r.readString();if(!c)throw new Error("Bone name must not be null.");let f=o==0?null:s.bones[r.readInt(!0)],d=new Xe(o,c,f);d.rotation=r.readFloat(),d.x=r.readFloat()*e,d.y=r.readFloat()*e,d.scaleX=r.readFloat(),d.scaleY=r.readFloat(),d.shearX=r.readFloat(),d.shearY=r.readFloat(),d.length=r.readFloat()*e,d.inherit=r.readByte(),d.skinRequired=r.readBoolean(),l&&(N.rgba8888ToColor(d.color,r.readInt32()),d.icon=r.readString()??void 0,d.visible=r.readBoolean()),s.bones.push(d)}n=r.readInt(!0);for(let o=0;o<n;o++){let c=r.readString();if(!c)throw new Error("Slot name must not be null.");let f=s.bones[r.readInt(!0)],d=new qe(o,c,f);N.rgba8888ToColor(d.color,r.readInt32());let m=r.readInt32();m!=-1&&N.rgb888ToColor(d.darkColor=new N,m),d.attachmentName=r.readStringRef(),d.blendMode=r.readInt(!0),l&&(d.visible=r.readBoolean()),s.slots.push(d)}n=r.readInt(!0);for(let o=0,c;o<n;o++){let f=r.readString();if(!f)throw new Error("IK constraint data name must not be null.");let d=new Pe(f);d.order=r.readInt(!0),c=r.readInt(!0);for(let u=0;u<c;u++)d.bones.push(s.bones[r.readInt(!0)]);d.target=s.bones[r.readInt(!0)];let m=r.readByte();d.skinRequired=(m&1)!=0,d.bendDirection=(m&2)!=0?1:-1,d.compress=(m&4)!=0,d.stretch=(m&8)!=0,d.uniform=(m&16)!=0,(m&32)!=0&&(d.mix=(m&64)!=0?r.readFloat():1),(m&128)!=0&&(d.softness=r.readFloat()*e),s.ikConstraints.push(d)}n=r.readInt(!0);for(let o=0,c;o<n;o++){let f=r.readString();if(!f)throw new Error("Transform constraint data name must not be null.");let d=new Ue(f);d.order=r.readInt(!0),c=r.readInt(!0);for(let u=0;u<c;u++)d.bones.push(s.bones[r.readInt(!0)]);d.target=s.bones[r.readInt(!0)];let m=r.readByte();d.skinRequired=(m&1)!=0,d.local=(m&2)!=0,d.relative=(m&4)!=0,(m&8)!=0&&(d.offsetRotation=r.readFloat()),(m&16)!=0&&(d.offsetX=r.readFloat()*e),(m&32)!=0&&(d.offsetY=r.readFloat()*e),(m&64)!=0&&(d.offsetScaleX=r.readFloat()),(m&128)!=0&&(d.offsetScaleY=r.readFloat()),m=r.readByte(),(m&1)!=0&&(d.offsetShearY=r.readFloat()),(m&2)!=0&&(d.mixRotate=r.readFloat()),(m&4)!=0&&(d.mixX=r.readFloat()),(m&8)!=0&&(d.mixY=r.readFloat()),(m&16)!=0&&(d.mixScaleX=r.readFloat()),(m&32)!=0&&(d.mixScaleY=r.readFloat()),(m&64)!=0&&(d.mixShearY=r.readFloat()),s.transformConstraints.push(d)}n=r.readInt(!0);for(let o=0,c;o<n;o++){let f=r.readString();if(!f)throw new Error("Path constraint data name must not be null.");let d=new Be(f);d.order=r.readInt(!0),d.skinRequired=r.readBoolean(),c=r.readInt(!0);for(let u=0;u<c;u++)d.bones.push(s.bones[r.readInt(!0)]);d.target=s.slots[r.readInt(!0)];const m=r.readByte();d.positionMode=m&1,d.spacingMode=m>>1&3,d.rotateMode=m>>3&3,(m&128)!=0&&(d.offsetRotation=r.readFloat()),d.position=r.readFloat(),d.positionMode==0&&(d.position*=e),d.spacing=r.readFloat(),(d.spacingMode==0||d.spacingMode==1)&&(d.spacing*=e),d.mixRotate=r.readFloat(),d.mixX=r.readFloat(),d.mixY=r.readFloat(),s.pathConstraints.push(d)}n=r.readInt(!0);for(let o=0,c;o<n;o++){const f=r.readString();if(!f)throw new Error("Physics constraint data name must not be null.");const d=new Is(f);d.order=r.readInt(!0),d.bone=s.bones[r.readInt(!0)];let m=r.readByte();d.skinRequired=(m&1)!=0,(m&2)!=0&&(d.x=r.readFloat()),(m&4)!=0&&(d.y=r.readFloat()),(m&8)!=0&&(d.rotate=r.readFloat()),(m&16)!=0&&(d.scaleX=r.readFloat()),(m&32)!=0&&(d.shearX=r.readFloat()),d.limit=((m&64)!=0?r.readFloat():5e3)*e,d.step=1/r.readUnsignedByte(),d.inertia=r.readFloat(),d.strength=r.readFloat(),d.damping=r.readFloat(),d.massInverse=(m&128)!=0?r.readFloat():1,d.wind=r.readFloat(),d.gravity=r.readFloat(),m=r.readByte(),(m&1)!=0&&(d.inertiaGlobal=!0),(m&2)!=0&&(d.strengthGlobal=!0),(m&4)!=0&&(d.dampingGlobal=!0),(m&8)!=0&&(d.massGlobal=!0),(m&16)!=0&&(d.windGlobal=!0),(m&32)!=0&&(d.gravityGlobal=!0),(m&64)!=0&&(d.mixGlobal=!0),d.mix=(m&128)!=0?r.readFloat():1,s.physicsConstraints.push(d)}let a=this.readSkin(r,s,!0,l);a&&(s.defaultSkin=a,s.skins.push(a));{let o=s.skins.length;for(P.setArraySize(s.skins,n=o+r.readInt(!0));o<n;o++){let c=this.readSkin(r,s,!1,l);if(!c)throw new Error("readSkin() should not have returned null.");s.skins[o]=c}}n=this.linkedMeshes.length;for(let o=0;o<n;o++){let c=this.linkedMeshes[o];const f=s.skins[c.skinIndex];if(!c.parent)throw new Error("Linked mesh parent must not be null");let d=f.getAttachment(c.slotIndex,c.parent);if(!d)throw new Error(`Parent mesh not found: ${c.parent}`);c.mesh.timelineAttachment=c.inheritTimeline?d:c.mesh,c.mesh.setParentMesh(d),c.mesh.region!=null&&c.mesh.updateRegion()}this.linkedMeshes.length=0,n=r.readInt(!0);for(let o=0;o<n;o++){let c=r.readString();if(!c)throw new Error("Event data name must not be null");let f=new Re(c);f.intValue=r.readInt(!1),f.floatValue=r.readFloat(),f.stringValue=r.readString(),f.audioPath=r.readString(),f.audioPath&&(f.volume=r.readFloat(),f.balance=r.readFloat()),s.events.push(f)}n=r.readInt(!0);for(let o=0;o<n;o++){let c=r.readString();if(!c)throw new Error("Animatio name must not be null.");s.animations.push(this.readAnimation(r,c,s))}return s}readSkin(t,e,s,r){let i=null,h=0;if(s){if(h=t.readInt(!0),h==0)return null;i=new qt("default")}else{let l=t.readString();if(!l)throw new Error("Skin name must not be null.");i=new qt(l),r&&N.rgba8888ToColor(i.color,t.readInt32()),i.bones.length=t.readInt(!0);for(let n=0,a=i.bones.length;n<a;n++)i.bones[n]=e.bones[t.readInt(!0)];for(let n=0,a=t.readInt(!0);n<a;n++)i.constraints.push(e.ikConstraints[t.readInt(!0)]);for(let n=0,a=t.readInt(!0);n<a;n++)i.constraints.push(e.transformConstraints[t.readInt(!0)]);for(let n=0,a=t.readInt(!0);n<a;n++)i.constraints.push(e.pathConstraints[t.readInt(!0)]);for(let n=0,a=t.readInt(!0);n<a;n++)i.constraints.push(e.physicsConstraints[t.readInt(!0)]);h=t.readInt(!0)}for(let l=0;l<h;l++){let n=t.readInt(!0);for(let a=0,o=t.readInt(!0);a<o;a++){let c=t.readStringRef();if(!c)throw new Error("Attachment name must not be null");let f=this.readAttachment(t,e,i,n,c,r);f&&i.setAttachment(n,c,f)}}return i}readAttachment(t,e,s,r,i,h){let l=this.scale,n=t.readByte();const a=(n&8)!=0?t.readStringRef():i;if(!a)throw new Error("Attachment name must not be null");switch(n&7){case 0:{let o=(n&16)!=0?t.readStringRef():null;const c=(n&32)!=0?t.readInt32():4294967295,f=(n&64)!=0?this.readSequence(t):null;let d=(n&128)!=0?t.readFloat():0,m=t.readFloat(),u=t.readFloat(),w=t.readFloat(),b=t.readFloat(),p=t.readFloat(),g=t.readFloat();o||(o=a);let x=this.attachmentLoader.newRegionAttachment(s,a,o,f);return x?(x.path=o,x.x=m*l,x.y=u*l,x.scaleX=w,x.scaleY=b,x.rotation=d,x.width=p*l,x.height=g*l,N.rgba8888ToColor(x.color,c),x.sequence=f,f==null&&x.updateRegion(),x):null}case 1:{let o=this.readVertices(t,(n&16)!=0),c=h?t.readInt32():0,f=this.attachmentLoader.newBoundingBoxAttachment(s,a);return f?(f.worldVerticesLength=o.length,f.vertices=o.vertices,f.bones=o.bones,h&&N.rgba8888ToColor(f.color,c),f):null}case 2:{let o=(n&16)!=0?t.readStringRef():a;const c=(n&32)!=0?t.readInt32():4294967295,f=(n&64)!=0?this.readSequence(t):null,d=t.readInt(!0),m=this.readVertices(t,(n&128)!=0),u=this.readFloatArray(t,m.length,1),w=this.readShortArray(t,(m.length-d-2)*3);let b=[],p=0,g=0;h&&(b=this.readShortArray(t,t.readInt(!0)),p=t.readFloat(),g=t.readFloat()),o||(o=a);let x=this.attachmentLoader.newMeshAttachment(s,a,o,f);return x?(x.path=o,N.rgba8888ToColor(x.color,c),x.bones=m.bones,x.vertices=m.vertices,x.worldVerticesLength=m.length,x.triangles=w,x.regionUVs=u,f==null&&x.updateRegion(),x.hullLength=d<<1,x.sequence=f,h&&(x.edges=b,x.width=p*l,x.height=g*l),x):null}case 3:{const o=(n&16)!=0?t.readStringRef():a;if(o==null)throw new Error("Path of linked mesh must not be null");const c=(n&32)!=0?t.readInt32():4294967295,f=(n&64)!=0?this.readSequence(t):null,d=(n&128)!=0,m=t.readInt(!0),u=t.readStringRef();let w=0,b=0;h&&(w=t.readFloat(),b=t.readFloat());let p=this.attachmentLoader.newMeshAttachment(s,a,o,f);return p?(p.path=o,N.rgba8888ToColor(p.color,c),p.sequence=f,h&&(p.width=w*l,p.height=b*l),this.linkedMeshes.push(new Zs(p,m,r,u,d)),p):null}case 4:{const o=(n&16)!=0,c=(n&32)!=0,f=this.readVertices(t,(n&64)!=0),d=P.newArray(f.length/6,0);for(let w=0,b=d.length;w<b;w++)d[w]=t.readFloat()*l;const m=h?t.readInt32():0,u=this.attachmentLoader.newPathAttachment(s,a);return u?(u.closed=o,u.constantSpeed=c,u.worldVerticesLength=f.length,u.vertices=f.vertices,u.bones=f.bones,u.lengths=d,h&&N.rgba8888ToColor(u.color,m),u):null}case 5:{const o=t.readFloat(),c=t.readFloat(),f=t.readFloat(),d=h?t.readInt32():0,m=this.attachmentLoader.newPointAttachment(s,a);return m?(m.x=c*l,m.y=f*l,m.rotation=o,h&&N.rgba8888ToColor(m.color,d),m):null}case 6:{const o=t.readInt(!0),c=this.readVertices(t,(n&16)!=0);let f=h?t.readInt32():0,d=this.attachmentLoader.newClippingAttachment(s,a);return d?(d.endSlot=e.slots[o],d.worldVerticesLength=c.length,d.vertices=c.vertices,d.bones=c.bones,h&&N.rgba8888ToColor(d.color,f),d):null}}return null}readSequence(t){let e=new es(t.readInt(!0));return e.start=t.readInt(!0),e.digits=t.readInt(!0),e.setupIndex=t.readInt(!0),e}readVertices(t,e){const s=this.scale,r=t.readInt(!0),i=new ti;if(i.length=r<<1,!e)return i.vertices=this.readFloatArray(t,i.length,s),i;let h=new Array,l=new Array;for(let n=0;n<r;n++){let a=t.readInt(!0);l.push(a);for(let o=0;o<a;o++)l.push(t.readInt(!0)),h.push(t.readFloat()*s),h.push(t.readFloat()*s),h.push(t.readFloat())}return i.vertices=P.toFloatArray(h),i.bones=l,i}readFloatArray(t,e,s){let r=new Array(e);if(s==1)for(let i=0;i<e;i++)r[i]=t.readFloat();else for(let i=0;i<e;i++)r[i]=t.readFloat()*s;return r}readShortArray(t,e){let s=new Array(e);for(let r=0;r<e;r++)s[r]=t.readInt(!0);return s}readAnimation(t,e,s){t.readInt(!0);let r=new Array,i=this.scale;for(let a=0,o=t.readInt(!0);a<o;a++){let c=t.readInt(!0);for(let f=0,d=t.readInt(!0);f<d;f++){let m=t.readByte(),u=t.readInt(!0),w=u-1;switch(m){case fi:{let b=new ut(u,c);for(let p=0;p<u;p++)b.setFrame(p,t.readFloat(),t.readStringRef());r.push(b);break}case ui:{let b=t.readInt(!0),p=new re(u,b,c),g=t.readFloat(),x=t.readUnsignedByte()/255,y=t.readUnsignedByte()/255,v=t.readUnsignedByte()/255,A=t.readUnsignedByte()/255;for(let S=0,C=0;p.setFrame(S,g,x,y,v,A),S!=w;S++){let k=t.readFloat(),Y=t.readUnsignedByte()/255,M=t.readUnsignedByte()/255,F=t.readUnsignedByte()/255,E=t.readUnsignedByte()/255;switch(t.readByte()){case ot:p.setStepped(S);break;case ht:U(t,p,C++,S,0,g,k,x,Y,1),U(t,p,C++,S,1,g,k,y,M,1),U(t,p,C++,S,2,g,k,v,F,1),U(t,p,C++,S,3,g,k,A,E,1)}g=k,x=Y,y=M,v=F,A=E}r.push(p);break}case mi:{let b=t.readInt(!0),p=new ne(u,b,c),g=t.readFloat(),x=t.readUnsignedByte()/255,y=t.readUnsignedByte()/255,v=t.readUnsignedByte()/255;for(let A=0,S=0;p.setFrame(A,g,x,y,v),A!=w;A++){let C=t.readFloat(),k=t.readUnsignedByte()/255,Y=t.readUnsignedByte()/255,M=t.readUnsignedByte()/255;switch(t.readByte()){case ot:p.setStepped(A);break;case ht:U(t,p,S++,A,0,g,C,x,k,1),U(t,p,S++,A,1,g,C,y,Y,1),U(t,p,S++,A,2,g,C,v,M,1)}g=C,x=k,y=Y,v=M}r.push(p);break}case gi:{let b=t.readInt(!0),p=new le(u,b,c),g=t.readFloat(),x=t.readUnsignedByte()/255,y=t.readUnsignedByte()/255,v=t.readUnsignedByte()/255,A=t.readUnsignedByte()/255,S=t.readUnsignedByte()/255,C=t.readUnsignedByte()/255,k=t.readUnsignedByte()/255;for(let Y=0,M=0;p.setFrame(Y,g,x,y,v,A,S,C,k),Y!=w;Y++){let F=t.readFloat(),E=t.readUnsignedByte()/255,T=t.readUnsignedByte()/255,X=t.readUnsignedByte()/255,V=t.readUnsignedByte()/255,D=t.readUnsignedByte()/255,L=t.readUnsignedByte()/255,O=t.readUnsignedByte()/255;switch(t.readByte()){case ot:p.setStepped(Y);break;case ht:U(t,p,M++,Y,0,g,F,x,E,1),U(t,p,M++,Y,1,g,F,y,T,1),U(t,p,M++,Y,2,g,F,v,X,1),U(t,p,M++,Y,3,g,F,A,V,1),U(t,p,M++,Y,4,g,F,S,D,1),U(t,p,M++,Y,5,g,F,C,L,1),U(t,p,M++,Y,6,g,F,k,O,1)}g=F,x=E,y=T,v=X,A=V,S=D,C=L,k=O}r.push(p);break}case xi:{let b=t.readInt(!0),p=new oe(u,b,c),g=t.readFloat(),x=t.readUnsignedByte()/255,y=t.readUnsignedByte()/255,v=t.readUnsignedByte()/255,A=t.readUnsignedByte()/255,S=t.readUnsignedByte()/255,C=t.readUnsignedByte()/255;for(let k=0,Y=0;p.setFrame(k,g,x,y,v,A,S,C),k!=w;k++){let M=t.readFloat(),F=t.readUnsignedByte()/255,E=t.readUnsignedByte()/255,T=t.readUnsignedByte()/255,X=t.readUnsignedByte()/255,V=t.readUnsignedByte()/255,D=t.readUnsignedByte()/255;switch(t.readByte()){case ot:p.setStepped(k);break;case ht:U(t,p,Y++,k,0,g,M,x,F,1),U(t,p,Y++,k,1,g,M,y,E,1),U(t,p,Y++,k,2,g,M,v,T,1),U(t,p,Y++,k,3,g,M,A,X,1),U(t,p,Y++,k,4,g,M,S,V,1),U(t,p,Y++,k,5,g,M,C,D,1)}g=M,x=F,y=E,v=T,A=X,S=V,C=D}r.push(p);break}case wi:{let b=new ae(u,t.readInt(!0),c),p=t.readFloat(),g=t.readUnsignedByte()/255;for(let x=0,y=0;b.setFrame(x,p,g),x!=w;x++){let v=t.readFloat(),A=t.readUnsignedByte()/255;switch(t.readByte()){case ot:b.setStepped(x);break;case ht:U(t,b,y++,x,0,p,v,g,A,1)}p=v,g=A}r.push(b)}}}}for(let a=0,o=t.readInt(!0);a<o;a++){let c=t.readInt(!0);for(let f=0,d=t.readInt(!0);f<d;f++){let m=t.readByte(),u=t.readInt(!0);if(m==di){let b=new ie(u,c);for(let p=0;p<u;p++)b.setFrame(p,t.readFloat(),t.readByte());r.push(b);continue}let w=t.readInt(!0);switch(m){case ei:r.push(Z(t,new At(u,w,c),1));break;case si:r.push(ze(t,new Ht(u,w,c),i));break;case ii:r.push(Z(t,new jt(u,w,c),i));break;case ri:r.push(Z(t,new Jt(u,w,c),i));break;case ni:r.push(ze(t,new Kt(u,w,c),1));break;case ai:r.push(Z(t,new Qt(u,w,c),1));break;case li:r.push(Z(t,new Zt(u,w,c),1));break;case oi:r.push(ze(t,new te(u,w,c),1));break;case hi:r.push(Z(t,new ee(u,w,c),1));break;case ci:r.push(Z(t,new se(u,w,c),1))}}}for(let a=0,o=t.readInt(!0);a<o;a++){let c=t.readInt(!0),f=t.readInt(!0),d=f-1,m=new ce(f,t.readInt(!0),c),u=t.readByte(),w=t.readFloat(),b=(u&1)!=0?(u&2)!=0?t.readFloat():1:0,p=(u&4)!=0?t.readFloat()*i:0;for(let g=0,x=0;m.setFrame(g,w,b,p,(u&8)!=0?1:-1,(u&16)!=0,(u&32)!=0),g!=d;g++){u=t.readByte();const y=t.readFloat(),v=(u&1)!=0?(u&2)!=0?t.readFloat():1:0,A=(u&4)!=0?t.readFloat()*i:0;(u&64)!=0?m.setStepped(g):(u&128)!=0&&(U(t,m,x++,g,0,w,y,b,v,1),U(t,m,x++,g,1,w,y,p,A,i)),w=y,b=v,p=A}r.push(m)}for(let a=0,o=t.readInt(!0);a<o;a++){let c=t.readInt(!0),f=t.readInt(!0),d=f-1,m=new de(f,t.readInt(!0),c),u=t.readFloat(),w=t.readFloat(),b=t.readFloat(),p=t.readFloat(),g=t.readFloat(),x=t.readFloat(),y=t.readFloat();for(let v=0,A=0;m.setFrame(v,u,w,b,p,g,x,y),v!=d;v++){let S=t.readFloat(),C=t.readFloat(),k=t.readFloat(),Y=t.readFloat(),M=t.readFloat(),F=t.readFloat(),E=t.readFloat();switch(t.readByte()){case ot:m.setStepped(v);break;case ht:U(t,m,A++,v,0,u,S,w,C,1),U(t,m,A++,v,1,u,S,b,k,1),U(t,m,A++,v,2,u,S,p,Y,1),U(t,m,A++,v,3,u,S,g,M,1),U(t,m,A++,v,4,u,S,x,F,1),U(t,m,A++,v,5,u,S,y,E,1)}u=S,w=C,b=k,p=Y,g=M,x=F,y=E}r.push(m)}for(let a=0,o=t.readInt(!0);a<o;a++){let c=t.readInt(!0),f=s.pathConstraints[c];for(let d=0,m=t.readInt(!0);d<m;d++){const u=t.readByte(),w=t.readInt(!0),b=t.readInt(!0);switch(u){case yi:r.push(Z(t,new fe(w,b,c),f.positionMode==0?i:1));break;case vi:r.push(Z(t,new ue(w,b,c),f.spacingMode==0||f.spacingMode==1?i:1));break;case Ai:let p=new me(w,b,c),g=t.readFloat(),x=t.readFloat(),y=t.readFloat(),v=t.readFloat();for(let A=0,S=0,C=p.getFrameCount()-1;p.setFrame(A,g,x,y,v),A!=C;A++){let k=t.readFloat(),Y=t.readFloat(),M=t.readFloat(),F=t.readFloat();switch(t.readByte()){case ot:p.setStepped(A);break;case ht:U(t,p,S++,A,0,g,k,x,Y,1),U(t,p,S++,A,1,g,k,y,M,1),U(t,p,S++,A,2,g,k,v,F,1)}g=k,x=Y,y=M,v=F}r.push(p)}}}for(let a=0,o=t.readInt(!0);a<o;a++){const c=t.readInt(!0)-1;for(let f=0,d=t.readInt(!0);f<d;f++){const m=t.readByte(),u=t.readInt(!0);if(m==Xi){const b=new Ae(u,c);for(let p=0;p<u;p++)b.setFrame(p,t.readFloat());r.push(b);continue}const w=t.readInt(!0);switch(m){case Si:r.push(Z(t,new ge(u,w,c),1));break;case Ii:r.push(Z(t,new xe(u,w,c),1));break;case Ci:r.push(Z(t,new we(u,w,c),1));break;case ki:r.push(Z(t,new pe(u,w,c),1));break;case Ti:r.push(Z(t,new be(u,w,c),1));break;case Mi:r.push(Z(t,new ye(u,w,c),1));break;case Yi:r.push(Z(t,new ve(u,w,c),1))}}}for(let a=0,o=t.readInt(!0);a<o;a++){let c=s.skins[t.readInt(!0)];for(let f=0,d=t.readInt(!0);f<d;f++){let m=t.readInt(!0);for(let u=0,w=t.readInt(!0);u<w;u++){let b=t.readStringRef();if(!b)throw new Error("attachmentName must not be null.");let p=c.getAttachment(m,b),g=t.readByte(),x=t.readInt(!0),y=x-1;switch(g){case pi:{let v=p,A=v.bones,S=v.vertices,C=A?S.length/3*2:S.length,k=t.readInt(!0),Y=new he(x,k,m,v),M=t.readFloat();for(let F=0,E=0;;F++){let T,X=t.readInt(!0);if(X==0)T=A?P.newFloatArray(C):S;else{T=P.newFloatArray(C);let D=t.readInt(!0);if(X+=D,i==1)for(let L=D;L<X;L++)T[L]=t.readFloat();else for(let L=D;L<X;L++)T[L]=t.readFloat()*i;if(!A)for(let L=0,O=T.length;L<O;L++)T[L]+=S[L]}if(Y.setFrame(F,M,T),F==y)break;let V=t.readFloat();switch(t.readByte()){case ot:Y.setStepped(F);break;case ht:U(t,Y,E++,F,0,M,V,0,1,1)}M=V}r.push(Y);break}case bi:{let v=new Se(x,m,p);for(let A=0;A<x;A++){let S=t.readFloat(),C=t.readInt32();v.setFrame(A,S,is[C&15],C>>4,t.readFloat())}r.push(v);break}}}}}let h=t.readInt(!0);if(h>0){let a=new wt(h),o=s.slots.length;for(let c=0;c<h;c++){let f=t.readFloat(),d=t.readInt(!0),m=P.newArray(o,0);for(let p=o-1;p>=0;p--)m[p]=-1;let u=P.newArray(o-d,0),w=0,b=0;for(let p=0;p<d;p++){let g=t.readInt(!0);for(;w!=g;)u[b++]=w++;m[w+t.readInt(!0)]=w++}for(;w<o;)u[b++]=w++;for(let p=o-1;p>=0;p--)m[p]==-1&&(m[p]=u[--b]);a.setFrame(c,f,m)}r.push(a)}let l=t.readInt(!0);if(l>0){let a=new Et(l);for(let o=0;o<l;o++){let c=t.readFloat(),f=s.events[t.readInt(!0)],d=new Ee(c,f);d.intValue=t.readInt(!1),d.floatValue=t.readFloat(),d.stringValue=t.readString(),d.stringValue==null&&(d.stringValue=f.stringValue),d.data.audioPath&&(d.volume=t.readFloat(),d.balance=t.readFloat()),a.setFrame(o,d)}r.push(a)}let n=0;for(let a=0,o=r.length;a<o;a++)n=Math.max(n,r[a].getDuration());return new Xt(e,r,n)}},ks=class{constructor(t,e=new Array,s=0,r=new DataView(t instanceof ArrayBuffer?t:t.buffer)){this.strings=e,this.index=s,this.buffer=r}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(),s=e&127;return(e&128)!=0&&(e=this.readByte(),s|=(e&127)<<7,(e&128)!=0&&(e=this.readByte(),s|=(e&127)<<14,(e&128)!=0&&(e=this.readByte(),s|=(e&127)<<21,(e&128)!=0&&(e=this.readByte(),s|=(e&127)<<28)))),t?s:s>>>1^-(s&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="",s=0;for(let r=0;r<t;){let i=this.readUnsignedByte();switch(i>>4){case 12:case 13:e+=String.fromCharCode((i&31)<<6|this.readByte()&63),r+=2;break;case 14:e+=String.fromCharCode((i&15)<<12|(this.readByte()&63)<<6|this.readByte()&63),r+=3;break;default:e+=String.fromCharCode(i),r++}}return e}readFloat(){let t=this.buffer.getFloat32(this.index);return this.index+=4,t}readBoolean(){return this.readByte()!=0}},Zs=class{parent;skinIndex;slotIndex;mesh;inheritTimeline;constructor(t,e,s,r,i){this.mesh=t,this.skinIndex=e,this.slotIndex=s,this.parent=r,this.inheritTimeline=i}},ti=class{constructor(t=null,e=null,s=0){this.bones=t,this.vertices=e,this.length=s}};function Z(t,e,s){let r=t.readFloat(),i=t.readFloat()*s;for(let h=0,l=0,n=e.getFrameCount()-1;e.setFrame(h,r,i),h!=n;h++){let a=t.readFloat(),o=t.readFloat()*s;switch(t.readByte()){case ot:e.setStepped(h);break;case ht:U(t,e,l++,h,0,r,a,i,o,s)}r=a,i=o}return e}function ze(t,e,s){let r=t.readFloat(),i=t.readFloat()*s,h=t.readFloat()*s;for(let l=0,n=0,a=e.getFrameCount()-1;e.setFrame(l,r,i,h),l!=a;l++){let o=t.readFloat(),c=t.readFloat()*s,f=t.readFloat()*s;switch(t.readByte()){case ot:e.setStepped(l);break;case ht:U(t,e,n++,l,0,r,o,i,c,s),U(t,e,n++,l,1,r,o,h,f,s)}r=o,i=c,h=f}return e}function U(t,e,s,r,i,h,l,n,a,o){e.setBezier(s,r,i,h,n,t.readFloat(),t.readFloat()*o,t.readFloat(),t.readFloat()*o,l,a)}var ei=0,si=1,ii=2,ri=3,ni=4,ai=5,li=6,oi=7,hi=8,ci=9,di=10,fi=0,ui=1,mi=2,gi=3,xi=4,wi=5,pi=0,bi=1,yi=0,vi=1,Ai=2,Si=0,Ii=1,Ci=2,ki=4,Ti=5,Mi=6,Yi=7,Xi=8,ot=1,ht=2,Fi=class{minX=0;minY=0;maxX=0;maxY=0;boundingBoxes=new Array;polygons=new Array;polygonPool=new vt(()=>P.newFloatArray(16));update(t,e){if(!t)throw new Error("skeleton cannot be null.");let s=this.boundingBoxes,r=this.polygons,i=this.polygonPool,h=t.slots,l=h.length;s.length=0,i.freeAll(r),r.length=0;for(let n=0;n<l;n++){let a=h[n];if(!a.bone.active)continue;let o=a.getAttachment();if(o instanceof Te){let c=o;s.push(c);let f=i.obtain();f.length!=c.worldVerticesLength&&(f=P.newFloatArray(c.worldVerticesLength)),r.push(f),c.computeWorldVertices(a,0,c.worldVerticesLength,f,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,s=Number.NEGATIVE_INFINITY,r=Number.NEGATIVE_INFINITY,i=this.polygons;for(let h=0,l=i.length;h<l;h++){let n=i[h],a=n;for(let o=0,c=n.length;o<c;o+=2){let f=a[o],d=a[o+1];t=Math.min(t,f),e=Math.min(e,d),s=Math.max(s,f),r=Math.max(r,d)}}this.minX=t,this.minY=e,this.maxX=s,this.maxY=r}aabbContainsPoint(t,e){return t>=this.minX&&t<=this.maxX&&e>=this.minY&&e<=this.maxY}aabbIntersectsSegment(t,e,s,r){let i=this.minX,h=this.minY,l=this.maxX,n=this.maxY;if(t<=i&&s<=i||e<=h&&r<=h||t>=l&&s>=l||e>=n&&r>=n)return!1;let a=(r-e)/(s-t),o=a*(i-t)+e;if(o>h&&o<n||(o=a*(l-t)+e,o>h&&o<n))return!0;let c=(h-e)/a+t;return c>i&&c<l||(c=(n-e)/a+t,c>i&&c<l)}aabbIntersectsSkeleton(t){return this.minX<t.maxX&&this.maxX>t.minX&&this.minY<t.maxY&&this.maxY>t.minY}containsPoint(t,e){let s=this.polygons;for(let r=0,i=s.length;r<i;r++)if(this.containsPointPolygon(s[r],t,e))return this.boundingBoxes[r];return null}containsPointPolygon(t,e,s){let r=t,i=t.length,h=i-2,l=!1;for(let n=0;n<i;n+=2){let a=r[n+1],o=r[h+1];if(a<s&&o>=s||o<s&&a>=s){let c=r[n];c+(s-a)/(o-a)*(r[h]-c)<e&&(l=!l)}h=n}return l}intersectsSegment(t,e,s,r){let i=this.polygons;for(let h=0,l=i.length;h<l;h++)if(this.intersectsSegmentPolygon(i[h],t,e,s,r))return this.boundingBoxes[h];return null}intersectsSegmentPolygon(t,e,s,r,i){let h=t,l=t.length,n=e-r,a=s-i,o=e*i-s*r,c=h[l-2],f=h[l-1];for(let d=0;d<l;d+=2){let m=h[d],u=h[d+1],w=c*u-f*m,b=c-m,p=f-u,g=n*p-a*b,x=(o*b-n*w)/g;if((x>=c&&x<=m||x>=m&&x<=c)&&(x>=e&&x<=r||x>=r&&x<=e)){let y=(o*p-a*w)/g;if((y>=f&&y<=u||y>=u&&y<=f)&&(y>=s&&y<=i||y>=i&&y<=s))return!0}c=m,f=u}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}},Ts=class et{convexPolygons=new Array;convexPolygonsIndices=new Array;indicesArray=new Array;isConcaveArray=new Array;triangles=new Array;polygonPool=new vt(()=>new Array);polygonIndicesPool=new vt(()=>new Array);triangulate(e){let s=e,r=e.length>>1,i=this.indicesArray;i.length=0;for(let n=0;n<r;n++)i[n]=n;let h=this.isConcaveArray;h.length=0;for(let n=0,a=r;n<a;++n)h[n]=et.isConcave(n,r,s,i);let l=this.triangles;for(l.length=0;r>3;){let n=r-1,a=0,o=1;for(;;){t:if(!h[a]){let d=i[n]<<1,m=i[a]<<1,u=i[o]<<1,w=s[d],b=s[d+1],p=s[m],g=s[m+1],x=s[u],y=s[u+1];for(let v=(o+1)%r;v!=n;v=(v+1)%r){if(!h[v])continue;let A=i[v]<<1,S=s[A],C=s[A+1];if(et.positiveArea(x,y,w,b,S,C)&&et.positiveArea(w,b,p,g,S,C)&&et.positiveArea(p,g,x,y,S,C))break t}break}if(o==0){do{if(!h[a])break;a--}while(a>0);break}n=a,a=o,o=(o+1)%r}l.push(i[(r+a-1)%r]),l.push(i[a]),l.push(i[(a+1)%r]),i.splice(a,1),h.splice(a,1),r--;let c=(r+a-1)%r,f=a==r?0:a;h[c]=et.isConcave(c,r,s,i),h[f]=et.isConcave(f,r,s,i)}return r==3&&(l.push(i[2]),l.push(i[0]),l.push(i[1])),l}decompose(e,s){let r=e,i=this.convexPolygons;this.polygonPool.freeAll(i),i.length=0;let h=this.convexPolygonsIndices;this.polygonIndicesPool.freeAll(h),h.length=0;let l=this.polygonIndicesPool.obtain();l.length=0;let n=this.polygonPool.obtain();n.length=0;let a=-1,o=0;for(let c=0,f=s.length;c<f;c+=3){let d=s[c]<<1,m=s[c+1]<<1,u=s[c+2]<<1,w=r[d],b=r[d+1],p=r[m],g=r[m+1],x=r[u],y=r[u+1],v=!1;if(a==d){let A=n.length-4,S=et.winding(n[A],n[A+1],n[A+2],n[A+3],x,y),C=et.winding(x,y,n[0],n[1],n[2],n[3]);S==o&&C==o&&(n.push(x),n.push(y),l.push(u),v=!0)}v||(n.length>0?(i.push(n),h.push(l)):(this.polygonPool.free(n),this.polygonIndicesPool.free(l)),n=this.polygonPool.obtain(),n.length=0,n.push(w),n.push(b),n.push(p),n.push(g),n.push(x),n.push(y),l=this.polygonIndicesPool.obtain(),l.length=0,l.push(d),l.push(m),l.push(u),o=et.winding(w,b,p,g,x,y),a=d)}n.length>0&&(i.push(n),h.push(l));for(let c=0,f=i.length;c<f;c++){if(l=h[c],l.length==0)continue;let d=l[0],m=l[l.length-1];n=i[c];let u=n.length-4,w=n[u],b=n[u+1],p=n[u+2],g=n[u+3],x=n[0],y=n[1],v=n[2],A=n[3],S=et.winding(w,b,p,g,x,y);for(let C=0;C<f;C++){if(C==c)continue;let k=h[C];if(k.length!=3)continue;let Y=k[0],M=k[1],F=k[2],E=i[C],T=E[E.length-2],X=E[E.length-1];if(Y!=d||M!=m)continue;let V=et.winding(w,b,p,g,T,X),D=et.winding(T,X,x,y,v,A);V==S&&D==S&&(E.length=0,k.length=0,n.push(T),n.push(X),l.push(F),w=p,b=g,p=T,g=X,C=0)}}for(let c=i.length-1;c>=0;c--)n=i[c],n.length==0&&(i.splice(c,1),this.polygonPool.free(n),l=h[c],h.splice(c,1),this.polygonIndicesPool.free(l));return i}static isConcave(e,s,r,i){let h=i[(s+e-1)%s]<<1,l=i[e]<<1,n=i[(e+1)%s]<<1;return!this.positiveArea(r[h],r[h+1],r[l],r[l+1],r[n],r[n+1])}static positiveArea(e,s,r,i,h,l){return e*(l-i)+r*(s-l)+h*(i-s)>=0}static winding(e,s,r,i,h,l){let n=r-e,a=i-s;return h*a-l*n+n*s-e*a>=0?1:-1}},Ms=class He{triangulator=new Ts;clippingPolygon=new Array;clipOutput=new Array;clippedVertices=new Array;clippedUVs=new Array;clippedTriangles=new Array;scratch=new Array;clipAttachment=null;clippingPolygons=null;clipStart(e,s){if(this.clipAttachment)return 0;this.clipAttachment=s;let r=s.worldVerticesLength,i=P.setArraySize(this.clippingPolygon,r);s.computeWorldVertices(e,0,r,i,0,2);let h=this.clippingPolygon;He.makeClockwise(h);let l=this.clippingPolygons=this.triangulator.decompose(h,this.triangulator.triangulate(h));for(let n=0,a=l.length;n<a;n++){let o=l[n];He.makeClockwise(o),o.push(o[0]),o.push(o[1])}return l.length}clipEndWithSlot(e){this.clipAttachment&&this.clipAttachment.endSlot==e.data&&this.clipEnd()}clipEnd(){this.clipAttachment&&(this.clipAttachment=null,this.clippingPolygons=null,this.clippedVertices.length=0,this.clippedTriangles.length=0,this.clippingPolygon.length=0)}isClipping(){return this.clipAttachment!=null}clipTriangles(e,s,r,i,h,l,n,a){let o,c,f,d,m,u;typeof s=="number"?(o=r,c=i,f=h,d=l,m=n,u=a):(o=s,c=r,f=i,d=h,m=l,u=n),f&&d&&m&&typeof u=="boolean"?this.clipTrianglesRender(e,o,c,f,d,m,u):this.clipTrianglesNoRender(e,o,c)}clipTrianglesNoRender(e,s,r){let i=this.clipOutput,h=this.clippedVertices,l=this.clippedTriangles,n=this.clippingPolygons,a=n.length,o=0;h.length=0,l.length=0;for(let c=0;c<r;c+=3){let f=s[c]<<1,d=e[f],m=e[f+1];f=s[c+1]<<1;let u=e[f],w=e[f+1];f=s[c+2]<<1;let b=e[f],p=e[f+1];for(let g=0;g<a;g++){let x=h.length;if(this.clip(d,m,u,w,b,p,n[g],i)){let y=i.length;if(y==0)continue;let v=y>>1,A=this.clipOutput,S=P.setArraySize(h,x+v*2);for(let k=0;k<y;k+=2,x+=2){let Y=A[k],M=A[k+1];S[x]=Y,S[x+1]=M}x=l.length;let C=P.setArraySize(l,x+3*(v-2));v--;for(let k=1;k<v;k++,x+=3)C[x]=o,C[x+1]=o+k,C[x+2]=o+k+1;o+=v+1}else{let y=P.setArraySize(h,x+6);y[x]=d,y[x+1]=m,y[x+2]=u,y[x+3]=w,y[x+4]=b,y[x+5]=p,x=l.length;let v=P.setArraySize(l,x+3);v[x]=o,v[x+1]=o+1,v[x+2]=o+2,o+=3;break}}}}clipTrianglesRender(e,s,r,i,h,l,n){let a=this.clipOutput,o=this.clippedVertices,c=this.clippedTriangles,f=this.clippingPolygons,d=f.length,m=n?12:8,u=0;o.length=0,c.length=0;for(let w=0;w<r;w+=3){let b=s[w]<<1,p=e[b],g=e[b+1],x=i[b],y=i[b+1];b=s[w+1]<<1;let v=e[b],A=e[b+1],S=i[b],C=i[b+1];b=s[w+2]<<1;let k=e[b],Y=e[b+1],M=i[b],F=i[b+1];for(let E=0;E<d;E++){let T=o.length;if(this.clip(p,g,v,A,k,Y,f[E],a)){let X=a.length;if(X==0)continue;let V=A-Y,D=k-v,L=p-k,O=Y-g,$=1/(V*L+D*(g-Y)),z=X>>1,j=this.clipOutput,B=P.setArraySize(o,T+z*m);for(let G=0;G<X;G+=2,T+=m){let tt=j[G],J=j[G+1];B[T]=tt,B[T+1]=J,B[T+2]=h.r,B[T+3]=h.g,B[T+4]=h.b,B[T+5]=h.a;let K=tt-k,Q=J-Y,it=(V*K+D*Q)*$,gt=(O*K+L*Q)*$,bt=1-it-gt;B[T+6]=x*it+S*gt+M*bt,B[T+7]=y*it+C*gt+F*bt,n&&(B[T+8]=l.r,B[T+9]=l.g,B[T+10]=l.b,B[T+11]=l.a)}T=c.length;let W=P.setArraySize(c,T+3*(z-2));z--;for(let G=1;G<z;G++,T+=3)W[T]=u,W[T+1]=u+G,W[T+2]=u+G+1;u+=z+1}else{let X=P.setArraySize(o,T+3*m);X[T]=p,X[T+1]=g,X[T+2]=h.r,X[T+3]=h.g,X[T+4]=h.b,X[T+5]=h.a,n?(X[T+6]=x,X[T+7]=y,X[T+8]=l.r,X[T+9]=l.g,X[T+10]=l.b,X[T+11]=l.a,X[T+12]=v,X[T+13]=A,X[T+14]=h.r,X[T+15]=h.g,X[T+16]=h.b,X[T+17]=h.a,X[T+18]=S,X[T+19]=C,X[T+20]=l.r,X[T+21]=l.g,X[T+22]=l.b,X[T+23]=l.a,X[T+24]=k,X[T+25]=Y,X[T+26]=h.r,X[T+27]=h.g,X[T+28]=h.b,X[T+29]=h.a,X[T+30]=M,X[T+31]=F,X[T+32]=l.r,X[T+33]=l.g,X[T+34]=l.b,X[T+35]=l.a):(X[T+6]=x,X[T+7]=y,X[T+8]=v,X[T+9]=A,X[T+10]=h.r,X[T+11]=h.g,X[T+12]=h.b,X[T+13]=h.a,X[T+14]=S,X[T+15]=C,X[T+16]=k,X[T+17]=Y,X[T+18]=h.r,X[T+19]=h.g,X[T+20]=h.b,X[T+21]=h.a,X[T+22]=M,X[T+23]=F),T=c.length;let V=P.setArraySize(c,T+3);V[T]=u,V[T+1]=u+1,V[T+2]=u+2,u+=3;break}}}}clipTrianglesUnpacked(e,s,r,i){let h=this.clipOutput,l=this.clippedVertices,n=this.clippedUVs,a=this.clippedTriangles,o=this.clippingPolygons,c=o.length,f=0;l.length=0,n.length=0,a.length=0;for(let d=0;d<r;d+=3){let m=s[d]<<1,u=e[m],w=e[m+1],b=i[m],p=i[m+1];m=s[d+1]<<1;let g=e[m],x=e[m+1],y=i[m],v=i[m+1];m=s[d+2]<<1;let A=e[m],S=e[m+1],C=i[m],k=i[m+1];for(let Y=0;Y<c;Y++){let M=l.length;if(this.clip(u,w,g,x,A,S,o[Y],h)){let F=h.length;if(F==0)continue;let E=x-S,T=A-g,X=u-A,V=S-w,D=1/(E*X+T*(w-S)),L=F>>1,O=this.clipOutput,$=P.setArraySize(l,M+L*2),z=P.setArraySize(n,M+L*2);for(let B=0;B<F;B+=2,M+=2){let W=O[B],G=O[B+1];$[M]=W,$[M+1]=G;let tt=W-A,J=G-S,K=(E*tt+T*J)*D,Q=(V*tt+X*J)*D,it=1-K-Q;z[M]=b*K+y*Q+C*it,z[M+1]=p*K+v*Q+k*it}M=a.length;let j=P.setArraySize(a,M+3*(L-2));L--;for(let B=1;B<L;B++,M+=3)j[M]=f,j[M+1]=f+B,j[M+2]=f+B+1;f+=L+1}else{let F=P.setArraySize(l,M+6);F[M]=u,F[M+1]=w,F[M+2]=g,F[M+3]=x,F[M+4]=A,F[M+5]=S;let E=P.setArraySize(n,M+3*2);E[M]=b,E[M+1]=p,E[M+2]=y,E[M+3]=v,E[M+4]=C,E[M+5]=k,M=a.length;let T=P.setArraySize(a,M+3);T[M]=f,T[M+1]=f+1,T[M+2]=f+2,f+=3;break}}}}clip(e,s,r,i,h,l,n,a){let o=a,c=!1,f;n.length%4>=2?(f=a,a=this.scratch):f=this.scratch,f.length=0,f.push(e),f.push(s),f.push(r),f.push(i),f.push(h),f.push(l),f.push(e),f.push(s),a.length=0;let d=n.length-4,m=n;for(let u=0;;u+=2){let w=m[u],b=m[u+1],p=w-m[u+2],g=b-m[u+3],x=a.length,y=f;for(let A=0,S=f.length-2;A<S;){let C=y[A],k=y[A+1];A+=2;let Y=y[A],M=y[A+1],F=g*(w-Y)>p*(b-M),E=g*(w-C)-p*(b-k);if(E>0){if(F){a.push(Y),a.push(M);continue}let T=Y-C,X=M-k,V=E/(T*g-X*p);if(V>=0&&V<=1)a.push(C+T*V),a.push(k+X*V);else{a.push(Y),a.push(M);continue}}else if(F){let T=Y-C,X=M-k,V=E/(T*g-X*p);if(V>=0&&V<=1)a.push(C+T*V),a.push(k+X*V),a.push(Y),a.push(M);else{a.push(Y),a.push(M);continue}}c=!0}if(x==a.length)return o.length=0,!0;if(a.push(a[0]),a.push(a[1]),u==d)break;let v=a;a=f,a.length=0,f=v}if(o!=a){o.length=0;for(let u=0,w=a.length-2;u<w;u++)o[u]=a[u]}else o.length=o.length-2;return c}static makeClockwise(e){let s=e,r=e.length,i=s[r-2]*s[1]-s[0]*s[r-1],h=0,l=0,n=0,a=0;for(let o=0,c=r-3;o<c;o+=2)h=s[o],l=s[o+1],n=s[o+2],a=s[o+3],i+=h*a-n*l;if(!(i<0))for(let o=0,c=r-2,f=r>>1;o<f;o+=2){let d=s[o],m=s[o+1],u=c-o;s[o]=s[u],s[o+1]=s[u+1],s[u]=d,s[u+1]=m}}},Ys=class{attachmentLoader;scale=1;linkedMeshes=new Array;constructor(t){this.attachmentLoader=t}readSkeletonData(t){let e=this.scale,s=new De,r=typeof t=="string"?JSON.parse(t):t,i=r.skeleton;if(i&&(s.hash=i.hash,s.version=i.spine,s.x=i.x,s.y=i.y,s.width=i.width,s.height=i.height,s.referenceScale=I(i,"referenceScale",100)*e,s.fps=i.fps,s.imagesPath=i.images??null,s.audioPath=i.audio??null),r.bones)for(let h=0;h<r.bones.length;h++){let l=r.bones[h],n=null,a=I(l,"parent",null);a&&(n=s.findBone(a));let o=new Xe(s.bones.length,l.name,n);o.length=I(l,"length",0)*e,o.x=I(l,"x",0)*e,o.y=I(l,"y",0)*e,o.rotation=I(l,"rotation",0),o.scaleX=I(l,"scaleX",1),o.scaleY=I(l,"scaleY",1),o.shearX=I(l,"shearX",0),o.shearY=I(l,"shearY",0),o.inherit=P.enumValue(Dt,I(l,"inherit","Normal")),o.skinRequired=I(l,"skin",!1);let c=I(l,"color",null);c&&o.color.setFromString(c),s.bones.push(o)}if(r.slots)for(let h=0;h<r.slots.length;h++){let l=r.slots[h],n=l.name,a=s.findBone(l.bone);if(!a)throw new Error(`Couldn't find bone ${l.bone} for slot ${n}`);let o=new qe(s.slots.length,n,a),c=I(l,"color",null);c&&o.color.setFromString(c);let f=I(l,"dark",null);f&&(o.darkColor=N.fromString(f)),o.attachmentName=I(l,"attachment",null),o.blendMode=P.enumValue(We,I(l,"blend","normal")),o.visible=I(l,"visible",!0),s.slots.push(o)}if(r.ik)for(let h=0;h<r.ik.length;h++){let l=r.ik[h],n=new Pe(l.name);n.order=I(l,"order",0),n.skinRequired=I(l,"skin",!1);for(let o=0;o<l.bones.length;o++){let c=s.findBone(l.bones[o]);if(!c)throw new Error(`Couldn't find bone ${l.bones[o]} for IK constraint ${l.name}.`);n.bones.push(c)}let a=s.findBone(l.target);if(!a)throw new Error(`Couldn't find target bone ${l.target} for IK constraint ${l.name}.`);n.target=a,n.mix=I(l,"mix",1),n.softness=I(l,"softness",0)*e,n.bendDirection=I(l,"bendPositive",!0)?1:-1,n.compress=I(l,"compress",!1),n.stretch=I(l,"stretch",!1),n.uniform=I(l,"uniform",!1),s.ikConstraints.push(n)}if(r.transform)for(let h=0;h<r.transform.length;h++){let l=r.transform[h],n=new Ue(l.name);n.order=I(l,"order",0),n.skinRequired=I(l,"skin",!1);for(let c=0;c<l.bones.length;c++){let f=l.bones[c],d=s.findBone(f);if(!d)throw new Error(`Couldn't find bone ${f} for transform constraint ${l.name}.`);n.bones.push(d)}let a=l.target,o=s.findBone(a);if(!o)throw new Error(`Couldn't find target bone ${a} for transform constraint ${l.name}.`);n.target=o,n.local=I(l,"local",!1),n.relative=I(l,"relative",!1),n.offsetRotation=I(l,"rotation",0),n.offsetX=I(l,"x",0)*e,n.offsetY=I(l,"y",0)*e,n.offsetScaleX=I(l,"scaleX",0),n.offsetScaleY=I(l,"scaleY",0),n.offsetShearY=I(l,"shearY",0),n.mixRotate=I(l,"mixRotate",1),n.mixX=I(l,"mixX",1),n.mixY=I(l,"mixY",n.mixX),n.mixScaleX=I(l,"mixScaleX",1),n.mixScaleY=I(l,"mixScaleY",n.mixScaleX),n.mixShearY=I(l,"mixShearY",1),s.transformConstraints.push(n)}if(r.path)for(let h=0;h<r.path.length;h++){let l=r.path[h],n=new Be(l.name);n.order=I(l,"order",0),n.skinRequired=I(l,"skin",!1);for(let c=0;c<l.bones.length;c++){let f=l.bones[c],d=s.findBone(f);if(!d)throw new Error(`Couldn't find bone ${f} for path constraint ${l.name}.`);n.bones.push(d)}let a=l.target,o=s.findSlot(a);if(!o)throw new Error(`Couldn't find target slot ${a} for path constraint ${l.name}.`);n.target=o,n.positionMode=P.enumValue(Ve,I(l,"positionMode","Percent")),n.spacingMode=P.enumValue(Le,I(l,"spacingMode","Length")),n.rotateMode=P.enumValue(Ne,I(l,"rotateMode","Tangent")),n.offsetRotation=I(l,"rotation",0),n.position=I(l,"position",0),n.positionMode==0&&(n.position*=e),n.spacing=I(l,"spacing",0),(n.spacingMode==0||n.spacingMode==1)&&(n.spacing*=e),n.mixRotate=I(l,"mixRotate",1),n.mixX=I(l,"mixX",1),n.mixY=I(l,"mixY",n.mixX),s.pathConstraints.push(n)}if(r.physics)for(let h=0;h<r.physics.length;h++){const l=r.physics[h],n=new Is(l.name);n.order=I(l,"order",0),n.skinRequired=I(l,"skin",!1);const a=l.bone,o=s.findBone(a);if(o==null)throw new Error("Physics bone not found: "+a);n.bone=o,n.x=I(l,"x",0),n.y=I(l,"y",0),n.rotate=I(l,"rotate",0),n.scaleX=I(l,"scaleX",0),n.shearX=I(l,"shearX",0),n.limit=I(l,"limit",5e3)*e,n.step=1/I(l,"fps",60),n.inertia=I(l,"inertia",1),n.strength=I(l,"strength",100),n.damping=I(l,"damping",1),n.massInverse=1/I(l,"mass",1),n.wind=I(l,"wind",0),n.gravity=I(l,"gravity",0),n.mix=I(l,"mix",1),n.inertiaGlobal=I(l,"inertiaGlobal",!1),n.strengthGlobal=I(l,"strengthGlobal",!1),n.dampingGlobal=I(l,"dampingGlobal",!1),n.massGlobal=I(l,"massGlobal",!1),n.windGlobal=I(l,"windGlobal",!1),n.gravityGlobal=I(l,"gravityGlobal",!1),n.mixGlobal=I(l,"mixGlobal",!1),s.physicsConstraints.push(n)}if(r.skins)for(let h=0;h<r.skins.length;h++){let l=r.skins[h],n=new qt(l.name);if(l.bones)for(let a=0;a<l.bones.length;a++){let o=l.bones[a],c=s.findBone(o);if(!c)throw new Error(`Couldn't find bone ${o} for skin ${l.name}.`);n.bones.push(c)}if(l.ik)for(let a=0;a<l.ik.length;a++){let o=l.ik[a],c=s.findIkConstraint(o);if(!c)throw new Error(`Couldn't find IK constraint ${o} for skin ${l.name}.`);n.constraints.push(c)}if(l.transform)for(let a=0;a<l.transform.length;a++){let o=l.transform[a],c=s.findTransformConstraint(o);if(!c)throw new Error(`Couldn't find transform constraint ${o} for skin ${l.name}.`);n.constraints.push(c)}if(l.path)for(let a=0;a<l.path.length;a++){let o=l.path[a],c=s.findPathConstraint(o);if(!c)throw new Error(`Couldn't find path constraint ${o} for skin ${l.name}.`);n.constraints.push(c)}if(l.physics)for(let a=0;a<l.physics.length;a++){let o=l.physics[a],c=s.findPhysicsConstraint(o);if(!c)throw new Error(`Couldn't find physics constraint ${o} for skin ${l.name}.`);n.constraints.push(c)}for(let a in l.attachments){let o=s.findSlot(a);if(!o)throw new Error(`Couldn't find slot ${a} for skin ${l.name}.`);let c=l.attachments[a];for(let f in c){let d=this.readAttachment(c[f],n,o.index,f,s);d&&n.setAttachment(o.index,f,d)}}s.skins.push(n),n.name=="default"&&(s.defaultSkin=n)}for(let h=0,l=this.linkedMeshes.length;h<l;h++){let n=this.linkedMeshes[h],a=n.skin?s.findSkin(n.skin):s.defaultSkin;if(!a)throw new Error(`Skin not found: ${n.skin}`);let o=a.getAttachment(n.slotIndex,n.parent);if(!o)throw new Error(`Parent mesh not found: ${n.parent}`);n.mesh.timelineAttachment=n.inheritTimeline?o:n.mesh,n.mesh.setParentMesh(o),n.mesh.region!=null&&n.mesh.updateRegion()}if(this.linkedMeshes.length=0,r.events)for(let h in r.events){let l=r.events[h],n=new Re(h);n.intValue=I(l,"int",0),n.floatValue=I(l,"float",0),n.stringValue=I(l,"string",""),n.audioPath=I(l,"audio",null),n.audioPath&&(n.volume=I(l,"volume",1),n.balance=I(l,"balance",0)),s.events.push(n)}if(r.animations)for(let h in r.animations){let l=r.animations[h];this.readAnimation(l,h,s)}return s}readAttachment(t,e,s,r,i){let h=this.scale;switch(r=I(t,"name",r),I(t,"type","region")){case"region":{let l=I(t,"path",r),n=this.readSequence(I(t,"sequence",null)),a=this.attachmentLoader.newRegionAttachment(e,r,l,n);if(!a)return null;a.path=l,a.x=I(t,"x",0)*h,a.y=I(t,"y",0)*h,a.scaleX=I(t,"scaleX",1),a.scaleY=I(t,"scaleY",1),a.rotation=I(t,"rotation",0),a.width=t.width*h,a.height=t.height*h,a.sequence=n;let o=I(t,"color",null);return o&&a.color.setFromString(o),a.region!=null&&a.updateRegion(),a}case"boundingbox":{let l=this.attachmentLoader.newBoundingBoxAttachment(e,r);if(!l)return null;this.readVertices(t,l,t.vertexCount<<1);let n=I(t,"color",null);return n&&l.color.setFromString(n),l}case"mesh":case"linkedmesh":{let l=I(t,"path",r),n=this.readSequence(I(t,"sequence",null)),a=this.attachmentLoader.newMeshAttachment(e,r,l,n);if(!a)return null;a.path=l;let o=I(t,"color",null);o&&a.color.setFromString(o),a.width=I(t,"width",0)*h,a.height=I(t,"height",0)*h,a.sequence=n;let c=I(t,"parent",null);if(c)return this.linkedMeshes.push(new Ei(a,I(t,"skin",null),s,c,I(t,"timelines",!0))),a;let f=t.uvs;return this.readVertices(t,a,f.length),a.triangles=t.triangles,a.regionUVs=f,a.region!=null&&a.updateRegion(),a.edges=I(t,"edges",null),a.hullLength=I(t,"hull",0)*2,a}case"path":{let l=this.attachmentLoader.newPathAttachment(e,r);if(!l)return null;l.closed=I(t,"closed",!1),l.constantSpeed=I(t,"constantSpeed",!0);let n=t.vertexCount;this.readVertices(t,l,n<<1);let a=P.newArray(n/3,0);for(let c=0;c<t.lengths.length;c++)a[c]=t.lengths[c]*h;l.lengths=a;let o=I(t,"color",null);return o&&l.color.setFromString(o),l}case"point":{let l=this.attachmentLoader.newPointAttachment(e,r);if(!l)return null;l.x=I(t,"x",0)*h,l.y=I(t,"y",0)*h,l.rotation=I(t,"rotation",0);let n=I(t,"color",null);return n&&l.color.setFromString(n),l}case"clipping":{let l=this.attachmentLoader.newClippingAttachment(e,r);if(!l)return null;let n=I(t,"end",null);n&&(l.endSlot=i.findSlot(n));let a=t.vertexCount;this.readVertices(t,l,a<<1);let o=I(t,"color",null);return o&&l.color.setFromString(o),l}}return null}readSequence(t){if(t==null)return null;let e=new es(I(t,"count",0));return e.start=I(t,"start",1),e.digits=I(t,"digits",0),e.setupIndex=I(t,"setup",0),e}readVertices(t,e,s){let r=this.scale;e.worldVerticesLength=s;let i=t.vertices;if(s==i.length){let n=P.toFloatArray(i);if(r!=1)for(let a=0,o=i.length;a<o;a++)n[a]*=r;e.vertices=n;return}let h=new Array,l=new Array;for(let n=0,a=i.length;n<a;){let o=i[n++];l.push(o);for(let c=n+o*4;n<c;n+=4)l.push(i[n]),h.push(i[n+1]*r),h.push(i[n+2]*r),h.push(i[n+3])}e.bones=l,e.vertices=P.toFloatArray(h)}readAnimation(t,e,s){let r=this.scale,i=new Array;if(t.slots)for(let l in t.slots){let n=t.slots[l],a=s.findSlot(l);if(!a)throw new Error("Slot not found: "+l);let o=a.index;for(let c in n){let f=n[c];if(!f)continue;let d=f.length;if(c=="attachment"){let m=new ut(d,o);for(let u=0;u<d;u++){let w=f[u];m.setFrame(u,I(w,"time",0),I(w,"name",null))}i.push(m)}else if(c=="rgba"){let m=new re(d,d<<2,o),u=f[0],w=I(u,"time",0),b=N.fromString(u.color);for(let p=0,g=0;;p++){m.setFrame(p,w,b.r,b.g,b.b,b.a);let x=f[p+1];if(!x){m.shrink(g);break}let y=I(x,"time",0),v=N.fromString(x.color),A=u.curve;A&&(g=_(A,m,g,p,0,w,y,b.r,v.r,1),g=_(A,m,g,p,1,w,y,b.g,v.g,1),g=_(A,m,g,p,2,w,y,b.b,v.b,1),g=_(A,m,g,p,3,w,y,b.a,v.a,1)),w=y,b=v,u=x}i.push(m)}else if(c=="rgb"){let m=new ne(d,d*3,o),u=f[0],w=I(u,"time",0),b=N.fromString(u.color);for(let p=0,g=0;;p++){m.setFrame(p,w,b.r,b.g,b.b);let x=f[p+1];if(!x){m.shrink(g);break}let y=I(x,"time",0),v=N.fromString(x.color),A=u.curve;A&&(g=_(A,m,g,p,0,w,y,b.r,v.r,1),g=_(A,m,g,p,1,w,y,b.g,v.g,1),g=_(A,m,g,p,2,w,y,b.b,v.b,1)),w=y,b=v,u=x}i.push(m)}else if(c=="alpha")i.push(nt(f,new ae(d,d,o),0,1));else if(c=="rgba2"){let m=new le(d,d*7,o),u=f[0],w=I(u,"time",0),b=N.fromString(u.light),p=N.fromString(u.dark);for(let g=0,x=0;;g++){m.setFrame(g,w,b.r,b.g,b.b,b.a,p.r,p.g,p.b);let y=f[g+1];if(!y){m.shrink(x);break}let v=I(y,"time",0),A=N.fromString(y.light),S=N.fromString(y.dark),C=u.curve;C&&(x=_(C,m,x,g,0,w,v,b.r,A.r,1),x=_(C,m,x,g,1,w,v,b.g,A.g,1),x=_(C,m,x,g,2,w,v,b.b,A.b,1),x=_(C,m,x,g,3,w,v,b.a,A.a,1),x=_(C,m,x,g,4,w,v,p.r,S.r,1),x=_(C,m,x,g,5,w,v,p.g,S.g,1),x=_(C,m,x,g,6,w,v,p.b,S.b,1)),w=v,b=A,p=S,u=y}i.push(m)}else if(c=="rgb2"){let m=new oe(d,d*6,o),u=f[0],w=I(u,"time",0),b=N.fromString(u.light),p=N.fromString(u.dark);for(let g=0,x=0;;g++){m.setFrame(g,w,b.r,b.g,b.b,p.r,p.g,p.b);let y=f[g+1];if(!y){m.shrink(x);break}let v=I(y,"time",0),A=N.fromString(y.light),S=N.fromString(y.dark),C=u.curve;C&&(x=_(C,m,x,g,0,w,v,b.r,A.r,1),x=_(C,m,x,g,1,w,v,b.g,A.g,1),x=_(C,m,x,g,2,w,v,b.b,A.b,1),x=_(C,m,x,g,3,w,v,p.r,S.r,1),x=_(C,m,x,g,4,w,v,p.g,S.g,1),x=_(C,m,x,g,5,w,v,p.b,S.b,1)),w=v,b=A,p=S,u=y}i.push(m)}}}if(t.bones)for(let l in t.bones){let n=t.bones[l],a=s.findBone(l);if(!a)throw new Error("Bone not found: "+l);let o=a.index;for(let c in n){let f=n[c],d=f.length;if(d!=0){if(c==="rotate")i.push(nt(f,new At(d,d,o),0,1));else if(c==="translate"){let m=new Ht(d,d<<1,o);i.push(_e(f,m,"x","y",0,r))}else if(c==="translatex"){let m=new jt(d,d,o);i.push(nt(f,m,0,r))}else if(c==="translatey"){let m=new Jt(d,d,o);i.push(nt(f,m,0,r))}else if(c==="scale"){let m=new Kt(d,d<<1,o);i.push(_e(f,m,"x","y",1,1))}else if(c==="scalex"){let m=new Qt(d,d,o);i.push(nt(f,m,1,1))}else if(c==="scaley"){let m=new Zt(d,d,o);i.push(nt(f,m,1,1))}else if(c==="shear"){let m=new te(d,d<<1,o);i.push(_e(f,m,"x","y",0,1))}else if(c==="shearx"){let m=new ee(d,d,o);i.push(nt(f,m,0,1))}else if(c==="sheary"){let m=new se(d,d,o);i.push(nt(f,m,0,1))}else if(c==="inherit"){let m=new ie(d,a.index);for(let u=0;u<f.length;u++){let w=f[u];m.setFrame(u,I(w,"time",0),P.enumValue(Dt,I(w,"inherit","Normal")))}i.push(m)}}}}if(t.ik)for(let l in t.ik){let n=t.ik[l],a=n[0];if(!a)continue;let o=s.findIkConstraint(l);if(!o)throw new Error("IK Constraint not found: "+l);let c=s.ikConstraints.indexOf(o),f=new ce(n.length,n.length<<1,c),d=I(a,"time",0),m=I(a,"mix",1),u=I(a,"softness",0)*r;for(let w=0,b=0;;w++){f.setFrame(w,d,m,u,I(a,"bendPositive",!0)?1:-1,I(a,"compress",!1),I(a,"stretch",!1));let p=n[w+1];if(!p){f.shrink(b);break}let g=I(p,"time",0),x=I(p,"mix",1),y=I(p,"softness",0)*r,v=a.curve;v&&(b=_(v,f,b,w,0,d,g,m,x,1),b=_(v,f,b,w,1,d,g,u,y,r)),d=g,m=x,u=y,a=p}i.push(f)}if(t.transform)for(let l in t.transform){let n=t.transform[l],a=n[0];if(!a)continue;let o=s.findTransformConstraint(l);if(!o)throw new Error("Transform constraint not found: "+l);let c=s.transformConstraints.indexOf(o),f=new de(n.length,n.length*6,c),d=I(a,"time",0),m=I(a,"mixRotate",1),u=I(a,"mixX",1),w=I(a,"mixY",u),b=I(a,"mixScaleX",1),p=I(a,"mixScaleY",b),g=I(a,"mixShearY",1);for(let x=0,y=0;;x++){f.setFrame(x,d,m,u,w,b,p,g);let v=n[x+1];if(!v){f.shrink(y);break}let A=I(v,"time",0),S=I(v,"mixRotate",1),C=I(v,"mixX",1),k=I(v,"mixY",C),Y=I(v,"mixScaleX",1),M=I(v,"mixScaleY",Y),F=I(v,"mixShearY",1),E=a.curve;E&&(y=_(E,f,y,x,0,d,A,m,S,1),y=_(E,f,y,x,1,d,A,u,C,1),y=_(E,f,y,x,2,d,A,w,k,1),y=_(E,f,y,x,3,d,A,b,Y,1),y=_(E,f,y,x,4,d,A,p,M,1),y=_(E,f,y,x,5,d,A,g,F,1)),d=A,m=S,u=C,w=k,b=Y,p=M,b=Y,a=v}i.push(f)}if(t.path)for(let l in t.path){let n=t.path[l],a=s.findPathConstraint(l);if(!a)throw new Error("Path constraint not found: "+l);let o=s.pathConstraints.indexOf(a);for(let c in n){let f=n[c],d=f[0];if(!d)continue;let m=f.length;if(c==="position"){let u=new fe(m,m,o);i.push(nt(f,u,0,a.positionMode==0?r:1))}else if(c==="spacing"){let u=new ue(m,m,o);i.push(nt(f,u,0,a.spacingMode==0||a.spacingMode==1?r:1))}else if(c==="mix"){let u=new me(m,m*3,o),w=I(d,"time",0),b=I(d,"mixRotate",1),p=I(d,"mixX",1),g=I(d,"mixY",p);for(let x=0,y=0;;x++){u.setFrame(x,w,b,p,g);let v=f[x+1];if(!v){u.shrink(y);break}let A=I(v,"time",0),S=I(v,"mixRotate",1),C=I(v,"mixX",1),k=I(v,"mixY",C),Y=d.curve;Y&&(y=_(Y,u,y,x,0,w,A,b,S,1),y=_(Y,u,y,x,1,w,A,p,C,1),y=_(Y,u,y,x,2,w,A,g,k,1)),w=A,b=S,p=C,g=k,d=v}i.push(u)}}}if(t.physics)for(let l in t.physics){let n=t.physics[l],a=-1;if(l.length>0){let o=s.findPhysicsConstraint(l);if(!o)throw new Error("Physics constraint not found: "+l);a=s.physicsConstraints.indexOf(o)}for(let o in n){let c=n[o],f=c[0];if(!f)continue;let d=c.length;if(o=="reset"){const u=new Ae(d,a);for(let w=0;f!=null;f=c[w+1],w++)u.setFrame(w,I(f,"time",0));i.push(u);continue}let m;if(o=="inertia")m=new ge(d,d,a);else if(o=="strength")m=new xe(d,d,a);else if(o=="damping")m=new we(d,d,a);else if(o=="mass")m=new pe(d,d,a);else if(o=="wind")m=new be(d,d,a);else if(o=="gravity")m=new ye(d,d,a);else if(o=="mix")m=new ve(d,d,a);else continue;i.push(nt(c,m,0,1))}}if(t.attachments)for(let l in t.attachments){let n=t.attachments[l],a=s.findSkin(l);if(!a)throw new Error("Skin not found: "+l);for(let o in n){let c=n[o],f=s.findSlot(o);if(!f)throw new Error("Slot not found: "+o);let d=f.index;for(let m in c){let u=c[m],w=a.getAttachment(d,m);for(let b in u){let p=u[b],g=p[0];if(g){if(b=="deform"){let x=w.bones,y=w.vertices,v=x?y.length/3*2:y.length,A=new he(p.length,p.length,d,w),S=I(g,"time",0);for(let C=0,k=0;;C++){let Y,M=I(g,"vertices",null);if(!M)Y=x?P.newFloatArray(v):y;else{Y=P.newFloatArray(v);let X=I(g,"offset",0);if(P.arrayCopy(M,0,Y,X,M.length),r!=1)for(let V=X,D=V+M.length;V<D;V++)Y[V]*=r;if(!x)for(let V=0;V<v;V++)Y[V]+=y[V]}A.setFrame(C,S,Y);let F=p[C+1];if(!F){A.shrink(k);break}let E=I(F,"time",0),T=g.curve;T&&(k=_(T,A,k,C,0,S,E,0,1,1)),S=E,g=F}i.push(A)}else if(b=="sequence"){let x=new Se(p.length,d,w),y=0;for(let v=0;v<p.length;v++){let A=I(g,"delay",y),S=I(g,"time",0),C=ss[I(g,"mode","hold")],k=I(g,"index",0);x.setFrame(v,S,C,k,A),y=A,g=p[v+1]}i.push(x)}}}}}}if(t.drawOrder){let l=new wt(t.drawOrder.length),n=s.slots.length,a=0;for(let o=0;o<t.drawOrder.length;o++,a++){let c=t.drawOrder[o],f=null,d=I(c,"offsets",null);if(d){f=P.newArray(n,-1);let m=P.newArray(n-d.length,0),u=0,w=0;for(let b=0;b<d.length;b++){let p=d[b],g=s.findSlot(p.slot);if(!g)throw new Error("Slot not found: "+g);let x=g.index;for(;u!=x;)m[w++]=u++;f[u+p.offset]=u++}for(;u<n;)m[w++]=u++;for(let b=n-1;b>=0;b--)f[b]==-1&&(f[b]=m[--w])}l.setFrame(a,I(c,"time",0),f)}i.push(l)}if(t.events){let l=new Et(t.events.length),n=0;for(let a=0;a<t.events.length;a++,n++){let o=t.events[a],c=s.findEvent(o.name);if(!c)throw new Error("Event not found: "+o.name);let f=new Ee(P.toSinglePrecision(I(o,"time",0)),c);f.intValue=I(o,"int",c.intValue),f.floatValue=I(o,"float",c.floatValue),f.stringValue=I(o,"string",c.stringValue),f.data.audioPath&&(f.volume=I(o,"volume",1),f.balance=I(o,"balance",0)),l.setFrame(n,f)}i.push(l)}let h=0;for(let l=0,n=i.length;l<n;l++)h=Math.max(h,i[l].getDuration());s.animations.push(new Xt(e,i,h))}},Ei=class{parent;skin;slotIndex;mesh;inheritTimeline;constructor(t,e,s,r,i){this.mesh=t,this.skin=e,this.slotIndex=s,this.parent=r,this.inheritTimeline=i}};function nt(t,e,s,r){let i=t[0],h=I(i,"time",0),l=I(i,"value",s)*r,n=0;for(let a=0;;a++){e.setFrame(a,h,l);let o=t[a+1];if(!o)return e.shrink(n),e;let c=I(o,"time",0),f=I(o,"value",s)*r;i.curve&&(n=_(i.curve,e,n,a,0,h,c,l,f,r)),h=c,l=f,i=o}}function _e(t,e,s,r,i,h){let l=t[0],n=I(l,"time",0),a=I(l,s,i)*h,o=I(l,r,i)*h,c=0;for(let f=0;;f++){e.setFrame(f,n,a,o);let d=t[f+1];if(!d)return e.shrink(c),e;let m=I(d,"time",0),u=I(d,s,i)*h,w=I(d,r,i)*h,b=l.curve;b&&(c=_(b,e,c,f,0,n,m,a,u,h),c=_(b,e,c,f,1,n,m,o,w,h)),n=m,a=u,o=w,l=d}}function _(t,e,s,r,i,h,l,n,a,o){if(t=="stepped")return e.setStepped(r),s;let c=i<<2,f=t[c],d=t[c+1]*o,m=t[c+2],u=t[c+3]*o;return e.setBezier(s,r,i,h,n,f,d,m,u,l,a),s+1}function I(t,e,s){return t[e]!==void 0?t[e]:s}typeof Math.fround>"u"&&(Math.fround=function(t){return function(e){return t[0]=e,t[0]}}(new Float32Array(1))),Ot.yDown=!0;function Ri(t,e){switch(e){case 0:return t.BlendMode.SrcOver;case 1:return t.BlendMode.Plus;case 2:return t.BlendMode.SrcOver;case 3:return t.BlendMode.Screen;default:return t.BlendMode.SrcOver}}function Xs(t){if(typeof Buffer<"u")return t.toString("utf-8");if(typeof TextDecoder<"u")return new TextDecoder("utf-8").decode(t);throw new Error("Unsupported environment")}var Pi=class qs extends Me{getImage(){return this._image}setFilters(e,s){}setWraps(e,s){}dispose(){const e=this._image;for(const s of e.paintPerBlendMode.values())s.delete();for(const s of e.shaders)s.delete();e.image.delete(),this._image=null}static async fromFile(e,s,r){const i=await r(s);if(!i)throw new Error(`Could not load image ${s}`);const h=e.MakeImageFromEncoded(i);if(!h)throw new Error(`Could not load image ${s}`);const l=new Map,n=[];for(const a of[0,1,2,3]){const o=new e.Paint,c=h.makeShaderOptions(e.TileMode.Clamp,e.TileMode.Clamp,e.FilterMode.Linear,e.MipmapMode.Linear);o.setShader(c),o.setBlendMode(Ri(e,a)),l.set(a,o),n.push(c)}return new qs({shaders:n,paintPerBlendMode:l,image:h})}};async function Bi(t,e,s){const r=new Lt(Xs(await s(e))),i=e.lastIndexOf("/"),h=i>=0?e.substring(0,i+1):"";for(const l of r.pages){const n=await Pi.fromFile(t,h+l.name,s);l.setTexture(n)}return r}async function Vi(t,e,s,r=1){const i=new ws(e),h=t.endsWith(".json")?new Ys(i):new Cs(i);h.scale=r;let l=await s(t);return t.endsWith(".json")&&(l=Xs(l)),h.readSkeletonData(l)}var Fs=class{skeleton;animationState;constructor(t){this.skeleton=new Ot(t),this.animationState=new as(new fs(t))}update(t,e=2){this.animationState.update(t),this.skeleton.update(t),this.animationState.apply(this.skeleton),this.skeleton.updateWorldTransform(e)}},Li=class Ws{constructor(e){this.ck=e}clipper=new Ms;tempColor=new N;tempColor2=new N;static QUAD_TRIANGLES=[0,1,2,2,3,0];scratchPositions=P.newFloatArray(100);scratchColors=P.newFloatArray(100);scratchUVs=P.newFloatArray(100);render(e,s){s instanceof Fs&&(s=s.skeleton);let r=this.clipper,i=s.drawOrder,h=s.color;for(let l=0,n=i.length;l<n;l++){let a=i[l];if(!a.bone.active){r.clipEndWithSlot(a);continue}let o=a.getAttachment(),c=this.scratchPositions,f=this.scratchColors,d,m,u,w,b=0;if(o instanceof Nt){let p=o;c=c.length<8?P.newFloatArray(8):c,b=4,p.computeWorldVertices(a,c,0,2),u=Ws.QUAD_TRIANGLES,d=p.uvs,m=p.region?.texture,w=p.color}else if(o instanceof St){let p=o;c=c.length<p.worldVerticesLength?P.newFloatArray(p.worldVerticesLength):c,b=p.worldVerticesLength>>1,p.computeWorldVertices(a,0,p.worldVerticesLength,c,0,2),u=p.triangles,m=p.region?.texture,d=p.uvs,w=p.color}else if(o instanceof Bt){let p=o;r.clipStart(a,p);continue}else{r.clipEndWithSlot(a);continue}if(m){r.isClipping()&&(r.clipTrianglesUnpacked(c,u,u.length,d),c=r.clippedVertices,d=r.clippedUVs,u=r.clippedTriangles);let p=a.color,g=this.tempColor;g.r=h.r*p.r*w.r,g.g=h.g*p.g*w.g,g.b=h.b*p.b*w.b,g.a=h.a*p.a*w.a,f.length/4<b&&(f=P.newFloatArray(b*4));for(let C=0,k=b*4;C<k;C+=4)f[C]=g.r,f[C+1]=g.g,f[C+2]=g.b,f[C+3]=g.a;const x=this.scratchUVs.length<d.length?P.newFloatArray(d.length):this.scratchUVs,y=m.getImage().image.width(),v=m.getImage().image.height();for(let C=0;C<d.length;C+=2)x[C]=d[C]*y,x[C+1]=d[C+1]*v;const A=a.data.blendMode,S=this.ck.MakeVertices(this.ck.VertexMode.Triangles,c,x,f,u,!1);e.drawVertices(S,this.ck.BlendMode.Modulate,m.getImage().paintPerBlendMode.get(A)),S.delete()}r.clipEndWithSlot(a)}r.clipEnd()}};export{ae as AlphaTimeline,Xt as Animation,as as AnimationState,Hs as AnimationStateAdapter,fs as AnimationStateData,Ks as AssetManagerBase,ws as AtlasAttachmentLoader,$t as Attachment,ut as AttachmentTimeline,ks as BinaryInput,We as BlendMode,Fe as Bone,Xe as BoneData,Te as BoundingBoxAttachment,ds as CURRENT,Bt as ClippingAttachment,N as Color,Ct as ConstraintData,rt as CurveTimeline,st as CurveTimeline1,Ft as CurveTimeline2,_s as DebugUtils,he as DeformTimeline,ps as Downloader,wt as DrawOrderTimeline,Ee as Event,Re as EventData,os as EventQueue,Et as EventTimeline,hs as EventType,Ie as FIRST,js as FakeTexture,Pt as HOLD_FIRST,cs as HOLD_MIX,Ce as HOLD_SUBSEQUENT,bs as IkConstraint,Pe as IkConstraintData,ce as IkConstraintTimeline,Dt as Inherit,ie as InheritTimeline,Us as IntSet,Ze as Interpolation,R as MathUtils,St as MeshAttachment,rs as MixBlend,ns as MixDirection,It as PathAttachment,ys as PathConstraint,Be as PathConstraintData,me as PathConstraintMixTimeline,fe as PathConstraintPositionTimeline,ue as PathConstraintSpacingTimeline,Ss as Physics,we as PhysicsConstraintDampingTimeline,ye as PhysicsConstraintGravityTimeline,ge as PhysicsConstraintInertiaTimeline,pe as PhysicsConstraintMassTimeline,ve as PhysicsConstraintMixTimeline,Ae as PhysicsConstraintResetTimeline,xe as PhysicsConstraintStrengthTimeline,ct as PhysicsConstraintTimeline,be as PhysicsConstraintWindTimeline,xs as PointAttachment,vt as Pool,Ve as PositionMode,ts as Pow,zs as PowOut,oe as RGB2Timeline,le as RGBA2Timeline,re as RGBATimeline,ne as RGBTimeline,Nt as RegionAttachment,Ne as RotateMode,At as RotateTimeline,ke as SETUP,Rt as SUBSEQUENT,Kt as ScaleTimeline,Qt as ScaleXTimeline,Zt as ScaleYTimeline,Se as SequenceTimeline,te as ShearTimeline,ee as ShearXTimeline,se as ShearYTimeline,Ot as Skeleton,Cs as SkeletonBinary,Fi as SkeletonBounds,Ms as SkeletonClipping,De as SkeletonData,Fs as SkeletonDrawable,Ys as SkeletonJson,Li as SkeletonRenderer,qt as Skin,Oe as SkinEntry,vs as Slot,qe as SlotData,Le as SpacingMode,Gt as StringSet,Me as Texture,Lt as TextureAtlas,gs as TextureAtlasPage,Ye as TextureAtlasRegion,Vt as TextureFilter,ms as TextureRegion,us as TextureWrap,Gs as TimeKeeper,H as Timeline,ls as TrackEntry,As as TransformConstraint,Ue as TransformConstraintData,de as TransformConstraintTimeline,Ht as TranslateTimeline,jt as TranslateXTimeline,Jt as TranslateYTimeline,Ts as Triangulator,P as Utils,Yt as Vector2,lt as VertexAttachment,$s as WindowedMean,Vi as loadSkeletonData,Bi as loadTextureAtlas};