Ignore:
Timestamp:
05/15/06 18:48:34 (19 years ago)
Author:
igarcia
Message:
 
Location:
GTP/trunk/Lib/Illum/IBRBillboardCloudTrees/OGRE/src
Files:
2 added
5 edited

Legend:

Unmodified
Added
Removed
  • GTP/trunk/Lib/Illum/IBRBillboardCloudTrees/OGRE/src

    • Property svn:ignore set to
      LBBCPointClusterGenerator.cpp
  • GTP/trunk/Lib/Illum/IBRBillboardCloudTrees/OGRE/src/IBRBillboardCloudTreeApplication.cpp

    r950 r961  
    253253        } 
    254254 
     255        { 
     256                LBBC::SceneViewMode *anotherFrameListenerMode; 
     257                anotherFrameListenerMode = new LBBC::SceneViewMode(mWindow,mFrameListener->getNumFrameListenerModes()); 
     258                anotherFrameListenerMode->chooseSceneManager(); 
     259                anotherFrameListenerMode->createCamera(); 
     260                anotherFrameListenerMode->createViewports(); 
     261                anotherFrameListenerMode->createScene(); 
     262                //anotherFrameListenerMode->loadScene("../../media/scene/scene.OSM"); 
     263                ////anotherFrameListenerMode->loadScene("../../media/scene/sceneLeaves.OSM"); 
     264                //anotherFrameListenerMode->loadScene("../../media/scene/scenePointLeaves.OSM"); 
     265                mFrameListener->addFrameListenerMode(anotherFrameListenerMode); 
     266        } 
     267 
    255268        mFrameListener->removeFrameListenerMode(0); 
    256269        mFrameListener->setEnabledFrameListenerMode(0); 
  • GTP/trunk/Lib/Illum/IBRBillboardCloudTrees/OGRE/src/IBRBillboardCloudTreeFrameListener.cpp

    r900 r961  
    106106        } 
    107107 
     108        if (mInputDevice->isKeyDown(Ogre::KC_F7)) 
     109        {                
     110                mCurrentOgreFrameListenerMode = 6; 
     111                this->setEnabledFrameListenerMode(mCurrentOgreFrameListenerMode); 
     112                mWindow->setDebugText(""); 
     113 
     114                //mTimeUntilNextToggle = 0.25;           
     115        } 
     116 
    108117        // Return true to continue rendering 
    109118        return true; 
  • GTP/trunk/Lib/Illum/IBRBillboardCloudTrees/OGRE/src/LBBCManager.cpp

    r958 r961  
    1111        mLeafDistributionGenerator = new LeafDistributionGenerator(); 
    1212        mBillboardCloudGenerator = new KMeansClusterGenerator(); 
     13        mDiffuseColorPointClusterGenerator = new DiffuseColorPointClusterGenerator(); 
    1314        mBillboardCloudUVMapper = new BBC::BillboardCloudUVMapper(); 
    1415        mOgreMeshSerializer = new BBC::OgreMeshSerializer(); 
     
    3435        { 
    3536                delete mLeafDistributionSerializer; 
     37        } 
     38        if (mDiffuseColorPointClusterGenerator) 
     39        { 
     40                delete mDiffuseColorPointClusterGenerator; 
    3641        } 
    3742        if (mLeafDistributionGenerator) 
     
    499504        } 
    500505 
    501         saveBillboardCloudIndirectSplittedPointMeshName(); 
    502 } 
    503  
    504 void LBBCManager::saveBillboardCloudIndirectSplittedPointMeshName() 
     506        generateBillboardCloudDiffuseColorPointCluster(); 
     507} 
     508 
     509void LBBCManager::generateBillboardCloudDiffuseColorPointCluster() 
    505510{ 
    506511        BBC::EntityPtr entity; 
    507         unsigned int numSubEntities = 0; 
    508  
    509512        entity = BBC::EntityPtr(new BBC::Entity()); 
    510         entity->removeSubEntity(0); 
    511          
    512         for (unsigned int iBillboard = 0; iBillboard < getLeaves()->getBillboardCloud()->getNumBillboards(); iBillboard++) 
    513         { 
    514                 BBC::BillboardPtr billboard = getLeaves()->getBillboardCloud()->getBillboard(iBillboard);                
    515                 BBC::EntityClusterPtr entityCluster = billboard->getBillboardClusterData()->getEntityCluster(); 
    516  
    517                 if (entityCluster->getNumEntitiesClusterData() > 0) 
    518                 {                                        
    519                         entity->createSubEntity(); 
    520                         entity->getSubEntity(numSubEntities)->setMaterialName(mSampleConfigFile->getBillboardCloudIndirectPointMaterialName()); 
    521                         entity->getSubEntity(numSubEntities)->enableNormals(false); 
    522                         entity->getSubEntity(numSubEntities)->enableTextureCoords(true); 
    523                         entity->getSubEntity(numSubEntities)->addTextureCoordSet(2); 
    524                         entity->getSubEntity(numSubEntities)->enableVertexColours(true); 
    525  
    526                         Ogre::Vector3 p1, p2, p3, p4, pa, pb; 
    527                         Ogre::Real mua, mub; 
    528                         Ogre::Real height, width; 
    529                         Ogre::Real hDistance, wDistance; 
    530  
    531                         height = Ogre::Vector3(billboard->getBillboardClusterData()->getQuadTopLeftCorner() - billboard->getBillboardClusterData()->getQuadBottomLeftCorner()).length(); 
    532                         width = Ogre::Vector3(billboard->getBillboardClusterData()->getQuadTopLeftCorner() - billboard->getBillboardClusterData()->getQuadTopRightCorner()).length(); 
    533  
    534                         for (unsigned int iLeaf = 0; iLeaf < entityCluster->getNumEntitiesClusterData(); iLeaf++) 
    535                         { 
    536                                 BBC::UniqueVertex vertex; 
    537  
    538                                 //LeafKMeansClusterData *leafKMeansClusterData = (LeafKMeansClusterData*)entityCluster->getEntityClusterData(iLeaf).get(); 
    539                                 //Leaf *leaf = (Leaf*)leafKMeansClusterData->getEntity().get(); 
    540                                 BBC::EntityClusterData* entityClusterData = entityCluster->getEntityClusterData(iLeaf).get(); 
    541                                 Leaf *leaf = (Leaf*)entityClusterData->getEntity().get(); 
    542                                 vertex.position = leaf->getPosition(); 
    543  
    544                                 //hDistance = 0.0; 
    545                                 //wDistance = 0.0; 
    546  
    547                                 //p1 = billboard->getBillboardClusterData()->getQuadTopRightCorner(); 
    548                                 //p2 = billboard->getBillboardClusterData()->getQuadBottomRightCorner(); 
    549                                 //p3 = leaf->getPosition(); 
    550                                 //p4 = leaf->getPosition() + billboard->getBillboardClusterData()->getAxisY(); 
    551  
    552                                 //if (BBC::Util::lineLineIntersect(p1, p2, p3, p4, &pa, &pb, &mua, &mub)) 
    553                                 //{ 
    554                                 //      hDistance = Ogre::Vector3(pa - p1).length(); 
    555                                 //} 
    556                                 //else 
    557                                 //{ 
    558                                 //      Ogre::LogManager::getSingleton().logMessage("Error with intersection: no solution exists."); 
    559                                 //} 
    560  
    561                                 //p1 = billboard->getBillboardClusterData()->getQuadTopLeftCorner(); 
    562                                 //p2 = billboard->getBillboardClusterData()->getQuadTopRightCorner(); 
    563                                 //p3 = leaf->getPosition(); 
    564                                 //p4 = leaf->getPosition() + billboard->getBillboardClusterData()->getAxisX(); 
    565  
    566                                 //if (BBC::Util::lineLineIntersect(p1, p2, p3, p4, &pa, &pb, &mua, &mub)) 
    567                                 //{ 
    568                                 //      wDistance = Ogre::Vector3(pa - p2).length(); 
    569                                 //} 
    570                                 //else 
    571                                 //{ 
    572                                 //      Ogre::LogManager::getSingleton().logMessage("Error with intersection: no solution exists."); 
    573                                 //} 
    574  
    575                                 //Ogre::LogManager::getSingleton().logMessage("W:" + Ogre::StringConverter::toString(width) + " UW:" + Ogre::StringConverter::toString(wDistance)); 
    576                                 //Ogre::LogManager::getSingleton().logMessage("H:" + Ogre::StringConverter::toString(height) + " UH:" + Ogre::StringConverter::toString(hDistance)); 
    577  
    578                                 //vertex.uv[0] = Ogre::Vector3(wDistance / width, hDistance / height, 0.0); 
    579                                 //vertex.uv[0] = Ogre::Vector3(1.0 - (hDistance / height), 1.0 - (wDistance / width), 0.0); 
    580                                 Ogre::Real numSamples = mSampleConfigFile->getBillboardCloudDiffuseColorEntityTextureAtlasNumSamples(); 
    581                                 Ogre::Real randomInt = Ogre::Math::Ceil(Ogre::Math::RangeRandom(0.5,numSamples)); 
    582  
    583                                 Ogre::Vector2 topLeftCorner[16]; 
    584                                 topLeftCorner[0] = Ogre::Vector2(0.0,  0.0); 
    585                                 topLeftCorner[1] = Ogre::Vector2(0.25, 0.0); 
    586                                 topLeftCorner[2] = Ogre::Vector2(0.5,  0.0); 
    587                                 topLeftCorner[3] = Ogre::Vector2(0.75, 0.0); 
    588                                 topLeftCorner[4] = Ogre::Vector2(0.0,  0.25); 
    589                                 topLeftCorner[5] = Ogre::Vector2(0.25, 0.25); 
    590                                 topLeftCorner[6] = Ogre::Vector2(0.5,  0.25); 
    591                                 topLeftCorner[7] = Ogre::Vector2(0.75, 0.25); 
    592                                 topLeftCorner[8] = Ogre::Vector2(0.0,  0.5); 
    593                                 topLeftCorner[9] = Ogre::Vector2(0.25, 0.5); 
    594                                 topLeftCorner[10] = Ogre::Vector2(0.5,  0.5); 
    595                                 topLeftCorner[11] = Ogre::Vector2(0.75, 0.5); 
    596                                 topLeftCorner[12] = Ogre::Vector2(0.0,  0.75); 
    597                                 topLeftCorner[13] = Ogre::Vector2(0.25, 0.75); 
    598                                 topLeftCorner[14] = Ogre::Vector2(0.5,  0.75); 
    599                                 topLeftCorner[15] = Ogre::Vector2(0.75, 0.75); 
    600  
    601                                 //vertex.uv[0] = Ogre::Vector3(randomInt / numSamples, 0.0, 0.0); 
    602                                  
    603                                 vertex.uv[0] = Ogre::Vector3(1.0 - topLeftCorner[(unsigned int)randomInt-1][0], 1.0 - topLeftCorner[(unsigned int)randomInt-1][1], 0.0); 
    604                                 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();  
    605                                 entity->getSubEntity(numSubEntities)->addUniqueVertex(vertex); 
    606                         } 
    607  
    608                         unsigned int iVertexFace = 0; 
    609                         Ogre::Vector3 faceVertexIndices = Ogre::Vector3::ZERO; 
    610  
    611                         for (unsigned int iVertex = 0; iVertex < entity->getSubEntity(numSubEntities)->getNumVertices(); iVertex++) 
    612                         { 
    613                                 faceVertexIndices[iVertexFace] = iVertex; 
    614                                 iVertexFace++; 
    615                                  
    616                                 if ((iVertex + 1) != entity->getSubEntity(numSubEntities)->getNumVertices()) 
    617                                 { 
    618                                         if (iVertexFace == 3) 
    619                                         { 
    620                                                 entity->getSubEntity(numSubEntities)->addFaceVerticesIDs(faceVertexIndices); 
    621                                                 iVertexFace = 0; 
    622                                                 faceVertexIndices = Ogre::Vector3::ZERO; 
    623                                         } 
    624                                 } 
    625                                 else 
    626                                 { 
    627                                         entity->getSubEntity(numSubEntities)->addFaceVerticesIDs(faceVertexIndices); 
    628                                 }                                
    629                         } 
    630  
    631                         numSubEntities++; 
    632                 } 
    633         } 
    634          
    635         mOgreMeshSerializer->setEntity(entity); 
     513        mDiffuseColorPointClusterGenerator->setEntity(entity); 
     514        mDiffuseColorPointClusterGenerator->setMaterialName(mSampleConfigFile->getBillboardCloudIndirectPointMaterialName()); 
     515        mDiffuseColorPointClusterGenerator->setNumSamples(mSampleConfigFile->getBillboardCloudDiffuseColorEntityTextureAtlasNumSamples()); 
     516        mDiffuseColorPointClusterGenerator->setBillboardCloud(getLeaves()->getBillboardCloud()); 
     517        mDiffuseColorPointClusterGenerator->generateDiffuseColorPointCluster(); 
     518        saveBillboardCloudDiffuseColorPointCluster(); 
     519} 
     520 
     521void LBBCManager::saveBillboardCloudDiffuseColorPointCluster() 
     522{ 
     523        mOgreMeshSerializer->setEntity(mDiffuseColorPointClusterGenerator->getEntity()); 
    636524        mOgreMeshSerializer->exportMesh(mSampleConfigFile->getBillboardCloudFolder() + mSampleConfigFile->getBillboardCloudIndirectPointMeshName(), false, false); 
    637         OBA::OgreBase::getSingleton().getMeshSerializer()->exportMesh(entity->getMesh()->get(), mSampleConfigFile->getEntityDistributionFolder() + mSampleConfigFile->getBillboardCloudIndirectPointMeshName()); 
     525        OBA::OgreBase::getSingleton().getMeshSerializer()->exportMesh(mDiffuseColorPointClusterGenerator->getEntity()->getMesh()->get(), mSampleConfigFile->getEntityDistributionFolder() + mSampleConfigFile->getBillboardCloudIndirectPointMeshName()); 
    638526        //OBA::OgreBase::getSingleton().getXMLMeshSerializer()->exportMesh(entity->getMesh()->get(), mSampleConfigFile->getEntityDistributionFolder() + mSampleConfigFile->getBillboardCloudIndirectPointMeshName() + ".xml");   
    639  
    640527} 
    641528 
  • GTP/trunk/Lib/Illum/IBRBillboardCloudTrees/OGRE/src/OBAOgreFrameListenerMode.cpp

    r900 r961  
    33 
    44namespace OBA { 
     5 
     6void OSceneCallback::OnCameraCreate(Ogre::Camera* pCamera, TiXmlElement* pCameraDesc)  
     7{ 
     8        // If a camera of name "FirstCamera" is loaded, it will be set as the default current  
     9        if(pCamera->getName() == "FirstCamera") 
     10                Ogre::Root::getSingleton().getAutoCreatedWindow()->getViewport(0)->setCamera(pCamera); 
     11} 
    512 
    613OgreFrameListenerMode::OgreFrameListenerMode(Ogre::RenderWindow *win, unsigned int ogreFrameListenerModeHandle, bool useBufferedInputKeys, bool useBufferedInputMouse) 
     
    121128        mCamera->yaw(mRotScale); 
    122129    } 
     130 
     131        // We can cycle cameras with the 'c' key 
     132        if (mInputDevice->isKeyDown(Ogre::KC_C) && (mTimeUntilNextToggle <= 0))  
     133        {                        
     134 
     135                Ogre::Camera* firstCam; 
     136                Ogre::Camera* currentCam = mWindow->getViewport(0)->getCamera(); 
     137 
     138                Ogre::Viewport* vp = mWindow->getViewport(0); 
     139 
     140                Ogre::SceneManager::CameraIterator it = mSceneMgr->getCameraIterator(); 
     141 
     142                if(it.hasMoreElements()) 
     143                { 
     144                        firstCam = it.peekNextValue(); 
     145                } 
     146 
     147                while(it.hasMoreElements())  
     148                {                        
     149                        Ogre::Camera* cam = it.getNext(); 
     150 
     151                        if(currentCam == cam)  
     152                        { 
     153                                Ogre::Camera* camera = it.hasMoreElements() ? it.getNext() : firstCam; 
     154                                vp->setCamera(camera);                                   
     155                        } 
     156                } 
     157                mTimeUntilNextToggle = 0.5f;             
     158        } 
    123159 
    124160        // see if switching is on, and you want to toggle  
     
    303339        } 
    304340 
     341        static Ogre::Real currentTime = 0; 
     342 
     343        // We update all loaded animations each frame 
     344        Ogre::SceneManager::AnimationIterator animationIt = mSceneMgr->getAnimationIterator(); 
     345 
     346        while(animationIt.hasMoreElements())  
     347        { 
     348                Ogre::Animation* animation = animationIt.getNext(); 
     349                 
     350                const Ogre::Animation::NodeTrackList& trackList = animation->_getNodeTrackList(); 
     351                 
     352                Ogre::Animation::NodeTrackList::const_iterator it = trackList.begin(); 
     353                Ogre::Animation::NodeTrackList::const_iterator iend = trackList.end(); 
     354 
     355                for(; it != iend; ++it) { 
     356                        const Ogre::NodeAnimationTrack* track = it->second; 
     357                        track->getAssociatedNode()->resetToInitialState(); 
     358                } 
     359                 
     360                currentTime += evt.timeSinceLastFrame; 
     361                animation->apply(currentTime); 
     362        }                
     363   
    305364        return true; 
    306365} 
     
    410469} 
    411470 
     471void OgreFrameListenerMode::loadScene(Ogre::String filename) 
     472{ 
     473        // Create an oE_Loader Callback object to post-process created objects 
     474        OSceneCallback oeCallback; 
     475         
     476        mOScene = new OSMScene(mSceneMgr, mWindow); 
     477 
     478        // Initialises with the scene to be loaded and the callback if requiered 
     479        mOScene->initialise(filename.c_str(), &oeCallback); 
     480 
     481        // create and setup the scene in the root node 
     482        mOScene->createScene(); 
     483} 
     484 
    412485void OgreFrameListenerMode::createScene() 
    413486{ 
Note: See TracChangeset for help on using the changeset viewer.