asciify-engine 1.0.7 → 1.0.8

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.
package/dist/embed.js CHANGED
@@ -1 +1 @@
1
- (function(){'use strict';function en(t){let f=atob(t),n=new Uint8Array(f.length);for(let s=0;s<f.length;s++)n[s]=f.charCodeAt(s);return n}function fn(t){return Array.isArray(t)?t.map(en):[en(t)]}function Mn(t,f,n,s){let e=t[0],r=1+(n*s+f)*e;if(e===4){let M=Math.round(.299*t[r]+.587*t[r+1]+.114*t[r+2]);return {r:t[r],g:t[r+1],b:t[r+2],a:t[r+3],l:M}}return {r:t[r],g:t[r],b:t[r],l:t[r],a:t[r+1]}}function gn(t){return t*t*(3-2*t)}function dn(t,f){if(t==="fullcolor")return (n,s,e)=>`rgb(${n},${s},${e})`;if(t==="matrix")return (n,s,e)=>`rgb(0,${Math.floor(.299*n+.587*s+.114*e)},0)`;if(t==="accent"){let n=f.replace("#",""),s=parseInt(n.substring(0,2),16),e=parseInt(n.substring(2,4),16),r=parseInt(n.substring(4,6),16);return (M,y,c)=>{let a=(.299*M+.587*y+.114*c)/255;return `rgb(${Math.floor(s*a)},${Math.floor(e*a)},${Math.floor(r*a)})`}}return (n,s,e)=>{let r=Math.floor(.299*n+.587*s+.114*e);return `rgb(${r},${r},${r})`}}function bn(t,f,n,s,e,r,M){let y=f,c=M*y;switch(t){case "wave":{let a=Math.sin(n/e*Math.PI*4+c*3)*.5+.5,o=Math.sin(s/r*Math.PI*3+c*2)*.5+.5;return .3+.7*(a*.6+o*.4)}case "pulse":{let a=e/2,o=r/2,u=Math.sqrt((n-a)**2+(s-o)**2),h=Math.sqrt(a*a+o*o);return .2+.8*(Math.sin(u/h*Math.PI*6-c*4)*.5+.5)}case "rain":return .1+.9*(Math.sin(s/r*Math.PI*8-c*5+n*.3)*.5+.5)*(Math.sin(n/e*Math.PI*2+c)*.3+.7);case "breathe":return Math.max(.1,Math.min(1,Math.sin(c*2)*.3+.7+Math.sin((n+s)*.1+c)*.1));case "sparkle":{let a=Math.sin(n*127.1+s*311.7+Math.floor(c*8)*43758.5453)*43758.5453,o=a-Math.floor(a);return o>.7?1:.15+o*.4}case "glitch":{let a=Math.floor(s/(r*.05)),o=Math.sin(a*43.23+Math.floor(c*6)*17.89)*43758.5453;if(o-Math.floor(o)>.85){let h=Math.sin(c*30+a)*.5+.5;return h<.3?0:h}return 1}case "spiral":{let a=e/2,o=r/2,u=n-a,h=s-o,g=Math.atan2(h,u),$=Math.sqrt(u*u+h*h),k=Math.sqrt(a*a+o*o);return .15+.85*(Math.sin(g*3+$/k*Math.PI*8-c*3)*.5+.5)}case "typewriter":{let a=e*r,o=s*e+n,u=c*.5%1,h=u*a*1.3,g=o-h;return g>0?0:Math.min(1,Math.max(0,1+g/(a*.15)))}case "scatter":{let a=e/2,o=r/2,u=n-a,h=s-o,g=Math.sqrt(u*u+h*h)/Math.sqrt(a*a+o*o),$=Math.sin(c*1.5)*.5+.5;return g>$?Math.max(0,1-(g-$)*3):.7+.3*Math.sin(g*10-c*2)}default:return 1}}function pn(t,f,n){let s=document.getElementById(t);if(!s){console.error(`Asciify: canvas #${t} not found`);return}let e=s.getContext("2d"),{r,c:M,w:y,h:c}=n,a=n.fps??10,o=n.cs??" .:-=+*#%@",u=n.cm??"grayscale",h=n.ac??"#ffffff",g=n.as??"none",$=n.sp??1,k=n.inv??false,l=n.hs??0,rn=n.hr??.3,E=n.he??"spotlight",T=n.hc??"#ffffff",sn=n.dr??.7,an=n.dots??false,K=n.anim??false,on=parseInt(T.slice(1,3),16)||255,cn=parseInt(T.slice(3,5),16)||255,hn=parseInt(T.slice(5,7),16)||255,I=y/M,w=c/r,N=fn(f),ln=dn(u,h),F=l>0,Q=g!=="none"||K,L=-1,U=-1,v=0,W=.5,X=.5,Y=0,V=0;F&&(s.addEventListener("mousemove",q=>{let P=s.getBoundingClientRect();L=(q.clientX-P.left)/P.width,U=(q.clientY-P.top)/P.height;}),s.addEventListener("mouseleave",()=>{L=-1,U=-1;}));function D(q){let P=q/1e3;K&&q-V>=1e3/a&&(Y=(Y+1)%N.length,V=q);let mn=N[Y];e.clearRect(0,0,y,c),e.fillStyle="#0a0a0a",e.fillRect(0,0,y,c),F&&(L>=0?(W+=(L-W)*.1,X+=(U-X)*.1,v+=(1-v)*.12):(v*=.96,v<.003&&(v=0)));for(let R=0;R<r;R++)for(let S=0;S<M;S++){let x=Mn(mn,S,R,M);if(x.a<10)continue;let G=bn(g,$,S,R,M,r,P);if(G<.05)continue;let C=1,J=0,j=0,B=0,A=0;if(F&&v>.003){let m=S/M,d=R/r,b=m-W,p=d-X,nn=Math.sqrt(b*b+p*p),tn=.08+rn*.35+l*.04;if(nn<tn){let un=1-nn/tn,i=gn(un)*v,O=Math.atan2(p,b);if(E==="spotlight"){C=1+i*l*1.8;let H=i*i*l*.6;J=Math.cos(O)*H*I,j=Math.sin(O)*H*w,B=i*l*.4,A=i*i*l*.25;}else if(E==="magnify")C=1+i*l*2.5,B=i*l*.15;else if(E==="repel"){C=1+i*l*.3;let H=i*i*l*1.2;J=Math.cos(O)*H*I,j=Math.sin(O)*H*w;}else E==="glow"?(B=i*l*.8,A=i*l*.4):E==="colorShift"&&(C=1+i*l*.4,B=i*l*.2,A=i*l*.7);}}let Z=S*I+I/2+J,_=R*w+w/2+j,z=ln(x.r,x.g,x.b);if(A>0){let m=z.match(/rgb\((\d+),(\d+),(\d+)\)/);if(m){let d=+m[1],b=+m[2],p=+m[3];z=`rgb(${Math.min(255,Math.round(d+(on-d)*A))},${Math.min(255,Math.round(b+(cn-b)*A))},${Math.min(255,Math.round(p+(hn-p)*A))})`;}}if(e.globalAlpha=Math.min(1,x.a/255*G*(1+B)),e.fillStyle=z,an){let m=x.l/255;if(k&&(m=1-m),m<.02)continue;let d=Math.min(I,w)*.5*sn*m*G*C;if(d<.3)continue;e.beginPath(),e.arc(Z,_,d,0,Math.PI*2),e.fill();}else {let m=x.l/255;k&&(m=1-m);let d=Math.floor(m*(o.length-1)),b=o[Math.max(0,Math.min(o.length-1,d))];if(b===" ")continue;let p=Math.min(I/.55,w)*.9*C;e.font=`${p}px "JetBrains Mono",monospace`,e.textAlign="center",e.textBaseline="middle",e.fillText(b,Z,_);}}e.globalAlpha=1,(Q||F)&&requestAnimationFrame(D);}Q||F?requestAnimationFrame(D):D(0);}window.Asciify=pn;})();
1
+ (function(){'use strict';function et(n){let m=atob(n),t=new Uint8Array(m.length);for(let a=0;a<m.length;a++)t[a]=m.charCodeAt(a);return t}function dt(n){return Array.isArray(n)?n.map(et):[et(n)]}function Mt(n,m,t,a){let e=n[0],r=1+(t*a+m)*e;if(e===4){let d=Math.round(.299*n[r]+.587*n[r+1]+.114*n[r+2]);return {r:n[r],g:n[r+1],b:n[r+2],a:n[r+3],l:d}}return {r:n[r],g:n[r],b:n[r],l:n[r],a:n[r+1]}}function gt(n){return n*n*(3-2*n)}function bt(n,m){if(n==="fullcolor")return (t,a,e)=>`rgb(${t},${a},${e})`;if(n==="matrix")return (t,a,e)=>`rgb(0,${Math.floor(.299*t+.587*a+.114*e)},0)`;if(n==="accent"){let t=m.replace("#",""),a=parseInt(t.substring(0,2),16),e=parseInt(t.substring(2,4),16),r=parseInt(t.substring(4,6),16);return (d,y,o)=>{let s=(.299*d+.587*y+.114*o)/255;return `rgb(${Math.floor(a*s)},${Math.floor(e*s)},${Math.floor(r*s)})`}}return (t,a,e)=>{let r=Math.floor(.299*t+.587*a+.114*e);return `rgb(${r},${r},${r})`}}function pt(n,m,t,a,e,r,d){let y=m,o=d*y;switch(n){case "wave":{let s=Math.sin(t/e*Math.PI*4+o*3)*.5+.5,i=Math.sin(a/r*Math.PI*3+o*2)*.5+.5;return .3+.7*(s*.6+i*.4)}case "pulse":{let s=e/2,i=r/2,f=Math.sqrt((t-s)**2+(a-i)**2),l=Math.sqrt(s*s+i*i);return .2+.8*(Math.sin(f/l*Math.PI*6-o*4)*.5+.5)}case "rain":return .1+.9*(Math.sin(a/r*Math.PI*8-o*5+t*.3)*.5+.5)*(Math.sin(t/e*Math.PI*2+o)*.3+.7);case "breathe":return Math.max(.1,Math.min(1,Math.sin(o*2)*.3+.7+Math.sin((t+a)*.1+o)*.1));case "sparkle":{let s=Math.sin(t*127.1+a*311.7+Math.floor(o*8)*43758.5453)*43758.5453,i=s-Math.floor(s);return i>.7?1:.15+i*.4}case "glitch":{let s=Math.floor(a/(r*.05)),i=Math.sin(s*43.23+Math.floor(o*6)*17.89)*43758.5453;if(i-Math.floor(i)>.85){let l=Math.sin(o*30+s)*.5+.5;return l<.3?0:l}return 1}case "spiral":{let s=e/2,i=r/2,f=t-s,l=a-i,M=Math.atan2(l,f),I=Math.sqrt(f*f+l*l),H=Math.sqrt(s*s+i*i);return .15+.85*(Math.sin(M*3+I/H*Math.PI*8-o*3)*.5+.5)}case "typewriter":{let s=e*r,i=a*e+t,f=o*.5%1,l=f*s*1.3,M=i-l;return M>0?0:Math.min(1,Math.max(0,1+M/(s*.15)))}case "scatter":{let s=e/2,i=r/2,f=t-s,l=a-i,M=Math.sqrt(f*f+l*l)/Math.sqrt(s*s+i*i),I=Math.sin(o*1.5)*.5+.5;return M>I?Math.max(0,1-(M-I)*3):.7+.3*Math.sin(M*10-o*2)}default:return 1}}function at(n,m,t){let a=document.getElementById(n);if(!a){console.error(`Asciify: canvas #${n} not found`);return}let e=a.getContext("2d"),{r,c:d,w:y,h:o}=t,s=t.fps??10,i=t.cs??" .:-=+*#%@",f=t.cm??"grayscale",l=t.ac??"#ffffff",M=t.as??"none",I=t.sp??1,H=t.inv??false,h=t.hs??0,st=t.hr??.3,P=t.he??"spotlight",k=t.hc??"#ffffff",it=t.dr??.7,ot=t.dots??false,z=t.anim??false,ct=parseInt(k.slice(1,3),16)||255,lt=parseInt(k.slice(3,5),16)||255,ht=parseInt(k.slice(5,7),16)||255,$=y/d,w=o/r,K=dt(m),ut=bt(f,l),R=h>0,Q=M!=="none"||z,B=-1,U=-1,A=0,D=.5,J=.5,W=0,V=0;R&&(a.addEventListener("mousemove",S=>{let E=a.getBoundingClientRect();B=(S.clientX-E.left)/E.width,U=(S.clientY-E.top)/E.height;}),a.addEventListener("mouseleave",()=>{B=-1,U=-1;}));function N(S){let E=S/1e3;z&&S-V>=1e3/s&&(W=(W+1)%K.length,V=S);let mt=K[W];e.clearRect(0,0,y,o),e.fillStyle="#0a0a0a",e.fillRect(0,0,y,o),R&&(B>=0?(D+=(B-D)*.1,J+=(U-J)*.1,A+=(1-A)*.12):(A*=.96,A<.003&&(A=0)));for(let q=0;q<r;q++)for(let C=0;C<d;C++){let v=Mt(mt,C,q,d);if(v.a<10)continue;let X=pt(M,I,C,q,d,r,E);if(X<.05)continue;let O=1,Y=0,G=0,L=0,x=0;if(R&&A>.003){let u=C/d,g=q/r,b=u-D,p=g-J,tt=Math.sqrt(b*b+p*p),nt=.08+st*.35+h*.04;if(tt<nt){let ft=1-tt/nt,c=gt(ft)*A,T=Math.atan2(p,b);if(P==="spotlight"){O=1+c*h*1.8;let F=c*c*h*.6;Y=Math.cos(T)*F*$,G=Math.sin(T)*F*w,L=c*h*.4,x=c*c*h*.25;}else if(P==="magnify")O=1+c*h*2.5,L=c*h*.15;else if(P==="repel"){O=1+c*h*.3;let F=c*c*h*1.2;Y=Math.cos(T)*F*$,G=Math.sin(T)*F*w;}else P==="glow"?(L=c*h*.8,x=c*h*.4):P==="colorShift"&&(O=1+c*h*.4,L=c*h*.2,x=c*h*.7);}}let Z=C*$+$/2+Y,_=q*w+w/2+G,j=ut(v.r,v.g,v.b);if(x>0){let u=j.match(/rgb\((\d+),(\d+),(\d+)\)/);if(u){let g=+u[1],b=+u[2],p=+u[3];j=`rgb(${Math.min(255,Math.round(g+(ct-g)*x))},${Math.min(255,Math.round(b+(lt-b)*x))},${Math.min(255,Math.round(p+(ht-p)*x))})`;}}if(e.globalAlpha=Math.min(1,v.a/255*X*(1+L)),e.fillStyle=j,ot){let u=v.l/255;if(H&&(u=1-u),u<.02)continue;let g=Math.min($,w)*.5*it*u*X*O;if(g<.3)continue;e.beginPath(),e.arc(Z,_,g,0,Math.PI*2),e.fill();}else {let u=v.l/255;H&&(u=1-u);let g=Math.floor(u*(i.length-1)),b=i[Math.max(0,Math.min(i.length-1,g))];if(b===" ")continue;let p=Math.min($/.55,w)*.9*O;e.font=`${p}px "JetBrains Mono",monospace`,e.textAlign="center",e.textBaseline="middle",e.fillText(b,Z,_);}}e.globalAlpha=1,(Q||R)&&requestAnimationFrame(N);}Q||R?requestAnimationFrame(N):N(0);}window.Asciify=at;function rt(){document.querySelectorAll("canvas[data-asciify-id]").forEach(n=>{let m=n.getAttribute("data-asciify-id"),t=n.getAttribute("data-asciify-src"),a=n.getAttribute("data-asciify-opts");if(!(!t||!a))try{let e=JSON.parse(a),r=JSON.parse(t);at(m,r,e);}catch(e){console.error("Asciify: failed to parse embed data on #"+m,e);}});}document.readyState==="loading"?document.addEventListener("DOMContentLoaded",rt):rt();})();
package/dist/index.cjs CHANGED
@@ -834,7 +834,7 @@ async function asciifyVideo(source, canvas, { fontSize = 10, style = "classic",
834
834
  cancelAnimationFrame(animId);
835
835
  };
836
836
  }
