source: trunk/VUT/work/ogre_changes/RenderSystems/GL/include/OgreGLHardwareOcclusionQuery.h @ 88

Revision 88, 4.9 KB checked in by mattausch, 19 years ago (diff)
Line 
1/*
2-----------------------------------------------------------------------------
3This source file is part of OGRE
4    (Object-oriented Graphics Rendering Engine)
5For the latest info, see http://ogre.sourceforge.net/
6
7Copyright (c) 2000-2005 The OGRE Team
8Also see acknowledgements in Readme.html
9
10This program is free software; you can redistribute it and/or modify it under
11the terms of the GNU Lesser General Public License as published by the Free Software
12Foundation; either version 2 of the License, or (at your option) any later
13version.
14
15This program is distributed in the hope that it will be useful, but WITHOUT
16ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
17FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
18
19You should have received a copy of the GNU Lesser General Public License along with
20this program; if not, write to the Free Software Foundation, Inc., 59 Temple
21Place - Suite 330, Boston, MA 02111-1307, USA, or go to
22http://www.gnu.org/copyleft/lesser.txt.
23-----------------------------------------------------------------------------
24*/
25
26/*
27The nVidia occlusion query extension is defined in glext.h so you don't
28need anything else. You do need to look up the function, we provide a
29GLSupport class to do this, which has platform implementations for
30getProcAddress. Check the way that extensions like glActiveTextureARB are
31initialised and used in glRenderSystem and copy what is done there.
32
33
34
35  To do: fix so dx7 and DX9 checks and flags if HW Occlusion is supported
36  See the openGl dito for ideas what to do.
37
38*/
39
40
41
42//GL_ActiveTextureARB_Func* glActiveTextureARB_ptr = (GL_ActiveTextureARB_Func)mGLSupport->getProcAddress("glActiveTextureARB");
43
44#ifndef __GLHARDWAREOCCLUSIONQUERY_H__
45#define __GLHARDWAREOCCLUSIONQUERY_H__
46
47#include "OgreGLPrerequisites.h"
48#include "OgreHardwareOcclusionQuery.h"
49
50
51namespace Ogre {
52
53
54// If you use multiple rendering passes you can test only the first pass and all other passes don't have to be rendered
55// if the first pass resultet has too few pixels visable.
56
57// Be sure to render all occlluder first and whats out so the RenderQue don't switch places on
58// the occluding objects and the tested objects because it thinks it's more effective..
59
60
61/**
62  * This is a class that is the base class of the query class for
63  * hardware occlusion.
64  *
65  * @author Lee Sandberg email: lee@abcmedia.se
66  */
67
68class GLHardwareOcclusionQuery : public HardwareOcclusionQuery
69{
70//----------------------------------------------------------------------
71// Public methods
72//--
73public:
74        /**
75          * Default object constructor
76          *
77          */
78        GLHardwareOcclusionQuery();
79        /**
80          * Object destructor
81          */
82        ~GLHardwareOcclusionQuery();
83
84        //------------------------------------------------------------------
85        // Occlusion query functions (see base class documentation for this)
86        //--
87
88        void beginOcclusionQuery();
89        void endOcclusionQuery();
90        bool pullOcclusionQuery( unsigned int* NumOfFragments, const bool waitForResult );
91        bool pullOcclusionQuery( unsigned int* NumOfFragments, const bool waitForResult,
92                                                         const HW_OCCLUSIONQUERY flag  );
93
94        unsigned int getLastQuerysPixelcount() { return m_uintPixelCount; }
95
96        // This functions are optional, it's a simple filter that simply skipps some hardware occlusion tests on visable objects only
97        // 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..
98        // (None visable objects and object you introduce for the first time have allways to be tested allthough the cheepest possible
99        // LOD (Level Of Detail) mesh and material wize).
100
101        /**
102          *   
103          * Remarks This function allows you to set how often the hardware occlusion really sent to the driver
104          * if you set it to 0 every hw occlusion test is acctually made. If you set it to 2 only 50% of your queries are sent.
105          * for all visable objects. 3 will result in 33% of all queries to acctualy be sent and so on.
106          * New and none visable objects will be tested all the time.
107          * This functionality is here because this class can keep track on visable and none visable objects for you.
108          * Once you you set the SkipRate for any hardware occlusion instance it effects all others.
109          */
110
111        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.
112        int      getSkipRate() { return m_Skip; }
113
114
115//----------------------------------------------------------------------
116// Protected members
117//--
118protected:
119
120        unsigned int    m_uintPixelCount;
121        unsigned int    m_uintQuery[1];
122        bool                    m_bOcclusionQuery;
123        int                             m_SkipCounter;          // m_SkipConter =  m_SkipConter % m_Skip; if ( m_SkipConter == 0 && m_uintPixelCount !=0 ) TestHWOcclusion else just return
124        static int              m_Skip;                         // This is shared by all instancies
125        bool                    m_bHWOcclusionSupport;
126};
127
128
129}
130
131#endif
132
Note: See TracBrowser for help on using the repository browser.