Implemented lighter weight setting of the CurrentVertexArrayState and introduced GlobalVertexArrayState.
This commit is contained in:
@@ -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;
|
||||
|
||||
@@ -153,7 +153,7 @@ public:
|
||||
public:
|
||||
|
||||
|
||||
osg::GLBufferObject* getGLBufferObject(osg::Array* array);
|
||||
// osg::GLBufferObject* getGLBufferObject(osg::Array* array);
|
||||
|
||||
osg::ref_ptr<osg::GLExtensions> _ext;
|
||||
|
||||
|
||||
@@ -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
|
||||
|
||||
@@ -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");
|
||||
|
||||
@@ -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()
|
||||
{
|
||||
|
||||
Reference in New Issue
Block a user