Advertisement
FlyFar

RotatingDonut

Aug 12th, 2023
1,154
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C 0.95 KB | Cybersecurity | 0 0
  1. // Developer- Andy Sloane (https://www.a1k0n.net/about.html)
  2. // Intro- Shows a 3d animated doughnut with ASCII art.
  3. // Details- https://www.a1k0n.net/2011/07/20/donut-math.html
  4.  
  5.              k;double sin()
  6.          ,cos();main(){float A=
  7.        0,B=0,i,j,z[1760];char b[
  8.      1760];/**###/////####**/for(;;
  9.   ){memset(b,32,1760);memset(z,0,7040)
  10.   ;for(j=0;6.28>j;j+=0.07)for(i=0;6.28
  11.  >i;i+=0.02){float c=sin(i),d=cos(j),e=
  12.  sin(A),f=sin(j),g=cos(A),h=d+2,D=1/(c*
  13.  h*e+f*g+5),l=cos      (i),m=cos(B),n=s\
  14. in(B),t=c*h*g-f*        e;int x=40+30*D*
  15. (l*h*m-t*n),y=            12+15*D*(l*h*n
  16. +t*m),o=x+80*y,          N=8*((f*e-c*d*g
  17.  )*m-c*d*e-f*g-l        *d*n);if(22>y&&
  18.  y>0&&x>0&&80>x&&D>z[o]){z[o]=D;;;b[o]=
  19.  ".,-~:;=!*#$@"[N>0?N:0];}}/*#****!!-*/
  20.   /**#++#|||||#**/for(k=0;1761>k;k++)
  21.    putchar(k%80?b[k]:10);A+=0.04;B+=
  22.      0.02;int strt=clock();while((
  23.        clock()-strt)<(300));///
  24.          system("cls");}}/***!
  25.              ..,--____--*/
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement