generated from taichi-dev/voxel-challenge
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrandomsphere-night.py
33 lines (26 loc) · 1.1 KB
/
randomsphere-night.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
from scene import Scene
import taichi as ti
from taichi.math import *
scene = Scene(voxel_edges=0, exposure=10)
scene.set_floor(-1.0, (1.0, 1.0, 1.0)) # height, color
scene.set_background_color((1, 1, 1))
scene.set_directional_light((1,1,1), 0.1, (.002, .002, .002)) # direction, noise, color
@ti.func
def sphere(pos, r, mat, color):
for i,j,k in ti.ndrange((-64,64),(-64,64),(-64,64)):
if (i-pos[0])**2 + (j-pos[1])**2 + (k-pos[2])**2 < r*r:
scene.set_voxel(vec3(i,j,k), mat, color)
@ti.kernel
def initialize_voxels():
# Your code here! :-)
# scene.set_voxel(vec3(0, 10, 0), 2, vec3(0.9, 0.1, 0.1)) # idx, mat, color
for s in range(48):
pos = [(ti.random()-0.5)*100, (ti.random()-0.5)*100, (ti.random()-0.5)*100]
mat = 1
sphere(pos, ti.random()*14 , mat, vec3(ti.random(), ti.random(), ti.random()))
for s in range(12):
pos = [(ti.random()-0.5)*100, (ti.random()-0.5)*100, (ti.random()-0.5)*100]
mat = 2
sphere(pos, ti.random()*8 , mat, vec3(ti.random(), ti.random(), ti.random()))
initialize_voxels()
scene.finish()