837
- var EMBED_CDN_VERSION = "1.0.7";
837
+ var EMBED_CDN_VERSION = "1.0.8";
838
838
  function buildEmbedOpts(options, rows, cols, width, height, fps, animated) {
839
839
  const o = {
840
840
  r: rows,
@@ -858,32 +858,31 @@ function buildEmbedOpts(options, rows, cols, width, height, fps, animated) {
858
858
  if (animated) o.anim = true;
859
859
  return JSON.stringify(o);
860
860
  }
861
+ var CDN_SCRIPT = `<script src="https://cdn.jsdelivr.net/npm/asciify-engine@${EMBED_CDN_VERSION}/dist/embed.js" async></script>`;
861
862
  function generateEmbedCode(frame, options, width, height) {
862
863
  const rows = frame.length;
863
864
  if (rows === 0) return "";
864
865
  const cols = frame[0].length;
865
- const isDots = options.renderMode === "dots";
866
- const data = serializeFrame(frame, !isDots);
866
+ const isFullColor = options.colorMode === "fullcolor";
867
+ const data = serializeFrame(frame, isFullColor);
867
868
  const id = `ar-${Math.random().toString(36).slice(2, 9)}`;
868
869
  const opts = buildEmbedOpts(options, rows, cols, width, height);
869
870
  return `<!-- Asciify Embed -->
870
- <canvas id="${id}" width="${width}" height="${height}" style="display:block"></canvas>
871
- <script src="https://cdn.jsdelivr.net/npm/asciify-engine@${EMBED_CDN_VERSION}/dist/embed.js"></script>
872
- <script>Asciify('${id}','${data}',${opts})</script>
871
+ <canvas data-asciify-id="${id}" data-asciify-src='"${data}"' data-asciify-opts='${opts}' width="${width}" height="${height}"></canvas>
872
+ ${CDN_SCRIPT}
873
873
  <!-- /Asciify Embed -->`;
874
874
  }
875
875
  function generateAnimatedEmbedCode(frames, options, fps, width, height) {
876
876
  if (frames.length === 0) return "";
877
877
  const rows = frames[0].length;
878
878
  const cols = frames[0][0].length;
879
- const isDots = options.renderMode === "dots";
880
- const allData = frames.map((f) => serializeFrame(f, !isDots));
879
+ const isFullColor = options.colorMode === "fullcolor";
880
+ const allData = frames.map((f) => serializeFrame(f, isFullColor));
881
881
  const id = `ar-${Math.random().toString(36).slice(2, 9)}`;
882
882
  const opts = buildEmbedOpts(options, rows, cols, width, height, fps, true);
883
883
  return `<!-- Asciify Animated Embed -->
884
- <canvas id="${id}" width="${width}" height="${height}" style="display:block"></canvas>
885
- <script src="https://cdn.jsdelivr.net/npm/asciify-engine@${EMBED_CDN_VERSION}/dist/embed.js"></script>
886
- <script>Asciify('${id}',${JSON.stringify(allData)},${opts})</script>
884
+ <canvas data-asciify-id="${id}" data-asciify-src='${JSON.stringify(allData)}' data-asciify-opts='${opts}' width="${width}" height="${height}"></canvas>
885
+ ${CDN_SCRIPT}
887
886
  <!-- /Asciify Animated Embed -->`;
888
887
  }
889
888
  function _fade(t) {