Changeset 241
- Timestamp:
- 08/16/05 20:30:53 (19 years ago)
- Location:
- trunk/VUT/GtpVisibilityPreprocessor/src
- Files:
-
- 4 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/VUT/GtpVisibilityPreprocessor/src/KdTree.cpp
r191 r241 562 562 // case P4 563 563 } 564 564 } 565 565 // $$ modification 3.5.2004 - hints from Kamil Ghais 566 566 // case N4 or P4 … … 569 569 extp = ray.GetLoc() + ray.GetDir()*tdist; 570 570 maxt = tdist; 571 571 } else { 572 572 // compute intersection with all objects in this leaf 573 573 KdLeaf *leaf = (KdLeaf *) node; -
trunk/VUT/GtpVisibilityPreprocessor/src/Plane3.h
r239 r241 45 45 const Vector3 v = b - a; // line from A to B 46 46 float dv = DotProd(mNormal, v); 47 float u = 0; 47 48 if (signum(dv) == 0) 49 { 50 if (coplanar) 51 (*coplanar) = true; 52 53 return a; 54 } 55 56 float u = - Distance(a) / dv; // TODO: could be done more efficiently 57 //Debug << "t: " << u << ", b - a: " << v << ", norm: " << mNormal << ", dist(a): " << - Distance(a) << ", dv: " << dv << endl; 58 if (coplanar) 59 (*coplanar) = false; 48 60 49 if (signum(dv) != 0)50 {51 u = - Distance(a) / dv; // NOTE: could be done more efficiently52 //Debug << "t: " << u << ", b - a: " << v << ", norm: " << mNormal << ", dist(a): " << - Distance(a) << ", dv: " << dv << endl;53 if (coplanar)54 (*coplanar) = false;55 }56 else if (coplanar)57 {58 (*coplanar) = true;59 }60 61 61 if (t) 62 62 (*t) = u; -
trunk/VUT/GtpVisibilityPreprocessor/src/ViewCellBsp.cpp
r240 r241 6 6 #include "Environment.h" 7 7 #include "Polygon3.h" 8 #include "Ray.h" 8 9 9 10 #include <stack> … … 264 265 265 266 PolygonContainer polys; 267 266 268 // copy polygon information to guide the split process 267 CopyMesh2Polygons(viewCell->GetMesh(), polys); 269 AddMesh2Polygons(viewCell->GetMesh(), polys); 270 mBox.Include(viewCell->GetBox()); // also add to BSP root box 268 271 269 272 BspNode *firstNode = mRoot ? mRoot : new BspLeaf(); // traverse tree or create new one … … 331 334 } 332 335 333 void BspTree:: CopyMesh2Polygons(Mesh *mesh, PolygonContainer &polys)336 void BspTree::AddMesh2Polygons(Mesh *mesh, PolygonContainer &polys) 334 337 { 335 338 FaceContainer::const_iterator fi; … … 343 346 } 344 347 345 void BspTree::Copy2PolygonSoup(const ObjectContainer &objects, PolygonContainer &polys, int max Polys)348 void BspTree::Copy2PolygonSoup(const ObjectContainer &objects, PolygonContainer &polys, int maxObjects) 346 349 { 347 350 ObjectContainer::const_iterator it, it_end = objects.end(); 348 351 349 int limit = (maxPolys > 0) ? min((int)objects.size(), maxPolys) : (int)objects.size(); 350 352 int limit = (maxObjects > 0) ? min((int)objects.size(), maxObjects) : (int)objects.size(); 353 354 // initialise bounding box 355 mBox.Initialize(); 356 351 357 for (int i = 0; i < limit; ++i) 352 358 { … … 363 369 mesh = dynamic_cast<ViewCell *>(object)->GetMesh(); 364 370 break; 371 // TODO: handle transformed mesh instances 365 372 default: 366 373 break; 367 374 } 368 375 369 if (mesh) // copy the mesh data to polygons 370 { 371 CopyMesh2Polygons(mesh, polys); 372 } 373 } 374 375 Debug << "Number of polygons: " << polys.size() << endl; 376 if (mesh) // copy the mesh data to polygons 377 { 378 mBox.Include(object->GetBox()); // also add to BSP root box 379 AddMesh2Polygons(mesh, polys); 380 } 381 } 382 383 Debug << "Number of polygons: " << polys.size() << ", BSP root box: " << mBox << endl; 376 384 } 377 385 … … 391 399 Copy2PolygonSoup(objects, *polys, 100); 392 400 393 BspTraversalData tData(new BspLeaf(), mRoot->GetParent(), polys, 0); 401 BspTraversalData tData(new BspLeaf(), mRoot->GetParent(), polys, 0); // new root corresponding to unbounded space 394 402 395 403 tStack.push(tData); … … 687 695 #endif 688 696 } 697 698 int BspTree::CastRay(Ray &ray) 699 { 700 int hits = 0; 701 702 stack<BspRayTraversalData> tStack; 703 704 float maxt = 1e6; 705 float mint = 0; 706 707 Intersectable::NewMail(); 708 709 // test with tree bounding box 710 if (!mBox.GetMinMaxT(ray, &mint, &maxt)) 711 return 0; 712 713 if (mint < 0) 714 mint = 0; 715 716 maxt += Limits::Threshold; 717 718 Vector3 entp = ray.Extrap(mint); 719 Vector3 extp = ray.Extrap(maxt); 720 721 BspNode *node = mRoot; 722 BspNode *farChild; 723 724 float position; 725 726 while (1) // endless loop 727 { 728 if (!node->IsLeaf()) 729 { 730 BspInterior *in = (BspInterior *) node; 731 732 Plane3 *splitPlane = in->GetPlane(); 733 734 float t = 0; 735 bool coplanar = false; 736 737 int entSide = splitPlane->Side(entp); 738 int extSide = splitPlane->Side(extp); 739 740 Vector3 intersection; 741 742 if (entSide < 0) 743 { 744 if(extSide > 0) // plane splits ray 745 { 746 node = in->GetBack(); 747 farChild = in->GetFront(); 748 } else 749 { 750 node = in->GetBack(); 751 continue; 752 } 753 } 754 } else if (entSide > 0) 755 { 756 if (extSide < 0) // plane splits ray 757 { 758 node = in->GetFront(); 759 farChild = in->GetBack(); 760 } else 761 { 762 node = in->GetFront(); 763 continue; 764 } 765 } 766 else // ray and plane are coincident // DOTO: WHAT IN THIS CASE ? 767 { 768 //node = in->GetFront(); 769 continue; 770 } 771 772 // case N4 or P4 773 float tdist = (position - ray.GetLoc(axis)) / ray.GetDir(axis); 774 tStack.push(RayTraversalData(farChild, extp, maxt)); 775 extp = ray.GetLoc() + ray.GetDir()*tdist; 776 maxt = tdist; 777 778 float tDist = 0; 779 extp = splitPlane->FindIntersection(entp, extp, &t); 780 781 tStack.push(BspRayTraversalData(farChild, extp, maxt)); 782 783 784 785 maxt = tDist; 786 } 787 } else // compute intersections with objects in leaf 788 { 789 BspLeaf *leaf = dynamic_cast<BspLeaf *>(node); 790 //ray.leaves.push_back(leaf); 791 792 /*ObjectContainer::const_iterator mi; 793 for (mi = leaf->mObjects.begin(); mi != leaf->mObjects.end(); ++mi) 794 { 795 Intersectable *object = *mi; 796 if (!object->Mailed()) 797 { 798 object->Mail(); 799 //ray.meshes.push_back(mesh); 800 hits += object->CastRay(ray); 801 } 802 }*/ 803 804 if (hits && ray.GetType() == Ray::LOCAL_RAY) 805 if (ray.intersections[0].mT <= maxt) 806 break; 807 808 // get the next node from the stack 809 if (tStack.empty()) 810 break; 811 812 entp = extp; 813 mint = maxt; 814 BspRayTraversalData &s = tStack.top(); 815 node = s.mNode; 816 extp = s.mExitPoint; 817 maxt = s.mMaxT; 818 819 tStack.pop(); 820 } 821 822 return hits; 823 } 824 } 825 689 826 //} // GtpVisibilityPreprocessor -
trunk/VUT/GtpVisibilityPreprocessor/src/ViewCellBsp.h
r240 r241 4 4 #include "Mesh.h" 5 5 #include "Containers.h" 6 7 6 8 #include <queue> 7 9 #include <stack> … … 19 21 */ 20 22 typedef std::vector<Polygon3 *> PolygonContainer; 23 24 struct BspRayTraversalData 25 { 26 BspNode *mNode; 27 Vector3 mExitPoint; 28 float mMaxT; 29 30 BspRayTraversalData() {} 31 32 BspRayTraversalData(BspNode *n, const Vector3 &p, const float maxt): 33 mNode(n), mExitPoint(p), mMaxT(maxt) 34 {} 35 }; 21 36 22 37 class BspTreeStatistics // TODO: should have common superclass with KdTreeStatistics … … 299 314 Plane3 SelectPlaneHeuristics(PolygonContainer *polygons, int maxTests) const; 300 315 301 /** Extracts the meshes of the objects and copies them into the mesh. 302 */ 303 static void Copy2PolygonSoup(const ObjectContainer &objects, PolygonContainer &polys, int maxPolys); 304 305 /** copy this mesh into polygons. 306 */ 307 static void CopyMesh2Polygons(Mesh *mesh, PolygonContainer &polys); 316 /** Extracts the meshes of the objects and copies them into the mesh. Also calculcates the bounding box of the tree. 317 @param maxPolys the maximal number of objects to be stored as polygons 318 */ 319 void Copy2PolygonSoup(const ObjectContainer &objects, PolygonContainer &polys, int maxObjects); 320 321 /** Add this mesh as polygons to polygon container. 322 */ 323 void AddMesh2Polygons(Mesh *mesh, PolygonContainer &polys); 324 325 /** A ray is cast possible intersecting the tree. 326 @param the ray that is cast. 327 @returns the number of intersections with objects stored in the tree. 328 */ 329 int CastRay(Ray &ray); 308 330 309 331 /// Pointer to the root of the tree … … 321 343 /// Strategies for choosing next split plane. 322 344 enum {NEXT_POLYGON, LEAST_SPLITS, BALANCED_TREE, COMBINED}; 345 346 /// box around the whole view domain 347 AxisAlignedBox3 mBox; 323 348 324 349 public:
Note: See TracChangeset
for help on using the changeset viewer.