From 174dd828940acaf097f5b1e9cef4c1d0d4c42264 Mon Sep 17 00:00:00 2001 From: scrawl Date: Fri, 11 Mar 2016 15:42:14 +0100 Subject: [PATCH] Manually apply the osg::Light state Reduce the amount of virtual function calls. Don't use the osg::Light's lightNum. Don't set spotlight state that we're not using (yet). --- components/sceneutil/lightmanager.cpp | 21 +++++++++++++++++---- 1 file changed, 17 insertions(+), 4 deletions(-) diff --git a/components/sceneutil/lightmanager.cpp b/components/sceneutil/lightmanager.cpp index 04ff3b603..f7c0573a4 100644 --- a/components/sceneutil/lightmanager.cpp +++ b/components/sceneutil/lightmanager.cpp @@ -51,14 +51,27 @@ namespace SceneUtil state.applyModelViewMatrix(state.getInitialViewMatrix()); for (unsigned int i=0; isetLightNum(i+mIndex); - mLights[i]->apply(state); - } + applyLight((GLenum)((int)GL_LIGHT0 + i + mIndex), mLights[i].get()); state.applyModelViewMatrix(modelViewMatrix); } + void applyLight(GLenum lightNum, const osg::Light* light) const + { + glLightfv( lightNum, GL_AMBIENT, light->getAmbient().ptr() ); + glLightfv( lightNum, GL_DIFFUSE, light->getDiffuse().ptr() ); + glLightfv( lightNum, GL_SPECULAR, light->getSpecular().ptr() ); + glLightfv( lightNum, GL_POSITION, light->getPosition().ptr() ); + // TODO: enable this once spot lights are supported + // need to transform SPOT_DIRECTION by the world matrix? + //glLightfv( lightNum, GL_SPOT_DIRECTION, light->getDirection().ptr() ); + //glLightf ( lightNum, GL_SPOT_EXPONENT, light->getSpotExponent() ); + //glLightf ( lightNum, GL_SPOT_CUTOFF, light->getSpotCutoff() ); + glLightf ( lightNum, GL_CONSTANT_ATTENUATION, light->getConstantAttenuation() ); + glLightf ( lightNum, GL_LINEAR_ATTENUATION, light->getLinearAttenuation() ); + glLightf ( lightNum, GL_QUADRATIC_ATTENUATION, light->getQuadraticAttenuation() ); + } + private: unsigned int mIndex;