Changeset 115 for trunk/VUT/work


Ignore:
Timestamp:
05/30/05 03:20:23 (20 years ago)
Author:
mattausch
Message:

added depth pass algorithm + delayed transparent object rendering (so depth ordering is right)

Location:
trunk/VUT/work
Files:
4 added
19 edited

Legend:

Unmodified
Added
Removed
  • trunk/VUT/work/TestCulling/TestCulling.vcproj

    r107 r115  
    1313                <Configuration 
    1414                        Name="Debug|Win32" 
    15                         OutputDirectory=".\bin\$(ConfigurationName)" 
     15                        OutputDirectory=".\lib\$(ConfigurationName)" 
    1616                        IntermediateDirectory=".\obj\$(ConfigurationName)" 
    1717                        ConfigurationType="1" 
     
    2121                                Name="VCCLCompilerTool" 
    2222                                Optimization="0" 
    23                                 AdditionalIncludeDirectories="&quot;$(OGRE_PATH)\Dependencies\include&quot;;&quot;$(OGRE_PATH)\OgreMain\include&quot;;&quot;$(OGRE_PATH)\Samples\Common\include&quot;;&quot;$(OGRE_PATH)\Dependencies\include\CEGUI&quot;;&quot;$(OGRE_PATH)\PlugIns\OctreeSceneManager\include&quot;;&quot;$(OGRE_ADDONS_PATH)\dotsceneoctree\PlugIns\DotSceneManager\include&quot;;&quot;$(OGRE_PATH)\Samples\Common\CEGUIRenderer\include&quot;;../include;../../GtpVisibility/include" 
     23                                AdditionalIncludeDirectories="&quot;$(OGRE_PATH)\Dependencies\include&quot;;&quot;$(OGRE_PATH)\OgreMain\include&quot;;&quot;$(OGRE_PATH)\Samples\Common\include&quot;;&quot;$(OGRE_PATH)\Dependencies\include\CEGUI&quot;;&quot;$(OGRE_PATH)\PlugIns\OctreeSceneManager\include&quot;;&quot;$(OGRE_ADDONS_PATH)\dotsceneoctree\PlugIns\DotSceneManager\include&quot;;&quot;$(OGRE_PATH)\Samples\Common\CEGUIRenderer\include&quot;;../include;../../GtpVisibility/include;../../Ogre/include" 
    2424                                PreprocessorDefinitions="_WINDOWS;_STLP_USE_DYNAMIC_LIB;OGRE_LIBRARY_IMPORTS;_DEBUG;WIN32;_STLP_DEBUG;PLUGIN_TERRAIN_IMPORTS;GTP_VISIBILITY_MODIFIED_OGRE" 
    2525                                MinimalRebuild="TRUE" 
     
    3434                        <Tool 
    3535                                Name="VCLinkerTool" 
    36                                 AdditionalDependencies="Plugin_OctreeSceneManager.lib OGREMain_d.LIB CEGUIBase_d.lib OgreGUIRenderer_d.lib Plugin_DotSceneManager.lib" 
     36                                AdditionalDependencies="Plugin_OctreeSceneManager.lib OGREMain_d.LIB CEGUIBase_d.lib OgreGUIRenderer_d.lib Plugin_DotSceneManager.lib Plugin_VisibilitySceneManager.lib" 
    3737                                OutputFile="$(OGRE_PATH)/Samples/Common/bin/Debug/TestCulling.exe" 
    3838                                LinkIncremental="2" 
    39                                 AdditionalLibraryDirectories="&quot;$(OGRE_PATH)\Dependencies\Lib\$(ConfigurationName)&quot;;&quot;$(OGRE_ADDONS_PATH)\dotsceneoctree\PlugIns\DotSceneManager\bin\$(ConfigurationName)&quot;;&quot;$(OGRE_PATH)\OgreMain\Lib\$(ConfigurationName)&quot;;&quot;$(OGRE_PATH)\PlugIns\OctreeSceneManager\bin\$(ConfigurationName)&quot;;&quot;$(OGRE_PATH)\Samples\Common\CEGUIRenderer\lib&quot;" 
     39                                AdditionalLibraryDirectories="&quot;$(OGRE_PATH)\Dependencies\Lib\$(ConfigurationName)&quot;;&quot;$(OGRE_ADDONS_PATH)\dotsceneoctree\PlugIns\DotSceneManager\bin\$(ConfigurationName)&quot;;&quot;$(OGRE_PATH)\OgreMain\Lib\$(ConfigurationName)&quot;;&quot;$(OGRE_PATH)\PlugIns\OctreeSceneManager\bin\$(ConfigurationName)&quot;;&quot;$(OGRE_PATH)\Samples\Common\CEGUIRenderer\lib&quot;;&quot;$(GAMETOOLS_PATH)\trunk\VUT\Ogre\lib\$(ConfigurationName)&quot;" 
    4040                                GenerateDebugInformation="TRUE" 
    4141                                ProgramDatabaseFile="$(OutDir)/TestCulling.pdb" 
  • trunk/VUT/work/TestCulling/TestCullingApplication.cpp

    r112 r115  
    8181void TestCullingApplication::createFrameListener() 
    8282{ 
    83         mFrameListener= new MouseQueryListener(mWindow, mCamera, mSceneMgr,  
     83        mFrameListener= new TerrainMouseQueryListener(mWindow, mCamera, mSceneMgr,  
    8484                mGUIRenderer, mSceneContentGenerator); 
    8585        mFrameListener->showDebugOverlay(true); 
     
    9494 
    9595/***********************************************/ 
    96 /* MouseQueryListener implementation           */ 
     96/* TerrainMouseQueryListener implementation           */ 
    9797/***********************************************/ 
    9898//----------------------------------------------------------------------- 
    99 MouseQueryListener::MouseQueryListener(RenderWindow* win, Camera* cam,  
     99TerrainMouseQueryListener::TerrainMouseQueryListener(RenderWindow* win, Camera* cam,  
    100100                                                                           SceneManager *sceneManager,  
    101101                                                                           CEGUI::Renderer *renderer, 
     
    111111mCurrentAlgorithm(GtpVisibility::VisibilityEnvironment::COHERENT_HIERARCHICAL_CULLING), 
    112112mShowOctree(false), 
    113 mUseVisibilityCulling(true), 
     113mUseDepthPass(false), 
    114114mUseOptimization(true), 
    115115mShowVisualization(false), 
     
    154154         
    155155        mSceneMgr->setOption("UseOptimization", &mUseOptimization); 
    156         mSceneMgr->setOption("UseVisibilityCulling", &mUseVisibilityCulling); 
     156        mSceneMgr->setOption("UseDepthPass", &mUseDepthPass); 
    157157        mSceneMgr->setOption("ShowVizualisation", &mShowVisualization); 
    158158        mSceneMgr->setOption("ShowOctree", &mShowOctree); 
     
    161161}  
    162162//----------------------------------------------------------------------- 
    163 MouseQueryListener::~MouseQueryListener( ) 
    164 { 
    165 } 
    166 //----------------------------------------------------------------------- 
    167 void MouseQueryListener::mouseMoved (MouseEvent *e) 
     163TerrainMouseQueryListener::~TerrainMouseQueryListener( ) 
     164{ 
     165} 
     166//----------------------------------------------------------------------- 
     167void TerrainMouseQueryListener::mouseMoved (MouseEvent *e) 
    168168{ 
    169169        // Update CEGUI with the mouse motion 
     
    171171} 
    172172//----------------------------------------------------------------------- 
    173 void MouseQueryListener::mousePressed(MouseEvent* e) 
     173void TerrainMouseQueryListener::mousePressed(MouseEvent* e) 
    174174{ 
    175175     // Left mouse button down 
     
    187187 
    188188 //----------------------------------------------------------------------- 
    189 void MouseQueryListener::mouseReleased(MouseEvent* e) 
     189void TerrainMouseQueryListener::mouseReleased(MouseEvent* e) 
    190190{ 
    191191    // Left mouse button up 
     
    203203}  
    204204//----------------------------------------------------------------------- 
    205 void MouseQueryListener::mouseDragged (MouseEvent *e) 
     205void TerrainMouseQueryListener::mouseDragged (MouseEvent *e) 
    206206 { 
    207207         // If we are dragging the left mouse button.             
     
    218218} 
    219219//----------------------------------------------------------------------- 
    220 bool MouseQueryListener::frameStarted(const FrameEvent &evt) 
     220bool TerrainMouseQueryListener::frameStarted(const FrameEvent &evt) 
    221221{         
    222222        return ExampleFrameListener::frameStarted(evt); 
    223223} 
    224224//----------------------------------------------------------------------- 
    225 bool MouseQueryListener::frameEnded(const FrameEvent& evt) 
     225bool TerrainMouseQueryListener::frameEnded(const FrameEvent& evt) 
    226226{ 
    227227        if (mShutdownRequested) 
     
    236236        KEY_PRESSED(KC_ADD, 0, changeThreshold(10)); 
    237237        KEY_PRESSED(KC_O, 0.3, toggleUseOptimization()); 
    238         KEY_PRESSED(KC_C, 0.3, toggleUseVisibilityCulling()); 
     238        KEY_PRESSED(KC_C, 0.3, toggleUseDepthPass()); 
    239239        KEY_PRESSED(KC_V, 0.3, toggleShowViz()); 
    240240 
     
    244244} 
    245245//----------------------------------------------------------------------- 
    246 void MouseQueryListener::changeThreshold(int incr) 
     246void TerrainMouseQueryListener::changeThreshold(int incr) 
    247247{ 
    248248        mVisibilityThreshold += incr;  
     
    255255} 
    256256//----------------------------------------------------------------------- 
    257 void MouseQueryListener::nextAlgorithm() 
     257void TerrainMouseQueryListener::nextAlgorithm() 
    258258{ 
    259259        mCurrentAlgorithm = ++mCurrentAlgorithm %  
     
    263263} 
    264264//----------------------------------------------------------------------- 
    265 void MouseQueryListener::toggleUseOptimization() 
     265void TerrainMouseQueryListener::toggleUseOptimization() 
    266266{ 
    267267        mUseOptimization = !mUseOptimization; 
     
    275275} 
    276276//----------------------------------------------------------------------- 
    277 void MouseQueryListener::toggleShowOctree() 
     277void TerrainMouseQueryListener::toggleShowOctree() 
    278278{ 
    279279        mShowOctree = !mShowOctree; 
     
    282282} 
    283283//----------------------------------------------------------------------- 
    284 void MouseQueryListener::toggleUseVisibilityCulling() 
    285 { 
    286         mUseVisibilityCulling = !mUseVisibilityCulling; 
    287  
    288         mSceneMgr->setOption("UseVisibilityCulling", &mUseVisibilityCulling); 
    289 } 
    290 //----------------------------------------------------------------------- 
    291 void MouseQueryListener::toggleShowViz() 
     284void TerrainMouseQueryListener::toggleUseDepthPass() 
     285{ 
     286        mUseDepthPass = !mUseDepthPass; 
     287 
     288        mSceneMgr->setOption("UseDepthPass", &mUseDepthPass); 
     289} 
     290//----------------------------------------------------------------------- 
     291void TerrainMouseQueryListener::toggleShowViz() 
    292292{ 
    293293        mShowVisualization = !mShowVisualization; 
     
    297297} 
    298298//----------------------------------------------------------------------- 
    299 void MouseQueryListener::setAlgorithm(int algorithm) 
     299void TerrainMouseQueryListener::setAlgorithm(int algorithm) 
    300300{ 
    301301        mAlgorithmInfo->setCaption(": " + mCurrentAlgorithmCaptions[mCurrentAlgorithm]); 
     
    303303} 
    304304//----------------------------------------------------------------------- 
    305 void MouseQueryListener::updateStats() 
     305void TerrainMouseQueryListener::updateStats() 
    306306{ 
    307307        unsigned int opt = 0; 
     
    330330} 
    331331//----------------------------------------------------------------------- 
    332 void MouseQueryListener::keyPressed(KeyEvent* e) 
     332void TerrainMouseQueryListener::keyPressed(KeyEvent* e) 
    333333{ 
    334334        if(e->getKey() == KC_ESCAPE) 
     
    344344} 
    345345//----------------------------------------------------------------------- 
    346 void MouseQueryListener::keyReleased(KeyEvent* e) 
     346void TerrainMouseQueryListener::keyReleased(KeyEvent* e) 
    347347{ 
    348348        CEGUI::System::getSingleton().injectKeyUp(e->getKey()); 
     
    350350} 
    351351//----------------------------------------------------------------------- 
    352 void MouseQueryListener::keyClicked(KeyEvent* e)  
     352void TerrainMouseQueryListener::keyClicked(KeyEvent* e)  
    353353{ 
    354354        // Do nothing 
  • trunk/VUT/work/TestCulling/TestCullingApplication.h

    r112 r115  
    2525}; 
    2626 
    27 class MouseQueryListener : public ExampleFrameListener, public MouseListener, public MouseMotionListener 
     27class TerrainMouseQueryListener : public ExampleFrameListener, public MouseListener, public MouseMotionListener 
    2828{ 
    2929public: 
    3030 
    31     MouseQueryListener(RenderWindow* win, Camera* cam, SceneManager *sceneManager,  
     31    TerrainMouseQueryListener(RenderWindow* win, Camera* cam, SceneManager *sceneManager,  
    3232                        CEGUI::Renderer *renderer, SceneContentGenerator *sceneContentGenerator); 
    3333 
    3434 
    35     ~MouseQueryListener( ); 
     35    ~TerrainMouseQueryListener( ); 
    3636 
    3737        bool frameStarted(const FrameEvent& evt); 
     
    6666        void toggleUseOptimization(); 
    6767        void toggleShowOctree(); 
    68         void toggleUseVisibilityCulling(); 
     68        void toggleUseDepthPass(); 
    6969        void toggleShowViz(); 
    7070 
     
    9494        bool mUseOptimization; 
    9595        bool mShowOctree; 
    96         bool mUseVisibilityCulling; 
     96        bool mUseDepthPass; 
    9797        bool mShowVisualization; 
    9898 
  • trunk/VUT/work/TestCullingTerrain/TestCullingTerrain.vcproj

    r107 r115  
    3434                        <Tool 
    3535                                Name="VCLinkerTool" 
    36                                 AdditionalDependencies="Plugin_OctreeSceneManager.lib OGREMain_d.LIB CEGUIBase_d.lib OgreGUIRenderer_d.lib Plugin_DotSceneManager.lib" 
     36                                AdditionalDependencies="Plugin_OctreeSceneManager.lib Plugin_VisibilitySceneManager.lib OGREMain_d.LIB CEGUIBase_d.lib OgreGUIRenderer_d.lib Plugin_DotSceneManager.lib" 
    3737                                OutputFile="$(OGRE_PATH)/Samples/Common/bin/Debug/TestCullingTerrain.exe" 
    3838                                LinkIncremental="2" 
    39                                 AdditionalLibraryDirectories="&quot;$(OGRE_PATH)\Dependencies\Lib\$(ConfigurationName)&quot;;&quot;$(OGRE_ADDONS_PATH)\dotsceneoctree\PlugIns\DotSceneManager\bin\$(ConfigurationName)&quot;;&quot;$(OGRE_PATH)\OgreMain\Lib\$(ConfigurationName)&quot;;&quot;$(OGRE_PATH)\PlugIns\OctreeSceneManager\bin\$(ConfigurationName)&quot;;&quot;$(OGRE_PATH)\Samples\Common\CEGUIRenderer\lib&quot;" 
     39                                AdditionalLibraryDirectories="&quot;$(OGRE_PATH)\Dependencies\Lib\$(ConfigurationName)&quot;;&quot;$(OGRE_ADDONS_PATH)\dotsceneoctree\PlugIns\DotSceneManager\bin\$(ConfigurationName)&quot;;&quot;$(GAMETOOLS_PATH)\trunk\VUT\Ogre\lib\$(ConfigurationName)&quot;;&quot;$(OGRE_PATH)\OgreMain\Lib\$(ConfigurationName)&quot;;&quot;$(OGRE_PATH)\PlugIns\OctreeSceneManager\bin\$(ConfigurationName)&quot;;&quot;$(OGRE_PATH)\Samples\Common\CEGUIRenderer\lib&quot;" 
    4040                                GenerateDebugInformation="TRUE" 
    4141                                ProgramDatabaseFile="$(OutDir)/TestCullingTerrain.pdb" 
     
    122122                        UniqueIdentifier="{4FC737F1-C7A5-4376-A066-2A32D752A2FF}"> 
    123123                        <File 
     124                                RelativePath=".\TerrainMouseQueryListener.cpp"> 
     125                        </File> 
     126                        <File 
    124127                                RelativePath=".\TestCullingTerrainApplication.cpp"> 
    125128                        </File> 
     
    130133                        UniqueIdentifier="{93995380-89BD-4b04-88EB-625FBE52EBFB}"> 
    131134                        <File 
     135                                RelativePath=".\TerrainMouseQueryListener.h"> 
     136                        </File> 
     137                        <File 
    132138                                RelativePath=".\TestCullingTerrainApplication.h"> 
    133139                        </File> 
  • trunk/VUT/work/TestCullingTerrain/TestCullingTerrainApplication.cpp

    r114 r115  
    1 /** 
    2     \file  
    3         TestCullingTerrainApplication.cpp 
    4     \brief 
    5         Tests the visibility culling algorithm 
    6 */ 
    7  
    81#include <OgreNoMemoryMacros.h> 
    92#include <CEGUI/CEGUI.h> 
     
    147 
    158#include <Ogre.h> 
    16 #include "OgreReferenceAppLayer.h" 
     9//#include "OgreReferenceAppLayer.h" 
    1710//#include "OgreRefAppWorld.h" 
    1811#include "TestCullingTerrainApplication.h" 
    1912 
     13 
    2014#define WIN32_LEAN_AND_MEAN 
    2115#include <windows.h> 
    22  
    23 #define VIZ_VIEWPORT_Z_ORDER 10 
    24  
    25 const char* frame_outfile = "frame.out"; 
    26 const char* objects_outfile = "objects.out"; 
    2716 
    2817/*******************************************************/ 
     
    201190void TestCullingTerrainApplication::createFrameListener() 
    202191{ 
    203         mFrameListener= new MouseQueryListener(mWindow, mCamera, mSceneMgr,  
     192        mTerrainFrameListener = new TerrainMouseQueryListener(mWindow, mCamera, mSceneMgr,  
    204193                mGUIRenderer, mTerrainContentGenerator, mVizCamera, mCamNode); 
    205         mFrameListener->showDebugOverlay(true); 
    206         mRoot->addFrameListener(mFrameListener); 
     194        mTerrainFrameListener->showDebugOverlay(true); 
     195        mRoot->addFrameListener(mTerrainFrameListener); 
    207196} 
    208197//----------------------------------------------------------------------- 
     
    211200        mSceneMgr = mRoot->getSceneManager(ST_EXTERIOR_CLOSE); 
    212201} 
    213 /***********************************************/ 
    214 /*      MouseQueryListener implementation      */ 
    215 /***********************************************/ 
    216 //----------------------------------------------------------------------- 
    217 MouseQueryListener::MouseQueryListener(RenderWindow* win, Camera* cam,  
    218                                                                            SceneManager *sceneManager,  
    219                                                                            CEGUI::Renderer *renderer, 
    220                                                                            TerrainContentGenerator *sceneGenerator, 
    221                                                                            Camera *vizCamera, 
    222                                                                            SceneNode *camNode):  
    223 ExampleFrameListener(win, cam, false, true),  
    224 mGUIRenderer(renderer),  
    225 mShutdownRequested(false),  
    226 mLMouseDown(false), 
    227 mRMouseDown(false), 
    228 mSceneMgr(sceneManager), 
    229 mCurrentObject(NULL), 
    230 mTerrainContentGenerator(sceneGenerator), 
    231 mVisibilityThreshold(0), 
    232 mCurrentAlgorithm(GtpVisibility::VisibilityEnvironment::COHERENT_HIERARCHICAL_CULLING), 
    233 mShowOctree(false), 
    234 mUseVisibilityCulling(true), 
    235 mUseOptimization(true), 
    236 mVizCamera(vizCamera), 
    237 mShowVisualization(false), 
    238 mNodeVizMode(NODEVIZ_NONE), 
    239 mVizCameraHeight(Real(2500.0)), 
    240 mCamNode(camNode), 
    241 mCullCamera(false), 
    242 mAppState(WALKTHROUGH), 
    243 mCurrentFrame(0), 
    244 mRecord(false), 
    245 mTimeElapsed(0), 
    246 mUseShadows(false), 
    247 mVisualizeCulledNodes(false) 
    248 { 
    249         // Reduce move speed 
    250         mMoveSpeed = 50; 
    251         mRotateSpeed *= 2; 
    252      
    253         // Register this so that we get mouse events. 
    254         mEventProcessor->addMouseListener(this); 
    255         mEventProcessor->addMouseMotionListener(this); 
    256         mEventProcessor->addKeyListener(this); 
    257  
    258         mRayQueryExecutor = new RayQueryExecutor(mSceneMgr); 
    259          
    260         // show overlay 
    261         Overlay* pOver = OverlayManager::getSingleton().getByName("Example/VisibilityDemoOverlay");  
    262  
    263         mAlgorithmInfo = OverlayManager::getSingleton().getOverlayElement("Example/Visibility/AlgorithmInfo"); 
    264         mThresholdInfo = OverlayManager::getSingleton().getOverlayElement("Example/Visibility/ThresholdInfo"); 
    265          
    266         mFrustumCulledNodesInfo = OverlayManager::getSingleton().getOverlayElement("Example/Visibility/FrustumCulledNodesInfo"); 
    267         mQueryCulledNodesInfo = OverlayManager::getSingleton().getOverlayElement("Example/Visibility/QueryCulledNodesInfo"); 
    268     mTraversedNodesInfo = OverlayManager::getSingleton().getOverlayElement("Example/Visibility/TraversedNodesInfo"); 
    269         mHierarchyNodesInfo = OverlayManager::getSingleton().getOverlayElement("Example/Visibility/HierarchyNodesInfo"); 
    270         mRenderedNodesInfo = OverlayManager::getSingleton().getOverlayElement("Example/Visibility/RenderedNodesInfo"); 
    271         mObjectsInfo = OverlayManager::getSingleton().getOverlayElement("Example/Visibility/ObjectsInfo"); 
    272         mUseOptimizationInfo = OverlayManager::getSingleton().getOverlayElement("Example/Visibility/UseOptimizationInfo"); 
    273         mQueriesIssuedInfo = OverlayManager::getSingleton().getOverlayElement("Example/Visibility/QueriesIssuedInfo"); 
    274          
    275         mAlgorithmInfo->setCaption(": " + mCurrentAlgorithmCaptions[mCurrentAlgorithm]); 
    276         mThresholdInfo->setCaption(": 0"); 
    277         mFrustumCulledNodesInfo->setCaption(": 0"); 
    278         mQueryCulledNodesInfo->setCaption(": 0"); 
    279         mTraversedNodesInfo->setCaption(": 0"); 
    280         mHierarchyNodesInfo->setCaption(": 0"); 
    281         mRenderedNodesInfo->setCaption(": 0"); 
    282         mObjectsInfo->setCaption(": 0"); 
    283         mUseOptimizationInfo->setCaption(": true"); 
    284         mQueriesIssuedInfo->setCaption(": 0"); 
    285  
    286         setAlgorithm(mCurrentAlgorithm); 
    287  
    288         mSceneMgr->setOption("UseOptimization", &mUseOptimization); 
    289         mSceneMgr->setOption("UseVisibilityCulling", &mUseVisibilityCulling); 
    290         mSceneMgr->setOption("ShowOctree", &mShowOctree); 
    291         mSceneMgr->setOption("CullCamera", &mCullCamera); 
    292         mSceneMgr->setOption("ShowVisualization", &mShowVisualization); 
    293          
    294         pOver->show(); 
    295 }  
    296 //----------------------------------------------------------------------- 
    297 MouseQueryListener::~MouseQueryListener() 
    298 { 
    299         delete mRayQueryExecutor; 
    300 } 
    301 //----------------------------------------------------------------------- 
    302 void MouseQueryListener::mouseMoved(MouseEvent *e) 
    303 { 
    304         // Update CEGUI with the mouse motion 
    305     CEGUI::System::getSingleton().injectMouseMove(e->getRelX() *  
    306                 mGUIRenderer->getWidth(), e->getRelY() * mGUIRenderer->getHeight()); 
    307 } 
    308 //----------------------------------------------------------------------- 
    309 void MouseQueryListener::mousePressed(MouseEvent* e) 
    310 { 
    311      // Left mouse button down 
    312      if (e->getButtonID() & InputEvent::BUTTON0_MASK) 
    313      { 
    314                  CEGUI::MouseCursor::getSingleton().hide(); 
    315  
    316                  // Setup the ray scene query 
    317          Ray mouseRay = mCamera->getCameraToViewportRay(e->getX(), e->getY()); 
    318     
    319                  Vector3 queryResult; 
    320                   
    321                  // Get results, create a node/entity on the position 
    322                  mCurrentObject = mTerrainContentGenerator->GenerateSceneObject( 
    323                          mouseRay.getOrigin(), Vector3(0,0,0), "robot"); 
    324                  
    325          mLMouseDown = true;  
    326      } 
    327      // Right mouse button down 
    328      else if (e->getButtonID() & InputEvent::BUTTON1_MASK) 
    329      { 
    330          CEGUI::MouseCursor::getSingleton().hide(); 
    331          mRMouseDown = true; 
    332      } 
    333 } // mousePressed 
    334 //----------------------------------------------------------------------- 
    335 void MouseQueryListener::mouseReleased(MouseEvent* e) 
    336 { 
    337     // Left mouse button up 
    338     if (e->getButtonID() & InputEvent::BUTTON0_MASK) 
    339     { 
    340                 CEGUI::MouseCursor::getSingleton().show(); 
    341         mLMouseDown = false; 
    342     } 
    343     // Right mouse button up 
    344     else if (e->getButtonID() & InputEvent::BUTTON1_MASK) 
    345     { 
    346         CEGUI::MouseCursor::getSingleton().show(); 
    347         mRMouseDown = false; 
    348     } 
    349 }  
    350 //----------------------------------------------------------------------- 
    351 void MouseQueryListener::mouseDragged(MouseEvent *e) 
    352  { 
    353          // If we are dragging the left mouse button.             
    354          if (mLMouseDown) 
    355      { 
    356                  Vector3 queryResult; 
    357                  Ray mouseRay = mCamera->getCameraToViewportRay(e->getX(), e->getY()); 
    358  
    359                  if (mRayQueryExecutor->executeRayQuery(&queryResult, mouseRay)) 
    360                  { 
    361                          if (mCurrentObject) 
    362                          { 
    363                                  mCurrentObject->setPosition(queryResult); 
    364                          } 
    365                  } 
    366      } 
    367          // If we are dragging the right mouse button. 
    368          if (mRMouseDown) 
    369          { 
    370                  //mCamera->yaw(-e->getRelX() * mRotateSpeed); 
    371                  //mCamera->pitch(-e->getRelY() * mRotateSpeed); 
    372                  mCamNode->yaw(-e->getRelX() * mRotateSpeed); 
    373                  mCamNode->pitch(-e->getRelY() * mRotateSpeed); 
    374          } 
    375 } 
    376 //----------------------------------------------------------------------- 
    377 bool MouseQueryListener::frameStarted(const FrameEvent &evt) 
    378 { 
    379         switch (mAppState) 
    380         { 
    381         case REPLAY: 
    382                 setCurrentFrameInfo(evt.timeSinceLastFrame); 
    383                 break; 
    384         case WALKTHROUGH: 
    385                 if (mRecord) 
    386                 { 
    387                         addFrameInfo(mCamNode, evt.timeSinceLastFrame); 
    388                         // print recording message 
    389                         mWindow->setDebugText("Recording frame " +  
    390                                 StringConverter::toString(mFrameInfo.size() - 1)); 
    391                 }        
    392          
    393                 Clamp2Terrain(); 
    394                 break; 
    395         default: 
    396                 break; 
    397         };       
    398          
    399         if (mShowVisualization) 
    400         { 
    401                 // important for visualization => draw octree bounding boxes 
    402                 mSceneMgr->setOption("ShowOctree", &mShowVisualization); 
    403                 // also render nodew content? 
    404                 //mSceneMgr->setOption("RenderNodesForViz", &mRenderNodesForViz); 
    405  
    406                 // -- setup visualization camera 
    407                 mVizCamera->setPosition(0, 0, 0); 
    408                 mVizCamera->setOrientation(Quaternion::IDENTITY); 
    409  
    410                 Vector3 camPos = mCamNode->getPosition(); 
    411                 mVizCamera->setPosition(camPos.x, mVizCameraHeight, camPos.z); 
    412  
    413                 // point down -Z axis 
    414                 mVizCamera->pitch(Radian(Degree(270.0))); 
    415          
    416                 // rotation arounnd X axis 
    417                 mVizCamera->yaw(Math::ATan2(-mCamera->getDerivedDirection().x,  
    418                         -mCamera->getDerivedDirection().z)); 
    419                  
    420                 // move by a constant so view plane is on bottom of viewport 
    421                 mVizCamera->moveRelative(Vector3(0, 800, 0)); 
    422         } 
    423  
    424         return ExampleFrameListener::frameStarted(evt); 
    425 } 
    426 //----------------------------------------------------------------------- 
    427 void MouseQueryListener::Clamp2Terrain() 
    428 { 
    429         // clamp to terrain 
    430         Vector3 camPos = mCamNode->getPosition(); 
    431         Vector3 queryResult; 
    432  
    433         if (mRayQueryExecutor->executeRayQuery(&queryResult,  
    434                         Vector3(camPos.x, 5000.0f, camPos.z), Vector3::NEGATIVE_UNIT_Y)) 
    435         { 
    436                 mCamNode->setPosition(camPos.x, queryResult.y + 10, camPos.z); 
    437         } 
    438 } 
    439 //----------------------------------------------------------------------- 
    440 bool MouseQueryListener::frameEnded(const FrameEvent& evt) 
    441 { 
    442         if (mShutdownRequested) 
    443                 return false; 
    444  
    445     if (timeDelay >= 0)  
    446         timeDelay -= evt.timeSinceLastFrame; 
    447  
    448         KEY_PRESSED(KC_SPACE, 0.3, nextAlgorithm()); 
    449  
    450         KEY_PRESSED(KC_O, 0.3, toggleUseOptimization()); 
    451         KEY_PRESSED(KC_T, 0.3, toggleShowOctree()); 
    452         KEY_PRESSED(KC_C, 0.3, toggleUseVisibilityCulling()); 
    453         KEY_PRESSED(KC_1, 0.3, toggleShowViz()); 
    454         KEY_PRESSED(KC_2, 0.3, nextNodeVizMode()); 
    455          
    456         KEY_PRESSED(KC_SUBTRACT, 0, changeThreshold(-10)); 
    457         KEY_PRESSED(KC_ADD, 0, changeThreshold(10)); 
    458          
    459         KEY_PRESSED(KC_4, 0, zoomVizCamera(50)); 
    460         KEY_PRESSED(KC_5, 0, zoomVizCamera(-50)); 
    461  
    462         KEY_PRESSED(KC_F1, 0.3, nextAppState()); 
    463         KEY_PRESSED(KC_F2, 0.3, toggleRecord()); 
    464         KEY_PRESSED(KC_F3, 0.3, mTerrainContentGenerator->WriteObjects(objects_outfile)); 
    465         KEY_PRESSED(KC_F4, 0.3, toggleUseShadows()); 
    466         //KEY_PRESSED(KC_F3, 0.3, writeFrames()); 
    467         //KEY_PRESSED(KC_F4, 0.3, loadFrames()); 
    468  
    469         updateStats(); 
    470  
    471         //return ExampleFrameListener::frameStarted(evt) && ExampleFrameListener::frameEnded(evt); 
    472         return ExampleFrameListener::frameEnded(evt); 
    473 } 
    474 //----------------------------------------------------------------------- 
    475 void MouseQueryListener::moveCamera() 
    476 { 
    477         mCamNode->yaw(mRotX); 
    478         mCamNode->pitch(mRotY); 
    479         mCamNode->translate(mCamNode->getLocalAxes(), mTranslateVector); 
    480 } 
    481 //----------------------------------------------------------------------- 
    482 void MouseQueryListener::writeFrames() 
    483 { 
    484         std::ofstream ofstr(frame_outfile); 
    485          
    486         std::vector<frame_info>::const_iterator it, it_end; 
    487  
    488         it_end = mFrameInfo.end(); 
    489         for(it = mFrameInfo.begin(); it < it_end; ++it) 
    490         { 
    491                 ofstr << StringConverter::toString((*it).position) << " "  
    492                         << StringConverter::toString((*it).orientation) << " " 
    493                         << StringConverter::toString((*it).timeElapsed) << "\n"; 
    494         } 
    495         ofstr.close(); 
    496 } 
    497 //----------------------------------------------------------------------- 
    498 void MouseQueryListener::loadFrames() 
    499 { 
    500         std::ifstream ifstr(frame_outfile); 
    501         char line[256]; 
    502         frame_info info; 
    503  
    504         // reset current values 
    505         mFrameInfo.clear(); 
    506         mCurrentFrame = 0; 
    507          
    508         while (!ifstr.eof())  
    509         { 
    510                 ifstr.getline(line, 256); 
    511                 sscanf(line, "%f %f %f %f %f %f %f %f", &info.position.x, &info.position.y, &info.position.z, 
    512                                 &info.orientation.w, &info.orientation.x, &info.orientation.y, &info.orientation.z, 
    513                                 &info.timeElapsed); 
    514                  
    515                 mFrameInfo.push_back(info); 
    516                  
    517                 /* 
    518                 std::stringstream d; 
    519                 d << StringConverter::toString(info.position) << " " << StringConverter::toString(info.orientation); 
    520                 LogManager::getSingleton().logMessage(d.str()); 
    521                 */ 
    522         } 
    523         ifstr.close(); 
    524 } 
    525 //----------------------------------------------------------------------- 
    526 void MouseQueryListener::setAppState(int state) 
    527 { 
    528         mAppState = state; 
    529 } 
    530 //----------------------------------------------------------------------- 
    531 void MouseQueryListener::nextAppState() 
    532 { 
    533         mCurrentFrame = 0; 
    534  
    535         // if last state was replay state 
    536         if (mAppState == REPLAY) 
    537         { 
    538                 // reset debug text and write frame info to file 
    539                 mWindow->setDebugText(""); 
    540                 writeFrames(); 
    541                  
    542                 //-- write out stats 
    543                 std::stringstream d; 
    544                 d << "Algorithm: " << mCurrentAlgorithmCaptions[mCurrentAlgorithm] << "\n" 
    545                   << "avg. FPS: " << mWindow->getAverageFPS() << "\n" 
    546                   << "best FPS: " << mWindow->getBestFPS() << "\n" 
    547                   << "worst FPS: " << mWindow->getWorstFPS() << "\n" 
    548                   << "best frame time: " <<     mWindow->getBestFrameTime() << "\n" 
    549                   << "worst frame time: " << mWindow->getWorstFrameTime(); 
    550                  
    551                 LogManager::getSingleton().logMessage(d.str()); 
    552         } 
    553          
    554         //-- set the next státe 
    555         mAppState = (mAppState + 1) % STATE_NUM; 
    556  
    557         // replay recorded walkthrough 
    558         if (mAppState == REPLAY) 
    559         { 
    560                 // no recording during replay 
    561                 mRecord = false; 
    562  
    563                 // load recorded walkthrough 
    564                 if (mFrameInfo.size() == 0) 
    565                 { 
    566                         loadFrames(); 
    567                 } 
    568  
    569                 // if there are no recorded frames => set next state 
    570                 if (mFrameInfo.size() == 0)  
    571                 { 
    572                         nextAppState(); 
    573                 } 
    574                 else 
    575                 { 
    576                         mWindow->setDebugText("Replay"); 
    577                          
    578                         // reset, because we measure fps stats during walkthrough 
    579                         mWindow->resetStatistics(); 
    580  
    581                         //-- initialise frame data 
    582                         mTimeElapsed = 0; 
    583  
    584                         mCamNode->setPosition(mFrameInfo[0].position); 
    585                         mCamNode->setOrientation(mFrameInfo[0].orientation); 
    586                 } 
    587         } 
    588  
    589 } 
    590 //----------------------------------------------------------------------- 
    591 void MouseQueryListener::toggleRecord() 
    592 { 
    593         mRecord = !mRecord; 
    594  
    595         // clear previous camera path 
    596         if (mRecord) 
    597                 mFrameInfo.clear(); 
    598         else 
    599                 mWindow->setDebugText(""); 
    600 } 
    601 //----------------------------------------------------------------------- 
    602 void MouseQueryListener::changeThreshold(int incr) 
    603 { 
    604         mVisibilityThreshold += incr;  
    605         if(mVisibilityThreshold < 0) mVisibilityThreshold = 0; 
    606          
    607         char str[100]; sprintf(str,": %d", mVisibilityThreshold); 
    608  
    609         mSceneMgr->setOption("Threshold", &mVisibilityThreshold);  
    610         mThresholdInfo->setCaption(str); 
    611 } 
    612 //----------------------------------------------------------------------- 
    613 bool MouseQueryListener::processUnbufferedKeyInput(const FrameEvent& evt) 
    614 {     
    615         if (mInputDevice->isKeyDown(KC_RIGHT)) 
    616         { 
    617                 mCamNode->yaw(-mRotScale); 
    618                 return true; 
    619         } 
    620         if (mInputDevice->isKeyDown(KC_LEFT)) 
    621         { 
    622                 mCamNode->yaw(mRotScale); 
    623                 return true; 
    624         } 
    625  
    626         return ExampleFrameListener::processUnbufferedKeyInput(evt); 
    627 } 
    628 //----------------------------------------------------------------------- 
    629 void MouseQueryListener::zoomVizCamera(int zoom) 
    630 { 
    631         mVizCameraHeight += zoom;  
    632         if(mVizCameraHeight < 0) mVizCameraHeight = 0; 
    633 } 
    634 //----------------------------------------------------------------------- 
    635 void MouseQueryListener::nextAlgorithm() 
    636 { 
    637         mCurrentAlgorithm = (mCurrentAlgorithm + 1) %  
    638                 GtpVisibility::VisibilityEnvironment::NUM_CULLING_MANAGERS, 
    639  
    640         setAlgorithm(mCurrentAlgorithm); 
    641 } 
    642 //----------------------------------------------------------------------- 
    643 void MouseQueryListener::setAlgorithm(int algorithm) 
    644 { 
    645         mAlgorithmInfo->setCaption(": " + mCurrentAlgorithmCaptions[mCurrentAlgorithm]); 
    646         mSceneMgr->setOption("Algorithm", &mCurrentAlgorithm); 
    647 } 
    648 //----------------------------------------------------------------------- 
    649 void MouseQueryListener::updateStats() 
    650 { 
    651         unsigned int opt = 0; 
    652         char str[100]; 
    653          
    654         mSceneMgr->getOption("NumFrustumCulledNodes", &opt); sprintf(str,": %d", opt);  
    655         mFrustumCulledNodesInfo->setCaption(str); 
    656          
    657         mSceneMgr->getOption("NumQueriesIssued", &opt); sprintf(str,": %d", opt);  
    658         mQueriesIssuedInfo->setCaption(str); 
    659          
    660         mSceneMgr->getOption("NumQueryCulledNodes", &opt); sprintf(str,": %d", opt);  
    661         mQueryCulledNodesInfo->setCaption(str); 
    662          
    663         mSceneMgr->getOption("NumTraversedNodes", &opt); sprintf(str,": %d", opt);  
    664         mTraversedNodesInfo->setCaption(str); 
    665  
    666         mSceneMgr->getOption("NumHierarchyNodes", &opt); sprintf(str,": %d", opt);  
    667         mHierarchyNodesInfo->setCaption(str); 
    668  
    669         mSceneMgr->getOption("NumRenderedNodes", &opt); sprintf(str,": %d", opt);  
    670         mRenderedNodesInfo->setCaption(str); 
    671  
    672         sprintf(str,": %d", mTerrainContentGenerator->GetObjectCount());  
    673         mObjectsInfo->setCaption(str); 
    674 } 
    675 //----------------------------------------------------------------------- 
    676 void MouseQueryListener::toggleUseOptimization() 
    677 { 
    678         mUseOptimization = !mUseOptimization; 
    679  
    680         mSceneMgr->setOption("UseOptimization", &mUseOptimization); 
    681  
    682         if (mUseOptimization) 
    683                 mUseOptimizationInfo->setCaption(": true"); 
    684         else 
    685                 mUseOptimizationInfo->setCaption(": false"); 
    686 } 
    687 //----------------------------------------------------------------------- 
    688 void MouseQueryListener::toggleShowOctree() 
    689 { 
    690         mShowOctree = !mShowOctree; 
    691  
    692         mSceneMgr->setOption("ShowOctree", &mShowOctree); 
    693 } 
    694 //----------------------------------------------------------------------- 
    695 void MouseQueryListener::toggleUseVisibilityCulling() 
    696 { 
    697         mUseVisibilityCulling = !mUseVisibilityCulling; 
    698  
    699         mSceneMgr->setOption("UseVisibilityCulling", &mUseVisibilityCulling); 
    700 } 
    701 //----------------------------------------------------------------------- 
    702 void MouseQueryListener::toggleShowViz() 
    703 { 
    704         mShowVisualization = !mShowVisualization; 
    705         mVisualizeCulledNodes = !mVisualizeCulledNodes; 
    706  
    707         // create viewport with priority VIZ_VIEWPORT_Z_ORDER:  
    708         // will be rendered over standard viewport 
    709         if (mShowVisualization) 
    710         {        
    711                 Viewport *vizvp = mWindow->addViewport(mVizCamera,  
    712                         VIZ_VIEWPORT_Z_ORDER, 0.6, 0.6, 0.4, 0.4);  
    713                                  
    714                 vizvp->setBackgroundColour(ColourValue(0.0, 0.3, 0.2, 1)); 
    715  
    716                 vizvp->setOverlaysEnabled(false); 
    717                 // Alter the camera aspect ratio to match the viewport 
    718         mVizCamera->setAspectRatio(Real(vizvp->getActualWidth()) /  
    719                         Real(vizvp->getActualHeight())); 
    720                  
    721                 mSceneMgr->setOption("VisualizeCulledNodes", &mVisualizeCulledNodes); 
    722                 //vizvp->setClearEveryFrame(false); 
    723  
    724                 // Create a skyplane (for visualization background) 
    725                 /* 
    726                 Plane plane; 
    727                 plane.d = -1000; 
    728                 plane.normal = Vector3::UNIT_Y; 
    729                 mSceneMgr->setSkyPlane(true, plane, "Examples/TransparentTest", 4000, 75, false); 
    730                 */ 
    731                  
    732         } 
    733         else 
    734         { 
    735                 mWindow->removeViewport(VIZ_VIEWPORT_Z_ORDER); 
    736                 // if octree was enabled for visualization purpose, reset now 
    737                 mSceneMgr->setOption("ShowOctree", &mShowOctree); 
    738         } 
    739 } 
    740 //----------------------------------------------------------------------- 
    741 void MouseQueryListener::toggleUseShadows() 
    742 { 
    743         mUseShadows = !mUseShadows; 
    744  
    745         //mSunLight->setCastShadows(mUseShadows); 
    746  
    747         if (mUseShadows) 
    748         { 
    749                 mSceneMgr->setShadowTechnique(SHADOWTYPE_TEXTURE_MODULATIVE); 
    750         } 
    751         else 
    752         { 
    753                 mSceneMgr->setShadowTechnique(SHADOWTYPE_NONE); 
    754         } 
    755  
    756 } 
    757 //----------------------------------------------------------------------- 
    758 void MouseQueryListener::nextNodeVizMode() 
    759 { 
    760         mNodeVizMode = (mNodeVizMode + 1) % NODEVIZ_MODES_NUM; 
    761  
    762         //bool renderNodesForViz = (mNodeVizMode == NODEVIZ_RENDER_NODES) || (mNodeVizMode == NODEVIZ_RENDER_NODES_AND_CONTENT); 
    763         bool renderNodesContentForViz = mNodeVizMode == NODEVIZ_RENDER_GEOMETRY; 
    764  
    765         //mSceneMgr->setOption("RenderNodesForViz", &renderNodesForViz); 
    766         mSceneMgr->setOption("RenderNodesContentForViz", &renderNodesContentForViz); 
    767 } 
    768 //----------------------------------------------------------------------- 
    769 void MouseQueryListener::keyPressed(KeyEvent* e) 
    770 { 
    771         if(e->getKey() == KC_ESCAPE) 
    772     { 
    773                 mShutdownRequested = true; 
    774                 e->consume(); 
    775                 return; 
    776         } 
    777  
    778         CEGUI::System::getSingleton().injectKeyDown(e->getKey()); 
    779         CEGUI::System::getSingleton().injectChar(e->getKeyChar()); 
    780         e->consume(); 
    781 } 
    782 //----------------------------------------------------------------------- 
    783 void MouseQueryListener::keyReleased(KeyEvent* e) 
    784 { 
    785         CEGUI::System::getSingleton().injectKeyUp(e->getKey()); 
    786         e->consume(); 
    787 } 
    788 //----------------------------------------------------------------------- 
    789 void MouseQueryListener::keyClicked(KeyEvent* e)  
    790 { 
    791         // Do nothing 
    792         e->consume(); 
    793 } 
    794 //----------------------------------------------------------------------- 
    795 void MouseQueryListener::addFrameInfo(SceneNode *camNode, Real timeElapsed) 
    796 { 
    797         frame_info info; 
    798         info.orientation = mCamNode->getOrientation(); 
    799         info.position = mCamNode->getPosition(); 
    800         info.timeElapsed = timeElapsed; 
    801  
    802         mFrameInfo.push_back(info); 
    803 } 
    804 //----------------------------------------------------------------------- 
    805 void MouseQueryListener::setCurrentFrameInfo(Real timeElapsed) 
    806 { 
    807         //-- find current frame relative to elapsed frame time           
    808         mTimeElapsed -= timeElapsed; 
    809  
    810         while ((mTimeElapsed <= 0) && (mCurrentFrame < (int)mFrameInfo.size() - 1)) 
    811         { 
    812                 mTimeElapsed += mFrameInfo[mCurrentFrame ++].timeElapsed; 
    813         } 
    814  
    815         frame_info new_frame = mFrameInfo[mCurrentFrame]; 
    816         frame_info old_frame = mFrameInfo[mCurrentFrame - 1]; 
    817                  
    818         //-- interpolate frames 
    819         Real factor = 1; 
    820  
    821         if (old_frame.timeElapsed > 0) 
    822                 factor = mTimeElapsed / old_frame.timeElapsed; 
    823  
    824         Vector3 camPos = old_frame.position + factor * (new_frame.position - old_frame.position); 
    825         Quaternion camOrienation = Quaternion::Slerp(factor, old_frame.orientation,  
    826                 new_frame.orientation, true); 
    827  
    828         mCamNode->setPosition(camPos); 
    829         mCamNode->setOrientation(camOrienation); 
    830          
    831         // stop replay after a full walkthrough 
    832         if (mCurrentFrame == (int)mFrameInfo.size() - 1) 
    833         { 
    834                 nextAppState(); 
    835         } 
    836 } 
     202 
    837203 
    838204/**************************************************************/ 
  • trunk/VUT/work/TestCullingTerrain/TestCullingTerrainApplication.h

    r114 r115  
    1 /** 
    2     \file  
    3         TestCullingTerrainApplication.h 
    4 */ 
     1#ifndef _TestCullingTerrainApplication_H__ 
     2#define _TestCullingTerrainApplication_H__ 
     3 
    54#include "CEGUIForwardRefs.h" 
    65#include "ExampleApplication.h" 
    76#include "OgreTerrainContentGenerator.h" 
    8 #include "VisibilityEnvironment.h" 
     7 
    98#include <OgreRenderTargetListener.h> 
    10 #include <vector> 
    11  
    12 Real timeDelay = 0; 
    13 #define KEY_PRESSED(_key,_timeDelay, _macro) \ 
    14 { \ 
    15     if (mInputDevice->isKeyDown(_key) && timeDelay <= 0) \ 
    16 { \ 
    17     timeDelay = _timeDelay; \ 
    18     _macro ; \ 
    19 } \ 
    20 } 
    21  
    22 String mCurrentAlgorithmCaptions[GtpVisibility::VisibilityEnvironment::NUM_CULLING_MANAGERS] =  
    23 { 
    24     "View Frustum Culling",  
    25         "Stop and Wait Culling",  
    26         "Coherent Hierarchical Culling" 
    27 }; 
    28  
    29 /** The information about camera position and orienation per frame */ 
    30 typedef struct 
    31 { 
    32         Vector3 position; 
    33         Quaternion orientation; 
    34         Real timeElapsed; 
    35 } frame_info; 
    36  
     9#include "TerrainMouseQueryListener.h" 
    3710 
    3811class VisualizationRenderTargetListener: public RenderTargetListener 
     
    4619 
    4720        SceneManager *mSceneMgr; 
    48 }; 
    49  
    50 class MouseQueryListener : public ExampleFrameListener, public MouseListener, public MouseMotionListener 
    51 { 
    52 public: 
    53          
    54     MouseQueryListener(RenderWindow* win, Camera* cam, SceneManager *sceneManager,  
    55                 CEGUI::Renderer *renderer, TerrainContentGenerator *contentGenerator, Camera *vizCamera, 
    56                 SceneNode *camNode); 
    57  
    58     ~MouseQueryListener(); 
    59  
    60         bool frameStarted(const FrameEvent& evt); 
    61         bool frameEnded(const FrameEvent& evt); 
    62         bool processUnbufferedKeyInput(const FrameEvent& evt); 
    63      
    64  
    65     /* MouseListener callbacks. */ 
    66     virtual void mouseClicked(MouseEvent* e) { } 
    67     virtual void mouseEntered(MouseEvent* e) { } 
    68     virtual void mouseExited(MouseEvent* e)  { } 
    69  
    70     // This is when the mouse button goes DOWN. 
    71     virtual void mousePressed(MouseEvent* e); 
    72  
    73     // This is when the mouse button is let UP. 
    74     virtual void mouseReleased(MouseEvent* e); 
    75  
    76     /* MouseMotionListener callbacks */ 
    77     virtual void mouseMoved (MouseEvent *e); 
    78     
    79     // This is when the mouse is clicked, held and dragged. 
    80     virtual void mouseDragged (MouseEvent *e); 
    81  
    82     void keyPressed(KeyEvent* e); 
    83  
    84         void keyReleased(KeyEvent* e); 
    85         void keyClicked(KeyEvent* e); 
    86  
    87         enum  {WALKTHROUGH, REPLAY, STATE_NUM}; 
    88  
    89         // visualization modes for scene nodes 
    90         //enum {NODEVIZ_NONE, NODEVIZ_RENDER_NODES,  
    91         //        NODEVIZ_RENDER_NODES_AND_CONTENT, NODEVIZ_MODES_NUM}; 
    92         enum {NODEVIZ_NONE, NODEVIZ_RENDER_GEOMETRY, NODEVIZ_MODES_NUM}; 
    93  
    94         void nextAlgorithm(); 
    95         void changeThreshold(int incr); 
    96         void updateStats(); 
    97  
    98         void toggleUseOptimization(); 
    99         void toggleShowOctree(); 
    100         void toggleUseVisibilityCulling(); 
    101         void toggleShowViz(); 
    102         void nextNodeVizMode(); 
    103         void toggleRecord(); 
    104  
    105         void zoomVizCamera(int zoom); 
    106          
    107         void addFrameInfo(SceneNode *camNode, Real timeElapsed); 
    108         void setCurrentFrameInfo(Real timeElapsed); 
    109  
    110         void setAppState(int state); 
    111         void nextAppState(); 
    112  
    113         void setAlgorithm(int algorithm); 
    114  
    115         void moveCamera(); 
    116          
    117         void writeFrames(); 
    118         void loadFrames(); 
    119  
    120         void toggleUseShadows(); 
    121  
    122 protected: 
    123         void Clamp2Terrain(); 
    124          
    125     bool mLMouseDown, mRMouseDown;     // True if the mouse buttons are down 
    126     SceneManager *mSceneMgr;           // A pointer to the scene manager 
    127      
    128         CEGUI::Renderer *mGUIRenderer;     // cegui renderer 
    129          
    130         bool mShutdownRequested; 
    131         int mCurrentAlgorithm; 
    132         int mVisibilityThreshold; 
    133          
    134         OverlayElement *mAlgorithmInfo; 
    135         OverlayElement *mThresholdInfo; 
    136         OverlayElement *mFrustumCulledNodesInfo; 
    137         OverlayElement *mQueryCulledNodesInfo; 
    138     OverlayElement *mTraversedNodesInfo; 
    139         OverlayElement *mHierarchyNodesInfo; 
    140         OverlayElement *mUseOptimizationInfo; 
    141         OverlayElement *mRenderedNodesInfo; 
    142         OverlayElement *mObjectsInfo; 
    143         OverlayElement *mQueriesIssuedInfo; 
    144  
    145         SceneNode *mCurrentObject;    // the newly created object 
    146         int mObjectCount;             // The number of objects on the screen 
    147  
    148         RayQueryExecutor *mRayQueryExecutor; 
    149         TerrainContentGenerator *mTerrainContentGenerator; 
    150  
    151         bool mUseOptimization; 
    152         bool mShowOctree; 
    153         bool mUseVisibilityCulling; 
    154         bool mShowVisualization; 
    155         int mNodeVizMode; 
    156         bool mCullCamera; 
    157  
    158         Real mVizCameraHeight; 
    159  
    160         Camera *mVizCamera; 
    161         SceneNode *mCamNode; 
    162          
    163         //std::deque<Vector3> mWalkList;   // The list of points we are walking to 
    164         std::vector<frame_info> mFrameInfo; 
    165                  
    166         int mCurrentFrame; 
    167         // the current application state 
    168         int mAppState; 
    169         bool mRecord; 
    170         Real mTimeElapsed; 
    171         bool mUseShadows; 
    172  
    173         bool mVisualizeCulledNodes; 
    17421}; 
    17522 
     
    20956        VisualizationRenderTargetListener *mRenderTargetListener; 
    21057 
     58        TerrainMouseQueryListener *mTerrainFrameListener; 
     59 
    21160private: 
    21261        void chooseSceneManager(void); 
    21362}; 
     63 
     64#endif // TestCullingTerrainApplication 
  • trunk/VUT/work/ogre_changes/OgreMain/include/OgreHardwareOcclusionQuery.h

    r92 r115  
    9696      * Pulls the hardware occlusion query too see if there is a result. 
    9797      * @retval NumOfFragments will get the resulting number of fragments. 
    98           * @param waitForResult if true, the query will wait until a result is available 
    99       * @return True if success or false if not. 
    100           * @Remarks Hardware occlusion is an assyncronius process the result may take a frame or so. 
    101           *                     one idea is to test pass1 and if not visible skip pass2. Also note that objects 
    102           *                     not visible must be tested evrey frame. Visable objects don't need testing every frame. 
    103           *                     Testing non visable objects can be don unlit, no texture with low LOD object. 
    104           *        0 will generate all the levels till 1x1. [default: 0] 
    105       */ 
    106 #ifdef GTP_VISIBILITY_MODIFIED_OGRE 
    107           virtual bool pullOcclusionQuery( unsigned int* NumOfFragments, const bool waitForResult ) = 0; 
    108 #else 
    109          virtual bool pullOcclusionQuery( unsigned int* NumOfFragments ) = 0; 
    110 #endif 
    111         /** 
    112       * Pulls the hardware occlusion query too see if there is a result. 
    113       * @retval NumOfFragments will get the resulting number of fragments. 
    114           * @param waitForResult if true, the query will wait until a result is available 
    11598      * @return True if success or false if not. 
    11699          * @Remarks In DX9 mode specifying OCCLUSIONQUERY_FLUSH as the flag, will case the driver to flush whatever API calls are batched. 
    117100          * In OpenGL mode it makes no difference if you specify OCCLUSIONQUERY_FLUSH or OCCLUSIONQUERY_NOFLUSH. 
    118101      */ 
    119 #ifdef GTP_VISIBILITY_MODIFIED_OGRE 
    120         virtual bool pullOcclusionQuery( unsigned int* NumOfFragments, const bool waitForResult, 
    121                                                                          const HW_OCCLUSIONQUERY flag  ) = 0;  
    122 #else 
    123           virtual bool pullOcclusionQuery( unsigned int* NumOfFragments,  
    124                                                                            const HW_OCCLUSIONQUERY flag  ) = 0;  
    125 #endif 
     102        virtual bool pullOcclusionQuery(unsigned int* NumOfFragments, const HW_OCCLUSIONQUERY flag = HWOCCLUSIONQUERY_FLUSH) = 0; 
     103 
    126104        /** 
    127105          * Let's you get the last pixel count with out doing the hardware occlusion test 
     
    143121        virtual void    setSkipRate( int skip ) = 0; 
    144122        virtual int             getSkipRate() = 0; 
     123 
     124#ifdef GTP_VISIBILITY_MODIFIED_OGRE 
     125        /** 
     126                Pulls occlusion query. 
     127                @param NumOfFragments number of visible fragments if query result was available. 
     128                Last query result if query result was not yet available. 
     129 
     130                @param waitForResult if true, the function waits until the result is available. 
     131                Otherwise the function returns immediately, not waiting for the result. 
     132                @returns true if query result was available, false if result was not yet available 
     133        */ 
     134        virtual bool pullOcclusionQuery( unsigned int* NumOfFragments, const bool waitForResult,  
     135                const HW_OCCLUSIONQUERY flag = HWOCCLUSIONQUERY_FLUSH ) = 0;  
     136#endif // GTP_VISIBILITY_MODIFIED_OGRE 
     137 
    145138//---------------------------------------------------------------------- 
    146139// Private members 
  • trunk/VUT/work/ogre_changes/OgreMain/include/OgreSceneManager.h

    r74 r115  
    128128                        @param node scene node to be rendered 
    129129                        @param cam current camera 
     130                        @param leaveTransparentsInQueue if only solid objects should be rendered 
    130131                */ 
    131                 void _renderSceneNode( Camera *cam, SceneNode *node ); 
    132                 /** deletes all queues which we were currently processing 
    133                         @remark clears renderqueue after rendering scene node 
     132                void _renderSceneNode(Camera *cam, SceneNode *node, bool leaveTransparentsInQueue = false); 
     133                /** deletes all processed queues 
     134                        @remark clears render queues after rendering scene node 
    134135                */ 
    135                 void _deleteRenderedQueueGroups(); 
     136                void _deleteRenderedQueueGroups(bool leaveTransparentsInQueue); 
    136137                /** Internal method used by _renderVisibleObjects to deal with renderables 
    137138            which override the camera's own view / projection materices.  
  • trunk/VUT/work/ogre_changes/OgreMain/src/OgreSceneManager.cpp

    r99 r115  
    5959#include "OgreDataStream.h" 
    6060#include "OgreStaticGeometry.h" 
    61 #include <windows.h> //matt: remove later 
     61 
    6262// This class implements the most basic scene manager 
    6363 
     
    665665        if (lastUsedVertexProgram) 
    666666        { 
    667                         //matt: remove later 
    668                         //OutputDebugString("unbinding vertex program\n"); 
    669  
    670667            mDestRenderSystem->unbindGpuProgram(GPT_VERTEX_PROGRAM); 
    671668            lastUsedVertexProgram = false; 
     
    990987                               const String& groupName) 
    991988{ 
    992     mSkyPlaneEnabled = enable; 
    993989    if (enable) 
    994990    { 
     
    10611057 
    10621058    } 
     1059        mSkyPlaneEnabled = enable; 
    10631060} 
    10641061//----------------------------------------------------------------------- 
     
    10711068                             const String& groupName) 
    10721069{ 
    1073     mSkyBoxEnabled = enable; 
    10741070    if (enable) 
    10751071    { 
     
    11431139 
    11441140    } 
    1145  
     1141        mSkyBoxEnabled = enable; 
    11461142} 
    11471143//----------------------------------------------------------------------- 
     
    11571153                              const String& groupName) 
    11581154{ 
    1159     mSkyDomeEnabled = enable; 
    11601155    if (enable) 
    11611156    { 
     
    11641159        { 
    11651160            OGRE_EXCEPT(Exception::ERR_INVALIDPARAMS,  
    1166                 "Sky dome material '" + materialName + " not found.", 
     1161                "Sky dome material '" + materialName + "' not found.", 
    11671162                "SceneManager::setSkyDome"); 
    11681163        } 
     
    12081203 
    12091204    } 
     1205        mSkyDomeEnabled = enable; 
    12101206} 
    12111207//----------------------------------------------------------------------- 
     
    26582654    { 
    26592655        Light* l = i->second; 
     2656                if (l->isVisible()) 
     2657                { 
    26602658        if (l->getType() == Light::LT_DIRECTIONAL) 
    26612659        { 
     
    26752673 
    26762674        } 
     2675    } 
    26772676    } 
    26782677 
     
    41804179#ifdef GTP_VISIBILITY_MODIFIED_OGRE 
    41814180//----------------------------------------------------------------------- 
    4182 void SceneManager::_renderSceneNode( Camera *cam, SceneNode *node ) 
     4181void SceneManager::_renderSceneNode(Camera *cam, SceneNode *node, bool leaveTransparentsInQueue) 
    41834182{ 
    41844183        node->_findVisibleObjects(cam, getRenderQueue(), false, mDisplayNodes, false); 
     
    41864185         
    41874186        // delete all rendered objects from renderqueue 
    4188         _deleteRenderedQueueGroups(); 
    4189 } 
    4190 //----------------------------------------------------------------------- 
    4191 void SceneManager::_deleteRenderedQueueGroups() 
     4187        _deleteRenderedQueueGroups(leaveTransparentsInQueue); 
     4188} 
     4189//----------------------------------------------------------------------- 
     4190void SceneManager::_deleteRenderedQueueGroups(bool leaveTransparentsInQueue) 
    41924191{ 
    41934192        RenderQueue::QueueGroupIterator queueIt = getRenderQueue()->_getQueueGroupIterator(); 
     
    42004199 
    42014200                if (isRenderQueueToBeProcessed(qId)) 
     4201                { 
     4202                        if (leaveTransparentsInQueue) 
     4203                        { 
     4204                                pGroup->clearSolids(); 
     4205                        } 
     4206                        else 
     4207                        { 
    42024208                        pGroup->clear(); 
     4209        } 
     4210                } 
    42034211        } 
    42044212         
  • trunk/VUT/work/ogre_changes/Plugins/OctreeSceneManager/include/OgreOctreeSceneManager.h

    r112 r115  
    105105        /** Renders one octant of an octree, i.e., renders current octant 
    106106                node and does not traverse deeper into the tree. 
     107 
    107108                @remark Note that OctreeNode instances are NOT part of the octree  
    108109                hierarchy, instead one octant of an Octree contains many OctreeNode instances. 
    109                 @param octree the octree to be rendered 
     110                 
    110111                @param cam current camera 
     112                @param octree the octant to be rendered (without children) 
     113                @param onlyShadowCasters if only shadow casters are rendered 
     114                @param leaveTransparentsInQueue if transparemt should be left in queue for later processing 
    111115        */ 
    112         void _renderOctant(Camera* cam, Octree *octree, bool onlyShadowCasters); 
     116        void _renderOctant(Camera* cam, Octree *octree, bool onlyShadowCasters, bool leaveTransparentsInQueue = false); 
    113117 
    114118        /** Returns stored list of boxes */ 
     
    214218    IntersectionSceneQuery* createIntersectionQuery(unsigned long mask); 
    215219 
     220 
    216221protected: 
    217222 
  • trunk/VUT/work/ogre_changes/Plugins/OctreeSceneManager/src/OgreOctree.cpp

    r61 r115  
    109109                mDepth = 0; 
    110110 
    111         //matt: remove later 
    112         //char msg[100]; 
    113         //sprintf(msg, "creating new octant in depth %d", mDepth); 
    114         //OutputDebugString(msg); 
    115  
    116111#endif //GTP_VISIBILITY_MODIFIED_OGRE 
    117112    mNumNodes = 0; 
     
    171166 
    172167        mWireBoundingBox->setupBoundingBox(mBox); 
    173  
    174         // matt: change this back 
    175         //AxisAlignedBox box; _getCullBounds(&box);  
    176         //mWireBoundingBox->setupBoundingBox(box); 
    177  
    178168    return mWireBoundingBox; 
    179169} 
  • trunk/VUT/work/ogre_changes/Plugins/OctreeSceneManager/src/OgreOctreeSceneManager.cpp

    r112 r115  
    3939#include <OgreOctreeCamera.h> 
    4040#include <OgreRenderSystem.h> 
    41 #include <windows.h> 
     41 
    4242 
    4343extern "C" 
     
    508508        } 
    509509 
    510                 //matt: remove later 
    511                 //OutputDebugString("adding octree node\n"); 
    512                  
    513  
    514510        _addOctreeNode( n, octant -> mChildren[ x ][ y ][ z ], ++depth ); 
    515511 
     
    11731169} 
    11741170//----------------------------------------------------------------------- 
    1175 void OctreeSceneManager::_renderOctant(Camera *cam, Octree *octant, bool onlyShadowCasters) 
     1171void OctreeSceneManager::_renderOctant(Camera *cam, Octree *octant, bool onlyShadowCasters,  
     1172                                                                           bool leaveTransparentsInQueue)//, bool useZPassQueue) 
    11761173{ 
    11771174        //Add stuff to be rendered; 
     
    11881185                { 
    11891186                        sn->_addToRenderQueue(cam, getRenderQueue(), onlyShadowCasters); 
    1190                         //node->_findVisibleObjects(cam, getRenderQueue(), false, mDisplayNodes, false); 
    11911187                        mVisible.push_back(sn); 
    11921188 
     
    12071203        if (mShowBoxes) 
    12081204        { 
     1205                octant->getWireBoundingBox()->setMaterial("BaseWhiteNoLighting"); 
     1206 
    12091207                getRenderQueue()->addRenderable(octant->getWireBoundingBox()); 
    12101208                mBoxes.push_back(octant->getWireBoundingBox()); 
    12111209        } 
    12121210 
     1211        //-- the actual rendering 
    12131212        SceneManager::_renderVisibleObjects(); 
    1214  
    12151213        // delete all rendered objects from the render queue 
    1216         _deleteRenderedQueueGroups(); 
     1214        _deleteRenderedQueueGroups(leaveTransparentsInQueue); 
    12171215} 
    12181216#endif // GTP_VISIBILITY_MODIFIED_OGRE 
  • trunk/VUT/work/ogre_changes/RenderSystems/Direct3D9/include/OgreD3D9HardwareOcclusionQuery.h

    r92 r115  
    3333namespace Ogre { 
    3434 
    35  
    36  
    3735// If you use multiple rendering passes you can test only the first pass and all other passes don't have to be rendered  
    38 // if the first pass resultet has too few pixels visable. 
     36        // if the first pass resultet has too few pixels visible. 
    3937 
    4038// Be sure to render all occlluder first and whats out so the RenderQue don't switch places on  
     
    4644  * 
    4745  * @author Lee Sandberg, email lee@abcmedia.se 
     46        * 
     47        * Updated on 12/7/2004 by Chris McGuirk 
    4848  */ 
    4949class D3D9HardwareOcclusionQuery : public HardwareOcclusionQuery 
     
    7171        void beginOcclusionQuery();      
    7272        void endOcclusionQuery(); 
     73                bool pullOcclusionQuery( unsigned int* NumOfFragments, const HW_OCCLUSIONQUERY flag = HWOCCLUSIONQUERY_FLUSH); 
     74                unsigned int getLastQuerysPixelcount() { return mPixelCount; } 
    7375 
    74 #ifdef GTP_VISIBILITY_MODIFIED_OGRE 
    75         bool pullOcclusionQuery( unsigned int* NumOfFragments, const bool waitForResult, 
    76                                                          const HW_OCCLUSIONQUERY flag  );  
    77         bool pullOcclusionQuery( unsigned int* NumOfFragments, const bool waitForResult ); 
    78 #else 
    79         bool pullOcclusionQuery( unsigned int* NumOfFragments ); 
    80         bool pullOcclusionQuery( unsigned int* NumOfFragments, const HW_OCCLUSIONQUERY flag  );  
    81 #endif // GTP_VISIBILITY_MODIFIED_OGRE 
    82  
    83         unsigned int getLastQuerysPixelcount() { return m_uintPixelCount; } 
    84          
    85         // This functions are optional, it's a simple filter that simply skips some hardware occlusion tests on visable objects only 
    86         // It's easy to use if you don't have to keep track on which objects are visable (can be skipped) and what objects arn't visable.. 
    87         // (None visable objects and object you introduce for the first time have allways to be tested allthough the cheepest possible  
    88         // LOD (Level Of Detail) mesh and material wize).  
     76                // These functions are optional, it's a simple filter that simply skips some hardware occlusion tests on visible objects only 
     77                // It's easy to use if you don't have to keep track of which objects are visible (can be skipped) and what objects arn't visible.. 
     78                // (None visible objects and object you introduce for the first time have always to be tested although the cheapest possible  
     79                // LOD (Level Of Detail) mesh and material-wise).  
    8980 
    9081        /** 
    9182          *    
    92           * Remarks This function allows you to set how often the hardware occlusion really are sent to the driver 
     83                * Remarks This function allows you to set how often the hardware occlusion query is sent to the driver 
    9384          * if you set it to 0 every hw occlusion test is acctually made. If you set it to 1 only the half of your queries are sent  
    94           * for all visable objects. 2 will result in 25% of all queries to acctualy be sent.  
    95           * New and none visable objects will be tested all the time. 
    96           * This functionality is here because this class can keep track on visable and none visable objects for you. 
     85                * 2 will result in 25% of all queries to acctualy be sent.  
     86                * This functionality is here because this class can keep track on visible and none visible objects for you. 
    9787          * Once you you set the SkipRate for any hardware occlusion instance it effects all others. 
    9888          */ 
    9989 
     90                void setSkipRate( int skip ) { mSkipInterval = skip; }                  // Using 2 only 50 % of the tests are actully made and 3 results in only 33% of the tests. So on. 
     91                int      getSkipRate() { return mSkipInterval; }  
    10092 
    101         void setSkipRate( int skip ) { m_Skip = skip; }                 // Using 2 only 50 % of the tests are actually made and 3 results in only 33% of the tests. So on. 
    102         int      getSkipRate() { return m_Skip; }  
    103  
     93#ifdef GTP_VISIBILITY_MODIFIED_OGRE 
     94        bool pullOcclusionQuery( unsigned int* NumOfFragments, const bool waitForResult, const HW_OCCLUSIONQUERY flag = HWOCCLUSIONQUERY_FLUSH );  
     95#endif // GTP_VISIBILITY_MODIFIED_OGRE 
    10496//---------------------------------------------------------------------- 
    10597// Protected members 
     
    10799protected: 
    108100 
    109         bool pullOcclusionQuery( unsigned int* NumOfFragments, const bool waitForResult,  
    110                                                      const DWORD queryFlag ); 
    111  
    112         unsigned int            m_uintPixelCount;                
    113         IDirect3DQuery9*        m_pD3DQuery; 
    114         IDirect3DDevice9*   m_pD3DDevice;       // d3d device 
    115         bool                            m_bOcclusionQuery; 
    116         int                                     m_SkipCounter;          // m_SkipConter =  m_SkipConter % m_Skip; if ( m_SkipConter == 0 && m_uintPixelCount !=0 ) TestHWOcclusion else just return  
    117         static int                      m_Skip;                         // This is shared by all instancies 
    118         bool                            m_bHWOcclusionSupport; 
     101                unsigned int            mPixelCount;             
     102                IDirect3DQuery9*        mpQuery; 
     103                IDirect3DDevice9*   mpDevice; 
     104                int                                     mSkipCounter; 
     105                int                                     mSkipInterval; 
     106                bool                            mHasOcclusionSupport; 
    119107}; 
    120108 
  • trunk/VUT/work/ogre_changes/RenderSystems/Direct3D9/src/OgreD3D9HardwareOcclusionQuery.cpp

    r97 r115  
    2929namespace Ogre { 
    3030 
    31 int D3D9HardwareOcclusionQuery::m_Skip = 0; 
    32  
    3331/** 
    3432  * This is a class that is the DirectX9 implementation of  
     
    3634  * 
    3735  * @author Lee Sandberg 
     36        * 
     37        * Updated on 12/7/2004 by Chris McGuirk 
    3838  */ 
    3939 
    4040/** 
    4141  * Default object constructor 
    42   *  
    4342  */ 
    4443D3D9HardwareOcclusionQuery::D3D9HardwareOcclusionQuery( IDirect3DDevice9* pD3DDevice )  
    4544{  
    46         m_pD3DDevice = pD3DDevice; 
    47         m_uintPixelCount = 0;  
    48         m_SkipCounter = 0; 
    49         m_bHWOcclusionSupport = false; 
     45                mpDevice = pD3DDevice; 
     46                mPixelCount = 0;  
     47                mSkipCounter = 0; 
     48                mSkipInterval = 0; 
     49                mHasOcclusionSupport = false; 
    5050 
    51         HRESULT hr = m_pD3DDevice->CreateQuery(D3DQUERYTYPE_OCCLUSION, &m_pD3DQuery); 
     51                // create the occlusion query 
     52                HRESULT hr = mpDevice->CreateQuery(D3DQUERYTYPE_OCCLUSION, &mpQuery); 
     53 
    5254        if ( hr != D3D_OK )  
    5355        { 
    54                 //OGRE_EXCEPT(hr, "D3D9HardwareOcclusionQuery couldn't create hardware occlusion query object.",  
    55         //        "D3D9HardwareOcclusionQuery::D3D9HardwareOcclusionQuery"); 
    56                 m_bHWOcclusionSupport = false; 
     56                        mHasOcclusionSupport = false; 
    5757        } 
    5858        else  
    5959        { 
    60                 m_bHWOcclusionSupport = true; 
     60                        mHasOcclusionSupport = true; 
    6161        } 
    6262} 
    63  
    6463 
    6564/** 
     
    6867D3D9HardwareOcclusionQuery::~D3D9HardwareOcclusionQuery()  
    6968{  
    70         SAFE_RELEASE( m_pD3DQuery );  
     69                SAFE_RELEASE(mpQuery);  
    7170} 
    7271 
    73 #ifndef GTP_VISIBILITY_MODIFIED_OGRE 
    7472//------------------------------------------------------------------ 
    7573// Occlusion query functions (see base class documentation for this) 
     
    7775void D3D9HardwareOcclusionQuery::beginOcclusionQuery()  
    7876{  
    79         if( m_bHWOcclusionSupport )             // Make it fail silently if hardware occlusion isn't supported 
     77                // Make it fail silently if hardware occlusion isn't supported 
     78                if(mHasOcclusionSupport) 
    8079        { 
    81                 if  ( m_SkipCounter ==  m_Skip ) { m_SkipCounter = 0; };                // Counter starts at 0 again at m_Skip  
    82                  
    83                 if ( m_SkipCounter == 0 && m_uintPixelCount != 0 )      // New or none visable objects must allways be tested but visable objects can be skiped 
     80#ifndef GTP_VISIBILITY_MODIFIED_OGRE 
     81                        // Counter starts at 0 again at mSkipInterval  
     82                        if(mSkipCounter == mSkipInterval)  
     83#else 
     84                        if (mSkipCounter >= mSkipInterval)  // otherwise no query ever issued if mSkipInterval = 0 ! 
     85#endif // GTP_VISIBILITY_MODIFIED_OGRE 
    8486                { 
    85                         m_pD3DQuery->Issue(D3DISSUE_BEGIN);  
     87                                mSkipCounter = 0;  
     88} 
     89                        //std::stringstream d; d << "count: " << mSkipCounter; 
     90                        //LogManager::getSingleton().logMessage(d.str()); 
     91                        if (mSkipCounter == 0) 
     92                { 
     93                                mpQuery->Issue(D3DISSUE_BEGIN);  
    8694                } 
    8795        } 
     96         
    8897} 
    89          
    90 void D3D9HardwareOcclusionQuery::endOcclusionQuery()  
    91 {  
    92         if( m_bHWOcclusionSupport )     // Make it fail silently if hardware occlusion isn't supported 
     98 
     99        void D3D9HardwareOcclusionQuery::endOcclusionQuery()  
    93100        { 
    94                 if (m_SkipCounter == 0 && m_uintPixelCount != 0 ) // New or none visable objects must allways be tested but visable objects can be skiped 
    95                 { 
    96                         m_pD3DQuery->Issue(D3DISSUE_END);  
    97                 } 
    98                 m_SkipCounter++;                                                                 // The skip counter is increased  
     101                // Make it fail silently if hardware occlusion isn't supported 
     102                if(mHasOcclusionSupport) 
     103                        { 
     104                        if(mSkipCounter == 0) 
     105                        {  
     106                                mpQuery->Issue(D3DISSUE_END);  
     107        } 
     108 
     109                        // The skip counter is increased 
     110                        mSkipCounter++;  
    99111        } 
    100112} 
    101113 
    102114//------------------------------------------------------------------ 
    103 // This version of pullOcclusionQuery cases the DX9 API/Driver to flush all commands to the 3D card 
    104 // to allow a fast result from the query, but at the cost of poorer batching of API calls to the card. 
    105 // Note: OpenGL dosn't use this flag at all so the application running OpenGL won't display any different behaviour. 
    106 //-- 
    107 bool D3D9HardwareOcclusionQuery::pullOcclusionQuery( unsigned int* NumOfFragments)  
    108 { 
    109         HRESULT hr; 
    110          
    111         if( m_bHWOcclusionSupport )     // Make it fail silently if hardware occlusion isn't supported 
    112         { 
    113                 hr = m_pD3DQuery->GetData( NumOfFragments, sizeof( NumOfFragments ), D3DGETDATA_FLUSH ); 
    114  
    115                 if ( hr != S_OK )  
    116                         { 
    117                                 return false;  
    118                         } 
    119                         else  
    120                         {  
    121                                 m_uintPixelCount = *NumOfFragments;  
    122                                 return true;  
    123                         } 
    124         } 
    125         else 
    126         { 
    127                 m_uintPixelCount = 100000; // Fails quitlly if hardware occlusion is not supported - every object is visable 
    128                 return true; 
    129         } 
    130 } 
    131  
    132 //------------------------------------------------------------------ 
    133 // This version of pullOcclusionQuery cases the DX9 API/Driver to not flush all commands to the 3D card 
     115        // This version of pullOcclusionQuery causes the DX9 API/Driver to not flush all commands to the 3D card 
    134116// to allow a fast result from the query, but the batching of API calls to the card will be normal.  
    135 // But the query wont be processed until the card recives the query in the nexr batch. 
     117        // But the query wont be processed until the card recives the query in the next batch. 
    136118// Note: OpenGL dosn't use this flag at all so the application running OpenGL won't display any different behaviour. 
    137119//-- 
     
    140122        HRESULT hr; 
    141123 
    142         // TO DO: USE lockOpts= D3D9Mappings::get(options); instead of RS_OCCLUSIONQUERY enum 
     124                // Make it fail silently if hardware occlusion isn't supported 
     125                if(mHasOcclusionSupport) 
     126        { 
     127                        DWORD d3dFlags = (flag == HWOCCLUSIONQUERY_FLUSH) ? D3DGETDATA_FLUSH : 0; 
     128         
     129                        // run until success (http://www.gamedev.net/reference/programming/features/occlusionculling/page2.asp) 
     130                        while(hr = mpQuery->GetData( NumOfFragments, sizeof( NumOfFragments ), d3dFlags) == S_FALSE); 
    143131 
    144         if( m_bHWOcclusionSupport )     // Make it fail silently if hardware occlusion isn't supported 
    145         { 
    146          
    147                 switch( flag ) 
    148                 { 
    149                         case HWOCCLUSIONQUERY_FLUSH :    
    150                                 hr = m_pD3DQuery->GetData( NumOfFragments, sizeof( NumOfFragments ), D3DGETDATA_FLUSH ); 
    151                         break; 
    152  
    153                         case HWOCCLUSIONQUERY_NOFLUSH :  
    154                                 hr = m_pD3DQuery->GetData( NumOfFragments, sizeof( NumOfFragments ), 0 ); 
    155                         break; 
    156                 }; 
    157  
    158  
    159  
    160                 if ( hr != S_OK )  
    161                         { 
    162                                 return false;  
     132                        mPixelCount = *NumOfFragments; 
    163133                        } 
    164134                        else  
    165135                        {  
    166                                 m_uintPixelCount = *NumOfFragments;  
    167                                 return true;  
     136                        // fail silently if not supported, assume visible i suppose 
     137                        mPixelCount = 100000; 
    168138                        } 
    169         } 
    170         else  
    171         { 
    172                 m_uintPixelCount = 100000; // Fails quitlly if hardware occlusion is not supported - every object is visable 
     139 
    173140                return true; 
    174141        } 
    175 } 
    176 #else // GTP_VISIBILITY_MODIFIED_OGRE 
     142 
     143#ifdef GTP_VISIBILITY_MODIFIED_OGRE 
    177144//------------------------------------------------------------------ 
    178 void D3D9HardwareOcclusionQuery::beginOcclusionQuery()  
    179 {  
    180         if( m_bHWOcclusionSupport )             // Make it fail silently if hardware occlusion isn't supported 
     145        bool D3D9HardwareOcclusionQuery::pullOcclusionQuery( unsigned int* NumOfFragments, const bool waitForResult,  
     146                                                                                                             const HW_OCCLUSIONQUERY flag )  
    181147        { 
    182                 m_pD3DQuery->Issue(D3DISSUE_BEGIN);  
     148                HRESULT hr = S_OK; 
     149                DWORD queryFlag = (flag == HWOCCLUSIONQUERY_FLUSH) ? D3DGETDATA_FLUSH : 0; 
     150 
     151                if (mHasOcclusionSupport)       // In case hardware occlusion isn't supported 
     152                {        
     153                        do 
     154                        { 
     155                                hr = mpQuery->GetData(NumOfFragments, sizeof(NumOfFragments), queryFlag); 
     156                } 
     157                        while(waitForResult && (hr == S_FALSE)); 
     158                 
     159                        mPixelCount = *NumOfFragments; 
     160                } 
     161                else 
     162                { 
     163                        mPixelCount = 100000; // every object is visible 
     164                } 
     165         
     166                return hr == S_OK; 
    183167        } 
    184 } 
    185 //------------------------------------------------------------------ 
    186 void D3D9HardwareOcclusionQuery::endOcclusionQuery()  
    187 {  
    188         if( m_bHWOcclusionSupport )     // Make it fail silently if hardware occlusion isn't supported 
    189         { 
    190                 m_pD3DQuery->Issue(D3DISSUE_END);  
    191         } 
    192 } 
    193 //------------------------------------------------------------------ 
    194 bool D3D9HardwareOcclusionQuery::pullOcclusionQuery( unsigned int* NumOfFragments, const bool waitForResult )  
    195 { 
    196         return pullOcclusionQuery(NumOfFragments, waitForResult, HWOCCLUSIONQUERY_FLUSH); 
    197 } 
    198  
    199 //------------------------------------------------------------------ 
    200 bool D3D9HardwareOcclusionQuery::pullOcclusionQuery( unsigned int* NumOfFragments, const bool waitForResult,  
    201                                                                                                      const HW_OCCLUSIONQUERY flag  )  
    202 { 
    203         DWORD queryFlag = flag == HWOCCLUSIONQUERY_FLUSH ? D3DGETDATA_FLUSH : 0; 
    204         // TO DO: USE lockOpts= D3D9Mappings::get(options); instead of RS_OCCLUSIONQUERY enum 
    205  
    206         return pullOcclusionQuery(NumOfFragments, waitForResult, queryFlag); 
    207 } 
    208  
    209 //------------------------------------------------------------------ 
    210 bool D3D9HardwareOcclusionQuery::pullOcclusionQuery( unsigned int* NumOfFragments, const bool waitForResult,  
    211                                                                                                      const DWORD queryFlag )  
    212 { 
    213         HRESULT hr = S_OK; 
    214  
    215         if( m_bHWOcclusionSupport )     // In case hardware occlusion isn't supported 
    216         {        
    217                 do 
    218                 { 
    219                         hr = m_pD3DQuery->GetData( NumOfFragments, sizeof( NumOfFragments ), queryFlag ); 
    220                 } 
    221                 while(waitForResult && (hr == S_FALSE)); 
    222                  
    223                 m_uintPixelCount = *NumOfFragments;  
    224         } 
    225         else 
    226         { 
    227                 m_uintPixelCount = 100000; // every object is visible 
    228         } 
    229          
    230         return hr == S_OK; 
    231 } 
    232168 
    233169 
    234170#endif // GTP_VISIBILITY_MODIFIED_OGRE 
    235171 
    236 } // namespace OGre 
     172 
     173} 
  • trunk/VUT/work/ogre_changes/RenderSystems/GL/include/OgreGLHardwareOcclusionQuery.h

    r92 r115  
    8888        void beginOcclusionQuery(); 
    8989        void endOcclusionQuery(); 
    90  
    91 #ifdef GTP_VISIBILITY_MODIFIED_OGRE 
    92         bool pullOcclusionQuery( unsigned int* NumOfFragments, const bool waitForResult, 
    93                                                          const HW_OCCLUSIONQUERY flag  );  
    94         bool pullOcclusionQuery( unsigned int* NumOfFragments, const bool waitForResult ); 
    95 #else 
    96         bool pullOcclusionQuery( unsigned int* NumOfFragments ); 
    9790        bool pullOcclusionQuery( unsigned int* NumOfFragments, const HW_OCCLUSIONQUERY flag  );  
    98 #endif // GTP_VISIBILITY_MODIFIED_OGRE 
    99  
    100         unsigned int getLastQuerysPixelcount() { return m_uintPixelCount; } 
     91        unsigned int getLastQuerysPixelcount() { return mPixelCount; } 
    10192 
    10293        // This functions are optional, it's a simple filter that simply skipps some hardware occlusion tests on visable objects only 
     
    115106          */ 
    116107 
    117         void setSkipRate( int skip ) { m_Skip = skip; }         // Using 2 only 50 % of the tests are actully made and 3 results in only 33% of the tests. So on. 
    118         int      getSkipRate() { return m_Skip; }  
     108        void setSkipRate( int skip ) { mSkipInterval = skip; }          // Using 2 only 50 % of the tests are actully made and 3 results in only 33% of the tests. So on. 
     109        int      getSkipRate() { return mSkipInterval; }  
    119110 
    120  
     111#ifdef GTP_VISIBILITY_MODIFIED_OGRE 
     112        bool pullOcclusionQuery( unsigned int* NumOfFragments, const bool waitForResult, const HW_OCCLUSIONQUERY flag = HWOCCLUSIONQUERY_FLUSH );  
     113#endif // GTP_VISIBILITY_MODIFIED_OGRE 
    121114//---------------------------------------------------------------------- 
    122115// Protected members 
     
    124117protected: 
    125118 
    126         unsigned int    m_uintPixelCount; 
    127         unsigned int    m_uintQuery[1]; 
     119        unsigned int    mPixelCount; 
     120        GLuint                  mQueryID; 
    128121        bool                    m_bOcclusionQuery; 
    129         int                             m_SkipCounter;          // m_SkipConter =  m_SkipConter % m_Skip; if ( m_SkipConter == 0 && m_uintPixelCount !=0 ) TestHWOcclusion else just return  
    130         static int              m_Skip;                         // This is shared by all instancies 
    131         bool                    m_bHWOcclusionSupport; 
     122        int                             mSkipCounter; 
     123        int                             mSkipInterval; 
     124        bool                    mHasOcclusionSupport; 
    132125}; 
    133  
    134126 
    135127} 
  • trunk/VUT/work/ogre_changes/RenderSystems/GL/include/OgreGLPrerequisites.h

    r97 r115  
    7070extern GL_SecondaryColorPointerEXT_Func glSecondaryColorPointerEXT_ptr; 
    7171 
     72// Pointer to glSecondaryColor3fEXT function 
     73typedef void (APIENTRY *GL_SecondaryColor3fEXT_Func)(GLfloat, GLfloat, GLfloat); 
     74extern GL_SecondaryColor3fEXT_Func glSecondaryColor3fEXT_ptr; 
     75 
    7276// Pointer to glGenBuffersARB function 
    7377typedef void (APIENTRY *GL_GenBuffersARB_Func)(GLsizei, GLuint*); 
     
    208212extern GL_GetOcclusionQueryuivNV_Func glGetOcclusionQueryuivNV_ptr; 
    209213 
    210 #ifdef GTP_VISIBILITY_MODIFIED_OGRE 
    211 // Pointer to glGenQueriesARB function 
    212 typedef void (APIENTRY *GL_GenQueriesARB_Func) (GLsizei n, GLuint *ids); 
    213 extern GL_GenQueriesARB_Func glGenQueriesARB_ptr; 
    214  
    215 // Pointer to glDeleteQueriesARB function 
    216 typedef void (APIENTRY *GL_DeleteQueriesARB_Func) (GLsizei n, const GLuint *ids); 
    217 extern GL_DeleteQueriesARB_Func glDeleteQueriesARB_ptr; 
    218  
    219 // Pointer to glIsQueryARB function 
    220 typedef GLboolean (APIENTRY *GL_IsQueryARB_Func) (GLuint id); 
    221 extern GL_IsQueryARB_Func glIsQueryARB_ptr; 
    222  
    223 // Pointer to glBeginQueryARB function 
    224 typedef void (APIENTRY *GL_BeginQueryARB_Func) (GLenum target, GLuint id); 
    225 extern GL_BeginQueryARB_Func glBeginQueryARB_ptr; 
    226  
    227 // Pointer to glEndQueryARB function 
    228 typedef void (APIENTRY *GL_EndQueryARB_Func) (GLenum target); 
    229 extern GL_EndQueryARB_Func glEndQueryARB_ptr; 
    230  
    231 // Pointer to glGetQueryivARB function 
    232 typedef void (APIENTRY *GL_GetQueryivARB_Func) (GLuint id, GLenum pname, GLint *params); 
    233 extern GL_GetQueryivARB_Func glGetQueryivARB_ptr; 
    234  
    235 // Pointer to glGetQueryObjectivARB function 
    236 typedef void (APIENTRY *GL_GetQueryObjectivARB_Func) (GLuint id, GLenum pname, GLint *params); 
    237 extern GL_GetQueryObjectivARB_Func glGetQueryObjectivARB_ptr; 
    238  
    239 // Pointer to glGetQueryObjectuivARB function 
    240 typedef void (APIENTRY *GL_GetQueryObjectuivARB_Func) (GLuint id, GLenum pname, GLuint *params); 
    241 extern GL_GetQueryObjectuivARB_Func glGetQueryObjectuivARB_ptr; 
    242  
    243 #endif // GTP_VISIBILITY_MODIFIED_OGRE 
    244  
    245214extern PFNGLCOMPRESSEDTEXIMAGE1DARBPROC glCompressedTexImage1DARB_ptr; 
    246215extern PFNGLCOMPRESSEDTEXIMAGE2DARBPROC glCompressedTexImage2DARB_ptr; 
     
    253222}; 
    254223 
     224// Pointer to glGenQueriesARB function 
     225typedef void (APIENTRY *GL_GenQueriesARB_Func) (GLuint n, GLuint *ids); 
     226extern GL_GenQueriesARB_Func glGenQueriesARB_ptr; 
     227 
     228// Pointer to glDeleteQueriesARB function 
     229typedef void (APIENTRY *GL_DeleteQueriesARB_Func) (GLuint n, const GLuint *ids); 
     230extern GL_DeleteQueriesARB_Func glDeleteQueriesARB_ptr; 
     231 
     232// Pointer to glBeginQueryARB function 
     233typedef void (APIENTRY *GL_BeginQueryARB_Func) (GLenum target, GLuint id); 
     234extern GL_BeginQueryARB_Func glBeginQueryARB_ptr; 
     235 
     236// Pointer to glEndQueryARB function 
     237typedef void (APIENTRY *GL_EndQueryARB_Func) (GLenum target); 
     238extern GL_EndQueryARB_Func glEndQueryARB_ptr; 
     239#ifdef GTP_VISIBILITY_MODIFIED_OGRE 
     240// Pointer to glGetQueryivARB function 
     241typedef void (APIENTRY *GL_GetQueryivARB_Func) (GLuint id, GLenum pname, GLint *params); 
     242extern GL_GetQueryivARB_Func glGetQueryivARB_ptr; 
     243 
     244// Pointer to glGetQueryObjectivARB function 
     245typedef void (APIENTRY *GL_GetQueryObjectivARB_Func) (GLuint id, GLenum pname, GLint *params); 
     246extern GL_GetQueryObjectivARB_Func glGetQueryObjectivARB_ptr; 
     247#endif // GTP_VISIBILITY_MODIFIED_OGRE 
     248// Pointer to glGetQueryObjectuivARB function 
     249typedef void (APIENTRY *GL_GetQueryObjectuivARB_Func) (GLuint id, GLenum pname, GLuint *params); 
     250extern GL_GetQueryObjectuivARB_Func glGetQueryObjectuivARB_ptr; 
    255251 
    256252 
  • trunk/VUT/work/ogre_changes/RenderSystems/GL/src/OgreGLHardwareOcclusionQuery.cpp

    r99 r115  
    2727#include "OgreException.h" 
    2828 
     29 
    2930namespace Ogre { 
    30  
    31 int GLHardwareOcclusionQuery::m_Skip = 0; 
    3231 
    3332/** 
     
    3635  * 
    3736  * @author Lee Sandberg email: lee@abcmedia.se 
     37  * 
     38  * Updated on 12/7/2004 by Chris McGuirk 
     39  * - Implemented ARB_occlusion_query 
    3840  */ 
    3941 
    40 /* Functions used; 
    41  
    42 glGenOcclusionQueriesNV_ptr( 1, m_uintQuery ); 
    43 glDeleteOcclusionQueriesNV_ptr( 1, &m_uintQuery[0] ); 
    44 glBeginOcclusionQueryNV_ptr( m_uintQuery[0] ); 
    45 glEndOcclusionQueryNV_ptr(); 
    46 glGetOcclusionQueryuivNV_ptr( m_uintQuery[0], GL_PIXEL_COUNT_NV, NumOfFragments ); 
    47  
    48   TO DO: change this to the new ARB functions... 
    49  
    50 */ 
    51  
    52 #ifndef GTP_VISIBILITY_MODIFIED_OGRE 
    5342/** 
    5443  * Default object constructor 
     
    5746GLHardwareOcclusionQuery::GLHardwareOcclusionQuery()  
    5847{  
    59         m_uintPixelCount = 0;  
    60         m_SkipCounter = 0; 
     48        mPixelCount = 0;  
     49        mSkipCounter = 0; 
     50        mSkipInterval = 0; 
    6151 
    6252        // Check for hardware occlusion support 
    63     if( glDeleteOcclusionQueriesNV_ptr != 0 )   // This is a hack to see if hw occlusion is supported. pointer is 0 if it's not supported. 
     53        // This is a hack to see if hw occlusion is supported. pointer is 0 if it's not supported. 
     54        //if (glGenQueriesARB_ptr != 0) 
     55        if (glGenOcclusionQueriesNV_ptr != 0) 
    6456    { 
    65                 m_bHWOcclusionSupport = true; 
     57                mHasOcclusionSupport = true; 
    6658        } 
    6759        else 
    6860        { 
    69                 m_bHWOcclusionSupport = false; 
     61                mHasOcclusionSupport = false; 
    7062        } 
    7163 
    72         if( m_bHWOcclusionSupport ) 
     64        if(mHasOcclusionSupport) 
    7365        { 
    74                 glGenOcclusionQueriesNV_ptr( 1, m_uintQuery );   
     66                //glGenQueriesARB_ptr(1, &mQueryID );    
     67                glGenOcclusionQueriesNV_ptr(1, &mQueryID); 
    7568        } 
    7669} 
    77  
    7870 
    7971/** 
     
    8274GLHardwareOcclusionQuery::~GLHardwareOcclusionQuery()  
    8375{  
    84         if( m_bHWOcclusionSupport ) 
     76        if( mHasOcclusionSupport ) 
    8577        { 
    86                 glDeleteOcclusionQueriesNV_ptr( 1, &m_uintQuery[0] );   
     78                //glDeleteQueriesARB_ptr(1, &mQueryID);   
     79                glDeleteOcclusionQueriesNV_ptr(1, &mQueryID);   
    8780        }        
    8881} 
     
    9386void GLHardwareOcclusionQuery::beginOcclusionQuery()  
    9487{  
    95         if( m_bHWOcclusionSupport )     // Make it fail silently if hardware occlusion isn't supported 
     88        // Make it fail silently if hardware occlusion isn't supported 
     89        if(mHasOcclusionSupport) 
    9690        { 
    97                 if  ( m_SkipCounter ==  m_Skip ) { m_SkipCounter = 0; };                // Counter starts at 0 again at m_Skip  
    98                 if ( m_SkipCounter == 0 && m_uintPixelCount != 0 ) // New or none visable objects must allways be tested but visable objects can be skiped 
     91                // Counter starts at 0 again at mSkipInterval  
     92#ifndef GTP_VISIBILITY_MODIFIED_OGRE 
     93                if(mSkipCounter == mSkipInterval)  
     94#else 
     95                if (mSkipCounter >= mSkipInterval)  // otherwise no query ever issued if mSkipInterval = 0 ! 
     96#endif // GTP_VISIBILITY_MODIFIED_OGRE 
     97        { 
     98                        mSkipCounter = 0;  
     99                } 
     100 
     101                if (mSkipCounter == 0) 
    99102                { 
    100                         glBeginOcclusionQueryNV_ptr( m_uintQuery[0] ); 
     103                        //glBeginQueryARB_ptr(GL_SAMPLES_PASSED_ARB, mQueryID); 
     104                        glBeginOcclusionQueryNV_ptr(mQueryID); 
    101105                } 
    102106        } 
     
    105109void GLHardwareOcclusionQuery::endOcclusionQuery()  
    106110{  
    107         if( m_bHWOcclusionSupport )     // Make it fail silently if hardware occlusion isn't supported 
     111        // Make it fail silently if hardware occlusion isn't supported 
     112        if(mHasOcclusionSupport) 
    108113        { 
    109                 if( m_SkipCounter == 0 && m_uintPixelCount != 0 ) // New or none visable objects must allways be tested but visable objects can be skiped 
     114                if( mSkipCounter == 0) 
    110115                { 
     116                        //glEndQueryARB_ptr(GL_SAMPLES_PASSED_ARB); 
    111117                        glEndOcclusionQueryNV_ptr(); 
    112118                } 
    113                 m_SkipCounter++; 
    114         } 
    115 } 
    116119 
    117 bool GLHardwareOcclusionQuery::pullOcclusionQuery( unsigned int * NumOfFragments)  
    118 { 
    119         if( m_bHWOcclusionSupport )     // Make it fail silently if hardware occlusion isn't supported 
    120         { 
    121                 glGetOcclusionQueryuivNV_ptr( m_uintQuery[0], GL_PIXEL_COUNT_NV, NumOfFragments ); 
     120                mSkipCounter++; 
    122121        }  
    123         else 
    124         { 
    125                 *NumOfFragments = 100000;               // Fails quitlly -> every object tested is visable. 
    126         } 
    127  
    128         m_uintPixelCount = *NumOfFragments;  
    129  
    130         return true; 
    131122} 
    132123 
    133124//------------------------------------------------------------------ 
    134 // OpenGL dosn't use the flag, but to fulfil the abstract interface we need to include this function. 
    135 // Using this function in OpenGL mode simple works the same way as calling the other function without the flag parameter, 
    136 // but in DX9 it works differentlly, see notes in the DX9 implementation. 
    137 //-- 
     125// OpenGL dosn't use the flag paramter. 
     126//------------------------------------------------------------------ 
    138127bool GLHardwareOcclusionQuery::pullOcclusionQuery( unsigned int* NumOfFragments, const HW_OCCLUSIONQUERY flag  )  
    139128{ 
    140         if( m_bHWOcclusionSupport )     // Make it fail silently if hardware occlusion isn't supported 
     129        if( mHasOcclusionSupport )      // Make it fail silently if hardware occlusion isn't supported 
    141130        { 
    142                 glGetOcclusionQueryuivNV_ptr( m_uintQuery[0], GL_PIXEL_COUNT_NV, NumOfFragments ); 
     131                //glGetQueryObjectuivARB_ptr(mQueryID, GL_QUERY_RESULT_ARB, NumOfFragments); 
     132glGetOcclusionQueryuivNV_ptr(mQueryID, GL_PIXEL_COUNT_NV, NumOfFragments); 
    143133        } 
    144134        else 
     
    147137        } 
    148138 
    149         m_uintPixelCount = *NumOfFragments;  
     139        mPixelCount = *NumOfFragments;  
    150140         
    151141        return true; 
    152142} 
    153143 
    154 #else // GTP_VISIBILITY_MODIFIED_OGRE 
    155  
    156 //------------------------------------------------------------------ 
    157 GLHardwareOcclusionQuery::GLHardwareOcclusionQuery()  
    158 {  
    159         m_uintPixelCount = 0;  
    160         m_SkipCounter = 0; 
    161  
    162         // 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 ) 
    165         { 
    166                 m_bHWOcclusionSupport = true; 
    167         } 
    168         else 
    169         { 
    170                 m_bHWOcclusionSupport = false; 
    171         } 
    172  
    173         if ( m_bHWOcclusionSupport ) 
    174         { 
    175                 glGenOcclusionQueriesNV_ptr( 1, m_uintQuery );   
    176                 //glGenQueriesARB_ptr(1, m_uintQuery); 
    177         } 
    178 } 
    179  
    180  
    181 //------------------------------------------------------------------ 
    182 GLHardwareOcclusionQuery::~GLHardwareOcclusionQuery()  
    183 {  
    184         if ( m_bHWOcclusionSupport ) 
    185         { 
    186                 glDeleteOcclusionQueriesNV_ptr( 1, &m_uintQuery[0] );   
    187                 //glDeleteQueriesARB_ptr(1, &m_uintQuery[0]); 
    188         }        
    189 } 
    190  
    191 //------------------------------------------------------------------ 
    192 void GLHardwareOcclusionQuery::beginOcclusionQuery()  
    193 {  
    194         if ( m_bHWOcclusionSupport )    // Make it fail silently if hardware occlusion isn't supported 
    195         { 
    196                 // do the actual occlusion query for this node 
    197                 glBeginOcclusionQueryNV_ptr( m_uintQuery[0] ); 
    198                 //glBeginQueryARB_ptr(GL_SAMPLES_PASSED_ARB, m_uintQuery[0]); 
    199         } 
    200 } 
    201          
    202 void GLHardwareOcclusionQuery::endOcclusionQuery()  
    203 {  
    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); 
    208         } 
    209 } 
    210 //------------------------------------------------------------------ 
    211 bool GLHardwareOcclusionQuery::pullOcclusionQuery( unsigned int * NumOfFragments, const bool waitForResult)  
     144#ifdef GTP_VISIBILITY_MODIFIED_OGRE 
     145        //------------------------------------------------------------------ 
     146        bool GLHardwareOcclusionQuery::pullOcclusionQuery( unsigned int * NumOfFragments, const bool waitForResult, const HW_OCCLUSIONQUERY flag)  
    212147{ 
    213148        unsigned int isAvailable = GL_TRUE; 
    214         //int isAvailable = GL_TRUE; 
    215149 
    216         if( m_bHWOcclusionSupport )      
     150                if (mHasOcclusionSupport)        
    217151        { 
    218152                if (!waitForResult) 
    219153                { 
    220                         glGetOcclusionQueryuivNV_ptr( m_uintQuery[0], GL_PIXEL_COUNT_AVAILABLE_NV, &isAvailable ); 
    221                         //glGetQueryivARB_ptr(m_uintQuery[0], GL_QUERY_RESULT_AVAILABLE_ARB, &isAvailable); 
     154                        // use nv queries rather that arb because they are faster (no flush) 
     155                                //glGetQueryivARB_ptr(mQueryID, GL_QUERY_RESULT_AVAILABLE_ARB, &isAvailable); 
     156                                glGetOcclusionQueryuivNV_ptr(mQueryID, GL_PIXEL_COUNT_AVAILABLE_NV, &isAvailable); 
    222157                } 
    223158 
    224159                if (isAvailable == GL_TRUE) 
    225160                { 
    226                         glGetOcclusionQueryuivNV_ptr( m_uintQuery[0], GL_PIXEL_COUNT_NV, NumOfFragments ); 
    227                         //glGetQueryObjectuivARB_ptr( m_uintQuery[0], GL_QUERY_RESULT_ARB, NumOfFragments); 
     161                                //glGetQueryObjectuivARB_ptr(mQueryID, GL_QUERY_RESULT_ARB, NumOfFragments); 
     162                                glGetOcclusionQueryuivNV_ptr(mQueryID, GL_PIXEL_COUNT_NV, NumOfFragments); 
    228163                } 
    229164        }  
     
    234169        } 
    235170 
    236         m_uintPixelCount = *NumOfFragments;  
     171                mPixelCount = *NumOfFragments;  
    237172 
    238173        return isAvailable == GL_TRUE;   
    239174} 
    240175 
    241 //------------------------------------------------------------------ 
    242 bool GLHardwareOcclusionQuery::pullOcclusionQuery( unsigned int* NumOfFragments, const bool waitForResult, const HW_OCCLUSIONQUERY flag  )  
    243 { 
    244         return pullOcclusionQuery(NumOfFragments, waitForResult); 
     176#endif // GTP_VIBILITY_MODIFIED_OGRE 
    245177} 
    246  
    247 #endif // GTP_VISIBILITY_MODIFIED_OGRE 
    248  
    249  
    250 } 
    251  
    252  
  • trunk/VUT/work/ogre_changes/RenderSystems/GL/src/OgreGLRenderSystem.cpp

    r97 r115  
    5858GL_ClientActiveTextureARB_Func glClientActiveTextureARB_ptr; 
    5959GL_SecondaryColorPointerEXT_Func glSecondaryColorPointerEXT_ptr; 
     60GL_SecondaryColor3fEXT_Func glSecondaryColor3fEXT_ptr; 
    6061GL_GenBuffersARB_Func glGenBuffersARB_ptr; 
    6162GL_BindBufferARB_Func glBindBufferARB_ptr; 
     
    9798GL_EndOcclusionQueryNV_Func glEndOcclusionQueryNV_ptr; 
    9899GL_GetOcclusionQueryuivNV_Func glGetOcclusionQueryuivNV_ptr; 
    99   
    100 #ifdef GTP_VISIBILITY_MODIFIED_OGRE 
    101100GL_GenQueriesARB_Func glGenQueriesARB_ptr; 
    102101GL_DeleteQueriesARB_Func glDeleteQueriesARB_ptr; 
    103 GL_IsQueryARB_Func glIsQueryARB_ptr; 
    104102GL_BeginQueryARB_Func glBeginQueryARB_ptr; 
    105103GL_EndQueryARB_Func glEndQueryARB_ptr; 
     104#ifdef GTP_VISIBILITY_MODIFIED_OGRE 
    106105GL_GetQueryivARB_Func glGetQueryivARB_ptr; 
    107106GL_GetQueryObjectivARB_Func glGetQueryObjectivARB_ptr; 
     107#endif // GTP_VISIBILITY_MODIFIED_OGRE 
    108108GL_GetQueryObjectuivARB_Func glGetQueryObjectuivARB_ptr; 
    109 #endif // GTP_VISIBILITY_MODIFIED_OGRE 
    110109 
    111110namespace Ogre { 
     
    191190        glClientActiveTextureARB_ptr = 0; 
    192191        glSecondaryColorPointerEXT_ptr = 0; 
     192        glSecondaryColor3fEXT_ptr = 0; 
    193193        glGenBuffersARB_ptr = 0; 
    194194        glBindBufferARB_ptr = 0; 
     
    220220        glEndOcclusionQueryNV_ptr = 0; 
    221221        glGetOcclusionQueryuivNV_ptr = 0; 
    222  
    223 #ifdef GTP_VISIBILITY_MODIFIED_OGRE 
    224222                glGenQueriesARB_ptr = 0; 
    225223                glDeleteQueriesARB_ptr = 0; 
    226                 glIsQueryARB_ptr = 0; 
    227224                glBeginQueryARB_ptr = 0; 
    228225                glEndQueryARB_ptr = 0; 
     226#ifdef GTP_VISIBILITY_MODIFIED_OGRE 
    229227                glGetQueryivARB_ptr = 0; 
    230228                glGetQueryObjectivARB_ptr = 0; 
     229#endif // GTP_VISIBILITY_MODIFIED_OGRE 
    231230                glGetQueryObjectuivARB_ptr = 0; 
    232 #endif // GTP_VISIBILITY_MODIFIED_OGRE 
    233231 
    234232        mCurrentLights = 0; 
     
    543541        glSecondaryColorPointerEXT_ptr =  
    544542            (GL_SecondaryColorPointerEXT_Func)mGLSupport->getProcAddress("glSecondaryColorPointerEXT"); 
     543        glSecondaryColor3fEXT_ptr =  
     544            (GL_SecondaryColor3fEXT_Func)mGLSupport->getProcAddress("glSecondaryColor3fEXT"); 
    545545        glGenBuffersARB_ptr =  
    546546            (GL_GenBuffersARB_Func)mGLSupport->getProcAddress("glGenBuffersARB"); 
     
    622622        glGetOcclusionQueryuivNV_ptr = 
    623623            (GL_GetOcclusionQueryuivNV_Func)mGLSupport->getProcAddress("glGetOcclusionQueryuivNV"); 
    624                 glGetQueryObjectivARB_ptr =  
    625                          (GL_GetQueryObjectivARB_Func)mGLSupport->getProcAddress("glGetQueryObjectivARB"); 
    626                 glGetQueryObjectuivARB_ptr =  
    627                          (GL_GetQueryObjectuivARB_Func)mGLSupport->getProcAddress("glGetQueryObjectuivARB"); 
    628 #ifdef GTP_VISIBILITY_MODIFIED_OGRE 
     624 
    629625                glGenQueriesARB_ptr =  
    630626                         (GL_GenQueriesARB_Func)mGLSupport->getProcAddress("glGenQueriesARB"); 
    631627                glDeleteQueriesARB_ptr = 
    632628                        (GL_DeleteQueriesARB_Func)mGLSupport->getProcAddress("glDeleteQueriesARB"); 
    633                 glIsQueryARB_ptr = 
    634                         (GL_IsQueryARB_Func)mGLSupport->getProcAddress("glIsQueryARB"); 
    635629                glBeginQueryARB_ptr = 
    636630                         (GL_BeginQueryARB_Func)mGLSupport->getProcAddress("glBeginQueryARB"); 
    637631                glEndQueryARB_ptr = 
    638632                         (GL_EndQueryARB_Func)mGLSupport->getProcAddress("glEndQueryARB"); 
     633        #ifdef GTP_VISIBILITY_MODIFIED_OGRE 
    639634                glGetQueryivARB_ptr =  
    640635                        (GL_GetQueryivARB_Func)mGLSupport->getProcAddress("glGetQueryivARB"); 
    641636                glGetQueryObjectivARB_ptr =  
    642637                         (GL_GetQueryObjectivARB_Func)mGLSupport->getProcAddress("glGetQueryObjectivARB"); 
     638        #endif // GTP_VISIBILITY_MODIFIED_OGRE 
    643639                glGetQueryObjectuivARB_ptr =  
    644640                         (GL_GetQueryObjectuivARB_Func)mGLSupport->getProcAddress("glGetQueryObjectuivARB"); 
    645 #endif // GTP_VISIBILITY_MODIFIED_OGRE 
    646641 
    647642        mCapabilities->log(LogManager::getSingleton().getDefaultLog()); 
     
    18571852                    cv1[2] = bm.colourArg1.b; 
    18581853                    cv1[3] = bm.colourArg1.a; 
     1854                        mManualBlendColours[stage][0] = bm.colourArg1; 
     1855 
    18591856 
    18601857                    cv2[0] = bm.colourArg2.r; 
     
    18621859                    cv2[2] = bm.colourArg2.b; 
    18631860                    cv2[3] = bm.colourArg2.a; 
     1861                        mManualBlendColours[stage][1] = bm.colourArg2; 
    18641862        } 
    18651863 
    18661864                if (bm.blendType == LBT_ALPHA) 
    18671865        { 
    1868                     cv1[0] = 0; 
    1869                     cv1[1] = 0; 
    1870                     cv1[2] = 0; 
     1866                    cv1[0] = mManualBlendColours[stage][0].r; 
     1867                    cv1[1] = mManualBlendColours[stage][0].g; 
     1868                    cv1[2] = mManualBlendColours[stage][0].b; 
    18711869                    cv1[3] = bm.alphaArg1; 
    18721870 
    1873                     cv2[0] = 0; 
    1874                     cv2[1] = 0; 
    1875                     cv2[2] = 0; 
     1871                    cv2[0] = mManualBlendColours[stage][1].r; 
     1872                    cv2[1] = mManualBlendColours[stage][1].g; 
     1873                    cv2[2] = mManualBlendColours[stage][1].b; 
    18761874                    cv2[3] = bm.alphaArg2; 
    18771875        } 
     
    22492247        } 
    22502248        glColor4f(1,1,1,1); 
     2249        glSecondaryColor3fEXT_ptr(0.0f, 0.0f, 0.0f); 
    22512250 
    22522251        // UnGuard 
     
    25372536        glLightModeli(GL_LIGHT_MODEL_COLOR_CONTROL, GL_SEPARATE_SPECULAR_COLOR); 
    25382537        glLightModeli(GL_LIGHT_MODEL_LOCAL_VIEWER, 1);         
     2538        glEnable(GL_COLOR_SUM); 
     2539 
    25392540        // Check for FSAA 
    25402541        // Enable the extension if it was enabled by the GLSupport 
  • trunk/VUT/work/ogre_changes/Samples/Common/include/ExampleFrameListener.h

    r100 r115  
    300300                return true; 
    301301        } 
    302 #ifdef GTP_VISIBILITY_MODIFIED_OGRE 
    303         virtual void moveCamera() // made virtual by matt (16.05.05) 
    304 #else 
     302 
    305303        void moveCamera() 
    306 #endif // GTP_VISIBILTIY_MODIFIED_OGRE 
    307304        { 
    308305 
Note: See TracChangeset for help on using the changeset viewer.