@esotericsoftware/spine-webgl 4.2.93 → 4.2.94
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,5 +1,5 @@
|
|
|
1
|
-
"use strict";var qi=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}},Ee=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,i=e.length;s<i;s++)this.add(e[s]);return t!=this.size}contains(e){return this.entries[e]}clear(){this.entries={},this.size=0}},et=class Nt{constructor(t=0,s=0,i=0,r=0){this.r=t,this.g=s,this.b=i,this.a=r}static WHITE=new Nt(1,1,1,1);static RED=new Nt(1,0,0,1);static GREEN=new Nt(0,1,0,1);static BLUE=new Nt(0,0,1,1);static MAGENTA=new Nt(1,0,1,1);set(t,s,i,r){return this.r=t,this.g=s,this.b=i,this.a=r,this.clamp()}setFromColor(t){return this.r=t.r,this.g=t.g,this.b=t.b,this.a=t.a,this}setFromString(t){return t=t.charAt(0)=="#"?t.substr(1):t,this.r=parseInt(t.substr(0,2),16)/255,this.g=parseInt(t.substr(2,2),16)/255,this.b=parseInt(t.substr(4,2),16)/255,this.a=t.length!=8?1:parseInt(t.substr(6,2),16)/255,this}add(t,s,i,r){return this.r+=t,this.g+=s,this.b+=i,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(t,s){t.r=((s&4278190080)>>>24)/255,t.g=((s&16711680)>>>16)/255,t.b=((s&65280)>>>8)/255,t.a=(s&255)/255}static rgb888ToColor(t,s){t.r=((s&16711680)>>>16)/255,t.g=((s&65280)>>>8)/255,t.b=(s&255)/255}toRgb888(){const t=s=>("0"+(s*255).toString(16)).slice(-2);return+("0x"+t(this.r)+t(this.g)+t(this.b))}static fromString(t,s=new Nt){return s.setFromString(t)}},L=class Et{static PI=3.1415927;static PI2=Et.PI*2;static invPI2=1/Et.PI2;static radiansToDegrees=180/Et.PI;static radDeg=Et.radiansToDegrees;static degreesToRadians=Et.PI/180;static degRad=Et.degreesToRadians;static clamp(t,s,i){return t<s?s:t>i?i:t}static cosDeg(t){return Math.cos(t*Et.degRad)}static sinDeg(t){return Math.sin(t*Et.degRad)}static atan2Deg(t,s){return Math.atan2(t,s)*Et.degRad}static signum(t){return t>0?1:t<0?-1:0}static toInt(t){return t>0?Math.floor(t):Math.ceil(t)}static cbrt(t){let s=Math.pow(Math.abs(t),.3333333333333333);return t<0?-s:s}static randomTriangular(t,s){return Et.randomTriangularWith(t,s,(t+s)*.5)}static randomTriangularWith(t,s,i){let r=Math.random(),h=s-t;return r<=(i-t)/h?t+Math.sqrt(r*h*(i-t)):s-Math.sqrt((1-r)*h*(s-i))}static isPowerOfTwo(t){return t&&(t&t-1)===0}},Hs=class{apply(e,t,s){return e+(t-e)*this.applyInternal(s)}},_s=class extends Hs{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}},Gi=class extends _s{constructor(e){super(e)}applyInternal(e){return Math.pow(e-1,this.power)*(this.power%2==0?-1:1)+1}},P=class Kt{static SUPPORTS_TYPED_ARRAYS=typeof Float32Array<"u";static arrayCopy(t,s,i,r,h){for(let l=s,n=r;l<s+h;l++,n++)i[n]=t[l]}static arrayFill(t,s,i,r){for(let h=s;h<i;h++)t[h]=r}static setArraySize(t,s,i=0){let r=t.length;if(r==s)return t;if(t.length=s,r<s)for(let h=r;h<s;h++)t[h]=i;return t}static ensureArrayCapacity(t,s,i=0){return t.length>=s?t:Kt.setArraySize(t,s,i)}static newArray(t,s){let i=new Array(t);for(let r=0;r<t;r++)i[r]=s;return i}static newFloatArray(t){if(Kt.SUPPORTS_TYPED_ARRAYS)return new Float32Array(t);{let s=new Array(t);for(let i=0;i<s.length;i++)s[i]=0;return s}}static newShortArray(t){if(Kt.SUPPORTS_TYPED_ARRAYS)return new Int16Array(t);{let s=new Array(t);for(let i=0;i<s.length;i++)s[i]=0;return s}}static toFloatArray(t){return Kt.SUPPORTS_TYPED_ARRAYS?new Float32Array(t):t}static toSinglePrecision(t){return Kt.SUPPORTS_TYPED_ARRAYS?Math.fround(t):t}static webkit602BugfixHelper(t,s){}static contains(t,s,i=!0){for(var r=0;r<t.length;r++)if(t[r]==s)return!0;return!1}static enumValue(t,s){return t[s[0].toUpperCase()+s.slice(1)]}},Hi=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)}}},$t=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}},Vt=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}},Ye=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)}},_i=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}},Re=class{name;constructor(e){if(!e)throw new Error("name cannot be null.");this.name=e}},Rt=class Li extends Re{static nextID=0;id=Li.nextID++;bones=null;vertices=[];worldVerticesLength=0;timelineAttachment=this;constructor(t){super(t)}computeWorldVertices(t,s,i,r,h,l){i=h+(i>>1)*l;let n=t.bone.skeleton,a=t.deform,o=this.vertices,c=this.bones;if(!c){a.length>0&&(o=a);let u=t.bone,g=u.worldX,w=u.worldY,b=u.a,x=u.b,p=u.c,v=u.d;for(let y=s,A=h;A<i;y+=2,A+=l){let C=o[y],S=o[y+1];r[A]=C*b+S*x+g,r[A+1]=C*p+S*v+w}return}let d=0,f=0;for(let u=0;u<s;u+=2){let g=c[d];d+=g+1,f+=g}let m=n.bones;if(a.length==0)for(let u=h,g=f*3;u<i;u+=l){let w=0,b=0,x=c[d++];for(x+=d;d<x;d++,g+=3){let p=m[c[d]],v=o[g],y=o[g+1],A=o[g+2];w+=(v*p.a+y*p.b+p.worldX)*A,b+=(v*p.c+y*p.d+p.worldY)*A}r[u]=w,r[u+1]=b}else{let u=a;for(let g=h,w=f*3,b=f<<1;g<i;g+=l){let x=0,p=0,v=c[d++];for(v+=d;d<v;d++,w+=3,b+=2){let y=m[c[d]],A=o[w]+u[b],C=o[w+1]+u[b+1],S=o[w+2];x+=(A*y.a+C*y.b+y.worldX)*S,p+=(A*y.c+C*y.d+y.worldY)*S}r[g]=x,r[g+1]=p}}}copyTo(t){this.bones?(t.bones=new Array(this.bones.length),P.arrayCopy(this.bones,0,t.bones,0,this.bones.length)):t.bones=null,this.vertices&&(t.vertices=P.newFloatArray(this.vertices.length),P.arrayCopy(this.vertices,0,t.vertices,0,this.vertices.length)),t.worldVerticesLength=this.worldVerticesLength,t.timelineAttachment=this.timelineAttachment}},js=class Ae{static _nextID=0;id=Ae.nextID();regions;start=0;digits=0;setupIndex=0;constructor(t){this.regions=new Array(t)}copy(){let t=new Ae(this.regions.length);return P.arrayCopy(this.regions,0,t.regions,0,this.regions.length),t.start=this.start,t.digits=this.digits,t.setupIndex=this.setupIndex,t}apply(t,s){let i=t.sequenceIndex;i==-1&&(i=this.setupIndex),i>=this.regions.length&&(i=this.regions.length-1);let r=this.regions[i];s.region!=r&&(s.region=r,s.updateRegion())}getPath(t,s){let i=t,r=(this.start+s).toString();for(let h=this.digits-r.length;h>0;h--)i+="0";return i+=r,i}static nextID(){return Ae._nextID++}},Zs=(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))(Zs||{}),Ks=[0,1,2,3,4,5,6],oe=class{name;timelines=[];timelineIds=new Ee;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,i,r,h,l,n){if(!e)throw new Error("skeleton cannot be null.");i&&this.duration!=0&&(s%=this.duration,t>0&&(t%=this.duration));let a=this.timelines;for(let o=0,c=a.length;o<c;o++)a[o].apply(e,t,s,r,h,l,n)}},Js=(e=>(e[e.setup=0]="setup",e[e.first=1]="first",e[e.replace=2]="replace",e[e.add=3]="add",e))(Js||{}),Qs=(e=>(e[e.mixIn=0]="mixIn",e[e.mixOut=1]="mixOut",e))(Qs||{}),rt={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},ft=class{propertyIds;frames;constructor(e,t){this.propertyIds=t,this.frames=P.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 i=1;i<s;i++)if(e[i]>t)return i-1;return s-1}static search(e,t,s){let i=e.length;for(let r=s;r<i;r+=s)if(e[r]>t)return r-s;return i-s}},St=class extends ft{curves;constructor(e,t,s){super(e,s),this.curves=P.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=P.newFloatArray(t);P.arrayCopy(this.curves,0,s,0,t),this.curves=s}}setBezier(e,t,s,i,r,h,l,n,a,o,c){let d=this.curves,f=this.getFrameCount()+e*18;s==0&&(d[t]=2+f);let m=(i-h*2+n)*.03,u=(r-l*2+a)*.03,g=((h-n)*3-i+o)*.006,w=((l-a)*3-r+c)*.006,b=m*2+g,x=u*2+w,p=(h-i)*.3+m+g*.16666667,v=(l-r)*.3+u+w*.16666667,y=i+p,A=r+v;for(let C=f+18;f<C;f+=2)d[f]=y,d[f+1]=A,p+=b,v+=x,b+=g,x+=w,y+=p,A+=v}getBezierValue(e,t,s,i){let r=this.curves;if(r[i]>e){let a=this.frames[t],o=this.frames[t+s];return o+(e-a)/(r[i]-a)*(r[i+1]-o)}let h=i+18;for(i+=2;i<h;i+=2)if(r[i]>=e){let a=r[i-2],o=r[i-1];return o+(e-a)/(r[i]-a)*(r[i+1]-o)}t+=this.getFrameEntries();let l=r[h-2],n=r[h-1];return n+(e-l)/(this.frames[t]-l)*(this.frames[t+s]-n)}},yt=class extends St{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 r=2;r<=s;r+=2)if(t[r]>e){s=r-2;break}let i=this.curves[s>>1];switch(i){case 0:let r=t[s],h=t[s+1];return h+(e-r)/(t[s+2]-r)*(t[s+2+1]-h);case 1:return t[s+1]}return this.getBezierValue(e,s,1,i-2)}getRelativeValue(e,t,s,i,r){if(e<this.frames[0]){switch(s){case 0:return r;case 1:return i+(r-i)*t}return i}let h=this.getCurveValue(e);switch(s){case 0:return r+h*t;case 1:case 2:h+=r-i}return i+h*t}getAbsoluteValue(e,t,s,i,r){if(e<this.frames[0]){switch(s){case 0:return r;case 1:return i+(r-i)*t}return i}let h=this.getCurveValue(e);return s==0?r+(h-r)*t:i+(h-i)*t}getAbsoluteValue2(e,t,s,i,r,h){if(e<this.frames[0]){switch(s){case 0:return r;case 1:return i+(r-i)*t}return i}return s==0?r+(h-r)*t:i+(h-i)*t}getScaleValue(e,t,s,i,r,h){const l=this.frames;if(e<l[0]){switch(s){case 0:return h;case 1:return r+(h-r)*t}return r}let n=this.getCurveValue(e)*h;if(t==1)return s==3?r+n-h:n;if(i==1)switch(s){case 0:return h+(Math.abs(n)*L.signum(h)-h)*t;case 1:case 2:return r+(Math.abs(n)*L.signum(r)-r)*t}else{let a=0;switch(s){case 0:return a=Math.abs(h)*L.signum(n),a+(n-a)*t;case 1:case 2:return a=Math.abs(r)*L.signum(n),a+(n-a)*t}}return r+(n-h)*t}},he=class extends St{constructor(e,t,s,i){super(e,t,[s,i])}getFrameEntries(){return 3}setFrame(e,t,s,i){e*=3,this.frames[e]=t,this.frames[e+1]=s,this.frames[e+2]=i}},te=class extends yt{boneIndex=0;constructor(e,t,s){super(e,t,rt.rotate+"|"+s),this.boneIndex=s}apply(e,t,s,i,r,h,l){let n=e.bones[this.boneIndex];n.active&&(n.rotation=this.getRelativeValue(s,r,h,n.rotation,n.data.rotation))}},ke=class extends he{boneIndex=0;constructor(e,t,s){super(e,t,rt.x+"|"+s,rt.y+"|"+s),this.boneIndex=s}apply(e,t,s,i,r,h,l){let n=e.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)*r,n.y+=(n.data.y-n.y)*r}return}let o=0,c=0,d=ft.search(a,s,3),f=this.curves[d/3];switch(f){case 0:let m=a[d];o=a[d+1],c=a[d+2];let u=(s-m)/(a[d+3]-m);o+=(a[d+3+1]-o)*u,c+=(a[d+3+2]-c)*u;break;case 1:o=a[d+1],c=a[d+2];break;default:o=this.getBezierValue(s,d,1,f-2),c=this.getBezierValue(s,d,2,f+18-2)}switch(h){case 0:n.x=n.data.x+o*r,n.y=n.data.y+c*r;break;case 1:case 2:n.x+=(n.data.x+o-n.x)*r,n.y+=(n.data.y+c-n.y)*r;break;case 3:n.x+=o*r,n.y+=c*r}}},Fe=class extends yt{boneIndex=0;constructor(e,t,s){super(e,t,rt.x+"|"+s),this.boneIndex=s}apply(e,t,s,i,r,h,l){let n=e.bones[this.boneIndex];n.active&&(n.x=this.getRelativeValue(s,r,h,n.x,n.data.x))}},Xe=class extends yt{boneIndex=0;constructor(e,t,s){super(e,t,rt.y+"|"+s),this.boneIndex=s}apply(e,t,s,i,r,h,l){let n=e.bones[this.boneIndex];n.active&&(n.y=this.getRelativeValue(s,r,h,n.y,n.data.y))}},Le=class extends he{boneIndex=0;constructor(e,t,s){super(e,t,rt.scaleX+"|"+s,rt.scaleY+"|"+s),this.boneIndex=s}apply(e,t,s,i,r,h,l){let n=e.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)*r,n.scaleY+=(n.data.scaleY-n.scaleY)*r}return}let o,c,d=ft.search(a,s,3),f=this.curves[d/3];switch(f){case 0:let m=a[d];o=a[d+1],c=a[d+2];let u=(s-m)/(a[d+3]-m);o+=(a[d+3+1]-o)*u,c+=(a[d+3+2]-c)*u;break;case 1:o=a[d+1],c=a[d+2];break;default:o=this.getBezierValue(s,d,1,f-2),c=this.getBezierValue(s,d,2,f+18-2)}if(o*=n.data.scaleX,c*=n.data.scaleY,r==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)*L.signum(m)-m)*r,n.scaleY=u+(Math.abs(c)*L.signum(u)-u)*r;break;case 1:case 2:m=n.scaleX,u=n.scaleY,n.scaleX=m+(Math.abs(o)*L.signum(m)-m)*r,n.scaleY=u+(Math.abs(c)*L.signum(u)-u)*r;break;case 3:n.scaleX+=(o-n.data.scaleX)*r,n.scaleY+=(c-n.data.scaleY)*r}else switch(h){case 0:m=Math.abs(n.data.scaleX)*L.signum(o),u=Math.abs(n.data.scaleY)*L.signum(c),n.scaleX=m+(o-m)*r,n.scaleY=u+(c-u)*r;break;case 1:case 2:m=Math.abs(n.scaleX)*L.signum(o),u=Math.abs(n.scaleY)*L.signum(c),n.scaleX=m+(o-m)*r,n.scaleY=u+(c-u)*r;break;case 3:n.scaleX+=(o-n.data.scaleX)*r,n.scaleY+=(c-n.data.scaleY)*r}}}},Pe=class extends yt{boneIndex=0;constructor(e,t,s){super(e,t,rt.scaleX+"|"+s),this.boneIndex=s}apply(e,t,s,i,r,h,l){let n=e.bones[this.boneIndex];n.active&&(n.scaleX=this.getScaleValue(s,r,h,l,n.scaleX,n.data.scaleX))}},Be=class extends yt{boneIndex=0;constructor(e,t,s){super(e,t,rt.scaleY+"|"+s),this.boneIndex=s}apply(e,t,s,i,r,h,l){let n=e.bones[this.boneIndex];n.active&&(n.scaleY=this.getScaleValue(s,r,h,l,n.scaleY,n.data.scaleY))}},Ve=class extends he{boneIndex=0;constructor(e,t,s){super(e,t,rt.shearX+"|"+s,rt.shearY+"|"+s),this.boneIndex=s}apply(e,t,s,i,r,h,l){let n=e.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)*r,n.shearY+=(n.data.shearY-n.shearY)*r}return}let o=0,c=0,d=ft.search(a,s,3),f=this.curves[d/3];switch(f){case 0:let m=a[d];o=a[d+1],c=a[d+2];let u=(s-m)/(a[d+3]-m);o+=(a[d+3+1]-o)*u,c+=(a[d+3+2]-c)*u;break;case 1:o=a[d+1],c=a[d+2];break;default:o=this.getBezierValue(s,d,1,f-2),c=this.getBezierValue(s,d,2,f+18-2)}switch(h){case 0:n.shearX=n.data.shearX+o*r,n.shearY=n.data.shearY+c*r;break;case 1:case 2:n.shearX+=(n.data.shearX+o-n.shearX)*r,n.shearY+=(n.data.shearY+c-n.shearY)*r;break;case 3:n.shearX+=o*r,n.shearY+=c*r}}},Oe=class extends yt{boneIndex=0;constructor(e,t,s){super(e,t,rt.shearX+"|"+s),this.boneIndex=s}apply(e,t,s,i,r,h,l){let n=e.bones[this.boneIndex];n.active&&(n.shearX=this.getRelativeValue(s,r,h,n.shearX,n.data.shearX))}},De=class extends yt{boneIndex=0;constructor(e,t,s){super(e,t,rt.shearY+"|"+s),this.boneIndex=s}apply(e,t,s,i,r,h,l){let n=e.bones[this.boneIndex];n.active&&(n.shearY=this.getRelativeValue(s,r,h,n.shearY,n.data.shearY))}},Ne=class extends ft{boneIndex=0;constructor(e,t){super(e,[rt.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,i,r,h,l){let n=e.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[ft.search(a,s,2)+1]}},Ue=class extends St{slotIndex=0;constructor(e,t,s){super(e,t,[rt.rgb+"|"+s,rt.alpha+"|"+s]),this.slotIndex=s}getFrameEntries(){return 5}setFrame(e,t,s,i,r,h){e*=5,this.frames[e]=t,this.frames[e+1]=s,this.frames[e+2]=i,this.frames[e+3]=r,this.frames[e+4]=h}apply(e,t,s,i,r,h,l){let n=e.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.setFromColor(w);return;case 1:o.add((w.r-o.r)*r,(w.g-o.g)*r,(w.b-o.b)*r,(w.a-o.a)*r)}return}let c=0,d=0,f=0,m=0,u=ft.search(a,s,5),g=this.curves[u/5];switch(g){case 0:let w=a[u];c=a[u+1],d=a[u+2],f=a[u+3],m=a[u+4];let b=(s-w)/(a[u+5]-w);c+=(a[u+5+1]-c)*b,d+=(a[u+5+2]-d)*b,f+=(a[u+5+3]-f)*b,m+=(a[u+5+4]-m)*b;break;case 1:c=a[u+1],d=a[u+2],f=a[u+3],m=a[u+4];break;default:c=this.getBezierValue(s,u,1,g-2),d=this.getBezierValue(s,u,2,g+18-2),f=this.getBezierValue(s,u,3,g+18*2-2),m=this.getBezierValue(s,u,4,g+18*3-2)}r==1?o.set(c,d,f,m):(h==0&&o.setFromColor(n.data.color),o.add((c-o.r)*r,(d-o.g)*r,(f-o.b)*r,(m-o.a)*r))}},ze=class extends St{slotIndex=0;constructor(e,t,s){super(e,t,[rt.rgb+"|"+s]),this.slotIndex=s}getFrameEntries(){return 4}setFrame(e,t,s,i,r){e<<=2,this.frames[e]=t,this.frames[e+1]=s,this.frames[e+2]=i,this.frames[e+3]=r}apply(e,t,s,i,r,h,l){let n=e.slots[this.slotIndex];if(!n.bone.active)return;let a=this.frames,o=n.color;if(s<a[0]){let g=n.data.color;switch(h){case 0:o.r=g.r,o.g=g.g,o.b=g.b;return;case 1:o.r+=(g.r-o.r)*r,o.g+=(g.g-o.g)*r,o.b+=(g.b-o.b)*r}return}let c=0,d=0,f=0,m=ft.search(a,s,4),u=this.curves[m>>2];switch(u){case 0:let g=a[m];c=a[m+1],d=a[m+2],f=a[m+3];let w=(s-g)/(a[m+4]-g);c+=(a[m+4+1]-c)*w,d+=(a[m+4+2]-d)*w,f+=(a[m+4+3]-f)*w;break;case 1:c=a[m+1],d=a[m+2],f=a[m+3];break;default:c=this.getBezierValue(s,m,1,u-2),d=this.getBezierValue(s,m,2,u+18-2),f=this.getBezierValue(s,m,3,u+18*2-2)}if(r==1)o.r=c,o.g=d,o.b=f;else{if(h==0){let g=n.data.color;o.r=g.r,o.g=g.g,o.b=g.b}o.r+=(c-o.r)*r,o.g+=(d-o.g)*r,o.b+=(f-o.b)*r}}},We=class extends yt{slotIndex=0;constructor(e,t,s){super(e,t,rt.alpha+"|"+s),this.slotIndex=s}apply(e,t,s,i,r,h,l){let n=e.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)*r}return}let o=this.getCurveValue(s);r==1?a.a=o:(h==0&&(a.a=n.data.color.a),a.a+=(o-a.a)*r)}},qe=class extends St{slotIndex=0;constructor(e,t,s){super(e,t,[rt.rgb+"|"+s,rt.alpha+"|"+s,rt.rgb2+"|"+s]),this.slotIndex=s}getFrameEntries(){return 8}setFrame(e,t,s,i,r,h,l,n,a){e<<=3,this.frames[e]=t,this.frames[e+1]=s,this.frames[e+2]=i,this.frames[e+3]=r,this.frames[e+4]=h,this.frames[e+5]=l,this.frames[e+6]=n,this.frames[e+7]=a}apply(e,t,s,i,r,h,l){let n=e.slots[this.slotIndex];if(!n.bone.active)return;let a=this.frames,o=n.color,c=n.darkColor;if(s<a[0]){let v=n.data.color,y=n.data.darkColor;switch(h){case 0:o.setFromColor(v),c.r=y.r,c.g=y.g,c.b=y.b;return;case 1:o.add((v.r-o.r)*r,(v.g-o.g)*r,(v.b-o.b)*r,(v.a-o.a)*r),c.r+=(y.r-c.r)*r,c.g+=(y.g-c.g)*r,c.b+=(y.b-c.b)*r}return}let d=0,f=0,m=0,u=0,g=0,w=0,b=0,x=ft.search(a,s,8),p=this.curves[x>>3];switch(p){case 0:let v=a[x];d=a[x+1],f=a[x+2],m=a[x+3],u=a[x+4],g=a[x+5],w=a[x+6],b=a[x+7];let y=(s-v)/(a[x+8]-v);d+=(a[x+8+1]-d)*y,f+=(a[x+8+2]-f)*y,m+=(a[x+8+3]-m)*y,u+=(a[x+8+4]-u)*y,g+=(a[x+8+5]-g)*y,w+=(a[x+8+6]-w)*y,b+=(a[x+8+7]-b)*y;break;case 1:d=a[x+1],f=a[x+2],m=a[x+3],u=a[x+4],g=a[x+5],w=a[x+6],b=a[x+7];break;default:d=this.getBezierValue(s,x,1,p-2),f=this.getBezierValue(s,x,2,p+18-2),m=this.getBezierValue(s,x,3,p+18*2-2),u=this.getBezierValue(s,x,4,p+18*3-2),g=this.getBezierValue(s,x,5,p+18*4-2),w=this.getBezierValue(s,x,6,p+18*5-2),b=this.getBezierValue(s,x,7,p+18*6-2)}if(r==1)o.set(d,f,m,u),c.r=g,c.g=w,c.b=b;else{if(h==0){o.setFromColor(n.data.color);let v=n.data.darkColor;c.r=v.r,c.g=v.g,c.b=v.b}o.add((d-o.r)*r,(f-o.g)*r,(m-o.b)*r,(u-o.a)*r),c.r+=(g-c.r)*r,c.g+=(w-c.g)*r,c.b+=(b-c.b)*r}}},Ge=class extends St{slotIndex=0;constructor(e,t,s){super(e,t,[rt.rgb+"|"+s,rt.rgb2+"|"+s]),this.slotIndex=s}getFrameEntries(){return 7}setFrame(e,t,s,i,r,h,l,n){e*=7,this.frames[e]=t,this.frames[e+1]=s,this.frames[e+2]=i,this.frames[e+3]=r,this.frames[e+4]=h,this.frames[e+5]=l,this.frames[e+6]=n}apply(e,t,s,i,r,h,l){let n=e.slots[this.slotIndex];if(!n.bone.active)return;let a=this.frames,o=n.color,c=n.darkColor;if(s<a[0]){let v=n.data.color,y=n.data.darkColor;switch(h){case 0:o.r=v.r,o.g=v.g,o.b=v.b,c.r=y.r,c.g=y.g,c.b=y.b;return;case 1:o.r+=(v.r-o.r)*r,o.g+=(v.g-o.g)*r,o.b+=(v.b-o.b)*r,c.r+=(y.r-c.r)*r,c.g+=(y.g-c.g)*r,c.b+=(y.b-c.b)*r}return}let d=0,f=0,m=0,u=0,g=0,w=0,b=0,x=ft.search(a,s,7),p=this.curves[x/7];switch(p){case 0:let v=a[x];d=a[x+1],f=a[x+2],m=a[x+3],g=a[x+4],w=a[x+5],b=a[x+6];let y=(s-v)/(a[x+7]-v);d+=(a[x+7+1]-d)*y,f+=(a[x+7+2]-f)*y,m+=(a[x+7+3]-m)*y,g+=(a[x+7+4]-g)*y,w+=(a[x+7+5]-w)*y,b+=(a[x+7+6]-b)*y;break;case 1:d=a[x+1],f=a[x+2],m=a[x+3],g=a[x+4],w=a[x+5],b=a[x+6];break;default:d=this.getBezierValue(s,x,1,p-2),f=this.getBezierValue(s,x,2,p+18-2),m=this.getBezierValue(s,x,3,p+18*2-2),g=this.getBezierValue(s,x,4,p+18*3-2),w=this.getBezierValue(s,x,5,p+18*4-2),b=this.getBezierValue(s,x,6,p+18*5-2)}if(r==1)o.r=d,o.g=f,o.b=m,c.r=g,c.g=w,c.b=b;else{if(h==0){let v=n.data.color,y=n.data.darkColor;o.r=v.r,o.g=v.g,o.b=v.b,c.r=y.r,c.g=y.g,c.b=y.b}o.r+=(d-o.r)*r,o.g+=(f-o.g)*r,o.b+=(m-o.b)*r,c.r+=(g-c.r)*r,c.g+=(w-c.g)*r,c.b+=(b-c.b)*r}}},Ot=class extends ft{slotIndex=0;attachmentNames;constructor(e,t){super(e,[rt.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,i,r,h,l){let n=e.slots[this.slotIndex];if(n.bone.active){if(l==1){h==0&&this.setAttachment(e,n,n.data.attachmentName);return}if(s<this.frames[0]){(h==0||h==1)&&this.setAttachment(e,n,n.data.attachmentName);return}this.setAttachment(e,n,this.attachmentNames[ft.search1(this.frames,s)])}}setAttachment(e,t,s){t.setAttachment(s?e.getAttachment(this.slotIndex,s):null)}},He=class extends St{slotIndex=0;attachment;vertices;constructor(e,t,s,i){super(e,t,[rt.deform+"|"+s+"|"+i.id]),this.slotIndex=s,this.attachment=i,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,i,r,h,l,n,a,o,c){let d=this.curves,f=this.getFrameCount()+e*18;s==0&&(d[t]=2+f);let m=(i-h*2+n)*.03,u=a*.03-l*.06,g=((h-n)*3-i+o)*.006,w=(l-a+.33333333)*.018,b=m*2+g,x=u*2+w,p=(h-i)*.3+m+g*.16666667,v=l*.3+u+w*.16666667,y=i+p,A=v;for(let C=f+18;f<C;f+=2)d[f]=y,d[f+1]=A,p+=b,v+=x,b+=g,x+=w,y+=p,A+=v}getCurvePercent(e,t){let s=this.curves,i=s[t];switch(i){case 0:let n=this.frames[t];return(e-n)/(this.frames[t+this.getFrameEntries()]-n);case 1:return 0}if(i-=2,s[i]>e){let n=this.frames[t];return s[i+1]*(e-n)/(s[i]-n)}let r=i+18;for(i+=2;i<r;i+=2)if(s[i]>=e){let n=s[i-2],a=s[i-1];return a+(e-n)/(s[i]-n)*(s[i+1]-a)}let h=s[r-2],l=s[r-1];return l+(1-l)*(e-h)/(this.frames[t+this.getFrameEntries()]-h)}apply(e,t,s,i,r,h,l){let n=e.slots[this.slotIndex];if(!n.bone.active)return;let a=n.getAttachment();if(!a||!(a instanceof Rt)||a.timelineAttachment!=this.attachment)return;let o=n.deform;o.length==0&&(h=0);let c=this.vertices,d=c[0].length,f=this.frames;if(s<f[0]){switch(h){case 0:o.length=0;return;case 1:if(r==1){o.length=0;return}o.length=d;let x=a;if(x.bones){r=1-r;for(var m=0;m<d;m++)o[m]*=r}else{let p=x.vertices;for(var m=0;m<d;m++)o[m]+=(p[m]-o[m])*r}}return}if(o.length=d,s>=f[f.length-1]){let x=c[f.length-1];if(r==1)if(h==3){let p=a;if(p.bones)for(let v=0;v<d;v++)o[v]+=x[v];else{let v=p.vertices;for(let y=0;y<d;y++)o[y]+=x[y]-v[y]}}else P.arrayCopy(x,0,o,0,d);else switch(h){case 0:{let v=a;if(v.bones)for(let y=0;y<d;y++)o[y]=x[y]*r;else{let y=v.vertices;for(let A=0;A<d;A++){let C=y[A];o[A]=C+(x[A]-C)*r}}break}case 1:case 2:for(let v=0;v<d;v++)o[v]+=(x[v]-o[v])*r;break;case 3:let p=a;if(p.bones)for(let v=0;v<d;v++)o[v]+=x[v]*r;else{let v=p.vertices;for(let y=0;y<d;y++)o[y]+=(x[y]-v[y])*r}}return}let u=ft.search1(f,s),g=this.getCurvePercent(s,u),w=c[u],b=c[u+1];if(r==1)if(h==3){let x=a;if(x.bones)for(let p=0;p<d;p++){let v=w[p];o[p]+=v+(b[p]-v)*g}else{let p=x.vertices;for(let v=0;v<d;v++){let y=w[v];o[v]+=y+(b[v]-y)*g-p[v]}}}else for(let x=0;x<d;x++){let p=w[x];o[x]=p+(b[x]-p)*g}else switch(h){case 0:{let p=a;if(p.bones)for(let v=0;v<d;v++){let y=w[v];o[v]=(y+(b[v]-y)*g)*r}else{let v=p.vertices;for(let y=0;y<d;y++){let A=w[y],C=v[y];o[y]=C+(A+(b[y]-A)*g-C)*r}}break}case 1:case 2:for(let p=0;p<d;p++){let v=w[p];o[p]+=(v+(b[p]-v)*g-o[p])*r}break;case 3:let x=a;if(x.bones)for(let p=0;p<d;p++){let v=w[p];o[p]+=(v+(b[p]-v)*g)*r}else{let p=x.vertices;for(let v=0;v<d;v++){let y=w[v];o[v]+=(y+(b[v]-y)*g-p[v])*r}}}}},ce=class Pi extends ft{static propertyIds=[""+rt.event];events;constructor(t){super(t,Pi.propertyIds),this.events=new Array(t)}getFrameCount(){return this.frames.length}setFrame(t,s){this.frames[t]=s.time,this.events[t]=s}apply(t,s,i,r,h,l,n){if(!r)return;let a=this.frames,o=this.frames.length;if(s>i)this.apply(t,s,Number.MAX_VALUE,r,h,l,n),s=-1;else if(s>=a[o-1])return;if(i<a[0])return;let c=0;if(s<a[0])c=0;else{c=ft.search1(a,s)+1;let d=a[c];for(;c>0&&a[c-1]==d;)c--}for(;c<o&&i>=a[c];c++)r.push(this.events[c])}},qt=class Bi extends ft{static propertyIds=[""+rt.drawOrder];drawOrders;constructor(t){super(t,Bi.propertyIds),this.drawOrders=new Array(t)}getFrameCount(){return this.frames.length}setFrame(t,s,i){this.frames[t]=s,this.drawOrders[t]=i}apply(t,s,i,r,h,l,n){if(n==1){l==0&&P.arrayCopy(t.slots,0,t.drawOrder,0,t.slots.length);return}if(i<this.frames[0]){(l==0||l==1)&&P.arrayCopy(t.slots,0,t.drawOrder,0,t.slots.length);return}let a=ft.search1(this.frames,i),o=this.drawOrders[a];if(!o)P.arrayCopy(t.slots,0,t.drawOrder,0,t.slots.length);else{let c=t.drawOrder,d=t.slots;for(let f=0,m=o.length;f<m;f++)c[f]=d[o[f]]}}},_e=class extends St{constraintIndex=0;constructor(e,t,s){super(e,t,[rt.ikConstraint+"|"+s]),this.constraintIndex=s}getFrameEntries(){return 6}setFrame(e,t,s,i,r,h,l){e*=6,this.frames[e]=t,this.frames[e+1]=s,this.frames[e+2]=i,this.frames[e+3]=r,this.frames[e+4]=h?1:0,this.frames[e+5]=l?1:0}apply(e,t,s,i,r,h,l){let n=e.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)*r,n.softness+=(n.data.softness-n.softness)*r,n.bendDirection=n.data.bendDirection,n.compress=n.data.compress,n.stretch=n.data.stretch}return}let o=0,c=0,d=ft.search(a,s,6),f=this.curves[d/6];switch(f){case 0:let m=a[d];o=a[d+1],c=a[d+2];let u=(s-m)/(a[d+6]-m);o+=(a[d+6+1]-o)*u,c+=(a[d+6+2]-c)*u;break;case 1:o=a[d+1],c=a[d+2];break;default:o=this.getBezierValue(s,d,1,f-2),c=this.getBezierValue(s,d,2,f+18-2)}h==0?(n.mix=n.data.mix+(o-n.data.mix)*r,n.softness=n.data.softness+(c-n.data.softness)*r,l==1?(n.bendDirection=n.data.bendDirection,n.compress=n.data.compress,n.stretch=n.data.stretch):(n.bendDirection=a[d+3],n.compress=a[d+4]!=0,n.stretch=a[d+5]!=0)):(n.mix+=(o-n.mix)*r,n.softness+=(c-n.softness)*r,l==0&&(n.bendDirection=a[d+3],n.compress=a[d+4]!=0,n.stretch=a[d+5]!=0))}},je=class extends St{constraintIndex=0;constructor(e,t,s){super(e,t,[rt.transformConstraint+"|"+s]),this.constraintIndex=s}getFrameEntries(){return 7}setFrame(e,t,s,i,r,h,l,n){let a=this.frames;e*=7,a[e]=t,a[e+1]=s,a[e+2]=i,a[e+3]=r,a[e+4]=h,a[e+5]=l,a[e+6]=n}apply(e,t,s,i,r,h,l){let n=e.transformConstraints[this.constraintIndex];if(!n.active)return;let a=this.frames;if(s<a[0]){let b=n.data;switch(h){case 0:n.mixRotate=b.mixRotate,n.mixX=b.mixX,n.mixY=b.mixY,n.mixScaleX=b.mixScaleX,n.mixScaleY=b.mixScaleY,n.mixShearY=b.mixShearY;return;case 1:n.mixRotate+=(b.mixRotate-n.mixRotate)*r,n.mixX+=(b.mixX-n.mixX)*r,n.mixY+=(b.mixY-n.mixY)*r,n.mixScaleX+=(b.mixScaleX-n.mixScaleX)*r,n.mixScaleY+=(b.mixScaleY-n.mixScaleY)*r,n.mixShearY+=(b.mixShearY-n.mixShearY)*r}return}let o,c,d,f,m,u,g=ft.search(a,s,7),w=this.curves[g/7];switch(w){case 0:let b=a[g];o=a[g+1],c=a[g+2],d=a[g+3],f=a[g+4],m=a[g+5],u=a[g+6];let x=(s-b)/(a[g+7]-b);o+=(a[g+7+1]-o)*x,c+=(a[g+7+2]-c)*x,d+=(a[g+7+3]-d)*x,f+=(a[g+7+4]-f)*x,m+=(a[g+7+5]-m)*x,u+=(a[g+7+6]-u)*x;break;case 1:o=a[g+1],c=a[g+2],d=a[g+3],f=a[g+4],m=a[g+5],u=a[g+6];break;default:o=this.getBezierValue(s,g,1,w-2),c=this.getBezierValue(s,g,2,w+18-2),d=this.getBezierValue(s,g,3,w+18*2-2),f=this.getBezierValue(s,g,4,w+18*3-2),m=this.getBezierValue(s,g,5,w+18*4-2),u=this.getBezierValue(s,g,6,w+18*5-2)}if(h==0){let b=n.data;n.mixRotate=b.mixRotate+(o-b.mixRotate)*r,n.mixX=b.mixX+(c-b.mixX)*r,n.mixY=b.mixY+(d-b.mixY)*r,n.mixScaleX=b.mixScaleX+(f-b.mixScaleX)*r,n.mixScaleY=b.mixScaleY+(m-b.mixScaleY)*r,n.mixShearY=b.mixShearY+(u-b.mixShearY)*r}else n.mixRotate+=(o-n.mixRotate)*r,n.mixX+=(c-n.mixX)*r,n.mixY+=(d-n.mixY)*r,n.mixScaleX+=(f-n.mixScaleX)*r,n.mixScaleY+=(m-n.mixScaleY)*r,n.mixShearY+=(u-n.mixShearY)*r}},Ze=class extends yt{constraintIndex=0;constructor(e,t,s){super(e,t,rt.pathConstraintPosition+"|"+s),this.constraintIndex=s}apply(e,t,s,i,r,h,l){let n=e.pathConstraints[this.constraintIndex];n.active&&(n.position=this.getAbsoluteValue(s,r,h,n.position,n.data.position))}},Ke=class extends yt{constraintIndex=0;constructor(e,t,s){super(e,t,rt.pathConstraintSpacing+"|"+s),this.constraintIndex=s}apply(e,t,s,i,r,h,l){let n=e.pathConstraints[this.constraintIndex];n.active&&(n.spacing=this.getAbsoluteValue(s,r,h,n.spacing,n.data.spacing))}},Je=class extends St{constraintIndex=0;constructor(e,t,s){super(e,t,[rt.pathConstraintMix+"|"+s]),this.constraintIndex=s}getFrameEntries(){return 4}setFrame(e,t,s,i,r){let h=this.frames;e<<=2,h[e]=t,h[e+1]=s,h[e+2]=i,h[e+3]=r}apply(e,t,s,i,r,h,l){let n=e.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)*r,n.mixX+=(n.data.mixX-n.mixX)*r,n.mixY+=(n.data.mixY-n.mixY)*r}return}let o,c,d,f=ft.search(a,s,4),m=this.curves[f>>2];switch(m){case 0:let u=a[f];o=a[f+1],c=a[f+2],d=a[f+3];let g=(s-u)/(a[f+4]-u);o+=(a[f+4+1]-o)*g,c+=(a[f+4+2]-c)*g,d+=(a[f+4+3]-d)*g;break;case 1:o=a[f+1],c=a[f+2],d=a[f+3];break;default:o=this.getBezierValue(s,f,1,m-2),c=this.getBezierValue(s,f,2,m+18-2),d=this.getBezierValue(s,f,3,m+18*2-2)}if(h==0){let u=n.data;n.mixRotate=u.mixRotate+(o-u.mixRotate)*r,n.mixX=u.mixX+(c-u.mixX)*r,n.mixY=u.mixY+(d-u.mixY)*r}else n.mixRotate+=(o-n.mixRotate)*r,n.mixX+=(c-n.mixX)*r,n.mixY+=(d-n.mixY)*r}},Lt=class extends yt{constraintIndex=0;constructor(e,t,s,i){super(e,t,i+"|"+s),this.constraintIndex=s}apply(e,t,s,i,r,h,l){let n;if(this.constraintIndex==-1){const a=s>=this.frames[0]?this.getCurveValue(s):0;for(const o of e.physicsConstraints)o.active&&this.global(o.data)&&this.set(o,this.getAbsoluteValue2(s,r,h,this.get(o),this.setup(o),a))}else n=e.physicsConstraints[this.constraintIndex],n.active&&this.set(n,this.getAbsoluteValue(s,r,h,this.get(n),this.setup(n)))}},Qe=class extends Lt{constructor(e,t,s){super(e,t,s,rt.physicsConstraintInertia)}setup(e){return e.data.inertia}get(e){return e.inertia}set(e,t){e.inertia=t}global(e){return e.inertiaGlobal}},$e=class extends Lt{constructor(e,t,s){super(e,t,s,rt.physicsConstraintStrength)}setup(e){return e.data.strength}get(e){return e.strength}set(e,t){e.strength=t}global(e){return e.strengthGlobal}},ts=class extends Lt{constructor(e,t,s){super(e,t,s,rt.physicsConstraintDamping)}setup(e){return e.data.damping}get(e){return e.damping}set(e,t){e.damping=t}global(e){return e.dampingGlobal}},es=class extends Lt{constructor(e,t,s){super(e,t,s,rt.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}},ss=class extends Lt{constructor(e,t,s){super(e,t,s,rt.physicsConstraintWind)}setup(e){return e.data.wind}get(e){return e.wind}set(e,t){e.wind=t}global(e){return e.windGlobal}},is=class extends Lt{constructor(e,t,s){super(e,t,s,rt.physicsConstraintGravity)}setup(e){return e.data.gravity}get(e){return e.gravity}set(e,t){e.gravity=t}global(e){return e.gravityGlobal}},rs=class extends Lt{constructor(e,t,s){super(e,t,s,rt.physicsConstraintMix)}setup(e){return e.data.mix}get(e){return e.mix}set(e,t){e.mix=t}global(e){return e.mixGlobal}},ns=class Vi extends ft{static propertyIds=[rt.physicsConstraintReset.toString()];constraintIndex;constructor(t,s){super(t,Vi.propertyIds),this.constraintIndex=s}getFrameCount(){return this.frames.length}setFrame(t,s){this.frames[t]=s}apply(t,s,i,r,h,l,n){let a;if(this.constraintIndex!=-1&&(a=t.physicsConstraints[this.constraintIndex],!a.active))return;const o=this.frames;if(s>i)this.apply(t,s,Number.MAX_VALUE,[],h,l,n),s=-1;else if(s>=o[o.length-1])return;if(!(i<o[0])&&(s<o[0]||i>=o[ft.search1(o,s)+1]))if(a!=null)a.reset();else for(const c of t.physicsConstraints)c.active&&c.reset()}},as=class Pt extends ft{static ENTRIES=3;static MODE=1;static DELAY=2;slotIndex;attachment;constructor(t,s,i){super(t,[rt.sequence+"|"+s+"|"+i.sequence.id]),this.slotIndex=s,this.attachment=i}getFrameEntries(){return Pt.ENTRIES}getSlotIndex(){return this.slotIndex}getAttachment(){return this.attachment}setFrame(t,s,i,r,h){let l=this.frames;t*=Pt.ENTRIES,l[t]=s,l[t+Pt.MODE]=i|r<<4,l[t+Pt.DELAY]=h}apply(t,s,i,r,h,l,n){let a=t.slots[this.slotIndex];if(!a.bone.active)return;let o=a.attachment,c=this.attachment;if(o!=c&&(!(o instanceof Rt)||o.timelineAttachment!=c))return;if(n==1){l==0&&(a.sequenceIndex=-1);return}let d=this.frames;if(i<d[0]){(l==0||l==1)&&(a.sequenceIndex=-1);return}let f=ft.search(d,i,Pt.ENTRIES),m=d[f],u=d[f+Pt.MODE],g=d[f+Pt.DELAY];if(!this.attachment.sequence)return;let w=u>>4,b=this.attachment.sequence.regions.length,x=Ks[u&15];if(x!=0)switch(w+=(i-m)/g+1e-5|0,x){case 1:w=Math.min(b-1,w);break;case 2:w%=b;break;case 3:{let p=(b<<1)-2;w=p==0?0:w%p,w>=b&&(w=p-w);break}case 4:w=Math.max(b-1-w,0);break;case 5:w=b-1-w%b;break;case 6:{let p=(b<<1)-2;w=p==0?0:(w+b-1)%p,w>=b&&(w=p-w)}}a.sequenceIndex=w}},ji=class Ce{static _emptyAnimation=new oe("<empty>",[],0);static emptyAnimation(){return Ce._emptyAnimation}data;tracks=new Array;timeScale=1;unkeyedState=0;events=new Array;listeners=new Array;queue=new ti(this);propertyIDs=new Ee;animationsChanged=!1;trackEntryPool=new $t(()=>new $s);constructor(t){this.data=t}update(t){t*=this.timeScale;let s=this.tracks;for(let i=0,r=s.length;i<r;i++){let h=s[i];if(!h)continue;h.animationLast=h.nextAnimationLast,h.trackLast=h.nextTrackLast;let l=t*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+t)*n.timeScale,h.trackTime+=l,this.setCurrent(i,n,!0);n.mixingFrom;)n.mixTime+=t,n=n.mixingFrom;continue}}else if(h.trackLast>=h.trackEnd&&!h.mixingFrom){s[i]=null,this.queue.end(h),this.clearNext(h);continue}if(h.mixingFrom&&this.updateMixingFrom(h,t)){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(t,s){let i=t.mixingFrom;if(!i)return!0;let r=this.updateMixingFrom(i,s);return i.animationLast=i.nextAnimationLast,i.trackLast=i.nextTrackLast,t.nextTrackLast!=-1&&t.mixTime>=t.mixDuration?((i.totalAlpha==0||t.mixDuration==0)&&(t.mixingFrom=i.mixingFrom,i.mixingFrom!=null&&(i.mixingFrom.mixingTo=t),t.interruptAlpha=i.interruptAlpha,this.queue.end(i)),r):(i.trackTime+=s*i.timeScale,t.mixTime+=s,!1)}apply(t){if(!t)throw new Error("skeleton cannot be null.");this.animationsChanged&&this._animationsChanged();let s=this.events,i=this.tracks,r=!1;for(let f=0,m=i.length;f<m;f++){let u=i[f];if(!u||u.delay>0)continue;r=!0;let g=f==0?1:u.mixBlend,w=u.alpha;u.mixingFrom?w*=this.applyMixingFrom(u,t,g):u.trackTime>=u.trackEnd&&!u.next&&(w=0);let b=w>=u.alphaAttachmentThreshold,x=u.animationLast,p=u.getAnimationTime(),v=p,y=s;u.reverse&&(v=u.animation.duration-v,y=null);let A=u.animation.timelines,C=A.length;if(f==0&&w==1||g==3){f==0&&(b=!0);for(let S=0;S<C;S++){P.webkit602BugfixHelper(w,g);var h=A[S];h instanceof Ot?this.applyAttachmentTimeline(h,t,v,g,b):h.apply(t,x,v,y,w,g,0)}}else{let S=u.timelineMode,T=u.shortestRotation,R=!T&&u.timelinesRotation.length!=C<<1;R&&(u.timelinesRotation.length=C<<1);for(let k=0;k<C;k++){let F=A[k],X=S[k]==de?g:0;!T&&F instanceof te?this.applyRotateTimeline(F,t,v,w,X,u.timelinesRotation,k<<1,R):F instanceof Ot?this.applyAttachmentTimeline(F,t,v,g,b):(P.webkit602BugfixHelper(w,g),F.apply(t,x,v,y,w,X,0))}}this.queueEvents(u,p),s.length=0,u.nextAnimationLast=p,u.nextTrackLast=u.trackTime}for(var l=this.unkeyedState+hs,n=t.slots,a=0,o=t.slots.length;a<o;a++){var c=n[a];if(c.attachmentState==l){var d=c.data.attachmentName;c.setAttachment(d?t.getAttachment(c.data.index,d):null)}}return this.unkeyedState+=2,this.queue.drain(),r}applyMixingFrom(t,s,i){let r=t.mixingFrom;r.mixingFrom&&this.applyMixingFrom(r,s,i);let h=0;t.mixDuration==0?(h=1,i==1&&(i=0)):(h=t.mixTime/t.mixDuration,h>1&&(h=1),i!=1&&(i=r.mixBlend));let l=h<r.mixAttachmentThreshold,n=h<r.mixDrawOrderThreshold,a=r.animation.timelines,o=a.length,c=r.alpha*t.interruptAlpha,d=c*(1-h),f=r.animationLast,m=r.getAnimationTime(),u=m,g=null;if(r.reverse?u=r.animation.duration-u:h<r.eventThreshold&&(g=this.events),i==3)for(let w=0;w<o;w++)a[w].apply(s,f,u,g,d,i,1);else{let w=r.timelineMode,b=r.timelineHoldMix,x=r.shortestRotation,p=!x&&r.timelinesRotation.length!=o<<1;p&&(r.timelinesRotation.length=o<<1),r.totalAlpha=0;for(let v=0;v<o;v++){let y=a[v],A=1,C,S=0;switch(w[v]){case de:if(!n&&y instanceof qt)continue;C=i,S=d;break;case ls:C=0,S=d;break;case os:C=i,S=c;break;case fe:C=0,S=c;break;default:C=0;let T=b[v];S=c*Math.max(0,1-T.mixTime/T.mixDuration);break}r.totalAlpha+=S,!x&&y instanceof te?this.applyRotateTimeline(y,s,u,S,C,r.timelinesRotation,v<<1,p):y instanceof Ot?this.applyAttachmentTimeline(y,s,u,C,l&&S>=r.alphaAttachmentThreshold):(P.webkit602BugfixHelper(S,i),n&&y instanceof qt&&C==0&&(A=0),y.apply(s,f,u,g,S,C,A))}}return t.mixDuration>0&&this.queueEvents(r,m),this.events.length=0,r.nextAnimationLast=m,r.nextTrackLast=r.trackTime,h}applyAttachmentTimeline(t,s,i,r,h){var l=s.slots[t.slotIndex];l.bone.active&&(i<t.frames[0]?(r==0||r==1)&&this.setAttachment(s,l,l.data.attachmentName,h):this.setAttachment(s,l,t.attachmentNames[ft.search1(t.frames,i)],h),l.attachmentState<=this.unkeyedState&&(l.attachmentState=this.unkeyedState+hs))}setAttachment(t,s,i,r){s.setAttachment(i?t.getAttachment(s.data.index,i):null),r&&(s.attachmentState=this.unkeyedState+ii)}applyRotateTimeline(t,s,i,r,h,l,n,a){if(a&&(l[n]=0),r==1){t.apply(s,0,i,null,1,h,0);return}let o=s.bones[t.boneIndex];if(!o.active)return;let c=t.frames,d=0,f=0;if(i<c[0])switch(h){case 0:o.rotation=o.data.rotation;default:return;case 1:d=o.rotation,f=o.data.rotation}else d=h==0?o.data.rotation:o.rotation,f=o.data.rotation+t.getCurveValue(i);let m=0,u=f-d;if(u-=Math.ceil(u/360-.5)*360,u==0)m=l[n];else{let g=0,w=0;a?(g=0,w=u):(g=l[n],w=l[n+1]);let b=g-g%360;m=u+b;let x=u>=0,p=g>=0;Math.abs(w)<=90&&L.signum(w)!=L.signum(u)&&(Math.abs(g-b)>180?(m+=360*L.signum(g),p=x):b!=0?m-=360*L.signum(g):p=x),p!=x&&(m+=360*L.signum(g)),l[n]=m}l[n+1]=u,o.rotation=d+m*r}queueEvents(t,s){let i=t.animationStart,r=t.animationEnd,h=r-i,l=t.trackLast%h,n=this.events,a=0,o=n.length;for(;a<o;a++){let d=n[a];if(d.time<l)break;d.time>r||this.queue.event(t,d)}let c=!1;if(t.loop)if(h==0)c=!0;else{const d=Math.floor(t.trackTime/h);c=d>0&&d>Math.floor(t.trackLast/h)}else c=s>=r&&t.animationLast<r;for(c&&this.queue.complete(t);a<o;a++){let d=n[a];d.time<i||this.queue.event(t,d)}}clearTracks(){let t=this.queue.drainDisabled;this.queue.drainDisabled=!0;for(let s=0,i=this.tracks.length;s<i;s++)this.clearTrack(s);this.tracks.length=0,this.queue.drainDisabled=t,this.queue.drain()}clearTrack(t){if(t>=this.tracks.length)return;let s=this.tracks[t];if(!s)return;this.queue.end(s),this.clearNext(s);let i=s;for(;;){let r=i.mixingFrom;if(!r)break;this.queue.end(r),i.mixingFrom=null,i.mixingTo=null,i=r}this.tracks[s.trackIndex]=null,this.queue.drain()}setCurrent(t,s,i){let r=this.expandToIndex(t);this.tracks[t]=s,s.previous=null,r&&(i&&this.queue.interrupt(r),s.mixingFrom=r,r.mixingTo=s,s.mixTime=0,r.mixingFrom&&r.mixDuration>0&&(s.interruptAlpha*=Math.min(1,r.mixTime/r.mixDuration)),r.timelinesRotation.length=0),this.queue.start(s)}setAnimation(t,s,i=!1){let r=this.data.skeletonData.findAnimation(s);if(!r)throw new Error("Animation not found: "+s);return this.setAnimationWith(t,r,i)}setAnimationWith(t,s,i=!1){if(!s)throw new Error("animation cannot be null.");let r=!0,h=this.expandToIndex(t);h&&(h.nextTrackLast==-1?(this.tracks[t]=h.mixingFrom,this.queue.interrupt(h),this.queue.end(h),this.clearNext(h),h=h.mixingFrom,r=!1):this.clearNext(h));let l=this.trackEntry(t,s,i,h);return this.setCurrent(t,l,r),this.queue.drain(),l}addAnimation(t,s,i=!1,r=0){let h=this.data.skeletonData.findAnimation(s);if(!h)throw new Error("Animation not found: "+s);return this.addAnimationWith(t,h,i,r)}addAnimationWith(t,s,i=!1,r=0){if(!s)throw new Error("animation cannot be null.");let h=this.expandToIndex(t);if(h)for(;h.next;)h=h.next;let l=this.trackEntry(t,s,i,h);return h?(h.next=l,l.previous=h,r<=0&&(r=Math.max(r+h.getTrackComplete()-l.mixDuration,0))):(this.setCurrent(t,l,!0),this.queue.drain(),r<0&&(r=0)),l.delay=r,l}setEmptyAnimation(t,s=0){let i=this.setAnimationWith(t,Ce.emptyAnimation(),!1);return i.mixDuration=s,i.trackEnd=s,i}addEmptyAnimation(t,s=0,i=0){let r=this.addAnimationWith(t,Ce.emptyAnimation(),!1,i);return i<=0&&(r.delay=Math.max(r.delay+r.mixDuration-s,0)),r.mixDuration=s,r.trackEnd=s,r}setEmptyAnimations(t=0){let s=this.queue.drainDisabled;this.queue.drainDisabled=!0;for(let i=0,r=this.tracks.length;i<r;i++){let h=this.tracks[i];h&&this.setEmptyAnimation(h.trackIndex,t)}this.queue.drainDisabled=s,this.queue.drain()}expandToIndex(t){return t<this.tracks.length?this.tracks[t]:(P.ensureArrayCapacity(this.tracks,t+1,null),this.tracks.length=t+1,null)}trackEntry(t,s,i,r){let h=this.trackEntryPool.obtain();return h.reset(),h.trackIndex=t,h.animation=s,h.loop=i,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=r?this.data.getMix(r.animation,s):0,h.interruptAlpha=1,h.totalAlpha=0,h.mixBlend=2,h}clearNext(t){let s=t.next;for(;s;)this.queue.dispose(s),s=s.next;t.next=null}_animationsChanged(){this.animationsChanged=!1,this.propertyIDs.clear();let t=this.tracks;for(let s=0,i=t.length;s<i;s++){let r=t[s];if(r){for(;r.mixingFrom;)r=r.mixingFrom;do(!r.mixingTo||r.mixBlend!=3)&&this.computeHold(r),r=r.mixingTo;while(r)}}}computeHold(t){let s=t.mixingTo,i=t.animation.timelines,r=t.animation.timelines.length,h=t.timelineMode;h.length=r;let l=t.timelineHoldMix;l.length=0;let n=this.propertyIDs;if(s&&s.holdPrevious){for(let a=0;a<r;a++)h[a]=n.addAll(i[a].getPropertyIds())?fe:os;return}t:for(let a=0;a<r;a++){let o=i[a],c=o.getPropertyIds();if(!n.addAll(c))h[a]=de;else if(!s||o instanceof Ot||o instanceof qt||o instanceof ce||!s.animation.hasTimeline(c))h[a]=ls;else{for(let d=s.mixingTo;d;d=d.mixingTo)if(!d.animation.hasTimeline(c)){if(t.mixDuration>0){h[a]=si,l[a]=d;continue t}break}h[a]=fe}}}getCurrent(t){return t>=this.tracks.length?null:this.tracks[t]}addListener(t){if(!t)throw new Error("listener cannot be null.");this.listeners.push(t)}removeListener(t){let s=this.listeners.indexOf(t);s>=0&&this.listeners.splice(s,1)}clearListeners(){this.listeners.length=0}clearListenerNotifications(){this.queue.clear()}},$s=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}},ti=class{objects=[];drainDisabled=!1;animState;constructor(e){this.animState=e}start(e){this.objects.push(0),this.objects.push(e),this.animState.animationsChanged=!0}interrupt(e){this.objects.push(1),this.objects.push(e)}end(e){this.objects.push(2),this.objects.push(e),this.animState.animationsChanged=!0}dispose(e){this.objects.push(3),this.objects.push(e)}complete(e){this.objects.push(4),this.objects.push(e)}event(e,t){this.objects.push(5),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 i=e[s],r=e[s+1];switch(i){case 0:r.listener&&r.listener.start&&r.listener.start(r);for(let l=0;l<t.length;l++){let n=t[l];n.start&&n.start(r)}break;case 1:r.listener&&r.listener.interrupt&&r.listener.interrupt(r);for(let l=0;l<t.length;l++){let n=t[l];n.interrupt&&n.interrupt(r)}break;case 2:r.listener&&r.listener.end&&r.listener.end(r);for(let l=0;l<t.length;l++){let n=t[l];n.end&&n.end(r)}case 3:r.listener&&r.listener.dispose&&r.listener.dispose(r);for(let l=0;l<t.length;l++){let n=t[l];n.dispose&&n.dispose(r)}this.animState.trackEntryPool.free(r);break;case 4:r.listener&&r.listener.complete&&r.listener.complete(r);for(let l=0;l<t.length;l++){let n=t[l];n.complete&&n.complete(r)}break;case 5:let h=e[s+++2];r.listener&&r.listener.event&&r.listener.event(r,h);for(let l=0;l<t.length;l++){let n=t[l];n.event&&n.event(r,h)}break}}this.clear(),this.drainDisabled=!1}clear(){this.objects.length=0}},ei=(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))(ei||{}),Zi=class{start(e){}interrupt(e){}end(e){}dispose(e){}complete(e){}event(e,t){}},de=0,ls=1,os=2,fe=3,si=4,hs=1,ii=2,Ki=class{skeletonData;animationToMixTime={};defaultMix=0;constructor(e){if(!e)throw new Error("skeletonData cannot be null.");this.skeletonData=e}setMix(e,t,s){let i=this.skeletonData.findAnimation(e);if(!i)throw new Error("Animation not found: "+e);let r=this.skeletonData.findAnimation(t);if(!r)throw new Error("Animation not found: "+t);this.setMixWith(i,r,s)}setMixWith(e,t,s){if(!e)throw new Error("from cannot be null.");if(!t)throw new Error("to cannot be null.");let i=e.name+"."+t.name;this.animationToMixTime[i]=s}getMix(e,t){let s=e.name+"."+t.name,i=this.animationToMixTime[s];return i===void 0?this.defaultMix:i}},cs=class Oi extends Rt{color=new et(1,1,1,1);constructor(t){super(t)}copy(){let t=new Oi(this.name);return this.copyTo(t),t.color.setFromColor(this.color),t}},ee=class Di extends Rt{endSlot=null;color=new et(.2275,.2275,.8078,1);constructor(t){super(t)}copy(){let t=new Di(this.name);return this.copyTo(t),t.endSlot=this.endSlot,t.color.setFromColor(this.color),t}},ds=class{_image;constructor(e){this._image=e}getImage(){return this._image}},ue=(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))(ue||{}),ri=(e=>(e[e.MirroredRepeat=33648]="MirroredRepeat",e[e.ClampToEdge=33071]="ClampToEdge",e[e.Repeat=10497]="Repeat",e))(ri||{}),ni=class{texture;u=0;v=0;u2=0;v2=0;width=0;height=0;degrees=0;offsetX=0;offsetY=0;originalWidth=0;originalHeight=0},Ji=class extends ds{setFilters(e,t){}setWraps(e,t){}dispose(){}},fs=class{pages=new Array;regions=new Array;constructor(e){let t=new Qi(e),s=new Array(4),i={};i.size=o=>{o.width=parseInt(s[1]),o.height=parseInt(s[2])},i.format=()=>{},i.filter=o=>{o.minFilter=P.enumValue(ue,s[1]),o.magFilter=P.enumValue(ue,s[2])},i.repeat=o=>{s[1].indexOf("x")!=-1&&(o.uWrap=10497),s[1].indexOf("y")!=-1&&(o.vWrap=10497)},i.pma=o=>{o.pma=s[1]=="true"};var r={};r.xy=o=>{o.x=parseInt(s[1]),o.y=parseInt(s[2])},r.size=o=>{o.width=parseInt(s[1]),o.height=parseInt(s[2])},r.bounds=o=>{o.x=parseInt(s[1]),o.y=parseInt(s[2]),o.width=parseInt(s[3]),o.height=parseInt(s[4])},r.offset=o=>{o.offsetX=parseInt(s[1]),o.offsetY=parseInt(s[2])},r.orig=o=>{o.originalWidth=parseInt(s[1]),o.originalHeight=parseInt(s[2])},r.offsets=o=>{o.offsetX=parseInt(s[1]),o.offsetY=parseInt(s[2]),o.originalWidth=parseInt(s[3]),o.originalHeight=parseInt(s[4])},r.rotate=o=>{let c=s[1];c=="true"?o.degrees=90:c!="false"&&(o.degrees=parseInt(c))},r.index=o=>{o.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 l=null,n=null,a=null;for(;h!==null;)if(h.trim().length==0)l=null,h=t.readLine();else if(l){let o=new us(l,h);for(;;){let c=t.readEntry(s,h=t.readLine());if(c==0)break;let d=r[s[0]];if(d)d(o);else{n||(n=[]),a||(a=[]),n.push(s[0]);let f=[];for(let m=0;m<c;m++)f.push(parseInt(s[m+1]));a.push(f)}}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 ai(h.trim());t.readEntry(s,h=t.readLine())!=0;){let o=i[s[0]];o&&o(l)}this.pages.push(l)}}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()}},Qi=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 i=1,r=s+1;;i++){let h=t.indexOf(",",r);if(h==-1)return e[i]=t.substr(r).trim(),i;if(e[i]=t.substr(r,h-r).trim(),r=h+1,i==4)return 4}}},ai=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}},us=class extends ni{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)}},Gt=class Os extends Rt{region=null;path;regionUVs=[];uvs=[];triangles=[];color=new et(1,1,1,1);width=0;height=0;hullLength=0;edges=[];parentMesh=null;sequence=null;tempColor=new et(0,0,0,0);constructor(t,s){super(t),this.path=s}updateRegion(){if(!this.region)throw new Error("Region not set.");let t=this.regionUVs;(!this.uvs||this.uvs.length!=t.length)&&(this.uvs=P.newFloatArray(t.length));let s=this.uvs,i=this.uvs.length,r=this.region.u,h=this.region.v,l=0,n=0;if(this.region instanceof us){let a=this.region,o=a.page,c=o.width,d=o.height;switch(a.degrees){case 90:r-=(a.originalHeight-a.offsetY-a.height)/c,h-=(a.originalWidth-a.offsetX-a.width)/d,l=a.originalHeight/c,n=a.originalWidth/d;for(let f=0;f<i;f+=2)s[f]=r+t[f+1]*l,s[f+1]=h+(1-t[f])*n;return;case 180:r-=(a.originalWidth-a.offsetX-a.width)/c,h-=a.offsetY/d,l=a.originalWidth/c,n=a.originalHeight/d;for(let f=0;f<i;f+=2)s[f]=r+(1-t[f])*l,s[f+1]=h+(1-t[f+1])*n;return;case 270:r-=a.offsetY/c,h-=a.offsetX/d,l=a.originalHeight/c,n=a.originalWidth/d;for(let f=0;f<i;f+=2)s[f]=r+(1-t[f+1])*l,s[f+1]=h+t[f]*n;return}r-=a.offsetX/c,h-=(a.originalHeight-a.offsetY-a.height)/d,l=a.originalWidth/c,n=a.originalHeight/d}else this.region?(l=this.region.u2-r,n=this.region.v2-h):(r=h=0,l=n=1);for(let a=0;a<i;a+=2)s[a]=r+t[a]*l,s[a+1]=h+t[a+1]*n}getParentMesh(){return this.parentMesh}setParentMesh(t){this.parentMesh=t,t&&(this.bones=t.bones,this.vertices=t.vertices,this.worldVerticesLength=t.worldVerticesLength,this.regionUVs=t.regionUVs,this.triangles=t.triangles,this.hullLength=t.hullLength,this.worldVerticesLength=t.worldVerticesLength)}copy(){if(this.parentMesh)return this.newLinkedMesh();let t=new Os(this.name,this.path);return t.region=this.region,t.color.setFromColor(this.color),this.copyTo(t),t.regionUVs=new Array(this.regionUVs.length),P.arrayCopy(this.regionUVs,0,t.regionUVs,0,this.regionUVs.length),t.uvs=this.uvs instanceof Float32Array?P.newFloatArray(this.uvs.length):new Array(this.uvs.length),P.arrayCopy(this.uvs,0,t.uvs,0,this.uvs.length),t.triangles=new Array(this.triangles.length),P.arrayCopy(this.triangles,0,t.triangles,0,this.triangles.length),t.hullLength=this.hullLength,t.sequence=this.sequence!=null?this.sequence.copy():null,this.edges&&(t.edges=new Array(this.edges.length),P.arrayCopy(this.edges,0,t.edges,0,this.edges.length)),t.width=this.width,t.height=this.height,t}computeWorldVertices(t,s,i,r,h,l){this.sequence!=null&&this.sequence.apply(t,this),super.computeWorldVertices(t,s,i,r,h,l)}newLinkedMesh(){let t=new Os(this.name,this.path);return t.region=this.region,t.color.setFromColor(this.color),t.timelineAttachment=this.timelineAttachment,t.setParentMesh(this.parentMesh?this.parentMesh:this),t.region!=null&&t.updateRegion(),t}},Ht=class Ni extends Rt{lengths=[];closed=!1;constantSpeed=!1;color=new et(1,1,1,1);constructor(t){super(t)}copy(){let t=new Ni(this.name);return this.copyTo(t),t.lengths=new Array(this.lengths.length),P.arrayCopy(this.lengths,0,t.lengths,0,this.lengths.length),t.closed=closed,t.constantSpeed=this.constantSpeed,t.color.setFromColor(this.color),t}},li=class Ui extends Rt{x=0;y=0;rotation=0;color=new et(.38,.94,0,1);constructor(t){super(t)}computeWorldPosition(t,s){return s.x=this.x*t.a+this.y*t.b+t.worldX,s.y=this.x*t.c+this.y*t.d+t.worldY,s}computeWorldRotation(t){const s=this.rotation*L.degRad,i=Math.cos(s),r=Math.sin(s),h=i*t.a+r*t.b,l=i*t.c+r*t.d;return L.atan2Deg(l,h)}copy(){let t=new Ui(this.name);return t.x=this.x,t.y=this.y,t.rotation=this.rotation,t.color.setFromColor(this.color),t}},se=class zi extends Re{x=0;y=0;scaleX=1;scaleY=1;rotation=0;width=0;height=0;color=new et(1,1,1,1);path;region=null;sequence=null;offset=P.newFloatArray(8);uvs=P.newFloatArray(8);tempColor=new et(1,1,1,1);constructor(t,s){super(t),this.path=s}updateRegion(){if(!this.region)throw new Error("Region not set.");let t=this.region,s=this.uvs;if(t==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 i=this.width/this.region.originalWidth*this.scaleX,r=this.height/this.region.originalHeight*this.scaleY,h=-this.width/2*this.scaleX+this.region.offsetX*i,l=-this.height/2*this.scaleY+this.region.offsetY*r,n=h+this.region.width*i,a=l+this.region.height*r,o=this.rotation*L.degRad,c=Math.cos(o),d=Math.sin(o),f=this.x,m=this.y,u=h*c+f,g=h*d,w=l*c+m,b=l*d,x=n*c+f,p=n*d,v=a*c+m,y=a*d,A=this.offset;A[0]=u-b,A[1]=w+g,A[2]=u-y,A[3]=v+g,A[4]=x-y,A[5]=v+p,A[6]=x-b,A[7]=w+p,t.degrees==90?(s[0]=t.u2,s[1]=t.v2,s[2]=t.u,s[3]=t.v2,s[4]=t.u,s[5]=t.v,s[6]=t.u2,s[7]=t.v):(s[0]=t.u,s[1]=t.v2,s[2]=t.u,s[3]=t.v,s[4]=t.u2,s[5]=t.v,s[6]=t.u2,s[7]=t.v2)}computeWorldVertices(t,s,i,r){this.sequence!=null&&this.sequence.apply(t,this);let h=t.bone,l=this.offset,n=h.worldX,a=h.worldY,o=h.a,c=h.b,d=h.c,f=h.d,m=0,u=0;m=l[0],u=l[1],s[i]=m*o+u*c+n,s[i+1]=m*d+u*f+a,i+=r,m=l[2],u=l[3],s[i]=m*o+u*c+n,s[i+1]=m*d+u*f+a,i+=r,m=l[4],u=l[5],s[i]=m*o+u*c+n,s[i+1]=m*d+u*f+a,i+=r,m=l[6],u=l[7],s[i]=m*o+u*c+n,s[i+1]=m*d+u*f+a}copy(){let t=new zi(this.name,this.path);return t.region=this.region,t.x=this.x,t.y=this.y,t.scaleX=this.scaleX,t.scaleY=this.scaleY,t.rotation=this.rotation,t.width=this.width,t.height=this.height,P.arrayCopy(this.uvs,0,t.uvs,0,8),P.arrayCopy(this.offset,0,t.offset,0,8),t.color.setFromColor(this.color),t.sequence=this.sequence!=null?this.sequence.copy():null,t}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},$i=class{atlas;constructor(e){this.atlas=e}loadSequence(e,t,s){let i=s.regions;for(let r=0,h=i.length;r<h;r++){let l=s.getPath(t,r),n=this.atlas.findRegion(l);if(n==null)throw new Error("Region not found in atlas: "+l+" (sequence: "+e+")");i[r]=n}}newRegionAttachment(e,t,s,i){let r=new se(t,s);if(i!=null)this.loadSequence(t,s,i);else{let h=this.atlas.findRegion(s);if(!h)throw new Error("Region not found in atlas: "+s+" (region attachment: "+t+")");r.region=h}return r}newMeshAttachment(e,t,s,i){let r=new Gt(t,s);if(i!=null)this.loadSequence(t,s,i);else{let h=this.atlas.findRegion(s);if(!h)throw new Error("Region not found in atlas: "+s+" (mesh attachment: "+t+")");r.region=h}return r}newBoundingBoxAttachment(e,t){return new cs(t)}newPathAttachment(e,t){return new Ht(t)}newPointAttachment(e,t){return new li(t)}newClippingAttachment(e,t){return new ee(t)}},ms=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 et;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}},me=(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))(me||{}),gs=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,i,r,h,l){this.ax=e,this.ay=t,this.arotation=s,this.ascaleX=i,this.ascaleY=r,this.ashearX=h,this.ashearY=l;let n=this.parent;if(!n){let f=this.skeleton;const m=f.scaleX,u=f.scaleY,g=(s+h)*L.degRad,w=(s+90+l)*L.degRad;this.a=Math.cos(g)*i*m,this.b=Math.cos(w)*r*m,this.c=Math.sin(g)*i*u,this.d=Math.sin(w)*r*u,this.worldX=e*m+f.x,this.worldY=t*u+f.y;return}let a=n.a,o=n.b,c=n.c,d=n.d;switch(this.worldX=a*e+o*t+n.worldX,this.worldY=c*e+d*t+n.worldY,this.inherit){case 0:{const f=(s+h)*L.degRad,m=(s+90+l)*L.degRad,u=Math.cos(f)*i,g=Math.cos(m)*r,w=Math.sin(f)*i,b=Math.sin(m)*r;this.a=a*u+o*w,this.b=a*g+o*b,this.c=c*u+d*w,this.d=c*g+d*b;return}case 1:{const f=(s+h)*L.degRad,m=(s+90+l)*L.degRad;this.a=Math.cos(f)*i,this.b=Math.cos(m)*r,this.c=Math.sin(f)*i,this.d=Math.sin(m)*r;break}case 2:{let f=1/this.skeleton.scaleX,m=1/this.skeleton.scaleY;a*=f,c*=m;let u=a*a+c*c,g=0;u>1e-4?(u=Math.abs(a*d*m-o*f*c)/u,o=c*u,d=a*u,g=Math.atan2(c,a)*L.radDeg):(a=0,c=0,g=90-Math.atan2(d,o)*L.radDeg);const w=(s+h-g)*L.degRad,b=(s+l-g+90)*L.degRad,x=Math.cos(w)*i,p=Math.cos(b)*r,v=Math.sin(w)*i,y=Math.sin(b)*r;this.a=a*x-o*v,this.b=a*p-o*y,this.c=c*x+d*v,this.d=c*p+d*y;break}case 3:case 4:{s*=L.degRad;const f=Math.cos(s),m=Math.sin(s);let u=(a*f+o*m)/this.skeleton.scaleX,g=(c*f+d*m)/this.skeleton.scaleY,w=Math.sqrt(u*u+g*g);w>1e-5&&(w=1/w),u*=w,g*=w,w=Math.sqrt(u*u+g*g),this.inherit==3&&a*d-o*c<0!=(this.skeleton.scaleX<0!=this.skeleton.scaleY<0)&&(w=-w),s=Math.PI/2+Math.atan2(g,u);const b=Math.cos(s)*w,x=Math.sin(s)*w;h*=L.degRad,l=(90+l)*L.degRad;const p=Math.cos(h)*i,v=Math.cos(l)*r,y=Math.sin(h)*i,A=Math.sin(l)*r;this.a=u*p+b*y,this.b=u*v+b*A,this.c=g*p+x*y,this.d=g*v+x*A;break}}this.a*=this.skeleton.scaleX,this.b*=this.skeleton.scaleX,this.c*=this.skeleton.scaleY,this.d*=this.skeleton.scaleY}setToSetupPose(){let e=this.data;this.x=e.x,this.y=e.y,this.rotation=e.rotation,this.scaleX=e.scaleX,this.scaleY=e.scaleY,this.shearX=e.shearX,this.shearY=e.shearY,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)*L.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)*L.radDeg;return}let t=e.a,s=e.b,i=e.c,r=e.d,h=1/(t*r-s*i),l=r*h,n=s*h,a=i*h,o=t*h,c=this.worldX-e.worldX,d=this.worldY-e.worldY;this.ax=c*l-d*n,this.ay=d*o-c*a;let f,m,u,g;if(this.inherit==1)f=this.a,m=this.b,u=this.c,g=this.d;else{switch(this.inherit){case 2:{let v=Math.abs(t*r-s*i)/(t*t+i*i);s=-i*this.skeleton.scaleX*v/this.skeleton.scaleY,r=t*this.skeleton.scaleY*v/this.skeleton.scaleX,h=1/(t*r-s*i),l=r*h,n=s*h;break}case 3:case 4:let w=L.cosDeg(this.rotation),b=L.sinDeg(this.rotation);t=(t*w+s*b)/this.skeleton.scaleX,i=(i*w+r*b)/this.skeleton.scaleY;let x=Math.sqrt(t*t+i*i);x>1e-5&&(x=1/x),t*=x,i*=x,x=Math.sqrt(t*t+i*i),this.inherit==3&&h<0!=(this.skeleton.scaleX<0!=this.skeleton.scaleY<0)&&(x=-x);let p=L.PI/2+Math.atan2(i,t);s=Math.cos(p)*x,r=Math.sin(p)*x,h=1/(t*r-s*i),l=r*h,n=s*h,a=i*h,o=t*h}f=l*this.a-n*this.c,m=l*this.b-n*this.d,u=o*this.c-a*this.a,g=o*this.d-a*this.b}if(this.ashearX=0,this.ascaleX=Math.sqrt(f*f+u*u),this.ascaleX>1e-4){let w=f*g-m*u;this.ascaleY=w/this.ascaleX,this.ashearY=-Math.atan2(f*m+u*g,w)*L.radDeg,this.arotation=Math.atan2(u,f)*L.radDeg}else this.ascaleX=0,this.ascaleY=Math.sqrt(m*m+g*g),this.ashearY=0,this.arotation=90-Math.atan2(g,m)*L.radDeg}getWorldRotationX(){return Math.atan2(this.c,this.a)*L.radDeg}getWorldRotationY(){return Math.atan2(this.d,this.b)*L.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,i=e.y-this.worldY;return e.x=s*this.d*t-i*this.b*t,e.y=i*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=L.sinDeg(e),s=L.cosDeg(e);return Math.atan2(this.a*t-this.c*s,this.d*s-this.b*t)*L.radDeg+this.rotation-this.shearX}localToWorldRotation(e){e-=this.rotation-this.shearX;let t=L.sinDeg(e),s=L.cosDeg(e);return Math.atan2(s*this.c+t*this.d,s*this.a+t*this.b)*L.radDeg}rotateWorld(e){e*=L.degRad;const t=Math.sin(e),s=Math.cos(e),i=this.a,r=this.b;this.a=s*i-t*this.c,this.b=s*r-t*this.d,this.c=t*i+s*this.c,this.d=t*r+s*this.d}},ie=class{constructor(e,t,s){this.name=e,this.order=t,this.skinRequired=s}},oi=class{pathPrefix="";textureLoader;downloader;cache;errors={};toLoad=0;loaded=0;constructor(e,t="",s=new xs,i=new hi){this.textureLoader=e,this.pathPrefix=t,this.downloader=s,this.cache=i}start(e){return this.toLoad++,this.pathPrefix+e}success(e,t,s){this.toLoad--,this.loaded++,this.cache.assets[t]=s,this.cache.assetsRefCount[t]=(this.cache.assetsRefCount[t]||0)+1,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 i=()=>{if(this.isLoadingComplete()){this.hasErrors()?s(this.errors):t(this);return}requestAnimationFrame(i)};requestAnimationFrame(i)})}setRawDataURI(e,t){this.downloader.rawDataUris[this.pathPrefix+e]=t}loadBinary(e,t=()=>{},s=()=>{}){e=this.start(e),!this.reuseAssets(e,t,s)&&(this.cache.assetsLoaded[e]=new Promise((i,r)=>{this.downloader.downloadBinary(e,h=>{this.success(t,e,h),i(h)},(h,l)=>{const n=`Couldn't load binary ${e}: status ${h}, ${l}`;this.error(s,e,n),r(n)})}))}loadText(e,t=()=>{},s=()=>{}){e=this.start(e),this.downloader.downloadText(e,i=>{this.success(t,e,i)},(i,r)=>{this.error(s,e,`Couldn't load text ${e}: status ${i}, ${r}`)})}loadJson(e,t=()=>{},s=()=>{}){e=this.start(e),!this.reuseAssets(e,t,s)&&(this.cache.assetsLoaded[e]=new Promise((i,r)=>{this.downloader.downloadJson(e,h=>{this.success(t,e,h),i(h)},(h,l)=>{const n=`Couldn't load JSON ${e}: status ${h}, ${l}`;this.error(s,e,n),r(n)})}))}reuseAssets(e,t=()=>{},s=()=>{}){const i=this.cache.assetsLoaded[e],r=i!==void 0;return r&&(this.cache.assetsLoaded[e]=i.then(h=>(h=h instanceof Image||h instanceof ImageBitmap?this.textureLoader(h):h,this.success(t,e,h),h)).catch(h=>this.error(s,e,h))),r}loadTexture(e,t=()=>{},s=()=>{}){e=this.start(e),!this.reuseAssets(e,t,s)&&(this.cache.assetsLoaded[e]=new Promise((i,r)=>{if(!!!(typeof window<"u"&&typeof navigator<"u"&&window.document))fetch(e,{mode:"cors"}).then(n=>{if(n.ok)return n.blob();const a=`Couldn't load image: ${e}`;this.error(s,e,`Couldn't load image: ${e}`),r(a)}).then(n=>n?createImageBitmap(n,{premultiplyAlpha:"none",colorSpaceConversion:"none"}):null).then(n=>{if(n){const a=this.textureLoader(n);this.success(t,e,a),i(a)}});else{let n=new Image;n.crossOrigin="anonymous",n.onload=()=>{const a=this.textureLoader(n);this.success(t,e,a),i(a)},n.onerror=()=>{const a=`Couldn't load image: ${e}`;this.error(s,e,a),r(a)},this.downloader.rawDataUris[e]&&(e=this.downloader.rawDataUris[e]),n.src=e}}))}loadTextureAtlas(e,t=()=>{},s=()=>{},i){let r=e.lastIndexOf("/"),h=r>=0?e.substring(0,r+1):"";e=this.start(e),!this.reuseAssets(e,t,s)&&(this.cache.assetsLoaded[e]=new Promise((l,n)=>{this.downloader.downloadText(e,a=>{try{let o=new fs(a),c=o.pages.length,d=!1;for(let f of o.pages)this.loadTexture(i?i[f.name]:h+f.name,(m,u)=>{d||(f.setTexture(u),--c==0&&(this.success(t,e,o),l(o)))},(m,u)=>{if(!d){const g=`Couldn't load texture ${e} page image: ${m}`;this.error(s,e,g),n(g)}d=!0})}catch(o){const c=`Couldn't parse texture atlas ${e}: ${o.message}`;this.error(s,e,c),n(c)}},(a,o)=>{const c=`Couldn't load texture atlas ${e}: status ${a}, ${o}`;this.error(s,e,c),n(c)})}))}loadTextureAtlasButNoTextures(e,t=()=>{},s=()=>{},i){e=this.start(e),!this.reuseAssets(e,t,s)&&(this.cache.assetsLoaded[e]=new Promise((r,h)=>{this.downloader.downloadText(e,l=>{try{const n=new fs(l);this.success(t,e,n),r(n)}catch(n){const a=`Couldn't parse texture atlas ${e}: ${n.message}`;this.error(s,e,a),h(a)}},(l,n)=>{const a=`Couldn't load texture atlas ${e}: status ${l}, ${n}`;this.error(s,e,a),h(a)})}))}async loadBinaryAsync(e){return new Promise((t,s)=>{this.loadBinary(e,(i,r)=>t(r),(i,r)=>s(r))})}async loadJsonAsync(e){return new Promise((t,s)=>{this.loadJson(e,(i,r)=>t(r),(i,r)=>s(r))})}async loadTextureAsync(e){return new Promise((t,s)=>{this.loadTexture(e,(i,r)=>t(r),(i,r)=>s(r))})}async loadTextureAtlasAsync(e){return new Promise((t,s)=>{this.loadTextureAtlas(e,(i,r)=>t(r),(i,r)=>s(r))})}async loadTextureAtlasButNoTexturesAsync(e){return new Promise((t,s)=>{this.loadTextureAtlasButNoTextures(e,(i,r)=>t(r),(i,r)=>s(r))})}setCache(e){this.cache=e}get(e){return this.cache.assets[this.pathPrefix+e]}require(e){e=this.pathPrefix+e;let t=this.cache.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.cache.assets[e];return t.dispose&&t.dispose(),delete this.cache.assets[e],delete this.cache.assetsRefCount[e],delete this.cache.assetsLoaded[e],t}removeAll(){for(let e in this.cache.assets){let t=this.cache.assets[e];t.dispose&&t.dispose()}this.cache.assets={},this.cache.assetsLoaded={},this.cache.assetsRefCount={}}isLoadingComplete(){return this.toLoad==0}getToLoad(){return this.toLoad}getLoaded(){return this.loaded}dispose(){this.removeAll()}disposeAsset(e){--this.cache.assetsRefCount[e]===0&&this.remove(e)}hasErrors(){return Object.keys(this.errors).length>0}getErrors(){return this.errors}},hi=class Se{assets={};assetsRefCount={};assetsLoaded={};static AVAILABLE_CACHES=new Map;static getCache(t){const s=Se.AVAILABLE_CACHES.get(t);if(s)return s;const i=new Se;return Se.AVAILABLE_CACHES.set(t,i),i}async addAsset(t,s){this.assetsLoaded[t]=Promise.resolve(s),this.assets[t]=await s}},xs=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,i=new Uint8Array(s),r=0;r<s;r++)i[r]=t.charCodeAt(r);return i}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;const i=this.rawDataUris[e];if(i&&!i.includes(".")){try{this.finish(e,200,this.dataUriToString(i))}catch(l){this.finish(e,400,JSON.stringify(l))}return}let r=new XMLHttpRequest;r.overrideMimeType("text/html"),r.open("GET",i||e,!0);let h=()=>{this.finish(e,r.status,r.responseText)};r.onload=h,r.onerror=h,r.send()}downloadJson(e,t,s){this.downloadText(e,i=>{t(JSON.parse(i))},s)}downloadBinary(e,t,s){if(this.start(e,t,s))return;const i=this.rawDataUris[e];if(i&&!i.includes(".")){try{this.finish(e,200,this.dataUriToUint8Array(i))}catch(l){this.finish(e,400,JSON.stringify(l))}return}let r=new XMLHttpRequest;r.open("GET",i||e,!0),r.responseType="arraybuffer";let h=()=>{this.finish(e,r.status,r.response)};r.onload=()=>{r.status==200||r.status==0?this.finish(e,200,new Uint8Array(r.response)):h()},r.onerror=h,r.send()}start(e,t,s){let i=this.callbacks[e];try{if(i)return!0;this.callbacks[e]=i=[]}finally{i.push(t,s)}}finish(e,t,s){let i=this.callbacks[e];delete this.callbacks[e];let r=t==200||t==0?[s]:[t,s];for(let h=r.length-1,l=i.length;h<l;h+=2)i[h].apply(null,r)}},ps=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}},ws=class{name;intValue=0;floatValue=0;stringValue=null;audioPath=null;volume=0;balance=0;constructor(e){this.name=e}},ci=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 i=0;i<e.bones.length;i++){let r=t.findBone(e.bones[i].name);if(!r)throw new Error(`Couldn't find bone ${e.bones[i].name}`);this.bones.push(r)}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,i,r,h,l){let n=e.parent;if(!n)throw new Error("IK bone must have parent.");let a=n.a,o=n.b,c=n.c,d=n.d,f=-e.ashearX-e.arotation,m=0,u=0;switch(e.inherit){case 1:m=(t-e.worldX)*L.signum(e.skeleton.scaleX),u=(s-e.worldY)*L.signum(e.skeleton.scaleY);break;case 2:let b=Math.abs(a*d-o*c)/Math.max(1e-4,a*a+c*c),x=a/e.skeleton.scaleX,p=c/e.skeleton.scaleY;o=-p*b*e.skeleton.scaleX,d=x*b*e.skeleton.scaleY,f+=Math.atan2(p,x)*L.radDeg;default:let v=t-n.worldX,y=s-n.worldY,A=a*d-o*c;Math.abs(A)<=1e-4?(m=0,u=0):(m=(v*d-y*o)/A-e.ax,u=(y*a-v*c)/A-e.ay)}f+=Math.atan2(u,m)*L.radDeg,e.ascaleX<0&&(f+=180),f>180?f-=360:f<-180&&(f+=360);let g=e.ascaleX,w=e.ascaleY;if(i||r){switch(e.inherit){case 3:case 4:m=t-e.worldX,u=s-e.worldY}const b=e.data.length*g;if(b>1e-4){const x=m*m+u*u;if(i&&x<b*b||r&&x>b*b){const p=(Math.sqrt(x)/b-1)*l+1;g*=p,h&&(w*=p)}}}e.updateWorldTransformWith(e.ax,e.ay,e.arotation+f*l,g,w,e.ashearX,e.ashearY)}apply2(e,t,s,i,r,h,l,n,a){if(e.inherit!=0||t.inherit!=0)return;let o=e.ax,c=e.ay,d=e.ascaleX,f=e.ascaleY,m=d,u=f,g=t.ascaleX,w=0,b=0,x=0;d<0?(d=-d,w=180,x=-1):(w=0,x=1),f<0&&(f=-f,x=-x),g<0?(g=-g,b=180):b=0;let p=t.ax,v=0,y=0,A=0,C=e.a,S=e.b,T=e.c,R=e.d,k=Math.abs(d-f)<=1e-4;!k||h?(v=0,y=C*p+e.worldX,A=T*p+e.worldY):(v=t.ay,y=C*p+S*v+e.worldX,A=T*p+R*v+e.worldY);let F=e.parent;if(!F)throw new Error("IK parent must itself have a parent.");C=F.a,S=F.b,T=F.c,R=F.d;let X=C*R-S*T,E=y-F.worldX,Y=A-F.worldY;X=Math.abs(X)<=1e-4?0:1/X;let B=(E*R-Y*S)*X-o,st=(Y*C-E*T)*X-c,tt=Math.sqrt(B*B+st*st),it=t.data.length*g,ct,lt;if(tt<1e-4){this.apply1(e,s,i,!1,h,!1,a),t.updateWorldTransformWith(p,v,0,t.ascaleX,t.ascaleY,t.ashearX,t.ashearY);return}E=s-F.worldX,Y=i-F.worldY;let ut=(E*R-Y*S)*X-o,W=(Y*C-E*T)*X-c,nt=ut*ut+W*W;if(n!=0){n*=d*(g+1)*.5;let mt=Math.sqrt(nt),gt=mt-tt-it*d+n;if(gt>0){let xt=Math.min(1,gt/(n*2))-1;xt=(gt-n*(1-xt*xt))/mt,ut-=xt*ut,W-=xt*W,nt=ut*ut+W*W}}t:if(k){it*=d;let mt=(nt-tt*tt-it*it)/(2*tt*it);mt<-1?(mt=-1,lt=Math.PI*r):mt>1?(mt=1,lt=0,h&&(C=(Math.sqrt(nt)/(tt+it)-1)*a+1,m*=C,l&&(u*=C))):lt=Math.acos(mt)*r,C=tt+it*mt,S=it*Math.sin(lt),ct=Math.atan2(W*C-ut*S,ut*C+W*S)}else{C=d*it,S=f*it;let mt=C*C,gt=S*S,xt=Math.atan2(W,ut);T=gt*tt*tt+mt*nt-mt*gt;let Ct=-2*gt*tt,zt=gt-mt;if(R=Ct*Ct-4*zt*T,R>=0){let Wt=Math.sqrt(R);Ct<0&&(Wt=-Wt),Wt=-(Ct+Wt)*.5;let Qt=Wt/zt,Gs=T/Wt,le=Math.abs(Qt)<Math.abs(Gs)?Qt:Gs;if(Qt=nt-le*le,Qt>=0){Y=Math.sqrt(Qt)*r,ct=xt-Math.atan2(Y,le),lt=Math.atan2(Y/f,(le-tt)/d);break t}}let Jt=L.PI,ne=tt-C,Te=ne*ne,zs=0,Ws=0,ae=tt+C,Me=ae*ae,qs=0;T=-C*tt/(mt-gt),T>=-1&&T<=1&&(T=Math.acos(T),E=C*Math.cos(T)+tt,Y=S*Math.sin(T),R=E*E+Y*Y,R<Te&&(Jt=T,Te=R,ne=E,zs=Y),R>Me&&(Ws=T,Me=R,ae=E,qs=Y)),nt<=(Te+Me)*.5?(ct=xt-Math.atan2(zs*r,ne),lt=Jt*r):(ct=xt-Math.atan2(qs*r,ae),lt=Ws*r)}let ht=Math.atan2(v,p)*x,bt=e.arotation;ct=(ct-ht)*L.radDeg+w-bt,ct>180?ct-=360:ct<-180&&(ct+=360),e.updateWorldTransformWith(o,c,bt+ct*a,m,u,0,0),bt=t.arotation,lt=((lt+ht)*L.radDeg-t.ashearX)*x+b-bt,lt>180?lt-=360:lt<-180&&(lt+=360),t.updateWorldTransformWith(p,v,bt+lt*a,t.ascaleX,t.ascaleY,t.ashearX,t.ashearY)}},bs=class extends ie{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)}},vs=class extends ie{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=0;spacingMode=1;rotateMode=1;offsetRotation=0;position=0;spacing=0;mixRotate=0;mixX=0;mixY=0;constructor(e){super(e,0,!1)}},ys=(e=>(e[e.Fixed=0]="Fixed",e[e.Percent=1]="Percent",e))(ys||{}),As=(e=>(e[e.Length=0]="Length",e[e.Fixed=1]="Fixed",e[e.Percent=2]="Percent",e[e.Proportional=3]="Proportional",e))(As||{}),Cs=(e=>(e[e.Tangent=0]="Tangent",e[e.Chain=1]="Chain",e[e.ChainScale=2]="ChainScale",e))(Cs||{}),di=class Bt{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(t,s){if(!t)throw new Error("data cannot be null.");if(!s)throw new Error("skeleton cannot be null.");this.data=t,this.bones=new Array;for(let r=0,h=t.bones.length;r<h;r++){let l=s.findBone(t.bones[r].name);if(!l)throw new Error(`Couldn't find bone ${t.bones[r].name}.`);this.bones.push(l)}let i=s.findSlot(t.target.name);if(!i)throw new Error(`Couldn't find target bone ${t.target.name}`);this.target=i,this.position=t.position,this.spacing=t.spacing,this.mixRotate=t.mixRotate,this.mixX=t.mixX,this.mixY=t.mixY}isActive(){return this.active}setToSetupPose(){const t=this.data;this.position=t.position,this.spacing=t.spacing,this.mixRotate=t.mixRotate,this.mixX=t.mixX,this.mixY=t.mixY}update(t){let s=this.target.getAttachment();if(!(s instanceof Ht))return;let i=this.mixRotate,r=this.mixX,h=this.mixY;if(i==0&&r==0&&h==0)return;let l=this.data,n=l.rotateMode==0,a=l.rotateMode==2,o=this.bones,c=o.length,d=n?c:c+1,f=P.setArraySize(this.spaces,d),m=a?this.lengths=P.setArraySize(this.lengths,c):[],u=this.spacing;switch(l.spacingMode){case 2:if(a)for(let A=0,C=d-1;A<C;A++){let S=o[A],T=S.data.length,R=T*S.a,k=T*S.c;m[A]=Math.sqrt(R*R+k*k)}P.arrayFill(f,1,d,u);break;case 3:let v=0;for(let A=0,C=d-1;A<C;){let S=o[A],T=S.data.length;if(T<Bt.epsilon)a&&(m[A]=0),f[++A]=u;else{let R=T*S.a,k=T*S.c,F=Math.sqrt(R*R+k*k);a&&(m[A]=F),f[++A]=F,v+=F}}if(v>0){v=d/v*u;for(let A=1;A<d;A++)f[A]*=v}break;default:let y=l.spacingMode==0;for(let A=0,C=d-1;A<C;){let S=o[A],T=S.data.length;if(T<Bt.epsilon)a&&(m[A]=0),f[++A]=u;else{let R=T*S.a,k=T*S.c,F=Math.sqrt(R*R+k*k);a&&(m[A]=F),f[++A]=(y?T+u:u)*F/T}}}let g=this.computeWorldPositions(s,d,n),w=g[0],b=g[1],x=l.offsetRotation,p=!1;if(x==0)p=l.rotateMode==1;else{p=!1;let v=this.target.bone;x*=v.a*v.d-v.b*v.c>0?L.degRad:-L.degRad}for(let v=0,y=3;v<c;v++,y+=3){let A=o[v];A.worldX+=(w-A.worldX)*r,A.worldY+=(b-A.worldY)*h;let C=g[y],S=g[y+1],T=C-w,R=S-b;if(a){let k=m[v];if(k!=0){let F=(Math.sqrt(T*T+R*R)/k-1)*i+1;A.a*=F,A.c*=F}}if(w=C,b=S,i>0){let k=A.a,F=A.b,X=A.c,E=A.d,Y=0,B=0,st=0;if(n?Y=g[y-1]:f[v+1]==0?Y=g[y+2]:Y=Math.atan2(R,T),Y-=Math.atan2(X,k),p){B=Math.cos(Y),st=Math.sin(Y);let tt=A.data.length;w+=(tt*(B*k-st*X)-T)*i,b+=(tt*(st*k+B*X)-R)*i}else Y+=x;Y>L.PI?Y-=L.PI2:Y<-L.PI&&(Y+=L.PI2),Y*=i,B=Math.cos(Y),st=Math.sin(Y),A.a=B*k-st*X,A.b=B*F-st*E,A.c=st*k+B*X,A.d=st*F+B*E}A.updateAppliedTransform()}}computeWorldPositions(t,s,i){let r=this.target,h=this.position,l=this.spaces,n=P.setArraySize(this.positions,s*3+2),a=this.world,o=t.closed,c=t.worldVerticesLength,d=c/6,f=Bt.NONE;if(!t.constantSpeed){let tt=t.lengths;d-=o?1:2;let it=tt[d];this.data.positionMode==1&&(h*=it);let ct;switch(this.data.spacingMode){case 2:ct=it;break;case 3:ct=it/s;break;default:ct=1}a=P.setArraySize(this.world,8);for(let lt=0,ut=0,W=0;lt<s;lt++,ut+=3){let nt=l[lt]*ct;h+=nt;let ht=h;if(o)ht%=it,ht<0&&(ht+=it),W=0;else if(ht<0){f!=Bt.BEFORE&&(f=Bt.BEFORE,t.computeWorldVertices(r,2,4,a,0,2)),this.addBeforePosition(ht,a,0,n,ut);continue}else if(ht>it){f!=Bt.AFTER&&(f=Bt.AFTER,t.computeWorldVertices(r,c-6,4,a,0,2)),this.addAfterPosition(ht-it,a,0,n,ut);continue}for(;;W++){let bt=tt[W];if(!(ht>bt)){if(W==0)ht/=bt;else{let mt=tt[W-1];ht=(ht-mt)/(bt-mt)}break}}W!=f&&(f=W,o&&W==d?(t.computeWorldVertices(r,c-4,4,a,0,2),t.computeWorldVertices(r,0,4,a,4,2)):t.computeWorldVertices(r,W*6+2,8,a,0,2)),this.addCurvePosition(ht,a[0],a[1],a[2],a[3],a[4],a[5],a[6],a[7],n,ut,i||lt>0&&nt==0)}return n}o?(c+=2,a=P.setArraySize(this.world,c),t.computeWorldVertices(r,2,c-4,a,0,2),t.computeWorldVertices(r,0,2,a,c-4,2),a[c-2]=a[0],a[c-1]=a[1]):(d--,c-=4,a=P.setArraySize(this.world,c),t.computeWorldVertices(r,2,c,a,0,2));let m=P.setArraySize(this.curves,d),u=0,g=a[0],w=a[1],b=0,x=0,p=0,v=0,y=0,A=0,C=0,S=0,T=0,R=0,k=0,F=0,X=0,E=0;for(let tt=0,it=2;tt<d;tt++,it+=6)b=a[it],x=a[it+1],p=a[it+2],v=a[it+3],y=a[it+4],A=a[it+5],C=(g-b*2+p)*.1875,S=(w-x*2+v)*.1875,T=((b-p)*3-g+y)*.09375,R=((x-v)*3-w+A)*.09375,k=C*2+T,F=S*2+R,X=(b-g)*.75+C+T*.16666667,E=(x-w)*.75+S+R*.16666667,u+=Math.sqrt(X*X+E*E),X+=k,E+=F,k+=T,F+=R,u+=Math.sqrt(X*X+E*E),X+=k,E+=F,u+=Math.sqrt(X*X+E*E),X+=k+T,E+=F+R,u+=Math.sqrt(X*X+E*E),m[tt]=u,g=y,w=A;this.data.positionMode==1&&(h*=u);let Y;switch(this.data.spacingMode){case 2:Y=u;break;case 3:Y=u/s;break;default:Y=1}let B=this.segments,st=0;for(let tt=0,it=0,ct=0,lt=0;tt<s;tt++,it+=3){let ut=l[tt]*Y;h+=ut;let W=h;if(o)W%=u,W<0&&(W+=u),ct=0;else if(W<0){this.addBeforePosition(W,a,0,n,it);continue}else if(W>u){this.addAfterPosition(W-u,a,c-4,n,it);continue}for(;;ct++){let nt=m[ct];if(!(W>nt)){if(ct==0)W/=nt;else{let ht=m[ct-1];W=(W-ht)/(nt-ht)}break}}if(ct!=f){f=ct;let nt=ct*6;for(g=a[nt],w=a[nt+1],b=a[nt+2],x=a[nt+3],p=a[nt+4],v=a[nt+5],y=a[nt+6],A=a[nt+7],C=(g-b*2+p)*.03,S=(w-x*2+v)*.03,T=((b-p)*3-g+y)*.006,R=((x-v)*3-w+A)*.006,k=C*2+T,F=S*2+R,X=(b-g)*.3+C+T*.16666667,E=(x-w)*.3+S+R*.16666667,st=Math.sqrt(X*X+E*E),B[0]=st,nt=1;nt<8;nt++)X+=k,E+=F,k+=T,F+=R,st+=Math.sqrt(X*X+E*E),B[nt]=st;X+=k,E+=F,st+=Math.sqrt(X*X+E*E),B[8]=st,X+=k+T,E+=F+R,st+=Math.sqrt(X*X+E*E),B[9]=st,lt=0}for(W*=st;;lt++){let nt=B[lt];if(!(W>nt)){if(lt==0)W/=nt;else{let ht=B[lt-1];W=lt+(W-ht)/(nt-ht)}break}}this.addCurvePosition(W*.1,g,w,b,x,p,v,y,A,n,it,i||tt>0&&ut==0)}return n}addBeforePosition(t,s,i,r,h){let l=s[i],n=s[i+1],a=s[i+2]-l,o=s[i+3]-n,c=Math.atan2(o,a);r[h]=l+t*Math.cos(c),r[h+1]=n+t*Math.sin(c),r[h+2]=c}addAfterPosition(t,s,i,r,h){let l=s[i+2],n=s[i+3],a=l-s[i],o=n-s[i+1],c=Math.atan2(o,a);r[h]=l+t*Math.cos(c),r[h+1]=n+t*Math.sin(c),r[h+2]=c}addCurvePosition(t,s,i,r,h,l,n,a,o,c,d,f){if(t==0||isNaN(t)){c[d]=s,c[d+1]=i,c[d+2]=Math.atan2(h-i,r-s);return}let m=t*t,u=m*t,g=1-t,w=g*g,b=w*g,x=g*t,p=x*3,v=g*p,y=p*t,A=s*b+r*v+l*y+a*u,C=i*b+h*v+n*y+o*u;c[d]=A,c[d+1]=C,f&&(t<.001?c[d+2]=Math.atan2(h-i,r-s):c[d+2]=Math.atan2(C-(i*w+h*x*2+n*m),A-(s*w+r*x*2+l*m)))}},tr=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,i=this.data.y>0,r=this.data.rotate>0||this.data.shearX>0,h=this.data.scaleX>0,l=this.bone,n=l.data.length;switch(e){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,d=l.worldY;if(this._reset)this._reset=!1,this.ux=c,this.uy=d;else{let f=this.remaining,m=this.inertia,u=this.data.step,g=this.skeleton.data.referenceScale,w=-1,b=this.data.limit*o,x=b*Math.abs(a.scaleY);if(b*=Math.abs(a.scaleX),s||i){if(s){const p=(this.ux-c)*m;this.xOffset+=p>b?b:p<-b?-b:p,this.ux=c}if(i){const p=(this.uy-d)*m;this.yOffset+=p>x?x:p<-x?-x:p,this.uy=d}if(f>=u){w=Math.pow(this.damping,60*u);const p=this.massInverse*u,v=this.strength,y=this.wind*g*a.scaleX,A=this.gravity*g*a.scaleY;do s&&(this.xVelocity+=(y-this.xOffset*v)*p,this.xOffset+=this.xVelocity*u,this.xVelocity*=w),i&&(this.yVelocity-=(A+this.yOffset*v)*p,this.yOffset+=this.yVelocity*u,this.yVelocity*=w),f-=u;while(f>=u)}s&&(l.worldX+=this.xOffset*t*this.data.x),i&&(l.worldY+=this.yOffset*t*this.data.y)}if(r||h){let p=Math.atan2(l.c,l.a),v=0,y=0,A=0,C=this.cx-l.worldX,S=this.cy-l.worldY;if(C>b?C=b:C<-b&&(C=-b),S>x?S=x:S<-x&&(S=-x),r){A=(this.data.rotate+this.data.shearX)*t;let T=Math.atan2(S+this.ty,C+this.tx)-p-this.rotateOffset*A;this.rotateOffset+=(T-Math.ceil(T*L.invPI2-.5)*L.PI2)*m,T=this.rotateOffset*A+p,v=Math.cos(T),y=Math.sin(T),h&&(T=n*l.getWorldScaleX(),T>0&&(this.scaleOffset+=(C*v+S*y)*m/T))}else{v=Math.cos(p),y=Math.sin(p);const T=n*l.getWorldScaleX();T>0&&(this.scaleOffset+=(C*v+S*y)*m/T)}if(f=this.remaining,f>=u){w==-1&&(w=Math.pow(this.damping,60*u));const T=this.massInverse*u,R=this.strength,k=this.wind,F=mi.yDown?-this.gravity:this.gravity,X=n/g;for(;;)if(f-=u,h&&(this.scaleVelocity+=(k*v-F*y-this.scaleOffset*R)*T,this.scaleOffset+=this.scaleVelocity*u,this.scaleVelocity*=w),r){if(this.rotateVelocity-=((k*y+F*v)*X+this.rotateOffset*R)*T,this.rotateOffset+=this.rotateVelocity*u,this.rotateVelocity*=w,f<u)break;const E=this.rotateOffset*A+p;v=Math.cos(E),y=Math.sin(E)}else if(f<u)break}}this.remaining=f}this.cx=l.worldX,this.cy=l.worldY;break;case 3:s&&(l.worldX+=this.xOffset*t*this.data.x),i&&(l.worldY+=this.yOffset*t*this.data.y)}if(r){let a=this.rotateOffset*t,o=0,c=0,d=0;if(this.data.shearX>0){let f=0;this.data.rotate>0&&(f=a*this.data.rotate,o=Math.sin(f),c=Math.cos(f),d=l.b,l.b=c*d-o*l.d,l.d=o*d+c*l.d),f+=a*this.data.shearX,o=Math.sin(f),c=Math.cos(f),d=l.a,l.a=c*d-o*l.c,l.c=o*d+c*l.c}else a*=this.data.rotate,o=Math.sin(a),c=Math.cos(a),d=l.a,l.a=c*d-o*l.c,l.c=o*d+c*l.c,d=l.b,l.b=c*d-o*l.d,l.d=o*d+c*l.d}if(h){const a=1+this.scaleOffset*t*this.data.scaleX;l.a*=a,l.c*=a}e!=3&&(this.tx=n*l.a,this.ty=n*l.c),l.updateAppliedTransform()}translate(e,t){this.ux-=e,this.uy-=t,this.cx-=e,this.cy-=t}rotate(e,t,s){const i=s*L.degRad,r=Math.cos(i),h=Math.sin(i),l=this.cx-e,n=this.cy-t;this.translate(l*r-n*h-l,l*h+n*r-n)}},fi=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 et,this.darkColor=e.darkColor?new et:null,this.setToSetupPose()}getSkeleton(){return this.bone.skeleton}getAttachment(){return this.attachment}setAttachment(e){this.attachment!=e&&((!(e instanceof Rt)||!(this.attachment instanceof Rt)||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}},ui=class{data;bones;target;mixRotate=0;mixX=0;mixY=0;mixScaleX=0;mixScaleY=0;mixShearY=0;temp=new Vt;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 i=0;i<e.bones.length;i++){let r=t.findBone(e.bones[i].name);if(!r)throw new Error(`Couldn't find bone ${e.bones[i].name}.`);this.bones.push(r)}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,i=this.mixScaleX,r=this.mixScaleY,h=this.mixShearY,l=t!=0||s!=0,n=this.target,a=n.a,o=n.b,c=n.c,d=n.d,f=a*d-o*c>0?L.degRad:-L.degRad,m=this.data.offsetRotation*f,u=this.data.offsetShearY*f,g=this.bones;for(let w=0,b=g.length;w<b;w++){let x=g[w];if(e!=0){let p=x.a,v=x.b,y=x.c,A=x.d,C=Math.atan2(c,a)-Math.atan2(y,p)+m;C>L.PI?C-=L.PI2:C<-L.PI&&(C+=L.PI2),C*=e;let S=Math.cos(C),T=Math.sin(C);x.a=S*p-T*y,x.b=S*v-T*A,x.c=T*p+S*y,x.d=T*v+S*A}if(l){let p=this.temp;n.localToWorld(p.set(this.data.offsetX,this.data.offsetY)),x.worldX+=(p.x-x.worldX)*t,x.worldY+=(p.y-x.worldY)*s}if(i!=0){let p=Math.sqrt(x.a*x.a+x.c*x.c);p!=0&&(p=(p+(Math.sqrt(a*a+c*c)-p+this.data.offsetScaleX)*i)/p),x.a*=p,x.c*=p}if(r!=0){let p=Math.sqrt(x.b*x.b+x.d*x.d);p!=0&&(p=(p+(Math.sqrt(o*o+d*d)-p+this.data.offsetScaleY)*r)/p),x.b*=p,x.d*=p}if(h>0){let p=x.b,v=x.d,y=Math.atan2(v,p),A=Math.atan2(d,o)-Math.atan2(c,a)-(y-Math.atan2(x.c,x.a));A>L.PI?A-=L.PI2:A<-L.PI&&(A+=L.PI2),A=y+(A+u)*h;let C=Math.sqrt(p*p+v*v);x.b=Math.cos(A)*C,x.d=Math.sin(A)*C}x.updateAppliedTransform()}}applyRelativeWorld(){let e=this.mixRotate,t=this.mixX,s=this.mixY,i=this.mixScaleX,r=this.mixScaleY,h=this.mixShearY,l=t!=0||s!=0,n=this.target,a=n.a,o=n.b,c=n.c,d=n.d,f=a*d-o*c>0?L.degRad:-L.degRad,m=this.data.offsetRotation*f,u=this.data.offsetShearY*f,g=this.bones;for(let w=0,b=g.length;w<b;w++){let x=g[w];if(e!=0){let p=x.a,v=x.b,y=x.c,A=x.d,C=Math.atan2(c,a)+m;C>L.PI?C-=L.PI2:C<-L.PI&&(C+=L.PI2),C*=e;let S=Math.cos(C),T=Math.sin(C);x.a=S*p-T*y,x.b=S*v-T*A,x.c=T*p+S*y,x.d=T*v+S*A}if(l){let p=this.temp;n.localToWorld(p.set(this.data.offsetX,this.data.offsetY)),x.worldX+=p.x*t,x.worldY+=p.y*s}if(i!=0){let p=(Math.sqrt(a*a+c*c)-1+this.data.offsetScaleX)*i+1;x.a*=p,x.c*=p}if(r!=0){let p=(Math.sqrt(o*o+d*d)-1+this.data.offsetScaleY)*r+1;x.b*=p,x.d*=p}if(h>0){let p=Math.atan2(d,o)-Math.atan2(c,a);p>L.PI?p-=L.PI2:p<-L.PI&&(p+=L.PI2);let v=x.b,y=x.d;p=Math.atan2(y,v)+(p-L.PI/2+u)*h;let A=Math.sqrt(v*v+y*y);x.b=Math.cos(p)*A,x.d=Math.sin(p)*A}x.updateAppliedTransform()}}applyAbsoluteLocal(){let e=this.mixRotate,t=this.mixX,s=this.mixY,i=this.mixScaleX,r=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],d=c.arotation;e!=0&&(d+=(l.arotation-d+this.data.offsetRotation)*e);let f=c.ax,m=c.ay;f+=(l.ax-f+this.data.offsetX)*t,m+=(l.ay-m+this.data.offsetY)*s;let u=c.ascaleX,g=c.ascaleY;i!=0&&u!=0&&(u=(u+(l.ascaleX-u+this.data.offsetScaleX)*i)/u),r!=0&&g!=0&&(g=(g+(l.ascaleY-g+this.data.offsetScaleY)*r)/g);let w=c.ashearY;h!=0&&(w+=(l.ashearY-w+this.data.offsetShearY)*h),c.updateWorldTransformWith(f,m,d,u,g,c.ashearX,w)}}applyRelativeLocal(){let e=this.mixRotate,t=this.mixX,s=this.mixY,i=this.mixScaleX,r=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],d=c.arotation+(l.arotation+this.data.offsetRotation)*e,f=c.ax+(l.ax+this.data.offsetX)*t,m=c.ay+(l.ay+this.data.offsetY)*s,u=c.ascaleX*((l.ascaleX-1+this.data.offsetScaleX)*i+1),g=c.ascaleY*((l.ascaleY-1+this.data.offsetScaleY)*r+1),w=c.ashearY+(l.ashearY+this.data.offsetShearY)*h;c.updateWorldTransformWith(f,m,d,u,g,c.ashearX,w)}}},mi=class Ds{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 Ds.yDown?-this._scaleY:this._scaleY}set scaleY(t){this._scaleY=t}x=0;y=0;time=0;constructor(t){if(!t)throw new Error("data cannot be null.");this.data=t,this.bones=new Array;for(let s=0;s<t.bones.length;s++){let i=t.bones[s],r;if(!i.parent)r=new gs(i,this,null);else{let h=this.bones[i.parent.index];r=new gs(i,this,h),h.children.push(r)}this.bones.push(r)}this.slots=new Array,this.drawOrder=new Array;for(let s=0;s<t.slots.length;s++){let i=t.slots[s],r=this.bones[i.boneData.index],h=new fi(i,r);this.slots.push(h),this.drawOrder.push(h)}this.ikConstraints=new Array;for(let s=0;s<t.ikConstraints.length;s++){let i=t.ikConstraints[s];this.ikConstraints.push(new ci(i,this))}this.transformConstraints=new Array;for(let s=0;s<t.transformConstraints.length;s++){let i=t.transformConstraints[s];this.transformConstraints.push(new ui(i,this))}this.pathConstraints=new Array;for(let s=0;s<t.pathConstraints.length;s++){let i=t.pathConstraints[s];this.pathConstraints.push(new di(i,this))}this.physicsConstraints=new Array;for(let s=0;s<t.physicsConstraints.length;s++){let i=t.physicsConstraints[s];this.physicsConstraints.push(new tr(i,this))}this.color=new et(1,1,1,1),this.updateCache()}updateCache(){let t=this._updateCache;t.length=0;let s=this.bones;for(let f=0,m=s.length;f<m;f++){let u=s[f];u.sorted=u.data.skinRequired,u.active=!u.sorted}if(this.skin){let f=this.skin.bones;for(let m=0,u=this.skin.bones.length;m<u;m++){let g=this.bones[f[m].index];do g.sorted=!1,g.active=!0,g=g.parent;while(g)}}let i=this.ikConstraints,r=this.transformConstraints,h=this.pathConstraints,l=this.physicsConstraints,n=i.length,a=r.length,o=h.length,c=this.physicsConstraints.length,d=n+a+o+c;t:for(let f=0;f<d;f++){for(let m=0;m<n;m++){let u=i[m];if(u.data.order==f){this.sortIkConstraint(u);continue t}}for(let m=0;m<a;m++){let u=r[m];if(u.data.order==f){this.sortTransformConstraint(u);continue t}}for(let m=0;m<o;m++){let u=h[m];if(u.data.order==f){this.sortPathConstraint(u);continue t}}for(let m=0;m<c;m++){const u=l[m];if(u.data.order==f){this.sortPhysicsConstraint(u);continue t}}}for(let f=0,m=s.length;f<m;f++)this.sortBone(s[f])}sortIkConstraint(t){if(t.active=t.target.isActive()&&(!t.data.skinRequired||this.skin&&P.contains(this.skin.constraints,t.data,!0)),!t.active)return;let s=t.target;this.sortBone(s);let i=t.bones,r=i[0];if(this.sortBone(r),i.length==1)this._updateCache.push(t),this.sortReset(r.children);else{let h=i[i.length-1];this.sortBone(h),this._updateCache.push(t),this.sortReset(r.children),h.sorted=!0}}sortPathConstraint(t){if(t.active=t.target.bone.isActive()&&(!t.data.skinRequired||this.skin&&P.contains(this.skin.constraints,t.data,!0)),!t.active)return;let s=t.target,i=s.data.index,r=s.bone;this.skin&&this.sortPathConstraintAttachment(this.skin,i,r),this.data.defaultSkin&&this.data.defaultSkin!=this.skin&&this.sortPathConstraintAttachment(this.data.defaultSkin,i,r);for(let a=0,o=this.data.skins.length;a<o;a++)this.sortPathConstraintAttachment(this.data.skins[a],i,r);let h=s.getAttachment();h instanceof Ht&&this.sortPathConstraintAttachmentWith(h,r);let l=t.bones,n=l.length;for(let a=0;a<n;a++)this.sortBone(l[a]);this._updateCache.push(t);for(let a=0;a<n;a++)this.sortReset(l[a].children);for(let a=0;a<n;a++)l[a].sorted=!0}sortTransformConstraint(t){if(t.active=t.target.isActive()&&(!t.data.skinRequired||this.skin&&P.contains(this.skin.constraints,t.data,!0)),!t.active)return;this.sortBone(t.target);let s=t.bones,i=s.length;if(t.data.local)for(let r=0;r<i;r++){let h=s[r];this.sortBone(h.parent),this.sortBone(h)}else for(let r=0;r<i;r++)this.sortBone(s[r]);this._updateCache.push(t);for(let r=0;r<i;r++)this.sortReset(s[r].children);for(let r=0;r<i;r++)s[r].sorted=!0}sortPathConstraintAttachment(t,s,i){let r=t.attachments[s];if(r)for(let h in r)this.sortPathConstraintAttachmentWith(r[h],i)}sortPathConstraintAttachmentWith(t,s){if(!(t instanceof Ht))return;let i=t.bones;if(!i)this.sortBone(s);else{let r=this.bones;for(let h=0,l=i.length;h<l;){let n=i[h++];for(n+=h;h<n;)this.sortBone(r[i[h++]])}}}sortPhysicsConstraint(t){const s=t.bone;t.active=s.active&&(!t.data.skinRequired||this.skin!=null&&P.contains(this.skin.constraints,t.data,!0)),t.active&&(this.sortBone(s),this._updateCache.push(t),this.sortReset(s.children),s.sorted=!0)}sortBone(t){if(!t||t.sorted)return;let s=t.parent;s&&this.sortBone(s),t.sorted=!0,this._updateCache.push(t)}sortReset(t){for(let s=0,i=t.length;s<i;s++){let r=t[s];r.active&&(r.sorted&&this.sortReset(r.children),r.sorted=!1)}}updateWorldTransform(t){if(t==null)throw new Error("physics is undefined");let s=this.bones;for(let r=0,h=s.length;r<h;r++){let l=s[r];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 i=this._updateCache;for(let r=0,h=i.length;r<h;r++)i[r].update(t)}updateWorldTransformWith(t,s){if(!s)throw new Error("parent cannot be null.");let i=this.bones;for(let w=1,b=i.length;w<b;w++){let x=i[w];x.ax=x.x,x.ay=x.y,x.arotation=x.rotation,x.ascaleX=x.scaleX,x.ascaleY=x.scaleY,x.ashearX=x.shearX,x.ashearY=x.shearY}let r=this.getRootBone();if(!r)throw new Error("Root bone must not be null.");let h=s.a,l=s.b,n=s.c,a=s.d;r.worldX=h*this.x+l*this.y+s.worldX,r.worldY=n*this.x+a*this.y+s.worldY;const o=(r.rotation+r.shearX)*L.degRad,c=(r.rotation+90+r.shearY)*L.degRad,d=Math.cos(o)*r.scaleX,f=Math.cos(c)*r.scaleY,m=Math.sin(o)*r.scaleX,u=Math.sin(c)*r.scaleY;r.a=(h*d+l*m)*this.scaleX,r.b=(h*f+l*u)*this.scaleX,r.c=(n*d+a*m)*this.scaleY,r.d=(n*f+a*u)*this.scaleY;let g=this._updateCache;for(let w=0,b=g.length;w<b;w++){let x=g[w];x!=r&&x.update(t)}}setToSetupPose(){this.setBonesToSetupPose(),this.setSlotsToSetupPose()}setBonesToSetupPose(){for(const t of this.bones)t.setToSetupPose();for(const t of this.ikConstraints)t.setToSetupPose();for(const t of this.transformConstraints)t.setToSetupPose();for(const t of this.pathConstraints)t.setToSetupPose();for(const t of this.physicsConstraints)t.setToSetupPose()}setSlotsToSetupPose(){let t=this.slots;P.arrayCopy(t,0,this.drawOrder,0,t.length);for(let s=0,i=t.length;s<i;s++)t[s].setToSetupPose()}getRootBone(){return this.bones.length==0?null:this.bones[0]}findBone(t){if(!t)throw new Error("boneName cannot be null.");let s=this.bones;for(let i=0,r=s.length;i<r;i++){let h=s[i];if(h.data.name==t)return h}return null}findSlot(t){if(!t)throw new Error("slotName cannot be null.");let s=this.slots;for(let i=0,r=s.length;i<r;i++){let h=s[i];if(h.data.name==t)return h}return null}setSkinByName(t){let s=this.data.findSkin(t);if(!s)throw new Error("Skin not found: "+t);this.setSkin(s)}setSkin(t){if(t!=this.skin){if(t)if(this.skin)t.attachAll(this,this.skin);else{let s=this.slots;for(let i=0,r=s.length;i<r;i++){let h=s[i],l=h.data.attachmentName;if(l){let n=t.getAttachment(i,l);n&&h.setAttachment(n)}}}this.skin=t,this.updateCache()}}getAttachmentByName(t,s){let i=this.data.findSlot(t);if(!i)throw new Error(`Can't find slot with name ${t}`);return this.getAttachment(i.index,s)}getAttachment(t,s){if(!s)throw new Error("attachmentName cannot be null.");if(this.skin){let i=this.skin.getAttachment(t,s);if(i)return i}return this.data.defaultSkin?this.data.defaultSkin.getAttachment(t,s):null}setAttachment(t,s){if(!t)throw new Error("slotName cannot be null.");let i=this.slots;for(let r=0,h=i.length;r<h;r++){let l=i[r];if(l.data.name==t){let n=null;if(s&&(n=this.getAttachment(r,s),!n))throw new Error("Attachment not found: "+s+", for slot: "+t);l.setAttachment(n);return}}throw new Error("Slot not found: "+t)}findIkConstraint(t){if(!t)throw new Error("constraintName cannot be null.");return this.ikConstraints.find(s=>s.data.name==t)??null}findTransformConstraint(t){if(!t)throw new Error("constraintName cannot be null.");return this.transformConstraints.find(s=>s.data.name==t)??null}findPathConstraint(t){if(!t)throw new Error("constraintName cannot be null.");return this.pathConstraints.find(s=>s.data.name==t)??null}findPhysicsConstraint(t){if(t==null)throw new Error("constraintName cannot be null.");return this.physicsConstraints.find(s=>s.data.name==t)??null}getBoundsRect(t){let s=new Vt,i=new Vt;return this.getBounds(s,i,void 0,t),{x:s.x,y:s.y,width:i.x,height:i.y}}getBounds(t,s,i=new Array(2),r=null){if(!t)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,d=h.length;c<d;c++){let f=h[c];if(!f.bone.active)continue;let m=0,u=null,g=null,w=f.getAttachment();if(w instanceof se)m=8,u=P.setArraySize(i,m,0),w.computeWorldVertices(f,u,0,2),g=Ds.quadTriangles;else if(w instanceof Gt){let b=w;m=b.worldVerticesLength,u=P.setArraySize(i,m,0),b.computeWorldVertices(f,0,m,u,0,2),g=b.triangles}else if(w instanceof ee&&r!=null){r.clipStart(f,w);continue}if(u&&g){r!=null&&r.isClipping()&&(r.clipTriangles(u,g,g.length),u=r.clippedVertices,m=r.clippedVertices.length);for(let b=0,x=u.length;b<x;b+=2){let p=u[b],v=u[b+1];l=Math.min(l,p),n=Math.min(n,v),a=Math.max(a,p),o=Math.max(o,v)}}r?.clipEndWithSlot(f)}r?.clipEnd(),t.set(l,n),s.set(a-l,o-n)}update(t){this.time+=t}physicsTranslate(t,s){const i=this.physicsConstraints;for(let r=0,h=i.length;r<h;r++)i[r].translate(t,s)}physicsRotate(t,s,i){const r=this.physicsConstraints;for(let h=0,l=r.length;h<l;h++)r[h].rotate(t,s,i)}},gi=(e=>(e[e.none=0]="none",e[e.reset=1]="reset",e[e.update=2]="update",e[e.pose=3]="pose",e))(gi||{}),xi=class extends ie{_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)}},Ss=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,i=t.length;s<i;s++){let r=t[s];if(r.name==e)return r}return null}findSlot(e){if(!e)throw new Error("slotName cannot be null.");let t=this.slots;for(let s=0,i=t.length;s<i;s++){let r=t[s];if(r.name==e)return r}return null}findSkin(e){if(!e)throw new Error("skinName cannot be null.");let t=this.skins;for(let s=0,i=t.length;s<i;s++){let r=t[s];if(r.name==e)return r}return null}findEvent(e){if(!e)throw new Error("eventDataName cannot be null.");let t=this.events;for(let s=0,i=t.length;s<i;s++){let r=t[s];if(r.name==e)return r}return null}findAnimation(e){if(!e)throw new Error("animationName cannot be null.");let t=this.animations;for(let s=0,i=t.length;s<i;s++){let r=t[s];if(r.name==e)return r}return null}findIkConstraint(e){if(!e)throw new Error("constraintName cannot be null.");const t=this.ikConstraints;for(let s=0,i=t.length;s<i;s++){const r=t[s];if(r.name==e)return r}return null}findTransformConstraint(e){if(!e)throw new Error("constraintName cannot be null.");const t=this.transformConstraints;for(let s=0,i=t.length;s<i;s++){const r=t[s];if(r.name==e)return r}return null}findPathConstraint(e){if(!e)throw new Error("constraintName cannot be null.");const t=this.pathConstraints;for(let s=0,i=t.length;s<i;s++){const r=t[s];if(r.name==e)return r}return null}findPhysicsConstraint(e){if(!e)throw new Error("constraintName cannot be null.");const t=this.physicsConstraints;for(let s=0,i=t.length;s<i;s++){const r=t[s];if(r.name==e)return r}return null}},Is=class{constructor(e=0,t,s){this.slotIndex=e,this.name=t,this.attachment=s}},ge=class{name;attachments=new Array;bones=Array();constraints=new Array;color=new et(.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 i=this.attachments;e>=i.length&&(i.length=e+1),i[e]||(i[e]={}),i[e][t]=s}addSkin(e){for(let i=0;i<e.bones.length;i++){let r=e.bones[i],h=!1;for(let l=0;l<this.bones.length;l++)if(this.bones[l]==r){h=!0;break}h||this.bones.push(r)}for(let i=0;i<e.constraints.length;i++){let r=e.constraints[i],h=!1;for(let l=0;l<this.constraints.length;l++)if(this.constraints[l]==r){h=!0;break}h||this.constraints.push(r)}let t=e.getAttachments();for(let i=0;i<t.length;i++){var s=t[i];this.setAttachment(s.slotIndex,s.name,s.attachment)}}copySkin(e){for(let i=0;i<e.bones.length;i++){let r=e.bones[i],h=!1;for(let l=0;l<this.bones.length;l++)if(this.bones[l]==r){h=!0;break}h||this.bones.push(r)}for(let i=0;i<e.constraints.length;i++){let r=e.constraints[i],h=!1;for(let l=0;l<this.constraints.length;l++)if(this.constraints[l]==r){h=!0;break}h||this.constraints.push(r)}let t=e.getAttachments();for(let i=0;i<t.length;i++){var s=t[i];s.attachment&&(s.attachment instanceof Gt?(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 i in s){let r=s[i];r&&e.push(new Is(t,i,r))}}return e}getAttachmentsForSlot(e,t){let s=this.attachments[e];if(s)for(let i in s){let r=s[i];r&&t.push(new Is(e,i,r))}}clear(){this.attachments.length=0,this.bones.length=0,this.constraints.length=0}attachAll(e,t){let s=0;for(let i=0;i<e.slots.length;i++){let r=e.slots[i],h=r.getAttachment();if(h&&s<t.attachments.length){let l=t.attachments[s];for(let n in l){let a=l[n];if(h==a){let o=this.getAttachment(s,n);o&&r.setAttachment(o);break}}}s++}}},Ts=class{index=0;name;boneData;color=new et(1,1,1,1);darkColor=null;attachmentName=null;blendMode=0;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}},Ms=(e=>(e[e.Normal=0]="Normal",e[e.Additive=1]="Additive",e[e.Multiply=2]="Multiply",e[e.Screen=3]="Screen",e))(Ms||{}),Es=class extends ie{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)}},er=class{scale=1;attachmentLoader;linkedMeshes=new Array;constructor(e){this.attachmentLoader=e}readSkeletonData(e){let t=this.scale,s=new Ss;s.name="";let i=new pi(e),r=i.readInt32(),h=i.readInt32();s.hash=h==0&&r==0?null:h.toString(16)+r.toString(16),s.version=i.readString(),s.x=i.readFloat(),s.y=i.readFloat(),s.width=i.readFloat(),s.height=i.readFloat(),s.referenceScale=i.readFloat()*t;let l=i.readBoolean();l&&(s.fps=i.readFloat(),s.imagesPath=i.readString(),s.audioPath=i.readString());let n=0;n=i.readInt(!0);for(let o=0;o<n;o++){let c=i.readString();if(!c)throw new Error("String in string table must not be null.");i.strings.push(c)}n=i.readInt(!0);for(let o=0;o<n;o++){let c=i.readString();if(!c)throw new Error("Bone name must not be null.");let d=o==0?null:s.bones[i.readInt(!0)],f=new ms(o,c,d);f.rotation=i.readFloat(),f.x=i.readFloat()*t,f.y=i.readFloat()*t,f.scaleX=i.readFloat(),f.scaleY=i.readFloat(),f.shearX=i.readFloat(),f.shearY=i.readFloat(),f.length=i.readFloat()*t,f.inherit=i.readByte(),f.skinRequired=i.readBoolean(),l&&(et.rgba8888ToColor(f.color,i.readInt32()),f.icon=i.readString()??void 0,f.visible=i.readBoolean()),s.bones.push(f)}n=i.readInt(!0);for(let o=0;o<n;o++){let c=i.readString();if(!c)throw new Error("Slot name must not be null.");let d=s.bones[i.readInt(!0)],f=new Ts(o,c,d);et.rgba8888ToColor(f.color,i.readInt32());let m=i.readInt32();m!=-1&&et.rgb888ToColor(f.darkColor=new et,m),f.attachmentName=i.readStringRef(),f.blendMode=i.readInt(!0),l&&(f.visible=i.readBoolean()),s.slots.push(f)}n=i.readInt(!0);for(let o=0,c;o<n;o++){let d=i.readString();if(!d)throw new Error("IK constraint data name must not be null.");let f=new bs(d);f.order=i.readInt(!0),c=i.readInt(!0);for(let u=0;u<c;u++)f.bones.push(s.bones[i.readInt(!0)]);f.target=s.bones[i.readInt(!0)];let m=i.readByte();f.skinRequired=(m&1)!=0,f.bendDirection=(m&2)!=0?1:-1,f.compress=(m&4)!=0,f.stretch=(m&8)!=0,f.uniform=(m&16)!=0,(m&32)!=0&&(f.mix=(m&64)!=0?i.readFloat():1),(m&128)!=0&&(f.softness=i.readFloat()*t),s.ikConstraints.push(f)}n=i.readInt(!0);for(let o=0,c;o<n;o++){let d=i.readString();if(!d)throw new Error("Transform constraint data name must not be null.");let f=new Es(d);f.order=i.readInt(!0),c=i.readInt(!0);for(let u=0;u<c;u++)f.bones.push(s.bones[i.readInt(!0)]);f.target=s.bones[i.readInt(!0)];let m=i.readByte();f.skinRequired=(m&1)!=0,f.local=(m&2)!=0,f.relative=(m&4)!=0,(m&8)!=0&&(f.offsetRotation=i.readFloat()),(m&16)!=0&&(f.offsetX=i.readFloat()*t),(m&32)!=0&&(f.offsetY=i.readFloat()*t),(m&64)!=0&&(f.offsetScaleX=i.readFloat()),(m&128)!=0&&(f.offsetScaleY=i.readFloat()),m=i.readByte(),(m&1)!=0&&(f.offsetShearY=i.readFloat()),(m&2)!=0&&(f.mixRotate=i.readFloat()),(m&4)!=0&&(f.mixX=i.readFloat()),(m&8)!=0&&(f.mixY=i.readFloat()),(m&16)!=0&&(f.mixScaleX=i.readFloat()),(m&32)!=0&&(f.mixScaleY=i.readFloat()),(m&64)!=0&&(f.mixShearY=i.readFloat()),s.transformConstraints.push(f)}n=i.readInt(!0);for(let o=0,c;o<n;o++){let d=i.readString();if(!d)throw new Error("Path constraint data name must not be null.");let f=new vs(d);f.order=i.readInt(!0),f.skinRequired=i.readBoolean(),c=i.readInt(!0);for(let u=0;u<c;u++)f.bones.push(s.bones[i.readInt(!0)]);f.target=s.slots[i.readInt(!0)];const m=i.readByte();f.positionMode=m&1,f.spacingMode=m>>1&3,f.rotateMode=m>>3&3,(m&128)!=0&&(f.offsetRotation=i.readFloat()),f.position=i.readFloat(),f.positionMode==0&&(f.position*=t),f.spacing=i.readFloat(),(f.spacingMode==0||f.spacingMode==1)&&(f.spacing*=t),f.mixRotate=i.readFloat(),f.mixX=i.readFloat(),f.mixY=i.readFloat(),s.pathConstraints.push(f)}n=i.readInt(!0);for(let o=0,c;o<n;o++){const d=i.readString();if(!d)throw new Error("Physics constraint data name must not be null.");const f=new xi(d);f.order=i.readInt(!0),f.bone=s.bones[i.readInt(!0)];let m=i.readByte();f.skinRequired=(m&1)!=0,(m&2)!=0&&(f.x=i.readFloat()),(m&4)!=0&&(f.y=i.readFloat()),(m&8)!=0&&(f.rotate=i.readFloat()),(m&16)!=0&&(f.scaleX=i.readFloat()),(m&32)!=0&&(f.shearX=i.readFloat()),f.limit=((m&64)!=0?i.readFloat():5e3)*t,f.step=1/i.readUnsignedByte(),f.inertia=i.readFloat(),f.strength=i.readFloat(),f.damping=i.readFloat(),f.massInverse=(m&128)!=0?i.readFloat():1,f.wind=i.readFloat(),f.gravity=i.readFloat(),m=i.readByte(),(m&1)!=0&&(f.inertiaGlobal=!0),(m&2)!=0&&(f.strengthGlobal=!0),(m&4)!=0&&(f.dampingGlobal=!0),(m&8)!=0&&(f.massGlobal=!0),(m&16)!=0&&(f.windGlobal=!0),(m&32)!=0&&(f.gravityGlobal=!0),(m&64)!=0&&(f.mixGlobal=!0),f.mix=(m&128)!=0?i.readFloat():1,s.physicsConstraints.push(f)}let a=this.readSkin(i,s,!0,l);a&&(s.defaultSkin=a,s.skins.push(a));{let o=s.skins.length;for(P.setArraySize(s.skins,n=o+i.readInt(!0));o<n;o++){let c=this.readSkin(i,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 d=s.skins[c.skinIndex];if(!c.parent)throw new Error("Linked mesh parent must not be null");let f=d.getAttachment(c.slotIndex,c.parent);if(!f)throw new Error(`Parent mesh not found: ${c.parent}`);c.mesh.timelineAttachment=c.inheritTimeline?f:c.mesh,c.mesh.setParentMesh(f),c.mesh.region!=null&&c.mesh.updateRegion()}this.linkedMeshes.length=0,n=i.readInt(!0);for(let o=0;o<n;o++){let c=i.readString();if(!c)throw new Error("Event data name must not be null");let d=new ws(c);d.intValue=i.readInt(!1),d.floatValue=i.readFloat(),d.stringValue=i.readString(),d.audioPath=i.readString(),d.audioPath&&(d.volume=i.readFloat(),d.balance=i.readFloat()),s.events.push(d)}n=i.readInt(!0);for(let o=0;o<n;o++){let c=i.readString();if(!c)throw new Error("Animatio name must not be null.");s.animations.push(this.readAnimation(i,c,s))}return s}readSkin(e,t,s,i){let r=null,h=0;if(s){if(h=e.readInt(!0),h==0)return null;r=new ge("default")}else{let l=e.readString();if(!l)throw new Error("Skin name must not be null.");r=new ge(l),i&&et.rgba8888ToColor(r.color,e.readInt32()),r.bones.length=e.readInt(!0);for(let n=0,a=r.bones.length;n<a;n++)r.bones[n]=t.bones[e.readInt(!0)];for(let n=0,a=e.readInt(!0);n<a;n++)r.constraints.push(t.ikConstraints[e.readInt(!0)]);for(let n=0,a=e.readInt(!0);n<a;n++)r.constraints.push(t.transformConstraints[e.readInt(!0)]);for(let n=0,a=e.readInt(!0);n<a;n++)r.constraints.push(t.pathConstraints[e.readInt(!0)]);for(let n=0,a=e.readInt(!0);n<a;n++)r.constraints.push(t.physicsConstraints[e.readInt(!0)]);h=e.readInt(!0)}for(let l=0;l<h;l++){let n=e.readInt(!0);for(let a=0,o=e.readInt(!0);a<o;a++){let c=e.readStringRef();if(!c)throw new Error("Attachment name must not be null");let d=this.readAttachment(e,t,r,n,c,i);d&&r.setAttachment(n,c,d)}}return r}readAttachment(e,t,s,i,r,h){let l=this.scale,n=e.readByte();const a=(n&8)!=0?e.readStringRef():r;if(!a)throw new Error("Attachment name must not be null");switch(n&7){case 0:{let o=(n&16)!=0?e.readStringRef():null;const c=(n&32)!=0?e.readInt32():4294967295,d=(n&64)!=0?this.readSequence(e):null;let f=(n&128)!=0?e.readFloat():0,m=e.readFloat(),u=e.readFloat(),g=e.readFloat(),w=e.readFloat(),b=e.readFloat(),x=e.readFloat();o||(o=a);let p=this.attachmentLoader.newRegionAttachment(s,a,o,d);return p?(p.path=o,p.x=m*l,p.y=u*l,p.scaleX=g,p.scaleY=w,p.rotation=f,p.width=b*l,p.height=x*l,et.rgba8888ToColor(p.color,c),p.sequence=d,d==null&&p.updateRegion(),p):null}case 1:{let o=this.readVertices(e,(n&16)!=0),c=h?e.readInt32():0,d=this.attachmentLoader.newBoundingBoxAttachment(s,a);return d?(d.worldVerticesLength=o.length,d.vertices=o.vertices,d.bones=o.bones,h&&et.rgba8888ToColor(d.color,c),d):null}case 2:{let o=(n&16)!=0?e.readStringRef():a;const c=(n&32)!=0?e.readInt32():4294967295,d=(n&64)!=0?this.readSequence(e):null,f=e.readInt(!0),m=this.readVertices(e,(n&128)!=0),u=this.readFloatArray(e,m.length,1),g=this.readShortArray(e,(m.length-f-2)*3);let w=[],b=0,x=0;h&&(w=this.readShortArray(e,e.readInt(!0)),b=e.readFloat(),x=e.readFloat()),o||(o=a);let p=this.attachmentLoader.newMeshAttachment(s,a,o,d);return p?(p.path=o,et.rgba8888ToColor(p.color,c),p.bones=m.bones,p.vertices=m.vertices,p.worldVerticesLength=m.length,p.triangles=g,p.regionUVs=u,d==null&&p.updateRegion(),p.hullLength=f<<1,p.sequence=d,h&&(p.edges=w,p.width=b*l,p.height=x*l),p):null}case 3:{const o=(n&16)!=0?e.readStringRef():a;if(o==null)throw new Error("Path of linked mesh must not be null");const c=(n&32)!=0?e.readInt32():4294967295,d=(n&64)!=0?this.readSequence(e):null,f=(n&128)!=0,m=e.readInt(!0),u=e.readStringRef();let g=0,w=0;h&&(g=e.readFloat(),w=e.readFloat());let b=this.attachmentLoader.newMeshAttachment(s,a,o,d);return b?(b.path=o,et.rgba8888ToColor(b.color,c),b.sequence=d,h&&(b.width=g*l,b.height=w*l),this.linkedMeshes.push(new sr(b,m,i,u,f)),b):null}case 4:{const o=(n&16)!=0,c=(n&32)!=0,d=this.readVertices(e,(n&64)!=0),f=P.newArray(d.length/6,0);for(let g=0,w=f.length;g<w;g++)f[g]=e.readFloat()*l;const m=h?e.readInt32():0,u=this.attachmentLoader.newPathAttachment(s,a);return u?(u.closed=o,u.constantSpeed=c,u.worldVerticesLength=d.length,u.vertices=d.vertices,u.bones=d.bones,u.lengths=f,h&&et.rgba8888ToColor(u.color,m),u):null}case 5:{const o=e.readFloat(),c=e.readFloat(),d=e.readFloat(),f=h?e.readInt32():0,m=this.attachmentLoader.newPointAttachment(s,a);return m?(m.x=c*l,m.y=d*l,m.rotation=o,h&&et.rgba8888ToColor(m.color,f),m):null}case 6:{const o=e.readInt(!0),c=this.readVertices(e,(n&16)!=0);let d=h?e.readInt32():0,f=this.attachmentLoader.newClippingAttachment(s,a);return f?(f.endSlot=t.slots[o],f.worldVerticesLength=c.length,f.vertices=c.vertices,f.bones=c.bones,h&&et.rgba8888ToColor(f.color,d),f):null}}return null}readSequence(e){let t=new js(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,i=e.readInt(!0),r=new ir;if(r.length=i<<1,!t)return r.vertices=this.readFloatArray(e,r.length,s),r;let h=new Array,l=new Array;for(let n=0;n<i;n++){let a=e.readInt(!0);l.push(a);for(let o=0;o<a;o++)l.push(e.readInt(!0)),h.push(e.readFloat()*s),h.push(e.readFloat()*s),h.push(e.readFloat())}return r.vertices=P.toFloatArray(h),r.bones=l,r}readFloatArray(e,t,s){let i=new Array(t);if(s==1)for(let r=0;r<t;r++)i[r]=e.readFloat();else for(let r=0;r<t;r++)i[r]=e.readFloat()*s;return i}readShortArray(e,t){let s=new Array(t);for(let i=0;i<t;i++)s[i]=e.readInt(!0);return s}readAnimation(e,t,s){e.readInt(!0);let i=new Array,r=this.scale;for(let a=0,o=e.readInt(!0);a<o;a++){let c=e.readInt(!0);for(let d=0,f=e.readInt(!0);d<f;d++){let m=e.readByte(),u=e.readInt(!0),g=u-1;switch(m){case gr:{let w=new Ot(u,c);for(let b=0;b<u;b++)w.setFrame(b,e.readFloat(),e.readStringRef());i.push(w);break}case xr:{let w=e.readInt(!0),b=new Ue(u,w,c),x=e.readFloat(),p=e.readUnsignedByte()/255,v=e.readUnsignedByte()/255,y=e.readUnsignedByte()/255,A=e.readUnsignedByte()/255;for(let C=0,S=0;b.setFrame(C,x,p,v,y,A),C!=g;C++){let T=e.readFloat(),R=e.readUnsignedByte()/255,k=e.readUnsignedByte()/255,F=e.readUnsignedByte()/255,X=e.readUnsignedByte()/255;switch(e.readByte()){case kt:b.setStepped(C);break;case Ft:at(e,b,S++,C,0,x,T,p,R,1),at(e,b,S++,C,1,x,T,v,k,1),at(e,b,S++,C,2,x,T,y,F,1),at(e,b,S++,C,3,x,T,A,X,1)}x=T,p=R,v=k,y=F,A=X}i.push(b);break}case pr:{let w=e.readInt(!0),b=new ze(u,w,c),x=e.readFloat(),p=e.readUnsignedByte()/255,v=e.readUnsignedByte()/255,y=e.readUnsignedByte()/255;for(let A=0,C=0;b.setFrame(A,x,p,v,y),A!=g;A++){let S=e.readFloat(),T=e.readUnsignedByte()/255,R=e.readUnsignedByte()/255,k=e.readUnsignedByte()/255;switch(e.readByte()){case kt:b.setStepped(A);break;case Ft:at(e,b,C++,A,0,x,S,p,T,1),at(e,b,C++,A,1,x,S,v,R,1),at(e,b,C++,A,2,x,S,y,k,1)}x=S,p=T,v=R,y=k}i.push(b);break}case wr:{let w=e.readInt(!0),b=new qe(u,w,c),x=e.readFloat(),p=e.readUnsignedByte()/255,v=e.readUnsignedByte()/255,y=e.readUnsignedByte()/255,A=e.readUnsignedByte()/255,C=e.readUnsignedByte()/255,S=e.readUnsignedByte()/255,T=e.readUnsignedByte()/255;for(let R=0,k=0;b.setFrame(R,x,p,v,y,A,C,S,T),R!=g;R++){let F=e.readFloat(),X=e.readUnsignedByte()/255,E=e.readUnsignedByte()/255,Y=e.readUnsignedByte()/255,B=e.readUnsignedByte()/255,st=e.readUnsignedByte()/255,tt=e.readUnsignedByte()/255,it=e.readUnsignedByte()/255;switch(e.readByte()){case kt:b.setStepped(R);break;case Ft:at(e,b,k++,R,0,x,F,p,X,1),at(e,b,k++,R,1,x,F,v,E,1),at(e,b,k++,R,2,x,F,y,Y,1),at(e,b,k++,R,3,x,F,A,B,1),at(e,b,k++,R,4,x,F,C,st,1),at(e,b,k++,R,5,x,F,S,tt,1),at(e,b,k++,R,6,x,F,T,it,1)}x=F,p=X,v=E,y=Y,A=B,C=st,S=tt,T=it}i.push(b);break}case br:{let w=e.readInt(!0),b=new Ge(u,w,c),x=e.readFloat(),p=e.readUnsignedByte()/255,v=e.readUnsignedByte()/255,y=e.readUnsignedByte()/255,A=e.readUnsignedByte()/255,C=e.readUnsignedByte()/255,S=e.readUnsignedByte()/255;for(let T=0,R=0;b.setFrame(T,x,p,v,y,A,C,S),T!=g;T++){let k=e.readFloat(),F=e.readUnsignedByte()/255,X=e.readUnsignedByte()/255,E=e.readUnsignedByte()/255,Y=e.readUnsignedByte()/255,B=e.readUnsignedByte()/255,st=e.readUnsignedByte()/255;switch(e.readByte()){case kt:b.setStepped(T);break;case Ft:at(e,b,R++,T,0,x,k,p,F,1),at(e,b,R++,T,1,x,k,v,X,1),at(e,b,R++,T,2,x,k,y,E,1),at(e,b,R++,T,3,x,k,A,Y,1),at(e,b,R++,T,4,x,k,C,B,1),at(e,b,R++,T,5,x,k,S,st,1)}x=k,p=F,v=X,y=E,A=Y,C=B,S=st}i.push(b);break}case vr:{let w=new We(u,e.readInt(!0),c),b=e.readFloat(),x=e.readUnsignedByte()/255;for(let p=0,v=0;w.setFrame(p,b,x),p!=g;p++){let y=e.readFloat(),A=e.readUnsignedByte()/255;switch(e.readByte()){case kt:w.setStepped(p);break;case Ft:at(e,w,v++,p,0,b,y,x,A,1)}b=y,x=A}i.push(w)}}}}for(let a=0,o=e.readInt(!0);a<o;a++){let c=e.readInt(!0);for(let d=0,f=e.readInt(!0);d<f;d++){let m=e.readByte(),u=e.readInt(!0);if(m==mr){let w=new Ne(u,c);for(let b=0;b<u;b++)w.setFrame(b,e.readFloat(),e.readByte());i.push(w);continue}let g=e.readInt(!0);switch(m){case rr:i.push(pt(e,new te(u,g,c),1));break;case nr:i.push(Ys(e,new ke(u,g,c),r));break;case ar:i.push(pt(e,new Fe(u,g,c),r));break;case lr:i.push(pt(e,new Xe(u,g,c),r));break;case or:i.push(Ys(e,new Le(u,g,c),1));break;case hr:i.push(pt(e,new Pe(u,g,c),1));break;case cr:i.push(pt(e,new Be(u,g,c),1));break;case dr:i.push(Ys(e,new Ve(u,g,c),1));break;case fr:i.push(pt(e,new Oe(u,g,c),1));break;case ur:i.push(pt(e,new De(u,g,c),1))}}}for(let a=0,o=e.readInt(!0);a<o;a++){let c=e.readInt(!0),d=e.readInt(!0),f=d-1,m=new _e(d,e.readInt(!0),c),u=e.readByte(),g=e.readFloat(),w=(u&1)!=0?(u&2)!=0?e.readFloat():1:0,b=(u&4)!=0?e.readFloat()*r:0;for(let x=0,p=0;m.setFrame(x,g,w,b,(u&8)!=0?1:-1,(u&16)!=0,(u&32)!=0),x!=f;x++){u=e.readByte();const v=e.readFloat(),y=(u&1)!=0?(u&2)!=0?e.readFloat():1:0,A=(u&4)!=0?e.readFloat()*r:0;(u&64)!=0?m.setStepped(x):(u&128)!=0&&(at(e,m,p++,x,0,g,v,w,y,1),at(e,m,p++,x,1,g,v,b,A,r)),g=v,w=y,b=A}i.push(m)}for(let a=0,o=e.readInt(!0);a<o;a++){let c=e.readInt(!0),d=e.readInt(!0),f=d-1,m=new je(d,e.readInt(!0),c),u=e.readFloat(),g=e.readFloat(),w=e.readFloat(),b=e.readFloat(),x=e.readFloat(),p=e.readFloat(),v=e.readFloat();for(let y=0,A=0;m.setFrame(y,u,g,w,b,x,p,v),y!=f;y++){let C=e.readFloat(),S=e.readFloat(),T=e.readFloat(),R=e.readFloat(),k=e.readFloat(),F=e.readFloat(),X=e.readFloat();switch(e.readByte()){case kt:m.setStepped(y);break;case Ft:at(e,m,A++,y,0,u,C,g,S,1),at(e,m,A++,y,1,u,C,w,T,1),at(e,m,A++,y,2,u,C,b,R,1),at(e,m,A++,y,3,u,C,x,k,1),at(e,m,A++,y,4,u,C,p,F,1),at(e,m,A++,y,5,u,C,v,X,1)}u=C,g=S,w=T,b=R,x=k,p=F,v=X}i.push(m)}for(let a=0,o=e.readInt(!0);a<o;a++){let c=e.readInt(!0),d=s.pathConstraints[c];for(let f=0,m=e.readInt(!0);f<m;f++){const u=e.readByte(),g=e.readInt(!0),w=e.readInt(!0);switch(u){case Cr:i.push(pt(e,new Ze(g,w,c),d.positionMode==0?r:1));break;case Sr:i.push(pt(e,new Ke(g,w,c),d.spacingMode==0||d.spacingMode==1?r:1));break;case Ir:let b=new Je(g,w,c),x=e.readFloat(),p=e.readFloat(),v=e.readFloat(),y=e.readFloat();for(let A=0,C=0,S=b.getFrameCount()-1;b.setFrame(A,x,p,v,y),A!=S;A++){let T=e.readFloat(),R=e.readFloat(),k=e.readFloat(),F=e.readFloat();switch(e.readByte()){case kt:b.setStepped(A);break;case Ft:at(e,b,C++,A,0,x,T,p,R,1),at(e,b,C++,A,1,x,T,v,k,1),at(e,b,C++,A,2,x,T,y,F,1)}x=T,p=R,v=k,y=F}i.push(b)}}}for(let a=0,o=e.readInt(!0);a<o;a++){const c=e.readInt(!0)-1;for(let d=0,f=e.readInt(!0);d<f;d++){const m=e.readByte(),u=e.readInt(!0);if(m==Xr){const w=new ns(u,c);for(let b=0;b<u;b++)w.setFrame(b,e.readFloat());i.push(w);continue}const g=e.readInt(!0);switch(m){case Tr:i.push(pt(e,new Qe(u,g,c),1));break;case Mr:i.push(pt(e,new $e(u,g,c),1));break;case Er:i.push(pt(e,new ts(u,g,c),1));break;case Yr:i.push(pt(e,new es(u,g,c),1));break;case Rr:i.push(pt(e,new ss(u,g,c),1));break;case kr:i.push(pt(e,new is(u,g,c),1));break;case Fr:i.push(pt(e,new rs(u,g,c),1))}}}for(let a=0,o=e.readInt(!0);a<o;a++){let c=s.skins[e.readInt(!0)];for(let d=0,f=e.readInt(!0);d<f;d++){let m=e.readInt(!0);for(let u=0,g=e.readInt(!0);u<g;u++){let w=e.readStringRef();if(!w)throw new Error("attachmentName must not be null.");let b=c.getAttachment(m,w),x=e.readByte(),p=e.readInt(!0),v=p-1;switch(x){case yr:{let y=b,A=y.bones,C=y.vertices,S=A?C.length/3*2:C.length,T=e.readInt(!0),R=new He(p,T,m,y),k=e.readFloat();for(let F=0,X=0;;F++){let E,Y=e.readInt(!0);if(Y==0)E=A?P.newFloatArray(S):C;else{E=P.newFloatArray(S);let st=e.readInt(!0);if(Y+=st,r==1)for(let tt=st;tt<Y;tt++)E[tt]=e.readFloat();else for(let tt=st;tt<Y;tt++)E[tt]=e.readFloat()*r;if(!A)for(let tt=0,it=E.length;tt<it;tt++)E[tt]+=C[tt]}if(R.setFrame(F,k,E),F==v)break;let B=e.readFloat();switch(e.readByte()){case kt:R.setStepped(F);break;case Ft:at(e,R,X++,F,0,k,B,0,1,1)}k=B}i.push(R);break}case Ar:{let y=new as(p,m,b);for(let A=0;A<p;A++){let C=e.readFloat(),S=e.readInt32();y.setFrame(A,C,Ks[S&15],S>>4,e.readFloat())}i.push(y);break}}}}}let h=e.readInt(!0);if(h>0){let a=new qt(h),o=s.slots.length;for(let c=0;c<h;c++){let d=e.readFloat(),f=e.readInt(!0),m=P.newArray(o,0);for(let b=o-1;b>=0;b--)m[b]=-1;let u=P.newArray(o-f,0),g=0,w=0;for(let b=0;b<f;b++){let x=e.readInt(!0);for(;g!=x;)u[w++]=g++;m[g+e.readInt(!0)]=g++}for(;g<o;)u[w++]=g++;for(let b=o-1;b>=0;b--)m[b]==-1&&(m[b]=u[--w]);a.setFrame(c,d,m)}i.push(a)}let l=e.readInt(!0);if(l>0){let a=new ce(l);for(let o=0;o<l;o++){let c=e.readFloat(),d=s.events[e.readInt(!0)],f=new ps(c,d);f.intValue=e.readInt(!1),f.floatValue=e.readFloat(),f.stringValue=e.readString(),f.stringValue==null&&(f.stringValue=d.stringValue),f.data.audioPath&&(f.volume=e.readFloat(),f.balance=e.readFloat()),a.setFrame(o,f)}i.push(a)}let n=0;for(let a=0,o=i.length;a<o;a++)n=Math.max(n,i[a].getDuration());return new oe(t,i,n)}},pi=class{constructor(e,t=new Array,s=0,i=new DataView(e instanceof ArrayBuffer?e:e.buffer)){this.strings=t,this.index=s,this.buffer=i}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)!=0&&(t=this.readByte(),s|=(t&127)<<7,(t&128)!=0&&(t=this.readByte(),s|=(t&127)<<14,(t&128)!=0&&(t=this.readByte(),s|=(t&127)<<21,(t&128)!=0&&(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 i=0;i<e;){let r=this.readUnsignedByte();switch(r>>4){case 12:case 13:t+=String.fromCharCode((r&31)<<6|this.readByte()&63),i+=2;break;case 14:t+=String.fromCharCode((r&15)<<12|(this.readByte()&63)<<6|this.readByte()&63),i+=3;break;default:t+=String.fromCharCode(r),i++}}return t}readFloat(){let e=this.buffer.getFloat32(this.index);return this.index+=4,e}readBoolean(){return this.readByte()!=0}},sr=class{parent;skinIndex;slotIndex;mesh;inheritTimeline;constructor(e,t,s,i,r){this.mesh=e,this.skinIndex=t,this.slotIndex=s,this.parent=i,this.inheritTimeline=r}},ir=class{constructor(e=null,t=null,s=0){this.bones=e,this.vertices=t,this.length=s}};function pt(e,t,s){let i=e.readFloat(),r=e.readFloat()*s;for(let h=0,l=0,n=t.getFrameCount()-1;t.setFrame(h,i,r),h!=n;h++){let a=e.readFloat(),o=e.readFloat()*s;switch(e.readByte()){case kt:t.setStepped(h);break;case Ft:at(e,t,l++,h,0,i,a,r,o,s)}i=a,r=o}return t}function Ys(e,t,s){let i=e.readFloat(),r=e.readFloat()*s,h=e.readFloat()*s;for(let l=0,n=0,a=t.getFrameCount()-1;t.setFrame(l,i,r,h),l!=a;l++){let o=e.readFloat(),c=e.readFloat()*s,d=e.readFloat()*s;switch(e.readByte()){case kt:t.setStepped(l);break;case Ft:at(e,t,n++,l,0,i,o,r,c,s),at(e,t,n++,l,1,i,o,h,d,s)}i=o,r=c,h=d}return t}function at(e,t,s,i,r,h,l,n,a,o){t.setBezier(s,i,r,h,n,e.readFloat(),e.readFloat()*o,e.readFloat(),e.readFloat()*o,l,a)}var rr=0,nr=1,ar=2,lr=3,or=4,hr=5,cr=6,dr=7,fr=8,ur=9,mr=10,gr=0,xr=1,pr=2,wr=3,br=4,vr=5,yr=0,Ar=1,Cr=0,Sr=1,Ir=2,Tr=0,Mr=1,Er=2,Yr=4,Rr=5,kr=6,Fr=7,Xr=8,kt=1,Ft=2,wi=class{minX=0;minY=0;maxX=0;maxY=0;boundingBoxes=new Array;polygons=new Array;polygonPool=new $t(()=>P.newFloatArray(16));update(e,t){if(!e)throw new Error("skeleton cannot be null.");let s=this.boundingBoxes,i=this.polygons,r=this.polygonPool,h=e.slots,l=h.length;s.length=0,r.freeAll(i),i.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 cs){let c=o;s.push(c);let d=r.obtain();d.length!=c.worldVerticesLength&&(d=P.newFloatArray(c.worldVerticesLength)),i.push(d),c.computeWorldVertices(a,0,c.worldVerticesLength,d,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,i=Number.NEGATIVE_INFINITY,r=this.polygons;for(let h=0,l=r.length;h<l;h++){let n=r[h],a=n;for(let o=0,c=n.length;o<c;o+=2){let d=a[o],f=a[o+1];e=Math.min(e,d),t=Math.min(t,f),s=Math.max(s,d),i=Math.max(i,f)}}this.minX=e,this.minY=t,this.maxX=s,this.maxY=i}aabbContainsPoint(e,t){return e>=this.minX&&e<=this.maxX&&t>=this.minY&&t<=this.maxY}aabbIntersectsSegment(e,t,s,i){let r=this.minX,h=this.minY,l=this.maxX,n=this.maxY;if(e<=r&&s<=r||t<=h&&i<=h||e>=l&&s>=l||t>=n&&i>=n)return!1;let a=(i-t)/(s-e),o=a*(r-e)+t;if(o>h&&o<n||(o=a*(l-e)+t,o>h&&o<n))return!0;let c=(h-t)/a+e;return c>r&&c<l||(c=(n-t)/a+e,c>r&&c<l)}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 i=0,r=s.length;i<r;i++)if(this.containsPointPolygon(s[i],e,t))return this.boundingBoxes[i];return null}containsPointPolygon(e,t,s){let i=e,r=e.length,h=r-2,l=!1;for(let n=0;n<r;n+=2){let a=i[n+1],o=i[h+1];if(a<s&&o>=s||o<s&&a>=s){let c=i[n];c+(s-a)/(o-a)*(i[h]-c)<t&&(l=!l)}h=n}return l}intersectsSegment(e,t,s,i){let r=this.polygons;for(let h=0,l=r.length;h<l;h++)if(this.intersectsSegmentPolygon(r[h],e,t,s,i))return this.boundingBoxes[h];return null}intersectsSegmentPolygon(e,t,s,i,r){let h=e,l=e.length,n=t-i,a=s-r,o=t*r-s*i,c=h[l-2],d=h[l-1];for(let f=0;f<l;f+=2){let m=h[f],u=h[f+1],g=c*u-d*m,w=c-m,b=d-u,x=n*b-a*w,p=(o*w-n*g)/x;if((p>=c&&p<=m||p>=m&&p<=c)&&(p>=t&&p<=i||p>=i&&p<=t)){let v=(o*b-a*g)/x;if((v>=d&&v<=u||v>=u&&v<=d)&&(v>=s&&v<=r||v>=r&&v<=s))return!0}c=m,d=u}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}},bi=class vt{convexPolygons=new Array;convexPolygonsIndices=new Array;indicesArray=new Array;isConcaveArray=new Array;triangles=new Array;polygonPool=new $t(()=>new Array);polygonIndicesPool=new $t(()=>new Array);triangulate(t){let s=t,i=t.length>>1,r=this.indicesArray;r.length=0;for(let n=0;n<i;n++)r[n]=n;let h=this.isConcaveArray;h.length=0;for(let n=0,a=i;n<a;++n)h[n]=vt.isConcave(n,i,s,r);let l=this.triangles;for(l.length=0;i>3;){let n=i-1,a=0,o=1;for(;;){t:if(!h[a]){let f=r[n]<<1,m=r[a]<<1,u=r[o]<<1,g=s[f],w=s[f+1],b=s[m],x=s[m+1],p=s[u],v=s[u+1];for(let y=(o+1)%i;y!=n;y=(y+1)%i){if(!h[y])continue;let A=r[y]<<1,C=s[A],S=s[A+1];if(vt.positiveArea(p,v,g,w,C,S)&&vt.positiveArea(g,w,b,x,C,S)&&vt.positiveArea(b,x,p,v,C,S))break t}break}if(o==0){do{if(!h[a])break;a--}while(a>0);break}n=a,a=o,o=(o+1)%i}l.push(r[(i+a-1)%i]),l.push(r[a]),l.push(r[(a+1)%i]),r.splice(a,1),h.splice(a,1),i--;let c=(i+a-1)%i,d=a==i?0:a;h[c]=vt.isConcave(c,i,s,r),h[d]=vt.isConcave(d,i,s,r)}return i==3&&(l.push(r[2]),l.push(r[0]),l.push(r[1])),l}decompose(t,s){let i=t,r=this.convexPolygons;this.polygonPool.freeAll(r),r.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,d=s.length;c<d;c+=3){let f=s[c]<<1,m=s[c+1]<<1,u=s[c+2]<<1,g=i[f],w=i[f+1],b=i[m],x=i[m+1],p=i[u],v=i[u+1],y=!1;if(a==f){let A=n.length-4,C=vt.winding(n[A],n[A+1],n[A+2],n[A+3],p,v),S=vt.winding(p,v,n[0],n[1],n[2],n[3]);C==o&&S==o&&(n.push(p),n.push(v),l.push(u),y=!0)}y||(n.length>0?(r.push(n),h.push(l)):(this.polygonPool.free(n),this.polygonIndicesPool.free(l)),n=this.polygonPool.obtain(),n.length=0,n.push(g),n.push(w),n.push(b),n.push(x),n.push(p),n.push(v),l=this.polygonIndicesPool.obtain(),l.length=0,l.push(f),l.push(m),l.push(u),o=vt.winding(g,w,b,x,p,v),a=f)}n.length>0&&(r.push(n),h.push(l));for(let c=0,d=r.length;c<d;c++){if(l=h[c],l.length==0)continue;let f=l[0],m=l[l.length-1];n=r[c];let u=n.length-4,g=n[u],w=n[u+1],b=n[u+2],x=n[u+3],p=n[0],v=n[1],y=n[2],A=n[3],C=vt.winding(g,w,b,x,p,v);for(let S=0;S<d;S++){if(S==c)continue;let T=h[S];if(T.length!=3)continue;let R=T[0],k=T[1],F=T[2],X=r[S],E=X[X.length-2],Y=X[X.length-1];if(R!=f||k!=m)continue;let B=vt.winding(g,w,b,x,E,Y),st=vt.winding(E,Y,p,v,y,A);B==C&&st==C&&(X.length=0,T.length=0,n.push(E),n.push(Y),l.push(F),g=b,w=x,b=E,x=Y,S=0)}}for(let c=r.length-1;c>=0;c--)n=r[c],n.length==0&&(r.splice(c,1),this.polygonPool.free(n),l=h[c],h.splice(c,1),this.polygonIndicesPool.free(l));return r}static isConcave(t,s,i,r){let h=r[(s+t-1)%s]<<1,l=r[t]<<1,n=r[(t+1)%s]<<1;return!this.positiveArea(i[h],i[h+1],i[l],i[l+1],i[n],i[n+1])}static positiveArea(t,s,i,r,h,l){return t*(l-r)+i*(s-l)+h*(r-s)>=0}static winding(t,s,i,r,h,l){let n=i-t,a=r-s;return h*a-l*n+n*s-t*a>=0?1:-1}},vi=class Ns{triangulator=new bi;clippingPolygon=new Array;clipOutput=new Array;clippedVertices=new Array;clippedUVs=new Array;clippedTriangles=new Array;scratch=new Array;clipAttachment=null;clippingPolygons=null;clipStart(t,s){if(this.clipAttachment)return 0;this.clipAttachment=s;let i=s.worldVerticesLength,r=P.setArraySize(this.clippingPolygon,i);s.computeWorldVertices(t,0,i,r,0,2);let h=this.clippingPolygon;Ns.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];Ns.makeClockwise(o),o.push(o[0]),o.push(o[1])}return l.length}clipEndWithSlot(t){this.clipAttachment&&this.clipAttachment.endSlot==t.data&&this.clipEnd()}clipEnd(){this.clipAttachment&&(this.clipAttachment=null,this.clippingPolygons=null,this.clippedVertices.length=0,this.clippedTriangles.length=0,this.clippingPolygon.length=0)}isClipping(){return this.clipAttachment!=null}clipTriangles(t,s,i,r,h,l,n,a){let o,c,d,f,m,u;typeof s=="number"?(o=i,c=r,d=h,f=l,m=n,u=a):(o=s,c=i,d=r,f=h,m=l,u=n),d&&f&&m&&typeof u=="boolean"?this.clipTrianglesRender(t,o,c,d,f,m,u):this.clipTrianglesNoRender(t,o,c)}clipTrianglesNoRender(t,s,i){let r=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<i;c+=3){let d=s[c]<<1,f=t[d],m=t[d+1];d=s[c+1]<<1;let u=t[d],g=t[d+1];d=s[c+2]<<1;let w=t[d],b=t[d+1];for(let x=0;x<a;x++){let p=h.length;if(this.clip(f,m,u,g,w,b,n[x],r)){let v=r.length;if(v==0)continue;let y=v>>1,A=this.clipOutput,C=P.setArraySize(h,p+y*2);for(let T=0;T<v;T+=2,p+=2){let R=A[T],k=A[T+1];C[p]=R,C[p+1]=k}p=l.length;let S=P.setArraySize(l,p+3*(y-2));y--;for(let T=1;T<y;T++,p+=3)S[p]=o,S[p+1]=o+T,S[p+2]=o+T+1;o+=y+1}else{let v=P.setArraySize(h,p+6);v[p]=f,v[p+1]=m,v[p+2]=u,v[p+3]=g,v[p+4]=w,v[p+5]=b,p=l.length;let y=P.setArraySize(l,p+3);y[p]=o,y[p+1]=o+1,y[p+2]=o+2,o+=3;break}}}}clipTrianglesRender(t,s,i,r,h,l,n){let a=this.clipOutput,o=this.clippedVertices,c=this.clippedTriangles,d=this.clippingPolygons,f=d.length,m=n?12:8,u=0;o.length=0,c.length=0;for(let g=0;g<i;g+=3){let w=s[g]<<1,b=t[w],x=t[w+1],p=r[w],v=r[w+1];w=s[g+1]<<1;let y=t[w],A=t[w+1],C=r[w],S=r[w+1];w=s[g+2]<<1;let T=t[w],R=t[w+1],k=r[w],F=r[w+1];for(let X=0;X<f;X++){let E=o.length;if(this.clip(b,x,y,A,T,R,d[X],a)){let Y=a.length;if(Y==0)continue;let B=A-R,st=T-y,tt=b-T,it=R-x,ct=1/(B*tt+st*(x-R)),lt=Y>>1,ut=this.clipOutput,W=P.setArraySize(o,E+lt*m);for(let ht=0;ht<Y;ht+=2,E+=m){let bt=ut[ht],mt=ut[ht+1];W[E]=bt,W[E+1]=mt,W[E+2]=h.r,W[E+3]=h.g,W[E+4]=h.b,W[E+5]=h.a;let gt=bt-T,xt=mt-R,Ct=(B*gt+st*xt)*ct,zt=(it*gt+tt*xt)*ct,Jt=1-Ct-zt;W[E+6]=p*Ct+C*zt+k*Jt,W[E+7]=v*Ct+S*zt+F*Jt,n&&(W[E+8]=l.r,W[E+9]=l.g,W[E+10]=l.b,W[E+11]=l.a)}E=c.length;let nt=P.setArraySize(c,E+3*(lt-2));lt--;for(let ht=1;ht<lt;ht++,E+=3)nt[E]=u,nt[E+1]=u+ht,nt[E+2]=u+ht+1;u+=lt+1}else{let Y=P.setArraySize(o,E+3*m);Y[E]=b,Y[E+1]=x,Y[E+2]=h.r,Y[E+3]=h.g,Y[E+4]=h.b,Y[E+5]=h.a,n?(Y[E+6]=p,Y[E+7]=v,Y[E+8]=l.r,Y[E+9]=l.g,Y[E+10]=l.b,Y[E+11]=l.a,Y[E+12]=y,Y[E+13]=A,Y[E+14]=h.r,Y[E+15]=h.g,Y[E+16]=h.b,Y[E+17]=h.a,Y[E+18]=C,Y[E+19]=S,Y[E+20]=l.r,Y[E+21]=l.g,Y[E+22]=l.b,Y[E+23]=l.a,Y[E+24]=T,Y[E+25]=R,Y[E+26]=h.r,Y[E+27]=h.g,Y[E+28]=h.b,Y[E+29]=h.a,Y[E+30]=k,Y[E+31]=F,Y[E+32]=l.r,Y[E+33]=l.g,Y[E+34]=l.b,Y[E+35]=l.a):(Y[E+6]=p,Y[E+7]=v,Y[E+8]=y,Y[E+9]=A,Y[E+10]=h.r,Y[E+11]=h.g,Y[E+12]=h.b,Y[E+13]=h.a,Y[E+14]=C,Y[E+15]=S,Y[E+16]=T,Y[E+17]=R,Y[E+18]=h.r,Y[E+19]=h.g,Y[E+20]=h.b,Y[E+21]=h.a,Y[E+22]=k,Y[E+23]=F),E=c.length;let B=P.setArraySize(c,E+3);B[E]=u,B[E+1]=u+1,B[E+2]=u+2,u+=3;break}}}}clipTrianglesUnpacked(t,s,i,r){let h=this.clipOutput,l=this.clippedVertices,n=this.clippedUVs,a=this.clippedTriangles,o=this.clippingPolygons,c=o.length,d=0;l.length=0,n.length=0,a.length=0;for(let f=0;f<i;f+=3){let m=s[f]<<1,u=t[m],g=t[m+1],w=r[m],b=r[m+1];m=s[f+1]<<1;let x=t[m],p=t[m+1],v=r[m],y=r[m+1];m=s[f+2]<<1;let A=t[m],C=t[m+1],S=r[m],T=r[m+1];for(let R=0;R<c;R++){let k=l.length;if(this.clip(u,g,x,p,A,C,o[R],h)){let F=h.length;if(F==0)continue;let X=p-C,E=A-x,Y=u-A,B=C-g,st=1/(X*Y+E*(g-C)),tt=F>>1,it=this.clipOutput,ct=P.setArraySize(l,k+tt*2),lt=P.setArraySize(n,k+tt*2);for(let W=0;W<F;W+=2,k+=2){let nt=it[W],ht=it[W+1];ct[k]=nt,ct[k+1]=ht;let bt=nt-A,mt=ht-C,gt=(X*bt+E*mt)*st,xt=(B*bt+Y*mt)*st,Ct=1-gt-xt;lt[k]=w*gt+v*xt+S*Ct,lt[k+1]=b*gt+y*xt+T*Ct}k=a.length;let ut=P.setArraySize(a,k+3*(tt-2));tt--;for(let W=1;W<tt;W++,k+=3)ut[k]=d,ut[k+1]=d+W,ut[k+2]=d+W+1;d+=tt+1}else{let F=P.setArraySize(l,k+6);F[k]=u,F[k+1]=g,F[k+2]=x,F[k+3]=p,F[k+4]=A,F[k+5]=C;let X=P.setArraySize(n,k+3*2);X[k]=w,X[k+1]=b,X[k+2]=v,X[k+3]=y,X[k+4]=S,X[k+5]=T,k=a.length;let E=P.setArraySize(a,k+3);E[k]=d,E[k+1]=d+1,E[k+2]=d+2,d+=3;break}}}}clip(t,s,i,r,h,l,n,a){let o=a,c=!1,d;n.length%4>=2?(d=a,a=this.scratch):d=this.scratch,d.length=0,d.push(t),d.push(s),d.push(i),d.push(r),d.push(h),d.push(l),d.push(t),d.push(s),a.length=0;let f=n.length-4,m=n;for(let u=0;;u+=2){let g=m[u],w=m[u+1],b=g-m[u+2],x=w-m[u+3],p=a.length,v=d;for(let A=0,C=d.length-2;A<C;){let S=v[A],T=v[A+1];A+=2;let R=v[A],k=v[A+1],F=x*(g-R)>b*(w-k),X=x*(g-S)-b*(w-T);if(X>0){if(F){a.push(R),a.push(k);continue}let E=R-S,Y=k-T,B=X/(E*x-Y*b);if(B>=0&&B<=1)a.push(S+E*B),a.push(T+Y*B);else{a.push(R),a.push(k);continue}}else if(F){let E=R-S,Y=k-T,B=X/(E*x-Y*b);if(B>=0&&B<=1)a.push(S+E*B),a.push(T+Y*B),a.push(R),a.push(k);else{a.push(R),a.push(k);continue}}c=!0}if(p==a.length)return o.length=0,!0;if(a.push(a[0]),a.push(a[1]),u==f)break;let y=a;a=d,a.length=0,d=y}if(o!=a){o.length=0;for(let u=0,g=a.length-2;u<g;u++)o[u]=a[u]}else o.length=o.length-2;return c}static makeClockwise(t){let s=t,i=t.length,r=s[i-2]*s[1]-s[0]*s[i-1],h=0,l=0,n=0,a=0;for(let o=0,c=i-3;o<c;o+=2)h=s[o],l=s[o+1],n=s[o+2],a=s[o+3],r+=h*a-n*l;if(!(r<0))for(let o=0,c=i-2,d=i>>1;o<d;o+=2){let f=s[o],m=s[o+1],u=c-o;s[o]=s[u],s[o+1]=s[u+1],s[u]=f,s[u+1]=m}}},Lr=class{attachmentLoader;scale=1;linkedMeshes=new Array;constructor(e){this.attachmentLoader=e}readSkeletonData(e){let t=this.scale,s=new Ss,i=typeof e=="string"?JSON.parse(e):e,r=i.skeleton;if(r&&(s.hash=r.hash,s.version=r.spine,s.x=r.x,s.y=r.y,s.width=r.width,s.height=r.height,s.referenceScale=M(r,"referenceScale",100)*t,s.fps=r.fps,s.imagesPath=r.images??null,s.audioPath=r.audio??null),i.bones)for(let h=0;h<i.bones.length;h++){let l=i.bones[h],n=null,a=M(l,"parent",null);a&&(n=s.findBone(a));let o=new ms(s.bones.length,l.name,n);o.length=M(l,"length",0)*t,o.x=M(l,"x",0)*t,o.y=M(l,"y",0)*t,o.rotation=M(l,"rotation",0),o.scaleX=M(l,"scaleX",1),o.scaleY=M(l,"scaleY",1),o.shearX=M(l,"shearX",0),o.shearY=M(l,"shearY",0),o.inherit=P.enumValue(me,M(l,"inherit","Normal")),o.skinRequired=M(l,"skin",!1);let c=M(l,"color",null);c&&o.color.setFromString(c),s.bones.push(o)}if(i.slots)for(let h=0;h<i.slots.length;h++){let l=i.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 Ts(s.slots.length,n,a),c=M(l,"color",null);c&&o.color.setFromString(c);let d=M(l,"dark",null);d&&(o.darkColor=et.fromString(d)),o.attachmentName=M(l,"attachment",null),o.blendMode=P.enumValue(Ms,M(l,"blend","normal")),o.visible=M(l,"visible",!0),s.slots.push(o)}if(i.ik)for(let h=0;h<i.ik.length;h++){let l=i.ik[h],n=new bs(l.name);n.order=M(l,"order",0),n.skinRequired=M(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=M(l,"mix",1),n.softness=M(l,"softness",0)*t,n.bendDirection=M(l,"bendPositive",!0)?1:-1,n.compress=M(l,"compress",!1),n.stretch=M(l,"stretch",!1),n.uniform=M(l,"uniform",!1),s.ikConstraints.push(n)}if(i.transform)for(let h=0;h<i.transform.length;h++){let l=i.transform[h],n=new Es(l.name);n.order=M(l,"order",0),n.skinRequired=M(l,"skin",!1);for(let c=0;c<l.bones.length;c++){let d=l.bones[c],f=s.findBone(d);if(!f)throw new Error(`Couldn't find bone ${d} for transform constraint ${l.name}.`);n.bones.push(f)}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=M(l,"local",!1),n.relative=M(l,"relative",!1),n.offsetRotation=M(l,"rotation",0),n.offsetX=M(l,"x",0)*t,n.offsetY=M(l,"y",0)*t,n.offsetScaleX=M(l,"scaleX",0),n.offsetScaleY=M(l,"scaleY",0),n.offsetShearY=M(l,"shearY",0),n.mixRotate=M(l,"mixRotate",1),n.mixX=M(l,"mixX",1),n.mixY=M(l,"mixY",n.mixX),n.mixScaleX=M(l,"mixScaleX",1),n.mixScaleY=M(l,"mixScaleY",n.mixScaleX),n.mixShearY=M(l,"mixShearY",1),s.transformConstraints.push(n)}if(i.path)for(let h=0;h<i.path.length;h++){let l=i.path[h],n=new vs(l.name);n.order=M(l,"order",0),n.skinRequired=M(l,"skin",!1);for(let c=0;c<l.bones.length;c++){let d=l.bones[c],f=s.findBone(d);if(!f)throw new Error(`Couldn't find bone ${d} for path constraint ${l.name}.`);n.bones.push(f)}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(ys,M(l,"positionMode","Percent")),n.spacingMode=P.enumValue(As,M(l,"spacingMode","Length")),n.rotateMode=P.enumValue(Cs,M(l,"rotateMode","Tangent")),n.offsetRotation=M(l,"rotation",0),n.position=M(l,"position",0),n.positionMode==0&&(n.position*=t),n.spacing=M(l,"spacing",0),(n.spacingMode==0||n.spacingMode==1)&&(n.spacing*=t),n.mixRotate=M(l,"mixRotate",1),n.mixX=M(l,"mixX",1),n.mixY=M(l,"mixY",n.mixX),s.pathConstraints.push(n)}if(i.physics)for(let h=0;h<i.physics.length;h++){const l=i.physics[h],n=new xi(l.name);n.order=M(l,"order",0),n.skinRequired=M(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=M(l,"x",0),n.y=M(l,"y",0),n.rotate=M(l,"rotate",0),n.scaleX=M(l,"scaleX",0),n.shearX=M(l,"shearX",0),n.limit=M(l,"limit",5e3)*t,n.step=1/M(l,"fps",60),n.inertia=M(l,"inertia",1),n.strength=M(l,"strength",100),n.damping=M(l,"damping",1),n.massInverse=1/M(l,"mass",1),n.wind=M(l,"wind",0),n.gravity=M(l,"gravity",0),n.mix=M(l,"mix",1),n.inertiaGlobal=M(l,"inertiaGlobal",!1),n.strengthGlobal=M(l,"strengthGlobal",!1),n.dampingGlobal=M(l,"dampingGlobal",!1),n.massGlobal=M(l,"massGlobal",!1),n.windGlobal=M(l,"windGlobal",!1),n.gravityGlobal=M(l,"gravityGlobal",!1),n.mixGlobal=M(l,"mixGlobal",!1),s.physicsConstraints.push(n)}if(i.skins)for(let h=0;h<i.skins.length;h++){let l=i.skins[h],n=new ge(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 d in c){let f=this.readAttachment(c[d],n,o.index,d,s);f&&n.setAttachment(o.index,d,f)}}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,i.events)for(let h in i.events){let l=i.events[h],n=new ws(h);n.intValue=M(l,"int",0),n.floatValue=M(l,"float",0),n.stringValue=M(l,"string",""),n.audioPath=M(l,"audio",null),n.audioPath&&(n.volume=M(l,"volume",1),n.balance=M(l,"balance",0)),s.events.push(n)}if(i.animations)for(let h in i.animations){let l=i.animations[h];this.readAnimation(l,h,s)}return s}readAttachment(e,t,s,i,r){let h=this.scale;switch(i=M(e,"name",i),M(e,"type","region")){case"region":{let l=M(e,"path",i),n=this.readSequence(M(e,"sequence",null)),a=this.attachmentLoader.newRegionAttachment(t,i,l,n);if(!a)return null;a.path=l,a.x=M(e,"x",0)*h,a.y=M(e,"y",0)*h,a.scaleX=M(e,"scaleX",1),a.scaleY=M(e,"scaleY",1),a.rotation=M(e,"rotation",0),a.width=e.width*h,a.height=e.height*h,a.sequence=n;let o=M(e,"color",null);return o&&a.color.setFromString(o),a.region!=null&&a.updateRegion(),a}case"boundingbox":{let l=this.attachmentLoader.newBoundingBoxAttachment(t,i);if(!l)return null;this.readVertices(e,l,e.vertexCount<<1);let n=M(e,"color",null);return n&&l.color.setFromString(n),l}case"mesh":case"linkedmesh":{let l=M(e,"path",i),n=this.readSequence(M(e,"sequence",null)),a=this.attachmentLoader.newMeshAttachment(t,i,l,n);if(!a)return null;a.path=l;let o=M(e,"color",null);o&&a.color.setFromString(o),a.width=M(e,"width",0)*h,a.height=M(e,"height",0)*h,a.sequence=n;let c=M(e,"parent",null);if(c)return this.linkedMeshes.push(new Pr(a,M(e,"skin",null),s,c,M(e,"timelines",!0))),a;let d=e.uvs;return this.readVertices(e,a,d.length),a.triangles=e.triangles,a.regionUVs=d,a.region!=null&&a.updateRegion(),a.edges=M(e,"edges",null),a.hullLength=M(e,"hull",0)*2,a}case"path":{let l=this.attachmentLoader.newPathAttachment(t,i);if(!l)return null;l.closed=M(e,"closed",!1),l.constantSpeed=M(e,"constantSpeed",!0);let n=e.vertexCount;this.readVertices(e,l,n<<1);let a=P.newArray(n/3,0);for(let c=0;c<e.lengths.length;c++)a[c]=e.lengths[c]*h;l.lengths=a;let o=M(e,"color",null);return o&&l.color.setFromString(o),l}case"point":{let l=this.attachmentLoader.newPointAttachment(t,i);if(!l)return null;l.x=M(e,"x",0)*h,l.y=M(e,"y",0)*h,l.rotation=M(e,"rotation",0);let n=M(e,"color",null);return n&&l.color.setFromString(n),l}case"clipping":{let l=this.attachmentLoader.newClippingAttachment(t,i);if(!l)return null;let n=M(e,"end",null);n&&(l.endSlot=r.findSlot(n));let a=e.vertexCount;this.readVertices(e,l,a<<1);let o=M(e,"color",null);return o&&l.color.setFromString(o),l}}return null}readSequence(e){if(e==null)return null;let t=new js(M(e,"count",0));return t.start=M(e,"start",1),t.digits=M(e,"digits",0),t.setupIndex=M(e,"setup",0),t}readVertices(e,t,s){let i=this.scale;t.worldVerticesLength=s;let r=e.vertices;if(s==r.length){let n=P.toFloatArray(r);if(i!=1)for(let a=0,o=r.length;a<o;a++)n[a]*=i;t.vertices=n;return}let h=new Array,l=new Array;for(let n=0,a=r.length;n<a;){let o=r[n++];l.push(o);for(let c=n+o*4;n<c;n+=4)l.push(r[n]),h.push(r[n+1]*i),h.push(r[n+2]*i),h.push(r[n+3])}t.bones=l,t.vertices=P.toFloatArray(h)}readAnimation(e,t,s){let i=this.scale,r=new Array;if(e.slots)for(let l in e.slots){let n=e.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 d=n[c];if(!d)continue;let f=d.length;if(c=="attachment"){let m=new Ot(f,o);for(let u=0;u<f;u++){let g=d[u];m.setFrame(u,M(g,"time",0),M(g,"name",null))}r.push(m)}else if(c=="rgba"){let m=new Ue(f,f<<2,o),u=d[0],g=M(u,"time",0),w=et.fromString(u.color);for(let b=0,x=0;;b++){m.setFrame(b,g,w.r,w.g,w.b,w.a);let p=d[b+1];if(!p){m.shrink(x);break}let v=M(p,"time",0),y=et.fromString(p.color),A=u.curve;A&&(x=ot(A,m,x,b,0,g,v,w.r,y.r,1),x=ot(A,m,x,b,1,g,v,w.g,y.g,1),x=ot(A,m,x,b,2,g,v,w.b,y.b,1),x=ot(A,m,x,b,3,g,v,w.a,y.a,1)),g=v,w=y,u=p}r.push(m)}else if(c=="rgb"){let m=new ze(f,f*3,o),u=d[0],g=M(u,"time",0),w=et.fromString(u.color);for(let b=0,x=0;;b++){m.setFrame(b,g,w.r,w.g,w.b);let p=d[b+1];if(!p){m.shrink(x);break}let v=M(p,"time",0),y=et.fromString(p.color),A=u.curve;A&&(x=ot(A,m,x,b,0,g,v,w.r,y.r,1),x=ot(A,m,x,b,1,g,v,w.g,y.g,1),x=ot(A,m,x,b,2,g,v,w.b,y.b,1)),g=v,w=y,u=p}r.push(m)}else if(c=="alpha")r.push(It(d,new We(f,f,o),0,1));else if(c=="rgba2"){let m=new qe(f,f*7,o),u=d[0],g=M(u,"time",0),w=et.fromString(u.light),b=et.fromString(u.dark);for(let x=0,p=0;;x++){m.setFrame(x,g,w.r,w.g,w.b,w.a,b.r,b.g,b.b);let v=d[x+1];if(!v){m.shrink(p);break}let y=M(v,"time",0),A=et.fromString(v.light),C=et.fromString(v.dark),S=u.curve;S&&(p=ot(S,m,p,x,0,g,y,w.r,A.r,1),p=ot(S,m,p,x,1,g,y,w.g,A.g,1),p=ot(S,m,p,x,2,g,y,w.b,A.b,1),p=ot(S,m,p,x,3,g,y,w.a,A.a,1),p=ot(S,m,p,x,4,g,y,b.r,C.r,1),p=ot(S,m,p,x,5,g,y,b.g,C.g,1),p=ot(S,m,p,x,6,g,y,b.b,C.b,1)),g=y,w=A,b=C,u=v}r.push(m)}else if(c=="rgb2"){let m=new Ge(f,f*6,o),u=d[0],g=M(u,"time",0),w=et.fromString(u.light),b=et.fromString(u.dark);for(let x=0,p=0;;x++){m.setFrame(x,g,w.r,w.g,w.b,b.r,b.g,b.b);let v=d[x+1];if(!v){m.shrink(p);break}let y=M(v,"time",0),A=et.fromString(v.light),C=et.fromString(v.dark),S=u.curve;S&&(p=ot(S,m,p,x,0,g,y,w.r,A.r,1),p=ot(S,m,p,x,1,g,y,w.g,A.g,1),p=ot(S,m,p,x,2,g,y,w.b,A.b,1),p=ot(S,m,p,x,3,g,y,b.r,C.r,1),p=ot(S,m,p,x,4,g,y,b.g,C.g,1),p=ot(S,m,p,x,5,g,y,b.b,C.b,1)),g=y,w=A,b=C,u=v}r.push(m)}}}if(e.bones)for(let l in e.bones){let n=e.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 d=n[c],f=d.length;if(f!=0){if(c==="rotate")r.push(It(d,new te(f,f,o),0,1));else if(c==="translate"){let m=new ke(f,f<<1,o);r.push(Rs(d,m,"x","y",0,i))}else if(c==="translatex"){let m=new Fe(f,f,o);r.push(It(d,m,0,i))}else if(c==="translatey"){let m=new Xe(f,f,o);r.push(It(d,m,0,i))}else if(c==="scale"){let m=new Le(f,f<<1,o);r.push(Rs(d,m,"x","y",1,1))}else if(c==="scalex"){let m=new Pe(f,f,o);r.push(It(d,m,1,1))}else if(c==="scaley"){let m=new Be(f,f,o);r.push(It(d,m,1,1))}else if(c==="shear"){let m=new Ve(f,f<<1,o);r.push(Rs(d,m,"x","y",0,1))}else if(c==="shearx"){let m=new Oe(f,f,o);r.push(It(d,m,0,1))}else if(c==="sheary"){let m=new De(f,f,o);r.push(It(d,m,0,1))}else if(c==="inherit"){let m=new Ne(f,a.index);for(let u=0;u<d.length;u++){let g=d[u];m.setFrame(u,M(g,"time",0),P.enumValue(me,M(g,"inherit","Normal")))}r.push(m)}}}}if(e.ik)for(let l in e.ik){let n=e.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),d=new _e(n.length,n.length<<1,c),f=M(a,"time",0),m=M(a,"mix",1),u=M(a,"softness",0)*i;for(let g=0,w=0;;g++){d.setFrame(g,f,m,u,M(a,"bendPositive",!0)?1:-1,M(a,"compress",!1),M(a,"stretch",!1));let b=n[g+1];if(!b){d.shrink(w);break}let x=M(b,"time",0),p=M(b,"mix",1),v=M(b,"softness",0)*i,y=a.curve;y&&(w=ot(y,d,w,g,0,f,x,m,p,1),w=ot(y,d,w,g,1,f,x,u,v,i)),f=x,m=p,u=v,a=b}r.push(d)}if(e.transform)for(let l in e.transform){let n=e.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),d=new je(n.length,n.length*6,c),f=M(a,"time",0),m=M(a,"mixRotate",1),u=M(a,"mixX",1),g=M(a,"mixY",u),w=M(a,"mixScaleX",1),b=M(a,"mixScaleY",w),x=M(a,"mixShearY",1);for(let p=0,v=0;;p++){d.setFrame(p,f,m,u,g,w,b,x);let y=n[p+1];if(!y){d.shrink(v);break}let A=M(y,"time",0),C=M(y,"mixRotate",1),S=M(y,"mixX",1),T=M(y,"mixY",S),R=M(y,"mixScaleX",1),k=M(y,"mixScaleY",R),F=M(y,"mixShearY",1),X=a.curve;X&&(v=ot(X,d,v,p,0,f,A,m,C,1),v=ot(X,d,v,p,1,f,A,u,S,1),v=ot(X,d,v,p,2,f,A,g,T,1),v=ot(X,d,v,p,3,f,A,w,R,1),v=ot(X,d,v,p,4,f,A,b,k,1),v=ot(X,d,v,p,5,f,A,x,F,1)),f=A,m=C,u=S,g=T,w=R,b=k,w=R,a=y}r.push(d)}if(e.path)for(let l in e.path){let n=e.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 d=n[c],f=d[0];if(!f)continue;let m=d.length;if(c==="position"){let u=new Ze(m,m,o);r.push(It(d,u,0,a.positionMode==0?i:1))}else if(c==="spacing"){let u=new Ke(m,m,o);r.push(It(d,u,0,a.spacingMode==0||a.spacingMode==1?i:1))}else if(c==="mix"){let u=new Je(m,m*3,o),g=M(f,"time",0),w=M(f,"mixRotate",1),b=M(f,"mixX",1),x=M(f,"mixY",b);for(let p=0,v=0;;p++){u.setFrame(p,g,w,b,x);let y=d[p+1];if(!y){u.shrink(v);break}let A=M(y,"time",0),C=M(y,"mixRotate",1),S=M(y,"mixX",1),T=M(y,"mixY",S),R=f.curve;R&&(v=ot(R,u,v,p,0,g,A,w,C,1),v=ot(R,u,v,p,1,g,A,b,S,1),v=ot(R,u,v,p,2,g,A,x,T,1)),g=A,w=C,b=S,x=T,f=y}r.push(u)}}}if(e.physics)for(let l in e.physics){let n=e.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],d=c[0];if(!d)continue;let f=c.length;if(o=="reset"){const u=new ns(f,a);for(let g=0;d!=null;d=c[g+1],g++)u.setFrame(g,M(d,"time",0));r.push(u);continue}let m;if(o=="inertia")m=new Qe(f,f,a);else if(o=="strength")m=new $e(f,f,a);else if(o=="damping")m=new ts(f,f,a);else if(o=="mass")m=new es(f,f,a);else if(o=="wind")m=new ss(f,f,a);else if(o=="gravity")m=new is(f,f,a);else if(o=="mix")m=new rs(f,f,a);else continue;r.push(It(c,m,0,1))}}if(e.attachments)for(let l in e.attachments){let n=e.attachments[l],a=s.findSkin(l);if(!a)throw new Error("Skin not found: "+l);for(let o in n){let c=n[o],d=s.findSlot(o);if(!d)throw new Error("Slot not found: "+o);let f=d.index;for(let m in c){let u=c[m],g=a.getAttachment(f,m);for(let w in u){let b=u[w],x=b[0];if(x){if(w=="deform"){let p=g.bones,v=g.vertices,y=p?v.length/3*2:v.length,A=new He(b.length,b.length,f,g),C=M(x,"time",0);for(let S=0,T=0;;S++){let R,k=M(x,"vertices",null);if(!k)R=p?P.newFloatArray(y):v;else{R=P.newFloatArray(y);let Y=M(x,"offset",0);if(P.arrayCopy(k,0,R,Y,k.length),i!=1)for(let B=Y,st=B+k.length;B<st;B++)R[B]*=i;if(!p)for(let B=0;B<y;B++)R[B]+=v[B]}A.setFrame(S,C,R);let F=b[S+1];if(!F){A.shrink(T);break}let X=M(F,"time",0),E=x.curve;E&&(T=ot(E,A,T,S,0,C,X,0,1,1)),C=X,x=F}r.push(A)}else if(w=="sequence"){let p=new as(b.length,f,g),v=0;for(let y=0;y<b.length;y++){let A=M(x,"delay",v),C=M(x,"time",0),S=Zs[M(x,"mode","hold")],T=M(x,"index",0);p.setFrame(y,C,S,T,A),v=A,x=b[y+1]}r.push(p)}}}}}}if(e.drawOrder){let l=new qt(e.drawOrder.length),n=s.slots.length,a=0;for(let o=0;o<e.drawOrder.length;o++,a++){let c=e.drawOrder[o],d=null,f=M(c,"offsets",null);if(f){d=P.newArray(n,-1);let m=P.newArray(n-f.length,0),u=0,g=0;for(let w=0;w<f.length;w++){let b=f[w],x=s.findSlot(b.slot);if(!x)throw new Error("Slot not found: "+x);let p=x.index;for(;u!=p;)m[g++]=u++;d[u+b.offset]=u++}for(;u<n;)m[g++]=u++;for(let w=n-1;w>=0;w--)d[w]==-1&&(d[w]=m[--g])}l.setFrame(a,M(c,"time",0),d)}r.push(l)}if(e.events){let l=new ce(e.events.length),n=0;for(let a=0;a<e.events.length;a++,n++){let o=e.events[a],c=s.findEvent(o.name);if(!c)throw new Error("Event not found: "+o.name);let d=new ps(P.toSinglePrecision(M(o,"time",0)),c);d.intValue=M(o,"int",c.intValue),d.floatValue=M(o,"float",c.floatValue),d.stringValue=M(o,"string",c.stringValue),d.data.audioPath&&(d.volume=M(o,"volume",1),d.balance=M(o,"balance",0)),l.setFrame(n,d)}r.push(l)}let h=0;for(let l=0,n=r.length;l<n;l++)h=Math.max(h,r[l].getDuration());s.animations.push(new oe(t,r,h))}},Pr=class{parent;skin;slotIndex;mesh;inheritTimeline;constructor(e,t,s,i,r){this.mesh=e,this.skin=t,this.slotIndex=s,this.parent=i,this.inheritTimeline=r}};function It(e,t,s,i){let r=e[0],h=M(r,"time",0),l=M(r,"value",s)*i,n=0;for(let a=0;;a++){t.setFrame(a,h,l);let o=e[a+1];if(!o)return t.shrink(n),t;let c=M(o,"time",0),d=M(o,"value",s)*i;r.curve&&(n=ot(r.curve,t,n,a,0,h,c,l,d,i)),h=c,l=d,r=o}}function Rs(e,t,s,i,r,h){let l=e[0],n=M(l,"time",0),a=M(l,s,r)*h,o=M(l,i,r)*h,c=0;for(let d=0;;d++){t.setFrame(d,n,a,o);let f=e[d+1];if(!f)return t.shrink(c),t;let m=M(f,"time",0),u=M(f,s,r)*h,g=M(f,i,r)*h,w=l.curve;w&&(c=ot(w,t,c,d,0,n,m,a,u,h),c=ot(w,t,c,d,1,n,m,o,g,h)),n=m,a=u,o=g,l=f}}function ot(e,t,s,i,r,h,l,n,a,o){if(e=="stepped")return t.setStepped(i),s;let c=r<<2,d=e[c],f=e[c+1]*o,m=e[c+2],u=e[c+3]*o;return t.setBezier(s,i,r,h,n,d,f,m,u,l,a),s+1}function M(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)));var wt=class{canvas;gl;restorables=[];constructor(e,t={alpha:!0}){if(e instanceof WebGLRenderingContext||typeof WebGL2RenderingContext<"u"&&e instanceof WebGL2RenderingContext)this.gl=e,this.canvas=this.gl.canvas;else{const s=e;this.gl=s.getContext("webgl2",t)||s.getContext("webgl",t),this.canvas=s,s.addEventListener("webglcontextlost",this.contextLostHandler),s.addEventListener("webglcontextrestored",this.contextRestoredHandler)}}contextLostHandler=e=>{e&&e.preventDefault()};contextRestoredHandler=()=>{for(let e=0,t=this.restorables.length;e<t;e++)this.restorables[e].restore()};dispose(){this.canvas.removeEventListener("webglcontextlost",this.contextLostHandler),this.canvas.removeEventListener("webglcontextrestored",this.contextRestoredHandler)}addRestorable(e){this.restorables.push(e)}removeRestorable(e){const t=this.restorables.indexOf(e);t>-1&&this.restorables.splice(t,1)}},_t=class Ie extends ds{context;texture=null;boundUnit=0;useMipMaps=!1;static DISABLE_UNPACK_PREMULTIPLIED_ALPHA_WEBGL=!1;constructor(t,s,i=!1){super(s),this.context=t instanceof wt?t:new wt(t),this.useMipMaps=i,this.restore(),this.context.addRestorable(this)}setFilters(t,s){let i=this.context.gl;this.bind(),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_MIN_FILTER,t),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_MAG_FILTER,Ie.validateMagFilter(s)),this.useMipMaps=Ie.usesMipMaps(t),this.useMipMaps&&i.generateMipmap(i.TEXTURE_2D)}static validateMagFilter(t){switch(t){case 9987:case 9985:case 9986:case 9984:return 9729;default:return t}}static usesMipMaps(t){switch(t){case 9987:case 9985:case 9986:case 9984:return!0;default:return!1}}setWraps(t,s){let i=this.context.gl;this.bind(),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_WRAP_S,t),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_WRAP_T,s)}update(t){let s=this.context.gl;this.texture||(this.texture=this.context.gl.createTexture()),this.bind(),Ie.DISABLE_UNPACK_PREMULTIPLIED_ALPHA_WEBGL&&s.pixelStorei(s.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1),s.texImage2D(s.TEXTURE_2D,0,s.RGBA,s.RGBA,s.UNSIGNED_BYTE,this._image),s.texParameteri(s.TEXTURE_2D,s.TEXTURE_MAG_FILTER,s.LINEAR),s.texParameteri(s.TEXTURE_2D,s.TEXTURE_MIN_FILTER,t?s.LINEAR_MIPMAP_LINEAR:s.LINEAR),s.texParameteri(s.TEXTURE_2D,s.TEXTURE_WRAP_S,s.CLAMP_TO_EDGE),s.texParameteri(s.TEXTURE_2D,s.TEXTURE_WRAP_T,s.CLAMP_TO_EDGE),t&&s.generateMipmap(s.TEXTURE_2D)}restore(){this.texture=null,this.update(this.useMipMaps)}bind(t=0){let s=this.context.gl;this.boundUnit=t,s.activeTexture(s.TEXTURE0+t),s.bindTexture(s.TEXTURE_2D,this.texture)}unbind(){let t=this.context.gl;t.activeTexture(t.TEXTURE0+this.boundUnit),t.bindTexture(t.TEXTURE_2D,null)}dispose(){this.context.removeRestorable(this),this.context.gl.deleteTexture(this.texture)}},yi=class extends oi{constructor(e,t="",s=new xs){super(i=>new _t(e,i),t,s)}},At=class{x=0;y=0;z=0;constructor(e=0,t=0,s=0){this.x=e,this.y=t,this.z=s}setFrom(e){return this.x=e.x,this.y=e.y,this.z=e.z,this}set(e,t,s){return this.x=e,this.y=t,this.z=s,this}add(e){return this.x+=e.x,this.y+=e.y,this.z+=e.z,this}sub(e){return this.x-=e.x,this.y-=e.y,this.z-=e.z,this}scale(e){return this.x*=e,this.y*=e,this.z*=e,this}normalize(){let e=this.length();return e==0?this:(e=1/e,this.x*=e,this.y*=e,this.z*=e,this)}cross(e){return this.set(this.y*e.z-this.z*e.y,this.z*e.x-this.x*e.z,this.x*e.y-this.y*e.x)}multiply(e){let t=e.values;return this.set(this.x*t[V]+this.y*t[q]+this.z*t[G]+t[O],this.x*t[H]+this.y*t[D]+this.z*t[_]+t[N],this.x*t[j]+this.y*t[Z]+this.z*t[U]+t[z])}project(e){let t=e.values,s=1/(this.x*t[J]+this.y*t[Q]+this.z*t[$]+t[K]);return this.set((this.x*t[V]+this.y*t[q]+this.z*t[G]+t[O])*s,(this.x*t[H]+this.y*t[D]+this.z*t[_]+t[N])*s,(this.x*t[j]+this.y*t[Z]+this.z*t[U]+t[z])*s)}dot(e){return this.x*e.x+this.y*e.y+this.z*e.z}length(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z)}distance(e){let t=e.x-this.x,s=e.y-this.y,i=e.z-this.z;return Math.sqrt(t*t+s*s+i*i)}},V=0,q=4,G=8,O=12,H=1,D=5,_=9,N=13,j=2,Z=6,U=10,z=14,J=3,Q=7,$=11,K=15,re=class Yt{temp=new Float32Array(16);values=new Float32Array(16);static xAxis=new At;static yAxis=new At;static zAxis=new At;static tmpMatrix=new Yt;constructor(){let t=this.values;t[V]=1,t[D]=1,t[U]=1,t[K]=1}set(t){return this.values.set(t),this}transpose(){let t=this.temp,s=this.values;return t[V]=s[V],t[q]=s[H],t[G]=s[j],t[O]=s[J],t[H]=s[q],t[D]=s[D],t[_]=s[Z],t[N]=s[Q],t[j]=s[G],t[Z]=s[_],t[U]=s[U],t[z]=s[$],t[J]=s[O],t[Q]=s[N],t[$]=s[z],t[K]=s[K],this.set(t)}identity(){let t=this.values;return t[V]=1,t[q]=0,t[G]=0,t[O]=0,t[H]=0,t[D]=1,t[_]=0,t[N]=0,t[j]=0,t[Z]=0,t[U]=1,t[z]=0,t[J]=0,t[Q]=0,t[$]=0,t[K]=1,this}invert(){let t=this.values,s=this.temp,i=t[J]*t[Z]*t[_]*t[O]-t[j]*t[Q]*t[_]*t[O]-t[J]*t[D]*t[U]*t[O]+t[H]*t[Q]*t[U]*t[O]+t[j]*t[D]*t[$]*t[O]-t[H]*t[Z]*t[$]*t[O]-t[J]*t[Z]*t[G]*t[N]+t[j]*t[Q]*t[G]*t[N]+t[J]*t[q]*t[U]*t[N]-t[V]*t[Q]*t[U]*t[N]-t[j]*t[q]*t[$]*t[N]+t[V]*t[Z]*t[$]*t[N]+t[J]*t[D]*t[G]*t[z]-t[H]*t[Q]*t[G]*t[z]-t[J]*t[q]*t[_]*t[z]+t[V]*t[Q]*t[_]*t[z]+t[H]*t[q]*t[$]*t[z]-t[V]*t[D]*t[$]*t[z]-t[j]*t[D]*t[G]*t[K]+t[H]*t[Z]*t[G]*t[K]+t[j]*t[q]*t[_]*t[K]-t[V]*t[Z]*t[_]*t[K]-t[H]*t[q]*t[U]*t[K]+t[V]*t[D]*t[U]*t[K];if(i==0)throw new Error("non-invertible matrix");let r=1/i;return s[V]=t[_]*t[z]*t[Q]-t[N]*t[U]*t[Q]+t[N]*t[Z]*t[$]-t[D]*t[z]*t[$]-t[_]*t[Z]*t[K]+t[D]*t[U]*t[K],s[q]=t[O]*t[U]*t[Q]-t[G]*t[z]*t[Q]-t[O]*t[Z]*t[$]+t[q]*t[z]*t[$]+t[G]*t[Z]*t[K]-t[q]*t[U]*t[K],s[G]=t[G]*t[N]*t[Q]-t[O]*t[_]*t[Q]+t[O]*t[D]*t[$]-t[q]*t[N]*t[$]-t[G]*t[D]*t[K]+t[q]*t[_]*t[K],s[O]=t[O]*t[_]*t[Z]-t[G]*t[N]*t[Z]-t[O]*t[D]*t[U]+t[q]*t[N]*t[U]+t[G]*t[D]*t[z]-t[q]*t[_]*t[z],s[H]=t[N]*t[U]*t[J]-t[_]*t[z]*t[J]-t[N]*t[j]*t[$]+t[H]*t[z]*t[$]+t[_]*t[j]*t[K]-t[H]*t[U]*t[K],s[D]=t[G]*t[z]*t[J]-t[O]*t[U]*t[J]+t[O]*t[j]*t[$]-t[V]*t[z]*t[$]-t[G]*t[j]*t[K]+t[V]*t[U]*t[K],s[_]=t[O]*t[_]*t[J]-t[G]*t[N]*t[J]-t[O]*t[H]*t[$]+t[V]*t[N]*t[$]+t[G]*t[H]*t[K]-t[V]*t[_]*t[K],s[N]=t[G]*t[N]*t[j]-t[O]*t[_]*t[j]+t[O]*t[H]*t[U]-t[V]*t[N]*t[U]-t[G]*t[H]*t[z]+t[V]*t[_]*t[z],s[j]=t[D]*t[z]*t[J]-t[N]*t[Z]*t[J]+t[N]*t[j]*t[Q]-t[H]*t[z]*t[Q]-t[D]*t[j]*t[K]+t[H]*t[Z]*t[K],s[Z]=t[O]*t[Z]*t[J]-t[q]*t[z]*t[J]-t[O]*t[j]*t[Q]+t[V]*t[z]*t[Q]+t[q]*t[j]*t[K]-t[V]*t[Z]*t[K],s[U]=t[q]*t[N]*t[J]-t[O]*t[D]*t[J]+t[O]*t[H]*t[Q]-t[V]*t[N]*t[Q]-t[q]*t[H]*t[K]+t[V]*t[D]*t[K],s[z]=t[O]*t[D]*t[j]-t[q]*t[N]*t[j]-t[O]*t[H]*t[Z]+t[V]*t[N]*t[Z]+t[q]*t[H]*t[z]-t[V]*t[D]*t[z],s[J]=t[_]*t[Z]*t[J]-t[D]*t[U]*t[J]-t[_]*t[j]*t[Q]+t[H]*t[U]*t[Q]+t[D]*t[j]*t[$]-t[H]*t[Z]*t[$],s[Q]=t[q]*t[U]*t[J]-t[G]*t[Z]*t[J]+t[G]*t[j]*t[Q]-t[V]*t[U]*t[Q]-t[q]*t[j]*t[$]+t[V]*t[Z]*t[$],s[$]=t[G]*t[D]*t[J]-t[q]*t[_]*t[J]-t[G]*t[H]*t[Q]+t[V]*t[_]*t[Q]+t[q]*t[H]*t[$]-t[V]*t[D]*t[$],s[K]=t[q]*t[_]*t[j]-t[G]*t[D]*t[j]+t[G]*t[H]*t[Z]-t[V]*t[_]*t[Z]-t[q]*t[H]*t[U]+t[V]*t[D]*t[U],t[V]=s[V]*r,t[q]=s[q]*r,t[G]=s[G]*r,t[O]=s[O]*r,t[H]=s[H]*r,t[D]=s[D]*r,t[_]=s[_]*r,t[N]=s[N]*r,t[j]=s[j]*r,t[Z]=s[Z]*r,t[U]=s[U]*r,t[z]=s[z]*r,t[J]=s[J]*r,t[Q]=s[Q]*r,t[$]=s[$]*r,t[K]=s[K]*r,this}determinant(){let t=this.values;return t[J]*t[Z]*t[_]*t[O]-t[j]*t[Q]*t[_]*t[O]-t[J]*t[D]*t[U]*t[O]+t[H]*t[Q]*t[U]*t[O]+t[j]*t[D]*t[$]*t[O]-t[H]*t[Z]*t[$]*t[O]-t[J]*t[Z]*t[G]*t[N]+t[j]*t[Q]*t[G]*t[N]+t[J]*t[q]*t[U]*t[N]-t[V]*t[Q]*t[U]*t[N]-t[j]*t[q]*t[$]*t[N]+t[V]*t[Z]*t[$]*t[N]+t[J]*t[D]*t[G]*t[z]-t[H]*t[Q]*t[G]*t[z]-t[J]*t[q]*t[_]*t[z]+t[V]*t[Q]*t[_]*t[z]+t[H]*t[q]*t[$]*t[z]-t[V]*t[D]*t[$]*t[z]-t[j]*t[D]*t[G]*t[K]+t[H]*t[Z]*t[G]*t[K]+t[j]*t[q]*t[_]*t[K]-t[V]*t[Z]*t[_]*t[K]-t[H]*t[q]*t[U]*t[K]+t[V]*t[D]*t[U]*t[K]}translate(t,s,i){let r=this.values;return r[O]+=t,r[N]+=s,r[z]+=i,this}copy(){return new Yt().set(this.values)}projection(t,s,i,r){this.identity();let h=1/Math.tan(i*(Math.PI/180)/2),l=(s+t)/(t-s),n=2*s*t/(t-s),a=this.values;return a[V]=h/r,a[H]=0,a[j]=0,a[J]=0,a[q]=0,a[D]=h,a[Z]=0,a[Q]=0,a[G]=0,a[_]=0,a[U]=l,a[$]=-1,a[O]=0,a[N]=0,a[z]=n,a[K]=0,this}ortho2d(t,s,i,r){return this.ortho(t,t+i,s,s+r,0,1)}ortho(t,s,i,r,h,l){this.identity();let n=2/(s-t),a=2/(r-i),o=-2/(l-h),c=-(s+t)/(s-t),d=-(r+i)/(r-i),f=-(l+h)/(l-h),m=this.values;return m[V]=n,m[H]=0,m[j]=0,m[J]=0,m[q]=0,m[D]=a,m[Z]=0,m[Q]=0,m[G]=0,m[_]=0,m[U]=o,m[$]=0,m[O]=c,m[N]=d,m[z]=f,m[K]=1,this}multiply(t){let s=this.temp,i=this.values,r=t.values;return s[V]=i[V]*r[V]+i[q]*r[H]+i[G]*r[j]+i[O]*r[J],s[q]=i[V]*r[q]+i[q]*r[D]+i[G]*r[Z]+i[O]*r[Q],s[G]=i[V]*r[G]+i[q]*r[_]+i[G]*r[U]+i[O]*r[$],s[O]=i[V]*r[O]+i[q]*r[N]+i[G]*r[z]+i[O]*r[K],s[H]=i[H]*r[V]+i[D]*r[H]+i[_]*r[j]+i[N]*r[J],s[D]=i[H]*r[q]+i[D]*r[D]+i[_]*r[Z]+i[N]*r[Q],s[_]=i[H]*r[G]+i[D]*r[_]+i[_]*r[U]+i[N]*r[$],s[N]=i[H]*r[O]+i[D]*r[N]+i[_]*r[z]+i[N]*r[K],s[j]=i[j]*r[V]+i[Z]*r[H]+i[U]*r[j]+i[z]*r[J],s[Z]=i[j]*r[q]+i[Z]*r[D]+i[U]*r[Z]+i[z]*r[Q],s[U]=i[j]*r[G]+i[Z]*r[_]+i[U]*r[U]+i[z]*r[$],s[z]=i[j]*r[O]+i[Z]*r[N]+i[U]*r[z]+i[z]*r[K],s[J]=i[J]*r[V]+i[Q]*r[H]+i[$]*r[j]+i[K]*r[J],s[Q]=i[J]*r[q]+i[Q]*r[D]+i[$]*r[Z]+i[K]*r[Q],s[$]=i[J]*r[G]+i[Q]*r[_]+i[$]*r[U]+i[K]*r[$],s[K]=i[J]*r[O]+i[Q]*r[N]+i[$]*r[z]+i[K]*r[K],this.set(this.temp)}multiplyLeft(t){let s=this.temp,i=this.values,r=t.values;return s[V]=r[V]*i[V]+r[q]*i[H]+r[G]*i[j]+r[O]*i[J],s[q]=r[V]*i[q]+r[q]*i[D]+r[G]*i[Z]+r[O]*i[Q],s[G]=r[V]*i[G]+r[q]*i[_]+r[G]*i[U]+r[O]*i[$],s[O]=r[V]*i[O]+r[q]*i[N]+r[G]*i[z]+r[O]*i[K],s[H]=r[H]*i[V]+r[D]*i[H]+r[_]*i[j]+r[N]*i[J],s[D]=r[H]*i[q]+r[D]*i[D]+r[_]*i[Z]+r[N]*i[Q],s[_]=r[H]*i[G]+r[D]*i[_]+r[_]*i[U]+r[N]*i[$],s[N]=r[H]*i[O]+r[D]*i[N]+r[_]*i[z]+r[N]*i[K],s[j]=r[j]*i[V]+r[Z]*i[H]+r[U]*i[j]+r[z]*i[J],s[Z]=r[j]*i[q]+r[Z]*i[D]+r[U]*i[Z]+r[z]*i[Q],s[U]=r[j]*i[G]+r[Z]*i[_]+r[U]*i[U]+r[z]*i[$],s[z]=r[j]*i[O]+r[Z]*i[N]+r[U]*i[z]+r[z]*i[K],s[J]=r[J]*i[V]+r[Q]*i[H]+r[$]*i[j]+r[K]*i[J],s[Q]=r[J]*i[q]+r[Q]*i[D]+r[$]*i[Z]+r[K]*i[Q],s[$]=r[J]*i[G]+r[Q]*i[_]+r[$]*i[U]+r[K]*i[$],s[K]=r[J]*i[O]+r[Q]*i[N]+r[$]*i[z]+r[K]*i[K],this.set(this.temp)}lookAt(t,s,i){let r=Yt.xAxis,h=Yt.yAxis,l=Yt.zAxis;l.setFrom(s).normalize(),r.setFrom(s).normalize(),r.cross(i).normalize(),h.setFrom(r).cross(l).normalize(),this.identity();let n=this.values;return n[V]=r.x,n[q]=r.y,n[G]=r.z,n[H]=h.x,n[D]=h.y,n[_]=h.z,n[j]=-l.x,n[Z]=-l.y,n[U]=-l.z,Yt.tmpMatrix.identity(),Yt.tmpMatrix.values[O]=-t.x,Yt.tmpMatrix.values[N]=-t.y,Yt.tmpMatrix.values[z]=-t.z,this.multiply(Yt.tmpMatrix),this}},Ai=class{position=new At(0,0,0);direction=new At(0,0,-1);up=new At(0,1,0);near=0;far=100;zoom=1;viewportWidth=0;viewportHeight=0;projectionView=new re;inverseProjectionView=new re;projection=new re;view=new re;constructor(e,t){this.viewportWidth=e,this.viewportHeight=t,this.update()}update(){let e=this.projection,t=this.view,s=this.projectionView,i=this.inverseProjectionView,r=this.zoom,h=this.viewportWidth,l=this.viewportHeight;e.ortho(r*(-h/2),r*(h/2),r*(-l/2),r*(l/2),this.near,this.far),t.lookAt(this.position,this.direction,this.up),s.set(e.values),s.multiply(t),i.set(s.values).invert()}screenToWorld(e,t,s){let i=e.x,r=s-e.y-1;return e.x=2*i/t-1,e.y=2*r/s-1,e.z=2*e.z-1,e.project(this.inverseProjectionView),e}worldToScreen(e,t,s){return e.project(this.projectionView),e.x=t*(e.x+1)/2,e.y=s*(e.y+1)/2,e.z=(e.z+1)/2,e}setViewport(e,t){this.viewportWidth=e,this.viewportHeight=t}},ks=class{element;mouseX=0;mouseY=0;buttonDown=!1;touch0=null;touch1=null;initialPinchDistance=0;listeners=new Array;autoPreventDefault;isTouch=!1;callbacks;constructor(e,t=!0){this.element=e,this.autoPreventDefault=t,this.callbacks=this.setupCallbacks(e)}setupCallbacks(e){const t=a=>{if(a instanceof MouseEvent&&!this.isTouch){let o=e.getBoundingClientRect();this.mouseX=a.clientX-o.left,this.mouseY=a.clientY-o.top,this.buttonDown=!0,this.listeners.map(c=>{c.down&&c.down(this.mouseX,this.mouseY,a)})}},s=a=>{if(a instanceof MouseEvent&&!this.isTouch){let o=e.getBoundingClientRect();this.mouseX=a.clientX-o.left,this.mouseY=a.clientY-o.top,this.listeners.map(c=>{this.buttonDown?c.dragged&&c.dragged(this.mouseX,this.mouseY,a):c.moved&&c.moved(this.mouseX,this.mouseY,a)})}},i=a=>{if(a instanceof MouseEvent&&!this.isTouch){let o=e.getBoundingClientRect();this.mouseX=a.clientX-o.left,this.mouseY=a.clientY-o.top,this.buttonDown=!1,this.listeners.map(c=>{c.up&&c.up(this.mouseX,this.mouseY,a)})}},r=a=>{this.autoPreventDefault&&a.preventDefault();let o=a.deltaY;a.deltaMode==WheelEvent.DOM_DELTA_LINE&&(o*=8),a.deltaMode==WheelEvent.DOM_DELTA_PAGE&&(o*=24),this.listeners.map(c=>{c.wheel&&c.wheel(a.deltaY,a)})},h=a=>{if(this.isTouch=!0,!this.touch0||!this.touch1){var o=a.changedTouches;let c=o.item(0);if(!c)return;let d=e.getBoundingClientRect(),f=c.clientX-d.left,m=c.clientY-d.top,u=new Ci(c.identifier,f,m);if(this.mouseX=f,this.mouseY=m,this.buttonDown=!0,!this.touch0)this.touch0=u,this.listeners.map(g=>{g.down&&g.down(u.x,u.y,a)});else if(!this.touch1){this.touch1=u;let g=this.touch1.x-this.touch0.x,w=this.touch1.x-this.touch0.x;this.initialPinchDistance=Math.sqrt(g*g+w*w),this.listeners.map(b=>{b.zoom&&b.zoom(this.initialPinchDistance,this.initialPinchDistance,a)})}}this.autoPreventDefault&&a.preventDefault()},l=a=>{if(this.isTouch=!0,this.touch0){var o=a.changedTouches;let f=e.getBoundingClientRect();for(var c=0;c<o.length;c++){var d=o[c];let m=d.clientX-f.left,u=d.clientY-f.top;this.touch0.identifier===d.identifier&&(this.touch0.x=this.mouseX=m,this.touch0.y=this.mouseY=u,this.listeners.map(g=>{g.dragged&&g.dragged(m,u,a)})),this.touch1&&this.touch1.identifier===d.identifier&&(this.touch1.x=this.mouseX=m,this.touch1.y=this.mouseY=u)}if(this.touch0&&this.touch1){let m=this.touch1.x-this.touch0.x,u=this.touch1.x-this.touch0.x,g=Math.sqrt(m*m+u*u);this.listeners.map(w=>{w.zoom&&w.zoom(this.initialPinchDistance,g,a)})}}this.autoPreventDefault&&a.preventDefault()},n=a=>{if(this.isTouch=!0,this.touch0){var o=a.changedTouches;let f=e.getBoundingClientRect();for(var c=0;c<o.length;c++){var d=o[c];let m=d.clientX-f.left,u=d.clientY-f.top;if(this.touch0.identifier===d.identifier)if(this.touch0=null,this.mouseX=m,this.mouseY=u,this.listeners.map(g=>{g.up&&g.up(m,u,a)}),this.touch1)this.touch0=this.touch1,this.touch1=null,this.mouseX=this.touch0.x,this.mouseX=this.touch0.x,this.buttonDown=!0,this.listeners.map(g=>{g.down&&g.down(this.touch0.x,this.touch0.y,a)});else{this.buttonDown=!1;break}this.touch1&&this.touch1.identifier&&(this.touch1=null)}}this.autoPreventDefault&&a.preventDefault()};return e.addEventListener("mousedown",t,!0),e.addEventListener("mousemove",s,!0),e.addEventListener("mouseup",i,!0),e.addEventListener("wheel",r,!0),e.addEventListener("touchstart",h,{passive:!1,capture:!1}),e.addEventListener("touchmove",l,{passive:!1,capture:!1}),e.addEventListener("touchend",n,{passive:!1,capture:!1}),e.addEventListener("touchcancel",n),{mouseDown:t,mouseMove:s,mouseUp:i,mouseWheel:r,touchStart:h,touchMove:l,touchEnd:n}}dispose(){const e=this.element;e.removeEventListener("mousedown",this.callbacks.mouseDown,!0),e.removeEventListener("mousemove",this.callbacks.mouseMove,!0),e.removeEventListener("mouseup",this.callbacks.mouseUp,!0),e.removeEventListener("wheel",this.callbacks.mouseWheel,!0),e.removeEventListener("touchstart",this.callbacks.touchStart,{capture:!1}),e.removeEventListener("touchmove",this.callbacks.touchMove,{capture:!1}),e.removeEventListener("touchend",this.callbacks.touchEnd,{capture:!1}),e.removeEventListener("touchcancel",this.callbacks.touchEnd),this.listeners.length=0}addListener(e){this.listeners.push(e)}removeListener(e){let t=this.listeners.indexOf(e);t>-1&&this.listeners.splice(t,1)}},Ci=class{constructor(e,t,s){this.identifier=e,this.x=t,this.y=s}},Br=class{constructor(e,t){this.canvas=e,this.camera=t;let s=0,i=0,r=0,h=0,l=0,n=0,a=0,o=0;new ks(e).addListener({down:(c,d)=>{s=t.position.x,i=t.position.y,h=n=c,l=a=d,o=t.zoom},dragged:(c,d)=>{let f=c-h,m=d-l,u=t.screenToWorld(new At(0,0),e.clientWidth,e.clientHeight),g=t.screenToWorld(new At(f,m),e.clientWidth,e.clientHeight).sub(u);t.position.set(s-g.x,i-g.y,0),t.update(),n=c,a=d},wheel:c=>{let d=c/200*t.zoom,f=t.zoom+d;if(f>0){let m=0,u=0;if(c<0)m=n,u=a;else{let b=new At(e.clientWidth/2+15,e.clientHeight/2),x=n-b.x,p=e.clientHeight-1-a-b.y;m=b.x-x,u=e.clientHeight-1-b.y+p}let g=t.screenToWorld(new At(m,u),e.clientWidth,e.clientHeight);t.zoom=f,t.update();let w=t.screenToWorld(new At(m,u),e.clientWidth,e.clientHeight);t.position.add(g.sub(w)),t.update()}},zoom:(c,d)=>{let f=c/d;t.zoom=o*f},up:(c,d)=>{n=c,a=d},moved:(c,d)=>{n=c,a=d}})}},Tt=class dt{constructor(t,s,i){this.vertexShader=s,this.fragmentShader=i,this.vsSource=s,this.fsSource=i,this.context=t instanceof wt?t:new wt(t),this.context.addRestorable(this),this.compile()}static MVP_MATRIX="u_projTrans";static POSITION="a_position";static COLOR="a_color";static COLOR2="a_color2";static TEXCOORDS="a_texCoords";static SAMPLER="u_texture";context;vs=null;vsSource;fs=null;fsSource;program=null;tmp2x2=new Float32Array(2*2);tmp3x3=new Float32Array(3*3);tmp4x4=new Float32Array(4*4);getProgram(){return this.program}getVertexShader(){return this.vertexShader}getFragmentShader(){return this.fragmentShader}getVertexShaderSource(){return this.vsSource}getFragmentSource(){return this.fsSource}compile(){let t=this.context.gl;try{if(this.vs=this.compileShader(t.VERTEX_SHADER,this.vertexShader),!this.vs)throw new Error("Couldn't compile vertex shader.");if(this.fs=this.compileShader(t.FRAGMENT_SHADER,this.fragmentShader),!this.fs)throw new Error("Couldn#t compile fragment shader.");this.program=this.compileProgram(this.vs,this.fs)}catch(s){throw this.dispose(),s}}compileShader(t,s){let i=this.context.gl,r=i.createShader(t);if(!r)throw new Error("Couldn't create shader.");if(i.shaderSource(r,s),i.compileShader(r),!i.getShaderParameter(r,i.COMPILE_STATUS)){let h="Couldn't compile shader: "+i.getShaderInfoLog(r);if(i.deleteShader(r),!i.isContextLost())throw new Error(h)}return r}compileProgram(t,s){let i=this.context.gl,r=i.createProgram();if(!r)throw new Error("Couldn't compile program.");if(i.attachShader(r,t),i.attachShader(r,s),i.linkProgram(r),!i.getProgramParameter(r,i.LINK_STATUS)){let h="Couldn't compile shader program: "+i.getProgramInfoLog(r);if(i.deleteProgram(r),!i.isContextLost())throw new Error(h)}return r}restore(){this.compile()}bind(){this.context.gl.useProgram(this.program)}unbind(){this.context.gl.useProgram(null)}setUniformi(t,s){this.context.gl.uniform1i(this.getUniformLocation(t),s)}setUniformf(t,s){this.context.gl.uniform1f(this.getUniformLocation(t),s)}setUniform2f(t,s,i){this.context.gl.uniform2f(this.getUniformLocation(t),s,i)}setUniform3f(t,s,i,r){this.context.gl.uniform3f(this.getUniformLocation(t),s,i,r)}setUniform4f(t,s,i,r,h){this.context.gl.uniform4f(this.getUniformLocation(t),s,i,r,h)}setUniform2x2f(t,s){let i=this.context.gl;this.tmp2x2.set(s),i.uniformMatrix2fv(this.getUniformLocation(t),!1,this.tmp2x2)}setUniform3x3f(t,s){let i=this.context.gl;this.tmp3x3.set(s),i.uniformMatrix3fv(this.getUniformLocation(t),!1,this.tmp3x3)}setUniform4x4f(t,s){let i=this.context.gl;this.tmp4x4.set(s),i.uniformMatrix4fv(this.getUniformLocation(t),!1,this.tmp4x4)}getUniformLocation(t){let s=this.context.gl;if(!this.program)throw new Error("Shader not compiled.");let i=s.getUniformLocation(this.program,t);if(!i&&!s.isContextLost())throw new Error(`Couldn't find location for uniform ${t}`);return i}getAttributeLocation(t){let s=this.context.gl;if(!this.program)throw new Error("Shader not compiled.");let i=s.getAttribLocation(this.program,t);if(i==-1&&!s.isContextLost())throw new Error(`Couldn't find location for attribute ${t}`);return i}dispose(){this.context.removeRestorable(this);let t=this.context.gl;this.vs&&(t.deleteShader(this.vs),this.vs=null),this.fs&&(t.deleteShader(this.fs),this.fs=null),this.program&&(t.deleteProgram(this.program),this.program=null)}static newColoredTextured(t){let s=`
|
|
1
|
+
"use strict";var qi=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}},Ee=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,i=e.length;s<i;s++)this.add(e[s]);return t!=this.size}contains(e){return this.entries[e]}clear(){this.entries={},this.size=0}},et=class Nt{constructor(t=0,s=0,i=0,r=0){this.r=t,this.g=s,this.b=i,this.a=r}static WHITE=new Nt(1,1,1,1);static RED=new Nt(1,0,0,1);static GREEN=new Nt(0,1,0,1);static BLUE=new Nt(0,0,1,1);static MAGENTA=new Nt(1,0,1,1);set(t,s,i,r){return this.r=t,this.g=s,this.b=i,this.a=r,this.clamp()}setFromColor(t){return this.r=t.r,this.g=t.g,this.b=t.b,this.a=t.a,this}setFromString(t){return t=t.charAt(0)=="#"?t.substr(1):t,this.r=parseInt(t.substr(0,2),16)/255,this.g=parseInt(t.substr(2,2),16)/255,this.b=parseInt(t.substr(4,2),16)/255,this.a=t.length!=8?1:parseInt(t.substr(6,2),16)/255,this}add(t,s,i,r){return this.r+=t,this.g+=s,this.b+=i,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(t,s){t.r=((s&4278190080)>>>24)/255,t.g=((s&16711680)>>>16)/255,t.b=((s&65280)>>>8)/255,t.a=(s&255)/255}static rgb888ToColor(t,s){t.r=((s&16711680)>>>16)/255,t.g=((s&65280)>>>8)/255,t.b=(s&255)/255}toRgb888(){const t=s=>("0"+(s*255).toString(16)).slice(-2);return+("0x"+t(this.r)+t(this.g)+t(this.b))}static fromString(t,s=new Nt){return s.setFromString(t)}},L=class Et{static PI=3.1415927;static PI2=Et.PI*2;static invPI2=1/Et.PI2;static radiansToDegrees=180/Et.PI;static radDeg=Et.radiansToDegrees;static degreesToRadians=Et.PI/180;static degRad=Et.degreesToRadians;static clamp(t,s,i){return t<s?s:t>i?i:t}static cosDeg(t){return Math.cos(t*Et.degRad)}static sinDeg(t){return Math.sin(t*Et.degRad)}static atan2Deg(t,s){return Math.atan2(t,s)*Et.degRad}static signum(t){return t>0?1:t<0?-1:0}static toInt(t){return t>0?Math.floor(t):Math.ceil(t)}static cbrt(t){let s=Math.pow(Math.abs(t),.3333333333333333);return t<0?-s:s}static randomTriangular(t,s){return Et.randomTriangularWith(t,s,(t+s)*.5)}static randomTriangularWith(t,s,i){let r=Math.random(),h=s-t;return r<=(i-t)/h?t+Math.sqrt(r*h*(i-t)):s-Math.sqrt((1-r)*h*(s-i))}static isPowerOfTwo(t){return t&&(t&t-1)===0}},Hs=class{apply(e,t,s){return e+(t-e)*this.applyInternal(s)}},_s=class extends Hs{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}},Gi=class extends _s{constructor(e){super(e)}applyInternal(e){return Math.pow(e-1,this.power)*(this.power%2==0?-1:1)+1}},P=class Kt{static SUPPORTS_TYPED_ARRAYS=typeof Float32Array<"u";static arrayCopy(t,s,i,r,h){for(let l=s,n=r;l<s+h;l++,n++)i[n]=t[l]}static arrayFill(t,s,i,r){for(let h=s;h<i;h++)t[h]=r}static setArraySize(t,s,i=0){let r=t.length;if(r==s)return t;if(t.length=s,r<s)for(let h=r;h<s;h++)t[h]=i;return t}static ensureArrayCapacity(t,s,i=0){return t.length>=s?t:Kt.setArraySize(t,s,i)}static newArray(t,s){let i=new Array(t);for(let r=0;r<t;r++)i[r]=s;return i}static newFloatArray(t){if(Kt.SUPPORTS_TYPED_ARRAYS)return new Float32Array(t);{let s=new Array(t);for(let i=0;i<s.length;i++)s[i]=0;return s}}static newShortArray(t){if(Kt.SUPPORTS_TYPED_ARRAYS)return new Int16Array(t);{let s=new Array(t);for(let i=0;i<s.length;i++)s[i]=0;return s}}static toFloatArray(t){return Kt.SUPPORTS_TYPED_ARRAYS?new Float32Array(t):t}static toSinglePrecision(t){return Kt.SUPPORTS_TYPED_ARRAYS?Math.fround(t):t}static webkit602BugfixHelper(t,s){}static contains(t,s,i=!0){for(var r=0;r<t.length;r++)if(t[r]==s)return!0;return!1}static enumValue(t,s){return t[s[0].toUpperCase()+s.slice(1)]}},Hi=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)}}},$t=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}},Vt=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}},Ye=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)}},_i=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}},Re=class{name;constructor(e){if(!e)throw new Error("name cannot be null.");this.name=e}},Rt=class Li extends Re{static nextID=0;id=Li.nextID++;bones=null;vertices=[];worldVerticesLength=0;timelineAttachment=this;constructor(t){super(t)}computeWorldVertices(t,s,i,r,h,l){i=h+(i>>1)*l;let n=t.bone.skeleton,a=t.deform,o=this.vertices,c=this.bones;if(!c){a.length>0&&(o=a);let u=t.bone,g=u.worldX,w=u.worldY,b=u.a,x=u.b,p=u.c,v=u.d;for(let y=s,A=h;A<i;y+=2,A+=l){let C=o[y],S=o[y+1];r[A]=C*b+S*x+g,r[A+1]=C*p+S*v+w}return}let d=0,f=0;for(let u=0;u<s;u+=2){let g=c[d];d+=g+1,f+=g}let m=n.bones;if(a.length==0)for(let u=h,g=f*3;u<i;u+=l){let w=0,b=0,x=c[d++];for(x+=d;d<x;d++,g+=3){let p=m[c[d]],v=o[g],y=o[g+1],A=o[g+2];w+=(v*p.a+y*p.b+p.worldX)*A,b+=(v*p.c+y*p.d+p.worldY)*A}r[u]=w,r[u+1]=b}else{let u=a;for(let g=h,w=f*3,b=f<<1;g<i;g+=l){let x=0,p=0,v=c[d++];for(v+=d;d<v;d++,w+=3,b+=2){let y=m[c[d]],A=o[w]+u[b],C=o[w+1]+u[b+1],S=o[w+2];x+=(A*y.a+C*y.b+y.worldX)*S,p+=(A*y.c+C*y.d+y.worldY)*S}r[g]=x,r[g+1]=p}}}copyTo(t){this.bones?(t.bones=new Array(this.bones.length),P.arrayCopy(this.bones,0,t.bones,0,this.bones.length)):t.bones=null,this.vertices&&(t.vertices=P.newFloatArray(this.vertices.length),P.arrayCopy(this.vertices,0,t.vertices,0,this.vertices.length)),t.worldVerticesLength=this.worldVerticesLength,t.timelineAttachment=this.timelineAttachment}},js=class Ae{static _nextID=0;id=Ae.nextID();regions;start=0;digits=0;setupIndex=0;constructor(t){this.regions=new Array(t)}copy(){let t=new Ae(this.regions.length);return P.arrayCopy(this.regions,0,t.regions,0,this.regions.length),t.start=this.start,t.digits=this.digits,t.setupIndex=this.setupIndex,t}apply(t,s){let i=t.sequenceIndex;i==-1&&(i=this.setupIndex),i>=this.regions.length&&(i=this.regions.length-1);let r=this.regions[i];s.region!=r&&(s.region=r,s.updateRegion())}getPath(t,s){let i=t,r=(this.start+s).toString();for(let h=this.digits-r.length;h>0;h--)i+="0";return i+=r,i}static nextID(){return Ae._nextID++}},Zs=(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))(Zs||{}),Ks=[0,1,2,3,4,5,6],oe=class{name;timelines=[];timelineIds=new Ee;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,i,r,h,l,n){if(!e)throw new Error("skeleton cannot be null.");i&&this.duration!=0&&(s%=this.duration,t>0&&(t%=this.duration));let a=this.timelines;for(let o=0,c=a.length;o<c;o++)a[o].apply(e,t,s,r,h,l,n)}},Js=(e=>(e[e.setup=0]="setup",e[e.first=1]="first",e[e.replace=2]="replace",e[e.add=3]="add",e))(Js||{}),Qs=(e=>(e[e.mixIn=0]="mixIn",e[e.mixOut=1]="mixOut",e))(Qs||{}),rt={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},ft=class{propertyIds;frames;constructor(e,t){this.propertyIds=t,this.frames=P.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 i=1;i<s;i++)if(e[i]>t)return i-1;return s-1}static search(e,t,s){let i=e.length;for(let r=s;r<i;r+=s)if(e[r]>t)return r-s;return i-s}},St=class extends ft{curves;constructor(e,t,s){super(e,s),this.curves=P.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=P.newFloatArray(t);P.arrayCopy(this.curves,0,s,0,t),this.curves=s}}setBezier(e,t,s,i,r,h,l,n,a,o,c){let d=this.curves,f=this.getFrameCount()+e*18;s==0&&(d[t]=2+f);let m=(i-h*2+n)*.03,u=(r-l*2+a)*.03,g=((h-n)*3-i+o)*.006,w=((l-a)*3-r+c)*.006,b=m*2+g,x=u*2+w,p=(h-i)*.3+m+g*.16666667,v=(l-r)*.3+u+w*.16666667,y=i+p,A=r+v;for(let C=f+18;f<C;f+=2)d[f]=y,d[f+1]=A,p+=b,v+=x,b+=g,x+=w,y+=p,A+=v}getBezierValue(e,t,s,i){let r=this.curves;if(r[i]>e){let a=this.frames[t],o=this.frames[t+s];return o+(e-a)/(r[i]-a)*(r[i+1]-o)}let h=i+18;for(i+=2;i<h;i+=2)if(r[i]>=e){let a=r[i-2],o=r[i-1];return o+(e-a)/(r[i]-a)*(r[i+1]-o)}t+=this.getFrameEntries();let l=r[h-2],n=r[h-1];return n+(e-l)/(this.frames[t]-l)*(this.frames[t+s]-n)}},yt=class extends St{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 r=2;r<=s;r+=2)if(t[r]>e){s=r-2;break}let i=this.curves[s>>1];switch(i){case 0:let r=t[s],h=t[s+1];return h+(e-r)/(t[s+2]-r)*(t[s+2+1]-h);case 1:return t[s+1]}return this.getBezierValue(e,s,1,i-2)}getRelativeValue(e,t,s,i,r){if(e<this.frames[0]){switch(s){case 0:return r;case 1:return i+(r-i)*t}return i}let h=this.getCurveValue(e);switch(s){case 0:return r+h*t;case 1:case 2:h+=r-i}return i+h*t}getAbsoluteValue(e,t,s,i,r){if(e<this.frames[0]){switch(s){case 0:return r;case 1:return i+(r-i)*t}return i}let h=this.getCurveValue(e);return s==0?r+(h-r)*t:i+(h-i)*t}getAbsoluteValue2(e,t,s,i,r,h){if(e<this.frames[0]){switch(s){case 0:return r;case 1:return i+(r-i)*t}return i}return s==0?r+(h-r)*t:i+(h-i)*t}getScaleValue(e,t,s,i,r,h){const l=this.frames;if(e<l[0]){switch(s){case 0:return h;case 1:return r+(h-r)*t}return r}let n=this.getCurveValue(e)*h;if(t==1)return s==3?r+n-h:n;if(i==1)switch(s){case 0:return h+(Math.abs(n)*L.signum(h)-h)*t;case 1:case 2:return r+(Math.abs(n)*L.signum(r)-r)*t}else{let a=0;switch(s){case 0:return a=Math.abs(h)*L.signum(n),a+(n-a)*t;case 1:case 2:return a=Math.abs(r)*L.signum(n),a+(n-a)*t}}return r+(n-h)*t}},he=class extends St{constructor(e,t,s,i){super(e,t,[s,i])}getFrameEntries(){return 3}setFrame(e,t,s,i){e*=3,this.frames[e]=t,this.frames[e+1]=s,this.frames[e+2]=i}},te=class extends yt{boneIndex=0;constructor(e,t,s){super(e,t,rt.rotate+"|"+s),this.boneIndex=s}apply(e,t,s,i,r,h,l){let n=e.bones[this.boneIndex];n.active&&(n.rotation=this.getRelativeValue(s,r,h,n.rotation,n.data.rotation))}},ke=class extends he{boneIndex=0;constructor(e,t,s){super(e,t,rt.x+"|"+s,rt.y+"|"+s),this.boneIndex=s}apply(e,t,s,i,r,h,l){let n=e.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)*r,n.y+=(n.data.y-n.y)*r}return}let o=0,c=0,d=ft.search(a,s,3),f=this.curves[d/3];switch(f){case 0:let m=a[d];o=a[d+1],c=a[d+2];let u=(s-m)/(a[d+3]-m);o+=(a[d+3+1]-o)*u,c+=(a[d+3+2]-c)*u;break;case 1:o=a[d+1],c=a[d+2];break;default:o=this.getBezierValue(s,d,1,f-2),c=this.getBezierValue(s,d,2,f+18-2)}switch(h){case 0:n.x=n.data.x+o*r,n.y=n.data.y+c*r;break;case 1:case 2:n.x+=(n.data.x+o-n.x)*r,n.y+=(n.data.y+c-n.y)*r;break;case 3:n.x+=o*r,n.y+=c*r}}},Fe=class extends yt{boneIndex=0;constructor(e,t,s){super(e,t,rt.x+"|"+s),this.boneIndex=s}apply(e,t,s,i,r,h,l){let n=e.bones[this.boneIndex];n.active&&(n.x=this.getRelativeValue(s,r,h,n.x,n.data.x))}},Xe=class extends yt{boneIndex=0;constructor(e,t,s){super(e,t,rt.y+"|"+s),this.boneIndex=s}apply(e,t,s,i,r,h,l){let n=e.bones[this.boneIndex];n.active&&(n.y=this.getRelativeValue(s,r,h,n.y,n.data.y))}},Le=class extends he{boneIndex=0;constructor(e,t,s){super(e,t,rt.scaleX+"|"+s,rt.scaleY+"|"+s),this.boneIndex=s}apply(e,t,s,i,r,h,l){let n=e.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)*r,n.scaleY+=(n.data.scaleY-n.scaleY)*r}return}let o,c,d=ft.search(a,s,3),f=this.curves[d/3];switch(f){case 0:let m=a[d];o=a[d+1],c=a[d+2];let u=(s-m)/(a[d+3]-m);o+=(a[d+3+1]-o)*u,c+=(a[d+3+2]-c)*u;break;case 1:o=a[d+1],c=a[d+2];break;default:o=this.getBezierValue(s,d,1,f-2),c=this.getBezierValue(s,d,2,f+18-2)}if(o*=n.data.scaleX,c*=n.data.scaleY,r==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)*L.signum(m)-m)*r,n.scaleY=u+(Math.abs(c)*L.signum(u)-u)*r;break;case 1:case 2:m=n.scaleX,u=n.scaleY,n.scaleX=m+(Math.abs(o)*L.signum(m)-m)*r,n.scaleY=u+(Math.abs(c)*L.signum(u)-u)*r;break;case 3:n.scaleX+=(o-n.data.scaleX)*r,n.scaleY+=(c-n.data.scaleY)*r}else switch(h){case 0:m=Math.abs(n.data.scaleX)*L.signum(o),u=Math.abs(n.data.scaleY)*L.signum(c),n.scaleX=m+(o-m)*r,n.scaleY=u+(c-u)*r;break;case 1:case 2:m=Math.abs(n.scaleX)*L.signum(o),u=Math.abs(n.scaleY)*L.signum(c),n.scaleX=m+(o-m)*r,n.scaleY=u+(c-u)*r;break;case 3:n.scaleX+=(o-n.data.scaleX)*r,n.scaleY+=(c-n.data.scaleY)*r}}}},Pe=class extends yt{boneIndex=0;constructor(e,t,s){super(e,t,rt.scaleX+"|"+s),this.boneIndex=s}apply(e,t,s,i,r,h,l){let n=e.bones[this.boneIndex];n.active&&(n.scaleX=this.getScaleValue(s,r,h,l,n.scaleX,n.data.scaleX))}},Be=class extends yt{boneIndex=0;constructor(e,t,s){super(e,t,rt.scaleY+"|"+s),this.boneIndex=s}apply(e,t,s,i,r,h,l){let n=e.bones[this.boneIndex];n.active&&(n.scaleY=this.getScaleValue(s,r,h,l,n.scaleY,n.data.scaleY))}},Ve=class extends he{boneIndex=0;constructor(e,t,s){super(e,t,rt.shearX+"|"+s,rt.shearY+"|"+s),this.boneIndex=s}apply(e,t,s,i,r,h,l){let n=e.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)*r,n.shearY+=(n.data.shearY-n.shearY)*r}return}let o=0,c=0,d=ft.search(a,s,3),f=this.curves[d/3];switch(f){case 0:let m=a[d];o=a[d+1],c=a[d+2];let u=(s-m)/(a[d+3]-m);o+=(a[d+3+1]-o)*u,c+=(a[d+3+2]-c)*u;break;case 1:o=a[d+1],c=a[d+2];break;default:o=this.getBezierValue(s,d,1,f-2),c=this.getBezierValue(s,d,2,f+18-2)}switch(h){case 0:n.shearX=n.data.shearX+o*r,n.shearY=n.data.shearY+c*r;break;case 1:case 2:n.shearX+=(n.data.shearX+o-n.shearX)*r,n.shearY+=(n.data.shearY+c-n.shearY)*r;break;case 3:n.shearX+=o*r,n.shearY+=c*r}}},Oe=class extends yt{boneIndex=0;constructor(e,t,s){super(e,t,rt.shearX+"|"+s),this.boneIndex=s}apply(e,t,s,i,r,h,l){let n=e.bones[this.boneIndex];n.active&&(n.shearX=this.getRelativeValue(s,r,h,n.shearX,n.data.shearX))}},De=class extends yt{boneIndex=0;constructor(e,t,s){super(e,t,rt.shearY+"|"+s),this.boneIndex=s}apply(e,t,s,i,r,h,l){let n=e.bones[this.boneIndex];n.active&&(n.shearY=this.getRelativeValue(s,r,h,n.shearY,n.data.shearY))}},Ne=class extends ft{boneIndex=0;constructor(e,t){super(e,[rt.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,i,r,h,l){let n=e.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[ft.search(a,s,2)+1]}},Ue=class extends St{slotIndex=0;constructor(e,t,s){super(e,t,[rt.rgb+"|"+s,rt.alpha+"|"+s]),this.slotIndex=s}getFrameEntries(){return 5}setFrame(e,t,s,i,r,h){e*=5,this.frames[e]=t,this.frames[e+1]=s,this.frames[e+2]=i,this.frames[e+3]=r,this.frames[e+4]=h}apply(e,t,s,i,r,h,l){let n=e.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.setFromColor(w);return;case 1:o.add((w.r-o.r)*r,(w.g-o.g)*r,(w.b-o.b)*r,(w.a-o.a)*r)}return}let c=0,d=0,f=0,m=0,u=ft.search(a,s,5),g=this.curves[u/5];switch(g){case 0:let w=a[u];c=a[u+1],d=a[u+2],f=a[u+3],m=a[u+4];let b=(s-w)/(a[u+5]-w);c+=(a[u+5+1]-c)*b,d+=(a[u+5+2]-d)*b,f+=(a[u+5+3]-f)*b,m+=(a[u+5+4]-m)*b;break;case 1:c=a[u+1],d=a[u+2],f=a[u+3],m=a[u+4];break;default:c=this.getBezierValue(s,u,1,g-2),d=this.getBezierValue(s,u,2,g+18-2),f=this.getBezierValue(s,u,3,g+18*2-2),m=this.getBezierValue(s,u,4,g+18*3-2)}r==1?o.set(c,d,f,m):(h==0&&o.setFromColor(n.data.color),o.add((c-o.r)*r,(d-o.g)*r,(f-o.b)*r,(m-o.a)*r))}},ze=class extends St{slotIndex=0;constructor(e,t,s){super(e,t,[rt.rgb+"|"+s]),this.slotIndex=s}getFrameEntries(){return 4}setFrame(e,t,s,i,r){e<<=2,this.frames[e]=t,this.frames[e+1]=s,this.frames[e+2]=i,this.frames[e+3]=r}apply(e,t,s,i,r,h,l){let n=e.slots[this.slotIndex];if(!n.bone.active)return;let a=this.frames,o=n.color;if(s<a[0]){let g=n.data.color;switch(h){case 0:o.r=g.r,o.g=g.g,o.b=g.b;return;case 1:o.r+=(g.r-o.r)*r,o.g+=(g.g-o.g)*r,o.b+=(g.b-o.b)*r}return}let c=0,d=0,f=0,m=ft.search(a,s,4),u=this.curves[m>>2];switch(u){case 0:let g=a[m];c=a[m+1],d=a[m+2],f=a[m+3];let w=(s-g)/(a[m+4]-g);c+=(a[m+4+1]-c)*w,d+=(a[m+4+2]-d)*w,f+=(a[m+4+3]-f)*w;break;case 1:c=a[m+1],d=a[m+2],f=a[m+3];break;default:c=this.getBezierValue(s,m,1,u-2),d=this.getBezierValue(s,m,2,u+18-2),f=this.getBezierValue(s,m,3,u+18*2-2)}if(r==1)o.r=c,o.g=d,o.b=f;else{if(h==0){let g=n.data.color;o.r=g.r,o.g=g.g,o.b=g.b}o.r+=(c-o.r)*r,o.g+=(d-o.g)*r,o.b+=(f-o.b)*r}}},We=class extends yt{slotIndex=0;constructor(e,t,s){super(e,t,rt.alpha+"|"+s),this.slotIndex=s}apply(e,t,s,i,r,h,l){let n=e.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)*r}return}let o=this.getCurveValue(s);r==1?a.a=o:(h==0&&(a.a=n.data.color.a),a.a+=(o-a.a)*r)}},qe=class extends St{slotIndex=0;constructor(e,t,s){super(e,t,[rt.rgb+"|"+s,rt.alpha+"|"+s,rt.rgb2+"|"+s]),this.slotIndex=s}getFrameEntries(){return 8}setFrame(e,t,s,i,r,h,l,n,a){e<<=3,this.frames[e]=t,this.frames[e+1]=s,this.frames[e+2]=i,this.frames[e+3]=r,this.frames[e+4]=h,this.frames[e+5]=l,this.frames[e+6]=n,this.frames[e+7]=a}apply(e,t,s,i,r,h,l){let n=e.slots[this.slotIndex];if(!n.bone.active)return;let a=this.frames,o=n.color,c=n.darkColor;if(s<a[0]){let v=n.data.color,y=n.data.darkColor;switch(h){case 0:o.setFromColor(v),c.r=y.r,c.g=y.g,c.b=y.b;return;case 1:o.add((v.r-o.r)*r,(v.g-o.g)*r,(v.b-o.b)*r,(v.a-o.a)*r),c.r+=(y.r-c.r)*r,c.g+=(y.g-c.g)*r,c.b+=(y.b-c.b)*r}return}let d=0,f=0,m=0,u=0,g=0,w=0,b=0,x=ft.search(a,s,8),p=this.curves[x>>3];switch(p){case 0:let v=a[x];d=a[x+1],f=a[x+2],m=a[x+3],u=a[x+4],g=a[x+5],w=a[x+6],b=a[x+7];let y=(s-v)/(a[x+8]-v);d+=(a[x+8+1]-d)*y,f+=(a[x+8+2]-f)*y,m+=(a[x+8+3]-m)*y,u+=(a[x+8+4]-u)*y,g+=(a[x+8+5]-g)*y,w+=(a[x+8+6]-w)*y,b+=(a[x+8+7]-b)*y;break;case 1:d=a[x+1],f=a[x+2],m=a[x+3],u=a[x+4],g=a[x+5],w=a[x+6],b=a[x+7];break;default:d=this.getBezierValue(s,x,1,p-2),f=this.getBezierValue(s,x,2,p+18-2),m=this.getBezierValue(s,x,3,p+18*2-2),u=this.getBezierValue(s,x,4,p+18*3-2),g=this.getBezierValue(s,x,5,p+18*4-2),w=this.getBezierValue(s,x,6,p+18*5-2),b=this.getBezierValue(s,x,7,p+18*6-2)}if(r==1)o.set(d,f,m,u),c.r=g,c.g=w,c.b=b;else{if(h==0){o.setFromColor(n.data.color);let v=n.data.darkColor;c.r=v.r,c.g=v.g,c.b=v.b}o.add((d-o.r)*r,(f-o.g)*r,(m-o.b)*r,(u-o.a)*r),c.r+=(g-c.r)*r,c.g+=(w-c.g)*r,c.b+=(b-c.b)*r}}},Ge=class extends St{slotIndex=0;constructor(e,t,s){super(e,t,[rt.rgb+"|"+s,rt.rgb2+"|"+s]),this.slotIndex=s}getFrameEntries(){return 7}setFrame(e,t,s,i,r,h,l,n){e*=7,this.frames[e]=t,this.frames[e+1]=s,this.frames[e+2]=i,this.frames[e+3]=r,this.frames[e+4]=h,this.frames[e+5]=l,this.frames[e+6]=n}apply(e,t,s,i,r,h,l){let n=e.slots[this.slotIndex];if(!n.bone.active)return;let a=this.frames,o=n.color,c=n.darkColor;if(s<a[0]){let v=n.data.color,y=n.data.darkColor;switch(h){case 0:o.r=v.r,o.g=v.g,o.b=v.b,c.r=y.r,c.g=y.g,c.b=y.b;return;case 1:o.r+=(v.r-o.r)*r,o.g+=(v.g-o.g)*r,o.b+=(v.b-o.b)*r,c.r+=(y.r-c.r)*r,c.g+=(y.g-c.g)*r,c.b+=(y.b-c.b)*r}return}let d=0,f=0,m=0,u=0,g=0,w=0,b=0,x=ft.search(a,s,7),p=this.curves[x/7];switch(p){case 0:let v=a[x];d=a[x+1],f=a[x+2],m=a[x+3],g=a[x+4],w=a[x+5],b=a[x+6];let y=(s-v)/(a[x+7]-v);d+=(a[x+7+1]-d)*y,f+=(a[x+7+2]-f)*y,m+=(a[x+7+3]-m)*y,g+=(a[x+7+4]-g)*y,w+=(a[x+7+5]-w)*y,b+=(a[x+7+6]-b)*y;break;case 1:d=a[x+1],f=a[x+2],m=a[x+3],g=a[x+4],w=a[x+5],b=a[x+6];break;default:d=this.getBezierValue(s,x,1,p-2),f=this.getBezierValue(s,x,2,p+18-2),m=this.getBezierValue(s,x,3,p+18*2-2),g=this.getBezierValue(s,x,4,p+18*3-2),w=this.getBezierValue(s,x,5,p+18*4-2),b=this.getBezierValue(s,x,6,p+18*5-2)}if(r==1)o.r=d,o.g=f,o.b=m,c.r=g,c.g=w,c.b=b;else{if(h==0){let v=n.data.color,y=n.data.darkColor;o.r=v.r,o.g=v.g,o.b=v.b,c.r=y.r,c.g=y.g,c.b=y.b}o.r+=(d-o.r)*r,o.g+=(f-o.g)*r,o.b+=(m-o.b)*r,c.r+=(g-c.r)*r,c.g+=(w-c.g)*r,c.b+=(b-c.b)*r}}},Ot=class extends ft{slotIndex=0;attachmentNames;constructor(e,t){super(e,[rt.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,i,r,h,l){let n=e.slots[this.slotIndex];if(n.bone.active){if(l==1){h==0&&this.setAttachment(e,n,n.data.attachmentName);return}if(s<this.frames[0]){(h==0||h==1)&&this.setAttachment(e,n,n.data.attachmentName);return}this.setAttachment(e,n,this.attachmentNames[ft.search1(this.frames,s)])}}setAttachment(e,t,s){t.setAttachment(s?e.getAttachment(this.slotIndex,s):null)}},He=class extends St{slotIndex=0;attachment;vertices;constructor(e,t,s,i){super(e,t,[rt.deform+"|"+s+"|"+i.id]),this.slotIndex=s,this.attachment=i,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,i,r,h,l,n,a,o,c){let d=this.curves,f=this.getFrameCount()+e*18;s==0&&(d[t]=2+f);let m=(i-h*2+n)*.03,u=a*.03-l*.06,g=((h-n)*3-i+o)*.006,w=(l-a+.33333333)*.018,b=m*2+g,x=u*2+w,p=(h-i)*.3+m+g*.16666667,v=l*.3+u+w*.16666667,y=i+p,A=v;for(let C=f+18;f<C;f+=2)d[f]=y,d[f+1]=A,p+=b,v+=x,b+=g,x+=w,y+=p,A+=v}getCurvePercent(e,t){let s=this.curves,i=s[t];switch(i){case 0:let n=this.frames[t];return(e-n)/(this.frames[t+this.getFrameEntries()]-n);case 1:return 0}if(i-=2,s[i]>e){let n=this.frames[t];return s[i+1]*(e-n)/(s[i]-n)}let r=i+18;for(i+=2;i<r;i+=2)if(s[i]>=e){let n=s[i-2],a=s[i-1];return a+(e-n)/(s[i]-n)*(s[i+1]-a)}let h=s[r-2],l=s[r-1];return l+(1-l)*(e-h)/(this.frames[t+this.getFrameEntries()]-h)}apply(e,t,s,i,r,h,l){let n=e.slots[this.slotIndex];if(!n.bone.active)return;let a=n.getAttachment();if(!a||!(a instanceof Rt)||a.timelineAttachment!=this.attachment)return;let o=n.deform;o.length==0&&(h=0);let c=this.vertices,d=c[0].length,f=this.frames;if(s<f[0]){switch(h){case 0:o.length=0;return;case 1:if(r==1){o.length=0;return}o.length=d;let x=a;if(x.bones){r=1-r;for(var m=0;m<d;m++)o[m]*=r}else{let p=x.vertices;for(var m=0;m<d;m++)o[m]+=(p[m]-o[m])*r}}return}if(o.length=d,s>=f[f.length-1]){let x=c[f.length-1];if(r==1)if(h==3){let p=a;if(p.bones)for(let v=0;v<d;v++)o[v]+=x[v];else{let v=p.vertices;for(let y=0;y<d;y++)o[y]+=x[y]-v[y]}}else P.arrayCopy(x,0,o,0,d);else switch(h){case 0:{let v=a;if(v.bones)for(let y=0;y<d;y++)o[y]=x[y]*r;else{let y=v.vertices;for(let A=0;A<d;A++){let C=y[A];o[A]=C+(x[A]-C)*r}}break}case 1:case 2:for(let v=0;v<d;v++)o[v]+=(x[v]-o[v])*r;break;case 3:let p=a;if(p.bones)for(let v=0;v<d;v++)o[v]+=x[v]*r;else{let v=p.vertices;for(let y=0;y<d;y++)o[y]+=(x[y]-v[y])*r}}return}let u=ft.search1(f,s),g=this.getCurvePercent(s,u),w=c[u],b=c[u+1];if(r==1)if(h==3){let x=a;if(x.bones)for(let p=0;p<d;p++){let v=w[p];o[p]+=v+(b[p]-v)*g}else{let p=x.vertices;for(let v=0;v<d;v++){let y=w[v];o[v]+=y+(b[v]-y)*g-p[v]}}}else for(let x=0;x<d;x++){let p=w[x];o[x]=p+(b[x]-p)*g}else switch(h){case 0:{let p=a;if(p.bones)for(let v=0;v<d;v++){let y=w[v];o[v]=(y+(b[v]-y)*g)*r}else{let v=p.vertices;for(let y=0;y<d;y++){let A=w[y],C=v[y];o[y]=C+(A+(b[y]-A)*g-C)*r}}break}case 1:case 2:for(let p=0;p<d;p++){let v=w[p];o[p]+=(v+(b[p]-v)*g-o[p])*r}break;case 3:let x=a;if(x.bones)for(let p=0;p<d;p++){let v=w[p];o[p]+=(v+(b[p]-v)*g)*r}else{let p=x.vertices;for(let v=0;v<d;v++){let y=w[v];o[v]+=(y+(b[v]-y)*g-p[v])*r}}}}},ce=class Pi extends ft{static propertyIds=[""+rt.event];events;constructor(t){super(t,Pi.propertyIds),this.events=new Array(t)}getFrameCount(){return this.frames.length}setFrame(t,s){this.frames[t]=s.time,this.events[t]=s}apply(t,s,i,r,h,l,n){if(!r)return;let a=this.frames,o=this.frames.length;if(s>i)this.apply(t,s,Number.MAX_VALUE,r,h,l,n),s=-1;else if(s>=a[o-1])return;if(i<a[0])return;let c=0;if(s<a[0])c=0;else{c=ft.search1(a,s)+1;let d=a[c];for(;c>0&&a[c-1]==d;)c--}for(;c<o&&i>=a[c];c++)r.push(this.events[c])}},qt=class Bi extends ft{static propertyIds=[""+rt.drawOrder];drawOrders;constructor(t){super(t,Bi.propertyIds),this.drawOrders=new Array(t)}getFrameCount(){return this.frames.length}setFrame(t,s,i){this.frames[t]=s,this.drawOrders[t]=i}apply(t,s,i,r,h,l,n){if(n==1){l==0&&P.arrayCopy(t.slots,0,t.drawOrder,0,t.slots.length);return}if(i<this.frames[0]){(l==0||l==1)&&P.arrayCopy(t.slots,0,t.drawOrder,0,t.slots.length);return}let a=ft.search1(this.frames,i),o=this.drawOrders[a];if(!o)P.arrayCopy(t.slots,0,t.drawOrder,0,t.slots.length);else{let c=t.drawOrder,d=t.slots;for(let f=0,m=o.length;f<m;f++)c[f]=d[o[f]]}}},_e=class extends St{constraintIndex=0;constructor(e,t,s){super(e,t,[rt.ikConstraint+"|"+s]),this.constraintIndex=s}getFrameEntries(){return 6}setFrame(e,t,s,i,r,h,l){e*=6,this.frames[e]=t,this.frames[e+1]=s,this.frames[e+2]=i,this.frames[e+3]=r,this.frames[e+4]=h?1:0,this.frames[e+5]=l?1:0}apply(e,t,s,i,r,h,l){let n=e.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)*r,n.softness+=(n.data.softness-n.softness)*r,n.bendDirection=n.data.bendDirection,n.compress=n.data.compress,n.stretch=n.data.stretch}return}let o=0,c=0,d=ft.search(a,s,6),f=this.curves[d/6];switch(f){case 0:let m=a[d];o=a[d+1],c=a[d+2];let u=(s-m)/(a[d+6]-m);o+=(a[d+6+1]-o)*u,c+=(a[d+6+2]-c)*u;break;case 1:o=a[d+1],c=a[d+2];break;default:o=this.getBezierValue(s,d,1,f-2),c=this.getBezierValue(s,d,2,f+18-2)}h==0?(n.mix=n.data.mix+(o-n.data.mix)*r,n.softness=n.data.softness+(c-n.data.softness)*r,l==1?(n.bendDirection=n.data.bendDirection,n.compress=n.data.compress,n.stretch=n.data.stretch):(n.bendDirection=a[d+3],n.compress=a[d+4]!=0,n.stretch=a[d+5]!=0)):(n.mix+=(o-n.mix)*r,n.softness+=(c-n.softness)*r,l==0&&(n.bendDirection=a[d+3],n.compress=a[d+4]!=0,n.stretch=a[d+5]!=0))}},je=class extends St{constraintIndex=0;constructor(e,t,s){super(e,t,[rt.transformConstraint+"|"+s]),this.constraintIndex=s}getFrameEntries(){return 7}setFrame(e,t,s,i,r,h,l,n){let a=this.frames;e*=7,a[e]=t,a[e+1]=s,a[e+2]=i,a[e+3]=r,a[e+4]=h,a[e+5]=l,a[e+6]=n}apply(e,t,s,i,r,h,l){let n=e.transformConstraints[this.constraintIndex];if(!n.active)return;let a=this.frames;if(s<a[0]){let b=n.data;switch(h){case 0:n.mixRotate=b.mixRotate,n.mixX=b.mixX,n.mixY=b.mixY,n.mixScaleX=b.mixScaleX,n.mixScaleY=b.mixScaleY,n.mixShearY=b.mixShearY;return;case 1:n.mixRotate+=(b.mixRotate-n.mixRotate)*r,n.mixX+=(b.mixX-n.mixX)*r,n.mixY+=(b.mixY-n.mixY)*r,n.mixScaleX+=(b.mixScaleX-n.mixScaleX)*r,n.mixScaleY+=(b.mixScaleY-n.mixScaleY)*r,n.mixShearY+=(b.mixShearY-n.mixShearY)*r}return}let o,c,d,f,m,u,g=ft.search(a,s,7),w=this.curves[g/7];switch(w){case 0:let b=a[g];o=a[g+1],c=a[g+2],d=a[g+3],f=a[g+4],m=a[g+5],u=a[g+6];let x=(s-b)/(a[g+7]-b);o+=(a[g+7+1]-o)*x,c+=(a[g+7+2]-c)*x,d+=(a[g+7+3]-d)*x,f+=(a[g+7+4]-f)*x,m+=(a[g+7+5]-m)*x,u+=(a[g+7+6]-u)*x;break;case 1:o=a[g+1],c=a[g+2],d=a[g+3],f=a[g+4],m=a[g+5],u=a[g+6];break;default:o=this.getBezierValue(s,g,1,w-2),c=this.getBezierValue(s,g,2,w+18-2),d=this.getBezierValue(s,g,3,w+18*2-2),f=this.getBezierValue(s,g,4,w+18*3-2),m=this.getBezierValue(s,g,5,w+18*4-2),u=this.getBezierValue(s,g,6,w+18*5-2)}if(h==0){let b=n.data;n.mixRotate=b.mixRotate+(o-b.mixRotate)*r,n.mixX=b.mixX+(c-b.mixX)*r,n.mixY=b.mixY+(d-b.mixY)*r,n.mixScaleX=b.mixScaleX+(f-b.mixScaleX)*r,n.mixScaleY=b.mixScaleY+(m-b.mixScaleY)*r,n.mixShearY=b.mixShearY+(u-b.mixShearY)*r}else n.mixRotate+=(o-n.mixRotate)*r,n.mixX+=(c-n.mixX)*r,n.mixY+=(d-n.mixY)*r,n.mixScaleX+=(f-n.mixScaleX)*r,n.mixScaleY+=(m-n.mixScaleY)*r,n.mixShearY+=(u-n.mixShearY)*r}},Ze=class extends yt{constraintIndex=0;constructor(e,t,s){super(e,t,rt.pathConstraintPosition+"|"+s),this.constraintIndex=s}apply(e,t,s,i,r,h,l){let n=e.pathConstraints[this.constraintIndex];n.active&&(n.position=this.getAbsoluteValue(s,r,h,n.position,n.data.position))}},Ke=class extends yt{constraintIndex=0;constructor(e,t,s){super(e,t,rt.pathConstraintSpacing+"|"+s),this.constraintIndex=s}apply(e,t,s,i,r,h,l){let n=e.pathConstraints[this.constraintIndex];n.active&&(n.spacing=this.getAbsoluteValue(s,r,h,n.spacing,n.data.spacing))}},Je=class extends St{constraintIndex=0;constructor(e,t,s){super(e,t,[rt.pathConstraintMix+"|"+s]),this.constraintIndex=s}getFrameEntries(){return 4}setFrame(e,t,s,i,r){let h=this.frames;e<<=2,h[e]=t,h[e+1]=s,h[e+2]=i,h[e+3]=r}apply(e,t,s,i,r,h,l){let n=e.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)*r,n.mixX+=(n.data.mixX-n.mixX)*r,n.mixY+=(n.data.mixY-n.mixY)*r}return}let o,c,d,f=ft.search(a,s,4),m=this.curves[f>>2];switch(m){case 0:let u=a[f];o=a[f+1],c=a[f+2],d=a[f+3];let g=(s-u)/(a[f+4]-u);o+=(a[f+4+1]-o)*g,c+=(a[f+4+2]-c)*g,d+=(a[f+4+3]-d)*g;break;case 1:o=a[f+1],c=a[f+2],d=a[f+3];break;default:o=this.getBezierValue(s,f,1,m-2),c=this.getBezierValue(s,f,2,m+18-2),d=this.getBezierValue(s,f,3,m+18*2-2)}if(h==0){let u=n.data;n.mixRotate=u.mixRotate+(o-u.mixRotate)*r,n.mixX=u.mixX+(c-u.mixX)*r,n.mixY=u.mixY+(d-u.mixY)*r}else n.mixRotate+=(o-n.mixRotate)*r,n.mixX+=(c-n.mixX)*r,n.mixY+=(d-n.mixY)*r}},Lt=class extends yt{constraintIndex=0;constructor(e,t,s,i){super(e,t,i+"|"+s),this.constraintIndex=s}apply(e,t,s,i,r,h,l){let n;if(this.constraintIndex==-1){const a=s>=this.frames[0]?this.getCurveValue(s):0;for(const o of e.physicsConstraints)o.active&&this.global(o.data)&&this.set(o,this.getAbsoluteValue2(s,r,h,this.get(o),this.setup(o),a))}else n=e.physicsConstraints[this.constraintIndex],n.active&&this.set(n,this.getAbsoluteValue(s,r,h,this.get(n),this.setup(n)))}},Qe=class extends Lt{constructor(e,t,s){super(e,t,s,rt.physicsConstraintInertia)}setup(e){return e.data.inertia}get(e){return e.inertia}set(e,t){e.inertia=t}global(e){return e.inertiaGlobal}},$e=class extends Lt{constructor(e,t,s){super(e,t,s,rt.physicsConstraintStrength)}setup(e){return e.data.strength}get(e){return e.strength}set(e,t){e.strength=t}global(e){return e.strengthGlobal}},ts=class extends Lt{constructor(e,t,s){super(e,t,s,rt.physicsConstraintDamping)}setup(e){return e.data.damping}get(e){return e.damping}set(e,t){e.damping=t}global(e){return e.dampingGlobal}},es=class extends Lt{constructor(e,t,s){super(e,t,s,rt.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}},ss=class extends Lt{constructor(e,t,s){super(e,t,s,rt.physicsConstraintWind)}setup(e){return e.data.wind}get(e){return e.wind}set(e,t){e.wind=t}global(e){return e.windGlobal}},is=class extends Lt{constructor(e,t,s){super(e,t,s,rt.physicsConstraintGravity)}setup(e){return e.data.gravity}get(e){return e.gravity}set(e,t){e.gravity=t}global(e){return e.gravityGlobal}},rs=class extends Lt{constructor(e,t,s){super(e,t,s,rt.physicsConstraintMix)}setup(e){return e.data.mix}get(e){return e.mix}set(e,t){e.mix=t}global(e){return e.mixGlobal}},ns=class Vi extends ft{static propertyIds=[rt.physicsConstraintReset.toString()];constraintIndex;constructor(t,s){super(t,Vi.propertyIds),this.constraintIndex=s}getFrameCount(){return this.frames.length}setFrame(t,s){this.frames[t]=s}apply(t,s,i,r,h,l,n){let a;if(this.constraintIndex!=-1&&(a=t.physicsConstraints[this.constraintIndex],!a.active))return;const o=this.frames;if(s>i)this.apply(t,s,Number.MAX_VALUE,[],h,l,n),s=-1;else if(s>=o[o.length-1])return;if(!(i<o[0])&&(s<o[0]||i>=o[ft.search1(o,s)+1]))if(a!=null)a.reset();else for(const c of t.physicsConstraints)c.active&&c.reset()}},as=class Pt extends ft{static ENTRIES=3;static MODE=1;static DELAY=2;slotIndex;attachment;constructor(t,s,i){super(t,[rt.sequence+"|"+s+"|"+i.sequence.id]),this.slotIndex=s,this.attachment=i}getFrameEntries(){return Pt.ENTRIES}getSlotIndex(){return this.slotIndex}getAttachment(){return this.attachment}setFrame(t,s,i,r,h){let l=this.frames;t*=Pt.ENTRIES,l[t]=s,l[t+Pt.MODE]=i|r<<4,l[t+Pt.DELAY]=h}apply(t,s,i,r,h,l,n){let a=t.slots[this.slotIndex];if(!a.bone.active)return;let o=a.attachment,c=this.attachment;if(o!=c&&(!(o instanceof Rt)||o.timelineAttachment!=c))return;if(n==1){l==0&&(a.sequenceIndex=-1);return}let d=this.frames;if(i<d[0]){(l==0||l==1)&&(a.sequenceIndex=-1);return}let f=ft.search(d,i,Pt.ENTRIES),m=d[f],u=d[f+Pt.MODE],g=d[f+Pt.DELAY];if(!this.attachment.sequence)return;let w=u>>4,b=this.attachment.sequence.regions.length,x=Ks[u&15];if(x!=0)switch(w+=(i-m)/g+1e-5|0,x){case 1:w=Math.min(b-1,w);break;case 2:w%=b;break;case 3:{let p=(b<<1)-2;w=p==0?0:w%p,w>=b&&(w=p-w);break}case 4:w=Math.max(b-1-w,0);break;case 5:w=b-1-w%b;break;case 6:{let p=(b<<1)-2;w=p==0?0:(w+b-1)%p,w>=b&&(w=p-w)}}a.sequenceIndex=w}},ji=class Ce{static _emptyAnimation=new oe("<empty>",[],0);static emptyAnimation(){return Ce._emptyAnimation}data;tracks=new Array;timeScale=1;unkeyedState=0;events=new Array;listeners=new Array;queue=new ti(this);propertyIDs=new Ee;animationsChanged=!1;trackEntryPool=new $t(()=>new $s);constructor(t){this.data=t}update(t){t*=this.timeScale;let s=this.tracks;for(let i=0,r=s.length;i<r;i++){let h=s[i];if(!h)continue;h.animationLast=h.nextAnimationLast,h.trackLast=h.nextTrackLast;let l=t*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+t)*n.timeScale,h.trackTime+=l,this.setCurrent(i,n,!0);n.mixingFrom;)n.mixTime+=t,n=n.mixingFrom;continue}}else if(h.trackLast>=h.trackEnd&&!h.mixingFrom){s[i]=null,this.queue.end(h),this.clearNext(h);continue}if(h.mixingFrom&&this.updateMixingFrom(h,t)){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(t,s){let i=t.mixingFrom;if(!i)return!0;let r=this.updateMixingFrom(i,s);return i.animationLast=i.nextAnimationLast,i.trackLast=i.nextTrackLast,t.nextTrackLast!=-1&&t.mixTime>=t.mixDuration?((i.totalAlpha==0||t.mixDuration==0)&&(t.mixingFrom=i.mixingFrom,i.mixingFrom!=null&&(i.mixingFrom.mixingTo=t),t.interruptAlpha=i.interruptAlpha,this.queue.end(i)),r):(i.trackTime+=s*i.timeScale,t.mixTime+=s,!1)}apply(t){if(!t)throw new Error("skeleton cannot be null.");this.animationsChanged&&this._animationsChanged();let s=this.events,i=this.tracks,r=!1;for(let f=0,m=i.length;f<m;f++){let u=i[f];if(!u||u.delay>0)continue;r=!0;let g=f==0?1:u.mixBlend,w=u.alpha;u.mixingFrom?w*=this.applyMixingFrom(u,t,g):u.trackTime>=u.trackEnd&&!u.next&&(w=0);let b=w>=u.alphaAttachmentThreshold,x=u.animationLast,p=u.getAnimationTime(),v=p,y=s;u.reverse&&(v=u.animation.duration-v,y=null);let A=u.animation.timelines,C=A.length;if(f==0&&w==1||g==3){f==0&&(b=!0);for(let S=0;S<C;S++){P.webkit602BugfixHelper(w,g);var h=A[S];h instanceof Ot?this.applyAttachmentTimeline(h,t,v,g,b):h.apply(t,x,v,y,w,g,0)}}else{let S=u.timelineMode,T=u.shortestRotation,R=!T&&u.timelinesRotation.length!=C<<1;R&&(u.timelinesRotation.length=C<<1);for(let k=0;k<C;k++){let F=A[k],X=S[k]==de?g:0;!T&&F instanceof te?this.applyRotateTimeline(F,t,v,w,X,u.timelinesRotation,k<<1,R):F instanceof Ot?this.applyAttachmentTimeline(F,t,v,g,b):(P.webkit602BugfixHelper(w,g),F.apply(t,x,v,y,w,X,0))}}this.queueEvents(u,p),s.length=0,u.nextAnimationLast=p,u.nextTrackLast=u.trackTime}for(var l=this.unkeyedState+hs,n=t.slots,a=0,o=t.slots.length;a<o;a++){var c=n[a];if(c.attachmentState==l){var d=c.data.attachmentName;c.setAttachment(d?t.getAttachment(c.data.index,d):null)}}return this.unkeyedState+=2,this.queue.drain(),r}applyMixingFrom(t,s,i){let r=t.mixingFrom;r.mixingFrom&&this.applyMixingFrom(r,s,i);let h=0;t.mixDuration==0?(h=1,i==1&&(i=0)):(h=t.mixTime/t.mixDuration,h>1&&(h=1),i!=1&&(i=r.mixBlend));let l=h<r.mixAttachmentThreshold,n=h<r.mixDrawOrderThreshold,a=r.animation.timelines,o=a.length,c=r.alpha*t.interruptAlpha,d=c*(1-h),f=r.animationLast,m=r.getAnimationTime(),u=m,g=null;if(r.reverse?u=r.animation.duration-u:h<r.eventThreshold&&(g=this.events),i==3)for(let w=0;w<o;w++)a[w].apply(s,f,u,g,d,i,1);else{let w=r.timelineMode,b=r.timelineHoldMix,x=r.shortestRotation,p=!x&&r.timelinesRotation.length!=o<<1;p&&(r.timelinesRotation.length=o<<1),r.totalAlpha=0;for(let v=0;v<o;v++){let y=a[v],A=1,C,S=0;switch(w[v]){case de:if(!n&&y instanceof qt)continue;C=i,S=d;break;case ls:C=0,S=d;break;case os:C=i,S=c;break;case fe:C=0,S=c;break;default:C=0;let T=b[v];S=c*Math.max(0,1-T.mixTime/T.mixDuration);break}r.totalAlpha+=S,!x&&y instanceof te?this.applyRotateTimeline(y,s,u,S,C,r.timelinesRotation,v<<1,p):y instanceof Ot?this.applyAttachmentTimeline(y,s,u,C,l&&S>=r.alphaAttachmentThreshold):(P.webkit602BugfixHelper(S,i),n&&y instanceof qt&&C==0&&(A=0),y.apply(s,f,u,g,S,C,A))}}return t.mixDuration>0&&this.queueEvents(r,m),this.events.length=0,r.nextAnimationLast=m,r.nextTrackLast=r.trackTime,h}applyAttachmentTimeline(t,s,i,r,h){var l=s.slots[t.slotIndex];l.bone.active&&(i<t.frames[0]?(r==0||r==1)&&this.setAttachment(s,l,l.data.attachmentName,h):this.setAttachment(s,l,t.attachmentNames[ft.search1(t.frames,i)],h),l.attachmentState<=this.unkeyedState&&(l.attachmentState=this.unkeyedState+hs))}setAttachment(t,s,i,r){s.setAttachment(i?t.getAttachment(s.data.index,i):null),r&&(s.attachmentState=this.unkeyedState+ii)}applyRotateTimeline(t,s,i,r,h,l,n,a){if(a&&(l[n]=0),r==1){t.apply(s,0,i,null,1,h,0);return}let o=s.bones[t.boneIndex];if(!o.active)return;let c=t.frames,d=0,f=0;if(i<c[0])switch(h){case 0:o.rotation=o.data.rotation;default:return;case 1:d=o.rotation,f=o.data.rotation}else d=h==0?o.data.rotation:o.rotation,f=o.data.rotation+t.getCurveValue(i);let m=0,u=f-d;if(u-=Math.ceil(u/360-.5)*360,u==0)m=l[n];else{let g=0,w=0;a?(g=0,w=u):(g=l[n],w=l[n+1]);let b=g-g%360;m=u+b;let x=u>=0,p=g>=0;Math.abs(w)<=90&&L.signum(w)!=L.signum(u)&&(Math.abs(g-b)>180?(m+=360*L.signum(g),p=x):b!=0?m-=360*L.signum(g):p=x),p!=x&&(m+=360*L.signum(g)),l[n]=m}l[n+1]=u,o.rotation=d+m*r}queueEvents(t,s){let i=t.animationStart,r=t.animationEnd,h=r-i,l=t.trackLast%h,n=this.events,a=0,o=n.length;for(;a<o;a++){let d=n[a];if(d.time<l)break;d.time>r||this.queue.event(t,d)}let c=!1;if(t.loop)if(h==0)c=!0;else{const d=Math.floor(t.trackTime/h);c=d>0&&d>Math.floor(t.trackLast/h)}else c=s>=r&&t.animationLast<r;for(c&&this.queue.complete(t);a<o;a++){let d=n[a];d.time<i||this.queue.event(t,d)}}clearTracks(){let t=this.queue.drainDisabled;this.queue.drainDisabled=!0;for(let s=0,i=this.tracks.length;s<i;s++)this.clearTrack(s);this.tracks.length=0,this.queue.drainDisabled=t,this.queue.drain()}clearTrack(t){if(t>=this.tracks.length)return;let s=this.tracks[t];if(!s)return;this.queue.end(s),this.clearNext(s);let i=s;for(;;){let r=i.mixingFrom;if(!r)break;this.queue.end(r),i.mixingFrom=null,i.mixingTo=null,i=r}this.tracks[s.trackIndex]=null,this.queue.drain()}setCurrent(t,s,i){let r=this.expandToIndex(t);this.tracks[t]=s,s.previous=null,r&&(i&&this.queue.interrupt(r),s.mixingFrom=r,r.mixingTo=s,s.mixTime=0,r.mixingFrom&&r.mixDuration>0&&(s.interruptAlpha*=Math.min(1,r.mixTime/r.mixDuration)),r.timelinesRotation.length=0),this.queue.start(s)}setAnimation(t,s,i=!1){let r=this.data.skeletonData.findAnimation(s);if(!r)throw new Error("Animation not found: "+s);return this.setAnimationWith(t,r,i)}setAnimationWith(t,s,i=!1){if(!s)throw new Error("animation cannot be null.");let r=!0,h=this.expandToIndex(t);h&&(h.nextTrackLast==-1?(this.tracks[t]=h.mixingFrom,this.queue.interrupt(h),this.queue.end(h),this.clearNext(h),h=h.mixingFrom,r=!1):this.clearNext(h));let l=this.trackEntry(t,s,i,h);return this.setCurrent(t,l,r),this.queue.drain(),l}addAnimation(t,s,i=!1,r=0){let h=this.data.skeletonData.findAnimation(s);if(!h)throw new Error("Animation not found: "+s);return this.addAnimationWith(t,h,i,r)}addAnimationWith(t,s,i=!1,r=0){if(!s)throw new Error("animation cannot be null.");let h=this.expandToIndex(t);if(h)for(;h.next;)h=h.next;let l=this.trackEntry(t,s,i,h);return h?(h.next=l,l.previous=h,r<=0&&(r=Math.max(r+h.getTrackComplete()-l.mixDuration,0))):(this.setCurrent(t,l,!0),this.queue.drain(),r<0&&(r=0)),l.delay=r,l}setEmptyAnimation(t,s=0){let i=this.setAnimationWith(t,Ce.emptyAnimation(),!1);return i.mixDuration=s,i.trackEnd=s,i}addEmptyAnimation(t,s=0,i=0){let r=this.addAnimationWith(t,Ce.emptyAnimation(),!1,i);return i<=0&&(r.delay=Math.max(r.delay+r.mixDuration-s,0)),r.mixDuration=s,r.trackEnd=s,r}setEmptyAnimations(t=0){let s=this.queue.drainDisabled;this.queue.drainDisabled=!0;for(let i=0,r=this.tracks.length;i<r;i++){let h=this.tracks[i];h&&this.setEmptyAnimation(h.trackIndex,t)}this.queue.drainDisabled=s,this.queue.drain()}expandToIndex(t){return t<this.tracks.length?this.tracks[t]:(P.ensureArrayCapacity(this.tracks,t+1,null),this.tracks.length=t+1,null)}trackEntry(t,s,i,r){let h=this.trackEntryPool.obtain();return h.reset(),h.trackIndex=t,h.animation=s,h.loop=i,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=r?this.data.getMix(r.animation,s):0,h.interruptAlpha=1,h.totalAlpha=0,h.mixBlend=2,h}clearNext(t){let s=t.next;for(;s;)this.queue.dispose(s),s=s.next;t.next=null}_animationsChanged(){this.animationsChanged=!1,this.propertyIDs.clear();let t=this.tracks;for(let s=0,i=t.length;s<i;s++){let r=t[s];if(r){for(;r.mixingFrom;)r=r.mixingFrom;do(!r.mixingTo||r.mixBlend!=3)&&this.computeHold(r),r=r.mixingTo;while(r)}}}computeHold(t){let s=t.mixingTo,i=t.animation.timelines,r=t.animation.timelines.length,h=t.timelineMode;h.length=r;let l=t.timelineHoldMix;l.length=0;let n=this.propertyIDs;if(s&&s.holdPrevious){for(let a=0;a<r;a++)h[a]=n.addAll(i[a].getPropertyIds())?fe:os;return}t:for(let a=0;a<r;a++){let o=i[a],c=o.getPropertyIds();if(!n.addAll(c))h[a]=de;else if(!s||o instanceof Ot||o instanceof qt||o instanceof ce||!s.animation.hasTimeline(c))h[a]=ls;else{for(let d=s.mixingTo;d;d=d.mixingTo)if(!d.animation.hasTimeline(c)){if(t.mixDuration>0){h[a]=si,l[a]=d;continue t}break}h[a]=fe}}}getCurrent(t){return t>=this.tracks.length?null:this.tracks[t]}addListener(t){if(!t)throw new Error("listener cannot be null.");this.listeners.push(t)}removeListener(t){let s=this.listeners.indexOf(t);s>=0&&this.listeners.splice(s,1)}clearListeners(){this.listeners.length=0}clearListenerNotifications(){this.queue.clear()}},$s=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}},ti=class{objects=[];drainDisabled=!1;animState;constructor(e){this.animState=e}start(e){this.objects.push(0),this.objects.push(e),this.animState.animationsChanged=!0}interrupt(e){this.objects.push(1),this.objects.push(e)}end(e){this.objects.push(2),this.objects.push(e),this.animState.animationsChanged=!0}dispose(e){this.objects.push(3),this.objects.push(e)}complete(e){this.objects.push(4),this.objects.push(e)}event(e,t){this.objects.push(5),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 i=e[s],r=e[s+1];switch(i){case 0:r.listener&&r.listener.start&&r.listener.start(r);for(let l=0;l<t.length;l++){let n=t[l];n.start&&n.start(r)}break;case 1:r.listener&&r.listener.interrupt&&r.listener.interrupt(r);for(let l=0;l<t.length;l++){let n=t[l];n.interrupt&&n.interrupt(r)}break;case 2:r.listener&&r.listener.end&&r.listener.end(r);for(let l=0;l<t.length;l++){let n=t[l];n.end&&n.end(r)}case 3:r.listener&&r.listener.dispose&&r.listener.dispose(r);for(let l=0;l<t.length;l++){let n=t[l];n.dispose&&n.dispose(r)}this.animState.trackEntryPool.free(r);break;case 4:r.listener&&r.listener.complete&&r.listener.complete(r);for(let l=0;l<t.length;l++){let n=t[l];n.complete&&n.complete(r)}break;case 5:let h=e[s+++2];r.listener&&r.listener.event&&r.listener.event(r,h);for(let l=0;l<t.length;l++){let n=t[l];n.event&&n.event(r,h)}break}}this.clear(),this.drainDisabled=!1}clear(){this.objects.length=0}},ei=(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))(ei||{}),Zi=class{start(e){}interrupt(e){}end(e){}dispose(e){}complete(e){}event(e,t){}},de=0,ls=1,os=2,fe=3,si=4,hs=1,ii=2,Ki=class{skeletonData;animationToMixTime={};defaultMix=0;constructor(e){if(!e)throw new Error("skeletonData cannot be null.");this.skeletonData=e}setMix(e,t,s){let i=this.skeletonData.findAnimation(e);if(!i)throw new Error("Animation not found: "+e);let r=this.skeletonData.findAnimation(t);if(!r)throw new Error("Animation not found: "+t);this.setMixWith(i,r,s)}setMixWith(e,t,s){if(!e)throw new Error("from cannot be null.");if(!t)throw new Error("to cannot be null.");let i=e.name+"."+t.name;this.animationToMixTime[i]=s}getMix(e,t){let s=e.name+"."+t.name,i=this.animationToMixTime[s];return i===void 0?this.defaultMix:i}},cs=class Oi extends Rt{color=new et(1,1,1,1);constructor(t){super(t)}copy(){let t=new Oi(this.name);return this.copyTo(t),t.color.setFromColor(this.color),t}},ee=class Di extends Rt{endSlot=null;color=new et(.2275,.2275,.8078,1);constructor(t){super(t)}copy(){let t=new Di(this.name);return this.copyTo(t),t.endSlot=this.endSlot,t.color.setFromColor(this.color),t}},ds=class{_image;constructor(e){this._image=e}getImage(){return this._image}},ue=(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))(ue||{}),ri=(e=>(e[e.MirroredRepeat=33648]="MirroredRepeat",e[e.ClampToEdge=33071]="ClampToEdge",e[e.Repeat=10497]="Repeat",e))(ri||{}),ni=class{texture;u=0;v=0;u2=0;v2=0;width=0;height=0;degrees=0;offsetX=0;offsetY=0;originalWidth=0;originalHeight=0},Ji=class extends ds{setFilters(e,t){}setWraps(e,t){}dispose(){}},fs=class{pages=new Array;regions=new Array;constructor(e){let t=new Qi(e),s=new Array(4),i={};i.size=o=>{o.width=parseInt(s[1]),o.height=parseInt(s[2])},i.format=()=>{},i.filter=o=>{o.minFilter=P.enumValue(ue,s[1]),o.magFilter=P.enumValue(ue,s[2])},i.repeat=o=>{s[1].indexOf("x")!=-1&&(o.uWrap=10497),s[1].indexOf("y")!=-1&&(o.vWrap=10497)},i.pma=o=>{o.pma=s[1]=="true"};var r={};r.xy=o=>{o.x=parseInt(s[1]),o.y=parseInt(s[2])},r.size=o=>{o.width=parseInt(s[1]),o.height=parseInt(s[2])},r.bounds=o=>{o.x=parseInt(s[1]),o.y=parseInt(s[2]),o.width=parseInt(s[3]),o.height=parseInt(s[4])},r.offset=o=>{o.offsetX=parseInt(s[1]),o.offsetY=parseInt(s[2])},r.orig=o=>{o.originalWidth=parseInt(s[1]),o.originalHeight=parseInt(s[2])},r.offsets=o=>{o.offsetX=parseInt(s[1]),o.offsetY=parseInt(s[2]),o.originalWidth=parseInt(s[3]),o.originalHeight=parseInt(s[4])},r.rotate=o=>{let c=s[1];c=="true"?o.degrees=90:c!="false"&&(o.degrees=parseInt(c))},r.index=o=>{o.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 l=null,n=null,a=null;for(;h!==null;)if(h.trim().length==0)l=null,h=t.readLine();else if(l){let o=new us(l,h);for(;;){let c=t.readEntry(s,h=t.readLine());if(c==0)break;let d=r[s[0]];if(d)d(o);else{n||(n=[]),a||(a=[]),n.push(s[0]);let f=[];for(let m=0;m<c;m++)f.push(parseInt(s[m+1]));a.push(f)}}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 ai(h.trim());t.readEntry(s,h=t.readLine())!=0;){let o=i[s[0]];o&&o(l)}this.pages.push(l)}}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()}},Qi=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 i=1,r=s+1;;i++){let h=t.indexOf(",",r);if(h==-1)return e[i]=t.substr(r).trim(),i;if(e[i]=t.substr(r,h-r).trim(),r=h+1,i==4)return 4}}},ai=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}},us=class extends ni{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)}},Gt=class Os extends Rt{region=null;path;regionUVs=[];uvs=[];triangles=[];color=new et(1,1,1,1);width=0;height=0;hullLength=0;edges=[];parentMesh=null;sequence=null;tempColor=new et(0,0,0,0);constructor(t,s){super(t),this.path=s}updateRegion(){if(!this.region)throw new Error("Region not set.");let t=this.regionUVs;(!this.uvs||this.uvs.length!=t.length)&&(this.uvs=P.newFloatArray(t.length));let s=this.uvs,i=this.uvs.length,r=this.region.u,h=this.region.v,l=0,n=0;if(this.region instanceof us){let a=this.region,o=a.page,c=o.width,d=o.height;switch(a.degrees){case 90:r-=(a.originalHeight-a.offsetY-a.height)/c,h-=(a.originalWidth-a.offsetX-a.width)/d,l=a.originalHeight/c,n=a.originalWidth/d;for(let f=0;f<i;f+=2)s[f]=r+t[f+1]*l,s[f+1]=h+(1-t[f])*n;return;case 180:r-=(a.originalWidth-a.offsetX-a.width)/c,h-=a.offsetY/d,l=a.originalWidth/c,n=a.originalHeight/d;for(let f=0;f<i;f+=2)s[f]=r+(1-t[f])*l,s[f+1]=h+(1-t[f+1])*n;return;case 270:r-=a.offsetY/c,h-=a.offsetX/d,l=a.originalHeight/c,n=a.originalWidth/d;for(let f=0;f<i;f+=2)s[f]=r+(1-t[f+1])*l,s[f+1]=h+t[f]*n;return}r-=a.offsetX/c,h-=(a.originalHeight-a.offsetY-a.height)/d,l=a.originalWidth/c,n=a.originalHeight/d}else this.region?(l=this.region.u2-r,n=this.region.v2-h):(r=h=0,l=n=1);for(let a=0;a<i;a+=2)s[a]=r+t[a]*l,s[a+1]=h+t[a+1]*n}getParentMesh(){return this.parentMesh}setParentMesh(t){this.parentMesh=t,t&&(this.bones=t.bones,this.vertices=t.vertices,this.worldVerticesLength=t.worldVerticesLength,this.regionUVs=t.regionUVs,this.triangles=t.triangles,this.hullLength=t.hullLength,this.worldVerticesLength=t.worldVerticesLength)}copy(){if(this.parentMesh)return this.newLinkedMesh();let t=new Os(this.name,this.path);return t.region=this.region,t.color.setFromColor(this.color),this.copyTo(t),t.regionUVs=new Array(this.regionUVs.length),P.arrayCopy(this.regionUVs,0,t.regionUVs,0,this.regionUVs.length),t.uvs=this.uvs instanceof Float32Array?P.newFloatArray(this.uvs.length):new Array(this.uvs.length),P.arrayCopy(this.uvs,0,t.uvs,0,this.uvs.length),t.triangles=new Array(this.triangles.length),P.arrayCopy(this.triangles,0,t.triangles,0,this.triangles.length),t.hullLength=this.hullLength,t.sequence=this.sequence!=null?this.sequence.copy():null,this.edges&&(t.edges=new Array(this.edges.length),P.arrayCopy(this.edges,0,t.edges,0,this.edges.length)),t.width=this.width,t.height=this.height,t}computeWorldVertices(t,s,i,r,h,l){this.sequence!=null&&this.sequence.apply(t,this),super.computeWorldVertices(t,s,i,r,h,l)}newLinkedMesh(){let t=new Os(this.name,this.path);return t.region=this.region,t.color.setFromColor(this.color),t.timelineAttachment=this.timelineAttachment,t.setParentMesh(this.parentMesh?this.parentMesh:this),t.region!=null&&t.updateRegion(),t}},Ht=class Ni extends Rt{lengths=[];closed=!1;constantSpeed=!1;color=new et(1,1,1,1);constructor(t){super(t)}copy(){let t=new Ni(this.name);return this.copyTo(t),t.lengths=new Array(this.lengths.length),P.arrayCopy(this.lengths,0,t.lengths,0,this.lengths.length),t.closed=closed,t.constantSpeed=this.constantSpeed,t.color.setFromColor(this.color),t}},li=class Ui extends Rt{x=0;y=0;rotation=0;color=new et(.38,.94,0,1);constructor(t){super(t)}computeWorldPosition(t,s){return s.x=this.x*t.a+this.y*t.b+t.worldX,s.y=this.x*t.c+this.y*t.d+t.worldY,s}computeWorldRotation(t){const s=this.rotation*L.degRad,i=Math.cos(s),r=Math.sin(s),h=i*t.a+r*t.b,l=i*t.c+r*t.d;return L.atan2Deg(l,h)}copy(){let t=new Ui(this.name);return t.x=this.x,t.y=this.y,t.rotation=this.rotation,t.color.setFromColor(this.color),t}},se=class zi extends Re{x=0;y=0;scaleX=1;scaleY=1;rotation=0;width=0;height=0;color=new et(1,1,1,1);path;region=null;sequence=null;offset=P.newFloatArray(8);uvs=P.newFloatArray(8);tempColor=new et(1,1,1,1);constructor(t,s){super(t),this.path=s}updateRegion(){if(!this.region)throw new Error("Region not set.");let t=this.region,s=this.uvs;if(t==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 i=this.width/this.region.originalWidth*this.scaleX,r=this.height/this.region.originalHeight*this.scaleY,h=-this.width/2*this.scaleX+this.region.offsetX*i,l=-this.height/2*this.scaleY+this.region.offsetY*r,n=h+this.region.width*i,a=l+this.region.height*r,o=this.rotation*L.degRad,c=Math.cos(o),d=Math.sin(o),f=this.x,m=this.y,u=h*c+f,g=h*d,w=l*c+m,b=l*d,x=n*c+f,p=n*d,v=a*c+m,y=a*d,A=this.offset;A[0]=u-b,A[1]=w+g,A[2]=u-y,A[3]=v+g,A[4]=x-y,A[5]=v+p,A[6]=x-b,A[7]=w+p,t.degrees==90?(s[0]=t.u2,s[1]=t.v2,s[2]=t.u,s[3]=t.v2,s[4]=t.u,s[5]=t.v,s[6]=t.u2,s[7]=t.v):(s[0]=t.u,s[1]=t.v2,s[2]=t.u,s[3]=t.v,s[4]=t.u2,s[5]=t.v,s[6]=t.u2,s[7]=t.v2)}computeWorldVertices(t,s,i,r){this.sequence!=null&&this.sequence.apply(t,this);let h=t.bone,l=this.offset,n=h.worldX,a=h.worldY,o=h.a,c=h.b,d=h.c,f=h.d,m=0,u=0;m=l[0],u=l[1],s[i]=m*o+u*c+n,s[i+1]=m*d+u*f+a,i+=r,m=l[2],u=l[3],s[i]=m*o+u*c+n,s[i+1]=m*d+u*f+a,i+=r,m=l[4],u=l[5],s[i]=m*o+u*c+n,s[i+1]=m*d+u*f+a,i+=r,m=l[6],u=l[7],s[i]=m*o+u*c+n,s[i+1]=m*d+u*f+a}copy(){let t=new zi(this.name,this.path);return t.region=this.region,t.x=this.x,t.y=this.y,t.scaleX=this.scaleX,t.scaleY=this.scaleY,t.rotation=this.rotation,t.width=this.width,t.height=this.height,P.arrayCopy(this.uvs,0,t.uvs,0,8),P.arrayCopy(this.offset,0,t.offset,0,8),t.color.setFromColor(this.color),t.sequence=this.sequence!=null?this.sequence.copy():null,t}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},$i=class{atlas;constructor(e){this.atlas=e}loadSequence(e,t,s){let i=s.regions;for(let r=0,h=i.length;r<h;r++){let l=s.getPath(t,r),n=this.atlas.findRegion(l);if(n==null)throw new Error("Region not found in atlas: "+l+" (sequence: "+e+")");i[r]=n}}newRegionAttachment(e,t,s,i){let r=new se(t,s);if(i!=null)this.loadSequence(t,s,i);else{let h=this.atlas.findRegion(s);if(!h)throw new Error("Region not found in atlas: "+s+" (region attachment: "+t+")");r.region=h}return r}newMeshAttachment(e,t,s,i){let r=new Gt(t,s);if(i!=null)this.loadSequence(t,s,i);else{let h=this.atlas.findRegion(s);if(!h)throw new Error("Region not found in atlas: "+s+" (mesh attachment: "+t+")");r.region=h}return r}newBoundingBoxAttachment(e,t){return new cs(t)}newPathAttachment(e,t){return new Ht(t)}newPointAttachment(e,t){return new li(t)}newClippingAttachment(e,t){return new ee(t)}},ms=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 et;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}},me=(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))(me||{}),gs=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,i,r,h,l){this.ax=e,this.ay=t,this.arotation=s,this.ascaleX=i,this.ascaleY=r,this.ashearX=h,this.ashearY=l;let n=this.parent;if(!n){let f=this.skeleton;const m=f.scaleX,u=f.scaleY,g=(s+h)*L.degRad,w=(s+90+l)*L.degRad;this.a=Math.cos(g)*i*m,this.b=Math.cos(w)*r*m,this.c=Math.sin(g)*i*u,this.d=Math.sin(w)*r*u,this.worldX=e*m+f.x,this.worldY=t*u+f.y;return}let a=n.a,o=n.b,c=n.c,d=n.d;switch(this.worldX=a*e+o*t+n.worldX,this.worldY=c*e+d*t+n.worldY,this.inherit){case 0:{const f=(s+h)*L.degRad,m=(s+90+l)*L.degRad,u=Math.cos(f)*i,g=Math.cos(m)*r,w=Math.sin(f)*i,b=Math.sin(m)*r;this.a=a*u+o*w,this.b=a*g+o*b,this.c=c*u+d*w,this.d=c*g+d*b;return}case 1:{const f=(s+h)*L.degRad,m=(s+90+l)*L.degRad;this.a=Math.cos(f)*i,this.b=Math.cos(m)*r,this.c=Math.sin(f)*i,this.d=Math.sin(m)*r;break}case 2:{let f=1/this.skeleton.scaleX,m=1/this.skeleton.scaleY;a*=f,c*=m;let u=a*a+c*c,g=0;u>1e-4?(u=Math.abs(a*d*m-o*f*c)/u,o=c*u,d=a*u,g=Math.atan2(c,a)*L.radDeg):(a=0,c=0,g=90-Math.atan2(d,o)*L.radDeg);const w=(s+h-g)*L.degRad,b=(s+l-g+90)*L.degRad,x=Math.cos(w)*i,p=Math.cos(b)*r,v=Math.sin(w)*i,y=Math.sin(b)*r;this.a=a*x-o*v,this.b=a*p-o*y,this.c=c*x+d*v,this.d=c*p+d*y;break}case 3:case 4:{s*=L.degRad;const f=Math.cos(s),m=Math.sin(s);let u=(a*f+o*m)/this.skeleton.scaleX,g=(c*f+d*m)/this.skeleton.scaleY,w=Math.sqrt(u*u+g*g);w>1e-5&&(w=1/w),u*=w,g*=w,w=Math.sqrt(u*u+g*g),this.inherit==3&&a*d-o*c<0!=(this.skeleton.scaleX<0!=this.skeleton.scaleY<0)&&(w=-w),s=Math.PI/2+Math.atan2(g,u);const b=Math.cos(s)*w,x=Math.sin(s)*w;h*=L.degRad,l=(90+l)*L.degRad;const p=Math.cos(h)*i,v=Math.cos(l)*r,y=Math.sin(h)*i,A=Math.sin(l)*r;this.a=u*p+b*y,this.b=u*v+b*A,this.c=g*p+x*y,this.d=g*v+x*A;break}}this.a*=this.skeleton.scaleX,this.b*=this.skeleton.scaleX,this.c*=this.skeleton.scaleY,this.d*=this.skeleton.scaleY}setToSetupPose(){let e=this.data;this.x=e.x,this.y=e.y,this.rotation=e.rotation,this.scaleX=e.scaleX,this.scaleY=e.scaleY,this.shearX=e.shearX,this.shearY=e.shearY,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)*L.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)*L.radDeg;return}let t=e.a,s=e.b,i=e.c,r=e.d,h=1/(t*r-s*i),l=r*h,n=s*h,a=i*h,o=t*h,c=this.worldX-e.worldX,d=this.worldY-e.worldY;this.ax=c*l-d*n,this.ay=d*o-c*a;let f,m,u,g;if(this.inherit==1)f=this.a,m=this.b,u=this.c,g=this.d;else{switch(this.inherit){case 2:{let v=Math.abs(t*r-s*i)/(t*t+i*i);s=-i*this.skeleton.scaleX*v/this.skeleton.scaleY,r=t*this.skeleton.scaleY*v/this.skeleton.scaleX,h=1/(t*r-s*i),l=r*h,n=s*h;break}case 3:case 4:let w=L.cosDeg(this.rotation),b=L.sinDeg(this.rotation);t=(t*w+s*b)/this.skeleton.scaleX,i=(i*w+r*b)/this.skeleton.scaleY;let x=Math.sqrt(t*t+i*i);x>1e-5&&(x=1/x),t*=x,i*=x,x=Math.sqrt(t*t+i*i),this.inherit==3&&h<0!=(this.skeleton.scaleX<0!=this.skeleton.scaleY<0)&&(x=-x);let p=L.PI/2+Math.atan2(i,t);s=Math.cos(p)*x,r=Math.sin(p)*x,h=1/(t*r-s*i),l=r*h,n=s*h,a=i*h,o=t*h}f=l*this.a-n*this.c,m=l*this.b-n*this.d,u=o*this.c-a*this.a,g=o*this.d-a*this.b}if(this.ashearX=0,this.ascaleX=Math.sqrt(f*f+u*u),this.ascaleX>1e-4){let w=f*g-m*u;this.ascaleY=w/this.ascaleX,this.ashearY=-Math.atan2(f*m+u*g,w)*L.radDeg,this.arotation=Math.atan2(u,f)*L.radDeg}else this.ascaleX=0,this.ascaleY=Math.sqrt(m*m+g*g),this.ashearY=0,this.arotation=90-Math.atan2(g,m)*L.radDeg}getWorldRotationX(){return Math.atan2(this.c,this.a)*L.radDeg}getWorldRotationY(){return Math.atan2(this.d,this.b)*L.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,i=e.y-this.worldY;return e.x=s*this.d*t-i*this.b*t,e.y=i*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=L.sinDeg(e),s=L.cosDeg(e);return Math.atan2(this.a*t-this.c*s,this.d*s-this.b*t)*L.radDeg+this.rotation-this.shearX}localToWorldRotation(e){e-=this.rotation-this.shearX;let t=L.sinDeg(e),s=L.cosDeg(e);return Math.atan2(s*this.c+t*this.d,s*this.a+t*this.b)*L.radDeg}rotateWorld(e){e*=L.degRad;const t=Math.sin(e),s=Math.cos(e),i=this.a,r=this.b;this.a=s*i-t*this.c,this.b=s*r-t*this.d,this.c=t*i+s*this.c,this.d=t*r+s*this.d}},ie=class{constructor(e,t,s){this.name=e,this.order=t,this.skinRequired=s}},oi=class{pathPrefix="";textureLoader;downloader;cache;errors={};toLoad=0;loaded=0;constructor(e,t="",s=new xs,i=new hi){this.textureLoader=e,this.pathPrefix=t,this.downloader=s,this.cache=i}start(e){return this.toLoad++,this.pathPrefix+e}success(e,t,s){this.toLoad--,this.loaded++,this.cache.assets[t]=s,this.cache.assetsRefCount[t]=(this.cache.assetsRefCount[t]||0)+1,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 i=()=>{if(this.isLoadingComplete()){this.hasErrors()?s(this.errors):t(this);return}requestAnimationFrame(i)};requestAnimationFrame(i)})}setRawDataURI(e,t){this.downloader.rawDataUris[this.pathPrefix+e]=t}loadBinary(e,t=()=>{},s=()=>{}){e=this.start(e),!this.reuseAssets(e,t,s)&&(this.cache.assetsLoaded[e]=new Promise((i,r)=>{this.downloader.downloadBinary(e,h=>{this.success(t,e,h),i(h)},(h,l)=>{const n=`Couldn't load binary ${e}: status ${h}, ${l}`;this.error(s,e,n),r(n)})}))}loadText(e,t=()=>{},s=()=>{}){e=this.start(e),this.downloader.downloadText(e,i=>{this.success(t,e,i)},(i,r)=>{this.error(s,e,`Couldn't load text ${e}: status ${i}, ${r}`)})}loadJson(e,t=()=>{},s=()=>{}){e=this.start(e),!this.reuseAssets(e,t,s)&&(this.cache.assetsLoaded[e]=new Promise((i,r)=>{this.downloader.downloadJson(e,h=>{this.success(t,e,h),i(h)},(h,l)=>{const n=`Couldn't load JSON ${e}: status ${h}, ${l}`;this.error(s,e,n),r(n)})}))}reuseAssets(e,t=()=>{},s=()=>{}){const i=this.cache.assetsLoaded[e],r=i!==void 0;return r&&(this.cache.assetsLoaded[e]=i.then(h=>(h=h instanceof Image||h instanceof ImageBitmap?this.textureLoader(h):h,this.success(t,e,h),h)).catch(h=>this.error(s,e,h))),r}loadTexture(e,t=()=>{},s=()=>{}){e=this.start(e),!this.reuseAssets(e,t,s)&&(this.cache.assetsLoaded[e]=new Promise((i,r)=>{if(!!!(typeof window<"u"&&typeof navigator<"u"&&window.document))fetch(e,{mode:"cors"}).then(n=>{if(n.ok)return n.blob();const a=`Couldn't load image: ${e}`;this.error(s,e,`Couldn't load image: ${e}`),r(a)}).then(n=>n?createImageBitmap(n,{premultiplyAlpha:"none",colorSpaceConversion:"none"}):null).then(n=>{if(n){const a=this.createTexture(e,n);this.success(t,e,a),i(a)}});else{let n=new Image;n.crossOrigin="anonymous",n.onload=()=>{const a=this.createTexture(e,n);this.success(t,e,a),i(a)},n.onerror=()=>{const a=`Couldn't load image: ${e}`;this.error(s,e,a),r(a)},this.downloader.rawDataUris[e]&&(e=this.downloader.rawDataUris[e]),n.src=e}}))}loadTextureAtlas(e,t=()=>{},s=()=>{},i){let r=e.lastIndexOf("/"),h=r>=0?e.substring(0,r+1):"";e=this.start(e),!this.reuseAssets(e,t,s)&&(this.cache.assetsLoaded[e]=new Promise((l,n)=>{this.downloader.downloadText(e,a=>{try{const o=this.createTextureAtlas(e,a);let c=o.pages.length,d=!1;for(let f of o.pages)this.loadTexture(i?i[f.name]:h+f.name,(m,u)=>{d||(f.setTexture(u),--c==0&&(this.success(t,e,o),l(o)))},(m,u)=>{if(!d){const g=`Couldn't load texture ${e} page image: ${m}`;this.error(s,e,g),n(g)}d=!0})}catch(o){const c=`Couldn't parse texture atlas ${e}: ${o.message}`;this.error(s,e,c),n(c)}},(a,o)=>{const c=`Couldn't load texture atlas ${e}: status ${a}, ${o}`;this.error(s,e,c),n(c)})}))}loadTextureAtlasButNoTextures(e,t=()=>{},s=()=>{},i){e=this.start(e),!this.reuseAssets(e,t,s)&&(this.cache.assetsLoaded[e]=new Promise((r,h)=>{this.downloader.downloadText(e,l=>{try{const n=this.createTextureAtlas(e,l);this.success(t,e,n),r(n)}catch(n){const a=`Couldn't parse texture atlas ${e}: ${n.message}`;this.error(s,e,a),h(a)}},(l,n)=>{const a=`Couldn't load texture atlas ${e}: status ${l}, ${n}`;this.error(s,e,a),h(a)})}))}async loadBinaryAsync(e){return new Promise((t,s)=>{this.loadBinary(e,(i,r)=>t(r),(i,r)=>s(r))})}async loadJsonAsync(e){return new Promise((t,s)=>{this.loadJson(e,(i,r)=>t(r),(i,r)=>s(r))})}async loadTextureAsync(e){return new Promise((t,s)=>{this.loadTexture(e,(i,r)=>t(r),(i,r)=>s(r))})}async loadTextureAtlasAsync(e){return new Promise((t,s)=>{this.loadTextureAtlas(e,(i,r)=>t(r),(i,r)=>s(r))})}async loadTextureAtlasButNoTexturesAsync(e){return new Promise((t,s)=>{this.loadTextureAtlasButNoTextures(e,(i,r)=>t(r),(i,r)=>s(r))})}setCache(e){this.cache=e}get(e){return this.cache.assets[this.pathPrefix+e]}require(e){e=this.pathPrefix+e;let t=this.cache.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.cache.assets[e];return t.dispose&&t.dispose(),delete this.cache.assets[e],delete this.cache.assetsRefCount[e],delete this.cache.assetsLoaded[e],t}removeAll(){for(let e in this.cache.assets){let t=this.cache.assets[e];t.dispose&&t.dispose()}this.cache.assets={},this.cache.assetsLoaded={},this.cache.assetsRefCount={}}isLoadingComplete(){return this.toLoad==0}getToLoad(){return this.toLoad}getLoaded(){return this.loaded}dispose(){this.removeAll()}disposeAsset(e){const t=this.cache.assets[e];if(t instanceof fs){t.dispose();return}this.disposeAssetInternal(e)}hasErrors(){return Object.keys(this.errors).length>0}getErrors(){return this.errors}disposeAssetInternal(e){if(this.cache.assetsRefCount[e]>0&&--this.cache.assetsRefCount[e]===0)return this.remove(e)}createTextureAtlas(e,t){const s=new fs(t);return s.dispose=()=>{if(!(this.cache.assetsRefCount[e]<=0)){this.disposeAssetInternal(e);for(const i of s.pages)i.texture?.dispose()}},s}createTexture(e,t){const s=this.textureLoader(t),i=s.dispose.bind(s);return s.dispose=()=>{this.disposeAssetInternal(e)&&i()},s}},hi=class Se{assets={};assetsRefCount={};assetsLoaded={};static AVAILABLE_CACHES=new Map;static getCache(t){const s=Se.AVAILABLE_CACHES.get(t);if(s)return s;const i=new Se;return Se.AVAILABLE_CACHES.set(t,i),i}async addAsset(t,s){this.assetsLoaded[t]=Promise.resolve(s),this.assets[t]=await s}},xs=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,i=new Uint8Array(s),r=0;r<s;r++)i[r]=t.charCodeAt(r);return i}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;const i=this.rawDataUris[e];if(i&&!i.includes(".")){try{this.finish(e,200,this.dataUriToString(i))}catch(l){this.finish(e,400,JSON.stringify(l))}return}let r=new XMLHttpRequest;r.overrideMimeType("text/html"),r.open("GET",i||e,!0);let h=()=>{this.finish(e,r.status,r.responseText)};r.onload=h,r.onerror=h,r.send()}downloadJson(e,t,s){this.downloadText(e,i=>{t(JSON.parse(i))},s)}downloadBinary(e,t,s){if(this.start(e,t,s))return;const i=this.rawDataUris[e];if(i&&!i.includes(".")){try{this.finish(e,200,this.dataUriToUint8Array(i))}catch(l){this.finish(e,400,JSON.stringify(l))}return}let r=new XMLHttpRequest;r.open("GET",i||e,!0),r.responseType="arraybuffer";let h=()=>{this.finish(e,r.status,r.response)};r.onload=()=>{r.status==200||r.status==0?this.finish(e,200,new Uint8Array(r.response)):h()},r.onerror=h,r.send()}start(e,t,s){let i=this.callbacks[e];try{if(i)return!0;this.callbacks[e]=i=[]}finally{i.push(t,s)}}finish(e,t,s){let i=this.callbacks[e];delete this.callbacks[e];let r=t==200||t==0?[s]:[t,s];for(let h=r.length-1,l=i.length;h<l;h+=2)i[h].apply(null,r)}},ps=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}},ws=class{name;intValue=0;floatValue=0;stringValue=null;audioPath=null;volume=0;balance=0;constructor(e){this.name=e}},ci=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 i=0;i<e.bones.length;i++){let r=t.findBone(e.bones[i].name);if(!r)throw new Error(`Couldn't find bone ${e.bones[i].name}`);this.bones.push(r)}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,i,r,h,l){let n=e.parent;if(!n)throw new Error("IK bone must have parent.");let a=n.a,o=n.b,c=n.c,d=n.d,f=-e.ashearX-e.arotation,m=0,u=0;switch(e.inherit){case 1:m=(t-e.worldX)*L.signum(e.skeleton.scaleX),u=(s-e.worldY)*L.signum(e.skeleton.scaleY);break;case 2:let b=Math.abs(a*d-o*c)/Math.max(1e-4,a*a+c*c),x=a/e.skeleton.scaleX,p=c/e.skeleton.scaleY;o=-p*b*e.skeleton.scaleX,d=x*b*e.skeleton.scaleY,f+=Math.atan2(p,x)*L.radDeg;default:let v=t-n.worldX,y=s-n.worldY,A=a*d-o*c;Math.abs(A)<=1e-4?(m=0,u=0):(m=(v*d-y*o)/A-e.ax,u=(y*a-v*c)/A-e.ay)}f+=Math.atan2(u,m)*L.radDeg,e.ascaleX<0&&(f+=180),f>180?f-=360:f<-180&&(f+=360);let g=e.ascaleX,w=e.ascaleY;if(i||r){switch(e.inherit){case 3:case 4:m=t-e.worldX,u=s-e.worldY}const b=e.data.length*g;if(b>1e-4){const x=m*m+u*u;if(i&&x<b*b||r&&x>b*b){const p=(Math.sqrt(x)/b-1)*l+1;g*=p,h&&(w*=p)}}}e.updateWorldTransformWith(e.ax,e.ay,e.arotation+f*l,g,w,e.ashearX,e.ashearY)}apply2(e,t,s,i,r,h,l,n,a){if(e.inherit!=0||t.inherit!=0)return;let o=e.ax,c=e.ay,d=e.ascaleX,f=e.ascaleY,m=d,u=f,g=t.ascaleX,w=0,b=0,x=0;d<0?(d=-d,w=180,x=-1):(w=0,x=1),f<0&&(f=-f,x=-x),g<0?(g=-g,b=180):b=0;let p=t.ax,v=0,y=0,A=0,C=e.a,S=e.b,T=e.c,R=e.d,k=Math.abs(d-f)<=1e-4;!k||h?(v=0,y=C*p+e.worldX,A=T*p+e.worldY):(v=t.ay,y=C*p+S*v+e.worldX,A=T*p+R*v+e.worldY);let F=e.parent;if(!F)throw new Error("IK parent must itself have a parent.");C=F.a,S=F.b,T=F.c,R=F.d;let X=C*R-S*T,E=y-F.worldX,Y=A-F.worldY;X=Math.abs(X)<=1e-4?0:1/X;let B=(E*R-Y*S)*X-o,st=(Y*C-E*T)*X-c,tt=Math.sqrt(B*B+st*st),it=t.data.length*g,ct,lt;if(tt<1e-4){this.apply1(e,s,i,!1,h,!1,a),t.updateWorldTransformWith(p,v,0,t.ascaleX,t.ascaleY,t.ashearX,t.ashearY);return}E=s-F.worldX,Y=i-F.worldY;let ut=(E*R-Y*S)*X-o,W=(Y*C-E*T)*X-c,nt=ut*ut+W*W;if(n!=0){n*=d*(g+1)*.5;let mt=Math.sqrt(nt),gt=mt-tt-it*d+n;if(gt>0){let xt=Math.min(1,gt/(n*2))-1;xt=(gt-n*(1-xt*xt))/mt,ut-=xt*ut,W-=xt*W,nt=ut*ut+W*W}}t:if(k){it*=d;let mt=(nt-tt*tt-it*it)/(2*tt*it);mt<-1?(mt=-1,lt=Math.PI*r):mt>1?(mt=1,lt=0,h&&(C=(Math.sqrt(nt)/(tt+it)-1)*a+1,m*=C,l&&(u*=C))):lt=Math.acos(mt)*r,C=tt+it*mt,S=it*Math.sin(lt),ct=Math.atan2(W*C-ut*S,ut*C+W*S)}else{C=d*it,S=f*it;let mt=C*C,gt=S*S,xt=Math.atan2(W,ut);T=gt*tt*tt+mt*nt-mt*gt;let Ct=-2*gt*tt,zt=gt-mt;if(R=Ct*Ct-4*zt*T,R>=0){let Wt=Math.sqrt(R);Ct<0&&(Wt=-Wt),Wt=-(Ct+Wt)*.5;let Qt=Wt/zt,Gs=T/Wt,le=Math.abs(Qt)<Math.abs(Gs)?Qt:Gs;if(Qt=nt-le*le,Qt>=0){Y=Math.sqrt(Qt)*r,ct=xt-Math.atan2(Y,le),lt=Math.atan2(Y/f,(le-tt)/d);break t}}let Jt=L.PI,ne=tt-C,Te=ne*ne,zs=0,Ws=0,ae=tt+C,Me=ae*ae,qs=0;T=-C*tt/(mt-gt),T>=-1&&T<=1&&(T=Math.acos(T),E=C*Math.cos(T)+tt,Y=S*Math.sin(T),R=E*E+Y*Y,R<Te&&(Jt=T,Te=R,ne=E,zs=Y),R>Me&&(Ws=T,Me=R,ae=E,qs=Y)),nt<=(Te+Me)*.5?(ct=xt-Math.atan2(zs*r,ne),lt=Jt*r):(ct=xt-Math.atan2(qs*r,ae),lt=Ws*r)}let ht=Math.atan2(v,p)*x,bt=e.arotation;ct=(ct-ht)*L.radDeg+w-bt,ct>180?ct-=360:ct<-180&&(ct+=360),e.updateWorldTransformWith(o,c,bt+ct*a,m,u,0,0),bt=t.arotation,lt=((lt+ht)*L.radDeg-t.ashearX)*x+b-bt,lt>180?lt-=360:lt<-180&&(lt+=360),t.updateWorldTransformWith(p,v,bt+lt*a,t.ascaleX,t.ascaleY,t.ashearX,t.ashearY)}},bs=class extends ie{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)}},vs=class extends ie{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=0;spacingMode=1;rotateMode=1;offsetRotation=0;position=0;spacing=0;mixRotate=0;mixX=0;mixY=0;constructor(e){super(e,0,!1)}},ys=(e=>(e[e.Fixed=0]="Fixed",e[e.Percent=1]="Percent",e))(ys||{}),As=(e=>(e[e.Length=0]="Length",e[e.Fixed=1]="Fixed",e[e.Percent=2]="Percent",e[e.Proportional=3]="Proportional",e))(As||{}),Cs=(e=>(e[e.Tangent=0]="Tangent",e[e.Chain=1]="Chain",e[e.ChainScale=2]="ChainScale",e))(Cs||{}),di=class Bt{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(t,s){if(!t)throw new Error("data cannot be null.");if(!s)throw new Error("skeleton cannot be null.");this.data=t,this.bones=new Array;for(let r=0,h=t.bones.length;r<h;r++){let l=s.findBone(t.bones[r].name);if(!l)throw new Error(`Couldn't find bone ${t.bones[r].name}.`);this.bones.push(l)}let i=s.findSlot(t.target.name);if(!i)throw new Error(`Couldn't find target bone ${t.target.name}`);this.target=i,this.position=t.position,this.spacing=t.spacing,this.mixRotate=t.mixRotate,this.mixX=t.mixX,this.mixY=t.mixY}isActive(){return this.active}setToSetupPose(){const t=this.data;this.position=t.position,this.spacing=t.spacing,this.mixRotate=t.mixRotate,this.mixX=t.mixX,this.mixY=t.mixY}update(t){let s=this.target.getAttachment();if(!(s instanceof Ht))return;let i=this.mixRotate,r=this.mixX,h=this.mixY;if(i==0&&r==0&&h==0)return;let l=this.data,n=l.rotateMode==0,a=l.rotateMode==2,o=this.bones,c=o.length,d=n?c:c+1,f=P.setArraySize(this.spaces,d),m=a?this.lengths=P.setArraySize(this.lengths,c):[],u=this.spacing;switch(l.spacingMode){case 2:if(a)for(let A=0,C=d-1;A<C;A++){let S=o[A],T=S.data.length,R=T*S.a,k=T*S.c;m[A]=Math.sqrt(R*R+k*k)}P.arrayFill(f,1,d,u);break;case 3:let v=0;for(let A=0,C=d-1;A<C;){let S=o[A],T=S.data.length;if(T<Bt.epsilon)a&&(m[A]=0),f[++A]=u;else{let R=T*S.a,k=T*S.c,F=Math.sqrt(R*R+k*k);a&&(m[A]=F),f[++A]=F,v+=F}}if(v>0){v=d/v*u;for(let A=1;A<d;A++)f[A]*=v}break;default:let y=l.spacingMode==0;for(let A=0,C=d-1;A<C;){let S=o[A],T=S.data.length;if(T<Bt.epsilon)a&&(m[A]=0),f[++A]=u;else{let R=T*S.a,k=T*S.c,F=Math.sqrt(R*R+k*k);a&&(m[A]=F),f[++A]=(y?T+u:u)*F/T}}}let g=this.computeWorldPositions(s,d,n),w=g[0],b=g[1],x=l.offsetRotation,p=!1;if(x==0)p=l.rotateMode==1;else{p=!1;let v=this.target.bone;x*=v.a*v.d-v.b*v.c>0?L.degRad:-L.degRad}for(let v=0,y=3;v<c;v++,y+=3){let A=o[v];A.worldX+=(w-A.worldX)*r,A.worldY+=(b-A.worldY)*h;let C=g[y],S=g[y+1],T=C-w,R=S-b;if(a){let k=m[v];if(k!=0){let F=(Math.sqrt(T*T+R*R)/k-1)*i+1;A.a*=F,A.c*=F}}if(w=C,b=S,i>0){let k=A.a,F=A.b,X=A.c,E=A.d,Y=0,B=0,st=0;if(n?Y=g[y-1]:f[v+1]==0?Y=g[y+2]:Y=Math.atan2(R,T),Y-=Math.atan2(X,k),p){B=Math.cos(Y),st=Math.sin(Y);let tt=A.data.length;w+=(tt*(B*k-st*X)-T)*i,b+=(tt*(st*k+B*X)-R)*i}else Y+=x;Y>L.PI?Y-=L.PI2:Y<-L.PI&&(Y+=L.PI2),Y*=i,B=Math.cos(Y),st=Math.sin(Y),A.a=B*k-st*X,A.b=B*F-st*E,A.c=st*k+B*X,A.d=st*F+B*E}A.updateAppliedTransform()}}computeWorldPositions(t,s,i){let r=this.target,h=this.position,l=this.spaces,n=P.setArraySize(this.positions,s*3+2),a=this.world,o=t.closed,c=t.worldVerticesLength,d=c/6,f=Bt.NONE;if(!t.constantSpeed){let tt=t.lengths;d-=o?1:2;let it=tt[d];this.data.positionMode==1&&(h*=it);let ct;switch(this.data.spacingMode){case 2:ct=it;break;case 3:ct=it/s;break;default:ct=1}a=P.setArraySize(this.world,8);for(let lt=0,ut=0,W=0;lt<s;lt++,ut+=3){let nt=l[lt]*ct;h+=nt;let ht=h;if(o)ht%=it,ht<0&&(ht+=it),W=0;else if(ht<0){f!=Bt.BEFORE&&(f=Bt.BEFORE,t.computeWorldVertices(r,2,4,a,0,2)),this.addBeforePosition(ht,a,0,n,ut);continue}else if(ht>it){f!=Bt.AFTER&&(f=Bt.AFTER,t.computeWorldVertices(r,c-6,4,a,0,2)),this.addAfterPosition(ht-it,a,0,n,ut);continue}for(;;W++){let bt=tt[W];if(!(ht>bt)){if(W==0)ht/=bt;else{let mt=tt[W-1];ht=(ht-mt)/(bt-mt)}break}}W!=f&&(f=W,o&&W==d?(t.computeWorldVertices(r,c-4,4,a,0,2),t.computeWorldVertices(r,0,4,a,4,2)):t.computeWorldVertices(r,W*6+2,8,a,0,2)),this.addCurvePosition(ht,a[0],a[1],a[2],a[3],a[4],a[5],a[6],a[7],n,ut,i||lt>0&&nt==0)}return n}o?(c+=2,a=P.setArraySize(this.world,c),t.computeWorldVertices(r,2,c-4,a,0,2),t.computeWorldVertices(r,0,2,a,c-4,2),a[c-2]=a[0],a[c-1]=a[1]):(d--,c-=4,a=P.setArraySize(this.world,c),t.computeWorldVertices(r,2,c,a,0,2));let m=P.setArraySize(this.curves,d),u=0,g=a[0],w=a[1],b=0,x=0,p=0,v=0,y=0,A=0,C=0,S=0,T=0,R=0,k=0,F=0,X=0,E=0;for(let tt=0,it=2;tt<d;tt++,it+=6)b=a[it],x=a[it+1],p=a[it+2],v=a[it+3],y=a[it+4],A=a[it+5],C=(g-b*2+p)*.1875,S=(w-x*2+v)*.1875,T=((b-p)*3-g+y)*.09375,R=((x-v)*3-w+A)*.09375,k=C*2+T,F=S*2+R,X=(b-g)*.75+C+T*.16666667,E=(x-w)*.75+S+R*.16666667,u+=Math.sqrt(X*X+E*E),X+=k,E+=F,k+=T,F+=R,u+=Math.sqrt(X*X+E*E),X+=k,E+=F,u+=Math.sqrt(X*X+E*E),X+=k+T,E+=F+R,u+=Math.sqrt(X*X+E*E),m[tt]=u,g=y,w=A;this.data.positionMode==1&&(h*=u);let Y;switch(this.data.spacingMode){case 2:Y=u;break;case 3:Y=u/s;break;default:Y=1}let B=this.segments,st=0;for(let tt=0,it=0,ct=0,lt=0;tt<s;tt++,it+=3){let ut=l[tt]*Y;h+=ut;let W=h;if(o)W%=u,W<0&&(W+=u),ct=0;else if(W<0){this.addBeforePosition(W,a,0,n,it);continue}else if(W>u){this.addAfterPosition(W-u,a,c-4,n,it);continue}for(;;ct++){let nt=m[ct];if(!(W>nt)){if(ct==0)W/=nt;else{let ht=m[ct-1];W=(W-ht)/(nt-ht)}break}}if(ct!=f){f=ct;let nt=ct*6;for(g=a[nt],w=a[nt+1],b=a[nt+2],x=a[nt+3],p=a[nt+4],v=a[nt+5],y=a[nt+6],A=a[nt+7],C=(g-b*2+p)*.03,S=(w-x*2+v)*.03,T=((b-p)*3-g+y)*.006,R=((x-v)*3-w+A)*.006,k=C*2+T,F=S*2+R,X=(b-g)*.3+C+T*.16666667,E=(x-w)*.3+S+R*.16666667,st=Math.sqrt(X*X+E*E),B[0]=st,nt=1;nt<8;nt++)X+=k,E+=F,k+=T,F+=R,st+=Math.sqrt(X*X+E*E),B[nt]=st;X+=k,E+=F,st+=Math.sqrt(X*X+E*E),B[8]=st,X+=k+T,E+=F+R,st+=Math.sqrt(X*X+E*E),B[9]=st,lt=0}for(W*=st;;lt++){let nt=B[lt];if(!(W>nt)){if(lt==0)W/=nt;else{let ht=B[lt-1];W=lt+(W-ht)/(nt-ht)}break}}this.addCurvePosition(W*.1,g,w,b,x,p,v,y,A,n,it,i||tt>0&&ut==0)}return n}addBeforePosition(t,s,i,r,h){let l=s[i],n=s[i+1],a=s[i+2]-l,o=s[i+3]-n,c=Math.atan2(o,a);r[h]=l+t*Math.cos(c),r[h+1]=n+t*Math.sin(c),r[h+2]=c}addAfterPosition(t,s,i,r,h){let l=s[i+2],n=s[i+3],a=l-s[i],o=n-s[i+1],c=Math.atan2(o,a);r[h]=l+t*Math.cos(c),r[h+1]=n+t*Math.sin(c),r[h+2]=c}addCurvePosition(t,s,i,r,h,l,n,a,o,c,d,f){if(t==0||isNaN(t)){c[d]=s,c[d+1]=i,c[d+2]=Math.atan2(h-i,r-s);return}let m=t*t,u=m*t,g=1-t,w=g*g,b=w*g,x=g*t,p=x*3,v=g*p,y=p*t,A=s*b+r*v+l*y+a*u,C=i*b+h*v+n*y+o*u;c[d]=A,c[d+1]=C,f&&(t<.001?c[d+2]=Math.atan2(h-i,r-s):c[d+2]=Math.atan2(C-(i*w+h*x*2+n*m),A-(s*w+r*x*2+l*m)))}},tr=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,i=this.data.y>0,r=this.data.rotate>0||this.data.shearX>0,h=this.data.scaleX>0,l=this.bone,n=l.data.length;switch(e){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,d=l.worldY;if(this._reset)this._reset=!1,this.ux=c,this.uy=d;else{let f=this.remaining,m=this.inertia,u=this.data.step,g=this.skeleton.data.referenceScale,w=-1,b=this.data.limit*o,x=b*Math.abs(a.scaleY);if(b*=Math.abs(a.scaleX),s||i){if(s){const p=(this.ux-c)*m;this.xOffset+=p>b?b:p<-b?-b:p,this.ux=c}if(i){const p=(this.uy-d)*m;this.yOffset+=p>x?x:p<-x?-x:p,this.uy=d}if(f>=u){w=Math.pow(this.damping,60*u);const p=this.massInverse*u,v=this.strength,y=this.wind*g*a.scaleX,A=this.gravity*g*a.scaleY;do s&&(this.xVelocity+=(y-this.xOffset*v)*p,this.xOffset+=this.xVelocity*u,this.xVelocity*=w),i&&(this.yVelocity-=(A+this.yOffset*v)*p,this.yOffset+=this.yVelocity*u,this.yVelocity*=w),f-=u;while(f>=u)}s&&(l.worldX+=this.xOffset*t*this.data.x),i&&(l.worldY+=this.yOffset*t*this.data.y)}if(r||h){let p=Math.atan2(l.c,l.a),v=0,y=0,A=0,C=this.cx-l.worldX,S=this.cy-l.worldY;if(C>b?C=b:C<-b&&(C=-b),S>x?S=x:S<-x&&(S=-x),r){A=(this.data.rotate+this.data.shearX)*t;let T=Math.atan2(S+this.ty,C+this.tx)-p-this.rotateOffset*A;this.rotateOffset+=(T-Math.ceil(T*L.invPI2-.5)*L.PI2)*m,T=this.rotateOffset*A+p,v=Math.cos(T),y=Math.sin(T),h&&(T=n*l.getWorldScaleX(),T>0&&(this.scaleOffset+=(C*v+S*y)*m/T))}else{v=Math.cos(p),y=Math.sin(p);const T=n*l.getWorldScaleX();T>0&&(this.scaleOffset+=(C*v+S*y)*m/T)}if(f=this.remaining,f>=u){w==-1&&(w=Math.pow(this.damping,60*u));const T=this.massInverse*u,R=this.strength,k=this.wind,F=mi.yDown?-this.gravity:this.gravity,X=n/g;for(;;)if(f-=u,h&&(this.scaleVelocity+=(k*v-F*y-this.scaleOffset*R)*T,this.scaleOffset+=this.scaleVelocity*u,this.scaleVelocity*=w),r){if(this.rotateVelocity-=((k*y+F*v)*X+this.rotateOffset*R)*T,this.rotateOffset+=this.rotateVelocity*u,this.rotateVelocity*=w,f<u)break;const E=this.rotateOffset*A+p;v=Math.cos(E),y=Math.sin(E)}else if(f<u)break}}this.remaining=f}this.cx=l.worldX,this.cy=l.worldY;break;case 3:s&&(l.worldX+=this.xOffset*t*this.data.x),i&&(l.worldY+=this.yOffset*t*this.data.y)}if(r){let a=this.rotateOffset*t,o=0,c=0,d=0;if(this.data.shearX>0){let f=0;this.data.rotate>0&&(f=a*this.data.rotate,o=Math.sin(f),c=Math.cos(f),d=l.b,l.b=c*d-o*l.d,l.d=o*d+c*l.d),f+=a*this.data.shearX,o=Math.sin(f),c=Math.cos(f),d=l.a,l.a=c*d-o*l.c,l.c=o*d+c*l.c}else a*=this.data.rotate,o=Math.sin(a),c=Math.cos(a),d=l.a,l.a=c*d-o*l.c,l.c=o*d+c*l.c,d=l.b,l.b=c*d-o*l.d,l.d=o*d+c*l.d}if(h){const a=1+this.scaleOffset*t*this.data.scaleX;l.a*=a,l.c*=a}e!=3&&(this.tx=n*l.a,this.ty=n*l.c),l.updateAppliedTransform()}translate(e,t){this.ux-=e,this.uy-=t,this.cx-=e,this.cy-=t}rotate(e,t,s){const i=s*L.degRad,r=Math.cos(i),h=Math.sin(i),l=this.cx-e,n=this.cy-t;this.translate(l*r-n*h-l,l*h+n*r-n)}},fi=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 et,this.darkColor=e.darkColor?new et:null,this.setToSetupPose()}getSkeleton(){return this.bone.skeleton}getAttachment(){return this.attachment}setAttachment(e){this.attachment!=e&&((!(e instanceof Rt)||!(this.attachment instanceof Rt)||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}},ui=class{data;bones;target;mixRotate=0;mixX=0;mixY=0;mixScaleX=0;mixScaleY=0;mixShearY=0;temp=new Vt;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 i=0;i<e.bones.length;i++){let r=t.findBone(e.bones[i].name);if(!r)throw new Error(`Couldn't find bone ${e.bones[i].name}.`);this.bones.push(r)}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,i=this.mixScaleX,r=this.mixScaleY,h=this.mixShearY,l=t!=0||s!=0,n=this.target,a=n.a,o=n.b,c=n.c,d=n.d,f=a*d-o*c>0?L.degRad:-L.degRad,m=this.data.offsetRotation*f,u=this.data.offsetShearY*f,g=this.bones;for(let w=0,b=g.length;w<b;w++){let x=g[w];if(e!=0){let p=x.a,v=x.b,y=x.c,A=x.d,C=Math.atan2(c,a)-Math.atan2(y,p)+m;C>L.PI?C-=L.PI2:C<-L.PI&&(C+=L.PI2),C*=e;let S=Math.cos(C),T=Math.sin(C);x.a=S*p-T*y,x.b=S*v-T*A,x.c=T*p+S*y,x.d=T*v+S*A}if(l){let p=this.temp;n.localToWorld(p.set(this.data.offsetX,this.data.offsetY)),x.worldX+=(p.x-x.worldX)*t,x.worldY+=(p.y-x.worldY)*s}if(i!=0){let p=Math.sqrt(x.a*x.a+x.c*x.c);p!=0&&(p=(p+(Math.sqrt(a*a+c*c)-p+this.data.offsetScaleX)*i)/p),x.a*=p,x.c*=p}if(r!=0){let p=Math.sqrt(x.b*x.b+x.d*x.d);p!=0&&(p=(p+(Math.sqrt(o*o+d*d)-p+this.data.offsetScaleY)*r)/p),x.b*=p,x.d*=p}if(h>0){let p=x.b,v=x.d,y=Math.atan2(v,p),A=Math.atan2(d,o)-Math.atan2(c,a)-(y-Math.atan2(x.c,x.a));A>L.PI?A-=L.PI2:A<-L.PI&&(A+=L.PI2),A=y+(A+u)*h;let C=Math.sqrt(p*p+v*v);x.b=Math.cos(A)*C,x.d=Math.sin(A)*C}x.updateAppliedTransform()}}applyRelativeWorld(){let e=this.mixRotate,t=this.mixX,s=this.mixY,i=this.mixScaleX,r=this.mixScaleY,h=this.mixShearY,l=t!=0||s!=0,n=this.target,a=n.a,o=n.b,c=n.c,d=n.d,f=a*d-o*c>0?L.degRad:-L.degRad,m=this.data.offsetRotation*f,u=this.data.offsetShearY*f,g=this.bones;for(let w=0,b=g.length;w<b;w++){let x=g[w];if(e!=0){let p=x.a,v=x.b,y=x.c,A=x.d,C=Math.atan2(c,a)+m;C>L.PI?C-=L.PI2:C<-L.PI&&(C+=L.PI2),C*=e;let S=Math.cos(C),T=Math.sin(C);x.a=S*p-T*y,x.b=S*v-T*A,x.c=T*p+S*y,x.d=T*v+S*A}if(l){let p=this.temp;n.localToWorld(p.set(this.data.offsetX,this.data.offsetY)),x.worldX+=p.x*t,x.worldY+=p.y*s}if(i!=0){let p=(Math.sqrt(a*a+c*c)-1+this.data.offsetScaleX)*i+1;x.a*=p,x.c*=p}if(r!=0){let p=(Math.sqrt(o*o+d*d)-1+this.data.offsetScaleY)*r+1;x.b*=p,x.d*=p}if(h>0){let p=Math.atan2(d,o)-Math.atan2(c,a);p>L.PI?p-=L.PI2:p<-L.PI&&(p+=L.PI2);let v=x.b,y=x.d;p=Math.atan2(y,v)+(p-L.PI/2+u)*h;let A=Math.sqrt(v*v+y*y);x.b=Math.cos(p)*A,x.d=Math.sin(p)*A}x.updateAppliedTransform()}}applyAbsoluteLocal(){let e=this.mixRotate,t=this.mixX,s=this.mixY,i=this.mixScaleX,r=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],d=c.arotation;e!=0&&(d+=(l.arotation-d+this.data.offsetRotation)*e);let f=c.ax,m=c.ay;f+=(l.ax-f+this.data.offsetX)*t,m+=(l.ay-m+this.data.offsetY)*s;let u=c.ascaleX,g=c.ascaleY;i!=0&&u!=0&&(u=(u+(l.ascaleX-u+this.data.offsetScaleX)*i)/u),r!=0&&g!=0&&(g=(g+(l.ascaleY-g+this.data.offsetScaleY)*r)/g);let w=c.ashearY;h!=0&&(w+=(l.ashearY-w+this.data.offsetShearY)*h),c.updateWorldTransformWith(f,m,d,u,g,c.ashearX,w)}}applyRelativeLocal(){let e=this.mixRotate,t=this.mixX,s=this.mixY,i=this.mixScaleX,r=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],d=c.arotation+(l.arotation+this.data.offsetRotation)*e,f=c.ax+(l.ax+this.data.offsetX)*t,m=c.ay+(l.ay+this.data.offsetY)*s,u=c.ascaleX*((l.ascaleX-1+this.data.offsetScaleX)*i+1),g=c.ascaleY*((l.ascaleY-1+this.data.offsetScaleY)*r+1),w=c.ashearY+(l.ashearY+this.data.offsetShearY)*h;c.updateWorldTransformWith(f,m,d,u,g,c.ashearX,w)}}},mi=class Ds{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 Ds.yDown?-this._scaleY:this._scaleY}set scaleY(t){this._scaleY=t}x=0;y=0;time=0;constructor(t){if(!t)throw new Error("data cannot be null.");this.data=t,this.bones=new Array;for(let s=0;s<t.bones.length;s++){let i=t.bones[s],r;if(!i.parent)r=new gs(i,this,null);else{let h=this.bones[i.parent.index];r=new gs(i,this,h),h.children.push(r)}this.bones.push(r)}this.slots=new Array,this.drawOrder=new Array;for(let s=0;s<t.slots.length;s++){let i=t.slots[s],r=this.bones[i.boneData.index],h=new fi(i,r);this.slots.push(h),this.drawOrder.push(h)}this.ikConstraints=new Array;for(let s=0;s<t.ikConstraints.length;s++){let i=t.ikConstraints[s];this.ikConstraints.push(new ci(i,this))}this.transformConstraints=new Array;for(let s=0;s<t.transformConstraints.length;s++){let i=t.transformConstraints[s];this.transformConstraints.push(new ui(i,this))}this.pathConstraints=new Array;for(let s=0;s<t.pathConstraints.length;s++){let i=t.pathConstraints[s];this.pathConstraints.push(new di(i,this))}this.physicsConstraints=new Array;for(let s=0;s<t.physicsConstraints.length;s++){let i=t.physicsConstraints[s];this.physicsConstraints.push(new tr(i,this))}this.color=new et(1,1,1,1),this.updateCache()}updateCache(){let t=this._updateCache;t.length=0;let s=this.bones;for(let f=0,m=s.length;f<m;f++){let u=s[f];u.sorted=u.data.skinRequired,u.active=!u.sorted}if(this.skin){let f=this.skin.bones;for(let m=0,u=this.skin.bones.length;m<u;m++){let g=this.bones[f[m].index];do g.sorted=!1,g.active=!0,g=g.parent;while(g)}}let i=this.ikConstraints,r=this.transformConstraints,h=this.pathConstraints,l=this.physicsConstraints,n=i.length,a=r.length,o=h.length,c=this.physicsConstraints.length,d=n+a+o+c;t:for(let f=0;f<d;f++){for(let m=0;m<n;m++){let u=i[m];if(u.data.order==f){this.sortIkConstraint(u);continue t}}for(let m=0;m<a;m++){let u=r[m];if(u.data.order==f){this.sortTransformConstraint(u);continue t}}for(let m=0;m<o;m++){let u=h[m];if(u.data.order==f){this.sortPathConstraint(u);continue t}}for(let m=0;m<c;m++){const u=l[m];if(u.data.order==f){this.sortPhysicsConstraint(u);continue t}}}for(let f=0,m=s.length;f<m;f++)this.sortBone(s[f])}sortIkConstraint(t){if(t.active=t.target.isActive()&&(!t.data.skinRequired||this.skin&&P.contains(this.skin.constraints,t.data,!0)),!t.active)return;let s=t.target;this.sortBone(s);let i=t.bones,r=i[0];if(this.sortBone(r),i.length==1)this._updateCache.push(t),this.sortReset(r.children);else{let h=i[i.length-1];this.sortBone(h),this._updateCache.push(t),this.sortReset(r.children),h.sorted=!0}}sortPathConstraint(t){if(t.active=t.target.bone.isActive()&&(!t.data.skinRequired||this.skin&&P.contains(this.skin.constraints,t.data,!0)),!t.active)return;let s=t.target,i=s.data.index,r=s.bone;this.skin&&this.sortPathConstraintAttachment(this.skin,i,r),this.data.defaultSkin&&this.data.defaultSkin!=this.skin&&this.sortPathConstraintAttachment(this.data.defaultSkin,i,r);for(let a=0,o=this.data.skins.length;a<o;a++)this.sortPathConstraintAttachment(this.data.skins[a],i,r);let h=s.getAttachment();h instanceof Ht&&this.sortPathConstraintAttachmentWith(h,r);let l=t.bones,n=l.length;for(let a=0;a<n;a++)this.sortBone(l[a]);this._updateCache.push(t);for(let a=0;a<n;a++)this.sortReset(l[a].children);for(let a=0;a<n;a++)l[a].sorted=!0}sortTransformConstraint(t){if(t.active=t.target.isActive()&&(!t.data.skinRequired||this.skin&&P.contains(this.skin.constraints,t.data,!0)),!t.active)return;this.sortBone(t.target);let s=t.bones,i=s.length;if(t.data.local)for(let r=0;r<i;r++){let h=s[r];this.sortBone(h.parent),this.sortBone(h)}else for(let r=0;r<i;r++)this.sortBone(s[r]);this._updateCache.push(t);for(let r=0;r<i;r++)this.sortReset(s[r].children);for(let r=0;r<i;r++)s[r].sorted=!0}sortPathConstraintAttachment(t,s,i){let r=t.attachments[s];if(r)for(let h in r)this.sortPathConstraintAttachmentWith(r[h],i)}sortPathConstraintAttachmentWith(t,s){if(!(t instanceof Ht))return;let i=t.bones;if(!i)this.sortBone(s);else{let r=this.bones;for(let h=0,l=i.length;h<l;){let n=i[h++];for(n+=h;h<n;)this.sortBone(r[i[h++]])}}}sortPhysicsConstraint(t){const s=t.bone;t.active=s.active&&(!t.data.skinRequired||this.skin!=null&&P.contains(this.skin.constraints,t.data,!0)),t.active&&(this.sortBone(s),this._updateCache.push(t),this.sortReset(s.children),s.sorted=!0)}sortBone(t){if(!t||t.sorted)return;let s=t.parent;s&&this.sortBone(s),t.sorted=!0,this._updateCache.push(t)}sortReset(t){for(let s=0,i=t.length;s<i;s++){let r=t[s];r.active&&(r.sorted&&this.sortReset(r.children),r.sorted=!1)}}updateWorldTransform(t){if(t==null)throw new Error("physics is undefined");let s=this.bones;for(let r=0,h=s.length;r<h;r++){let l=s[r];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 i=this._updateCache;for(let r=0,h=i.length;r<h;r++)i[r].update(t)}updateWorldTransformWith(t,s){if(!s)throw new Error("parent cannot be null.");let i=this.bones;for(let w=1,b=i.length;w<b;w++){let x=i[w];x.ax=x.x,x.ay=x.y,x.arotation=x.rotation,x.ascaleX=x.scaleX,x.ascaleY=x.scaleY,x.ashearX=x.shearX,x.ashearY=x.shearY}let r=this.getRootBone();if(!r)throw new Error("Root bone must not be null.");let h=s.a,l=s.b,n=s.c,a=s.d;r.worldX=h*this.x+l*this.y+s.worldX,r.worldY=n*this.x+a*this.y+s.worldY;const o=(r.rotation+r.shearX)*L.degRad,c=(r.rotation+90+r.shearY)*L.degRad,d=Math.cos(o)*r.scaleX,f=Math.cos(c)*r.scaleY,m=Math.sin(o)*r.scaleX,u=Math.sin(c)*r.scaleY;r.a=(h*d+l*m)*this.scaleX,r.b=(h*f+l*u)*this.scaleX,r.c=(n*d+a*m)*this.scaleY,r.d=(n*f+a*u)*this.scaleY;let g=this._updateCache;for(let w=0,b=g.length;w<b;w++){let x=g[w];x!=r&&x.update(t)}}setToSetupPose(){this.setBonesToSetupPose(),this.setSlotsToSetupPose()}setBonesToSetupPose(){for(const t of this.bones)t.setToSetupPose();for(const t of this.ikConstraints)t.setToSetupPose();for(const t of this.transformConstraints)t.setToSetupPose();for(const t of this.pathConstraints)t.setToSetupPose();for(const t of this.physicsConstraints)t.setToSetupPose()}setSlotsToSetupPose(){let t=this.slots;P.arrayCopy(t,0,this.drawOrder,0,t.length);for(let s=0,i=t.length;s<i;s++)t[s].setToSetupPose()}getRootBone(){return this.bones.length==0?null:this.bones[0]}findBone(t){if(!t)throw new Error("boneName cannot be null.");let s=this.bones;for(let i=0,r=s.length;i<r;i++){let h=s[i];if(h.data.name==t)return h}return null}findSlot(t){if(!t)throw new Error("slotName cannot be null.");let s=this.slots;for(let i=0,r=s.length;i<r;i++){let h=s[i];if(h.data.name==t)return h}return null}setSkinByName(t){let s=this.data.findSkin(t);if(!s)throw new Error("Skin not found: "+t);this.setSkin(s)}setSkin(t){if(t!=this.skin){if(t)if(this.skin)t.attachAll(this,this.skin);else{let s=this.slots;for(let i=0,r=s.length;i<r;i++){let h=s[i],l=h.data.attachmentName;if(l){let n=t.getAttachment(i,l);n&&h.setAttachment(n)}}}this.skin=t,this.updateCache()}}getAttachmentByName(t,s){let i=this.data.findSlot(t);if(!i)throw new Error(`Can't find slot with name ${t}`);return this.getAttachment(i.index,s)}getAttachment(t,s){if(!s)throw new Error("attachmentName cannot be null.");if(this.skin){let i=this.skin.getAttachment(t,s);if(i)return i}return this.data.defaultSkin?this.data.defaultSkin.getAttachment(t,s):null}setAttachment(t,s){if(!t)throw new Error("slotName cannot be null.");let i=this.slots;for(let r=0,h=i.length;r<h;r++){let l=i[r];if(l.data.name==t){let n=null;if(s&&(n=this.getAttachment(r,s),!n))throw new Error("Attachment not found: "+s+", for slot: "+t);l.setAttachment(n);return}}throw new Error("Slot not found: "+t)}findIkConstraint(t){if(!t)throw new Error("constraintName cannot be null.");return this.ikConstraints.find(s=>s.data.name==t)??null}findTransformConstraint(t){if(!t)throw new Error("constraintName cannot be null.");return this.transformConstraints.find(s=>s.data.name==t)??null}findPathConstraint(t){if(!t)throw new Error("constraintName cannot be null.");return this.pathConstraints.find(s=>s.data.name==t)??null}findPhysicsConstraint(t){if(t==null)throw new Error("constraintName cannot be null.");return this.physicsConstraints.find(s=>s.data.name==t)??null}getBoundsRect(t){let s=new Vt,i=new Vt;return this.getBounds(s,i,void 0,t),{x:s.x,y:s.y,width:i.x,height:i.y}}getBounds(t,s,i=new Array(2),r=null){if(!t)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,d=h.length;c<d;c++){let f=h[c];if(!f.bone.active)continue;let m=0,u=null,g=null,w=f.getAttachment();if(w instanceof se)m=8,u=P.setArraySize(i,m,0),w.computeWorldVertices(f,u,0,2),g=Ds.quadTriangles;else if(w instanceof Gt){let b=w;m=b.worldVerticesLength,u=P.setArraySize(i,m,0),b.computeWorldVertices(f,0,m,u,0,2),g=b.triangles}else if(w instanceof ee&&r!=null){r.clipStart(f,w);continue}if(u&&g){r!=null&&r.isClipping()&&(r.clipTriangles(u,g,g.length),u=r.clippedVertices,m=r.clippedVertices.length);for(let b=0,x=u.length;b<x;b+=2){let p=u[b],v=u[b+1];l=Math.min(l,p),n=Math.min(n,v),a=Math.max(a,p),o=Math.max(o,v)}}r?.clipEndWithSlot(f)}r?.clipEnd(),t.set(l,n),s.set(a-l,o-n)}update(t){this.time+=t}physicsTranslate(t,s){const i=this.physicsConstraints;for(let r=0,h=i.length;r<h;r++)i[r].translate(t,s)}physicsRotate(t,s,i){const r=this.physicsConstraints;for(let h=0,l=r.length;h<l;h++)r[h].rotate(t,s,i)}},gi=(e=>(e[e.none=0]="none",e[e.reset=1]="reset",e[e.update=2]="update",e[e.pose=3]="pose",e))(gi||{}),xi=class extends ie{_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)}},Ss=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,i=t.length;s<i;s++){let r=t[s];if(r.name==e)return r}return null}findSlot(e){if(!e)throw new Error("slotName cannot be null.");let t=this.slots;for(let s=0,i=t.length;s<i;s++){let r=t[s];if(r.name==e)return r}return null}findSkin(e){if(!e)throw new Error("skinName cannot be null.");let t=this.skins;for(let s=0,i=t.length;s<i;s++){let r=t[s];if(r.name==e)return r}return null}findEvent(e){if(!e)throw new Error("eventDataName cannot be null.");let t=this.events;for(let s=0,i=t.length;s<i;s++){let r=t[s];if(r.name==e)return r}return null}findAnimation(e){if(!e)throw new Error("animationName cannot be null.");let t=this.animations;for(let s=0,i=t.length;s<i;s++){let r=t[s];if(r.name==e)return r}return null}findIkConstraint(e){if(!e)throw new Error("constraintName cannot be null.");const t=this.ikConstraints;for(let s=0,i=t.length;s<i;s++){const r=t[s];if(r.name==e)return r}return null}findTransformConstraint(e){if(!e)throw new Error("constraintName cannot be null.");const t=this.transformConstraints;for(let s=0,i=t.length;s<i;s++){const r=t[s];if(r.name==e)return r}return null}findPathConstraint(e){if(!e)throw new Error("constraintName cannot be null.");const t=this.pathConstraints;for(let s=0,i=t.length;s<i;s++){const r=t[s];if(r.name==e)return r}return null}findPhysicsConstraint(e){if(!e)throw new Error("constraintName cannot be null.");const t=this.physicsConstraints;for(let s=0,i=t.length;s<i;s++){const r=t[s];if(r.name==e)return r}return null}},Is=class{constructor(e=0,t,s){this.slotIndex=e,this.name=t,this.attachment=s}},ge=class{name;attachments=new Array;bones=Array();constraints=new Array;color=new et(.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 i=this.attachments;e>=i.length&&(i.length=e+1),i[e]||(i[e]={}),i[e][t]=s}addSkin(e){for(let i=0;i<e.bones.length;i++){let r=e.bones[i],h=!1;for(let l=0;l<this.bones.length;l++)if(this.bones[l]==r){h=!0;break}h||this.bones.push(r)}for(let i=0;i<e.constraints.length;i++){let r=e.constraints[i],h=!1;for(let l=0;l<this.constraints.length;l++)if(this.constraints[l]==r){h=!0;break}h||this.constraints.push(r)}let t=e.getAttachments();for(let i=0;i<t.length;i++){var s=t[i];this.setAttachment(s.slotIndex,s.name,s.attachment)}}copySkin(e){for(let i=0;i<e.bones.length;i++){let r=e.bones[i],h=!1;for(let l=0;l<this.bones.length;l++)if(this.bones[l]==r){h=!0;break}h||this.bones.push(r)}for(let i=0;i<e.constraints.length;i++){let r=e.constraints[i],h=!1;for(let l=0;l<this.constraints.length;l++)if(this.constraints[l]==r){h=!0;break}h||this.constraints.push(r)}let t=e.getAttachments();for(let i=0;i<t.length;i++){var s=t[i];s.attachment&&(s.attachment instanceof Gt?(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 i in s){let r=s[i];r&&e.push(new Is(t,i,r))}}return e}getAttachmentsForSlot(e,t){let s=this.attachments[e];if(s)for(let i in s){let r=s[i];r&&t.push(new Is(e,i,r))}}clear(){this.attachments.length=0,this.bones.length=0,this.constraints.length=0}attachAll(e,t){let s=0;for(let i=0;i<e.slots.length;i++){let r=e.slots[i],h=r.getAttachment();if(h&&s<t.attachments.length){let l=t.attachments[s];for(let n in l){let a=l[n];if(h==a){let o=this.getAttachment(s,n);o&&r.setAttachment(o);break}}}s++}}},Ts=class{index=0;name;boneData;color=new et(1,1,1,1);darkColor=null;attachmentName=null;blendMode=0;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}},Ms=(e=>(e[e.Normal=0]="Normal",e[e.Additive=1]="Additive",e[e.Multiply=2]="Multiply",e[e.Screen=3]="Screen",e))(Ms||{}),Es=class extends ie{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)}},er=class{scale=1;attachmentLoader;linkedMeshes=new Array;constructor(e){this.attachmentLoader=e}readSkeletonData(e){let t=this.scale,s=new Ss;s.name="";let i=new pi(e),r=i.readInt32(),h=i.readInt32();s.hash=h==0&&r==0?null:h.toString(16)+r.toString(16),s.version=i.readString(),s.x=i.readFloat(),s.y=i.readFloat(),s.width=i.readFloat(),s.height=i.readFloat(),s.referenceScale=i.readFloat()*t;let l=i.readBoolean();l&&(s.fps=i.readFloat(),s.imagesPath=i.readString(),s.audioPath=i.readString());let n=0;n=i.readInt(!0);for(let o=0;o<n;o++){let c=i.readString();if(!c)throw new Error("String in string table must not be null.");i.strings.push(c)}n=i.readInt(!0);for(let o=0;o<n;o++){let c=i.readString();if(!c)throw new Error("Bone name must not be null.");let d=o==0?null:s.bones[i.readInt(!0)],f=new ms(o,c,d);f.rotation=i.readFloat(),f.x=i.readFloat()*t,f.y=i.readFloat()*t,f.scaleX=i.readFloat(),f.scaleY=i.readFloat(),f.shearX=i.readFloat(),f.shearY=i.readFloat(),f.length=i.readFloat()*t,f.inherit=i.readByte(),f.skinRequired=i.readBoolean(),l&&(et.rgba8888ToColor(f.color,i.readInt32()),f.icon=i.readString()??void 0,f.visible=i.readBoolean()),s.bones.push(f)}n=i.readInt(!0);for(let o=0;o<n;o++){let c=i.readString();if(!c)throw new Error("Slot name must not be null.");let d=s.bones[i.readInt(!0)],f=new Ts(o,c,d);et.rgba8888ToColor(f.color,i.readInt32());let m=i.readInt32();m!=-1&&et.rgb888ToColor(f.darkColor=new et,m),f.attachmentName=i.readStringRef(),f.blendMode=i.readInt(!0),l&&(f.visible=i.readBoolean()),s.slots.push(f)}n=i.readInt(!0);for(let o=0,c;o<n;o++){let d=i.readString();if(!d)throw new Error("IK constraint data name must not be null.");let f=new bs(d);f.order=i.readInt(!0),c=i.readInt(!0);for(let u=0;u<c;u++)f.bones.push(s.bones[i.readInt(!0)]);f.target=s.bones[i.readInt(!0)];let m=i.readByte();f.skinRequired=(m&1)!=0,f.bendDirection=(m&2)!=0?1:-1,f.compress=(m&4)!=0,f.stretch=(m&8)!=0,f.uniform=(m&16)!=0,(m&32)!=0&&(f.mix=(m&64)!=0?i.readFloat():1),(m&128)!=0&&(f.softness=i.readFloat()*t),s.ikConstraints.push(f)}n=i.readInt(!0);for(let o=0,c;o<n;o++){let d=i.readString();if(!d)throw new Error("Transform constraint data name must not be null.");let f=new Es(d);f.order=i.readInt(!0),c=i.readInt(!0);for(let u=0;u<c;u++)f.bones.push(s.bones[i.readInt(!0)]);f.target=s.bones[i.readInt(!0)];let m=i.readByte();f.skinRequired=(m&1)!=0,f.local=(m&2)!=0,f.relative=(m&4)!=0,(m&8)!=0&&(f.offsetRotation=i.readFloat()),(m&16)!=0&&(f.offsetX=i.readFloat()*t),(m&32)!=0&&(f.offsetY=i.readFloat()*t),(m&64)!=0&&(f.offsetScaleX=i.readFloat()),(m&128)!=0&&(f.offsetScaleY=i.readFloat()),m=i.readByte(),(m&1)!=0&&(f.offsetShearY=i.readFloat()),(m&2)!=0&&(f.mixRotate=i.readFloat()),(m&4)!=0&&(f.mixX=i.readFloat()),(m&8)!=0&&(f.mixY=i.readFloat()),(m&16)!=0&&(f.mixScaleX=i.readFloat()),(m&32)!=0&&(f.mixScaleY=i.readFloat()),(m&64)!=0&&(f.mixShearY=i.readFloat()),s.transformConstraints.push(f)}n=i.readInt(!0);for(let o=0,c;o<n;o++){let d=i.readString();if(!d)throw new Error("Path constraint data name must not be null.");let f=new vs(d);f.order=i.readInt(!0),f.skinRequired=i.readBoolean(),c=i.readInt(!0);for(let u=0;u<c;u++)f.bones.push(s.bones[i.readInt(!0)]);f.target=s.slots[i.readInt(!0)];const m=i.readByte();f.positionMode=m&1,f.spacingMode=m>>1&3,f.rotateMode=m>>3&3,(m&128)!=0&&(f.offsetRotation=i.readFloat()),f.position=i.readFloat(),f.positionMode==0&&(f.position*=t),f.spacing=i.readFloat(),(f.spacingMode==0||f.spacingMode==1)&&(f.spacing*=t),f.mixRotate=i.readFloat(),f.mixX=i.readFloat(),f.mixY=i.readFloat(),s.pathConstraints.push(f)}n=i.readInt(!0);for(let o=0,c;o<n;o++){const d=i.readString();if(!d)throw new Error("Physics constraint data name must not be null.");const f=new xi(d);f.order=i.readInt(!0),f.bone=s.bones[i.readInt(!0)];let m=i.readByte();f.skinRequired=(m&1)!=0,(m&2)!=0&&(f.x=i.readFloat()),(m&4)!=0&&(f.y=i.readFloat()),(m&8)!=0&&(f.rotate=i.readFloat()),(m&16)!=0&&(f.scaleX=i.readFloat()),(m&32)!=0&&(f.shearX=i.readFloat()),f.limit=((m&64)!=0?i.readFloat():5e3)*t,f.step=1/i.readUnsignedByte(),f.inertia=i.readFloat(),f.strength=i.readFloat(),f.damping=i.readFloat(),f.massInverse=(m&128)!=0?i.readFloat():1,f.wind=i.readFloat(),f.gravity=i.readFloat(),m=i.readByte(),(m&1)!=0&&(f.inertiaGlobal=!0),(m&2)!=0&&(f.strengthGlobal=!0),(m&4)!=0&&(f.dampingGlobal=!0),(m&8)!=0&&(f.massGlobal=!0),(m&16)!=0&&(f.windGlobal=!0),(m&32)!=0&&(f.gravityGlobal=!0),(m&64)!=0&&(f.mixGlobal=!0),f.mix=(m&128)!=0?i.readFloat():1,s.physicsConstraints.push(f)}let a=this.readSkin(i,s,!0,l);a&&(s.defaultSkin=a,s.skins.push(a));{let o=s.skins.length;for(P.setArraySize(s.skins,n=o+i.readInt(!0));o<n;o++){let c=this.readSkin(i,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 d=s.skins[c.skinIndex];if(!c.parent)throw new Error("Linked mesh parent must not be null");let f=d.getAttachment(c.slotIndex,c.parent);if(!f)throw new Error(`Parent mesh not found: ${c.parent}`);c.mesh.timelineAttachment=c.inheritTimeline?f:c.mesh,c.mesh.setParentMesh(f),c.mesh.region!=null&&c.mesh.updateRegion()}this.linkedMeshes.length=0,n=i.readInt(!0);for(let o=0;o<n;o++){let c=i.readString();if(!c)throw new Error("Event data name must not be null");let d=new ws(c);d.intValue=i.readInt(!1),d.floatValue=i.readFloat(),d.stringValue=i.readString(),d.audioPath=i.readString(),d.audioPath&&(d.volume=i.readFloat(),d.balance=i.readFloat()),s.events.push(d)}n=i.readInt(!0);for(let o=0;o<n;o++){let c=i.readString();if(!c)throw new Error("Animatio name must not be null.");s.animations.push(this.readAnimation(i,c,s))}return s}readSkin(e,t,s,i){let r=null,h=0;if(s){if(h=e.readInt(!0),h==0)return null;r=new ge("default")}else{let l=e.readString();if(!l)throw new Error("Skin name must not be null.");r=new ge(l),i&&et.rgba8888ToColor(r.color,e.readInt32()),r.bones.length=e.readInt(!0);for(let n=0,a=r.bones.length;n<a;n++)r.bones[n]=t.bones[e.readInt(!0)];for(let n=0,a=e.readInt(!0);n<a;n++)r.constraints.push(t.ikConstraints[e.readInt(!0)]);for(let n=0,a=e.readInt(!0);n<a;n++)r.constraints.push(t.transformConstraints[e.readInt(!0)]);for(let n=0,a=e.readInt(!0);n<a;n++)r.constraints.push(t.pathConstraints[e.readInt(!0)]);for(let n=0,a=e.readInt(!0);n<a;n++)r.constraints.push(t.physicsConstraints[e.readInt(!0)]);h=e.readInt(!0)}for(let l=0;l<h;l++){let n=e.readInt(!0);for(let a=0,o=e.readInt(!0);a<o;a++){let c=e.readStringRef();if(!c)throw new Error("Attachment name must not be null");let d=this.readAttachment(e,t,r,n,c,i);d&&r.setAttachment(n,c,d)}}return r}readAttachment(e,t,s,i,r,h){let l=this.scale,n=e.readByte();const a=(n&8)!=0?e.readStringRef():r;if(!a)throw new Error("Attachment name must not be null");switch(n&7){case 0:{let o=(n&16)!=0?e.readStringRef():null;const c=(n&32)!=0?e.readInt32():4294967295,d=(n&64)!=0?this.readSequence(e):null;let f=(n&128)!=0?e.readFloat():0,m=e.readFloat(),u=e.readFloat(),g=e.readFloat(),w=e.readFloat(),b=e.readFloat(),x=e.readFloat();o||(o=a);let p=this.attachmentLoader.newRegionAttachment(s,a,o,d);return p?(p.path=o,p.x=m*l,p.y=u*l,p.scaleX=g,p.scaleY=w,p.rotation=f,p.width=b*l,p.height=x*l,et.rgba8888ToColor(p.color,c),p.sequence=d,d==null&&p.updateRegion(),p):null}case 1:{let o=this.readVertices(e,(n&16)!=0),c=h?e.readInt32():0,d=this.attachmentLoader.newBoundingBoxAttachment(s,a);return d?(d.worldVerticesLength=o.length,d.vertices=o.vertices,d.bones=o.bones,h&&et.rgba8888ToColor(d.color,c),d):null}case 2:{let o=(n&16)!=0?e.readStringRef():a;const c=(n&32)!=0?e.readInt32():4294967295,d=(n&64)!=0?this.readSequence(e):null,f=e.readInt(!0),m=this.readVertices(e,(n&128)!=0),u=this.readFloatArray(e,m.length,1),g=this.readShortArray(e,(m.length-f-2)*3);let w=[],b=0,x=0;h&&(w=this.readShortArray(e,e.readInt(!0)),b=e.readFloat(),x=e.readFloat()),o||(o=a);let p=this.attachmentLoader.newMeshAttachment(s,a,o,d);return p?(p.path=o,et.rgba8888ToColor(p.color,c),p.bones=m.bones,p.vertices=m.vertices,p.worldVerticesLength=m.length,p.triangles=g,p.regionUVs=u,d==null&&p.updateRegion(),p.hullLength=f<<1,p.sequence=d,h&&(p.edges=w,p.width=b*l,p.height=x*l),p):null}case 3:{const o=(n&16)!=0?e.readStringRef():a;if(o==null)throw new Error("Path of linked mesh must not be null");const c=(n&32)!=0?e.readInt32():4294967295,d=(n&64)!=0?this.readSequence(e):null,f=(n&128)!=0,m=e.readInt(!0),u=e.readStringRef();let g=0,w=0;h&&(g=e.readFloat(),w=e.readFloat());let b=this.attachmentLoader.newMeshAttachment(s,a,o,d);return b?(b.path=o,et.rgba8888ToColor(b.color,c),b.sequence=d,h&&(b.width=g*l,b.height=w*l),this.linkedMeshes.push(new sr(b,m,i,u,f)),b):null}case 4:{const o=(n&16)!=0,c=(n&32)!=0,d=this.readVertices(e,(n&64)!=0),f=P.newArray(d.length/6,0);for(let g=0,w=f.length;g<w;g++)f[g]=e.readFloat()*l;const m=h?e.readInt32():0,u=this.attachmentLoader.newPathAttachment(s,a);return u?(u.closed=o,u.constantSpeed=c,u.worldVerticesLength=d.length,u.vertices=d.vertices,u.bones=d.bones,u.lengths=f,h&&et.rgba8888ToColor(u.color,m),u):null}case 5:{const o=e.readFloat(),c=e.readFloat(),d=e.readFloat(),f=h?e.readInt32():0,m=this.attachmentLoader.newPointAttachment(s,a);return m?(m.x=c*l,m.y=d*l,m.rotation=o,h&&et.rgba8888ToColor(m.color,f),m):null}case 6:{const o=e.readInt(!0),c=this.readVertices(e,(n&16)!=0);let d=h?e.readInt32():0,f=this.attachmentLoader.newClippingAttachment(s,a);return f?(f.endSlot=t.slots[o],f.worldVerticesLength=c.length,f.vertices=c.vertices,f.bones=c.bones,h&&et.rgba8888ToColor(f.color,d),f):null}}return null}readSequence(e){let t=new js(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,i=e.readInt(!0),r=new ir;if(r.length=i<<1,!t)return r.vertices=this.readFloatArray(e,r.length,s),r;let h=new Array,l=new Array;for(let n=0;n<i;n++){let a=e.readInt(!0);l.push(a);for(let o=0;o<a;o++)l.push(e.readInt(!0)),h.push(e.readFloat()*s),h.push(e.readFloat()*s),h.push(e.readFloat())}return r.vertices=P.toFloatArray(h),r.bones=l,r}readFloatArray(e,t,s){let i=new Array(t);if(s==1)for(let r=0;r<t;r++)i[r]=e.readFloat();else for(let r=0;r<t;r++)i[r]=e.readFloat()*s;return i}readShortArray(e,t){let s=new Array(t);for(let i=0;i<t;i++)s[i]=e.readInt(!0);return s}readAnimation(e,t,s){e.readInt(!0);let i=new Array,r=this.scale;for(let a=0,o=e.readInt(!0);a<o;a++){let c=e.readInt(!0);for(let d=0,f=e.readInt(!0);d<f;d++){let m=e.readByte(),u=e.readInt(!0),g=u-1;switch(m){case gr:{let w=new Ot(u,c);for(let b=0;b<u;b++)w.setFrame(b,e.readFloat(),e.readStringRef());i.push(w);break}case xr:{let w=e.readInt(!0),b=new Ue(u,w,c),x=e.readFloat(),p=e.readUnsignedByte()/255,v=e.readUnsignedByte()/255,y=e.readUnsignedByte()/255,A=e.readUnsignedByte()/255;for(let C=0,S=0;b.setFrame(C,x,p,v,y,A),C!=g;C++){let T=e.readFloat(),R=e.readUnsignedByte()/255,k=e.readUnsignedByte()/255,F=e.readUnsignedByte()/255,X=e.readUnsignedByte()/255;switch(e.readByte()){case kt:b.setStepped(C);break;case Ft:at(e,b,S++,C,0,x,T,p,R,1),at(e,b,S++,C,1,x,T,v,k,1),at(e,b,S++,C,2,x,T,y,F,1),at(e,b,S++,C,3,x,T,A,X,1)}x=T,p=R,v=k,y=F,A=X}i.push(b);break}case pr:{let w=e.readInt(!0),b=new ze(u,w,c),x=e.readFloat(),p=e.readUnsignedByte()/255,v=e.readUnsignedByte()/255,y=e.readUnsignedByte()/255;for(let A=0,C=0;b.setFrame(A,x,p,v,y),A!=g;A++){let S=e.readFloat(),T=e.readUnsignedByte()/255,R=e.readUnsignedByte()/255,k=e.readUnsignedByte()/255;switch(e.readByte()){case kt:b.setStepped(A);break;case Ft:at(e,b,C++,A,0,x,S,p,T,1),at(e,b,C++,A,1,x,S,v,R,1),at(e,b,C++,A,2,x,S,y,k,1)}x=S,p=T,v=R,y=k}i.push(b);break}case wr:{let w=e.readInt(!0),b=new qe(u,w,c),x=e.readFloat(),p=e.readUnsignedByte()/255,v=e.readUnsignedByte()/255,y=e.readUnsignedByte()/255,A=e.readUnsignedByte()/255,C=e.readUnsignedByte()/255,S=e.readUnsignedByte()/255,T=e.readUnsignedByte()/255;for(let R=0,k=0;b.setFrame(R,x,p,v,y,A,C,S,T),R!=g;R++){let F=e.readFloat(),X=e.readUnsignedByte()/255,E=e.readUnsignedByte()/255,Y=e.readUnsignedByte()/255,B=e.readUnsignedByte()/255,st=e.readUnsignedByte()/255,tt=e.readUnsignedByte()/255,it=e.readUnsignedByte()/255;switch(e.readByte()){case kt:b.setStepped(R);break;case Ft:at(e,b,k++,R,0,x,F,p,X,1),at(e,b,k++,R,1,x,F,v,E,1),at(e,b,k++,R,2,x,F,y,Y,1),at(e,b,k++,R,3,x,F,A,B,1),at(e,b,k++,R,4,x,F,C,st,1),at(e,b,k++,R,5,x,F,S,tt,1),at(e,b,k++,R,6,x,F,T,it,1)}x=F,p=X,v=E,y=Y,A=B,C=st,S=tt,T=it}i.push(b);break}case br:{let w=e.readInt(!0),b=new Ge(u,w,c),x=e.readFloat(),p=e.readUnsignedByte()/255,v=e.readUnsignedByte()/255,y=e.readUnsignedByte()/255,A=e.readUnsignedByte()/255,C=e.readUnsignedByte()/255,S=e.readUnsignedByte()/255;for(let T=0,R=0;b.setFrame(T,x,p,v,y,A,C,S),T!=g;T++){let k=e.readFloat(),F=e.readUnsignedByte()/255,X=e.readUnsignedByte()/255,E=e.readUnsignedByte()/255,Y=e.readUnsignedByte()/255,B=e.readUnsignedByte()/255,st=e.readUnsignedByte()/255;switch(e.readByte()){case kt:b.setStepped(T);break;case Ft:at(e,b,R++,T,0,x,k,p,F,1),at(e,b,R++,T,1,x,k,v,X,1),at(e,b,R++,T,2,x,k,y,E,1),at(e,b,R++,T,3,x,k,A,Y,1),at(e,b,R++,T,4,x,k,C,B,1),at(e,b,R++,T,5,x,k,S,st,1)}x=k,p=F,v=X,y=E,A=Y,C=B,S=st}i.push(b);break}case vr:{let w=new We(u,e.readInt(!0),c),b=e.readFloat(),x=e.readUnsignedByte()/255;for(let p=0,v=0;w.setFrame(p,b,x),p!=g;p++){let y=e.readFloat(),A=e.readUnsignedByte()/255;switch(e.readByte()){case kt:w.setStepped(p);break;case Ft:at(e,w,v++,p,0,b,y,x,A,1)}b=y,x=A}i.push(w)}}}}for(let a=0,o=e.readInt(!0);a<o;a++){let c=e.readInt(!0);for(let d=0,f=e.readInt(!0);d<f;d++){let m=e.readByte(),u=e.readInt(!0);if(m==mr){let w=new Ne(u,c);for(let b=0;b<u;b++)w.setFrame(b,e.readFloat(),e.readByte());i.push(w);continue}let g=e.readInt(!0);switch(m){case rr:i.push(pt(e,new te(u,g,c),1));break;case nr:i.push(Ys(e,new ke(u,g,c),r));break;case ar:i.push(pt(e,new Fe(u,g,c),r));break;case lr:i.push(pt(e,new Xe(u,g,c),r));break;case or:i.push(Ys(e,new Le(u,g,c),1));break;case hr:i.push(pt(e,new Pe(u,g,c),1));break;case cr:i.push(pt(e,new Be(u,g,c),1));break;case dr:i.push(Ys(e,new Ve(u,g,c),1));break;case fr:i.push(pt(e,new Oe(u,g,c),1));break;case ur:i.push(pt(e,new De(u,g,c),1))}}}for(let a=0,o=e.readInt(!0);a<o;a++){let c=e.readInt(!0),d=e.readInt(!0),f=d-1,m=new _e(d,e.readInt(!0),c),u=e.readByte(),g=e.readFloat(),w=(u&1)!=0?(u&2)!=0?e.readFloat():1:0,b=(u&4)!=0?e.readFloat()*r:0;for(let x=0,p=0;m.setFrame(x,g,w,b,(u&8)!=0?1:-1,(u&16)!=0,(u&32)!=0),x!=f;x++){u=e.readByte();const v=e.readFloat(),y=(u&1)!=0?(u&2)!=0?e.readFloat():1:0,A=(u&4)!=0?e.readFloat()*r:0;(u&64)!=0?m.setStepped(x):(u&128)!=0&&(at(e,m,p++,x,0,g,v,w,y,1),at(e,m,p++,x,1,g,v,b,A,r)),g=v,w=y,b=A}i.push(m)}for(let a=0,o=e.readInt(!0);a<o;a++){let c=e.readInt(!0),d=e.readInt(!0),f=d-1,m=new je(d,e.readInt(!0),c),u=e.readFloat(),g=e.readFloat(),w=e.readFloat(),b=e.readFloat(),x=e.readFloat(),p=e.readFloat(),v=e.readFloat();for(let y=0,A=0;m.setFrame(y,u,g,w,b,x,p,v),y!=f;y++){let C=e.readFloat(),S=e.readFloat(),T=e.readFloat(),R=e.readFloat(),k=e.readFloat(),F=e.readFloat(),X=e.readFloat();switch(e.readByte()){case kt:m.setStepped(y);break;case Ft:at(e,m,A++,y,0,u,C,g,S,1),at(e,m,A++,y,1,u,C,w,T,1),at(e,m,A++,y,2,u,C,b,R,1),at(e,m,A++,y,3,u,C,x,k,1),at(e,m,A++,y,4,u,C,p,F,1),at(e,m,A++,y,5,u,C,v,X,1)}u=C,g=S,w=T,b=R,x=k,p=F,v=X}i.push(m)}for(let a=0,o=e.readInt(!0);a<o;a++){let c=e.readInt(!0),d=s.pathConstraints[c];for(let f=0,m=e.readInt(!0);f<m;f++){const u=e.readByte(),g=e.readInt(!0),w=e.readInt(!0);switch(u){case Cr:i.push(pt(e,new Ze(g,w,c),d.positionMode==0?r:1));break;case Sr:i.push(pt(e,new Ke(g,w,c),d.spacingMode==0||d.spacingMode==1?r:1));break;case Ir:let b=new Je(g,w,c),x=e.readFloat(),p=e.readFloat(),v=e.readFloat(),y=e.readFloat();for(let A=0,C=0,S=b.getFrameCount()-1;b.setFrame(A,x,p,v,y),A!=S;A++){let T=e.readFloat(),R=e.readFloat(),k=e.readFloat(),F=e.readFloat();switch(e.readByte()){case kt:b.setStepped(A);break;case Ft:at(e,b,C++,A,0,x,T,p,R,1),at(e,b,C++,A,1,x,T,v,k,1),at(e,b,C++,A,2,x,T,y,F,1)}x=T,p=R,v=k,y=F}i.push(b)}}}for(let a=0,o=e.readInt(!0);a<o;a++){const c=e.readInt(!0)-1;for(let d=0,f=e.readInt(!0);d<f;d++){const m=e.readByte(),u=e.readInt(!0);if(m==Xr){const w=new ns(u,c);for(let b=0;b<u;b++)w.setFrame(b,e.readFloat());i.push(w);continue}const g=e.readInt(!0);switch(m){case Tr:i.push(pt(e,new Qe(u,g,c),1));break;case Mr:i.push(pt(e,new $e(u,g,c),1));break;case Er:i.push(pt(e,new ts(u,g,c),1));break;case Yr:i.push(pt(e,new es(u,g,c),1));break;case Rr:i.push(pt(e,new ss(u,g,c),1));break;case kr:i.push(pt(e,new is(u,g,c),1));break;case Fr:i.push(pt(e,new rs(u,g,c),1))}}}for(let a=0,o=e.readInt(!0);a<o;a++){let c=s.skins[e.readInt(!0)];for(let d=0,f=e.readInt(!0);d<f;d++){let m=e.readInt(!0);for(let u=0,g=e.readInt(!0);u<g;u++){let w=e.readStringRef();if(!w)throw new Error("attachmentName must not be null.");let b=c.getAttachment(m,w),x=e.readByte(),p=e.readInt(!0),v=p-1;switch(x){case yr:{let y=b,A=y.bones,C=y.vertices,S=A?C.length/3*2:C.length,T=e.readInt(!0),R=new He(p,T,m,y),k=e.readFloat();for(let F=0,X=0;;F++){let E,Y=e.readInt(!0);if(Y==0)E=A?P.newFloatArray(S):C;else{E=P.newFloatArray(S);let st=e.readInt(!0);if(Y+=st,r==1)for(let tt=st;tt<Y;tt++)E[tt]=e.readFloat();else for(let tt=st;tt<Y;tt++)E[tt]=e.readFloat()*r;if(!A)for(let tt=0,it=E.length;tt<it;tt++)E[tt]+=C[tt]}if(R.setFrame(F,k,E),F==v)break;let B=e.readFloat();switch(e.readByte()){case kt:R.setStepped(F);break;case Ft:at(e,R,X++,F,0,k,B,0,1,1)}k=B}i.push(R);break}case Ar:{let y=new as(p,m,b);for(let A=0;A<p;A++){let C=e.readFloat(),S=e.readInt32();y.setFrame(A,C,Ks[S&15],S>>4,e.readFloat())}i.push(y);break}}}}}let h=e.readInt(!0);if(h>0){let a=new qt(h),o=s.slots.length;for(let c=0;c<h;c++){let d=e.readFloat(),f=e.readInt(!0),m=P.newArray(o,0);for(let b=o-1;b>=0;b--)m[b]=-1;let u=P.newArray(o-f,0),g=0,w=0;for(let b=0;b<f;b++){let x=e.readInt(!0);for(;g!=x;)u[w++]=g++;m[g+e.readInt(!0)]=g++}for(;g<o;)u[w++]=g++;for(let b=o-1;b>=0;b--)m[b]==-1&&(m[b]=u[--w]);a.setFrame(c,d,m)}i.push(a)}let l=e.readInt(!0);if(l>0){let a=new ce(l);for(let o=0;o<l;o++){let c=e.readFloat(),d=s.events[e.readInt(!0)],f=new ps(c,d);f.intValue=e.readInt(!1),f.floatValue=e.readFloat(),f.stringValue=e.readString(),f.stringValue==null&&(f.stringValue=d.stringValue),f.data.audioPath&&(f.volume=e.readFloat(),f.balance=e.readFloat()),a.setFrame(o,f)}i.push(a)}let n=0;for(let a=0,o=i.length;a<o;a++)n=Math.max(n,i[a].getDuration());return new oe(t,i,n)}},pi=class{constructor(e,t=new Array,s=0,i=new DataView(e instanceof ArrayBuffer?e:e.buffer)){this.strings=t,this.index=s,this.buffer=i}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)!=0&&(t=this.readByte(),s|=(t&127)<<7,(t&128)!=0&&(t=this.readByte(),s|=(t&127)<<14,(t&128)!=0&&(t=this.readByte(),s|=(t&127)<<21,(t&128)!=0&&(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 i=0;i<e;){let r=this.readUnsignedByte();switch(r>>4){case 12:case 13:t+=String.fromCharCode((r&31)<<6|this.readByte()&63),i+=2;break;case 14:t+=String.fromCharCode((r&15)<<12|(this.readByte()&63)<<6|this.readByte()&63),i+=3;break;default:t+=String.fromCharCode(r),i++}}return t}readFloat(){let e=this.buffer.getFloat32(this.index);return this.index+=4,e}readBoolean(){return this.readByte()!=0}},sr=class{parent;skinIndex;slotIndex;mesh;inheritTimeline;constructor(e,t,s,i,r){this.mesh=e,this.skinIndex=t,this.slotIndex=s,this.parent=i,this.inheritTimeline=r}},ir=class{constructor(e=null,t=null,s=0){this.bones=e,this.vertices=t,this.length=s}};function pt(e,t,s){let i=e.readFloat(),r=e.readFloat()*s;for(let h=0,l=0,n=t.getFrameCount()-1;t.setFrame(h,i,r),h!=n;h++){let a=e.readFloat(),o=e.readFloat()*s;switch(e.readByte()){case kt:t.setStepped(h);break;case Ft:at(e,t,l++,h,0,i,a,r,o,s)}i=a,r=o}return t}function Ys(e,t,s){let i=e.readFloat(),r=e.readFloat()*s,h=e.readFloat()*s;for(let l=0,n=0,a=t.getFrameCount()-1;t.setFrame(l,i,r,h),l!=a;l++){let o=e.readFloat(),c=e.readFloat()*s,d=e.readFloat()*s;switch(e.readByte()){case kt:t.setStepped(l);break;case Ft:at(e,t,n++,l,0,i,o,r,c,s),at(e,t,n++,l,1,i,o,h,d,s)}i=o,r=c,h=d}return t}function at(e,t,s,i,r,h,l,n,a,o){t.setBezier(s,i,r,h,n,e.readFloat(),e.readFloat()*o,e.readFloat(),e.readFloat()*o,l,a)}var rr=0,nr=1,ar=2,lr=3,or=4,hr=5,cr=6,dr=7,fr=8,ur=9,mr=10,gr=0,xr=1,pr=2,wr=3,br=4,vr=5,yr=0,Ar=1,Cr=0,Sr=1,Ir=2,Tr=0,Mr=1,Er=2,Yr=4,Rr=5,kr=6,Fr=7,Xr=8,kt=1,Ft=2,wi=class{minX=0;minY=0;maxX=0;maxY=0;boundingBoxes=new Array;polygons=new Array;polygonPool=new $t(()=>P.newFloatArray(16));update(e,t){if(!e)throw new Error("skeleton cannot be null.");let s=this.boundingBoxes,i=this.polygons,r=this.polygonPool,h=e.slots,l=h.length;s.length=0,r.freeAll(i),i.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 cs){let c=o;s.push(c);let d=r.obtain();d.length!=c.worldVerticesLength&&(d=P.newFloatArray(c.worldVerticesLength)),i.push(d),c.computeWorldVertices(a,0,c.worldVerticesLength,d,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,i=Number.NEGATIVE_INFINITY,r=this.polygons;for(let h=0,l=r.length;h<l;h++){let n=r[h],a=n;for(let o=0,c=n.length;o<c;o+=2){let d=a[o],f=a[o+1];e=Math.min(e,d),t=Math.min(t,f),s=Math.max(s,d),i=Math.max(i,f)}}this.minX=e,this.minY=t,this.maxX=s,this.maxY=i}aabbContainsPoint(e,t){return e>=this.minX&&e<=this.maxX&&t>=this.minY&&t<=this.maxY}aabbIntersectsSegment(e,t,s,i){let r=this.minX,h=this.minY,l=this.maxX,n=this.maxY;if(e<=r&&s<=r||t<=h&&i<=h||e>=l&&s>=l||t>=n&&i>=n)return!1;let a=(i-t)/(s-e),o=a*(r-e)+t;if(o>h&&o<n||(o=a*(l-e)+t,o>h&&o<n))return!0;let c=(h-t)/a+e;return c>r&&c<l||(c=(n-t)/a+e,c>r&&c<l)}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 i=0,r=s.length;i<r;i++)if(this.containsPointPolygon(s[i],e,t))return this.boundingBoxes[i];return null}containsPointPolygon(e,t,s){let i=e,r=e.length,h=r-2,l=!1;for(let n=0;n<r;n+=2){let a=i[n+1],o=i[h+1];if(a<s&&o>=s||o<s&&a>=s){let c=i[n];c+(s-a)/(o-a)*(i[h]-c)<t&&(l=!l)}h=n}return l}intersectsSegment(e,t,s,i){let r=this.polygons;for(let h=0,l=r.length;h<l;h++)if(this.intersectsSegmentPolygon(r[h],e,t,s,i))return this.boundingBoxes[h];return null}intersectsSegmentPolygon(e,t,s,i,r){let h=e,l=e.length,n=t-i,a=s-r,o=t*r-s*i,c=h[l-2],d=h[l-1];for(let f=0;f<l;f+=2){let m=h[f],u=h[f+1],g=c*u-d*m,w=c-m,b=d-u,x=n*b-a*w,p=(o*w-n*g)/x;if((p>=c&&p<=m||p>=m&&p<=c)&&(p>=t&&p<=i||p>=i&&p<=t)){let v=(o*b-a*g)/x;if((v>=d&&v<=u||v>=u&&v<=d)&&(v>=s&&v<=r||v>=r&&v<=s))return!0}c=m,d=u}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}},bi=class vt{convexPolygons=new Array;convexPolygonsIndices=new Array;indicesArray=new Array;isConcaveArray=new Array;triangles=new Array;polygonPool=new $t(()=>new Array);polygonIndicesPool=new $t(()=>new Array);triangulate(t){let s=t,i=t.length>>1,r=this.indicesArray;r.length=0;for(let n=0;n<i;n++)r[n]=n;let h=this.isConcaveArray;h.length=0;for(let n=0,a=i;n<a;++n)h[n]=vt.isConcave(n,i,s,r);let l=this.triangles;for(l.length=0;i>3;){let n=i-1,a=0,o=1;for(;;){t:if(!h[a]){let f=r[n]<<1,m=r[a]<<1,u=r[o]<<1,g=s[f],w=s[f+1],b=s[m],x=s[m+1],p=s[u],v=s[u+1];for(let y=(o+1)%i;y!=n;y=(y+1)%i){if(!h[y])continue;let A=r[y]<<1,C=s[A],S=s[A+1];if(vt.positiveArea(p,v,g,w,C,S)&&vt.positiveArea(g,w,b,x,C,S)&&vt.positiveArea(b,x,p,v,C,S))break t}break}if(o==0){do{if(!h[a])break;a--}while(a>0);break}n=a,a=o,o=(o+1)%i}l.push(r[(i+a-1)%i]),l.push(r[a]),l.push(r[(a+1)%i]),r.splice(a,1),h.splice(a,1),i--;let c=(i+a-1)%i,d=a==i?0:a;h[c]=vt.isConcave(c,i,s,r),h[d]=vt.isConcave(d,i,s,r)}return i==3&&(l.push(r[2]),l.push(r[0]),l.push(r[1])),l}decompose(t,s){let i=t,r=this.convexPolygons;this.polygonPool.freeAll(r),r.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,d=s.length;c<d;c+=3){let f=s[c]<<1,m=s[c+1]<<1,u=s[c+2]<<1,g=i[f],w=i[f+1],b=i[m],x=i[m+1],p=i[u],v=i[u+1],y=!1;if(a==f){let A=n.length-4,C=vt.winding(n[A],n[A+1],n[A+2],n[A+3],p,v),S=vt.winding(p,v,n[0],n[1],n[2],n[3]);C==o&&S==o&&(n.push(p),n.push(v),l.push(u),y=!0)}y||(n.length>0?(r.push(n),h.push(l)):(this.polygonPool.free(n),this.polygonIndicesPool.free(l)),n=this.polygonPool.obtain(),n.length=0,n.push(g),n.push(w),n.push(b),n.push(x),n.push(p),n.push(v),l=this.polygonIndicesPool.obtain(),l.length=0,l.push(f),l.push(m),l.push(u),o=vt.winding(g,w,b,x,p,v),a=f)}n.length>0&&(r.push(n),h.push(l));for(let c=0,d=r.length;c<d;c++){if(l=h[c],l.length==0)continue;let f=l[0],m=l[l.length-1];n=r[c];let u=n.length-4,g=n[u],w=n[u+1],b=n[u+2],x=n[u+3],p=n[0],v=n[1],y=n[2],A=n[3],C=vt.winding(g,w,b,x,p,v);for(let S=0;S<d;S++){if(S==c)continue;let T=h[S];if(T.length!=3)continue;let R=T[0],k=T[1],F=T[2],X=r[S],E=X[X.length-2],Y=X[X.length-1];if(R!=f||k!=m)continue;let B=vt.winding(g,w,b,x,E,Y),st=vt.winding(E,Y,p,v,y,A);B==C&&st==C&&(X.length=0,T.length=0,n.push(E),n.push(Y),l.push(F),g=b,w=x,b=E,x=Y,S=0)}}for(let c=r.length-1;c>=0;c--)n=r[c],n.length==0&&(r.splice(c,1),this.polygonPool.free(n),l=h[c],h.splice(c,1),this.polygonIndicesPool.free(l));return r}static isConcave(t,s,i,r){let h=r[(s+t-1)%s]<<1,l=r[t]<<1,n=r[(t+1)%s]<<1;return!this.positiveArea(i[h],i[h+1],i[l],i[l+1],i[n],i[n+1])}static positiveArea(t,s,i,r,h,l){return t*(l-r)+i*(s-l)+h*(r-s)>=0}static winding(t,s,i,r,h,l){let n=i-t,a=r-s;return h*a-l*n+n*s-t*a>=0?1:-1}},vi=class Ns{triangulator=new bi;clippingPolygon=new Array;clipOutput=new Array;clippedVertices=new Array;clippedUVs=new Array;clippedTriangles=new Array;scratch=new Array;clipAttachment=null;clippingPolygons=null;clipStart(t,s){if(this.clipAttachment)return 0;this.clipAttachment=s;let i=s.worldVerticesLength,r=P.setArraySize(this.clippingPolygon,i);s.computeWorldVertices(t,0,i,r,0,2);let h=this.clippingPolygon;Ns.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];Ns.makeClockwise(o),o.push(o[0]),o.push(o[1])}return l.length}clipEndWithSlot(t){this.clipAttachment&&this.clipAttachment.endSlot==t.data&&this.clipEnd()}clipEnd(){this.clipAttachment&&(this.clipAttachment=null,this.clippingPolygons=null,this.clippedVertices.length=0,this.clippedTriangles.length=0,this.clippingPolygon.length=0)}isClipping(){return this.clipAttachment!=null}clipTriangles(t,s,i,r,h,l,n,a){let o,c,d,f,m,u;typeof s=="number"?(o=i,c=r,d=h,f=l,m=n,u=a):(o=s,c=i,d=r,f=h,m=l,u=n),d&&f&&m&&typeof u=="boolean"?this.clipTrianglesRender(t,o,c,d,f,m,u):this.clipTrianglesNoRender(t,o,c)}clipTrianglesNoRender(t,s,i){let r=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<i;c+=3){let d=s[c]<<1,f=t[d],m=t[d+1];d=s[c+1]<<1;let u=t[d],g=t[d+1];d=s[c+2]<<1;let w=t[d],b=t[d+1];for(let x=0;x<a;x++){let p=h.length;if(this.clip(f,m,u,g,w,b,n[x],r)){let v=r.length;if(v==0)continue;let y=v>>1,A=this.clipOutput,C=P.setArraySize(h,p+y*2);for(let T=0;T<v;T+=2,p+=2){let R=A[T],k=A[T+1];C[p]=R,C[p+1]=k}p=l.length;let S=P.setArraySize(l,p+3*(y-2));y--;for(let T=1;T<y;T++,p+=3)S[p]=o,S[p+1]=o+T,S[p+2]=o+T+1;o+=y+1}else{let v=P.setArraySize(h,p+6);v[p]=f,v[p+1]=m,v[p+2]=u,v[p+3]=g,v[p+4]=w,v[p+5]=b,p=l.length;let y=P.setArraySize(l,p+3);y[p]=o,y[p+1]=o+1,y[p+2]=o+2,o+=3;break}}}}clipTrianglesRender(t,s,i,r,h,l,n){let a=this.clipOutput,o=this.clippedVertices,c=this.clippedTriangles,d=this.clippingPolygons,f=d.length,m=n?12:8,u=0;o.length=0,c.length=0;for(let g=0;g<i;g+=3){let w=s[g]<<1,b=t[w],x=t[w+1],p=r[w],v=r[w+1];w=s[g+1]<<1;let y=t[w],A=t[w+1],C=r[w],S=r[w+1];w=s[g+2]<<1;let T=t[w],R=t[w+1],k=r[w],F=r[w+1];for(let X=0;X<f;X++){let E=o.length;if(this.clip(b,x,y,A,T,R,d[X],a)){let Y=a.length;if(Y==0)continue;let B=A-R,st=T-y,tt=b-T,it=R-x,ct=1/(B*tt+st*(x-R)),lt=Y>>1,ut=this.clipOutput,W=P.setArraySize(o,E+lt*m);for(let ht=0;ht<Y;ht+=2,E+=m){let bt=ut[ht],mt=ut[ht+1];W[E]=bt,W[E+1]=mt,W[E+2]=h.r,W[E+3]=h.g,W[E+4]=h.b,W[E+5]=h.a;let gt=bt-T,xt=mt-R,Ct=(B*gt+st*xt)*ct,zt=(it*gt+tt*xt)*ct,Jt=1-Ct-zt;W[E+6]=p*Ct+C*zt+k*Jt,W[E+7]=v*Ct+S*zt+F*Jt,n&&(W[E+8]=l.r,W[E+9]=l.g,W[E+10]=l.b,W[E+11]=l.a)}E=c.length;let nt=P.setArraySize(c,E+3*(lt-2));lt--;for(let ht=1;ht<lt;ht++,E+=3)nt[E]=u,nt[E+1]=u+ht,nt[E+2]=u+ht+1;u+=lt+1}else{let Y=P.setArraySize(o,E+3*m);Y[E]=b,Y[E+1]=x,Y[E+2]=h.r,Y[E+3]=h.g,Y[E+4]=h.b,Y[E+5]=h.a,n?(Y[E+6]=p,Y[E+7]=v,Y[E+8]=l.r,Y[E+9]=l.g,Y[E+10]=l.b,Y[E+11]=l.a,Y[E+12]=y,Y[E+13]=A,Y[E+14]=h.r,Y[E+15]=h.g,Y[E+16]=h.b,Y[E+17]=h.a,Y[E+18]=C,Y[E+19]=S,Y[E+20]=l.r,Y[E+21]=l.g,Y[E+22]=l.b,Y[E+23]=l.a,Y[E+24]=T,Y[E+25]=R,Y[E+26]=h.r,Y[E+27]=h.g,Y[E+28]=h.b,Y[E+29]=h.a,Y[E+30]=k,Y[E+31]=F,Y[E+32]=l.r,Y[E+33]=l.g,Y[E+34]=l.b,Y[E+35]=l.a):(Y[E+6]=p,Y[E+7]=v,Y[E+8]=y,Y[E+9]=A,Y[E+10]=h.r,Y[E+11]=h.g,Y[E+12]=h.b,Y[E+13]=h.a,Y[E+14]=C,Y[E+15]=S,Y[E+16]=T,Y[E+17]=R,Y[E+18]=h.r,Y[E+19]=h.g,Y[E+20]=h.b,Y[E+21]=h.a,Y[E+22]=k,Y[E+23]=F),E=c.length;let B=P.setArraySize(c,E+3);B[E]=u,B[E+1]=u+1,B[E+2]=u+2,u+=3;break}}}}clipTrianglesUnpacked(t,s,i,r){let h=this.clipOutput,l=this.clippedVertices,n=this.clippedUVs,a=this.clippedTriangles,o=this.clippingPolygons,c=o.length,d=0;l.length=0,n.length=0,a.length=0;for(let f=0;f<i;f+=3){let m=s[f]<<1,u=t[m],g=t[m+1],w=r[m],b=r[m+1];m=s[f+1]<<1;let x=t[m],p=t[m+1],v=r[m],y=r[m+1];m=s[f+2]<<1;let A=t[m],C=t[m+1],S=r[m],T=r[m+1];for(let R=0;R<c;R++){let k=l.length;if(this.clip(u,g,x,p,A,C,o[R],h)){let F=h.length;if(F==0)continue;let X=p-C,E=A-x,Y=u-A,B=C-g,st=1/(X*Y+E*(g-C)),tt=F>>1,it=this.clipOutput,ct=P.setArraySize(l,k+tt*2),lt=P.setArraySize(n,k+tt*2);for(let W=0;W<F;W+=2,k+=2){let nt=it[W],ht=it[W+1];ct[k]=nt,ct[k+1]=ht;let bt=nt-A,mt=ht-C,gt=(X*bt+E*mt)*st,xt=(B*bt+Y*mt)*st,Ct=1-gt-xt;lt[k]=w*gt+v*xt+S*Ct,lt[k+1]=b*gt+y*xt+T*Ct}k=a.length;let ut=P.setArraySize(a,k+3*(tt-2));tt--;for(let W=1;W<tt;W++,k+=3)ut[k]=d,ut[k+1]=d+W,ut[k+2]=d+W+1;d+=tt+1}else{let F=P.setArraySize(l,k+6);F[k]=u,F[k+1]=g,F[k+2]=x,F[k+3]=p,F[k+4]=A,F[k+5]=C;let X=P.setArraySize(n,k+3*2);X[k]=w,X[k+1]=b,X[k+2]=v,X[k+3]=y,X[k+4]=S,X[k+5]=T,k=a.length;let E=P.setArraySize(a,k+3);E[k]=d,E[k+1]=d+1,E[k+2]=d+2,d+=3;break}}}}clip(t,s,i,r,h,l,n,a){let o=a,c=!1,d;n.length%4>=2?(d=a,a=this.scratch):d=this.scratch,d.length=0,d.push(t),d.push(s),d.push(i),d.push(r),d.push(h),d.push(l),d.push(t),d.push(s),a.length=0;let f=n.length-4,m=n;for(let u=0;;u+=2){let g=m[u],w=m[u+1],b=g-m[u+2],x=w-m[u+3],p=a.length,v=d;for(let A=0,C=d.length-2;A<C;){let S=v[A],T=v[A+1];A+=2;let R=v[A],k=v[A+1],F=x*(g-R)>b*(w-k),X=x*(g-S)-b*(w-T);if(X>0){if(F){a.push(R),a.push(k);continue}let E=R-S,Y=k-T,B=X/(E*x-Y*b);if(B>=0&&B<=1)a.push(S+E*B),a.push(T+Y*B);else{a.push(R),a.push(k);continue}}else if(F){let E=R-S,Y=k-T,B=X/(E*x-Y*b);if(B>=0&&B<=1)a.push(S+E*B),a.push(T+Y*B),a.push(R),a.push(k);else{a.push(R),a.push(k);continue}}c=!0}if(p==a.length)return o.length=0,!0;if(a.push(a[0]),a.push(a[1]),u==f)break;let y=a;a=d,a.length=0,d=y}if(o!=a){o.length=0;for(let u=0,g=a.length-2;u<g;u++)o[u]=a[u]}else o.length=o.length-2;return c}static makeClockwise(t){let s=t,i=t.length,r=s[i-2]*s[1]-s[0]*s[i-1],h=0,l=0,n=0,a=0;for(let o=0,c=i-3;o<c;o+=2)h=s[o],l=s[o+1],n=s[o+2],a=s[o+3],r+=h*a-n*l;if(!(r<0))for(let o=0,c=i-2,d=i>>1;o<d;o+=2){let f=s[o],m=s[o+1],u=c-o;s[o]=s[u],s[o+1]=s[u+1],s[u]=f,s[u+1]=m}}},Lr=class{attachmentLoader;scale=1;linkedMeshes=new Array;constructor(e){this.attachmentLoader=e}readSkeletonData(e){let t=this.scale,s=new Ss,i=typeof e=="string"?JSON.parse(e):e,r=i.skeleton;if(r&&(s.hash=r.hash,s.version=r.spine,s.x=r.x,s.y=r.y,s.width=r.width,s.height=r.height,s.referenceScale=M(r,"referenceScale",100)*t,s.fps=r.fps,s.imagesPath=r.images??null,s.audioPath=r.audio??null),i.bones)for(let h=0;h<i.bones.length;h++){let l=i.bones[h],n=null,a=M(l,"parent",null);a&&(n=s.findBone(a));let o=new ms(s.bones.length,l.name,n);o.length=M(l,"length",0)*t,o.x=M(l,"x",0)*t,o.y=M(l,"y",0)*t,o.rotation=M(l,"rotation",0),o.scaleX=M(l,"scaleX",1),o.scaleY=M(l,"scaleY",1),o.shearX=M(l,"shearX",0),o.shearY=M(l,"shearY",0),o.inherit=P.enumValue(me,M(l,"inherit","Normal")),o.skinRequired=M(l,"skin",!1);let c=M(l,"color",null);c&&o.color.setFromString(c),s.bones.push(o)}if(i.slots)for(let h=0;h<i.slots.length;h++){let l=i.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 Ts(s.slots.length,n,a),c=M(l,"color",null);c&&o.color.setFromString(c);let d=M(l,"dark",null);d&&(o.darkColor=et.fromString(d)),o.attachmentName=M(l,"attachment",null),o.blendMode=P.enumValue(Ms,M(l,"blend","normal")),o.visible=M(l,"visible",!0),s.slots.push(o)}if(i.ik)for(let h=0;h<i.ik.length;h++){let l=i.ik[h],n=new bs(l.name);n.order=M(l,"order",0),n.skinRequired=M(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=M(l,"mix",1),n.softness=M(l,"softness",0)*t,n.bendDirection=M(l,"bendPositive",!0)?1:-1,n.compress=M(l,"compress",!1),n.stretch=M(l,"stretch",!1),n.uniform=M(l,"uniform",!1),s.ikConstraints.push(n)}if(i.transform)for(let h=0;h<i.transform.length;h++){let l=i.transform[h],n=new Es(l.name);n.order=M(l,"order",0),n.skinRequired=M(l,"skin",!1);for(let c=0;c<l.bones.length;c++){let d=l.bones[c],f=s.findBone(d);if(!f)throw new Error(`Couldn't find bone ${d} for transform constraint ${l.name}.`);n.bones.push(f)}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=M(l,"local",!1),n.relative=M(l,"relative",!1),n.offsetRotation=M(l,"rotation",0),n.offsetX=M(l,"x",0)*t,n.offsetY=M(l,"y",0)*t,n.offsetScaleX=M(l,"scaleX",0),n.offsetScaleY=M(l,"scaleY",0),n.offsetShearY=M(l,"shearY",0),n.mixRotate=M(l,"mixRotate",1),n.mixX=M(l,"mixX",1),n.mixY=M(l,"mixY",n.mixX),n.mixScaleX=M(l,"mixScaleX",1),n.mixScaleY=M(l,"mixScaleY",n.mixScaleX),n.mixShearY=M(l,"mixShearY",1),s.transformConstraints.push(n)}if(i.path)for(let h=0;h<i.path.length;h++){let l=i.path[h],n=new vs(l.name);n.order=M(l,"order",0),n.skinRequired=M(l,"skin",!1);for(let c=0;c<l.bones.length;c++){let d=l.bones[c],f=s.findBone(d);if(!f)throw new Error(`Couldn't find bone ${d} for path constraint ${l.name}.`);n.bones.push(f)}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(ys,M(l,"positionMode","Percent")),n.spacingMode=P.enumValue(As,M(l,"spacingMode","Length")),n.rotateMode=P.enumValue(Cs,M(l,"rotateMode","Tangent")),n.offsetRotation=M(l,"rotation",0),n.position=M(l,"position",0),n.positionMode==0&&(n.position*=t),n.spacing=M(l,"spacing",0),(n.spacingMode==0||n.spacingMode==1)&&(n.spacing*=t),n.mixRotate=M(l,"mixRotate",1),n.mixX=M(l,"mixX",1),n.mixY=M(l,"mixY",n.mixX),s.pathConstraints.push(n)}if(i.physics)for(let h=0;h<i.physics.length;h++){const l=i.physics[h],n=new xi(l.name);n.order=M(l,"order",0),n.skinRequired=M(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=M(l,"x",0),n.y=M(l,"y",0),n.rotate=M(l,"rotate",0),n.scaleX=M(l,"scaleX",0),n.shearX=M(l,"shearX",0),n.limit=M(l,"limit",5e3)*t,n.step=1/M(l,"fps",60),n.inertia=M(l,"inertia",1),n.strength=M(l,"strength",100),n.damping=M(l,"damping",1),n.massInverse=1/M(l,"mass",1),n.wind=M(l,"wind",0),n.gravity=M(l,"gravity",0),n.mix=M(l,"mix",1),n.inertiaGlobal=M(l,"inertiaGlobal",!1),n.strengthGlobal=M(l,"strengthGlobal",!1),n.dampingGlobal=M(l,"dampingGlobal",!1),n.massGlobal=M(l,"massGlobal",!1),n.windGlobal=M(l,"windGlobal",!1),n.gravityGlobal=M(l,"gravityGlobal",!1),n.mixGlobal=M(l,"mixGlobal",!1),s.physicsConstraints.push(n)}if(i.skins)for(let h=0;h<i.skins.length;h++){let l=i.skins[h],n=new ge(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 d in c){let f=this.readAttachment(c[d],n,o.index,d,s);f&&n.setAttachment(o.index,d,f)}}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,i.events)for(let h in i.events){let l=i.events[h],n=new ws(h);n.intValue=M(l,"int",0),n.floatValue=M(l,"float",0),n.stringValue=M(l,"string",""),n.audioPath=M(l,"audio",null),n.audioPath&&(n.volume=M(l,"volume",1),n.balance=M(l,"balance",0)),s.events.push(n)}if(i.animations)for(let h in i.animations){let l=i.animations[h];this.readAnimation(l,h,s)}return s}readAttachment(e,t,s,i,r){let h=this.scale;switch(i=M(e,"name",i),M(e,"type","region")){case"region":{let l=M(e,"path",i),n=this.readSequence(M(e,"sequence",null)),a=this.attachmentLoader.newRegionAttachment(t,i,l,n);if(!a)return null;a.path=l,a.x=M(e,"x",0)*h,a.y=M(e,"y",0)*h,a.scaleX=M(e,"scaleX",1),a.scaleY=M(e,"scaleY",1),a.rotation=M(e,"rotation",0),a.width=e.width*h,a.height=e.height*h,a.sequence=n;let o=M(e,"color",null);return o&&a.color.setFromString(o),a.region!=null&&a.updateRegion(),a}case"boundingbox":{let l=this.attachmentLoader.newBoundingBoxAttachment(t,i);if(!l)return null;this.readVertices(e,l,e.vertexCount<<1);let n=M(e,"color",null);return n&&l.color.setFromString(n),l}case"mesh":case"linkedmesh":{let l=M(e,"path",i),n=this.readSequence(M(e,"sequence",null)),a=this.attachmentLoader.newMeshAttachment(t,i,l,n);if(!a)return null;a.path=l;let o=M(e,"color",null);o&&a.color.setFromString(o),a.width=M(e,"width",0)*h,a.height=M(e,"height",0)*h,a.sequence=n;let c=M(e,"parent",null);if(c)return this.linkedMeshes.push(new Pr(a,M(e,"skin",null),s,c,M(e,"timelines",!0))),a;let d=e.uvs;return this.readVertices(e,a,d.length),a.triangles=e.triangles,a.regionUVs=d,a.region!=null&&a.updateRegion(),a.edges=M(e,"edges",null),a.hullLength=M(e,"hull",0)*2,a}case"path":{let l=this.attachmentLoader.newPathAttachment(t,i);if(!l)return null;l.closed=M(e,"closed",!1),l.constantSpeed=M(e,"constantSpeed",!0);let n=e.vertexCount;this.readVertices(e,l,n<<1);let a=P.newArray(n/3,0);for(let c=0;c<e.lengths.length;c++)a[c]=e.lengths[c]*h;l.lengths=a;let o=M(e,"color",null);return o&&l.color.setFromString(o),l}case"point":{let l=this.attachmentLoader.newPointAttachment(t,i);if(!l)return null;l.x=M(e,"x",0)*h,l.y=M(e,"y",0)*h,l.rotation=M(e,"rotation",0);let n=M(e,"color",null);return n&&l.color.setFromString(n),l}case"clipping":{let l=this.attachmentLoader.newClippingAttachment(t,i);if(!l)return null;let n=M(e,"end",null);n&&(l.endSlot=r.findSlot(n));let a=e.vertexCount;this.readVertices(e,l,a<<1);let o=M(e,"color",null);return o&&l.color.setFromString(o),l}}return null}readSequence(e){if(e==null)return null;let t=new js(M(e,"count",0));return t.start=M(e,"start",1),t.digits=M(e,"digits",0),t.setupIndex=M(e,"setup",0),t}readVertices(e,t,s){let i=this.scale;t.worldVerticesLength=s;let r=e.vertices;if(s==r.length){let n=P.toFloatArray(r);if(i!=1)for(let a=0,o=r.length;a<o;a++)n[a]*=i;t.vertices=n;return}let h=new Array,l=new Array;for(let n=0,a=r.length;n<a;){let o=r[n++];l.push(o);for(let c=n+o*4;n<c;n+=4)l.push(r[n]),h.push(r[n+1]*i),h.push(r[n+2]*i),h.push(r[n+3])}t.bones=l,t.vertices=P.toFloatArray(h)}readAnimation(e,t,s){let i=this.scale,r=new Array;if(e.slots)for(let l in e.slots){let n=e.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 d=n[c];if(!d)continue;let f=d.length;if(c=="attachment"){let m=new Ot(f,o);for(let u=0;u<f;u++){let g=d[u];m.setFrame(u,M(g,"time",0),M(g,"name",null))}r.push(m)}else if(c=="rgba"){let m=new Ue(f,f<<2,o),u=d[0],g=M(u,"time",0),w=et.fromString(u.color);for(let b=0,x=0;;b++){m.setFrame(b,g,w.r,w.g,w.b,w.a);let p=d[b+1];if(!p){m.shrink(x);break}let v=M(p,"time",0),y=et.fromString(p.color),A=u.curve;A&&(x=ot(A,m,x,b,0,g,v,w.r,y.r,1),x=ot(A,m,x,b,1,g,v,w.g,y.g,1),x=ot(A,m,x,b,2,g,v,w.b,y.b,1),x=ot(A,m,x,b,3,g,v,w.a,y.a,1)),g=v,w=y,u=p}r.push(m)}else if(c=="rgb"){let m=new ze(f,f*3,o),u=d[0],g=M(u,"time",0),w=et.fromString(u.color);for(let b=0,x=0;;b++){m.setFrame(b,g,w.r,w.g,w.b);let p=d[b+1];if(!p){m.shrink(x);break}let v=M(p,"time",0),y=et.fromString(p.color),A=u.curve;A&&(x=ot(A,m,x,b,0,g,v,w.r,y.r,1),x=ot(A,m,x,b,1,g,v,w.g,y.g,1),x=ot(A,m,x,b,2,g,v,w.b,y.b,1)),g=v,w=y,u=p}r.push(m)}else if(c=="alpha")r.push(It(d,new We(f,f,o),0,1));else if(c=="rgba2"){let m=new qe(f,f*7,o),u=d[0],g=M(u,"time",0),w=et.fromString(u.light),b=et.fromString(u.dark);for(let x=0,p=0;;x++){m.setFrame(x,g,w.r,w.g,w.b,w.a,b.r,b.g,b.b);let v=d[x+1];if(!v){m.shrink(p);break}let y=M(v,"time",0),A=et.fromString(v.light),C=et.fromString(v.dark),S=u.curve;S&&(p=ot(S,m,p,x,0,g,y,w.r,A.r,1),p=ot(S,m,p,x,1,g,y,w.g,A.g,1),p=ot(S,m,p,x,2,g,y,w.b,A.b,1),p=ot(S,m,p,x,3,g,y,w.a,A.a,1),p=ot(S,m,p,x,4,g,y,b.r,C.r,1),p=ot(S,m,p,x,5,g,y,b.g,C.g,1),p=ot(S,m,p,x,6,g,y,b.b,C.b,1)),g=y,w=A,b=C,u=v}r.push(m)}else if(c=="rgb2"){let m=new Ge(f,f*6,o),u=d[0],g=M(u,"time",0),w=et.fromString(u.light),b=et.fromString(u.dark);for(let x=0,p=0;;x++){m.setFrame(x,g,w.r,w.g,w.b,b.r,b.g,b.b);let v=d[x+1];if(!v){m.shrink(p);break}let y=M(v,"time",0),A=et.fromString(v.light),C=et.fromString(v.dark),S=u.curve;S&&(p=ot(S,m,p,x,0,g,y,w.r,A.r,1),p=ot(S,m,p,x,1,g,y,w.g,A.g,1),p=ot(S,m,p,x,2,g,y,w.b,A.b,1),p=ot(S,m,p,x,3,g,y,b.r,C.r,1),p=ot(S,m,p,x,4,g,y,b.g,C.g,1),p=ot(S,m,p,x,5,g,y,b.b,C.b,1)),g=y,w=A,b=C,u=v}r.push(m)}}}if(e.bones)for(let l in e.bones){let n=e.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 d=n[c],f=d.length;if(f!=0){if(c==="rotate")r.push(It(d,new te(f,f,o),0,1));else if(c==="translate"){let m=new ke(f,f<<1,o);r.push(Rs(d,m,"x","y",0,i))}else if(c==="translatex"){let m=new Fe(f,f,o);r.push(It(d,m,0,i))}else if(c==="translatey"){let m=new Xe(f,f,o);r.push(It(d,m,0,i))}else if(c==="scale"){let m=new Le(f,f<<1,o);r.push(Rs(d,m,"x","y",1,1))}else if(c==="scalex"){let m=new Pe(f,f,o);r.push(It(d,m,1,1))}else if(c==="scaley"){let m=new Be(f,f,o);r.push(It(d,m,1,1))}else if(c==="shear"){let m=new Ve(f,f<<1,o);r.push(Rs(d,m,"x","y",0,1))}else if(c==="shearx"){let m=new Oe(f,f,o);r.push(It(d,m,0,1))}else if(c==="sheary"){let m=new De(f,f,o);r.push(It(d,m,0,1))}else if(c==="inherit"){let m=new Ne(f,a.index);for(let u=0;u<d.length;u++){let g=d[u];m.setFrame(u,M(g,"time",0),P.enumValue(me,M(g,"inherit","Normal")))}r.push(m)}}}}if(e.ik)for(let l in e.ik){let n=e.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),d=new _e(n.length,n.length<<1,c),f=M(a,"time",0),m=M(a,"mix",1),u=M(a,"softness",0)*i;for(let g=0,w=0;;g++){d.setFrame(g,f,m,u,M(a,"bendPositive",!0)?1:-1,M(a,"compress",!1),M(a,"stretch",!1));let b=n[g+1];if(!b){d.shrink(w);break}let x=M(b,"time",0),p=M(b,"mix",1),v=M(b,"softness",0)*i,y=a.curve;y&&(w=ot(y,d,w,g,0,f,x,m,p,1),w=ot(y,d,w,g,1,f,x,u,v,i)),f=x,m=p,u=v,a=b}r.push(d)}if(e.transform)for(let l in e.transform){let n=e.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),d=new je(n.length,n.length*6,c),f=M(a,"time",0),m=M(a,"mixRotate",1),u=M(a,"mixX",1),g=M(a,"mixY",u),w=M(a,"mixScaleX",1),b=M(a,"mixScaleY",w),x=M(a,"mixShearY",1);for(let p=0,v=0;;p++){d.setFrame(p,f,m,u,g,w,b,x);let y=n[p+1];if(!y){d.shrink(v);break}let A=M(y,"time",0),C=M(y,"mixRotate",1),S=M(y,"mixX",1),T=M(y,"mixY",S),R=M(y,"mixScaleX",1),k=M(y,"mixScaleY",R),F=M(y,"mixShearY",1),X=a.curve;X&&(v=ot(X,d,v,p,0,f,A,m,C,1),v=ot(X,d,v,p,1,f,A,u,S,1),v=ot(X,d,v,p,2,f,A,g,T,1),v=ot(X,d,v,p,3,f,A,w,R,1),v=ot(X,d,v,p,4,f,A,b,k,1),v=ot(X,d,v,p,5,f,A,x,F,1)),f=A,m=C,u=S,g=T,w=R,b=k,w=R,a=y}r.push(d)}if(e.path)for(let l in e.path){let n=e.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 d=n[c],f=d[0];if(!f)continue;let m=d.length;if(c==="position"){let u=new Ze(m,m,o);r.push(It(d,u,0,a.positionMode==0?i:1))}else if(c==="spacing"){let u=new Ke(m,m,o);r.push(It(d,u,0,a.spacingMode==0||a.spacingMode==1?i:1))}else if(c==="mix"){let u=new Je(m,m*3,o),g=M(f,"time",0),w=M(f,"mixRotate",1),b=M(f,"mixX",1),x=M(f,"mixY",b);for(let p=0,v=0;;p++){u.setFrame(p,g,w,b,x);let y=d[p+1];if(!y){u.shrink(v);break}let A=M(y,"time",0),C=M(y,"mixRotate",1),S=M(y,"mixX",1),T=M(y,"mixY",S),R=f.curve;R&&(v=ot(R,u,v,p,0,g,A,w,C,1),v=ot(R,u,v,p,1,g,A,b,S,1),v=ot(R,u,v,p,2,g,A,x,T,1)),g=A,w=C,b=S,x=T,f=y}r.push(u)}}}if(e.physics)for(let l in e.physics){let n=e.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],d=c[0];if(!d)continue;let f=c.length;if(o=="reset"){const u=new ns(f,a);for(let g=0;d!=null;d=c[g+1],g++)u.setFrame(g,M(d,"time",0));r.push(u);continue}let m;if(o=="inertia")m=new Qe(f,f,a);else if(o=="strength")m=new $e(f,f,a);else if(o=="damping")m=new ts(f,f,a);else if(o=="mass")m=new es(f,f,a);else if(o=="wind")m=new ss(f,f,a);else if(o=="gravity")m=new is(f,f,a);else if(o=="mix")m=new rs(f,f,a);else continue;r.push(It(c,m,0,1))}}if(e.attachments)for(let l in e.attachments){let n=e.attachments[l],a=s.findSkin(l);if(!a)throw new Error("Skin not found: "+l);for(let o in n){let c=n[o],d=s.findSlot(o);if(!d)throw new Error("Slot not found: "+o);let f=d.index;for(let m in c){let u=c[m],g=a.getAttachment(f,m);for(let w in u){let b=u[w],x=b[0];if(x){if(w=="deform"){let p=g.bones,v=g.vertices,y=p?v.length/3*2:v.length,A=new He(b.length,b.length,f,g),C=M(x,"time",0);for(let S=0,T=0;;S++){let R,k=M(x,"vertices",null);if(!k)R=p?P.newFloatArray(y):v;else{R=P.newFloatArray(y);let Y=M(x,"offset",0);if(P.arrayCopy(k,0,R,Y,k.length),i!=1)for(let B=Y,st=B+k.length;B<st;B++)R[B]*=i;if(!p)for(let B=0;B<y;B++)R[B]+=v[B]}A.setFrame(S,C,R);let F=b[S+1];if(!F){A.shrink(T);break}let X=M(F,"time",0),E=x.curve;E&&(T=ot(E,A,T,S,0,C,X,0,1,1)),C=X,x=F}r.push(A)}else if(w=="sequence"){let p=new as(b.length,f,g),v=0;for(let y=0;y<b.length;y++){let A=M(x,"delay",v),C=M(x,"time",0),S=Zs[M(x,"mode","hold")],T=M(x,"index",0);p.setFrame(y,C,S,T,A),v=A,x=b[y+1]}r.push(p)}}}}}}if(e.drawOrder){let l=new qt(e.drawOrder.length),n=s.slots.length,a=0;for(let o=0;o<e.drawOrder.length;o++,a++){let c=e.drawOrder[o],d=null,f=M(c,"offsets",null);if(f){d=P.newArray(n,-1);let m=P.newArray(n-f.length,0),u=0,g=0;for(let w=0;w<f.length;w++){let b=f[w],x=s.findSlot(b.slot);if(!x)throw new Error("Slot not found: "+x);let p=x.index;for(;u!=p;)m[g++]=u++;d[u+b.offset]=u++}for(;u<n;)m[g++]=u++;for(let w=n-1;w>=0;w--)d[w]==-1&&(d[w]=m[--g])}l.setFrame(a,M(c,"time",0),d)}r.push(l)}if(e.events){let l=new ce(e.events.length),n=0;for(let a=0;a<e.events.length;a++,n++){let o=e.events[a],c=s.findEvent(o.name);if(!c)throw new Error("Event not found: "+o.name);let d=new ps(P.toSinglePrecision(M(o,"time",0)),c);d.intValue=M(o,"int",c.intValue),d.floatValue=M(o,"float",c.floatValue),d.stringValue=M(o,"string",c.stringValue),d.data.audioPath&&(d.volume=M(o,"volume",1),d.balance=M(o,"balance",0)),l.setFrame(n,d)}r.push(l)}let h=0;for(let l=0,n=r.length;l<n;l++)h=Math.max(h,r[l].getDuration());s.animations.push(new oe(t,r,h))}},Pr=class{parent;skin;slotIndex;mesh;inheritTimeline;constructor(e,t,s,i,r){this.mesh=e,this.skin=t,this.slotIndex=s,this.parent=i,this.inheritTimeline=r}};function It(e,t,s,i){let r=e[0],h=M(r,"time",0),l=M(r,"value",s)*i,n=0;for(let a=0;;a++){t.setFrame(a,h,l);let o=e[a+1];if(!o)return t.shrink(n),t;let c=M(o,"time",0),d=M(o,"value",s)*i;r.curve&&(n=ot(r.curve,t,n,a,0,h,c,l,d,i)),h=c,l=d,r=o}}function Rs(e,t,s,i,r,h){let l=e[0],n=M(l,"time",0),a=M(l,s,r)*h,o=M(l,i,r)*h,c=0;for(let d=0;;d++){t.setFrame(d,n,a,o);let f=e[d+1];if(!f)return t.shrink(c),t;let m=M(f,"time",0),u=M(f,s,r)*h,g=M(f,i,r)*h,w=l.curve;w&&(c=ot(w,t,c,d,0,n,m,a,u,h),c=ot(w,t,c,d,1,n,m,o,g,h)),n=m,a=u,o=g,l=f}}function ot(e,t,s,i,r,h,l,n,a,o){if(e=="stepped")return t.setStepped(i),s;let c=r<<2,d=e[c],f=e[c+1]*o,m=e[c+2],u=e[c+3]*o;return t.setBezier(s,i,r,h,n,d,f,m,u,l,a),s+1}function M(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)));var wt=class{canvas;gl;restorables=[];constructor(e,t={alpha:!0}){if(e instanceof WebGLRenderingContext||typeof WebGL2RenderingContext<"u"&&e instanceof WebGL2RenderingContext)this.gl=e,this.canvas=this.gl.canvas;else{const s=e;this.gl=s.getContext("webgl2",t)||s.getContext("webgl",t),this.canvas=s,s.addEventListener("webglcontextlost",this.contextLostHandler),s.addEventListener("webglcontextrestored",this.contextRestoredHandler)}}contextLostHandler=e=>{e&&e.preventDefault()};contextRestoredHandler=()=>{for(let e=0,t=this.restorables.length;e<t;e++)this.restorables[e].restore()};dispose(){this.canvas.removeEventListener("webglcontextlost",this.contextLostHandler),this.canvas.removeEventListener("webglcontextrestored",this.contextRestoredHandler)}addRestorable(e){this.restorables.push(e)}removeRestorable(e){const t=this.restorables.indexOf(e);t>-1&&this.restorables.splice(t,1)}},_t=class Ie extends ds{context;texture=null;boundUnit=0;useMipMaps=!1;static DISABLE_UNPACK_PREMULTIPLIED_ALPHA_WEBGL=!1;constructor(t,s,i=!1){super(s),this.context=t instanceof wt?t:new wt(t),this.useMipMaps=i,this.restore(),this.context.addRestorable(this)}setFilters(t,s){let i=this.context.gl;this.bind(),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_MIN_FILTER,t),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_MAG_FILTER,Ie.validateMagFilter(s)),this.useMipMaps=Ie.usesMipMaps(t),this.useMipMaps&&i.generateMipmap(i.TEXTURE_2D)}static validateMagFilter(t){switch(t){case 9987:case 9985:case 9986:case 9984:return 9729;default:return t}}static usesMipMaps(t){switch(t){case 9987:case 9985:case 9986:case 9984:return!0;default:return!1}}setWraps(t,s){let i=this.context.gl;this.bind(),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_WRAP_S,t),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_WRAP_T,s)}update(t){let s=this.context.gl;this.texture||(this.texture=this.context.gl.createTexture()),this.bind(),Ie.DISABLE_UNPACK_PREMULTIPLIED_ALPHA_WEBGL&&s.pixelStorei(s.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1),s.texImage2D(s.TEXTURE_2D,0,s.RGBA,s.RGBA,s.UNSIGNED_BYTE,this._image),s.texParameteri(s.TEXTURE_2D,s.TEXTURE_MAG_FILTER,s.LINEAR),s.texParameteri(s.TEXTURE_2D,s.TEXTURE_MIN_FILTER,t?s.LINEAR_MIPMAP_LINEAR:s.LINEAR),s.texParameteri(s.TEXTURE_2D,s.TEXTURE_WRAP_S,s.CLAMP_TO_EDGE),s.texParameteri(s.TEXTURE_2D,s.TEXTURE_WRAP_T,s.CLAMP_TO_EDGE),t&&s.generateMipmap(s.TEXTURE_2D)}restore(){this.texture=null,this.update(this.useMipMaps)}bind(t=0){let s=this.context.gl;this.boundUnit=t,s.activeTexture(s.TEXTURE0+t),s.bindTexture(s.TEXTURE_2D,this.texture)}unbind(){let t=this.context.gl;t.activeTexture(t.TEXTURE0+this.boundUnit),t.bindTexture(t.TEXTURE_2D,null)}dispose(){this.context.removeRestorable(this),this.context.gl.deleteTexture(this.texture)}},yi=class extends oi{constructor(e,t="",s=new xs){super(i=>new _t(e,i),t,s)}},At=class{x=0;y=0;z=0;constructor(e=0,t=0,s=0){this.x=e,this.y=t,this.z=s}setFrom(e){return this.x=e.x,this.y=e.y,this.z=e.z,this}set(e,t,s){return this.x=e,this.y=t,this.z=s,this}add(e){return this.x+=e.x,this.y+=e.y,this.z+=e.z,this}sub(e){return this.x-=e.x,this.y-=e.y,this.z-=e.z,this}scale(e){return this.x*=e,this.y*=e,this.z*=e,this}normalize(){let e=this.length();return e==0?this:(e=1/e,this.x*=e,this.y*=e,this.z*=e,this)}cross(e){return this.set(this.y*e.z-this.z*e.y,this.z*e.x-this.x*e.z,this.x*e.y-this.y*e.x)}multiply(e){let t=e.values;return this.set(this.x*t[V]+this.y*t[q]+this.z*t[G]+t[O],this.x*t[H]+this.y*t[D]+this.z*t[_]+t[N],this.x*t[j]+this.y*t[Z]+this.z*t[U]+t[z])}project(e){let t=e.values,s=1/(this.x*t[J]+this.y*t[Q]+this.z*t[$]+t[K]);return this.set((this.x*t[V]+this.y*t[q]+this.z*t[G]+t[O])*s,(this.x*t[H]+this.y*t[D]+this.z*t[_]+t[N])*s,(this.x*t[j]+this.y*t[Z]+this.z*t[U]+t[z])*s)}dot(e){return this.x*e.x+this.y*e.y+this.z*e.z}length(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z)}distance(e){let t=e.x-this.x,s=e.y-this.y,i=e.z-this.z;return Math.sqrt(t*t+s*s+i*i)}},V=0,q=4,G=8,O=12,H=1,D=5,_=9,N=13,j=2,Z=6,U=10,z=14,J=3,Q=7,$=11,K=15,re=class Yt{temp=new Float32Array(16);values=new Float32Array(16);static xAxis=new At;static yAxis=new At;static zAxis=new At;static tmpMatrix=new Yt;constructor(){let t=this.values;t[V]=1,t[D]=1,t[U]=1,t[K]=1}set(t){return this.values.set(t),this}transpose(){let t=this.temp,s=this.values;return t[V]=s[V],t[q]=s[H],t[G]=s[j],t[O]=s[J],t[H]=s[q],t[D]=s[D],t[_]=s[Z],t[N]=s[Q],t[j]=s[G],t[Z]=s[_],t[U]=s[U],t[z]=s[$],t[J]=s[O],t[Q]=s[N],t[$]=s[z],t[K]=s[K],this.set(t)}identity(){let t=this.values;return t[V]=1,t[q]=0,t[G]=0,t[O]=0,t[H]=0,t[D]=1,t[_]=0,t[N]=0,t[j]=0,t[Z]=0,t[U]=1,t[z]=0,t[J]=0,t[Q]=0,t[$]=0,t[K]=1,this}invert(){let t=this.values,s=this.temp,i=t[J]*t[Z]*t[_]*t[O]-t[j]*t[Q]*t[_]*t[O]-t[J]*t[D]*t[U]*t[O]+t[H]*t[Q]*t[U]*t[O]+t[j]*t[D]*t[$]*t[O]-t[H]*t[Z]*t[$]*t[O]-t[J]*t[Z]*t[G]*t[N]+t[j]*t[Q]*t[G]*t[N]+t[J]*t[q]*t[U]*t[N]-t[V]*t[Q]*t[U]*t[N]-t[j]*t[q]*t[$]*t[N]+t[V]*t[Z]*t[$]*t[N]+t[J]*t[D]*t[G]*t[z]-t[H]*t[Q]*t[G]*t[z]-t[J]*t[q]*t[_]*t[z]+t[V]*t[Q]*t[_]*t[z]+t[H]*t[q]*t[$]*t[z]-t[V]*t[D]*t[$]*t[z]-t[j]*t[D]*t[G]*t[K]+t[H]*t[Z]*t[G]*t[K]+t[j]*t[q]*t[_]*t[K]-t[V]*t[Z]*t[_]*t[K]-t[H]*t[q]*t[U]*t[K]+t[V]*t[D]*t[U]*t[K];if(i==0)throw new Error("non-invertible matrix");let r=1/i;return s[V]=t[_]*t[z]*t[Q]-t[N]*t[U]*t[Q]+t[N]*t[Z]*t[$]-t[D]*t[z]*t[$]-t[_]*t[Z]*t[K]+t[D]*t[U]*t[K],s[q]=t[O]*t[U]*t[Q]-t[G]*t[z]*t[Q]-t[O]*t[Z]*t[$]+t[q]*t[z]*t[$]+t[G]*t[Z]*t[K]-t[q]*t[U]*t[K],s[G]=t[G]*t[N]*t[Q]-t[O]*t[_]*t[Q]+t[O]*t[D]*t[$]-t[q]*t[N]*t[$]-t[G]*t[D]*t[K]+t[q]*t[_]*t[K],s[O]=t[O]*t[_]*t[Z]-t[G]*t[N]*t[Z]-t[O]*t[D]*t[U]+t[q]*t[N]*t[U]+t[G]*t[D]*t[z]-t[q]*t[_]*t[z],s[H]=t[N]*t[U]*t[J]-t[_]*t[z]*t[J]-t[N]*t[j]*t[$]+t[H]*t[z]*t[$]+t[_]*t[j]*t[K]-t[H]*t[U]*t[K],s[D]=t[G]*t[z]*t[J]-t[O]*t[U]*t[J]+t[O]*t[j]*t[$]-t[V]*t[z]*t[$]-t[G]*t[j]*t[K]+t[V]*t[U]*t[K],s[_]=t[O]*t[_]*t[J]-t[G]*t[N]*t[J]-t[O]*t[H]*t[$]+t[V]*t[N]*t[$]+t[G]*t[H]*t[K]-t[V]*t[_]*t[K],s[N]=t[G]*t[N]*t[j]-t[O]*t[_]*t[j]+t[O]*t[H]*t[U]-t[V]*t[N]*t[U]-t[G]*t[H]*t[z]+t[V]*t[_]*t[z],s[j]=t[D]*t[z]*t[J]-t[N]*t[Z]*t[J]+t[N]*t[j]*t[Q]-t[H]*t[z]*t[Q]-t[D]*t[j]*t[K]+t[H]*t[Z]*t[K],s[Z]=t[O]*t[Z]*t[J]-t[q]*t[z]*t[J]-t[O]*t[j]*t[Q]+t[V]*t[z]*t[Q]+t[q]*t[j]*t[K]-t[V]*t[Z]*t[K],s[U]=t[q]*t[N]*t[J]-t[O]*t[D]*t[J]+t[O]*t[H]*t[Q]-t[V]*t[N]*t[Q]-t[q]*t[H]*t[K]+t[V]*t[D]*t[K],s[z]=t[O]*t[D]*t[j]-t[q]*t[N]*t[j]-t[O]*t[H]*t[Z]+t[V]*t[N]*t[Z]+t[q]*t[H]*t[z]-t[V]*t[D]*t[z],s[J]=t[_]*t[Z]*t[J]-t[D]*t[U]*t[J]-t[_]*t[j]*t[Q]+t[H]*t[U]*t[Q]+t[D]*t[j]*t[$]-t[H]*t[Z]*t[$],s[Q]=t[q]*t[U]*t[J]-t[G]*t[Z]*t[J]+t[G]*t[j]*t[Q]-t[V]*t[U]*t[Q]-t[q]*t[j]*t[$]+t[V]*t[Z]*t[$],s[$]=t[G]*t[D]*t[J]-t[q]*t[_]*t[J]-t[G]*t[H]*t[Q]+t[V]*t[_]*t[Q]+t[q]*t[H]*t[$]-t[V]*t[D]*t[$],s[K]=t[q]*t[_]*t[j]-t[G]*t[D]*t[j]+t[G]*t[H]*t[Z]-t[V]*t[_]*t[Z]-t[q]*t[H]*t[U]+t[V]*t[D]*t[U],t[V]=s[V]*r,t[q]=s[q]*r,t[G]=s[G]*r,t[O]=s[O]*r,t[H]=s[H]*r,t[D]=s[D]*r,t[_]=s[_]*r,t[N]=s[N]*r,t[j]=s[j]*r,t[Z]=s[Z]*r,t[U]=s[U]*r,t[z]=s[z]*r,t[J]=s[J]*r,t[Q]=s[Q]*r,t[$]=s[$]*r,t[K]=s[K]*r,this}determinant(){let t=this.values;return t[J]*t[Z]*t[_]*t[O]-t[j]*t[Q]*t[_]*t[O]-t[J]*t[D]*t[U]*t[O]+t[H]*t[Q]*t[U]*t[O]+t[j]*t[D]*t[$]*t[O]-t[H]*t[Z]*t[$]*t[O]-t[J]*t[Z]*t[G]*t[N]+t[j]*t[Q]*t[G]*t[N]+t[J]*t[q]*t[U]*t[N]-t[V]*t[Q]*t[U]*t[N]-t[j]*t[q]*t[$]*t[N]+t[V]*t[Z]*t[$]*t[N]+t[J]*t[D]*t[G]*t[z]-t[H]*t[Q]*t[G]*t[z]-t[J]*t[q]*t[_]*t[z]+t[V]*t[Q]*t[_]*t[z]+t[H]*t[q]*t[$]*t[z]-t[V]*t[D]*t[$]*t[z]-t[j]*t[D]*t[G]*t[K]+t[H]*t[Z]*t[G]*t[K]+t[j]*t[q]*t[_]*t[K]-t[V]*t[Z]*t[_]*t[K]-t[H]*t[q]*t[U]*t[K]+t[V]*t[D]*t[U]*t[K]}translate(t,s,i){let r=this.values;return r[O]+=t,r[N]+=s,r[z]+=i,this}copy(){return new Yt().set(this.values)}projection(t,s,i,r){this.identity();let h=1/Math.tan(i*(Math.PI/180)/2),l=(s+t)/(t-s),n=2*s*t/(t-s),a=this.values;return a[V]=h/r,a[H]=0,a[j]=0,a[J]=0,a[q]=0,a[D]=h,a[Z]=0,a[Q]=0,a[G]=0,a[_]=0,a[U]=l,a[$]=-1,a[O]=0,a[N]=0,a[z]=n,a[K]=0,this}ortho2d(t,s,i,r){return this.ortho(t,t+i,s,s+r,0,1)}ortho(t,s,i,r,h,l){this.identity();let n=2/(s-t),a=2/(r-i),o=-2/(l-h),c=-(s+t)/(s-t),d=-(r+i)/(r-i),f=-(l+h)/(l-h),m=this.values;return m[V]=n,m[H]=0,m[j]=0,m[J]=0,m[q]=0,m[D]=a,m[Z]=0,m[Q]=0,m[G]=0,m[_]=0,m[U]=o,m[$]=0,m[O]=c,m[N]=d,m[z]=f,m[K]=1,this}multiply(t){let s=this.temp,i=this.values,r=t.values;return s[V]=i[V]*r[V]+i[q]*r[H]+i[G]*r[j]+i[O]*r[J],s[q]=i[V]*r[q]+i[q]*r[D]+i[G]*r[Z]+i[O]*r[Q],s[G]=i[V]*r[G]+i[q]*r[_]+i[G]*r[U]+i[O]*r[$],s[O]=i[V]*r[O]+i[q]*r[N]+i[G]*r[z]+i[O]*r[K],s[H]=i[H]*r[V]+i[D]*r[H]+i[_]*r[j]+i[N]*r[J],s[D]=i[H]*r[q]+i[D]*r[D]+i[_]*r[Z]+i[N]*r[Q],s[_]=i[H]*r[G]+i[D]*r[_]+i[_]*r[U]+i[N]*r[$],s[N]=i[H]*r[O]+i[D]*r[N]+i[_]*r[z]+i[N]*r[K],s[j]=i[j]*r[V]+i[Z]*r[H]+i[U]*r[j]+i[z]*r[J],s[Z]=i[j]*r[q]+i[Z]*r[D]+i[U]*r[Z]+i[z]*r[Q],s[U]=i[j]*r[G]+i[Z]*r[_]+i[U]*r[U]+i[z]*r[$],s[z]=i[j]*r[O]+i[Z]*r[N]+i[U]*r[z]+i[z]*r[K],s[J]=i[J]*r[V]+i[Q]*r[H]+i[$]*r[j]+i[K]*r[J],s[Q]=i[J]*r[q]+i[Q]*r[D]+i[$]*r[Z]+i[K]*r[Q],s[$]=i[J]*r[G]+i[Q]*r[_]+i[$]*r[U]+i[K]*r[$],s[K]=i[J]*r[O]+i[Q]*r[N]+i[$]*r[z]+i[K]*r[K],this.set(this.temp)}multiplyLeft(t){let s=this.temp,i=this.values,r=t.values;return s[V]=r[V]*i[V]+r[q]*i[H]+r[G]*i[j]+r[O]*i[J],s[q]=r[V]*i[q]+r[q]*i[D]+r[G]*i[Z]+r[O]*i[Q],s[G]=r[V]*i[G]+r[q]*i[_]+r[G]*i[U]+r[O]*i[$],s[O]=r[V]*i[O]+r[q]*i[N]+r[G]*i[z]+r[O]*i[K],s[H]=r[H]*i[V]+r[D]*i[H]+r[_]*i[j]+r[N]*i[J],s[D]=r[H]*i[q]+r[D]*i[D]+r[_]*i[Z]+r[N]*i[Q],s[_]=r[H]*i[G]+r[D]*i[_]+r[_]*i[U]+r[N]*i[$],s[N]=r[H]*i[O]+r[D]*i[N]+r[_]*i[z]+r[N]*i[K],s[j]=r[j]*i[V]+r[Z]*i[H]+r[U]*i[j]+r[z]*i[J],s[Z]=r[j]*i[q]+r[Z]*i[D]+r[U]*i[Z]+r[z]*i[Q],s[U]=r[j]*i[G]+r[Z]*i[_]+r[U]*i[U]+r[z]*i[$],s[z]=r[j]*i[O]+r[Z]*i[N]+r[U]*i[z]+r[z]*i[K],s[J]=r[J]*i[V]+r[Q]*i[H]+r[$]*i[j]+r[K]*i[J],s[Q]=r[J]*i[q]+r[Q]*i[D]+r[$]*i[Z]+r[K]*i[Q],s[$]=r[J]*i[G]+r[Q]*i[_]+r[$]*i[U]+r[K]*i[$],s[K]=r[J]*i[O]+r[Q]*i[N]+r[$]*i[z]+r[K]*i[K],this.set(this.temp)}lookAt(t,s,i){let r=Yt.xAxis,h=Yt.yAxis,l=Yt.zAxis;l.setFrom(s).normalize(),r.setFrom(s).normalize(),r.cross(i).normalize(),h.setFrom(r).cross(l).normalize(),this.identity();let n=this.values;return n[V]=r.x,n[q]=r.y,n[G]=r.z,n[H]=h.x,n[D]=h.y,n[_]=h.z,n[j]=-l.x,n[Z]=-l.y,n[U]=-l.z,Yt.tmpMatrix.identity(),Yt.tmpMatrix.values[O]=-t.x,Yt.tmpMatrix.values[N]=-t.y,Yt.tmpMatrix.values[z]=-t.z,this.multiply(Yt.tmpMatrix),this}},Ai=class{position=new At(0,0,0);direction=new At(0,0,-1);up=new At(0,1,0);near=0;far=100;zoom=1;viewportWidth=0;viewportHeight=0;projectionView=new re;inverseProjectionView=new re;projection=new re;view=new re;constructor(e,t){this.viewportWidth=e,this.viewportHeight=t,this.update()}update(){let e=this.projection,t=this.view,s=this.projectionView,i=this.inverseProjectionView,r=this.zoom,h=this.viewportWidth,l=this.viewportHeight;e.ortho(r*(-h/2),r*(h/2),r*(-l/2),r*(l/2),this.near,this.far),t.lookAt(this.position,this.direction,this.up),s.set(e.values),s.multiply(t),i.set(s.values).invert()}screenToWorld(e,t,s){let i=e.x,r=s-e.y-1;return e.x=2*i/t-1,e.y=2*r/s-1,e.z=2*e.z-1,e.project(this.inverseProjectionView),e}worldToScreen(e,t,s){return e.project(this.projectionView),e.x=t*(e.x+1)/2,e.y=s*(e.y+1)/2,e.z=(e.z+1)/2,e}setViewport(e,t){this.viewportWidth=e,this.viewportHeight=t}},ks=class{element;mouseX=0;mouseY=0;buttonDown=!1;touch0=null;touch1=null;initialPinchDistance=0;listeners=new Array;autoPreventDefault;isTouch=!1;callbacks;constructor(e,t=!0){this.element=e,this.autoPreventDefault=t,this.callbacks=this.setupCallbacks(e)}setupCallbacks(e){const t=a=>{if(a instanceof MouseEvent&&!this.isTouch){let o=e.getBoundingClientRect();this.mouseX=a.clientX-o.left,this.mouseY=a.clientY-o.top,this.buttonDown=!0,this.listeners.map(c=>{c.down&&c.down(this.mouseX,this.mouseY,a)})}},s=a=>{if(a instanceof MouseEvent&&!this.isTouch){let o=e.getBoundingClientRect();this.mouseX=a.clientX-o.left,this.mouseY=a.clientY-o.top,this.listeners.map(c=>{this.buttonDown?c.dragged&&c.dragged(this.mouseX,this.mouseY,a):c.moved&&c.moved(this.mouseX,this.mouseY,a)})}},i=a=>{if(a instanceof MouseEvent&&!this.isTouch){let o=e.getBoundingClientRect();this.mouseX=a.clientX-o.left,this.mouseY=a.clientY-o.top,this.buttonDown=!1,this.listeners.map(c=>{c.up&&c.up(this.mouseX,this.mouseY,a)})}},r=a=>{this.autoPreventDefault&&a.preventDefault();let o=a.deltaY;a.deltaMode==WheelEvent.DOM_DELTA_LINE&&(o*=8),a.deltaMode==WheelEvent.DOM_DELTA_PAGE&&(o*=24),this.listeners.map(c=>{c.wheel&&c.wheel(a.deltaY,a)})},h=a=>{if(this.isTouch=!0,!this.touch0||!this.touch1){var o=a.changedTouches;let c=o.item(0);if(!c)return;let d=e.getBoundingClientRect(),f=c.clientX-d.left,m=c.clientY-d.top,u=new Ci(c.identifier,f,m);if(this.mouseX=f,this.mouseY=m,this.buttonDown=!0,!this.touch0)this.touch0=u,this.listeners.map(g=>{g.down&&g.down(u.x,u.y,a)});else if(!this.touch1){this.touch1=u;let g=this.touch1.x-this.touch0.x,w=this.touch1.x-this.touch0.x;this.initialPinchDistance=Math.sqrt(g*g+w*w),this.listeners.map(b=>{b.zoom&&b.zoom(this.initialPinchDistance,this.initialPinchDistance,a)})}}this.autoPreventDefault&&a.preventDefault()},l=a=>{if(this.isTouch=!0,this.touch0){var o=a.changedTouches;let f=e.getBoundingClientRect();for(var c=0;c<o.length;c++){var d=o[c];let m=d.clientX-f.left,u=d.clientY-f.top;this.touch0.identifier===d.identifier&&(this.touch0.x=this.mouseX=m,this.touch0.y=this.mouseY=u,this.listeners.map(g=>{g.dragged&&g.dragged(m,u,a)})),this.touch1&&this.touch1.identifier===d.identifier&&(this.touch1.x=this.mouseX=m,this.touch1.y=this.mouseY=u)}if(this.touch0&&this.touch1){let m=this.touch1.x-this.touch0.x,u=this.touch1.x-this.touch0.x,g=Math.sqrt(m*m+u*u);this.listeners.map(w=>{w.zoom&&w.zoom(this.initialPinchDistance,g,a)})}}this.autoPreventDefault&&a.preventDefault()},n=a=>{if(this.isTouch=!0,this.touch0){var o=a.changedTouches;let f=e.getBoundingClientRect();for(var c=0;c<o.length;c++){var d=o[c];let m=d.clientX-f.left,u=d.clientY-f.top;if(this.touch0.identifier===d.identifier)if(this.touch0=null,this.mouseX=m,this.mouseY=u,this.listeners.map(g=>{g.up&&g.up(m,u,a)}),this.touch1)this.touch0=this.touch1,this.touch1=null,this.mouseX=this.touch0.x,this.mouseX=this.touch0.x,this.buttonDown=!0,this.listeners.map(g=>{g.down&&g.down(this.touch0.x,this.touch0.y,a)});else{this.buttonDown=!1;break}this.touch1&&this.touch1.identifier&&(this.touch1=null)}}this.autoPreventDefault&&a.preventDefault()};return e.addEventListener("mousedown",t,!0),e.addEventListener("mousemove",s,!0),e.addEventListener("mouseup",i,!0),e.addEventListener("wheel",r,!0),e.addEventListener("touchstart",h,{passive:!1,capture:!1}),e.addEventListener("touchmove",l,{passive:!1,capture:!1}),e.addEventListener("touchend",n,{passive:!1,capture:!1}),e.addEventListener("touchcancel",n),{mouseDown:t,mouseMove:s,mouseUp:i,mouseWheel:r,touchStart:h,touchMove:l,touchEnd:n}}dispose(){const e=this.element;e.removeEventListener("mousedown",this.callbacks.mouseDown,!0),e.removeEventListener("mousemove",this.callbacks.mouseMove,!0),e.removeEventListener("mouseup",this.callbacks.mouseUp,!0),e.removeEventListener("wheel",this.callbacks.mouseWheel,!0),e.removeEventListener("touchstart",this.callbacks.touchStart,{capture:!1}),e.removeEventListener("touchmove",this.callbacks.touchMove,{capture:!1}),e.removeEventListener("touchend",this.callbacks.touchEnd,{capture:!1}),e.removeEventListener("touchcancel",this.callbacks.touchEnd),this.listeners.length=0}addListener(e){this.listeners.push(e)}removeListener(e){let t=this.listeners.indexOf(e);t>-1&&this.listeners.splice(t,1)}},Ci=class{constructor(e,t,s){this.identifier=e,this.x=t,this.y=s}},Br=class{constructor(e,t){this.canvas=e,this.camera=t;let s=0,i=0,r=0,h=0,l=0,n=0,a=0,o=0;new ks(e).addListener({down:(c,d)=>{s=t.position.x,i=t.position.y,h=n=c,l=a=d,o=t.zoom},dragged:(c,d)=>{let f=c-h,m=d-l,u=t.screenToWorld(new At(0,0),e.clientWidth,e.clientHeight),g=t.screenToWorld(new At(f,m),e.clientWidth,e.clientHeight).sub(u);t.position.set(s-g.x,i-g.y,0),t.update(),n=c,a=d},wheel:c=>{let d=c/200*t.zoom,f=t.zoom+d;if(f>0){let m=0,u=0;if(c<0)m=n,u=a;else{let b=new At(e.clientWidth/2+15,e.clientHeight/2),x=n-b.x,p=e.clientHeight-1-a-b.y;m=b.x-x,u=e.clientHeight-1-b.y+p}let g=t.screenToWorld(new At(m,u),e.clientWidth,e.clientHeight);t.zoom=f,t.update();let w=t.screenToWorld(new At(m,u),e.clientWidth,e.clientHeight);t.position.add(g.sub(w)),t.update()}},zoom:(c,d)=>{let f=c/d;t.zoom=o*f},up:(c,d)=>{n=c,a=d},moved:(c,d)=>{n=c,a=d}})}},Tt=class dt{constructor(t,s,i){this.vertexShader=s,this.fragmentShader=i,this.vsSource=s,this.fsSource=i,this.context=t instanceof wt?t:new wt(t),this.context.addRestorable(this),this.compile()}static MVP_MATRIX="u_projTrans";static POSITION="a_position";static COLOR="a_color";static COLOR2="a_color2";static TEXCOORDS="a_texCoords";static SAMPLER="u_texture";context;vs=null;vsSource;fs=null;fsSource;program=null;tmp2x2=new Float32Array(2*2);tmp3x3=new Float32Array(3*3);tmp4x4=new Float32Array(4*4);getProgram(){return this.program}getVertexShader(){return this.vertexShader}getFragmentShader(){return this.fragmentShader}getVertexShaderSource(){return this.vsSource}getFragmentSource(){return this.fsSource}compile(){let t=this.context.gl;try{if(this.vs=this.compileShader(t.VERTEX_SHADER,this.vertexShader),!this.vs)throw new Error("Couldn't compile vertex shader.");if(this.fs=this.compileShader(t.FRAGMENT_SHADER,this.fragmentShader),!this.fs)throw new Error("Couldn#t compile fragment shader.");this.program=this.compileProgram(this.vs,this.fs)}catch(s){throw this.dispose(),s}}compileShader(t,s){let i=this.context.gl,r=i.createShader(t);if(!r)throw new Error("Couldn't create shader.");if(i.shaderSource(r,s),i.compileShader(r),!i.getShaderParameter(r,i.COMPILE_STATUS)){let h="Couldn't compile shader: "+i.getShaderInfoLog(r);if(i.deleteShader(r),!i.isContextLost())throw new Error(h)}return r}compileProgram(t,s){let i=this.context.gl,r=i.createProgram();if(!r)throw new Error("Couldn't compile program.");if(i.attachShader(r,t),i.attachShader(r,s),i.linkProgram(r),!i.getProgramParameter(r,i.LINK_STATUS)){let h="Couldn't compile shader program: "+i.getProgramInfoLog(r);if(i.deleteProgram(r),!i.isContextLost())throw new Error(h)}return r}restore(){this.compile()}bind(){this.context.gl.useProgram(this.program)}unbind(){this.context.gl.useProgram(null)}setUniformi(t,s){this.context.gl.uniform1i(this.getUniformLocation(t),s)}setUniformf(t,s){this.context.gl.uniform1f(this.getUniformLocation(t),s)}setUniform2f(t,s,i){this.context.gl.uniform2f(this.getUniformLocation(t),s,i)}setUniform3f(t,s,i,r){this.context.gl.uniform3f(this.getUniformLocation(t),s,i,r)}setUniform4f(t,s,i,r,h){this.context.gl.uniform4f(this.getUniformLocation(t),s,i,r,h)}setUniform2x2f(t,s){let i=this.context.gl;this.tmp2x2.set(s),i.uniformMatrix2fv(this.getUniformLocation(t),!1,this.tmp2x2)}setUniform3x3f(t,s){let i=this.context.gl;this.tmp3x3.set(s),i.uniformMatrix3fv(this.getUniformLocation(t),!1,this.tmp3x3)}setUniform4x4f(t,s){let i=this.context.gl;this.tmp4x4.set(s),i.uniformMatrix4fv(this.getUniformLocation(t),!1,this.tmp4x4)}getUniformLocation(t){let s=this.context.gl;if(!this.program)throw new Error("Shader not compiled.");let i=s.getUniformLocation(this.program,t);if(!i&&!s.isContextLost())throw new Error(`Couldn't find location for uniform ${t}`);return i}getAttributeLocation(t){let s=this.context.gl;if(!this.program)throw new Error("Shader not compiled.");let i=s.getAttribLocation(this.program,t);if(i==-1&&!s.isContextLost())throw new Error(`Couldn't find location for attribute ${t}`);return i}dispose(){this.context.removeRestorable(this);let t=this.context.gl;this.vs&&(t.deleteShader(this.vs),this.vs=null),this.fs&&(t.deleteShader(this.fs),this.fs=null),this.program&&(t.deleteProgram(this.program),this.program=null)}static newColoredTextured(t){let s=`
|
|
3
3
|
attribute vec4 ${dt.POSITION};
|
|
4
4
|
attribute vec4 ${dt.COLOR};
|
|
5
5
|
attribute vec2 ${dt.TEXCOORDS};
|