Fix issues with light of attached CAOs

This commit is contained in:
RealBadAngel 2015-07-23 04:35:13 +02:00
parent 4eacce5e2f
commit 1e0e85f82e
3 changed files with 27 additions and 6 deletions

View File

@ -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;}

View File

@ -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()
{ {

View File

@ -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();