Changeset 778 for GTP/trunk/Lib/Illum/IBRBillboardCloudTrees
- Timestamp:
- 04/21/06 19:56:55 (19 years ago)
- Location:
- GTP/trunk/Lib/Illum/IBRBillboardCloudTrees/OGRE
- Files:
-
- 4 added
- 2 deleted
- 7 edited
Legend:
- Unmodified
- Added
- Removed
-
GTP/trunk/Lib/Illum/IBRBillboardCloudTrees/OGRE/include/BBC/BBCUtil.h
r751 r778 5 5 6 6 namespace BBC { 7 8 const Ogre::Real EPSILON_INTERSECT = 0.00000001; 7 9 8 10 class _BBCExport Util … … 35 37 } 36 38 39 // Calculate the line segment PaPb that is the shortest route between 40 // two lines P1P2 and P3P4. Calculate also the values of mua and mub where 41 // Pa = P1 + mua (P2 - P1) 42 // Pb = P3 + mub (P4 - P3) 43 // Return false if no solution exists. 44 45 static int lineLineIntersect( 46 Ogre::Vector3 p1, Ogre::Vector3 p2, Ogre::Vector3 p3, Ogre::Vector3 p4, Ogre::Vector3 *pa, Ogre::Vector3 *pb, 47 Ogre::Real *mua, Ogre::Real *mub) 48 { 49 Ogre::Vector3 p13,p43,p21; 50 Ogre::Real d1343,d4321,d1321,d4343,d2121; 51 Ogre::Real numer,denom; 52 53 p13.x = p1.x - p3.x; 54 p13.y = p1.y - p3.y; 55 p13.z = p1.z - p3.z; 56 p43.x = p4.x - p3.x; 57 p43.y = p4.y - p3.y; 58 p43.z = p4.z - p3.z; 59 if (Ogre::Math::Abs(p43.x) < EPSILON_INTERSECT && Ogre::Math::Abs(p43.y) < EPSILON_INTERSECT && Ogre::Math::Abs(p43.z) < EPSILON_INTERSECT) 60 { 61 return(false); 62 } 63 p21.x = p2.x - p1.x; 64 p21.y = p2.y - p1.y; 65 p21.z = p2.z - p1.z; 66 if (Ogre::Math::Abs(p21.x) < EPSILON_INTERSECT && Ogre::Math::Abs(p21.y) < EPSILON_INTERSECT && Ogre::Math::Abs(p21.z) < EPSILON_INTERSECT) 67 { 68 return(false); 69 } 70 71 d1343 = p13.x * p43.x + p13.y * p43.y + p13.z * p43.z; 72 d4321 = p43.x * p21.x + p43.y * p21.y + p43.z * p21.z; 73 d1321 = p13.x * p21.x + p13.y * p21.y + p13.z * p21.z; 74 d4343 = p43.x * p43.x + p43.y * p43.y + p43.z * p43.z; 75 d2121 = p21.x * p21.x + p21.y * p21.y + p21.z * p21.z; 76 77 denom = d2121 * d4343 - d4321 * d4321; 78 if (Ogre::Math::Abs(denom) < EPSILON_INTERSECT) 79 { 80 return(false); 81 } 82 numer = d1343 * d4321 - d1321 * d4343; 83 84 *mua = numer / denom; 85 *mub = (d1343 + d4321 * (*mua)) / d4343; 86 87 pa->x = p1.x + *mua * p21.x; 88 pa->y = p1.y + *mua * p21.y; 89 pa->z = p1.z + *mua * p21.z; 90 pb->x = p3.x + *mub * p43.x; 91 pb->y = p3.y + *mub * p43.y; 92 pb->z = p3.z + *mub * p43.z; 93 94 return(true); 95 } 37 96 }; 38 97 39 98 /* 40 extern "C" _BBCExport double fround(doublen, unsigned d)99 extern "C" _BBCExport Ogre::Real fround(Ogre::Real n, unsigned d) 41 100 { 42 return floor(n * pow(( double)10.,(int) d) + .5) / pow((double)10.,(int) d);101 return floor(n * pow((Ogre::Real)10.,(int) d) + .5) / pow((Ogre::Real)10.,(int) d); 43 102 } 44 103 45 extern "C" _BBCExport int iround( doublex)104 extern "C" _BBCExport int iround(Ogre::Real x) 46 105 { 47 106 return (int)floor(x + 0.5); -
GTP/trunk/Lib/Illum/IBRBillboardCloudTrees/OGRE/include/LBBC/LBBC.h
r745 r778 10 10 #include <LBBCClusterViewMode.h> 11 11 #include <LBBCEntityTextureAtlasViewMode.h> 12 #include <LBBCBillboardCloudTextureViewMode.h> 12 #include <LBBCBillboardCloudDiffuseColorTextureViewMode.h> 13 #include <LBBCBillboardCloudIndirectTextureViewMode.h> 13 14 #endif -
GTP/trunk/Lib/Illum/IBRBillboardCloudTrees/OGRE/scripts/IBRBillboardCloudTreeGenerator.vcproj
r751 r778 213 213 Filter=""> 214 214 <File 215 RelativePath="..\src\LBBCBillboardCloudTextureViewMode.cpp"> 215 RelativePath="..\src\LBBCBillboardCloudDiffuseColorTextureViewMode.cpp"> 216 </File> 217 <File 218 RelativePath="..\src\LBBCBillboardCloudIndirectTextureViewMode.cpp"> 216 219 </File> 217 220 <File … … 416 419 </File> 417 420 <File 418 RelativePath="..\include\Lbbc\LBBCBillboardCloudTextureViewMode.h"> 421 RelativePath="..\include\Lbbc\LBBCBillboardCloudDiffuseColorTextureViewMode.h"> 422 </File> 423 <File 424 RelativePath="..\include\Lbbc\LBBCBillboardCloudIndirectTextureViewMode.h"> 419 425 </File> 420 426 <File -
GTP/trunk/Lib/Illum/IBRBillboardCloudTrees/OGRE/src/BBCBillboardCloudUVMapper.cpp
r751 r778 152 152 Ogre::Vector2 texCoords01,texCoords02,texCoords03,texCoords04; 153 153 154 // DirectX working version... 155 texCoords03[0] = min[0] / mTextureAtlasWidth; 156 texCoords03[1] = 1.0 - (min[1] / mTextureAtlasHeight); 157 158 texCoords04[0] = max[0] / mTextureAtlasWidth; 159 texCoords04[1] = 1.0 - (min[1] / mTextureAtlasHeight); 160 161 texCoords01[0] = max[0] / mTextureAtlasWidth; 162 texCoords01[1] = 1.0 - (max[1] / mTextureAtlasHeight); 163 154 164 texCoords02[0] = min[0] / mTextureAtlasWidth; 155 texCoords02[1] = 1.0 - (min[1] / mTextureAtlasHeight); 156 157 texCoords01[0] = max[0] / mTextureAtlasWidth; 158 texCoords01[1] = 1.0 - (min[1] / mTextureAtlasHeight); 159 160 texCoords04[0] = max[0] / mTextureAtlasWidth; 161 texCoords04[1] = 1.0 - (max[1] / mTextureAtlasHeight); 162 163 texCoords03[0] = min[0] / mTextureAtlasWidth; 164 texCoords03[1] = 1.0 - (max[1] / mTextureAtlasHeight); 165 texCoords02[1] = 1.0 - (max[1] / mTextureAtlasHeight); 166 167 //texCoords02[0] = min[0] / mTextureAtlasWidth; 168 //texCoords02[1] = 1.0 - (min[1] / mTextureAtlasHeight); 169 170 //texCoords01[0] = max[0] / mTextureAtlasWidth; 171 //texCoords01[1] = 1.0 - (min[1] / mTextureAtlasHeight); 172 173 //texCoords04[0] = max[0] / mTextureAtlasWidth; 174 //texCoords04[1] = 1.0 - (max[1] / mTextureAtlasHeight); 175 176 //texCoords03[0] = min[0] / mTextureAtlasWidth; 177 //texCoords03[1] = 1.0 - (max[1] / mTextureAtlasHeight); 165 178 166 179 if (groupedBillboards) -
GTP/trunk/Lib/Illum/IBRBillboardCloudTrees/OGRE/src/IBRBillboardCloudTreeApplication.cpp
r751 r778 147 147 mSceneMgr = mFrameListener->getEnabledFrameListenerMode()->getSceneManager(); 148 148 149 if (mSampleConfigFile->getBillboardCloudDiffuseColorEntityTextureAtlasGeneration()) 149 150 { 150 151 LBBC::EntityTextureAtlasViewMode *textureAtlasFrameListenerMode; … … 164 165 } 165 166 166 { 167 LBBC::BillboardCloudTextureViewMode *anotherFrameListenerMode; 168 anotherFrameListenerMode = new LBBC::BillboardCloudTextureViewMode(mWindow,mFrameListener->getNumFrameListenerModes()); 167 if (mSampleConfigFile->getBillboardCloudDiffuseColorGroupedBillboardsTextureAtlasGeneration()) 168 { 169 LBBC::BillboardCloudDiffuseColorTextureViewMode *anotherFrameListenerMode; 170 anotherFrameListenerMode = new LBBC::BillboardCloudDiffuseColorTextureViewMode(mWindow,mFrameListener->getNumFrameListenerModes()); 169 171 anotherFrameListenerMode->chooseSceneManager(); 170 172 anotherFrameListenerMode->createCamera(); … … 177 179 anotherFrameListenerMode->setTextureAtlasFolder(mSampleConfigFile->getBillboardCloudFolder()); 178 180 anotherFrameListenerMode->setEntityClustersGroupedName(mSampleConfigFile->getEntityClustersGroupedMeshName()); 179 //anotherFrameListenerMode->setBillboardCloudSplittedName(mSampleConfigFile->getBillboardCloudSplittedMeshName()); 180 anotherFrameListenerMode->setBillboardCloudSplittedName(mSampleConfigFile->getBillboardCloudIndirectPointMeshName()); 181 anotherFrameListenerMode->setBillboardCloudSplittedName(mSampleConfigFile->getBillboardCloudSplittedMeshName()); 181 182 anotherFrameListenerMode->setBillboardCloudGroupedTextureAtlasDebug(mSampleConfigFile->getBillboardCloudDiffuseColorGroupedBillboardsTextureAtlasDebug()); 183 anotherFrameListenerMode->createScene(); 184 mFrameListener->addFrameListenerMode(anotherFrameListenerMode); 185 } 186 187 if (mSampleConfigFile->getBillboardCloudIndirectGroupedBillboardsTextureAtlasGeneration()) 188 { 189 LBBC::BillboardCloudIndirectTextureViewMode *anotherFrameListenerMode; 190 anotherFrameListenerMode = new LBBC::BillboardCloudIndirectTextureViewMode(mWindow, mFrameListener->getNumFrameListenerModes()); 191 anotherFrameListenerMode->chooseSceneManager(); 192 anotherFrameListenerMode->createCamera(); 193 anotherFrameListenerMode->createViewports(); 194 anotherFrameListenerMode->setTextureAtlasSize(mSampleConfigFile->getBillboardCloudIndirectGroupedBillboardsTextureAtlasSize()); 195 anotherFrameListenerMode->setTextureSize(mSampleConfigFile->getBillboardCloudIndirectGroupedBillboardsTextureSize()); 196 anotherFrameListenerMode->setTextureAtlasBitRange(mSampleConfigFile->getBillboardCloudIndirectGroupedBillboardsTextureAtlasBitRange()); 197 anotherFrameListenerMode->setTextureAtlasName(mSampleConfigFile->getBillboardCloudIndirectGroupedBillboardsTextureAtlasName()); 198 anotherFrameListenerMode->setTextureAtlasFolder(mSampleConfigFile->getBillboardCloudFolder()); 199 anotherFrameListenerMode->setBillboardCloudPointClustersName(mSampleConfigFile->getBillboardCloudIndirectPointMeshName()); 200 anotherFrameListenerMode->setBillboardCloudSplittedName(mSampleConfigFile->getBillboardCloudSplittedMeshName()); 201 anotherFrameListenerMode->setEntityClustersGroupedName(mSampleConfigFile->getEntityClustersGroupedMeshName()); 202 anotherFrameListenerMode->setBillboardCloudGroupedTextureAtlasDebug(mSampleConfigFile->getBillboardCloudIndirectGroupedBillboardsTextureAtlasDebug()); 182 203 anotherFrameListenerMode->createScene(); 183 204 mFrameListener->addFrameListenerMode(anotherFrameListenerMode); -
GTP/trunk/Lib/Illum/IBRBillboardCloudTrees/OGRE/src/LBBCManager.cpp
r751 r778 497 497 entity->getSubEntity(numSubEntities)->setMaterialName(mSampleConfigFile->getBillboardCloudIndirectPointMaterialName()); 498 498 entity->getSubEntity(numSubEntities)->enableNormals(false); 499 entity->getSubEntity(numSubEntities)->enableTextureCoords(false); 499 entity->getSubEntity(numSubEntities)->enableTextureCoords(true); 500 entity->getSubEntity(numSubEntities)->addTextureCoordSet(2); 500 501 entity->getSubEntity(numSubEntities)->enableVertexColours(true); 502 503 Ogre::Vector3 p1, p2, p3, p4, pa, pb; 504 Ogre::Real mua, mub; 505 Ogre::Real height, width; 506 Ogre::Real hDistance, wDistance; 507 508 height = Ogre::Vector3(billboard->getBillboardClusterData()->getQuadTopLeftCorner() - billboard->getBillboardClusterData()->getQuadBottomLeftCorner()).length(); 509 width = Ogre::Vector3(billboard->getBillboardClusterData()->getQuadTopLeftCorner() - billboard->getBillboardClusterData()->getQuadTopRightCorner()).length(); 501 510 502 511 for (unsigned int iLeaf = 0; iLeaf < entityCluster->getNumEntitiesClusterData(); iLeaf++) … … 507 516 Leaf *leaf = (Leaf*)leafKMeansClusterData->getEntity().get(); 508 517 vertex.position = leaf->getPosition(); 518 519 hDistance = 0.0; 520 wDistance = 0.0; 521 522 p1 = billboard->getBillboardClusterData()->getQuadTopRightCorner(); 523 p2 = billboard->getBillboardClusterData()->getQuadBottomRightCorner(); 524 p3 = leaf->getPosition(); 525 p4 = leaf->getPosition() + billboard->getBillboardClusterData()->getAxisY(); 526 527 if (BBC::Util::lineLineIntersect(p1, p2, p3, p4, &pa, &pb, &mua, &mub)) 528 { 529 hDistance = Ogre::Vector3(pa - p1).length(); 530 } 531 else 532 { 533 Ogre::LogManager::getSingleton().logMessage("Error with intersection: no solution exists."); 534 } 535 536 p1 = billboard->getBillboardClusterData()->getQuadTopLeftCorner(); 537 p2 = billboard->getBillboardClusterData()->getQuadTopRightCorner(); 538 p3 = leaf->getPosition(); 539 p4 = leaf->getPosition() + billboard->getBillboardClusterData()->getAxisX(); 540 541 if (BBC::Util::lineLineIntersect(p1, p2, p3, p4, &pa, &pb, &mua, &mub)) 542 { 543 wDistance = Ogre::Vector3(pa - p2).length(); 544 } 545 else 546 { 547 Ogre::LogManager::getSingleton().logMessage("Error with intersection: no solution exists."); 548 } 549 550 //Ogre::LogManager::getSingleton().logMessage("W:" + Ogre::StringConverter::toString(width) + " UW:" + Ogre::StringConverter::toString(wDistance)); 551 //Ogre::LogManager::getSingleton().logMessage("H:" + Ogre::StringConverter::toString(height) + " UH:" + Ogre::StringConverter::toString(hDistance)); 552 553 //vertex.uv[0] = Ogre::Vector3(wDistance / width, hDistance / height, 0.0); 554 vertex.uv[0] = Ogre::Vector3(1.0 - (hDistance / height), 1.0 - (wDistance / width), 0.0); 509 555 vertex.colour = Ogre::ColourValue(Ogre::Math::RangeRandom(0.0, 1.0), Ogre::Math::RangeRandom(0.0, 1.0), Ogre::Math::RangeRandom(0.0, 1.0), 1.0).getAsRGBA(); 510 556 entity->getSubEntity(numSubEntities)->addUniqueVertex(vertex); -
GTP/trunk/Lib/Illum/IBRBillboardCloudTrees/OGRE/src/OBAOgreFrameListener.cpp
r751 r778 102 102 } 103 103 104 if (mInputDevice->isKeyDown(Ogre::KC_TAB) && mTimeUntilNextToggle <= 0) 104 //if (mInputDevice->isKeyDown(Ogre::KC_TAB) && mTimeUntilNextToggle <= 0) 105 if (mInputDevice->isKeyDown(Ogre::KC_TAB)) 105 106 { 106 107 mCurrentOgreFrameListenerMode = (mCurrentOgreFrameListenerMode+1) % this->getNumFrameListenerModes(); … … 108 109 mWindow->setDebugText("P: " + mDefaultOgreFrameListenerMode->getSceneManager()->getName()); 109 110 110 mTimeUntilNextToggle = 0.25;111 //mTimeUntilNextToggle = 0.25; 111 112 } 112 113
Note: See TracChangeset
for help on using the changeset viewer.