Changeset 99


Ignore:
Timestamp:
05/15/05 04:08:02 (20 years ago)
Author:
mattausch
Message:
 
Location:
trunk/VUT
Files:
14 edited

Legend:

Unmodified
Added
Removed
  • trunk/VUT/GtpVisibility/src/VisibilityManager.cpp

    r95 r99  
    1414        mVisibilityEnvironment = visEnvironment; 
    1515         
    16         SetCullingManager(VisibilityEnvironment::COHERENT_HIERARCHICAL_CULLING); 
    17         //SetCullingManager(VisibilityEnvironment::FRUSTUM_CULLING); 
     16        //SetCullingManager(VisibilityEnvironment::COHERENT_HIERARCHICAL_CULLING); 
     17        SetCullingManager(VisibilityEnvironment::FRUSTUM_CULLING); 
    1818 
    1919        mQueryManager = new DummyQueryManager(0); 
  • trunk/VUT/Ogre/include/OgreVisibilityOctreeSceneManager.h

    r93 r99  
    5050        GtpVisibility::VisibilityManager *getVisibilityManager( void ); 
    5151 
    52         //writes out statis into the Ogre log file 
     52        //writes out stats into the Ogre log file 
    5353        void WriteLog(); 
    5454 
     
    5757        OctreeHierarchyInterface *mHierarchyInterface; 
    5858        GtpVisibility::VisibilityManager *mVisibilityManager; 
    59         bool mUseCulling; 
     59        bool mUseVisibilityCulling; 
    6060}; 
    6161 
  • trunk/VUT/Ogre/include/OgreVisibilitySceneManager.h

    r87 r99  
    5656        SceneNodeHierarchyInterface *mHierarchyInterface; 
    5757        GtpVisibility::VisibilityManager *mVisibilityManager; 
    58         bool mUseCulling; 
     58        bool mUseVisibilityCulling; 
    5959}; 
    6060} // namespace Ogre 
  • trunk/VUT/Ogre/include/OgreVisibilityTerrainSceneManager.h

    r93 r99  
    5353        GtpVisibility::VisibilityManager *getVisibilityManager(); 
    5454         
    55         //writes out statis into the Ogre log file 
     55        //writes out stats into the Ogre log file 
    5656        void WriteLog(); 
    57  
     57        void SetShowVisualization(bool showViz); 
     58         
    5859protected: 
    5960         
    6061        OctreeHierarchyInterface *mHierarchyInterface; 
    6162        GtpVisibility::VisibilityManager *mVisibilityManager; 
    62         bool mUseCulling; 
     63 
     64        bool mUseVisibilityCulling; 
     65        bool mShowVisualization; 
    6366}; 
    6467 
  • trunk/VUT/Ogre/src/OgreVisibilityOctreeSceneManager.cpp

    r96 r99  
    1212VisibilityOctreeSceneManager::VisibilityOctreeSceneManager( 
    1313        GtpVisibility::VisibilityManager *visManager) 
    14 : mVisibilityManager(visManager), mUseCulling(true) 
     14: mVisibilityManager(visManager), mUseVisibilityCulling(true) 
    1515{ 
    1616        mHierarchyInterface =  
     
    3838 
    3939        // standard scenemanager rendering without hierarchical culling 
    40         if(!mUseCulling) 
     40        if(!mUseVisibilityCulling) 
    4141        {        
    4242                OctreeSceneManager::_renderVisibleObjects(); 
     
    7676        SceneManager::_renderVisibleObjects(); 
    7777 
    78         // write out stats 
    79         WriteLog(); 
     78        //WriteLog(); // write out stats 
    8079} 
    8180//----------------------------------------------------------------------- 
    8281void VisibilityOctreeSceneManager::_findVisibleObjects(Camera* cam, bool onlyShadowCasters) 
    8382{ 
    84         // empty if hierarchical culling is used => 
     83        // does nothing if hierarchical culling is used => 
    8584        // we interleave identification and rendering of objects  
    8685        // in _renderVisibibleObjects  
    87         if(!mUseCulling) 
     86        getRenderQueue()->clear(); 
     87    mBoxes.clear(); 
     88    mVisible.clear(); 
     89 
     90        if(!mUseVisibilityCulling) 
    8891        { 
    8992                OctreeSceneManager::_findVisibleObjects(cam, onlyShadowCasters); 
     
    104107bool VisibilityOctreeSceneManager::setOption(const String & key, const void * val) 
    105108{ 
    106         if (key == "UseCulling") 
     109        if (key == "UseVisibilityCulling") 
    107110        { 
    108                 mUseCulling = (*static_cast<const bool *>(val)); 
     111                mUseVisibilityCulling = (*static_cast<const bool *>(val)); 
    109112                return true; 
    110113        } 
    111  
     114         
    112115        return VisibilityOptionsManager(mVisibilityManager, mHierarchyInterface). 
    113116                setOption(key, val) || OctreeSceneManager::setOption(key, val); 
  • trunk/VUT/Ogre/src/OgreVisibilitySceneManager.cpp

    r96 r99  
    1212//----------------------------------------------------------------------- 
    1313VisibilitySceneManager::VisibilitySceneManager(GtpVisibility::VisibilityManager *visManager) 
    14 :mVisibilityManager(visManager), mUseCulling(true) 
     14:mVisibilityManager(visManager), mUseVisibilityCulling(true) 
    1515{ 
    1616        mHierarchyInterface = new SceneNodeHierarchyInterface(this, mDestRenderSystem); 
     
    2727        // we interleave identification and rendering of objects  
    2828        // in _renderVisibibleObjects  
    29         if(!mUseCulling) 
     29        if(!mUseVisibilityCulling) 
    3030        { 
    3131                SceneManager::_findVisibleObjects(cam, onlyShadowCasters); 
     
    3838        mVisibilityManager->GetCullingManager()->InitFrame(); 
    3939 
    40         if(!mUseCulling) 
     40        if(!mUseVisibilityCulling) 
    4141        {        
    4242                SceneManager::_renderVisibleObjects(); 
  • trunk/VUT/Ogre/src/OgreVisibilityTerrainSceneManager.cpp

    r96 r99  
    1515VisibilityTerrainSceneManager::VisibilityTerrainSceneManager( 
    1616        GtpVisibility::VisibilityManager *visManager) 
    17 : mVisibilityManager(visManager), mUseCulling(true) 
     17: mVisibilityManager(visManager), mUseVisibilityCulling(true), 
     18mShowVisualization(false) 
    1819{ 
    1920        mHierarchyInterface =  
     
    3839         
    3940        // standard scenemanager rendering without hierarchical culling 
    40         if(!mUseCulling) 
     41        if(!mUseVisibilityCulling || mShowVisualization) 
    4142        {        
    4243                OctreeSceneManager::_renderVisibleObjects(); 
     
    7475        clearSpecialCaseRenderQueues(); 
    7576        SceneManager::_renderVisibleObjects(); 
     77 
     78        //WriteLog(); // write out stats 
    7679} 
    7780//----------------------------------------------------------------------- 
    7881void VisibilityTerrainSceneManager::_findVisibleObjects(Camera* cam, bool onlyShadowCasters) 
    7982{ 
    80         // empty if hierarchical culling is used => 
     83        // does nothing if hierarchical culling is used => 
    8184        // we interleave identification and rendering of objects  
    8285        // in _renderVisibibleObjects  
    83         if(!mUseCulling) 
     86        if (mShowVisualization) 
     87    { 
     88                for ( BoxList::iterator it = mBoxes.begin(); it != mBoxes.end(); ++it ) 
     89                { 
     90                        getRenderQueue()->addRenderable(*it); 
     91                } 
     92        } 
     93 
     94        getRenderQueue()->clear(); 
     95    mBoxes.clear(); 
     96    mVisible.clear(); 
     97 
     98        if(!mUseVisibilityCulling) 
    8499        { 
    85100                OctreeSceneManager::_findVisibleObjects(cam, onlyShadowCasters); 
     
    101116bool VisibilityTerrainSceneManager::setOption(const String & key, const void * val) 
    102117{ 
    103         if (key == "UseCulling") 
     118        if (key == "UseVisibilityCulling") 
    104119        { 
    105                 mUseCulling = (*static_cast<const bool *>(val)); 
     120                mUseVisibilityCulling = (*static_cast<const bool *>(val)); 
     121                return true; 
     122        } 
     123        if (key == "ShowVisualization") 
     124        { 
     125                mShowVisualization = (*static_cast<const bool *>(val)); 
    106126                return true; 
    107127        } 
     
    119139        } 
    120140         
     141 
    121142        return VisibilityOptionsManager(mVisibilityManager, mHierarchyInterface). 
    122143                getOption(key, val) && TerrainSceneManager::getOption(key, val); 
     
    144165} 
    145166//----------------------------------------------------------------------- 
     167void VisibilityTerrainSceneManager::SetShowVisualization(bool showViz) 
     168{ 
     169        mShowVisualization = showViz; 
     170} 
     171//----------------------------------------------------------------------- 
    146172void VisibilityTerrainSceneManager::WriteLog() 
    147173{ 
  • trunk/VUT/work/TestCulling/TestCullingApplication.cpp

    r94 r99  
    111111mCurrentAlgorithm(GtpVisibility::VisibilityEnvironment::COHERENT_HIERARCHICAL_CULLING), 
    112112mShowOctree(false), 
    113 mUseCulling(true), 
     113mUseVisibilityCulling(true), 
    114114mUseOptimization(true), 
    115 mUseCullCamera(false) 
     115mShowVisualization(false) 
    116116{ 
    117117    // Reduce move speed 
     
    153153         
    154154        mSceneMgr->setOption("UseOptimization", &mUseOptimization); 
    155         mSceneMgr->setOption("UseCulling", &mUseCulling); 
    156         mSceneMgr->setOption("CullCamera", &mUseCullCamera); 
     155        mSceneMgr->setOption("UseVisibilityCulling", &mUseVisibilityCulling); 
     156        mSceneMgr->setOption("ShowVizualisation", &mShowVisualization); 
    157157        mSceneMgr->setOption("ShowOctree", &mShowOctree); 
    158158 
     
    235235        KEY_PRESSED(KC_ADD, 0, changeThreshold(10)); 
    236236        KEY_PRESSED(KC_O, 0.3, toggleUseOptimization()); 
    237         KEY_PRESSED(KC_C, 0.3, toggleUseCulling()); 
    238         KEY_PRESSED(KC_V, 0.3, toggleCullCamera()); 
     237        KEY_PRESSED(KC_C, 0.3, toggleUseVisibilityCulling()); 
     238        KEY_PRESSED(KC_V, 0.3, toggleShowViz()); 
    239239 
    240240        updateStats(); 
     
    281281} 
    282282//----------------------------------------------------------------------- 
    283 void MouseQueryListener::toggleUseCulling() 
    284 { 
    285         mUseCulling = !mUseCulling; 
    286  
    287         mSceneMgr->setOption("UseCulling", &mUseCulling); 
    288 } 
    289 //----------------------------------------------------------------------- 
    290 void MouseQueryListener::toggleCullCamera() 
    291 { 
    292         mUseCullCamera = !mUseCullCamera; 
    293  
    294         mSceneMgr->setOption("CullCamera", &mUseCullCamera); 
     283void MouseQueryListener::toggleUseVisibilityCulling() 
     284{ 
     285        mUseVisibilityCulling = !mUseVisibilityCulling; 
     286 
     287        mSceneMgr->setOption("UseVisibilityCulling", &mUseVisibilityCulling); 
     288} 
     289//----------------------------------------------------------------------- 
     290void MouseQueryListener::toggleShowViz() 
     291{ 
     292        mShowVisualization = !mShowVisualization; 
     293 
     294        mSceneMgr->setOption("CullCamera", &mShowVisualization); 
    295295} 
    296296//----------------------------------------------------------------------- 
  • trunk/VUT/work/TestCulling/TestCullingApplication.h

    r94 r99  
    6666        void toggleUseOptimization(); 
    6767        void toggleShowOctree(); 
    68         void toggleUseCulling(); 
    69         void toggleCullCamera(); 
     68        void toggleUseVisibilityCulling(); 
     69        void toggleShowViz(); 
    7070 
    7171protected: 
     
    9494        bool mUseOptimization; 
    9595        bool mShowOctree; 
    96         bool mUseCulling; 
    97         bool mUseCullCamera; 
     96        bool mUseVisibilityCulling; 
     97        bool mShowVisualization; 
    9898 
    9999        Camera *mVisualizationCamera; 
  • trunk/VUT/work/TestCullingTerrain/TestCullingTerrainApplication.cpp

    r98 r99  
    2727        if(mTerrainContentGenerator) 
    2828                delete mTerrainContentGenerator; 
     29        //if(mRenderTargetListener)     delete mRenderTargetListener; 
    2930} 
    3031//----------------------------------------------------------------------- 
    3132void TestCullingTerrainApplication::createCamera() 
    3233{ 
    33         // Create the camera 
    34         mCamera = mSceneMgr->createCamera("CullCamera"); 
    35          
    36         // Set a nice viewpoint 
     34        // create the camera 
     35        mCamera = mSceneMgr->createCamera("PlayerCam"); 
     36         
     37        // set a nice viewpoint 
    3738        mCamera->setPosition(707, 2500, 528); 
    3839        mCamera->setOrientation(Quaternion(-0.3486, 0.0122, 0.9365, 0.0329)); 
    3940         
    40         //--create cull camera 
    41         mVisualizationCamera = mSceneMgr->createCamera("VisualizationCamera"); 
    42         mVisualizationCamera->setPosition(707, 2500, 528); 
    43         mVisualizationCamera->setOrientation(Quaternion(-0.3486, 0.0122, 0.9365, 0.0329)); 
     41        //--create visualization camera 
     42        mVisualizationCamera = mSceneMgr->createCamera("VizCam"); 
     43        mVisualizationCamera->setPosition(mCamera->getPosition()); 
     44        mVisualizationCamera->setOrientation(mCamera->getOrientation()); 
    4445 
    4546        mVisualizationCamera->setNearClipDistance(1); 
    4647        mCamera->setNearClipDistance(1); 
    4748 
    48         // Infinite far plane? 
     49        // infinite far plane? 
    4950        if (mRoot->getRenderSystem()->getCapabilities()->hasCapability(RSC_INFINITE_FAR_PLANE)) 
    5051        { 
     
    5657                 mVisualizationCamera->setFarClipDistance(1000); 
    5758                 mCamera->setFarClipDistance(1000); 
    58         } 
    59          
     59        }        
     60} 
     61 
     62//----------------------------------------------------------------------- 
     63bool TestCullingTerrainApplication::setup() 
     64{ 
     65        bool result = ExampleApplication::setup(); 
     66 
     67        createRenderTargetListener(); 
     68 
     69        return result; 
     70} 
     71//----------------------------------------------------------------------- 
     72void TestCullingTerrainApplication::createRenderTargetListener() 
     73{ 
     74        mWindow->addListener(new VisualizationRenderTargetListener(mSceneMgr)); 
    6075} 
    6176//----------------------------------------------------------------------- 
     
    152167mCurrentAlgorithm(GtpVisibility::VisibilityEnvironment::COHERENT_HIERARCHICAL_CULLING), 
    153168mShowOctree(false), 
    154 mUseCulling(true), 
     169mUseVisibilityCulling(true), 
    155170mUseOptimization(true), 
    156 mUseCullCamera(false), 
    157171mVisualizationCamera(vizCamera) 
    158172{ 
     
    197211 
    198212        mSceneMgr->setOption("UseOptimization", &mUseOptimization); 
    199         mSceneMgr->setOption("UseCulling", &mUseCulling); 
    200         mSceneMgr->setOption("CullCamera", &mUseCullCamera); 
     213        mSceneMgr->setOption("UseVisibilityCulling", &mUseVisibilityCulling); 
    201214        mSceneMgr->setOption("ShowOctree", &mShowOctree); 
    202  
     215         
    203216    pOver->show(); 
    204217}  
     
    241254     } // else if 
    242255} // mousePressed 
    243  
    244  //----------------------------------------------------------------------- 
     256//----------------------------------------------------------------------- 
    245257void MouseQueryListener::mouseReleased(MouseEvent* e) 
    246258{ 
     
    316328        KEY_PRESSED(KC_O, 0.3, toggleUseOptimization()); 
    317329        KEY_PRESSED(KC_Y, 0.3, toggleShowOctree()); 
    318         KEY_PRESSED(KC_C, 0.3, toggleUseCulling()); 
    319         KEY_PRESSED(KC_V, 0.3, toggleCullCamera()); 
     330        KEY_PRESSED(KC_C, 0.3, toggleUseVisibilityCulling()); 
     331        KEY_PRESSED(KC_V, 0.3, toggleShowViz()); 
    320332        KEY_PRESSED(KC_X, 0.3, FixVizCamera()); 
    321333 
     
    397409} 
    398410//----------------------------------------------------------------------- 
    399 void MouseQueryListener::toggleUseCulling() 
    400 { 
    401         mUseCulling = !mUseCulling; 
    402  
    403         mSceneMgr->setOption("UseCulling", &mUseCulling); 
    404 } 
    405 //----------------------------------------------------------------------- 
    406 void MouseQueryListener::toggleCullCamera() 
    407 { 
    408         mUseCullCamera = !mUseCullCamera; 
    409  
    410         if(mUseCullCamera) 
     411void MouseQueryListener::toggleUseVisibilityCulling() 
     412{ 
     413        mUseVisibilityCulling = !mUseVisibilityCulling; 
     414 
     415        mSceneMgr->setOption("UseVisibilityCulling", &mUseVisibilityCulling); 
     416} 
     417//----------------------------------------------------------------------- 
     418void MouseQueryListener::toggleShowViz() 
     419{ 
     420        mShowVisualization = !mShowVisualization; 
     421 
     422        // create viewport with priority 10: will be rendered over standard viewport 
     423        if(mShowVisualization) 
    411424        {        
    412425                mWindow->addViewport(mVisualizationCamera, 10, 0.5, 0.5, 1, 1); 
     
    414427        } 
    415428        else 
     429        { 
    416430                mWindow->removeViewport(10); 
    417  
    418         mSceneMgr->setOption("CullCamera", &mUseCullCamera); 
     431        } 
    419432} 
    420433//----------------------------------------------------------------------- 
     
    451464        // Do nothing 
    452465        e->consume(); 
     466} 
     467/**************************************************************/ 
     468/*      VisualizationRenderTargetListener implementation      */ 
     469/**************************************************************/ 
     470VisualizationRenderTargetListener::VisualizationRenderTargetListener(SceneManager *sceneMgr) 
     471:RenderTargetListener(), mSceneMgr(sceneMgr) 
     472{ 
     473} 
     474//----------------------------------------------------------------------- 
     475void VisualizationRenderTargetListener::preViewportUpdate(const RenderTargetViewportEvent &evt) 
     476{ 
     477        const bool b = evt.source->getZOrder() == 10; // visualization viewport 
     478                         
     479        mSceneMgr->setOption("ShowVisualization", &b); 
     480         
     481        RenderTargetListener::preViewportUpdate(evt); 
     482} 
     483//----------------------------------------------------------------------- 
     484void VisualizationRenderTargetListener::postRenderTargetUpdate(const RenderTargetEvent &evt) 
     485{ 
     486        RenderTargetListener::postRenderTargetUpdate(evt); 
    453487} 
    454488//----------------------------------------------------------------------- 
  • trunk/VUT/work/TestCullingTerrain/TestCullingTerrainApplication.h

    r94 r99  
    77#include "TerrainContentGenerator.h" 
    88#include "VisibilityEnvironment.h" 
     9#include <OgreRenderTargetListener.h> 
    910 
    1011Real timeDelay = 0; 
     
    2324        "Stop and Wait Culling",  
    2425        "Coherent Hierarchical Culling" 
     26}; 
     27 
     28class VisualizationRenderTargetListener: public RenderTargetListener 
     29{ 
     30public: 
     31        VisualizationRenderTargetListener(SceneManager *sceneMgr); 
     32 
     33protected: 
     34        void preViewportUpdate (const RenderTargetViewportEvent &evt); 
     35        void postRenderTargetUpdate (const RenderTargetEvent &evt); 
     36 
     37        SceneManager *mSceneMgr; 
    2538}; 
    2639 
     
    6578        void toggleUseOptimization(); 
    6679        void toggleShowOctree(); 
    67         void toggleUseCulling(); 
    68         void toggleCullCamera(); 
     80        void toggleUseVisibilityCulling(); 
     81        void toggleShowViz(); 
    6982        void FixVizCamera(); 
    7083 
     
    100113        bool mUseOptimization; 
    101114        bool mShowOctree; 
    102         bool mUseCulling; 
    103         bool mUseCullCamera; 
     115        bool mUseVisibilityCulling; 
     116        bool mShowVisualization; 
    104117 
    105118        Camera *mVisualizationCamera; 
     
    113126 
    114127protected: 
     128        //-- inherited from ExampleApplication 
     129        bool setup(); 
    115130        void createScene(); 
    116131        void createFrameListener(); 
     132        void createCamera(); 
     133        //void createViewports(); 
     134         
     135        virtual void createRenderTargetListener(); 
     136 
     137        /** cegui setup */ 
    117138        void setupGui(); 
    118         virtual void createCamera(); 
    119139 
    120140        CEGUI::OgreCEGUIRenderer *mGUIRenderer; 
     
    128148 
    129149        TerrainContentGenerator *mTerrainContentGenerator; 
     150         
     151        Camera *mVisualizationCamera; 
     152        VisualizationRenderTargetListener *mRenderTargetListener; 
    130153 
    131         Camera *mVisualizationCamera; 
    132          
    133154private: 
    134155        void chooseSceneManager(void); 
    135156}; 
    136  
  • trunk/VUT/work/ogre_changes/OgreMain/src/OgreSceneManager.cpp

    r61 r99  
    41784178    } 
    41794179} 
    4180 #ifdef OGRE_COHERENT_OCCLUSION_CULLING 
     4180#ifdef GTP_VISIBILITY_MODIFIED_OGRE 
    41814181//----------------------------------------------------------------------- 
    41824182void SceneManager::_renderSceneNode( Camera *cam, SceneNode *node ) 
     
    41934193        RenderQueue::QueueGroupIterator queueIt = getRenderQueue()->_getQueueGroupIterator(); 
    41944194 
     4195        // find currently processed queue groups and delelete them from render queue 
    41954196        while (queueIt.hasMoreElements()) 
    41964197        { 
     
    41984199                RenderQueueGroup* pGroup = queueIt.getNext(); 
    41994200 
    4200                 // delete this queue group if already processed 
    42014201                if (isRenderQueueToBeProcessed(qId)) 
    42024202                        pGroup->clear(); 
     
    42064206        // Pass::processPendingPassUpdates(); 
    42074207} 
    4208 #endif //OGRE_COHERENT_OCCLUSION_CULLING 
    4209 } 
     4208#endif //GTP_VISIBILITY_MODIFIED_OGRE 
     4209} 
  • trunk/VUT/work/ogre_changes/Plugins/OctreeSceneManager/src/OgreOctreeSceneManager.cpp

    r61 r99  
    316316 
    317317    mOctree = new Octree( 0 ); 
    318 #ifdef OGRE_COHERENT_OCCLUSION_CULLING 
     318#ifdef GTP_VISIBILITY_MODIFIED_OGRE 
    319319        mNumOctreeNodes = 1; 
    320 #endif // OGRE_COHERENT_OCCLUSION_CULLING 
     320#endif // GTP_VISIBILITY_MODIFIED_OGRE 
    321321    mMaxDepth = depth; 
    322322    mBox = box; 
     
    461461        { 
    462462            octant -> mChildren[ x ][ y ][ z ] = new Octree( octant ); 
    463 #ifdef OGRE_COHERENT_OCCLUSION_CULLING 
     463#ifdef GTP_VISIBILITY_MODIFIED_OGRE 
    464464        mNumOctreeNodes ++; 
    465 #endif // OGRE_COHERENT_OCCLUSION_CULLING 
     465#endif // GTP_VISIBILITY_MODIFIED_OGRE 
    466466 
    467467            const Vector3 *corners = octant -> mBox.getAllCorners(); 
     
    10281028 
    10291029    mOctree = new Octree( 0 ); 
    1030 #ifdef OGRE_COHERENT_OCCLUSION_CULLING 
     1030#ifdef GTP_VISIBILITY_MODIFIED_OGRE 
    10311031        mNumOctreeNodes = 1; 
    1032 #endif // OGRE_COHERENT_OCCLUSION_CULLING 
     1032#endif // GTP_VISIBILITY_MODIFIED_OGRE 
    10331033    mOctree->mBox = box; 
    10341034 
     
    11661166    return q; 
    11671167} 
    1168 #ifdef OGRE_COHERENT_OCCLUSION_CULLING 
     1168#ifdef GTP_VISIBILITY_MODIFIED_OGRE 
    11691169//----------------------------------------------------------------------- 
    11701170void OctreeSceneManager::_renderOctant(Camera *cam, Octree *octant) 
     
    11771177                OctreeNode *sn = *it; 
    11781178 
    1179         mNumObjects++; 
     1179        ++mNumObjects; 
    11801180 
    11811181                // check bounding box visibility of scene nodes 
     
    11871187 
    11881188                        if (mDisplayNodes) 
     1189                        { 
    11891190                                getRenderQueue()->addRenderable(sn); 
     1191                        } 
    11901192 
    11911193                        // check if the scene manager or this node wants the bounding box shown. 
    11921194                        if (sn->getShowBoundingBox() || mShowBoundingBoxes) 
     1195                        { 
    11931196                                sn->_addBoundingBoxToQueue(getRenderQueue()); 
    1194  
    1195                         if (mShowBoxes) 
    1196                                 getRenderQueue()->addRenderable(octant->getWireBoundingBox()); 
     1197                        } 
    11971198                } 
    11981199        ++it; 
    11991200        } 
    12001201 
     1202        if (mShowBoxes) 
     1203        { 
     1204                getRenderQueue()->addRenderable(octant->getWireBoundingBox()); 
     1205                ++mNumObjects; 
     1206        } 
     1207 
    12011208        SceneManager::_renderVisibleObjects(); 
    12021209 
    1203         // delete all rendered objects from renderqueue 
     1210        // delete all rendered objects from the render queue 
    12041211        _deleteRenderedQueueGroups(); 
    12051212} 
    1206 #endif // OGRE_COHERENT_OCCLUSION_CULLING 
    1207 } 
     1213#endif // GTP_VISIBILITY_MODIFIED_OGRE 
     1214} 
  • trunk/VUT/work/ogre_changes/RenderSystems/GL/src/OgreGLHardwareOcclusionQuery.cpp

    r97 r99  
    161161 
    162162        // Check for hardware occlusion support 
    163     // if( glDeleteOcclusionQueriesNV_ptr != 0 )        // This is a hack to see if hw occlusion is supported. pointer is 0 if it's not supported. 
    164         if( glDeleteQueriesARB_ptr != 0 ) 
     163    if ( glDeleteOcclusionQueriesNV_ptr != 0 )  // This is a hack to see if hw occlusion is supported. pointer is 0 if it's not supported. 
     164        //if ( glDeleteQueriesARB_ptr != 0 ) 
    165165        { 
    166166                m_bHWOcclusionSupport = true; 
     
    171171        } 
    172172 
    173         if( m_bHWOcclusionSupport ) 
    174         { 
    175                 //glGenOcclusionQueriesNV_ptr( 1, m_uintQuery );         
    176                 glGenQueriesARB_ptr(1, m_uintQuery); 
     173        if ( m_bHWOcclusionSupport ) 
     174        { 
     175                glGenOcclusionQueriesNV_ptr( 1, m_uintQuery );   
     176                //glGenQueriesARB_ptr(1, m_uintQuery); 
    177177        } 
    178178} 
     
    182182GLHardwareOcclusionQuery::~GLHardwareOcclusionQuery()  
    183183{  
    184         if( m_bHWOcclusionSupport ) 
    185         { 
    186                 //glDeleteOcclusionQueriesNV_ptr( 1, &m_uintQuery[0] );   
    187                 glDeleteQueriesARB_ptr(1, &m_uintQuery[0]); 
     184        if ( m_bHWOcclusionSupport ) 
     185        { 
     186                glDeleteOcclusionQueriesNV_ptr( 1, &m_uintQuery[0] );   
     187                //glDeleteQueriesARB_ptr(1, &m_uintQuery[0]); 
    188188        }        
    189189} 
     
    192192void GLHardwareOcclusionQuery::beginOcclusionQuery()  
    193193{  
    194         if( m_bHWOcclusionSupport )     // Make it fail silently if hardware occlusion isn't supported 
     194        if ( m_bHWOcclusionSupport )    // Make it fail silently if hardware occlusion isn't supported 
    195195        { 
    196196                // do the actual occlusion query for this node 
    197                 //glBeginOcclusionQueryNV_ptr( m_uintQuery[0] ); 
    198                 glBeginQueryARB_ptr(GL_SAMPLES_PASSED_ARB, m_uintQuery[0]); 
     197                glBeginOcclusionQueryNV_ptr( m_uintQuery[0] ); 
     198                //glBeginQueryARB_ptr(GL_SAMPLES_PASSED_ARB, m_uintQuery[0]); 
    199199        } 
    200200} 
     
    202202void GLHardwareOcclusionQuery::endOcclusionQuery()  
    203203{  
    204         if( m_bHWOcclusionSupport )     // Make it fail silently if hardware occlusion isn't supported 
    205         { 
    206                 //glEndOcclusionQueryNV_ptr(); 
    207                 glEndQueryARB_ptr(GL_SAMPLES_PASSED_ARB); 
     204        if ( m_bHWOcclusionSupport )    // Make it fail silently if hardware occlusion isn't supported 
     205        { 
     206                glEndOcclusionQueryNV_ptr(); 
     207                //glEndQueryARB_ptr(GL_SAMPLES_PASSED_ARB); 
    208208        } 
    209209} 
     
    211211bool GLHardwareOcclusionQuery::pullOcclusionQuery( unsigned int * NumOfFragments, const bool waitForResult)  
    212212{ 
    213         //unsigned int isAvailable = GL_TRUE; 
    214         int isAvailable = GL_TRUE; 
     213        unsigned int isAvailable = GL_TRUE; 
     214        //int isAvailable = GL_TRUE; 
    215215 
    216216        if( m_bHWOcclusionSupport )      
    217217        { 
    218                 if(!waitForResult) 
    219                 { 
    220                         //glGetOcclusionQueryuivNV_ptr( m_uintQuery[0], GL_PIXEL_COUNT_AVAILABLE_NV, &isAvailable ); 
    221                         glGetQueryivARB_ptr(m_uintQuery[0], GL_QUERY_RESULT_AVAILABLE_ARB, &isAvailable); 
    222                 } 
    223  
    224                 if(isAvailable == GL_TRUE) 
    225                 { 
    226                         glGetQueryObjectuivARB_ptr( m_uintQuery[0], GL_QUERY_RESULT_ARB, NumOfFragments); 
    227                         //glGetOcclusionQueryuivNV_ptr( m_uintQuery[0], GL_PIXEL_COUNT_NV, NumOfFragments ); 
     218                if (!waitForResult) 
     219                { 
     220                        glGetOcclusionQueryuivNV_ptr( m_uintQuery[0], GL_PIXEL_COUNT_AVAILABLE_NV, &isAvailable ); 
     221                        //glGetQueryivARB_ptr(m_uintQuery[0], GL_QUERY_RESULT_AVAILABLE_ARB, &isAvailable); 
     222                } 
     223 
     224                if (isAvailable == GL_TRUE) 
     225                { 
     226                        glGetOcclusionQueryuivNV_ptr( m_uintQuery[0], GL_PIXEL_COUNT_NV, NumOfFragments ); 
     227                        //glGetQueryObjectuivARB_ptr( m_uintQuery[0], GL_QUERY_RESULT_ARB, NumOfFragments); 
    228228                } 
    229229        }  
Note: See TracChangeset for help on using the changeset viewer.