| author | Radek Brich <radek.brich@devl.cz> | 
| Thu, 29 Nov 2007 18:30:16 +0100 | |
| branch | pyrit | 
| changeset 20 | f22952603f29 | 
| parent 19 | 4e0955fca797 | 
| child 21 | 79b516a3803d | 
| permissions | -rw-r--r-- | 
| 11 
4d192e13ee84
move nearest_intersection() to Container, add dummy KdTree.load(), plus small fixes
 Radek Brich <radek.brich@devl.cz> parents: 
7diff
changeset | 1 | * kd-tree: | 
| 
4d192e13ee84
move nearest_intersection() to Container, add dummy KdTree.load(), plus small fixes
 Radek Brich <radek.brich@devl.cz> parents: 
7diff
changeset | 2 | - optimize structures | 
| 
4d192e13ee84
move nearest_intersection() to Container, add dummy KdTree.load(), plus small fixes
 Radek Brich <radek.brich@devl.cz> parents: 
7diff
changeset | 3 | - optimize construction: do not use bounding boxes of shapes, instead implement box-shape intersection | 
| 19 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
15diff
changeset | 4 | - save/load | 
| 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
15diff
changeset | 5 | * update Python binding, Camera, new classes | 
| 13 | 6 | * more complex demos | 
| 20 
f22952603f29
new C++ demo: realtime.cc (real-time scene viewer using SDL)
 Radek Brich <radek.brich@devl.cz> parents: 
19diff
changeset | 7 | * check/update triangle routines | 
| 3 | 8 | |
| 14 
fc18ac4833f2
replace Plane with axis-aligned Box (because infinite Plane is not usable with kd-tree)
 Radek Brich <radek.brich@devl.cz> parents: 
13diff
changeset | 9 | |
| 7 
bf17f9f84c91
kd-tree: build algorithm - searching for all posible splits
 Radek Brich <radek.brich@devl.cz> parents: 
6diff
changeset | 10 | New Classes? | 
| 
bf17f9f84c91
kd-tree: build algorithm - searching for all posible splits
 Radek Brich <radek.brich@devl.cz> parents: 
6diff
changeset | 11 | ============ | 
| 3 | 12 | |
| 13 | container.h -- Container | |
| 14 | kdtree.h -- KdTree | |
| 15 | shapes.h -- Triangle, Sphere | |
| 16 | scene.h -- Ray, Light, Camera, Scene | |
| 17 | material.h -- Material, Texture | |
| 18 | matrix.h -- Matrix | |
| 19 | vector.h -- Vector3 | |
| 20 | reader.h -- Reader, WavefrontReader | |
| 21 | ||
| 7 
bf17f9f84c91
kd-tree: build algorithm - searching for all posible splits
 Radek Brich <radek.brich@devl.cz> parents: 
6diff
changeset | 22 | KdTree top | 
| 3 | 23 | wf = new WavefrontReader() | 
| 7 
bf17f9f84c91
kd-tree: build algorithm - searching for all posible splits
 Radek Brich <radek.brich@devl.cz> parents: 
6diff
changeset | 24 | wf.setContainer(top) | 
| 
bf17f9f84c91
kd-tree: build algorithm - searching for all posible splits
 Radek Brich <radek.brich@devl.cz> parents: 
6diff
changeset | 25 | wf.setTransform(monkey_pos_matrix) | 
| 3 | 26 | wf.read("monkey.obj")
 | 
| 7 
bf17f9f84c91
kd-tree: build algorithm - searching for all posible splits
 Radek Brich <radek.brich@devl.cz> parents: 
6diff
changeset | 27 | // more transform&reads | 
| 3 | 28 | destroy wf | 
| 29 | ||
| 7 
bf17f9f84c91
kd-tree: build algorithm - searching for all posible splits
 Radek Brich <radek.brich@devl.cz> parents: 
6diff
changeset | 30 | top.optimize() -- i.e. build tree | 
| 3 | 31 | |
| 32 | Scene scene -- container with shapes, a camera and lights | |
| 33 | scene = new Scene() | |
| 7 
bf17f9f84c91
kd-tree: build algorithm - searching for all posible splits
 Radek Brich <radek.brich@devl.cz> parents: 
6diff
changeset | 34 | scene.setTop(top) -- top object in hierarchy | 
| 20 
f22952603f29
new C++ demo: realtime.cc (real-time scene viewer using SDL)
 Radek Brich <radek.brich@devl.cz> parents: 
19diff
changeset | 35 | scene.setCamera(new Camera(eye, u, v, p)) | 
| 3 | 36 | scene.addLight(new PointLight(pos, color)) | 
| 37 | rt.setScene(scene) | |
| 38 | rt.render(w,h) | |
| 39 | ||
| 40 | ||
| 41 | constructors have zero or one parameter by default -- the object to copy data from | |
| 42 | more parameters -- the data (ray origin and direction) |