Implemented lighter weight setting of the CurrentVertexArrayState and introduced GlobalVertexArrayState.

This commit is contained in:
Robert Osfield
2016-07-23 16:33:39 +01:00
parent 7d83d735ad
commit 4b4cd13d31
5 changed files with 21 additions and 14 deletions

View File

@@ -500,12 +500,22 @@ class OSG_EXPORT State : public Referenced
void dirtyAllAttributes();
struct SetCurrentVertexArrayStateProxy
{
SetCurrentVertexArrayStateProxy(osg::State& state, VertexArrayState* vas):_state(state) { _state.setCurrentVertexArrayState(vas); }
~SetCurrentVertexArrayStateProxy() { _state.setCurrentToGloabalVertexArrayState(); }
osg::State& _state;
};
/** Set the CurrentVetexArrayState object that take which vertex arrays are bound.*/
void setCurrentVertexArrayState(VertexArrayState* vas) { _currentVertexArrayState = vas; }
/** Get the CurrentVetexArrayState object that take which vertex arrays are bound.*/
VertexArrayState* getCurrentVertexArrayState() const { return _currentVertexArrayState.get(); }
VertexArrayState* getCurrentVertexArrayState() const { return _currentVertexArrayState; }
/** Set the getCurrentVertexArrayState to the GloabalVertexArrayState.*/
void setCurrentToGloabalVertexArrayState() { _currentVertexArrayState = _globalVertexArrayState.get(); }
/** disable the vertex, normal, color, tex coords, secondary color, fog coord and index arrays.*/
@@ -1780,7 +1790,8 @@ class OSG_EXPORT State : public Referenced
GraphicsContext* _graphicsContext;
unsigned int _contextID;
osg::ref_ptr<VertexArrayState> _currentVertexArrayState;
osg::ref_ptr<VertexArrayState> _globalVertexArrayState;
VertexArrayState* _currentVertexArrayState;
bool _shaderCompositionEnabled;
bool _shaderCompositionDirty;

View File

@@ -153,7 +153,7 @@ public:
public:
osg::GLBufferObject* getGLBufferObject(osg::Array* array);
// osg::GLBufferObject* getGLBufferObject(osg::Array* array);
osg::ref_ptr<osg::GLExtensions> _ext;

View File

@@ -629,18 +629,12 @@ void Drawable::draw(RenderInfo& renderInfo) const
_vertexArrayStateList[contextID] = vas = setUpVertexArrayState(renderInfo, true);
}
//state.pushVAO(localVAO);
osg::ref_ptr<VertexArrayState> previous_vas = state.getCurrentVertexArrayState();
state.setCurrentVertexArrayState(vas);
State::SetCurrentVertexArrayStateProxy setVASProxy(state, vas);
vas->bindVertexArrayObject();
drawInner(renderInfo);
// state.popVAO();
state.setCurrentVertexArrayState(previous_vas);
return;
}
#endif

View File

@@ -140,8 +140,7 @@ State::State():
_gpuTimestamp = 0;
_timestampBits = 0;
_currentVertexArrayState = 0;
}
State::~State()
@@ -986,8 +985,9 @@ void State::initializeExtensionProcs()
GLExtensions::Set(_contextID, _glExtensions.get());
#ifdef USE_VERTEXARRAYSTATE
_currentVertexArrayState = new VertexArrayState(_glExtensions.get());
_currentVertexArrayState->assignAllDispatchers();
_globalVertexArrayState = new VertexArrayState(_glExtensions.get());
_globalVertexArrayState->assignAllDispatchers();
setCurrentToGloabalVertexArrayState();
#endif
setGLExtensionFuncPtr(_glClientActiveTexture,"glClientActiveTexture","glClientActiveTextureARB");

View File

@@ -345,6 +345,7 @@ VertexArrayState::VertexArrayState(osg::GLExtensions* ext):
{
}
#if 0
osg::GLBufferObject* VertexArrayState::getGLBufferObject(osg::Array* array)
{
if (_ext->isBufferObjectSupported && array->getBufferObject())
@@ -356,6 +357,7 @@ osg::GLBufferObject* VertexArrayState::getGLBufferObject(osg::Array* array)
return 0;
}
}
#endif
void VertexArrayState::generateVretexArrayObject()
{