author | Radek Brich <radek.brich@devl.cz> |
Wed, 23 Apr 2008 10:38:33 +0200 | |
branch | pyrit |
changeset 78 | 9569e9f35374 |
parent 75 | 20dee9819b17 |
child 90 | f6a72eb99631 |
permissions | -rwxr-xr-x |
72
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
1 |
#!/usr/bin/python |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
2 |
|
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
3 |
# read nff data from standart input and render image to render_nff.png |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
4 |
# see http://tog.acm.org/resources/SPD/ |
73
a5127346fbcd
correct camera angle of view
Radek Brich <radek.brich@devl.cz>
parents:
72
diff
changeset
|
5 |
# cylinders are not implemented |
72
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
6 |
|
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
7 |
from raytracer import Raytracer, Camera, Light, Material, Sphere, NormalVertex, Triangle |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
8 |
from math import pi |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
9 |
import sys, Image |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
10 |
|
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
11 |
rt = Raytracer() |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
12 |
imagesize = (800, 600) |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
13 |
|
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
14 |
mat = Material(colour=(1.0, 1.0, 1.0)) |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
15 |
|
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
16 |
f = sys.stdin |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
17 |
while True: |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
18 |
line = f.readline() |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
19 |
if line == "": |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
20 |
break; |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
21 |
ln = line.split() |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
22 |
if ln[0] == 'v': # Viewpoint location |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
23 |
# from |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
24 |
ln = f.readline().split() |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
25 |
assert ln[0] == 'from' |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
26 |
eye = (float(ln[1]), float(ln[2]), float(ln[3])) |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
27 |
# at |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
28 |
ln = f.readline().split() |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
29 |
assert ln[0] == 'at' |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
30 |
lookat = (float(ln[1]), float(ln[2]), float(ln[3])) |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
31 |
# up |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
32 |
ln = f.readline().split() |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
33 |
assert ln[0] == 'up' |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
34 |
up = (float(ln[1]), float(ln[2]), float(ln[3])) |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
35 |
# angle |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
36 |
ln = f.readline().split() |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
37 |
assert ln[0] == 'angle' |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
38 |
angle = float(ln[1]) |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
39 |
# hither |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
40 |
ln = f.readline().split() |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
41 |
assert ln[0] == 'hither' |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
42 |
hither = float(ln[1]) |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
43 |
# resolution |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
44 |
ln = f.readline().split() |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
45 |
assert ln[0] == 'resolution' |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
46 |
imagesize = (int(ln[1]), int(ln[2])) |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
47 |
# set camera as specified |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
48 |
cam = Camera(eye=eye, lookat=lookat, up=up) |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
49 |
cam.setAngle(angle/180*pi) |
75
20dee9819b17
unify capitalization of method names in C++ and Python
Radek Brich <radek.brich@devl.cz>
parents:
74
diff
changeset
|
50 |
rt.setCamera(cam) |
72
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
51 |
elif ln[0] == 'b': # Background color |
75
20dee9819b17
unify capitalization of method names in C++ and Python
Radek Brich <radek.brich@devl.cz>
parents:
74
diff
changeset
|
52 |
rt.setBgColour((float(ln[1]), float(ln[2]), float(ln[3]))) |
72
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
53 |
elif ln[0] == 'l': # Light |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
54 |
pos = (float(ln[1]), float(ln[2]), float(ln[3])) |
75
20dee9819b17
unify capitalization of method names in C++ and Python
Radek Brich <radek.brich@devl.cz>
parents:
74
diff
changeset
|
55 |
rt.addLight(Light(position=pos)) |
72
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
56 |
elif ln[0] == 'f': # Fill color and shading parameters |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
57 |
colour = (float(ln[1]), float(ln[2]), float(ln[3])) |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
58 |
mat = Material(colour=colour) |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
59 |
mat.setPhong(0,float(ln[4]),float(ln[5]),float(ln[6])) |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
60 |
mat.setTransmissivity(float(ln[7]),float(ln[8])) |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
61 |
elif ln[0] == 's': # Sphere |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
62 |
center = (float(ln[1]), float(ln[2]), float(ln[3])) |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
63 |
radius = float(ln[4]) |
75
20dee9819b17
unify capitalization of method names in C++ and Python
Radek Brich <radek.brich@devl.cz>
parents:
74
diff
changeset
|
64 |
rt.addShape(Sphere(centre=center, radius=radius, material=mat)) |
72
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
65 |
elif ln[0] == 'p': # Polygon |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
66 |
vertex_count = int(ln[1]) |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
67 |
vertices = [] |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
68 |
for i in range(vertex_count): |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
69 |
ln = f.readline().split() |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
70 |
vertex = (float(ln[0]), float(ln[1]), float(ln[2])) |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
71 |
vertices.append(NormalVertex(vertex)) |
75
20dee9819b17
unify capitalization of method names in C++ and Python
Radek Brich <radek.brich@devl.cz>
parents:
74
diff
changeset
|
72 |
rt.addShape(Triangle(vertices[0], vertices[1], vertices[2], mat)) |
72
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
73 |
for i in range(vertex_count)[3:]: |
75
20dee9819b17
unify capitalization of method names in C++ and Python
Radek Brich <radek.brich@devl.cz>
parents:
74
diff
changeset
|
74 |
rt.addShape(Triangle(vertices[0], vertices[i-1], vertices[i], mat)) |
73
a5127346fbcd
correct camera angle of view
Radek Brich <radek.brich@devl.cz>
parents:
72
diff
changeset
|
75 |
elif ln[0] == 'pp': # Polygonal patch |
a5127346fbcd
correct camera angle of view
Radek Brich <radek.brich@devl.cz>
parents:
72
diff
changeset
|
76 |
mat.setSmooth(True) |
a5127346fbcd
correct camera angle of view
Radek Brich <radek.brich@devl.cz>
parents:
72
diff
changeset
|
77 |
vertex_count = int(ln[1]) |
a5127346fbcd
correct camera angle of view
Radek Brich <radek.brich@devl.cz>
parents:
72
diff
changeset
|
78 |
vertices = [] |
a5127346fbcd
correct camera angle of view
Radek Brich <radek.brich@devl.cz>
parents:
72
diff
changeset
|
79 |
for i in range(vertex_count): |
a5127346fbcd
correct camera angle of view
Radek Brich <radek.brich@devl.cz>
parents:
72
diff
changeset
|
80 |
ln = f.readline().split() |
a5127346fbcd
correct camera angle of view
Radek Brich <radek.brich@devl.cz>
parents:
72
diff
changeset
|
81 |
vertex = (float(ln[0]), float(ln[1]), float(ln[2])) |
a5127346fbcd
correct camera angle of view
Radek Brich <radek.brich@devl.cz>
parents:
72
diff
changeset
|
82 |
normal = (float(ln[3]), float(ln[4]), float(ln[5])) |
a5127346fbcd
correct camera angle of view
Radek Brich <radek.brich@devl.cz>
parents:
72
diff
changeset
|
83 |
vertices.append(NormalVertex(vertex, normal)) |
75
20dee9819b17
unify capitalization of method names in C++ and Python
Radek Brich <radek.brich@devl.cz>
parents:
74
diff
changeset
|
84 |
rt.addShape(Triangle(vertices[0], vertices[1], vertices[2], mat)) |
73
a5127346fbcd
correct camera angle of view
Radek Brich <radek.brich@devl.cz>
parents:
72
diff
changeset
|
85 |
for i in range(vertex_count)[3:]: |
75
20dee9819b17
unify capitalization of method names in C++ and Python
Radek Brich <radek.brich@devl.cz>
parents:
74
diff
changeset
|
86 |
rt.addShape(Triangle(vertices[0], vertices[i-1], vertices[i], mat)) |
74
09aedbf5f95f
kd-tree traversal - avoid dynamic memory allocation
Radek Brich <radek.brich@devl.cz>
parents:
73
diff
changeset
|
87 |
elif ln[0] == '#': # Comment |
09aedbf5f95f
kd-tree traversal - avoid dynamic memory allocation
Radek Brich <radek.brich@devl.cz>
parents:
73
diff
changeset
|
88 |
pass |
72
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
89 |
else: |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
90 |
print "Not implemented:", line |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
91 |
f.close() |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
92 |
|
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
93 |
data = rt.render(imagesize) |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
94 |
img = Image.fromstring("RGB", imagesize, data) |
7c3f38dff082
kd-tree building - check all axes for best split, add additional shape-bbox check
Radek Brich <radek.brich@devl.cz>
parents:
diff
changeset
|
95 |
img.save('render_nff.png') |