Fixed coding style issues (same should be done with speedweight objects).
This commit is contained in:
parent
ecc4e30cbe
commit
7ad0a0cf69
@ -273,17 +273,17 @@ KartModel::~KartModel()
|
|||||||
for (size_t i = 0; i < m_headlight_objects.size(); i++)
|
for (size_t i = 0; i < m_headlight_objects.size(); i++)
|
||||||
{
|
{
|
||||||
HeadlightObject& obj = m_headlight_objects[i];
|
HeadlightObject& obj = m_headlight_objects[i];
|
||||||
obj.m_node = NULL;
|
obj.setNode(NULL);
|
||||||
if (obj.m_node)
|
if (obj.getNode())
|
||||||
{
|
{
|
||||||
// Master KartModels should never have a speed weighted object attached.
|
// Master KartModels should never have a headlight attached.
|
||||||
assert(!m_is_master);
|
assert(!m_is_master);
|
||||||
obj.m_node->drop();
|
obj.getNode()->drop();
|
||||||
}
|
}
|
||||||
if (m_is_master && obj.m_model)
|
if (m_is_master && obj.getModel())
|
||||||
{
|
{
|
||||||
irr_driver->dropAllTextures(obj.m_model);
|
irr_driver->dropAllTextures(obj.getModel());
|
||||||
irr_driver->removeMeshFromCache(obj.m_model);
|
irr_driver->removeMeshFromCache(obj.getModel());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -368,8 +368,8 @@ KartModel* KartModel::makeCopy(KartRenderType krt)
|
|||||||
km->m_headlight_objects.resize(m_headlight_objects.size());
|
km->m_headlight_objects.resize(m_headlight_objects.size());
|
||||||
for (size_t i = 0; i<m_headlight_objects.size(); i++)
|
for (size_t i = 0; i<m_headlight_objects.size(); i++)
|
||||||
{
|
{
|
||||||
// Master should not have any speed weighted nodes.
|
// Master should not have any headlight nodes.
|
||||||
assert(!m_headlight_objects[i].m_node);
|
assert(!m_headlight_objects[i].getNode());
|
||||||
km->m_headlight_objects[i] = m_headlight_objects[i];
|
km->m_headlight_objects[i] = m_headlight_objects[i];
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -448,8 +448,8 @@ scene::ISceneNode* KartModel::attachModel(bool animated_models, bool always_anim
|
|||||||
|
|
||||||
for (size_t i = 0; i<m_headlight_objects.size(); i++)
|
for (size_t i = 0; i<m_headlight_objects.size(); i++)
|
||||||
{
|
{
|
||||||
if (!m_headlight_objects[i].m_node) continue;
|
if (!m_headlight_objects[i].getNode()) continue;
|
||||||
m_headlight_objects[i].m_node->setParent(lod_node);
|
m_headlight_objects[i].getNode()->setParent(lod_node);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef SERVER_ONLY
|
#ifndef SERVER_ONLY
|
||||||
@ -534,16 +534,19 @@ scene::ISceneNode* KartModel::attachModel(bool animated_models, bool always_anim
|
|||||||
{
|
{
|
||||||
HeadlightObject& obj = m_headlight_objects[i];
|
HeadlightObject& obj = m_headlight_objects[i];
|
||||||
|
|
||||||
obj.m_node = NULL;
|
obj.setNode(NULL);
|
||||||
if (obj.m_model)
|
if (obj.getModel())
|
||||||
{
|
{
|
||||||
obj.m_node = irr_driver->addMesh(obj.m_model, "kart_headlight", node, getRenderInfo());
|
scene::ISceneNode *new_node =
|
||||||
obj.m_node->grab();
|
irr_driver->addMesh(obj.getModel(), "kart_headlight",
|
||||||
obj.m_node->setPosition(obj.getPosition());
|
node, getRenderInfo() );
|
||||||
|
|
||||||
|
new_node->grab();
|
||||||
|
obj.setNode(new_node);
|
||||||
|
|
||||||
Track* track = Track::getCurrentTrack();
|
Track* track = Track::getCurrentTrack();
|
||||||
if (track == NULL || track->getIsDuringDay())
|
if (track == NULL || track->getIsDuringDay())
|
||||||
obj.m_node->setVisible(false);
|
obj.getNode()->setVisible(false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -646,8 +649,8 @@ bool KartModel::loadModels(const KartProperties &kart_properties)
|
|||||||
{
|
{
|
||||||
HeadlightObject& obj = m_headlight_objects[i];
|
HeadlightObject& obj = m_headlight_objects[i];
|
||||||
std::string full_name = kart_properties.getKartDir() + obj.getFilename();
|
std::string full_name = kart_properties.getKartDir() + obj.getFilename();
|
||||||
obj.m_model = irr_driver->getMesh(full_name);
|
obj.setModel(irr_driver->getMesh(full_name));
|
||||||
irr_driver->grabAllTextures(obj.m_model);
|
irr_driver->grabAllTextures(obj.getModel());
|
||||||
}
|
}
|
||||||
|
|
||||||
Vec3 size = kart_max-kart_min;
|
Vec3 size = kart_max-kart_min;
|
||||||
@ -722,7 +725,8 @@ void KartModel::loadNitroEmitterInfo(const XMLNode &node,
|
|||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
/** Loads a single speed weighted node. */
|
/** Loads a single speed weighted node. */
|
||||||
void KartModel::loadSpeedWeightedInfo(const XMLNode* speed_weighted_node, const SpeedWeightedObject::Properties& fallback_properties)
|
void KartModel::loadSpeedWeightedInfo(const XMLNode* speed_weighted_node,
|
||||||
|
const SpeedWeightedObject::Properties& fallback_properties)
|
||||||
{
|
{
|
||||||
SpeedWeightedObject obj;
|
SpeedWeightedObject obj;
|
||||||
obj.m_properties = fallback_properties;
|
obj.m_properties = fallback_properties;
|
||||||
@ -778,7 +782,7 @@ void KartModel::loadHeadlights(const XMLNode &node)
|
|||||||
Log::warn("KartModel", "Unknown XML node in the headlights section");
|
Log::warn("KartModel", "Unknown XML node in the headlights section");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
} // loadHeadlights
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
/** Resets the kart model. It stops animation from being played and resets
|
/** Resets the kart model. It stops animation from being played and resets
|
||||||
|
@ -84,33 +84,64 @@ struct SpeedWeightedObject
|
|||||||
};
|
};
|
||||||
typedef std::vector<SpeedWeightedObject> SpeedWeightedObjectList;
|
typedef std::vector<SpeedWeightedObject> SpeedWeightedObjectList;
|
||||||
|
|
||||||
|
// ============================================================================
|
||||||
|
/** A class to store the headlights of a kart.
|
||||||
|
*/
|
||||||
class HeadlightObject
|
class HeadlightObject
|
||||||
{
|
{
|
||||||
|
private:
|
||||||
|
/** The filename of the headlight model. */
|
||||||
std::string m_filename;
|
std::string m_filename;
|
||||||
|
/** The position relative to the parent kart scene node where the
|
||||||
|
* headlight mesh is attached to. */
|
||||||
core::vector3df m_position;
|
core::vector3df m_position;
|
||||||
|
/** The mesh for the headlight. */
|
||||||
|
scene::IMesh* m_model;
|
||||||
|
/** The scene node of the headlight. */
|
||||||
|
scene::ISceneNode* m_node;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
scene::IMesh* m_model;
|
|
||||||
scene::ISceneNode* m_node;
|
|
||||||
|
|
||||||
HeadlightObject()
|
HeadlightObject()
|
||||||
{
|
{
|
||||||
m_model = NULL;
|
m_model = NULL;
|
||||||
m_node = NULL;
|
m_node = NULL;
|
||||||
}
|
m_filename = "";
|
||||||
|
m_position.set(0, 0, 0);
|
||||||
HeadlightObject(const std::string& filename, core::vector3df pos)
|
} // HeadlightObject
|
||||||
|
// ------------------------------------------------------------------------
|
||||||
|
HeadlightObject(const std::string& filename, core::vector3df &pos)
|
||||||
{
|
{
|
||||||
m_filename = filename;
|
m_filename = filename;
|
||||||
m_position = pos;
|
m_position = pos;
|
||||||
m_model = NULL;
|
m_model = NULL;
|
||||||
m_node = NULL;
|
m_node = NULL;
|
||||||
}
|
} // HeadlightObjects
|
||||||
|
// ------------------------------------------------------------------------
|
||||||
const std::string& getFilename() const { return m_filename; }
|
const std::string& getFilename() const { return m_filename; }
|
||||||
const core::vector3df getPosition() const { return m_position; }
|
// ------------------------------------------------------------------------
|
||||||
};
|
/** Sets the mesh for this headlight object. */
|
||||||
|
void setModel(scene::IMesh *mesh) { m_model = mesh; }
|
||||||
|
// ------------------------------------------------------------------------
|
||||||
|
/** Sets the node of the headlight, and (if not NULL) also sets the
|
||||||
|
* position of this scene node to be the position of the headlight. */
|
||||||
|
void setNode(scene::ISceneNode *node)
|
||||||
|
{
|
||||||
|
m_node = node;
|
||||||
|
if (m_node) m_node->setPosition(m_position);
|
||||||
|
} // setNode
|
||||||
|
// ------------------------------------------------------------------------
|
||||||
|
const scene::ISceneNode *getNode() const { return m_node; }
|
||||||
|
// ------------------------------------------------------------------------
|
||||||
|
scene::ISceneNode *getNode() { return m_node; }
|
||||||
|
// ------------------------------------------------------------------------
|
||||||
|
const scene::IMesh *getModel() const { return m_model; }
|
||||||
|
// ------------------------------------------------------------------------
|
||||||
|
scene::IMesh *getModel() { return m_model; }
|
||||||
|
// ------------------------------------------------------------------------
|
||||||
|
}; // class HeadlightObject
|
||||||
|
|
||||||
|
// ============================================================================
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* \brief This class stores a 3D kart model.
|
* \brief This class stores a 3D kart model.
|
||||||
|
Loading…
Reference in New Issue
Block a user