@esotericsoftware/spine-phaser-v3 4.2.80 → 4.2.82

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 spine=(()=>{var wr=Object.create,dt=Object.defineProperty,vr=Object.getOwnPropertyDescriptor,yr=Object.getOwnPropertyNames,Ar=Object.getPrototypeOf,Cr=Object.prototype.hasOwnProperty,Sr=(e,t,i)=>t in e?dt(e,t,{enumerable:!0,configurable:!0,writable:!0,value:i}):e[t]=i,Tr=(e=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(e,{get:(t,i)=>(typeof require<"u"?require:t)[i]}):e)(function(e){if(typeof require<"u")return require.apply(this,arguments);throw new Error('Dynamic require of "'+e+'" is not supported')}),Ir=(e,t)=>{for(var i in t)dt(e,i,{get:t[i],enumerable:!0})},os=(e,t,i,s)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of yr(t))!Cr.call(e,n)&&n!==i&&dt(e,n,{get:()=>t[n],enumerable:!(s=vr(t,n))||s.enumerable});return e},Mr=(e,t,i)=>(i=e!=null?wr(Ar(e)):{},os(t||!e||!e.__esModule?dt(i,"default",{value:e,enumerable:!0}):i,e)),Er=e=>os(dt({},"__esModule",{value:!0}),e),B=(e,t,i)=>(Sr(e,typeof t!="symbol"?t+"":t,i),i),hs={};if(Ir(hs,{AABBRectangleBoundsProvider:()=>Yn,Alpha:()=>sr,AlphaMixin:()=>dr,AlphaTimeline:()=>fi,Animation:()=>St,AnimationState:()=>Et,AnimationStateAdapter:()=>Or,AnimationStateData:()=>Ss,AssetManager:()=>Ds,AssetManagerBase:()=>Rs,AtlasAttachmentLoader:()=>Li,Attachment:()=>Qt,AttachmentTimeline:()=>Ze,BinaryInput:()=>Bs,BlendMode:()=>Ot,Bone:()=>Bi,BoneData:()=>Xi,BoundingBoxAttachment:()=>Yt,CURRENT:()=>Cs,CameraController:()=>yn,ClippingAttachment:()=>st,Color:()=>O,Color2Attribute:()=>Us,ColorAttribute:()=>Nt,ComputedSize:()=>Js,ComputedSizeMixin:()=>rr,ConstraintData:()=>pt,CurveTimeline:()=>Ye,CurveTimeline1:()=>Ie,CurveTimeline2:()=>Tt,DebugUtils:()=>Xr,DeformTimeline:()=>gi,Depth:()=>Ks,DepthMixin:()=>nr,Downloader:()=>Oi,DrawOrderTimeline:()=>Je,Event:()=>Vi,EventData:()=>Di,EventQueue:()=>ys,EventTimeline:()=>mt,EventType:()=>Ce,FIRST:()=>Ei,FakeTexture:()=>Vr,Flip:()=>Qs,FlipMixin:()=>ar,GLTexture:()=>at,HOLD_FIRST:()=>kt,HOLD_MIX:()=>As,HOLD_SUBSEQUENT:()=>Ri,IkConstraint:()=>ks,IkConstraintData:()=>Ni,IkConstraintTimeline:()=>pi,Inherit:()=>gt,InheritTimeline:()=>hi,Input:()=>Zi,IntSet:()=>Pr,Interpolation:()=>cs,LoadingScreen:()=>In,M00:()=>D,M01:()=>z,M02:()=>q,M03:()=>N,M10:()=>H,M11:()=>_,M12:()=>j,M13:()=>U,M20:()=>Z,M21:()=>J,M22:()=>W,M23:()=>G,M30:()=>$,M31:()=>ee,M32:()=>te,M33:()=>Q,ManagedWebGLRenderingContext:()=>be,MathUtils:()=>L,Matrix4:()=>Oe,Mesh:()=>Ji,MeshAttachment:()=>Be,MixBlend:()=>gs,MixDirection:()=>ps,Origin:()=>ir,OriginMixin:()=>cr,OrthoCamera:()=>Ns,PathAttachment:()=>Ke,PathConstraint:()=>rt,PathConstraintData:()=>_i,PathConstraintMixTimeline:()=>vi,PathConstraintPositionTimeline:()=>bi,PathConstraintSpacingTimeline:()=>wi,Physics:()=>Ps,PhysicsConstraintDampingTimeline:()=>Ci,PhysicsConstraintGravityTimeline:()=>Ii,PhysicsConstraintInertiaTimeline:()=>yi,PhysicsConstraintMassTimeline:()=>Si,PhysicsConstraintMixTimeline:()=>Mi,PhysicsConstraintResetTimeline:()=>It,PhysicsConstraintStrengthTimeline:()=>Ai,PhysicsConstraintTimeline:()=>Ne,PhysicsConstraintWindTimeline:()=>Ti,PointAttachment:()=>Pi,PolygonBatcher:()=>ot,Pool:()=>ft,Position2Attribute:()=>Dt,Position3Attribute:()=>An,PositionMode:()=>Lt,Pow:()=>ds,PowOut:()=>Lr,RGB2Timeline:()=>mi,RGBA2Timeline:()=>ui,RGBATimeline:()=>ci,RGBTimeline:()=>di,RegionAttachment:()=>V,ResizeMode:()=>Gt,RotateMode:()=>Bt,RotateTimeline:()=>ut,SETUP:()=>ki,SUBSEQUENT:()=>Rt,ScaleTimeline:()=>si,ScaleXTimeline:()=>ri,ScaleYTimeline:()=>ni,SceneRenderer:()=>ts,ScrollFactor:()=>$s,ScrollFactorMixin:()=>lr,SequenceTimeline:()=>it,SetupPoseBoundsProvider:()=>fr,Shader:()=>pe,ShapeRenderer:()=>Qi,ShapeType:()=>ye,ShearTimeline:()=>ai,ShearXTimeline:()=>li,ShearYTimeline:()=>oi,Skeleton:()=>We,SkeletonBinary:()=>Xs,SkeletonBounds:()=>Os,SkeletonClipping:()=>nt,SkeletonData:()=>Wi,SkeletonDebugRenderer:()=>_t,SkeletonJson:()=>Vs,SkeletonRenderer:()=>es,Skin:()=>xt,SkinEntry:()=>Gi,SkinsAndAnimationBoundsProvider:()=>Fn,Slot:()=>Ys,SlotData:()=>zi,SpacingMode:()=>Xt,SpineCanvas:()=>Rn,SpineGameObject:()=>ss,SpinePlugin:()=>vt,StringSet:()=>Jt,TexCoordAttribute:()=>Ki,Texture:()=>Ft,TextureAtlas:()=>Yi,TextureAtlasPage:()=>Ms,TextureAtlasRegion:()=>Fi,TextureFilter:()=>Pt,TextureRegion:()=>Is,TextureWrap:()=>Ts,TimeKeeper:()=>Kt,Timeline:()=>me,Touch:()=>_s,TrackEntry:()=>vs,Transform:()=>er,TransformConstraint:()=>Fs,TransformConstraintData:()=>qi,TransformConstraintTimeline:()=>xi,TransformMixin:()=>or,TranslateTimeline:()=>ei,TranslateXTimeline:()=>ti,TranslateYTimeline:()=>ii,Triangulator:()=>Se,Utils:()=>X,Vector2:()=>je,Vector3:()=>Me,VertexAttachment:()=>ke,VertexAttribute:()=>lt,VertexAttributeType:()=>Qe,Visible:()=>tr,VisibleMixin:()=>hr,WindowedMean:()=>Br,createMixin:()=>De}),typeof window<"u"&&window.Phaser){let e=window.require;window.require=t=>{if(e)return e(t);if(t==="Phaser")return window.Phaser}}var Ae=Mr(Tr("Phaser"),1),Rr="esotericsoftware.spine.skeletonFile.cache",kr="esotericsoftware.spine.atlas.cache",Yr="spineSkeletonData",Fr="spineAtlasData",Zt="spine",Pr=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}},Jt=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 i=0,s=e.length;i<s;i++)this.add(e[i]);return t!=this.size}contains(e){return this.entries[e]}clear(){this.entries={},this.size=0}},He=class{constructor(e=0,t=0,i=0,s=0){this.r=e,this.g=t,this.b=i,this.a=s}set(e,t,i,s){return this.r=e,this.g=t,this.b=i,this.a=s,this.clamp()}setFromColor(e){return this.r=e.r,this.g=e.g,this.b=e.b,this.a=e.a,this}setFromString(e){return e=e.charAt(0)=="#"?e.substr(1):e,this.r=parseInt(e.substr(0,2),16)/255,this.g=parseInt(e.substr(2,2),16)/255,this.b=parseInt(e.substr(4,2),16)/255,this.a=e.length!=8?1:parseInt(e.substr(6,2),16)/255,this}add(e,t,i,s){return this.r+=e,this.g+=t,this.b+=i,this.a+=s,this.clamp()}clamp(){return this.r<0?this.r=0:this.r>1&&(this.r=1),this.g<0?this.g=0:this.g>1&&(this.g=1),this.b<0?this.b=0:this.b>1&&(this.b=1),this.a<0?this.a=0:this.a>1&&(this.a=1),this}static rgba8888ToColor(e,t){e.r=((t&4278190080)>>>24)/255,e.g=((t&16711680)>>>16)/255,e.b=((t&65280)>>>8)/255,e.a=(t&255)/255}static rgb888ToColor(e,t){e.r=((t&16711680)>>>16)/255,e.g=((t&65280)>>>8)/255,e.b=(t&255)/255}toRgb888(){const e=t=>("0"+(t*255).toString(16)).slice(-2);return Number("0x"+e(this.r)+e(this.g)+e(this.b))}static fromString(e){return new He().setFromString(e)}},O=He;B(O,"WHITE",new He(1,1,1,1)),B(O,"RED",new He(1,0,0,1)),B(O,"GREEN",new He(0,1,0,1)),B(O,"BLUE",new He(0,0,1,1)),B(O,"MAGENTA",new He(1,0,1,1));var Re=class{static clamp(e,t,i){return e<t?t:e>i?i:e}static cosDeg(e){return Math.cos(e*Re.degRad)}static sinDeg(e){return Math.sin(e*Re.degRad)}static atan2Deg(e,t){return Math.atan2(e,t)*Re.degRad}static signum(e){return e>0?1:e<0?-1:0}static toInt(e){return e>0?Math.floor(e):Math.ceil(e)}static cbrt(e){let t=Math.pow(Math.abs(e),.3333333333333333);return e<0?-t:t}static randomTriangular(e,t){return Re.randomTriangularWith(e,t,(e+t)*.5)}static randomTriangularWith(e,t,i){let s=Math.random(),n=t-e;return s<=(i-e)/n?e+Math.sqrt(s*n*(i-e)):t-Math.sqrt((1-s)*n*(t-i))}static isPowerOfTwo(e){return e&&(e&e-1)===0}},L=Re;B(L,"PI",3.1415927),B(L,"PI2",Re.PI*2),B(L,"invPI2",1/Re.PI2),B(L,"radiansToDegrees",180/Re.PI),B(L,"radDeg",Re.radiansToDegrees),B(L,"degreesToRadians",Re.PI/180),B(L,"degRad",Re.degreesToRadians);var cs=class{apply(e,t,i){return e+(t-e)*this.applyInternal(i)}},ds=class extends cs{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}},Lr=class extends ds{constructor(e){super(e)}applyInternal(e){return Math.pow(e-1,this.power)*(this.power%2==0?-1:1)+1}},tt=class{static arrayCopy(e,t,i,s,n){for(let h=t,a=s;h<t+n;h++,a++)i[a]=e[h]}static arrayFill(e,t,i,s){for(let n=t;n<i;n++)e[n]=s}static setArraySize(e,t,i=0){let s=e.length;if(s==t)return e;if(e.length=t,s<t)for(let n=s;n<t;n++)e[n]=i;return e}static ensureArrayCapacity(e,t,i=0){return e.length>=t?e:tt.setArraySize(e,t,i)}static newArray(e,t){let i=new Array(e);for(let s=0;s<e;s++)i[s]=t;return i}static newFloatArray(e){if(tt.SUPPORTS_TYPED_ARRAYS)return new Float32Array(e);{let t=new Array(e);for(let i=0;i<t.length;i++)t[i]=0;return t}}static newShortArray(e){if(tt.SUPPORTS_TYPED_ARRAYS)return new Int16Array(e);{let t=new Array(e);for(let i=0;i<t.length;i++)t[i]=0;return t}}static toFloatArray(e){return tt.SUPPORTS_TYPED_ARRAYS?new Float32Array(e):e}static toSinglePrecision(e){return tt.SUPPORTS_TYPED_ARRAYS?Math.fround(e):e}static webkit602BugfixHelper(e,t){}static contains(e,t,i=!0){for(var s=0;s<e.length;s++)if(e[s]==t)return!0;return!1}static enumValue(e,t){return e[t[0].toUpperCase()+t.slice(1)]}},X=tt;B(X,"SUPPORTS_TYPED_ARRAYS",typeof Float32Array<"u");var Xr=class{static logBones(e){for(let t=0;t<e.bones.length;t++){let i=e.bones[t];console.log(i.data.name+", "+i.a+", "+i.b+", "+i.c+", "+i.d+", "+i.worldX+", "+i.worldY)}}},ft=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}},je=class{constructor(e=0,t=0){this.x=e,this.y=t}set(e,t){return this.x=e,this.y=t,this}length(){let e=this.x,t=this.y;return Math.sqrt(e*e+t*t)}normalize(){let e=this.length();return e!=0&&(this.x/=e,this.y/=e),this}},Kt=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)}},Br=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}},Qt=class{name;constructor(e){if(!e)throw new Error("name cannot be null.");this.name=e}},fs=class extends Qt{id=fs.nextID++;bones=null;vertices=[];worldVerticesLength=0;timelineAttachment=this;constructor(e){super(e)}computeWorldVertices(e,t,i,s,n,h){i=n+(i>>1)*h;let a=e.bone.skeleton,r=e.deform,o=this.vertices,l=this.bones;if(!l){r.length>0&&(o=r);let u=e.bone,m=u.worldX,g=u.worldY,w=u.a,b=u.b,p=u.c,x=u.d;for(let y=t,v=n;v<i;y+=2,v+=h){let A=o[y],C=o[y+1];s[v]=A*w+C*b+m,s[v+1]=A*p+C*x+g}return}let c=0,f=0;for(let u=0;u<t;u+=2){let m=l[c];c+=m+1,f+=m}let d=a.bones;if(r.length==0)for(let u=n,m=f*3;u<i;u+=h){let g=0,w=0,b=l[c++];for(b+=c;c<b;c++,m+=3){let p=d[l[c]],x=o[m],y=o[m+1],v=o[m+2];g+=(x*p.a+y*p.b+p.worldX)*v,w+=(x*p.c+y*p.d+p.worldY)*v}s[u]=g,s[u+1]=w}else{let u=r;for(let m=n,g=f*3,w=f<<1;m<i;m+=h){let b=0,p=0,x=l[c++];for(x+=c;c<x;c++,g+=3,w+=2){let y=d[l[c]],v=o[g]+u[w],A=o[g+1]+u[w+1],C=o[g+2];b+=(v*y.a+A*y.b+y.worldX)*C,p+=(v*y.c+A*y.d+y.worldY)*C}s[m]=b,s[m+1]=p}}}copyTo(e){this.bones?(e.bones=new Array(this.bones.length),X.arrayCopy(this.bones,0,e.bones,0,this.bones.length)):e.bones=null,this.vertices&&(e.vertices=X.newFloatArray(this.vertices.length),X.arrayCopy(this.vertices,0,e.vertices,0,this.vertices.length)),e.worldVerticesLength=this.worldVerticesLength,e.timelineAttachment=this.timelineAttachment}},ke=fs;B(ke,"nextID",0);var Ct=class{id=Ct.nextID();regions;start=0;digits=0;setupIndex=0;constructor(e){this.regions=new Array(e)}copy(){let e=new Ct(this.regions.length);return X.arrayCopy(this.regions,0,e.regions,0,this.regions.length),e.start=this.start,e.digits=this.digits,e.setupIndex=this.setupIndex,e}apply(e,t){let i=e.sequenceIndex;i==-1&&(i=this.setupIndex),i>=this.regions.length&&(i=this.regions.length-1);let s=this.regions[i];t.region!=s&&(t.region=s,t.updateRegion())}getPath(e,t){let i=e,s=(this.start+t).toString();for(let n=this.digits-s.length;n>0;n--)i+="0";return i+=s,i}static nextID(){return Ct._nextID++}},$t=Ct;B($t,"_nextID",0);var us=(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))(us||{}),ms=[0,1,2,3,4,5,6],St=class{name;timelines=[];timelineIds=new Jt;duration;constructor(e,t,i){if(!e)throw new Error("name cannot be null.");this.name=e,this.setTimelines(t),this.duration=i}setTimelines(e){if(!e)throw new Error("timelines cannot be null.");this.timelines=e,this.timelineIds.clear();for(var t=0;t<e.length;t++)this.timelineIds.addAll(e[t].getPropertyIds())}hasTimeline(e){for(let t=0;t<e.length;t++)if(this.timelineIds.contains(e[t]))return!0;return!1}apply(e,t,i,s,n,h,a,r){if(!e)throw new Error("skeleton cannot be null.");s&&this.duration!=0&&(i%=this.duration,t>0&&(t%=this.duration));let o=this.timelines;for(let l=0,c=o.length;l<c;l++)o[l].apply(e,t,i,n,h,a,r)}},gs=(e=>(e[e.setup=0]="setup",e[e.first=1]="first",e[e.replace=2]="replace",e[e.add=3]="add",e))(gs||{}),ps=(e=>(e[e.mixIn=0]="mixIn",e[e.mixOut=1]="mixOut",e))(ps||{}),ne={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},me=class{propertyIds;frames;constructor(e,t){this.propertyIds=t,this.frames=X.newFloatArray(e*this.getFrameEntries())}getPropertyIds(){return this.propertyIds}getFrameEntries(){return 1}getFrameCount(){return this.frames.length/this.getFrameEntries()}getDuration(){return this.frames[this.frames.length-this.getFrameEntries()]}static search1(e,t){let i=e.length;for(let s=1;s<i;s++)if(e[s]>t)return s-1;return i-1}static search(e,t,i){let s=e.length;for(let n=i;n<s;n+=i)if(e[n]>t)return n-i;return s-i}},Ye=class extends me{curves;constructor(e,t,i){super(e,i),this.curves=X.newFloatArray(e+t*18),this.curves[e-1]=1}setLinear(e){this.curves[e]=0}setStepped(e){this.curves[e]=1}shrink(e){let t=this.getFrameCount()+e*18;if(this.curves.length>t){let i=X.newFloatArray(t);X.arrayCopy(this.curves,0,i,0,t),this.curves=i}}setBezier(e,t,i,s,n,h,a,r,o,l,c){let f=this.curves,d=this.getFrameCount()+e*18;i==0&&(f[t]=2+d);let u=(s-h*2+r)*.03,m=(n-a*2+o)*.03,g=((h-r)*3-s+l)*.006,w=((a-o)*3-n+c)*.006,b=u*2+g,p=m*2+w,x=(h-s)*.3+u+g*.16666667,y=(a-n)*.3+m+w*.16666667,v=s+x,A=n+y;for(let C=d+18;d<C;d+=2)f[d]=v,f[d+1]=A,x+=b,y+=p,b+=g,p+=w,v+=x,A+=y}getBezierValue(e,t,i,s){let n=this.curves;if(n[s]>e){let o=this.frames[t],l=this.frames[t+i];return l+(e-o)/(n[s]-o)*(n[s+1]-l)}let h=s+18;for(s+=2;s<h;s+=2)if(n[s]>=e){let o=n[s-2],l=n[s-1];return l+(e-o)/(n[s]-o)*(n[s+1]-l)}t+=this.getFrameEntries();let a=n[h-2],r=n[h-1];return r+(e-a)/(this.frames[t]-a)*(this.frames[t+i]-r)}},Ie=class extends Ye{constructor(e,t,i){super(e,t,[i])}getFrameEntries(){return 2}setFrame(e,t,i){e<<=1,this.frames[e]=t,this.frames[e+1]=i}getCurveValue(e){let t=this.frames,i=t.length-2;for(let n=2;n<=i;n+=2)if(t[n]>e){i=n-2;break}let s=this.curves[i>>1];switch(s){case 0:let n=t[i],h=t[i+1];return h+(e-n)/(t[i+2]-n)*(t[i+2+1]-h);case 1:return t[i+1]}return this.getBezierValue(e,i,1,s-2)}getRelativeValue(e,t,i,s,n){if(e<this.frames[0]){switch(i){case 0:return n;case 1:return s+(n-s)*t}return s}let h=this.getCurveValue(e);switch(i){case 0:return n+h*t;case 1:case 2:h+=n-s}return s+h*t}getAbsoluteValue(e,t,i,s,n){if(e<this.frames[0]){switch(i){case 0:return n;case 1:return s+(n-s)*t}return s}let h=this.getCurveValue(e);return i==0?n+(h-n)*t:s+(h-s)*t}getAbsoluteValue2(e,t,i,s,n,h){if(e<this.frames[0]){switch(i){case 0:return n;case 1:return s+(n-s)*t}return s}return i==0?n+(h-n)*t:s+(h-s)*t}getScaleValue(e,t,i,s,n,h){const a=this.frames;if(e<a[0]){switch(i){case 0:return h;case 1:return n+(h-n)*t}return n}let r=this.getCurveValue(e)*h;if(t==1)return i==3?n+r-h:r;if(s==1)switch(i){case 0:return h+(Math.abs(r)*L.signum(h)-h)*t;case 1:case 2:return n+(Math.abs(r)*L.signum(n)-n)*t}else{let o=0;switch(i){case 0:return o=Math.abs(h)*L.signum(r),o+(r-o)*t;case 1:case 2:return o=Math.abs(n)*L.signum(r),o+(r-o)*t}}return n+(r-h)*t}},Tt=class extends Ye{constructor(e,t,i,s){super(e,t,[i,s])}getFrameEntries(){return 3}setFrame(e,t,i,s){e*=3,this.frames[e]=t,this.frames[e+1]=i,this.frames[e+2]=s}},ut=class extends Ie{boneIndex=0;constructor(e,t,i){super(e,t,ne.rotate+"|"+i),this.boneIndex=i}apply(e,t,i,s,n,h,a){let r=e.bones[this.boneIndex];r.active&&(r.rotation=this.getRelativeValue(i,n,h,r.rotation,r.data.rotation))}},ei=class extends Tt{boneIndex=0;constructor(e,t,i){super(e,t,ne.x+"|"+i,ne.y+"|"+i),this.boneIndex=i}apply(e,t,i,s,n,h,a){let r=e.bones[this.boneIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(h){case 0:r.x=r.data.x,r.y=r.data.y;return;case 1:r.x+=(r.data.x-r.x)*n,r.y+=(r.data.y-r.y)*n}return}let l=0,c=0,f=me.search(o,i,3),d=this.curves[f/3];switch(d){case 0:let u=o[f];l=o[f+1],c=o[f+2];let m=(i-u)/(o[f+3]-u);l+=(o[f+3+1]-l)*m,c+=(o[f+3+2]-c)*m;break;case 1:l=o[f+1],c=o[f+2];break;default:l=this.getBezierValue(i,f,1,d-2),c=this.getBezierValue(i,f,2,d+18-2)}switch(h){case 0:r.x=r.data.x+l*n,r.y=r.data.y+c*n;break;case 1:case 2:r.x+=(r.data.x+l-r.x)*n,r.y+=(r.data.y+c-r.y)*n;break;case 3:r.x+=l*n,r.y+=c*n}}},ti=class extends Ie{boneIndex=0;constructor(e,t,i){super(e,t,ne.x+"|"+i),this.boneIndex=i}apply(e,t,i,s,n,h,a){let r=e.bones[this.boneIndex];r.active&&(r.x=this.getRelativeValue(i,n,h,r.x,r.data.x))}},ii=class extends Ie{boneIndex=0;constructor(e,t,i){super(e,t,ne.y+"|"+i),this.boneIndex=i}apply(e,t,i,s,n,h,a){let r=e.bones[this.boneIndex];r.active&&(r.y=this.getRelativeValue(i,n,h,r.y,r.data.y))}},si=class extends Tt{boneIndex=0;constructor(e,t,i){super(e,t,ne.scaleX+"|"+i,ne.scaleY+"|"+i),this.boneIndex=i}apply(e,t,i,s,n,h,a){let r=e.bones[this.boneIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(h){case 0:r.scaleX=r.data.scaleX,r.scaleY=r.data.scaleY;return;case 1:r.scaleX+=(r.data.scaleX-r.scaleX)*n,r.scaleY+=(r.data.scaleY-r.scaleY)*n}return}let l,c,f=me.search(o,i,3),d=this.curves[f/3];switch(d){case 0:let u=o[f];l=o[f+1],c=o[f+2];let m=(i-u)/(o[f+3]-u);l+=(o[f+3+1]-l)*m,c+=(o[f+3+2]-c)*m;break;case 1:l=o[f+1],c=o[f+2];break;default:l=this.getBezierValue(i,f,1,d-2),c=this.getBezierValue(i,f,2,d+18-2)}if(l*=r.data.scaleX,c*=r.data.scaleY,n==1)h==3?(r.scaleX+=l-r.data.scaleX,r.scaleY+=c-r.data.scaleY):(r.scaleX=l,r.scaleY=c);else{let u=0,m=0;if(a==1)switch(h){case 0:u=r.data.scaleX,m=r.data.scaleY,r.scaleX=u+(Math.abs(l)*L.signum(u)-u)*n,r.scaleY=m+(Math.abs(c)*L.signum(m)-m)*n;break;case 1:case 2:u=r.scaleX,m=r.scaleY,r.scaleX=u+(Math.abs(l)*L.signum(u)-u)*n,r.scaleY=m+(Math.abs(c)*L.signum(m)-m)*n;break;case 3:r.scaleX+=(l-r.data.scaleX)*n,r.scaleY+=(c-r.data.scaleY)*n}else switch(h){case 0:u=Math.abs(r.data.scaleX)*L.signum(l),m=Math.abs(r.data.scaleY)*L.signum(c),r.scaleX=u+(l-u)*n,r.scaleY=m+(c-m)*n;break;case 1:case 2:u=Math.abs(r.scaleX)*L.signum(l),m=Math.abs(r.scaleY)*L.signum(c),r.scaleX=u+(l-u)*n,r.scaleY=m+(c-m)*n;break;case 3:r.scaleX+=(l-r.data.scaleX)*n,r.scaleY+=(c-r.data.scaleY)*n}}}},ri=class extends Ie{boneIndex=0;constructor(e,t,i){super(e,t,ne.scaleX+"|"+i),this.boneIndex=i}apply(e,t,i,s,n,h,a){let r=e.bones[this.boneIndex];r.active&&(r.scaleX=this.getScaleValue(i,n,h,a,r.scaleX,r.data.scaleX))}},ni=class extends Ie{boneIndex=0;constructor(e,t,i){super(e,t,ne.scaleY+"|"+i),this.boneIndex=i}apply(e,t,i,s,n,h,a){let r=e.bones[this.boneIndex];r.active&&(r.scaleY=this.getScaleValue(i,n,h,a,r.scaleY,r.data.scaleY))}},ai=class extends Tt{boneIndex=0;constructor(e,t,i){super(e,t,ne.shearX+"|"+i,ne.shearY+"|"+i),this.boneIndex=i}apply(e,t,i,s,n,h,a){let r=e.bones[this.boneIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(h){case 0:r.shearX=r.data.shearX,r.shearY=r.data.shearY;return;case 1:r.shearX+=(r.data.shearX-r.shearX)*n,r.shearY+=(r.data.shearY-r.shearY)*n}return}let l=0,c=0,f=me.search(o,i,3),d=this.curves[f/3];switch(d){case 0:let u=o[f];l=o[f+1],c=o[f+2];let m=(i-u)/(o[f+3]-u);l+=(o[f+3+1]-l)*m,c+=(o[f+3+2]-c)*m;break;case 1:l=o[f+1],c=o[f+2];break;default:l=this.getBezierValue(i,f,1,d-2),c=this.getBezierValue(i,f,2,d+18-2)}switch(h){case 0:r.shearX=r.data.shearX+l*n,r.shearY=r.data.shearY+c*n;break;case 1:case 2:r.shearX+=(r.data.shearX+l-r.shearX)*n,r.shearY+=(r.data.shearY+c-r.shearY)*n;break;case 3:r.shearX+=l*n,r.shearY+=c*n}}},li=class extends Ie{boneIndex=0;constructor(e,t,i){super(e,t,ne.shearX+"|"+i),this.boneIndex=i}apply(e,t,i,s,n,h,a){let r=e.bones[this.boneIndex];r.active&&(r.shearX=this.getRelativeValue(i,n,h,r.shearX,r.data.shearX))}},oi=class extends Ie{boneIndex=0;constructor(e,t,i){super(e,t,ne.shearY+"|"+i),this.boneIndex=i}apply(e,t,i,s,n,h,a){let r=e.bones[this.boneIndex];r.active&&(r.shearY=this.getRelativeValue(i,n,h,r.shearY,r.data.shearY))}},hi=class extends me{boneIndex=0;constructor(e,t){super(e,[ne.inherit+"|"+t]),this.boneIndex=t}getFrameEntries(){return 2}setFrame(e,t,i){e*=2,this.frames[e]=t,this.frames[e+1]=i}apply(e,t,i,s,n,h,a){let r=e.bones[this.boneIndex];if(!r.active)return;if(a==1){h==0&&(r.inherit=r.data.inherit);return}let o=this.frames;if(i<o[0]){(h==0||h==1)&&(r.inherit=r.data.inherit);return}r.inherit=this.frames[me.search(o,i,2)+1]}},ci=class extends Ye{slotIndex=0;constructor(e,t,i){super(e,t,[ne.rgb+"|"+i,ne.alpha+"|"+i]),this.slotIndex=i}getFrameEntries(){return 5}setFrame(e,t,i,s,n,h){e*=5,this.frames[e]=t,this.frames[e+1]=i,this.frames[e+2]=s,this.frames[e+3]=n,this.frames[e+4]=h}apply(e,t,i,s,n,h,a){let r=e.slots[this.slotIndex];if(!r.bone.active)return;let o=this.frames,l=r.color;if(i<o[0]){let w=r.data.color;switch(h){case 0:l.setFromColor(w);return;case 1:l.add((w.r-l.r)*n,(w.g-l.g)*n,(w.b-l.b)*n,(w.a-l.a)*n)}return}let c=0,f=0,d=0,u=0,m=me.search(o,i,5),g=this.curves[m/5];switch(g){case 0:let w=o[m];c=o[m+1],f=o[m+2],d=o[m+3],u=o[m+4];let b=(i-w)/(o[m+5]-w);c+=(o[m+5+1]-c)*b,f+=(o[m+5+2]-f)*b,d+=(o[m+5+3]-d)*b,u+=(o[m+5+4]-u)*b;break;case 1:c=o[m+1],f=o[m+2],d=o[m+3],u=o[m+4];break;default:c=this.getBezierValue(i,m,1,g-2),f=this.getBezierValue(i,m,2,g+18-2),d=this.getBezierValue(i,m,3,g+18*2-2),u=this.getBezierValue(i,m,4,g+18*3-2)}n==1?l.set(c,f,d,u):(h==0&&l.setFromColor(r.data.color),l.add((c-l.r)*n,(f-l.g)*n,(d-l.b)*n,(u-l.a)*n))}},di=class extends Ye{slotIndex=0;constructor(e,t,i){super(e,t,[ne.rgb+"|"+i]),this.slotIndex=i}getFrameEntries(){return 4}setFrame(e,t,i,s,n){e<<=2,this.frames[e]=t,this.frames[e+1]=i,this.frames[e+2]=s,this.frames[e+3]=n}apply(e,t,i,s,n,h,a){let r=e.slots[this.slotIndex];if(!r.bone.active)return;let o=this.frames,l=r.color;if(i<o[0]){let g=r.data.color;switch(h){case 0:l.r=g.r,l.g=g.g,l.b=g.b;return;case 1:l.r+=(g.r-l.r)*n,l.g+=(g.g-l.g)*n,l.b+=(g.b-l.b)*n}return}let c=0,f=0,d=0,u=me.search(o,i,4),m=this.curves[u>>2];switch(m){case 0:let g=o[u];c=o[u+1],f=o[u+2],d=o[u+3];let w=(i-g)/(o[u+4]-g);c+=(o[u+4+1]-c)*w,f+=(o[u+4+2]-f)*w,d+=(o[u+4+3]-d)*w;break;case 1:c=o[u+1],f=o[u+2],d=o[u+3];break;default:c=this.getBezierValue(i,u,1,m-2),f=this.getBezierValue(i,u,2,m+18-2),d=this.getBezierValue(i,u,3,m+18*2-2)}if(n==1)l.r=c,l.g=f,l.b=d;else{if(h==0){let g=r.data.color;l.r=g.r,l.g=g.g,l.b=g.b}l.r+=(c-l.r)*n,l.g+=(f-l.g)*n,l.b+=(d-l.b)*n}}},fi=class extends Ie{slotIndex=0;constructor(e,t,i){super(e,t,ne.alpha+"|"+i),this.slotIndex=i}apply(e,t,i,s,n,h,a){let r=e.slots[this.slotIndex];if(!r.bone.active)return;let o=r.color;if(i<this.frames[0]){let c=r.data.color;switch(h){case 0:o.a=c.a;return;case 1:o.a+=(c.a-o.a)*n}return}let l=this.getCurveValue(i);n==1?o.a=l:(h==0&&(o.a=r.data.color.a),o.a+=(l-o.a)*n)}},ui=class extends Ye{slotIndex=0;constructor(e,t,i){super(e,t,[ne.rgb+"|"+i,ne.alpha+"|"+i,ne.rgb2+"|"+i]),this.slotIndex=i}getFrameEntries(){return 8}setFrame(e,t,i,s,n,h,a,r,o){e<<=3,this.frames[e]=t,this.frames[e+1]=i,this.frames[e+2]=s,this.frames[e+3]=n,this.frames[e+4]=h,this.frames[e+5]=a,this.frames[e+6]=r,this.frames[e+7]=o}apply(e,t,i,s,n,h,a){let r=e.slots[this.slotIndex];if(!r.bone.active)return;let o=this.frames,l=r.color,c=r.darkColor;if(i<o[0]){let y=r.data.color,v=r.data.darkColor;switch(h){case 0:l.setFromColor(y),c.r=v.r,c.g=v.g,c.b=v.b;return;case 1:l.add((y.r-l.r)*n,(y.g-l.g)*n,(y.b-l.b)*n,(y.a-l.a)*n),c.r+=(v.r-c.r)*n,c.g+=(v.g-c.g)*n,c.b+=(v.b-c.b)*n}return}let f=0,d=0,u=0,m=0,g=0,w=0,b=0,p=me.search(o,i,8),x=this.curves[p>>3];switch(x){case 0:let y=o[p];f=o[p+1],d=o[p+2],u=o[p+3],m=o[p+4],g=o[p+5],w=o[p+6],b=o[p+7];let v=(i-y)/(o[p+8]-y);f+=(o[p+8+1]-f)*v,d+=(o[p+8+2]-d)*v,u+=(o[p+8+3]-u)*v,m+=(o[p+8+4]-m)*v,g+=(o[p+8+5]-g)*v,w+=(o[p+8+6]-w)*v,b+=(o[p+8+7]-b)*v;break;case 1:f=o[p+1],d=o[p+2],u=o[p+3],m=o[p+4],g=o[p+5],w=o[p+6],b=o[p+7];break;default:f=this.getBezierValue(i,p,1,x-2),d=this.getBezierValue(i,p,2,x+18-2),u=this.getBezierValue(i,p,3,x+18*2-2),m=this.getBezierValue(i,p,4,x+18*3-2),g=this.getBezierValue(i,p,5,x+18*4-2),w=this.getBezierValue(i,p,6,x+18*5-2),b=this.getBezierValue(i,p,7,x+18*6-2)}if(n==1)l.set(f,d,u,m),c.r=g,c.g=w,c.b=b;else{if(h==0){l.setFromColor(r.data.color);let y=r.data.darkColor;c.r=y.r,c.g=y.g,c.b=y.b}l.add((f-l.r)*n,(d-l.g)*n,(u-l.b)*n,(m-l.a)*n),c.r+=(g-c.r)*n,c.g+=(w-c.g)*n,c.b+=(b-c.b)*n}}},mi=class extends Ye{slotIndex=0;constructor(e,t,i){super(e,t,[ne.rgb+"|"+i,ne.rgb2+"|"+i]),this.slotIndex=i}getFrameEntries(){return 7}setFrame(e,t,i,s,n,h,a,r){e*=7,this.frames[e]=t,this.frames[e+1]=i,this.frames[e+2]=s,this.frames[e+3]=n,this.frames[e+4]=h,this.frames[e+5]=a,this.frames[e+6]=r}apply(e,t,i,s,n,h,a){let r=e.slots[this.slotIndex];if(!r.bone.active)return;let o=this.frames,l=r.color,c=r.darkColor;if(i<o[0]){let y=r.data.color,v=r.data.darkColor;switch(h){case 0:l.r=y.r,l.g=y.g,l.b=y.b,c.r=v.r,c.g=v.g,c.b=v.b;return;case 1:l.r+=(y.r-l.r)*n,l.g+=(y.g-l.g)*n,l.b+=(y.b-l.b)*n,c.r+=(v.r-c.r)*n,c.g+=(v.g-c.g)*n,c.b+=(v.b-c.b)*n}return}let f=0,d=0,u=0,m=0,g=0,w=0,b=0,p=me.search(o,i,7),x=this.curves[p/7];switch(x){case 0:let y=o[p];f=o[p+1],d=o[p+2],u=o[p+3],g=o[p+4],w=o[p+5],b=o[p+6];let v=(i-y)/(o[p+7]-y);f+=(o[p+7+1]-f)*v,d+=(o[p+7+2]-d)*v,u+=(o[p+7+3]-u)*v,g+=(o[p+7+4]-g)*v,w+=(o[p+7+5]-w)*v,b+=(o[p+7+6]-b)*v;break;case 1:f=o[p+1],d=o[p+2],u=o[p+3],g=o[p+4],w=o[p+5],b=o[p+6];break;default:f=this.getBezierValue(i,p,1,x-2),d=this.getBezierValue(i,p,2,x+18-2),u=this.getBezierValue(i,p,3,x+18*2-2),g=this.getBezierValue(i,p,4,x+18*3-2),w=this.getBezierValue(i,p,5,x+18*4-2),b=this.getBezierValue(i,p,6,x+18*5-2)}if(n==1)l.r=f,l.g=d,l.b=u,c.r=g,c.g=w,c.b=b;else{if(h==0){let y=r.data.color,v=r.data.darkColor;l.r=y.r,l.g=y.g,l.b=y.b,c.r=v.r,c.g=v.g,c.b=v.b}l.r+=(f-l.r)*n,l.g+=(d-l.g)*n,l.b+=(u-l.b)*n,c.r+=(g-c.r)*n,c.g+=(w-c.g)*n,c.b+=(b-c.b)*n}}},Ze=class extends me{slotIndex=0;attachmentNames;constructor(e,t){super(e,[ne.attachment+"|"+t]),this.slotIndex=t,this.attachmentNames=new Array(e)}getFrameCount(){return this.frames.length}setFrame(e,t,i){this.frames[e]=t,this.attachmentNames[e]=i}apply(e,t,i,s,n,h,a){let r=e.slots[this.slotIndex];if(r.bone.active){if(a==1){h==0&&this.setAttachment(e,r,r.data.attachmentName);return}if(i<this.frames[0]){(h==0||h==1)&&this.setAttachment(e,r,r.data.attachmentName);return}this.setAttachment(e,r,this.attachmentNames[me.search1(this.frames,i)])}}setAttachment(e,t,i){t.setAttachment(i?e.getAttachment(this.slotIndex,i):null)}},gi=class extends Ye{slotIndex=0;attachment;vertices;constructor(e,t,i,s){super(e,t,[ne.deform+"|"+i+"|"+s.id]),this.slotIndex=i,this.attachment=s,this.vertices=new Array(e)}getFrameCount(){return this.frames.length}setFrame(e,t,i){this.frames[e]=t,this.vertices[e]=i}setBezier(e,t,i,s,n,h,a,r,o,l,c){let f=this.curves,d=this.getFrameCount()+e*18;i==0&&(f[t]=2+d);let u=(s-h*2+r)*.03,m=o*.03-a*.06,g=((h-r)*3-s+l)*.006,w=(a-o+.33333333)*.018,b=u*2+g,p=m*2+w,x=(h-s)*.3+u+g*.16666667,y=a*.3+m+w*.16666667,v=s+x,A=y;for(let C=d+18;d<C;d+=2)f[d]=v,f[d+1]=A,x+=b,y+=p,b+=g,p+=w,v+=x,A+=y}getCurvePercent(e,t){let i=this.curves,s=i[t];switch(s){case 0:let r=this.frames[t];return(e-r)/(this.frames[t+this.getFrameEntries()]-r);case 1:return 0}if(s-=2,i[s]>e){let r=this.frames[t];return i[s+1]*(e-r)/(i[s]-r)}let n=s+18;for(s+=2;s<n;s+=2)if(i[s]>=e){let r=i[s-2],o=i[s-1];return o+(e-r)/(i[s]-r)*(i[s+1]-o)}let h=i[n-2],a=i[n-1];return a+(1-a)*(e-h)/(this.frames[t+this.getFrameEntries()]-h)}apply(e,t,i,s,n,h,a){let r=e.slots[this.slotIndex];if(!r.bone.active)return;let o=r.getAttachment();if(!o||!(o instanceof ke)||o.timelineAttachment!=this.attachment)return;let l=r.deform;l.length==0&&(h=0);let c=this.vertices,f=c[0].length,d=this.frames;if(i<d[0]){switch(h){case 0:l.length=0;return;case 1:if(n==1){l.length=0;return}l.length=f;let p=o;if(p.bones){n=1-n;for(var u=0;u<f;u++)l[u]*=n}else{let x=p.vertices;for(var u=0;u<f;u++)l[u]+=(x[u]-l[u])*n}}return}if(l.length=f,i>=d[d.length-1]){let p=c[d.length-1];if(n==1)if(h==3){let x=o;if(x.bones)for(let y=0;y<f;y++)l[y]+=p[y];else{let y=x.vertices;for(let v=0;v<f;v++)l[v]+=p[v]-y[v]}}else X.arrayCopy(p,0,l,0,f);else switch(h){case 0:{let y=o;if(y.bones)for(let v=0;v<f;v++)l[v]=p[v]*n;else{let v=y.vertices;for(let A=0;A<f;A++){let C=v[A];l[A]=C+(p[A]-C)*n}}break}case 1:case 2:for(let y=0;y<f;y++)l[y]+=(p[y]-l[y])*n;break;case 3:let x=o;if(x.bones)for(let y=0;y<f;y++)l[y]+=p[y]*n;else{let y=x.vertices;for(let v=0;v<f;v++)l[v]+=(p[v]-y[v])*n}}return}let m=me.search1(d,i),g=this.getCurvePercent(i,m),w=c[m],b=c[m+1];if(n==1)if(h==3){let p=o;if(p.bones)for(let x=0;x<f;x++){let y=w[x];l[x]+=y+(b[x]-y)*g}else{let x=p.vertices;for(let y=0;y<f;y++){let v=w[y];l[y]+=v+(b[y]-v)*g-x[y]}}}else for(let p=0;p<f;p++){let x=w[p];l[p]=x+(b[p]-x)*g}else switch(h){case 0:{let x=o;if(x.bones)for(let y=0;y<f;y++){let v=w[y];l[y]=(v+(b[y]-v)*g)*n}else{let y=x.vertices;for(let v=0;v<f;v++){let A=w[v],C=y[v];l[v]=C+(A+(b[v]-A)*g-C)*n}}break}case 1:case 2:for(let x=0;x<f;x++){let y=w[x];l[x]+=(y+(b[x]-y)*g-l[x])*n}break;case 3:let p=o;if(p.bones)for(let x=0;x<f;x++){let y=w[x];l[x]+=(y+(b[x]-y)*g)*n}else{let x=p.vertices;for(let y=0;y<f;y++){let v=w[y];l[y]+=(v+(b[y]-v)*g-x[y])*n}}}}},xs=class extends me{events;constructor(e){super(e,xs.propertyIds),this.events=new Array(e)}getFrameCount(){return this.frames.length}setFrame(e,t){this.frames[e]=t.time,this.events[e]=t}apply(e,t,i,s,n,h,a){if(!s)return;let r=this.frames,o=this.frames.length;if(t>i)this.apply(e,t,Number.MAX_VALUE,s,n,h,a),t=-1;else if(t>=r[o-1])return;if(i<r[0])return;let l=0;if(t<r[0])l=0;else{l=me.search1(r,t)+1;let c=r[l];for(;l>0&&r[l-1]==c;)l--}for(;l<o&&i>=r[l];l++)s.push(this.events[l])}},mt=xs;B(mt,"propertyIds",[""+ne.event]);var bs=class extends me{drawOrders;constructor(e){super(e,bs.propertyIds),this.drawOrders=new Array(e)}getFrameCount(){return this.frames.length}setFrame(e,t,i){this.frames[e]=t,this.drawOrders[e]=i}apply(e,t,i,s,n,h,a){if(a==1){h==0&&X.arrayCopy(e.slots,0,e.drawOrder,0,e.slots.length);return}if(i<this.frames[0]){(h==0||h==1)&&X.arrayCopy(e.slots,0,e.drawOrder,0,e.slots.length);return}let r=me.search1(this.frames,i),o=this.drawOrders[r];if(!o)X.arrayCopy(e.slots,0,e.drawOrder,0,e.slots.length);else{let l=e.drawOrder,c=e.slots;for(let f=0,d=o.length;f<d;f++)l[f]=c[o[f]]}}},Je=bs;B(Je,"propertyIds",[""+ne.drawOrder]);var pi=class extends Ye{constraintIndex=0;constructor(e,t,i){super(e,t,[ne.ikConstraint+"|"+i]),this.constraintIndex=i}getFrameEntries(){return 6}setFrame(e,t,i,s,n,h,a){e*=6,this.frames[e]=t,this.frames[e+1]=i,this.frames[e+2]=s,this.frames[e+3]=n,this.frames[e+4]=h?1:0,this.frames[e+5]=a?1:0}apply(e,t,i,s,n,h,a){let r=e.ikConstraints[this.constraintIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(h){case 0:r.mix=r.data.mix,r.softness=r.data.softness,r.bendDirection=r.data.bendDirection,r.compress=r.data.compress,r.stretch=r.data.stretch;return;case 1:r.mix+=(r.data.mix-r.mix)*n,r.softness+=(r.data.softness-r.softness)*n,r.bendDirection=r.data.bendDirection,r.compress=r.data.compress,r.stretch=r.data.stretch}return}let l=0,c=0,f=me.search(o,i,6),d=this.curves[f/6];switch(d){case 0:let u=o[f];l=o[f+1],c=o[f+2];let m=(i-u)/(o[f+6]-u);l+=(o[f+6+1]-l)*m,c+=(o[f+6+2]-c)*m;break;case 1:l=o[f+1],c=o[f+2];break;default:l=this.getBezierValue(i,f,1,d-2),c=this.getBezierValue(i,f,2,d+18-2)}h==0?(r.mix=r.data.mix+(l-r.data.mix)*n,r.softness=r.data.softness+(c-r.data.softness)*n,a==1?(r.bendDirection=r.data.bendDirection,r.compress=r.data.compress,r.stretch=r.data.stretch):(r.bendDirection=o[f+3],r.compress=o[f+4]!=0,r.stretch=o[f+5]!=0)):(r.mix+=(l-r.mix)*n,r.softness+=(c-r.softness)*n,a==0&&(r.bendDirection=o[f+3],r.compress=o[f+4]!=0,r.stretch=o[f+5]!=0))}},xi=class extends Ye{constraintIndex=0;constructor(e,t,i){super(e,t,[ne.transformConstraint+"|"+i]),this.constraintIndex=i}getFrameEntries(){return 7}setFrame(e,t,i,s,n,h,a,r){let o=this.frames;e*=7,o[e]=t,o[e+1]=i,o[e+2]=s,o[e+3]=n,o[e+4]=h,o[e+5]=a,o[e+6]=r}apply(e,t,i,s,n,h,a){let r=e.transformConstraints[this.constraintIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){let b=r.data;switch(h){case 0:r.mixRotate=b.mixRotate,r.mixX=b.mixX,r.mixY=b.mixY,r.mixScaleX=b.mixScaleX,r.mixScaleY=b.mixScaleY,r.mixShearY=b.mixShearY;return;case 1:r.mixRotate+=(b.mixRotate-r.mixRotate)*n,r.mixX+=(b.mixX-r.mixX)*n,r.mixY+=(b.mixY-r.mixY)*n,r.mixScaleX+=(b.mixScaleX-r.mixScaleX)*n,r.mixScaleY+=(b.mixScaleY-r.mixScaleY)*n,r.mixShearY+=(b.mixShearY-r.mixShearY)*n}return}let l,c,f,d,u,m,g=me.search(o,i,7),w=this.curves[g/7];switch(w){case 0:let b=o[g];l=o[g+1],c=o[g+2],f=o[g+3],d=o[g+4],u=o[g+5],m=o[g+6];let p=(i-b)/(o[g+7]-b);l+=(o[g+7+1]-l)*p,c+=(o[g+7+2]-c)*p,f+=(o[g+7+3]-f)*p,d+=(o[g+7+4]-d)*p,u+=(o[g+7+5]-u)*p,m+=(o[g+7+6]-m)*p;break;case 1:l=o[g+1],c=o[g+2],f=o[g+3],d=o[g+4],u=o[g+5],m=o[g+6];break;default:l=this.getBezierValue(i,g,1,w-2),c=this.getBezierValue(i,g,2,w+18-2),f=this.getBezierValue(i,g,3,w+18*2-2),d=this.getBezierValue(i,g,4,w+18*3-2),u=this.getBezierValue(i,g,5,w+18*4-2),m=this.getBezierValue(i,g,6,w+18*5-2)}if(h==0){let b=r.data;r.mixRotate=b.mixRotate+(l-b.mixRotate)*n,r.mixX=b.mixX+(c-b.mixX)*n,r.mixY=b.mixY+(f-b.mixY)*n,r.mixScaleX=b.mixScaleX+(d-b.mixScaleX)*n,r.mixScaleY=b.mixScaleY+(u-b.mixScaleY)*n,r.mixShearY=b.mixShearY+(m-b.mixShearY)*n}else r.mixRotate+=(l-r.mixRotate)*n,r.mixX+=(c-r.mixX)*n,r.mixY+=(f-r.mixY)*n,r.mixScaleX+=(d-r.mixScaleX)*n,r.mixScaleY+=(u-r.mixScaleY)*n,r.mixShearY+=(m-r.mixShearY)*n}},bi=class extends Ie{constraintIndex=0;constructor(e,t,i){super(e,t,ne.pathConstraintPosition+"|"+i),this.constraintIndex=i}apply(e,t,i,s,n,h,a){let r=e.pathConstraints[this.constraintIndex];r.active&&(r.position=this.getAbsoluteValue(i,n,h,r.position,r.data.position))}},wi=class extends Ie{constraintIndex=0;constructor(e,t,i){super(e,t,ne.pathConstraintSpacing+"|"+i),this.constraintIndex=i}apply(e,t,i,s,n,h,a){let r=e.pathConstraints[this.constraintIndex];r.active&&(r.spacing=this.getAbsoluteValue(i,n,h,r.spacing,r.data.spacing))}},vi=class extends Ye{constraintIndex=0;constructor(e,t,i){super(e,t,[ne.pathConstraintMix+"|"+i]),this.constraintIndex=i}getFrameEntries(){return 4}setFrame(e,t,i,s,n){let h=this.frames;e<<=2,h[e]=t,h[e+1]=i,h[e+2]=s,h[e+3]=n}apply(e,t,i,s,n,h,a){let r=e.pathConstraints[this.constraintIndex];if(!r.active)return;let o=this.frames;if(i<o[0]){switch(h){case 0:r.mixRotate=r.data.mixRotate,r.mixX=r.data.mixX,r.mixY=r.data.mixY;return;case 1:r.mixRotate+=(r.data.mixRotate-r.mixRotate)*n,r.mixX+=(r.data.mixX-r.mixX)*n,r.mixY+=(r.data.mixY-r.mixY)*n}return}let l,c,f,d=me.search(o,i,4),u=this.curves[d>>2];switch(u){case 0:let m=o[d];l=o[d+1],c=o[d+2],f=o[d+3];let g=(i-m)/(o[d+4]-m);l+=(o[d+4+1]-l)*g,c+=(o[d+4+2]-c)*g,f+=(o[d+4+3]-f)*g;break;case 1:l=o[d+1],c=o[d+2],f=o[d+3];break;default:l=this.getBezierValue(i,d,1,u-2),c=this.getBezierValue(i,d,2,u+18-2),f=this.getBezierValue(i,d,3,u+18*2-2)}if(h==0){let m=r.data;r.mixRotate=m.mixRotate+(l-m.mixRotate)*n,r.mixX=m.mixX+(c-m.mixX)*n,r.mixY=m.mixY+(f-m.mixY)*n}else r.mixRotate+=(l-r.mixRotate)*n,r.mixX+=(c-r.mixX)*n,r.mixY+=(f-r.mixY)*n}},Ne=class extends Ie{constraintIndex=0;constructor(e,t,i,s){super(e,t,s+"|"+i),this.constraintIndex=i}apply(e,t,i,s,n,h,a){let r;if(this.constraintIndex==-1){const o=i>=this.frames[0]?this.getCurveValue(i):0;for(const l of e.physicsConstraints)l.active&&this.global(l.data)&&this.set(l,this.getAbsoluteValue2(i,n,h,this.get(l),this.setup(l),o))}else r=e.physicsConstraints[this.constraintIndex],r.active&&this.set(r,this.getAbsoluteValue(i,n,h,this.get(r),this.setup(r)))}},yi=class extends Ne{constructor(e,t,i){super(e,t,i,ne.physicsConstraintInertia)}setup(e){return e.data.inertia}get(e){return e.inertia}set(e,t){e.inertia=t}global(e){return e.inertiaGlobal}},Ai=class extends Ne{constructor(e,t,i){super(e,t,i,ne.physicsConstraintStrength)}setup(e){return e.data.strength}get(e){return e.strength}set(e,t){e.strength=t}global(e){return e.strengthGlobal}},Ci=class extends Ne{constructor(e,t,i){super(e,t,i,ne.physicsConstraintDamping)}setup(e){return e.data.damping}get(e){return e.damping}set(e,t){e.damping=t}global(e){return e.dampingGlobal}},Si=class extends Ne{constructor(e,t,i){super(e,t,i,ne.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}},Ti=class extends Ne{constructor(e,t,i){super(e,t,i,ne.physicsConstraintWind)}setup(e){return e.data.wind}get(e){return e.wind}set(e,t){e.wind=t}global(e){return e.windGlobal}},Ii=class extends Ne{constructor(e,t,i){super(e,t,i,ne.physicsConstraintGravity)}setup(e){return e.data.gravity}get(e){return e.gravity}set(e,t){e.gravity=t}global(e){return e.gravityGlobal}},Mi=class extends Ne{constructor(e,t,i){super(e,t,i,ne.physicsConstraintMix)}setup(e){return e.data.mix}get(e){return e.mix}set(e,t){e.mix=t}global(e){return e.mixGlobal}},ws=class extends me{constraintIndex;constructor(e,t){super(e,ws.propertyIds),this.constraintIndex=t}getFrameCount(){return this.frames.length}setFrame(e,t){this.frames[e]=t}apply(e,t,i,s,n,h,a){let r;if(this.constraintIndex!=-1&&(r=e.physicsConstraints[this.constraintIndex],!r.active))return;const o=this.frames;if(t>i)this.apply(e,t,Number.MAX_VALUE,[],n,h,a),t=-1;else if(t>=o[o.length-1])return;if(!(i<o[0])&&(t<o[0]||i>=o[me.search1(o,t)+1]))if(r!=null)r.reset();else for(const l of e.physicsConstraints)l.active&&l.reset()}},It=ws;B(It,"propertyIds",[ne.physicsConstraintReset.toString()]);var _e=class extends me{slotIndex;attachment;constructor(e,t,i){super(e,[ne.sequence+"|"+t+"|"+i.sequence.id]),this.slotIndex=t,this.attachment=i}getFrameEntries(){return _e.ENTRIES}getSlotIndex(){return this.slotIndex}getAttachment(){return this.attachment}setFrame(e,t,i,s,n){let h=this.frames;e*=_e.ENTRIES,h[e]=t,h[e+_e.MODE]=i|s<<4,h[e+_e.DELAY]=n}apply(e,t,i,s,n,h,a){let r=e.slots[this.slotIndex];if(!r.bone.active)return;let o=r.attachment,l=this.attachment;if(o!=l&&(!(o instanceof ke)||o.timelineAttachment!=l))return;if(a==1){h==0&&(r.sequenceIndex=-1);return}let c=this.frames;if(i<c[0]){(h==0||h==1)&&(r.sequenceIndex=-1);return}let f=me.search(c,i,_e.ENTRIES),d=c[f],u=c[f+_e.MODE],m=c[f+_e.DELAY];if(!this.attachment.sequence)return;let g=u>>4,w=this.attachment.sequence.regions.length,b=ms[u&15];if(b!=0)switch(g+=(i-d)/m+1e-5|0,b){case 1:g=Math.min(w-1,g);break;case 2:g%=w;break;case 3:{let p=(w<<1)-2;g=p==0?0:g%p,g>=w&&(g=p-g);break}case 4:g=Math.max(w-1-g,0);break;case 5:g=w-1-g%w;break;case 6:{let p=(w<<1)-2;g=p==0?0:(g+w-1)%p,g>=w&&(g=p-g)}}r.sequenceIndex=g}},it=_e;B(it,"ENTRIES",3),B(it,"MODE",1),B(it,"DELAY",2);var Mt=class{static emptyAnimation(){return Mt._emptyAnimation}data;tracks=new Array;timeScale=1;unkeyedState=0;events=new Array;listeners=new Array;queue=new ys(this);propertyIDs=new Jt;animationsChanged=!1;trackEntryPool=new ft(()=>new vs);constructor(e){this.data=e}update(e){e*=this.timeScale;let t=this.tracks;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(!n)continue;n.animationLast=n.nextAnimationLast,n.trackLast=n.nextTrackLast;let h=e*n.timeScale;if(n.delay>0){if(n.delay-=h,n.delay>0)continue;h=-n.delay,n.delay=0}let a=n.next;if(a){let r=n.trackLast-a.delay;if(r>=0){for(a.delay=0,a.trackTime+=n.timeScale==0?0:(r/n.timeScale+e)*a.timeScale,n.trackTime+=h,this.setCurrent(i,a,!0);a.mixingFrom;)a.mixTime+=e,a=a.mixingFrom;continue}}else if(n.trackLast>=n.trackEnd&&!n.mixingFrom){t[i]=null,this.queue.end(n),this.clearNext(n);continue}if(n.mixingFrom&&this.updateMixingFrom(n,e)){let r=n.mixingFrom;for(n.mixingFrom=null,r&&(r.mixingTo=null);r;)this.queue.end(r),r=r.mixingFrom}n.trackTime+=h}this.queue.drain()}updateMixingFrom(e,t){let i=e.mixingFrom;if(!i)return!0;let s=this.updateMixingFrom(i,t);return i.animationLast=i.nextAnimationLast,i.trackLast=i.nextTrackLast,e.nextTrackLast!=-1&&e.mixTime>=e.mixDuration?((i.totalAlpha==0||e.mixDuration==0)&&(e.mixingFrom=i.mixingFrom,i.mixingFrom!=null&&(i.mixingFrom.mixingTo=e),e.interruptAlpha=i.interruptAlpha,this.queue.end(i)),s):(i.trackTime+=t*i.timeScale,e.mixTime+=t,!1)}apply(e){if(!e)throw new Error("skeleton cannot be null.");this.animationsChanged&&this._animationsChanged();let t=this.events,i=this.tracks,s=!1;for(let f=0,d=i.length;f<d;f++){let u=i[f];if(!u||u.delay>0)continue;s=!0;let m=f==0?1:u.mixBlend,g=u.alpha;u.mixingFrom?g*=this.applyMixingFrom(u,e,m):u.trackTime>=u.trackEnd&&!u.next&&(g=0);let w=g>=u.alphaAttachmentThreshold,b=u.animationLast,p=u.getAnimationTime(),x=p,y=t;u.reverse&&(x=u.animation.duration-x,y=null);let v=u.animation.timelines,A=v.length;if(f==0&&g==1||m==3){f==0&&(w=!0);for(let C=0;C<A;C++){X.webkit602BugfixHelper(g,m);var n=v[C];n instanceof Ze?this.applyAttachmentTimeline(n,e,x,m,w):n.apply(e,b,x,y,g,m,0)}}else{let C=u.timelineMode,S=u.shortestRotation,E=!S&&u.timelinesRotation.length!=A<<1;E&&(u.timelinesRotation.length=A<<1);for(let R=0;R<A;R++){let Y=v[R],P=C[R]==Rt?m:0;!S&&Y instanceof ut?this.applyRotateTimeline(Y,e,x,g,P,u.timelinesRotation,R<<1,E):Y instanceof Ze?this.applyAttachmentTimeline(Y,e,x,m,w):(X.webkit602BugfixHelper(g,m),Y.apply(e,b,x,y,g,P,0))}}this.queueEvents(u,p),t.length=0,u.nextAnimationLast=p,u.nextTrackLast=u.trackTime}for(var h=this.unkeyedState+ki,a=e.slots,r=0,o=e.slots.length;r<o;r++){var l=a[r];if(l.attachmentState==h){var c=l.data.attachmentName;l.setAttachment(c?e.getAttachment(l.data.index,c):null)}}return this.unkeyedState+=2,this.queue.drain(),s}applyMixingFrom(e,t,i){let s=e.mixingFrom;s.mixingFrom&&this.applyMixingFrom(s,t,i);let n=0;e.mixDuration==0?(n=1,i==1&&(i=0)):(n=e.mixTime/e.mixDuration,n>1&&(n=1),i!=1&&(i=s.mixBlend));let h=n<s.mixAttachmentThreshold,a=n<s.mixDrawOrderThreshold,r=s.animation.timelines,o=r.length,l=s.alpha*e.interruptAlpha,c=l*(1-n),f=s.animationLast,d=s.getAnimationTime(),u=d,m=null;if(s.reverse?u=s.animation.duration-u:n<s.eventThreshold&&(m=this.events),i==3)for(let g=0;g<o;g++)r[g].apply(t,f,u,m,c,i,1);else{let g=s.timelineMode,w=s.timelineHoldMix,b=s.shortestRotation,p=!b&&s.timelinesRotation.length!=o<<1;p&&(s.timelinesRotation.length=o<<1),s.totalAlpha=0;for(let x=0;x<o;x++){let y=r[x],v=1,A,C=0;switch(g[x]){case Rt:if(!a&&y instanceof Je)continue;A=i,C=c;break;case Ei:A=0,C=c;break;case Ri:A=i,C=l;break;case kt:A=0,C=l;break;default:A=0;let S=w[x];C=l*Math.max(0,1-S.mixTime/S.mixDuration);break}s.totalAlpha+=C,!b&&y instanceof ut?this.applyRotateTimeline(y,t,u,C,A,s.timelinesRotation,x<<1,p):y instanceof Ze?this.applyAttachmentTimeline(y,t,u,A,h&&C>=s.alphaAttachmentThreshold):(X.webkit602BugfixHelper(C,i),a&&y instanceof Je&&A==0&&(v=0),y.apply(t,f,u,m,C,A,v))}}return e.mixDuration>0&&this.queueEvents(s,d),this.events.length=0,s.nextAnimationLast=d,s.nextTrackLast=s.trackTime,n}applyAttachmentTimeline(e,t,i,s,n){var h=t.slots[e.slotIndex];h.bone.active&&(i<e.frames[0]?(s==0||s==1)&&this.setAttachment(t,h,h.data.attachmentName,n):this.setAttachment(t,h,e.attachmentNames[me.search1(e.frames,i)],n),h.attachmentState<=this.unkeyedState&&(h.attachmentState=this.unkeyedState+ki))}setAttachment(e,t,i,s){t.setAttachment(i?e.getAttachment(t.data.index,i):null),s&&(t.attachmentState=this.unkeyedState+Cs)}applyRotateTimeline(e,t,i,s,n,h,a,r){if(r&&(h[a]=0),s==1){e.apply(t,0,i,null,1,n,0);return}let o=t.bones[e.boneIndex];if(!o.active)return;let l=e.frames,c=0,f=0;if(i<l[0])switch(n){case 0:o.rotation=o.data.rotation;default:return;case 1:c=o.rotation,f=o.data.rotation}else c=n==0?o.data.rotation:o.rotation,f=o.data.rotation+e.getCurveValue(i);let d=0,u=f-c;if(u-=Math.ceil(u/360-.5)*360,u==0)d=h[a];else{let m=0,g=0;r?(m=0,g=u):(m=h[a],g=h[a+1]);let w=m-m%360;d=u+w;let b=u>=0,p=m>=0;Math.abs(g)<=90&&L.signum(g)!=L.signum(u)&&(Math.abs(m-w)>180?(d+=360*L.signum(m),p=b):w!=0?d-=360*L.signum(m):p=b),p!=b&&(d+=360*L.signum(m)),h[a]=d}h[a+1]=u,o.rotation=c+d*s}queueEvents(e,t){let i=e.animationStart,s=e.animationEnd,n=s-i,h=e.trackLast%n,a=this.events,r=0,o=a.length;for(;r<o;r++){let c=a[r];if(c.time<h)break;c.time>s||this.queue.event(e,c)}let l=!1;if(e.loop)if(n==0)l=!0;else{const c=Math.floor(e.trackTime/n);l=c>0&&c>Math.floor(e.trackLast/n)}else l=t>=s&&e.animationLast<s;for(l&&this.queue.complete(e);r<o;r++){let c=a[r];c.time<i||this.queue.event(e,c)}}clearTracks(){let e=this.queue.drainDisabled;this.queue.drainDisabled=!0;for(let t=0,i=this.tracks.length;t<i;t++)this.clearTrack(t);this.tracks.length=0,this.queue.drainDisabled=e,this.queue.drain()}clearTrack(e){if(e>=this.tracks.length)return;let t=this.tracks[e];if(!t)return;this.queue.end(t),this.clearNext(t);let i=t;for(;;){let s=i.mixingFrom;if(!s)break;this.queue.end(s),i.mixingFrom=null,i.mixingTo=null,i=s}this.tracks[t.trackIndex]=null,this.queue.drain()}setCurrent(e,t,i){let s=this.expandToIndex(e);this.tracks[e]=t,t.previous=null,s&&(i&&this.queue.interrupt(s),t.mixingFrom=s,s.mixingTo=t,t.mixTime=0,s.mixingFrom&&s.mixDuration>0&&(t.interruptAlpha*=Math.min(1,s.mixTime/s.mixDuration)),s.timelinesRotation.length=0),this.queue.start(t)}setAnimation(e,t,i=!1){let s=this.data.skeletonData.findAnimation(t);if(!s)throw new Error("Animation not found: "+t);return this.setAnimationWith(e,s,i)}setAnimationWith(e,t,i=!1){if(!t)throw new Error("animation cannot be null.");let s=!0,n=this.expandToIndex(e);n&&(n.nextTrackLast==-1?(this.tracks[e]=n.mixingFrom,this.queue.interrupt(n),this.queue.end(n),this.clearNext(n),n=n.mixingFrom,s=!1):this.clearNext(n));let h=this.trackEntry(e,t,i,n);return this.setCurrent(e,h,s),this.queue.drain(),h}addAnimation(e,t,i=!1,s=0){let n=this.data.skeletonData.findAnimation(t);if(!n)throw new Error("Animation not found: "+t);return this.addAnimationWith(e,n,i,s)}addAnimationWith(e,t,i=!1,s=0){if(!t)throw new Error("animation cannot be null.");let n=this.expandToIndex(e);if(n)for(;n.next;)n=n.next;let h=this.trackEntry(e,t,i,n);return n?(n.next=h,h.previous=n,s<=0&&(s+=n.getTrackComplete()-h.mixDuration)):(this.setCurrent(e,h,!0),this.queue.drain()),h.delay=s,h}setEmptyAnimation(e,t=0){let i=this.setAnimationWith(e,Mt.emptyAnimation(),!1);return i.mixDuration=t,i.trackEnd=t,i}addEmptyAnimation(e,t=0,i=0){let s=this.addAnimationWith(e,Mt.emptyAnimation(),!1,i);return i<=0&&(s.delay+=s.mixDuration-t),s.mixDuration=t,s.trackEnd=t,s}setEmptyAnimations(e=0){let t=this.queue.drainDisabled;this.queue.drainDisabled=!0;for(let i=0,s=this.tracks.length;i<s;i++){let n=this.tracks[i];n&&this.setEmptyAnimation(n.trackIndex,e)}this.queue.drainDisabled=t,this.queue.drain()}expandToIndex(e){return e<this.tracks.length?this.tracks[e]:(X.ensureArrayCapacity(this.tracks,e+1,null),this.tracks.length=e+1,null)}trackEntry(e,t,i,s){let n=this.trackEntryPool.obtain();return n.reset(),n.trackIndex=e,n.animation=t,n.loop=i,n.holdPrevious=!1,n.reverse=!1,n.shortestRotation=!1,n.eventThreshold=0,n.alphaAttachmentThreshold=0,n.mixAttachmentThreshold=0,n.mixDrawOrderThreshold=0,n.animationStart=0,n.animationEnd=t.duration,n.animationLast=-1,n.nextAnimationLast=-1,n.delay=0,n.trackTime=0,n.trackLast=-1,n.nextTrackLast=-1,n.trackEnd=Number.MAX_VALUE,n.timeScale=1,n.alpha=1,n.mixTime=0,n.mixDuration=s?this.data.getMix(s.animation,t):0,n.interruptAlpha=1,n.totalAlpha=0,n.mixBlend=2,n}clearNext(e){let t=e.next;for(;t;)this.queue.dispose(t),t=t.next;e.next=null}_animationsChanged(){this.animationsChanged=!1,this.propertyIDs.clear();let e=this.tracks;for(let t=0,i=e.length;t<i;t++){let s=e[t];if(s){for(;s.mixingFrom;)s=s.mixingFrom;do(!s.mixingTo||s.mixBlend!=3)&&this.computeHold(s),s=s.mixingTo;while(s)}}}computeHold(e){let t=e.mixingTo,i=e.animation.timelines,s=e.animation.timelines.length,n=e.timelineMode;n.length=s;let h=e.timelineHoldMix;h.length=0;let a=this.propertyIDs;if(t&&t.holdPrevious){for(let r=0;r<s;r++)n[r]=a.addAll(i[r].getPropertyIds())?kt:Ri;return}e:for(let r=0;r<s;r++){let o=i[r],l=o.getPropertyIds();if(!a.addAll(l))n[r]=Rt;else if(!t||o instanceof Ze||o instanceof Je||o instanceof mt||!t.animation.hasTimeline(l))n[r]=Ei;else{for(let c=t.mixingTo;c;c=c.mixingTo)if(!c.animation.hasTimeline(l)){if(e.mixDuration>0){n[r]=As,h[r]=c;continue e}break}n[r]=kt}}}getCurrent(e){return e>=this.tracks.length?null:this.tracks[e]}addListener(e){if(!e)throw new Error("listener cannot be null.");this.listeners.push(e)}removeListener(e){let t=this.listeners.indexOf(e);t>=0&&this.listeners.splice(t,1)}clearListeners(){this.listeners.length=0}clearListenerNotifications(){this.queue.clear()}},Et=Mt;B(Et,"_emptyAnimation",new St("<empty>",[],0));var vs=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,this.previous!=null&&t<=0&&(t+=this.previous.getTrackComplete()-e),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}},ys=class{objects=[];drainDisabled=!1;animState;constructor(e){this.animState=e}start(e){this.objects.push(Ce.start),this.objects.push(e),this.animState.animationsChanged=!0}interrupt(e){this.objects.push(Ce.interrupt),this.objects.push(e)}end(e){this.objects.push(Ce.end),this.objects.push(e),this.animState.animationsChanged=!0}dispose(e){this.objects.push(Ce.dispose),this.objects.push(e)}complete(e){this.objects.push(Ce.complete),this.objects.push(e)}event(e,t){this.objects.push(Ce.event),this.objects.push(e),this.objects.push(t)}drain(){if(this.drainDisabled)return;this.drainDisabled=!0;let e=this.objects,t=this.animState.listeners;for(let i=0;i<e.length;i+=2){let s=e[i],n=e[i+1];switch(s){case Ce.start:n.listener&&n.listener.start&&n.listener.start(n);for(let a=0;a<t.length;a++){let r=t[a];r.start&&r.start(n)}break;case Ce.interrupt:n.listener&&n.listener.interrupt&&n.listener.interrupt(n);for(let a=0;a<t.length;a++){let r=t[a];r.interrupt&&r.interrupt(n)}break;case Ce.end:n.listener&&n.listener.end&&n.listener.end(n);for(let a=0;a<t.length;a++){let r=t[a];r.end&&r.end(n)}case Ce.dispose:n.listener&&n.listener.dispose&&n.listener.dispose(n);for(let a=0;a<t.length;a++){let r=t[a];r.dispose&&r.dispose(n)}this.animState.trackEntryPool.free(n);break;case Ce.complete:n.listener&&n.listener.complete&&n.listener.complete(n);for(let a=0;a<t.length;a++){let r=t[a];r.complete&&r.complete(n)}break;case Ce.event:let h=e[i+++2];n.listener&&n.listener.event&&n.listener.event(n,h);for(let a=0;a<t.length;a++){let r=t[a];r.event&&r.event(n,h)}break}}this.clear(),this.drainDisabled=!1}clear(){this.objects.length=0}},Ce=(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))(Ce||{}),Or=class{start(e){}interrupt(e){}end(e){}dispose(e){}complete(e){}event(e,t){}},Rt=0,Ei=1,Ri=2,kt=3,As=4,ki=1,Cs=2,Ss=class{skeletonData;animationToMixTime={};defaultMix=0;constructor(e){if(!e)throw new Error("skeletonData cannot be null.");this.skeletonData=e}setMix(e,t,i){let s=this.skeletonData.findAnimation(e);if(!s)throw new Error("Animation not found: "+e);let n=this.skeletonData.findAnimation(t);if(!n)throw new Error("Animation not found: "+t);this.setMixWith(s,n,i)}setMixWith(e,t,i){if(!e)throw new Error("from cannot be null.");if(!t)throw new Error("to cannot be null.");let s=e.name+"."+t.name;this.animationToMixTime[s]=i}getMix(e,t){let i=e.name+"."+t.name,s=this.animationToMixTime[i];return s===void 0?this.defaultMix:s}},Yt=class extends ke{color=new O(1,1,1,1);constructor(e){super(e)}copy(){let e=new Yt(this.name);return this.copyTo(e),e.color.setFromColor(this.color),e}},st=class extends ke{endSlot=null;color=new O(.2275,.2275,.8078,1);constructor(e){super(e)}copy(){let e=new st(this.name);return this.copyTo(e),e.endSlot=this.endSlot,e.color.setFromColor(this.color),e}},Ft=class{_image;constructor(e){this._image=e}getImage(){return this._image}},Pt=(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))(Pt||{}),Ts=(e=>(e[e.MirroredRepeat=33648]="MirroredRepeat",e[e.ClampToEdge=33071]="ClampToEdge",e[e.Repeat=10497]="Repeat",e))(Ts||{}),Is=class{texture;u=0;v=0;u2=0;v2=0;width=0;height=0;degrees=0;offsetX=0;offsetY=0;originalWidth=0;originalHeight=0},Vr=class extends Ft{setFilters(e,t){}setWraps(e,t){}dispose(){}},Yi=class{pages=new Array;regions=new Array;constructor(e){let t=new Dr(e),i=new Array(4),s={};s.size=l=>{l.width=parseInt(i[1]),l.height=parseInt(i[2])},s.format=()=>{},s.filter=l=>{l.minFilter=X.enumValue(Pt,i[1]),l.magFilter=X.enumValue(Pt,i[2])},s.repeat=l=>{i[1].indexOf("x")!=-1&&(l.uWrap=10497),i[1].indexOf("y")!=-1&&(l.vWrap=10497)},s.pma=l=>{l.pma=i[1]=="true"};var n={};n.xy=l=>{l.x=parseInt(i[1]),l.y=parseInt(i[2])},n.size=l=>{l.width=parseInt(i[1]),l.height=parseInt(i[2])},n.bounds=l=>{l.x=parseInt(i[1]),l.y=parseInt(i[2]),l.width=parseInt(i[3]),l.height=parseInt(i[4])},n.offset=l=>{l.offsetX=parseInt(i[1]),l.offsetY=parseInt(i[2])},n.orig=l=>{l.originalWidth=parseInt(i[1]),l.originalHeight=parseInt(i[2])},n.offsets=l=>{l.offsetX=parseInt(i[1]),l.offsetY=parseInt(i[2]),l.originalWidth=parseInt(i[3]),l.originalHeight=parseInt(i[4])},n.rotate=l=>{let c=i[1];c=="true"?l.degrees=90:c!="false"&&(l.degrees=parseInt(c))},n.index=l=>{l.index=parseInt(i[1])};let h=t.readLine();for(;h&&h.trim().length==0;)h=t.readLine();for(;!(!h||h.trim().length==0||t.readEntry(i,h)==0);)h=t.readLine();let a=null,r=null,o=null;for(;h!==null;)if(h.trim().length==0)a=null,h=t.readLine();else if(a){let l=new Fi(a,h);for(;;){let c=t.readEntry(i,h=t.readLine());if(c==0)break;let f=n[i[0]];if(f)f(l);else{r||(r=[]),o||(o=[]),r.push(i[0]);let d=[];for(let u=0;u<c;u++)d.push(parseInt(i[u+1]));o.push(d)}}l.originalWidth==0&&l.originalHeight==0&&(l.originalWidth=l.width,l.originalHeight=l.height),r&&r.length>0&&o&&o.length>0&&(l.names=r,l.values=o,r=null,o=null),l.u=l.x/a.width,l.v=l.y/a.height,l.degrees==90?(l.u2=(l.x+l.height)/a.width,l.v2=(l.y+l.width)/a.height):(l.u2=(l.x+l.width)/a.width,l.v2=(l.y+l.height)/a.height),this.regions.push(l)}else{for(a=new Ms(h.trim());t.readEntry(i,h=t.readLine())!=0;){let l=s[i[0]];l&&l(a)}this.pages.push(a)}}findRegion(e){for(let t=0;t<this.regions.length;t++)if(this.regions[t].name==e)return this.regions[t];return null}setTextures(e,t=""){for(let i of this.pages)i.setTexture(e.get(t+i.name))}dispose(){for(let e=0;e<this.pages.length;e++)this.pages[e].texture?.dispose()}},Dr=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 i=t.indexOf(":");if(i==-1)return 0;e[0]=t.substr(0,i).trim();for(let s=1,n=i+1;;s++){let h=t.indexOf(",",n);if(h==-1)return e[s]=t.substr(n).trim(),s;if(e[s]=t.substr(n,h-n).trim(),n=h+1,s==4)return 4}}},Ms=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}},Fi=class extends Is{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)}},Be=class extends ke{region=null;path;regionUVs=[];uvs=[];triangles=[];color=new O(1,1,1,1);width=0;height=0;hullLength=0;edges=[];parentMesh=null;sequence=null;tempColor=new O(0,0,0,0);constructor(e,t){super(e),this.path=t}updateRegion(){if(!this.region)throw new Error("Region not set.");let e=this.regionUVs;(!this.uvs||this.uvs.length!=e.length)&&(this.uvs=X.newFloatArray(e.length));let t=this.uvs,i=this.uvs.length,s=this.region.u,n=this.region.v,h=0,a=0;if(this.region instanceof Fi){let r=this.region,o=r.page,l=o.width,c=o.height;switch(r.degrees){case 90:s-=(r.originalHeight-r.offsetY-r.height)/l,n-=(r.originalWidth-r.offsetX-r.width)/c,h=r.originalHeight/l,a=r.originalWidth/c;for(let f=0;f<i;f+=2)t[f]=s+e[f+1]*h,t[f+1]=n+(1-e[f])*a;return;case 180:s-=(r.originalWidth-r.offsetX-r.width)/l,n-=r.offsetY/c,h=r.originalWidth/l,a=r.originalHeight/c;for(let f=0;f<i;f+=2)t[f]=s+(1-e[f])*h,t[f+1]=n+(1-e[f+1])*a;return;case 270:s-=r.offsetY/l,n-=r.offsetX/c,h=r.originalHeight/l,a=r.originalWidth/c;for(let f=0;f<i;f+=2)t[f]=s+(1-e[f+1])*h,t[f+1]=n+e[f]*a;return}s-=r.offsetX/l,n-=(r.originalHeight-r.offsetY-r.height)/c,h=r.originalWidth/l,a=r.originalHeight/c}else this.region?(h=this.region.u2-s,a=this.region.v2-n):(s=n=0,h=a=1);for(let r=0;r<i;r+=2)t[r]=s+e[r]*h,t[r+1]=n+e[r+1]*a}getParentMesh(){return this.parentMesh}setParentMesh(e){this.parentMesh=e,e&&(this.bones=e.bones,this.vertices=e.vertices,this.worldVerticesLength=e.worldVerticesLength,this.regionUVs=e.regionUVs,this.triangles=e.triangles,this.hullLength=e.hullLength,this.worldVerticesLength=e.worldVerticesLength)}copy(){if(this.parentMesh)return this.newLinkedMesh();let e=new Be(this.name,this.path);return e.region=this.region,e.color.setFromColor(this.color),this.copyTo(e),e.regionUVs=new Array(this.regionUVs.length),X.arrayCopy(this.regionUVs,0,e.regionUVs,0,this.regionUVs.length),e.uvs=new Array(this.uvs.length),X.arrayCopy(this.uvs,0,e.uvs,0,this.uvs.length),e.triangles=new Array(this.triangles.length),X.arrayCopy(this.triangles,0,e.triangles,0,this.triangles.length),e.hullLength=this.hullLength,e.sequence=this.sequence!=null?this.sequence.copy():null,this.edges&&(e.edges=new Array(this.edges.length),X.arrayCopy(this.edges,0,e.edges,0,this.edges.length)),e.width=this.width,e.height=this.height,e}computeWorldVertices(e,t,i,s,n,h){this.sequence!=null&&this.sequence.apply(e,this),super.computeWorldVertices(e,t,i,s,n,h)}newLinkedMesh(){let e=new Be(this.name,this.path);return e.region=this.region,e.color.setFromColor(this.color),e.timelineAttachment=this.timelineAttachment,e.setParentMesh(this.parentMesh?this.parentMesh:this),e.region!=null&&e.updateRegion(),e}},Ke=class extends ke{lengths=[];closed=!1;constantSpeed=!1;color=new O(1,1,1,1);constructor(e){super(e)}copy(){let e=new Ke(this.name);return this.copyTo(e),e.lengths=new Array(this.lengths.length),X.arrayCopy(this.lengths,0,e.lengths,0,this.lengths.length),e.closed=closed,e.constantSpeed=this.constantSpeed,e.color.setFromColor(this.color),e}},Pi=class extends ke{x=0;y=0;rotation=0;color=new O(.38,.94,0,1);constructor(e){super(e)}computeWorldPosition(e,t){return t.x=this.x*e.a+this.y*e.b+e.worldX,t.y=this.x*e.c+this.y*e.d+e.worldY,t}computeWorldRotation(e){const t=this.rotation*L.degRad,i=Math.cos(t),s=Math.sin(t),n=i*e.a+s*e.b,h=i*e.c+s*e.d;return L.atan2Deg(h,n)}copy(){let e=new Pi(this.name);return e.x=this.x,e.y=this.y,e.rotation=this.rotation,e.color.setFromColor(this.color),e}},Es=class extends Qt{x=0;y=0;scaleX=1;scaleY=1;rotation=0;width=0;height=0;color=new O(1,1,1,1);path;region=null;sequence=null;offset=X.newFloatArray(8);uvs=X.newFloatArray(8);tempColor=new O(1,1,1,1);constructor(e,t){super(e),this.path=t}updateRegion(){if(!this.region)throw new Error("Region not set.");let e=this.region,t=this.uvs;if(e==null){t[0]=0,t[1]=0,t[2]=0,t[3]=1,t[4]=1,t[5]=1,t[6]=1,t[7]=0;return}let i=this.width/this.region.originalWidth*this.scaleX,s=this.height/this.region.originalHeight*this.scaleY,n=-this.width/2*this.scaleX+this.region.offsetX*i,h=-this.height/2*this.scaleY+this.region.offsetY*s,a=n+this.region.width*i,r=h+this.region.height*s,o=this.rotation*L.degRad,l=Math.cos(o),c=Math.sin(o),f=this.x,d=this.y,u=n*l+f,m=n*c,g=h*l+d,w=h*c,b=a*l+f,p=a*c,x=r*l+d,y=r*c,v=this.offset;v[0]=u-w,v[1]=g+m,v[2]=u-y,v[3]=x+m,v[4]=b-y,v[5]=x+p,v[6]=b-w,v[7]=g+p,e.degrees==90?(t[0]=e.u2,t[1]=e.v2,t[2]=e.u,t[3]=e.v2,t[4]=e.u,t[5]=e.v,t[6]=e.u2,t[7]=e.v):(t[0]=e.u,t[1]=e.v2,t[2]=e.u,t[3]=e.v,t[4]=e.u2,t[5]=e.v,t[6]=e.u2,t[7]=e.v2)}computeWorldVertices(e,t,i,s){this.sequence!=null&&this.sequence.apply(e,this);let n=e.bone,h=this.offset,a=n.worldX,r=n.worldY,o=n.a,l=n.b,c=n.c,f=n.d,d=0,u=0;d=h[0],u=h[1],t[i]=d*o+u*l+a,t[i+1]=d*c+u*f+r,i+=s,d=h[2],u=h[3],t[i]=d*o+u*l+a,t[i+1]=d*c+u*f+r,i+=s,d=h[4],u=h[5],t[i]=d*o+u*l+a,t[i+1]=d*c+u*f+r,i+=s,d=h[6],u=h[7],t[i]=d*o+u*l+a,t[i+1]=d*c+u*f+r}copy(){let e=new Es(this.name,this.path);return e.region=this.region,e.x=this.x,e.y=this.y,e.scaleX=this.scaleX,e.scaleY=this.scaleY,e.rotation=this.rotation,e.width=this.width,e.height=this.height,X.arrayCopy(this.uvs,0,e.uvs,0,8),X.arrayCopy(this.offset,0,e.offset,0,8),e.color.setFromColor(this.color),e.sequence=this.sequence!=null?this.sequence.copy():null,e}},V=Es;B(V,"X1",0),B(V,"Y1",1),B(V,"C1R",2),B(V,"C1G",3),B(V,"C1B",4),B(V,"C1A",5),B(V,"U1",6),B(V,"V1",7),B(V,"X2",8),B(V,"Y2",9),B(V,"C2R",10),B(V,"C2G",11),B(V,"C2B",12),B(V,"C2A",13),B(V,"U2",14),B(V,"V2",15),B(V,"X3",16),B(V,"Y3",17),B(V,"C3R",18),B(V,"C3G",19),B(V,"C3B",20),B(V,"C3A",21),B(V,"U3",22),B(V,"V3",23),B(V,"X4",24),B(V,"Y4",25),B(V,"C4R",26),B(V,"C4G",27),B(V,"C4B",28),B(V,"C4A",29),B(V,"U4",30),B(V,"V4",31);var Li=class{atlas;constructor(e){this.atlas=e}loadSequence(e,t,i){let s=i.regions;for(let n=0,h=s.length;n<h;n++){let a=i.getPath(t,n),r=this.atlas.findRegion(a);if(r==null)throw new Error("Region not found in atlas: "+a+" (sequence: "+e+")");s[n]=r}}newRegionAttachment(e,t,i,s){let n=new V(t,i);if(s!=null)this.loadSequence(t,i,s);else{let h=this.atlas.findRegion(i);if(!h)throw new Error("Region not found in atlas: "+i+" (region attachment: "+t+")");n.region=h}return n}newMeshAttachment(e,t,i,s){let n=new Be(t,i);if(s!=null)this.loadSequence(t,i,s);else{let h=this.atlas.findRegion(i);if(!h)throw new Error("Region not found in atlas: "+i+" (mesh attachment: "+t+")");n.region=h}return n}newBoundingBoxAttachment(e,t){return new Yt(t)}newPathAttachment(e,t){return new Ke(t)}newPointAttachment(e,t){return new Pi(t)}newClippingAttachment(e,t){return new st(t)}},Xi=class{index=0;name;parent=null;length=0;x=0;y=0;rotation=0;scaleX=1;scaleY=1;shearX=0;shearY=0;inherit=gt.Normal;skinRequired=!1;color=new O;icon;visible=!1;constructor(e,t,i){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=i}},gt=(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))(gt||{}),Bi=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,i){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=i,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,i,s,n,h,a){this.ax=e,this.ay=t,this.arotation=i,this.ascaleX=s,this.ascaleY=n,this.ashearX=h,this.ashearY=a;let r=this.parent;if(!r){let d=this.skeleton;const u=d.scaleX,m=d.scaleY,g=(i+h)*L.degRad,w=(i+90+a)*L.degRad;this.a=Math.cos(g)*s*u,this.b=Math.cos(w)*n*u,this.c=Math.sin(g)*s*m,this.d=Math.sin(w)*n*m,this.worldX=e*u+d.x,this.worldY=t*m+d.y;return}let o=r.a,l=r.b,c=r.c,f=r.d;switch(this.worldX=o*e+l*t+r.worldX,this.worldY=c*e+f*t+r.worldY,this.inherit){case 0:{const d=(i+h)*L.degRad,u=(i+90+a)*L.degRad,m=Math.cos(d)*s,g=Math.cos(u)*n,w=Math.sin(d)*s,b=Math.sin(u)*n;this.a=o*m+l*w,this.b=o*g+l*b,this.c=c*m+f*w,this.d=c*g+f*b;return}case 1:{const d=(i+h)*L.degRad,u=(i+90+a)*L.degRad;this.a=Math.cos(d)*s,this.b=Math.cos(u)*n,this.c=Math.sin(d)*s,this.d=Math.sin(u)*n;break}case 2:{let d=1/this.skeleton.scaleX,u=1/this.skeleton.scaleY;o*=d,c*=u;let m=o*o+c*c,g=0;m>1e-4?(m=Math.abs(o*f*u-l*d*c)/m,l=c*m,f=o*m,g=Math.atan2(c,o)*L.radDeg):(o=0,c=0,g=90-Math.atan2(f,l)*L.radDeg);const w=(i+h-g)*L.degRad,b=(i+a-g+90)*L.degRad,p=Math.cos(w)*s,x=Math.cos(b)*n,y=Math.sin(w)*s,v=Math.sin(b)*n;this.a=o*p-l*y,this.b=o*x-l*v,this.c=c*p+f*y,this.d=c*x+f*v;break}case 3:case 4:{i*=L.degRad;const d=Math.cos(i),u=Math.sin(i);let m=(o*d+l*u)/this.skeleton.scaleX,g=(c*d+f*u)/this.skeleton.scaleY,w=Math.sqrt(m*m+g*g);w>1e-5&&(w=1/w),m*=w,g*=w,w=Math.sqrt(m*m+g*g),this.inherit==3&&o*f-l*c<0!=(this.skeleton.scaleX<0!=this.skeleton.scaleY<0)&&(w=-w),i=Math.PI/2+Math.atan2(g,m);const b=Math.cos(i)*w,p=Math.sin(i)*w;h*=L.degRad,a=(90+a)*L.degRad;const x=Math.cos(h)*s,y=Math.cos(a)*n,v=Math.sin(h)*s,A=Math.sin(a)*n;this.a=m*x+b*v,this.b=m*y+b*A,this.c=g*x+p*v,this.d=g*y+p*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,i=e.b,s=e.c,n=e.d,h=1/(t*n-i*s),a=n*h,r=i*h,o=s*h,l=t*h,c=this.worldX-e.worldX,f=this.worldY-e.worldY;this.ax=c*a-f*r,this.ay=f*l-c*o;let d,u,m,g;if(this.inherit==1)d=this.a,u=this.b,m=this.c,g=this.d;else{switch(this.inherit){case 2:{let y=Math.abs(t*n-i*s)/(t*t+s*s);i=-s*this.skeleton.scaleX*y/this.skeleton.scaleY,n=t*this.skeleton.scaleY*y/this.skeleton.scaleX,h=1/(t*n-i*s),a=n*h,r=i*h;break}case 3:case 4:let w=L.cosDeg(this.rotation),b=L.sinDeg(this.rotation);t=(t*w+i*b)/this.skeleton.scaleX,s=(s*w+n*b)/this.skeleton.scaleY;let p=Math.sqrt(t*t+s*s);p>1e-5&&(p=1/p),t*=p,s*=p,p=Math.sqrt(t*t+s*s),this.inherit==3&&h<0!=(this.skeleton.scaleX<0!=this.skeleton.scaleY<0)&&(p=-p);let x=L.PI/2+Math.atan2(s,t);i=Math.cos(x)*p,n=Math.sin(x)*p,h=1/(t*n-i*s),a=n*h,r=i*h,o=s*h,l=t*h}d=a*this.a-r*this.c,u=a*this.b-r*this.d,m=l*this.c-o*this.a,g=l*this.d-o*this.b}if(this.ashearX=0,this.ascaleX=Math.sqrt(d*d+m*m),this.ascaleX>1e-4){let w=d*g-u*m;this.ascaleY=w/this.ascaleX,this.ashearY=-Math.atan2(d*u+m*g,w)*L.radDeg,this.arotation=Math.atan2(m,d)*L.radDeg}else this.ascaleX=0,this.ascaleY=Math.sqrt(u*u+g*g),this.ashearY=0,this.arotation=90-Math.atan2(g,u)*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),i=e.x-this.worldX,s=e.y-this.worldY;return e.x=i*this.d*t-s*this.b*t,e.y=s*this.a*t-i*this.c*t,e}localToWorld(e){let t=e.x,i=e.y;return e.x=t*this.a+i*this.b+this.worldX,e.y=t*this.c+i*this.d+this.worldY,e}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),i=L.cosDeg(e);return Math.atan2(this.a*t-this.c*i,this.d*i-this.b*t)*L.radDeg+this.rotation-this.shearX}localToWorldRotation(e){e-=this.rotation-this.shearX;let t=L.sinDeg(e),i=L.cosDeg(e);return Math.atan2(i*this.c+t*this.d,i*this.a+t*this.b)*L.radDeg}rotateWorld(e){e*=L.degRad;const t=Math.sin(e),i=Math.cos(e),s=this.a,n=this.b;this.a=i*s-t*this.c,this.b=i*n-t*this.d,this.c=t*s+i*this.c,this.d=t*n+i*this.d}},pt=class{constructor(e,t,i){this.name=e,this.order=t,this.skinRequired=i}},Rs=class{pathPrefix="";textureLoader;downloader;assets={};errors={};toLoad=0;loaded=0;constructor(e,t="",i=new Oi){this.textureLoader=e,this.pathPrefix=t,this.downloader=i}start(e){return this.toLoad++,this.pathPrefix+e}success(e,t,i){this.toLoad--,this.loaded++,this.assets[t]=i,e&&e(t,i)}error(e,t,i){this.toLoad--,this.loaded++,this.errors[t]=i,e&&e(t,i)}loadAll(){return new Promise((t,i)=>{let s=()=>{if(this.isLoadingComplete()){this.hasErrors()?i(this.errors):t(this);return}requestAnimationFrame(s)};requestAnimationFrame(s)})}setRawDataURI(e,t){this.downloader.rawDataUris[this.pathPrefix+e]=t}loadBinary(e,t=()=>{},i=()=>{}){e=this.start(e),this.downloader.downloadBinary(e,s=>{this.success(t,e,s)},(s,n)=>{this.error(i,e,`Couldn't load binary ${e}: status ${s}, ${n}`)})}loadText(e,t=()=>{},i=()=>{}){e=this.start(e),this.downloader.downloadText(e,s=>{this.success(t,e,s)},(s,n)=>{this.error(i,e,`Couldn't load text ${e}: status ${s}, ${n}`)})}loadJson(e,t=()=>{},i=()=>{}){e=this.start(e),this.downloader.downloadJson(e,s=>{this.success(t,e,s)},(s,n)=>{this.error(i,e,`Couldn't load JSON ${e}: status ${s}, ${n}`)})}loadTexture(e,t=()=>{},i=()=>{}){if(e=this.start(e),!!!(typeof window<"u"&&typeof navigator<"u"&&window.document))fetch(e,{mode:"cors"}).then(h=>h.ok?h.blob():(this.error(i,e,`Couldn't load image: ${e}`),null)).then(h=>h?createImageBitmap(h,{premultiplyAlpha:"none",colorSpaceConversion:"none"}):null).then(h=>{h&&this.success(t,e,this.textureLoader(h))});else{let h=new Image;h.crossOrigin="anonymous",h.onload=()=>{this.success(t,e,this.textureLoader(h))},h.onerror=()=>{this.error(i,e,`Couldn't load image: ${e}`)},this.downloader.rawDataUris[e]&&(e=this.downloader.rawDataUris[e]),h.src=e}}loadTextureAtlas(e,t=()=>{},i=()=>{},s){let n=e.lastIndexOf("/"),h=n>=0?e.substring(0,n+1):"";e=this.start(e),this.downloader.downloadText(e,a=>{try{let r=new Yi(a),o=r.pages.length,l=!1;for(let c of r.pages)this.loadTexture(s?s[c.name]:h+c.name,(f,d)=>{l||(c.setTexture(d),--o==0&&this.success(t,e,r))},(f,d)=>{l||this.error(i,e,`Couldn't load texture atlas ${e} page image: ${f}`),l=!0})}catch(r){this.error(i,e,`Couldn't parse texture atlas ${e}: ${r.message}`)}},(a,r)=>{this.error(i,e,`Couldn't load texture atlas ${e}: status ${a}, ${r}`)})}get(e){return this.assets[this.pathPrefix+e]}require(e){e=this.pathPrefix+e;let t=this.assets[e];if(t)return t;let i=this.errors[e];throw Error("Asset not found: "+e+(i?`
2
- `+i:""))}remove(e){e=this.pathPrefix+e;let t=this.assets[e];return t.dispose&&t.dispose(),delete this.assets[e],t}removeAll(){for(let e in this.assets){let t=this.assets[e];t.dispose&&t.dispose()}this.assets={}}isLoadingComplete(){return this.toLoad==0}getToLoad(){return this.toLoad}getLoaded(){return this.loaded}dispose(){this.removeAll()}hasErrors(){return Object.keys(this.errors).length>0}getErrors(){return this.errors}},Oi=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),i=t.length,s=new Uint8Array(i),n=0;n<i;n++)s[n]=t.charCodeAt(n);return s}dataUriToUint8Array(e){if(!e.startsWith("data:"))throw new Error("Not a data URI.");let t=e.indexOf("base64,");if(t==-1)throw new Error("Not a binary data URI.");return t+=7,this.base64ToUint8Array(e.substr(t))}downloadText(e,t,i){if(this.start(e,t,i))return;if(this.rawDataUris[e]){try{let h=this.rawDataUris[e];this.finish(e,200,this.dataUriToString(h))}catch(h){this.finish(e,400,JSON.stringify(h))}return}let s=new XMLHttpRequest;s.overrideMimeType("text/html"),s.open("GET",e,!0);let n=()=>{this.finish(e,s.status,s.responseText)};s.onload=n,s.onerror=n,s.send()}downloadJson(e,t,i){this.downloadText(e,s=>{t(JSON.parse(s))},i)}downloadBinary(e,t,i){if(this.start(e,t,i))return;if(this.rawDataUris[e]){try{let h=this.rawDataUris[e];this.finish(e,200,this.dataUriToUint8Array(h))}catch(h){this.finish(e,400,JSON.stringify(h))}return}let s=new XMLHttpRequest;s.open("GET",e,!0),s.responseType="arraybuffer";let n=()=>{this.finish(e,s.status,s.response)};s.onload=()=>{s.status==200||s.status==0?this.finish(e,200,new Uint8Array(s.response)):n()},s.onerror=n,s.send()}start(e,t,i){let s=this.callbacks[e];try{if(s)return!0;this.callbacks[e]=s=[]}finally{s.push(t,i)}}finish(e,t,i){let s=this.callbacks[e];delete this.callbacks[e];let n=t==200||t==0?[i]:[t,i];for(let h=n.length-1,a=s.length;h<a;h+=2)s[h].apply(null,n)}},Vi=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}},Di=class{name;intValue=0;floatValue=0;stringValue=null;audioPath=null;volume=0;balance=0;constructor(e){this.name=e}},ks=class{data;bones;target;bendDirection=0;compress=!1;stretch=!1;mix=1;softness=0;active=!1;constructor(e,t){if(!e)throw new Error("data cannot be null.");if(!t)throw new Error("skeleton cannot be null.");this.data=e,this.bones=new Array;for(let s=0;s<e.bones.length;s++){let n=t.findBone(e.bones[s].name);if(!n)throw new Error(`Couldn't find bone ${e.bones[s].name}`);this.bones.push(n)}let i=t.findBone(e.target.name);if(!i)throw new Error(`Couldn't find bone ${e.target.name}`);this.target=i,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,i=this.bones;switch(i.length){case 1:this.apply1(i[0],t.worldX,t.worldY,this.compress,this.stretch,this.data.uniform,this.mix);break;case 2:this.apply2(i[0],i[1],t.worldX,t.worldY,this.bendDirection,this.stretch,this.data.uniform,this.softness,this.mix);break}}apply1(e,t,i,s,n,h,a){let r=e.parent;if(!r)throw new Error("IK bone must have parent.");let o=r.a,l=r.b,c=r.c,f=r.d,d=-e.ashearX-e.arotation,u=0,m=0;switch(e.inherit){case 1:u=(t-e.worldX)*L.signum(e.skeleton.scaleX),m=(i-e.worldY)*L.signum(e.skeleton.scaleY);break;case 2:let b=Math.abs(o*f-l*c)/Math.max(1e-4,o*o+c*c),p=o/e.skeleton.scaleX,x=c/e.skeleton.scaleY;l=-x*b*e.skeleton.scaleX,f=p*b*e.skeleton.scaleY,d+=Math.atan2(x,p)*L.radDeg;default:let y=t-r.worldX,v=i-r.worldY,A=o*f-l*c;Math.abs(A)<=1e-4?(u=0,m=0):(u=(y*f-v*l)/A-e.ax,m=(v*o-y*c)/A-e.ay)}d+=Math.atan2(m,u)*L.radDeg,e.ascaleX<0&&(d+=180),d>180?d-=360:d<-180&&(d+=360);let g=e.ascaleX,w=e.ascaleY;if(s||n){switch(e.inherit){case 3:case 4:u=t-e.worldX,m=i-e.worldY}const b=e.data.length*g;if(b>1e-4){const p=u*u+m*m;if(s&&p<b*b||n&&p>b*b){const x=(Math.sqrt(p)/b-1)*a+1;g*=x,h&&(w*=x)}}}e.updateWorldTransformWith(e.ax,e.ay,e.arotation+d*a,g,w,e.ashearX,e.ashearY)}apply2(e,t,i,s,n,h,a,r,o){if(e.inherit!=0||t.inherit!=0)return;let l=e.ax,c=e.ay,f=e.ascaleX,d=e.ascaleY,u=f,m=d,g=t.ascaleX,w=0,b=0,p=0;f<0?(f=-f,w=180,p=-1):(w=0,p=1),d<0&&(d=-d,p=-p),g<0?(g=-g,b=180):b=0;let x=t.ax,y=0,v=0,A=0,C=e.a,S=e.b,E=e.c,R=e.d,Y=Math.abs(f-d)<=1e-4;!Y||h?(y=0,v=C*x+e.worldX,A=E*x+e.worldY):(y=t.ay,v=C*x+S*y+e.worldX,A=E*x+R*y+e.worldY);let P=e.parent;if(!P)throw new Error("IK parent must itself have a parent.");C=P.a,S=P.b,E=P.c,R=P.d;let I=C*R-S*E,k=v-P.worldX,F=A-P.worldY;I=Math.abs(I)<=1e-4?0:1/I;let se=(k*R-F*S)*I-l,re=(F*C-k*E)*I-c,ie=Math.sqrt(se*se+re*re),ce=t.data.length*g,de,fe;if(ie<1e-4){this.apply1(e,i,s,!1,h,!1,o),t.updateWorldTransformWith(x,y,0,t.ascaleX,t.ascaleY,t.ashearX,t.ashearY);return}k=i-P.worldX,F=s-P.worldY;let K=(k*R-F*S)*I-l,ae=(F*C-k*E)*I-c,le=K*K+ae*ae;if(r!=0){r*=f*(g+1)*.5;let ge=Math.sqrt(le),we=ge-ie-ce*f+r;if(we>0){let ve=Math.min(1,we/(r*2))-1;ve=(we-r*(1-ve*ve))/ge,K-=ve*K,ae-=ve*ae,le=K*K+ae*ae}}e:if(Y){ce*=f;let ge=(le-ie*ie-ce*ce)/(2*ie*ce);ge<-1?(ge=-1,fe=Math.PI*n):ge>1?(ge=1,fe=0,h&&(C=(Math.sqrt(le)/(ie+ce)-1)*o+1,u*=C,a&&(m*=C))):fe=Math.acos(ge)*n,C=ie+ce*ge,S=ce*Math.sin(fe),de=Math.atan2(ae*C-K*S,K*C+ae*S)}else{C=f*ce,S=d*ce;let ge=C*C,we=S*S,ve=Math.atan2(ae,K);E=we*ie*ie+ge*le-ge*we;let qe=-2*we*ie,yt=we-ge;if(R=qe*qe-4*yt*E,R>=0){let ct=Math.sqrt(R);qe<0&&(ct=-ct),ct=-(qe+ct)*.5;let At=ct/yt,br=E/ct,jt=Math.abs(At)<Math.abs(br)?At:br;if(At=le-jt*jt,At>=0){F=Math.sqrt(At)*n,de=ve-Math.atan2(F,jt),fe=Math.atan2(F/d,(jt-ie)/f);break e}}let mr=L.PI,qt=ie-C,as=qt*qt,gr=0,pr=0,Ht=ie+C,ls=Ht*Ht,xr=0;E=-C*ie/(ge-we),E>=-1&&E<=1&&(E=Math.acos(E),k=C*Math.cos(E)+ie,F=S*Math.sin(E),R=k*k+F*F,R<as&&(mr=E,as=R,qt=k,gr=F),R>ls&&(pr=E,ls=R,Ht=k,xr=F)),le<=(as+ls)*.5?(de=ve-Math.atan2(gr*n,qt),fe=mr*n):(de=ve-Math.atan2(xr*n,Ht),fe=pr*n)}let Ee=Math.atan2(y,x)*p,Te=e.arotation;de=(de-Ee)*L.radDeg+w-Te,de>180?de-=360:de<-180&&(de+=360),e.updateWorldTransformWith(l,c,Te+de*o,u,m,0,0),Te=t.arotation,fe=((fe+Ee)*L.radDeg-t.ashearX)*p+b-Te,fe>180?fe-=360:fe<-180&&(fe+=360),t.updateWorldTransformWith(x,y,Te+fe*o,t.ascaleX,t.ascaleY,t.ashearX,t.ashearY)}},Ni=class extends pt{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)}},_i=class extends pt{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=Lt.Fixed;spacingMode=Xt.Fixed;rotateMode=Bt.Chain;offsetRotation=0;position=0;spacing=0;mixRotate=0;mixX=0;mixY=0;constructor(e){super(e,0,!1)}},Lt=(e=>(e[e.Fixed=0]="Fixed",e[e.Percent=1]="Percent",e))(Lt||{}),Xt=(e=>(e[e.Length=0]="Length",e[e.Fixed=1]="Fixed",e[e.Percent=2]="Percent",e[e.Proportional=3]="Proportional",e))(Xt||{}),Bt=(e=>(e[e.Tangent=0]="Tangent",e[e.Chain=1]="Chain",e[e.ChainScale=2]="ChainScale",e))(Bt||{}),Ue=class{data;bones;target;position=0;spacing=0;mixRotate=0;mixX=0;mixY=0;spaces=new Array;positions=new Array;world=new Array;curves=new Array;lengths=new Array;segments=new Array;active=!1;constructor(e,t){if(!e)throw new Error("data cannot be null.");if(!t)throw new Error("skeleton cannot be null.");this.data=e,this.bones=new Array;for(let s=0,n=e.bones.length;s<n;s++){let h=t.findBone(e.bones[s].name);if(!h)throw new Error(`Couldn't find bone ${e.bones[s].name}.`);this.bones.push(h)}let i=t.findSlot(e.target.name);if(!i)throw new Error(`Couldn't find target bone ${e.target.name}`);this.target=i,this.position=e.position,this.spacing=e.spacing,this.mixRotate=e.mixRotate,this.mixX=e.mixX,this.mixY=e.mixY}isActive(){return this.active}setToSetupPose(){const e=this.data;this.position=e.position,this.spacing=e.spacing,this.mixRotate=e.mixRotate,this.mixX=e.mixX,this.mixY=e.mixY}update(e){let t=this.target.getAttachment();if(!(t instanceof Ke))return;let i=this.mixRotate,s=this.mixX,n=this.mixY;if(i==0&&s==0&&n==0)return;let h=this.data,a=h.rotateMode==0,r=h.rotateMode==2,o=this.bones,l=o.length,c=a?l:l+1,f=X.setArraySize(this.spaces,c),d=r?this.lengths=X.setArraySize(this.lengths,l):[],u=this.spacing;switch(h.spacingMode){case 2:if(r)for(let v=0,A=c-1;v<A;v++){let C=o[v],S=C.data.length,E=S*C.a,R=S*C.c;d[v]=Math.sqrt(E*E+R*R)}X.arrayFill(f,1,c,u);break;case 3:let x=0;for(let v=0,A=c-1;v<A;){let C=o[v],S=C.data.length;if(S<Ue.epsilon)r&&(d[v]=0),f[++v]=u;else{let E=S*C.a,R=S*C.c,Y=Math.sqrt(E*E+R*R);r&&(d[v]=Y),f[++v]=Y,x+=Y}}if(x>0){x=c/x*u;for(let v=1;v<c;v++)f[v]*=x}break;default:let y=h.spacingMode==0;for(let v=0,A=c-1;v<A;){let C=o[v],S=C.data.length;if(S<Ue.epsilon)r&&(d[v]=0),f[++v]=u;else{let E=S*C.a,R=S*C.c,Y=Math.sqrt(E*E+R*R);r&&(d[v]=Y),f[++v]=(y?S+u:u)*Y/S}}}let m=this.computeWorldPositions(t,c,a),g=m[0],w=m[1],b=h.offsetRotation,p=!1;if(b==0)p=h.rotateMode==1;else{p=!1;let x=this.target.bone;b*=x.a*x.d-x.b*x.c>0?L.degRad:-L.degRad}for(let x=0,y=3;x<l;x++,y+=3){let v=o[x];v.worldX+=(g-v.worldX)*s,v.worldY+=(w-v.worldY)*n;let A=m[y],C=m[y+1],S=A-g,E=C-w;if(r){let R=d[x];if(R!=0){let Y=(Math.sqrt(S*S+E*E)/R-1)*i+1;v.a*=Y,v.c*=Y}}if(g=A,w=C,i>0){let R=v.a,Y=v.b,P=v.c,I=v.d,k=0,F=0,se=0;if(a?k=m[y-1]:f[x+1]==0?k=m[y+2]:k=Math.atan2(E,S),k-=Math.atan2(P,R),p){F=Math.cos(k),se=Math.sin(k);let re=v.data.length;g+=(re*(F*R-se*P)-S)*i,w+=(re*(se*R+F*P)-E)*i}else k+=b;k>L.PI?k-=L.PI2:k<-L.PI&&(k+=L.PI2),k*=i,F=Math.cos(k),se=Math.sin(k),v.a=F*R-se*P,v.b=F*Y-se*I,v.c=se*R+F*P,v.d=se*Y+F*I}v.updateAppliedTransform()}}computeWorldPositions(e,t,i){let s=this.target,n=this.position,h=this.spaces,a=X.setArraySize(this.positions,t*3+2),r=this.world,o=e.closed,l=e.worldVerticesLength,c=l/6,f=Ue.NONE;if(!e.constantSpeed){let re=e.lengths;c-=o?1:2;let ie=re[c];this.data.positionMode==1&&(n*=ie);let ce;switch(this.data.spacingMode){case 2:ce=ie;break;case 3:ce=ie/t;break;default:ce=1}r=X.setArraySize(this.world,8);for(let de=0,fe=0,K=0;de<t;de++,fe+=3){let ae=h[de]*ce;n+=ae;let le=n;if(o)le%=ie,le<0&&(le+=ie),K=0;else if(le<0){f!=Ue.BEFORE&&(f=Ue.BEFORE,e.computeWorldVertices(s,2,4,r,0,2)),this.addBeforePosition(le,r,0,a,fe);continue}else if(le>ie){f!=Ue.AFTER&&(f=Ue.AFTER,e.computeWorldVertices(s,l-6,4,r,0,2)),this.addAfterPosition(le-ie,r,0,a,fe);continue}for(;;K++){let Ee=re[K];if(!(le>Ee)){if(K==0)le/=Ee;else{let Te=re[K-1];le=(le-Te)/(Ee-Te)}break}}K!=f&&(f=K,o&&K==c?(e.computeWorldVertices(s,l-4,4,r,0,2),e.computeWorldVertices(s,0,4,r,4,2)):e.computeWorldVertices(s,K*6+2,8,r,0,2)),this.addCurvePosition(le,r[0],r[1],r[2],r[3],r[4],r[5],r[6],r[7],a,fe,i||de>0&&ae==0)}return a}o?(l+=2,r=X.setArraySize(this.world,l),e.computeWorldVertices(s,2,l-4,r,0,2),e.computeWorldVertices(s,0,2,r,l-4,2),r[l-2]=r[0],r[l-1]=r[1]):(c--,l-=4,r=X.setArraySize(this.world,l),e.computeWorldVertices(s,2,l,r,0,2));let d=X.setArraySize(this.curves,c),u=0,m=r[0],g=r[1],w=0,b=0,p=0,x=0,y=0,v=0,A=0,C=0,S=0,E=0,R=0,Y=0,P=0,I=0;for(let re=0,ie=2;re<c;re++,ie+=6)w=r[ie],b=r[ie+1],p=r[ie+2],x=r[ie+3],y=r[ie+4],v=r[ie+5],A=(m-w*2+p)*.1875,C=(g-b*2+x)*.1875,S=((w-p)*3-m+y)*.09375,E=((b-x)*3-g+v)*.09375,R=A*2+S,Y=C*2+E,P=(w-m)*.75+A+S*.16666667,I=(b-g)*.75+C+E*.16666667,u+=Math.sqrt(P*P+I*I),P+=R,I+=Y,R+=S,Y+=E,u+=Math.sqrt(P*P+I*I),P+=R,I+=Y,u+=Math.sqrt(P*P+I*I),P+=R+S,I+=Y+E,u+=Math.sqrt(P*P+I*I),d[re]=u,m=y,g=v;this.data.positionMode==1&&(n*=u);let k;switch(this.data.spacingMode){case 2:k=u;break;case 3:k=u/t;break;default:k=1}let F=this.segments,se=0;for(let re=0,ie=0,ce=0,de=0;re<t;re++,ie+=3){let fe=h[re]*k;n+=fe;let K=n;if(o)K%=u,K<0&&(K+=u),ce=0;else if(K<0){this.addBeforePosition(K,r,0,a,ie);continue}else if(K>u){this.addAfterPosition(K-u,r,l-4,a,ie);continue}for(;;ce++){let ae=d[ce];if(!(K>ae)){if(ce==0)K/=ae;else{let le=d[ce-1];K=(K-le)/(ae-le)}break}}if(ce!=f){f=ce;let ae=ce*6;for(m=r[ae],g=r[ae+1],w=r[ae+2],b=r[ae+3],p=r[ae+4],x=r[ae+5],y=r[ae+6],v=r[ae+7],A=(m-w*2+p)*.03,C=(g-b*2+x)*.03,S=((w-p)*3-m+y)*.006,E=((b-x)*3-g+v)*.006,R=A*2+S,Y=C*2+E,P=(w-m)*.3+A+S*.16666667,I=(b-g)*.3+C+E*.16666667,se=Math.sqrt(P*P+I*I),F[0]=se,ae=1;ae<8;ae++)P+=R,I+=Y,R+=S,Y+=E,se+=Math.sqrt(P*P+I*I),F[ae]=se;P+=R,I+=Y,se+=Math.sqrt(P*P+I*I),F[8]=se,P+=R+S,I+=Y+E,se+=Math.sqrt(P*P+I*I),F[9]=se,de=0}for(K*=se;;de++){let ae=F[de];if(!(K>ae)){if(de==0)K/=ae;else{let le=F[de-1];K=de+(K-le)/(ae-le)}break}}this.addCurvePosition(K*.1,m,g,w,b,p,x,y,v,a,ie,i||re>0&&fe==0)}return a}addBeforePosition(e,t,i,s,n){let h=t[i],a=t[i+1],r=t[i+2]-h,o=t[i+3]-a,l=Math.atan2(o,r);s[n]=h+e*Math.cos(l),s[n+1]=a+e*Math.sin(l),s[n+2]=l}addAfterPosition(e,t,i,s,n){let h=t[i+2],a=t[i+3],r=h-t[i],o=a-t[i+1],l=Math.atan2(o,r);s[n]=h+e*Math.cos(l),s[n+1]=a+e*Math.sin(l),s[n+2]=l}addCurvePosition(e,t,i,s,n,h,a,r,o,l,c,f){if(e==0||isNaN(e)){l[c]=t,l[c+1]=i,l[c+2]=Math.atan2(n-i,s-t);return}let d=e*e,u=d*e,m=1-e,g=m*m,w=g*m,b=m*e,p=b*3,x=m*p,y=p*e,v=t*w+s*x+h*y+r*u,A=i*w+n*x+a*y+o*u;l[c]=v,l[c+1]=A,f&&(e<.001?l[c+2]=Math.atan2(n-i,s-t):l[c+2]=Math.atan2(A-(i*g+n*b*2+a*d),v-(t*g+s*b*2+h*d)))}},rt=Ue;B(rt,"NONE",-1),B(rt,"BEFORE",-2),B(rt,"AFTER",-3),B(rt,"epsilon",1e-5);var Nr=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 i=this.data.x>0,s=this.data.y>0,n=this.data.rotate>0||this.data.shearX>0,h=this.data.scaleX>0,a=this.bone,r=a.data.length;switch(e){case 0:return;case 1:this.reset();case 2:const o=this.skeleton,l=Math.max(this.skeleton.time-this.lastTime,0);this.remaining+=l,this.lastTime=o.time;const c=a.worldX,f=a.worldY;if(this._reset)this._reset=!1,this.ux=c,this.uy=f;else{let d=this.remaining,u=this.inertia,m=this.data.step,g=this.skeleton.data.referenceScale,w=-1,b=this.data.limit*l,p=b*Math.abs(o.scaleY);if(b*=Math.abs(o.scaleX),i||s){if(i){const x=(this.ux-c)*u;this.xOffset+=x>b?b:x<-b?-b:x,this.ux=c}if(s){const x=(this.uy-f)*u;this.yOffset+=x>p?p:x<-p?-p:x,this.uy=f}if(d>=m){w=Math.pow(this.damping,60*m);const x=this.massInverse*m,y=this.strength,v=this.wind*g*o.scaleX,A=this.gravity*g*o.scaleY;do i&&(this.xVelocity+=(v-this.xOffset*y)*x,this.xOffset+=this.xVelocity*m,this.xVelocity*=w),s&&(this.yVelocity-=(A+this.yOffset*y)*x,this.yOffset+=this.yVelocity*m,this.yVelocity*=w),d-=m;while(d>=m)}i&&(a.worldX+=this.xOffset*t*this.data.x),s&&(a.worldY+=this.yOffset*t*this.data.y)}if(n||h){let x=Math.atan2(a.c,a.a),y=0,v=0,A=0,C=this.cx-a.worldX,S=this.cy-a.worldY;if(C>b?C=b:C<-b&&(C=-b),S>p?S=p:S<-p&&(S=-p),n){A=(this.data.rotate+this.data.shearX)*t;let E=Math.atan2(S+this.ty,C+this.tx)-x-this.rotateOffset*A;this.rotateOffset+=(E-Math.ceil(E*L.invPI2-.5)*L.PI2)*u,E=this.rotateOffset*A+x,y=Math.cos(E),v=Math.sin(E),h&&(E=r*a.getWorldScaleX(),E>0&&(this.scaleOffset+=(C*y+S*v)*u/E))}else{y=Math.cos(x),v=Math.sin(x);const E=r*a.getWorldScaleX();E>0&&(this.scaleOffset+=(C*y+S*v)*u/E)}if(d=this.remaining,d>=m){w==-1&&(w=Math.pow(this.damping,60*m));const E=this.massInverse*m,R=this.strength,Y=this.wind,P=We.yDown?-this.gravity:this.gravity,I=r/g;for(;;)if(d-=m,h&&(this.scaleVelocity+=(Y*y-P*v-this.scaleOffset*R)*E,this.scaleOffset+=this.scaleVelocity*m,this.scaleVelocity*=w),n){if(this.rotateVelocity-=((Y*v+P*y)*I+this.rotateOffset*R)*E,this.rotateOffset+=this.rotateVelocity*m,this.rotateVelocity*=w,d<m)break;const k=this.rotateOffset*A+x;y=Math.cos(k),v=Math.sin(k)}else if(d<m)break}}this.remaining=d}this.cx=a.worldX,this.cy=a.worldY;break;case 3:i&&(a.worldX+=this.xOffset*t*this.data.x),s&&(a.worldY+=this.yOffset*t*this.data.y)}if(n){let o=this.rotateOffset*t,l=0,c=0,f=0;if(this.data.shearX>0){let d=0;this.data.rotate>0&&(d=o*this.data.rotate,l=Math.sin(d),c=Math.cos(d),f=a.b,a.b=c*f-l*a.d,a.d=l*f+c*a.d),d+=o*this.data.shearX,l=Math.sin(d),c=Math.cos(d),f=a.a,a.a=c*f-l*a.c,a.c=l*f+c*a.c}else o*=this.data.rotate,l=Math.sin(o),c=Math.cos(o),f=a.a,a.a=c*f-l*a.c,a.c=l*f+c*a.c,f=a.b,a.b=c*f-l*a.d,a.d=l*f+c*a.d}if(h){const o=1+this.scaleOffset*t*this.data.scaleX;a.a*=o,a.c*=o}e!=3&&(this.tx=r*a.a,this.ty=r*a.c),a.updateAppliedTransform()}translate(e,t){this.ux-=e,this.uy-=t,this.cx-=e,this.cy-=t}rotate(e,t,i){const s=i*L.degRad,n=Math.cos(s),h=Math.sin(s),a=this.cx-e,r=this.cy-t;this.translate(a*n-r*h-a,a*h+r*n-r)}},Ys=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 O,this.darkColor=e.darkColor?new O:null,this.setToSetupPose()}getSkeleton(){return this.bone.skeleton}getAttachment(){return this.attachment}setAttachment(e){this.attachment!=e&&((!(e instanceof ke)||!(this.attachment instanceof ke)||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}},Fs=class{data;bones;target;mixRotate=0;mixX=0;mixY=0;mixScaleX=0;mixScaleY=0;mixShearY=0;temp=new je;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 s=0;s<e.bones.length;s++){let n=t.findBone(e.bones[s].name);if(!n)throw new Error(`Couldn't find bone ${e.bones[s].name}.`);this.bones.push(n)}let i=t.findBone(e.target.name);if(!i)throw new Error(`Couldn't find target bone ${e.target.name}.`);this.target=i,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,i=this.mixY,s=this.mixScaleX,n=this.mixScaleY,h=this.mixShearY,a=t!=0||i!=0,r=this.target,o=r.a,l=r.b,c=r.c,f=r.d,d=o*f-l*c>0?L.degRad:-L.degRad,u=this.data.offsetRotation*d,m=this.data.offsetShearY*d,g=this.bones;for(let w=0,b=g.length;w<b;w++){let p=g[w];if(e!=0){let x=p.a,y=p.b,v=p.c,A=p.d,C=Math.atan2(c,o)-Math.atan2(v,x)+u;C>L.PI?C-=L.PI2:C<-L.PI&&(C+=L.PI2),C*=e;let S=Math.cos(C),E=Math.sin(C);p.a=S*x-E*v,p.b=S*y-E*A,p.c=E*x+S*v,p.d=E*y+S*A}if(a){let x=this.temp;r.localToWorld(x.set(this.data.offsetX,this.data.offsetY)),p.worldX+=(x.x-p.worldX)*t,p.worldY+=(x.y-p.worldY)*i}if(s!=0){let x=Math.sqrt(p.a*p.a+p.c*p.c);x!=0&&(x=(x+(Math.sqrt(o*o+c*c)-x+this.data.offsetScaleX)*s)/x),p.a*=x,p.c*=x}if(n!=0){let x=Math.sqrt(p.b*p.b+p.d*p.d);x!=0&&(x=(x+(Math.sqrt(l*l+f*f)-x+this.data.offsetScaleY)*n)/x),p.b*=x,p.d*=x}if(h>0){let x=p.b,y=p.d,v=Math.atan2(y,x),A=Math.atan2(f,l)-Math.atan2(c,o)-(v-Math.atan2(p.c,p.a));A>L.PI?A-=L.PI2:A<-L.PI&&(A+=L.PI2),A=v+(A+m)*h;let C=Math.sqrt(x*x+y*y);p.b=Math.cos(A)*C,p.d=Math.sin(A)*C}p.updateAppliedTransform()}}applyRelativeWorld(){let e=this.mixRotate,t=this.mixX,i=this.mixY,s=this.mixScaleX,n=this.mixScaleY,h=this.mixShearY,a=t!=0||i!=0,r=this.target,o=r.a,l=r.b,c=r.c,f=r.d,d=o*f-l*c>0?L.degRad:-L.degRad,u=this.data.offsetRotation*d,m=this.data.offsetShearY*d,g=this.bones;for(let w=0,b=g.length;w<b;w++){let p=g[w];if(e!=0){let x=p.a,y=p.b,v=p.c,A=p.d,C=Math.atan2(c,o)+u;C>L.PI?C-=L.PI2:C<-L.PI&&(C+=L.PI2),C*=e;let S=Math.cos(C),E=Math.sin(C);p.a=S*x-E*v,p.b=S*y-E*A,p.c=E*x+S*v,p.d=E*y+S*A}if(a){let x=this.temp;r.localToWorld(x.set(this.data.offsetX,this.data.offsetY)),p.worldX+=x.x*t,p.worldY+=x.y*i}if(s!=0){let x=(Math.sqrt(o*o+c*c)-1+this.data.offsetScaleX)*s+1;p.a*=x,p.c*=x}if(n!=0){let x=(Math.sqrt(l*l+f*f)-1+this.data.offsetScaleY)*n+1;p.b*=x,p.d*=x}if(h>0){let x=Math.atan2(f,l)-Math.atan2(c,o);x>L.PI?x-=L.PI2:x<-L.PI&&(x+=L.PI2);let y=p.b,v=p.d;x=Math.atan2(v,y)+(x-L.PI/2+m)*h;let A=Math.sqrt(y*y+v*v);p.b=Math.cos(x)*A,p.d=Math.sin(x)*A}p.updateAppliedTransform()}}applyAbsoluteLocal(){let e=this.mixRotate,t=this.mixX,i=this.mixY,s=this.mixScaleX,n=this.mixScaleY,h=this.mixShearY,a=this.target,r=this.bones;for(let o=0,l=r.length;o<l;o++){let c=r[o],f=c.arotation;e!=0&&(f+=(a.arotation-f+this.data.offsetRotation)*e);let d=c.ax,u=c.ay;d+=(a.ax-d+this.data.offsetX)*t,u+=(a.ay-u+this.data.offsetY)*i;let m=c.ascaleX,g=c.ascaleY;s!=0&&m!=0&&(m=(m+(a.ascaleX-m+this.data.offsetScaleX)*s)/m),n!=0&&g!=0&&(g=(g+(a.ascaleY-g+this.data.offsetScaleY)*n)/g);let w=c.ashearY;h!=0&&(w+=(a.ashearY-w+this.data.offsetShearY)*h),c.updateWorldTransformWith(d,u,f,m,g,c.ashearX,w)}}applyRelativeLocal(){let e=this.mixRotate,t=this.mixX,i=this.mixY,s=this.mixScaleX,n=this.mixScaleY,h=this.mixShearY,a=this.target,r=this.bones;for(let o=0,l=r.length;o<l;o++){let c=r[o],f=c.arotation+(a.arotation+this.data.offsetRotation)*e,d=c.ax+(a.ax+this.data.offsetX)*t,u=c.ay+(a.ay+this.data.offsetY)*i,m=c.ascaleX*((a.ascaleX-1+this.data.offsetScaleX)*s+1),g=c.ascaleY*((a.ascaleY-1+this.data.offsetScaleY)*n+1),w=c.ashearY+(a.ashearY+this.data.offsetShearY)*h;c.updateWorldTransformWith(d,u,f,m,g,c.ashearX,w)}}},Ui=class{data;bones;slots;drawOrder;ikConstraints;transformConstraints;pathConstraints;physicsConstraints;_updateCache=new Array;skin=null;color;scaleX=1;_scaleY=1;get scaleY(){return Ui.yDown?-this._scaleY:this._scaleY}set scaleY(e){this._scaleY=e}x=0;y=0;time=0;constructor(e){if(!e)throw new Error("data cannot be null.");this.data=e,this.bones=new Array;for(let t=0;t<e.bones.length;t++){let i=e.bones[t],s;if(!i.parent)s=new Bi(i,this,null);else{let n=this.bones[i.parent.index];s=new Bi(i,this,n),n.children.push(s)}this.bones.push(s)}this.slots=new Array,this.drawOrder=new Array;for(let t=0;t<e.slots.length;t++){let i=e.slots[t],s=this.bones[i.boneData.index],n=new Ys(i,s);this.slots.push(n),this.drawOrder.push(n)}this.ikConstraints=new Array;for(let t=0;t<e.ikConstraints.length;t++){let i=e.ikConstraints[t];this.ikConstraints.push(new ks(i,this))}this.transformConstraints=new Array;for(let t=0;t<e.transformConstraints.length;t++){let i=e.transformConstraints[t];this.transformConstraints.push(new Fs(i,this))}this.pathConstraints=new Array;for(let t=0;t<e.pathConstraints.length;t++){let i=e.pathConstraints[t];this.pathConstraints.push(new rt(i,this))}this.physicsConstraints=new Array;for(let t=0;t<e.physicsConstraints.length;t++){let i=e.physicsConstraints[t];this.physicsConstraints.push(new Nr(i,this))}this.color=new O(1,1,1,1),this.updateCache()}updateCache(){let e=this._updateCache;e.length=0;let t=this.bones;for(let f=0,d=t.length;f<d;f++){let u=t[f];u.sorted=u.data.skinRequired,u.active=!u.sorted}if(this.skin){let f=this.skin.bones;for(let d=0,u=this.skin.bones.length;d<u;d++){let m=this.bones[f[d].index];do m.sorted=!1,m.active=!0,m=m.parent;while(m)}}let i=this.ikConstraints,s=this.transformConstraints,n=this.pathConstraints,h=this.physicsConstraints,a=i.length,r=s.length,o=n.length,l=this.physicsConstraints.length,c=a+r+o+l;e:for(let f=0;f<c;f++){for(let d=0;d<a;d++){let u=i[d];if(u.data.order==f){this.sortIkConstraint(u);continue e}}for(let d=0;d<r;d++){let u=s[d];if(u.data.order==f){this.sortTransformConstraint(u);continue e}}for(let d=0;d<o;d++){let u=n[d];if(u.data.order==f){this.sortPathConstraint(u);continue e}}for(let d=0;d<l;d++){const u=h[d];if(u.data.order==f){this.sortPhysicsConstraint(u);continue e}}}for(let f=0,d=t.length;f<d;f++)this.sortBone(t[f])}sortIkConstraint(e){if(e.active=e.target.isActive()&&(!e.data.skinRequired||this.skin&&X.contains(this.skin.constraints,e.data,!0)),!e.active)return;let t=e.target;this.sortBone(t);let i=e.bones,s=i[0];if(this.sortBone(s),i.length==1)this._updateCache.push(e),this.sortReset(s.children);else{let n=i[i.length-1];this.sortBone(n),this._updateCache.push(e),this.sortReset(s.children),n.sorted=!0}}sortPathConstraint(e){if(e.active=e.target.bone.isActive()&&(!e.data.skinRequired||this.skin&&X.contains(this.skin.constraints,e.data,!0)),!e.active)return;let t=e.target,i=t.data.index,s=t.bone;this.skin&&this.sortPathConstraintAttachment(this.skin,i,s),this.data.defaultSkin&&this.data.defaultSkin!=this.skin&&this.sortPathConstraintAttachment(this.data.defaultSkin,i,s);for(let r=0,o=this.data.skins.length;r<o;r++)this.sortPathConstraintAttachment(this.data.skins[r],i,s);let n=t.getAttachment();n instanceof Ke&&this.sortPathConstraintAttachmentWith(n,s);let h=e.bones,a=h.length;for(let r=0;r<a;r++)this.sortBone(h[r]);this._updateCache.push(e);for(let r=0;r<a;r++)this.sortReset(h[r].children);for(let r=0;r<a;r++)h[r].sorted=!0}sortTransformConstraint(e){if(e.active=e.target.isActive()&&(!e.data.skinRequired||this.skin&&X.contains(this.skin.constraints,e.data,!0)),!e.active)return;this.sortBone(e.target);let t=e.bones,i=t.length;if(e.data.local)for(let s=0;s<i;s++){let n=t[s];this.sortBone(n.parent),this.sortBone(n)}else for(let s=0;s<i;s++)this.sortBone(t[s]);this._updateCache.push(e);for(let s=0;s<i;s++)this.sortReset(t[s].children);for(let s=0;s<i;s++)t[s].sorted=!0}sortPathConstraintAttachment(e,t,i){let s=e.attachments[t];if(s)for(let n in s)this.sortPathConstraintAttachmentWith(s[n],i)}sortPathConstraintAttachmentWith(e,t){if(!(e instanceof Ke))return;let i=e.bones;if(!i)this.sortBone(t);else{let s=this.bones;for(let n=0,h=i.length;n<h;){let a=i[n++];for(a+=n;n<a;)this.sortBone(s[i[n++]])}}}sortPhysicsConstraint(e){const t=e.bone;e.active=t.active&&(!e.data.skinRequired||this.skin!=null&&X.contains(this.skin.constraints,e.data,!0)),e.active&&(this.sortBone(t),this._updateCache.push(e),this.sortReset(t.children),t.sorted=!0)}sortBone(e){if(!e||e.sorted)return;let t=e.parent;t&&this.sortBone(t),e.sorted=!0,this._updateCache.push(e)}sortReset(e){for(let t=0,i=e.length;t<i;t++){let s=e[t];s.active&&(s.sorted&&this.sortReset(s.children),s.sorted=!1)}}updateWorldTransform(e){if(e==null)throw new Error("physics is undefined");let t=this.bones;for(let s=0,n=t.length;s<n;s++){let h=t[s];h.ax=h.x,h.ay=h.y,h.arotation=h.rotation,h.ascaleX=h.scaleX,h.ascaleY=h.scaleY,h.ashearX=h.shearX,h.ashearY=h.shearY}let i=this._updateCache;for(let s=0,n=i.length;s<n;s++)i[s].update(e)}updateWorldTransformWith(e,t){if(!t)throw new Error("parent cannot be null.");let i=this.bones;for(let g=1,w=i.length;g<w;g++){let b=i[g];b.ax=b.x,b.ay=b.y,b.arotation=b.rotation,b.ascaleX=b.scaleX,b.ascaleY=b.scaleY,b.ashearX=b.shearX,b.ashearY=b.shearY}let s=this.getRootBone();if(!s)throw new Error("Root bone must not be null.");let n=t.a,h=t.b,a=t.c,r=t.d;s.worldX=n*this.x+h*this.y+t.worldX,s.worldY=a*this.x+r*this.y+t.worldY;const o=(s.rotation+s.shearX)*L.degRad,l=(s.rotation+90+s.shearY)*L.degRad,c=Math.cos(o)*s.scaleX,f=Math.cos(l)*s.scaleY,d=Math.sin(o)*s.scaleX,u=Math.sin(l)*s.scaleY;s.a=(n*c+h*d)*this.scaleX,s.b=(n*f+h*u)*this.scaleX,s.c=(a*c+r*d)*this.scaleY,s.d=(a*f+r*u)*this.scaleY;let m=this._updateCache;for(let g=0,w=m.length;g<w;g++){let b=m[g];b!=s&&b.update(e)}}setToSetupPose(){this.setBonesToSetupPose(),this.setSlotsToSetupPose()}setBonesToSetupPose(){for(const e of this.bones)e.setToSetupPose();for(const e of this.ikConstraints)e.setToSetupPose();for(const e of this.transformConstraints)e.setToSetupPose();for(const e of this.pathConstraints)e.setToSetupPose();for(const e of this.physicsConstraints)e.setToSetupPose()}setSlotsToSetupPose(){let e=this.slots;X.arrayCopy(e,0,this.drawOrder,0,e.length);for(let t=0,i=e.length;t<i;t++)e[t].setToSetupPose()}getRootBone(){return this.bones.length==0?null:this.bones[0]}findBone(e){if(!e)throw new Error("boneName cannot be null.");let t=this.bones;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.data.name==e)return n}return null}findSlot(e){if(!e)throw new Error("slotName cannot be null.");let t=this.slots;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.data.name==e)return n}return null}setSkinByName(e){let t=this.data.findSkin(e);if(!t)throw new Error("Skin not found: "+e);this.setSkin(t)}setSkin(e){if(e!=this.skin){if(e)if(this.skin)e.attachAll(this,this.skin);else{let t=this.slots;for(let i=0,s=t.length;i<s;i++){let n=t[i],h=n.data.attachmentName;if(h){let a=e.getAttachment(i,h);a&&n.setAttachment(a)}}}this.skin=e,this.updateCache()}}getAttachmentByName(e,t){let i=this.data.findSlot(e);if(!i)throw new Error(`Can't find slot with name ${e}`);return this.getAttachment(i.index,t)}getAttachment(e,t){if(!t)throw new Error("attachmentName cannot be null.");if(this.skin){let i=this.skin.getAttachment(e,t);if(i)return i}return this.data.defaultSkin?this.data.defaultSkin.getAttachment(e,t):null}setAttachment(e,t){if(!e)throw new Error("slotName cannot be null.");let i=this.slots;for(let s=0,n=i.length;s<n;s++){let h=i[s];if(h.data.name==e){let a=null;if(t&&(a=this.getAttachment(s,t),!a))throw new Error("Attachment not found: "+t+", for slot: "+e);h.setAttachment(a);return}}throw new Error("Slot not found: "+e)}findIkConstraint(e){if(!e)throw new Error("constraintName cannot be null.");return this.ikConstraints.find(t=>t.data.name==e)??null}findTransformConstraint(e){if(!e)throw new Error("constraintName cannot be null.");return this.transformConstraints.find(t=>t.data.name==e)??null}findPathConstraint(e){if(!e)throw new Error("constraintName cannot be null.");return this.pathConstraints.find(t=>t.data.name==e)??null}findPhysicsConstraint(e){if(e==null)throw new Error("constraintName cannot be null.");return this.physicsConstraints.find(t=>t.data.name==e)??null}getBoundsRect(e){let t=new je,i=new je;return this.getBounds(t,i,void 0,e),{x:t.x,y:t.y,width:i.x,height:i.y}}getBounds(e,t,i=new Array(2),s=null){if(!e)throw new Error("offset cannot be null.");if(!t)throw new Error("size cannot be null.");let n=this.drawOrder,h=Number.POSITIVE_INFINITY,a=Number.POSITIVE_INFINITY,r=Number.NEGATIVE_INFINITY,o=Number.NEGATIVE_INFINITY;for(let l=0,c=n.length;l<c;l++){let f=n[l];if(!f.bone.active)continue;let d=0,u=null,m=null,g=f.getAttachment();if(g instanceof V)d=8,u=X.setArraySize(i,d,0),g.computeWorldVertices(f,u,0,2),m=Ui.quadTriangles;else if(g instanceof Be){let w=g;d=w.worldVerticesLength,u=X.setArraySize(i,d,0),w.computeWorldVertices(f,0,d,u,0,2),m=w.triangles}else if(g instanceof st&&s!=null){s.clipStart(f,g);continue}if(u&&m){s!=null&&s.isClipping()&&(s.clipTriangles(u,m,m.length),u=s.clippedVertices,d=s.clippedVertices.length);for(let w=0,b=u.length;w<b;w+=2){let p=u[w],x=u[w+1];h=Math.min(h,p),a=Math.min(a,x),r=Math.max(r,p),o=Math.max(o,x)}}s?.clipEndWithSlot(f)}s?.clipEnd(),e.set(h,a),t.set(r-h,o-a)}update(e){this.time+=e}physicsTranslate(e,t){const i=this.physicsConstraints;for(let s=0,n=i.length;s<n;s++)i[s].translate(e,t)}physicsRotate(e,t,i){const s=this.physicsConstraints;for(let n=0,h=s.length;n<h;n++)s[n].rotate(e,t,i)}},We=Ui;B(We,"quadTriangles",[0,1,2,2,3,0]),B(We,"yDown",!1);var Ps=(e=>(e[e.none=0]="none",e[e.reset=1]="reset",e[e.update=2]="update",e[e.pose=3]="pose",e))(Ps||{}),Ls=class extends pt{_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)}},Wi=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 i=0,s=t.length;i<s;i++){let n=t[i];if(n.name==e)return n}return null}findSlot(e){if(!e)throw new Error("slotName cannot be null.");let t=this.slots;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.name==e)return n}return null}findSkin(e){if(!e)throw new Error("skinName cannot be null.");let t=this.skins;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.name==e)return n}return null}findEvent(e){if(!e)throw new Error("eventDataName cannot be null.");let t=this.events;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.name==e)return n}return null}findAnimation(e){if(!e)throw new Error("animationName cannot be null.");let t=this.animations;for(let i=0,s=t.length;i<s;i++){let n=t[i];if(n.name==e)return n}return null}findIkConstraint(e){if(!e)throw new Error("constraintName cannot be null.");const t=this.ikConstraints;for(let i=0,s=t.length;i<s;i++){const n=t[i];if(n.name==e)return n}return null}findTransformConstraint(e){if(!e)throw new Error("constraintName cannot be null.");const t=this.transformConstraints;for(let i=0,s=t.length;i<s;i++){const n=t[i];if(n.name==e)return n}return null}findPathConstraint(e){if(!e)throw new Error("constraintName cannot be null.");const t=this.pathConstraints;for(let i=0,s=t.length;i<s;i++){const n=t[i];if(n.name==e)return n}return null}findPhysicsConstraint(e){if(!e)throw new Error("constraintName cannot be null.");const t=this.physicsConstraints;for(let i=0,s=t.length;i<s;i++){const n=t[i];if(n.name==e)return n}return null}},Gi=class{constructor(e=0,t,i){this.slotIndex=e,this.name=t,this.attachment=i}},xt=class{name;attachments=new Array;bones=Array();constraints=new Array;color=new O(.99607843,.61960787,.30980393,1);constructor(e){if(!e)throw new Error("name cannot be null.");this.name=e}setAttachment(e,t,i){if(!i)throw new Error("attachment cannot be null.");let s=this.attachments;e>=s.length&&(s.length=e+1),s[e]||(s[e]={}),s[e][t]=i}addSkin(e){for(let s=0;s<e.bones.length;s++){let n=e.bones[s],h=!1;for(let a=0;a<this.bones.length;a++)if(this.bones[a]==n){h=!0;break}h||this.bones.push(n)}for(let s=0;s<e.constraints.length;s++){let n=e.constraints[s],h=!1;for(let a=0;a<this.constraints.length;a++)if(this.constraints[a]==n){h=!0;break}h||this.constraints.push(n)}let t=e.getAttachments();for(let s=0;s<t.length;s++){var i=t[s];this.setAttachment(i.slotIndex,i.name,i.attachment)}}copySkin(e){for(let s=0;s<e.bones.length;s++){let n=e.bones[s],h=!1;for(let a=0;a<this.bones.length;a++)if(this.bones[a]==n){h=!0;break}h||this.bones.push(n)}for(let s=0;s<e.constraints.length;s++){let n=e.constraints[s],h=!1;for(let a=0;a<this.constraints.length;a++)if(this.constraints[a]==n){h=!0;break}h||this.constraints.push(n)}let t=e.getAttachments();for(let s=0;s<t.length;s++){var i=t[s];i.attachment&&(i.attachment instanceof Be?(i.attachment=i.attachment.newLinkedMesh(),this.setAttachment(i.slotIndex,i.name,i.attachment)):(i.attachment=i.attachment.copy(),this.setAttachment(i.slotIndex,i.name,i.attachment)))}}getAttachment(e,t){let i=this.attachments[e];return i?i[t]:null}removeAttachment(e,t){let i=this.attachments[e];i&&delete i[t]}getAttachments(){let e=new Array;for(var t=0;t<this.attachments.length;t++){let i=this.attachments[t];if(i)for(let s in i){let n=i[s];n&&e.push(new Gi(t,s,n))}}return e}getAttachmentsForSlot(e,t){let i=this.attachments[e];if(i)for(let s in i){let n=i[s];n&&t.push(new Gi(e,s,n))}}clear(){this.attachments.length=0,this.bones.length=0,this.constraints.length=0}attachAll(e,t){let i=0;for(let s=0;s<e.slots.length;s++){let n=e.slots[s],h=n.getAttachment();if(h&&i<t.attachments.length){let a=t.attachments[i];for(let r in a){let o=a[r];if(h==o){let l=this.getAttachment(i,r);l&&n.setAttachment(l);break}}}i++}}},zi=class{index=0;name;boneData;color=new O(1,1,1,1);darkColor=null;attachmentName=null;blendMode=Ot.Normal;visible=!0;constructor(e,t,i){if(e<0)throw new Error("index must be >= 0.");if(!t)throw new Error("name cannot be null.");if(!i)throw new Error("boneData cannot be null.");this.index=e,this.name=t,this.boneData=i}},Ot=(e=>(e[e.Normal=0]="Normal",e[e.Additive=1]="Additive",e[e.Multiply=2]="Multiply",e[e.Screen=3]="Screen",e))(Ot||{}),qi=class extends pt{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)}},Xs=class{scale=1;attachmentLoader;linkedMeshes=new Array;constructor(e){this.attachmentLoader=e}readSkeletonData(e){let t=this.scale,i=new Wi;i.name="";let s=new Bs(e),n=s.readInt32(),h=s.readInt32();i.hash=h==0&&n==0?null:h.toString(16)+n.toString(16),i.version=s.readString(),i.x=s.readFloat(),i.y=s.readFloat(),i.width=s.readFloat(),i.height=s.readFloat(),i.referenceScale=s.readFloat()*t;let a=s.readBoolean();a&&(i.fps=s.readFloat(),i.imagesPath=s.readString(),i.audioPath=s.readString());let r=0;r=s.readInt(!0);for(let l=0;l<r;l++){let c=s.readString();if(!c)throw new Error("String in string table must not be null.");s.strings.push(c)}r=s.readInt(!0);for(let l=0;l<r;l++){let c=s.readString();if(!c)throw new Error("Bone name must not be null.");let f=l==0?null:i.bones[s.readInt(!0)],d=new Xi(l,c,f);d.rotation=s.readFloat(),d.x=s.readFloat()*t,d.y=s.readFloat()*t,d.scaleX=s.readFloat(),d.scaleY=s.readFloat(),d.shearX=s.readFloat(),d.shearY=s.readFloat(),d.length=s.readFloat()*t,d.inherit=s.readByte(),d.skinRequired=s.readBoolean(),a&&(O.rgba8888ToColor(d.color,s.readInt32()),d.icon=s.readString()??void 0,d.visible=s.readBoolean()),i.bones.push(d)}r=s.readInt(!0);for(let l=0;l<r;l++){let c=s.readString();if(!c)throw new Error("Slot name must not be null.");let f=i.bones[s.readInt(!0)],d=new zi(l,c,f);O.rgba8888ToColor(d.color,s.readInt32());let u=s.readInt32();u!=-1&&O.rgb888ToColor(d.darkColor=new O,u),d.attachmentName=s.readStringRef(),d.blendMode=s.readInt(!0),a&&(d.visible=s.readBoolean()),i.slots.push(d)}r=s.readInt(!0);for(let l=0,c;l<r;l++){let f=s.readString();if(!f)throw new Error("IK constraint data name must not be null.");let d=new Ni(f);d.order=s.readInt(!0),c=s.readInt(!0);for(let m=0;m<c;m++)d.bones.push(i.bones[s.readInt(!0)]);d.target=i.bones[s.readInt(!0)];let u=s.readByte();d.skinRequired=(u&1)!=0,d.bendDirection=u&2?1:-1,d.compress=(u&4)!=0,d.stretch=(u&8)!=0,d.uniform=(u&16)!=0,u&32&&(d.mix=u&64?s.readFloat():1),u&128&&(d.softness=s.readFloat()*t),i.ikConstraints.push(d)}r=s.readInt(!0);for(let l=0,c;l<r;l++){let f=s.readString();if(!f)throw new Error("Transform constraint data name must not be null.");let d=new qi(f);d.order=s.readInt(!0),c=s.readInt(!0);for(let m=0;m<c;m++)d.bones.push(i.bones[s.readInt(!0)]);d.target=i.bones[s.readInt(!0)];let u=s.readByte();d.skinRequired=(u&1)!=0,d.local=(u&2)!=0,d.relative=(u&4)!=0,u&8&&(d.offsetRotation=s.readFloat()),u&16&&(d.offsetX=s.readFloat()*t),u&32&&(d.offsetY=s.readFloat()*t),u&64&&(d.offsetScaleX=s.readFloat()),u&128&&(d.offsetScaleY=s.readFloat()),u=s.readByte(),u&1&&(d.offsetShearY=s.readFloat()),u&2&&(d.mixRotate=s.readFloat()),u&4&&(d.mixX=s.readFloat()),u&8&&(d.mixY=s.readFloat()),u&16&&(d.mixScaleX=s.readFloat()),u&32&&(d.mixScaleY=s.readFloat()),u&64&&(d.mixShearY=s.readFloat()),i.transformConstraints.push(d)}r=s.readInt(!0);for(let l=0,c;l<r;l++){let f=s.readString();if(!f)throw new Error("Path constraint data name must not be null.");let d=new _i(f);d.order=s.readInt(!0),d.skinRequired=s.readBoolean(),c=s.readInt(!0);for(let m=0;m<c;m++)d.bones.push(i.bones[s.readInt(!0)]);d.target=i.slots[s.readInt(!0)];const u=s.readByte();d.positionMode=u&1,d.spacingMode=u>>1&3,d.rotateMode=u>>3&3,u&128&&(d.offsetRotation=s.readFloat()),d.position=s.readFloat(),d.positionMode==0&&(d.position*=t),d.spacing=s.readFloat(),(d.spacingMode==0||d.spacingMode==1)&&(d.spacing*=t),d.mixRotate=s.readFloat(),d.mixX=s.readFloat(),d.mixY=s.readFloat(),i.pathConstraints.push(d)}r=s.readInt(!0);for(let l=0,c;l<r;l++){const f=s.readString();if(!f)throw new Error("Physics constraint data name must not be null.");const d=new Ls(f);d.order=s.readInt(!0),d.bone=i.bones[s.readInt(!0)];let u=s.readByte();d.skinRequired=(u&1)!=0,u&2&&(d.x=s.readFloat()),u&4&&(d.y=s.readFloat()),u&8&&(d.rotate=s.readFloat()),u&16&&(d.scaleX=s.readFloat()),u&32&&(d.shearX=s.readFloat()),d.limit=(u&64?s.readFloat():5e3)*t,d.step=1/s.readUnsignedByte(),d.inertia=s.readFloat(),d.strength=s.readFloat(),d.damping=s.readFloat(),d.massInverse=u&128?s.readFloat():1,d.wind=s.readFloat(),d.gravity=s.readFloat(),u=s.readByte(),u&1&&(d.inertiaGlobal=!0),u&2&&(d.strengthGlobal=!0),u&4&&(d.dampingGlobal=!0),u&8&&(d.massGlobal=!0),u&16&&(d.windGlobal=!0),u&32&&(d.gravityGlobal=!0),u&64&&(d.mixGlobal=!0),d.mix=u&128?s.readFloat():1,i.physicsConstraints.push(d)}let o=this.readSkin(s,i,!0,a);o&&(i.defaultSkin=o,i.skins.push(o));{let l=i.skins.length;for(X.setArraySize(i.skins,r=l+s.readInt(!0));l<r;l++){let c=this.readSkin(s,i,!1,a);if(!c)throw new Error("readSkin() should not have returned null.");i.skins[l]=c}}r=this.linkedMeshes.length;for(let l=0;l<r;l++){let c=this.linkedMeshes[l];const f=i.skins[c.skinIndex];if(!c.parent)throw new Error("Linked mesh parent must not be null");let d=f.getAttachment(c.slotIndex,c.parent);if(!d)throw new Error(`Parent mesh not found: ${c.parent}`);c.mesh.timelineAttachment=c.inheritTimeline?d:c.mesh,c.mesh.setParentMesh(d),c.mesh.region!=null&&c.mesh.updateRegion()}this.linkedMeshes.length=0,r=s.readInt(!0);for(let l=0;l<r;l++){let c=s.readString();if(!c)throw new Error("Event data name must not be null");let f=new Di(c);f.intValue=s.readInt(!1),f.floatValue=s.readFloat(),f.stringValue=s.readString(),f.audioPath=s.readString(),f.audioPath&&(f.volume=s.readFloat(),f.balance=s.readFloat()),i.events.push(f)}r=s.readInt(!0);for(let l=0;l<r;l++){let c=s.readString();if(!c)throw new Error("Animatio name must not be null.");i.animations.push(this.readAnimation(s,c,i))}return i}readSkin(e,t,i,s){let n=null,h=0;if(i){if(h=e.readInt(!0),h==0)return null;n=new xt("default")}else{let a=e.readString();if(!a)throw new Error("Skin name must not be null.");n=new xt(a),s&&O.rgba8888ToColor(n.color,e.readInt32()),n.bones.length=e.readInt(!0);for(let r=0,o=n.bones.length;r<o;r++)n.bones[r]=t.bones[e.readInt(!0)];for(let r=0,o=e.readInt(!0);r<o;r++)n.constraints.push(t.ikConstraints[e.readInt(!0)]);for(let r=0,o=e.readInt(!0);r<o;r++)n.constraints.push(t.transformConstraints[e.readInt(!0)]);for(let r=0,o=e.readInt(!0);r<o;r++)n.constraints.push(t.pathConstraints[e.readInt(!0)]);for(let r=0,o=e.readInt(!0);r<o;r++)n.constraints.push(t.physicsConstraints[e.readInt(!0)]);h=e.readInt(!0)}for(let a=0;a<h;a++){let r=e.readInt(!0);for(let o=0,l=e.readInt(!0);o<l;o++){let c=e.readStringRef();if(!c)throw new Error("Attachment name must not be null");let f=this.readAttachment(e,t,n,r,c,s);f&&n.setAttachment(r,c,f)}}return n}readAttachment(e,t,i,s,n,h){let a=this.scale,r=e.readByte();const o=r&8?e.readStringRef():n;if(!o)throw new Error("Attachment name must not be null");switch(r&7){case Ge.Region:{let l=r&16?e.readStringRef():null;const c=r&32?e.readInt32():4294967295,f=r&64?this.readSequence(e):null;let d=r&128?e.readFloat():0,u=e.readFloat(),m=e.readFloat(),g=e.readFloat(),w=e.readFloat(),b=e.readFloat(),p=e.readFloat();l||(l=o);let x=this.attachmentLoader.newRegionAttachment(i,o,l,f);return x?(x.path=l,x.x=u*a,x.y=m*a,x.scaleX=g,x.scaleY=w,x.rotation=d,x.width=b*a,x.height=p*a,O.rgba8888ToColor(x.color,c),x.sequence=f,f==null&&x.updateRegion(),x):null}case Ge.BoundingBox:{let l=this.readVertices(e,(r&16)!=0),c=h?e.readInt32():0,f=this.attachmentLoader.newBoundingBoxAttachment(i,o);return f?(f.worldVerticesLength=l.length,f.vertices=l.vertices,f.bones=l.bones,h&&O.rgba8888ToColor(f.color,c),f):null}case Ge.Mesh:{let l=r&16?e.readStringRef():o;const c=r&32?e.readInt32():4294967295,f=r&64?this.readSequence(e):null,d=e.readInt(!0),u=this.readVertices(e,(r&128)!=0),m=this.readFloatArray(e,u.length,1),g=this.readShortArray(e,(u.length-d-2)*3);let w=[],b=0,p=0;h&&(w=this.readShortArray(e,e.readInt(!0)),b=e.readFloat(),p=e.readFloat()),l||(l=o);let x=this.attachmentLoader.newMeshAttachment(i,o,l,f);return x?(x.path=l,O.rgba8888ToColor(x.color,c),x.bones=u.bones,x.vertices=u.vertices,x.worldVerticesLength=u.length,x.triangles=g,x.regionUVs=m,f==null&&x.updateRegion(),x.hullLength=d<<1,x.sequence=f,h&&(x.edges=w,x.width=b*a,x.height=p*a),x):null}case Ge.LinkedMesh:{const l=r&16?e.readStringRef():o;if(l==null)throw new Error("Path of linked mesh must not be null");const c=r&32?e.readInt32():4294967295,f=r&64?this.readSequence(e):null,d=(r&128)!=0,u=e.readInt(!0),m=e.readStringRef();let g=0,w=0;h&&(g=e.readFloat(),w=e.readFloat());let b=this.attachmentLoader.newMeshAttachment(i,o,l,f);return b?(b.path=l,O.rgba8888ToColor(b.color,c),b.sequence=f,h&&(b.width=g*a,b.height=w*a),this.linkedMeshes.push(new _r(b,u,s,m,d)),b):null}case Ge.Path:{const l=(r&16)!=0,c=(r&32)!=0,f=this.readVertices(e,(r&64)!=0),d=X.newArray(f.length/6,0);for(let g=0,w=d.length;g<w;g++)d[g]=e.readFloat()*a;const u=h?e.readInt32():0,m=this.attachmentLoader.newPathAttachment(i,o);return m?(m.closed=l,m.constantSpeed=c,m.worldVerticesLength=f.length,m.vertices=f.vertices,m.bones=f.bones,m.lengths=d,h&&O.rgba8888ToColor(m.color,u),m):null}case Ge.Point:{const l=e.readFloat(),c=e.readFloat(),f=e.readFloat(),d=h?e.readInt32():0,u=this.attachmentLoader.newPointAttachment(i,o);return u?(u.x=c*a,u.y=f*a,u.rotation=l,h&&O.rgba8888ToColor(u.color,d),u):null}case Ge.Clipping:{const l=e.readInt(!0),c=this.readVertices(e,(r&16)!=0);let f=h?e.readInt32():0,d=this.attachmentLoader.newClippingAttachment(i,o);return d?(d.endSlot=t.slots[l],d.worldVerticesLength=c.length,d.vertices=c.vertices,d.bones=c.bones,h&&O.rgba8888ToColor(d.color,f),d):null}}return null}readSequence(e){let t=new $t(e.readInt(!0));return t.start=e.readInt(!0),t.digits=e.readInt(!0),t.setupIndex=e.readInt(!0),t}readVertices(e,t){const i=this.scale,s=e.readInt(!0),n=new Ur;if(n.length=s<<1,!t)return n.vertices=this.readFloatArray(e,n.length,i),n;let h=new Array,a=new Array;for(let r=0;r<s;r++){let o=e.readInt(!0);a.push(o);for(let l=0;l<o;l++)a.push(e.readInt(!0)),h.push(e.readFloat()*i),h.push(e.readFloat()*i),h.push(e.readFloat())}return n.vertices=X.toFloatArray(h),n.bones=a,n}readFloatArray(e,t,i){let s=new Array(t);if(i==1)for(let n=0;n<t;n++)s[n]=e.readFloat();else for(let n=0;n<t;n++)s[n]=e.readFloat()*i;return s}readShortArray(e,t){let i=new Array(t);for(let s=0;s<t;s++)i[s]=e.readInt(!0);return i}readAnimation(e,t,i){e.readInt(!0);let s=new Array,n=this.scale;for(let o=0,l=e.readInt(!0);o<l;o++){let c=e.readInt(!0);for(let f=0,d=e.readInt(!0);f<d;f++){let u=e.readByte(),m=e.readInt(!0),g=m-1;switch(u){case en:{let w=new Ze(m,c);for(let b=0;b<m;b++)w.setFrame(b,e.readFloat(),e.readStringRef());s.push(w);break}case tn:{let w=e.readInt(!0),b=new ci(m,w,c),p=e.readFloat(),x=e.readUnsignedByte()/255,y=e.readUnsignedByte()/255,v=e.readUnsignedByte()/255,A=e.readUnsignedByte()/255;for(let C=0,S=0;b.setFrame(C,p,x,y,v,A),C!=g;C++){let E=e.readFloat(),R=e.readUnsignedByte()/255,Y=e.readUnsignedByte()/255,P=e.readUnsignedByte()/255,I=e.readUnsignedByte()/255;switch(e.readByte()){case Le:b.setStepped(C);break;case Xe:oe(e,b,S++,C,0,p,E,x,R,1),oe(e,b,S++,C,1,p,E,y,Y,1),oe(e,b,S++,C,2,p,E,v,P,1),oe(e,b,S++,C,3,p,E,A,I,1)}p=E,x=R,y=Y,v=P,A=I}s.push(b);break}case sn:{let w=e.readInt(!0),b=new di(m,w,c),p=e.readFloat(),x=e.readUnsignedByte()/255,y=e.readUnsignedByte()/255,v=e.readUnsignedByte()/255;for(let A=0,C=0;b.setFrame(A,p,x,y,v),A!=g;A++){let S=e.readFloat(),E=e.readUnsignedByte()/255,R=e.readUnsignedByte()/255,Y=e.readUnsignedByte()/255;switch(e.readByte()){case Le:b.setStepped(A);break;case Xe:oe(e,b,C++,A,0,p,S,x,E,1),oe(e,b,C++,A,1,p,S,y,R,1),oe(e,b,C++,A,2,p,S,v,Y,1)}p=S,x=E,y=R,v=Y}s.push(b);break}case rn:{let w=e.readInt(!0),b=new ui(m,w,c),p=e.readFloat(),x=e.readUnsignedByte()/255,y=e.readUnsignedByte()/255,v=e.readUnsignedByte()/255,A=e.readUnsignedByte()/255,C=e.readUnsignedByte()/255,S=e.readUnsignedByte()/255,E=e.readUnsignedByte()/255;for(let R=0,Y=0;b.setFrame(R,p,x,y,v,A,C,S,E),R!=g;R++){let P=e.readFloat(),I=e.readUnsignedByte()/255,k=e.readUnsignedByte()/255,F=e.readUnsignedByte()/255,se=e.readUnsignedByte()/255,re=e.readUnsignedByte()/255,ie=e.readUnsignedByte()/255,ce=e.readUnsignedByte()/255;switch(e.readByte()){case Le:b.setStepped(R);break;case Xe:oe(e,b,Y++,R,0,p,P,x,I,1),oe(e,b,Y++,R,1,p,P,y,k,1),oe(e,b,Y++,R,2,p,P,v,F,1),oe(e,b,Y++,R,3,p,P,A,se,1),oe(e,b,Y++,R,4,p,P,C,re,1),oe(e,b,Y++,R,5,p,P,S,ie,1),oe(e,b,Y++,R,6,p,P,E,ce,1)}p=P,x=I,y=k,v=F,A=se,C=re,S=ie,E=ce}s.push(b);break}case nn:{let w=e.readInt(!0),b=new mi(m,w,c),p=e.readFloat(),x=e.readUnsignedByte()/255,y=e.readUnsignedByte()/255,v=e.readUnsignedByte()/255,A=e.readUnsignedByte()/255,C=e.readUnsignedByte()/255,S=e.readUnsignedByte()/255;for(let E=0,R=0;b.setFrame(E,p,x,y,v,A,C,S),E!=g;E++){let Y=e.readFloat(),P=e.readUnsignedByte()/255,I=e.readUnsignedByte()/255,k=e.readUnsignedByte()/255,F=e.readUnsignedByte()/255,se=e.readUnsignedByte()/255,re=e.readUnsignedByte()/255;switch(e.readByte()){case Le:b.setStepped(E);break;case Xe:oe(e,b,R++,E,0,p,Y,x,P,1),oe(e,b,R++,E,1,p,Y,y,I,1),oe(e,b,R++,E,2,p,Y,v,k,1),oe(e,b,R++,E,3,p,Y,A,F,1),oe(e,b,R++,E,4,p,Y,C,se,1),oe(e,b,R++,E,5,p,Y,S,re,1)}p=Y,x=P,y=I,v=k,A=F,C=se,S=re}s.push(b);break}case an:{let w=new fi(m,e.readInt(!0),c),b=e.readFloat(),p=e.readUnsignedByte()/255;for(let x=0,y=0;w.setFrame(x,b,p),x!=g;x++){let v=e.readFloat(),A=e.readUnsignedByte()/255;switch(e.readByte()){case Le:w.setStepped(x);break;case Xe:oe(e,w,y++,x,0,b,v,p,A,1)}b=v,p=A}s.push(w)}}}}for(let o=0,l=e.readInt(!0);o<l;o++){let c=e.readInt(!0);for(let f=0,d=e.readInt(!0);f<d;f++){let u=e.readByte(),m=e.readInt(!0);if(u==$r){let w=new hi(m,c);for(let b=0;b<m;b++)w.setFrame(b,e.readFloat(),e.readByte());s.push(w);continue}let g=e.readInt(!0);switch(u){case Wr:s.push(xe(e,new ut(m,g,c),1));break;case Gr:s.push(Hi(e,new ei(m,g,c),n));break;case zr:s.push(xe(e,new ti(m,g,c),n));break;case qr:s.push(xe(e,new ii(m,g,c),n));break;case Hr:s.push(Hi(e,new si(m,g,c),1));break;case jr:s.push(xe(e,new ri(m,g,c),1));break;case Zr:s.push(xe(e,new ni(m,g,c),1));break;case Jr:s.push(Hi(e,new ai(m,g,c),1));break;case Kr:s.push(xe(e,new li(m,g,c),1));break;case Qr:s.push(xe(e,new oi(m,g,c),1))}}}for(let o=0,l=e.readInt(!0);o<l;o++){let c=e.readInt(!0),f=e.readInt(!0),d=f-1,u=new pi(f,e.readInt(!0),c),m=e.readByte(),g=e.readFloat(),w=m&1?m&2?e.readFloat():1:0,b=m&4?e.readFloat()*n:0;for(let p=0,x=0;u.setFrame(p,g,w,b,m&8?1:-1,(m&16)!=0,(m&32)!=0),p!=d;p++){m=e.readByte();const y=e.readFloat(),v=m&1?m&2?e.readFloat():1:0,A=m&4?e.readFloat()*n:0;m&64?u.setStepped(p):m&128&&(oe(e,u,x++,p,0,g,y,w,v,1),oe(e,u,x++,p,1,g,y,b,A,n)),g=y,w=v,b=A}s.push(u)}for(let o=0,l=e.readInt(!0);o<l;o++){let c=e.readInt(!0),f=e.readInt(!0),d=f-1,u=new xi(f,e.readInt(!0),c),m=e.readFloat(),g=e.readFloat(),w=e.readFloat(),b=e.readFloat(),p=e.readFloat(),x=e.readFloat(),y=e.readFloat();for(let v=0,A=0;u.setFrame(v,m,g,w,b,p,x,y),v!=d;v++){let C=e.readFloat(),S=e.readFloat(),E=e.readFloat(),R=e.readFloat(),Y=e.readFloat(),P=e.readFloat(),I=e.readFloat();switch(e.readByte()){case Le:u.setStepped(v);break;case Xe:oe(e,u,A++,v,0,m,C,g,S,1),oe(e,u,A++,v,1,m,C,w,E,1),oe(e,u,A++,v,2,m,C,b,R,1),oe(e,u,A++,v,3,m,C,p,Y,1),oe(e,u,A++,v,4,m,C,x,P,1),oe(e,u,A++,v,5,m,C,y,I,1)}m=C,g=S,w=E,b=R,p=Y,x=P,y=I}s.push(u)}for(let o=0,l=e.readInt(!0);o<l;o++){let c=e.readInt(!0),f=i.pathConstraints[c];for(let d=0,u=e.readInt(!0);d<u;d++){const m=e.readByte(),g=e.readInt(!0),w=e.readInt(!0);switch(m){case hn:s.push(xe(e,new bi(g,w,c),f.positionMode==0?n:1));break;case cn:s.push(xe(e,new wi(g,w,c),f.spacingMode==0||f.spacingMode==1?n:1));break;case dn:let b=new vi(g,w,c),p=e.readFloat(),x=e.readFloat(),y=e.readFloat(),v=e.readFloat();for(let A=0,C=0,S=b.getFrameCount()-1;b.setFrame(A,p,x,y,v),A!=S;A++){let E=e.readFloat(),R=e.readFloat(),Y=e.readFloat(),P=e.readFloat();switch(e.readByte()){case Le:b.setStepped(A);break;case Xe:oe(e,b,C++,A,0,p,E,x,R,1),oe(e,b,C++,A,1,p,E,y,Y,1),oe(e,b,C++,A,2,p,E,v,P,1)}p=E,x=R,y=Y,v=P}s.push(b)}}}for(let o=0,l=e.readInt(!0);o<l;o++){const c=e.readInt(!0)-1;for(let f=0,d=e.readInt(!0);f<d;f++){const u=e.readByte(),m=e.readInt(!0);if(u==wn){const w=new It(m,c);for(let b=0;b<m;b++)w.setFrame(b,e.readFloat());s.push(w);continue}const g=e.readInt(!0);switch(u){case fn:s.push(xe(e,new yi(m,g,c),1));break;case un:s.push(xe(e,new Ai(m,g,c),1));break;case mn:s.push(xe(e,new Ci(m,g,c),1));break;case gn:s.push(xe(e,new Si(m,g,c),1));break;case pn:s.push(xe(e,new Ti(m,g,c),1));break;case xn:s.push(xe(e,new Ii(m,g,c),1));break;case bn:s.push(xe(e,new Mi(m,g,c),1))}}}for(let o=0,l=e.readInt(!0);o<l;o++){let c=i.skins[e.readInt(!0)];for(let f=0,d=e.readInt(!0);f<d;f++){let u=e.readInt(!0);for(let m=0,g=e.readInt(!0);m<g;m++){let w=e.readStringRef();if(!w)throw new Error("attachmentName must not be null.");let b=c.getAttachment(u,w),p=e.readByte(),x=e.readInt(!0),y=x-1;switch(p){case ln:{let v=b,A=v.bones,C=v.vertices,S=A?C.length/3*2:C.length,E=e.readInt(!0),R=new gi(x,E,u,v),Y=e.readFloat();for(let P=0,I=0;;P++){let k,F=e.readInt(!0);if(F==0)k=A?X.newFloatArray(S):C;else{k=X.newFloatArray(S);let re=e.readInt(!0);if(F+=re,n==1)for(let ie=re;ie<F;ie++)k[ie]=e.readFloat();else for(let ie=re;ie<F;ie++)k[ie]=e.readFloat()*n;if(!A)for(let ie=0,ce=k.length;ie<ce;ie++)k[ie]+=C[ie]}if(R.setFrame(P,Y,k),P==y)break;let se=e.readFloat();switch(e.readByte()){case Le:R.setStepped(P);break;case Xe:oe(e,R,I++,P,0,Y,se,0,1,1)}Y=se}s.push(R);break}case on:{let v=new it(x,u,b);for(let A=0;A<x;A++){let C=e.readFloat(),S=e.readInt32();v.setFrame(A,C,ms[S&15],S>>4,e.readFloat())}s.push(v);break}}}}}let h=e.readInt(!0);if(h>0){let o=new Je(h),l=i.slots.length;for(let c=0;c<h;c++){let f=e.readFloat(),d=e.readInt(!0),u=X.newArray(l,0);for(let b=l-1;b>=0;b--)u[b]=-1;let m=X.newArray(l-d,0),g=0,w=0;for(let b=0;b<d;b++){let p=e.readInt(!0);for(;g!=p;)m[w++]=g++;u[g+e.readInt(!0)]=g++}for(;g<l;)m[w++]=g++;for(let b=l-1;b>=0;b--)u[b]==-1&&(u[b]=m[--w]);o.setFrame(c,f,u)}s.push(o)}let a=e.readInt(!0);if(a>0){let o=new mt(a);for(let l=0;l<a;l++){let c=e.readFloat(),f=i.events[e.readInt(!0)],d=new Vi(c,f);d.intValue=e.readInt(!1),d.floatValue=e.readFloat(),d.stringValue=e.readString(),d.stringValue==null&&(d.stringValue=f.stringValue),d.data.audioPath&&(d.volume=e.readFloat(),d.balance=e.readFloat()),o.setFrame(l,d)}s.push(o)}let r=0;for(let o=0,l=s.length;o<l;o++)r=Math.max(r,s[o].getDuration());return new St(t,s,r)}},Bs=class{constructor(e,t=new Array,i=0,s=new DataView(e instanceof ArrayBuffer?e:e.buffer)){this.strings=t,this.index=i,this.buffer=s}readByte(){return this.buffer.getInt8(this.index++)}readUnsignedByte(){return this.buffer.getUint8(this.index++)}readShort(){let e=this.buffer.getInt16(this.index);return this.index+=2,e}readInt32(){let e=this.buffer.getInt32(this.index);return this.index+=4,e}readInt(e){let t=this.readByte(),i=t&127;return t&128&&(t=this.readByte(),i|=(t&127)<<7,t&128&&(t=this.readByte(),i|=(t&127)<<14,t&128&&(t=this.readByte(),i|=(t&127)<<21,t&128&&(t=this.readByte(),i|=(t&127)<<28)))),e?i:i>>>1^-(i&1)}readStringRef(){let e=this.readInt(!0);return e==0?null:this.strings[e-1]}readString(){let e=this.readInt(!0);switch(e){case 0:return null;case 1:return""}e--;let t="",i=0;for(let s=0;s<e;){let n=this.readUnsignedByte();switch(n>>4){case 12:case 13:t+=String.fromCharCode((n&31)<<6|this.readByte()&63),s+=2;break;case 14:t+=String.fromCharCode((n&15)<<12|(this.readByte()&63)<<6|this.readByte()&63),s+=3;break;default:t+=String.fromCharCode(n),s++}}return t}readFloat(){let e=this.buffer.getFloat32(this.index);return this.index+=4,e}readBoolean(){return this.readByte()!=0}},_r=class{parent;skinIndex;slotIndex;mesh;inheritTimeline;constructor(e,t,i,s,n){this.mesh=e,this.skinIndex=t,this.slotIndex=i,this.parent=s,this.inheritTimeline=n}},Ur=class{constructor(e=null,t=null,i=0){this.bones=e,this.vertices=t,this.length=i}},Ge=(e=>(e[e.Region=0]="Region",e[e.BoundingBox=1]="BoundingBox",e[e.Mesh=2]="Mesh",e[e.LinkedMesh=3]="LinkedMesh",e[e.Path=4]="Path",e[e.Point=5]="Point",e[e.Clipping=6]="Clipping",e))(Ge||{});function xe(e,t,i){let s=e.readFloat(),n=e.readFloat()*i;for(let h=0,a=0,r=t.getFrameCount()-1;t.setFrame(h,s,n),h!=r;h++){let o=e.readFloat(),l=e.readFloat()*i;switch(e.readByte()){case Le:t.setStepped(h);break;case Xe:oe(e,t,a++,h,0,s,o,n,l,i)}s=o,n=l}return t}function Hi(e,t,i){let s=e.readFloat(),n=e.readFloat()*i,h=e.readFloat()*i;for(let a=0,r=0,o=t.getFrameCount()-1;t.setFrame(a,s,n,h),a!=o;a++){let l=e.readFloat(),c=e.readFloat()*i,f=e.readFloat()*i;switch(e.readByte()){case Le:t.setStepped(a);break;case Xe:oe(e,t,r++,a,0,s,l,n,c,i),oe(e,t,r++,a,1,s,l,h,f,i)}s=l,n=c,h=f}return t}function oe(e,t,i,s,n,h,a,r,o,l){t.setBezier(i,s,n,h,r,e.readFloat(),e.readFloat()*l,e.readFloat(),e.readFloat()*l,a,o)}var Wr=0,Gr=1,zr=2,qr=3,Hr=4,jr=5,Zr=6,Jr=7,Kr=8,Qr=9,$r=10,en=0,tn=1,sn=2,rn=3,nn=4,an=5,ln=0,on=1,hn=0,cn=1,dn=2,fn=0,un=1,mn=2,gn=4,pn=5,xn=6,bn=7,wn=8,Le=1,Xe=2,Os=class{minX=0;minY=0;maxX=0;maxY=0;boundingBoxes=new Array;polygons=new Array;polygonPool=new ft(()=>X.newFloatArray(16));update(e,t){if(!e)throw new Error("skeleton cannot be null.");let i=this.boundingBoxes,s=this.polygons,n=this.polygonPool,h=e.slots,a=h.length;i.length=0,n.freeAll(s),s.length=0;for(let r=0;r<a;r++){let o=h[r];if(!o.bone.active)continue;let l=o.getAttachment();if(l instanceof Yt){let c=l;i.push(c);let f=n.obtain();f.length!=c.worldVerticesLength&&(f=X.newFloatArray(c.worldVerticesLength)),s.push(f),c.computeWorldVertices(o,0,c.worldVerticesLength,f,0,2)}}t?this.aabbCompute():(this.minX=Number.POSITIVE_INFINITY,this.minY=Number.POSITIVE_INFINITY,this.maxX=Number.NEGATIVE_INFINITY,this.maxY=Number.NEGATIVE_INFINITY)}aabbCompute(){let e=Number.POSITIVE_INFINITY,t=Number.POSITIVE_INFINITY,i=Number.NEGATIVE_INFINITY,s=Number.NEGATIVE_INFINITY,n=this.polygons;for(let h=0,a=n.length;h<a;h++){let r=n[h],o=r;for(let l=0,c=r.length;l<c;l+=2){let f=o[l],d=o[l+1];e=Math.min(e,f),t=Math.min(t,d),i=Math.max(i,f),s=Math.max(s,d)}}this.minX=e,this.minY=t,this.maxX=i,this.maxY=s}aabbContainsPoint(e,t){return e>=this.minX&&e<=this.maxX&&t>=this.minY&&t<=this.maxY}aabbIntersectsSegment(e,t,i,s){let n=this.minX,h=this.minY,a=this.maxX,r=this.maxY;if(e<=n&&i<=n||t<=h&&s<=h||e>=a&&i>=a||t>=r&&s>=r)return!1;let o=(s-t)/(i-e),l=o*(n-e)+t;if(l>h&&l<r||(l=o*(a-e)+t,l>h&&l<r))return!0;let c=(h-t)/o+e;return c>n&&c<a||(c=(r-t)/o+e,c>n&&c<a)}aabbIntersectsSkeleton(e){return this.minX<e.maxX&&this.maxX>e.minX&&this.minY<e.maxY&&this.maxY>e.minY}containsPoint(e,t){let i=this.polygons;for(let s=0,n=i.length;s<n;s++)if(this.containsPointPolygon(i[s],e,t))return this.boundingBoxes[s];return null}containsPointPolygon(e,t,i){let s=e,n=e.length,h=n-2,a=!1;for(let r=0;r<n;r+=2){let o=s[r+1],l=s[h+1];if(o<i&&l>=i||l<i&&o>=i){let c=s[r];c+(i-o)/(l-o)*(s[h]-c)<t&&(a=!a)}h=r}return a}intersectsSegment(e,t,i,s){let n=this.polygons;for(let h=0,a=n.length;h<a;h++)if(this.intersectsSegmentPolygon(n[h],e,t,i,s))return this.boundingBoxes[h];return null}intersectsSegmentPolygon(e,t,i,s,n){let h=e,a=e.length,r=t-s,o=i-n,l=t*n-i*s,c=h[a-2],f=h[a-1];for(let d=0;d<a;d+=2){let u=h[d],m=h[d+1],g=c*m-f*u,w=c-u,b=f-m,p=r*b-o*w,x=(l*w-r*g)/p;if((x>=c&&x<=u||x>=u&&x<=c)&&(x>=t&&x<=s||x>=s&&x<=t)){let y=(l*b-o*g)/p;if((y>=f&&y<=m||y>=m&&y<=f)&&(y>=i&&y<=n||y>=n&&y<=i))return!0}c=u,f=m}return!1}getPolygon(e){if(!e)throw new Error("boundingBox cannot be null.");let t=this.boundingBoxes.indexOf(e);return t==-1?null:this.polygons[t]}getWidth(){return this.maxX-this.minX}getHeight(){return this.maxY-this.minY}},Se=class{convexPolygons=new Array;convexPolygonsIndices=new Array;indicesArray=new Array;isConcaveArray=new Array;triangles=new Array;polygonPool=new ft(()=>new Array);polygonIndicesPool=new ft(()=>new Array);triangulate(e){let t=e,i=e.length>>1,s=this.indicesArray;s.length=0;for(let a=0;a<i;a++)s[a]=a;let n=this.isConcaveArray;n.length=0;for(let a=0,r=i;a<r;++a)n[a]=Se.isConcave(a,i,t,s);let h=this.triangles;for(h.length=0;i>3;){let a=i-1,r=0,o=1;for(;;){e:if(!n[r]){let f=s[a]<<1,d=s[r]<<1,u=s[o]<<1,m=t[f],g=t[f+1],w=t[d],b=t[d+1],p=t[u],x=t[u+1];for(let y=(o+1)%i;y!=a;y=(y+1)%i){if(!n[y])continue;let v=s[y]<<1,A=t[v],C=t[v+1];if(Se.positiveArea(p,x,m,g,A,C)&&Se.positiveArea(m,g,w,b,A,C)&&Se.positiveArea(w,b,p,x,A,C))break e}break}if(o==0){do{if(!n[r])break;r--}while(r>0);break}a=r,r=o,o=(o+1)%i}h.push(s[(i+r-1)%i]),h.push(s[r]),h.push(s[(r+1)%i]),s.splice(r,1),n.splice(r,1),i--;let l=(i+r-1)%i,c=r==i?0:r;n[l]=Se.isConcave(l,i,t,s),n[c]=Se.isConcave(c,i,t,s)}return i==3&&(h.push(s[2]),h.push(s[0]),h.push(s[1])),h}decompose(e,t){let i=e,s=this.convexPolygons;this.polygonPool.freeAll(s),s.length=0;let n=this.convexPolygonsIndices;this.polygonIndicesPool.freeAll(n),n.length=0;let h=this.polygonIndicesPool.obtain();h.length=0;let a=this.polygonPool.obtain();a.length=0;let r=-1,o=0;for(let l=0,c=t.length;l<c;l+=3){let f=t[l]<<1,d=t[l+1]<<1,u=t[l+2]<<1,m=i[f],g=i[f+1],w=i[d],b=i[d+1],p=i[u],x=i[u+1],y=!1;if(r==f){let v=a.length-4,A=Se.winding(a[v],a[v+1],a[v+2],a[v+3],p,x),C=Se.winding(p,x,a[0],a[1],a[2],a[3]);A==o&&C==o&&(a.push(p),a.push(x),h.push(u),y=!0)}y||(a.length>0?(s.push(a),n.push(h)):(this.polygonPool.free(a),this.polygonIndicesPool.free(h)),a=this.polygonPool.obtain(),a.length=0,a.push(m),a.push(g),a.push(w),a.push(b),a.push(p),a.push(x),h=this.polygonIndicesPool.obtain(),h.length=0,h.push(f),h.push(d),h.push(u),o=Se.winding(m,g,w,b,p,x),r=f)}a.length>0&&(s.push(a),n.push(h));for(let l=0,c=s.length;l<c;l++){if(h=n[l],h.length==0)continue;let f=h[0],d=h[h.length-1];a=s[l];let u=a.length-4,m=a[u],g=a[u+1],w=a[u+2],b=a[u+3],p=a[0],x=a[1],y=a[2],v=a[3],A=Se.winding(m,g,w,b,p,x);for(let C=0;C<c;C++){if(C==l)continue;let S=n[C];if(S.length!=3)continue;let E=S[0],R=S[1],Y=S[2],P=s[C],I=P[P.length-2],k=P[P.length-1];if(E!=f||R!=d)continue;let F=Se.winding(m,g,w,b,I,k),se=Se.winding(I,k,p,x,y,v);F==A&&se==A&&(P.length=0,S.length=0,a.push(I),a.push(k),h.push(Y),m=w,g=b,w=I,b=k,C=0)}}for(let l=s.length-1;l>=0;l--)a=s[l],a.length==0&&(s.splice(l,1),this.polygonPool.free(a),h=n[l],n.splice(l,1),this.polygonIndicesPool.free(h));return s}static isConcave(e,t,i,s){let n=s[(t+e-1)%t]<<1,h=s[e]<<1,a=s[(e+1)%t]<<1;return!this.positiveArea(i[n],i[n+1],i[h],i[h+1],i[a],i[a+1])}static positiveArea(e,t,i,s,n,h){return e*(h-s)+i*(t-h)+n*(s-t)>=0}static winding(e,t,i,s,n,h){let a=i-e,r=s-t;return n*r-h*a+a*t-e*r>=0?1:-1}},nt=class{triangulator=new Se;clippingPolygon=new Array;clipOutput=new Array;clippedVertices=new Array;clippedUVs=new Array;clippedTriangles=new Array;scratch=new Array;clipAttachment=null;clippingPolygons=null;clipStart(e,t){if(this.clipAttachment)return 0;this.clipAttachment=t;let i=t.worldVerticesLength,s=X.setArraySize(this.clippingPolygon,i);t.computeWorldVertices(e,0,i,s,0,2);let n=this.clippingPolygon;nt.makeClockwise(n);let h=this.clippingPolygons=this.triangulator.decompose(n,this.triangulator.triangulate(n));for(let a=0,r=h.length;a<r;a++){let o=h[a];nt.makeClockwise(o),o.push(o[0]),o.push(o[1])}return h.length}clipEndWithSlot(e){this.clipAttachment&&this.clipAttachment.endSlot==e.data&&this.clipEnd()}clipEnd(){this.clipAttachment&&(this.clipAttachment=null,this.clippingPolygons=null,this.clippedVertices.length=0,this.clippedTriangles.length=0,this.clippingPolygon.length=0)}isClipping(){return this.clipAttachment!=null}clipTriangles(e,t,i,s,n,h,a,r){let o,l,c,f,d,u;typeof t=="number"?(o=i,l=s,c=n,f=h,d=a,u=r):(o=t,l=i,c=s,f=n,d=h,u=a),c&&f&&d&&typeof u=="boolean"?this.clipTrianglesRender(e,o,l,c,f,d,u):this.clipTrianglesNoRender(e,o,l)}clipTrianglesNoRender(e,t,i){let s=this.clipOutput,n=this.clippedVertices,h=this.clippedTriangles,a=this.clippingPolygons,r=a.length,o=0;n.length=0,h.length=0;for(let l=0;l<i;l+=3){let c=t[l]<<1,f=e[c],d=e[c+1];c=t[l+1]<<1;let u=e[c],m=e[c+1];c=t[l+2]<<1;let g=e[c],w=e[c+1];for(let b=0;b<r;b++){let p=n.length;if(this.clip(f,d,u,m,g,w,a[b],s)){let x=s.length;if(x==0)continue;let y=x>>1,v=this.clipOutput,A=X.setArraySize(n,p+y*2);for(let S=0;S<x;S+=2,p+=2){let E=v[S],R=v[S+1];A[p]=E,A[p+1]=R}p=h.length;let C=X.setArraySize(h,p+3*(y-2));y--;for(let S=1;S<y;S++,p+=3)C[p]=o,C[p+1]=o+S,C[p+2]=o+S+1;o+=y+1}else{let x=X.setArraySize(n,p+6);x[p]=f,x[p+1]=d,x[p+2]=u,x[p+3]=m,x[p+4]=g,x[p+5]=w,p=h.length;let y=X.setArraySize(h,p+3);y[p]=o,y[p+1]=o+1,y[p+2]=o+2,o+=3;break}}}}clipTrianglesRender(e,t,i,s,n,h,a){let r=this.clipOutput,o=this.clippedVertices,l=this.clippedTriangles,c=this.clippingPolygons,f=c.length,d=a?12:8,u=0;o.length=0,l.length=0;for(let m=0;m<i;m+=3){let g=t[m]<<1,w=e[g],b=e[g+1],p=s[g],x=s[g+1];g=t[m+1]<<1;let y=e[g],v=e[g+1],A=s[g],C=s[g+1];g=t[m+2]<<1;let S=e[g],E=e[g+1],R=s[g],Y=s[g+1];for(let P=0;P<f;P++){let I=o.length;if(this.clip(w,b,y,v,S,E,c[P],r)){let k=r.length;if(k==0)continue;let F=v-E,se=S-y,re=w-S,ie=E-b,ce=1/(F*re+se*(b-E)),de=k>>1,fe=this.clipOutput,K=X.setArraySize(o,I+de*d);for(let le=0;le<k;le+=2,I+=d){let Ee=fe[le],Te=fe[le+1];K[I]=Ee,K[I+1]=Te,K[I+2]=n.r,K[I+3]=n.g,K[I+4]=n.b,K[I+5]=n.a;let ge=Ee-S,we=Te-E,ve=(F*ge+se*we)*ce,qe=(ie*ge+re*we)*ce,yt=1-ve-qe;K[I+6]=p*ve+A*qe+R*yt,K[I+7]=x*ve+C*qe+Y*yt,a&&(K[I+8]=h.r,K[I+9]=h.g,K[I+10]=h.b,K[I+11]=h.a)}I=l.length;let ae=X.setArraySize(l,I+3*(de-2));de--;for(let le=1;le<de;le++,I+=3)ae[I]=u,ae[I+1]=u+le,ae[I+2]=u+le+1;u+=de+1}else{let k=X.setArraySize(o,I+3*d);k[I]=w,k[I+1]=b,k[I+2]=n.r,k[I+3]=n.g,k[I+4]=n.b,k[I+5]=n.a,a?(k[I+6]=p,k[I+7]=x,k[I+8]=h.r,k[I+9]=h.g,k[I+10]=h.b,k[I+11]=h.a,k[I+12]=y,k[I+13]=v,k[I+14]=n.r,k[I+15]=n.g,k[I+16]=n.b,k[I+17]=n.a,k[I+18]=A,k[I+19]=C,k[I+20]=h.r,k[I+21]=h.g,k[I+22]=h.b,k[I+23]=h.a,k[I+24]=S,k[I+25]=E,k[I+26]=n.r,k[I+27]=n.g,k[I+28]=n.b,k[I+29]=n.a,k[I+30]=R,k[I+31]=Y,k[I+32]=h.r,k[I+33]=h.g,k[I+34]=h.b,k[I+35]=h.a):(k[I+6]=p,k[I+7]=x,k[I+8]=y,k[I+9]=v,k[I+10]=n.r,k[I+11]=n.g,k[I+12]=n.b,k[I+13]=n.a,k[I+14]=A,k[I+15]=C,k[I+16]=S,k[I+17]=E,k[I+18]=n.r,k[I+19]=n.g,k[I+20]=n.b,k[I+21]=n.a,k[I+22]=R,k[I+23]=Y),I=l.length;let F=X.setArraySize(l,I+3);F[I]=u,F[I+1]=u+1,F[I+2]=u+2,u+=3;break}}}}clipTrianglesUnpacked(e,t,i,s){let n=this.clipOutput,h=this.clippedVertices,a=this.clippedUVs,r=this.clippedTriangles,o=this.clippingPolygons,l=o.length,c=0;h.length=0,a.length=0,r.length=0;for(let f=0;f<i;f+=3){let d=t[f]<<1,u=e[d],m=e[d+1],g=s[d],w=s[d+1];d=t[f+1]<<1;let b=e[d],p=e[d+1],x=s[d],y=s[d+1];d=t[f+2]<<1;let v=e[d],A=e[d+1],C=s[d],S=s[d+1];for(let E=0;E<l;E++){let R=h.length;if(this.clip(u,m,b,p,v,A,o[E],n)){let Y=n.length;if(Y==0)continue;let P=p-A,I=v-b,k=u-v,F=A-m,se=1/(P*k+I*(m-A)),re=Y>>1,ie=this.clipOutput,ce=X.setArraySize(h,R+re*2),de=X.setArraySize(a,R+re*2);for(let K=0;K<Y;K+=2,R+=2){let ae=ie[K],le=ie[K+1];ce[R]=ae,ce[R+1]=le;let Ee=ae-v,Te=le-A,ge=(P*Ee+I*Te)*se,we=(F*Ee+k*Te)*se,ve=1-ge-we;de[R]=g*ge+x*we+C*ve,de[R+1]=w*ge+y*we+S*ve}R=r.length;let fe=X.setArraySize(r,R+3*(re-2));re--;for(let K=1;K<re;K++,R+=3)fe[R]=c,fe[R+1]=c+K,fe[R+2]=c+K+1;c+=re+1}else{let Y=X.setArraySize(h,R+6);Y[R]=u,Y[R+1]=m,Y[R+2]=b,Y[R+3]=p,Y[R+4]=v,Y[R+5]=A;let P=X.setArraySize(a,R+3*2);P[R]=g,P[R+1]=w,P[R+2]=x,P[R+3]=y,P[R+4]=C,P[R+5]=S,R=r.length;let I=X.setArraySize(r,R+3);I[R]=c,I[R+1]=c+1,I[R+2]=c+2,c+=3;break}}}}clip(e,t,i,s,n,h,a,r){let o=r,l=!1,c;a.length%4>=2?(c=r,r=this.scratch):c=this.scratch,c.length=0,c.push(e),c.push(t),c.push(i),c.push(s),c.push(n),c.push(h),c.push(e),c.push(t),r.length=0;let f=a.length-4,d=a;for(let u=0;;u+=2){let m=d[u],g=d[u+1],w=m-d[u+2],b=g-d[u+3],p=r.length,x=c;for(let v=0,A=c.length-2;v<A;){let C=x[v],S=x[v+1];v+=2;let E=x[v],R=x[v+1],Y=b*(m-E)>w*(g-R),P=b*(m-C)-w*(g-S);if(P>0){if(Y){r.push(E),r.push(R);continue}let I=E-C,k=R-S,F=P/(I*b-k*w);if(F>=0&&F<=1)r.push(C+I*F),r.push(S+k*F);else{r.push(E),r.push(R);continue}}else if(Y){let I=E-C,k=R-S,F=P/(I*b-k*w);if(F>=0&&F<=1)r.push(C+I*F),r.push(S+k*F),r.push(E),r.push(R);else{r.push(E),r.push(R);continue}}l=!0}if(p==r.length)return o.length=0,!0;if(r.push(r[0]),r.push(r[1]),u==f)break;let y=r;r=c,r.length=0,c=y}if(o!=r){o.length=0;for(let u=0,m=r.length-2;u<m;u++)o[u]=r[u]}else o.length=o.length-2;return l}static makeClockwise(e){let t=e,i=e.length,s=t[i-2]*t[1]-t[0]*t[i-1],n=0,h=0,a=0,r=0;for(let o=0,l=i-3;o<l;o+=2)n=t[o],h=t[o+1],a=t[o+2],r=t[o+3],s+=n*r-a*h;if(!(s<0))for(let o=0,l=i-2,c=i>>1;o<c;o+=2){let f=t[o],d=t[o+1],u=l-o;t[o]=t[u],t[o+1]=t[u+1],t[u]=f,t[u+1]=d}}},Vs=class{attachmentLoader;scale=1;linkedMeshes=new Array;constructor(e){this.attachmentLoader=e}readSkeletonData(e){let t=this.scale,i=new Wi,s=typeof e=="string"?JSON.parse(e):e,n=s.skeleton;if(n&&(i.hash=n.hash,i.version=n.spine,i.x=n.x,i.y=n.y,i.width=n.width,i.height=n.height,i.referenceScale=M(n,"referenceScale",100)*t,i.fps=n.fps,i.imagesPath=n.images??null,i.audioPath=n.audio??null),s.bones)for(let h=0;h<s.bones.length;h++){let a=s.bones[h],r=null,o=M(a,"parent",null);o&&(r=i.findBone(o));let l=new Xi(i.bones.length,a.name,r);l.length=M(a,"length",0)*t,l.x=M(a,"x",0)*t,l.y=M(a,"y",0)*t,l.rotation=M(a,"rotation",0),l.scaleX=M(a,"scaleX",1),l.scaleY=M(a,"scaleY",1),l.shearX=M(a,"shearX",0),l.shearY=M(a,"shearY",0),l.inherit=X.enumValue(gt,M(a,"inherit","Normal")),l.skinRequired=M(a,"skin",!1);let c=M(a,"color",null);c&&l.color.setFromString(c),i.bones.push(l)}if(s.slots)for(let h=0;h<s.slots.length;h++){let a=s.slots[h],r=a.name,o=i.findBone(a.bone);if(!o)throw new Error(`Couldn't find bone ${a.bone} for slot ${r}`);let l=new zi(i.slots.length,r,o),c=M(a,"color",null);c&&l.color.setFromString(c);let f=M(a,"dark",null);f&&(l.darkColor=O.fromString(f)),l.attachmentName=M(a,"attachment",null),l.blendMode=X.enumValue(Ot,M(a,"blend","normal")),l.visible=M(a,"visible",!0),i.slots.push(l)}if(s.ik)for(let h=0;h<s.ik.length;h++){let a=s.ik[h],r=new Ni(a.name);r.order=M(a,"order",0),r.skinRequired=M(a,"skin",!1);for(let l=0;l<a.bones.length;l++){let c=i.findBone(a.bones[l]);if(!c)throw new Error(`Couldn't find bone ${a.bones[l]} for IK constraint ${a.name}.`);r.bones.push(c)}let o=i.findBone(a.target);if(!o)throw new Error(`Couldn't find target bone ${a.target} for IK constraint ${a.name}.`);r.target=o,r.mix=M(a,"mix",1),r.softness=M(a,"softness",0)*t,r.bendDirection=M(a,"bendPositive",!0)?1:-1,r.compress=M(a,"compress",!1),r.stretch=M(a,"stretch",!1),r.uniform=M(a,"uniform",!1),i.ikConstraints.push(r)}if(s.transform)for(let h=0;h<s.transform.length;h++){let a=s.transform[h],r=new qi(a.name);r.order=M(a,"order",0),r.skinRequired=M(a,"skin",!1);for(let c=0;c<a.bones.length;c++){let f=a.bones[c],d=i.findBone(f);if(!d)throw new Error(`Couldn't find bone ${f} for transform constraint ${a.name}.`);r.bones.push(d)}let o=a.target,l=i.findBone(o);if(!l)throw new Error(`Couldn't find target bone ${o} for transform constraint ${a.name}.`);r.target=l,r.local=M(a,"local",!1),r.relative=M(a,"relative",!1),r.offsetRotation=M(a,"rotation",0),r.offsetX=M(a,"x",0)*t,r.offsetY=M(a,"y",0)*t,r.offsetScaleX=M(a,"scaleX",0),r.offsetScaleY=M(a,"scaleY",0),r.offsetShearY=M(a,"shearY",0),r.mixRotate=M(a,"mixRotate",1),r.mixX=M(a,"mixX",1),r.mixY=M(a,"mixY",r.mixX),r.mixScaleX=M(a,"mixScaleX",1),r.mixScaleY=M(a,"mixScaleY",r.mixScaleX),r.mixShearY=M(a,"mixShearY",1),i.transformConstraints.push(r)}if(s.path)for(let h=0;h<s.path.length;h++){let a=s.path[h],r=new _i(a.name);r.order=M(a,"order",0),r.skinRequired=M(a,"skin",!1);for(let c=0;c<a.bones.length;c++){let f=a.bones[c],d=i.findBone(f);if(!d)throw new Error(`Couldn't find bone ${f} for path constraint ${a.name}.`);r.bones.push(d)}let o=a.target,l=i.findSlot(o);if(!l)throw new Error(`Couldn't find target slot ${o} for path constraint ${a.name}.`);r.target=l,r.positionMode=X.enumValue(Lt,M(a,"positionMode","Percent")),r.spacingMode=X.enumValue(Xt,M(a,"spacingMode","Length")),r.rotateMode=X.enumValue(Bt,M(a,"rotateMode","Tangent")),r.offsetRotation=M(a,"rotation",0),r.position=M(a,"position",0),r.positionMode==0&&(r.position*=t),r.spacing=M(a,"spacing",0),(r.spacingMode==0||r.spacingMode==1)&&(r.spacing*=t),r.mixRotate=M(a,"mixRotate",1),r.mixX=M(a,"mixX",1),r.mixY=M(a,"mixY",r.mixX),i.pathConstraints.push(r)}if(s.physics)for(let h=0;h<s.physics.length;h++){const a=s.physics[h],r=new Ls(a.name);r.order=M(a,"order",0),r.skinRequired=M(a,"skin",!1);const o=a.bone,l=i.findBone(o);if(l==null)throw new Error("Physics bone not found: "+o);r.bone=l,r.x=M(a,"x",0),r.y=M(a,"y",0),r.rotate=M(a,"rotate",0),r.scaleX=M(a,"scaleX",0),r.shearX=M(a,"shearX",0),r.limit=M(a,"limit",5e3)*t,r.step=1/M(a,"fps",60),r.inertia=M(a,"inertia",1),r.strength=M(a,"strength",100),r.damping=M(a,"damping",1),r.massInverse=1/M(a,"mass",1),r.wind=M(a,"wind",0),r.gravity=M(a,"gravity",0),r.mix=M(a,"mix",1),r.inertiaGlobal=M(a,"inertiaGlobal",!1),r.strengthGlobal=M(a,"strengthGlobal",!1),r.dampingGlobal=M(a,"dampingGlobal",!1),r.massGlobal=M(a,"massGlobal",!1),r.windGlobal=M(a,"windGlobal",!1),r.gravityGlobal=M(a,"gravityGlobal",!1),r.mixGlobal=M(a,"mixGlobal",!1),i.physicsConstraints.push(r)}if(s.skins)for(let h=0;h<s.skins.length;h++){let a=s.skins[h],r=new xt(a.name);if(a.bones)for(let o=0;o<a.bones.length;o++){let l=a.bones[o],c=i.findBone(l);if(!c)throw new Error(`Couldn't find bone ${l} for skin ${a.name}.`);r.bones.push(c)}if(a.ik)for(let o=0;o<a.ik.length;o++){let l=a.ik[o],c=i.findIkConstraint(l);if(!c)throw new Error(`Couldn't find IK constraint ${l} for skin ${a.name}.`);r.constraints.push(c)}if(a.transform)for(let o=0;o<a.transform.length;o++){let l=a.transform[o],c=i.findTransformConstraint(l);if(!c)throw new Error(`Couldn't find transform constraint ${l} for skin ${a.name}.`);r.constraints.push(c)}if(a.path)for(let o=0;o<a.path.length;o++){let l=a.path[o],c=i.findPathConstraint(l);if(!c)throw new Error(`Couldn't find path constraint ${l} for skin ${a.name}.`);r.constraints.push(c)}if(a.physics)for(let o=0;o<a.physics.length;o++){let l=a.physics[o],c=i.findPhysicsConstraint(l);if(!c)throw new Error(`Couldn't find physics constraint ${l} for skin ${a.name}.`);r.constraints.push(c)}for(let o in a.attachments){let l=i.findSlot(o);if(!l)throw new Error(`Couldn't find slot ${o} for skin ${a.name}.`);let c=a.attachments[o];for(let f in c){let d=this.readAttachment(c[f],r,l.index,f,i);d&&r.setAttachment(l.index,f,d)}}i.skins.push(r),r.name=="default"&&(i.defaultSkin=r)}for(let h=0,a=this.linkedMeshes.length;h<a;h++){let r=this.linkedMeshes[h],o=r.skin?i.findSkin(r.skin):i.defaultSkin;if(!o)throw new Error(`Skin not found: ${r.skin}`);let l=o.getAttachment(r.slotIndex,r.parent);if(!l)throw new Error(`Parent mesh not found: ${r.parent}`);r.mesh.timelineAttachment=r.inheritTimeline?l:r.mesh,r.mesh.setParentMesh(l),r.mesh.region!=null&&r.mesh.updateRegion()}if(this.linkedMeshes.length=0,s.events)for(let h in s.events){let a=s.events[h],r=new Di(h);r.intValue=M(a,"int",0),r.floatValue=M(a,"float",0),r.stringValue=M(a,"string",""),r.audioPath=M(a,"audio",null),r.audioPath&&(r.volume=M(a,"volume",1),r.balance=M(a,"balance",0)),i.events.push(r)}if(s.animations)for(let h in s.animations){let a=s.animations[h];this.readAnimation(a,h,i)}return i}readAttachment(e,t,i,s,n){let h=this.scale;switch(s=M(e,"name",s),M(e,"type","region")){case"region":{let a=M(e,"path",s),r=this.readSequence(M(e,"sequence",null)),o=this.attachmentLoader.newRegionAttachment(t,s,a,r);if(!o)return null;o.path=a,o.x=M(e,"x",0)*h,o.y=M(e,"y",0)*h,o.scaleX=M(e,"scaleX",1),o.scaleY=M(e,"scaleY",1),o.rotation=M(e,"rotation",0),o.width=e.width*h,o.height=e.height*h,o.sequence=r;let l=M(e,"color",null);return l&&o.color.setFromString(l),o.region!=null&&o.updateRegion(),o}case"boundingbox":{let a=this.attachmentLoader.newBoundingBoxAttachment(t,s);if(!a)return null;this.readVertices(e,a,e.vertexCount<<1);let r=M(e,"color",null);return r&&a.color.setFromString(r),a}case"mesh":case"linkedmesh":{let a=M(e,"path",s),r=this.readSequence(M(e,"sequence",null)),o=this.attachmentLoader.newMeshAttachment(t,s,a,r);if(!o)return null;o.path=a;let l=M(e,"color",null);l&&o.color.setFromString(l),o.width=M(e,"width",0)*h,o.height=M(e,"height",0)*h,o.sequence=r;let c=M(e,"parent",null);if(c)return this.linkedMeshes.push(new vn(o,M(e,"skin",null),i,c,M(e,"timelines",!0))),o;let f=e.uvs;return this.readVertices(e,o,f.length),o.triangles=e.triangles,o.regionUVs=f,o.region!=null&&o.updateRegion(),o.edges=M(e,"edges",null),o.hullLength=M(e,"hull",0)*2,o}case"path":{let a=this.attachmentLoader.newPathAttachment(t,s);if(!a)return null;a.closed=M(e,"closed",!1),a.constantSpeed=M(e,"constantSpeed",!0);let r=e.vertexCount;this.readVertices(e,a,r<<1);let o=X.newArray(r/3,0);for(let c=0;c<e.lengths.length;c++)o[c]=e.lengths[c]*h;a.lengths=o;let l=M(e,"color",null);return l&&a.color.setFromString(l),a}case"point":{let a=this.attachmentLoader.newPointAttachment(t,s);if(!a)return null;a.x=M(e,"x",0)*h,a.y=M(e,"y",0)*h,a.rotation=M(e,"rotation",0);let r=M(e,"color",null);return r&&a.color.setFromString(r),a}case"clipping":{let a=this.attachmentLoader.newClippingAttachment(t,s);if(!a)return null;let r=M(e,"end",null);r&&(a.endSlot=n.findSlot(r));let o=e.vertexCount;this.readVertices(e,a,o<<1);let l=M(e,"color",null);return l&&a.color.setFromString(l),a}}return null}readSequence(e){if(e==null)return null;let t=new $t(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,i){let s=this.scale;t.worldVerticesLength=i;let n=e.vertices;if(i==n.length){let r=X.toFloatArray(n);if(s!=1)for(let o=0,l=n.length;o<l;o++)r[o]*=s;t.vertices=r;return}let h=new Array,a=new Array;for(let r=0,o=n.length;r<o;){let l=n[r++];a.push(l);for(let c=r+l*4;r<c;r+=4)a.push(n[r]),h.push(n[r+1]*s),h.push(n[r+2]*s),h.push(n[r+3])}t.bones=a,t.vertices=X.toFloatArray(h)}readAnimation(e,t,i){let s=this.scale,n=new Array;if(e.slots)for(let a in e.slots){let r=e.slots[a],o=i.findSlot(a);if(!o)throw new Error("Slot not found: "+a);let l=o.index;for(let c in r){let f=r[c];if(!f)continue;let d=f.length;if(c=="attachment"){let u=new Ze(d,l);for(let m=0;m<d;m++){let g=f[m];u.setFrame(m,M(g,"time",0),M(g,"name",null))}n.push(u)}else if(c=="rgba"){let u=new ci(d,d<<2,l),m=f[0],g=M(m,"time",0),w=O.fromString(m.color);for(let b=0,p=0;;b++){u.setFrame(b,g,w.r,w.g,w.b,w.a);let x=f[b+1];if(!x){u.shrink(p);break}let y=M(x,"time",0),v=O.fromString(x.color),A=m.curve;A&&(p=he(A,u,p,b,0,g,y,w.r,v.r,1),p=he(A,u,p,b,1,g,y,w.g,v.g,1),p=he(A,u,p,b,2,g,y,w.b,v.b,1),p=he(A,u,p,b,3,g,y,w.a,v.a,1)),g=y,w=v,m=x}n.push(u)}else if(c=="rgb"){let u=new di(d,d*3,l),m=f[0],g=M(m,"time",0),w=O.fromString(m.color);for(let b=0,p=0;;b++){u.setFrame(b,g,w.r,w.g,w.b);let x=f[b+1];if(!x){u.shrink(p);break}let y=M(x,"time",0),v=O.fromString(x.color),A=m.curve;A&&(p=he(A,u,p,b,0,g,y,w.r,v.r,1),p=he(A,u,p,b,1,g,y,w.g,v.g,1),p=he(A,u,p,b,2,g,y,w.b,v.b,1)),g=y,w=v,m=x}n.push(u)}else if(c=="alpha")n.push(Fe(f,new fi(d,d,l),0,1));else if(c=="rgba2"){let u=new ui(d,d*7,l),m=f[0],g=M(m,"time",0),w=O.fromString(m.light),b=O.fromString(m.dark);for(let p=0,x=0;;p++){u.setFrame(p,g,w.r,w.g,w.b,w.a,b.r,b.g,b.b);let y=f[p+1];if(!y){u.shrink(x);break}let v=M(y,"time",0),A=O.fromString(y.light),C=O.fromString(y.dark),S=m.curve;S&&(x=he(S,u,x,p,0,g,v,w.r,A.r,1),x=he(S,u,x,p,1,g,v,w.g,A.g,1),x=he(S,u,x,p,2,g,v,w.b,A.b,1),x=he(S,u,x,p,3,g,v,w.a,A.a,1),x=he(S,u,x,p,4,g,v,b.r,C.r,1),x=he(S,u,x,p,5,g,v,b.g,C.g,1),x=he(S,u,x,p,6,g,v,b.b,C.b,1)),g=v,w=A,b=C,m=y}n.push(u)}else if(c=="rgb2"){let u=new mi(d,d*6,l),m=f[0],g=M(m,"time",0),w=O.fromString(m.light),b=O.fromString(m.dark);for(let p=0,x=0;;p++){u.setFrame(p,g,w.r,w.g,w.b,b.r,b.g,b.b);let y=f[p+1];if(!y){u.shrink(x);break}let v=M(y,"time",0),A=O.fromString(y.light),C=O.fromString(y.dark),S=m.curve;S&&(x=he(S,u,x,p,0,g,v,w.r,A.r,1),x=he(S,u,x,p,1,g,v,w.g,A.g,1),x=he(S,u,x,p,2,g,v,w.b,A.b,1),x=he(S,u,x,p,3,g,v,b.r,C.r,1),x=he(S,u,x,p,4,g,v,b.g,C.g,1),x=he(S,u,x,p,5,g,v,b.b,C.b,1)),g=v,w=A,b=C,m=y}n.push(u)}}}if(e.bones)for(let a in e.bones){let r=e.bones[a],o=i.findBone(a);if(!o)throw new Error("Bone not found: "+a);let l=o.index;for(let c in r){let f=r[c],d=f.length;if(d!=0){if(c==="rotate")n.push(Fe(f,new ut(d,d,l),0,1));else if(c==="translate"){let u=new ei(d,d<<1,l);n.push(ji(f,u,"x","y",0,s))}else if(c==="translatex"){let u=new ti(d,d,l);n.push(Fe(f,u,0,s))}else if(c==="translatey"){let u=new ii(d,d,l);n.push(Fe(f,u,0,s))}else if(c==="scale"){let u=new si(d,d<<1,l);n.push(ji(f,u,"x","y",1,1))}else if(c==="scalex"){let u=new ri(d,d,l);n.push(Fe(f,u,1,1))}else if(c==="scaley"){let u=new ni(d,d,l);n.push(Fe(f,u,1,1))}else if(c==="shear"){let u=new ai(d,d<<1,l);n.push(ji(f,u,"x","y",0,1))}else if(c==="shearx"){let u=new li(d,d,l);n.push(Fe(f,u,0,1))}else if(c==="sheary"){let u=new oi(d,d,l);n.push(Fe(f,u,0,1))}else if(c==="inherit"){let u=new hi(d,o.index);for(let m=0;m<f.length;m++){let g=f[m];u.setFrame(m,M(g,"time",0),X.enumValue(gt,M(g,"inherit","Normal")))}n.push(u)}}}}if(e.ik)for(let a in e.ik){let r=e.ik[a],o=r[0];if(!o)continue;let l=i.findIkConstraint(a);if(!l)throw new Error("IK Constraint not found: "+a);let c=i.ikConstraints.indexOf(l),f=new pi(r.length,r.length<<1,c),d=M(o,"time",0),u=M(o,"mix",1),m=M(o,"softness",0)*s;for(let g=0,w=0;;g++){f.setFrame(g,d,u,m,M(o,"bendPositive",!0)?1:-1,M(o,"compress",!1),M(o,"stretch",!1));let b=r[g+1];if(!b){f.shrink(w);break}let p=M(b,"time",0),x=M(b,"mix",1),y=M(b,"softness",0)*s,v=o.curve;v&&(w=he(v,f,w,g,0,d,p,u,x,1),w=he(v,f,w,g,1,d,p,m,y,s)),d=p,u=x,m=y,o=b}n.push(f)}if(e.transform)for(let a in e.transform){let r=e.transform[a],o=r[0];if(!o)continue;let l=i.findTransformConstraint(a);if(!l)throw new Error("Transform constraint not found: "+a);let c=i.transformConstraints.indexOf(l),f=new xi(r.length,r.length*6,c),d=M(o,"time",0),u=M(o,"mixRotate",1),m=M(o,"mixX",1),g=M(o,"mixY",m),w=M(o,"mixScaleX",1),b=M(o,"mixScaleY",w),p=M(o,"mixShearY",1);for(let x=0,y=0;;x++){f.setFrame(x,d,u,m,g,w,b,p);let v=r[x+1];if(!v){f.shrink(y);break}let A=M(v,"time",0),C=M(v,"mixRotate",1),S=M(v,"mixX",1),E=M(v,"mixY",S),R=M(v,"mixScaleX",1),Y=M(v,"mixScaleY",R),P=M(v,"mixShearY",1),I=o.curve;I&&(y=he(I,f,y,x,0,d,A,u,C,1),y=he(I,f,y,x,1,d,A,m,S,1),y=he(I,f,y,x,2,d,A,g,E,1),y=he(I,f,y,x,3,d,A,w,R,1),y=he(I,f,y,x,4,d,A,b,Y,1),y=he(I,f,y,x,5,d,A,p,P,1)),d=A,u=C,m=S,g=E,w=R,b=Y,w=R,o=v}n.push(f)}if(e.path)for(let a in e.path){let r=e.path[a],o=i.findPathConstraint(a);if(!o)throw new Error("Path constraint not found: "+a);let l=i.pathConstraints.indexOf(o);for(let c in r){let f=r[c],d=f[0];if(!d)continue;let u=f.length;if(c==="position"){let m=new bi(u,u,l);n.push(Fe(f,m,0,o.positionMode==0?s:1))}else if(c==="spacing"){let m=new wi(u,u,l);n.push(Fe(f,m,0,o.spacingMode==0||o.spacingMode==1?s:1))}else if(c==="mix"){let m=new vi(u,u*3,l),g=M(d,"time",0),w=M(d,"mixRotate",1),b=M(d,"mixX",1),p=M(d,"mixY",b);for(let x=0,y=0;;x++){m.setFrame(x,g,w,b,p);let v=f[x+1];if(!v){m.shrink(y);break}let A=M(v,"time",0),C=M(v,"mixRotate",1),S=M(v,"mixX",1),E=M(v,"mixY",S),R=d.curve;R&&(y=he(R,m,y,x,0,g,A,w,C,1),y=he(R,m,y,x,1,g,A,b,S,1),y=he(R,m,y,x,2,g,A,p,E,1)),g=A,w=C,b=S,p=E,d=v}n.push(m)}}}if(e.physics)for(let a in e.physics){let r=e.physics[a],o=-1;if(a.length>0){let l=i.findPhysicsConstraint(a);if(!l)throw new Error("Physics constraint not found: "+a);o=i.physicsConstraints.indexOf(l)}for(let l in r){let c=r[l],f=c[0];if(!f)continue;let d=c.length;if(l=="reset"){const m=new It(d,o);for(let g=0;f!=null;f=c[g+1],g++)m.setFrame(g,M(f,"time",0));n.push(m);continue}let u;if(l=="inertia")u=new yi(d,d,o);else if(l=="strength")u=new Ai(d,d,o);else if(l=="damping")u=new Ci(d,d,o);else if(l=="mass")u=new Si(d,d,o);else if(l=="wind")u=new Ti(d,d,o);else if(l=="gravity")u=new Ii(d,d,o);else if(l=="mix")u=new Mi(d,d,o);else continue;n.push(Fe(c,u,0,1))}}if(e.attachments)for(let a in e.attachments){let r=e.attachments[a],o=i.findSkin(a);if(!o)throw new Error("Skin not found: "+a);for(let l in r){let c=r[l],f=i.findSlot(l);if(!f)throw new Error("Slot not found: "+l);let d=f.index;for(let u in c){let m=c[u],g=o.getAttachment(d,u);for(let w in m){let b=m[w],p=b[0];if(p){if(w=="deform"){let x=g.bones,y=g.vertices,v=x?y.length/3*2:y.length,A=new gi(b.length,b.length,d,g),C=M(p,"time",0);for(let S=0,E=0;;S++){let R,Y=M(p,"vertices",null);if(!Y)R=x?X.newFloatArray(v):y;else{R=X.newFloatArray(v);let F=M(p,"offset",0);if(X.arrayCopy(Y,0,R,F,Y.length),s!=1)for(let se=F,re=se+Y.length;se<re;se++)R[se]*=s;if(!x)for(let se=0;se<v;se++)R[se]+=y[se]}A.setFrame(S,C,R);let P=b[S+1];if(!P){A.shrink(E);break}let I=M(P,"time",0),k=p.curve;k&&(E=he(k,A,E,S,0,C,I,0,1,1)),C=I,p=P}n.push(A)}else if(w=="sequence"){let x=new it(b.length,d,g),y=0;for(let v=0;v<b.length;v++){let A=M(p,"delay",y),C=M(p,"time",0),S=us[M(p,"mode","hold")],E=M(p,"index",0);x.setFrame(v,C,S,E,A),y=A,p=b[v+1]}n.push(x)}}}}}}if(e.drawOrder){let a=new Je(e.drawOrder.length),r=i.slots.length,o=0;for(let l=0;l<e.drawOrder.length;l++,o++){let c=e.drawOrder[l],f=null,d=M(c,"offsets",null);if(d){f=X.newArray(r,-1);let u=X.newArray(r-d.length,0),m=0,g=0;for(let w=0;w<d.length;w++){let b=d[w],p=i.findSlot(b.slot);if(!p)throw new Error("Slot not found: "+p);let x=p.index;for(;m!=x;)u[g++]=m++;f[m+b.offset]=m++}for(;m<r;)u[g++]=m++;for(let w=r-1;w>=0;w--)f[w]==-1&&(f[w]=u[--g])}a.setFrame(o,M(c,"time",0),f)}n.push(a)}if(e.events){let a=new mt(e.events.length),r=0;for(let o=0;o<e.events.length;o++,r++){let l=e.events[o],c=i.findEvent(l.name);if(!c)throw new Error("Event not found: "+l.name);let f=new Vi(X.toSinglePrecision(M(l,"time",0)),c);f.intValue=M(l,"int",c.intValue),f.floatValue=M(l,"float",c.floatValue),f.stringValue=M(l,"string",c.stringValue),f.data.audioPath&&(f.volume=M(l,"volume",1),f.balance=M(l,"balance",0)),a.setFrame(r,f)}n.push(a)}let h=0;for(let a=0,r=n.length;a<r;a++)h=Math.max(h,n[a].getDuration());i.animations.push(new St(t,n,h))}},vn=class{parent;skin;slotIndex;mesh;inheritTimeline;constructor(e,t,i,s,n){this.mesh=e,this.skin=t,this.slotIndex=i,this.parent=s,this.inheritTimeline=n}};function Fe(e,t,i,s){let n=e[0],h=M(n,"time",0),a=M(n,"value",i)*s,r=0;for(let o=0;;o++){t.setFrame(o,h,a);let l=e[o+1];if(!l)return t.shrink(r),t;let c=M(l,"time",0),f=M(l,"value",i)*s;n.curve&&(r=he(n.curve,t,r,o,0,h,c,a,f,s)),h=c,a=f,n=l}}function ji(e,t,i,s,n,h){let a=e[0],r=M(a,"time",0),o=M(a,i,n)*h,l=M(a,s,n)*h,c=0;for(let f=0;;f++){t.setFrame(f,r,o,l);let d=e[f+1];if(!d)return t.shrink(c),t;let u=M(d,"time",0),m=M(d,i,n)*h,g=M(d,s,n)*h,w=a.curve;w&&(c=he(w,t,c,f,0,r,u,o,m,h),c=he(w,t,c,f,1,r,u,l,g,h)),r=u,o=m,l=g,a=d}}function he(e,t,i,s,n,h,a,r,o,l){if(e=="stepped")return t.setStepped(s),i;let c=n<<2,f=e[c],d=e[c+1]*l,u=e[c+2],m=e[c+3]*l;return t.setBezier(i,s,n,h,r,f,d,u,m,a,o),i+1}function M(e,t,i){return e[t]!==void 0?e[t]:i}typeof Math.fround>"u"&&(Math.fround=function(e){return function(t){return e[0]=t,e[0]}}(new Float32Array(1)));var be=class{canvas;gl;restorables=new Array;constructor(e,t={alpha:"true"}){if(e instanceof WebGLRenderingContext||typeof WebGL2RenderingContext<"u"&&e instanceof WebGL2RenderingContext)this.gl=e,this.canvas=this.gl.canvas;else{let i=e;this.gl=i.getContext("webgl2",t)||i.getContext("webgl",t),this.canvas=i,i.addEventListener("webglcontextlost",s=>{let n=s;s&&s.preventDefault()}),i.addEventListener("webglcontextrestored",s=>{for(let n=0,h=this.restorables.length;n<h;n++)this.restorables[n].restore()})}}addRestorable(e){this.restorables.push(e)}removeRestorable(e){let t=this.restorables.indexOf(e);t>-1&&this.restorables.splice(t,1)}},Vt=class extends Ft{context;texture=null;boundUnit=0;useMipMaps=!1;constructor(e,t,i=!1){super(t),this.context=e instanceof be?e:new be(e),this.useMipMaps=i,this.restore(),this.context.addRestorable(this)}setFilters(e,t){let i=this.context.gl;this.bind(),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_MIN_FILTER,e),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_MAG_FILTER,Vt.validateMagFilter(t)),this.useMipMaps=Vt.usesMipMaps(e),this.useMipMaps&&i.generateMipmap(i.TEXTURE_2D)}static validateMagFilter(e){switch(e){case 9987:case 9985:case 9986:case 9984:return 9729;default:return e}}static usesMipMaps(e){switch(e){case 9987:case 9985:case 9986:case 9984:return!0;default:return!1}}setWraps(e,t){let i=this.context.gl;this.bind(),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_WRAP_S,e),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_WRAP_T,t)}update(e){let t=this.context.gl;this.texture||(this.texture=this.context.gl.createTexture()),this.bind(),Vt.DISABLE_UNPACK_PREMULTIPLIED_ALPHA_WEBGL&&t.pixelStorei(t.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1),t.texImage2D(t.TEXTURE_2D,0,t.RGBA,t.RGBA,t.UNSIGNED_BYTE,this._image),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_MAG_FILTER,t.LINEAR),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_MIN_FILTER,e?t.LINEAR_MIPMAP_LINEAR:t.LINEAR),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_WRAP_S,t.CLAMP_TO_EDGE),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_WRAP_T,t.CLAMP_TO_EDGE),e&&t.generateMipmap(t.TEXTURE_2D)}restore(){this.texture=null,this.update(this.useMipMaps)}bind(e=0){let t=this.context.gl;this.boundUnit=e,t.activeTexture(t.TEXTURE0+e),t.bindTexture(t.TEXTURE_2D,this.texture)}unbind(){let e=this.context.gl;e.activeTexture(e.TEXTURE0+this.boundUnit),e.bindTexture(e.TEXTURE_2D,null)}dispose(){this.context.removeRestorable(this),this.context.gl.deleteTexture(this.texture)}},at=Vt;B(at,"DISABLE_UNPACK_PREMULTIPLIED_ALPHA_WEBGL",!1);var Ds=class extends Rs{constructor(e,t="",i=new Oi){super(s=>new at(e,s),t,i)}},Me=class{x=0;y=0;z=0;constructor(e=0,t=0,i=0){this.x=e,this.y=t,this.z=i}setFrom(e){return this.x=e.x,this.y=e.y,this.z=e.z,this}set(e,t,i){return this.x=e,this.y=t,this.z=i,this}add(e){return this.x+=e.x,this.y+=e.y,this.z+=e.z,this}sub(e){return this.x-=e.x,this.y-=e.y,this.z-=e.z,this}scale(e){return this.x*=e,this.y*=e,this.z*=e,this}normalize(){let e=this.length();return e==0?this:(e=1/e,this.x*=e,this.y*=e,this.z*=e,this)}cross(e){return this.set(this.y*e.z-this.z*e.y,this.z*e.x-this.x*e.z,this.x*e.y-this.y*e.x)}multiply(e){let t=e.values;return this.set(this.x*t[D]+this.y*t[z]+this.z*t[q]+t[N],this.x*t[H]+this.y*t[_]+this.z*t[j]+t[U],this.x*t[Z]+this.y*t[J]+this.z*t[W]+t[G])}project(e){let t=e.values,i=1/(this.x*t[$]+this.y*t[ee]+this.z*t[te]+t[Q]);return this.set((this.x*t[D]+this.y*t[z]+this.z*t[q]+t[N])*i,(this.x*t[H]+this.y*t[_]+this.z*t[j]+t[U])*i,(this.x*t[Z]+this.y*t[J]+this.z*t[W]+t[G])*i)}dot(e){return this.x*e.x+this.y*e.y+this.z*e.z}length(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z)}distance(e){let t=e.x-this.x,i=e.y-this.y,s=e.z-this.z;return Math.sqrt(t*t+i*i+s*s)}},D=0,z=4,q=8,N=12,H=1,_=5,j=9,U=13,Z=2,J=6,W=10,G=14,$=3,ee=7,te=11,Q=15,Pe=class{temp=new Float32Array(16);values=new Float32Array(16);constructor(){let e=this.values;e[D]=1,e[_]=1,e[W]=1,e[Q]=1}set(e){return this.values.set(e),this}transpose(){let e=this.temp,t=this.values;return e[D]=t[D],e[z]=t[H],e[q]=t[Z],e[N]=t[$],e[H]=t[z],e[_]=t[_],e[j]=t[J],e[U]=t[ee],e[Z]=t[q],e[J]=t[j],e[W]=t[W],e[G]=t[te],e[$]=t[N],e[ee]=t[U],e[te]=t[G],e[Q]=t[Q],this.set(e)}identity(){let e=this.values;return e[D]=1,e[z]=0,e[q]=0,e[N]=0,e[H]=0,e[_]=1,e[j]=0,e[U]=0,e[Z]=0,e[J]=0,e[W]=1,e[G]=0,e[$]=0,e[ee]=0,e[te]=0,e[Q]=1,this}invert(){let e=this.values,t=this.temp,i=e[$]*e[J]*e[j]*e[N]-e[Z]*e[ee]*e[j]*e[N]-e[$]*e[_]*e[W]*e[N]+e[H]*e[ee]*e[W]*e[N]+e[Z]*e[_]*e[te]*e[N]-e[H]*e[J]*e[te]*e[N]-e[$]*e[J]*e[q]*e[U]+e[Z]*e[ee]*e[q]*e[U]+e[$]*e[z]*e[W]*e[U]-e[D]*e[ee]*e[W]*e[U]-e[Z]*e[z]*e[te]*e[U]+e[D]*e[J]*e[te]*e[U]+e[$]*e[_]*e[q]*e[G]-e[H]*e[ee]*e[q]*e[G]-e[$]*e[z]*e[j]*e[G]+e[D]*e[ee]*e[j]*e[G]+e[H]*e[z]*e[te]*e[G]-e[D]*e[_]*e[te]*e[G]-e[Z]*e[_]*e[q]*e[Q]+e[H]*e[J]*e[q]*e[Q]+e[Z]*e[z]*e[j]*e[Q]-e[D]*e[J]*e[j]*e[Q]-e[H]*e[z]*e[W]*e[Q]+e[D]*e[_]*e[W]*e[Q];if(i==0)throw new Error("non-invertible matrix");let s=1/i;return t[D]=e[j]*e[G]*e[ee]-e[U]*e[W]*e[ee]+e[U]*e[J]*e[te]-e[_]*e[G]*e[te]-e[j]*e[J]*e[Q]+e[_]*e[W]*e[Q],t[z]=e[N]*e[W]*e[ee]-e[q]*e[G]*e[ee]-e[N]*e[J]*e[te]+e[z]*e[G]*e[te]+e[q]*e[J]*e[Q]-e[z]*e[W]*e[Q],t[q]=e[q]*e[U]*e[ee]-e[N]*e[j]*e[ee]+e[N]*e[_]*e[te]-e[z]*e[U]*e[te]-e[q]*e[_]*e[Q]+e[z]*e[j]*e[Q],t[N]=e[N]*e[j]*e[J]-e[q]*e[U]*e[J]-e[N]*e[_]*e[W]+e[z]*e[U]*e[W]+e[q]*e[_]*e[G]-e[z]*e[j]*e[G],t[H]=e[U]*e[W]*e[$]-e[j]*e[G]*e[$]-e[U]*e[Z]*e[te]+e[H]*e[G]*e[te]+e[j]*e[Z]*e[Q]-e[H]*e[W]*e[Q],t[_]=e[q]*e[G]*e[$]-e[N]*e[W]*e[$]+e[N]*e[Z]*e[te]-e[D]*e[G]*e[te]-e[q]*e[Z]*e[Q]+e[D]*e[W]*e[Q],t[j]=e[N]*e[j]*e[$]-e[q]*e[U]*e[$]-e[N]*e[H]*e[te]+e[D]*e[U]*e[te]+e[q]*e[H]*e[Q]-e[D]*e[j]*e[Q],t[U]=e[q]*e[U]*e[Z]-e[N]*e[j]*e[Z]+e[N]*e[H]*e[W]-e[D]*e[U]*e[W]-e[q]*e[H]*e[G]+e[D]*e[j]*e[G],t[Z]=e[_]*e[G]*e[$]-e[U]*e[J]*e[$]+e[U]*e[Z]*e[ee]-e[H]*e[G]*e[ee]-e[_]*e[Z]*e[Q]+e[H]*e[J]*e[Q],t[J]=e[N]*e[J]*e[$]-e[z]*e[G]*e[$]-e[N]*e[Z]*e[ee]+e[D]*e[G]*e[ee]+e[z]*e[Z]*e[Q]-e[D]*e[J]*e[Q],t[W]=e[z]*e[U]*e[$]-e[N]*e[_]*e[$]+e[N]*e[H]*e[ee]-e[D]*e[U]*e[ee]-e[z]*e[H]*e[Q]+e[D]*e[_]*e[Q],t[G]=e[N]*e[_]*e[Z]-e[z]*e[U]*e[Z]-e[N]*e[H]*e[J]+e[D]*e[U]*e[J]+e[z]*e[H]*e[G]-e[D]*e[_]*e[G],t[$]=e[j]*e[J]*e[$]-e[_]*e[W]*e[$]-e[j]*e[Z]*e[ee]+e[H]*e[W]*e[ee]+e[_]*e[Z]*e[te]-e[H]*e[J]*e[te],t[ee]=e[z]*e[W]*e[$]-e[q]*e[J]*e[$]+e[q]*e[Z]*e[ee]-e[D]*e[W]*e[ee]-e[z]*e[Z]*e[te]+e[D]*e[J]*e[te],t[te]=e[q]*e[_]*e[$]-e[z]*e[j]*e[$]-e[q]*e[H]*e[ee]+e[D]*e[j]*e[ee]+e[z]*e[H]*e[te]-e[D]*e[_]*e[te],t[Q]=e[z]*e[j]*e[Z]-e[q]*e[_]*e[Z]+e[q]*e[H]*e[J]-e[D]*e[j]*e[J]-e[z]*e[H]*e[W]+e[D]*e[_]*e[W],e[D]=t[D]*s,e[z]=t[z]*s,e[q]=t[q]*s,e[N]=t[N]*s,e[H]=t[H]*s,e[_]=t[_]*s,e[j]=t[j]*s,e[U]=t[U]*s,e[Z]=t[Z]*s,e[J]=t[J]*s,e[W]=t[W]*s,e[G]=t[G]*s,e[$]=t[$]*s,e[ee]=t[ee]*s,e[te]=t[te]*s,e[Q]=t[Q]*s,this}determinant(){let e=this.values;return e[$]*e[J]*e[j]*e[N]-e[Z]*e[ee]*e[j]*e[N]-e[$]*e[_]*e[W]*e[N]+e[H]*e[ee]*e[W]*e[N]+e[Z]*e[_]*e[te]*e[N]-e[H]*e[J]*e[te]*e[N]-e[$]*e[J]*e[q]*e[U]+e[Z]*e[ee]*e[q]*e[U]+e[$]*e[z]*e[W]*e[U]-e[D]*e[ee]*e[W]*e[U]-e[Z]*e[z]*e[te]*e[U]+e[D]*e[J]*e[te]*e[U]+e[$]*e[_]*e[q]*e[G]-e[H]*e[ee]*e[q]*e[G]-e[$]*e[z]*e[j]*e[G]+e[D]*e[ee]*e[j]*e[G]+e[H]*e[z]*e[te]*e[G]-e[D]*e[_]*e[te]*e[G]-e[Z]*e[_]*e[q]*e[Q]+e[H]*e[J]*e[q]*e[Q]+e[Z]*e[z]*e[j]*e[Q]-e[D]*e[J]*e[j]*e[Q]-e[H]*e[z]*e[W]*e[Q]+e[D]*e[_]*e[W]*e[Q]}translate(e,t,i){let s=this.values;return s[N]+=e,s[U]+=t,s[G]+=i,this}copy(){return new Pe().set(this.values)}projection(e,t,i,s){this.identity();let n=1/Math.tan(i*(Math.PI/180)/2),h=(t+e)/(e-t),a=2*t*e/(e-t),r=this.values;return r[D]=n/s,r[H]=0,r[Z]=0,r[$]=0,r[z]=0,r[_]=n,r[J]=0,r[ee]=0,r[q]=0,r[j]=0,r[W]=h,r[te]=-1,r[N]=0,r[U]=0,r[G]=a,r[Q]=0,this}ortho2d(e,t,i,s){return this.ortho(e,e+i,t,t+s,0,1)}ortho(e,t,i,s,n,h){this.identity();let a=2/(t-e),r=2/(s-i),o=-2/(h-n),l=-(t+e)/(t-e),c=-(s+i)/(s-i),f=-(h+n)/(h-n),d=this.values;return d[D]=a,d[H]=0,d[Z]=0,d[$]=0,d[z]=0,d[_]=r,d[J]=0,d[ee]=0,d[q]=0,d[j]=0,d[W]=o,d[te]=0,d[N]=l,d[U]=c,d[G]=f,d[Q]=1,this}multiply(e){let t=this.temp,i=this.values,s=e.values;return t[D]=i[D]*s[D]+i[z]*s[H]+i[q]*s[Z]+i[N]*s[$],t[z]=i[D]*s[z]+i[z]*s[_]+i[q]*s[J]+i[N]*s[ee],t[q]=i[D]*s[q]+i[z]*s[j]+i[q]*s[W]+i[N]*s[te],t[N]=i[D]*s[N]+i[z]*s[U]+i[q]*s[G]+i[N]*s[Q],t[H]=i[H]*s[D]+i[_]*s[H]+i[j]*s[Z]+i[U]*s[$],t[_]=i[H]*s[z]+i[_]*s[_]+i[j]*s[J]+i[U]*s[ee],t[j]=i[H]*s[q]+i[_]*s[j]+i[j]*s[W]+i[U]*s[te],t[U]=i[H]*s[N]+i[_]*s[U]+i[j]*s[G]+i[U]*s[Q],t[Z]=i[Z]*s[D]+i[J]*s[H]+i[W]*s[Z]+i[G]*s[$],t[J]=i[Z]*s[z]+i[J]*s[_]+i[W]*s[J]+i[G]*s[ee],t[W]=i[Z]*s[q]+i[J]*s[j]+i[W]*s[W]+i[G]*s[te],t[G]=i[Z]*s[N]+i[J]*s[U]+i[W]*s[G]+i[G]*s[Q],t[$]=i[$]*s[D]+i[ee]*s[H]+i[te]*s[Z]+i[Q]*s[$],t[ee]=i[$]*s[z]+i[ee]*s[_]+i[te]*s[J]+i[Q]*s[ee],t[te]=i[$]*s[q]+i[ee]*s[j]+i[te]*s[W]+i[Q]*s[te],t[Q]=i[$]*s[N]+i[ee]*s[U]+i[te]*s[G]+i[Q]*s[Q],this.set(this.temp)}multiplyLeft(e){let t=this.temp,i=this.values,s=e.values;return t[D]=s[D]*i[D]+s[z]*i[H]+s[q]*i[Z]+s[N]*i[$],t[z]=s[D]*i[z]+s[z]*i[_]+s[q]*i[J]+s[N]*i[ee],t[q]=s[D]*i[q]+s[z]*i[j]+s[q]*i[W]+s[N]*i[te],t[N]=s[D]*i[N]+s[z]*i[U]+s[q]*i[G]+s[N]*i[Q],t[H]=s[H]*i[D]+s[_]*i[H]+s[j]*i[Z]+s[U]*i[$],t[_]=s[H]*i[z]+s[_]*i[_]+s[j]*i[J]+s[U]*i[ee],t[j]=s[H]*i[q]+s[_]*i[j]+s[j]*i[W]+s[U]*i[te],t[U]=s[H]*i[N]+s[_]*i[U]+s[j]*i[G]+s[U]*i[Q],t[Z]=s[Z]*i[D]+s[J]*i[H]+s[W]*i[Z]+s[G]*i[$],t[J]=s[Z]*i[z]+s[J]*i[_]+s[W]*i[J]+s[G]*i[ee],t[W]=s[Z]*i[q]+s[J]*i[j]+s[W]*i[W]+s[G]*i[te],t[G]=s[Z]*i[N]+s[J]*i[U]+s[W]*i[G]+s[G]*i[Q],t[$]=s[$]*i[D]+s[ee]*i[H]+s[te]*i[Z]+s[Q]*i[$],t[ee]=s[$]*i[z]+s[ee]*i[_]+s[te]*i[J]+s[Q]*i[ee],t[te]=s[$]*i[q]+s[ee]*i[j]+s[te]*i[W]+s[Q]*i[te],t[Q]=s[$]*i[N]+s[ee]*i[U]+s[te]*i[G]+s[Q]*i[Q],this.set(this.temp)}lookAt(e,t,i){let s=Pe.xAxis,n=Pe.yAxis,h=Pe.zAxis;h.setFrom(t).normalize(),s.setFrom(t).normalize(),s.cross(i).normalize(),n.setFrom(s).cross(h).normalize(),this.identity();let a=this.values;return a[D]=s.x,a[z]=s.y,a[q]=s.z,a[H]=n.x,a[_]=n.y,a[j]=n.z,a[Z]=-h.x,a[J]=-h.y,a[W]=-h.z,Pe.tmpMatrix.identity(),Pe.tmpMatrix.values[N]=-e.x,Pe.tmpMatrix.values[U]=-e.y,Pe.tmpMatrix.values[G]=-e.z,this.multiply(Pe.tmpMatrix),this}},Oe=Pe;B(Oe,"xAxis",new Me),B(Oe,"yAxis",new Me),B(Oe,"zAxis",new Me),B(Oe,"tmpMatrix",new Pe);var Ns=class{position=new Me(0,0,0);direction=new Me(0,0,-1);up=new Me(0,1,0);near=0;far=100;zoom=1;viewportWidth=0;viewportHeight=0;projectionView=new Oe;inverseProjectionView=new Oe;projection=new Oe;view=new Oe;constructor(e,t){this.viewportWidth=e,this.viewportHeight=t,this.update()}update(){let e=this.projection,t=this.view,i=this.projectionView,s=this.inverseProjectionView,n=this.zoom,h=this.viewportWidth,a=this.viewportHeight;e.ortho(n*(-h/2),n*(h/2),n*(-a/2),n*(a/2),this.near,this.far),t.lookAt(this.position,this.direction,this.up),i.set(e.values),i.multiply(t),s.set(i.values).invert()}screenToWorld(e,t,i){let s=e.x,n=i-e.y-1;return e.x=2*s/t-1,e.y=2*n/i-1,e.z=2*e.z-1,e.project(this.inverseProjectionView),e}worldToScreen(e,t,i){return e.project(this.projectionView),e.x=t*(e.x+1)/2,e.y=i*(e.y+1)/2,e.z=(e.z+1)/2,e}setViewport(e,t){this.viewportWidth=e,this.viewportHeight=t}},Zi=class{element;mouseX=0;mouseY=0;buttonDown=!1;touch0=null;touch1=null;initialPinchDistance=0;listeners=new Array;eventListeners=[];constructor(e){this.element=e,this.setupCallbacks(e)}setupCallbacks(e){let t=a=>{if(a instanceof MouseEvent){let r=e.getBoundingClientRect();this.mouseX=a.clientX-r.left,this.mouseY=a.clientY-r.top,this.buttonDown=!0,this.listeners.map(o=>{o.down&&o.down(this.mouseX,this.mouseY)}),document.addEventListener("mousemove",i),document.addEventListener("mouseup",s)}},i=a=>{if(a instanceof MouseEvent){let r=e.getBoundingClientRect();this.mouseX=a.clientX-r.left,this.mouseY=a.clientY-r.top,this.listeners.map(o=>{this.buttonDown?o.dragged&&o.dragged(this.mouseX,this.mouseY):o.moved&&o.moved(this.mouseX,this.mouseY)})}},s=a=>{if(a instanceof MouseEvent){let r=e.getBoundingClientRect();this.mouseX=a.clientX-r.left,this.mouseY=a.clientY-r.top,this.buttonDown=!1,this.listeners.map(o=>{o.up&&o.up(this.mouseX,this.mouseY)}),document.removeEventListener("mousemove",i),document.removeEventListener("mouseup",s)}},n=a=>{a.preventDefault();let r=a.deltaY;a.deltaMode==WheelEvent.DOM_DELTA_LINE&&(r*=8),a.deltaMode==WheelEvent.DOM_DELTA_PAGE&&(r*=24),this.listeners.map(o=>{o.wheel&&o.wheel(a.deltaY)})};e.addEventListener("mousedown",t,!0),e.addEventListener("mousemove",i,!0),e.addEventListener("mouseup",s,!0),e.addEventListener("wheel",n,!0),e.addEventListener("touchstart",a=>{if(!this.touch0||!this.touch1){var r=a.changedTouches;let o=r.item(0);if(!o)return;let l=e.getBoundingClientRect(),c=o.clientX-l.left,f=o.clientY-l.top,d=new _s(o.identifier,c,f);if(this.mouseX=c,this.mouseY=f,this.buttonDown=!0,!this.touch0)this.touch0=d,this.listeners.map(u=>{u.down&&u.down(d.x,d.y)});else if(!this.touch1){this.touch1=d;let u=this.touch1.x-this.touch0.x,m=this.touch1.x-this.touch0.x;this.initialPinchDistance=Math.sqrt(u*u+m*m),this.listeners.map(g=>{g.zoom&&g.zoom(this.initialPinchDistance,this.initialPinchDistance)})}}a.preventDefault()},!1),e.addEventListener("touchmove",a=>{if(this.touch0){var r=a.changedTouches;let c=e.getBoundingClientRect();for(var o=0;o<r.length;o++){var l=r[o];let f=l.clientX-c.left,d=l.clientY-c.top;this.touch0.identifier===l.identifier&&(this.touch0.x=this.mouseX=f,this.touch0.y=this.mouseY=d,this.listeners.map(u=>{u.dragged&&u.dragged(f,d)})),this.touch1&&this.touch1.identifier===l.identifier&&(this.touch1.x=this.mouseX=f,this.touch1.y=this.mouseY=d)}if(this.touch0&&this.touch1){let f=this.touch1.x-this.touch0.x,d=this.touch1.x-this.touch0.x,u=Math.sqrt(f*f+d*d);this.listeners.map(m=>{m.zoom&&m.zoom(this.initialPinchDistance,u)})}}a.preventDefault()},!1);let h=a=>{if(this.touch0){var r=a.changedTouches;let c=e.getBoundingClientRect();for(var o=0;o<r.length;o++){var l=r[o];let f=l.clientX-c.left,d=l.clientY-c.top;if(this.touch0.identifier===l.identifier)if(this.touch0=null,this.mouseX=f,this.mouseY=d,this.listeners.map(u=>{u.up&&u.up(f,d)}),this.touch1)this.touch0=this.touch1,this.touch1=null,this.mouseX=this.touch0.x,this.mouseX=this.touch0.x,this.buttonDown=!0,this.listeners.map(u=>{u.down&&u.down(this.touch0.x,this.touch0.y)});else{this.buttonDown=!1;break}this.touch1&&this.touch1.identifier&&(this.touch1=null)}}a.preventDefault()};e.addEventListener("touchend",h,!1),e.addEventListener("touchcancel",h)}addListener(e){this.listeners.push(e)}removeListener(e){let t=this.listeners.indexOf(e);t>-1&&this.listeners.splice(t,1)}},_s=class{constructor(e,t,i){this.identifier=e,this.x=t,this.y=i}},yn=class{constructor(e,t){this.canvas=e,this.camera=t;let i=0,s=0,n=0,h=0,a=0,r=0,o=0,l=0;new Zi(e).addListener({down:(c,f)=>{i=t.position.x,s=t.position.y,h=r=c,a=o=f,l=t.zoom},dragged:(c,f)=>{let d=c-h,u=f-a,m=t.screenToWorld(new Me(0,0),e.clientWidth,e.clientHeight),g=t.screenToWorld(new Me(d,u),e.clientWidth,e.clientHeight).sub(m);t.position.set(i-g.x,s-g.y,0),t.update(),r=c,o=f},wheel:c=>{let f=c/200*t.zoom,d=t.zoom+f;if(d>0){let u=0,m=0;if(c<0)u=r,m=o;else{let b=new Me(e.clientWidth/2+15,e.clientHeight/2),p=r-b.x,x=e.clientHeight-1-o-b.y;u=b.x-p,m=e.clientHeight-1-b.y+x}let g=t.screenToWorld(new Me(u,m),e.clientWidth,e.clientHeight);t.zoom=d,t.update();let w=t.screenToWorld(new Me(u,m),e.clientWidth,e.clientHeight);t.position.add(g.sub(w)),t.update()}},zoom:(c,f)=>{let d=c/f;t.zoom=l*d},up:(c,f)=>{r=c,o=f},moved:(c,f)=>{r=c,o=f}})}},ue=class{constructor(e,t,i){this.vertexShader=t,this.fragmentShader=i,this.vsSource=t,this.fsSource=i,this.context=e instanceof be?e:new be(e),this.context.addRestorable(this),this.compile()}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 e=this.context.gl;try{if(this.vs=this.compileShader(e.VERTEX_SHADER,this.vertexShader),!this.vs)throw new Error("Couldn't compile vertex shader.");if(this.fs=this.compileShader(e.FRAGMENT_SHADER,this.fragmentShader),!this.fs)throw new Error("Couldn#t compile fragment shader.");this.program=this.compileProgram(this.vs,this.fs)}catch(t){throw this.dispose(),t}}compileShader(e,t){let i=this.context.gl,s=i.createShader(e);if(!s)throw new Error("Couldn't create shader.");if(i.shaderSource(s,t),i.compileShader(s),!i.getShaderParameter(s,i.COMPILE_STATUS)){let n="Couldn't compile shader: "+i.getShaderInfoLog(s);if(i.deleteShader(s),!i.isContextLost())throw new Error(n)}return s}compileProgram(e,t){let i=this.context.gl,s=i.createProgram();if(!s)throw new Error("Couldn't compile program.");if(i.attachShader(s,e),i.attachShader(s,t),i.linkProgram(s),!i.getProgramParameter(s,i.LINK_STATUS)){let n="Couldn't compile shader program: "+i.getProgramInfoLog(s);if(i.deleteProgram(s),!i.isContextLost())throw new Error(n)}return s}restore(){this.compile()}bind(){this.context.gl.useProgram(this.program)}unbind(){this.context.gl.useProgram(null)}setUniformi(e,t){this.context.gl.uniform1i(this.getUniformLocation(e),t)}setUniformf(e,t){this.context.gl.uniform1f(this.getUniformLocation(e),t)}setUniform2f(e,t,i){this.context.gl.uniform2f(this.getUniformLocation(e),t,i)}setUniform3f(e,t,i,s){this.context.gl.uniform3f(this.getUniformLocation(e),t,i,s)}setUniform4f(e,t,i,s,n){this.context.gl.uniform4f(this.getUniformLocation(e),t,i,s,n)}setUniform2x2f(e,t){let i=this.context.gl;this.tmp2x2.set(t),i.uniformMatrix2fv(this.getUniformLocation(e),!1,this.tmp2x2)}setUniform3x3f(e,t){let i=this.context.gl;this.tmp3x3.set(t),i.uniformMatrix3fv(this.getUniformLocation(e),!1,this.tmp3x3)}setUniform4x4f(e,t){let i=this.context.gl;this.tmp4x4.set(t),i.uniformMatrix4fv(this.getUniformLocation(e),!1,this.tmp4x4)}getUniformLocation(e){let t=this.context.gl;if(!this.program)throw new Error("Shader not compiled.");let i=t.getUniformLocation(this.program,e);if(!i&&!t.isContextLost())throw new Error(`Couldn't find location for uniform ${e}`);return i}getAttributeLocation(e){let t=this.context.gl;if(!this.program)throw new Error("Shader not compiled.");let i=t.getAttribLocation(this.program,e);if(i==-1&&!t.isContextLost())throw new Error(`Couldn't find location for attribute ${e}`);return i}dispose(){this.context.removeRestorable(this);let e=this.context.gl;this.vs&&(e.deleteShader(this.vs),this.vs=null),this.fs&&(e.deleteShader(this.fs),this.fs=null),this.program&&(e.deleteProgram(this.program),this.program=null)}static newColoredTextured(e){let t=`
1
+ "use strict";var spine=(()=>{var Ar=Object.create,dt=Object.defineProperty,Cr=Object.getOwnPropertyDescriptor,Sr=Object.getOwnPropertyNames,Tr=Object.getPrototypeOf,Ir=Object.prototype.hasOwnProperty,Mr=(t=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(t,{get:(e,i)=>(typeof require<"u"?require:e)[i]}):t)(function(t){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+t+'" is not supported')}),Er=(t,e)=>{for(var i in e)dt(t,i,{get:e[i],enumerable:!0})},ts=(t,e,i,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of Sr(e))!Ir.call(t,s)&&s!==i&&dt(t,s,{get:()=>e[s],enumerable:!(r=Cr(e,s))||r.enumerable});return t},Rr=(t,e,i)=>(i=t!=null?Ar(Tr(t)):{},ts(e||!t||!t.__esModule?dt(i,"default",{value:t,enumerable:!0}):i,t)),kr=t=>ts(dt({},"__esModule",{value:!0}),t),is={};if(Er(is,{AABBRectangleBoundsProvider:()=>Pn,Alpha:()=>Ks,AlphaMixin:()=>nr,AlphaTimeline:()=>Kt,Animation:()=>ut,AnimationState:()=>gi,AnimationStateAdapter:()=>Dr,AnimationStateData:()=>gs,AssetManager:()=>Fs,AssetManagerBase:()=>vs,AtlasAttachmentLoader:()=>yi,Attachment:()=>Vt,AttachmentTimeline:()=>We,BinaryInput:()=>Es,BlendMode:()=>Xi,Bone:()=>Ci,BoneData:()=>Ai,BoundingBoxAttachment:()=>bi,CURRENT:()=>ms,CameraController:()=>Cn,ClippingAttachment:()=>rt,Color:()=>K,Color2Attribute:()=>Xs,ColorAttribute:()=>Ct,ComputedSize:()=>zs,ComputedSizeMixin:()=>Qs,ConstraintData:()=>nt,CurveTimeline:()=>Te,CurveTimeline1:()=>Ce,CurveTimeline2:()=>ft,DebugUtils:()=>Or,DeformTimeline:()=>ei,Depth:()=>qs,DepthMixin:()=>$s,Downloader:()=>Si,DrawOrderTimeline:()=>je,Event:()=>Ti,EventData:()=>Ii,EventQueue:()=>ds,EventTimeline:()=>mt,EventType:()=>us,FIRST:()=>pi,FakeTexture:()=>Nr,Flip:()=>_s,FlipMixin:()=>er,GLTexture:()=>ze,HOLD_FIRST:()=>pt,HOLD_MIX:()=>fs,HOLD_SUBSEQUENT:()=>xi,IkConstraint:()=>ys,IkConstraintData:()=>Mi,IkConstraintTimeline:()=>ti,Inherit:()=>vt,InheritTimeline:()=>jt,Input:()=>Di,IntSet:()=>Xr,Interpolation:()=>ss,LoadingScreen:()=>En,M00:()=>O,M01:()=>G,M02:()=>z,M03:()=>V,M10:()=>q,M11:()=>D,M12:()=>_,M13:()=>N,M20:()=>H,M21:()=>j,M22:()=>U,M23:()=>W,M30:()=>Q,M31:()=>$,M32:()=>ee,M33:()=>J,ManagedWebGLRenderingContext:()=>xe,MathUtils:()=>L,Matrix4:()=>lt,Mesh:()=>Ni,MeshAttachment:()=>Ge,MixBlend:()=>os,MixDirection:()=>hs,Origin:()=>Js,OriginMixin:()=>rr,OrthoCamera:()=>Ps,PathAttachment:()=>Ze,PathConstraint:()=>As,PathConstraintData:()=>Ei,PathConstraintMixTimeline:()=>ni,PathConstraintPositionTimeline:()=>si,PathConstraintSpacingTimeline:()=>ri,Physics:()=>Ts,PhysicsConstraintDampingTimeline:()=>oi,PhysicsConstraintGravityTimeline:()=>di,PhysicsConstraintInertiaTimeline:()=>ai,PhysicsConstraintMassTimeline:()=>hi,PhysicsConstraintMixTimeline:()=>ui,PhysicsConstraintResetTimeline:()=>fi,PhysicsConstraintStrengthTimeline:()=>li,PhysicsConstraintTimeline:()=>Oe,PhysicsConstraintWindTimeline:()=>ci,PointAttachment:()=>bs,PolygonBatcher:()=>Wi,Pool:()=>it,Position2Attribute:()=>At,Position3Attribute:()=>Sn,PositionMode:()=>Ri,Pow:()=>rs,PowOut:()=>Br,RGB2Timeline:()=>$t,RGBA2Timeline:()=>Qt,RGBATimeline:()=>Zt,RGBTimeline:()=>Jt,RegionAttachment:()=>ce,ResizeMode:()=>Gs,RotateMode:()=>Yi,RotateTimeline:()=>st,SETUP:()=>wi,SUBSEQUENT:()=>gt,ScaleTimeline:()=>Wt,ScaleXTimeline:()=>Gt,ScaleYTimeline:()=>zt,SceneRenderer:()=>zi,ScrollFactor:()=>Hs,ScrollFactorMixin:()=>tr,SequenceTimeline:()=>mi,SetupPoseBoundsProvider:()=>ar,Shader:()=>Me,ShapeRenderer:()=>Gi,ShapeType:()=>Ns,ShearTimeline:()=>qt,ShearXTimeline:()=>_t,ShearYTimeline:()=>Ht,Skeleton:()=>Je,SkeletonBinary:()=>Ms,SkeletonBounds:()=>Rs,SkeletonClipping:()=>yt,SkeletonData:()=>Fi,SkeletonDebugRenderer:()=>Us,SkeletonJson:()=>Ys,SkeletonRenderer:()=>Ws,Skin:()=>at,SkinEntry:()=>Pi,SkinsAndAnimationBoundsProvider:()=>Ln,Slot:()=>Cs,SlotData:()=>Li,SpacingMode:()=>ki,SpineCanvas:()=>Yn,SpineGameObject:()=>Hi,SpinePlugin:()=>ji,StringSet:()=>Bt,TexCoordAttribute:()=>Ui,Texture:()=>xt,TextureAtlas:()=>bt,TextureAtlasPage:()=>ws,TextureAtlasRegion:()=>vi,TextureFilter:()=>wt,TextureRegion:()=>xs,TextureWrap:()=>ps,TimeKeeper:()=>Ot,Timeline:()=>fe,Touch:()=>Ls,TrackEntry:()=>cs,Transform:()=>js,TransformConstraint:()=>Ss,TransformConstraintData:()=>Bi,TransformConstraintTimeline:()=>ii,TransformMixin:()=>ir,TranslateTimeline:()=>Dt,TranslateXTimeline:()=>Nt,TranslateYTimeline:()=>Ut,Triangulator:()=>ks,Utils:()=>X,Vector2:()=>Ue,Vector3:()=>Se,VertexAttachment:()=>Fe,VertexAttribute:()=>Ke,VertexAttributeType:()=>Bs,Visible:()=>Zs,VisibleMixin:()=>sr,WindowedMean:()=>Vr,createMixin:()=>Be}),typeof window<"u"&&window.Phaser){let t=window.require;window.require=e=>{if(t)return t(e);if(e==="Phaser")return window.Phaser}}var ye=Rr(Mr("Phaser"),1),Yr="esotericsoftware.spine.skeletonFile.cache",Fr="esotericsoftware.spine.atlas.cache",Pr="spineSkeletonData",Lr="spineAtlasData",Xt="spine",Xr=class{array=new Array;add(t){let e=this.contains(t);return this.array[t|0]=t|0,!e}contains(t){return this.array[t|0]!=null}remove(t){this.array[t|0]=void 0}clear(){this.array.length=0}},Bt=class{entries={};size=0;add(t){let e=this.entries[t];return this.entries[t]=!0,e?!1:(this.size++,!0)}addAll(t){let e=this.size;for(var i=0,r=t.length;i<r;i++)this.add(t[i]);return e!=this.size}contains(t){return this.entries[t]}clear(){this.entries={},this.size=0}},K=class _e{constructor(e=0,i=0,r=0,s=0){this.r=e,this.g=i,this.b=r,this.a=s}static WHITE=new _e(1,1,1,1);static RED=new _e(1,0,0,1);static GREEN=new _e(0,1,0,1);static BLUE=new _e(0,0,1,1);static MAGENTA=new _e(1,0,1,1);set(e,i,r,s){return this.r=e,this.g=i,this.b=r,this.a=s,this.clamp()}setFromColor(e){return this.r=e.r,this.g=e.g,this.b=e.b,this.a=e.a,this}setFromString(e){return e=e.charAt(0)=="#"?e.substr(1):e,this.r=parseInt(e.substr(0,2),16)/255,this.g=parseInt(e.substr(2,2),16)/255,this.b=parseInt(e.substr(4,2),16)/255,this.a=e.length!=8?1:parseInt(e.substr(6,2),16)/255,this}add(e,i,r,s){return this.r+=e,this.g+=i,this.b+=r,this.a+=s,this.clamp()}clamp(){return this.r<0?this.r=0:this.r>1&&(this.r=1),this.g<0?this.g=0:this.g>1&&(this.g=1),this.b<0?this.b=0:this.b>1&&(this.b=1),this.a<0?this.a=0:this.a>1&&(this.a=1),this}static rgba8888ToColor(e,i){e.r=((i&4278190080)>>>24)/255,e.g=((i&16711680)>>>16)/255,e.b=((i&65280)>>>8)/255,e.a=(i&255)/255}static rgb888ToColor(e,i){e.r=((i&16711680)>>>16)/255,e.g=((i&65280)>>>8)/255,e.b=(i&255)/255}toRgb888(){const e=i=>("0"+(i*255).toString(16)).slice(-2);return+("0x"+e(this.r)+e(this.g)+e(this.b))}static fromString(e,i=new _e){return i.setFromString(e)}},L=class ke{static PI=3.1415927;static PI2=ke.PI*2;static invPI2=1/ke.PI2;static radiansToDegrees=180/ke.PI;static radDeg=ke.radiansToDegrees;static degreesToRadians=ke.PI/180;static degRad=ke.degreesToRadians;static clamp(e,i,r){return e<i?i:e>r?r:e}static cosDeg(e){return Math.cos(e*ke.degRad)}static sinDeg(e){return Math.sin(e*ke.degRad)}static atan2Deg(e,i){return Math.atan2(e,i)*ke.degRad}static signum(e){return e>0?1:e<0?-1:0}static toInt(e){return e>0?Math.floor(e):Math.ceil(e)}static cbrt(e){let i=Math.pow(Math.abs(e),.3333333333333333);return e<0?-i:i}static randomTriangular(e,i){return ke.randomTriangularWith(e,i,(e+i)*.5)}static randomTriangularWith(e,i,r){let s=Math.random(),h=i-e;return s<=(r-e)/h?e+Math.sqrt(s*h*(r-e)):i-Math.sqrt((1-s)*h*(i-r))}static isPowerOfTwo(e){return e&&(e&e-1)===0}},ss=class{apply(t,e,i){return t+(e-t)*this.applyInternal(i)}},rs=class extends ss{power=2;constructor(t){super(),this.power=t}applyInternal(t){return t<=.5?Math.pow(t*2,this.power)/2:Math.pow((t-1)*2,this.power)/(this.power%2==0?-2:2)+1}},Br=class extends rs{constructor(t){super(t)}applyInternal(t){return Math.pow(t-1,this.power)*(this.power%2==0?-1:1)+1}},X=class tt{static SUPPORTS_TYPED_ARRAYS=typeof Float32Array<"u";static arrayCopy(e,i,r,s,h){for(let l=i,n=s;l<i+h;l++,n++)r[n]=e[l]}static arrayFill(e,i,r,s){for(let h=i;h<r;h++)e[h]=s}static setArraySize(e,i,r=0){let s=e.length;if(s==i)return e;if(e.length=i,s<i)for(let h=s;h<i;h++)e[h]=r;return e}static ensureArrayCapacity(e,i,r=0){return e.length>=i?e:tt.setArraySize(e,i,r)}static newArray(e,i){let r=new Array(e);for(let s=0;s<e;s++)r[s]=i;return r}static newFloatArray(e){if(tt.SUPPORTS_TYPED_ARRAYS)return new Float32Array(e);{let i=new Array(e);for(let r=0;r<i.length;r++)i[r]=0;return i}}static newShortArray(e){if(tt.SUPPORTS_TYPED_ARRAYS)return new Int16Array(e);{let i=new Array(e);for(let r=0;r<i.length;r++)i[r]=0;return i}}static toFloatArray(e){return tt.SUPPORTS_TYPED_ARRAYS?new Float32Array(e):e}static toSinglePrecision(e){return tt.SUPPORTS_TYPED_ARRAYS?Math.fround(e):e}static webkit602BugfixHelper(e,i){}static contains(e,i,r=!0){for(var s=0;s<e.length;s++)if(e[s]==i)return!0;return!1}static enumValue(e,i){return e[i[0].toUpperCase()+i.slice(1)]}},Or=class{static logBones(t){for(let e=0;e<t.bones.length;e++){let i=t.bones[e];console.log(i.data.name+", "+i.a+", "+i.b+", "+i.c+", "+i.d+", "+i.worldX+", "+i.worldY)}}},it=class{items=new Array;instantiator;constructor(t){this.instantiator=t}obtain(){return this.items.length>0?this.items.pop():this.instantiator()}free(t){t.reset&&t.reset(),this.items.push(t)}freeAll(t){for(let e=0;e<t.length;e++)this.free(t[e])}clear(){this.items.length=0}},Ue=class{constructor(t=0,e=0){this.x=t,this.y=e}set(t,e){return this.x=t,this.y=e,this}length(){let t=this.x,e=this.y;return Math.sqrt(t*t+e*e)}normalize(){let t=this.length();return t!=0&&(this.x/=t,this.y/=t),this}},Ot=class{maxDelta=.064;framesPerSecond=0;delta=0;totalTime=0;lastTime=Date.now()/1e3;frameCount=0;frameTime=0;update(){let t=Date.now()/1e3;this.delta=t-this.lastTime,this.frameTime+=this.delta,this.totalTime+=this.delta,this.delta>this.maxDelta&&(this.delta=this.maxDelta),this.lastTime=t,this.frameCount++,this.frameTime>1&&(this.framesPerSecond=this.frameCount/this.frameTime,this.frameTime=0,this.frameCount=0)}},Vr=class{values;addedValues=0;lastValue=0;mean=0;dirty=!0;constructor(t=32){this.values=new Array(t)}hasEnoughData(){return this.addedValues>=this.values.length}addValue(t){this.addedValues<this.values.length&&this.addedValues++,this.values[this.lastValue++]=t,this.lastValue>this.values.length-1&&(this.lastValue=0),this.dirty=!0}getMean(){if(this.hasEnoughData()){if(this.dirty){let t=0;for(let e=0;e<this.values.length;e++)t+=this.values[e];this.mean=t/this.values.length,this.dirty=!1}return this.mean}return 0}},Vt=class{name;constructor(t){if(!t)throw new Error("name cannot be null.");this.name=t}},Fe=class ur extends Vt{static nextID=0;id=ur.nextID++;bones=null;vertices=[];worldVerticesLength=0;timelineAttachment=this;constructor(e){super(e)}computeWorldVertices(e,i,r,s,h,l){r=h+(r>>1)*l;let n=e.bone.skeleton,a=e.deform,o=this.vertices,c=this.bones;if(!c){a.length>0&&(o=a);let f=e.bone,g=f.worldX,x=f.worldY,b=f.a,p=f.b,w=f.c,v=f.d;for(let y=i,A=h;A<r;y+=2,A+=l){let C=o[y],S=o[y+1];s[A]=C*b+S*p+g,s[A+1]=C*w+S*v+x}return}let d=0,u=0;for(let f=0;f<i;f+=2){let g=c[d];d+=g+1,u+=g}let m=n.bones;if(a.length==0)for(let f=h,g=u*3;f<r;f+=l){let x=0,b=0,p=c[d++];for(p+=d;d<p;d++,g+=3){let w=m[c[d]],v=o[g],y=o[g+1],A=o[g+2];x+=(v*w.a+y*w.b+w.worldX)*A,b+=(v*w.c+y*w.d+w.worldY)*A}s[f]=x,s[f+1]=b}else{let f=a;for(let g=h,x=u*3,b=u<<1;g<r;g+=l){let p=0,w=0,v=c[d++];for(v+=d;d<v;d++,x+=3,b+=2){let y=m[c[d]],A=o[x]+f[b],C=o[x+1]+f[b+1],S=o[x+2];p+=(A*y.a+C*y.b+y.worldX)*S,w+=(A*y.c+C*y.d+y.worldY)*S}s[g]=p,s[g+1]=w}}}copyTo(e){this.bones?(e.bones=new Array(this.bones.length),X.arrayCopy(this.bones,0,e.bones,0,this.bones.length)):e.bones=null,this.vertices&&(e.vertices=X.newFloatArray(this.vertices.length),X.arrayCopy(this.vertices,0,e.vertices,0,this.vertices.length)),e.worldVerticesLength=this.worldVerticesLength,e.timelineAttachment=this.timelineAttachment}},ns=class Yt{static _nextID=0;id=Yt.nextID();regions;start=0;digits=0;setupIndex=0;constructor(e){this.regions=new Array(e)}copy(){let e=new Yt(this.regions.length);return X.arrayCopy(this.regions,0,e.regions,0,this.regions.length),e.start=this.start,e.digits=this.digits,e.setupIndex=this.setupIndex,e}apply(e,i){let r=e.sequenceIndex;r==-1&&(r=this.setupIndex),r>=this.regions.length&&(r=this.regions.length-1);let s=this.regions[r];i.region!=s&&(i.region=s,i.updateRegion())}getPath(e,i){let r=e,s=(this.start+i).toString();for(let h=this.digits-s.length;h>0;h--)r+="0";return r+=s,r}static nextID(){return Yt._nextID++}},as=(t=>(t[t.hold=0]="hold",t[t.once=1]="once",t[t.loop=2]="loop",t[t.pingpong=3]="pingpong",t[t.onceReverse=4]="onceReverse",t[t.loopReverse=5]="loopReverse",t[t.pingpongReverse=6]="pingpongReverse",t))(as||{}),ls=[0,1,2,3,4,5,6],ut=class{name;timelines=[];timelineIds=new Bt;duration;constructor(t,e,i){if(!t)throw new Error("name cannot be null.");this.name=t,this.setTimelines(e),this.duration=i}setTimelines(t){if(!t)throw new Error("timelines cannot be null.");this.timelines=t,this.timelineIds.clear();for(var e=0;e<t.length;e++)this.timelineIds.addAll(t[e].getPropertyIds())}hasTimeline(t){for(let e=0;e<t.length;e++)if(this.timelineIds.contains(t[e]))return!0;return!1}apply(t,e,i,r,s,h,l,n){if(!t)throw new Error("skeleton cannot be null.");r&&this.duration!=0&&(i%=this.duration,e>0&&(e%=this.duration));let a=this.timelines;for(let o=0,c=a.length;o<c;o++)a[o].apply(t,e,i,s,h,l,n)}},os=(t=>(t[t.setup=0]="setup",t[t.first=1]="first",t[t.replace=2]="replace",t[t.add=3]="add",t))(os||{}),hs=(t=>(t[t.mixIn=0]="mixIn",t[t.mixOut=1]="mixOut",t))(hs||{}),se={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},fe=class{propertyIds;frames;constructor(t,e){this.propertyIds=e,this.frames=X.newFloatArray(t*this.getFrameEntries())}getPropertyIds(){return this.propertyIds}getFrameEntries(){return 1}getFrameCount(){return this.frames.length/this.getFrameEntries()}getDuration(){return this.frames[this.frames.length-this.getFrameEntries()]}static search1(t,e){let i=t.length;for(let r=1;r<i;r++)if(t[r]>e)return r-1;return i-1}static search(t,e,i){let r=t.length;for(let s=i;s<r;s+=i)if(t[s]>e)return s-i;return r-i}},Te=class extends fe{curves;constructor(t,e,i){super(t,i),this.curves=X.newFloatArray(t+e*18),this.curves[t-1]=1}setLinear(t){this.curves[t]=0}setStepped(t){this.curves[t]=1}shrink(t){let e=this.getFrameCount()+t*18;if(this.curves.length>e){let i=X.newFloatArray(e);X.arrayCopy(this.curves,0,i,0,e),this.curves=i}}setBezier(t,e,i,r,s,h,l,n,a,o,c){let d=this.curves,u=this.getFrameCount()+t*18;i==0&&(d[e]=2+u);let m=(r-h*2+n)*.03,f=(s-l*2+a)*.03,g=((h-n)*3-r+o)*.006,x=((l-a)*3-s+c)*.006,b=m*2+g,p=f*2+x,w=(h-r)*.3+m+g*.16666667,v=(l-s)*.3+f+x*.16666667,y=r+w,A=s+v;for(let C=u+18;u<C;u+=2)d[u]=y,d[u+1]=A,w+=b,v+=p,b+=g,p+=x,y+=w,A+=v}getBezierValue(t,e,i,r){let s=this.curves;if(s[r]>t){let a=this.frames[e],o=this.frames[e+i];return o+(t-a)/(s[r]-a)*(s[r+1]-o)}let h=r+18;for(r+=2;r<h;r+=2)if(s[r]>=t){let a=s[r-2],o=s[r-1];return o+(t-a)/(s[r]-a)*(s[r+1]-o)}e+=this.getFrameEntries();let l=s[h-2],n=s[h-1];return n+(t-l)/(this.frames[e]-l)*(this.frames[e+i]-n)}},Ce=class extends Te{constructor(t,e,i){super(t,e,[i])}getFrameEntries(){return 2}setFrame(t,e,i){t<<=1,this.frames[t]=e,this.frames[t+1]=i}getCurveValue(t){let e=this.frames,i=e.length-2;for(let s=2;s<=i;s+=2)if(e[s]>t){i=s-2;break}let r=this.curves[i>>1];switch(r){case 0:let s=e[i],h=e[i+1];return h+(t-s)/(e[i+2]-s)*(e[i+2+1]-h);case 1:return e[i+1]}return this.getBezierValue(t,i,1,r-2)}getRelativeValue(t,e,i,r,s){if(t<this.frames[0]){switch(i){case 0:return s;case 1:return r+(s-r)*e}return r}let h=this.getCurveValue(t);switch(i){case 0:return s+h*e;case 1:case 2:h+=s-r}return r+h*e}getAbsoluteValue(t,e,i,r,s){if(t<this.frames[0]){switch(i){case 0:return s;case 1:return r+(s-r)*e}return r}let h=this.getCurveValue(t);return i==0?s+(h-s)*e:r+(h-r)*e}getAbsoluteValue2(t,e,i,r,s,h){if(t<this.frames[0]){switch(i){case 0:return s;case 1:return r+(s-r)*e}return r}return i==0?s+(h-s)*e:r+(h-r)*e}getScaleValue(t,e,i,r,s,h){const l=this.frames;if(t<l[0]){switch(i){case 0:return h;case 1:return s+(h-s)*e}return s}let n=this.getCurveValue(t)*h;if(e==1)return i==3?s+n-h:n;if(r==1)switch(i){case 0:return h+(Math.abs(n)*L.signum(h)-h)*e;case 1:case 2:return s+(Math.abs(n)*L.signum(s)-s)*e}else{let a=0;switch(i){case 0:return a=Math.abs(h)*L.signum(n),a+(n-a)*e;case 1:case 2:return a=Math.abs(s)*L.signum(n),a+(n-a)*e}}return s+(n-h)*e}},ft=class extends Te{constructor(t,e,i,r){super(t,e,[i,r])}getFrameEntries(){return 3}setFrame(t,e,i,r){t*=3,this.frames[t]=e,this.frames[t+1]=i,this.frames[t+2]=r}},st=class extends Ce{boneIndex=0;constructor(t,e,i){super(t,e,se.rotate+"|"+i),this.boneIndex=i}apply(t,e,i,r,s,h,l){let n=t.bones[this.boneIndex];n.active&&(n.rotation=this.getRelativeValue(i,s,h,n.rotation,n.data.rotation))}},Dt=class extends ft{boneIndex=0;constructor(t,e,i){super(t,e,se.x+"|"+i,se.y+"|"+i),this.boneIndex=i}apply(t,e,i,r,s,h,l){let n=t.bones[this.boneIndex];if(!n.active)return;let a=this.frames;if(i<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)*s,n.y+=(n.data.y-n.y)*s}return}let o=0,c=0,d=fe.search(a,i,3),u=this.curves[d/3];switch(u){case 0:let m=a[d];o=a[d+1],c=a[d+2];let f=(i-m)/(a[d+3]-m);o+=(a[d+3+1]-o)*f,c+=(a[d+3+2]-c)*f;break;case 1:o=a[d+1],c=a[d+2];break;default:o=this.getBezierValue(i,d,1,u-2),c=this.getBezierValue(i,d,2,u+18-2)}switch(h){case 0:n.x=n.data.x+o*s,n.y=n.data.y+c*s;break;case 1:case 2:n.x+=(n.data.x+o-n.x)*s,n.y+=(n.data.y+c-n.y)*s;break;case 3:n.x+=o*s,n.y+=c*s}}},Nt=class extends Ce{boneIndex=0;constructor(t,e,i){super(t,e,se.x+"|"+i),this.boneIndex=i}apply(t,e,i,r,s,h,l){let n=t.bones[this.boneIndex];n.active&&(n.x=this.getRelativeValue(i,s,h,n.x,n.data.x))}},Ut=class extends Ce{boneIndex=0;constructor(t,e,i){super(t,e,se.y+"|"+i),this.boneIndex=i}apply(t,e,i,r,s,h,l){let n=t.bones[this.boneIndex];n.active&&(n.y=this.getRelativeValue(i,s,h,n.y,n.data.y))}},Wt=class extends ft{boneIndex=0;constructor(t,e,i){super(t,e,se.scaleX+"|"+i,se.scaleY+"|"+i),this.boneIndex=i}apply(t,e,i,r,s,h,l){let n=t.bones[this.boneIndex];if(!n.active)return;let a=this.frames;if(i<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)*s,n.scaleY+=(n.data.scaleY-n.scaleY)*s}return}let o,c,d=fe.search(a,i,3),u=this.curves[d/3];switch(u){case 0:let m=a[d];o=a[d+1],c=a[d+2];let f=(i-m)/(a[d+3]-m);o+=(a[d+3+1]-o)*f,c+=(a[d+3+2]-c)*f;break;case 1:o=a[d+1],c=a[d+2];break;default:o=this.getBezierValue(i,d,1,u-2),c=this.getBezierValue(i,d,2,u+18-2)}if(o*=n.data.scaleX,c*=n.data.scaleY,s==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,f=0;if(l==1)switch(h){case 0:m=n.data.scaleX,f=n.data.scaleY,n.scaleX=m+(Math.abs(o)*L.signum(m)-m)*s,n.scaleY=f+(Math.abs(c)*L.signum(f)-f)*s;break;case 1:case 2:m=n.scaleX,f=n.scaleY,n.scaleX=m+(Math.abs(o)*L.signum(m)-m)*s,n.scaleY=f+(Math.abs(c)*L.signum(f)-f)*s;break;case 3:n.scaleX+=(o-n.data.scaleX)*s,n.scaleY+=(c-n.data.scaleY)*s}else switch(h){case 0:m=Math.abs(n.data.scaleX)*L.signum(o),f=Math.abs(n.data.scaleY)*L.signum(c),n.scaleX=m+(o-m)*s,n.scaleY=f+(c-f)*s;break;case 1:case 2:m=Math.abs(n.scaleX)*L.signum(o),f=Math.abs(n.scaleY)*L.signum(c),n.scaleX=m+(o-m)*s,n.scaleY=f+(c-f)*s;break;case 3:n.scaleX+=(o-n.data.scaleX)*s,n.scaleY+=(c-n.data.scaleY)*s}}}},Gt=class extends Ce{boneIndex=0;constructor(t,e,i){super(t,e,se.scaleX+"|"+i),this.boneIndex=i}apply(t,e,i,r,s,h,l){let n=t.bones[this.boneIndex];n.active&&(n.scaleX=this.getScaleValue(i,s,h,l,n.scaleX,n.data.scaleX))}},zt=class extends Ce{boneIndex=0;constructor(t,e,i){super(t,e,se.scaleY+"|"+i),this.boneIndex=i}apply(t,e,i,r,s,h,l){let n=t.bones[this.boneIndex];n.active&&(n.scaleY=this.getScaleValue(i,s,h,l,n.scaleY,n.data.scaleY))}},qt=class extends ft{boneIndex=0;constructor(t,e,i){super(t,e,se.shearX+"|"+i,se.shearY+"|"+i),this.boneIndex=i}apply(t,e,i,r,s,h,l){let n=t.bones[this.boneIndex];if(!n.active)return;let a=this.frames;if(i<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)*s,n.shearY+=(n.data.shearY-n.shearY)*s}return}let o=0,c=0,d=fe.search(a,i,3),u=this.curves[d/3];switch(u){case 0:let m=a[d];o=a[d+1],c=a[d+2];let f=(i-m)/(a[d+3]-m);o+=(a[d+3+1]-o)*f,c+=(a[d+3+2]-c)*f;break;case 1:o=a[d+1],c=a[d+2];break;default:o=this.getBezierValue(i,d,1,u-2),c=this.getBezierValue(i,d,2,u+18-2)}switch(h){case 0:n.shearX=n.data.shearX+o*s,n.shearY=n.data.shearY+c*s;break;case 1:case 2:n.shearX+=(n.data.shearX+o-n.shearX)*s,n.shearY+=(n.data.shearY+c-n.shearY)*s;break;case 3:n.shearX+=o*s,n.shearY+=c*s}}},_t=class extends Ce{boneIndex=0;constructor(t,e,i){super(t,e,se.shearX+"|"+i),this.boneIndex=i}apply(t,e,i,r,s,h,l){let n=t.bones[this.boneIndex];n.active&&(n.shearX=this.getRelativeValue(i,s,h,n.shearX,n.data.shearX))}},Ht=class extends Ce{boneIndex=0;constructor(t,e,i){super(t,e,se.shearY+"|"+i),this.boneIndex=i}apply(t,e,i,r,s,h,l){let n=t.bones[this.boneIndex];n.active&&(n.shearY=this.getRelativeValue(i,s,h,n.shearY,n.data.shearY))}},jt=class extends fe{boneIndex=0;constructor(t,e){super(t,[se.inherit+"|"+e]),this.boneIndex=e}getFrameEntries(){return 2}setFrame(t,e,i){t*=2,this.frames[t]=e,this.frames[t+1]=i}apply(t,e,i,r,s,h,l){let n=t.bones[this.boneIndex];if(!n.active)return;if(l==1){h==0&&(n.inherit=n.data.inherit);return}let a=this.frames;if(i<a[0]){(h==0||h==1)&&(n.inherit=n.data.inherit);return}n.inherit=this.frames[fe.search(a,i,2)+1]}},Zt=class extends Te{slotIndex=0;constructor(t,e,i){super(t,e,[se.rgb+"|"+i,se.alpha+"|"+i]),this.slotIndex=i}getFrameEntries(){return 5}setFrame(t,e,i,r,s,h){t*=5,this.frames[t]=e,this.frames[t+1]=i,this.frames[t+2]=r,this.frames[t+3]=s,this.frames[t+4]=h}apply(t,e,i,r,s,h,l){let n=t.slots[this.slotIndex];if(!n.bone.active)return;let a=this.frames,o=n.color;if(i<a[0]){let x=n.data.color;switch(h){case 0:o.setFromColor(x);return;case 1:o.add((x.r-o.r)*s,(x.g-o.g)*s,(x.b-o.b)*s,(x.a-o.a)*s)}return}let c=0,d=0,u=0,m=0,f=fe.search(a,i,5),g=this.curves[f/5];switch(g){case 0:let x=a[f];c=a[f+1],d=a[f+2],u=a[f+3],m=a[f+4];let b=(i-x)/(a[f+5]-x);c+=(a[f+5+1]-c)*b,d+=(a[f+5+2]-d)*b,u+=(a[f+5+3]-u)*b,m+=(a[f+5+4]-m)*b;break;case 1:c=a[f+1],d=a[f+2],u=a[f+3],m=a[f+4];break;default:c=this.getBezierValue(i,f,1,g-2),d=this.getBezierValue(i,f,2,g+18-2),u=this.getBezierValue(i,f,3,g+18*2-2),m=this.getBezierValue(i,f,4,g+18*3-2)}s==1?o.set(c,d,u,m):(h==0&&o.setFromColor(n.data.color),o.add((c-o.r)*s,(d-o.g)*s,(u-o.b)*s,(m-o.a)*s))}},Jt=class extends Te{slotIndex=0;constructor(t,e,i){super(t,e,[se.rgb+"|"+i]),this.slotIndex=i}getFrameEntries(){return 4}setFrame(t,e,i,r,s){t<<=2,this.frames[t]=e,this.frames[t+1]=i,this.frames[t+2]=r,this.frames[t+3]=s}apply(t,e,i,r,s,h,l){let n=t.slots[this.slotIndex];if(!n.bone.active)return;let a=this.frames,o=n.color;if(i<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)*s,o.g+=(g.g-o.g)*s,o.b+=(g.b-o.b)*s}return}let c=0,d=0,u=0,m=fe.search(a,i,4),f=this.curves[m>>2];switch(f){case 0:let g=a[m];c=a[m+1],d=a[m+2],u=a[m+3];let x=(i-g)/(a[m+4]-g);c+=(a[m+4+1]-c)*x,d+=(a[m+4+2]-d)*x,u+=(a[m+4+3]-u)*x;break;case 1:c=a[m+1],d=a[m+2],u=a[m+3];break;default:c=this.getBezierValue(i,m,1,f-2),d=this.getBezierValue(i,m,2,f+18-2),u=this.getBezierValue(i,m,3,f+18*2-2)}if(s==1)o.r=c,o.g=d,o.b=u;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)*s,o.g+=(d-o.g)*s,o.b+=(u-o.b)*s}}},Kt=class extends Ce{slotIndex=0;constructor(t,e,i){super(t,e,se.alpha+"|"+i),this.slotIndex=i}apply(t,e,i,r,s,h,l){let n=t.slots[this.slotIndex];if(!n.bone.active)return;let a=n.color;if(i<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)*s}return}let o=this.getCurveValue(i);s==1?a.a=o:(h==0&&(a.a=n.data.color.a),a.a+=(o-a.a)*s)}},Qt=class extends Te{slotIndex=0;constructor(t,e,i){super(t,e,[se.rgb+"|"+i,se.alpha+"|"+i,se.rgb2+"|"+i]),this.slotIndex=i}getFrameEntries(){return 8}setFrame(t,e,i,r,s,h,l,n,a){t<<=3,this.frames[t]=e,this.frames[t+1]=i,this.frames[t+2]=r,this.frames[t+3]=s,this.frames[t+4]=h,this.frames[t+5]=l,this.frames[t+6]=n,this.frames[t+7]=a}apply(t,e,i,r,s,h,l){let n=t.slots[this.slotIndex];if(!n.bone.active)return;let a=this.frames,o=n.color,c=n.darkColor;if(i<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)*s,(v.g-o.g)*s,(v.b-o.b)*s,(v.a-o.a)*s),c.r+=(y.r-c.r)*s,c.g+=(y.g-c.g)*s,c.b+=(y.b-c.b)*s}return}let d=0,u=0,m=0,f=0,g=0,x=0,b=0,p=fe.search(a,i,8),w=this.curves[p>>3];switch(w){case 0:let v=a[p];d=a[p+1],u=a[p+2],m=a[p+3],f=a[p+4],g=a[p+5],x=a[p+6],b=a[p+7];let y=(i-v)/(a[p+8]-v);d+=(a[p+8+1]-d)*y,u+=(a[p+8+2]-u)*y,m+=(a[p+8+3]-m)*y,f+=(a[p+8+4]-f)*y,g+=(a[p+8+5]-g)*y,x+=(a[p+8+6]-x)*y,b+=(a[p+8+7]-b)*y;break;case 1:d=a[p+1],u=a[p+2],m=a[p+3],f=a[p+4],g=a[p+5],x=a[p+6],b=a[p+7];break;default:d=this.getBezierValue(i,p,1,w-2),u=this.getBezierValue(i,p,2,w+18-2),m=this.getBezierValue(i,p,3,w+18*2-2),f=this.getBezierValue(i,p,4,w+18*3-2),g=this.getBezierValue(i,p,5,w+18*4-2),x=this.getBezierValue(i,p,6,w+18*5-2),b=this.getBezierValue(i,p,7,w+18*6-2)}if(s==1)o.set(d,u,m,f),c.r=g,c.g=x,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)*s,(u-o.g)*s,(m-o.b)*s,(f-o.a)*s),c.r+=(g-c.r)*s,c.g+=(x-c.g)*s,c.b+=(b-c.b)*s}}},$t=class extends Te{slotIndex=0;constructor(t,e,i){super(t,e,[se.rgb+"|"+i,se.rgb2+"|"+i]),this.slotIndex=i}getFrameEntries(){return 7}setFrame(t,e,i,r,s,h,l,n){t*=7,this.frames[t]=e,this.frames[t+1]=i,this.frames[t+2]=r,this.frames[t+3]=s,this.frames[t+4]=h,this.frames[t+5]=l,this.frames[t+6]=n}apply(t,e,i,r,s,h,l){let n=t.slots[this.slotIndex];if(!n.bone.active)return;let a=this.frames,o=n.color,c=n.darkColor;if(i<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)*s,o.g+=(v.g-o.g)*s,o.b+=(v.b-o.b)*s,c.r+=(y.r-c.r)*s,c.g+=(y.g-c.g)*s,c.b+=(y.b-c.b)*s}return}let d=0,u=0,m=0,f=0,g=0,x=0,b=0,p=fe.search(a,i,7),w=this.curves[p/7];switch(w){case 0:let v=a[p];d=a[p+1],u=a[p+2],m=a[p+3],g=a[p+4],x=a[p+5],b=a[p+6];let y=(i-v)/(a[p+7]-v);d+=(a[p+7+1]-d)*y,u+=(a[p+7+2]-u)*y,m+=(a[p+7+3]-m)*y,g+=(a[p+7+4]-g)*y,x+=(a[p+7+5]-x)*y,b+=(a[p+7+6]-b)*y;break;case 1:d=a[p+1],u=a[p+2],m=a[p+3],g=a[p+4],x=a[p+5],b=a[p+6];break;default:d=this.getBezierValue(i,p,1,w-2),u=this.getBezierValue(i,p,2,w+18-2),m=this.getBezierValue(i,p,3,w+18*2-2),g=this.getBezierValue(i,p,4,w+18*3-2),x=this.getBezierValue(i,p,5,w+18*4-2),b=this.getBezierValue(i,p,6,w+18*5-2)}if(s==1)o.r=d,o.g=u,o.b=m,c.r=g,c.g=x,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)*s,o.g+=(u-o.g)*s,o.b+=(m-o.b)*s,c.r+=(g-c.r)*s,c.g+=(x-c.g)*s,c.b+=(b-c.b)*s}}},We=class extends fe{slotIndex=0;attachmentNames;constructor(t,e){super(t,[se.attachment+"|"+e]),this.slotIndex=e,this.attachmentNames=new Array(t)}getFrameCount(){return this.frames.length}setFrame(t,e,i){this.frames[t]=e,this.attachmentNames[t]=i}apply(t,e,i,r,s,h,l){let n=t.slots[this.slotIndex];if(n.bone.active){if(l==1){h==0&&this.setAttachment(t,n,n.data.attachmentName);return}if(i<this.frames[0]){(h==0||h==1)&&this.setAttachment(t,n,n.data.attachmentName);return}this.setAttachment(t,n,this.attachmentNames[fe.search1(this.frames,i)])}}setAttachment(t,e,i){e.setAttachment(i?t.getAttachment(this.slotIndex,i):null)}},ei=class extends Te{slotIndex=0;attachment;vertices;constructor(t,e,i,r){super(t,e,[se.deform+"|"+i+"|"+r.id]),this.slotIndex=i,this.attachment=r,this.vertices=new Array(t)}getFrameCount(){return this.frames.length}setFrame(t,e,i){this.frames[t]=e,this.vertices[t]=i}setBezier(t,e,i,r,s,h,l,n,a,o,c){let d=this.curves,u=this.getFrameCount()+t*18;i==0&&(d[e]=2+u);let m=(r-h*2+n)*.03,f=a*.03-l*.06,g=((h-n)*3-r+o)*.006,x=(l-a+.33333333)*.018,b=m*2+g,p=f*2+x,w=(h-r)*.3+m+g*.16666667,v=l*.3+f+x*.16666667,y=r+w,A=v;for(let C=u+18;u<C;u+=2)d[u]=y,d[u+1]=A,w+=b,v+=p,b+=g,p+=x,y+=w,A+=v}getCurvePercent(t,e){let i=this.curves,r=i[e];switch(r){case 0:let n=this.frames[e];return(t-n)/(this.frames[e+this.getFrameEntries()]-n);case 1:return 0}if(r-=2,i[r]>t){let n=this.frames[e];return i[r+1]*(t-n)/(i[r]-n)}let s=r+18;for(r+=2;r<s;r+=2)if(i[r]>=t){let n=i[r-2],a=i[r-1];return a+(t-n)/(i[r]-n)*(i[r+1]-a)}let h=i[s-2],l=i[s-1];return l+(1-l)*(t-h)/(this.frames[e+this.getFrameEntries()]-h)}apply(t,e,i,r,s,h,l){let n=t.slots[this.slotIndex];if(!n.bone.active)return;let a=n.getAttachment();if(!a||!(a instanceof Fe)||a.timelineAttachment!=this.attachment)return;let o=n.deform;o.length==0&&(h=0);let c=this.vertices,d=c[0].length,u=this.frames;if(i<u[0]){switch(h){case 0:o.length=0;return;case 1:if(s==1){o.length=0;return}o.length=d;let p=a;if(p.bones){s=1-s;for(var m=0;m<d;m++)o[m]*=s}else{let w=p.vertices;for(var m=0;m<d;m++)o[m]+=(w[m]-o[m])*s}}return}if(o.length=d,i>=u[u.length-1]){let p=c[u.length-1];if(s==1)if(h==3){let w=a;if(w.bones)for(let v=0;v<d;v++)o[v]+=p[v];else{let v=w.vertices;for(let y=0;y<d;y++)o[y]+=p[y]-v[y]}}else X.arrayCopy(p,0,o,0,d);else switch(h){case 0:{let v=a;if(v.bones)for(let y=0;y<d;y++)o[y]=p[y]*s;else{let y=v.vertices;for(let A=0;A<d;A++){let C=y[A];o[A]=C+(p[A]-C)*s}}break}case 1:case 2:for(let v=0;v<d;v++)o[v]+=(p[v]-o[v])*s;break;case 3:let w=a;if(w.bones)for(let v=0;v<d;v++)o[v]+=p[v]*s;else{let v=w.vertices;for(let y=0;y<d;y++)o[y]+=(p[y]-v[y])*s}}return}let f=fe.search1(u,i),g=this.getCurvePercent(i,f),x=c[f],b=c[f+1];if(s==1)if(h==3){let p=a;if(p.bones)for(let w=0;w<d;w++){let v=x[w];o[w]+=v+(b[w]-v)*g}else{let w=p.vertices;for(let v=0;v<d;v++){let y=x[v];o[v]+=y+(b[v]-y)*g-w[v]}}}else for(let p=0;p<d;p++){let w=x[p];o[p]=w+(b[p]-w)*g}else switch(h){case 0:{let w=a;if(w.bones)for(let v=0;v<d;v++){let y=x[v];o[v]=(y+(b[v]-y)*g)*s}else{let v=w.vertices;for(let y=0;y<d;y++){let A=x[y],C=v[y];o[y]=C+(A+(b[y]-A)*g-C)*s}}break}case 1:case 2:for(let w=0;w<d;w++){let v=x[w];o[w]+=(v+(b[w]-v)*g-o[w])*s}break;case 3:let p=a;if(p.bones)for(let w=0;w<d;w++){let v=x[w];o[w]+=(v+(b[w]-v)*g)*s}else{let w=p.vertices;for(let v=0;v<d;v++){let y=x[v];o[v]+=(y+(b[v]-y)*g-w[v])*s}}}}},mt=class fr extends fe{static propertyIds=[""+se.event];events;constructor(e){super(e,fr.propertyIds),this.events=new Array(e)}getFrameCount(){return this.frames.length}setFrame(e,i){this.frames[e]=i.time,this.events[e]=i}apply(e,i,r,s,h,l,n){if(!s)return;let a=this.frames,o=this.frames.length;if(i>r)this.apply(e,i,Number.MAX_VALUE,s,h,l,n),i=-1;else if(i>=a[o-1])return;if(r<a[0])return;let c=0;if(i<a[0])c=0;else{c=fe.search1(a,i)+1;let d=a[c];for(;c>0&&a[c-1]==d;)c--}for(;c<o&&r>=a[c];c++)s.push(this.events[c])}},je=class mr extends fe{static propertyIds=[""+se.drawOrder];drawOrders;constructor(e){super(e,mr.propertyIds),this.drawOrders=new Array(e)}getFrameCount(){return this.frames.length}setFrame(e,i,r){this.frames[e]=i,this.drawOrders[e]=r}apply(e,i,r,s,h,l,n){if(n==1){l==0&&X.arrayCopy(e.slots,0,e.drawOrder,0,e.slots.length);return}if(r<this.frames[0]){(l==0||l==1)&&X.arrayCopy(e.slots,0,e.drawOrder,0,e.slots.length);return}let a=fe.search1(this.frames,r),o=this.drawOrders[a];if(!o)X.arrayCopy(e.slots,0,e.drawOrder,0,e.slots.length);else{let c=e.drawOrder,d=e.slots;for(let u=0,m=o.length;u<m;u++)c[u]=d[o[u]]}}},ti=class extends Te{constraintIndex=0;constructor(t,e,i){super(t,e,[se.ikConstraint+"|"+i]),this.constraintIndex=i}getFrameEntries(){return 6}setFrame(t,e,i,r,s,h,l){t*=6,this.frames[t]=e,this.frames[t+1]=i,this.frames[t+2]=r,this.frames[t+3]=s,this.frames[t+4]=h?1:0,this.frames[t+5]=l?1:0}apply(t,e,i,r,s,h,l){let n=t.ikConstraints[this.constraintIndex];if(!n.active)return;let a=this.frames;if(i<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)*s,n.softness+=(n.data.softness-n.softness)*s,n.bendDirection=n.data.bendDirection,n.compress=n.data.compress,n.stretch=n.data.stretch}return}let o=0,c=0,d=fe.search(a,i,6),u=this.curves[d/6];switch(u){case 0:let m=a[d];o=a[d+1],c=a[d+2];let f=(i-m)/(a[d+6]-m);o+=(a[d+6+1]-o)*f,c+=(a[d+6+2]-c)*f;break;case 1:o=a[d+1],c=a[d+2];break;default:o=this.getBezierValue(i,d,1,u-2),c=this.getBezierValue(i,d,2,u+18-2)}h==0?(n.mix=n.data.mix+(o-n.data.mix)*s,n.softness=n.data.softness+(c-n.data.softness)*s,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)*s,n.softness+=(c-n.softness)*s,l==0&&(n.bendDirection=a[d+3],n.compress=a[d+4]!=0,n.stretch=a[d+5]!=0))}},ii=class extends Te{constraintIndex=0;constructor(t,e,i){super(t,e,[se.transformConstraint+"|"+i]),this.constraintIndex=i}getFrameEntries(){return 7}setFrame(t,e,i,r,s,h,l,n){let a=this.frames;t*=7,a[t]=e,a[t+1]=i,a[t+2]=r,a[t+3]=s,a[t+4]=h,a[t+5]=l,a[t+6]=n}apply(t,e,i,r,s,h,l){let n=t.transformConstraints[this.constraintIndex];if(!n.active)return;let a=this.frames;if(i<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)*s,n.mixX+=(b.mixX-n.mixX)*s,n.mixY+=(b.mixY-n.mixY)*s,n.mixScaleX+=(b.mixScaleX-n.mixScaleX)*s,n.mixScaleY+=(b.mixScaleY-n.mixScaleY)*s,n.mixShearY+=(b.mixShearY-n.mixShearY)*s}return}let o,c,d,u,m,f,g=fe.search(a,i,7),x=this.curves[g/7];switch(x){case 0:let b=a[g];o=a[g+1],c=a[g+2],d=a[g+3],u=a[g+4],m=a[g+5],f=a[g+6];let p=(i-b)/(a[g+7]-b);o+=(a[g+7+1]-o)*p,c+=(a[g+7+2]-c)*p,d+=(a[g+7+3]-d)*p,u+=(a[g+7+4]-u)*p,m+=(a[g+7+5]-m)*p,f+=(a[g+7+6]-f)*p;break;case 1:o=a[g+1],c=a[g+2],d=a[g+3],u=a[g+4],m=a[g+5],f=a[g+6];break;default:o=this.getBezierValue(i,g,1,x-2),c=this.getBezierValue(i,g,2,x+18-2),d=this.getBezierValue(i,g,3,x+18*2-2),u=this.getBezierValue(i,g,4,x+18*3-2),m=this.getBezierValue(i,g,5,x+18*4-2),f=this.getBezierValue(i,g,6,x+18*5-2)}if(h==0){let b=n.data;n.mixRotate=b.mixRotate+(o-b.mixRotate)*s,n.mixX=b.mixX+(c-b.mixX)*s,n.mixY=b.mixY+(d-b.mixY)*s,n.mixScaleX=b.mixScaleX+(u-b.mixScaleX)*s,n.mixScaleY=b.mixScaleY+(m-b.mixScaleY)*s,n.mixShearY=b.mixShearY+(f-b.mixShearY)*s}else n.mixRotate+=(o-n.mixRotate)*s,n.mixX+=(c-n.mixX)*s,n.mixY+=(d-n.mixY)*s,n.mixScaleX+=(u-n.mixScaleX)*s,n.mixScaleY+=(m-n.mixScaleY)*s,n.mixShearY+=(f-n.mixShearY)*s}},si=class extends Ce{constraintIndex=0;constructor(t,e,i){super(t,e,se.pathConstraintPosition+"|"+i),this.constraintIndex=i}apply(t,e,i,r,s,h,l){let n=t.pathConstraints[this.constraintIndex];n.active&&(n.position=this.getAbsoluteValue(i,s,h,n.position,n.data.position))}},ri=class extends Ce{constraintIndex=0;constructor(t,e,i){super(t,e,se.pathConstraintSpacing+"|"+i),this.constraintIndex=i}apply(t,e,i,r,s,h,l){let n=t.pathConstraints[this.constraintIndex];n.active&&(n.spacing=this.getAbsoluteValue(i,s,h,n.spacing,n.data.spacing))}},ni=class extends Te{constraintIndex=0;constructor(t,e,i){super(t,e,[se.pathConstraintMix+"|"+i]),this.constraintIndex=i}getFrameEntries(){return 4}setFrame(t,e,i,r,s){let h=this.frames;t<<=2,h[t]=e,h[t+1]=i,h[t+2]=r,h[t+3]=s}apply(t,e,i,r,s,h,l){let n=t.pathConstraints[this.constraintIndex];if(!n.active)return;let a=this.frames;if(i<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)*s,n.mixX+=(n.data.mixX-n.mixX)*s,n.mixY+=(n.data.mixY-n.mixY)*s}return}let o,c,d,u=fe.search(a,i,4),m=this.curves[u>>2];switch(m){case 0:let f=a[u];o=a[u+1],c=a[u+2],d=a[u+3];let g=(i-f)/(a[u+4]-f);o+=(a[u+4+1]-o)*g,c+=(a[u+4+2]-c)*g,d+=(a[u+4+3]-d)*g;break;case 1:o=a[u+1],c=a[u+2],d=a[u+3];break;default:o=this.getBezierValue(i,u,1,m-2),c=this.getBezierValue(i,u,2,m+18-2),d=this.getBezierValue(i,u,3,m+18*2-2)}if(h==0){let f=n.data;n.mixRotate=f.mixRotate+(o-f.mixRotate)*s,n.mixX=f.mixX+(c-f.mixX)*s,n.mixY=f.mixY+(d-f.mixY)*s}else n.mixRotate+=(o-n.mixRotate)*s,n.mixX+=(c-n.mixX)*s,n.mixY+=(d-n.mixY)*s}},Oe=class extends Ce{constraintIndex=0;constructor(t,e,i,r){super(t,e,r+"|"+i),this.constraintIndex=i}apply(t,e,i,r,s,h,l){let n;if(this.constraintIndex==-1){const a=i>=this.frames[0]?this.getCurveValue(i):0;for(const o of t.physicsConstraints)o.active&&this.global(o.data)&&this.set(o,this.getAbsoluteValue2(i,s,h,this.get(o),this.setup(o),a))}else n=t.physicsConstraints[this.constraintIndex],n.active&&this.set(n,this.getAbsoluteValue(i,s,h,this.get(n),this.setup(n)))}},ai=class extends Oe{constructor(t,e,i){super(t,e,i,se.physicsConstraintInertia)}setup(t){return t.data.inertia}get(t){return t.inertia}set(t,e){t.inertia=e}global(t){return t.inertiaGlobal}},li=class extends Oe{constructor(t,e,i){super(t,e,i,se.physicsConstraintStrength)}setup(t){return t.data.strength}get(t){return t.strength}set(t,e){t.strength=e}global(t){return t.strengthGlobal}},oi=class extends Oe{constructor(t,e,i){super(t,e,i,se.physicsConstraintDamping)}setup(t){return t.data.damping}get(t){return t.damping}set(t,e){t.damping=e}global(t){return t.dampingGlobal}},hi=class extends Oe{constructor(t,e,i){super(t,e,i,se.physicsConstraintMass)}setup(t){return 1/t.data.massInverse}get(t){return 1/t.massInverse}set(t,e){t.massInverse=1/e}global(t){return t.massGlobal}},ci=class extends Oe{constructor(t,e,i){super(t,e,i,se.physicsConstraintWind)}setup(t){return t.data.wind}get(t){return t.wind}set(t,e){t.wind=e}global(t){return t.windGlobal}},di=class extends Oe{constructor(t,e,i){super(t,e,i,se.physicsConstraintGravity)}setup(t){return t.data.gravity}get(t){return t.gravity}set(t,e){t.gravity=e}global(t){return t.gravityGlobal}},ui=class extends Oe{constructor(t,e,i){super(t,e,i,se.physicsConstraintMix)}setup(t){return t.data.mix}get(t){return t.mix}set(t,e){t.mix=e}global(t){return t.mixGlobal}},fi=class gr extends fe{static propertyIds=[se.physicsConstraintReset.toString()];constraintIndex;constructor(e,i){super(e,gr.propertyIds),this.constraintIndex=i}getFrameCount(){return this.frames.length}setFrame(e,i){this.frames[e]=i}apply(e,i,r,s,h,l,n){let a;if(this.constraintIndex!=-1&&(a=e.physicsConstraints[this.constraintIndex],!a.active))return;const o=this.frames;if(i>r)this.apply(e,i,Number.MAX_VALUE,[],h,l,n),i=-1;else if(i>=o[o.length-1])return;if(!(r<o[0])&&(i<o[0]||r>=o[fe.search1(o,i)+1]))if(a!=null)a.reset();else for(const c of e.physicsConstraints)c.active&&c.reset()}},mi=class De extends fe{static ENTRIES=3;static MODE=1;static DELAY=2;slotIndex;attachment;constructor(e,i,r){super(e,[se.sequence+"|"+i+"|"+r.sequence.id]),this.slotIndex=i,this.attachment=r}getFrameEntries(){return De.ENTRIES}getSlotIndex(){return this.slotIndex}getAttachment(){return this.attachment}setFrame(e,i,r,s,h){let l=this.frames;e*=De.ENTRIES,l[e]=i,l[e+De.MODE]=r|s<<4,l[e+De.DELAY]=h}apply(e,i,r,s,h,l,n){let a=e.slots[this.slotIndex];if(!a.bone.active)return;let o=a.attachment,c=this.attachment;if(o!=c&&(!(o instanceof Fe)||o.timelineAttachment!=c))return;if(n==1){l==0&&(a.sequenceIndex=-1);return}let d=this.frames;if(r<d[0]){(l==0||l==1)&&(a.sequenceIndex=-1);return}let u=fe.search(d,r,De.ENTRIES),m=d[u],f=d[u+De.MODE],g=d[u+De.DELAY];if(!this.attachment.sequence)return;let x=f>>4,b=this.attachment.sequence.regions.length,p=ls[f&15];if(p!=0)switch(x+=(r-m)/g+1e-5|0,p){case 1:x=Math.min(b-1,x);break;case 2:x%=b;break;case 3:{let w=(b<<1)-2;x=w==0?0:x%w,x>=b&&(x=w-x);break}case 4:x=Math.max(b-1-x,0);break;case 5:x=b-1-x%b;break;case 6:{let w=(b<<1)-2;x=w==0?0:(x+b-1)%w,x>=b&&(x=w-x)}}a.sequenceIndex=x}},gi=class Ft{static _emptyAnimation=new ut("<empty>",[],0);static emptyAnimation(){return Ft._emptyAnimation}data;tracks=new Array;timeScale=1;unkeyedState=0;events=new Array;listeners=new Array;queue=new ds(this);propertyIDs=new Bt;animationsChanged=!1;trackEntryPool=new it(()=>new cs);constructor(e){this.data=e}update(e){e*=this.timeScale;let i=this.tracks;for(let r=0,s=i.length;r<s;r++){let h=i[r];if(!h)continue;h.animationLast=h.nextAnimationLast,h.trackLast=h.nextTrackLast;let l=e*h.timeScale;if(h.delay>0){if(h.delay-=l,h.delay>0)continue;l=-h.delay,h.delay=0}let n=h.next;if(n){let a=h.trackLast-n.delay;if(a>=0){for(n.delay=0,n.trackTime+=h.timeScale==0?0:(a/h.timeScale+e)*n.timeScale,h.trackTime+=l,this.setCurrent(r,n,!0);n.mixingFrom;)n.mixTime+=e,n=n.mixingFrom;continue}}else if(h.trackLast>=h.trackEnd&&!h.mixingFrom){i[r]=null,this.queue.end(h),this.clearNext(h);continue}if(h.mixingFrom&&this.updateMixingFrom(h,e)){let a=h.mixingFrom;for(h.mixingFrom=null,a&&(a.mixingTo=null);a;)this.queue.end(a),a=a.mixingFrom}h.trackTime+=l}this.queue.drain()}updateMixingFrom(e,i){let r=e.mixingFrom;if(!r)return!0;let s=this.updateMixingFrom(r,i);return r.animationLast=r.nextAnimationLast,r.trackLast=r.nextTrackLast,e.nextTrackLast!=-1&&e.mixTime>=e.mixDuration?((r.totalAlpha==0||e.mixDuration==0)&&(e.mixingFrom=r.mixingFrom,r.mixingFrom!=null&&(r.mixingFrom.mixingTo=e),e.interruptAlpha=r.interruptAlpha,this.queue.end(r)),s):(r.trackTime+=i*r.timeScale,e.mixTime+=i,!1)}apply(e){if(!e)throw new Error("skeleton cannot be null.");this.animationsChanged&&this._animationsChanged();let i=this.events,r=this.tracks,s=!1;for(let u=0,m=r.length;u<m;u++){let f=r[u];if(!f||f.delay>0)continue;s=!0;let g=u==0?1:f.mixBlend,x=f.alpha;f.mixingFrom?x*=this.applyMixingFrom(f,e,g):f.trackTime>=f.trackEnd&&!f.next&&(x=0);let b=x>=f.alphaAttachmentThreshold,p=f.animationLast,w=f.getAnimationTime(),v=w,y=i;f.reverse&&(v=f.animation.duration-v,y=null);let A=f.animation.timelines,C=A.length;if(u==0&&x==1||g==3){u==0&&(b=!0);for(let S=0;S<C;S++){X.webkit602BugfixHelper(x,g);var h=A[S];h instanceof We?this.applyAttachmentTimeline(h,e,v,g,b):h.apply(e,p,v,y,x,g,0)}}else{let S=f.timelineMode,I=f.shortestRotation,k=!I&&f.timelinesRotation.length!=C<<1;k&&(f.timelinesRotation.length=C<<1);for(let Y=0;Y<C;Y++){let F=A[Y],P=S[Y]==gt?g:0;!I&&F instanceof st?this.applyRotateTimeline(F,e,v,x,P,f.timelinesRotation,Y<<1,k):F instanceof We?this.applyAttachmentTimeline(F,e,v,g,b):(X.webkit602BugfixHelper(x,g),F.apply(e,p,v,y,x,P,0))}}this.queueEvents(f,w),i.length=0,f.nextAnimationLast=w,f.nextTrackLast=f.trackTime}for(var l=this.unkeyedState+wi,n=e.slots,a=0,o=e.slots.length;a<o;a++){var c=n[a];if(c.attachmentState==l){var d=c.data.attachmentName;c.setAttachment(d?e.getAttachment(c.data.index,d):null)}}return this.unkeyedState+=2,this.queue.drain(),s}applyMixingFrom(e,i,r){let s=e.mixingFrom;s.mixingFrom&&this.applyMixingFrom(s,i,r);let h=0;e.mixDuration==0?(h=1,r==1&&(r=0)):(h=e.mixTime/e.mixDuration,h>1&&(h=1),r!=1&&(r=s.mixBlend));let l=h<s.mixAttachmentThreshold,n=h<s.mixDrawOrderThreshold,a=s.animation.timelines,o=a.length,c=s.alpha*e.interruptAlpha,d=c*(1-h),u=s.animationLast,m=s.getAnimationTime(),f=m,g=null;if(s.reverse?f=s.animation.duration-f:h<s.eventThreshold&&(g=this.events),r==3)for(let x=0;x<o;x++)a[x].apply(i,u,f,g,d,r,1);else{let x=s.timelineMode,b=s.timelineHoldMix,p=s.shortestRotation,w=!p&&s.timelinesRotation.length!=o<<1;w&&(s.timelinesRotation.length=o<<1),s.totalAlpha=0;for(let v=0;v<o;v++){let y=a[v],A=1,C,S=0;switch(x[v]){case gt:if(!n&&y instanceof je)continue;C=r,S=d;break;case pi:C=0,S=d;break;case xi:C=r,S=c;break;case pt:C=0,S=c;break;default:C=0;let I=b[v];S=c*Math.max(0,1-I.mixTime/I.mixDuration);break}s.totalAlpha+=S,!p&&y instanceof st?this.applyRotateTimeline(y,i,f,S,C,s.timelinesRotation,v<<1,w):y instanceof We?this.applyAttachmentTimeline(y,i,f,C,l&&S>=s.alphaAttachmentThreshold):(X.webkit602BugfixHelper(S,r),n&&y instanceof je&&C==0&&(A=0),y.apply(i,u,f,g,S,C,A))}}return e.mixDuration>0&&this.queueEvents(s,m),this.events.length=0,s.nextAnimationLast=m,s.nextTrackLast=s.trackTime,h}applyAttachmentTimeline(e,i,r,s,h){var l=i.slots[e.slotIndex];l.bone.active&&(r<e.frames[0]?(s==0||s==1)&&this.setAttachment(i,l,l.data.attachmentName,h):this.setAttachment(i,l,e.attachmentNames[fe.search1(e.frames,r)],h),l.attachmentState<=this.unkeyedState&&(l.attachmentState=this.unkeyedState+wi))}setAttachment(e,i,r,s){i.setAttachment(r?e.getAttachment(i.data.index,r):null),s&&(i.attachmentState=this.unkeyedState+ms)}applyRotateTimeline(e,i,r,s,h,l,n,a){if(a&&(l[n]=0),s==1){e.apply(i,0,r,null,1,h,0);return}let o=i.bones[e.boneIndex];if(!o.active)return;let c=e.frames,d=0,u=0;if(r<c[0])switch(h){case 0:o.rotation=o.data.rotation;default:return;case 1:d=o.rotation,u=o.data.rotation}else d=h==0?o.data.rotation:o.rotation,u=o.data.rotation+e.getCurveValue(r);let m=0,f=u-d;if(f-=Math.ceil(f/360-.5)*360,f==0)m=l[n];else{let g=0,x=0;a?(g=0,x=f):(g=l[n],x=l[n+1]);let b=g-g%360;m=f+b;let p=f>=0,w=g>=0;Math.abs(x)<=90&&L.signum(x)!=L.signum(f)&&(Math.abs(g-b)>180?(m+=360*L.signum(g),w=p):b!=0?m-=360*L.signum(g):w=p),w!=p&&(m+=360*L.signum(g)),l[n]=m}l[n+1]=f,o.rotation=d+m*s}queueEvents(e,i){let r=e.animationStart,s=e.animationEnd,h=s-r,l=e.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>s||this.queue.event(e,d)}let c=!1;if(e.loop)if(h==0)c=!0;else{const d=Math.floor(e.trackTime/h);c=d>0&&d>Math.floor(e.trackLast/h)}else c=i>=s&&e.animationLast<s;for(c&&this.queue.complete(e);a<o;a++){let d=n[a];d.time<r||this.queue.event(e,d)}}clearTracks(){let e=this.queue.drainDisabled;this.queue.drainDisabled=!0;for(let i=0,r=this.tracks.length;i<r;i++)this.clearTrack(i);this.tracks.length=0,this.queue.drainDisabled=e,this.queue.drain()}clearTrack(e){if(e>=this.tracks.length)return;let i=this.tracks[e];if(!i)return;this.queue.end(i),this.clearNext(i);let r=i;for(;;){let s=r.mixingFrom;if(!s)break;this.queue.end(s),r.mixingFrom=null,r.mixingTo=null,r=s}this.tracks[i.trackIndex]=null,this.queue.drain()}setCurrent(e,i,r){let s=this.expandToIndex(e);this.tracks[e]=i,i.previous=null,s&&(r&&this.queue.interrupt(s),i.mixingFrom=s,s.mixingTo=i,i.mixTime=0,s.mixingFrom&&s.mixDuration>0&&(i.interruptAlpha*=Math.min(1,s.mixTime/s.mixDuration)),s.timelinesRotation.length=0),this.queue.start(i)}setAnimation(e,i,r=!1){let s=this.data.skeletonData.findAnimation(i);if(!s)throw new Error("Animation not found: "+i);return this.setAnimationWith(e,s,r)}setAnimationWith(e,i,r=!1){if(!i)throw new Error("animation cannot be null.");let s=!0,h=this.expandToIndex(e);h&&(h.nextTrackLast==-1?(this.tracks[e]=h.mixingFrom,this.queue.interrupt(h),this.queue.end(h),this.clearNext(h),h=h.mixingFrom,s=!1):this.clearNext(h));let l=this.trackEntry(e,i,r,h);return this.setCurrent(e,l,s),this.queue.drain(),l}addAnimation(e,i,r=!1,s=0){let h=this.data.skeletonData.findAnimation(i);if(!h)throw new Error("Animation not found: "+i);return this.addAnimationWith(e,h,r,s)}addAnimationWith(e,i,r=!1,s=0){if(!i)throw new Error("animation cannot be null.");let h=this.expandToIndex(e);if(h)for(;h.next;)h=h.next;let l=this.trackEntry(e,i,r,h);return h?(h.next=l,l.previous=h,s<=0&&(s=Math.max(s+h.getTrackComplete()-l.mixDuration,0))):(this.setCurrent(e,l,!0),this.queue.drain(),s<0&&(s=0)),l.delay=s,l}setEmptyAnimation(e,i=0){let r=this.setAnimationWith(e,Ft.emptyAnimation(),!1);return r.mixDuration=i,r.trackEnd=i,r}addEmptyAnimation(e,i=0,r=0){let s=this.addAnimationWith(e,Ft.emptyAnimation(),!1,r);return r<=0&&(s.delay=Math.max(s.delay+s.mixDuration-i,0)),s.mixDuration=i,s.trackEnd=i,s}setEmptyAnimations(e=0){let i=this.queue.drainDisabled;this.queue.drainDisabled=!0;for(let r=0,s=this.tracks.length;r<s;r++){let h=this.tracks[r];h&&this.setEmptyAnimation(h.trackIndex,e)}this.queue.drainDisabled=i,this.queue.drain()}expandToIndex(e){return e<this.tracks.length?this.tracks[e]:(X.ensureArrayCapacity(this.tracks,e+1,null),this.tracks.length=e+1,null)}trackEntry(e,i,r,s){let h=this.trackEntryPool.obtain();return h.reset(),h.trackIndex=e,h.animation=i,h.loop=r,h.holdPrevious=!1,h.reverse=!1,h.shortestRotation=!1,h.eventThreshold=0,h.alphaAttachmentThreshold=0,h.mixAttachmentThreshold=0,h.mixDrawOrderThreshold=0,h.animationStart=0,h.animationEnd=i.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=s?this.data.getMix(s.animation,i):0,h.interruptAlpha=1,h.totalAlpha=0,h.mixBlend=2,h}clearNext(e){let i=e.next;for(;i;)this.queue.dispose(i),i=i.next;e.next=null}_animationsChanged(){this.animationsChanged=!1,this.propertyIDs.clear();let e=this.tracks;for(let i=0,r=e.length;i<r;i++){let s=e[i];if(s){for(;s.mixingFrom;)s=s.mixingFrom;do(!s.mixingTo||s.mixBlend!=3)&&this.computeHold(s),s=s.mixingTo;while(s)}}}computeHold(e){let i=e.mixingTo,r=e.animation.timelines,s=e.animation.timelines.length,h=e.timelineMode;h.length=s;let l=e.timelineHoldMix;l.length=0;let n=this.propertyIDs;if(i&&i.holdPrevious){for(let a=0;a<s;a++)h[a]=n.addAll(r[a].getPropertyIds())?pt:xi;return}e:for(let a=0;a<s;a++){let o=r[a],c=o.getPropertyIds();if(!n.addAll(c))h[a]=gt;else if(!i||o instanceof We||o instanceof je||o instanceof mt||!i.animation.hasTimeline(c))h[a]=pi;else{for(let d=i.mixingTo;d;d=d.mixingTo)if(!d.animation.hasTimeline(c)){if(e.mixDuration>0){h[a]=fs,l[a]=d;continue e}break}h[a]=pt}}}getCurrent(e){return e>=this.tracks.length?null:this.tracks[e]}addListener(e){if(!e)throw new Error("listener cannot be null.");this.listeners.push(e)}removeListener(e){let i=this.listeners.indexOf(e);i>=0&&this.listeners.splice(i,1)}clearListeners(){this.listeners.length=0}clearListenerNotifications(){this.queue.clear()}},cs=class{animation=null;previous=null;next=null;mixingFrom=null;mixingTo=null;listener=null;trackIndex=0;loop=!1;holdPrevious=!1;reverse=!1;shortestRotation=!1;eventThreshold=0;mixAttachmentThreshold=0;alphaAttachmentThreshold=0;mixDrawOrderThreshold=0;animationStart=0;animationEnd=0;animationLast=0;nextAnimationLast=0;delay=0;trackTime=0;trackLast=0;nextTrackLast=0;trackEnd=0;timeScale=0;alpha=0;mixTime=0;_mixDuration=0;interruptAlpha=0;totalAlpha=0;get mixDuration(){return this._mixDuration}set mixDuration(t){this._mixDuration=t}setMixDurationWithDelay(t,e){this._mixDuration=t,e<=0&&(this.previous!=null?e=Math.max(e+this.previous.getTrackComplete()-t,0):e=0),this.delay=e}mixBlend=2;timelineMode=new Array;timelineHoldMix=new Array;timelinesRotation=new Array;reset(){this.next=null,this.previous=null,this.mixingFrom=null,this.mixingTo=null,this.animation=null,this.listener=null,this.timelineMode.length=0,this.timelineHoldMix.length=0,this.timelinesRotation.length=0}getAnimationTime(){if(this.loop){let t=this.animationEnd-this.animationStart;return t==0?this.animationStart:this.trackTime%t+this.animationStart}return Math.min(this.trackTime+this.animationStart,this.animationEnd)}setAnimationLast(t){this.animationLast=t,this.nextAnimationLast=t}isComplete(){return this.trackTime>=this.animationEnd-this.animationStart}resetRotationDirections(){this.timelinesRotation.length=0}getTrackComplete(){let t=this.animationEnd-this.animationStart;if(t!=0){if(this.loop)return t*(1+(this.trackTime/t|0));if(this.trackTime<t)return t}return this.trackTime}wasApplied(){return this.nextTrackLast!=-1}isNextReady(){return this.next!=null&&this.nextTrackLast-this.next.delay>=0}},ds=class{objects=[];drainDisabled=!1;animState;constructor(t){this.animState=t}start(t){this.objects.push(0),this.objects.push(t),this.animState.animationsChanged=!0}interrupt(t){this.objects.push(1),this.objects.push(t)}end(t){this.objects.push(2),this.objects.push(t),this.animState.animationsChanged=!0}dispose(t){this.objects.push(3),this.objects.push(t)}complete(t){this.objects.push(4),this.objects.push(t)}event(t,e){this.objects.push(5),this.objects.push(t),this.objects.push(e)}drain(){if(this.drainDisabled)return;this.drainDisabled=!0;let t=this.objects,e=this.animState.listeners;for(let i=0;i<t.length;i+=2){let r=t[i],s=t[i+1];switch(r){case 0:s.listener&&s.listener.start&&s.listener.start(s);for(let l=0;l<e.length;l++){let n=e[l];n.start&&n.start(s)}break;case 1:s.listener&&s.listener.interrupt&&s.listener.interrupt(s);for(let l=0;l<e.length;l++){let n=e[l];n.interrupt&&n.interrupt(s)}break;case 2:s.listener&&s.listener.end&&s.listener.end(s);for(let l=0;l<e.length;l++){let n=e[l];n.end&&n.end(s)}case 3:s.listener&&s.listener.dispose&&s.listener.dispose(s);for(let l=0;l<e.length;l++){let n=e[l];n.dispose&&n.dispose(s)}this.animState.trackEntryPool.free(s);break;case 4:s.listener&&s.listener.complete&&s.listener.complete(s);for(let l=0;l<e.length;l++){let n=e[l];n.complete&&n.complete(s)}break;case 5:let h=t[i+++2];s.listener&&s.listener.event&&s.listener.event(s,h);for(let l=0;l<e.length;l++){let n=e[l];n.event&&n.event(s,h)}break}}this.clear(),this.drainDisabled=!1}clear(){this.objects.length=0}},us=(t=>(t[t.start=0]="start",t[t.interrupt=1]="interrupt",t[t.end=2]="end",t[t.dispose=3]="dispose",t[t.complete=4]="complete",t[t.event=5]="event",t))(us||{}),Dr=class{start(t){}interrupt(t){}end(t){}dispose(t){}complete(t){}event(t,e){}},gt=0,pi=1,xi=2,pt=3,fs=4,wi=1,ms=2,gs=class{skeletonData;animationToMixTime={};defaultMix=0;constructor(t){if(!t)throw new Error("skeletonData cannot be null.");this.skeletonData=t}setMix(t,e,i){let r=this.skeletonData.findAnimation(t);if(!r)throw new Error("Animation not found: "+t);let s=this.skeletonData.findAnimation(e);if(!s)throw new Error("Animation not found: "+e);this.setMixWith(r,s,i)}setMixWith(t,e,i){if(!t)throw new Error("from cannot be null.");if(!e)throw new Error("to cannot be null.");let r=t.name+"."+e.name;this.animationToMixTime[r]=i}getMix(t,e){let i=t.name+"."+e.name,r=this.animationToMixTime[i];return r===void 0?this.defaultMix:r}},bi=class pr extends Fe{color=new K(1,1,1,1);constructor(e){super(e)}copy(){let e=new pr(this.name);return this.copyTo(e),e.color.setFromColor(this.color),e}},rt=class xr extends Fe{endSlot=null;color=new K(.2275,.2275,.8078,1);constructor(e){super(e)}copy(){let e=new xr(this.name);return this.copyTo(e),e.endSlot=this.endSlot,e.color.setFromColor(this.color),e}},xt=class{_image;constructor(t){this._image=t}getImage(){return this._image}},wt=(t=>(t[t.Nearest=9728]="Nearest",t[t.Linear=9729]="Linear",t[t.MipMap=9987]="MipMap",t[t.MipMapNearestNearest=9984]="MipMapNearestNearest",t[t.MipMapLinearNearest=9985]="MipMapLinearNearest",t[t.MipMapNearestLinear=9986]="MipMapNearestLinear",t[t.MipMapLinearLinear=9987]="MipMapLinearLinear",t))(wt||{}),ps=(t=>(t[t.MirroredRepeat=33648]="MirroredRepeat",t[t.ClampToEdge=33071]="ClampToEdge",t[t.Repeat=10497]="Repeat",t))(ps||{}),xs=class{texture;u=0;v=0;u2=0;v2=0;width=0;height=0;degrees=0;offsetX=0;offsetY=0;originalWidth=0;originalHeight=0},Nr=class extends xt{setFilters(t,e){}setWraps(t,e){}dispose(){}},bt=class{pages=new Array;regions=new Array;constructor(t){let e=new Ur(t),i=new Array(4),r={};r.size=o=>{o.width=parseInt(i[1]),o.height=parseInt(i[2])},r.format=()=>{},r.filter=o=>{o.minFilter=X.enumValue(wt,i[1]),o.magFilter=X.enumValue(wt,i[2])},r.repeat=o=>{i[1].indexOf("x")!=-1&&(o.uWrap=10497),i[1].indexOf("y")!=-1&&(o.vWrap=10497)},r.pma=o=>{o.pma=i[1]=="true"};var s={};s.xy=o=>{o.x=parseInt(i[1]),o.y=parseInt(i[2])},s.size=o=>{o.width=parseInt(i[1]),o.height=parseInt(i[2])},s.bounds=o=>{o.x=parseInt(i[1]),o.y=parseInt(i[2]),o.width=parseInt(i[3]),o.height=parseInt(i[4])},s.offset=o=>{o.offsetX=parseInt(i[1]),o.offsetY=parseInt(i[2])},s.orig=o=>{o.originalWidth=parseInt(i[1]),o.originalHeight=parseInt(i[2])},s.offsets=o=>{o.offsetX=parseInt(i[1]),o.offsetY=parseInt(i[2]),o.originalWidth=parseInt(i[3]),o.originalHeight=parseInt(i[4])},s.rotate=o=>{let c=i[1];c=="true"?o.degrees=90:c!="false"&&(o.degrees=parseInt(c))},s.index=o=>{o.index=parseInt(i[1])};let h=e.readLine();for(;h&&h.trim().length==0;)h=e.readLine();for(;!(!h||h.trim().length==0||e.readEntry(i,h)==0);)h=e.readLine();let l=null,n=null,a=null;for(;h!==null;)if(h.trim().length==0)l=null,h=e.readLine();else if(l){let o=new vi(l,h);for(;;){let c=e.readEntry(i,h=e.readLine());if(c==0)break;let d=s[i[0]];if(d)d(o);else{n||(n=[]),a||(a=[]),n.push(i[0]);let u=[];for(let m=0;m<c;m++)u.push(parseInt(i[m+1]));a.push(u)}}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 ws(h.trim());e.readEntry(i,h=e.readLine())!=0;){let o=r[i[0]];o&&o(l)}this.pages.push(l)}}findRegion(t){for(let e=0;e<this.regions.length;e++)if(this.regions[e].name==t)return this.regions[e];return null}setTextures(t,e=""){for(let i of this.pages)i.setTexture(t.get(e+i.name))}dispose(){for(let t=0;t<this.pages.length;t++)this.pages[t].texture?.dispose()}},Ur=class{lines;index=0;constructor(t){this.lines=t.split(/\r\n|\r|\n/)}readLine(){return this.index>=this.lines.length?null:this.lines[this.index++]}readEntry(t,e){if(!e||(e=e.trim(),e.length==0))return 0;let i=e.indexOf(":");if(i==-1)return 0;t[0]=e.substr(0,i).trim();for(let r=1,s=i+1;;r++){let h=e.indexOf(",",s);if(h==-1)return t[r]=e.substr(s).trim(),r;if(t[r]=e.substr(s,h-s).trim(),s=h+1,r==4)return 4}}},ws=class{name;minFilter=9728;magFilter=9728;uWrap=33071;vWrap=33071;texture=null;width=0;height=0;pma=!1;regions=new Array;constructor(t){this.name=t}setTexture(t){this.texture=t,t.setFilters(this.minFilter,this.magFilter),t.setWraps(this.uWrap,this.vWrap);for(let e of this.regions)e.texture=t}},vi=class extends xs{page;name;x=0;y=0;offsetX=0;offsetY=0;originalWidth=0;originalHeight=0;index=0;degrees=0;names=null;values=null;constructor(t,e){super(),this.page=t,this.name=e,t.regions.push(this)}},Ge=class Ki extends Fe{region=null;path;regionUVs=[];uvs=[];triangles=[];color=new K(1,1,1,1);width=0;height=0;hullLength=0;edges=[];parentMesh=null;sequence=null;tempColor=new K(0,0,0,0);constructor(e,i){super(e),this.path=i}updateRegion(){if(!this.region)throw new Error("Region not set.");let e=this.regionUVs;(!this.uvs||this.uvs.length!=e.length)&&(this.uvs=X.newFloatArray(e.length));let i=this.uvs,r=this.uvs.length,s=this.region.u,h=this.region.v,l=0,n=0;if(this.region instanceof vi){let a=this.region,o=a.page,c=o.width,d=o.height;switch(a.degrees){case 90:s-=(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 u=0;u<r;u+=2)i[u]=s+e[u+1]*l,i[u+1]=h+(1-e[u])*n;return;case 180:s-=(a.originalWidth-a.offsetX-a.width)/c,h-=a.offsetY/d,l=a.originalWidth/c,n=a.originalHeight/d;for(let u=0;u<r;u+=2)i[u]=s+(1-e[u])*l,i[u+1]=h+(1-e[u+1])*n;return;case 270:s-=a.offsetY/c,h-=a.offsetX/d,l=a.originalHeight/c,n=a.originalWidth/d;for(let u=0;u<r;u+=2)i[u]=s+(1-e[u+1])*l,i[u+1]=h+e[u]*n;return}s-=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-s,n=this.region.v2-h):(s=h=0,l=n=1);for(let a=0;a<r;a+=2)i[a]=s+e[a]*l,i[a+1]=h+e[a+1]*n}getParentMesh(){return this.parentMesh}setParentMesh(e){this.parentMesh=e,e&&(this.bones=e.bones,this.vertices=e.vertices,this.worldVerticesLength=e.worldVerticesLength,this.regionUVs=e.regionUVs,this.triangles=e.triangles,this.hullLength=e.hullLength,this.worldVerticesLength=e.worldVerticesLength)}copy(){if(this.parentMesh)return this.newLinkedMesh();let e=new Ki(this.name,this.path);return e.region=this.region,e.color.setFromColor(this.color),this.copyTo(e),e.regionUVs=new Array(this.regionUVs.length),X.arrayCopy(this.regionUVs,0,e.regionUVs,0,this.regionUVs.length),e.uvs=new Array(this.uvs.length),X.arrayCopy(this.uvs,0,e.uvs,0,this.uvs.length),e.triangles=new Array(this.triangles.length),X.arrayCopy(this.triangles,0,e.triangles,0,this.triangles.length),e.hullLength=this.hullLength,e.sequence=this.sequence!=null?this.sequence.copy():null,this.edges&&(e.edges=new Array(this.edges.length),X.arrayCopy(this.edges,0,e.edges,0,this.edges.length)),e.width=this.width,e.height=this.height,e}computeWorldVertices(e,i,r,s,h,l){this.sequence!=null&&this.sequence.apply(e,this),super.computeWorldVertices(e,i,r,s,h,l)}newLinkedMesh(){let e=new Ki(this.name,this.path);return e.region=this.region,e.color.setFromColor(this.color),e.timelineAttachment=this.timelineAttachment,e.setParentMesh(this.parentMesh?this.parentMesh:this),e.region!=null&&e.updateRegion(),e}},Ze=class wr extends Fe{lengths=[];closed=!1;constantSpeed=!1;color=new K(1,1,1,1);constructor(e){super(e)}copy(){let e=new wr(this.name);return this.copyTo(e),e.lengths=new Array(this.lengths.length),X.arrayCopy(this.lengths,0,e.lengths,0,this.lengths.length),e.closed=closed,e.constantSpeed=this.constantSpeed,e.color.setFromColor(this.color),e}},bs=class br extends Fe{x=0;y=0;rotation=0;color=new K(.38,.94,0,1);constructor(e){super(e)}computeWorldPosition(e,i){return i.x=this.x*e.a+this.y*e.b+e.worldX,i.y=this.x*e.c+this.y*e.d+e.worldY,i}computeWorldRotation(e){const i=this.rotation*L.degRad,r=Math.cos(i),s=Math.sin(i),h=r*e.a+s*e.b,l=r*e.c+s*e.d;return L.atan2Deg(l,h)}copy(){let e=new br(this.name);return e.x=this.x,e.y=this.y,e.rotation=this.rotation,e.color.setFromColor(this.color),e}},ce=class vr extends Vt{x=0;y=0;scaleX=1;scaleY=1;rotation=0;width=0;height=0;color=new K(1,1,1,1);path;region=null;sequence=null;offset=X.newFloatArray(8);uvs=X.newFloatArray(8);tempColor=new K(1,1,1,1);constructor(e,i){super(e),this.path=i}updateRegion(){if(!this.region)throw new Error("Region not set.");let e=this.region,i=this.uvs;if(e==null){i[0]=0,i[1]=0,i[2]=0,i[3]=1,i[4]=1,i[5]=1,i[6]=1,i[7]=0;return}let r=this.width/this.region.originalWidth*this.scaleX,s=this.height/this.region.originalHeight*this.scaleY,h=-this.width/2*this.scaleX+this.region.offsetX*r,l=-this.height/2*this.scaleY+this.region.offsetY*s,n=h+this.region.width*r,a=l+this.region.height*s,o=this.rotation*L.degRad,c=Math.cos(o),d=Math.sin(o),u=this.x,m=this.y,f=h*c+u,g=h*d,x=l*c+m,b=l*d,p=n*c+u,w=n*d,v=a*c+m,y=a*d,A=this.offset;A[0]=f-b,A[1]=x+g,A[2]=f-y,A[3]=v+g,A[4]=p-y,A[5]=v+w,A[6]=p-b,A[7]=x+w,e.degrees==90?(i[0]=e.u2,i[1]=e.v2,i[2]=e.u,i[3]=e.v2,i[4]=e.u,i[5]=e.v,i[6]=e.u2,i[7]=e.v):(i[0]=e.u,i[1]=e.v2,i[2]=e.u,i[3]=e.v,i[4]=e.u2,i[5]=e.v,i[6]=e.u2,i[7]=e.v2)}computeWorldVertices(e,i,r,s){this.sequence!=null&&this.sequence.apply(e,this);let h=e.bone,l=this.offset,n=h.worldX,a=h.worldY,o=h.a,c=h.b,d=h.c,u=h.d,m=0,f=0;m=l[0],f=l[1],i[r]=m*o+f*c+n,i[r+1]=m*d+f*u+a,r+=s,m=l[2],f=l[3],i[r]=m*o+f*c+n,i[r+1]=m*d+f*u+a,r+=s,m=l[4],f=l[5],i[r]=m*o+f*c+n,i[r+1]=m*d+f*u+a,r+=s,m=l[6],f=l[7],i[r]=m*o+f*c+n,i[r+1]=m*d+f*u+a}copy(){let e=new vr(this.name,this.path);return e.region=this.region,e.x=this.x,e.y=this.y,e.scaleX=this.scaleX,e.scaleY=this.scaleY,e.rotation=this.rotation,e.width=this.width,e.height=this.height,X.arrayCopy(this.uvs,0,e.uvs,0,8),X.arrayCopy(this.offset,0,e.offset,0,8),e.color.setFromColor(this.color),e.sequence=this.sequence!=null?this.sequence.copy():null,e}static X1=0;static Y1=1;static C1R=2;static C1G=3;static C1B=4;static C1A=5;static U1=6;static V1=7;static X2=8;static Y2=9;static C2R=10;static C2G=11;static C2B=12;static C2A=13;static U2=14;static V2=15;static X3=16;static Y3=17;static C3R=18;static C3G=19;static C3B=20;static C3A=21;static U3=22;static V3=23;static X4=24;static Y4=25;static C4R=26;static C4G=27;static C4B=28;static C4A=29;static U4=30;static V4=31},yi=class{atlas;constructor(t){this.atlas=t}loadSequence(t,e,i){let r=i.regions;for(let s=0,h=r.length;s<h;s++){let l=i.getPath(e,s),n=this.atlas.findRegion(l);if(n==null)throw new Error("Region not found in atlas: "+l+" (sequence: "+t+")");r[s]=n}}newRegionAttachment(t,e,i,r){let s=new ce(e,i);if(r!=null)this.loadSequence(e,i,r);else{let h=this.atlas.findRegion(i);if(!h)throw new Error("Region not found in atlas: "+i+" (region attachment: "+e+")");s.region=h}return s}newMeshAttachment(t,e,i,r){let s=new Ge(e,i);if(r!=null)this.loadSequence(e,i,r);else{let h=this.atlas.findRegion(i);if(!h)throw new Error("Region not found in atlas: "+i+" (mesh attachment: "+e+")");s.region=h}return s}newBoundingBoxAttachment(t,e){return new bi(e)}newPathAttachment(t,e){return new Ze(e)}newPointAttachment(t,e){return new bs(e)}newClippingAttachment(t,e){return new rt(e)}},Ai=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 K;icon;visible=!1;constructor(t,e,i){if(t<0)throw new Error("index must be >= 0.");if(!e)throw new Error("name cannot be null.");this.index=t,this.name=e,this.parent=i}},vt=(t=>(t[t.Normal=0]="Normal",t[t.OnlyTranslation=1]="OnlyTranslation",t[t.NoRotationOrReflection=2]="NoRotationOrReflection",t[t.NoScale=3]="NoScale",t[t.NoScaleOrReflection=4]="NoScaleOrReflection",t))(vt||{}),Ci=class{data;skeleton;parent=null;children=new Array;x=0;y=0;rotation=0;scaleX=0;scaleY=0;shearX=0;shearY=0;ax=0;ay=0;arotation=0;ascaleX=0;ascaleY=0;ashearX=0;ashearY=0;a=0;b=0;c=0;d=0;worldY=0;worldX=0;inherit=0;sorted=!1;active=!1;constructor(t,e,i){if(!t)throw new Error("data cannot be null.");if(!e)throw new Error("skeleton cannot be null.");this.data=t,this.skeleton=e,this.parent=i,this.setToSetupPose()}isActive(){return this.active}update(t){this.updateWorldTransformWith(this.ax,this.ay,this.arotation,this.ascaleX,this.ascaleY,this.ashearX,this.ashearY)}updateWorldTransform(){this.updateWorldTransformWith(this.x,this.y,this.rotation,this.scaleX,this.scaleY,this.shearX,this.shearY)}updateWorldTransformWith(t,e,i,r,s,h,l){this.ax=t,this.ay=e,this.arotation=i,this.ascaleX=r,this.ascaleY=s,this.ashearX=h,this.ashearY=l;let n=this.parent;if(!n){let u=this.skeleton;const m=u.scaleX,f=u.scaleY,g=(i+h)*L.degRad,x=(i+90+l)*L.degRad;this.a=Math.cos(g)*r*m,this.b=Math.cos(x)*s*m,this.c=Math.sin(g)*r*f,this.d=Math.sin(x)*s*f,this.worldX=t*m+u.x,this.worldY=e*f+u.y;return}let a=n.a,o=n.b,c=n.c,d=n.d;switch(this.worldX=a*t+o*e+n.worldX,this.worldY=c*t+d*e+n.worldY,this.inherit){case 0:{const u=(i+h)*L.degRad,m=(i+90+l)*L.degRad,f=Math.cos(u)*r,g=Math.cos(m)*s,x=Math.sin(u)*r,b=Math.sin(m)*s;this.a=a*f+o*x,this.b=a*g+o*b,this.c=c*f+d*x,this.d=c*g+d*b;return}case 1:{const u=(i+h)*L.degRad,m=(i+90+l)*L.degRad;this.a=Math.cos(u)*r,this.b=Math.cos(m)*s,this.c=Math.sin(u)*r,this.d=Math.sin(m)*s;break}case 2:{let u=1/this.skeleton.scaleX,m=1/this.skeleton.scaleY;a*=u,c*=m;let f=a*a+c*c,g=0;f>1e-4?(f=Math.abs(a*d*m-o*u*c)/f,o=c*f,d=a*f,g=Math.atan2(c,a)*L.radDeg):(a=0,c=0,g=90-Math.atan2(d,o)*L.radDeg);const x=(i+h-g)*L.degRad,b=(i+l-g+90)*L.degRad,p=Math.cos(x)*r,w=Math.cos(b)*s,v=Math.sin(x)*r,y=Math.sin(b)*s;this.a=a*p-o*v,this.b=a*w-o*y,this.c=c*p+d*v,this.d=c*w+d*y;break}case 3:case 4:{i*=L.degRad;const u=Math.cos(i),m=Math.sin(i);let f=(a*u+o*m)/this.skeleton.scaleX,g=(c*u+d*m)/this.skeleton.scaleY,x=Math.sqrt(f*f+g*g);x>1e-5&&(x=1/x),f*=x,g*=x,x=Math.sqrt(f*f+g*g),this.inherit==3&&a*d-o*c<0!=(this.skeleton.scaleX<0!=this.skeleton.scaleY<0)&&(x=-x),i=Math.PI/2+Math.atan2(g,f);const b=Math.cos(i)*x,p=Math.sin(i)*x;h*=L.degRad,l=(90+l)*L.degRad;const w=Math.cos(h)*r,v=Math.cos(l)*s,y=Math.sin(h)*r,A=Math.sin(l)*s;this.a=f*w+b*y,this.b=f*v+b*A,this.c=g*w+p*y,this.d=g*v+p*A;break}}this.a*=this.skeleton.scaleX,this.b*=this.skeleton.scaleX,this.c*=this.skeleton.scaleY,this.d*=this.skeleton.scaleY}setToSetupPose(){let t=this.data;this.x=t.x,this.y=t.y,this.rotation=t.rotation,this.scaleX=t.scaleX,this.scaleY=t.scaleY,this.shearX=t.shearX,this.shearY=t.shearY,this.inherit=t.inherit}updateAppliedTransform(){let t=this.parent;if(!t){this.ax=this.worldX-this.skeleton.x,this.ay=this.worldY-this.skeleton.y,this.arotation=Math.atan2(this.c,this.a)*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 e=t.a,i=t.b,r=t.c,s=t.d,h=1/(e*s-i*r),l=s*h,n=i*h,a=r*h,o=e*h,c=this.worldX-t.worldX,d=this.worldY-t.worldY;this.ax=c*l-d*n,this.ay=d*o-c*a;let u,m,f,g;if(this.inherit==1)u=this.a,m=this.b,f=this.c,g=this.d;else{switch(this.inherit){case 2:{let v=Math.abs(e*s-i*r)/(e*e+r*r);i=-r*this.skeleton.scaleX*v/this.skeleton.scaleY,s=e*this.skeleton.scaleY*v/this.skeleton.scaleX,h=1/(e*s-i*r),l=s*h,n=i*h;break}case 3:case 4:let x=L.cosDeg(this.rotation),b=L.sinDeg(this.rotation);e=(e*x+i*b)/this.skeleton.scaleX,r=(r*x+s*b)/this.skeleton.scaleY;let p=Math.sqrt(e*e+r*r);p>1e-5&&(p=1/p),e*=p,r*=p,p=Math.sqrt(e*e+r*r),this.inherit==3&&h<0!=(this.skeleton.scaleX<0!=this.skeleton.scaleY<0)&&(p=-p);let w=L.PI/2+Math.atan2(r,e);i=Math.cos(w)*p,s=Math.sin(w)*p,h=1/(e*s-i*r),l=s*h,n=i*h,a=r*h,o=e*h}u=l*this.a-n*this.c,m=l*this.b-n*this.d,f=o*this.c-a*this.a,g=o*this.d-a*this.b}if(this.ashearX=0,this.ascaleX=Math.sqrt(u*u+f*f),this.ascaleX>1e-4){let x=u*g-m*f;this.ascaleY=x/this.ascaleX,this.ashearY=-Math.atan2(u*m+f*g,x)*L.radDeg,this.arotation=Math.atan2(f,u)*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(t){let e=1/(this.a*this.d-this.b*this.c),i=t.x-this.worldX,r=t.y-this.worldY;return t.x=i*this.d*e-r*this.b*e,t.y=r*this.a*e-i*this.c*e,t}localToWorld(t){let e=t.x,i=t.y;return t.x=e*this.a+i*this.b+this.worldX,t.y=e*this.c+i*this.d+this.worldY,t}worldToParent(t){if(t==null)throw new Error("world cannot be null.");return this.parent==null?t:this.parent.worldToLocal(t)}parentToWorld(t){if(t==null)throw new Error("world cannot be null.");return this.parent==null?t:this.parent.localToWorld(t)}worldToLocalRotation(t){let e=L.sinDeg(t),i=L.cosDeg(t);return Math.atan2(this.a*e-this.c*i,this.d*i-this.b*e)*L.radDeg+this.rotation-this.shearX}localToWorldRotation(t){t-=this.rotation-this.shearX;let e=L.sinDeg(t),i=L.cosDeg(t);return Math.atan2(i*this.c+e*this.d,i*this.a+e*this.b)*L.radDeg}rotateWorld(t){t*=L.degRad;const e=Math.sin(t),i=Math.cos(t),r=this.a,s=this.b;this.a=i*r-e*this.c,this.b=i*s-e*this.d,this.c=e*r+i*this.c,this.d=e*s+i*this.d}},nt=class{constructor(t,e,i){this.name=t,this.order=e,this.skinRequired=i}},vs=class{pathPrefix="";textureLoader;downloader;assets={};assetsRefCount={};assetsLoaded={};errors={};toLoad=0;loaded=0;constructor(t,e="",i=new Si){this.textureLoader=t,this.pathPrefix=e,this.downloader=i}start(t){return this.toLoad++,this.pathPrefix+t}success(t,e,i){this.toLoad--,this.loaded++,this.assets[e]=i,this.assetsRefCount[e]=(this.assetsRefCount[e]||0)+1,t&&t(e,i)}error(t,e,i){this.toLoad--,this.loaded++,this.errors[e]=i,t&&t(e,i)}loadAll(){return new Promise((e,i)=>{let r=()=>{if(this.isLoadingComplete()){this.hasErrors()?i(this.errors):e(this);return}requestAnimationFrame(r)};requestAnimationFrame(r)})}setRawDataURI(t,e){this.downloader.rawDataUris[this.pathPrefix+t]=e}loadBinary(t,e=()=>{},i=()=>{}){t=this.start(t),!this.reuseAssets(t,e,i)&&(this.assetsLoaded[t]=new Promise((r,s)=>{this.downloader.downloadBinary(t,h=>{this.success(e,t,h),r(h)},(h,l)=>{const n=`Couldn't load binary ${t}: status ${h}, ${l}`;this.error(i,t,n),s(n)})}))}loadText(t,e=()=>{},i=()=>{}){t=this.start(t),this.downloader.downloadText(t,r=>{this.success(e,t,r)},(r,s)=>{this.error(i,t,`Couldn't load text ${t}: status ${r}, ${s}`)})}loadJson(t,e=()=>{},i=()=>{}){t=this.start(t),!this.reuseAssets(t,e,i)&&(this.assetsLoaded[t]=new Promise((r,s)=>{this.downloader.downloadJson(t,h=>{this.success(e,t,h),r(h)},(h,l)=>{const n=`Couldn't load JSON ${t}: status ${h}, ${l}`;this.error(i,t,n),s(n)})}))}reuseAssets(t,e=()=>{},i=()=>{}){const r=this.assetsLoaded[t],s=r!==void 0;return s&&r.then(h=>this.success(e,t,h)).catch(h=>this.error(i,t,h)),s}loadTexture(t,e=()=>{},i=()=>{}){t=this.start(t),!this.reuseAssets(t,e,i)&&(this.assetsLoaded[t]=new Promise((r,s)=>{if(!!!(typeof window<"u"&&typeof navigator<"u"&&window.document))fetch(t,{mode:"cors"}).then(n=>{if(n.ok)return n.blob();const a=`Couldn't load image: ${t}`;this.error(i,t,`Couldn't load image: ${t}`),s(a)}).then(n=>n?createImageBitmap(n,{premultiplyAlpha:"none",colorSpaceConversion:"none"}):null).then(n=>{if(n){const a=this.textureLoader(n);this.success(e,t,a),r(a)}});else{let n=new Image;n.crossOrigin="anonymous",n.onload=()=>{const a=this.textureLoader(n);this.success(e,t,a),r(a)},n.onerror=()=>{const a=`Couldn't load image: ${t}`;this.error(i,t,a),s(a)},this.downloader.rawDataUris[t]&&(t=this.downloader.rawDataUris[t]),n.src=t}}))}loadTextureAtlas(t,e=()=>{},i=()=>{},r){let s=t.lastIndexOf("/"),h=s>=0?t.substring(0,s+1):"";t=this.start(t),!this.reuseAssets(t,e,i)&&(this.assetsLoaded[t]=new Promise((l,n)=>{this.downloader.downloadText(t,a=>{try{let o=new bt(a),c=o.pages.length,d=!1;for(let u of o.pages)this.loadTexture(r?r[u.name]:h+u.name,(m,f)=>{d||(u.setTexture(f),--c==0&&(this.success(e,t,o),l(o)))},(m,f)=>{if(!d){const g=`Couldn't load texture atlas ${t} page image: ${m}`;this.error(i,t,g),n(g)}d=!0})}catch(o){const c=`Couldn't parse texture atlas ${t}: ${o.message}`;this.error(i,t,c),n(c)}},(a,o)=>{const c=`Couldn't load texture atlas ${t}: status ${a}, ${o}`;this.error(i,t,c),n(c)})}))}loadTextureAtlasButNoTextures(t,e=()=>{},i=()=>{},r){t=this.start(t),!this.reuseAssets(t,e,i)&&(this.assetsLoaded[t]=new Promise((s,h)=>{this.downloader.downloadText(t,l=>{try{const n=new bt(l);this.success(e,t,n),s(n)}catch(n){const a=`Couldn't parse texture atlas ${t}: ${n.message}`;this.error(i,t,a),h(a)}},(l,n)=>{const a=`Couldn't load texture atlas ${t}: status ${l}, ${n}`;this.error(i,t,a),h(a)})}))}async loadBinaryAsync(t){return new Promise((e,i)=>{this.loadBinary(t,(r,s)=>e(s),(r,s)=>i(s))})}async loadJsonAsync(t){return new Promise((e,i)=>{this.loadJson(t,(r,s)=>e(s),(r,s)=>i(s))})}async loadTextureAsync(t){return new Promise((e,i)=>{this.loadTexture(t,(r,s)=>e(s),(r,s)=>i(s))})}async loadTextureAtlasAsync(t){return new Promise((e,i)=>{this.loadTextureAtlas(t,(r,s)=>e(s),(r,s)=>i(s))})}async loadTextureAtlasButNoTexturesAsync(t){return new Promise((e,i)=>{this.loadTextureAtlasButNoTextures(t,(r,s)=>e(s),(r,s)=>i(s))})}get(t){return this.assets[this.pathPrefix+t]}require(t){t=this.pathPrefix+t;let e=this.assets[t];if(e)return e;let i=this.errors[t];throw Error("Asset not found: "+t+(i?`
2
+ `+i:""))}remove(t){t=this.pathPrefix+t;let e=this.assets[t];return e.dispose&&e.dispose(),delete this.assets[t],delete this.assetsRefCount[t],delete this.assetsLoaded[t],e}removeAll(){for(let t in this.assets){let e=this.assets[t];e.dispose&&e.dispose()}this.assets={},this.assetsLoaded={},this.assetsRefCount={}}isLoadingComplete(){return this.toLoad==0}getToLoad(){return this.toLoad}getLoaded(){return this.loaded}dispose(){this.removeAll()}disposeAsset(t){--this.assetsRefCount[t]===0&&this.remove(t)}hasErrors(){return Object.keys(this.errors).length>0}getErrors(){return this.errors}},Si=class{callbacks={};rawDataUris={};dataUriToString(t){if(!t.startsWith("data:"))throw new Error("Not a data URI.");let e=t.indexOf("base64,");return e!=-1?(e+=7,atob(t.substr(e))):t.substr(t.indexOf(",")+1)}base64ToUint8Array(t){for(var e=window.atob(t),i=e.length,r=new Uint8Array(i),s=0;s<i;s++)r[s]=e.charCodeAt(s);return r}dataUriToUint8Array(t){if(!t.startsWith("data:"))throw new Error("Not a data URI.");let e=t.indexOf("base64,");if(e==-1)throw new Error("Not a binary data URI.");return e+=7,this.base64ToUint8Array(t.substr(e))}downloadText(t,e,i){if(this.start(t,e,i))return;const r=this.rawDataUris[t];if(r&&!r.includes(".")){try{this.finish(t,200,this.dataUriToString(r))}catch(l){this.finish(t,400,JSON.stringify(l))}return}let s=new XMLHttpRequest;s.overrideMimeType("text/html"),s.open("GET",r||t,!0);let h=()=>{this.finish(t,s.status,s.responseText)};s.onload=h,s.onerror=h,s.send()}downloadJson(t,e,i){this.downloadText(t,r=>{e(JSON.parse(r))},i)}downloadBinary(t,e,i){if(this.start(t,e,i))return;const r=this.rawDataUris[t];if(r&&!r.includes(".")){try{this.finish(t,200,this.dataUriToUint8Array(r))}catch(l){this.finish(t,400,JSON.stringify(l))}return}let s=new XMLHttpRequest;s.open("GET",r||t,!0),s.responseType="arraybuffer";let h=()=>{this.finish(t,s.status,s.response)};s.onload=()=>{s.status==200||s.status==0?this.finish(t,200,new Uint8Array(s.response)):h()},s.onerror=h,s.send()}start(t,e,i){let r=this.callbacks[t];try{if(r)return!0;this.callbacks[t]=r=[]}finally{r.push(e,i)}}finish(t,e,i){let r=this.callbacks[t];delete this.callbacks[t];let s=e==200||e==0?[i]:[e,i];for(let h=s.length-1,l=r.length;h<l;h+=2)r[h].apply(null,s)}},Ti=class{data;intValue=0;floatValue=0;stringValue=null;time=0;volume=0;balance=0;constructor(t,e){if(!e)throw new Error("data cannot be null.");this.time=t,this.data=e}},Ii=class{name;intValue=0;floatValue=0;stringValue=null;audioPath=null;volume=0;balance=0;constructor(t){this.name=t}},ys=class{data;bones;target;bendDirection=0;compress=!1;stretch=!1;mix=1;softness=0;active=!1;constructor(t,e){if(!t)throw new Error("data cannot be null.");if(!e)throw new Error("skeleton cannot be null.");this.data=t,this.bones=new Array;for(let r=0;r<t.bones.length;r++){let s=e.findBone(t.bones[r].name);if(!s)throw new Error(`Couldn't find bone ${t.bones[r].name}`);this.bones.push(s)}let i=e.findBone(t.target.name);if(!i)throw new Error(`Couldn't find bone ${t.target.name}`);this.target=i,this.mix=t.mix,this.softness=t.softness,this.bendDirection=t.bendDirection,this.compress=t.compress,this.stretch=t.stretch}isActive(){return this.active}setToSetupPose(){const t=this.data;this.mix=t.mix,this.softness=t.softness,this.bendDirection=t.bendDirection,this.compress=t.compress,this.stretch=t.stretch}update(t){if(this.mix==0)return;let e=this.target,i=this.bones;switch(i.length){case 1:this.apply1(i[0],e.worldX,e.worldY,this.compress,this.stretch,this.data.uniform,this.mix);break;case 2:this.apply2(i[0],i[1],e.worldX,e.worldY,this.bendDirection,this.stretch,this.data.uniform,this.softness,this.mix);break}}apply1(t,e,i,r,s,h,l){let n=t.parent;if(!n)throw new Error("IK bone must have parent.");let a=n.a,o=n.b,c=n.c,d=n.d,u=-t.ashearX-t.arotation,m=0,f=0;switch(t.inherit){case 1:m=(e-t.worldX)*L.signum(t.skeleton.scaleX),f=(i-t.worldY)*L.signum(t.skeleton.scaleY);break;case 2:let b=Math.abs(a*d-o*c)/Math.max(1e-4,a*a+c*c),p=a/t.skeleton.scaleX,w=c/t.skeleton.scaleY;o=-w*b*t.skeleton.scaleX,d=p*b*t.skeleton.scaleY,u+=Math.atan2(w,p)*L.radDeg;default:let v=e-n.worldX,y=i-n.worldY,A=a*d-o*c;Math.abs(A)<=1e-4?(m=0,f=0):(m=(v*d-y*o)/A-t.ax,f=(y*a-v*c)/A-t.ay)}u+=Math.atan2(f,m)*L.radDeg,t.ascaleX<0&&(u+=180),u>180?u-=360:u<-180&&(u+=360);let g=t.ascaleX,x=t.ascaleY;if(r||s){switch(t.inherit){case 3:case 4:m=e-t.worldX,f=i-t.worldY}const b=t.data.length*g;if(b>1e-4){const p=m*m+f*f;if(r&&p<b*b||s&&p>b*b){const w=(Math.sqrt(p)/b-1)*l+1;g*=w,h&&(x*=w)}}}t.updateWorldTransformWith(t.ax,t.ay,t.arotation+u*l,g,x,t.ashearX,t.ashearY)}apply2(t,e,i,r,s,h,l,n,a){if(t.inherit!=0||e.inherit!=0)return;let o=t.ax,c=t.ay,d=t.ascaleX,u=t.ascaleY,m=d,f=u,g=e.ascaleX,x=0,b=0,p=0;d<0?(d=-d,x=180,p=-1):(x=0,p=1),u<0&&(u=-u,p=-p),g<0?(g=-g,b=180):b=0;let w=e.ax,v=0,y=0,A=0,C=t.a,S=t.b,I=t.c,k=t.d,Y=Math.abs(d-u)<=1e-4;!Y||h?(v=0,y=C*w+t.worldX,A=I*w+t.worldY):(v=e.ay,y=C*w+S*v+t.worldX,A=I*w+k*v+t.worldY);let F=t.parent;if(!F)throw new Error("IK parent must itself have a parent.");C=F.a,S=F.b,I=F.c,k=F.d;let P=C*k-S*I,M=y-F.worldX,R=A-F.worldY;P=Math.abs(P)<=1e-4?0:1/P;let B=(M*k-R*S)*P-o,ie=(R*C-M*I)*P-c,te=Math.sqrt(B*B+ie*ie),re=e.data.length*g,de,oe;if(te<1e-4){this.apply1(t,i,r,!1,h,!1,a),e.updateWorldTransformWith(w,v,0,e.ascaleX,e.ascaleY,e.ashearX,e.ashearY);return}M=i-F.worldX,R=r-F.worldY;let me=(M*k-R*S)*P-o,Z=(R*C-M*I)*P-c,ne=me*me+Z*Z;if(n!=0){n*=d*(g+1)*.5;let ge=Math.sqrt(ne),we=ge-te-re*d+n;if(we>0){let be=Math.min(1,we/(n*2))-1;be=(we-n*(1-be*be))/ge,me-=be*me,Z-=be*Z,ne=me*me+Z*Z}}e:if(Y){re*=d;let ge=(ne-te*te-re*re)/(2*te*re);ge<-1?(ge=-1,oe=Math.PI*s):ge>1?(ge=1,oe=0,h&&(C=(Math.sqrt(ne)/(te+re)-1)*a+1,m*=C,l&&(f*=C))):oe=Math.acos(ge)*s,C=te+re*ge,S=re*Math.sin(oe),de=Math.atan2(Z*C-me*S,me*C+Z*S)}else{C=d*re,S=u*re;let ge=C*C,we=S*S,be=Math.atan2(Z,me);I=we*te*te+ge*ne-ge*we;let Re=-2*we*te,$e=we-ge;if(k=Re*Re-4*$e*I,k>=0){let et=Math.sqrt(k);Re<0&&(et=-et),et=-(Re+et)*.5;let ht=et/$e,dr=I/et,kt=Math.abs(ht)<Math.abs(dr)?ht:dr;if(ht=ne-kt*kt,ht>=0){R=Math.sqrt(ht)*s,de=be-Math.atan2(R,kt),oe=Math.atan2(R/u,(kt-te)/d);break e}}let ot=L.PI,Et=te-C,Zi=Et*Et,or=0,hr=0,Rt=te+C,Ji=Rt*Rt,cr=0;I=-C*te/(ge-we),I>=-1&&I<=1&&(I=Math.acos(I),M=C*Math.cos(I)+te,R=S*Math.sin(I),k=M*M+R*R,k<Zi&&(ot=I,Zi=k,Et=M,or=R),k>Ji&&(hr=I,Ji=k,Rt=M,cr=R)),ne<=(Zi+Ji)*.5?(de=be-Math.atan2(or*s,Et),oe=ot*s):(de=be-Math.atan2(cr*s,Rt),oe=hr*s)}let he=Math.atan2(v,w)*p,ve=t.arotation;de=(de-he)*L.radDeg+x-ve,de>180?de-=360:de<-180&&(de+=360),t.updateWorldTransformWith(o,c,ve+de*a,m,f,0,0),ve=e.arotation,oe=((oe+he)*L.radDeg-e.ashearX)*p+b-ve,oe>180?oe-=360:oe<-180&&(oe+=360),e.updateWorldTransformWith(w,v,ve+oe*a,e.ascaleX,e.ascaleY,e.ashearX,e.ashearY)}},Mi=class extends nt{bones=new Array;_target=null;set target(t){this._target=t}get target(){if(this._target)return this._target;throw new Error("BoneData not set.")}bendDirection=0;compress=!1;stretch=!1;uniform=!1;mix=0;softness=0;constructor(t){super(t,0,!1)}},Ei=class extends nt{bones=new Array;_target=null;set target(t){this._target=t}get target(){if(this._target)return this._target;throw new Error("SlotData not set.")}positionMode=0;spacingMode=1;rotateMode=1;offsetRotation=0;position=0;spacing=0;mixRotate=0;mixX=0;mixY=0;constructor(t){super(t,0,!1)}},Ri=(t=>(t[t.Fixed=0]="Fixed",t[t.Percent=1]="Percent",t))(Ri||{}),ki=(t=>(t[t.Length=0]="Length",t[t.Fixed=1]="Fixed",t[t.Percent=2]="Percent",t[t.Proportional=3]="Proportional",t))(ki||{}),Yi=(t=>(t[t.Tangent=0]="Tangent",t[t.Chain=1]="Chain",t[t.ChainScale=2]="ChainScale",t))(Yi||{}),As=class Ne{static NONE=-1;static BEFORE=-2;static AFTER=-3;static epsilon=1e-5;data;bones;target;position=0;spacing=0;mixRotate=0;mixX=0;mixY=0;spaces=new Array;positions=new Array;world=new Array;curves=new Array;lengths=new Array;segments=new Array;active=!1;constructor(e,i){if(!e)throw new Error("data cannot be null.");if(!i)throw new Error("skeleton cannot be null.");this.data=e,this.bones=new Array;for(let s=0,h=e.bones.length;s<h;s++){let l=i.findBone(e.bones[s].name);if(!l)throw new Error(`Couldn't find bone ${e.bones[s].name}.`);this.bones.push(l)}let r=i.findSlot(e.target.name);if(!r)throw new Error(`Couldn't find target bone ${e.target.name}`);this.target=r,this.position=e.position,this.spacing=e.spacing,this.mixRotate=e.mixRotate,this.mixX=e.mixX,this.mixY=e.mixY}isActive(){return this.active}setToSetupPose(){const e=this.data;this.position=e.position,this.spacing=e.spacing,this.mixRotate=e.mixRotate,this.mixX=e.mixX,this.mixY=e.mixY}update(e){let i=this.target.getAttachment();if(!(i instanceof Ze))return;let r=this.mixRotate,s=this.mixX,h=this.mixY;if(r==0&&s==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,u=X.setArraySize(this.spaces,d),m=a?this.lengths=X.setArraySize(this.lengths,c):[],f=this.spacing;switch(l.spacingMode){case 2:if(a)for(let A=0,C=d-1;A<C;A++){let S=o[A],I=S.data.length,k=I*S.a,Y=I*S.c;m[A]=Math.sqrt(k*k+Y*Y)}X.arrayFill(u,1,d,f);break;case 3:let v=0;for(let A=0,C=d-1;A<C;){let S=o[A],I=S.data.length;if(I<Ne.epsilon)a&&(m[A]=0),u[++A]=f;else{let k=I*S.a,Y=I*S.c,F=Math.sqrt(k*k+Y*Y);a&&(m[A]=F),u[++A]=F,v+=F}}if(v>0){v=d/v*f;for(let A=1;A<d;A++)u[A]*=v}break;default:let y=l.spacingMode==0;for(let A=0,C=d-1;A<C;){let S=o[A],I=S.data.length;if(I<Ne.epsilon)a&&(m[A]=0),u[++A]=f;else{let k=I*S.a,Y=I*S.c,F=Math.sqrt(k*k+Y*Y);a&&(m[A]=F),u[++A]=(y?I+f:f)*F/I}}}let g=this.computeWorldPositions(i,d,n),x=g[0],b=g[1],p=l.offsetRotation,w=!1;if(p==0)w=l.rotateMode==1;else{w=!1;let v=this.target.bone;p*=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+=(x-A.worldX)*s,A.worldY+=(b-A.worldY)*h;let C=g[y],S=g[y+1],I=C-x,k=S-b;if(a){let Y=m[v];if(Y!=0){let F=(Math.sqrt(I*I+k*k)/Y-1)*r+1;A.a*=F,A.c*=F}}if(x=C,b=S,r>0){let Y=A.a,F=A.b,P=A.c,M=A.d,R=0,B=0,ie=0;if(n?R=g[y-1]:u[v+1]==0?R=g[y+2]:R=Math.atan2(k,I),R-=Math.atan2(P,Y),w){B=Math.cos(R),ie=Math.sin(R);let te=A.data.length;x+=(te*(B*Y-ie*P)-I)*r,b+=(te*(ie*Y+B*P)-k)*r}else R+=p;R>L.PI?R-=L.PI2:R<-L.PI&&(R+=L.PI2),R*=r,B=Math.cos(R),ie=Math.sin(R),A.a=B*Y-ie*P,A.b=B*F-ie*M,A.c=ie*Y+B*P,A.d=ie*F+B*M}A.updateAppliedTransform()}}computeWorldPositions(e,i,r){let s=this.target,h=this.position,l=this.spaces,n=X.setArraySize(this.positions,i*3+2),a=this.world,o=e.closed,c=e.worldVerticesLength,d=c/6,u=Ne.NONE;if(!e.constantSpeed){let te=e.lengths;d-=o?1:2;let re=te[d];this.data.positionMode==1&&(h*=re);let de;switch(this.data.spacingMode){case 2:de=re;break;case 3:de=re/i;break;default:de=1}a=X.setArraySize(this.world,8);for(let oe=0,me=0,Z=0;oe<i;oe++,me+=3){let ne=l[oe]*de;h+=ne;let he=h;if(o)he%=re,he<0&&(he+=re),Z=0;else if(he<0){u!=Ne.BEFORE&&(u=Ne.BEFORE,e.computeWorldVertices(s,2,4,a,0,2)),this.addBeforePosition(he,a,0,n,me);continue}else if(he>re){u!=Ne.AFTER&&(u=Ne.AFTER,e.computeWorldVertices(s,c-6,4,a,0,2)),this.addAfterPosition(he-re,a,0,n,me);continue}for(;;Z++){let ve=te[Z];if(!(he>ve)){if(Z==0)he/=ve;else{let ge=te[Z-1];he=(he-ge)/(ve-ge)}break}}Z!=u&&(u=Z,o&&Z==d?(e.computeWorldVertices(s,c-4,4,a,0,2),e.computeWorldVertices(s,0,4,a,4,2)):e.computeWorldVertices(s,Z*6+2,8,a,0,2)),this.addCurvePosition(he,a[0],a[1],a[2],a[3],a[4],a[5],a[6],a[7],n,me,r||oe>0&&ne==0)}return n}o?(c+=2,a=X.setArraySize(this.world,c),e.computeWorldVertices(s,2,c-4,a,0,2),e.computeWorldVertices(s,0,2,a,c-4,2),a[c-2]=a[0],a[c-1]=a[1]):(d--,c-=4,a=X.setArraySize(this.world,c),e.computeWorldVertices(s,2,c,a,0,2));let m=X.setArraySize(this.curves,d),f=0,g=a[0],x=a[1],b=0,p=0,w=0,v=0,y=0,A=0,C=0,S=0,I=0,k=0,Y=0,F=0,P=0,M=0;for(let te=0,re=2;te<d;te++,re+=6)b=a[re],p=a[re+1],w=a[re+2],v=a[re+3],y=a[re+4],A=a[re+5],C=(g-b*2+w)*.1875,S=(x-p*2+v)*.1875,I=((b-w)*3-g+y)*.09375,k=((p-v)*3-x+A)*.09375,Y=C*2+I,F=S*2+k,P=(b-g)*.75+C+I*.16666667,M=(p-x)*.75+S+k*.16666667,f+=Math.sqrt(P*P+M*M),P+=Y,M+=F,Y+=I,F+=k,f+=Math.sqrt(P*P+M*M),P+=Y,M+=F,f+=Math.sqrt(P*P+M*M),P+=Y+I,M+=F+k,f+=Math.sqrt(P*P+M*M),m[te]=f,g=y,x=A;this.data.positionMode==1&&(h*=f);let R;switch(this.data.spacingMode){case 2:R=f;break;case 3:R=f/i;break;default:R=1}let B=this.segments,ie=0;for(let te=0,re=0,de=0,oe=0;te<i;te++,re+=3){let me=l[te]*R;h+=me;let Z=h;if(o)Z%=f,Z<0&&(Z+=f),de=0;else if(Z<0){this.addBeforePosition(Z,a,0,n,re);continue}else if(Z>f){this.addAfterPosition(Z-f,a,c-4,n,re);continue}for(;;de++){let ne=m[de];if(!(Z>ne)){if(de==0)Z/=ne;else{let he=m[de-1];Z=(Z-he)/(ne-he)}break}}if(de!=u){u=de;let ne=de*6;for(g=a[ne],x=a[ne+1],b=a[ne+2],p=a[ne+3],w=a[ne+4],v=a[ne+5],y=a[ne+6],A=a[ne+7],C=(g-b*2+w)*.03,S=(x-p*2+v)*.03,I=((b-w)*3-g+y)*.006,k=((p-v)*3-x+A)*.006,Y=C*2+I,F=S*2+k,P=(b-g)*.3+C+I*.16666667,M=(p-x)*.3+S+k*.16666667,ie=Math.sqrt(P*P+M*M),B[0]=ie,ne=1;ne<8;ne++)P+=Y,M+=F,Y+=I,F+=k,ie+=Math.sqrt(P*P+M*M),B[ne]=ie;P+=Y,M+=F,ie+=Math.sqrt(P*P+M*M),B[8]=ie,P+=Y+I,M+=F+k,ie+=Math.sqrt(P*P+M*M),B[9]=ie,oe=0}for(Z*=ie;;oe++){let ne=B[oe];if(!(Z>ne)){if(oe==0)Z/=ne;else{let he=B[oe-1];Z=oe+(Z-he)/(ne-he)}break}}this.addCurvePosition(Z*.1,g,x,b,p,w,v,y,A,n,re,r||te>0&&me==0)}return n}addBeforePosition(e,i,r,s,h){let l=i[r],n=i[r+1],a=i[r+2]-l,o=i[r+3]-n,c=Math.atan2(o,a);s[h]=l+e*Math.cos(c),s[h+1]=n+e*Math.sin(c),s[h+2]=c}addAfterPosition(e,i,r,s,h){let l=i[r+2],n=i[r+3],a=l-i[r],o=n-i[r+1],c=Math.atan2(o,a);s[h]=l+e*Math.cos(c),s[h+1]=n+e*Math.sin(c),s[h+2]=c}addCurvePosition(e,i,r,s,h,l,n,a,o,c,d,u){if(e==0||isNaN(e)){c[d]=i,c[d+1]=r,c[d+2]=Math.atan2(h-r,s-i);return}let m=e*e,f=m*e,g=1-e,x=g*g,b=x*g,p=g*e,w=p*3,v=g*w,y=w*e,A=i*b+s*v+l*y+a*f,C=r*b+h*v+n*y+o*f;c[d]=A,c[d+1]=C,u&&(e<.001?c[d+2]=Math.atan2(h-r,s-i):c[d+2]=Math.atan2(C-(r*x+h*p*2+n*m),A-(i*x+s*p*2+l*m)))}},Wr=class{data;_bone=null;set bone(t){this._bone=t}get bone(){if(this._bone)return this._bone;throw new Error("Bone not set.")}inertia=0;strength=0;damping=0;massInverse=0;wind=0;gravity=0;mix=0;_reset=!0;ux=0;uy=0;cx=0;cy=0;tx=0;ty=0;xOffset=0;xVelocity=0;yOffset=0;yVelocity=0;rotateOffset=0;rotateVelocity=0;scaleOffset=0;scaleVelocity=0;active=!1;skeleton;remaining=0;lastTime=0;constructor(t,e){this.data=t,this.skeleton=e,this.bone=e.bones[t.bone.index],this.inertia=t.inertia,this.strength=t.strength,this.damping=t.damping,this.massInverse=t.massInverse,this.wind=t.wind,this.gravity=t.gravity,this.mix=t.mix}reset(){this.remaining=0,this.lastTime=this.skeleton.time,this._reset=!0,this.xOffset=0,this.xVelocity=0,this.yOffset=0,this.yVelocity=0,this.rotateOffset=0,this.rotateVelocity=0,this.scaleOffset=0,this.scaleVelocity=0}setToSetupPose(){const t=this.data;this.inertia=t.inertia,this.strength=t.strength,this.damping=t.damping,this.massInverse=t.massInverse,this.wind=t.wind,this.gravity=t.gravity,this.mix=t.mix}isActive(){return this.active}update(t){const e=this.mix;if(e==0)return;const i=this.data.x>0,r=this.data.y>0,s=this.data.rotate>0||this.data.shearX>0,h=this.data.scaleX>0,l=this.bone,n=l.data.length;switch(t){case 0:return;case 1:this.reset();case 2:const a=this.skeleton,o=Math.max(this.skeleton.time-this.lastTime,0);this.remaining+=o,this.lastTime=a.time;const c=l.worldX,d=l.worldY;if(this._reset)this._reset=!1,this.ux=c,this.uy=d;else{let u=this.remaining,m=this.inertia,f=this.data.step,g=this.skeleton.data.referenceScale,x=-1,b=this.data.limit*o,p=b*Math.abs(a.scaleY);if(b*=Math.abs(a.scaleX),i||r){if(i){const w=(this.ux-c)*m;this.xOffset+=w>b?b:w<-b?-b:w,this.ux=c}if(r){const w=(this.uy-d)*m;this.yOffset+=w>p?p:w<-p?-p:w,this.uy=d}if(u>=f){x=Math.pow(this.damping,60*f);const w=this.massInverse*f,v=this.strength,y=this.wind*g*a.scaleX,A=this.gravity*g*a.scaleY;do i&&(this.xVelocity+=(y-this.xOffset*v)*w,this.xOffset+=this.xVelocity*f,this.xVelocity*=x),r&&(this.yVelocity-=(A+this.yOffset*v)*w,this.yOffset+=this.yVelocity*f,this.yVelocity*=x),u-=f;while(u>=f)}i&&(l.worldX+=this.xOffset*e*this.data.x),r&&(l.worldY+=this.yOffset*e*this.data.y)}if(s||h){let w=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>p?S=p:S<-p&&(S=-p),s){A=(this.data.rotate+this.data.shearX)*e;let I=Math.atan2(S+this.ty,C+this.tx)-w-this.rotateOffset*A;this.rotateOffset+=(I-Math.ceil(I*L.invPI2-.5)*L.PI2)*m,I=this.rotateOffset*A+w,v=Math.cos(I),y=Math.sin(I),h&&(I=n*l.getWorldScaleX(),I>0&&(this.scaleOffset+=(C*v+S*y)*m/I))}else{v=Math.cos(w),y=Math.sin(w);const I=n*l.getWorldScaleX();I>0&&(this.scaleOffset+=(C*v+S*y)*m/I)}if(u=this.remaining,u>=f){x==-1&&(x=Math.pow(this.damping,60*f));const I=this.massInverse*f,k=this.strength,Y=this.wind,F=Je.yDown?-this.gravity:this.gravity,P=n/g;for(;;)if(u-=f,h&&(this.scaleVelocity+=(Y*v-F*y-this.scaleOffset*k)*I,this.scaleOffset+=this.scaleVelocity*f,this.scaleVelocity*=x),s){if(this.rotateVelocity-=((Y*y+F*v)*P+this.rotateOffset*k)*I,this.rotateOffset+=this.rotateVelocity*f,this.rotateVelocity*=x,u<f)break;const M=this.rotateOffset*A+w;v=Math.cos(M),y=Math.sin(M)}else if(u<f)break}}this.remaining=u}this.cx=l.worldX,this.cy=l.worldY;break;case 3:i&&(l.worldX+=this.xOffset*e*this.data.x),r&&(l.worldY+=this.yOffset*e*this.data.y)}if(s){let a=this.rotateOffset*e,o=0,c=0,d=0;if(this.data.shearX>0){let u=0;this.data.rotate>0&&(u=a*this.data.rotate,o=Math.sin(u),c=Math.cos(u),d=l.b,l.b=c*d-o*l.d,l.d=o*d+c*l.d),u+=a*this.data.shearX,o=Math.sin(u),c=Math.cos(u),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*e*this.data.scaleX;l.a*=a,l.c*=a}t!=3&&(this.tx=n*l.a,this.ty=n*l.c),l.updateAppliedTransform()}translate(t,e){this.ux-=t,this.uy-=e,this.cx-=t,this.cy-=e}rotate(t,e,i){const r=i*L.degRad,s=Math.cos(r),h=Math.sin(r),l=this.cx-t,n=this.cy-e;this.translate(l*s-n*h-l,l*h+n*s-n)}},Cs=class{data;bone;color;darkColor=null;attachment=null;attachmentState=0;sequenceIndex=-1;deform=new Array;constructor(t,e){if(!t)throw new Error("data cannot be null.");if(!e)throw new Error("bone cannot be null.");this.data=t,this.bone=e,this.color=new K,this.darkColor=t.darkColor?new K:null,this.setToSetupPose()}getSkeleton(){return this.bone.skeleton}getAttachment(){return this.attachment}setAttachment(t){this.attachment!=t&&((!(t instanceof Fe)||!(this.attachment instanceof Fe)||t.timelineAttachment!=this.attachment.timelineAttachment)&&(this.deform.length=0),this.attachment=t,this.sequenceIndex=-1)}setToSetupPose(){this.color.setFromColor(this.data.color),this.darkColor&&this.darkColor.setFromColor(this.data.darkColor),this.data.attachmentName?(this.attachment=null,this.setAttachment(this.bone.skeleton.getAttachment(this.data.index,this.data.attachmentName))):this.attachment=null}},Ss=class{data;bones;target;mixRotate=0;mixX=0;mixY=0;mixScaleX=0;mixScaleY=0;mixShearY=0;temp=new Ue;active=!1;constructor(t,e){if(!t)throw new Error("data cannot be null.");if(!e)throw new Error("skeleton cannot be null.");this.data=t,this.bones=new Array;for(let r=0;r<t.bones.length;r++){let s=e.findBone(t.bones[r].name);if(!s)throw new Error(`Couldn't find bone ${t.bones[r].name}.`);this.bones.push(s)}let i=e.findBone(t.target.name);if(!i)throw new Error(`Couldn't find target bone ${t.target.name}.`);this.target=i,this.mixRotate=t.mixRotate,this.mixX=t.mixX,this.mixY=t.mixY,this.mixScaleX=t.mixScaleX,this.mixScaleY=t.mixScaleY,this.mixShearY=t.mixShearY}isActive(){return this.active}setToSetupPose(){const t=this.data;this.mixRotate=t.mixRotate,this.mixX=t.mixX,this.mixY=t.mixY,this.mixScaleX=t.mixScaleX,this.mixScaleY=t.mixScaleY,this.mixShearY=t.mixShearY}update(t){this.mixRotate==0&&this.mixX==0&&this.mixY==0&&this.mixScaleX==0&&this.mixScaleY==0&&this.mixShearY==0||(this.data.local?this.data.relative?this.applyRelativeLocal():this.applyAbsoluteLocal():this.data.relative?this.applyRelativeWorld():this.applyAbsoluteWorld())}applyAbsoluteWorld(){let t=this.mixRotate,e=this.mixX,i=this.mixY,r=this.mixScaleX,s=this.mixScaleY,h=this.mixShearY,l=e!=0||i!=0,n=this.target,a=n.a,o=n.b,c=n.c,d=n.d,u=a*d-o*c>0?L.degRad:-L.degRad,m=this.data.offsetRotation*u,f=this.data.offsetShearY*u,g=this.bones;for(let x=0,b=g.length;x<b;x++){let p=g[x];if(t!=0){let w=p.a,v=p.b,y=p.c,A=p.d,C=Math.atan2(c,a)-Math.atan2(y,w)+m;C>L.PI?C-=L.PI2:C<-L.PI&&(C+=L.PI2),C*=t;let S=Math.cos(C),I=Math.sin(C);p.a=S*w-I*y,p.b=S*v-I*A,p.c=I*w+S*y,p.d=I*v+S*A}if(l){let w=this.temp;n.localToWorld(w.set(this.data.offsetX,this.data.offsetY)),p.worldX+=(w.x-p.worldX)*e,p.worldY+=(w.y-p.worldY)*i}if(r!=0){let w=Math.sqrt(p.a*p.a+p.c*p.c);w!=0&&(w=(w+(Math.sqrt(a*a+c*c)-w+this.data.offsetScaleX)*r)/w),p.a*=w,p.c*=w}if(s!=0){let w=Math.sqrt(p.b*p.b+p.d*p.d);w!=0&&(w=(w+(Math.sqrt(o*o+d*d)-w+this.data.offsetScaleY)*s)/w),p.b*=w,p.d*=w}if(h>0){let w=p.b,v=p.d,y=Math.atan2(v,w),A=Math.atan2(d,o)-Math.atan2(c,a)-(y-Math.atan2(p.c,p.a));A>L.PI?A-=L.PI2:A<-L.PI&&(A+=L.PI2),A=y+(A+f)*h;let C=Math.sqrt(w*w+v*v);p.b=Math.cos(A)*C,p.d=Math.sin(A)*C}p.updateAppliedTransform()}}applyRelativeWorld(){let t=this.mixRotate,e=this.mixX,i=this.mixY,r=this.mixScaleX,s=this.mixScaleY,h=this.mixShearY,l=e!=0||i!=0,n=this.target,a=n.a,o=n.b,c=n.c,d=n.d,u=a*d-o*c>0?L.degRad:-L.degRad,m=this.data.offsetRotation*u,f=this.data.offsetShearY*u,g=this.bones;for(let x=0,b=g.length;x<b;x++){let p=g[x];if(t!=0){let w=p.a,v=p.b,y=p.c,A=p.d,C=Math.atan2(c,a)+m;C>L.PI?C-=L.PI2:C<-L.PI&&(C+=L.PI2),C*=t;let S=Math.cos(C),I=Math.sin(C);p.a=S*w-I*y,p.b=S*v-I*A,p.c=I*w+S*y,p.d=I*v+S*A}if(l){let w=this.temp;n.localToWorld(w.set(this.data.offsetX,this.data.offsetY)),p.worldX+=w.x*e,p.worldY+=w.y*i}if(r!=0){let w=(Math.sqrt(a*a+c*c)-1+this.data.offsetScaleX)*r+1;p.a*=w,p.c*=w}if(s!=0){let w=(Math.sqrt(o*o+d*d)-1+this.data.offsetScaleY)*s+1;p.b*=w,p.d*=w}if(h>0){let w=Math.atan2(d,o)-Math.atan2(c,a);w>L.PI?w-=L.PI2:w<-L.PI&&(w+=L.PI2);let v=p.b,y=p.d;w=Math.atan2(y,v)+(w-L.PI/2+f)*h;let A=Math.sqrt(v*v+y*y);p.b=Math.cos(w)*A,p.d=Math.sin(w)*A}p.updateAppliedTransform()}}applyAbsoluteLocal(){let t=this.mixRotate,e=this.mixX,i=this.mixY,r=this.mixScaleX,s=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;t!=0&&(d+=(l.arotation-d+this.data.offsetRotation)*t);let u=c.ax,m=c.ay;u+=(l.ax-u+this.data.offsetX)*e,m+=(l.ay-m+this.data.offsetY)*i;let f=c.ascaleX,g=c.ascaleY;r!=0&&f!=0&&(f=(f+(l.ascaleX-f+this.data.offsetScaleX)*r)/f),s!=0&&g!=0&&(g=(g+(l.ascaleY-g+this.data.offsetScaleY)*s)/g);let x=c.ashearY;h!=0&&(x+=(l.ashearY-x+this.data.offsetShearY)*h),c.updateWorldTransformWith(u,m,d,f,g,c.ashearX,x)}}applyRelativeLocal(){let t=this.mixRotate,e=this.mixX,i=this.mixY,r=this.mixScaleX,s=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)*t,u=c.ax+(l.ax+this.data.offsetX)*e,m=c.ay+(l.ay+this.data.offsetY)*i,f=c.ascaleX*((l.ascaleX-1+this.data.offsetScaleX)*r+1),g=c.ascaleY*((l.ascaleY-1+this.data.offsetScaleY)*s+1),x=c.ashearY+(l.ashearY+this.data.offsetShearY)*h;c.updateWorldTransformWith(u,m,d,f,g,c.ashearX,x)}}},Je=class Qi{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 Qi.yDown?-this._scaleY:this._scaleY}set scaleY(e){this._scaleY=e}x=0;y=0;time=0;constructor(e){if(!e)throw new Error("data cannot be null.");this.data=e,this.bones=new Array;for(let i=0;i<e.bones.length;i++){let r=e.bones[i],s;if(!r.parent)s=new Ci(r,this,null);else{let h=this.bones[r.parent.index];s=new Ci(r,this,h),h.children.push(s)}this.bones.push(s)}this.slots=new Array,this.drawOrder=new Array;for(let i=0;i<e.slots.length;i++){let r=e.slots[i],s=this.bones[r.boneData.index],h=new Cs(r,s);this.slots.push(h),this.drawOrder.push(h)}this.ikConstraints=new Array;for(let i=0;i<e.ikConstraints.length;i++){let r=e.ikConstraints[i];this.ikConstraints.push(new ys(r,this))}this.transformConstraints=new Array;for(let i=0;i<e.transformConstraints.length;i++){let r=e.transformConstraints[i];this.transformConstraints.push(new Ss(r,this))}this.pathConstraints=new Array;for(let i=0;i<e.pathConstraints.length;i++){let r=e.pathConstraints[i];this.pathConstraints.push(new As(r,this))}this.physicsConstraints=new Array;for(let i=0;i<e.physicsConstraints.length;i++){let r=e.physicsConstraints[i];this.physicsConstraints.push(new Wr(r,this))}this.color=new K(1,1,1,1),this.updateCache()}updateCache(){let e=this._updateCache;e.length=0;let i=this.bones;for(let u=0,m=i.length;u<m;u++){let f=i[u];f.sorted=f.data.skinRequired,f.active=!f.sorted}if(this.skin){let u=this.skin.bones;for(let m=0,f=this.skin.bones.length;m<f;m++){let g=this.bones[u[m].index];do g.sorted=!1,g.active=!0,g=g.parent;while(g)}}let r=this.ikConstraints,s=this.transformConstraints,h=this.pathConstraints,l=this.physicsConstraints,n=r.length,a=s.length,o=h.length,c=this.physicsConstraints.length,d=n+a+o+c;e:for(let u=0;u<d;u++){for(let m=0;m<n;m++){let f=r[m];if(f.data.order==u){this.sortIkConstraint(f);continue e}}for(let m=0;m<a;m++){let f=s[m];if(f.data.order==u){this.sortTransformConstraint(f);continue e}}for(let m=0;m<o;m++){let f=h[m];if(f.data.order==u){this.sortPathConstraint(f);continue e}}for(let m=0;m<c;m++){const f=l[m];if(f.data.order==u){this.sortPhysicsConstraint(f);continue e}}}for(let u=0,m=i.length;u<m;u++)this.sortBone(i[u])}sortIkConstraint(e){if(e.active=e.target.isActive()&&(!e.data.skinRequired||this.skin&&X.contains(this.skin.constraints,e.data,!0)),!e.active)return;let i=e.target;this.sortBone(i);let r=e.bones,s=r[0];if(this.sortBone(s),r.length==1)this._updateCache.push(e),this.sortReset(s.children);else{let h=r[r.length-1];this.sortBone(h),this._updateCache.push(e),this.sortReset(s.children),h.sorted=!0}}sortPathConstraint(e){if(e.active=e.target.bone.isActive()&&(!e.data.skinRequired||this.skin&&X.contains(this.skin.constraints,e.data,!0)),!e.active)return;let i=e.target,r=i.data.index,s=i.bone;this.skin&&this.sortPathConstraintAttachment(this.skin,r,s),this.data.defaultSkin&&this.data.defaultSkin!=this.skin&&this.sortPathConstraintAttachment(this.data.defaultSkin,r,s);for(let a=0,o=this.data.skins.length;a<o;a++)this.sortPathConstraintAttachment(this.data.skins[a],r,s);let h=i.getAttachment();h instanceof Ze&&this.sortPathConstraintAttachmentWith(h,s);let l=e.bones,n=l.length;for(let a=0;a<n;a++)this.sortBone(l[a]);this._updateCache.push(e);for(let a=0;a<n;a++)this.sortReset(l[a].children);for(let a=0;a<n;a++)l[a].sorted=!0}sortTransformConstraint(e){if(e.active=e.target.isActive()&&(!e.data.skinRequired||this.skin&&X.contains(this.skin.constraints,e.data,!0)),!e.active)return;this.sortBone(e.target);let i=e.bones,r=i.length;if(e.data.local)for(let s=0;s<r;s++){let h=i[s];this.sortBone(h.parent),this.sortBone(h)}else for(let s=0;s<r;s++)this.sortBone(i[s]);this._updateCache.push(e);for(let s=0;s<r;s++)this.sortReset(i[s].children);for(let s=0;s<r;s++)i[s].sorted=!0}sortPathConstraintAttachment(e,i,r){let s=e.attachments[i];if(s)for(let h in s)this.sortPathConstraintAttachmentWith(s[h],r)}sortPathConstraintAttachmentWith(e,i){if(!(e instanceof Ze))return;let r=e.bones;if(!r)this.sortBone(i);else{let s=this.bones;for(let h=0,l=r.length;h<l;){let n=r[h++];for(n+=h;h<n;)this.sortBone(s[r[h++]])}}}sortPhysicsConstraint(e){const i=e.bone;e.active=i.active&&(!e.data.skinRequired||this.skin!=null&&X.contains(this.skin.constraints,e.data,!0)),e.active&&(this.sortBone(i),this._updateCache.push(e),this.sortReset(i.children),i.sorted=!0)}sortBone(e){if(!e||e.sorted)return;let i=e.parent;i&&this.sortBone(i),e.sorted=!0,this._updateCache.push(e)}sortReset(e){for(let i=0,r=e.length;i<r;i++){let s=e[i];s.active&&(s.sorted&&this.sortReset(s.children),s.sorted=!1)}}updateWorldTransform(e){if(e==null)throw new Error("physics is undefined");let i=this.bones;for(let s=0,h=i.length;s<h;s++){let l=i[s];l.ax=l.x,l.ay=l.y,l.arotation=l.rotation,l.ascaleX=l.scaleX,l.ascaleY=l.scaleY,l.ashearX=l.shearX,l.ashearY=l.shearY}let r=this._updateCache;for(let s=0,h=r.length;s<h;s++)r[s].update(e)}updateWorldTransformWith(e,i){if(!i)throw new Error("parent cannot be null.");let r=this.bones;for(let x=1,b=r.length;x<b;x++){let p=r[x];p.ax=p.x,p.ay=p.y,p.arotation=p.rotation,p.ascaleX=p.scaleX,p.ascaleY=p.scaleY,p.ashearX=p.shearX,p.ashearY=p.shearY}let s=this.getRootBone();if(!s)throw new Error("Root bone must not be null.");let h=i.a,l=i.b,n=i.c,a=i.d;s.worldX=h*this.x+l*this.y+i.worldX,s.worldY=n*this.x+a*this.y+i.worldY;const o=(s.rotation+s.shearX)*L.degRad,c=(s.rotation+90+s.shearY)*L.degRad,d=Math.cos(o)*s.scaleX,u=Math.cos(c)*s.scaleY,m=Math.sin(o)*s.scaleX,f=Math.sin(c)*s.scaleY;s.a=(h*d+l*m)*this.scaleX,s.b=(h*u+l*f)*this.scaleX,s.c=(n*d+a*m)*this.scaleY,s.d=(n*u+a*f)*this.scaleY;let g=this._updateCache;for(let x=0,b=g.length;x<b;x++){let p=g[x];p!=s&&p.update(e)}}setToSetupPose(){this.setBonesToSetupPose(),this.setSlotsToSetupPose()}setBonesToSetupPose(){for(const e of this.bones)e.setToSetupPose();for(const e of this.ikConstraints)e.setToSetupPose();for(const e of this.transformConstraints)e.setToSetupPose();for(const e of this.pathConstraints)e.setToSetupPose();for(const e of this.physicsConstraints)e.setToSetupPose()}setSlotsToSetupPose(){let e=this.slots;X.arrayCopy(e,0,this.drawOrder,0,e.length);for(let i=0,r=e.length;i<r;i++)e[i].setToSetupPose()}getRootBone(){return this.bones.length==0?null:this.bones[0]}findBone(e){if(!e)throw new Error("boneName cannot be null.");let i=this.bones;for(let r=0,s=i.length;r<s;r++){let h=i[r];if(h.data.name==e)return h}return null}findSlot(e){if(!e)throw new Error("slotName cannot be null.");let i=this.slots;for(let r=0,s=i.length;r<s;r++){let h=i[r];if(h.data.name==e)return h}return null}setSkinByName(e){let i=this.data.findSkin(e);if(!i)throw new Error("Skin not found: "+e);this.setSkin(i)}setSkin(e){if(e!=this.skin){if(e)if(this.skin)e.attachAll(this,this.skin);else{let i=this.slots;for(let r=0,s=i.length;r<s;r++){let h=i[r],l=h.data.attachmentName;if(l){let n=e.getAttachment(r,l);n&&h.setAttachment(n)}}}this.skin=e,this.updateCache()}}getAttachmentByName(e,i){let r=this.data.findSlot(e);if(!r)throw new Error(`Can't find slot with name ${e}`);return this.getAttachment(r.index,i)}getAttachment(e,i){if(!i)throw new Error("attachmentName cannot be null.");if(this.skin){let r=this.skin.getAttachment(e,i);if(r)return r}return this.data.defaultSkin?this.data.defaultSkin.getAttachment(e,i):null}setAttachment(e,i){if(!e)throw new Error("slotName cannot be null.");let r=this.slots;for(let s=0,h=r.length;s<h;s++){let l=r[s];if(l.data.name==e){let n=null;if(i&&(n=this.getAttachment(s,i),!n))throw new Error("Attachment not found: "+i+", for slot: "+e);l.setAttachment(n);return}}throw new Error("Slot not found: "+e)}findIkConstraint(e){if(!e)throw new Error("constraintName cannot be null.");return this.ikConstraints.find(i=>i.data.name==e)??null}findTransformConstraint(e){if(!e)throw new Error("constraintName cannot be null.");return this.transformConstraints.find(i=>i.data.name==e)??null}findPathConstraint(e){if(!e)throw new Error("constraintName cannot be null.");return this.pathConstraints.find(i=>i.data.name==e)??null}findPhysicsConstraint(e){if(e==null)throw new Error("constraintName cannot be null.");return this.physicsConstraints.find(i=>i.data.name==e)??null}getBoundsRect(e){let i=new Ue,r=new Ue;return this.getBounds(i,r,void 0,e),{x:i.x,y:i.y,width:r.x,height:r.y}}getBounds(e,i,r=new Array(2),s=null){if(!e)throw new Error("offset cannot be null.");if(!i)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 u=h[c];if(!u.bone.active)continue;let m=0,f=null,g=null,x=u.getAttachment();if(x instanceof ce)m=8,f=X.setArraySize(r,m,0),x.computeWorldVertices(u,f,0,2),g=Qi.quadTriangles;else if(x instanceof Ge){let b=x;m=b.worldVerticesLength,f=X.setArraySize(r,m,0),b.computeWorldVertices(u,0,m,f,0,2),g=b.triangles}else if(x instanceof rt&&s!=null){s.clipStart(u,x);continue}if(f&&g){s!=null&&s.isClipping()&&(s.clipTriangles(f,g,g.length),f=s.clippedVertices,m=s.clippedVertices.length);for(let b=0,p=f.length;b<p;b+=2){let w=f[b],v=f[b+1];l=Math.min(l,w),n=Math.min(n,v),a=Math.max(a,w),o=Math.max(o,v)}}s?.clipEndWithSlot(u)}s?.clipEnd(),e.set(l,n),i.set(a-l,o-n)}update(e){this.time+=e}physicsTranslate(e,i){const r=this.physicsConstraints;for(let s=0,h=r.length;s<h;s++)r[s].translate(e,i)}physicsRotate(e,i,r){const s=this.physicsConstraints;for(let h=0,l=s.length;h<l;h++)s[h].rotate(e,i,r)}},Ts=(t=>(t[t.none=0]="none",t[t.reset=1]="reset",t[t.update=2]="update",t[t.pose=3]="pose",t))(Ts||{}),Is=class extends nt{_bone=null;set bone(t){this._bone=t}get bone(){if(this._bone)return this._bone;throw new Error("BoneData not set.")}x=0;y=0;rotate=0;scaleX=0;shearX=0;limit=0;step=0;inertia=0;strength=0;damping=0;massInverse=0;wind=0;gravity=0;mix=0;inertiaGlobal=!1;strengthGlobal=!1;dampingGlobal=!1;massGlobal=!1;windGlobal=!1;gravityGlobal=!1;mixGlobal=!1;constructor(t){super(t,0,!1)}},Fi=class{name=null;bones=new Array;slots=new Array;skins=new Array;defaultSkin=null;events=new Array;animations=new Array;ikConstraints=new Array;transformConstraints=new Array;pathConstraints=new Array;physicsConstraints=new Array;x=0;y=0;width=0;height=0;referenceScale=100;version=null;hash=null;fps=0;imagesPath=null;audioPath=null;findBone(t){if(!t)throw new Error("boneName cannot be null.");let e=this.bones;for(let i=0,r=e.length;i<r;i++){let s=e[i];if(s.name==t)return s}return null}findSlot(t){if(!t)throw new Error("slotName cannot be null.");let e=this.slots;for(let i=0,r=e.length;i<r;i++){let s=e[i];if(s.name==t)return s}return null}findSkin(t){if(!t)throw new Error("skinName cannot be null.");let e=this.skins;for(let i=0,r=e.length;i<r;i++){let s=e[i];if(s.name==t)return s}return null}findEvent(t){if(!t)throw new Error("eventDataName cannot be null.");let e=this.events;for(let i=0,r=e.length;i<r;i++){let s=e[i];if(s.name==t)return s}return null}findAnimation(t){if(!t)throw new Error("animationName cannot be null.");let e=this.animations;for(let i=0,r=e.length;i<r;i++){let s=e[i];if(s.name==t)return s}return null}findIkConstraint(t){if(!t)throw new Error("constraintName cannot be null.");const e=this.ikConstraints;for(let i=0,r=e.length;i<r;i++){const s=e[i];if(s.name==t)return s}return null}findTransformConstraint(t){if(!t)throw new Error("constraintName cannot be null.");const e=this.transformConstraints;for(let i=0,r=e.length;i<r;i++){const s=e[i];if(s.name==t)return s}return null}findPathConstraint(t){if(!t)throw new Error("constraintName cannot be null.");const e=this.pathConstraints;for(let i=0,r=e.length;i<r;i++){const s=e[i];if(s.name==t)return s}return null}findPhysicsConstraint(t){if(!t)throw new Error("constraintName cannot be null.");const e=this.physicsConstraints;for(let i=0,r=e.length;i<r;i++){const s=e[i];if(s.name==t)return s}return null}},Pi=class{constructor(t=0,e,i){this.slotIndex=t,this.name=e,this.attachment=i}},at=class{name;attachments=new Array;bones=Array();constraints=new Array;color=new K(.99607843,.61960787,.30980393,1);constructor(t){if(!t)throw new Error("name cannot be null.");this.name=t}setAttachment(t,e,i){if(!i)throw new Error("attachment cannot be null.");let r=this.attachments;t>=r.length&&(r.length=t+1),r[t]||(r[t]={}),r[t][e]=i}addSkin(t){for(let r=0;r<t.bones.length;r++){let s=t.bones[r],h=!1;for(let l=0;l<this.bones.length;l++)if(this.bones[l]==s){h=!0;break}h||this.bones.push(s)}for(let r=0;r<t.constraints.length;r++){let s=t.constraints[r],h=!1;for(let l=0;l<this.constraints.length;l++)if(this.constraints[l]==s){h=!0;break}h||this.constraints.push(s)}let e=t.getAttachments();for(let r=0;r<e.length;r++){var i=e[r];this.setAttachment(i.slotIndex,i.name,i.attachment)}}copySkin(t){for(let r=0;r<t.bones.length;r++){let s=t.bones[r],h=!1;for(let l=0;l<this.bones.length;l++)if(this.bones[l]==s){h=!0;break}h||this.bones.push(s)}for(let r=0;r<t.constraints.length;r++){let s=t.constraints[r],h=!1;for(let l=0;l<this.constraints.length;l++)if(this.constraints[l]==s){h=!0;break}h||this.constraints.push(s)}let e=t.getAttachments();for(let r=0;r<e.length;r++){var i=e[r];i.attachment&&(i.attachment instanceof Ge?(i.attachment=i.attachment.newLinkedMesh(),this.setAttachment(i.slotIndex,i.name,i.attachment)):(i.attachment=i.attachment.copy(),this.setAttachment(i.slotIndex,i.name,i.attachment)))}}getAttachment(t,e){let i=this.attachments[t];return i?i[e]:null}removeAttachment(t,e){let i=this.attachments[t];i&&delete i[e]}getAttachments(){let t=new Array;for(var e=0;e<this.attachments.length;e++){let i=this.attachments[e];if(i)for(let r in i){let s=i[r];s&&t.push(new Pi(e,r,s))}}return t}getAttachmentsForSlot(t,e){let i=this.attachments[t];if(i)for(let r in i){let s=i[r];s&&e.push(new Pi(t,r,s))}}clear(){this.attachments.length=0,this.bones.length=0,this.constraints.length=0}attachAll(t,e){let i=0;for(let r=0;r<t.slots.length;r++){let s=t.slots[r],h=s.getAttachment();if(h&&i<e.attachments.length){let l=e.attachments[i];for(let n in l){let a=l[n];if(h==a){let o=this.getAttachment(i,n);o&&s.setAttachment(o);break}}}i++}}},Li=class{index=0;name;boneData;color=new K(1,1,1,1);darkColor=null;attachmentName=null;blendMode=0;visible=!0;constructor(t,e,i){if(t<0)throw new Error("index must be >= 0.");if(!e)throw new Error("name cannot be null.");if(!i)throw new Error("boneData cannot be null.");this.index=t,this.name=e,this.boneData=i}},Xi=(t=>(t[t.Normal=0]="Normal",t[t.Additive=1]="Additive",t[t.Multiply=2]="Multiply",t[t.Screen=3]="Screen",t))(Xi||{}),Bi=class extends nt{bones=new Array;_target=null;set target(t){this._target=t}get target(){if(this._target)return this._target;throw new Error("BoneData not set.")}mixRotate=0;mixX=0;mixY=0;mixScaleX=0;mixScaleY=0;mixShearY=0;offsetRotation=0;offsetX=0;offsetY=0;offsetScaleX=0;offsetScaleY=0;offsetShearY=0;relative=!1;local=!1;constructor(t){super(t,0,!1)}},Ms=class{scale=1;attachmentLoader;linkedMeshes=new Array;constructor(t){this.attachmentLoader=t}readSkeletonData(t){let e=this.scale,i=new Fi;i.name="";let r=new Es(t),s=r.readInt32(),h=r.readInt32();i.hash=h==0&&s==0?null:h.toString(16)+s.toString(16),i.version=r.readString(),i.x=r.readFloat(),i.y=r.readFloat(),i.width=r.readFloat(),i.height=r.readFloat(),i.referenceScale=r.readFloat()*e;let l=r.readBoolean();l&&(i.fps=r.readFloat(),i.imagesPath=r.readString(),i.audioPath=r.readString());let n=0;n=r.readInt(!0);for(let o=0;o<n;o++){let c=r.readString();if(!c)throw new Error("String in string table must not be null.");r.strings.push(c)}n=r.readInt(!0);for(let o=0;o<n;o++){let c=r.readString();if(!c)throw new Error("Bone name must not be null.");let d=o==0?null:i.bones[r.readInt(!0)],u=new Ai(o,c,d);u.rotation=r.readFloat(),u.x=r.readFloat()*e,u.y=r.readFloat()*e,u.scaleX=r.readFloat(),u.scaleY=r.readFloat(),u.shearX=r.readFloat(),u.shearY=r.readFloat(),u.length=r.readFloat()*e,u.inherit=r.readByte(),u.skinRequired=r.readBoolean(),l&&(K.rgba8888ToColor(u.color,r.readInt32()),u.icon=r.readString()??void 0,u.visible=r.readBoolean()),i.bones.push(u)}n=r.readInt(!0);for(let o=0;o<n;o++){let c=r.readString();if(!c)throw new Error("Slot name must not be null.");let d=i.bones[r.readInt(!0)],u=new Li(o,c,d);K.rgba8888ToColor(u.color,r.readInt32());let m=r.readInt32();m!=-1&&K.rgb888ToColor(u.darkColor=new K,m),u.attachmentName=r.readStringRef(),u.blendMode=r.readInt(!0),l&&(u.visible=r.readBoolean()),i.slots.push(u)}n=r.readInt(!0);for(let o=0,c;o<n;o++){let d=r.readString();if(!d)throw new Error("IK constraint data name must not be null.");let u=new Mi(d);u.order=r.readInt(!0),c=r.readInt(!0);for(let f=0;f<c;f++)u.bones.push(i.bones[r.readInt(!0)]);u.target=i.bones[r.readInt(!0)];let m=r.readByte();u.skinRequired=(m&1)!=0,u.bendDirection=(m&2)!=0?1:-1,u.compress=(m&4)!=0,u.stretch=(m&8)!=0,u.uniform=(m&16)!=0,(m&32)!=0&&(u.mix=(m&64)!=0?r.readFloat():1),(m&128)!=0&&(u.softness=r.readFloat()*e),i.ikConstraints.push(u)}n=r.readInt(!0);for(let o=0,c;o<n;o++){let d=r.readString();if(!d)throw new Error("Transform constraint data name must not be null.");let u=new Bi(d);u.order=r.readInt(!0),c=r.readInt(!0);for(let f=0;f<c;f++)u.bones.push(i.bones[r.readInt(!0)]);u.target=i.bones[r.readInt(!0)];let m=r.readByte();u.skinRequired=(m&1)!=0,u.local=(m&2)!=0,u.relative=(m&4)!=0,(m&8)!=0&&(u.offsetRotation=r.readFloat()),(m&16)!=0&&(u.offsetX=r.readFloat()*e),(m&32)!=0&&(u.offsetY=r.readFloat()*e),(m&64)!=0&&(u.offsetScaleX=r.readFloat()),(m&128)!=0&&(u.offsetScaleY=r.readFloat()),m=r.readByte(),(m&1)!=0&&(u.offsetShearY=r.readFloat()),(m&2)!=0&&(u.mixRotate=r.readFloat()),(m&4)!=0&&(u.mixX=r.readFloat()),(m&8)!=0&&(u.mixY=r.readFloat()),(m&16)!=0&&(u.mixScaleX=r.readFloat()),(m&32)!=0&&(u.mixScaleY=r.readFloat()),(m&64)!=0&&(u.mixShearY=r.readFloat()),i.transformConstraints.push(u)}n=r.readInt(!0);for(let o=0,c;o<n;o++){let d=r.readString();if(!d)throw new Error("Path constraint data name must not be null.");let u=new Ei(d);u.order=r.readInt(!0),u.skinRequired=r.readBoolean(),c=r.readInt(!0);for(let f=0;f<c;f++)u.bones.push(i.bones[r.readInt(!0)]);u.target=i.slots[r.readInt(!0)];const m=r.readByte();u.positionMode=m&1,u.spacingMode=m>>1&3,u.rotateMode=m>>3&3,(m&128)!=0&&(u.offsetRotation=r.readFloat()),u.position=r.readFloat(),u.positionMode==0&&(u.position*=e),u.spacing=r.readFloat(),(u.spacingMode==0||u.spacingMode==1)&&(u.spacing*=e),u.mixRotate=r.readFloat(),u.mixX=r.readFloat(),u.mixY=r.readFloat(),i.pathConstraints.push(u)}n=r.readInt(!0);for(let o=0,c;o<n;o++){const d=r.readString();if(!d)throw new Error("Physics constraint data name must not be null.");const u=new Is(d);u.order=r.readInt(!0),u.bone=i.bones[r.readInt(!0)];let m=r.readByte();u.skinRequired=(m&1)!=0,(m&2)!=0&&(u.x=r.readFloat()),(m&4)!=0&&(u.y=r.readFloat()),(m&8)!=0&&(u.rotate=r.readFloat()),(m&16)!=0&&(u.scaleX=r.readFloat()),(m&32)!=0&&(u.shearX=r.readFloat()),u.limit=((m&64)!=0?r.readFloat():5e3)*e,u.step=1/r.readUnsignedByte(),u.inertia=r.readFloat(),u.strength=r.readFloat(),u.damping=r.readFloat(),u.massInverse=(m&128)!=0?r.readFloat():1,u.wind=r.readFloat(),u.gravity=r.readFloat(),m=r.readByte(),(m&1)!=0&&(u.inertiaGlobal=!0),(m&2)!=0&&(u.strengthGlobal=!0),(m&4)!=0&&(u.dampingGlobal=!0),(m&8)!=0&&(u.massGlobal=!0),(m&16)!=0&&(u.windGlobal=!0),(m&32)!=0&&(u.gravityGlobal=!0),(m&64)!=0&&(u.mixGlobal=!0),u.mix=(m&128)!=0?r.readFloat():1,i.physicsConstraints.push(u)}let a=this.readSkin(r,i,!0,l);a&&(i.defaultSkin=a,i.skins.push(a));{let o=i.skins.length;for(X.setArraySize(i.skins,n=o+r.readInt(!0));o<n;o++){let c=this.readSkin(r,i,!1,l);if(!c)throw new Error("readSkin() should not have returned null.");i.skins[o]=c}}n=this.linkedMeshes.length;for(let o=0;o<n;o++){let c=this.linkedMeshes[o];const d=i.skins[c.skinIndex];if(!c.parent)throw new Error("Linked mesh parent must not be null");let u=d.getAttachment(c.slotIndex,c.parent);if(!u)throw new Error(`Parent mesh not found: ${c.parent}`);c.mesh.timelineAttachment=c.inheritTimeline?u:c.mesh,c.mesh.setParentMesh(u),c.mesh.region!=null&&c.mesh.updateRegion()}this.linkedMeshes.length=0,n=r.readInt(!0);for(let o=0;o<n;o++){let c=r.readString();if(!c)throw new Error("Event data name must not be null");let d=new Ii(c);d.intValue=r.readInt(!1),d.floatValue=r.readFloat(),d.stringValue=r.readString(),d.audioPath=r.readString(),d.audioPath&&(d.volume=r.readFloat(),d.balance=r.readFloat()),i.events.push(d)}n=r.readInt(!0);for(let o=0;o<n;o++){let c=r.readString();if(!c)throw new Error("Animatio name must not be null.");i.animations.push(this.readAnimation(r,c,i))}return i}readSkin(t,e,i,r){let s=null,h=0;if(i){if(h=t.readInt(!0),h==0)return null;s=new at("default")}else{let l=t.readString();if(!l)throw new Error("Skin name must not be null.");s=new at(l),r&&K.rgba8888ToColor(s.color,t.readInt32()),s.bones.length=t.readInt(!0);for(let n=0,a=s.bones.length;n<a;n++)s.bones[n]=e.bones[t.readInt(!0)];for(let n=0,a=t.readInt(!0);n<a;n++)s.constraints.push(e.ikConstraints[t.readInt(!0)]);for(let n=0,a=t.readInt(!0);n<a;n++)s.constraints.push(e.transformConstraints[t.readInt(!0)]);for(let n=0,a=t.readInt(!0);n<a;n++)s.constraints.push(e.pathConstraints[t.readInt(!0)]);for(let n=0,a=t.readInt(!0);n<a;n++)s.constraints.push(e.physicsConstraints[t.readInt(!0)]);h=t.readInt(!0)}for(let l=0;l<h;l++){let n=t.readInt(!0);for(let a=0,o=t.readInt(!0);a<o;a++){let c=t.readStringRef();if(!c)throw new Error("Attachment name must not be null");let d=this.readAttachment(t,e,s,n,c,r);d&&s.setAttachment(n,c,d)}}return s}readAttachment(t,e,i,r,s,h){let l=this.scale,n=t.readByte();const a=(n&8)!=0?t.readStringRef():s;if(!a)throw new Error("Attachment name must not be null");switch(n&7){case 0:{let o=(n&16)!=0?t.readStringRef():null;const c=(n&32)!=0?t.readInt32():4294967295,d=(n&64)!=0?this.readSequence(t):null;let u=(n&128)!=0?t.readFloat():0,m=t.readFloat(),f=t.readFloat(),g=t.readFloat(),x=t.readFloat(),b=t.readFloat(),p=t.readFloat();o||(o=a);let w=this.attachmentLoader.newRegionAttachment(i,a,o,d);return w?(w.path=o,w.x=m*l,w.y=f*l,w.scaleX=g,w.scaleY=x,w.rotation=u,w.width=b*l,w.height=p*l,K.rgba8888ToColor(w.color,c),w.sequence=d,d==null&&w.updateRegion(),w):null}case 1:{let o=this.readVertices(t,(n&16)!=0),c=h?t.readInt32():0,d=this.attachmentLoader.newBoundingBoxAttachment(i,a);return d?(d.worldVerticesLength=o.length,d.vertices=o.vertices,d.bones=o.bones,h&&K.rgba8888ToColor(d.color,c),d):null}case 2:{let o=(n&16)!=0?t.readStringRef():a;const c=(n&32)!=0?t.readInt32():4294967295,d=(n&64)!=0?this.readSequence(t):null,u=t.readInt(!0),m=this.readVertices(t,(n&128)!=0),f=this.readFloatArray(t,m.length,1),g=this.readShortArray(t,(m.length-u-2)*3);let x=[],b=0,p=0;h&&(x=this.readShortArray(t,t.readInt(!0)),b=t.readFloat(),p=t.readFloat()),o||(o=a);let w=this.attachmentLoader.newMeshAttachment(i,a,o,d);return w?(w.path=o,K.rgba8888ToColor(w.color,c),w.bones=m.bones,w.vertices=m.vertices,w.worldVerticesLength=m.length,w.triangles=g,w.regionUVs=f,d==null&&w.updateRegion(),w.hullLength=u<<1,w.sequence=d,h&&(w.edges=x,w.width=b*l,w.height=p*l),w):null}case 3:{const o=(n&16)!=0?t.readStringRef():a;if(o==null)throw new Error("Path of linked mesh must not be null");const c=(n&32)!=0?t.readInt32():4294967295,d=(n&64)!=0?this.readSequence(t):null,u=(n&128)!=0,m=t.readInt(!0),f=t.readStringRef();let g=0,x=0;h&&(g=t.readFloat(),x=t.readFloat());let b=this.attachmentLoader.newMeshAttachment(i,a,o,d);return b?(b.path=o,K.rgba8888ToColor(b.color,c),b.sequence=d,h&&(b.width=g*l,b.height=x*l),this.linkedMeshes.push(new Gr(b,m,r,f,u)),b):null}case 4:{const o=(n&16)!=0,c=(n&32)!=0,d=this.readVertices(t,(n&64)!=0),u=X.newArray(d.length/6,0);for(let g=0,x=u.length;g<x;g++)u[g]=t.readFloat()*l;const m=h?t.readInt32():0,f=this.attachmentLoader.newPathAttachment(i,a);return f?(f.closed=o,f.constantSpeed=c,f.worldVerticesLength=d.length,f.vertices=d.vertices,f.bones=d.bones,f.lengths=u,h&&K.rgba8888ToColor(f.color,m),f):null}case 5:{const o=t.readFloat(),c=t.readFloat(),d=t.readFloat(),u=h?t.readInt32():0,m=this.attachmentLoader.newPointAttachment(i,a);return m?(m.x=c*l,m.y=d*l,m.rotation=o,h&&K.rgba8888ToColor(m.color,u),m):null}case 6:{const o=t.readInt(!0),c=this.readVertices(t,(n&16)!=0);let d=h?t.readInt32():0,u=this.attachmentLoader.newClippingAttachment(i,a);return u?(u.endSlot=e.slots[o],u.worldVerticesLength=c.length,u.vertices=c.vertices,u.bones=c.bones,h&&K.rgba8888ToColor(u.color,d),u):null}}return null}readSequence(t){let e=new ns(t.readInt(!0));return e.start=t.readInt(!0),e.digits=t.readInt(!0),e.setupIndex=t.readInt(!0),e}readVertices(t,e){const i=this.scale,r=t.readInt(!0),s=new zr;if(s.length=r<<1,!e)return s.vertices=this.readFloatArray(t,s.length,i),s;let h=new Array,l=new Array;for(let n=0;n<r;n++){let a=t.readInt(!0);l.push(a);for(let o=0;o<a;o++)l.push(t.readInt(!0)),h.push(t.readFloat()*i),h.push(t.readFloat()*i),h.push(t.readFloat())}return s.vertices=X.toFloatArray(h),s.bones=l,s}readFloatArray(t,e,i){let r=new Array(e);if(i==1)for(let s=0;s<e;s++)r[s]=t.readFloat();else for(let s=0;s<e;s++)r[s]=t.readFloat()*i;return r}readShortArray(t,e){let i=new Array(e);for(let r=0;r<e;r++)i[r]=t.readInt(!0);return i}readAnimation(t,e,i){t.readInt(!0);let r=new Array,s=this.scale;for(let a=0,o=t.readInt(!0);a<o;a++){let c=t.readInt(!0);for(let d=0,u=t.readInt(!0);d<u;d++){let m=t.readByte(),f=t.readInt(!0),g=f-1;switch(m){case sn:{let x=new We(f,c);for(let b=0;b<f;b++)x.setFrame(b,t.readFloat(),t.readStringRef());r.push(x);break}case rn:{let x=t.readInt(!0),b=new Zt(f,x,c),p=t.readFloat(),w=t.readUnsignedByte()/255,v=t.readUnsignedByte()/255,y=t.readUnsignedByte()/255,A=t.readUnsignedByte()/255;for(let C=0,S=0;b.setFrame(C,p,w,v,y,A),C!=g;C++){let I=t.readFloat(),k=t.readUnsignedByte()/255,Y=t.readUnsignedByte()/255,F=t.readUnsignedByte()/255,P=t.readUnsignedByte()/255;switch(t.readByte()){case Pe:b.setStepped(C);break;case Le:ae(t,b,S++,C,0,p,I,w,k,1),ae(t,b,S++,C,1,p,I,v,Y,1),ae(t,b,S++,C,2,p,I,y,F,1),ae(t,b,S++,C,3,p,I,A,P,1)}p=I,w=k,v=Y,y=F,A=P}r.push(b);break}case nn:{let x=t.readInt(!0),b=new Jt(f,x,c),p=t.readFloat(),w=t.readUnsignedByte()/255,v=t.readUnsignedByte()/255,y=t.readUnsignedByte()/255;for(let A=0,C=0;b.setFrame(A,p,w,v,y),A!=g;A++){let S=t.readFloat(),I=t.readUnsignedByte()/255,k=t.readUnsignedByte()/255,Y=t.readUnsignedByte()/255;switch(t.readByte()){case Pe:b.setStepped(A);break;case Le:ae(t,b,C++,A,0,p,S,w,I,1),ae(t,b,C++,A,1,p,S,v,k,1),ae(t,b,C++,A,2,p,S,y,Y,1)}p=S,w=I,v=k,y=Y}r.push(b);break}case an:{let x=t.readInt(!0),b=new Qt(f,x,c),p=t.readFloat(),w=t.readUnsignedByte()/255,v=t.readUnsignedByte()/255,y=t.readUnsignedByte()/255,A=t.readUnsignedByte()/255,C=t.readUnsignedByte()/255,S=t.readUnsignedByte()/255,I=t.readUnsignedByte()/255;for(let k=0,Y=0;b.setFrame(k,p,w,v,y,A,C,S,I),k!=g;k++){let F=t.readFloat(),P=t.readUnsignedByte()/255,M=t.readUnsignedByte()/255,R=t.readUnsignedByte()/255,B=t.readUnsignedByte()/255,ie=t.readUnsignedByte()/255,te=t.readUnsignedByte()/255,re=t.readUnsignedByte()/255;switch(t.readByte()){case Pe:b.setStepped(k);break;case Le:ae(t,b,Y++,k,0,p,F,w,P,1),ae(t,b,Y++,k,1,p,F,v,M,1),ae(t,b,Y++,k,2,p,F,y,R,1),ae(t,b,Y++,k,3,p,F,A,B,1),ae(t,b,Y++,k,4,p,F,C,ie,1),ae(t,b,Y++,k,5,p,F,S,te,1),ae(t,b,Y++,k,6,p,F,I,re,1)}p=F,w=P,v=M,y=R,A=B,C=ie,S=te,I=re}r.push(b);break}case ln:{let x=t.readInt(!0),b=new $t(f,x,c),p=t.readFloat(),w=t.readUnsignedByte()/255,v=t.readUnsignedByte()/255,y=t.readUnsignedByte()/255,A=t.readUnsignedByte()/255,C=t.readUnsignedByte()/255,S=t.readUnsignedByte()/255;for(let I=0,k=0;b.setFrame(I,p,w,v,y,A,C,S),I!=g;I++){let Y=t.readFloat(),F=t.readUnsignedByte()/255,P=t.readUnsignedByte()/255,M=t.readUnsignedByte()/255,R=t.readUnsignedByte()/255,B=t.readUnsignedByte()/255,ie=t.readUnsignedByte()/255;switch(t.readByte()){case Pe:b.setStepped(I);break;case Le:ae(t,b,k++,I,0,p,Y,w,F,1),ae(t,b,k++,I,1,p,Y,v,P,1),ae(t,b,k++,I,2,p,Y,y,M,1),ae(t,b,k++,I,3,p,Y,A,R,1),ae(t,b,k++,I,4,p,Y,C,B,1),ae(t,b,k++,I,5,p,Y,S,ie,1)}p=Y,w=F,v=P,y=M,A=R,C=B,S=ie}r.push(b);break}case on:{let x=new Kt(f,t.readInt(!0),c),b=t.readFloat(),p=t.readUnsignedByte()/255;for(let w=0,v=0;x.setFrame(w,b,p),w!=g;w++){let y=t.readFloat(),A=t.readUnsignedByte()/255;switch(t.readByte()){case Pe:x.setStepped(w);break;case Le:ae(t,x,v++,w,0,b,y,p,A,1)}b=y,p=A}r.push(x)}}}}for(let a=0,o=t.readInt(!0);a<o;a++){let c=t.readInt(!0);for(let d=0,u=t.readInt(!0);d<u;d++){let m=t.readByte(),f=t.readInt(!0);if(m==tn){let x=new jt(f,c);for(let b=0;b<f;b++)x.setFrame(b,t.readFloat(),t.readByte());r.push(x);continue}let g=t.readInt(!0);switch(m){case qr:r.push(pe(t,new st(f,g,c),1));break;case _r:r.push(Oi(t,new Dt(f,g,c),s));break;case Hr:r.push(pe(t,new Nt(f,g,c),s));break;case jr:r.push(pe(t,new Ut(f,g,c),s));break;case Zr:r.push(Oi(t,new Wt(f,g,c),1));break;case Jr:r.push(pe(t,new Gt(f,g,c),1));break;case Kr:r.push(pe(t,new zt(f,g,c),1));break;case Qr:r.push(Oi(t,new qt(f,g,c),1));break;case $r:r.push(pe(t,new _t(f,g,c),1));break;case en:r.push(pe(t,new Ht(f,g,c),1))}}}for(let a=0,o=t.readInt(!0);a<o;a++){let c=t.readInt(!0),d=t.readInt(!0),u=d-1,m=new ti(d,t.readInt(!0),c),f=t.readByte(),g=t.readFloat(),x=(f&1)!=0?(f&2)!=0?t.readFloat():1:0,b=(f&4)!=0?t.readFloat()*s:0;for(let p=0,w=0;m.setFrame(p,g,x,b,(f&8)!=0?1:-1,(f&16)!=0,(f&32)!=0),p!=u;p++){f=t.readByte();const v=t.readFloat(),y=(f&1)!=0?(f&2)!=0?t.readFloat():1:0,A=(f&4)!=0?t.readFloat()*s:0;(f&64)!=0?m.setStepped(p):(f&128)!=0&&(ae(t,m,w++,p,0,g,v,x,y,1),ae(t,m,w++,p,1,g,v,b,A,s)),g=v,x=y,b=A}r.push(m)}for(let a=0,o=t.readInt(!0);a<o;a++){let c=t.readInt(!0),d=t.readInt(!0),u=d-1,m=new ii(d,t.readInt(!0),c),f=t.readFloat(),g=t.readFloat(),x=t.readFloat(),b=t.readFloat(),p=t.readFloat(),w=t.readFloat(),v=t.readFloat();for(let y=0,A=0;m.setFrame(y,f,g,x,b,p,w,v),y!=u;y++){let C=t.readFloat(),S=t.readFloat(),I=t.readFloat(),k=t.readFloat(),Y=t.readFloat(),F=t.readFloat(),P=t.readFloat();switch(t.readByte()){case Pe:m.setStepped(y);break;case Le:ae(t,m,A++,y,0,f,C,g,S,1),ae(t,m,A++,y,1,f,C,x,I,1),ae(t,m,A++,y,2,f,C,b,k,1),ae(t,m,A++,y,3,f,C,p,Y,1),ae(t,m,A++,y,4,f,C,w,F,1),ae(t,m,A++,y,5,f,C,v,P,1)}f=C,g=S,x=I,b=k,p=Y,w=F,v=P}r.push(m)}for(let a=0,o=t.readInt(!0);a<o;a++){let c=t.readInt(!0),d=i.pathConstraints[c];for(let u=0,m=t.readInt(!0);u<m;u++){const f=t.readByte(),g=t.readInt(!0),x=t.readInt(!0);switch(f){case dn:r.push(pe(t,new si(g,x,c),d.positionMode==0?s:1));break;case un:r.push(pe(t,new ri(g,x,c),d.spacingMode==0||d.spacingMode==1?s:1));break;case fn:let b=new ni(g,x,c),p=t.readFloat(),w=t.readFloat(),v=t.readFloat(),y=t.readFloat();for(let A=0,C=0,S=b.getFrameCount()-1;b.setFrame(A,p,w,v,y),A!=S;A++){let I=t.readFloat(),k=t.readFloat(),Y=t.readFloat(),F=t.readFloat();switch(t.readByte()){case Pe:b.setStepped(A);break;case Le:ae(t,b,C++,A,0,p,I,w,k,1),ae(t,b,C++,A,1,p,I,v,Y,1),ae(t,b,C++,A,2,p,I,y,F,1)}p=I,w=k,v=Y,y=F}r.push(b)}}}for(let a=0,o=t.readInt(!0);a<o;a++){const c=t.readInt(!0)-1;for(let d=0,u=t.readInt(!0);d<u;d++){const m=t.readByte(),f=t.readInt(!0);if(m==yn){const x=new fi(f,c);for(let b=0;b<f;b++)x.setFrame(b,t.readFloat());r.push(x);continue}const g=t.readInt(!0);switch(m){case mn:r.push(pe(t,new ai(f,g,c),1));break;case gn:r.push(pe(t,new li(f,g,c),1));break;case pn:r.push(pe(t,new oi(f,g,c),1));break;case xn:r.push(pe(t,new hi(f,g,c),1));break;case wn:r.push(pe(t,new ci(f,g,c),1));break;case bn:r.push(pe(t,new di(f,g,c),1));break;case vn:r.push(pe(t,new ui(f,g,c),1))}}}for(let a=0,o=t.readInt(!0);a<o;a++){let c=i.skins[t.readInt(!0)];for(let d=0,u=t.readInt(!0);d<u;d++){let m=t.readInt(!0);for(let f=0,g=t.readInt(!0);f<g;f++){let x=t.readStringRef();if(!x)throw new Error("attachmentName must not be null.");let b=c.getAttachment(m,x),p=t.readByte(),w=t.readInt(!0),v=w-1;switch(p){case hn:{let y=b,A=y.bones,C=y.vertices,S=A?C.length/3*2:C.length,I=t.readInt(!0),k=new ei(w,I,m,y),Y=t.readFloat();for(let F=0,P=0;;F++){let M,R=t.readInt(!0);if(R==0)M=A?X.newFloatArray(S):C;else{M=X.newFloatArray(S);let ie=t.readInt(!0);if(R+=ie,s==1)for(let te=ie;te<R;te++)M[te]=t.readFloat();else for(let te=ie;te<R;te++)M[te]=t.readFloat()*s;if(!A)for(let te=0,re=M.length;te<re;te++)M[te]+=C[te]}if(k.setFrame(F,Y,M),F==v)break;let B=t.readFloat();switch(t.readByte()){case Pe:k.setStepped(F);break;case Le:ae(t,k,P++,F,0,Y,B,0,1,1)}Y=B}r.push(k);break}case cn:{let y=new mi(w,m,b);for(let A=0;A<w;A++){let C=t.readFloat(),S=t.readInt32();y.setFrame(A,C,ls[S&15],S>>4,t.readFloat())}r.push(y);break}}}}}let h=t.readInt(!0);if(h>0){let a=new je(h),o=i.slots.length;for(let c=0;c<h;c++){let d=t.readFloat(),u=t.readInt(!0),m=X.newArray(o,0);for(let b=o-1;b>=0;b--)m[b]=-1;let f=X.newArray(o-u,0),g=0,x=0;for(let b=0;b<u;b++){let p=t.readInt(!0);for(;g!=p;)f[x++]=g++;m[g+t.readInt(!0)]=g++}for(;g<o;)f[x++]=g++;for(let b=o-1;b>=0;b--)m[b]==-1&&(m[b]=f[--x]);a.setFrame(c,d,m)}r.push(a)}let l=t.readInt(!0);if(l>0){let a=new mt(l);for(let o=0;o<l;o++){let c=t.readFloat(),d=i.events[t.readInt(!0)],u=new Ti(c,d);u.intValue=t.readInt(!1),u.floatValue=t.readFloat(),u.stringValue=t.readString(),u.stringValue==null&&(u.stringValue=d.stringValue),u.data.audioPath&&(u.volume=t.readFloat(),u.balance=t.readFloat()),a.setFrame(o,u)}r.push(a)}let n=0;for(let a=0,o=r.length;a<o;a++)n=Math.max(n,r[a].getDuration());return new ut(e,r,n)}},Es=class{constructor(t,e=new Array,i=0,r=new DataView(t instanceof ArrayBuffer?t:t.buffer)){this.strings=e,this.index=i,this.buffer=r}readByte(){return this.buffer.getInt8(this.index++)}readUnsignedByte(){return this.buffer.getUint8(this.index++)}readShort(){let t=this.buffer.getInt16(this.index);return this.index+=2,t}readInt32(){let t=this.buffer.getInt32(this.index);return this.index+=4,t}readInt(t){let e=this.readByte(),i=e&127;return(e&128)!=0&&(e=this.readByte(),i|=(e&127)<<7,(e&128)!=0&&(e=this.readByte(),i|=(e&127)<<14,(e&128)!=0&&(e=this.readByte(),i|=(e&127)<<21,(e&128)!=0&&(e=this.readByte(),i|=(e&127)<<28)))),t?i:i>>>1^-(i&1)}readStringRef(){let t=this.readInt(!0);return t==0?null:this.strings[t-1]}readString(){let t=this.readInt(!0);switch(t){case 0:return null;case 1:return""}t--;let e="",i=0;for(let r=0;r<t;){let s=this.readUnsignedByte();switch(s>>4){case 12:case 13:e+=String.fromCharCode((s&31)<<6|this.readByte()&63),r+=2;break;case 14:e+=String.fromCharCode((s&15)<<12|(this.readByte()&63)<<6|this.readByte()&63),r+=3;break;default:e+=String.fromCharCode(s),r++}}return e}readFloat(){let t=this.buffer.getFloat32(this.index);return this.index+=4,t}readBoolean(){return this.readByte()!=0}},Gr=class{parent;skinIndex;slotIndex;mesh;inheritTimeline;constructor(t,e,i,r,s){this.mesh=t,this.skinIndex=e,this.slotIndex=i,this.parent=r,this.inheritTimeline=s}},zr=class{constructor(t=null,e=null,i=0){this.bones=t,this.vertices=e,this.length=i}};function pe(t,e,i){let r=t.readFloat(),s=t.readFloat()*i;for(let h=0,l=0,n=e.getFrameCount()-1;e.setFrame(h,r,s),h!=n;h++){let a=t.readFloat(),o=t.readFloat()*i;switch(t.readByte()){case Pe:e.setStepped(h);break;case Le:ae(t,e,l++,h,0,r,a,s,o,i)}r=a,s=o}return e}function Oi(t,e,i){let r=t.readFloat(),s=t.readFloat()*i,h=t.readFloat()*i;for(let l=0,n=0,a=e.getFrameCount()-1;e.setFrame(l,r,s,h),l!=a;l++){let o=t.readFloat(),c=t.readFloat()*i,d=t.readFloat()*i;switch(t.readByte()){case Pe:e.setStepped(l);break;case Le:ae(t,e,n++,l,0,r,o,s,c,i),ae(t,e,n++,l,1,r,o,h,d,i)}r=o,s=c,h=d}return e}function ae(t,e,i,r,s,h,l,n,a,o){e.setBezier(i,r,s,h,n,t.readFloat(),t.readFloat()*o,t.readFloat(),t.readFloat()*o,l,a)}var qr=0,_r=1,Hr=2,jr=3,Zr=4,Jr=5,Kr=6,Qr=7,$r=8,en=9,tn=10,sn=0,rn=1,nn=2,an=3,ln=4,on=5,hn=0,cn=1,dn=0,un=1,fn=2,mn=0,gn=1,pn=2,xn=4,wn=5,bn=6,vn=7,yn=8,Pe=1,Le=2,Rs=class{minX=0;minY=0;maxX=0;maxY=0;boundingBoxes=new Array;polygons=new Array;polygonPool=new it(()=>X.newFloatArray(16));update(t,e){if(!t)throw new Error("skeleton cannot be null.");let i=this.boundingBoxes,r=this.polygons,s=this.polygonPool,h=t.slots,l=h.length;i.length=0,s.freeAll(r),r.length=0;for(let n=0;n<l;n++){let a=h[n];if(!a.bone.active)continue;let o=a.getAttachment();if(o instanceof bi){let c=o;i.push(c);let d=s.obtain();d.length!=c.worldVerticesLength&&(d=X.newFloatArray(c.worldVerticesLength)),r.push(d),c.computeWorldVertices(a,0,c.worldVerticesLength,d,0,2)}}e?this.aabbCompute():(this.minX=Number.POSITIVE_INFINITY,this.minY=Number.POSITIVE_INFINITY,this.maxX=Number.NEGATIVE_INFINITY,this.maxY=Number.NEGATIVE_INFINITY)}aabbCompute(){let t=Number.POSITIVE_INFINITY,e=Number.POSITIVE_INFINITY,i=Number.NEGATIVE_INFINITY,r=Number.NEGATIVE_INFINITY,s=this.polygons;for(let h=0,l=s.length;h<l;h++){let n=s[h],a=n;for(let o=0,c=n.length;o<c;o+=2){let d=a[o],u=a[o+1];t=Math.min(t,d),e=Math.min(e,u),i=Math.max(i,d),r=Math.max(r,u)}}this.minX=t,this.minY=e,this.maxX=i,this.maxY=r}aabbContainsPoint(t,e){return t>=this.minX&&t<=this.maxX&&e>=this.minY&&e<=this.maxY}aabbIntersectsSegment(t,e,i,r){let s=this.minX,h=this.minY,l=this.maxX,n=this.maxY;if(t<=s&&i<=s||e<=h&&r<=h||t>=l&&i>=l||e>=n&&r>=n)return!1;let a=(r-e)/(i-t),o=a*(s-t)+e;if(o>h&&o<n||(o=a*(l-t)+e,o>h&&o<n))return!0;let c=(h-e)/a+t;return c>s&&c<l||(c=(n-e)/a+t,c>s&&c<l)}aabbIntersectsSkeleton(t){return this.minX<t.maxX&&this.maxX>t.minX&&this.minY<t.maxY&&this.maxY>t.minY}containsPoint(t,e){let i=this.polygons;for(let r=0,s=i.length;r<s;r++)if(this.containsPointPolygon(i[r],t,e))return this.boundingBoxes[r];return null}containsPointPolygon(t,e,i){let r=t,s=t.length,h=s-2,l=!1;for(let n=0;n<s;n+=2){let a=r[n+1],o=r[h+1];if(a<i&&o>=i||o<i&&a>=i){let c=r[n];c+(i-a)/(o-a)*(r[h]-c)<e&&(l=!l)}h=n}return l}intersectsSegment(t,e,i,r){let s=this.polygons;for(let h=0,l=s.length;h<l;h++)if(this.intersectsSegmentPolygon(s[h],t,e,i,r))return this.boundingBoxes[h];return null}intersectsSegmentPolygon(t,e,i,r,s){let h=t,l=t.length,n=e-r,a=i-s,o=e*s-i*r,c=h[l-2],d=h[l-1];for(let u=0;u<l;u+=2){let m=h[u],f=h[u+1],g=c*f-d*m,x=c-m,b=d-f,p=n*b-a*x,w=(o*x-n*g)/p;if((w>=c&&w<=m||w>=m&&w<=c)&&(w>=e&&w<=r||w>=r&&w<=e)){let v=(o*b-a*g)/p;if((v>=d&&v<=f||v>=f&&v<=d)&&(v>=i&&v<=s||v>=s&&v<=i))return!0}c=m,d=f}return!1}getPolygon(t){if(!t)throw new Error("boundingBox cannot be null.");let e=this.boundingBoxes.indexOf(t);return e==-1?null:this.polygons[e]}getWidth(){return this.maxX-this.minX}getHeight(){return this.maxY-this.minY}},ks=class Ae{convexPolygons=new Array;convexPolygonsIndices=new Array;indicesArray=new Array;isConcaveArray=new Array;triangles=new Array;polygonPool=new it(()=>new Array);polygonIndicesPool=new it(()=>new Array);triangulate(e){let i=e,r=e.length>>1,s=this.indicesArray;s.length=0;for(let n=0;n<r;n++)s[n]=n;let h=this.isConcaveArray;h.length=0;for(let n=0,a=r;n<a;++n)h[n]=Ae.isConcave(n,r,i,s);let l=this.triangles;for(l.length=0;r>3;){let n=r-1,a=0,o=1;for(;;){e:if(!h[a]){let u=s[n]<<1,m=s[a]<<1,f=s[o]<<1,g=i[u],x=i[u+1],b=i[m],p=i[m+1],w=i[f],v=i[f+1];for(let y=(o+1)%r;y!=n;y=(y+1)%r){if(!h[y])continue;let A=s[y]<<1,C=i[A],S=i[A+1];if(Ae.positiveArea(w,v,g,x,C,S)&&Ae.positiveArea(g,x,b,p,C,S)&&Ae.positiveArea(b,p,w,v,C,S))break e}break}if(o==0){do{if(!h[a])break;a--}while(a>0);break}n=a,a=o,o=(o+1)%r}l.push(s[(r+a-1)%r]),l.push(s[a]),l.push(s[(a+1)%r]),s.splice(a,1),h.splice(a,1),r--;let c=(r+a-1)%r,d=a==r?0:a;h[c]=Ae.isConcave(c,r,i,s),h[d]=Ae.isConcave(d,r,i,s)}return r==3&&(l.push(s[2]),l.push(s[0]),l.push(s[1])),l}decompose(e,i){let r=e,s=this.convexPolygons;this.polygonPool.freeAll(s),s.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=i.length;c<d;c+=3){let u=i[c]<<1,m=i[c+1]<<1,f=i[c+2]<<1,g=r[u],x=r[u+1],b=r[m],p=r[m+1],w=r[f],v=r[f+1],y=!1;if(a==u){let A=n.length-4,C=Ae.winding(n[A],n[A+1],n[A+2],n[A+3],w,v),S=Ae.winding(w,v,n[0],n[1],n[2],n[3]);C==o&&S==o&&(n.push(w),n.push(v),l.push(f),y=!0)}y||(n.length>0?(s.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(x),n.push(b),n.push(p),n.push(w),n.push(v),l=this.polygonIndicesPool.obtain(),l.length=0,l.push(u),l.push(m),l.push(f),o=Ae.winding(g,x,b,p,w,v),a=u)}n.length>0&&(s.push(n),h.push(l));for(let c=0,d=s.length;c<d;c++){if(l=h[c],l.length==0)continue;let u=l[0],m=l[l.length-1];n=s[c];let f=n.length-4,g=n[f],x=n[f+1],b=n[f+2],p=n[f+3],w=n[0],v=n[1],y=n[2],A=n[3],C=Ae.winding(g,x,b,p,w,v);for(let S=0;S<d;S++){if(S==c)continue;let I=h[S];if(I.length!=3)continue;let k=I[0],Y=I[1],F=I[2],P=s[S],M=P[P.length-2],R=P[P.length-1];if(k!=u||Y!=m)continue;let B=Ae.winding(g,x,b,p,M,R),ie=Ae.winding(M,R,w,v,y,A);B==C&&ie==C&&(P.length=0,I.length=0,n.push(M),n.push(R),l.push(F),g=b,x=p,b=M,p=R,S=0)}}for(let c=s.length-1;c>=0;c--)n=s[c],n.length==0&&(s.splice(c,1),this.polygonPool.free(n),l=h[c],h.splice(c,1),this.polygonIndicesPool.free(l));return s}static isConcave(e,i,r,s){let h=s[(i+e-1)%i]<<1,l=s[e]<<1,n=s[(e+1)%i]<<1;return!this.positiveArea(r[h],r[h+1],r[l],r[l+1],r[n],r[n+1])}static positiveArea(e,i,r,s,h,l){return e*(l-s)+r*(i-l)+h*(s-i)>=0}static winding(e,i,r,s,h,l){let n=r-e,a=s-i;return h*a-l*n+n*i-e*a>=0?1:-1}},yt=class $i{triangulator=new ks;clippingPolygon=new Array;clipOutput=new Array;clippedVertices=new Array;clippedUVs=new Array;clippedTriangles=new Array;scratch=new Array;clipAttachment=null;clippingPolygons=null;clipStart(e,i){if(this.clipAttachment)return 0;this.clipAttachment=i;let r=i.worldVerticesLength,s=X.setArraySize(this.clippingPolygon,r);i.computeWorldVertices(e,0,r,s,0,2);let h=this.clippingPolygon;$i.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];$i.makeClockwise(o),o.push(o[0]),o.push(o[1])}return l.length}clipEndWithSlot(e){this.clipAttachment&&this.clipAttachment.endSlot==e.data&&this.clipEnd()}clipEnd(){this.clipAttachment&&(this.clipAttachment=null,this.clippingPolygons=null,this.clippedVertices.length=0,this.clippedTriangles.length=0,this.clippingPolygon.length=0)}isClipping(){return this.clipAttachment!=null}clipTriangles(e,i,r,s,h,l,n,a){let o,c,d,u,m,f;typeof i=="number"?(o=r,c=s,d=h,u=l,m=n,f=a):(o=i,c=r,d=s,u=h,m=l,f=n),d&&u&&m&&typeof f=="boolean"?this.clipTrianglesRender(e,o,c,d,u,m,f):this.clipTrianglesNoRender(e,o,c)}clipTrianglesNoRender(e,i,r){let s=this.clipOutput,h=this.clippedVertices,l=this.clippedTriangles,n=this.clippingPolygons,a=n.length,o=0;h.length=0,l.length=0;for(let c=0;c<r;c+=3){let d=i[c]<<1,u=e[d],m=e[d+1];d=i[c+1]<<1;let f=e[d],g=e[d+1];d=i[c+2]<<1;let x=e[d],b=e[d+1];for(let p=0;p<a;p++){let w=h.length;if(this.clip(u,m,f,g,x,b,n[p],s)){let v=s.length;if(v==0)continue;let y=v>>1,A=this.clipOutput,C=X.setArraySize(h,w+y*2);for(let I=0;I<v;I+=2,w+=2){let k=A[I],Y=A[I+1];C[w]=k,C[w+1]=Y}w=l.length;let S=X.setArraySize(l,w+3*(y-2));y--;for(let I=1;I<y;I++,w+=3)S[w]=o,S[w+1]=o+I,S[w+2]=o+I+1;o+=y+1}else{let v=X.setArraySize(h,w+6);v[w]=u,v[w+1]=m,v[w+2]=f,v[w+3]=g,v[w+4]=x,v[w+5]=b,w=l.length;let y=X.setArraySize(l,w+3);y[w]=o,y[w+1]=o+1,y[w+2]=o+2,o+=3;break}}}}clipTrianglesRender(e,i,r,s,h,l,n){let a=this.clipOutput,o=this.clippedVertices,c=this.clippedTriangles,d=this.clippingPolygons,u=d.length,m=n?12:8,f=0;o.length=0,c.length=0;for(let g=0;g<r;g+=3){let x=i[g]<<1,b=e[x],p=e[x+1],w=s[x],v=s[x+1];x=i[g+1]<<1;let y=e[x],A=e[x+1],C=s[x],S=s[x+1];x=i[g+2]<<1;let I=e[x],k=e[x+1],Y=s[x],F=s[x+1];for(let P=0;P<u;P++){let M=o.length;if(this.clip(b,p,y,A,I,k,d[P],a)){let R=a.length;if(R==0)continue;let B=A-k,ie=I-y,te=b-I,re=k-p,de=1/(B*te+ie*(p-k)),oe=R>>1,me=this.clipOutput,Z=X.setArraySize(o,M+oe*m);for(let he=0;he<R;he+=2,M+=m){let ve=me[he],ge=me[he+1];Z[M]=ve,Z[M+1]=ge,Z[M+2]=h.r,Z[M+3]=h.g,Z[M+4]=h.b,Z[M+5]=h.a;let we=ve-I,be=ge-k,Re=(B*we+ie*be)*de,$e=(re*we+te*be)*de,ot=1-Re-$e;Z[M+6]=w*Re+C*$e+Y*ot,Z[M+7]=v*Re+S*$e+F*ot,n&&(Z[M+8]=l.r,Z[M+9]=l.g,Z[M+10]=l.b,Z[M+11]=l.a)}M=c.length;let ne=X.setArraySize(c,M+3*(oe-2));oe--;for(let he=1;he<oe;he++,M+=3)ne[M]=f,ne[M+1]=f+he,ne[M+2]=f+he+1;f+=oe+1}else{let R=X.setArraySize(o,M+3*m);R[M]=b,R[M+1]=p,R[M+2]=h.r,R[M+3]=h.g,R[M+4]=h.b,R[M+5]=h.a,n?(R[M+6]=w,R[M+7]=v,R[M+8]=l.r,R[M+9]=l.g,R[M+10]=l.b,R[M+11]=l.a,R[M+12]=y,R[M+13]=A,R[M+14]=h.r,R[M+15]=h.g,R[M+16]=h.b,R[M+17]=h.a,R[M+18]=C,R[M+19]=S,R[M+20]=l.r,R[M+21]=l.g,R[M+22]=l.b,R[M+23]=l.a,R[M+24]=I,R[M+25]=k,R[M+26]=h.r,R[M+27]=h.g,R[M+28]=h.b,R[M+29]=h.a,R[M+30]=Y,R[M+31]=F,R[M+32]=l.r,R[M+33]=l.g,R[M+34]=l.b,R[M+35]=l.a):(R[M+6]=w,R[M+7]=v,R[M+8]=y,R[M+9]=A,R[M+10]=h.r,R[M+11]=h.g,R[M+12]=h.b,R[M+13]=h.a,R[M+14]=C,R[M+15]=S,R[M+16]=I,R[M+17]=k,R[M+18]=h.r,R[M+19]=h.g,R[M+20]=h.b,R[M+21]=h.a,R[M+22]=Y,R[M+23]=F),M=c.length;let B=X.setArraySize(c,M+3);B[M]=f,B[M+1]=f+1,B[M+2]=f+2,f+=3;break}}}}clipTrianglesUnpacked(e,i,r,s){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 u=0;u<r;u+=3){let m=i[u]<<1,f=e[m],g=e[m+1],x=s[m],b=s[m+1];m=i[u+1]<<1;let p=e[m],w=e[m+1],v=s[m],y=s[m+1];m=i[u+2]<<1;let A=e[m],C=e[m+1],S=s[m],I=s[m+1];for(let k=0;k<c;k++){let Y=l.length;if(this.clip(f,g,p,w,A,C,o[k],h)){let F=h.length;if(F==0)continue;let P=w-C,M=A-p,R=f-A,B=C-g,ie=1/(P*R+M*(g-C)),te=F>>1,re=this.clipOutput,de=X.setArraySize(l,Y+te*2),oe=X.setArraySize(n,Y+te*2);for(let Z=0;Z<F;Z+=2,Y+=2){let ne=re[Z],he=re[Z+1];de[Y]=ne,de[Y+1]=he;let ve=ne-A,ge=he-C,we=(P*ve+M*ge)*ie,be=(B*ve+R*ge)*ie,Re=1-we-be;oe[Y]=x*we+v*be+S*Re,oe[Y+1]=b*we+y*be+I*Re}Y=a.length;let me=X.setArraySize(a,Y+3*(te-2));te--;for(let Z=1;Z<te;Z++,Y+=3)me[Y]=d,me[Y+1]=d+Z,me[Y+2]=d+Z+1;d+=te+1}else{let F=X.setArraySize(l,Y+6);F[Y]=f,F[Y+1]=g,F[Y+2]=p,F[Y+3]=w,F[Y+4]=A,F[Y+5]=C;let P=X.setArraySize(n,Y+3*2);P[Y]=x,P[Y+1]=b,P[Y+2]=v,P[Y+3]=y,P[Y+4]=S,P[Y+5]=I,Y=a.length;let M=X.setArraySize(a,Y+3);M[Y]=d,M[Y+1]=d+1,M[Y+2]=d+2,d+=3;break}}}}clip(e,i,r,s,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(e),d.push(i),d.push(r),d.push(s),d.push(h),d.push(l),d.push(e),d.push(i),a.length=0;let u=n.length-4,m=n;for(let f=0;;f+=2){let g=m[f],x=m[f+1],b=g-m[f+2],p=x-m[f+3],w=a.length,v=d;for(let A=0,C=d.length-2;A<C;){let S=v[A],I=v[A+1];A+=2;let k=v[A],Y=v[A+1],F=p*(g-k)>b*(x-Y),P=p*(g-S)-b*(x-I);if(P>0){if(F){a.push(k),a.push(Y);continue}let M=k-S,R=Y-I,B=P/(M*p-R*b);if(B>=0&&B<=1)a.push(S+M*B),a.push(I+R*B);else{a.push(k),a.push(Y);continue}}else if(F){let M=k-S,R=Y-I,B=P/(M*p-R*b);if(B>=0&&B<=1)a.push(S+M*B),a.push(I+R*B),a.push(k),a.push(Y);else{a.push(k),a.push(Y);continue}}c=!0}if(w==a.length)return o.length=0,!0;if(a.push(a[0]),a.push(a[1]),f==u)break;let y=a;a=d,a.length=0,d=y}if(o!=a){o.length=0;for(let f=0,g=a.length-2;f<g;f++)o[f]=a[f]}else o.length=o.length-2;return c}static makeClockwise(e){let i=e,r=e.length,s=i[r-2]*i[1]-i[0]*i[r-1],h=0,l=0,n=0,a=0;for(let o=0,c=r-3;o<c;o+=2)h=i[o],l=i[o+1],n=i[o+2],a=i[o+3],s+=h*a-n*l;if(!(s<0))for(let o=0,c=r-2,d=r>>1;o<d;o+=2){let u=i[o],m=i[o+1],f=c-o;i[o]=i[f],i[o+1]=i[f+1],i[f]=u,i[f+1]=m}}},Ys=class{attachmentLoader;scale=1;linkedMeshes=new Array;constructor(t){this.attachmentLoader=t}readSkeletonData(t){let e=this.scale,i=new Fi,r=typeof t=="string"?JSON.parse(t):t,s=r.skeleton;if(s&&(i.hash=s.hash,i.version=s.spine,i.x=s.x,i.y=s.y,i.width=s.width,i.height=s.height,i.referenceScale=E(s,"referenceScale",100)*e,i.fps=s.fps,i.imagesPath=s.images??null,i.audioPath=s.audio??null),r.bones)for(let h=0;h<r.bones.length;h++){let l=r.bones[h],n=null,a=E(l,"parent",null);a&&(n=i.findBone(a));let o=new Ai(i.bones.length,l.name,n);o.length=E(l,"length",0)*e,o.x=E(l,"x",0)*e,o.y=E(l,"y",0)*e,o.rotation=E(l,"rotation",0),o.scaleX=E(l,"scaleX",1),o.scaleY=E(l,"scaleY",1),o.shearX=E(l,"shearX",0),o.shearY=E(l,"shearY",0),o.inherit=X.enumValue(vt,E(l,"inherit","Normal")),o.skinRequired=E(l,"skin",!1);let c=E(l,"color",null);c&&o.color.setFromString(c),i.bones.push(o)}if(r.slots)for(let h=0;h<r.slots.length;h++){let l=r.slots[h],n=l.name,a=i.findBone(l.bone);if(!a)throw new Error(`Couldn't find bone ${l.bone} for slot ${n}`);let o=new Li(i.slots.length,n,a),c=E(l,"color",null);c&&o.color.setFromString(c);let d=E(l,"dark",null);d&&(o.darkColor=K.fromString(d)),o.attachmentName=E(l,"attachment",null),o.blendMode=X.enumValue(Xi,E(l,"blend","normal")),o.visible=E(l,"visible",!0),i.slots.push(o)}if(r.ik)for(let h=0;h<r.ik.length;h++){let l=r.ik[h],n=new Mi(l.name);n.order=E(l,"order",0),n.skinRequired=E(l,"skin",!1);for(let o=0;o<l.bones.length;o++){let c=i.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=i.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=E(l,"mix",1),n.softness=E(l,"softness",0)*e,n.bendDirection=E(l,"bendPositive",!0)?1:-1,n.compress=E(l,"compress",!1),n.stretch=E(l,"stretch",!1),n.uniform=E(l,"uniform",!1),i.ikConstraints.push(n)}if(r.transform)for(let h=0;h<r.transform.length;h++){let l=r.transform[h],n=new Bi(l.name);n.order=E(l,"order",0),n.skinRequired=E(l,"skin",!1);for(let c=0;c<l.bones.length;c++){let d=l.bones[c],u=i.findBone(d);if(!u)throw new Error(`Couldn't find bone ${d} for transform constraint ${l.name}.`);n.bones.push(u)}let a=l.target,o=i.findBone(a);if(!o)throw new Error(`Couldn't find target bone ${a} for transform constraint ${l.name}.`);n.target=o,n.local=E(l,"local",!1),n.relative=E(l,"relative",!1),n.offsetRotation=E(l,"rotation",0),n.offsetX=E(l,"x",0)*e,n.offsetY=E(l,"y",0)*e,n.offsetScaleX=E(l,"scaleX",0),n.offsetScaleY=E(l,"scaleY",0),n.offsetShearY=E(l,"shearY",0),n.mixRotate=E(l,"mixRotate",1),n.mixX=E(l,"mixX",1),n.mixY=E(l,"mixY",n.mixX),n.mixScaleX=E(l,"mixScaleX",1),n.mixScaleY=E(l,"mixScaleY",n.mixScaleX),n.mixShearY=E(l,"mixShearY",1),i.transformConstraints.push(n)}if(r.path)for(let h=0;h<r.path.length;h++){let l=r.path[h],n=new Ei(l.name);n.order=E(l,"order",0),n.skinRequired=E(l,"skin",!1);for(let c=0;c<l.bones.length;c++){let d=l.bones[c],u=i.findBone(d);if(!u)throw new Error(`Couldn't find bone ${d} for path constraint ${l.name}.`);n.bones.push(u)}let a=l.target,o=i.findSlot(a);if(!o)throw new Error(`Couldn't find target slot ${a} for path constraint ${l.name}.`);n.target=o,n.positionMode=X.enumValue(Ri,E(l,"positionMode","Percent")),n.spacingMode=X.enumValue(ki,E(l,"spacingMode","Length")),n.rotateMode=X.enumValue(Yi,E(l,"rotateMode","Tangent")),n.offsetRotation=E(l,"rotation",0),n.position=E(l,"position",0),n.positionMode==0&&(n.position*=e),n.spacing=E(l,"spacing",0),(n.spacingMode==0||n.spacingMode==1)&&(n.spacing*=e),n.mixRotate=E(l,"mixRotate",1),n.mixX=E(l,"mixX",1),n.mixY=E(l,"mixY",n.mixX),i.pathConstraints.push(n)}if(r.physics)for(let h=0;h<r.physics.length;h++){const l=r.physics[h],n=new Is(l.name);n.order=E(l,"order",0),n.skinRequired=E(l,"skin",!1);const a=l.bone,o=i.findBone(a);if(o==null)throw new Error("Physics bone not found: "+a);n.bone=o,n.x=E(l,"x",0),n.y=E(l,"y",0),n.rotate=E(l,"rotate",0),n.scaleX=E(l,"scaleX",0),n.shearX=E(l,"shearX",0),n.limit=E(l,"limit",5e3)*e,n.step=1/E(l,"fps",60),n.inertia=E(l,"inertia",1),n.strength=E(l,"strength",100),n.damping=E(l,"damping",1),n.massInverse=1/E(l,"mass",1),n.wind=E(l,"wind",0),n.gravity=E(l,"gravity",0),n.mix=E(l,"mix",1),n.inertiaGlobal=E(l,"inertiaGlobal",!1),n.strengthGlobal=E(l,"strengthGlobal",!1),n.dampingGlobal=E(l,"dampingGlobal",!1),n.massGlobal=E(l,"massGlobal",!1),n.windGlobal=E(l,"windGlobal",!1),n.gravityGlobal=E(l,"gravityGlobal",!1),n.mixGlobal=E(l,"mixGlobal",!1),i.physicsConstraints.push(n)}if(r.skins)for(let h=0;h<r.skins.length;h++){let l=r.skins[h],n=new at(l.name);if(l.bones)for(let a=0;a<l.bones.length;a++){let o=l.bones[a],c=i.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=i.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=i.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=i.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=i.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=i.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 u=this.readAttachment(c[d],n,o.index,d,i);u&&n.setAttachment(o.index,d,u)}}i.skins.push(n),n.name=="default"&&(i.defaultSkin=n)}for(let h=0,l=this.linkedMeshes.length;h<l;h++){let n=this.linkedMeshes[h],a=n.skin?i.findSkin(n.skin):i.defaultSkin;if(!a)throw new Error(`Skin not found: ${n.skin}`);let o=a.getAttachment(n.slotIndex,n.parent);if(!o)throw new Error(`Parent mesh not found: ${n.parent}`);n.mesh.timelineAttachment=n.inheritTimeline?o:n.mesh,n.mesh.setParentMesh(o),n.mesh.region!=null&&n.mesh.updateRegion()}if(this.linkedMeshes.length=0,r.events)for(let h in r.events){let l=r.events[h],n=new Ii(h);n.intValue=E(l,"int",0),n.floatValue=E(l,"float",0),n.stringValue=E(l,"string",""),n.audioPath=E(l,"audio",null),n.audioPath&&(n.volume=E(l,"volume",1),n.balance=E(l,"balance",0)),i.events.push(n)}if(r.animations)for(let h in r.animations){let l=r.animations[h];this.readAnimation(l,h,i)}return i}readAttachment(t,e,i,r,s){let h=this.scale;switch(r=E(t,"name",r),E(t,"type","region")){case"region":{let l=E(t,"path",r),n=this.readSequence(E(t,"sequence",null)),a=this.attachmentLoader.newRegionAttachment(e,r,l,n);if(!a)return null;a.path=l,a.x=E(t,"x",0)*h,a.y=E(t,"y",0)*h,a.scaleX=E(t,"scaleX",1),a.scaleY=E(t,"scaleY",1),a.rotation=E(t,"rotation",0),a.width=t.width*h,a.height=t.height*h,a.sequence=n;let o=E(t,"color",null);return o&&a.color.setFromString(o),a.region!=null&&a.updateRegion(),a}case"boundingbox":{let l=this.attachmentLoader.newBoundingBoxAttachment(e,r);if(!l)return null;this.readVertices(t,l,t.vertexCount<<1);let n=E(t,"color",null);return n&&l.color.setFromString(n),l}case"mesh":case"linkedmesh":{let l=E(t,"path",r),n=this.readSequence(E(t,"sequence",null)),a=this.attachmentLoader.newMeshAttachment(e,r,l,n);if(!a)return null;a.path=l;let o=E(t,"color",null);o&&a.color.setFromString(o),a.width=E(t,"width",0)*h,a.height=E(t,"height",0)*h,a.sequence=n;let c=E(t,"parent",null);if(c)return this.linkedMeshes.push(new An(a,E(t,"skin",null),i,c,E(t,"timelines",!0))),a;let d=t.uvs;return this.readVertices(t,a,d.length),a.triangles=t.triangles,a.regionUVs=d,a.region!=null&&a.updateRegion(),a.edges=E(t,"edges",null),a.hullLength=E(t,"hull",0)*2,a}case"path":{let l=this.attachmentLoader.newPathAttachment(e,r);if(!l)return null;l.closed=E(t,"closed",!1),l.constantSpeed=E(t,"constantSpeed",!0);let n=t.vertexCount;this.readVertices(t,l,n<<1);let a=X.newArray(n/3,0);for(let c=0;c<t.lengths.length;c++)a[c]=t.lengths[c]*h;l.lengths=a;let o=E(t,"color",null);return o&&l.color.setFromString(o),l}case"point":{let l=this.attachmentLoader.newPointAttachment(e,r);if(!l)return null;l.x=E(t,"x",0)*h,l.y=E(t,"y",0)*h,l.rotation=E(t,"rotation",0);let n=E(t,"color",null);return n&&l.color.setFromString(n),l}case"clipping":{let l=this.attachmentLoader.newClippingAttachment(e,r);if(!l)return null;let n=E(t,"end",null);n&&(l.endSlot=s.findSlot(n));let a=t.vertexCount;this.readVertices(t,l,a<<1);let o=E(t,"color",null);return o&&l.color.setFromString(o),l}}return null}readSequence(t){if(t==null)return null;let e=new ns(E(t,"count",0));return e.start=E(t,"start",1),e.digits=E(t,"digits",0),e.setupIndex=E(t,"setup",0),e}readVertices(t,e,i){let r=this.scale;e.worldVerticesLength=i;let s=t.vertices;if(i==s.length){let n=X.toFloatArray(s);if(r!=1)for(let a=0,o=s.length;a<o;a++)n[a]*=r;e.vertices=n;return}let h=new Array,l=new Array;for(let n=0,a=s.length;n<a;){let o=s[n++];l.push(o);for(let c=n+o*4;n<c;n+=4)l.push(s[n]),h.push(s[n+1]*r),h.push(s[n+2]*r),h.push(s[n+3])}e.bones=l,e.vertices=X.toFloatArray(h)}readAnimation(t,e,i){let r=this.scale,s=new Array;if(t.slots)for(let l in t.slots){let n=t.slots[l],a=i.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 u=d.length;if(c=="attachment"){let m=new We(u,o);for(let f=0;f<u;f++){let g=d[f];m.setFrame(f,E(g,"time",0),E(g,"name",null))}s.push(m)}else if(c=="rgba"){let m=new Zt(u,u<<2,o),f=d[0],g=E(f,"time",0),x=K.fromString(f.color);for(let b=0,p=0;;b++){m.setFrame(b,g,x.r,x.g,x.b,x.a);let w=d[b+1];if(!w){m.shrink(p);break}let v=E(w,"time",0),y=K.fromString(w.color),A=f.curve;A&&(p=le(A,m,p,b,0,g,v,x.r,y.r,1),p=le(A,m,p,b,1,g,v,x.g,y.g,1),p=le(A,m,p,b,2,g,v,x.b,y.b,1),p=le(A,m,p,b,3,g,v,x.a,y.a,1)),g=v,x=y,f=w}s.push(m)}else if(c=="rgb"){let m=new Jt(u,u*3,o),f=d[0],g=E(f,"time",0),x=K.fromString(f.color);for(let b=0,p=0;;b++){m.setFrame(b,g,x.r,x.g,x.b);let w=d[b+1];if(!w){m.shrink(p);break}let v=E(w,"time",0),y=K.fromString(w.color),A=f.curve;A&&(p=le(A,m,p,b,0,g,v,x.r,y.r,1),p=le(A,m,p,b,1,g,v,x.g,y.g,1),p=le(A,m,p,b,2,g,v,x.b,y.b,1)),g=v,x=y,f=w}s.push(m)}else if(c=="alpha")s.push(Ie(d,new Kt(u,u,o),0,1));else if(c=="rgba2"){let m=new Qt(u,u*7,o),f=d[0],g=E(f,"time",0),x=K.fromString(f.light),b=K.fromString(f.dark);for(let p=0,w=0;;p++){m.setFrame(p,g,x.r,x.g,x.b,x.a,b.r,b.g,b.b);let v=d[p+1];if(!v){m.shrink(w);break}let y=E(v,"time",0),A=K.fromString(v.light),C=K.fromString(v.dark),S=f.curve;S&&(w=le(S,m,w,p,0,g,y,x.r,A.r,1),w=le(S,m,w,p,1,g,y,x.g,A.g,1),w=le(S,m,w,p,2,g,y,x.b,A.b,1),w=le(S,m,w,p,3,g,y,x.a,A.a,1),w=le(S,m,w,p,4,g,y,b.r,C.r,1),w=le(S,m,w,p,5,g,y,b.g,C.g,1),w=le(S,m,w,p,6,g,y,b.b,C.b,1)),g=y,x=A,b=C,f=v}s.push(m)}else if(c=="rgb2"){let m=new $t(u,u*6,o),f=d[0],g=E(f,"time",0),x=K.fromString(f.light),b=K.fromString(f.dark);for(let p=0,w=0;;p++){m.setFrame(p,g,x.r,x.g,x.b,b.r,b.g,b.b);let v=d[p+1];if(!v){m.shrink(w);break}let y=E(v,"time",0),A=K.fromString(v.light),C=K.fromString(v.dark),S=f.curve;S&&(w=le(S,m,w,p,0,g,y,x.r,A.r,1),w=le(S,m,w,p,1,g,y,x.g,A.g,1),w=le(S,m,w,p,2,g,y,x.b,A.b,1),w=le(S,m,w,p,3,g,y,b.r,C.r,1),w=le(S,m,w,p,4,g,y,b.g,C.g,1),w=le(S,m,w,p,5,g,y,b.b,C.b,1)),g=y,x=A,b=C,f=v}s.push(m)}}}if(t.bones)for(let l in t.bones){let n=t.bones[l],a=i.findBone(l);if(!a)throw new Error("Bone not found: "+l);let o=a.index;for(let c in n){let d=n[c],u=d.length;if(u!=0){if(c==="rotate")s.push(Ie(d,new st(u,u,o),0,1));else if(c==="translate"){let m=new Dt(u,u<<1,o);s.push(Vi(d,m,"x","y",0,r))}else if(c==="translatex"){let m=new Nt(u,u,o);s.push(Ie(d,m,0,r))}else if(c==="translatey"){let m=new Ut(u,u,o);s.push(Ie(d,m,0,r))}else if(c==="scale"){let m=new Wt(u,u<<1,o);s.push(Vi(d,m,"x","y",1,1))}else if(c==="scalex"){let m=new Gt(u,u,o);s.push(Ie(d,m,1,1))}else if(c==="scaley"){let m=new zt(u,u,o);s.push(Ie(d,m,1,1))}else if(c==="shear"){let m=new qt(u,u<<1,o);s.push(Vi(d,m,"x","y",0,1))}else if(c==="shearx"){let m=new _t(u,u,o);s.push(Ie(d,m,0,1))}else if(c==="sheary"){let m=new Ht(u,u,o);s.push(Ie(d,m,0,1))}else if(c==="inherit"){let m=new jt(u,a.index);for(let f=0;f<d.length;f++){let g=d[f];m.setFrame(f,E(g,"time",0),X.enumValue(vt,E(g,"inherit","Normal")))}s.push(m)}}}}if(t.ik)for(let l in t.ik){let n=t.ik[l],a=n[0];if(!a)continue;let o=i.findIkConstraint(l);if(!o)throw new Error("IK Constraint not found: "+l);let c=i.ikConstraints.indexOf(o),d=new ti(n.length,n.length<<1,c),u=E(a,"time",0),m=E(a,"mix",1),f=E(a,"softness",0)*r;for(let g=0,x=0;;g++){d.setFrame(g,u,m,f,E(a,"bendPositive",!0)?1:-1,E(a,"compress",!1),E(a,"stretch",!1));let b=n[g+1];if(!b){d.shrink(x);break}let p=E(b,"time",0),w=E(b,"mix",1),v=E(b,"softness",0)*r,y=a.curve;y&&(x=le(y,d,x,g,0,u,p,m,w,1),x=le(y,d,x,g,1,u,p,f,v,r)),u=p,m=w,f=v,a=b}s.push(d)}if(t.transform)for(let l in t.transform){let n=t.transform[l],a=n[0];if(!a)continue;let o=i.findTransformConstraint(l);if(!o)throw new Error("Transform constraint not found: "+l);let c=i.transformConstraints.indexOf(o),d=new ii(n.length,n.length*6,c),u=E(a,"time",0),m=E(a,"mixRotate",1),f=E(a,"mixX",1),g=E(a,"mixY",f),x=E(a,"mixScaleX",1),b=E(a,"mixScaleY",x),p=E(a,"mixShearY",1);for(let w=0,v=0;;w++){d.setFrame(w,u,m,f,g,x,b,p);let y=n[w+1];if(!y){d.shrink(v);break}let A=E(y,"time",0),C=E(y,"mixRotate",1),S=E(y,"mixX",1),I=E(y,"mixY",S),k=E(y,"mixScaleX",1),Y=E(y,"mixScaleY",k),F=E(y,"mixShearY",1),P=a.curve;P&&(v=le(P,d,v,w,0,u,A,m,C,1),v=le(P,d,v,w,1,u,A,f,S,1),v=le(P,d,v,w,2,u,A,g,I,1),v=le(P,d,v,w,3,u,A,x,k,1),v=le(P,d,v,w,4,u,A,b,Y,1),v=le(P,d,v,w,5,u,A,p,F,1)),u=A,m=C,f=S,g=I,x=k,b=Y,x=k,a=y}s.push(d)}if(t.path)for(let l in t.path){let n=t.path[l],a=i.findPathConstraint(l);if(!a)throw new Error("Path constraint not found: "+l);let o=i.pathConstraints.indexOf(a);for(let c in n){let d=n[c],u=d[0];if(!u)continue;let m=d.length;if(c==="position"){let f=new si(m,m,o);s.push(Ie(d,f,0,a.positionMode==0?r:1))}else if(c==="spacing"){let f=new ri(m,m,o);s.push(Ie(d,f,0,a.spacingMode==0||a.spacingMode==1?r:1))}else if(c==="mix"){let f=new ni(m,m*3,o),g=E(u,"time",0),x=E(u,"mixRotate",1),b=E(u,"mixX",1),p=E(u,"mixY",b);for(let w=0,v=0;;w++){f.setFrame(w,g,x,b,p);let y=d[w+1];if(!y){f.shrink(v);break}let A=E(y,"time",0),C=E(y,"mixRotate",1),S=E(y,"mixX",1),I=E(y,"mixY",S),k=u.curve;k&&(v=le(k,f,v,w,0,g,A,x,C,1),v=le(k,f,v,w,1,g,A,b,S,1),v=le(k,f,v,w,2,g,A,p,I,1)),g=A,x=C,b=S,p=I,u=y}s.push(f)}}}if(t.physics)for(let l in t.physics){let n=t.physics[l],a=-1;if(l.length>0){let o=i.findPhysicsConstraint(l);if(!o)throw new Error("Physics constraint not found: "+l);a=i.physicsConstraints.indexOf(o)}for(let o in n){let c=n[o],d=c[0];if(!d)continue;let u=c.length;if(o=="reset"){const f=new fi(u,a);for(let g=0;d!=null;d=c[g+1],g++)f.setFrame(g,E(d,"time",0));s.push(f);continue}let m;if(o=="inertia")m=new ai(u,u,a);else if(o=="strength")m=new li(u,u,a);else if(o=="damping")m=new oi(u,u,a);else if(o=="mass")m=new hi(u,u,a);else if(o=="wind")m=new ci(u,u,a);else if(o=="gravity")m=new di(u,u,a);else if(o=="mix")m=new ui(u,u,a);else continue;s.push(Ie(c,m,0,1))}}if(t.attachments)for(let l in t.attachments){let n=t.attachments[l],a=i.findSkin(l);if(!a)throw new Error("Skin not found: "+l);for(let o in n){let c=n[o],d=i.findSlot(o);if(!d)throw new Error("Slot not found: "+o);let u=d.index;for(let m in c){let f=c[m],g=a.getAttachment(u,m);for(let x in f){let b=f[x],p=b[0];if(p){if(x=="deform"){let w=g.bones,v=g.vertices,y=w?v.length/3*2:v.length,A=new ei(b.length,b.length,u,g),C=E(p,"time",0);for(let S=0,I=0;;S++){let k,Y=E(p,"vertices",null);if(!Y)k=w?X.newFloatArray(y):v;else{k=X.newFloatArray(y);let R=E(p,"offset",0);if(X.arrayCopy(Y,0,k,R,Y.length),r!=1)for(let B=R,ie=B+Y.length;B<ie;B++)k[B]*=r;if(!w)for(let B=0;B<y;B++)k[B]+=v[B]}A.setFrame(S,C,k);let F=b[S+1];if(!F){A.shrink(I);break}let P=E(F,"time",0),M=p.curve;M&&(I=le(M,A,I,S,0,C,P,0,1,1)),C=P,p=F}s.push(A)}else if(x=="sequence"){let w=new mi(b.length,u,g),v=0;for(let y=0;y<b.length;y++){let A=E(p,"delay",v),C=E(p,"time",0),S=as[E(p,"mode","hold")],I=E(p,"index",0);w.setFrame(y,C,S,I,A),v=A,p=b[y+1]}s.push(w)}}}}}}if(t.drawOrder){let l=new je(t.drawOrder.length),n=i.slots.length,a=0;for(let o=0;o<t.drawOrder.length;o++,a++){let c=t.drawOrder[o],d=null,u=E(c,"offsets",null);if(u){d=X.newArray(n,-1);let m=X.newArray(n-u.length,0),f=0,g=0;for(let x=0;x<u.length;x++){let b=u[x],p=i.findSlot(b.slot);if(!p)throw new Error("Slot not found: "+p);let w=p.index;for(;f!=w;)m[g++]=f++;d[f+b.offset]=f++}for(;f<n;)m[g++]=f++;for(let x=n-1;x>=0;x--)d[x]==-1&&(d[x]=m[--g])}l.setFrame(a,E(c,"time",0),d)}s.push(l)}if(t.events){let l=new mt(t.events.length),n=0;for(let a=0;a<t.events.length;a++,n++){let o=t.events[a],c=i.findEvent(o.name);if(!c)throw new Error("Event not found: "+o.name);let d=new Ti(X.toSinglePrecision(E(o,"time",0)),c);d.intValue=E(o,"int",c.intValue),d.floatValue=E(o,"float",c.floatValue),d.stringValue=E(o,"string",c.stringValue),d.data.audioPath&&(d.volume=E(o,"volume",1),d.balance=E(o,"balance",0)),l.setFrame(n,d)}s.push(l)}let h=0;for(let l=0,n=s.length;l<n;l++)h=Math.max(h,s[l].getDuration());i.animations.push(new ut(e,s,h))}},An=class{parent;skin;slotIndex;mesh;inheritTimeline;constructor(t,e,i,r,s){this.mesh=t,this.skin=e,this.slotIndex=i,this.parent=r,this.inheritTimeline=s}};function Ie(t,e,i,r){let s=t[0],h=E(s,"time",0),l=E(s,"value",i)*r,n=0;for(let a=0;;a++){e.setFrame(a,h,l);let o=t[a+1];if(!o)return e.shrink(n),e;let c=E(o,"time",0),d=E(o,"value",i)*r;s.curve&&(n=le(s.curve,e,n,a,0,h,c,l,d,r)),h=c,l=d,s=o}}function Vi(t,e,i,r,s,h){let l=t[0],n=E(l,"time",0),a=E(l,i,s)*h,o=E(l,r,s)*h,c=0;for(let d=0;;d++){e.setFrame(d,n,a,o);let u=t[d+1];if(!u)return e.shrink(c),e;let m=E(u,"time",0),f=E(u,i,s)*h,g=E(u,r,s)*h,x=l.curve;x&&(c=le(x,e,c,d,0,n,m,a,f,h),c=le(x,e,c,d,1,n,m,o,g,h)),n=m,a=f,o=g,l=u}}function le(t,e,i,r,s,h,l,n,a,o){if(t=="stepped")return e.setStepped(r),i;let c=s<<2,d=t[c],u=t[c+1]*o,m=t[c+2],f=t[c+3]*o;return e.setBezier(i,r,s,h,n,d,u,m,f,l,a),i+1}function E(t,e,i){return t[e]!==void 0?t[e]:i}typeof Math.fround>"u"&&(Math.fround=function(t){return function(e){return t[0]=e,t[0]}}(new Float32Array(1)));var xe=class{canvas;gl;restorables=new Array;constructor(t,e={alpha:"true"}){if(t instanceof WebGLRenderingContext||typeof WebGL2RenderingContext<"u"&&t instanceof WebGL2RenderingContext)this.gl=t,this.canvas=this.gl.canvas;else{let i=t;this.gl=i.getContext("webgl2",e)||i.getContext("webgl",e),this.canvas=i,i.addEventListener("webglcontextlost",r=>{let s=r;r&&r.preventDefault()}),i.addEventListener("webglcontextrestored",r=>{for(let s=0,h=this.restorables.length;s<h;s++)this.restorables[s].restore()})}}addRestorable(t){this.restorables.push(t)}removeRestorable(t){let e=this.restorables.indexOf(t);e>-1&&this.restorables.splice(e,1)}},ze=class Pt extends xt{context;texture=null;boundUnit=0;useMipMaps=!1;static DISABLE_UNPACK_PREMULTIPLIED_ALPHA_WEBGL=!1;constructor(e,i,r=!1){super(i),this.context=e instanceof xe?e:new xe(e),this.useMipMaps=r,this.restore(),this.context.addRestorable(this)}setFilters(e,i){let r=this.context.gl;this.bind(),r.texParameteri(r.TEXTURE_2D,r.TEXTURE_MIN_FILTER,e),r.texParameteri(r.TEXTURE_2D,r.TEXTURE_MAG_FILTER,Pt.validateMagFilter(i)),this.useMipMaps=Pt.usesMipMaps(e),this.useMipMaps&&r.generateMipmap(r.TEXTURE_2D)}static validateMagFilter(e){switch(e){case 9987:case 9985:case 9986:case 9984:return 9729;default:return e}}static usesMipMaps(e){switch(e){case 9987:case 9985:case 9986:case 9984:return!0;default:return!1}}setWraps(e,i){let r=this.context.gl;this.bind(),r.texParameteri(r.TEXTURE_2D,r.TEXTURE_WRAP_S,e),r.texParameteri(r.TEXTURE_2D,r.TEXTURE_WRAP_T,i)}update(e){let i=this.context.gl;this.texture||(this.texture=this.context.gl.createTexture()),this.bind(),Pt.DISABLE_UNPACK_PREMULTIPLIED_ALPHA_WEBGL&&i.pixelStorei(i.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1),i.texImage2D(i.TEXTURE_2D,0,i.RGBA,i.RGBA,i.UNSIGNED_BYTE,this._image),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_MAG_FILTER,i.LINEAR),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_MIN_FILTER,e?i.LINEAR_MIPMAP_LINEAR:i.LINEAR),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_WRAP_S,i.CLAMP_TO_EDGE),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_WRAP_T,i.CLAMP_TO_EDGE),e&&i.generateMipmap(i.TEXTURE_2D)}restore(){this.texture=null,this.update(this.useMipMaps)}bind(e=0){let i=this.context.gl;this.boundUnit=e,i.activeTexture(i.TEXTURE0+e),i.bindTexture(i.TEXTURE_2D,this.texture)}unbind(){let e=this.context.gl;e.activeTexture(e.TEXTURE0+this.boundUnit),e.bindTexture(e.TEXTURE_2D,null)}dispose(){this.context.removeRestorable(this),this.context.gl.deleteTexture(this.texture)}},Fs=class extends vs{constructor(t,e="",i=new Si){super(r=>new ze(t,r),e,i)}},Se=class{x=0;y=0;z=0;constructor(t=0,e=0,i=0){this.x=t,this.y=e,this.z=i}setFrom(t){return this.x=t.x,this.y=t.y,this.z=t.z,this}set(t,e,i){return this.x=t,this.y=e,this.z=i,this}add(t){return this.x+=t.x,this.y+=t.y,this.z+=t.z,this}sub(t){return this.x-=t.x,this.y-=t.y,this.z-=t.z,this}scale(t){return this.x*=t,this.y*=t,this.z*=t,this}normalize(){let t=this.length();return t==0?this:(t=1/t,this.x*=t,this.y*=t,this.z*=t,this)}cross(t){return this.set(this.y*t.z-this.z*t.y,this.z*t.x-this.x*t.z,this.x*t.y-this.y*t.x)}multiply(t){let e=t.values;return this.set(this.x*e[O]+this.y*e[G]+this.z*e[z]+e[V],this.x*e[q]+this.y*e[D]+this.z*e[_]+e[N],this.x*e[H]+this.y*e[j]+this.z*e[U]+e[W])}project(t){let e=t.values,i=1/(this.x*e[Q]+this.y*e[$]+this.z*e[ee]+e[J]);return this.set((this.x*e[O]+this.y*e[G]+this.z*e[z]+e[V])*i,(this.x*e[q]+this.y*e[D]+this.z*e[_]+e[N])*i,(this.x*e[H]+this.y*e[j]+this.z*e[U]+e[W])*i)}dot(t){return this.x*t.x+this.y*t.y+this.z*t.z}length(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z)}distance(t){let e=t.x-this.x,i=t.y-this.y,r=t.z-this.z;return Math.sqrt(e*e+i*i+r*r)}},O=0,G=4,z=8,V=12,q=1,D=5,_=9,N=13,H=2,j=6,U=10,W=14,Q=3,$=7,ee=11,J=15,lt=class Ye{temp=new Float32Array(16);values=new Float32Array(16);static xAxis=new Se;static yAxis=new Se;static zAxis=new Se;static tmpMatrix=new Ye;constructor(){let e=this.values;e[O]=1,e[D]=1,e[U]=1,e[J]=1}set(e){return this.values.set(e),this}transpose(){let e=this.temp,i=this.values;return e[O]=i[O],e[G]=i[q],e[z]=i[H],e[V]=i[Q],e[q]=i[G],e[D]=i[D],e[_]=i[j],e[N]=i[$],e[H]=i[z],e[j]=i[_],e[U]=i[U],e[W]=i[ee],e[Q]=i[V],e[$]=i[N],e[ee]=i[W],e[J]=i[J],this.set(e)}identity(){let e=this.values;return e[O]=1,e[G]=0,e[z]=0,e[V]=0,e[q]=0,e[D]=1,e[_]=0,e[N]=0,e[H]=0,e[j]=0,e[U]=1,e[W]=0,e[Q]=0,e[$]=0,e[ee]=0,e[J]=1,this}invert(){let e=this.values,i=this.temp,r=e[Q]*e[j]*e[_]*e[V]-e[H]*e[$]*e[_]*e[V]-e[Q]*e[D]*e[U]*e[V]+e[q]*e[$]*e[U]*e[V]+e[H]*e[D]*e[ee]*e[V]-e[q]*e[j]*e[ee]*e[V]-e[Q]*e[j]*e[z]*e[N]+e[H]*e[$]*e[z]*e[N]+e[Q]*e[G]*e[U]*e[N]-e[O]*e[$]*e[U]*e[N]-e[H]*e[G]*e[ee]*e[N]+e[O]*e[j]*e[ee]*e[N]+e[Q]*e[D]*e[z]*e[W]-e[q]*e[$]*e[z]*e[W]-e[Q]*e[G]*e[_]*e[W]+e[O]*e[$]*e[_]*e[W]+e[q]*e[G]*e[ee]*e[W]-e[O]*e[D]*e[ee]*e[W]-e[H]*e[D]*e[z]*e[J]+e[q]*e[j]*e[z]*e[J]+e[H]*e[G]*e[_]*e[J]-e[O]*e[j]*e[_]*e[J]-e[q]*e[G]*e[U]*e[J]+e[O]*e[D]*e[U]*e[J];if(r==0)throw new Error("non-invertible matrix");let s=1/r;return i[O]=e[_]*e[W]*e[$]-e[N]*e[U]*e[$]+e[N]*e[j]*e[ee]-e[D]*e[W]*e[ee]-e[_]*e[j]*e[J]+e[D]*e[U]*e[J],i[G]=e[V]*e[U]*e[$]-e[z]*e[W]*e[$]-e[V]*e[j]*e[ee]+e[G]*e[W]*e[ee]+e[z]*e[j]*e[J]-e[G]*e[U]*e[J],i[z]=e[z]*e[N]*e[$]-e[V]*e[_]*e[$]+e[V]*e[D]*e[ee]-e[G]*e[N]*e[ee]-e[z]*e[D]*e[J]+e[G]*e[_]*e[J],i[V]=e[V]*e[_]*e[j]-e[z]*e[N]*e[j]-e[V]*e[D]*e[U]+e[G]*e[N]*e[U]+e[z]*e[D]*e[W]-e[G]*e[_]*e[W],i[q]=e[N]*e[U]*e[Q]-e[_]*e[W]*e[Q]-e[N]*e[H]*e[ee]+e[q]*e[W]*e[ee]+e[_]*e[H]*e[J]-e[q]*e[U]*e[J],i[D]=e[z]*e[W]*e[Q]-e[V]*e[U]*e[Q]+e[V]*e[H]*e[ee]-e[O]*e[W]*e[ee]-e[z]*e[H]*e[J]+e[O]*e[U]*e[J],i[_]=e[V]*e[_]*e[Q]-e[z]*e[N]*e[Q]-e[V]*e[q]*e[ee]+e[O]*e[N]*e[ee]+e[z]*e[q]*e[J]-e[O]*e[_]*e[J],i[N]=e[z]*e[N]*e[H]-e[V]*e[_]*e[H]+e[V]*e[q]*e[U]-e[O]*e[N]*e[U]-e[z]*e[q]*e[W]+e[O]*e[_]*e[W],i[H]=e[D]*e[W]*e[Q]-e[N]*e[j]*e[Q]+e[N]*e[H]*e[$]-e[q]*e[W]*e[$]-e[D]*e[H]*e[J]+e[q]*e[j]*e[J],i[j]=e[V]*e[j]*e[Q]-e[G]*e[W]*e[Q]-e[V]*e[H]*e[$]+e[O]*e[W]*e[$]+e[G]*e[H]*e[J]-e[O]*e[j]*e[J],i[U]=e[G]*e[N]*e[Q]-e[V]*e[D]*e[Q]+e[V]*e[q]*e[$]-e[O]*e[N]*e[$]-e[G]*e[q]*e[J]+e[O]*e[D]*e[J],i[W]=e[V]*e[D]*e[H]-e[G]*e[N]*e[H]-e[V]*e[q]*e[j]+e[O]*e[N]*e[j]+e[G]*e[q]*e[W]-e[O]*e[D]*e[W],i[Q]=e[_]*e[j]*e[Q]-e[D]*e[U]*e[Q]-e[_]*e[H]*e[$]+e[q]*e[U]*e[$]+e[D]*e[H]*e[ee]-e[q]*e[j]*e[ee],i[$]=e[G]*e[U]*e[Q]-e[z]*e[j]*e[Q]+e[z]*e[H]*e[$]-e[O]*e[U]*e[$]-e[G]*e[H]*e[ee]+e[O]*e[j]*e[ee],i[ee]=e[z]*e[D]*e[Q]-e[G]*e[_]*e[Q]-e[z]*e[q]*e[$]+e[O]*e[_]*e[$]+e[G]*e[q]*e[ee]-e[O]*e[D]*e[ee],i[J]=e[G]*e[_]*e[H]-e[z]*e[D]*e[H]+e[z]*e[q]*e[j]-e[O]*e[_]*e[j]-e[G]*e[q]*e[U]+e[O]*e[D]*e[U],e[O]=i[O]*s,e[G]=i[G]*s,e[z]=i[z]*s,e[V]=i[V]*s,e[q]=i[q]*s,e[D]=i[D]*s,e[_]=i[_]*s,e[N]=i[N]*s,e[H]=i[H]*s,e[j]=i[j]*s,e[U]=i[U]*s,e[W]=i[W]*s,e[Q]=i[Q]*s,e[$]=i[$]*s,e[ee]=i[ee]*s,e[J]=i[J]*s,this}determinant(){let e=this.values;return e[Q]*e[j]*e[_]*e[V]-e[H]*e[$]*e[_]*e[V]-e[Q]*e[D]*e[U]*e[V]+e[q]*e[$]*e[U]*e[V]+e[H]*e[D]*e[ee]*e[V]-e[q]*e[j]*e[ee]*e[V]-e[Q]*e[j]*e[z]*e[N]+e[H]*e[$]*e[z]*e[N]+e[Q]*e[G]*e[U]*e[N]-e[O]*e[$]*e[U]*e[N]-e[H]*e[G]*e[ee]*e[N]+e[O]*e[j]*e[ee]*e[N]+e[Q]*e[D]*e[z]*e[W]-e[q]*e[$]*e[z]*e[W]-e[Q]*e[G]*e[_]*e[W]+e[O]*e[$]*e[_]*e[W]+e[q]*e[G]*e[ee]*e[W]-e[O]*e[D]*e[ee]*e[W]-e[H]*e[D]*e[z]*e[J]+e[q]*e[j]*e[z]*e[J]+e[H]*e[G]*e[_]*e[J]-e[O]*e[j]*e[_]*e[J]-e[q]*e[G]*e[U]*e[J]+e[O]*e[D]*e[U]*e[J]}translate(e,i,r){let s=this.values;return s[V]+=e,s[N]+=i,s[W]+=r,this}copy(){return new Ye().set(this.values)}projection(e,i,r,s){this.identity();let h=1/Math.tan(r*(Math.PI/180)/2),l=(i+e)/(e-i),n=2*i*e/(e-i),a=this.values;return a[O]=h/s,a[q]=0,a[H]=0,a[Q]=0,a[G]=0,a[D]=h,a[j]=0,a[$]=0,a[z]=0,a[_]=0,a[U]=l,a[ee]=-1,a[V]=0,a[N]=0,a[W]=n,a[J]=0,this}ortho2d(e,i,r,s){return this.ortho(e,e+r,i,i+s,0,1)}ortho(e,i,r,s,h,l){this.identity();let n=2/(i-e),a=2/(s-r),o=-2/(l-h),c=-(i+e)/(i-e),d=-(s+r)/(s-r),u=-(l+h)/(l-h),m=this.values;return m[O]=n,m[q]=0,m[H]=0,m[Q]=0,m[G]=0,m[D]=a,m[j]=0,m[$]=0,m[z]=0,m[_]=0,m[U]=o,m[ee]=0,m[V]=c,m[N]=d,m[W]=u,m[J]=1,this}multiply(e){let i=this.temp,r=this.values,s=e.values;return i[O]=r[O]*s[O]+r[G]*s[q]+r[z]*s[H]+r[V]*s[Q],i[G]=r[O]*s[G]+r[G]*s[D]+r[z]*s[j]+r[V]*s[$],i[z]=r[O]*s[z]+r[G]*s[_]+r[z]*s[U]+r[V]*s[ee],i[V]=r[O]*s[V]+r[G]*s[N]+r[z]*s[W]+r[V]*s[J],i[q]=r[q]*s[O]+r[D]*s[q]+r[_]*s[H]+r[N]*s[Q],i[D]=r[q]*s[G]+r[D]*s[D]+r[_]*s[j]+r[N]*s[$],i[_]=r[q]*s[z]+r[D]*s[_]+r[_]*s[U]+r[N]*s[ee],i[N]=r[q]*s[V]+r[D]*s[N]+r[_]*s[W]+r[N]*s[J],i[H]=r[H]*s[O]+r[j]*s[q]+r[U]*s[H]+r[W]*s[Q],i[j]=r[H]*s[G]+r[j]*s[D]+r[U]*s[j]+r[W]*s[$],i[U]=r[H]*s[z]+r[j]*s[_]+r[U]*s[U]+r[W]*s[ee],i[W]=r[H]*s[V]+r[j]*s[N]+r[U]*s[W]+r[W]*s[J],i[Q]=r[Q]*s[O]+r[$]*s[q]+r[ee]*s[H]+r[J]*s[Q],i[$]=r[Q]*s[G]+r[$]*s[D]+r[ee]*s[j]+r[J]*s[$],i[ee]=r[Q]*s[z]+r[$]*s[_]+r[ee]*s[U]+r[J]*s[ee],i[J]=r[Q]*s[V]+r[$]*s[N]+r[ee]*s[W]+r[J]*s[J],this.set(this.temp)}multiplyLeft(e){let i=this.temp,r=this.values,s=e.values;return i[O]=s[O]*r[O]+s[G]*r[q]+s[z]*r[H]+s[V]*r[Q],i[G]=s[O]*r[G]+s[G]*r[D]+s[z]*r[j]+s[V]*r[$],i[z]=s[O]*r[z]+s[G]*r[_]+s[z]*r[U]+s[V]*r[ee],i[V]=s[O]*r[V]+s[G]*r[N]+s[z]*r[W]+s[V]*r[J],i[q]=s[q]*r[O]+s[D]*r[q]+s[_]*r[H]+s[N]*r[Q],i[D]=s[q]*r[G]+s[D]*r[D]+s[_]*r[j]+s[N]*r[$],i[_]=s[q]*r[z]+s[D]*r[_]+s[_]*r[U]+s[N]*r[ee],i[N]=s[q]*r[V]+s[D]*r[N]+s[_]*r[W]+s[N]*r[J],i[H]=s[H]*r[O]+s[j]*r[q]+s[U]*r[H]+s[W]*r[Q],i[j]=s[H]*r[G]+s[j]*r[D]+s[U]*r[j]+s[W]*r[$],i[U]=s[H]*r[z]+s[j]*r[_]+s[U]*r[U]+s[W]*r[ee],i[W]=s[H]*r[V]+s[j]*r[N]+s[U]*r[W]+s[W]*r[J],i[Q]=s[Q]*r[O]+s[$]*r[q]+s[ee]*r[H]+s[J]*r[Q],i[$]=s[Q]*r[G]+s[$]*r[D]+s[ee]*r[j]+s[J]*r[$],i[ee]=s[Q]*r[z]+s[$]*r[_]+s[ee]*r[U]+s[J]*r[ee],i[J]=s[Q]*r[V]+s[$]*r[N]+s[ee]*r[W]+s[J]*r[J],this.set(this.temp)}lookAt(e,i,r){let s=Ye.xAxis,h=Ye.yAxis,l=Ye.zAxis;l.setFrom(i).normalize(),s.setFrom(i).normalize(),s.cross(r).normalize(),h.setFrom(s).cross(l).normalize(),this.identity();let n=this.values;return n[O]=s.x,n[G]=s.y,n[z]=s.z,n[q]=h.x,n[D]=h.y,n[_]=h.z,n[H]=-l.x,n[j]=-l.y,n[U]=-l.z,Ye.tmpMatrix.identity(),Ye.tmpMatrix.values[V]=-e.x,Ye.tmpMatrix.values[N]=-e.y,Ye.tmpMatrix.values[W]=-e.z,this.multiply(Ye.tmpMatrix),this}},Ps=class{position=new Se(0,0,0);direction=new Se(0,0,-1);up=new Se(0,1,0);near=0;far=100;zoom=1;viewportWidth=0;viewportHeight=0;projectionView=new lt;inverseProjectionView=new lt;projection=new lt;view=new lt;constructor(t,e){this.viewportWidth=t,this.viewportHeight=e,this.update()}update(){let t=this.projection,e=this.view,i=this.projectionView,r=this.inverseProjectionView,s=this.zoom,h=this.viewportWidth,l=this.viewportHeight;t.ortho(s*(-h/2),s*(h/2),s*(-l/2),s*(l/2),this.near,this.far),e.lookAt(this.position,this.direction,this.up),i.set(t.values),i.multiply(e),r.set(i.values).invert()}screenToWorld(t,e,i){let r=t.x,s=i-t.y-1;return t.x=2*r/e-1,t.y=2*s/i-1,t.z=2*t.z-1,t.project(this.inverseProjectionView),t}worldToScreen(t,e,i){return t.project(this.projectionView),t.x=e*(t.x+1)/2,t.y=i*(t.y+1)/2,t.z=(t.z+1)/2,t}setViewport(t,e){this.viewportWidth=t,this.viewportHeight=e}},Di=class{element;mouseX=0;mouseY=0;buttonDown=!1;touch0=null;touch1=null;initialPinchDistance=0;listeners=new Array;autoPreventDefault;isTouch=!1;callbacks;constructor(t,e=!0){this.element=t,this.autoPreventDefault=e,this.callbacks=this.setupCallbacks(t)}setupCallbacks(t){const e=a=>{if(a instanceof MouseEvent&&!this.isTouch){let o=t.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)})}},i=a=>{if(a instanceof MouseEvent&&!this.isTouch){let o=t.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)})}},r=a=>{if(a instanceof MouseEvent&&!this.isTouch){let o=t.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)})}},s=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=t.getBoundingClientRect(),u=c.clientX-d.left,m=c.clientY-d.top,f=new Ls(c.identifier,u,m);if(this.mouseX=u,this.mouseY=m,this.buttonDown=!0,!this.touch0)this.touch0=f,this.listeners.map(g=>{g.down&&g.down(f.x,f.y,a)});else if(!this.touch1){this.touch1=f;let g=this.touch1.x-this.touch0.x,x=this.touch1.x-this.touch0.x;this.initialPinchDistance=Math.sqrt(g*g+x*x),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 u=t.getBoundingClientRect();for(var c=0;c<o.length;c++){var d=o[c];let m=d.clientX-u.left,f=d.clientY-u.top;this.touch0.identifier===d.identifier&&(this.touch0.x=this.mouseX=m,this.touch0.y=this.mouseY=f,this.listeners.map(g=>{g.dragged&&g.dragged(m,f,a)})),this.touch1&&this.touch1.identifier===d.identifier&&(this.touch1.x=this.mouseX=m,this.touch1.y=this.mouseY=f)}if(this.touch0&&this.touch1){let m=this.touch1.x-this.touch0.x,f=this.touch1.x-this.touch0.x,g=Math.sqrt(m*m+f*f);this.listeners.map(x=>{x.zoom&&x.zoom(this.initialPinchDistance,g,a)})}}this.autoPreventDefault&&a.preventDefault()},n=a=>{if(this.isTouch=!0,this.touch0){var o=a.changedTouches;let u=t.getBoundingClientRect();for(var c=0;c<o.length;c++){var d=o[c];let m=d.clientX-u.left,f=d.clientY-u.top;if(this.touch0.identifier===d.identifier)if(this.touch0=null,this.mouseX=m,this.mouseY=f,this.listeners.map(g=>{g.up&&g.up(m,f,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 t.addEventListener("mousedown",e,!0),t.addEventListener("mousemove",i,!0),t.addEventListener("mouseup",r,!0),t.addEventListener("wheel",s,!0),t.addEventListener("touchstart",h,{passive:!1,capture:!1}),t.addEventListener("touchmove",l,{passive:!1,capture:!1}),t.addEventListener("touchend",n,{passive:!1,capture:!1}),t.addEventListener("touchcancel",n),{mouseDown:e,mouseMove:i,mouseUp:r,mouseWheel:s,touchStart:h,touchMove:l,touchEnd:n}}dispose(){const t=this.element;t.removeEventListener("mousedown",this.callbacks.mouseDown,!0),t.removeEventListener("mousemove",this.callbacks.mouseMove,!0),t.removeEventListener("mouseup",this.callbacks.mouseUp,!0),t.removeEventListener("wheel",this.callbacks.mouseWheel,!0),t.removeEventListener("touchstart",this.callbacks.touchStart,{capture:!1}),t.removeEventListener("touchmove",this.callbacks.touchMove,{capture:!1}),t.removeEventListener("touchend",this.callbacks.touchEnd,{capture:!1}),t.removeEventListener("touchcancel",this.callbacks.touchEnd),this.listeners.length=0}addListener(t){this.listeners.push(t)}removeListener(t){let e=this.listeners.indexOf(t);e>-1&&this.listeners.splice(e,1)}},Ls=class{constructor(t,e,i){this.identifier=t,this.x=e,this.y=i}},Cn=class{constructor(t,e){this.canvas=t,this.camera=e;let i=0,r=0,s=0,h=0,l=0,n=0,a=0,o=0;new Di(t).addListener({down:(c,d)=>{i=e.position.x,r=e.position.y,h=n=c,l=a=d,o=e.zoom},dragged:(c,d)=>{let u=c-h,m=d-l,f=e.screenToWorld(new Se(0,0),t.clientWidth,t.clientHeight),g=e.screenToWorld(new Se(u,m),t.clientWidth,t.clientHeight).sub(f);e.position.set(i-g.x,r-g.y,0),e.update(),n=c,a=d},wheel:c=>{let d=c/200*e.zoom,u=e.zoom+d;if(u>0){let m=0,f=0;if(c<0)m=n,f=a;else{let b=new Se(t.clientWidth/2+15,t.clientHeight/2),p=n-b.x,w=t.clientHeight-1-a-b.y;m=b.x-p,f=t.clientHeight-1-b.y+w}let g=e.screenToWorld(new Se(m,f),t.clientWidth,t.clientHeight);e.zoom=u,e.update();let x=e.screenToWorld(new Se(m,f),t.clientWidth,t.clientHeight);e.position.add(g.sub(x)),e.update()}},zoom:(c,d)=>{let u=c/d;e.zoom=o*u},up:(c,d)=>{n=c,a=d},moved:(c,d)=>{n=c,a=d}})}},Me=class ue{constructor(e,i,r){this.vertexShader=i,this.fragmentShader=r,this.vsSource=i,this.fsSource=r,this.context=e instanceof xe?e:new xe(e),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 e=this.context.gl;try{if(this.vs=this.compileShader(e.VERTEX_SHADER,this.vertexShader),!this.vs)throw new Error("Couldn't compile vertex shader.");if(this.fs=this.compileShader(e.FRAGMENT_SHADER,this.fragmentShader),!this.fs)throw new Error("Couldn#t compile fragment shader.");this.program=this.compileProgram(this.vs,this.fs)}catch(i){throw this.dispose(),i}}compileShader(e,i){let r=this.context.gl,s=r.createShader(e);if(!s)throw new Error("Couldn't create shader.");if(r.shaderSource(s,i),r.compileShader(s),!r.getShaderParameter(s,r.COMPILE_STATUS)){let h="Couldn't compile shader: "+r.getShaderInfoLog(s);if(r.deleteShader(s),!r.isContextLost())throw new Error(h)}return s}compileProgram(e,i){let r=this.context.gl,s=r.createProgram();if(!s)throw new Error("Couldn't compile program.");if(r.attachShader(s,e),r.attachShader(s,i),r.linkProgram(s),!r.getProgramParameter(s,r.LINK_STATUS)){let h="Couldn't compile shader program: "+r.getProgramInfoLog(s);if(r.deleteProgram(s),!r.isContextLost())throw new Error(h)}return s}restore(){this.compile()}bind(){this.context.gl.useProgram(this.program)}unbind(){this.context.gl.useProgram(null)}setUniformi(e,i){this.context.gl.uniform1i(this.getUniformLocation(e),i)}setUniformf(e,i){this.context.gl.uniform1f(this.getUniformLocation(e),i)}setUniform2f(e,i,r){this.context.gl.uniform2f(this.getUniformLocation(e),i,r)}setUniform3f(e,i,r,s){this.context.gl.uniform3f(this.getUniformLocation(e),i,r,s)}setUniform4f(e,i,r,s,h){this.context.gl.uniform4f(this.getUniformLocation(e),i,r,s,h)}setUniform2x2f(e,i){let r=this.context.gl;this.tmp2x2.set(i),r.uniformMatrix2fv(this.getUniformLocation(e),!1,this.tmp2x2)}setUniform3x3f(e,i){let r=this.context.gl;this.tmp3x3.set(i),r.uniformMatrix3fv(this.getUniformLocation(e),!1,this.tmp3x3)}setUniform4x4f(e,i){let r=this.context.gl;this.tmp4x4.set(i),r.uniformMatrix4fv(this.getUniformLocation(e),!1,this.tmp4x4)}getUniformLocation(e){let i=this.context.gl;if(!this.program)throw new Error("Shader not compiled.");let r=i.getUniformLocation(this.program,e);if(!r&&!i.isContextLost())throw new Error(`Couldn't find location for uniform ${e}`);return r}getAttributeLocation(e){let i=this.context.gl;if(!this.program)throw new Error("Shader not compiled.");let r=i.getAttribLocation(this.program,e);if(r==-1&&!i.isContextLost())throw new Error(`Couldn't find location for attribute ${e}`);return r}dispose(){this.context.removeRestorable(this);let e=this.context.gl;this.vs&&(e.deleteShader(this.vs),this.vs=null),this.fs&&(e.deleteShader(this.fs),this.fs=null),this.program&&(e.deleteProgram(this.program),this.program=null)}static newColoredTextured(e){let i=`
3
3
  attribute vec4 ${ue.POSITION};
4
4
  attribute vec4 ${ue.COLOR};
5
5
  attribute vec2 ${ue.TEXCOORDS};
@@ -12,7 +12,7 @@ void main () {
12
12
  v_texCoords = ${ue.TEXCOORDS};
13
13
  gl_Position = ${ue.MVP_MATRIX} * ${ue.POSITION};
14
14
  }
15
- `,i=`
15
+ `,r=`
16
16
  #ifdef GL_ES
17
17
  #define LOWP lowp
18
18
  precision mediump float;
@@ -26,7 +26,7 @@ uniform sampler2D u_texture;
26
26
  void main () {
27
27
  gl_FragColor = v_color * texture2D(u_texture, v_texCoords);
28
28
  }
29
- `;return new ue(e,t,i)}static newTwoColoredTextured(e){let t=`
29
+ `;return new ue(e,i,r)}static newTwoColoredTextured(e){let i=`
30
30
  attribute vec4 ${ue.POSITION};
31
31
  attribute vec4 ${ue.COLOR};
32
32
  attribute vec4 ${ue.COLOR2};
@@ -42,7 +42,7 @@ void main () {
42
42
  v_texCoords = ${ue.TEXCOORDS};
43
43
  gl_Position = ${ue.MVP_MATRIX} * ${ue.POSITION};
44
44
  }
45
- `,i=`
45
+ `,r=`
46
46
  #ifdef GL_ES
47
47
  #define LOWP lowp
48
48
  precision mediump float;
@@ -59,7 +59,7 @@ void main () {
59
59
  gl_FragColor.a = texColor.a * v_light.a;
60
60
  gl_FragColor.rgb = ((texColor.a - 1.0) * v_dark.a + 1.0 - texColor.rgb) * v_dark.rgb + texColor.rgb * v_light.rgb;
61
61
  }
62
- `;return new ue(e,t,i)}static newColored(e){let t=`
62
+ `;return new ue(e,i,r)}static newColored(e){let i=`
63
63
  attribute vec4 ${ue.POSITION};
64
64
  attribute vec4 ${ue.COLOR};
65
65
  uniform mat4 ${ue.MVP_MATRIX};
@@ -69,7 +69,7 @@ void main () {
69
69
  v_color = ${ue.COLOR};
70
70
  gl_Position = ${ue.MVP_MATRIX} * ${ue.POSITION};
71
71
  }
72
- `,i=`
72
+ `,r=`
73
73
  #ifdef GL_ES
74
74
  #define LOWP lowp
75
75
  precision mediump float;
@@ -81,4 +81,4 @@ varying LOWP vec4 v_color;
81
81
  void main () {
82
82
  gl_FragColor = v_color;
83
83
  }
84
- `;return new ue(e,t,i)}},pe=ue;B(pe,"MVP_MATRIX","u_projTrans"),B(pe,"POSITION","a_position"),B(pe,"COLOR","a_color"),B(pe,"COLOR2","a_color2"),B(pe,"TEXCOORDS","a_texCoords"),B(pe,"SAMPLER","u_texture");var Ji=class{constructor(e,t,i,s){this.attributes=t,this.context=e instanceof be?e:new be(e),this.elementsPerVertex=0;for(let n=0;n<t.length;n++)this.elementsPerVertex+=t[n].numElements;this.vertices=new Float32Array(i*this.elementsPerVertex),this.indices=new Uint16Array(s),this.context.addRestorable(this)}context;vertices;verticesBuffer=null;verticesLength=0;dirtyVertices=!1;indices;indicesBuffer=null;indicesLength=0;dirtyIndices=!1;elementsPerVertex=0;getAttributes(){return this.attributes}maxVertices(){return this.vertices.length/this.elementsPerVertex}numVertices(){return this.verticesLength/this.elementsPerVertex}setVerticesLength(e){this.dirtyVertices=!0,this.verticesLength=e}getVertices(){return this.vertices}maxIndices(){return this.indices.length}numIndices(){return this.indicesLength}setIndicesLength(e){this.dirtyIndices=!0,this.indicesLength=e}getIndices(){return this.indices}getVertexSizeInFloats(){let e=0;for(var t=0;t<this.attributes.length;t++){let i=this.attributes[t];e+=i.numElements}return e}setVertices(e){if(this.dirtyVertices=!0,e.length>this.vertices.length)throw Error("Mesh can't store more than "+this.maxVertices()+" vertices");this.vertices.set(e,0),this.verticesLength=e.length}setIndices(e){if(this.dirtyIndices=!0,e.length>this.indices.length)throw Error("Mesh can't store more than "+this.maxIndices()+" indices");this.indices.set(e,0),this.indicesLength=e.length}draw(e,t){this.drawWithOffset(e,t,0,this.indicesLength>0?this.indicesLength:this.verticesLength/this.elementsPerVertex)}drawWithOffset(e,t,i,s){let n=this.context.gl;(this.dirtyVertices||this.dirtyIndices)&&this.update(),this.bind(e),this.indicesLength>0?n.drawElements(t,s,n.UNSIGNED_SHORT,i*2):n.drawArrays(t,i,s),this.unbind(e)}bind(e){let t=this.context.gl;t.bindBuffer(t.ARRAY_BUFFER,this.verticesBuffer);let i=0;for(let s=0;s<this.attributes.length;s++){let n=this.attributes[s],h=e.getAttributeLocation(n.name);t.enableVertexAttribArray(h),t.vertexAttribPointer(h,n.numElements,t.FLOAT,!1,this.elementsPerVertex*4,i*4),i+=n.numElements}this.indicesLength>0&&t.bindBuffer(t.ELEMENT_ARRAY_BUFFER,this.indicesBuffer)}unbind(e){let t=this.context.gl;for(let i=0;i<this.attributes.length;i++){let s=this.attributes[i],n=e.getAttributeLocation(s.name);t.disableVertexAttribArray(n)}t.bindBuffer(t.ARRAY_BUFFER,null),this.indicesLength>0&&t.bindBuffer(t.ELEMENT_ARRAY_BUFFER,null)}update(){let e=this.context.gl;this.dirtyVertices&&(this.verticesBuffer||(this.verticesBuffer=e.createBuffer()),e.bindBuffer(e.ARRAY_BUFFER,this.verticesBuffer),e.bufferData(e.ARRAY_BUFFER,this.vertices.subarray(0,this.verticesLength),e.DYNAMIC_DRAW),this.dirtyVertices=!1),this.dirtyIndices&&(this.indicesBuffer||(this.indicesBuffer=e.createBuffer()),e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,this.indicesBuffer),e.bufferData(e.ELEMENT_ARRAY_BUFFER,this.indices.subarray(0,this.indicesLength),e.DYNAMIC_DRAW),this.dirtyIndices=!1)}restore(){this.verticesBuffer=null,this.indicesBuffer=null,this.update()}dispose(){this.context.removeRestorable(this);let e=this.context.gl;e.deleteBuffer(this.verticesBuffer),e.deleteBuffer(this.indicesBuffer)}},lt=class{constructor(e,t,i){this.name=e,this.type=t,this.numElements=i}},Dt=class extends lt{constructor(){super(pe.POSITION,Qe.Float,2)}},An=class extends lt{constructor(){super(pe.POSITION,Qe.Float,3)}},Ki=class extends lt{constructor(e=0){super(pe.TEXCOORDS+(e==0?"":e),Qe.Float,2)}},Nt=class extends lt{constructor(){super(pe.COLOR,Qe.Float,4)}},Us=class extends lt{constructor(){super(pe.COLOR2,Qe.Float,4)}},Qe=(e=>(e[e.Float=0]="Float",e))(Qe||{}),Ve=1,Cn=769,Ws=770,Gs=771,zs=774,$e=class{context;drawCalls=0;isDrawing=!1;mesh;shader=null;lastTexture=null;verticesLength=0;indicesLength=0;srcColorBlend;srcAlphaBlend;dstBlend;cullWasEnabled=!1;constructor(e,t=!0,i=10920){if(i>10920)throw new Error("Can't have more than 10920 triangles per batch: "+i);this.context=e instanceof be?e:new be(e);let s=t?[new Dt,new Nt,new Ki,new Us]:[new Dt,new Nt,new Ki];this.mesh=new Ji(e,s,i,i*3);let n=this.context.gl;this.srcColorBlend=n.SRC_ALPHA,this.srcAlphaBlend=n.ONE,this.dstBlend=n.ONE_MINUS_SRC_ALPHA}begin(e){if(this.isDrawing)throw new Error("PolygonBatch is already drawing. Call PolygonBatch.end() before calling PolygonBatch.begin()");this.drawCalls=0,this.shader=e,this.lastTexture=null,this.isDrawing=!0;let t=this.context.gl;t.enable(t.BLEND),t.blendFuncSeparate(this.srcColorBlend,this.dstBlend,this.srcAlphaBlend,this.dstBlend),$e.disableCulling&&(this.cullWasEnabled=t.isEnabled(t.CULL_FACE),this.cullWasEnabled&&t.disable(t.CULL_FACE))}setBlendMode(e,t){const i=$e.blendModesGL[e],s=t?i.srcRgbPma:i.srcRgb,n=i.srcAlpha,h=i.dstRgb;if(this.srcColorBlend==s&&this.srcAlphaBlend==n&&this.dstBlend==h)return;this.srcColorBlend=s,this.srcAlphaBlend=n,this.dstBlend=h,this.isDrawing&&this.flush(),this.context.gl.blendFuncSeparate(s,h,n,h)}draw(e,t,i){e!=this.lastTexture?(this.flush(),this.lastTexture=e):(this.verticesLength+t.length>this.mesh.getVertices().length||this.indicesLength+i.length>this.mesh.getIndices().length)&&this.flush();let s=this.mesh.numVertices();this.mesh.getVertices().set(t,this.verticesLength),this.verticesLength+=t.length,this.mesh.setVerticesLength(this.verticesLength);let n=this.mesh.getIndices();for(let h=this.indicesLength,a=0;a<i.length;h++,a++)n[h]=i[a]+s;this.indicesLength+=i.length,this.mesh.setIndicesLength(this.indicesLength)}flush(){if(this.verticesLength!=0){if(!this.lastTexture)throw new Error("No texture set.");if(!this.shader)throw new Error("No shader set.");this.lastTexture.bind(),this.mesh.draw(this.shader,this.context.gl.TRIANGLES),this.verticesLength=0,this.indicesLength=0,this.mesh.setVerticesLength(0),this.mesh.setIndicesLength(0),this.drawCalls++,$e.globalDrawCalls++}}end(){if(!this.isDrawing)throw new Error("PolygonBatch is not drawing. Call PolygonBatch.begin() before calling PolygonBatch.end()");(this.verticesLength>0||this.indicesLength>0)&&this.flush(),this.shader=null,this.lastTexture=null,this.isDrawing=!1;let e=this.context.gl;e.disable(e.BLEND),$e.disableCulling&&this.cullWasEnabled&&e.enable(e.CULL_FACE)}getDrawCalls(){return this.drawCalls}static getAndResetGlobalDrawCalls(){let e=$e.globalDrawCalls;return $e.globalDrawCalls=0,e}dispose(){this.mesh.dispose()}},ot=$e;B(ot,"disableCulling",!1),B(ot,"globalDrawCalls",0),B(ot,"blendModesGL",[{srcRgb:Ws,srcRgbPma:Ve,dstRgb:Gs,srcAlpha:Ve},{srcRgb:Ws,srcRgbPma:Ve,dstRgb:Ve,srcAlpha:Ve},{srcRgb:zs,srcRgbPma:zs,dstRgb:Gs,srcAlpha:Ve},{srcRgb:Ve,srcRgbPma:Ve,dstRgb:Cn,srcAlpha:Ve}]);var Qi=class{context;isDrawing=!1;mesh;shapeType=ye.Filled;color=new O(1,1,1,1);shader=null;vertexIndex=0;tmp=new je;srcColorBlend;srcAlphaBlend;dstBlend;constructor(e,t=10920){if(t>10920)throw new Error("Can't have more than 10920 triangles per batch: "+t);this.context=e instanceof be?e:new be(e),this.mesh=new Ji(e,[new Dt,new Nt],t,0);let i=this.context.gl;this.srcColorBlend=i.SRC_ALPHA,this.srcAlphaBlend=i.ONE,this.dstBlend=i.ONE_MINUS_SRC_ALPHA}begin(e){if(this.isDrawing)throw new Error("ShapeRenderer.begin() has already been called");this.shader=e,this.vertexIndex=0,this.isDrawing=!0;let t=this.context.gl;t.enable(t.BLEND),t.blendFuncSeparate(this.srcColorBlend,this.dstBlend,this.srcAlphaBlend,this.dstBlend)}setBlendMode(e,t,i){this.srcColorBlend=e,this.srcAlphaBlend=t,this.dstBlend=i,this.isDrawing&&(this.flush(),this.context.gl.blendFuncSeparate(e,i,t,i))}setColor(e){this.color.setFromColor(e)}setColorWith(e,t,i,s){this.color.set(e,t,i,s)}point(e,t,i){this.check(ye.Point,1),i||(i=this.color),this.vertex(e,t,i)}line(e,t,i,s,n){this.check(ye.Line,2);let h=this.mesh.getVertices(),a=this.vertexIndex;n||(n=this.color),this.vertex(e,t,n),this.vertex(i,s,n)}triangle(e,t,i,s,n,h,a,r,o,l){this.check(e?ye.Filled:ye.Line,3);let c=this.mesh.getVertices(),f=this.vertexIndex;r||(r=this.color),o||(o=this.color),l||(l=this.color),e?(this.vertex(t,i,r),this.vertex(s,n,o),this.vertex(h,a,l)):(this.vertex(t,i,r),this.vertex(s,n,o),this.vertex(s,n,r),this.vertex(h,a,o),this.vertex(h,a,r),this.vertex(t,i,o))}quad(e,t,i,s,n,h,a,r,o,l,c,f,d){this.check(e?ye.Filled:ye.Line,3);let u=this.mesh.getVertices(),m=this.vertexIndex;l||(l=this.color),c||(c=this.color),f||(f=this.color),d||(d=this.color),e?(this.vertex(t,i,l),this.vertex(s,n,c),this.vertex(h,a,f),this.vertex(h,a,f),this.vertex(r,o,d),this.vertex(t,i,l)):(this.vertex(t,i,l),this.vertex(s,n,c),this.vertex(s,n,c),this.vertex(h,a,f),this.vertex(h,a,f),this.vertex(r,o,d),this.vertex(r,o,d),this.vertex(t,i,l))}rect(e,t,i,s,n,h){this.quad(e,t,i,t+s,i,t+s,i+n,t,i+n,h,h,h,h)}rectLine(e,t,i,s,n,h,a){this.check(e?ye.Filled:ye.Line,8),a||(a=this.color);let r=this.tmp.set(n-i,t-s);r.normalize(),h*=.5;let o=r.x*h,l=r.y*h;e?(this.vertex(t+o,i+l,a),this.vertex(t-o,i-l,a),this.vertex(s+o,n+l,a),this.vertex(s-o,n-l,a),this.vertex(s+o,n+l,a),this.vertex(t-o,i-l,a)):(this.vertex(t+o,i+l,a),this.vertex(t-o,i-l,a),this.vertex(s+o,n+l,a),this.vertex(s-o,n-l,a),this.vertex(s+o,n+l,a),this.vertex(t+o,i+l,a),this.vertex(s-o,n-l,a),this.vertex(t-o,i-l,a))}x(e,t,i){this.line(e-i,t-i,e+i,t+i),this.line(e-i,t+i,e+i,t-i)}polygon(e,t,i,s){if(i<3)throw new Error("Polygon must contain at least 3 vertices");this.check(ye.Line,i*2),s||(s=this.color);let n=this.mesh.getVertices(),h=this.vertexIndex;t<<=1,i<<=1;let a=e[t],r=e[t+1],o=t+i;for(let l=t,c=t+i-2;l<c;l+=2){let f=e[l],d=e[l+1],u=0,m=0;l+2>=o?(u=a,m=r):(u=e[l+2],m=e[l+3]),this.vertex(f,d,s),this.vertex(u,m,s)}}circle(e,t,i,s,n,h=0){if(h==0&&(h=Math.max(1,6*L.cbrt(s)|0)),h<=0)throw new Error("segments must be > 0.");n||(n=this.color);let a=2*L.PI/h,r=Math.cos(a),o=Math.sin(a),l=s,c=0;if(e){this.check(ye.Filled,h*3+3),h--;for(let d=0;d<h;d++){this.vertex(t,i,n),this.vertex(t+l,i+c,n);let u=l;l=r*l-o*c,c=o*u+r*c,this.vertex(t+l,i+c,n)}this.vertex(t,i,n),this.vertex(t+l,i+c,n)}else{this.check(ye.Line,h*2+2);for(let d=0;d<h;d++){this.vertex(t+l,i+c,n);let u=l;l=r*l-o*c,c=o*u+r*c,this.vertex(t+l,i+c,n)}this.vertex(t+l,i+c,n)}let f=l;l=s,c=0,this.vertex(t+l,i+c,n)}curve(e,t,i,s,n,h,a,r,o,l){this.check(ye.Line,o*2+2),l||(l=this.color);let c=1/o,f=c*c,d=c*c*c,u=3*c,m=3*f,g=6*f,w=6*d,b=e-i*2+n,p=t-s*2+h,x=(i-n)*3-e+a,y=(s-h)*3-t+r,v=e,A=t,C=(i-e)*u+b*m+x*d,S=(s-t)*u+p*m+y*d,E=b*g+x*w,R=p*g+y*w,Y=x*w,P=y*w;for(;o-- >0;)this.vertex(v,A,l),v+=C,A+=S,C+=E,S+=R,E+=Y,R+=P,this.vertex(v,A,l);this.vertex(v,A,l),this.vertex(a,r,l)}vertex(e,t,i){let s=this.vertexIndex,n=this.mesh.getVertices();n[s++]=e,n[s++]=t,n[s++]=i.r,n[s++]=i.g,n[s++]=i.b,n[s++]=i.a,this.vertexIndex=s}end(){if(!this.isDrawing)throw new Error("ShapeRenderer.begin() has not been called");this.flush();let e=this.context.gl;e.disable(e.BLEND),this.isDrawing=!1}flush(){if(this.vertexIndex!=0){if(!this.shader)throw new Error("No shader set.");this.mesh.setVerticesLength(this.vertexIndex),this.mesh.draw(this.shader,this.shapeType),this.vertexIndex=0}}check(e,t){if(!this.isDrawing)throw new Error("ShapeRenderer.begin() has not been called");if(this.shapeType==e)if(this.mesh.maxVertices()-this.mesh.numVertices()<t)this.flush();else return;else this.flush(),this.shapeType=e}dispose(){this.mesh.dispose()}},ye=(e=>(e[e.Point=0]="Point",e[e.Line=1]="Line",e[e.Filled=4]="Filled",e))(ye||{}),$i=class{boneLineColor=new O(1,0,0,1);boneOriginColor=new O(0,1,0,1);attachmentLineColor=new O(0,0,1,.5);triangleLineColor=new O(1,.64,0,.5);pathColor=new O().setFromString("FF7F00");clipColor=new O(.8,0,0,2);aabbColor=new O(0,1,0,.5);drawBones=!0;drawRegionAttachments=!0;drawBoundingBoxes=!0;drawMeshHull=!0;drawMeshTriangles=!0;drawPaths=!0;drawSkeletonXY=!1;drawClipping=!0;premultipliedAlpha=!1;scale=1;boneWidth=2;context;bounds=new Os;temp=new Array;vertices=X.newFloatArray(2*1024);constructor(e){this.context=e instanceof be?e:new be(e)}draw(e,t,i){let s=t.x,n=t.y,h=this.context.gl,a=this.premultipliedAlpha?h.ONE:h.SRC_ALPHA;e.setBlendMode(a,h.ONE,h.ONE_MINUS_SRC_ALPHA);let r=t.bones;if(this.drawBones){e.setColor(this.boneLineColor);for(let o=0,l=r.length;o<l;o++){let c=r[o];if(i&&i.indexOf(c.data.name)>-1||!c.parent)continue;let f=c.data.length*c.a+c.worldX,d=c.data.length*c.c+c.worldY;e.rectLine(!0,c.worldX,c.worldY,f,d,this.boneWidth*this.scale)}this.drawSkeletonXY&&e.x(s,n,4*this.scale)}if(this.drawRegionAttachments){e.setColor(this.attachmentLineColor);let o=t.slots;for(let l=0,c=o.length;l<c;l++){let f=o[l],d=f.getAttachment();if(d instanceof V){let u=d,m=this.vertices;u.computeWorldVertices(f,m,0,2),e.line(m[0],m[1],m[2],m[3]),e.line(m[2],m[3],m[4],m[5]),e.line(m[4],m[5],m[6],m[7]),e.line(m[6],m[7],m[0],m[1])}}}if(this.drawMeshHull||this.drawMeshTriangles){let o=t.slots;for(let l=0,c=o.length;l<c;l++){let f=o[l];if(!f.bone.active)continue;let d=f.getAttachment();if(!(d instanceof Be))continue;let u=d,m=this.vertices;u.computeWorldVertices(f,0,u.worldVerticesLength,m,0,2);let g=u.triangles,w=u.hullLength;if(this.drawMeshTriangles){e.setColor(this.triangleLineColor);for(let b=0,p=g.length;b<p;b+=3){let x=g[b]*2,y=g[b+1]*2,v=g[b+2]*2;e.triangle(!1,m[x],m[x+1],m[y],m[y+1],m[v],m[v+1])}}if(this.drawMeshHull&&w>0){e.setColor(this.attachmentLineColor),w=(w>>1)*2;let b=m[w-2],p=m[w-1];for(let x=0,y=w;x<y;x+=2){let v=m[x],A=m[x+1];e.line(v,A,b,p),b=v,p=A}}}}if(this.drawBoundingBoxes){let o=this.bounds;o.update(t,!0),e.setColor(this.aabbColor),e.rect(!1,o.minX,o.minY,o.getWidth(),o.getHeight());let l=o.polygons,c=o.boundingBoxes;for(let f=0,d=l.length;f<d;f++){let u=l[f];e.setColor(c[f].color),e.polygon(u,0,u.length)}}if(this.drawPaths){let o=t.slots;for(let l=0,c=o.length;l<c;l++){let f=o[l];if(!f.bone.active)continue;let d=f.getAttachment();if(!(d instanceof Ke))continue;let u=d,m=u.worldVerticesLength,g=this.temp=X.setArraySize(this.temp,m,0);u.computeWorldVertices(f,0,m,g,0,2);let w=this.pathColor,b=g[2],p=g[3],x=0,y=0;if(u.closed){e.setColor(w);let v=g[0],A=g[1],C=g[m-2],S=g[m-1];x=g[m-4],y=g[m-3],e.curve(b,p,v,A,C,S,x,y,32),e.setColor($i.LIGHT_GRAY),e.line(b,p,v,A),e.line(x,y,C,S)}m-=4;for(let v=4;v<m;v+=6){let A=g[v],C=g[v+1],S=g[v+2],E=g[v+3];x=g[v+4],y=g[v+5],e.setColor(w),e.curve(b,p,A,C,S,E,x,y,32),e.setColor($i.LIGHT_GRAY),e.line(b,p,A,C),e.line(x,y,S,E),b=x,p=y}}}if(this.drawBones){e.setColor(this.boneOriginColor);for(let o=0,l=r.length;o<l;o++){let c=r[o];i&&i.indexOf(c.data.name)>-1||e.circle(!0,c.worldX,c.worldY,3*this.scale,this.boneOriginColor,8)}}if(this.drawClipping){let o=t.slots;e.setColor(this.clipColor);for(let l=0,c=o.length;l<c;l++){let f=o[l];if(!f.bone.active)continue;let d=f.getAttachment();if(!(d instanceof st))continue;let u=d,m=u.worldVerticesLength,g=this.temp=X.setArraySize(this.temp,m,0);u.computeWorldVertices(f,0,m,g,0,2);for(let w=0,b=g.length;w<b;w+=2){let p=g[w],x=g[w+1],y=g[(w+2)%g.length],v=g[(w+3)%g.length];e.line(p,x,y,v)}}}}dispose(){}},_t=$i;B(_t,"LIGHT_GRAY",new O(.7529411764705882,.7529411764705882,.7529411764705882,1)),B(_t,"GREEN",new O(0,1,0,1));var Sn=class{constructor(e,t,i){this.vertices=e,this.numVertices=t,this.numFloats=i}},qs=class{premultipliedAlpha=!1;tempColor=new O;tempColor2=new O;vertices;vertexSize=2+2+4;twoColorTint=!1;renderable=new Sn([],0,0);clipper=new nt;temp=new je;temp2=new je;temp3=new O;temp4=new O;constructor(e,t=!0){this.twoColorTint=t,t&&(this.vertexSize+=4),this.vertices=X.newFloatArray(this.vertexSize*1024)}draw(e,t,i=-1,s=-1,n=null){let h=this.clipper,a=this.premultipliedAlpha,r=this.twoColorTint,o=null,l=this.renderable,c,f,d=t.drawOrder,u,m=t.color,g=r?12:8,w=!1;i==-1&&(w=!0);for(let b=0,p=d.length;b<p;b++){let x=h.isClipping()?2:g,y=d[b];if(!y.bone.active){h.clipEndWithSlot(y);continue}if(i>=0&&i==y.data.index&&(w=!0),!w){h.clipEndWithSlot(y);continue}s>=0&&s==y.data.index&&(w=!1);let v=y.getAttachment(),A;if(v instanceof V){let C=v;l.vertices=this.vertices,l.numVertices=4,l.numFloats=x<<2,C.computeWorldVertices(y,l.vertices,0,x),f=qs.QUAD_TRIANGLES,c=C.uvs,A=C.region.texture,u=C.color}else if(v instanceof Be){let C=v;l.vertices=this.vertices,l.numVertices=C.worldVerticesLength>>1,l.numFloats=l.numVertices*x,l.numFloats>l.vertices.length&&(l.vertices=this.vertices=X.newFloatArray(l.numFloats)),C.computeWorldVertices(y,0,C.worldVerticesLength,l.vertices,0,x),f=C.triangles,A=C.region.texture,c=C.uvs,u=C.color}else if(v instanceof st){let C=v;h.clipStart(y,C);continue}else{h.clipEndWithSlot(y);continue}if(A){let C=y.color,S=this.tempColor;S.r=m.r*C.r*u.r,S.g=m.g*C.g*u.g,S.b=m.b*C.b*u.b,S.a=m.a*C.a*u.a,a&&(S.r*=S.a,S.g*=S.a,S.b*=S.a);let E=this.tempColor2;y.darkColor?(a?(E.r=y.darkColor.r*S.a,E.g=y.darkColor.g*S.a,E.b=y.darkColor.b*S.a):E.setFromColor(y.darkColor),E.a=a?1:0):E.set(0,0,0,1);let R=y.data.blendMode;if(R!=o&&(o=R,e.setBlendMode(o,a)),h.isClipping()){h.clipTriangles(l.vertices,f,f.length,c,S,E,r);let Y=new Float32Array(h.clippedVertices),P=h.clippedTriangles;n&&n(Y,Y.length,g),e.draw(A,Y,P)}else{let Y=l.vertices;if(r)for(let I=2,k=0,F=l.numFloats;I<F;I+=g,k+=2)Y[I]=S.r,Y[I+1]=S.g,Y[I+2]=S.b,Y[I+3]=S.a,Y[I+4]=c[k],Y[I+5]=c[k+1],Y[I+6]=E.r,Y[I+7]=E.g,Y[I+8]=E.b,Y[I+9]=E.a;else for(let I=2,k=0,F=l.numFloats;I<F;I+=g,k+=2)Y[I]=S.r,Y[I+1]=S.g,Y[I+2]=S.b,Y[I+3]=S.a,Y[I+4]=c[k],Y[I+5]=c[k+1];let P=l.vertices.subarray(0,l.numFloats);n&&n(l.vertices,l.numFloats,g),e.draw(A,P,f)}}h.clipEndWithSlot(y)}h.clipEnd()}getSkeletonClipping(){return this.clipper}},es=qs;B(es,"QUAD_TRIANGLES",[0,1,2,2,3,0]);var T=[0,0,1,1,1,1,0,0,0,0,1,1,1,1,0,0,0,0,1,1,1,1,0,0,0,0,1,1,1,1,0,0],Ut=[0,1,2,2,3,0],Wt=new O(1,1,1,1),ts=class{context;canvas;camera;batcher;twoColorTint=!1;batcherShader;shapes;shapesShader;activeRenderer=null;skeletonRenderer;skeletonDebugRenderer;constructor(e,t,i=!0){this.canvas=e,this.context=t instanceof be?t:new be(t),this.twoColorTint=i,this.camera=new Ns(e.width,e.height),this.batcherShader=i?pe.newTwoColoredTextured(this.context):pe.newColoredTextured(this.context),this.batcher=new ot(this.context,i),this.shapesShader=pe.newColored(this.context),this.shapes=new Qi(this.context),this.skeletonRenderer=new es(this.context,i),this.skeletonDebugRenderer=new _t(this.context)}dispose(){this.batcher.dispose(),this.batcherShader.dispose(),this.shapes.dispose(),this.shapesShader.dispose(),this.skeletonDebugRenderer.dispose()}begin(){this.camera.update(),this.enableRenderer(this.batcher)}drawSkeleton(e,t=!1,i=-1,s=-1,n=null){this.enableRenderer(this.batcher),this.skeletonRenderer.premultipliedAlpha=t,this.skeletonRenderer.draw(this.batcher,e,i,s,n)}drawSkeletonDebug(e,t=!1,i){this.enableRenderer(this.shapes),this.skeletonDebugRenderer.premultipliedAlpha=t,this.skeletonDebugRenderer.draw(this.shapes,e,i)}drawTexture(e,t,i,s,n,h){this.enableRenderer(this.batcher),h||(h=Wt);var a=0;T[a++]=t,T[a++]=i,T[a++]=h.r,T[a++]=h.g,T[a++]=h.b,T[a++]=h.a,T[a++]=0,T[a++]=1,this.twoColorTint&&(T[a++]=0,T[a++]=0,T[a++]=0,T[a++]=0),T[a++]=t+s,T[a++]=i,T[a++]=h.r,T[a++]=h.g,T[a++]=h.b,T[a++]=h.a,T[a++]=1,T[a++]=1,this.twoColorTint&&(T[a++]=0,T[a++]=0,T[a++]=0,T[a++]=0),T[a++]=t+s,T[a++]=i+n,T[a++]=h.r,T[a++]=h.g,T[a++]=h.b,T[a++]=h.a,T[a++]=1,T[a++]=0,this.twoColorTint&&(T[a++]=0,T[a++]=0,T[a++]=0,T[a++]=0),T[a++]=t,T[a++]=i+n,T[a++]=h.r,T[a++]=h.g,T[a++]=h.b,T[a++]=h.a,T[a++]=0,T[a++]=0,this.twoColorTint&&(T[a++]=0,T[a++]=0,T[a++]=0,T[a]=0),this.batcher.draw(e,T,Ut)}drawTextureUV(e,t,i,s,n,h,a,r,o,l){this.enableRenderer(this.batcher),l||(l=Wt);var c=0;T[c++]=t,T[c++]=i,T[c++]=l.r,T[c++]=l.g,T[c++]=l.b,T[c++]=l.a,T[c++]=h,T[c++]=a,this.twoColorTint&&(T[c++]=0,T[c++]=0,T[c++]=0,T[c++]=0),T[c++]=t+s,T[c++]=i,T[c++]=l.r,T[c++]=l.g,T[c++]=l.b,T[c++]=l.a,T[c++]=r,T[c++]=a,this.twoColorTint&&(T[c++]=0,T[c++]=0,T[c++]=0,T[c++]=0),T[c++]=t+s,T[c++]=i+n,T[c++]=l.r,T[c++]=l.g,T[c++]=l.b,T[c++]=l.a,T[c++]=r,T[c++]=o,this.twoColorTint&&(T[c++]=0,T[c++]=0,T[c++]=0,T[c++]=0),T[c++]=t,T[c++]=i+n,T[c++]=l.r,T[c++]=l.g,T[c++]=l.b,T[c++]=l.a,T[c++]=h,T[c++]=o,this.twoColorTint&&(T[c++]=0,T[c++]=0,T[c++]=0,T[c]=0),this.batcher.draw(e,T,Ut)}drawTextureRotated(e,t,i,s,n,h,a,r,o){this.enableRenderer(this.batcher),o||(o=Wt);let l=t+h,c=i+a,f=-h,d=-a,u=s-h,m=n-a,g=f,w=d,b=f,p=m,x=u,y=m,v=u,A=d,C=0,S=0,E=0,R=0,Y=0,P=0,I=0,k=0;if(r!=0){let se=L.cosDeg(r),re=L.sinDeg(r);C=se*g-re*w,S=re*g+se*w,I=se*b-re*p,k=re*b+se*p,Y=se*x-re*y,P=re*x+se*y,E=Y+(C-I),R=P+(S-k)}else C=g,S=w,I=b,k=p,Y=x,P=y,E=v,R=A;C+=l,S+=c,E+=l,R+=c,Y+=l,P+=c,I+=l,k+=c;var F=0;T[F++]=C,T[F++]=S,T[F++]=o.r,T[F++]=o.g,T[F++]=o.b,T[F++]=o.a,T[F++]=0,T[F++]=1,this.twoColorTint&&(T[F++]=0,T[F++]=0,T[F++]=0,T[F++]=0),T[F++]=E,T[F++]=R,T[F++]=o.r,T[F++]=o.g,T[F++]=o.b,T[F++]=o.a,T[F++]=1,T[F++]=1,this.twoColorTint&&(T[F++]=0,T[F++]=0,T[F++]=0,T[F++]=0),T[F++]=Y,T[F++]=P,T[F++]=o.r,T[F++]=o.g,T[F++]=o.b,T[F++]=o.a,T[F++]=1,T[F++]=0,this.twoColorTint&&(T[F++]=0,T[F++]=0,T[F++]=0,T[F++]=0),T[F++]=I,T[F++]=k,T[F++]=o.r,T[F++]=o.g,T[F++]=o.b,T[F++]=o.a,T[F++]=0,T[F++]=0,this.twoColorTint&&(T[F++]=0,T[F++]=0,T[F++]=0,T[F]=0),this.batcher.draw(e,T,Ut)}drawRegion(e,t,i,s,n,h){this.enableRenderer(this.batcher),h||(h=Wt);var a=0;T[a++]=t,T[a++]=i,T[a++]=h.r,T[a++]=h.g,T[a++]=h.b,T[a++]=h.a,T[a++]=e.u,T[a++]=e.v2,this.twoColorTint&&(T[a++]=0,T[a++]=0,T[a++]=0,T[a++]=0),T[a++]=t+s,T[a++]=i,T[a++]=h.r,T[a++]=h.g,T[a++]=h.b,T[a++]=h.a,T[a++]=e.u2,T[a++]=e.v2,this.twoColorTint&&(T[a++]=0,T[a++]=0,T[a++]=0,T[a++]=0),T[a++]=t+s,T[a++]=i+n,T[a++]=h.r,T[a++]=h.g,T[a++]=h.b,T[a++]=h.a,T[a++]=e.u2,T[a++]=e.v,this.twoColorTint&&(T[a++]=0,T[a++]=0,T[a++]=0,T[a++]=0),T[a++]=t,T[a++]=i+n,T[a++]=h.r,T[a++]=h.g,T[a++]=h.b,T[a++]=h.a,T[a++]=e.u,T[a++]=e.v,this.twoColorTint&&(T[a++]=0,T[a++]=0,T[a++]=0,T[a]=0),this.batcher.draw(e.page.texture,T,Ut)}line(e,t,i,s,n,h){this.enableRenderer(this.shapes),this.shapes.line(e,t,i,s,n)}triangle(e,t,i,s,n,h,a,r,o,l){this.enableRenderer(this.shapes),this.shapes.triangle(e,t,i,s,n,h,a,r,o,l)}quad(e,t,i,s,n,h,a,r,o,l,c,f,d){this.enableRenderer(this.shapes),this.shapes.quad(e,t,i,s,n,h,a,r,o,l,c,f,d)}rect(e,t,i,s,n,h){this.enableRenderer(this.shapes),this.shapes.rect(e,t,i,s,n,h)}rectLine(e,t,i,s,n,h,a){this.enableRenderer(this.shapes),this.shapes.rectLine(e,t,i,s,n,h,a)}polygon(e,t,i,s){this.enableRenderer(this.shapes),this.shapes.polygon(e,t,i,s)}circle(e,t,i,s,n,h=0){this.enableRenderer(this.shapes),this.shapes.circle(e,t,i,s,n,h)}curve(e,t,i,s,n,h,a,r,o,l){this.enableRenderer(this.shapes),this.shapes.curve(e,t,i,s,n,h,a,r,o,l)}end(){this.activeRenderer===this.batcher?this.batcher.end():this.activeRenderer===this.shapes&&this.shapes.end(),this.activeRenderer=null}resize(e){let t=this.canvas;var i=window.devicePixelRatio||1,s=Math.round(t.clientWidth*i),n=Math.round(t.clientHeight*i);if((t.width!=s||t.height!=n)&&(t.width=s,t.height=n),this.context.gl.viewport(0,0,t.width,t.height),e===Gt.Expand)this.camera.setViewport(s,n);else if(e===Gt.Fit){let h=t.width,a=t.height,r=this.camera.viewportWidth,o=this.camera.viewportHeight,l=o/r,c=a/h,f=l<c?r/h:o/a;this.camera.setViewport(h*f,a*f)}this.camera.update()}enableRenderer(e){this.activeRenderer!==e&&(this.end(),e instanceof ot?(this.batcherShader.bind(),this.batcherShader.setUniform4x4f(pe.MVP_MATRIX,this.camera.projectionView.values),this.batcherShader.setUniformi("u_texture",0),this.batcher.begin(this.batcherShader),this.activeRenderer=this.batcher):e instanceof Qi?(this.shapesShader.bind(),this.shapesShader.setUniform4x4f(pe.MVP_MATRIX,this.camera.projectionView.values),this.shapes.begin(this.shapesShader),this.activeRenderer=this.shapes):this.activeRenderer=this.skeletonDebugRenderer)}},Gt=(e=>(e[e.Stretch=0]="Stretch",e[e.Expand=1]="Expand",e[e.Fit=2]="Fit",e))(Gt||{}),bt,ht,Hs=0,Tn=1,is=1,js=165,Zs=108,et=163,In=class{renderer;logo=null;spinner=null;angle=0;fadeOut=0;fadeIn=0;timeKeeper=new Kt;backgroundColor=new O(.135,.135,.135,1);tempColor=new O;constructor(e){if(this.renderer=e,this.timeKeeper.maxDelta=9,!ht){let t=navigator.userAgent.indexOf("Safari")>-1,i=()=>Hs++;ht=new Image,ht.src=En,t||(ht.crossOrigin="anonymous"),ht.onload=i,bt=new Image,bt.src=Mn,t||(bt.crossOrigin="anonymous"),bt.onload=i}}dispose(){this.logo?.dispose(),this.spinner?.dispose()}draw(e=!1){if(Hs<2||e&&this.fadeOut>is)return;this.timeKeeper.update();let t=Math.abs(Math.sin(this.timeKeeper.totalTime+.25));this.angle-=this.timeKeeper.delta*200*(1+1.5*Math.pow(t,5));let i=this.tempColor,s=this.renderer,n=s.canvas,h=s.context.gl;if(s.resize(1),s.camera.position.set(n.width/2,n.height/2,0),s.batcher.setBlendMode(0,!0),e){if(this.fadeOut+=this.timeKeeper.delta*(this.timeKeeper.totalTime<1?2:1),this.fadeOut>is)return;i.setFromColor(this.backgroundColor),t=1-this.fadeOut/is,t=1-(t-1)*(t-1),i.a*=t,i.a>0&&(s.camera.zoom=1,s.begin(),s.quad(!0,0,0,n.width,0,n.width,n.height,0,n.height,i,i,i,i),s.end())}else this.fadeIn+=this.timeKeeper.delta,this.backgroundColor.a>0&&(h.clearColor(this.backgroundColor.r,this.backgroundColor.g,this.backgroundColor.b,this.backgroundColor.a),h.clear(h.COLOR_BUFFER_BIT)),t=1;t*=Math.min(this.fadeIn/Tn,1),i.set(t,t,t,t),this.logo||(this.logo=new at(s.context,ht),this.spinner=new at(s.context,bt)),s.camera.zoom=Math.max(1,et/n.height),s.begin(),s.drawTexture(this.logo,(n.width-js)/2,(n.height-Zs)/2,js,Zs,i),this.spinner&&s.drawTextureRotated(this.spinner,(n.width-et)/2,(n.height-et)/2,et,et,et/2,et/2,this.angle,i),s.end()}},Mn="data:image/png;base64,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",En="data:image/png;base64,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",Rn=class{constructor(e,t){this.config=t,t.pathPrefix||(t.pathPrefix=""),t.app||(t.app={loadAssets:()=>{},initialize:()=>{},update:()=>{},render:()=>{},error:()=>{},dispose:()=>{}}),t.webglConfig||(t.webglConfig={alpha:!0}),this.htmlCanvas=e,this.context=new be(e,t.webglConfig),this.renderer=new ts(e,this.context),this.gl=this.context.gl,this.assetManager=new Ds(this.context,t.pathPrefix),this.input=new Zi(e),t.app.loadAssets&&t.app.loadAssets(this);let i=()=>{this.disposed||(requestAnimationFrame(i),this.time.update(),t.app.update&&t.app.update(this,this.time.delta),t.app.render&&t.app.render(this))},s=()=>{if(!this.disposed){if(this.assetManager.isLoadingComplete()){this.assetManager.hasErrors()?t.app.error&&t.app.error(this,this.assetManager.getErrors()):(t.app.initialize&&t.app.initialize(this),i());return}requestAnimationFrame(s)}};requestAnimationFrame(s)}context;time=new Kt;htmlCanvas;gl;renderer;assetManager;input;disposed=!1;clear(e,t,i,s){this.gl.clearColor(e,t,i,s),this.gl.clear(this.gl.COLOR_BUFFER_BIT)}dispose(){this.config.app.dispose&&this.config.app.dispose(this),this.disposed=!0}},ze=Phaser.GameObjects.Components,Js=ze.ComputedSize,Ks=ze.Depth,Qs=ze.Flip,$s=ze.ScrollFactor,er=ze.Transform,tr=ze.Visible,ir=ze.Origin,sr=ze.Alpha;function De(...e){return t=>(Phaser.Class.mixin(t,e),t)}var rr=De(Js),nr=De(Ks),ar=De(Qs),lr=De($s),or=De(er),hr=De(tr),cr=De(ir),dr=De(sr),kn=class extends Phaser.GameObjects.GameObject{constructor(e,t){super(e,t)}},Yn=class{constructor(e,t,i,s){this.x=e,this.y=t,this.width=i,this.height=s}calculateBounds(){return{x:this.x,y:this.y,width:this.width,height:this.height}}},fr=class{constructor(e=!1){this.clipping=e}calculateBounds(e){if(!e.skeleton)return{x:0,y:0,width:0,height:0};const t=new We(e.skeleton.data);t.setToSetupPose(),t.updateWorldTransform(2);const i=t.getBoundsRect(this.clipping?new nt:void 0);return i.width==Number.NEGATIVE_INFINITY?{x:0,y:0,width:0,height:0}:i}},Fn=class{constructor(e,t=[],i=.05,s=!1){this.animation=e,this.skins=t,this.timeStep=i,this.clipping=s}calculateBounds(e){if(!e.skeleton||!e.animationState)return{x:0,y:0,width:0,height:0};const t=new Et(e.animationState.data),i=new We(e.skeleton.data),s=this.clipping?new nt:void 0,n=i.data;if(this.skins.length>0){let a=new xt("custom-skin");for(const r of this.skins){const o=n.findSkin(r);o!=null&&a.addSkin(o)}i.setSkin(a)}i.setToSetupPose();const h=this.animation!=null?n.findAnimation(this.animation):null;if(h==null){i.updateWorldTransform(2);const a=i.getBoundsRect(s);return a.width==Number.NEGATIVE_INFINITY?{x:0,y:0,width:0,height:0}:a}else{let a=Number.POSITIVE_INFINITY,r=Number.POSITIVE_INFINITY,o=Number.NEGATIVE_INFINITY,l=Number.NEGATIVE_INFINITY;t.clearTracks(),t.setAnimationWith(0,h,!1);const c=Math.max(h.duration/this.timeStep,1);for(let d=0;d<c;d++){const u=d>0?this.timeStep:0;t.update(u),t.apply(i),i.update(u),i.updateWorldTransform(2);const m=i.getBoundsRect(s);a=Math.min(a,m.x),r=Math.min(r,m.y),o=Math.max(o,m.x+m.width),l=Math.max(l,m.y+m.height)}const f={x:a,y:r,width:o-a,height:l-r};return f.width==Number.NEGATIVE_INFINITY?{x:0,y:0,width:0,height:0}:f}}},ss=class extends nr(cr(rr(ar(lr(or(hr(dr(kn)))))))){constructor(e,t,i,s,n,h,a=new fr){super(e,window.SPINE_GAME_OBJECT_TYPE?window.SPINE_GAME_OBJECT_TYPE:Zt),this.plugin=t,this.boundsProvider=a,this.setPosition(i,s),this.premultipliedAlpha=this.plugin.isAtlasPremultiplied(h),this.skeleton=this.plugin.createSkeleton(n,h),this.animationStateData=new Ss(this.skeleton.data),this.animationState=new Et(this.animationStateData),this.skeleton.updateWorldTransform(2),this.updateSize()}blendMode=-1;skeleton;animationStateData;animationState;beforeUpdateWorldTransforms=()=>{};afterUpdateWorldTransforms=()=>{};premultipliedAlpha=!1;offsetX=0;offsetY=0;updateSize(){if(!this.skeleton)return;let e=this.boundsProvider.calculateBounds(this);this.width=e.width,this.height=e.height,this.setDisplayOrigin(-e.x,-e.y),this.offsetX=-e.x,this.offsetY=-e.y}skeletonToPhaserWorldCoordinates(e){let t=this.getWorldTransformMatrix(),i=t.a,s=t.b,n=t.c,h=t.d,a=t.tx,r=t.ty,o=e.x,l=e.y;e.x=o*i+l*n+a,e.y=o*s+l*h+r}phaserWorldCoordinatesToSkeleton(e){let t=this.getWorldTransformMatrix();t=t.invert();let i=t.a,s=t.b,n=t.c,h=t.d,a=t.tx,r=t.ty,o=e.x,l=e.y;e.x=o*i+l*n+a,e.y=o*s+l*h+r}phaserWorldCoordinatesToBone(e,t){this.phaserWorldCoordinatesToSkeleton(e),t.parent?t.parent.worldToLocal(e):t.worldToLocal(e)}updatePose(e){this.animationState.update(e/1e3),this.animationState.apply(this.skeleton),this.beforeUpdateWorldTransforms(this),this.skeleton.update(e/1e3),this.skeleton.updateWorldTransform(2),this.afterUpdateWorldTransforms(this)}preUpdate(e,t){!this.skeleton||!this.animationState||this.updatePose(t)}preDestroy(){}willRender(e){var t=15,i=!this.skeleton||!(t!==this.renderFlags||this.cameraFilter!==0&&this.cameraFilter&e.id);if(this.visible||(i=!1),!i&&this.parentContainer&&this.plugin.webGLRenderer){var s=this.plugin.webGLRenderer;this.plugin.gl&&this.plugin.phaserRenderer instanceof Phaser.Renderer.WebGL.WebGLRenderer&&s.batcher.isDrawing&&(s.end(),this.plugin.phaserRenderer.pipelines.rebind())}return i}renderWebGL(e,t,i,s){if(!this.skeleton||!this.animationState||!this.plugin.webGLRenderer)return;let n=this.plugin.webGLRenderer;e.newType&&(e.pipelines.clear(),n.begin()),i.addToRenderList(t);let h=Phaser.GameObjects.GetCalcMatrix(t,i,s).calc,a=h.a,r=h.b,o=h.c,l=h.d,c=h.tx,f=h.ty,d=t.offsetX-t.displayOriginX,u=t.offsetY-t.displayOriginY;n.drawSkeleton(t.skeleton,t.premultipliedAlpha,-1,-1,(m,g,w)=>{for(let b=0;b<g;b+=w){let p=m[b]+d,x=m[b+1]+u;m[b]=p*a+x*o+c,m[b+1]=p*r+x*l+f}}),e.nextTypeMatch||(n.end(),e.pipelines.rebind())}renderCanvas(e,t,i,s){if(!this.skeleton||!this.animationState||!this.plugin.canvasRenderer)return;let n=e.currentContext,h=this.plugin.canvasRenderer;h.ctx=n,i.addToRenderList(t);let a=Phaser.GameObjects.GetCalcMatrix(t,i,s).calc,r=this.skeleton;r.x=a.tx,r.y=a.ty,r.scaleX=a.scaleX,r.scaleY=a.scaleY;let o=r.getRootBone();o.rotation=-L.radiansToDegrees*a.rotationNormalized,this.skeleton.updateWorldTransform(2),n.save(),h.draw(r),n.restore()}},Pn=class extends Ft{constructor(e){super(e)}setFilters(e,t){}setWraps(e,t){}dispose(){}},Ln=X.newFloatArray(8),zt=class{ctx;triangleRendering=!1;debugRendering=!1;vertices=X.newFloatArray(8*1024);tempColor=new O;constructor(e){this.ctx=e}draw(e){this.triangleRendering?this.drawTriangles(e):this.drawImages(e)}drawImages(e){let t=this.ctx,i=this.tempColor,s=e.color,n=e.drawOrder;this.debugRendering&&(t.strokeStyle="green");for(let h=0,a=n.length;h<a;h++){let r=n[h],o=r.bone;if(!o.active)continue;let l=r.getAttachment();if(!(l instanceof V))continue;l.computeWorldVertices(r,Ln,0,2);let c=l.region,f=c.texture.getImage(),d=r.color,u=l.color;i.set(s.r*d.r*u.r,s.g*d.g*u.g,s.b*d.b*u.b,s.a*d.a*u.a),t.save(),t.transform(o.a,o.c,o.b,o.d,o.worldX,o.worldY),t.translate(l.offset[0],l.offset[1]),t.rotate(l.rotation*Math.PI/180);let m=l.width/c.originalWidth;t.scale(m*l.scaleX,m*l.scaleY);let g=c.width,w=c.height;if(t.translate(g/2,w/2),l.region.degrees==90){let b=g;g=w,w=b,t.rotate(-Math.PI/2)}t.scale(1,-1),t.translate(-g/2,-w/2),t.globalAlpha=i.a,t.drawImage(f,f.width*c.u,f.height*c.v,g,w,0,0,g,w),this.debugRendering&&t.strokeRect(0,0,g,w),t.restore()}}drawTriangles(e){let t=this.ctx,i=this.tempColor,s=e.color,n=e.drawOrder,h=null,a=this.vertices,r=null;for(let l=0,c=n.length;l<c;l++){let f=n[l],d=f.getAttachment(),u,m;if(d instanceof V){let g=d;a=this.computeRegionVertices(f,g,!1),r=zt.QUAD_TRIANGLES,u=g.region.texture.getImage()}else if(d instanceof Be){let g=d;a=this.computeMeshVertices(f,g,!1),r=g.triangles,u=g.region.texture.getImage()}else continue;if(u){f.data.blendMode!=h&&(h=f.data.blendMode);let g=f.color,w=d.color;i.set(s.r*g.r*w.r,s.g*g.g*w.g,s.b*g.b*w.b,s.a*g.a*w.a),t.globalAlpha=i.a;for(var o=0;o<r.length;o+=3){let b=r[o]*8,p=r[o+1]*8,x=r[o+2]*8,y=a[b],v=a[b+1],A=a[b+6],C=a[b+7],S=a[p],E=a[p+1],R=a[p+6],Y=a[p+7],P=a[x],I=a[x+1],k=a[x+6],F=a[x+7];this.drawTriangle(u,y,v,A,C,S,E,R,Y,P,I,k,F),this.debugRendering&&(t.strokeStyle="green",t.beginPath(),t.moveTo(y,v),t.lineTo(S,E),t.lineTo(P,I),t.lineTo(y,v),t.stroke())}}}this.ctx.globalAlpha=1}drawTriangle(e,t,i,s,n,h,a,r,o,l,c,f,d){let u=this.ctx;const m=e.width-1,g=e.height-1;s*=m,n*=g,r*=m,o*=g,f*=m,d*=g,u.beginPath(),u.moveTo(t,i),u.lineTo(h,a),u.lineTo(l,c),u.closePath(),h-=t,a-=i,l-=t,c-=i,r-=s,o-=n,f-=s,d-=n;let w=r*d-f*o;if(w==0)return;w=1/w;const b=(d*h-o*l)*w,p=(d*a-o*c)*w,x=(r*l-f*h)*w,y=(r*c-f*a)*w,v=t-b*s-x*n,A=i-p*s-y*n;u.save(),u.transform(b,p,x,y,v,A),u.clip(),u.drawImage(e,0,0),u.restore()}computeRegionVertices(e,t,i){let s=e.bone.skeleton.color,n=e.color,h=t.color,a=s.a*n.a*h.a,r=i?a:1,o=this.tempColor;o.set(s.r*n.r*h.r*r,s.g*n.g*h.g*r,s.b*n.b*h.b*r,a),t.computeWorldVertices(e,this.vertices,0,zt.VERTEX_SIZE);let l=this.vertices,c=t.uvs;return l[V.C1R]=o.r,l[V.C1G]=o.g,l[V.C1B]=o.b,l[V.C1A]=o.a,l[V.U1]=c[0],l[V.V1]=c[1],l[V.C2R]=o.r,l[V.C2G]=o.g,l[V.C2B]=o.b,l[V.C2A]=o.a,l[V.U2]=c[2],l[V.V2]=c[3],l[V.C3R]=o.r,l[V.C3G]=o.g,l[V.C3B]=o.b,l[V.C3A]=o.a,l[V.U3]=c[4],l[V.V3]=c[5],l[V.C4R]=o.r,l[V.C4G]=o.g,l[V.C4B]=o.b,l[V.C4A]=o.a,l[V.U4]=c[6],l[V.V4]=c[7],l}computeMeshVertices(e,t,i){let s=e.bone.skeleton.color,n=e.color,h=t.color,a=s.a*n.a*h.a,r=i?a:1,o=this.tempColor;o.set(s.r*n.r*h.r*r,s.g*n.g*h.g*r,s.b*n.b*h.b*r,a);let l=t.worldVerticesLength/2,c=this.vertices;c.length<t.worldVerticesLength&&(this.vertices=c=X.newFloatArray(t.worldVerticesLength)),t.computeWorldVertices(e,0,t.worldVerticesLength,c,0,zt.VERTEX_SIZE);let f=t.uvs;for(let d=0,u=0,m=2;d<l;d++)c[m++]=o.r,c[m++]=o.g,c[m++]=o.b,c[m++]=o.a,c[m++]=f[u++],c[m++]=f[u++],m+=2;return c}},rs=zt;B(rs,"QUAD_TRIANGLES",[0,1,2,2,3,0]),B(rs,"VERTEX_SIZE",8);var wt=class extends Ae.Plugins.ScenePlugin{game;isWebGL;gl;get webGLRenderer(){return wt.gameWebGLRenderer}canvasRenderer;phaserRenderer;skeletonDataCache;atlasCache;constructor(e,t,i){super(e,t,i),this.game=t.game,this.isWebGL=this.game.config.renderType===2,this.gl=this.isWebGL?this.game.renderer.gl:null,this.phaserRenderer=this.game.renderer,this.canvasRenderer=null,this.skeletonDataCache=this.game.cache.addCustom(Rr),this.atlasCache=this.game.cache.addCustom(kr);let s=function(o,l,c){let f=new ur(this,o,l,ns.json,c);return this.addFile(f.files),this};t.registerFileType("spineJson",s,e);let n=function(o,l,c){let f=new ur(this,o,l,ns.binary,c);return this.addFile(f.files),this};t.registerFileType("spineBinary",n,e);let h=function(o,l,c,f){let d=new Xn(this,o,l,c,f);return this.addFile(d.files),this};t.registerFileType("spineAtlas",h,e);let a=function(o,l,c,f,d){this.scene.sys.renderer instanceof Ae.Renderer.WebGL.WebGLRenderer&&this.scene.sys.renderer.pipelines.clear();const u=this.scene.sys[i];let m=new ss(this.scene,u,o,l,c,f,d);return this.displayList.add(m),this.updateList.add(m),this.scene.sys.renderer instanceof Ae.Renderer.WebGL.WebGLRenderer&&this.scene.sys.renderer.pipelines.rebind(),m},r=function(o,l=!1){this.scene.sys.renderer instanceof Ae.Renderer.WebGL.WebGLRenderer&&this.scene.sys.renderer.pipelines.clear();let c=o.x?o.x:0,f=o.y?o.y:0,d=o.boundsProvider?o.boundsProvider:void 0;const u=this.scene.sys[i];let m=new ss(this.scene,u,c,f,o.dataKey,o.atlasKey,d);return l!==void 0&&(o.add=l),this.scene.sys.renderer instanceof Ae.Renderer.WebGL.WebGLRenderer&&this.scene.sys.renderer.pipelines.rebind(),Ae.GameObjects.BuildGameObject(this.scene,m,o)};t.registerGameObject(window.SPINE_GAME_OBJECT_TYPE?window.SPINE_GAME_OBJECT_TYPE:Zt,a,r)}boot(){We.yDown=!0,this.isWebGL?(wt.gameWebGLRenderer||(wt.gameWebGLRenderer=new ts(this.game.renderer.canvas,this.gl,!0)),this.onResize(),this.game.scale.on(Ae.Scale.Events.RESIZE,this.onResize,this)):this.canvasRenderer||(this.canvasRenderer=new rs(this.scene.sys.context));var e=this.systems.events;e.once("shutdown",this.shutdown,this),e.once("destroy",this.destroy,this),this.game.events.once("destroy",this.gameDestroy,this)}onResize(){var e=this.game.renderer,t=this.webGLRenderer;if(e&&t){var i=e.width,s=e.height;t.camera.position.x=i/2,t.camera.position.y=s/2,t.camera.up.y=-1,t.camera.direction.z=1,t.camera.setViewport(i,s)}}shutdown(){this.systems.events.off("shutdown",this.shutdown,this),this.isWebGL&&this.game.scale.off(Ae.Scale.Events.RESIZE,this.onResize,this)}destroy(){this.shutdown()}gameDestroy(){this.pluginManager.removeGameObject(window.SPINE_GAME_OBJECT_TYPE?window.SPINE_GAME_OBJECT_TYPE:Zt,!0,!0),this.webGLRenderer&&this.webGLRenderer.dispose(),wt.gameWebGLRenderer=null}getAtlas(e){let t;if(this.atlasCache.exists(e))t=this.atlasCache.get(e);else{let i=this.game.cache.text.get(e);if(t=new Yi(i.data),this.isWebGL){let s=this.gl;const n=s.getParameter(s.UNPACK_PREMULTIPLY_ALPHA_WEBGL);n&&s.pixelStorei(s.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1);for(let h of t.pages)h.setTexture(new at(s,this.game.textures.get(e+"!"+h.name).getSourceImage(),!1));n&&s.pixelStorei(s.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!0)}else for(let s of t.pages)s.setTexture(new Pn(this.game.textures.get(e+"!"+s.name).getSourceImage()));this.atlasCache.add(e,t)}return t}isAtlasPremultiplied(e){let t=this.game.cache.text.get(e);return t?t.premultipliedAlpha:!1}getSkeletonData(e,t){const i=this.getAtlas(t),s=e+t;let n;if(this.skeletonDataCache.exists(s))n=this.skeletonDataCache.get(s);else{if(this.game.cache.json.exists(e)){let h=this.game.cache.json.get(e);n=new Vs(new Li(i)).readSkeletonData(h)}else{let h=this.game.cache.binary.get(e);n=new Xs(new Li(i)).readSkeletonData(new Uint8Array(h))}this.skeletonDataCache.add(s,n)}return n}createSkeleton(e,t){return new We(this.getSkeletonData(e,t))}},vt=wt;B(vt,"gameWebGLRenderer",null),B(vt,"rendererId",0);var ns=(e=>(e[e.json=0]="json",e[e.binary=1]="binary",e))(ns||{}),ur=class extends Ae.Loader.MultiFile{constructor(e,t,i,s,n){if(typeof t!="string"){const r=t;t=r.key,i=r.url,s=r.type==="spineJson"?0:1,n=r.xhrSettings}let h=null;s==0?h=new Ae.Loader.FileTypes.JSONFile(e,{key:t,url:i,extension:"json",xhrSettings:n}):h=new Ae.Loader.FileTypes.BinaryFile(e,{key:t,url:i,extension:"skel",xhrSettings:n}),super(e,Yr,t,[h]),this.fileType=s}onFileComplete(e){this.pending--}addToCache(){this.isReadyToProcess()&&this.files[0].addToCache()}},Xn=class extends Ae.Loader.MultiFile{constructor(e,t,i,s,n){if(typeof t!="string"){const h=t;t=h.key,i=h.url,s=h.premultipliedAlpha,n=h.xhrSettings}super(e,Fr,t,[new Ae.Loader.FileTypes.TextFile(e,{key:t,url:i,xhrSettings:n,extension:"atlas"})]),this.premultipliedAlpha=s}onFileComplete(e){if(this.files.indexOf(e)!=-1&&(this.pending--,e.type=="text")){var t=e.data.split(/\r\n|\r|\n/);let o=[];o.push(t[0]);for(var i=1;i<t.length;i++){var s=t[i];s.trim()===""&&i<t.length-1&&(s=t[i+1],o.push(s))}let l=e.src.match(/^.*\//)??"";for(var n=0;n<o.length;n++){var h=l+o[n],a=e.key+"!"+o[n],r=new Ae.Loader.FileTypes.ImageFile(this.loader,a,h);this.loader.keyExists(r)||(this.addToMultiFile(r),this.loader.addFile(r))}}}addToCache(){if(this.isReadyToProcess()){let e=this.loader.textureManager;for(let t of this.files)t.type=="image"?e.exists(t.key)||e.addImage(t.key,t.data):(this.premultipliedAlpha=this.premultipliedAlpha??(t.data.indexOf("pma: true")>=0||t.data.indexOf("pma:true")>=0),t.data={data:t.data,premultipliedAlpha:this.premultipliedAlpha},t.addToCache())}}};return window.spine={SpinePlugin:vt},window["spine.SpinePlugin"]=vt,Er(hs)})();
84
+ `;return new ue(e,i,r)}},Ni=class{constructor(t,e,i,r){this.attributes=e,this.context=t instanceof xe?t:new xe(t),this.elementsPerVertex=0;for(let s=0;s<e.length;s++)this.elementsPerVertex+=e[s].numElements;this.vertices=new Float32Array(i*this.elementsPerVertex),this.indices=new Uint16Array(r),this.context.addRestorable(this)}context;vertices;verticesBuffer=null;verticesLength=0;dirtyVertices=!1;indices;indicesBuffer=null;indicesLength=0;dirtyIndices=!1;elementsPerVertex=0;getAttributes(){return this.attributes}maxVertices(){return this.vertices.length/this.elementsPerVertex}numVertices(){return this.verticesLength/this.elementsPerVertex}setVerticesLength(t){this.dirtyVertices=!0,this.verticesLength=t}getVertices(){return this.vertices}maxIndices(){return this.indices.length}numIndices(){return this.indicesLength}setIndicesLength(t){this.dirtyIndices=!0,this.indicesLength=t}getIndices(){return this.indices}getVertexSizeInFloats(){let t=0;for(var e=0;e<this.attributes.length;e++){let i=this.attributes[e];t+=i.numElements}return t}setVertices(t){if(this.dirtyVertices=!0,t.length>this.vertices.length)throw Error("Mesh can't store more than "+this.maxVertices()+" vertices");this.vertices.set(t,0),this.verticesLength=t.length}setIndices(t){if(this.dirtyIndices=!0,t.length>this.indices.length)throw Error("Mesh can't store more than "+this.maxIndices()+" indices");this.indices.set(t,0),this.indicesLength=t.length}draw(t,e){this.drawWithOffset(t,e,0,this.indicesLength>0?this.indicesLength:this.verticesLength/this.elementsPerVertex)}drawWithOffset(t,e,i,r){let s=this.context.gl;(this.dirtyVertices||this.dirtyIndices)&&this.update(),this.bind(t),this.indicesLength>0?s.drawElements(e,r,s.UNSIGNED_SHORT,i*2):s.drawArrays(e,i,r),this.unbind(t)}bind(t){let e=this.context.gl;e.bindBuffer(e.ARRAY_BUFFER,this.verticesBuffer);let i=0;for(let r=0;r<this.attributes.length;r++){let s=this.attributes[r],h=t.getAttributeLocation(s.name);e.enableVertexAttribArray(h),e.vertexAttribPointer(h,s.numElements,e.FLOAT,!1,this.elementsPerVertex*4,i*4),i+=s.numElements}this.indicesLength>0&&e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,this.indicesBuffer)}unbind(t){let e=this.context.gl;for(let i=0;i<this.attributes.length;i++){let r=this.attributes[i],s=t.getAttributeLocation(r.name);e.disableVertexAttribArray(s)}e.bindBuffer(e.ARRAY_BUFFER,null),this.indicesLength>0&&e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,null)}update(){let t=this.context.gl;this.dirtyVertices&&(this.verticesBuffer||(this.verticesBuffer=t.createBuffer()),t.bindBuffer(t.ARRAY_BUFFER,this.verticesBuffer),t.bufferData(t.ARRAY_BUFFER,this.vertices.subarray(0,this.verticesLength),t.DYNAMIC_DRAW),this.dirtyVertices=!1),this.dirtyIndices&&(this.indicesBuffer||(this.indicesBuffer=t.createBuffer()),t.bindBuffer(t.ELEMENT_ARRAY_BUFFER,this.indicesBuffer),t.bufferData(t.ELEMENT_ARRAY_BUFFER,this.indices.subarray(0,this.indicesLength),t.DYNAMIC_DRAW),this.dirtyIndices=!1)}restore(){this.verticesBuffer=null,this.indicesBuffer=null,this.update()}dispose(){this.context.removeRestorable(this);let t=this.context.gl;t.deleteBuffer(this.verticesBuffer),t.deleteBuffer(this.indicesBuffer)}},Ke=class{constructor(t,e,i){this.name=t,this.type=e,this.numElements=i}},At=class extends Ke{constructor(){super(Me.POSITION,0,2)}},Sn=class extends Ke{constructor(){super(Me.POSITION,0,3)}},Ui=class extends Ke{constructor(t=0){super(Me.TEXCOORDS+(t==0?"":t),0,2)}},Ct=class extends Ke{constructor(){super(Me.COLOR,0,4)}},Xs=class extends Ke{constructor(){super(Me.COLOR2,0,4)}},Bs=(t=>(t[t.Float=0]="Float",t))(Bs||{}),Xe=1,Tn=769,Os=770,Vs=771,Ds=774,Wi=class He{static disableCulling=!1;context;drawCalls=0;static globalDrawCalls=0;isDrawing=!1;mesh;shader=null;lastTexture=null;verticesLength=0;indicesLength=0;srcColorBlend;srcAlphaBlend;dstBlend;cullWasEnabled=!1;constructor(e,i=!0,r=10920){if(r>10920)throw new Error("Can't have more than 10920 triangles per batch: "+r);this.context=e instanceof xe?e:new xe(e);let s=i?[new At,new Ct,new Ui,new Xs]:[new At,new Ct,new Ui];this.mesh=new Ni(e,s,r,r*3);let h=this.context.gl;this.srcColorBlend=h.SRC_ALPHA,this.srcAlphaBlend=h.ONE,this.dstBlend=h.ONE_MINUS_SRC_ALPHA}begin(e){if(this.isDrawing)throw new Error("PolygonBatch is already drawing. Call PolygonBatch.end() before calling PolygonBatch.begin()");this.drawCalls=0,this.shader=e,this.lastTexture=null,this.isDrawing=!0;let i=this.context.gl;i.enable(i.BLEND),i.blendFuncSeparate(this.srcColorBlend,this.dstBlend,this.srcAlphaBlend,this.dstBlend),He.disableCulling&&(this.cullWasEnabled=i.isEnabled(i.CULL_FACE),this.cullWasEnabled&&i.disable(i.CULL_FACE))}static blendModesGL=[{srcRgb:Os,srcRgbPma:Xe,dstRgb:Vs,srcAlpha:Xe},{srcRgb:Os,srcRgbPma:Xe,dstRgb:Xe,srcAlpha:Xe},{srcRgb:Ds,srcRgbPma:Ds,dstRgb:Vs,srcAlpha:Xe},{srcRgb:Xe,srcRgbPma:Xe,dstRgb:Tn,srcAlpha:Xe}];setBlendMode(e,i){const r=He.blendModesGL[e],s=i?r.srcRgbPma:r.srcRgb,h=r.srcAlpha,l=r.dstRgb;if(this.srcColorBlend==s&&this.srcAlphaBlend==h&&this.dstBlend==l)return;this.srcColorBlend=s,this.srcAlphaBlend=h,this.dstBlend=l,this.isDrawing&&this.flush(),this.context.gl.blendFuncSeparate(s,l,h,l)}draw(e,i,r){e!=this.lastTexture?(this.flush(),this.lastTexture=e):(this.verticesLength+i.length>this.mesh.getVertices().length||this.indicesLength+r.length>this.mesh.getIndices().length)&&this.flush();let s=this.mesh.numVertices();this.mesh.getVertices().set(i,this.verticesLength),this.verticesLength+=i.length,this.mesh.setVerticesLength(this.verticesLength);let h=this.mesh.getIndices();for(let l=this.indicesLength,n=0;n<r.length;l++,n++)h[l]=r[n]+s;this.indicesLength+=r.length,this.mesh.setIndicesLength(this.indicesLength)}flush(){if(this.verticesLength!=0){if(!this.lastTexture)throw new Error("No texture set.");if(!this.shader)throw new Error("No shader set.");this.lastTexture.bind(),this.mesh.draw(this.shader,this.context.gl.TRIANGLES),this.verticesLength=0,this.indicesLength=0,this.mesh.setVerticesLength(0),this.mesh.setIndicesLength(0),this.drawCalls++,He.globalDrawCalls++}}end(){if(!this.isDrawing)throw new Error("PolygonBatch is not drawing. Call PolygonBatch.begin() before calling PolygonBatch.end()");(this.verticesLength>0||this.indicesLength>0)&&this.flush(),this.shader=null,this.lastTexture=null,this.isDrawing=!1;let e=this.context.gl;e.disable(e.BLEND),He.disableCulling&&this.cullWasEnabled&&e.enable(e.CULL_FACE)}getDrawCalls(){return this.drawCalls}static getAndResetGlobalDrawCalls(){let e=He.globalDrawCalls;return He.globalDrawCalls=0,e}dispose(){this.mesh.dispose()}},Gi=class{context;isDrawing=!1;mesh;shapeType=4;color=new K(1,1,1,1);shader=null;vertexIndex=0;tmp=new Ue;srcColorBlend;srcAlphaBlend;dstBlend;constructor(t,e=10920){if(e>10920)throw new Error("Can't have more than 10920 triangles per batch: "+e);this.context=t instanceof xe?t:new xe(t),this.mesh=new Ni(t,[new At,new Ct],e,0);let i=this.context.gl;this.srcColorBlend=i.SRC_ALPHA,this.srcAlphaBlend=i.ONE,this.dstBlend=i.ONE_MINUS_SRC_ALPHA}begin(t){if(this.isDrawing)throw new Error("ShapeRenderer.begin() has already been called");this.shader=t,this.vertexIndex=0,this.isDrawing=!0;let e=this.context.gl;e.enable(e.BLEND),e.blendFuncSeparate(this.srcColorBlend,this.dstBlend,this.srcAlphaBlend,this.dstBlend)}setBlendMode(t,e,i){this.srcColorBlend=t,this.srcAlphaBlend=e,this.dstBlend=i,this.isDrawing&&(this.flush(),this.context.gl.blendFuncSeparate(t,i,e,i))}setColor(t){this.color.setFromColor(t)}setColorWith(t,e,i,r){this.color.set(t,e,i,r)}point(t,e,i){this.check(0,1),i||(i=this.color),this.vertex(t,e,i)}line(t,e,i,r,s){this.check(1,2);let h=this.mesh.getVertices(),l=this.vertexIndex;s||(s=this.color),this.vertex(t,e,s),this.vertex(i,r,s)}triangle(t,e,i,r,s,h,l,n,a,o){this.check(t?4:1,3);let c=this.mesh.getVertices(),d=this.vertexIndex;n||(n=this.color),a||(a=this.color),o||(o=this.color),t?(this.vertex(e,i,n),this.vertex(r,s,a),this.vertex(h,l,o)):(this.vertex(e,i,n),this.vertex(r,s,a),this.vertex(r,s,n),this.vertex(h,l,a),this.vertex(h,l,n),this.vertex(e,i,a))}quad(t,e,i,r,s,h,l,n,a,o,c,d,u){this.check(t?4:1,3);let m=this.mesh.getVertices(),f=this.vertexIndex;o||(o=this.color),c||(c=this.color),d||(d=this.color),u||(u=this.color),t?(this.vertex(e,i,o),this.vertex(r,s,c),this.vertex(h,l,d),this.vertex(h,l,d),this.vertex(n,a,u),this.vertex(e,i,o)):(this.vertex(e,i,o),this.vertex(r,s,c),this.vertex(r,s,c),this.vertex(h,l,d),this.vertex(h,l,d),this.vertex(n,a,u),this.vertex(n,a,u),this.vertex(e,i,o))}rect(t,e,i,r,s,h){this.quad(t,e,i,e+r,i,e+r,i+s,e,i+s,h,h,h,h)}rectLine(t,e,i,r,s,h,l){this.check(t?4:1,8),l||(l=this.color);let n=this.tmp.set(s-i,e-r);n.normalize(),h*=.5;let a=n.x*h,o=n.y*h;t?(this.vertex(e+a,i+o,l),this.vertex(e-a,i-o,l),this.vertex(r+a,s+o,l),this.vertex(r-a,s-o,l),this.vertex(r+a,s+o,l),this.vertex(e-a,i-o,l)):(this.vertex(e+a,i+o,l),this.vertex(e-a,i-o,l),this.vertex(r+a,s+o,l),this.vertex(r-a,s-o,l),this.vertex(r+a,s+o,l),this.vertex(e+a,i+o,l),this.vertex(r-a,s-o,l),this.vertex(e-a,i-o,l))}x(t,e,i){this.line(t-i,e-i,t+i,e+i),this.line(t-i,e+i,t+i,e-i)}polygon(t,e,i,r){if(i<3)throw new Error("Polygon must contain at least 3 vertices");this.check(1,i*2),r||(r=this.color);let s=this.mesh.getVertices(),h=this.vertexIndex;e<<=1,i<<=1;let l=t[e],n=t[e+1],a=e+i;for(let o=e,c=e+i-2;o<c;o+=2){let d=t[o],u=t[o+1],m=0,f=0;o+2>=a?(m=l,f=n):(m=t[o+2],f=t[o+3]),this.vertex(d,u,r),this.vertex(m,f,r)}}circle(t,e,i,r,s,h=0){if(h==0&&(h=Math.max(1,6*L.cbrt(r)|0)),h<=0)throw new Error("segments must be > 0.");s||(s=this.color);let l=2*L.PI/h,n=Math.cos(l),a=Math.sin(l),o=r,c=0;if(t){this.check(4,h*3+3),h--;for(let u=0;u<h;u++){this.vertex(e,i,s),this.vertex(e+o,i+c,s);let m=o;o=n*o-a*c,c=a*m+n*c,this.vertex(e+o,i+c,s)}this.vertex(e,i,s),this.vertex(e+o,i+c,s)}else{this.check(1,h*2+2);for(let u=0;u<h;u++){this.vertex(e+o,i+c,s);let m=o;o=n*o-a*c,c=a*m+n*c,this.vertex(e+o,i+c,s)}this.vertex(e+o,i+c,s)}let d=o;o=r,c=0,this.vertex(e+o,i+c,s)}curve(t,e,i,r,s,h,l,n,a,o){this.check(1,a*2+2),o||(o=this.color);let c=1/a,d=c*c,u=c*c*c,m=3*c,f=3*d,g=6*d,x=6*u,b=t-i*2+s,p=e-r*2+h,w=(i-s)*3-t+l,v=(r-h)*3-e+n,y=t,A=e,C=(i-t)*m+b*f+w*u,S=(r-e)*m+p*f+v*u,I=b*g+w*x,k=p*g+v*x,Y=w*x,F=v*x;for(;a-- >0;)this.vertex(y,A,o),y+=C,A+=S,C+=I,S+=k,I+=Y,k+=F,this.vertex(y,A,o);this.vertex(y,A,o),this.vertex(l,n,o)}vertex(t,e,i){let r=this.vertexIndex,s=this.mesh.getVertices();s[r++]=t,s[r++]=e,s[r++]=i.r,s[r++]=i.g,s[r++]=i.b,s[r++]=i.a,this.vertexIndex=r}end(){if(!this.isDrawing)throw new Error("ShapeRenderer.begin() has not been called");this.flush();let t=this.context.gl;t.disable(t.BLEND),this.isDrawing=!1}flush(){if(this.vertexIndex!=0){if(!this.shader)throw new Error("No shader set.");this.mesh.setVerticesLength(this.vertexIndex),this.mesh.draw(this.shader,this.shapeType),this.vertexIndex=0}}check(t,e){if(!this.isDrawing)throw new Error("ShapeRenderer.begin() has not been called");if(this.shapeType==t)if(this.mesh.maxVertices()-this.mesh.numVertices()<e)this.flush();else return;else this.flush(),this.shapeType=t}dispose(){this.mesh.dispose()}},Ns=(t=>(t[t.Point=0]="Point",t[t.Line=1]="Line",t[t.Filled=4]="Filled",t))(Ns||{}),Us=class es{boneLineColor=new K(1,0,0,1);boneOriginColor=new K(0,1,0,1);attachmentLineColor=new K(0,0,1,.5);triangleLineColor=new K(1,.64,0,.5);pathColor=new K().setFromString("FF7F00");clipColor=new K(.8,0,0,2);aabbColor=new K(0,1,0,.5);drawBones=!0;drawRegionAttachments=!0;drawBoundingBoxes=!0;drawMeshHull=!0;drawMeshTriangles=!0;drawPaths=!0;drawSkeletonXY=!1;drawClipping=!0;premultipliedAlpha=!1;scale=1;boneWidth=2;context;bounds=new Rs;temp=new Array;vertices=X.newFloatArray(2*1024);static LIGHT_GRAY=new K(192/255,192/255,192/255,1);static GREEN=new K(0,1,0,1);constructor(e){this.context=e instanceof xe?e:new xe(e)}draw(e,i,r){let s=i.x,h=i.y,l=this.context.gl,n=this.premultipliedAlpha?l.ONE:l.SRC_ALPHA;e.setBlendMode(n,l.ONE,l.ONE_MINUS_SRC_ALPHA);let a=i.bones;if(this.drawBones){e.setColor(this.boneLineColor);for(let o=0,c=a.length;o<c;o++){let d=a[o];if(r&&r.indexOf(d.data.name)>-1||!d.parent)continue;let u=d.data.length*d.a+d.worldX,m=d.data.length*d.c+d.worldY;e.rectLine(!0,d.worldX,d.worldY,u,m,this.boneWidth*this.scale)}this.drawSkeletonXY&&e.x(s,h,4*this.scale)}if(this.drawRegionAttachments){e.setColor(this.attachmentLineColor);let o=i.slots;for(let c=0,d=o.length;c<d;c++){let u=o[c],m=u.getAttachment();if(m instanceof ce){let f=m,g=this.vertices;f.computeWorldVertices(u,g,0,2),e.line(g[0],g[1],g[2],g[3]),e.line(g[2],g[3],g[4],g[5]),e.line(g[4],g[5],g[6],g[7]),e.line(g[6],g[7],g[0],g[1])}}}if(this.drawMeshHull||this.drawMeshTriangles){let o=i.slots;for(let c=0,d=o.length;c<d;c++){let u=o[c];if(!u.bone.active)continue;let m=u.getAttachment();if(!(m instanceof Ge))continue;let f=m,g=this.vertices;f.computeWorldVertices(u,0,f.worldVerticesLength,g,0,2);let x=f.triangles,b=f.hullLength;if(this.drawMeshTriangles){e.setColor(this.triangleLineColor);for(let p=0,w=x.length;p<w;p+=3){let v=x[p]*2,y=x[p+1]*2,A=x[p+2]*2;e.triangle(!1,g[v],g[v+1],g[y],g[y+1],g[A],g[A+1])}}if(this.drawMeshHull&&b>0){e.setColor(this.attachmentLineColor),b=(b>>1)*2;let p=g[b-2],w=g[b-1];for(let v=0,y=b;v<y;v+=2){let A=g[v],C=g[v+1];e.line(A,C,p,w),p=A,w=C}}}}if(this.drawBoundingBoxes){let o=this.bounds;o.update(i,!0),e.setColor(this.aabbColor),e.rect(!1,o.minX,o.minY,o.getWidth(),o.getHeight());let c=o.polygons,d=o.boundingBoxes;for(let u=0,m=c.length;u<m;u++){let f=c[u];e.setColor(d[u].color),e.polygon(f,0,f.length)}}if(this.drawPaths){let o=i.slots;for(let c=0,d=o.length;c<d;c++){let u=o[c];if(!u.bone.active)continue;let m=u.getAttachment();if(!(m instanceof Ze))continue;let f=m,g=f.worldVerticesLength,x=this.temp=X.setArraySize(this.temp,g,0);f.computeWorldVertices(u,0,g,x,0,2);let b=this.pathColor,p=x[2],w=x[3],v=0,y=0;if(f.closed){e.setColor(b);let A=x[0],C=x[1],S=x[g-2],I=x[g-1];v=x[g-4],y=x[g-3],e.curve(p,w,A,C,S,I,v,y,32),e.setColor(es.LIGHT_GRAY),e.line(p,w,A,C),e.line(v,y,S,I)}g-=4;for(let A=4;A<g;A+=6){let C=x[A],S=x[A+1],I=x[A+2],k=x[A+3];v=x[A+4],y=x[A+5],e.setColor(b),e.curve(p,w,C,S,I,k,v,y,32),e.setColor(es.LIGHT_GRAY),e.line(p,w,C,S),e.line(v,y,I,k),p=v,w=y}}}if(this.drawBones){e.setColor(this.boneOriginColor);for(let o=0,c=a.length;o<c;o++){let d=a[o];r&&r.indexOf(d.data.name)>-1||e.circle(!0,d.worldX,d.worldY,3*this.scale,this.boneOriginColor,8)}}if(this.drawClipping){let o=i.slots;e.setColor(this.clipColor);for(let c=0,d=o.length;c<d;c++){let u=o[c];if(!u.bone.active)continue;let m=u.getAttachment();if(!(m instanceof rt))continue;let f=m,g=f.worldVerticesLength,x=this.temp=X.setArraySize(this.temp,g,0);f.computeWorldVertices(u,0,g,x,0,2);for(let b=0,p=x.length;b<p;b+=2){let w=x[b],v=x[b+1],y=x[(b+2)%x.length],A=x[(b+3)%x.length];e.line(w,v,y,A)}}}}dispose(){}},In=class{constructor(t,e,i){this.vertices=t,this.numVertices=e,this.numFloats=i}},Ws=class yr{static QUAD_TRIANGLES=[0,1,2,2,3,0];premultipliedAlpha=!1;tempColor=new K;tempColor2=new K;vertices;vertexSize=8;twoColorTint=!1;renderable=new In([],0,0);clipper=new yt;temp=new Ue;temp2=new Ue;temp3=new K;temp4=new K;constructor(e,i=!0){this.twoColorTint=i,i&&(this.vertexSize+=4),this.vertices=X.newFloatArray(this.vertexSize*1024)}draw(e,i,r=-1,s=-1,h=null){let l=this.clipper,n=this.premultipliedAlpha,a=this.twoColorTint,o=null,c=this.renderable,d,u,m=i.drawOrder,f,g=i.color,x=a?12:8,b=!1;r==-1&&(b=!0);for(let p=0,w=m.length;p<w;p++){let v=l.isClipping()?2:x,y=m[p];if(!y.bone.active){l.clipEndWithSlot(y);continue}if(r>=0&&r==y.data.index&&(b=!0),!b){l.clipEndWithSlot(y);continue}s>=0&&s==y.data.index&&(b=!1);let A=y.getAttachment(),C;if(A instanceof ce){let S=A;c.vertices=this.vertices,c.numVertices=4,c.numFloats=v<<2,S.computeWorldVertices(y,c.vertices,0,v),u=yr.QUAD_TRIANGLES,d=S.uvs,C=S.region.texture,f=S.color}else if(A instanceof Ge){let S=A;c.vertices=this.vertices,c.numVertices=S.worldVerticesLength>>1,c.numFloats=c.numVertices*v,c.numFloats>c.vertices.length&&(c.vertices=this.vertices=X.newFloatArray(c.numFloats)),S.computeWorldVertices(y,0,S.worldVerticesLength,c.vertices,0,v),u=S.triangles,C=S.region.texture,d=S.uvs,f=S.color}else if(A instanceof rt){let S=A;l.clipStart(y,S);continue}else{l.clipEndWithSlot(y);continue}if(C){let S=y.color,I=this.tempColor;I.r=g.r*S.r*f.r,I.g=g.g*S.g*f.g,I.b=g.b*S.b*f.b,I.a=g.a*S.a*f.a,n&&(I.r*=I.a,I.g*=I.a,I.b*=I.a);let k=this.tempColor2;y.darkColor?(n?(k.r=y.darkColor.r*I.a,k.g=y.darkColor.g*I.a,k.b=y.darkColor.b*I.a):k.setFromColor(y.darkColor),k.a=n?1:0):k.set(0,0,0,1);let Y=y.data.blendMode;if(Y!=o&&(o=Y,e.setBlendMode(o,n)),l.isClipping()){l.clipTriangles(c.vertices,u,u.length,d,I,k,a);let F=new Float32Array(l.clippedVertices),P=l.clippedTriangles;h&&h(F,F.length,x),e.draw(C,F,P)}else{let F=c.vertices;if(a)for(let M=2,R=0,B=c.numFloats;M<B;M+=x,R+=2)F[M]=I.r,F[M+1]=I.g,F[M+2]=I.b,F[M+3]=I.a,F[M+4]=d[R],F[M+5]=d[R+1],F[M+6]=k.r,F[M+7]=k.g,F[M+8]=k.b,F[M+9]=k.a;else for(let M=2,R=0,B=c.numFloats;M<B;M+=x,R+=2)F[M]=I.r,F[M+1]=I.g,F[M+2]=I.b,F[M+3]=I.a,F[M+4]=d[R],F[M+5]=d[R+1];let P=c.vertices.subarray(0,c.numFloats);h&&h(c.vertices,c.numFloats,x),e.draw(C,P,u)}}l.clipEndWithSlot(y)}l.clipEnd()}getSkeletonClipping(){return this.clipper}},T=[0,0,1,1,1,1,0,0,0,0,1,1,1,1,0,0,0,0,1,1,1,1,0,0,0,0,1,1,1,1,0,0],St=[0,1,2,2,3,0],Tt=new K(1,1,1,1),zi=class{context;canvas;camera;batcher;twoColorTint=!1;batcherShader;shapes;shapesShader;activeRenderer=null;skeletonRenderer;skeletonDebugRenderer;constructor(t,e,i=!0){this.canvas=t,this.context=e instanceof xe?e:new xe(e),this.twoColorTint=i,this.camera=new Ps(t.width,t.height),this.batcherShader=i?Me.newTwoColoredTextured(this.context):Me.newColoredTextured(this.context),this.batcher=new Wi(this.context,i),this.shapesShader=Me.newColored(this.context),this.shapes=new Gi(this.context),this.skeletonRenderer=new Ws(this.context,i),this.skeletonDebugRenderer=new Us(this.context)}dispose(){this.batcher.dispose(),this.batcherShader.dispose(),this.shapes.dispose(),this.shapesShader.dispose(),this.skeletonDebugRenderer.dispose()}begin(){this.camera.update(),this.enableRenderer(this.batcher)}drawSkeleton(t,e=!1,i=-1,r=-1,s=null){this.enableRenderer(this.batcher),this.skeletonRenderer.premultipliedAlpha=e,this.skeletonRenderer.draw(this.batcher,t,i,r,s)}drawSkeletonDebug(t,e=!1,i){this.enableRenderer(this.shapes),this.skeletonDebugRenderer.premultipliedAlpha=e,this.skeletonDebugRenderer.draw(this.shapes,t,i)}drawTexture(t,e,i,r,s,h){this.enableRenderer(this.batcher),h||(h=Tt);var l=0;T[l++]=e,T[l++]=i,T[l++]=h.r,T[l++]=h.g,T[l++]=h.b,T[l++]=h.a,T[l++]=0,T[l++]=1,this.twoColorTint&&(T[l++]=0,T[l++]=0,T[l++]=0,T[l++]=0),T[l++]=e+r,T[l++]=i,T[l++]=h.r,T[l++]=h.g,T[l++]=h.b,T[l++]=h.a,T[l++]=1,T[l++]=1,this.twoColorTint&&(T[l++]=0,T[l++]=0,T[l++]=0,T[l++]=0),T[l++]=e+r,T[l++]=i+s,T[l++]=h.r,T[l++]=h.g,T[l++]=h.b,T[l++]=h.a,T[l++]=1,T[l++]=0,this.twoColorTint&&(T[l++]=0,T[l++]=0,T[l++]=0,T[l++]=0),T[l++]=e,T[l++]=i+s,T[l++]=h.r,T[l++]=h.g,T[l++]=h.b,T[l++]=h.a,T[l++]=0,T[l++]=0,this.twoColorTint&&(T[l++]=0,T[l++]=0,T[l++]=0,T[l]=0),this.batcher.draw(t,T,St)}drawTextureUV(t,e,i,r,s,h,l,n,a,o){this.enableRenderer(this.batcher),o||(o=Tt);var c=0;T[c++]=e,T[c++]=i,T[c++]=o.r,T[c++]=o.g,T[c++]=o.b,T[c++]=o.a,T[c++]=h,T[c++]=l,this.twoColorTint&&(T[c++]=0,T[c++]=0,T[c++]=0,T[c++]=0),T[c++]=e+r,T[c++]=i,T[c++]=o.r,T[c++]=o.g,T[c++]=o.b,T[c++]=o.a,T[c++]=n,T[c++]=l,this.twoColorTint&&(T[c++]=0,T[c++]=0,T[c++]=0,T[c++]=0),T[c++]=e+r,T[c++]=i+s,T[c++]=o.r,T[c++]=o.g,T[c++]=o.b,T[c++]=o.a,T[c++]=n,T[c++]=a,this.twoColorTint&&(T[c++]=0,T[c++]=0,T[c++]=0,T[c++]=0),T[c++]=e,T[c++]=i+s,T[c++]=o.r,T[c++]=o.g,T[c++]=o.b,T[c++]=o.a,T[c++]=h,T[c++]=a,this.twoColorTint&&(T[c++]=0,T[c++]=0,T[c++]=0,T[c]=0),this.batcher.draw(t,T,St)}drawTextureRotated(t,e,i,r,s,h,l,n,a){this.enableRenderer(this.batcher),a||(a=Tt);let o=e+h,c=i+l,d=-h,u=-l,m=r-h,f=s-l,g=d,x=u,b=d,p=f,w=m,v=f,y=m,A=u,C=0,S=0,I=0,k=0,Y=0,F=0,P=0,M=0;if(n!=0){let B=L.cosDeg(n),ie=L.sinDeg(n);C=B*g-ie*x,S=ie*g+B*x,P=B*b-ie*p,M=ie*b+B*p,Y=B*w-ie*v,F=ie*w+B*v,I=Y+(C-P),k=F+(S-M)}else C=g,S=x,P=b,M=p,Y=w,F=v,I=y,k=A;C+=o,S+=c,I+=o,k+=c,Y+=o,F+=c,P+=o,M+=c;var R=0;T[R++]=C,T[R++]=S,T[R++]=a.r,T[R++]=a.g,T[R++]=a.b,T[R++]=a.a,T[R++]=0,T[R++]=1,this.twoColorTint&&(T[R++]=0,T[R++]=0,T[R++]=0,T[R++]=0),T[R++]=I,T[R++]=k,T[R++]=a.r,T[R++]=a.g,T[R++]=a.b,T[R++]=a.a,T[R++]=1,T[R++]=1,this.twoColorTint&&(T[R++]=0,T[R++]=0,T[R++]=0,T[R++]=0),T[R++]=Y,T[R++]=F,T[R++]=a.r,T[R++]=a.g,T[R++]=a.b,T[R++]=a.a,T[R++]=1,T[R++]=0,this.twoColorTint&&(T[R++]=0,T[R++]=0,T[R++]=0,T[R++]=0),T[R++]=P,T[R++]=M,T[R++]=a.r,T[R++]=a.g,T[R++]=a.b,T[R++]=a.a,T[R++]=0,T[R++]=0,this.twoColorTint&&(T[R++]=0,T[R++]=0,T[R++]=0,T[R]=0),this.batcher.draw(t,T,St)}drawRegion(t,e,i,r,s,h){this.enableRenderer(this.batcher),h||(h=Tt);var l=0;T[l++]=e,T[l++]=i,T[l++]=h.r,T[l++]=h.g,T[l++]=h.b,T[l++]=h.a,T[l++]=t.u,T[l++]=t.v2,this.twoColorTint&&(T[l++]=0,T[l++]=0,T[l++]=0,T[l++]=0),T[l++]=e+r,T[l++]=i,T[l++]=h.r,T[l++]=h.g,T[l++]=h.b,T[l++]=h.a,T[l++]=t.u2,T[l++]=t.v2,this.twoColorTint&&(T[l++]=0,T[l++]=0,T[l++]=0,T[l++]=0),T[l++]=e+r,T[l++]=i+s,T[l++]=h.r,T[l++]=h.g,T[l++]=h.b,T[l++]=h.a,T[l++]=t.u2,T[l++]=t.v,this.twoColorTint&&(T[l++]=0,T[l++]=0,T[l++]=0,T[l++]=0),T[l++]=e,T[l++]=i+s,T[l++]=h.r,T[l++]=h.g,T[l++]=h.b,T[l++]=h.a,T[l++]=t.u,T[l++]=t.v,this.twoColorTint&&(T[l++]=0,T[l++]=0,T[l++]=0,T[l]=0),this.batcher.draw(t.page.texture,T,St)}line(t,e,i,r,s,h){this.enableRenderer(this.shapes),this.shapes.line(t,e,i,r,s)}triangle(t,e,i,r,s,h,l,n,a,o){this.enableRenderer(this.shapes),this.shapes.triangle(t,e,i,r,s,h,l,n,a,o)}quad(t,e,i,r,s,h,l,n,a,o,c,d,u){this.enableRenderer(this.shapes),this.shapes.quad(t,e,i,r,s,h,l,n,a,o,c,d,u)}rect(t,e,i,r,s,h){this.enableRenderer(this.shapes),this.shapes.rect(t,e,i,r,s,h)}rectLine(t,e,i,r,s,h,l){this.enableRenderer(this.shapes),this.shapes.rectLine(t,e,i,r,s,h,l)}polygon(t,e,i,r){this.enableRenderer(this.shapes),this.shapes.polygon(t,e,i,r)}circle(t,e,i,r,s,h=0){this.enableRenderer(this.shapes),this.shapes.circle(t,e,i,r,s,h)}curve(t,e,i,r,s,h,l,n,a,o){this.enableRenderer(this.shapes),this.shapes.curve(t,e,i,r,s,h,l,n,a,o)}end(){this.activeRenderer===this.batcher?this.batcher.end():this.activeRenderer===this.shapes&&this.shapes.end(),this.activeRenderer=null}resize(t){let e=this.canvas;var i=window.devicePixelRatio||1,r=Math.round(e.clientWidth*i),s=Math.round(e.clientHeight*i);if((e.width!=r||e.height!=s)&&(e.width=r,e.height=s),this.context.gl.viewport(0,0,e.width,e.height),t===1)this.camera.setViewport(r,s);else if(t===2){let h=e.width,l=e.height,n=this.camera.viewportWidth,a=this.camera.viewportHeight,o=a/n,c=l/h,d=o<c?n/h:a/l;this.camera.setViewport(h*d,l*d)}this.camera.update()}enableRenderer(t){this.activeRenderer!==t&&(this.end(),t instanceof Wi?(this.batcherShader.bind(),this.batcherShader.setUniform4x4f(Me.MVP_MATRIX,this.camera.projectionView.values),this.batcherShader.setUniformi("u_texture",0),this.batcher.begin(this.batcherShader),this.activeRenderer=this.batcher):t instanceof Gi?(this.shapesShader.bind(),this.shapesShader.setUniform4x4f(Me.MVP_MATRIX,this.camera.projectionView.values),this.shapes.begin(this.shapesShader),this.activeRenderer=this.shapes):this.activeRenderer=this.skeletonDebugRenderer)}},Gs=(t=>(t[t.Stretch=0]="Stretch",t[t.Expand=1]="Expand",t[t.Fit=2]="Fit",t))(Gs||{}),Qe,qe,qi=0,Mn=1,_i=1,It=165,Mt=108,Ee=163,En=class{renderer;logo=null;spinner=null;angle=0;fadeOut=0;fadeIn=0;timeKeeper=new Ot;backgroundColor=new K(.135,.135,.135,1);tempColor=new K;constructor(t){if(this.renderer=t,this.timeKeeper.maxDelta=9,!qe){let e=navigator.userAgent.indexOf("Safari")>-1,i=()=>qi++;qe=new Image,qe.src=kn,e||(qe.crossOrigin="anonymous"),qe.onload=i,Qe=new Image,Qe.src=Rn,e||(Qe.crossOrigin="anonymous"),Qe.onload=i}}dispose(){this.logo?.dispose(),this.spinner?.dispose()}draw(t=!1){if(qi<2||t&&this.fadeOut>_i)return;this.timeKeeper.update();let e=Math.abs(Math.sin(this.timeKeeper.totalTime+.25));this.angle-=this.timeKeeper.delta*200*(1+1.5*Math.pow(e,5));let i=this.tempColor,r=this.renderer,s=r.canvas,h=r.context.gl;if(r.resize(1),r.camera.position.set(s.width/2,s.height/2,0),r.batcher.setBlendMode(0,!0),t){if(this.fadeOut+=this.timeKeeper.delta*(this.timeKeeper.totalTime<1?2:1),this.fadeOut>_i)return;i.setFromColor(this.backgroundColor),e=1-this.fadeOut/_i,e=1-(e-1)*(e-1),i.a*=e,i.a>0&&(r.camera.zoom=1,r.begin(),r.quad(!0,0,0,s.width,0,s.width,s.height,0,s.height,i,i,i,i),r.end())}else this.fadeIn+=this.timeKeeper.delta,this.backgroundColor.a>0&&(h.clearColor(this.backgroundColor.r,this.backgroundColor.g,this.backgroundColor.b,this.backgroundColor.a),h.clear(h.COLOR_BUFFER_BIT)),e=1;e*=Math.min(this.fadeIn/Mn,1),i.set(e,e,e,e),this.logo||(this.logo=new ze(r.context,qe),this.spinner=new ze(r.context,Qe)),r.camera.zoom=Math.max(1,Ee/s.height),r.begin(),r.drawTexture(this.logo,(s.width-It)/2,(s.height-Mt)/2,It,Mt,i),this.spinner&&r.drawTextureRotated(this.spinner,(s.width-Ee)/2,(s.height-Ee)/2,Ee,Ee,Ee/2,Ee/2,this.angle,i),r.end()}drawInCoordinates(t,e){if(qi<2)return;this.timeKeeper.update();let i=this.renderer;i.batcher.setBlendMode(0,!0),this.logo||(this.logo=new ze(i.context,qe),this.spinner=new ze(i.context,Qe));const r=t-It/2,s=e-Mt/2;i.drawTexture(this.logo,r,s,It,Mt),this.angle-=this.timeKeeper.delta*500,this.spinner&&i.drawTextureRotated(this.spinner,r,s-25,Ee,Ee,Ee/2,Ee/2,this.angle)}},Rn="data:image/png;base64,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",kn="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAKUAAABsCAYAAAALzHKmAAAQ7klEQVR42u3da4xdVRUA4D0zd2Y6nZY59DVtZ1puS9+lzC0YAi2UQ8AAQczFpPgA9VIeIQbirRqJ0cBUBVGjDr/QCKSNRSMmpuODxAdxqhgwxkhFjf6Sxh/+UUNVNGJCzR7uTvas7LXX2q9zzp3em6y0gTN3Zu75utZe5+yztxC9V+/Ve5X9En1Vjd7J6SFbLNF7naPw+l2jh7YHMBWssqMHtlsRdim4qsLtIawaPiHEQOLoNrA9iIkQDnRrVA1qD2LZ8ISoxYqKo13sQAtBWBayQWZUAXGRQM9JjCngDVY0UqJNDbQrMcaGmArdUKpIjbYiQLsCZCyIMQBy8QwnilR4Q5AuCpxFYvRFmBLbEiwKwpsSaWycVQGZBKMrwBjA9BhxDe57u2L2hOoKNCbOrgAZitEVYUxoKSMErQvSxYIzCkguRg5EF4AUhqUlhy/YUKSxcRaKsioYOQhD4I0yYxkR3PcJBcuFysmgsXAWBTMJyBCMIQh9kGGxXIXvexCQXbHGAMrBWTbM2CCpMSMLIxehC77lSJwXGth7M0FzoVJIXXDWQnGmhOkL0ic7YhhtWdGGkAuPAjUWGoF4faCmwBkbZmyUqUCyMqMLRA4+E6IsdTjidUHKBYrh9CnpRcH0ypKxsyOGEYNIIeTCOz91OIJ1QYoB5eAMyZo+MFNnyVTZ0YiRC9EGEMOyAgshxErHsL2XK1gOUgwohtM1a5YNM7Rsu4K0ZkcbRm4mpPBRwFZ5hg9eCqkrUB+csWGGogzNkqEgrdnRhpGLkINudaLgwvVB6oqzCjCTZElb2Y4B0gUjBtEG0ARnDRLjjoG9DwcshtQGlIPTljVjwUySLWNkyRCQVHa0ZUUTRAwgF91a33BEy0VKAcVwwqwZC2bqbOlUurllOxQkJzNyINoAYqjWhYYjWg5SCiiG05Q1U8FMjTIoS8YE6YORi1BHtJ4KIcQEEtTXUWAxpK44YVlPBdO1jCdFWTZIE8bVGEYMIRPcZGBw4HKQcoBiOE1ZMzbMgVQwU6JMAdKEEcuIJogUvg1YCCE2gsCO42DlIIVAKZwpYJaSLVNnSU6XjYHUmxhTmXaFaMO3EYkLqMC+FsLlIoVAKZzMrEnBhJeLfLNlKMrYWRIDCbOkFSSVHbHM6AKRC6/ODUewNqQ+OLlZkxpjUmV8MBbMUJSxyzY3Q1IgTRgxiBRCHdem0KDAUkBh9sRwwjEnAXMMgTnKhFlUtiwkS5rGka4g9SaGgxFmRC7AzTCEEBcyA36dDSsXqAtOLkysjGMwY5XxVChjZ0kuSCo7YlkRQsQQYtDEFsegsLoCxUp7Kpgps2UslFGzJGccSYHUmxhOZqwzEZqAbfUMCisHKIZzgsCpl3MTzMwTpi1bYp2477gyFKUxS7qWbdjY2EBS2dGE0QQRA7gNCyHEdhjE8RhUDlBT9tzgmjWZMFNlSy+Urk1OzCyJlW0XkK4YOQh1cDtcgwBrQmoDWkdgboBZE8mYsJSHlnFbJ+5bwmOPJ7lZkirbC8aRsMvmgtTHjBhGE0QbwJ2egUE1ITVlUC5OmDVdYNrKuN70xM6WoShjlW4464dbtiFIWK6x7GjESEHUUe0iYncnbMdQSE0Z1ITTNOb0hRmjjLtmS9dmJ2rp1jtuKktyyrb6YLEMCUHq2dGG0QQRQ7f72kzc+cJecerne8Wvv7JNPHPvenEkz8Sh3UtFc92QyGt9Yko/HgOLAIUZlItTz5ouMF3KuE+2jFLCQ1D6lm6fLMkBacuOJowYRBUXyfjuHjF3NhdnsfjvAfH6E9vFt9XxKgikEKgJZyyYalzOLeMu2bLbULI6bh+QGwmQ+rgRlumdGEQAao+K56bEL2woVUwOiev0r8OAUjiJrMmFCbvykGxZRAmPitK1dHM7bohyMsuyi/I8f0+e57fJYIKEZXpXo9E4mOf5XTKyLLvCBLETF8uY2SKepkC+dpX4T02Ivepr4HvZcOZ5fmee54fyPL+DmTUhzAs6n4n8bN5dr9f3YdkSg8nsxG0lPBVKVpNjG0/aGhzfLDmRZdnumZmZp8+c+cdZPV555fSr7Xb7s0jJ3i5Pcue4MxKkPPkvvXTqz/B92u32l0wYOzG1fkhcd/py8Rcbyq/vFM/KY1WA95h/3zzP71bfU6JsNpsfgj+P/FlbrdaDGExYyuXvLz8H+DudODH700ajcSM3W6Yu4alQ1spCOTd38jcKocTZbh9+9NixY99XJ8AEUkcpo9W64yH197m5k7+bnZ19QT+J09NHntQhwji/Jg58qi6++ofLxJ8gSFneVw2Ka4QQDfh1Ok4dZavVmtZ/nrm5k7/Vf55O1tRhboUw5+ZOvqyOl5+R/FyOHj32PYVU/tloNG5IXcKrhJIzngwp3fNjomazea/64BuNxts646f50lWv169utw9/DmtqdJQyZFaSJVuV6nq9fqMEof5/vV6/CYBqgJDlee+yAbF/+4i4ZWqZeNfaIfHWzn+Hx0KcEuU9+s8jv3ej0bhVlXOZydX/k0iRMeb8P0D5e6tj8zy/Xb9UJIc56h/yqVOnXul8lmuZ2bJslKmbHG7XrbpCmCXFRLvdfqQD6jTS3Jiy5I4OykM6ADV+1Eu1DmV6evopBORexzDi1L+X/HnGxsb2w3Hm9PSRJ9QxWPOTZdmlKht2hi+w6dkox5bqffI8fye3hDteGqKaHVsHXihKl0tB+h0cY+lute54AGRKDCW89LNTRynHb7ChUWVVjetOnJh9EYBUyPZeNCoOtsbFQwdXi4/esELcd+tq8cCHJ8UXp+viy9efLz7AgamjlKXc1AA1m83DoIRDlFubzeb96hhZLVTlgJ24gttutx+ONa50bHZKRenaeTs1OfpAfnr6yOOdE7EZdNwmlKocntXLNkA5JTGq47Ds+Lf94lWsyfnXleLfnIwJUN4DOnNYwuUxh2A3Ln9XULrfK8t3J27Tu3BVwiOjXJqoAy8UZej1yclGo3GTLN+gu3w+z/P3YaWbQqk3Ne12e4ZC+c8rxWsYytcPiP9RpZxCqWDKnxOiBNlyAUpOnGsoh4tA2Rm8X9xqtT6md5wyZmYe+0YRKL+1S/wYQ3n8zctBl5SBUv5djivfjMOPduIzcizeiYfr9foVvUwZG+XCuzibZKnSceZ5/v4QlKp8y7ElhnJlTeTP7BI/kllRYfzrfvHqFy4UX1vaL/aVlSmROzwbwdS29T2UcEwZF+V8ozM2lu1VY812u/15akypGh3TmFJesJbHHD167IdUxz3YJy5bNySuX1mbvy55CbMLtzU6tjGlsdFptVqfUMc0Go23F4wy1l2dSnbfvpMwVPe9WWVLDsrOJaF9MFu2Wq1PqmNkGce67xiXhTjdNwdlvV6/BgxfbPfBfVCetxi6b9/rlCup65QzM48dl2OjLMv26CibzeZ96sTIzEFdpwQXz9U1yrtVlpR/Zll2Fec65Y6l4pbbx8XHH9kknvzJlPjlHy8Tp29eKT5ou0aJoIT3w3dBlLDzVpfAJEZ1XOdaJZxnOSlvPMjPzxFljIvng914RwebsjYO7uhMyHu46sOfnf3Oz2TXDW6vvYxdFoIXz3Wc8J5zs9n8iOn2IrxTc2BM3Glqdp7dI553uaOjxrhwcob+MyuUpjs6WZZdon8OcigjPx8V+u+GTWFTSWEx3WYcdJ225jNDSE4q0GHCzlueHOyujn6bUWYgeb9ZZUaQPe+GzQ+Gc8+oOGhC+c1d4gfI16n3XDAhQ7+9qE9l01E2Go132GYKyXE1NiFDTcpoNpv3LOYJGWXNErJNW9sEp63p2RKiVPMn1bS1DgxsyhoGdGpmizj+xtXiDYnx7/vFmce3iWdW1cTVGEY4hQ2ZW0nNq8Qm/M6XbXm3S100lwGedFybuvNOibLI+ZS2ceU4eAxiEuvCkfmU8ycToDxETe6FgCBQHeqyAbFvfEhcO7BwDuXFCEbTZF840XeHK0jYcbs2OIGle0mVJ/mmnClEPQqxyTY5I8/zFhif7fSZee4bnrPOU4AssnRXHaVTCTd14dRDY3UbTIiSeFhsN/aMjgnqthFx880rxX3yATL5p3y4LPXzOaBkUyBjZMlYpbtQlIOBD475ZEusjMNSvkXe6VEoJVDkeZ2dzIfIFsRzU+JF2OyM9M9fTC/6SUYOyFQPjQ2nWiUjxnPfw5EeHqMWIqAeIFsAU847lJM2JM6xsewt1OIDLs99P7ZFHNdB/upS8XtPiD7PfLuCXJNolYyyFiNI/Zit65ItrOVafFbHcFohY7hPTN21Tjz4uc3iqfsnxKdX1MTl1OoYRFaMsToGB6Trw2JFP/OdZC2hJZ7ZkrMoAbbSGmelDJ91hFKuJeS7jlBMkJnrAqqJlgMUZS/dArPlGHNdSg5M3xXXtvquuEatvIYtDRhpxbUJuIgqsU5lGWtUploK0KuEU9mSW8YpmFQ556xNuYW7NiW13B+FkMiKHIy+C6eGgBxJvMR0oSv5hi6+z4HJyZoU0M2RVvDlrOQbcxVfX5AhZbuqy0v7ZstYMLHlAVlLTF9ALLbvu9Y5Zylpn/XOsd0ibIvxr2KCLHpp6SCUIdnSZSF+WzfOhem6GD+1KwR3Z4jNjrtDpNoZwmWd8yrupZN6Hx3fbMmFSe0Swdq2ZIPjxk1112Duo8OBGLrBkw/IoncdK2XHsdC9dHz204m50xh3tzFq1zFqtzHXrfCw7OgDsqyNnZLszVijsmXgrmNcmGtS78lIoMX2aJz03fKO2sDJddPQSCDPiQ1DfWBycY6XtXstc2PQKuxgG2McmXTPb9/9vmuJYXKyJrWjbeg+3xPM4O73nWqvbyw7xgZZSJbEUBa157cNJjdr2vb+5iA1YV3HxYscj30PDCEHIgcjtfm8K8hSsmRotkwFk5s1TTghUAopB6xrjHMBBkI0YYTZ0dZlxwLpkiWDULpmy5gwqayZgZNkA7oKQQCxctByYg0XIIEQQuRitGVHblMTA2ShKGPDpC6wu+DEgJqg2rDGDBtAF4Q6RAojp1xXGmSMbImVcR+YWNY04eQCtUG1ofUJ2/uvcETIgUhhdAE5GAlkKShjwHTNmhhODKgJqQ2sC14uOgyfD0IbRF+MlQaZAiZWyn2yJsTJATqGnHQO2Jhh+xlsACFCG0QbRtdyzQFZCZSxYPpmTS7Q5cjJHYNBYIkZpu99HoUQ/o4QIYSIZUZfjJ4ZMjZI32wZBDMU5yhy8pZTULl4XYP5fagMyEVoy4oupTpGduwnkloSlKEwY+AcQU4MhRTD6ovXBRwFzwWgCSEF0QVjJUGmgEllTS5OLlCIlIN1mS9mx/cZ5eLDALpCTI2RAhkTZQqYoTgpoCPECbaBHQ2ETL3PUl98ECAXYijG0OyYAmQoTG7W5ODkAF1CnVgm2JQx4okPA+gCMTbGskBGgRmaOblAh5GTORIrfKFx4VH4EIAxIXIxlg2SBbMvECY3e7oApbDaIgQu5/2HmeEKEINYiwSRi7EQkLFgumZOCuggctKGI4ULZN/vMeSLj0AYMytWEqMLzFg4fYDaoKaC6wvOFR4FkIPQFaILxrJAOsHsc/zlfYDWXE8qF22s8Pz5KHxcgEVALBtjJXBSSEOwFhk1Zgy4hitCT4hVw+gFs8/zwxqIBbUgyK7fcyA0PD9XX4iVxhiC0xdof6STWCsoBmKF7+cVCWFXQYyBMxRpf+STX1b0x45AhN0OMSrOGEirhrY/dfQAdjvS7oy+WCF6r1RIFxXWvlTRg1YVqFWBmxZbD99ig9pt0YPQw9rD1nstVri9V+/Ve3XrS/wfim4P5fIFxLoAAAAASUVORK5CYII=",Yn=class{constructor(t,e){this.config=e,e.pathPrefix||(e.pathPrefix=""),e.app||(e.app={loadAssets:()=>{},initialize:()=>{},update:()=>{},render:()=>{},error:()=>{},dispose:()=>{}}),e.webglConfig||(e.webglConfig={alpha:!0}),this.htmlCanvas=t,this.context=new xe(t,e.webglConfig),this.renderer=new zi(t,this.context),this.gl=this.context.gl,this.assetManager=new Fs(this.context,e.pathPrefix),this.input=new Di(t),e.app.loadAssets&&e.app.loadAssets(this);let i=()=>{this.disposed||(requestAnimationFrame(i),this.time.update(),e.app.update&&e.app.update(this,this.time.delta),e.app.render&&e.app.render(this))},r=()=>{if(!this.disposed){if(this.assetManager.isLoadingComplete()){this.assetManager.hasErrors()?e.app.error&&e.app.error(this,this.assetManager.getErrors()):(e.app.initialize&&e.app.initialize(this),i());return}requestAnimationFrame(r)}};requestAnimationFrame(r)}context;time=new Ot;htmlCanvas;gl;renderer;assetManager;input;disposed=!1;clear(t,e,i,r){this.gl.clearColor(t,e,i,r),this.gl.clear(this.gl.COLOR_BUFFER_BIT)}dispose(){this.config.app.dispose&&this.config.app.dispose(this),this.disposed=!0}},Ve=Phaser.GameObjects.Components,zs=Ve.ComputedSize,qs=Ve.Depth,_s=Ve.Flip,Hs=Ve.ScrollFactor,js=Ve.Transform,Zs=Ve.Visible,Js=Ve.Origin,Ks=Ve.Alpha;function Be(...t){return e=>(Phaser.Class.mixin(e,t),e)}var Qs=Be(zs),$s=Be(qs),er=Be(_s),tr=Be(Hs),ir=Be(js),sr=Be(Zs),rr=Be(Js),nr=Be(Ks),Fn=class extends Phaser.GameObjects.GameObject{constructor(t,e){super(t,e)}},Pn=class{constructor(t,e,i,r){this.x=t,this.y=e,this.width=i,this.height=r}calculateBounds(){return{x:this.x,y:this.y,width:this.width,height:this.height}}},ar=class{constructor(t=!1){this.clipping=t}calculateBounds(t){if(!t.skeleton)return{x:0,y:0,width:0,height:0};const e=new Je(t.skeleton.data);e.setToSetupPose(),e.updateWorldTransform(2);const i=e.getBoundsRect(this.clipping?new yt:void 0);return i.width==Number.NEGATIVE_INFINITY?{x:0,y:0,width:0,height:0}:i}},Ln=class{constructor(t,e=[],i=.05,r=!1){this.animation=t,this.skins=e,this.timeStep=i,this.clipping=r}calculateBounds(t){if(!t.skeleton||!t.animationState)return{x:0,y:0,width:0,height:0};const e=new gi(t.animationState.data),i=new Je(t.skeleton.data),r=this.clipping?new yt:void 0,s=i.data;if(this.skins.length>0){let l=new at("custom-skin");for(const n of this.skins){const a=s.findSkin(n);a!=null&&l.addSkin(a)}i.setSkin(l)}i.setToSetupPose();const h=this.animation!=null?s.findAnimation(this.animation):null;if(h==null){i.updateWorldTransform(2);const l=i.getBoundsRect(r);return l.width==Number.NEGATIVE_INFINITY?{x:0,y:0,width:0,height:0}:l}else{let l=Number.POSITIVE_INFINITY,n=Number.POSITIVE_INFINITY,a=Number.NEGATIVE_INFINITY,o=Number.NEGATIVE_INFINITY;e.clearTracks(),e.setAnimationWith(0,h,!1);const c=Math.max(h.duration/this.timeStep,1);for(let u=0;u<c;u++){const m=u>0?this.timeStep:0;e.update(m),e.apply(i),i.update(m),i.updateWorldTransform(2);const f=i.getBoundsRect(r);l=Math.min(l,f.x),n=Math.min(n,f.y),a=Math.max(a,f.x+f.width),o=Math.max(o,f.y+f.height)}const d={x:l,y:n,width:a-l,height:o-n};return d.width==Number.NEGATIVE_INFINITY?{x:0,y:0,width:0,height:0}:d}}},Hi=class extends $s(rr(Qs(er(tr(ir(sr(nr(Fn)))))))){constructor(t,e,i,r,s,h,l=new ar){super(t,window.SPINE_GAME_OBJECT_TYPE?window.SPINE_GAME_OBJECT_TYPE:Xt),this.plugin=e,this.boundsProvider=l,this.setPosition(i,r),this.premultipliedAlpha=this.plugin.isAtlasPremultiplied(h),this.skeleton=this.plugin.createSkeleton(s,h),this.animationStateData=new gs(this.skeleton.data),this.animationState=new gi(this.animationStateData),this.skeleton.updateWorldTransform(2),this.updateSize()}blendMode=-1;skeleton;animationStateData;animationState;beforeUpdateWorldTransforms=()=>{};afterUpdateWorldTransforms=()=>{};premultipliedAlpha=!1;offsetX=0;offsetY=0;updateSize(){if(!this.skeleton)return;let t=this.boundsProvider.calculateBounds(this);this.width=t.width,this.height=t.height,this.setDisplayOrigin(-t.x,-t.y),this.offsetX=-t.x,this.offsetY=-t.y}skeletonToPhaserWorldCoordinates(t){let e=this.getWorldTransformMatrix(),i=e.a,r=e.b,s=e.c,h=e.d,l=e.tx,n=e.ty,a=t.x,o=t.y;t.x=a*i+o*s+l,t.y=a*r+o*h+n}phaserWorldCoordinatesToSkeleton(t){let e=this.getWorldTransformMatrix();e=e.invert();let i=e.a,r=e.b,s=e.c,h=e.d,l=e.tx,n=e.ty,a=t.x,o=t.y;t.x=a*i+o*s+l,t.y=a*r+o*h+n}phaserWorldCoordinatesToBone(t,e){this.phaserWorldCoordinatesToSkeleton(t),e.parent?e.parent.worldToLocal(t):e.worldToLocal(t)}updatePose(t){this.animationState.update(t/1e3),this.animationState.apply(this.skeleton),this.beforeUpdateWorldTransforms(this),this.skeleton.update(t/1e3),this.skeleton.updateWorldTransform(2),this.afterUpdateWorldTransforms(this)}preUpdate(t,e){!this.skeleton||!this.animationState||this.updatePose(e)}preDestroy(){}willRender(t){var e=15,i=!this.skeleton||!(e!==this.renderFlags||this.cameraFilter!==0&&this.cameraFilter&t.id);if(this.visible||(i=!1),!i&&this.parentContainer&&this.plugin.webGLRenderer){var r=this.plugin.webGLRenderer;this.plugin.gl&&this.plugin.phaserRenderer instanceof Phaser.Renderer.WebGL.WebGLRenderer&&r.batcher.isDrawing&&(r.end(),this.plugin.phaserRenderer.pipelines.rebind())}return i}renderWebGL(t,e,i,r){if(!this.skeleton||!this.animationState||!this.plugin.webGLRenderer)return;let s=this.plugin.webGLRenderer;t.newType&&(t.pipelines.clear(),s.begin()),i.addToRenderList(e);let h=Phaser.GameObjects.GetCalcMatrix(e,i,r).calc,l=h.a,n=h.b,a=h.c,o=h.d,c=h.tx,d=h.ty,u=e.offsetX-e.displayOriginX,m=e.offsetY-e.displayOriginY;s.drawSkeleton(e.skeleton,e.premultipliedAlpha,-1,-1,(f,g,x)=>{for(let b=0;b<g;b+=x){let p=f[b]+u,w=f[b+1]+m;f[b]=p*l+w*a+c,f[b+1]=p*n+w*o+d}}),t.nextTypeMatch||(s.end(),t.pipelines.rebind())}renderCanvas(t,e,i,r){if(!this.skeleton||!this.animationState||!this.plugin.canvasRenderer)return;let s=t.currentContext,h=this.plugin.canvasRenderer;h.ctx=s,i.addToRenderList(e);let l=Phaser.GameObjects.GetCalcMatrix(e,i,r).calc,n=this.skeleton;n.x=l.tx,n.y=l.ty,n.scaleX=l.scaleX,n.scaleY=l.scaleY;let a=n.getRootBone();a.rotation=-L.radiansToDegrees*l.rotationNormalized,this.skeleton.updateWorldTransform(2),s.save(),h.draw(n),s.restore()}},Xn=class extends xt{constructor(t){super(t)}setFilters(t,e){}setWraps(t,e){}dispose(){}},Bn=X.newFloatArray(8),On=class Lt{static QUAD_TRIANGLES=[0,1,2,2,3,0];static VERTEX_SIZE=8;ctx;triangleRendering=!1;debugRendering=!1;vertices=X.newFloatArray(8*1024);tempColor=new K;constructor(e){this.ctx=e}draw(e){this.triangleRendering?this.drawTriangles(e):this.drawImages(e)}drawImages(e){let i=this.ctx,r=this.tempColor,s=e.color,h=e.drawOrder;this.debugRendering&&(i.strokeStyle="green");for(let l=0,n=h.length;l<n;l++){let a=h[l],o=a.bone;if(!o.active)continue;let c=a.getAttachment();if(!(c instanceof ce))continue;c.computeWorldVertices(a,Bn,0,2);let d=c.region,u=d.texture.getImage(),m=a.color,f=c.color;r.set(s.r*m.r*f.r,s.g*m.g*f.g,s.b*m.b*f.b,s.a*m.a*f.a),i.save(),i.transform(o.a,o.c,o.b,o.d,o.worldX,o.worldY),i.translate(c.offset[0],c.offset[1]),i.rotate(c.rotation*Math.PI/180);let g=c.width/d.originalWidth;i.scale(g*c.scaleX,g*c.scaleY);let x=d.width,b=d.height;if(i.translate(x/2,b/2),c.region.degrees==90){let p=x;x=b,b=p,i.rotate(-Math.PI/2)}i.scale(1,-1),i.translate(-x/2,-b/2),i.globalAlpha=r.a,i.drawImage(u,u.width*d.u,u.height*d.v,x,b,0,0,x,b),this.debugRendering&&i.strokeRect(0,0,x,b),i.restore()}}drawTriangles(e){let i=this.ctx,r=this.tempColor,s=e.color,h=e.drawOrder,l=null,n=this.vertices,a=null;for(let c=0,d=h.length;c<d;c++){let u=h[c],m=u.getAttachment(),f,g;if(m instanceof ce){let x=m;n=this.computeRegionVertices(u,x,!1),a=Lt.QUAD_TRIANGLES,f=x.region.texture.getImage()}else if(m instanceof Ge){let x=m;n=this.computeMeshVertices(u,x,!1),a=x.triangles,f=x.region.texture.getImage()}else continue;if(f){u.data.blendMode!=l&&(l=u.data.blendMode);let x=u.color,b=m.color;r.set(s.r*x.r*b.r,s.g*x.g*b.g,s.b*x.b*b.b,s.a*x.a*b.a),i.globalAlpha=r.a;for(var o=0;o<a.length;o+=3){let p=a[o]*8,w=a[o+1]*8,v=a[o+2]*8,y=n[p],A=n[p+1],C=n[p+6],S=n[p+7],I=n[w],k=n[w+1],Y=n[w+6],F=n[w+7],P=n[v],M=n[v+1],R=n[v+6],B=n[v+7];this.drawTriangle(f,y,A,C,S,I,k,Y,F,P,M,R,B),this.debugRendering&&(i.strokeStyle="green",i.beginPath(),i.moveTo(y,A),i.lineTo(I,k),i.lineTo(P,M),i.lineTo(y,A),i.stroke())}}}this.ctx.globalAlpha=1}drawTriangle(e,i,r,s,h,l,n,a,o,c,d,u,m){let f=this.ctx;const g=e.width-1,x=e.height-1;s*=g,h*=x,a*=g,o*=x,u*=g,m*=x,f.beginPath(),f.moveTo(i,r),f.lineTo(l,n),f.lineTo(c,d),f.closePath(),l-=i,n-=r,c-=i,d-=r,a-=s,o-=h,u-=s,m-=h;let b=a*m-u*o;if(b==0)return;b=1/b;const p=(m*l-o*c)*b,w=(m*n-o*d)*b,v=(a*c-u*l)*b,y=(a*d-u*n)*b,A=i-p*s-v*h,C=r-w*s-y*h;f.save(),f.transform(p,w,v,y,A,C),f.clip(),f.drawImage(e,0,0),f.restore()}computeRegionVertices(e,i,r){let s=e.bone.skeleton.color,h=e.color,l=i.color,n=s.a*h.a*l.a,a=r?n:1,o=this.tempColor;o.set(s.r*h.r*l.r*a,s.g*h.g*l.g*a,s.b*h.b*l.b*a,n),i.computeWorldVertices(e,this.vertices,0,Lt.VERTEX_SIZE);let c=this.vertices,d=i.uvs;return c[ce.C1R]=o.r,c[ce.C1G]=o.g,c[ce.C1B]=o.b,c[ce.C1A]=o.a,c[ce.U1]=d[0],c[ce.V1]=d[1],c[ce.C2R]=o.r,c[ce.C2G]=o.g,c[ce.C2B]=o.b,c[ce.C2A]=o.a,c[ce.U2]=d[2],c[ce.V2]=d[3],c[ce.C3R]=o.r,c[ce.C3G]=o.g,c[ce.C3B]=o.b,c[ce.C3A]=o.a,c[ce.U3]=d[4],c[ce.V3]=d[5],c[ce.C4R]=o.r,c[ce.C4G]=o.g,c[ce.C4B]=o.b,c[ce.C4A]=o.a,c[ce.U4]=d[6],c[ce.V4]=d[7],c}computeMeshVertices(e,i,r){let s=e.bone.skeleton.color,h=e.color,l=i.color,n=s.a*h.a*l.a,a=r?n:1,o=this.tempColor;o.set(s.r*h.r*l.r*a,s.g*h.g*l.g*a,s.b*h.b*l.b*a,n);let c=i.worldVerticesLength/2,d=this.vertices;d.length<i.worldVerticesLength&&(this.vertices=d=X.newFloatArray(i.worldVerticesLength)),i.computeWorldVertices(e,0,i.worldVerticesLength,d,0,Lt.VERTEX_SIZE);let u=i.uvs;for(let m=0,f=0,g=2;m<c;m++)d[g++]=o.r,d[g++]=o.g,d[g++]=o.b,d[g++]=o.a,d[g++]=u[f++],d[g++]=u[f++],g+=2;return d}},ji=class ct extends ye.Plugins.ScenePlugin{game;isWebGL;gl;static gameWebGLRenderer=null;get webGLRenderer(){return ct.gameWebGLRenderer}canvasRenderer;phaserRenderer;skeletonDataCache;atlasCache;constructor(e,i,r){super(e,i,r),this.game=i.game,this.isWebGL=this.game.config.renderType===2,this.gl=this.isWebGL?this.game.renderer.gl:null,this.phaserRenderer=this.game.renderer,this.canvasRenderer=null,this.skeletonDataCache=this.game.cache.addCustom(Yr),this.atlasCache=this.game.cache.addCustom(Fr);let s=function(o,c,d){let u=new lr(this,o,c,0,d);return this.addFile(u.files),this};i.registerFileType("spineJson",s,e);let h=function(o,c,d){let u=new lr(this,o,c,1,d);return this.addFile(u.files),this};i.registerFileType("spineBinary",h,e);let l=function(o,c,d,u){let m=new Vn(this,o,c,d,u);return this.addFile(m.files),this};i.registerFileType("spineAtlas",l,e);let n=function(o,c,d,u,m){this.scene.sys.renderer instanceof ye.Renderer.WebGL.WebGLRenderer&&this.scene.sys.renderer.pipelines.clear();const f=this.scene.sys[r];let g=new Hi(this.scene,f,o,c,d,u,m);return this.displayList.add(g),this.updateList.add(g),this.scene.sys.renderer instanceof ye.Renderer.WebGL.WebGLRenderer&&this.scene.sys.renderer.pipelines.rebind(),g},a=function(o,c=!1){this.scene.sys.renderer instanceof ye.Renderer.WebGL.WebGLRenderer&&this.scene.sys.renderer.pipelines.clear();let d=o.x?o.x:0,u=o.y?o.y:0,m=o.boundsProvider?o.boundsProvider:void 0;const f=this.scene.sys[r];let g=new Hi(this.scene,f,d,u,o.dataKey,o.atlasKey,m);return c!==void 0&&(o.add=c),this.scene.sys.renderer instanceof ye.Renderer.WebGL.WebGLRenderer&&this.scene.sys.renderer.pipelines.rebind(),ye.GameObjects.BuildGameObject(this.scene,g,o)};i.registerGameObject(window.SPINE_GAME_OBJECT_TYPE?window.SPINE_GAME_OBJECT_TYPE:Xt,n,a)}static rendererId=0;boot(){Je.yDown=!0,this.isWebGL?(ct.gameWebGLRenderer||(ct.gameWebGLRenderer=new zi(this.game.renderer.canvas,this.gl,!0)),this.onResize(),this.game.scale.on(ye.Scale.Events.RESIZE,this.onResize,this)):this.canvasRenderer||(this.canvasRenderer=new On(this.scene.sys.context));var e=this.systems.events;e.once("shutdown",this.shutdown,this),e.once("destroy",this.destroy,this),this.game.events.once("destroy",this.gameDestroy,this)}onResize(){var e=this.game.renderer,i=this.webGLRenderer;if(e&&i){var r=e.width,s=e.height;i.camera.position.x=r/2,i.camera.position.y=s/2,i.camera.up.y=-1,i.camera.direction.z=1,i.camera.setViewport(r,s)}}shutdown(){this.systems.events.off("shutdown",this.shutdown,this),this.isWebGL&&this.game.scale.off(ye.Scale.Events.RESIZE,this.onResize,this)}destroy(){this.shutdown()}gameDestroy(){this.pluginManager.removeGameObject(window.SPINE_GAME_OBJECT_TYPE?window.SPINE_GAME_OBJECT_TYPE:Xt,!0,!0),this.webGLRenderer&&this.webGLRenderer.dispose(),ct.gameWebGLRenderer=null}getAtlas(e){let i;if(this.atlasCache.exists(e))i=this.atlasCache.get(e);else{let r=this.game.cache.text.get(e);if(i=new bt(r.data),this.isWebGL){let s=this.gl;const h=s.getParameter(s.UNPACK_PREMULTIPLY_ALPHA_WEBGL);h&&s.pixelStorei(s.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1);for(let l of i.pages)l.setTexture(new ze(s,this.game.textures.get(e+"!"+l.name).getSourceImage(),!1));h&&s.pixelStorei(s.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!0)}else for(let s of i.pages)s.setTexture(new Xn(this.game.textures.get(e+"!"+s.name).getSourceImage()));this.atlasCache.add(e,i)}return i}isAtlasPremultiplied(e){let i=this.game.cache.text.get(e);return i?i.premultipliedAlpha:!1}getSkeletonData(e,i){const r=this.getAtlas(i),s=e+i;let h;if(this.skeletonDataCache.exists(s))h=this.skeletonDataCache.get(s);else{if(this.game.cache.json.exists(e)){let l=this.game.cache.json.get(e);h=new Ys(new yi(r)).readSkeletonData(l)}else{let l=this.game.cache.binary.get(e);h=new Ms(new yi(r)).readSkeletonData(new Uint8Array(l))}this.skeletonDataCache.add(s,h)}return h}createSkeleton(e,i){return new Je(this.getSkeletonData(e,i))}},lr=class extends ye.Loader.MultiFile{constructor(t,e,i,r,s){if(typeof e!="string"){const n=e;e=n.key,i=n.url,r=n.type==="spineJson"?0:1,s=n.xhrSettings}let h=null;r==0?h=new ye.Loader.FileTypes.JSONFile(t,{key:e,url:i,extension:"json",xhrSettings:s}):h=new ye.Loader.FileTypes.BinaryFile(t,{key:e,url:i,extension:"skel",xhrSettings:s}),super(t,Pr,e,[h]),this.fileType=r}onFileComplete(t){this.pending--}addToCache(){this.isReadyToProcess()&&this.files[0].addToCache()}},Vn=class extends ye.Loader.MultiFile{constructor(t,e,i,r,s){if(typeof e!="string"){const h=e;e=h.key,i=h.url,r=h.premultipliedAlpha,s=h.xhrSettings}super(t,Lr,e,[new ye.Loader.FileTypes.TextFile(t,{key:e,url:i,xhrSettings:s,extension:"atlas"})]),this.premultipliedAlpha=r}onFileComplete(t){if(this.files.indexOf(t)!=-1&&(this.pending--,t.type=="text")){var e=t.data.split(/\r\n|\r|\n/);let a=[];a.push(e[0]);for(var i=1;i<e.length;i++){var r=e[i];r.trim()===""&&i<e.length-1&&(r=e[i+1],a.push(r))}let o=(t.src.match(/^.*\//)??"").toString();this.loader.path&&this.loader.path.length>0&&o.startsWith(this.loader.path)&&(o=o.slice(this.loader.path.length));for(var s=0;s<a.length;s++){var h=o+a[s],l=t.key+"!"+a[s],n=new ye.Loader.FileTypes.ImageFile(this.loader,l,h);this.loader.keyExists(n)||(this.addToMultiFile(n),this.loader.addFile(n))}}}addToCache(){if(this.isReadyToProcess()){let t=this.loader.textureManager;for(let e of this.files)e.type=="image"?t.exists(e.key)||t.addImage(e.key,e.data):(this.premultipliedAlpha=this.premultipliedAlpha??(e.data.indexOf("pma: true")>=0||e.data.indexOf("pma:true")>=0),e.data={data:e.data,premultipliedAlpha:this.premultipliedAlpha},e.addToCache())}}};return window.spine={SpinePlugin:ji},window["spine.SpinePlugin"]=ji,kr(is)})();