Changeset 141 for trunk/VUT/Ogre


Ignore:
Timestamp:
06/21/05 11:18:09 (20 years ago)
Author:
mattausch
Message:

fixed visibility queries using occlusion queries
fixed visualization

Location:
trunk/VUT/Ogre/src
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • trunk/VUT/Ogre/src/OgrePlatformQueryManager.cpp

    r140 r141  
    105105        //---- collect results 
    106106        unsigned int visiblePixels = 0; 
     107        std::pair<InfoContainer<GtpVisibility::NodeInfo>::iterator, bool> insertNode; 
     108        std::pair<InfoContainer<GtpVisibility::MeshInfo>::iterator, bool> insertGeom; 
    107109 
    108110        GtpVisibility::QueryList::iterator visQueryIt, projQueryIt; 
     
    116118                (*visQueryIt)->GetQueryResult(visiblePixels, true); 
    117119         
    118                  
    119120                float vis = (float)visiblePixels; 
     121                bool isVisible = visiblePixels > 0; 
    120122 
    121123                if (relativeVisibility) 
     
    132134                ++visQueryIt; 
    133135                 
    134                 // leave nodes with visibilty 0 in queue:  
     136                // nodes with visibilty 0 in queue:  
    135137                // happens if node is intersected by near plane 
    136                 visibleNodes->push_back(GtpVisibility::NodeInfo(*nodeIt, vis)); 
     138                if (isVisible) 
     139                { 
     140                        insertNode = visibleNodes->insert(GtpVisibility::NodeInfo(*nodeIt, vis)); 
     141 
     142                        if (!insertNode.second) // element already in list 
     143                        { 
     144                                //LogManager::getSingleton().logMessage("element already in list"); 
     145                (*insertNode.first).SetVisibility((*insertNode.first).GetVisibility() + vis); 
     146 
     147                                if (relativeVisibility) // relative visibility between zero and one 
     148                                { 
     149                                        (*insertNode.first).SetVisibility((*insertNode.first).GetVisibility() * 0.5); 
     150                                } 
     151                        } 
     152                } 
    137153        } 
    138154 
     
    164180                // geometry maybe occluded 
    165181                if (isVisible) 
    166                 { 
    167                         visibleGeometry->push_back(GtpVisibility::MeshInfo(*geometryIt, vis)); 
     182                {                         
     183                        insertGeom = visibleGeometry->insert(GtpVisibility::MeshInfo(*geometryIt, vis)); 
     184                        if (!insertGeom.second) // element already in list 
     185                        { 
     186                                //LogManager::getSingleton().logMessage("element already in list"); 
     187                (*insertGeom.first).SetVisibility((*insertGeom.first).GetVisibility() + vis); 
     188 
     189                                if (relativeVisibility) // relative visibility between zero and one 
     190                                { 
     191                                        (*insertGeom.first).SetVisibility((*insertGeom.first).GetVisibility() * 0.5); 
     192                                } 
     193                        } 
    168194                } 
    169195        } 
     
    179205        Camera *cam = sm->createCamera("PointQueryCam");         
    180206 
    181         Camera *oldCam = mViewport->getCamera(); 
     207        //save old camera 
     208        Camera *savedCam = mViewport->getCamera(); 
     209         
     210        // --- initialise new camera 
    182211        mViewport->setCamera(cam); 
    183  
    184212        cam->setPosition(point); 
    185213 
     214        cam->setNearClipDistance(savedCam->getNearClipDistance()); 
     215        cam->setFarClipDistance(savedCam->getFarClipDistance()); 
     216 
    186217        // set frustum to 45 degrees so all the scene can be captured with 6 shots 
    187         //cam->setAspectRatio(1.0); 
    188         //cam->setFOVy(Radian(Math::HALF_PI)); 
    189          
     218        cam->setAspectRatio(1.0); 
     219        cam->setFOVy(Radian(Math::HALF_PI)); 
     220 
    190221        std::stringstream d; 
    191         d << "old camera: " + StringConverter::toString(oldCam->getDerivedPosition()) +  
    192                 " " + "O: " + StringConverter::toString(oldCam->getDerivedOrientation()); 
     222        d << "old camera: " + StringConverter::toString(savedCam->getDerivedPosition()) +  
     223                " " + "O: " + StringConverter::toString(savedCam->getDerivedOrientation()); 
    193224        LogManager::getSingleton().logMessage(d.str()); 
    194225 
     
    201232                 
    202233                // Print camera details 
    203         //mViewport->getTarget()->setDebugText("P: " + StringConverter::toString(cam->getDerivedPosition()) +  
    204                 //      " " + "O: " + StringConverter::toString(cam->getDerivedOrientation())); 
    205                  
    206                 std::stringstream d; 
     234        std::stringstream d; 
    207235                d << "Point query camera: " + StringConverter::toString(cam->getDerivedPosition()) +  
    208236                        " " + "O: " + StringConverter::toString(cam->getDerivedOrientation()); 
     
    211239                ComputeCameraVisibility(*cam, visibleNodes, visibleGeometry, relativeVisibility); 
    212240                            
    213                 mViewport->getTarget()->update(); 
    214                  
     241                //mViewport->getTarget()->update(); for(int j=0; j<10000000; j++)       printf("HAAHHAHAHAHAH"); 
     242 
     243                // permute directions 
    215244                Vector3 dir(0,0,0); 
    216245                dir[i/2] = sign; 
    217246 
    218247                cam->setDirection(dir); 
    219  
    220                 for(int j=0; j<10000000; j++)   printf("HAAHHAHAHAHAH"); 
    221                                  
    222                 // four shots around y axis, two around x axis 
    223                 //Vector3 axis = i < 4 ? Vector3::UNIT_Y : Vector3::UNIT_X;              
    224                 //Radian angle = i < 5 ?  
    225                 //cam->rotate(axis, Radian(Math::HALF_PI));              
    226248        } 
    227249         
    228250 
    229251        // reset camera 
    230         mViewport->setCamera(oldCam); 
     252        mViewport->setCamera(savedCam); 
    231253} 
    232254//----------------------------------------------------------------------- 
  • trunk/VUT/Ogre/src/OgreVisibilityTerrainSceneManager.cpp

    r139 r141  
    609609        mLeavePassesInQueue = 0; 
    610610         
    611 /*      if (mShadowTechnique == SHADOWTYPE_STENCIL_ADDITIVE) 
     611        if (mShadowTechnique == SHADOWTYPE_STENCIL_ADDITIVE) 
    612612        { 
    613613                mShadowTechnique = SHADOWTYPE_NONE; 
     
    615615                if (!mUseDepthPass) 
    616616                { 
    617                         // TODO: remove this 
     617                        // TODO: remove this because should be processed in first pass 
    618618                        mLeavePassesInQueue |= RenderPriorityGroup::SOLID_PASSES_NOSHADOW; 
    619619 
     
    633633                } 
    634634        } 
    635         */ 
     635         
    636636        if (mDelayRenderTransparents && (!mUseDepthPass)) 
    637637        { 
    638638                mLeavePassesInQueue |= RenderPriorityGroup::TRANSPARENT_PASSES; 
    639639        } 
    640         std::stringstream d; d << "leave passes in queue: " << mLeavePassesInQueue; 
    641         LogManager::getSingleton().logMessage(d.str()); 
     640        //std::stringstream d; d << "leave passes in queue: " << mLeavePassesInQueue;LogManager::getSingleton().logMessage(d.str()); 
    642641 
    643642        // possible two cameras (one for culling, one for rendering) 
Note: See TracChangeset for help on using the changeset viewer.