UNPKG

leafer-ui

Version:

一款革新、好用的 Canvas 引擎, 轻松实现专业图形编辑。适用于图形编辑、小游戏、互动应用、组态软件、生成图片与短视频等场景。

1 lines 209 kB
const t={toURL(t,e){let i=encodeURIComponent(t);return"text"===e?i="data:text/plain;charset=utf-8,"+i:"svg"===e&&(i="data:image/svg+xml,"+i),i},image:{hitCanvasSize:100,maxCacheSize:4096e3,maxPatternSize:8847360,crossOrigin:"anonymous",getRealURL(e){const{prefix:i,suffix:s}=t.image;return!s||e.startsWith("data:")||e.startsWith("blob:")||(e+=(e.includes("?")?"&":"?")+s),i&&"/"===e[0]&&(e=i+e),e}}},e={RUNTIME:"runtime",LEAF:"leaf",TASK:"task",CNAVAS:"canvas",IMAGE:"image",types:{},create(t){const{types:e}=i;return e[t]?e[t]++:(e[t]=1,0)}},i=e;var s;!function(t){t[t.No=0]="No",t[t.Yes=1]="Yes",t[t.NoAndSkip=2]="NoAndSkip",t[t.YesAndSkip=3]="YesAndSkip"}(s||(s={}));const r={};function n(t){return void 0===t}function o(t){return null==t}function a(t){return"string"==typeof t}const{isFinite:h}=Number;function l(t){return"number"==typeof t}const d=/^-?\d+(?:\.\d+)?$/;function c(t){return"string"==typeof t&&d.test(t)?+t:t}const{isArray:u}=Array;function _(t){return t&&"object"==typeof t}function p(t){return _(t)&&!u(t)}function g(t){return"{}"===JSON.stringify(t)}const f={default:(t,e)=>(y(e,t),y(t,e),t),assign(t,e,i){let s;Object.keys(e).forEach(r=>{var n,o;if(s=e[r],(null==s?void 0:s.constructor)===Object&&(null===(n=t[r])||void 0===n?void 0:n.constructor)===Object)return y(t[r],e[r],i&&i[r]);i&&r in i?(null===(o=i[r])||void 0===o?void 0:o.constructor)===Object&&y(t[r]={},e[r],i[r]):t[r]=e[r]})},copyAttrs:(t,e,i)=>(i.forEach(i=>{n(e[i])||(t[i]=e[i])}),t),clone:t=>JSON.parse(JSON.stringify(t)),toMap(t){const e={};for(let i=0,s=t.length;i<s;i++)e[t[i]]=!0;return e},stintSet(t,e,i){i||(i=void 0),t[e]!==i&&(t[e]=i)}},{assign:y}=f;class m{get __useNaturalRatio(){return!0}get __isLinePath(){const{path:t}=this;return t&&6===t.length&&1===t[0]}get __usePathBox(){return this.__pathInputed}get __blendMode(){if(this.eraser&&"path"!==this.eraser)return"destination-out";const{blendMode:t}=this;return"pass-through"===t?null:t}constructor(t){this.__leaf=t}__get(t){if(this.__input){const e=this.__input[t];if(!n(e))return e}return this[t]}__getData(){const t={tag:this.__leaf.tag},{__input:e}=this;let i;for(let s in this)"_"!==s[0]&&(i=e?e[s]:void 0,t[s]=n(i)?this[s]:i);return t}__setInput(t,e){this.__input||(this.__input={}),this.__input[t]=e}__getInput(t){if(this.__input){const e=this.__input[t];if(!n(e))return e}if("path"!==t||this.__pathInputed)return this["_"+t]}__removeInput(t){this.__input&&!n(this.__input[t])&&(this.__input[t]=void 0)}__getInputData(t,e){const i={};if(t)if(u(t))for(let e of t)i[e]=this.__getInput(e);else for(let e in t)i[e]=this.__getInput(e);else{let t,e,{__input:s}=this;i.tag=this.__leaf.tag;for(let r in this)if("_"!==r[0]&&(t=this["_"+r],!n(t))){if("path"===r&&!this.__pathInputed)continue;e=s?s[r]:void 0,i[r]=n(e)?t:e}}if(e&&e.matrix){const{a:t,b:e,c:s,d:r,e:n,f:o}=this.__leaf.__localMatrix;i.matrix={a:t,b:e,c:s,d:r,e:n,f:o}}return i}__setMiddle(t,e){this.__middle||(this.__middle={}),this.__middle[t]=e}__getMiddle(t){return this.__middle&&this.__middle[t]}__checkSingle(){const t=this;if("pass-through"===t.blendMode){const e=this.__leaf;t.opacity<1&&(e.isBranch||t.__hasMultiPaint)||e.__hasEraser||t.eraser||t.filter?t.__single=!0:t.__single&&(t.__single=!1)}else t.__single=!0}__removeNaturalSize(){this.__naturalWidth=this.__naturalHeight=void 0}destroy(){this.__input=this.__middle=null}}let v,w,x;const{max:b}=Math,B=[0,0,0,0],k={zero:[...B],tempFour:B,set:(t,e,i,s,r)=>(void 0===i&&(i=s=r=e),t[0]=e,t[1]=i,t[2]=s,t[3]=r,t),setTemp:(t,e,i,s)=>S(B,t,e,i,s),toTempAB(t,e,i){x=i?l(t)?e:t:[],l(t)?(v=R(t),w=e):l(e)?(v=t,w=R(e)):(v=t,w=e),4!==v.length&&(v=P(v)),4!==w.length&&(w=P(w))},get(t,e){let i;if(!l(t))switch(t.length){case 4:i=n(e)?t:[...t];break;case 2:i=[t[0],t[1],t[0],t[1]];break;case 3:i=[t[0],t[1],t[2],t[1]];break;case 1:t=t[0];break;default:t=0}if(i||(i=[t,t,t,t]),!n(e))for(let t=0;t<4;t++)i[t]>e&&(i[t]=e);return i},max:(t,e,i)=>l(t)&&l(e)?b(t,e):(C(t,e,i),S(x,b(v[0],w[0]),b(v[1],w[1]),b(v[2],w[2]),b(v[3],w[3]))),add:(t,e,i)=>l(t)&&l(e)?t+e:(C(t,e,i),S(x,v[0]+w[0],v[1]+w[1],v[2]+w[2],v[3]+w[3])),swapAndScale(t,e,i,s){if(l(t))return e===i?t*e:[t*i,t*e];const r=s?t:[],[n,o,a,h]=4===t.length?t:P(t);return S(r,a*i,h*e,n*i,o*e)}},{set:S,get:P,setTemp:R,toTempAB:C}=k,{round:T,pow:E,PI:L}=Math,O={within:(t,e,i)=>(_(e)&&(i=e.max,e=e.min),!n(e)&&t<e&&(t=e),!n(i)&&t>i&&(t=i),t),fourNumber:k.get,formatRotation:(t,e)=>(t%=360,e?t<0&&(t+=360):(t>180&&(t-=360),t<-180&&(t+=360)),O.float(t)),getGapRotation(t,e,i=0){let s=t+i;if(e>1){const t=Math.abs(s%e);(t<1||t>e-1)&&(s=Math.round(s/e)*e)}return s-i},float(t,e){const i=n(e)?1e12:E(10,e);return-0===(t=T(t*i)/i)?0:t},sign:t=>t<0?-1:1,getScaleData(t,e,i,s){if(s||(s={}),e){const t=(l(e)?e:e.width||0)/i.width,r=(l(e)?e:e.height||0)/i.height;s.scaleX=t||r||1,s.scaleY=r||t||1}else t&&O.assignScale(s,t);return s},assignScale(t,e){l(e)?t.scaleX=t.scaleY=e:(t.scaleX=e.x,t.scaleY=e.y)},randInt:A,randColor:t=>`rgba(${A(255)},${A(255)},${A(255)},${t||1})`};function A(t){return Math.round(Math.random()*t)}const D=L/180,M=2*L,W=L/2;function I(){return{x:0,y:0}}function F(){return{x:0,y:0,width:0,height:0}}function z(){return{a:1,b:0,c:0,d:1,e:0,f:0}}const{sin:N,cos:Y,acos:X,sqrt:H}=Math,{float:U}=O,j={};function V(){return Object.assign(Object.assign(Object.assign({},{a:1,b:0,c:0,d:1,e:0,f:0}),{x:0,y:0,width:0,height:0}),{scaleX:1,scaleY:1,rotation:0,skewX:0,skewY:0})}const G={defaultMatrix:{a:1,b:0,c:0,d:1,e:0,f:0},defaultWorld:V(),tempMatrix:{},set(t,e=1,i=0,s=0,r=1,n=0,o=0){t.a=e,t.b=i,t.c=s,t.d=r,t.e=n,t.f=o},get:z,getWorld:V,copy(t,e){t.a=e.a,t.b=e.b,t.c=e.c,t.d=e.d,t.e=e.e,t.f=e.f},translate(t,e,i){t.e+=e,t.f+=i},translateInner(t,e,i,s){t.e+=t.a*e+t.c*i,t.f+=t.b*e+t.d*i,s&&(t.e-=e,t.f-=i)},scale(t,e,i=e){t.a*=e,t.b*=e,t.c*=i,t.d*=i},pixelScale(t,e,i){i||(i=t),i.a=t.a*e,i.b=t.b*e,i.c=t.c*e,i.d=t.d*e,i.e=t.e*e,i.f=t.f*e},scaleOfOuter(t,e,i,s){K.toInnerPoint(t,e,j),K.scaleOfInner(t,j,i,s)},scaleOfInner(t,e,i,s=i){K.translateInner(t,e.x,e.y),K.scale(t,i,s),K.translateInner(t,-e.x,-e.y)},rotate(t,e){const{a:i,b:s,c:r,d:n}=t,o=Y(e*=D),a=N(e);t.a=i*o-s*a,t.b=i*a+s*o,t.c=r*o-n*a,t.d=r*a+n*o},rotateOfOuter(t,e,i){K.toInnerPoint(t,e,j),K.rotateOfInner(t,j,i)},rotateOfInner(t,e,i){K.translateInner(t,e.x,e.y),K.rotate(t,i),K.translateInner(t,-e.x,-e.y)},skew(t,e,i){const{a:s,b:r,c:n,d:o}=t;i&&(i*=D,t.a=s+n*i,t.b=r+o*i),e&&(e*=D,t.c=n+s*e,t.d=o+r*e)},skewOfOuter(t,e,i,s){K.toInnerPoint(t,e,j),K.skewOfInner(t,j,i,s)},skewOfInner(t,e,i,s=0){K.translateInner(t,e.x,e.y),K.skew(t,i,s),K.translateInner(t,-e.x,-e.y)},multiply(t,e){const{a:i,b:s,c:r,d:n,e:o,f:a}=t;t.a=e.a*i+e.b*r,t.b=e.a*s+e.b*n,t.c=e.c*i+e.d*r,t.d=e.c*s+e.d*n,t.e=e.e*i+e.f*r+o,t.f=e.e*s+e.f*n+a},multiplyParent(t,e,i,s,r){const{e:o,f:a}=t;if(i||(i=t),n(s)&&(s=1!==t.a||t.b||t.c||1!==t.d),s){const{a:s,b:n,c:o,d:a}=t;i.a=s*e.a+n*e.c,i.b=s*e.b+n*e.d,i.c=o*e.a+a*e.c,i.d=o*e.b+a*e.d,r&&(i.scaleX=e.scaleX*r.scaleX,i.scaleY=e.scaleY*r.scaleY)}else i.a=e.a,i.b=e.b,i.c=e.c,i.d=e.d,r&&(i.scaleX=e.scaleX,i.scaleY=e.scaleY);i.e=o*e.a+a*e.c+e.e,i.f=o*e.b+a*e.d+e.f},divide(t,e){K.multiply(t,K.tempInvert(e))},divideParent(t,e){K.multiplyParent(t,K.tempInvert(e))},tempInvert(t){const{tempMatrix:e}=K;return K.copy(e,t),K.invert(e),e},invert(t){const{a:e,b:i,c:s,d:r,e:n,f:o}=t;if(i||s){const a=1/(e*r-i*s);t.a=r*a,t.b=-i*a,t.c=-s*a,t.d=e*a,t.e=-(n*r-o*s)*a,t.f=-(o*e-n*i)*a}else if(1===e&&1===r)t.e=-n,t.f=-o;else{const i=1/(e*r);t.a=r*i,t.d=e*i,t.e=-n*r*i,t.f=-o*e*i}},toOuterPoint(t,e,i,s){const{x:r,y:n}=e;i||(i=e),i.x=r*t.a+n*t.c,i.y=r*t.b+n*t.d,s||(i.x+=t.e,i.y+=t.f)},toInnerPoint(t,e,i,s){const{a:r,b:n,c:o,d:a}=t,h=1/(r*a-n*o),{x:l,y:d}=e;if(i||(i=e),i.x=(l*a-d*o)*h,i.y=(d*r-l*n)*h,!s){const{e:e,f:s}=t;i.x-=(e*a-s*o)*h,i.y-=(s*r-e*n)*h}},setLayout(t,e,i,s,r){const{x:o,y:a,scaleX:h,scaleY:l}=e;if(n(r)&&(r=e.rotation||e.skewX||e.skewY),r){const{rotation:i,skewX:s,skewY:r}=e,n=i*D,o=Y(n),a=N(n);if(s||r){const e=s*D,i=r*D;t.a=(o+i*-a)*h,t.b=(a+i*o)*h,t.c=(e*o-a)*l,t.d=(o+e*a)*l}else t.a=o*h,t.b=a*h,t.c=-a*l,t.d=o*l}else t.a=h,t.b=0,t.c=0,t.d=l;t.e=o,t.f=a,(i=i||s)&&K.translateInner(t,-i.x,-i.y,!s)},getLayout(t,e,i,s){const{a:r,b:n,c:o,d:a,e:h,f:l}=t;let d,c,u,_,p,g=h,f=l;if(n||o){const t=r*a-n*o;if(o&&!s){d=H(r*r+n*n),c=t/d;const e=r/d;u=n>0?X(e):-X(e)}else{c=H(o*o+a*a),d=t/c;const e=o/c;u=W-(a>0?X(-e):-X(e))}const e=U(Y(u)),i=N(u);d=U(d),c=U(c),_=e?U((o/c+i)/e/D,9):0,p=e?U((n/d-i)/e/D,9):0,u=U(u/D)}else d=r,c=a,u=_=p=0;return(e=i||e)&&(g+=e.x*r+e.y*o,f+=e.x*n+e.y*a,i||(g-=e.x,f-=e.y)),{x:g,y:f,scaleX:d,scaleY:c,rotation:u,skewX:_,skewY:p}},withScale(t,e,i=e){const s=t;if(!e||!i){const{a:s,b:r,c:n,d:o}=t;r||n?i=(s*o-r*n)/(e=H(s*s+r*r)):(e=s,i=o)}return s.scaleX=e,s.scaleY=i,s},reset(t){K.set(t)}},K=G,{toInnerPoint:q,toOuterPoint:$}=G,{sin:Q,cos:J,abs:Z,sqrt:tt,atan2:et,min:it,round:st}=Math,rt={defaultPoint:{x:0,y:0},tempPoint:{},tempRadiusPoint:{},set(t,e=0,i=0){t.x=e,t.y=i},setRadius(t,e,i){t.radiusX=e,t.radiusY=n(i)?e:i},copy(t,e){t.x=e.x,t.y=e.y},copyFrom(t,e,i){t.x=e,t.y=i},round(t,e){t.x=e?st(t.x-.5)+.5:st(t.x),t.y=e?st(t.y-.5)+.5:st(t.y)},move(t,e,i){_(e)?(t.x+=e.x,t.y+=e.y):(t.x+=e,t.y+=i)},scale(t,e,i=e){t.x&&(t.x*=e),t.y&&(t.y*=i)},scaleOf(t,e,i,s=i){t.x+=(t.x-e.x)*(i-1),t.y+=(t.y-e.y)*(s-1)},rotate(t,e,i){i||(i=nt.defaultPoint);const s=J(e*=D),r=Q(e),n=t.x-i.x,o=t.y-i.y;t.x=i.x+n*s-o*r,t.y=i.y+n*r+o*s},tempToInnerOf(t,e){const{tempPoint:i}=nt;return at(i,t),q(e,i,i),i},tempToOuterOf(t,e){const{tempPoint:i}=nt;return at(i,t),$(e,i,i),i},tempToInnerRadiusPointOf(t,e){const{tempRadiusPoint:i}=nt;return at(i,t),nt.toInnerRadiusPointOf(t,e,i),i},toInnerRadiusPointOf(t,e,i){i||(i=t),q(e,t,i),i.radiusX=Math.abs(t.radiusX/e.scaleX),i.radiusY=Math.abs(t.radiusY/e.scaleY)},toInnerOf(t,e,i){q(e,t,i)},toOuterOf(t,e,i){$(e,t,i)},getCenter:(t,e)=>({x:t.x+(e.x-t.x)/2,y:t.y+(e.y-t.y)/2}),getCenterX:(t,e)=>t+(e-t)/2,getCenterY:(t,e)=>t+(e-t)/2,getDistance:(t,e)=>ot(t.x,t.y,e.x,e.y),getDistanceFrom(t,e,i,s){const r=Z(i-t),n=Z(s-e);return tt(r*r+n*n)},getMinDistanceFrom:(t,e,i,s,r,n)=>it(ot(t,e,i,s),ot(i,s,r,n)),getAngle:(t,e)=>ht(t,e)/D,getRotation:(t,e,i,s)=>(s||(s=e),nt.getRadianFrom(t.x,t.y,e.x,e.y,i.x,i.y,s.x,s.y)/D),getRadianFrom(t,e,i,s,r,o,a,h){n(a)&&(a=i,h=s);const l=t-i,d=e-s,c=r-a,u=o-h;return Math.atan2(l*u-d*c,l*c+d*u)},getAtan2:(t,e)=>et(e.y-t.y,e.x-t.x),getDistancePoint(t,e,i,s){const r=ht(t,e);return(e=s?e:{}).x=t.x+J(r)*i,e.y=t.y+Q(r)*i,e},toNumberPoints(t){let e=t;return _(t[0])&&(e=[],t.forEach(t=>e.push(t.x,t.y))),e},reset(t){nt.reset(t)}},nt=rt,{getDistanceFrom:ot,copy:at,getAtan2:ht}=nt;class lt{constructor(t,e){this.set(t,e)}set(t,e){return _(t)?rt.copy(this,t):rt.set(this,t,e),this}get(){const{x:t,y:e}=this;return{x:t,y:e}}clone(){return new lt(this)}move(t,e){return rt.move(this,t,e),this}scale(t,e){return rt.scale(this,t,e),this}scaleOf(t,e,i){return rt.scaleOf(this,t,e,i),this}rotate(t,e){return rt.rotate(this,t,e),this}rotateOf(t,e){return rt.rotate(this,e,t),this}getRotation(t,e,i){return rt.getRotation(this,t,e,i)}toInnerOf(t,e){return rt.toInnerOf(this,t,e),this}toOuterOf(t,e){return rt.toOuterOf(this,t,e),this}getCenter(t){return new lt(rt.getCenter(this,t))}getDistance(t){return rt.getDistance(this,t)}getDistancePoint(t,e,i){return new lt(rt.getDistancePoint(this,t,e,i))}getAngle(t){return rt.getAngle(this,t)}getAtan2(t){return rt.getAtan2(this,t)}reset(){return rt.reset(this),this}}const dt=new lt;class ct{constructor(t,e,i,s,r,n){this.set(t,e,i,s,r,n)}set(t,e,i,s,r,n){return _(t)?G.copy(this,t):G.set(this,t,e,i,s,r,n),this}setWith(t){return G.copy(this,t),this.scaleX=t.scaleX,this.scaleY=t.scaleY,this}get(){const{a:t,b:e,c:i,d:s,e:r,f:n}=this;return{a:t,b:e,c:i,d:s,e:r,f:n}}clone(){return new ct(this)}translate(t,e){return G.translate(this,t,e),this}translateInner(t,e){return G.translateInner(this,t,e),this}scale(t,e){return G.scale(this,t,e),this}scaleWith(t,e){return G.scale(this,t,e),this.scaleX*=t,this.scaleY*=e||t,this}pixelScale(t){return G.pixelScale(this,t),this}scaleOfOuter(t,e,i){return G.scaleOfOuter(this,t,e,i),this}scaleOfInner(t,e,i){return G.scaleOfInner(this,t,e,i),this}rotate(t){return G.rotate(this,t),this}rotateOfOuter(t,e){return G.rotateOfOuter(this,t,e),this}rotateOfInner(t,e){return G.rotateOfInner(this,t,e),this}skew(t,e){return G.skew(this,t,e),this}skewOfOuter(t,e,i){return G.skewOfOuter(this,t,e,i),this}skewOfInner(t,e,i){return G.skewOfInner(this,t,e,i),this}multiply(t){return G.multiply(this,t),this}multiplyParent(t){return G.multiplyParent(this,t),this}divide(t){return G.divide(this,t),this}divideParent(t){return G.divideParent(this,t),this}invert(){return G.invert(this),this}invertWith(){return G.invert(this),this.scaleX=1/this.scaleX,this.scaleY=1/this.scaleY,this}toOuterPoint(t,e,i){G.toOuterPoint(this,t,e,i)}toInnerPoint(t,e,i){G.toInnerPoint(this,t,e,i)}setLayout(t,e,i){return G.setLayout(this,t,e,i),this}getLayout(t,e,i){return G.getLayout(this,t,e,i)}withScale(t,e){return G.withScale(this,t,e)}reset(){G.reset(this)}}const ut=new ct,_t={tempPointBounds:{},setPoint(t,e,i){t.minX=t.maxX=e,t.minY=t.maxY=i},addPoint(t,e,i){t.minX=e<t.minX?e:t.minX,t.minY=i<t.minY?i:t.minY,t.maxX=e>t.maxX?e:t.maxX,t.maxY=i>t.maxY?i:t.maxY},addBounds(t,e,i,s,r){pt(t,e,i),pt(t,e+s,i+r)},copy(t,e){t.minX=e.minX,t.minY=e.minY,t.maxX=e.maxX,t.maxY=e.maxY},addPointBounds(t,e){t.minX=e.minX<t.minX?e.minX:t.minX,t.minY=e.minY<t.minY?e.minY:t.minY,t.maxX=e.maxX>t.maxX?e.maxX:t.maxX,t.maxY=e.maxY>t.maxY?e.maxY:t.maxY},toBounds(t,e){e.x=t.minX,e.y=t.minY,e.width=t.maxX-t.minX,e.height=t.maxY-t.minY}},{addPoint:pt}=_t;var gt,ft;!function(t){t[t.top=0]="top",t[t.right=1]="right",t[t.bottom=2]="bottom",t[t.left=3]="left"}(gt||(gt={})),function(t){t[t.topLeft=0]="topLeft",t[t.top=1]="top",t[t.topRight=2]="topRight",t[t.right=3]="right",t[t.bottomRight=4]="bottomRight",t[t.bottom=5]="bottom",t[t.bottomLeft=6]="bottomLeft",t[t.left=7]="left",t[t.center=8]="center",t[t["top-left"]=0]="top-left",t[t["top-right"]=2]="top-right",t[t["bottom-right"]=4]="bottom-right",t[t["bottom-left"]=6]="bottom-left"}(ft||(ft={}));const yt=[{x:0,y:0},{x:.5,y:0},{x:1,y:0},{x:1,y:.5},{x:1,y:1},{x:.5,y:1},{x:0,y:1},{x:0,y:.5},{x:.5,y:.5}];yt.forEach(t=>t.type="percent");const mt={directionData:yt,tempPoint:{},get:vt,toPoint(t,e,i,s,r,n){const o=vt(t);i.x=o.x,i.y=o.y,"percent"===o.type&&(i.x*=e.width,i.y*=e.height,r&&(n||(i.x-=r.x,i.y-=r.y),o.x&&(i.x-=1===o.x?r.width:.5===o.x?o.x*r.width:0),o.y&&(i.y-=1===o.y?r.height:.5===o.y?o.y*r.height:0))),s||(i.x+=e.x,i.y+=e.y)},getPoint:(t,e,i)=>(i||(i={}),mt.toPoint(t,e,i,!0),i)};function vt(t){return a(t)?yt[ft[t]]:t}const{toPoint:wt}=mt,xt={toPoint(t,e,i,s,r,n){wt(t,i,s,r,e,n)}},{tempPointBounds:bt,setPoint:Bt,addPoint:kt,toBounds:St}=_t,{toOuterPoint:Pt}=G,{float:Rt,fourNumber:Ct}=O,{floor:Tt,ceil:Et}=Math;let Lt,Ot,At,Dt;const Mt={},Wt={},It={},Ft={tempBounds:It,set(t,e=0,i=0,s=0,r=0){t.x=e,t.y=i,t.width=s,t.height=r},copy(t,e){t.x=e.x,t.y=e.y,t.width=e.width,t.height=e.height},copyAndSpread(t,e,i,s,r){const{x:n,y:o,width:a,height:h}=e;if(u(i)){const e=Ct(i);s?zt.set(t,n+e[3],o+e[0],a-e[1]-e[3],h-e[2]-e[0]):zt.set(t,n-e[3],o-e[0],a+e[1]+e[3],h+e[2]+e[0])}else s&&(i=-i),zt.set(t,n-i,o-i,a+2*i,h+2*i);r&&("width"===r?(t.y=o,t.height=h):(t.x=n,t.width=a))},minX:t=>t.width>0?t.x:t.x+t.width,minY:t=>t.height>0?t.y:t.y+t.height,maxX:t=>t.width>0?t.x+t.width:t.x,maxY:t=>t.height>0?t.y+t.height:t.y,move(t,e,i){t.x+=e,t.y+=i},scroll(t,e){t.x+=e.scrollX,t.y+=e.scrollY},getByMove:(t,e,i)=>(t=Object.assign({},t),zt.move(t,e,i),t),toOffsetOutBounds(t,e,i){e?Yt(e,t):e=t,i||(i=t),e.offsetX=zt.maxX(i),e.offsetY=zt.maxY(i),zt.move(e,-e.offsetX,-e.offsetY)},scale(t,e,i=e,s){s||rt.scale(t,e,i),t.width*=e,t.height*=i},scaleOf(t,e,i,s=i){rt.scaleOf(t,e,i,s),t.width*=i,t.height*=s},tempToOuterOf:(t,e)=>(zt.copy(It,t),zt.toOuterOf(It,e),It),getOuterOf:(t,e)=>(t=Object.assign({},t),zt.toOuterOf(t,e),t),toOuterOf(t,e,i){if(i||(i=t),0===e.b&&0===e.c){const{a:s,d:r}=e;s>0?(i.width=t.width*s,i.x=e.e+t.x*s):(i.width=t.width*-s,i.x=e.e+t.x*s-i.width),r>0?(i.height=t.height*r,i.y=e.f+t.y*r):(i.height=t.height*-r,i.y=e.f+t.y*r-i.height)}else Mt.x=t.x,Mt.y=t.y,Pt(e,Mt,Wt),Bt(bt,Wt.x,Wt.y),Mt.x=t.x+t.width,Pt(e,Mt,Wt),kt(bt,Wt.x,Wt.y),Mt.y=t.y+t.height,Pt(e,Mt,Wt),kt(bt,Wt.x,Wt.y),Mt.x=t.x,Pt(e,Mt,Wt),kt(bt,Wt.x,Wt.y),St(bt,i)},toInnerOf(t,e,i){i||(i=t),zt.move(i,-e.e,-e.f),zt.scale(i,1/e.a,1/e.d)},getFitMatrix(t,e,i=1){const s=Math.min(i,zt.getFitScale(t,e));return new ct(s,0,0,s,-e.x*s,-e.y*s)},getFitScale(t,e,i){const s=t.width/e.width,r=t.height/e.height;return i?Math.max(s,r):Math.min(s,r)},put(t,e,i="center",s=1,r=!0,n){n||(n=e),a(s)&&(s=zt.getFitScale(t,e,"cover"===s)),It.width=r?e.width*=s:e.width*s,It.height=r?e.height*=s:e.height*s,xt.toPoint(i,It,t,n,!0,!0)},getSpread(t,e,i){const s={};return zt.copyAndSpread(s,t,e,!1,i),s},spread(t,e,i){zt.copyAndSpread(t,t,e,!1,i)},shrink(t,e,i){zt.copyAndSpread(t,t,e,!0,i)},ceil(t){const{x:e,y:i}=t;t.x=Tt(t.x),t.y=Tt(t.y),t.width=e>t.x?Et(t.width+e-t.x):Et(t.width),t.height=i>t.y?Et(t.height+i-t.y):Et(t.height)},unsign(t){t.width<0&&(t.x+=t.width,t.width=-t.width),t.height<0&&(t.y+=t.height,t.height=-t.height)},float(t,e){t.x=Rt(t.x,e),t.y=Rt(t.y,e),t.width=Rt(t.width,e),t.height=Rt(t.height,e)},add(t,e,i){Lt=t.x+t.width,Ot=t.y+t.height,At=e.x,Dt=e.y,i||(At+=e.width,Dt+=e.height),Lt=Lt>At?Lt:At,Ot=Ot>Dt?Ot:Dt,t.x=t.x<e.x?t.x:e.x,t.y=t.y<e.y?t.y:e.y,t.width=Lt-t.x,t.height=Ot-t.y},addList(t,e){zt.setListWithFn(t,e,void 0,!0)},setList(t,e,i=!1){zt.setListWithFn(t,e,void 0,i)},addListWithFn(t,e,i){zt.setListWithFn(t,e,i,!0)},setListWithFn(t,e,i,s=!1){let r,n=!0;for(let o=0,a=e.length;o<a;o++)r=i?i(e[o],o):e[o],r&&(r.width||r.height)&&(n?(n=!1,s||Yt(t,r)):Nt(t,r));n&&zt.reset(t)},setPoints(t,e){e.forEach((t,e)=>0===e?Bt(bt,t.x,t.y):kt(bt,t.x,t.y)),St(bt,t)},setPoint(t,e){zt.set(t,e.x,e.y)},addPoint(t,e){Nt(t,e,!0)},getPoints(t){const{x:e,y:i,width:s,height:r}=t;return[{x:e,y:i},{x:e+s,y:i},{x:e+s,y:i+r},{x:e,y:i+r}]},hitRadiusPoint:(t,e,i)=>(i&&(e=rt.tempToInnerRadiusPointOf(e,i)),e.x>=t.x-e.radiusX&&e.x<=t.x+t.width+e.radiusX&&e.y>=t.y-e.radiusY&&e.y<=t.y+t.height+e.radiusY),hitPoint:(t,e,i)=>(i&&(e=rt.tempToInnerOf(e,i)),e.x>=t.x&&e.x<=t.x+t.width&&e.y>=t.y&&e.y<=t.y+t.height),hit:(t,e,i)=>(i&&(e=zt.tempToOuterOf(e,i)),!(t.y+t.height<e.y||e.y+e.height<t.y||t.x+t.width<e.x||e.x+e.width<t.x)),includes:(t,e,i)=>(i&&(e=zt.tempToOuterOf(e,i)),t.x<=e.x&&t.y<=e.y&&t.x+t.width>=e.x+e.width&&t.y+t.height>=e.y+e.height),getIntersectData(t,e,i){if(i&&(e=zt.tempToOuterOf(e,i)),!zt.hit(t,e))return{x:0,y:0,width:0,height:0};let{x:s,y:r,width:n,height:o}=e;return Lt=s+n,Ot=r+o,At=t.x+t.width,Dt=t.y+t.height,s=s>t.x?s:t.x,r=r>t.y?r:t.y,Lt=Lt<At?Lt:At,Ot=Ot<Dt?Ot:Dt,n=Lt-s,o=Ot-r,{x:s,y:r,width:n,height:o}},intersect(t,e,i){zt.copy(t,zt.getIntersectData(t,e,i))},isSame:(t,e)=>t.x===e.x&&t.y===e.y&&t.width===e.width&&t.height===e.height,isEmpty:t=>0===t.x&&0===t.y&&0===t.width&&0===t.height,reset(t){zt.set(t)}},zt=Ft,{add:Nt,copy:Yt}=zt;class Xt{get minX(){return Ft.minX(this)}get minY(){return Ft.minY(this)}get maxX(){return Ft.maxX(this)}get maxY(){return Ft.maxY(this)}constructor(t,e,i,s){this.set(t,e,i,s)}set(t,e,i,s){return _(t)?Ft.copy(this,t):Ft.set(this,t,e,i,s),this}get(){const{x:t,y:e,width:i,height:s}=this;return{x:t,y:e,width:i,height:s}}clone(){return new Xt(this)}move(t,e){return Ft.move(this,t,e),this}scale(t,e,i){return Ft.scale(this,t,e,i),this}scaleOf(t,e,i){return Ft.scaleOf(this,t,e,i),this}toOuterOf(t,e){return Ft.toOuterOf(this,t,e),this}toInnerOf(t,e){return Ft.toInnerOf(this,t,e),this}getFitMatrix(t,e){return Ft.getFitMatrix(this,t,e)}put(t,e,i){Ft.put(this,t,e,i)}spread(t,e){return Ft.spread(this,t,e),this}shrink(t,e){return Ft.shrink(this,t,e),this}ceil(){return Ft.ceil(this),this}unsign(){return Ft.unsign(this),this}float(t){return Ft.float(this,t),this}add(t){return Ft.add(this,t),this}addList(t){return Ft.setList(this,t,!0),this}setList(t){return Ft.setList(this,t),this}addListWithFn(t,e){return Ft.setListWithFn(this,t,e,!0),this}setListWithFn(t,e){return Ft.setListWithFn(this,t,e),this}setPoint(t){return Ft.setPoint(this,t),this}setPoints(t){return Ft.setPoints(this,t),this}addPoint(t){return Ft.addPoint(this,t),this}getPoints(){return Ft.getPoints(this)}hitPoint(t,e){return Ft.hitPoint(this,t,e)}hitRadiusPoint(t,e){return Ft.hitRadiusPoint(this,t,e)}hit(t,e){return Ft.hit(this,t,e)}includes(t,e){return Ft.includes(this,t,e)}intersect(t,e){return Ft.intersect(this,t,e),this}getIntersect(t,e){return new Xt(Ft.getIntersectData(this,t,e))}isSame(t){return Ft.isSame(this,t)}isEmpty(){return Ft.isEmpty(this)}reset(){Ft.reset(this)}}const Ht=new Xt;class Ut{constructor(t,e,i,s,r,n){_(t)?this.copy(t):this.set(t,e,i,s,r,n)}set(t=0,e=0,i=0,s=0,r=0,n=0){this.top=t,this.right=e,this.bottom=i,this.left=s,this.width=r,this.height=n}copy(t){const{top:e,right:i,bottom:s,left:r,width:n,height:o}=t;this.set(e,i,s,r,n,o)}getBoundsFrom(t){const{top:e,right:i,bottom:s,left:r,width:n,height:o}=this;return new Xt(r,e,n||t.width-r-i,o||t.height-e-s)}}const jt={0:1,1:1,2:1,3:1,4:1,5:1,6:1,7:1,8:1,9:1,".":1,e:1,E:1},{randColor:Vt}=O;class Gt{constructor(t){this.repeatMap={},this.name=t}static get(t){return new Gt(t)}static set filter(t){this.filterList=Kt(t)}static set exclude(t){this.excludeList=Kt(t)}static drawRepaint(t,e){const i=Vt();t.fillWorld(e,i.replace("1)",".1)")),t.strokeWorld(e,i)}static drawBounds(t,e,i){const s="hit"===Gt.showBounds,r=t.__nowWorld,n=Vt();s&&(e.setWorld(r),t.__drawHitPath(e),e.fillStyle=n.replace("1)",".2)"),e.fill()),e.resetTransform(),e.setStroke(n,2),s?e.stroke():e.strokeWorld(r,n)}log(...t){if(qt.enable){if(qt.filterList.length&&qt.filterList.every(t=>t!==this.name))return;if(qt.excludeList.length&&qt.excludeList.some(t=>t===this.name))return;console.log("%c"+this.name,"color:#21ae62",...t)}}tip(...t){qt.enable&&this.warn(...t)}warn(...t){qt.showWarn&&console.warn(this.name,...t)}repeat(t,...e){this.repeatMap[t]||(this.warn("repeat:"+t,...e),this.repeatMap[t]=!0)}error(...t){try{throw new Error}catch(e){console.error(this.name,...t,e)}}}function Kt(t){return t?a(t)&&(t=[t]):t=[],t}Gt.filterList=[],Gt.excludeList=[],Gt.showWarn=!0;const qt=Gt,$t=Gt.get("RunTime"),Qt={currentId:0,currentName:"",idMap:{},nameMap:{},nameToIdMap:{},start(t,i){const s=e.create(e.RUNTIME);return Jt.currentId=Jt.idMap[s]=i?performance.now():Date.now(),Jt.currentName=Jt.nameMap[s]=t,Jt.nameToIdMap[t]=s,s},end(t,e){const i=Jt.idMap[t],s=Jt.nameMap[t],r=e?(performance.now()-i)/1e3:Date.now()-i;Jt.idMap[t]=Jt.nameMap[t]=Jt.nameToIdMap[s]=void 0,$t.log(s,r,"ms")},endOfName(t,e){const i=Jt.nameToIdMap[t];n(i)||Jt.end(i,e)}},Jt=Qt,Zt=[],te={list:{},add(t,...e){this.list[t]=!0,Zt.push(...e)},has(t,e){const i=this.list[t];return!i&&e&&this.need(t),i},need(t){console.error("please install and import plugin: "+(t.includes("-x")?"":"@leafer-in/")+t)}};setTimeout(()=>Zt.forEach(t=>te.has(t,!0)));const ee={editor:t=>te.need("editor")},ie=Gt.get("UICreator"),se={list:{},register(t){const{__tag:e}=t.prototype;re[e]&&ie.repeat(e),re[e]=t},get(t,e,i,s,r,o){re[t]||ie.error("not register "+t);const a=new re[t](e);return n(i)||(a.x=i,s&&(a.y=s),r&&(a.width=r),o&&(a.height=o)),a}},{list:re}=se,ne=Gt.get("EventCreator"),oe={nameList:{},register(t){let e;Object.keys(t).forEach(i=>{e=t[i],a(e)&&(ae[e]&&ne.repeat(e),ae[e]=t)})},changeName(t,e){const i=ae[t];if(i){const s=Object.keys(i).find(e=>i[e]===t);s&&(i[s]=e,ae[e]=i)}},has(t){return!!this.nameList[t]},get:(t,...e)=>new ae[t](...e)},{nameList:ae}=oe;class he{constructor(){this.list=[]}add(t){t.manager=this,this.list.push(t)}get(t){let e;const{list:i}=this;for(let s=0,r=i.length;s<r;s++)if(e=i[s],e.recycled&&e.isSameSize(t))return e.recycled=!1,e.manager||(e.manager=this),e;const s=ee.canvas(t);return this.add(s),s}recycle(t){t.recycled=!0}clearRecycled(){let t;const e=[];for(let i=0,s=this.list.length;i<s;i++)t=this.list[i],t.recycled?t.destroy():e.push(t);this.list=e}clear(){this.list.forEach(t=>{t.destroy()}),this.list.length=0}destroy(){this.clear()}}function le(t,e,i,s){var r,n=arguments.length,o=n<3?e:null===s?s=Object.getOwnPropertyDescriptor(e,i):s;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)o=Reflect.decorate(t,e,i,s);else for(var a=t.length-1;a>=0;a--)(r=t[a])&&(o=(n<3?r(o):n>3?r(e,i,o):r(e,i))||o);return n>3&&o&&Object.defineProperty(e,i,o),o}function de(t,e,i,s){return new(i||(i=Promise))(function(r,n){function o(t){try{h(s.next(t))}catch(t){n(t)}}function a(t){try{h(s.throw(t))}catch(t){n(t)}}function h(t){var e;t.done?r(t.value):(e=t.value,e instanceof i?e:new i(function(t){t(e)})).then(o,a)}h((s=s.apply(t,e||[])).next())})}function ce(t){return(e,i)=>{t||(t=i);const s={get(){return this.context[t]},set(e){this.context[t]=e}};"strokeCap"===i&&(s.set=function(e){this.context[t]="none"===e?"butt":e}),Object.defineProperty(e,i,s)}}"function"==typeof SuppressedError&&SuppressedError;const ue=[];function _e(){return(t,e)=>{ue.push(e)}}const pe=[];let ge=class{set blendMode(t){"normal"===t&&(t="source-over"),this.context.globalCompositeOperation=t}get blendMode(){return this.context.globalCompositeOperation}set dashPattern(t){this.context.setLineDash(t||pe)}get dashPattern(){return this.context.getLineDash()}__bindContext(){let t;ue.forEach(e=>{t=this.context[e],t&&(this[e]=t.bind(this.context))}),this.textBaseline="alphabetic"}setTransform(t,e,i,s,r,n){}resetTransform(){}getTransform(){}save(){}restore(){}transform(t,e,i,s,r,n){_(t)?this.context.transform(t.a,t.b,t.c,t.d,t.e,t.f):this.context.transform(t,e,i,s,r,n)}translate(t,e){}scale(t,e){}rotate(t){}fill(t,e){}stroke(t){}clip(t,e){}fillRect(t,e,i,s){}strokeRect(t,e,i,s){}clearRect(t,e,i,s){}drawImage(t,e,i,s,r,n,o,a,h){switch(arguments.length){case 9:if(e<0){const t=-e/s*a;s+=e,e=0,n+=t,a-=t}if(i<0){const t=-i/r*h;r+=i,i=0,o+=t,h-=t}this.context.drawImage(t,e,i,s,r,n,o,a,h);break;case 5:this.context.drawImage(t,e,i,s,r);break;case 3:this.context.drawImage(t,e,i)}}beginPath(){}moveTo(t,e){}lineTo(t,e){}bezierCurveTo(t,e,i,s,r,n){}quadraticCurveTo(t,e,i,s){}closePath(){}arc(t,e,i,s,r,n){}arcTo(t,e,i,s,r){}ellipse(t,e,i,s,r,n,o,a){}rect(t,e,i,s){}roundRect(t,e,i,s,r){}createConicGradient(t,e,i){}createLinearGradient(t,e,i,s){}createPattern(t,e){}createRadialGradient(t,e,i,s,r,n){}fillText(t,e,i,s){}measureText(t){}strokeText(t,e,i,s){}destroy(){this.context=null}};le([ce("imageSmoothingEnabled")],ge.prototype,"smooth",void 0),le([ce("imageSmoothingQuality")],ge.prototype,"smoothLevel",void 0),le([ce("globalAlpha")],ge.prototype,"opacity",void 0),le([ce()],ge.prototype,"fillStyle",void 0),le([ce()],ge.prototype,"strokeStyle",void 0),le([ce("lineWidth")],ge.prototype,"strokeWidth",void 0),le([ce("lineCap")],ge.prototype,"strokeCap",void 0),le([ce("lineJoin")],ge.prototype,"strokeJoin",void 0),le([ce("lineDashOffset")],ge.prototype,"dashOffset",void 0),le([ce()],ge.prototype,"miterLimit",void 0),le([ce()],ge.prototype,"shadowBlur",void 0),le([ce()],ge.prototype,"shadowColor",void 0),le([ce()],ge.prototype,"shadowOffsetX",void 0),le([ce()],ge.prototype,"shadowOffsetY",void 0),le([ce()],ge.prototype,"filter",void 0),le([ce()],ge.prototype,"font",void 0),le([ce()],ge.prototype,"fontKerning",void 0),le([ce()],ge.prototype,"fontStretch",void 0),le([ce()],ge.prototype,"fontVariantCaps",void 0),le([ce()],ge.prototype,"textAlign",void 0),le([ce()],ge.prototype,"textBaseline",void 0),le([ce()],ge.prototype,"textRendering",void 0),le([ce()],ge.prototype,"wordSpacing",void 0),le([ce()],ge.prototype,"letterSpacing",void 0),le([ce()],ge.prototype,"direction",void 0),le([_e()],ge.prototype,"setTransform",null),le([_e()],ge.prototype,"resetTransform",null),le([_e()],ge.prototype,"getTransform",null),le([_e()],ge.prototype,"save",null),le([_e()],ge.prototype,"restore",null),le([_e()],ge.prototype,"translate",null),le([_e()],ge.prototype,"scale",null),le([_e()],ge.prototype,"rotate",null),le([_e()],ge.prototype,"fill",null),le([_e()],ge.prototype,"stroke",null),le([_e()],ge.prototype,"clip",null),le([_e()],ge.prototype,"fillRect",null),le([_e()],ge.prototype,"strokeRect",null),le([_e()],ge.prototype,"clearRect",null),le([_e()],ge.prototype,"beginPath",null),le([_e()],ge.prototype,"moveTo",null),le([_e()],ge.prototype,"lineTo",null),le([_e()],ge.prototype,"bezierCurveTo",null),le([_e()],ge.prototype,"quadraticCurveTo",null),le([_e()],ge.prototype,"closePath",null),le([_e()],ge.prototype,"arc",null),le([_e()],ge.prototype,"arcTo",null),le([_e()],ge.prototype,"ellipse",null),le([_e()],ge.prototype,"rect",null),le([_e()],ge.prototype,"roundRect",null),le([_e()],ge.prototype,"createConicGradient",null),le([_e()],ge.prototype,"createLinearGradient",null),le([_e()],ge.prototype,"createPattern",null),le([_e()],ge.prototype,"createRadialGradient",null),le([_e()],ge.prototype,"fillText",null),le([_e()],ge.prototype,"measureText",null),le([_e()],ge.prototype,"strokeText",null);const{copy:fe,multiplyParent:ye,pixelScale:me}=G,{round:ve}=Math,we=new Xt,xe=new Xt,be={width:1,height:1,pixelRatio:1},Be=["width","height","pixelRatio"];class ke extends ge{get width(){return this.size.width}get height(){return this.size.height}get pixelRatio(){return this.size.pixelRatio}get pixelWidth(){return this.width*this.pixelRatio||0}get pixelHeight(){return this.height*this.pixelRatio||0}get pixelSnap(){return this.config.pixelSnap}set pixelSnap(t){this.config.pixelSnap=t}get allowBackgroundColor(){return this.view&&this.parentView}constructor(i,s){super(),this.size={},this.worldTransform={},i||(i=be),this.manager=s,this.innerId=e.create(e.CNAVAS);const{width:r,height:n,pixelRatio:o}=i;this.autoLayout=!r||!n,this.size.pixelRatio=o||t.devicePixelRatio,this.config=i,this.init()}init(){}__createContext(){const{view:t}=this,{contextSettings:e}=this.config;this.context=e?t.getContext("2d",e):t.getContext("2d"),this.__bindContext()}export(t,e){}toBlob(t,e){}toDataURL(t,e){}saveAs(t,e){}resize(t,e=!0){if(this.isSameSize(t))return;let i;this.context&&!this.unreal&&e&&this.width&&(i=this.getSameCanvas(),i.copyWorld(this));const s=this.size;f.copyAttrs(s,t,Be),Be.forEach(t=>s[t]||(s[t]=1)),this.bounds=new Xt(0,0,this.width,this.height),this.updateViewSize(),this.updateClientBounds(),this.context&&(this.smooth=this.config.smooth,!this.unreal&&i&&(this.clearWorld(i.bounds),this.copyWorld(i),i.recycle()))}updateViewSize(){}updateClientBounds(){}getClientBounds(t){return t&&this.updateClientBounds(),this.clientBounds||this.bounds}startAutoLayout(t,e){}stopAutoLayout(){}setCursor(t){}setWorld(t,e){const{pixelRatio:i,pixelSnap:s}=this,r=this.worldTransform;e&&ye(t,e,r),me(t,i,r),s&&!t.ignorePixelSnap&&(t.half&&t.half*i%2?(r.e=ve(r.e-.5)+.5,r.f=ve(r.f-.5)+.5):(r.e=ve(r.e),r.f=ve(r.f))),this.setTransform(r.a,r.b,r.c,r.d,r.e,r.f)}useWorldTransform(t){t&&(this.worldTransform=t);const e=this.worldTransform;e&&this.setTransform(e.a,e.b,e.c,e.d,e.e,e.f)}setStroke(t,e,i,s){e&&(this.strokeWidth=e),t&&(this.strokeStyle=t),i&&this.setStrokeOptions(i,s)}setStrokeOptions(t,e){let{strokeCap:i,strokeJoin:s,dashPattern:r,dashOffset:o,miterLimit:a}=t;e&&(e.strokeCap&&(i=e.strokeCap),e.strokeJoin&&(s=e.strokeJoin),n(e.dashPattern)||(r=e.dashPattern),n(e.dashOffset)||(o=e.dashOffset),e.miterLimit&&(a=e.miterLimit)),this.strokeCap=i,this.strokeJoin=s,this.dashPattern=r,this.dashOffset=o,this.miterLimit=a}saveBlendMode(t){this.savedBlendMode=this.blendMode,this.blendMode=t}restoreBlendMode(){this.blendMode=this.savedBlendMode}hitFill(t,e){return!0}hitStroke(t,e){return!0}hitPixel(t,e,i=1){return!0}setWorldShadow(t,e,i,s){const{pixelRatio:r}=this;this.shadowOffsetX=t*r,this.shadowOffsetY=e*r,this.shadowBlur=i*r,this.shadowColor=s||"black"}setWorldBlur(t){const{pixelRatio:e}=this;this.filter=`blur(${t*e}px)`}copyWorld(t,e,i,s,r=!0){s&&(this.blendMode=s),e?(this.setTempPixelBounds(e,r),i?(this.setTempPixelBounds2(i,r),i=xe):i=we,this.drawImage(t.view,we.x,we.y,we.width,we.height,i.x,i.y,i.width,i.height)):this.drawImage(t.view,0,0),s&&(this.blendMode="source-over")}copyWorldToInner(t,e,i,s,r=!0){e.b||e.c?(this.save(),this.resetTransform(),this.copyWorld(t,e,Ft.tempToOuterOf(i,e),s,r),this.restore()):(s&&(this.blendMode=s),this.setTempPixelBounds(e,r),this.drawImage(t.view,we.x,we.y,we.width,we.height,i.x,i.y,i.width,i.height),s&&(this.blendMode="source-over"))}copyWorldByReset(t,e,i,s,r,n=!0){this.resetTransform(),this.copyWorld(t,e,i,s,n),r||this.useWorldTransform()}useGrayscaleAlpha(t){let e,i;this.setTempPixelBounds(t,!0,!0);const{context:s}=this,r=s.getImageData(we.x,we.y,we.width,we.height),{data:n}=r;for(let t=0,s=n.length;t<s;t+=4)i=.299*n[t]+.587*n[t+1]+.114*n[t+2],(e=n[t+3])&&(n[t+3]=255===e?i:e*(i/255));s.putImageData(r,we.x,we.y)}useMask(t,e,i){this.copyWorld(t,e,i,"destination-in")}useEraser(t,e,i){this.copyWorld(t,e,i,"destination-out")}fillWorld(t,e,i,s){i&&(this.blendMode=i),this.fillStyle=e,this.setTempPixelBounds(t,s),this.fillRect(we.x,we.y,we.width,we.height),i&&(this.blendMode="source-over")}strokeWorld(t,e,i,s){i&&(this.blendMode=i),this.strokeStyle=e,this.setTempPixelBounds(t,s),this.strokeRect(we.x,we.y,we.width,we.height),i&&(this.blendMode="source-over")}clipWorld(t,e=!0){this.beginPath(),this.setTempPixelBounds(t,e),this.rect(we.x,we.y,we.width,we.height),this.clip()}clipUI(t){t.windingRule?this.clip(t.windingRule):this.clip()}clearWorld(t,e=!0){this.setTempPixelBounds(t,e),this.clearRect(we.x,we.y,we.width,we.height)}clear(){const{pixelRatio:t}=this;this.clearRect(0,0,this.width*t+2,this.height*t+2)}setTempPixelBounds(t,e,i){this.copyToPixelBounds(we,t,e,i)}setTempPixelBounds2(t,e,i){this.copyToPixelBounds(xe,t,e,i)}copyToPixelBounds(t,e,i,s){t.set(e),s&&t.intersect(this.bounds),t.scale(this.pixelRatio),i&&t.ceil()}isSameSize(t){return this.width===t.width&&this.height===t.height&&(!t.pixelRatio||this.pixelRatio===t.pixelRatio)}getSameCanvas(t,e){const{size:i,pixelSnap:s}=this,r=this.manager?this.manager.get(i):ee.canvas(Object.assign({},i));return r.save(),t&&(fe(r.worldTransform,this.worldTransform),r.useWorldTransform()),e&&(r.smooth=this.smooth),r.pixelSnap!==s&&(r.pixelSnap=s),r}recycle(t){this.recycled||(this.restore(),t?this.clearWorld(t):this.clear(),this.manager?this.manager.recycle(this):this.destroy())}updateRender(t){}unrealCanvas(){}destroy(){this.manager=this.view=this.parentView=null}}const Se={creator:{},parse(t,e){},convertToCanvasData(t,e){}},Pe={N:21,D:22,X:23,G:24,F:25,O:26,P:27,U:28},Re=Object.assign({M:1,m:10,L:2,l:20,H:3,h:30,V:4,v:40,C:5,c:50,S:6,s:60,Q:7,q:70,T:8,t:80,A:9,a:90,Z:11,z:11,R:12},Pe),Ce={M:3,m:3,L:3,l:3,H:2,h:2,V:2,v:2,C:7,c:7,S:5,s:5,Q:5,q:5,T:3,t:3,A:8,a:8,Z:1,z:1,N:5,D:9,X:6,G:9,F:5,O:7,P:4,U:6},Te={m:10,l:20,H:3,h:30,V:4,v:40,c:50,S:6,s:60,q:70,T:8,t:80,A:9,a:90},Ee=Object.assign(Object.assign({},Te),Pe),Le=Re,Oe={};for(let t in Le)Oe[Le[t]]=t;const Ae={};for(let t in Le)Ae[Le[t]]=Ce[t];const De={drawRoundRect(t,e,i,s,r,n){const o=O.fourNumber(n,Math.min(s/2,r/2)),a=e+s,h=i+r;o[0]?t.moveTo(e+o[0],i):t.moveTo(e,i),o[1]?t.arcTo(a,i,a,h,o[1]):t.lineTo(a,i),o[2]?t.arcTo(a,h,e,h,o[2]):t.lineTo(a,h),o[3]?t.arcTo(e,h,e,i,o[3]):t.lineTo(e,h),o[0]?t.arcTo(e,i,a,i,o[0]):t.lineTo(e,i)}},{sin:Me,cos:We,hypot:Ie,atan2:Fe,ceil:ze,abs:Ne,PI:Ye,sqrt:Xe,pow:He}=Math,{setPoint:Ue,addPoint:je}=_t,{set:Ve,toNumberPoints:Ge}=rt,{M:Ke,L:qe,C:$e,Q:Qe,Z:Je}=Re,Ze={},ti={points(t,e,i,s){let r=Ge(e);if(t.push(Ke,r[0],r[1]),i&&r.length>5){let e,n,o,a,h,l,d,c,u,_,p,g,f,y=r.length;const m=!0===i?.5:i;s&&(r=[r[y-2],r[y-1],...r,r[0],r[1],r[2],r[3]],y=r.length);for(let i=2;i<y-2;i+=2)e=r[i-2],n=r[i-1],o=r[i],a=r[i+1],h=r[i+2],l=r[i+3],p=Xe(He(o-e,2)+He(a-n,2)),g=Xe(He(h-o,2)+He(l-a,2)),(p||g)&&(f=p+g,p=m*p/f,g=m*g/f,h-=e,l-=n,d=o-p*h,c=a-p*l,2===i?s||t.push(Qe,d,c,o,a):t.push($e,u,_,d,c,o,a),u=o+g*h,_=a+g*l);s||t.push(Qe,u,_,r[y-2],r[y-1])}else for(let e=2,i=r.length;e<i;e+=2)t.push(qe,r[e],r[e+1]);s&&t.push(Je)},rect(t,e,i,s,r){Se.creator.path=t,Se.creator.moveTo(e,i).lineTo(e+s,i).lineTo(e+s,i+r).lineTo(e,i+r).lineTo(e,i)},roundRect(t,e,i,s,r,n){Se.creator.path=[],De.drawRoundRect(Se.creator,e,i,s,r,n),t.push(...Se.convertToCanvasData(Se.creator.path,!0))},arcTo(t,e,i,s,r,n,o,a,h,l,d){const c=s-e,u=r-i,_=n-s,p=o-r;let g=Fe(u,c),f=Fe(p,_);const y=Ie(c,u),m=Ie(_,p);let v=f-g;if(v<0&&(v+=M),y<1e-12||m<1e-12||v<1e-12||Ne(v-Ye)<1e-12)return t&&t.push(qe,s,r),h&&(Ue(h,e,i),je(h,s,r)),d&&Ve(d,e,i),void(l&&Ve(l,s,r));const w=c*p-_*u<0,x=w?-1:1,b=a/We(v/2),B=s+b*We(g+v/2+W*x),k=r+b*Me(g+v/2+W*x);return g-=W*x,f-=W*x,si(t,B,k,a,a,0,g/D,f/D,w,h,l,d)},arc:(t,e,i,s,r,n,o,a,h,l)=>si(t,e,i,s,s,0,r,n,o,a,h,l),ellipse(t,e,i,s,r,n,o,a,h,l,d,c){const u=n*D,_=Me(u),p=We(u);let g=o*D,f=a*D;g>Ye&&(g-=M),f<0&&(f+=M);let y=f-g;y<0?y+=M:y>M&&(y-=M),h&&(y-=M);const m=ze(Ne(y/W)),v=y/m,w=Me(v/4),x=8/3*w*w/Me(v/2);f=g+v;let b,B,k,S,P,R,C,T,E=We(g),L=Me(g),O=k=p*s*E-_*r*L,A=S=_*s*E+p*r*L,I=e+k,F=i+S;t&&t.push(t.length?qe:Ke,I,F),l&&Ue(l,I,F),c&&Ve(c,I,F);for(let n=0;n<m;n++)b=We(f),B=Me(f),k=p*s*b-_*r*B,S=_*s*b+p*r*B,P=e+O-x*(p*s*L+_*r*E),R=i+A-x*(_*s*L-p*r*E),C=e+k+x*(p*s*B+_*r*b),T=i+S+x*(_*s*B-p*r*b),t&&t.push($e,P,R,C,T,e+k,i+S),l&&ii(e+O,i+A,P,R,C,T,e+k,i+S,l,!0),O=k,A=S,E=b,L=B,g=f,f+=v;d&&Ve(d,e+k,i+S)},quadraticCurveTo(t,e,i,s,r,n,o){t.push($e,(e+2*s)/3,(i+2*r)/3,(n+2*s)/3,(o+2*r)/3,n,o)},toTwoPointBoundsByQuadraticCurve(t,e,i,s,r,n,o,a){ii(t,e,(t+2*i)/3,(e+2*s)/3,(r+2*i)/3,(n+2*s)/3,r,n,o,a)},toTwoPointBounds(t,e,i,s,r,n,o,a,h,l){const d=[];let c,u,_,p,g,f,y,m,v=t,w=i,x=r,b=o;for(let t=0;t<2;++t)if(1==t&&(v=e,w=s,x=n,b=a),c=-3*v+9*w-9*x+3*b,u=6*v-12*w+6*x,_=3*w-3*v,Math.abs(c)<1e-12){if(Math.abs(u)<1e-12)continue;p=-_/u,0<p&&p<1&&d.push(p)}else y=u*u-4*_*c,m=Math.sqrt(y),y<0||(g=(-u+m)/(2*c),0<g&&g<1&&d.push(g),f=(-u-m)/(2*c),0<f&&f<1&&d.push(f));l?je(h,t,e):Ue(h,t,e),je(h,o,a);for(let l=0,c=d.length;l<c;l++)ei(d[l],t,e,i,s,r,n,o,a,Ze),je(h,Ze.x,Ze.y)},getPointAndSet(t,e,i,s,r,n,o,a,h,l){const d=1-t,c=d*d*d,u=3*d*d*t,_=3*d*t*t,p=t*t*t;l.x=c*e+u*s+_*n+p*a,l.y=c*i+u*r+_*o+p*h},getPoint(t,e,i,s,r,n,o,a,h){const l={};return ei(t,e,i,s,r,n,o,a,h,l),l},getDerivative(t,e,i,s,r){const n=1-t;return 3*n*n*(i-e)+6*n*t*(s-i)+3*t*t*(r-s)}},{getPointAndSet:ei,toTwoPointBounds:ii,ellipse:si}=ti,{sin:ri,cos:ni,sqrt:oi,atan2:ai}=Math,{ellipse:hi}=ti,li={ellipticalArc(e,i,s,r,n,o,a,h,l,d,c){const u=(l-i)/2,_=(d-s)/2,p=o*D,g=ri(p),f=ni(p),y=-f*u-g*_,m=-f*_+g*u,v=r*r,w=n*n,x=m*m,b=y*y,B=v*w-v*x-w*b;let k=0;if(B<0){const t=oi(1-B/(v*w));r*=t,n*=t}else k=(a===h?-1:1)*oi(B/(v*x+w*b));const S=k*r*m/n,P=-k*n*y/r,R=ai((m-P)/n,(y-S)/r),C=ai((-m-P)/n,(-y-S)/r);let T=C-R;0===h&&T>0?T-=M:1===h&&T<0&&(T+=M);const E=i+u+f*S-g*P,L=s+_+g*S+f*P,O=T<0?1:0;c||t.ellipseToCurve?hi(e,E,L,r,n,o,R/D,C/D,O):r!==n||o?e.push(Re.G,E,L,r,n,o,R/D,C/D,O):e.push(Re.O,E,L,r,R/D,C/D,O)}},{M:di,m:ci,L:ui,l:_i,H:pi,h:gi,V:fi,v:yi,C:mi,c:vi,S:wi,s:xi,Q:bi,q:Bi,T:ki,t:Si,A:Pi,a:Ri,Z:Ci,z:Ti,N:Ei,D:Li,X:Oi,G:Ai,F:Di,O:Mi,P:Wi,U:Ii}=Re,{rect:Fi,roundRect:zi,arcTo:Ni,arc:Yi,ellipse:Xi,quadraticCurveTo:Hi}=ti,{ellipticalArc:Ui}=li,ji=Gt.get("PathConvert"),Vi={},Gi={current:{dot:0},stringify(t,e){let i,s,r,n=0,o=t.length,a="";for(;n<o;){s=t[n],i=Ae[s],a+=s===r?" ":Oe[s];for(let s=1;s<i;s++)a+=O.float(t[n+s],e),s===i-1||(a+=" ");r=s,n+=i}return a},parse(t,e){let i,s,r,n="";const o=[],a=e?Ee:Te;for(let e=0,h=t.length;e<h;e++)s=t[e],jt[s]?("."===s&&(Ki.dot&&(qi(o,n),n=""),Ki.dot++),"0"===n&&"."!==s&&(qi(o,n),n=""),n+=s):Re[s]?(n&&(qi(o,n),n=""),Ki.name=Re[s],Ki.length=Ce[s],Ki.index=0,qi(o,Ki.name),!i&&a[s]&&(i=!0)):"-"===s||"+"===s?"e"===r||"E"===r?n+=s:(n&&qi(o,n),n=s):n&&(qi(o,n),n=""),r=s;return n&&qi(o,n),i?Gi.toCanvasData(o,e):o},toCanvasData(t,e){let i,s,r,n,o,a=0,h=0,l=0,d=0,c=0,u=t.length;const _=[];for(;c<u;){switch(r=t[c],r){case ci:t[c+1]+=a,t[c+2]+=h;case di:a=t[c+1],h=t[c+2],_.push(di,a,h),c+=3;break;case gi:t[c+1]+=a;case pi:a=t[c+1],_.push(ui,a,h),c+=2;break;case yi:t[c+1]+=h;case fi:h=t[c+1],_.push(ui,a,h),c+=2;break;case _i:t[c+1]+=a,t[c+2]+=h;case ui:a=t[c+1],h=t[c+2],_.push(ui,a,h),c+=3;break;case xi:t[c+1]+=a,t[c+2]+=h,t[c+3]+=a,t[c+4]+=h,r=wi;case wi:o=n===mi||n===wi,l=o?2*a-i:t[c+1],d=o?2*h-s:t[c+2],i=t[c+1],s=t[c+2],a=t[c+3],h=t[c+4],_.push(mi,l,d,i,s,a,h),c+=5;break;case vi:t[c+1]+=a,t[c+2]+=h,t[c+3]+=a,t[c+4]+=h,t[c+5]+=a,t[c+6]+=h,r=mi;case mi:i=t[c+3],s=t[c+4],a=t[c+5],h=t[c+6],_.push(mi,t[c+1],t[c+2],i,s,a,h),c+=7;break;case Si:t[c+1]+=a,t[c+2]+=h,r=ki;case ki:o=n===bi||n===ki,i=o?2*a-i:t[c+1],s=o?2*h-s:t[c+2],e?Hi(_,a,h,i,s,t[c+1],t[c+2]):_.push(bi,i,s,t[c+1],t[c+2]),a=t[c+1],h=t[c+2],c+=3;break;case Bi:t[c+1]+=a,t[c+2]+=h,t[c+3]+=a,t[c+4]+=h,r=bi;case bi:i=t[c+1],s=t[c+2],e?Hi(_,a,h,i,s,t[c+3],t[c+4]):_.push(bi,i,s,t[c+3],t[c+4]),a=t[c+3],h=t[c+4],c+=5;break;case Ri:t[c+6]+=a,t[c+7]+=h;case Pi:Ui(_,a,h,t[c+1],t[c+2],t[c+3],t[c+4],t[c+5],t[c+6],t[c+7],e),a=t[c+6],h=t[c+7],c+=8;break;case Ti:case Ci:_.push(Ci),c++;break;case Ei:a=t[c+1],h=t[c+2],e?Fi(_,a,h,t[c+3],t[c+4]):$i(_,t,c,5),c+=5;break;case Li:a=t[c+1],h=t[c+2],e?zi(_,a,h,t[c+3],t[c+4],[t[c+5],t[c+6],t[c+7],t[c+8]]):$i(_,t,c,9),c+=9;break;case Oi:a=t[c+1],h=t[c+2],e?zi(_,a,h,t[c+3],t[c+4],t[c+5]):$i(_,t,c,6),c+=6;break;case Ai:Xi(e?_:$i(_,t,c,9),t[c+1],t[c+2],t[c+3],t[c+4],t[c+5],t[c+6],t[c+7],t[c+8],null,Vi),a=Vi.x,h=Vi.y,c+=9;break;case Di:e?Xi(_,t[c+1],t[c+2],t[c+3],t[c+4],0,0,360,!1):$i(_,t,c,5),a=t[c+1]+t[c+3],h=t[c+2],c+=5;break;case Mi:Yi(e?_:$i(_,t,c,7),t[c+1],t[c+2],t[c+3],t[c+4],t[c+5],t[c+6],null,Vi),a=Vi.x,h=Vi.y,c+=7;break;case Wi:e?Yi(_,t[c+1],t[c+2],t[c+3],0,360,!1):$i(_,t,c,4),a=t[c+1]+t[c+3],h=t[c+2],c+=4;break;case Ii:Ni(e?_:$i(_,t,c,6),a,h,t[c+1],t[c+2],t[c+3],t[c+4],t[c+5],null,Vi),a=Vi.x,h=Vi.y,c+=6;break;default:return ji.error(`command: ${r} [index:${c}]`,t),_}n=r}return _},objectToCanvasData(t){const e=[];return t.forEach(t=>{switch(t.name){case"M":e.push(di,t.x,t.y);break;case"L":e.push(ui,t.x,t.y);break;case"C":e.push(mi,t.x1,t.y1,t.x2,t.y2,t.x,t.y);break;case"Q":e.push(bi,t.x1,t.y1,t.x,t.y);break;case"Z":e.push(Ci)}}),e},copyData(t,e,i,s){for(let r=i,n=i+s;r<n;r++)t.push(e[r])},pushData(t,e){Ki.index===Ki.length&&(Ki.index=1,t.push(Ki.name)),t.push(Number(e)),Ki.index++,Ki.dot=0}},{current:Ki,pushData:qi,copyData:$i}=Gi,{M:Qi,L:Ji,C:Zi,Q:ts,Z:es,N:is,D:ss,X:rs,G:ns,F:os,O:as,P:hs,U:ls}=Re,{getMinDistanceFrom:ds,getRadianFrom:cs}=rt,{tan:us,min:_s,abs:ps}=Math,gs={},fs={beginPath(t){t.length=0},moveTo(t,e,i){t.push(Qi,e,i)},lineTo(t,e,i){t.push(Ji,e,i)},bezierCurveTo(t,e,i,s,r,n,o){t.push(Zi,e,i,s,r,n,o)},quadraticCurveTo(t,e,i,s,r){t.push(ts,e,i,s,r)},closePath(t){t.push(es)},rect(t,e,i,s,r){t.push(is,e,i,s,r)},roundRect(t,e,i,s,r,n){if(l(n))t.push(rs,e,i,s,r,n);else{const o=O.fourNumber(n);o?t.push(ss,e,i,s,r,...o):t.push(is,e,i,s,r)}},ellipse(t,e,i,s,r,n,a,h,l){o(n)?t.push(os,e,i,s,r):(o(a)&&(a=0),o(h)&&(h=360),t.push(ns,e,i,s,r,n,a,h,l?1:0))},arc(t,e,i,s,r,n,a){o(r)?t.push(hs,e,i,s):(o(n)&&(n=360),t.push(as,e,i,s,r,n,a?1:0))},arcTo(t,e,i,s,r,o,a,h){if(!n(a)){const t=ds(a,h,e,i,s,r);o=_s(o,_s(t/2,t/2*ps(us(cs(a,h,e,i,s,r)/2))))}t.push(ls,e,i,s,r,o)},drawEllipse(t,e,i,s,r,n,a,h,l){ti.ellipse(null,e,i,s,r,o(n)?0:n,o(a)?0:a,o(h)?360:h,l,null,null,gs),t.push(Qi,gs.x,gs.y),ys(t,e,i,s,r,n,a,h,l)},drawArc(t,e,i,s,r,n,a){ti.arc(null,e,i,s,o(r)?0:r,o(n)?360:n,a,null,null,gs),t.push(Qi,gs.x,gs.y),ms(t,e,i,s,r,n,a)},drawPoints(t,e,i,s){ti.points(t,e,i,s)}},{ellipse:ys,arc:ms}=fs,{moveTo:vs,lineTo:ws,quadraticCurveTo:xs,bezierCurveTo:bs,closePath:Bs,beginPath:ks,rect:Ss,roundRect:Ps,ellipse:Rs,arc:Cs,arcTo:Ts,drawEllipse:Es,drawArc:Ls,drawPoints:Os}=fs;class As{set path(t){this.__path=t}get path(){return this.__path}constructor(t){this.set(t)}set(t){return this.__path=t?a(t)?Se.parse(t):t:[],this}beginPath(){return ks(this.__path),this.paint(),this}moveTo(t,e){return vs(this.__path,t,e),this.paint(),this}lineTo(t,e){return ws(this.__path,t,e),this.paint(),this}bezierCurveTo(t,e,i,s,r,n){return bs(this.__path,t,e,i,s,r,n),this.paint(),this}quadraticCurveTo(t,e,i,s){return xs(this.__path,t,e,i,s),this.paint(),this}closePath(){return Bs(this.__path),this.paint(),this}rect(t,e,i,s){return Ss(this.__path,t,e,i,s),this.paint(),this}roundRect(t,e,i,s,r){return Ps(this.__path,t,e,i,s,r),this.paint(),this}ellipse(t,e,i,s,r,n,o,a){return Rs(this.__path,t,e,i,s,r,n,o,a),this.paint(),this}arc(t,e,i,s,r,n){return Cs(this.__path,t,e,i,s,r,n),this.paint(),this}arcTo(t,e,i,s,r){return Ts(this.__path,t,e,i,s,r),this.paint(),this}drawEllipse(t,e,i,s,r,n,o,a){return Es(this.__path,t,e,i,s,r,n,o,a),this.paint(),this}drawArc(t,e,i,s,r,n){return Ls(this.__path,t,e,i,s,r,n),this.paint(),this}drawPoints(t,e,i){return Os(this.__path,t,e,i),this.paint(),this}clearPath(){return this.beginPath()}paint(){}}const{M:Ds,L:Ms,C:Ws,Q:Is,Z:Fs,N:zs,D:Ns,X:Ys,G:Xs,F:Hs,O:Us,P:js,U:Vs}=Re,Gs=Gt.get("PathDrawer"),Ks={drawPathByData(t,e){if(!e)return;let i,s=0,r=e.length;for(;s<r;)switch(i=e[s],i){case Ds:t.moveTo(e[s+1],e[s+2]),s+=3;break;case Ms:t.lineTo(e[s+1],e[s+2]),s+=3;break;case Ws:t.bezierCurveTo(e[s+1],e[s+2],e[s+3],e[s+4],e[s+5],e[s+6]),s+=7;break;case Is:t.quadraticCurveTo(e[s+1],e[s+2],e[s+3],e[s+4]),s+=5;break;case Fs:t.closePath(),s+=1;break;case zs:t.rect(e[s+1],e[s+2],e[s+3],e[s+4]),s+=5;break;case Ns:t.roundRect(e[s+1],e[s+2],e[s+3],e[s+4],[e[s+5],e[s+6],e[s+7],e[s+8]]),s+=9;break;case Ys:t.roundRect(e[s+1],e[s+2],e[s+3],e[s+4],e[s+5]),s+=6;break;case Xs:t.ellipse(e[s+1],e[s+2],e[s+3],e[s+4],e[s+5]*D,e[s+6]*D,e[s+7]*D,e[s+8]),s+=9;break;case Hs:t.ellipse(e[s+1],e[s+2],e[s+3],e[s+4],0,0,M,!1),s+=5;break;case Us:t.arc(e[s+1],e[s+2],e[s+3],e[s+4]*D,e[s+5]*D,e[s+6]),s+=7;break;case js:t.arc(e[s+1],e[s+2],e[s+3],0,M,!1),s+=4;break;case Vs:t.arcTo(e[s+1],e[s+2],e[s+3],e[s+4],e[s+5]),s+=6;break;default:return void Gs.error(`command: ${i} [index:${s}]`,e)}}},{M:qs,L:$s,C:Qs,Q:Js,Z:Zs,N:tr,D:er,X:ir,G:sr,F:rr,O:nr,P:or,U:ar}=Re,{toTwoPointBounds:hr,toTwoPointBoundsByQuadraticCurve:lr,arcTo:dr,arc:cr,ellipse:ur}=ti,{addPointBounds:_r,copy:pr,addPoint:gr,setPoint:fr,addBounds:yr,toBounds:mr}=_t,vr=Gt.get("PathBounds");let wr,xr,br;const Br={},kr={},Sr={},Pr={toBounds(t,e){Pr.toTwoPointBounds(t,kr),mr(kr,e)},toTwoPointBounds(t,e){if(!t||!t.length)return fr(e,0,0);let i,s,r,n,o,a=0,h=0,l=0;const d=t.length;for(;a<d;)switch(o=t[a],0===a&&(o===Zs||o===Qs||o===Js?fr(e,h,l):fr(e,t[a+1],t[a+2])),o){case qs:case $s:h=t[a+1],l=t[a+2],gr(e,h,l),a+=3;break;case Qs:r=t[a+5],n=t[a+6],hr(h,l,t[a+1],t[a+2],t[a+3],t[a+4],r,n,Br),_r(e,Br),h=r,l=n,a+=7;break;case Js:i=t[a+1],s=t[a+2],r=t[a+3],n=t[a+4],lr(h,l,i,s,r,n,Br),_r(e,Br),h=r,l=n,a+=5;break;case Zs:a+=1;break;case tr:h=t[a+1],l=t[a+2],yr(e,h,l,t[a+3],t[a+4]),a+=5;break;case er:case ir:h=t[a+1],l=t[a+2],yr(e,h,l,t[a+3],t[a+4]),a+=o===er?9:6;break;case sr:ur(null,t[a+1],t[a+2],t[a+3],t[a+4],t[a+5],t[a+6],t[a+7],t[a+8],Br,Sr),0===a?pr(e,Br):_r(e,Br),h=Sr.x,l=Sr.y,a+=9;break;case rr:h=t[a+1],l=t[a+2],xr=t[a+3],br=t[a+4],yr(e,h-xr,l-br,2*xr,2*br),h+=xr,a+=5;break;case nr:cr(null,t[a+1],t[a+2],t[a+3],t[a+4],t[a+5],t[a+6],Br,Sr),0===a?pr(e,Br):_r(e,Br),h=Sr.x,l=Sr.y,a+=7;break;case or:h=t[a+1],l=t[a+2],wr=t[a+3],yr(e,h-wr,l-wr,2*wr,2*wr),h+=wr,a+=4;break;case ar:dr(null,h,l,t[a+1],t[a+2],t[a+3],t[a+4],t[a+5],Br,Sr),0===a?pr(e,Br):_r(e,Br),h=Sr.x,l=Sr.y,a+=6;break;default:return void vr.error(`command: ${o} [index:${a}]`,t)}}},{M:Rr,L:Cr,Z:Tr}=Re,{getCenterX:Er,getCenterY:Lr}=rt,{arcTo:Or}=fs,Ar={smooth(t,e,i){let s,r,n,o=0,a=0,h=0,l=0,d=0,c=0,u=0,_=0,p=0;const g=t.length,f=[];for(;o<g;){switch(s=t[o],s){case Rr:l=_=t[o+1],d=p=t[o+2],o+=3,t[o]===Cr?(c=t[o+1],u=t[o+2],f.push(Rr,Er(l,c),Lr(d,u))):f.push(Rr,l,d);break;case Cr:switch(a=t[o+1],h=t[o+2],o+=3,t[o]){case Cr:Or(f,a,h,t[o+1],t[o+2],e,_,p);break;case Tr:Or(f,a,h,l,d,e,_,p);break;default:f.push(Cr,a,h)}_=a,p=h;break;case Tr:r!==Tr&&(Or(f,l,d,c,u,e,_,p),f.push(Tr)),o+=1;break;default:n=Ae[s];for(let e=0;e<n;e++)f.push(t[o+e]);o+=n}r=s}return s!==Tr&&(f[1]=l,f[2]=d),f}};function Dr(t){return new As(t)}const Mr=Dr();Se.creator=Dr(),Se.parse=Gi.parse,Se.convertToCanvasData=Gi.toCanvasData;const{drawRoundRect:Wr}=De;function Ir(t){!function(t){t&&!t.roundRect&&(t.roundRect=function(t,e,i,s,r){Wr(this,t,e,i,s,r)})}(t)}const Fr={alphaPixelTypes:["png","webp","svg"],upperCaseTypeMap:{},mineType:t=>!t||t.startsWith("image")?t:("jpg"===t&&(t="jpeg"),"image/"+t),fileType(t){const e=t.split(".");return e[e.length-1]},isOpaqueImage(t){const e=zr.fileType(t);return["jpg","jpeg"].some(t=>t===e)},getExportOptions(t){switch(typeof t){case"object":return t;case"number":return{quality:t};case"boolean":return{blob:t};default:return{}}}},zr=Fr;zr.alphaPixelTypes.forEach(t=>zr.upperCaseTypeMap[t]=t.toUpperCase());const Nr=Gt.get("TaskProcessor");class Yr{constructor(t){this.parallel=!0,this.time=1,this.id=e.create(e.TASK),this.task=t}run(){return de(this,void 0,void 0,function*(){try{this.task&&!this.isComplete&&this.parent.running&&(yield this.task())}catch(t){Nr.error(t)}})}complete(){this.isComplete=!0,this.parent=null,this.task=null}cancel(){this.isCancel=!0,this.complete()}}class Xr{get total(){return this.list.length+this.delayNumber}get finishedIndex(){return this.isComplete?0:this.index+this.parallelSuccessNumber}get remain(){return this.isComplete?this.total:this.total-this.finishedIndex}get percent(){const{total:t}=this;let e=0,i=0;for(let s=0;s<t;s++)s<=this.finishedIndex?(i+=this.list[s].time,s===this.finishedIndex&&(e=i)):e+=this.list[s].time;return this.isComplete?1:i/e}constructor(t){this.config={parallel:6},this.list=[],this.running=!1,this.isComplete=!0,this.index=0,this.delayNumber=0,t&&f.assign(this.config,t),this.empty()}add(t,e){let i,s,r,o;const a=new Yr(t);return a.parent=this,l(e)?o=e:e&&(s=e.parallel,i=e.start,r=e.time,o=e.delay),r&&(a.time=r),!1===s&&(a.parallel=!1),n(o)?this.push(a,i):(this.delayNumber++,setTimeout(()=>{this.delayNumber&&(this.delayNumber--,this.push(a,i))},o)),this.isComplete=!1,a}push(t,e){this.list.push(t),!1===e||this.timer||(this.timer=setTimeout(()=>this.start()))}empty(){this.index=0,this.parallelSuccessNumber=0,this.list=[],this.parallelList=[],this.d