pull down to refresh

This was fun to make. I haven't even searched if people do this reguarly.
#!/usr/bin/env python3
R=range
import curses as B,math as A,time as K,random as b
def C(C):
	L=True;C.nodelay(L);B.curs_set(0);S=False
	if B.has_colors():
		S=L;B.start_color();T=[B.COLOR_BLUE,B.COLOR_CYAN,B.COLOR_GREEN,B.COLOR_YELLOW,B.COLOR_MAGENTA,B.COLOR_RED,B.COLOR_WHITE]
		for(c,d)in enumerate(T):B.init_pair(c+1,d,B.COLOR_BLACK)
		e=len(T)
	U=' .:-=+*#%@';D=0;E=0;V=3;M=K.time();f=5
	while L:
		W,X=C.getmaxyx();g,h=X/2,W/2;H=2.
		for F in R(W):
			for G in R(X-1):
				I=G-g;J=F-h
				if E==0:i=A.sin(G/H+D);j=A.cos(F/H-D);k=A.sin(A.sqrt(I*I+J*J)/H-D);l=A.atan2(J,I);m=A.sin(l+D);N=A.sin((G+F)/H+D);O=i+j+k+m+N
				elif E==1:O=A.sin((G+D)*.3)+A.sin((F-D)*.3)+A.sin((G+F)*.1+D)
				else:Y=A.sqrt(I*I+J*J);O=A.sin(Y/H-D)+A.cos(Y/H+D)+A.sin(A.atan2(J,I)*4+D)
				n=A.sin(O);o=(n+1)/2;Z=int(o*(len(U)-1));a=U[Z]
				try:
					if S:N=Z%e;C.addch(F,G,a,B.color_pair(N+1))
					else:C.addch(F,G,a)
				except B.error:pass
		C.refresh();D+=.1;K.sleep(.05);P=C.getch()
		if P!=-1:
			try:
				if chr(P).lower()=='q':break
				elif chr(P)==' ':E=(E+1)%V;M=K.time()
			except:pass
		if K.time()-M>f:
			Q=E
			while Q==E:Q=b.randint(0,V-1)
			E=Q;M=K.time()
if __name__=='__main__':
	try:B.wrapper(C)
	except KeyboardInterrupt:pass
This is very cool.
reply
What does it output? Can you share that?
reply
This website will run it in the browser:
reply
Requires an account?
reply