kopia lustrzana https://github.com/villares/sketch-a-day
				
				
				
			
		
			
	
	
		
			79 wiersze
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Plaintext
		
	
	
		
		
			
		
	
	
			79 wiersze
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Plaintext
		
	
	
|   | # Alexandre B A Villares - https://abav.lugaralgum.com/sketch-a-day | ||
|  | SKETCH_NAME, OUTPUT = "s147", ".gif"  # 180527 | ||
|  | 
 | ||
|  | add_library('gifAnimation') | ||
|  | from gif_export_wrapper import * | ||
|  | 
 | ||
|  | GRID_SIZE = 50 | ||
|  | 
 | ||
|  | def setup(): | ||
|  |     size(500, 500) | ||
|  |     print_text_for_readme(SKETCH_NAME, OUTPUT) | ||
|  |     border = 20 | ||
|  |     spacing = (width - border * 2) / GRID_SIZE | ||
|  |     Ponto.spacing = spacing | ||
|  |     for j in range(GRID_SIZE): | ||
|  |         for i in range(GRID_SIZE): | ||
|  |             Ponto.PONTOS.append(Ponto(border + spacing / 2 + i * spacing, | ||
|  |                                       border + spacing / 2 + j * spacing) | ||
|  |                                 ) | ||
|  |     for p in Ponto.PONTOS: | ||
|  |         p.set_neighbours() | ||
|  |              | ||
|  | 
 | ||
|  | def draw(): | ||
|  |     background(0) | ||
|  |     for p in Ponto.PONTOS: | ||
|  |         p.update() | ||
|  |          | ||
|  |     if frameCount > 100 and not frameCount % 2: | ||
|  |         gif_export(GifMaker, frames=200, filename=SKETCH_NAME) | ||
|  | 
 | ||
|  | class Ponto(): | ||
|  |     PONTOS = [] | ||
|  | 
 | ||
|  |     def __init__(self, x, y): | ||
|  |         self.x = x | ||
|  |         self.y = y | ||
|  |         self.px = x | ||
|  |         self.py = y | ||
|  |          | ||
|  |     def set_neighbours(self): | ||
|  |         self.ort_ngb = [] # orthogonal neighbours | ||
|  |         self.dia_ngb = [] # diagonal neighbours | ||
|  |         for p in Ponto.PONTOS: | ||
|  |             d = dist(p.px, p.py, self.px, self.py) | ||
|  |             if  Ponto.spacing * 1.41 < d < Ponto.spacing * 1.42: | ||
|  |                 self.dia_ngb.append(p) | ||
|  |             elif  d < Ponto.spacing * 1.41: | ||
|  |                 self.ort_ngb.append(p) | ||
|  | 
 | ||
|  |     def update(self): | ||
|  |         rx = random(-0.5, 0.5) | ||
|  |         ry = random(-0.5, 0.5) | ||
|  |         if abs(self.px + rx - self.x) < Ponto.spacing * 0.25: | ||
|  |             self.px += rx | ||
|  |         if abs(self.py + ry - self.y) < Ponto.spacing * 0.25: | ||
|  |             self.py += ry | ||
|  |         self.plot() | ||
|  | 
 | ||
|  |     def plot(self): | ||
|  |         for p in self.ort_ngb + self.dia_ngb: | ||
|  |             d = dist(p.px, p.py, self.px, self.py) | ||
|  |             if  Ponto.spacing * .9 < d <= Ponto.spacing * 1.2: | ||
|  |                 stroke(128, 0, 0) | ||
|  |                 line(p.px, p.py, self.px, self.py) | ||
|  |             elif  d < Ponto.spacing * 0.9: | ||
|  |                 stroke(255)     | ||
|  |                 line(p.px, p.py, self.px, self.py) | ||
|  | 
 | ||
|  | 
 | ||
|  | def print_text_for_readme(name, output): | ||
|  |     println(""" | ||
|  |  | ||
|  | 
 | ||
|  | {1}: [code](https://github.com/villares/sketch-a-day/tree/master/{0}) [[Py.Processing](https://villares.github.io/como-instalar-o-processing-modo-python/index-EN)] | ||
|  | 
 | ||
|  | """.format(name, name[1:], output) | ||
|  |     ) |