Fixed coding style issues (same should be done with speedweight objects).

This commit is contained in:
hiker 2017-01-25 21:55:16 +11:00
parent ecc4e30cbe
commit 7ad0a0cf69
2 changed files with 70 additions and 35 deletions

View File

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

View File

@ -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.