Fix issues with light of attached CAOs
This commit is contained in:
parent
4eacce5e2f
commit
1e0e85f82e
@ -54,6 +54,7 @@ public:
|
|||||||
virtual void removeFromScene(bool permanent){}
|
virtual void removeFromScene(bool permanent){}
|
||||||
// 0 <= light_at_pos <= LIGHT_SUN
|
// 0 <= light_at_pos <= LIGHT_SUN
|
||||||
virtual void updateLight(u8 light_at_pos){}
|
virtual void updateLight(u8 light_at_pos){}
|
||||||
|
virtual void updateLightNoCheck(u8 light_at_pos){}
|
||||||
virtual v3s16 getLightPosition(){return v3s16(0,0,0);}
|
virtual v3s16 getLightPosition(){return v3s16(0,0,0);}
|
||||||
virtual core::aabbox3d<f32>* getSelectionBox(){return NULL;}
|
virtual core::aabbox3d<f32>* getSelectionBox(){return NULL;}
|
||||||
virtual bool getCollisionBox(aabb3f *toset){return false;}
|
virtual bool getCollisionBox(aabb3f *toset){return false;}
|
||||||
|
@ -985,21 +985,39 @@ void GenericCAO::addToScene(scene::ISceneManager *smgr, ITextureSource *tsrc,
|
|||||||
|
|
||||||
void GenericCAO::updateLight(u8 light_at_pos)
|
void GenericCAO::updateLight(u8 light_at_pos)
|
||||||
{
|
{
|
||||||
u8 li = decode_light(light_at_pos);
|
// Don't update light of attached one
|
||||||
if(li != m_last_light)
|
if (getParent() != NULL) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
updateLightNoCheck(light_at_pos);
|
||||||
|
|
||||||
|
// Update light of all children
|
||||||
|
for (std::vector<u16>::size_type i = 0; i < m_children.size(); i++) {
|
||||||
|
ClientActiveObject *obj = m_env->getActiveObject(m_children[i]);
|
||||||
|
if (obj) {
|
||||||
|
obj->updateLightNoCheck(light_at_pos);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void GenericCAO::updateLightNoCheck(u8 light_at_pos)
|
||||||
{
|
{
|
||||||
|
u8 li = decode_light(light_at_pos);
|
||||||
|
if (li != m_last_light) {
|
||||||
m_last_light = li;
|
m_last_light = li;
|
||||||
video::SColor color(255,li,li,li);
|
video::SColor color(255,li,li,li);
|
||||||
if(m_meshnode)
|
if (m_meshnode) {
|
||||||
setMeshColor(m_meshnode->getMesh(), color);
|
setMeshColor(m_meshnode->getMesh(), color);
|
||||||
if(m_animated_meshnode)
|
} else if (m_animated_meshnode) {
|
||||||
setMeshColor(m_animated_meshnode->getMesh(), color);
|
setMeshColor(m_animated_meshnode->getMesh(), color);
|
||||||
if(m_wield_meshnode)
|
} else if (m_wield_meshnode) {
|
||||||
m_wield_meshnode->setColor(color);
|
m_wield_meshnode->setColor(color);
|
||||||
if(m_spritenode)
|
} else if (m_spritenode) {
|
||||||
m_spritenode->setColor(color);
|
m_spritenode->setColor(color);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
v3s16 GenericCAO::getLightPosition()
|
v3s16 GenericCAO::getLightPosition()
|
||||||
{
|
{
|
||||||
|
@ -178,6 +178,8 @@ public:
|
|||||||
|
|
||||||
void updateLight(u8 light_at_pos);
|
void updateLight(u8 light_at_pos);
|
||||||
|
|
||||||
|
void updateLightNoCheck(u8 light_at_pos);
|
||||||
|
|
||||||
v3s16 getLightPosition();
|
v3s16 getLightPosition();
|
||||||
|
|
||||||
void updateNodePos();
|
void updateNodePos();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user