source: trunk/VUT/GtpVisibility/src/StopAndWaitCullingManager.cpp @ 175

Revision 175, 1.5 KB checked in by mattausch, 19 years ago (diff)

added trees

Line 
1#include "StopAndWaitCullingManager.h"
2#include <OgreLogManager.h>
3
4namespace GtpVisibility {
5
6//-----------------------------------------------------------------------
7void StopAndWaitCullingManager::RenderScene()
8{
9        //Ogre::LogManager::getSingleton().logMessage("Stop and Wait Culling");
10        while (!mHierarchyInterface->GetQueue()->empty())
11        {
12                HierarchyNode *node = mHierarchyInterface->GetQueue()->top();
13                mHierarchyInterface->GetQueue()->pop();
14                       
15                // interesting for visualization purpose
16                mHierarchyInterface->SetNodeVisible(node, false);
17                mHierarchyInterface->SetLastVisited(node, mHierarchyInterface->GetFrameId());
18
19                bool intersects = false;
20
21                if (!mHierarchyInterface->CheckFrustumVisible(node, intersects))
22                {
23                        ++ mNumFrustumCulledNodes;
24               
25                        if (mVisualizeCulledNodes)
26                        {
27                                mHierarchyInterface->VisualizeCulledNode(node, FRUSTUM_CULLED);
28                        }
29                }
30                // if intersects near plane => skip occlusion query because wrong results possible
31                else if (intersects)
32                {
33                        mHierarchyInterface->SetNodeVisible(node, true);
34                        mHierarchyInterface->TraverseNode(node);
35                }
36                else
37                {
38
39                        ++ mNumQueriesIssued;
40
41                        unsigned int visiblePixels = 0;
42
43                        mHierarchyInterface->IssueNodeOcclusionQuery(node)->GetQueryResult(visiblePixels, true);
44                       
45                        // node visible
46                        if (visiblePixels > mVisibilityThreshold)
47                        {
48                                mHierarchyInterface->TraverseNode(node);
49                        }
50                        else
51                        {       
52                                ++ mNumQueryCulledNodes;
53
54                                if (mVisualizeCulledNodes)
55                                {
56                                        mHierarchyInterface->VisualizeCulledNode(node, QUERY_CULLED);
57                                }
58                        }
59                }
60        }
61}
62} // namespace GtpVisibility
Note: See TracBrowser for help on using the repository browser.