fix a bug in KdNode::subdivide and remove some extra variables pyrit
authorRadek Brich <radek.brich@devl.cz>
Tue, 04 Dec 2007 08:58:05 +0100 (2007-12-04)
branchpyrit
changeset 23 7e258561a690
parent 22 76b7bd51d64a
child 24 d0d76e8a5203
fix a bug in KdNode::subdivide and remove some extra variables realtime.cc - use SW surface
ccdemos/realtime.cc
src/kdtree.cc
--- a/ccdemos/realtime.cc	Mon Dec 03 01:49:23 2007 +0100
+++ b/ccdemos/realtime.cc	Tue Dec 04 08:58:05 2007 +0100
@@ -53,7 +53,7 @@
 
 	atexit(SDL_Quit);
 
-	screen = SDL_SetVideoMode(w, h, 32, SDL_HWSURFACE|SDL_DOUBLEBUF|SDL_RESIZABLE);
+	screen = SDL_SetVideoMode(w, h, 32, SDL_SWSURFACE|SDL_DOUBLEBUF|SDL_RESIZABLE);
 	if ( screen == NULL ) {
 		fprintf(stderr, "Unable to set video mode: %s\n", SDL_GetError());
 		exit(1);
--- a/src/kdtree.cc	Mon Dec 03 01:49:23 2007 +0100
+++ b/src/kdtree.cc	Tue Dec 04 08:58:05 2007 +0100
@@ -186,7 +186,6 @@
 	const Float K = 1.4; // constant, K = cost of traversal / cost of ray-triangle intersection
 	Float SAV = 2*(bbox.w()*bbox.h() + bbox.w()*bbox.d() + bbox.h()*bbox.d()); // surface area of node
 	Float cost = SAV * (K + shapes->size()); // initial cost = non-split cost
-	SplitPos *splitpos = NULL;
 	bool leaf = true;
 	BBox lbb = bbox;
 	BBox rbb = bbox;
@@ -203,7 +202,7 @@
 		{
 			leaf = false;
 			cost = splitcost;
-			splitpos = &*spl;
+			split = spl->pos;
 		}
 	}
 
@@ -236,10 +235,6 @@
 	f += 4;
 #endif
 
-	split = splitpos->pos;
-	Float lnum = splitpos->lnum;
-	Float rnum = splitpos->rnum;
-
 	// split this node
 	delete shapes;
 	children = new KdNode[2];
@@ -279,13 +274,13 @@
 					if (split - bbox.L.cell[axis] < bbox.H.cell[axis] - split)
 					{
 						// left subcell is smaller -> if not empty, put shape here
-						if (lnum)
+						if (children[0].shapes->size())
 							children[0].addShape(sh->shape);
 						else
 							children[1].addShape(sh->shape);
 					} else {
 						// right subcell is smaller
-						if (rnum)
+						if (children[1].shapes->size())
 							children[1].addShape(sh->shape);
 						else
 							children[0].addShape(sh->shape);