+void GenericCAO::addToScene(scene::ISceneManager *smgr, ITextureSource *tsrc,
+ IrrlichtDevice *irr)
+{
+ m_smgr = smgr;
+ m_irr = irr;
+
+ if(m_meshnode != NULL || m_animated_meshnode != NULL || m_spritenode != NULL)
+ return;
+
+ m_visuals_expired = false;
+
+ if(!m_prop.is_visible)
+ return;
+
+ //video::IVideoDriver* driver = smgr->getVideoDriver();
+
+ if(m_prop.visual == "sprite")
+ {
+ infostream<<"GenericCAO::addToScene(): single_sprite"<<std::endl;
+ m_spritenode = smgr->addBillboardSceneNode(
+ NULL, v2f(1, 1), v3f(0,0,0), -1);
+ m_spritenode->grab();
+ m_spritenode->setMaterialTexture(0,
+ tsrc->getTexture("unknown_node.png"));
+ m_spritenode->setMaterialFlag(video::EMF_LIGHTING, false);
+ m_spritenode->setMaterialFlag(video::EMF_BILINEAR_FILTER, false);
+ m_spritenode->setMaterialType(video::EMT_TRANSPARENT_ALPHA_CHANNEL_REF);
+ m_spritenode->setMaterialFlag(video::EMF_FOG_ENABLE, true);
+ u8 li = m_last_light;
+ m_spritenode->setColor(video::SColor(255,li,li,li));
+ m_spritenode->setSize(m_prop.visual_size*BS);
+ {
+ const float txs = 1.0 / 1;
+ const float tys = 1.0 / 1;
+ setBillboardTextureMatrix(m_spritenode,
+ txs, tys, 0, 0);
+ }
+ }
+ else if(m_prop.visual == "upright_sprite") {
+ scene::SMesh *mesh = new scene::SMesh();
+ double dx = BS*m_prop.visual_size.X/2;
+ double dy = BS*m_prop.visual_size.Y/2;
+ { // Front
+ scene::IMeshBuffer *buf = new scene::SMeshBuffer();
+ u8 li = m_last_light;
+ video::SColor c(255,li,li,li);
+ video::S3DVertex vertices[4] =
+ {
+ video::S3DVertex(-dx,-dy,0, 0,0,0, c, 0,1),
+ video::S3DVertex(dx,-dy,0, 0,0,0, c, 1,1),
+ video::S3DVertex(dx,dy,0, 0,0,0, c, 1,0),
+ video::S3DVertex(-dx,dy,0, 0,0,0, c, 0,0),
+ };
+ u16 indices[] = {0,1,2,2,3,0};
+ buf->append(vertices, 4, indices, 6);
+ // Set material
+ buf->getMaterial().setFlag(video::EMF_LIGHTING, false);
+ buf->getMaterial().setFlag(video::EMF_BILINEAR_FILTER, false);
+ buf->getMaterial().setFlag(video::EMF_FOG_ENABLE, true);
+ buf->getMaterial().MaterialType = video::EMT_TRANSPARENT_ALPHA_CHANNEL;
+ // Add to mesh
+ mesh->addMeshBuffer(buf);
+ buf->drop();
+ }
+ { // Back
+ scene::IMeshBuffer *buf = new scene::SMeshBuffer();
+ u8 li = m_last_light;
+ video::SColor c(255,li,li,li);
+ video::S3DVertex vertices[4] =
+ {
+ video::S3DVertex(dx,-dy,0, 0,0,0, c, 1,1),
+ video::S3DVertex(-dx,-dy,0, 0,0,0, c, 0,1),
+ video::S3DVertex(-dx,dy,0, 0,0,0, c, 0,0),
+ video::S3DVertex(dx,dy,0, 0,0,0, c, 1,0),
+ };
+ u16 indices[] = {0,1,2,2,3,0};
+ buf->append(vertices, 4, indices, 6);
+ // Set material
+ buf->getMaterial().setFlag(video::EMF_LIGHTING, false);
+ buf->getMaterial().setFlag(video::EMF_BILINEAR_FILTER, false);
+ buf->getMaterial().setFlag(video::EMF_FOG_ENABLE, true);
+ buf->getMaterial().MaterialType = video::EMT_TRANSPARENT_ALPHA_CHANNEL_REF;
+ // Add to mesh
+ mesh->addMeshBuffer(buf);
+ buf->drop();
+ }
+ m_meshnode = smgr->addMeshSceneNode(mesh, NULL);
+ m_meshnode->grab();
+ mesh->drop();
+ // Set it to use the materials of the meshbuffers directly.
+ // This is needed for changing the texture in the future
+ m_meshnode->setReadOnlyMaterials(true);
+ }
+ else if(m_prop.visual == "cube") {
+ infostream<<"GenericCAO::addToScene(): cube"<<std::endl;
+ scene::IMesh *mesh = createCubeMesh(v3f(BS,BS,BS));
+ m_meshnode = smgr->addMeshSceneNode(mesh, NULL);
+ m_meshnode->grab();
+ mesh->drop();