|
|
@ -2,7 +2,6 @@
|
|
|
|
|
|
|
|
|
|
|
|
#include <osg/Light>
|
|
|
|
#include <osg/Light>
|
|
|
|
#include <osg/Group>
|
|
|
|
#include <osg/Group>
|
|
|
|
#include <osg/ComputeBoundsVisitor>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#include <components/esm3/loadligh.hpp>
|
|
|
|
#include <components/esm3/loadligh.hpp>
|
|
|
|
#include <components/fallback/fallback.hpp>
|
|
|
|
#include <components/fallback/fallback.hpp>
|
|
|
@ -11,7 +10,6 @@
|
|
|
|
#include "lightcontroller.hpp"
|
|
|
|
#include "lightcontroller.hpp"
|
|
|
|
#include "util.hpp"
|
|
|
|
#include "util.hpp"
|
|
|
|
#include "visitor.hpp"
|
|
|
|
#include "visitor.hpp"
|
|
|
|
#include "positionattitudetransform.hpp"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
namespace SceneUtil
|
|
|
|
namespace SceneUtil
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -58,34 +56,12 @@ namespace SceneUtil
|
|
|
|
light->setQuadraticAttenuation(quadraticAttenuation);
|
|
|
|
light->setQuadraticAttenuation(quadraticAttenuation);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
osg::ref_ptr<LightSource> addLight(osg::Group* node, const ESM::Light* esmLight, unsigned int partsysMask, unsigned int lightMask, bool isExterior)
|
|
|
|
osg::ref_ptr<LightSource> addLight(osg::Group* node, const ESM::Light* esmLight, unsigned int lightMask, bool isExterior)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
SceneUtil::FindByNameVisitor visitor("AttachLight");
|
|
|
|
SceneUtil::FindByNameVisitor visitor("AttachLight");
|
|
|
|
node->accept(visitor);
|
|
|
|
node->accept(visitor);
|
|
|
|
|
|
|
|
|
|
|
|
osg::Group* attachTo = nullptr;
|
|
|
|
osg::Group* attachTo = visitor.mFoundNode ? visitor.mFoundNode : node;
|
|
|
|
if (visitor.mFoundNode)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
attachTo = visitor.mFoundNode;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
osg::ComputeBoundsVisitor computeBound;
|
|
|
|
|
|
|
|
computeBound.setTraversalMask(~partsysMask);
|
|
|
|
|
|
|
|
// We want the bounds of all children of the node, ignoring the node's local transformation
|
|
|
|
|
|
|
|
// So do a traverse(), not accept()
|
|
|
|
|
|
|
|
computeBound.traverse(*node);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// PositionAttitudeTransform seems to be slightly faster than MatrixTransform
|
|
|
|
|
|
|
|
osg::ref_ptr<SceneUtil::PositionAttitudeTransform> trans(new SceneUtil::PositionAttitudeTransform);
|
|
|
|
|
|
|
|
trans->setPosition(computeBound.getBoundingBox().center());
|
|
|
|
|
|
|
|
trans->setNodeMask(lightMask);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
node->addChild(trans);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
attachTo = trans;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
osg::ref_ptr<LightSource> lightSource = createLightSource(esmLight, lightMask, isExterior, osg::Vec4f(0,0,0,1));
|
|
|
|
osg::ref_ptr<LightSource> lightSource = createLightSource(esmLight, lightMask, isExterior, osg::Vec4f(0,0,0,1));
|
|
|
|
attachTo->addChild(lightSource);
|
|
|
|
attachTo->addChild(lightSource);
|
|
|
|
return lightSource;
|
|
|
|
return lightSource;
|
|
|
|