generated from taichi-dev/voxel-challenge
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathexample3.py
36 lines (27 loc) · 1.02 KB
/
example3.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
34
35
36
from scene import Scene
import taichi as ti
from taichi.math import *
scene = Scene(voxel_edges=0, exposure=30)
scene.set_floor(0, (1.0, 1.0, 1.0))
n = 50
@ti.kernel
def initialize_voxels():
for i in range(n):
for j in range(n):
scene.set_voxel(vec3(0, i, j), 1, vec3(0.9, 0.3, 0.3))
scene.set_voxel(vec3(n, i, j), 1, vec3(0.3, 0.9, 0.3))
scene.set_voxel(vec3(i, n, j), 1, vec3(1, 1, 1))
scene.set_voxel(vec3(i, 0, j), 1, vec3(1, 1, 1))
scene.set_voxel(vec3(i, j, 0), 1, vec3(1, 1, 1))
for i in range(-n // 8, n // 8):
for j in range(-n // 8, n // 8):
scene.set_voxel(vec3(i + n // 2, n, j + n // 2), 2, vec3(1, 1, 1))
for i_ in range(n // 8 * 3):
i = i_ * 2
for j in range(n // 4 * 3):
scene.set_voxel(
vec3(j + n // 8, n // 4 + ti.sin(
(i + j) / n * 30) * 0.05 * n + i / 10, -i + n // 8 * 7), 1,
vec3(0.3, 0.3, 0.9))
initialize_voxels()
scene.finish()