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