Move RenderInfo class to GE

This commit is contained in:
Benau 2022-09-05 16:22:04 +08:00
parent 647988ad30
commit 2d0c945dd8
38 changed files with 139 additions and 135 deletions

View File

@ -0,0 +1,58 @@
/* ==========================================================================
* Copyright (c) 2022 SuperTuxKart-Team
*
* Permission is hereby granted, free of charge, to any person obtaining a
* copy of this software and associated documentation files (the
* "Software"), to deal in the Software without restriction, including
* without limitation the rights to use, copy, modify, merge, publish,
* distribute, sublicense, and/or sell copies of the Software, and to permit
* persons to whom the Software is furnished to do so, subject to the
* following conditions:
*
* The above copyright notice and this permission notice shall be included
* in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
* NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
* DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
* OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
* USE OR OTHER DEALINGS IN THE SOFTWARE.
* ==========================================================================
*/
#ifndef HEADER_GE_RENDER_INFO_HPP
#define HEADER_GE_RENDER_INFO_HPP
namespace GE
{
class GERenderInfo
{
private:
float m_hue;
bool m_transparent;
public:
// ------------------------------------------------------------------------
GERenderInfo(float hue = 0.0f, bool transparent = false)
{
m_hue = hue;
m_transparent = transparent;
}
// ------------------------------------------------------------------------
void setHue(float hue) { m_hue = hue; }
// ------------------------------------------------------------------------
void setTransparent(bool transparent) { m_transparent = transparent; }
// ------------------------------------------------------------------------
float getHue() const { return m_hue; }
// ------------------------------------------------------------------------
bool isTransparent() const { return m_transparent; }
}; // GERenderInfo
} // namespace GE
#endif

View File

@ -1399,7 +1399,7 @@ scene::IParticleSystemSceneNode *IrrDriver::addParticleNode(bool default_emitter
scene::ISceneNode *IrrDriver::addMesh(scene::IMesh *mesh, scene::ISceneNode *IrrDriver::addMesh(scene::IMesh *mesh,
const std::string& debug_name, const std::string& debug_name,
scene::ISceneNode *parent, scene::ISceneNode *parent,
std::shared_ptr<RenderInfo> render_info) std::shared_ptr<GE::GERenderInfo> render_info)
{ {
#ifdef SERVER_ONLY #ifdef SERVER_ONLY
return m_scene_manager->addMeshSceneNode(mesh, parent); return m_scene_manager->addMeshSceneNode(mesh, parent);
@ -1616,7 +1616,7 @@ void IrrDriver::removeTexture(video::ITexture *t)
*/ */
scene::IAnimatedMeshSceneNode *IrrDriver::addAnimatedMesh(scene::IAnimatedMesh *mesh, scene::IAnimatedMeshSceneNode *IrrDriver::addAnimatedMesh(scene::IAnimatedMesh *mesh,
const std::string& debug_name, scene::ISceneNode* parent, const std::string& debug_name, scene::ISceneNode* parent,
std::shared_ptr<RenderInfo> render_info) std::shared_ptr<GE::GERenderInfo> render_info)
{ {
scene::IAnimatedMeshSceneNode* node; scene::IAnimatedMeshSceneNode* node;
#ifndef SERVER_ONLY #ifndef SERVER_ONLY

View File

@ -68,7 +68,7 @@ class Camera;
class FrameBuffer; class FrameBuffer;
class LightNode; class LightNode;
class PerCameraNode; class PerCameraNode;
class RenderInfo; namespace GE { class GERenderInfo; }
class RenderTarget; class RenderTarget;
struct SHCoefficients; struct SHCoefficients;
@ -235,7 +235,7 @@ public:
scene::ISceneNode* addMesh(scene::IMesh *mesh, scene::ISceneNode* addMesh(scene::IMesh *mesh,
const std::string& debug_name, const std::string& debug_name,
scene::ISceneNode *parent = NULL, scene::ISceneNode *parent = NULL,
std::shared_ptr<RenderInfo> render_info = nullptr); std::shared_ptr<GE::GERenderInfo> render_info = nullptr);
PerCameraNode *addPerCameraNode(scene::ISceneNode* node, PerCameraNode *addPerCameraNode(scene::ISceneNode* node,
scene::ICameraSceneNode* cam, scene::ICameraSceneNode* cam,
scene::ISceneNode *parent = NULL); scene::ISceneNode *parent = NULL);
@ -254,7 +254,7 @@ public:
*addAnimatedMesh(scene::IAnimatedMesh *mesh, *addAnimatedMesh(scene::IAnimatedMesh *mesh,
const std::string& debug_name, const std::string& debug_name,
scene::ISceneNode* parent = NULL, scene::ISceneNode* parent = NULL,
std::shared_ptr<RenderInfo> render_info = nullptr); std::shared_ptr<GE::GERenderInfo> render_info = nullptr);
scene::ICameraSceneNode scene::ICameraSceneNode
*addCameraSceneNode(); *addCameraSceneNode();
Camera *addCamera(unsigned int index, AbstractKart *kart); Camera *addCamera(unsigned int index, AbstractKart *kart);

View File

@ -1,54 +0,0 @@
//
// SuperTuxKart - a fun racing game with go-kart
// Copyright (C) 2016 SuperTuxKart-Team
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License
// as published by the Free Software Foundation; either version 3
// of the License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
#ifndef HEADER_RENDER_INFO_HPP
#define HEADER_RENDER_INFO_HPP
#include "utils/no_copy.hpp"
/**
* \ingroup graphics
*/
class RenderInfo : public NoCopy
{
private:
float m_hue;
bool m_transparent;
public:
// ------------------------------------------------------------------------
RenderInfo(float hue = 0.0f, bool transparent = false)
{
m_hue = hue;
m_transparent = transparent;
}
// ------------------------------------------------------------------------
void setHue(float hue) { m_hue = hue; }
// ------------------------------------------------------------------------
void setTransparent(bool transparent) { m_transparent = transparent; }
// ------------------------------------------------------------------------
float getHue() const { return m_hue; }
// ------------------------------------------------------------------------
bool isTransparent() const { return m_transparent; }
}; // RenderInfo
#endif
/* EOF */

View File

@ -28,7 +28,7 @@
#include "graphics/shared_gpu_objects.hpp" #include "graphics/shared_gpu_objects.hpp"
#include "graphics/shader_based_renderer.hpp" #include "graphics/shader_based_renderer.hpp"
#include "graphics/post_processing.hpp" #include "graphics/post_processing.hpp"
#include "graphics/render_info.hpp" #include <ge_render_info.hpp>
#include "graphics/rtts.hpp" #include "graphics/rtts.hpp"
#include "graphics/shaders.hpp" #include "graphics/shaders.hpp"
#include "graphics/sp/sp_dynamic_draw_call.hpp" #include "graphics/sp/sp_dynamic_draw_call.hpp"

View File

@ -24,7 +24,7 @@
#include "graphics/graphics_restrictions.hpp" #include "graphics/graphics_restrictions.hpp"
#include "graphics/irr_driver.hpp" #include "graphics/irr_driver.hpp"
#include "graphics/material.hpp" #include "graphics/material.hpp"
#include "graphics/render_info.hpp" #include <ge_render_info.hpp>
#include "../../../lib/irrlicht/source/Irrlicht/CBoneSceneNode.h" #include "../../../lib/irrlicht/source/Irrlicht/CBoneSceneNode.h"
#include <algorithm> #include <algorithm>
@ -39,7 +39,7 @@ SPMeshNode::SPMeshNode(IAnimatedMesh* mesh, ISceneNode* parent,
const core::vector3df& position, const core::vector3df& position,
const core::vector3df& rotation, const core::vector3df& rotation,
const core::vector3df& scale, const core::vector3df& scale,
std::shared_ptr<RenderInfo> render_info) std::shared_ptr<GE::GERenderInfo> render_info)
: CAnimatedMeshSceneNode(mesh, parent, mgr, id, position, rotation, : CAnimatedMeshSceneNode(mesh, parent, mgr, id, position, rotation,
scale) scale)
{ {

View File

@ -28,7 +28,7 @@
using namespace irr; using namespace irr;
using namespace scene; using namespace scene;
class RenderInfo; namespace GE { class GERenderInfo; }
namespace SP namespace SP
{ {
@ -38,9 +38,9 @@ class SPShader;
class SPMeshNode : public irr::scene::CAnimatedMeshSceneNode class SPMeshNode : public irr::scene::CAnimatedMeshSceneNode
{ {
private: private:
std::vector<std::shared_ptr<RenderInfo> > m_render_info; std::vector<std::shared_ptr<GE::GERenderInfo> > m_render_info;
std::shared_ptr<RenderInfo> m_first_render_info; std::shared_ptr<GE::GERenderInfo> m_first_render_info;
std::unordered_map<std::string, IBoneSceneNode*> m_joint_nodes; std::unordered_map<std::string, IBoneSceneNode*> m_joint_nodes;
@ -80,7 +80,7 @@ public:
const core::vector3df& position = core::vector3df(), const core::vector3df& position = core::vector3df(),
const core::vector3df& rotation = core::vector3df(), const core::vector3df& rotation = core::vector3df(),
const core::vector3df& scale = core::vector3df(1, 1, 1), const core::vector3df& scale = core::vector3df(1, 1, 1),
std::shared_ptr<RenderInfo> render_info = nullptr); std::shared_ptr<GE::GERenderInfo> render_info = nullptr);
// ------------------------------------------------------------------------ // ------------------------------------------------------------------------
~SPMeshNode(); ~SPMeshNode();
// ------------------------------------------------------------------------ // ------------------------------------------------------------------------
@ -131,7 +131,7 @@ public:
const core::matrix4* getSkinningMatrices() const const core::matrix4* getSkinningMatrices() const
{ return m_skinning_matrices.data(); } { return m_skinning_matrices.data(); }
// ------------------------------------------------------------------------ // ------------------------------------------------------------------------
RenderInfo* getRenderInfo(unsigned mb_id) const GE::GERenderInfo* getRenderInfo(unsigned mb_id) const
{ {
if (m_render_info.size() > mb_id && m_render_info[mb_id].get()) if (m_render_info.size() > mb_id && m_render_info[mb_id].get())
{ {
@ -140,7 +140,7 @@ public:
return NULL; return NULL;
} }
// ------------------------------------------------------------------------ // ------------------------------------------------------------------------
void resetFirstRenderInfo(std::shared_ptr<RenderInfo> ri) void resetFirstRenderInfo(std::shared_ptr<GE::GERenderInfo> ri)
{ {
m_render_info.clear(); m_render_info.clear();
m_first_render_info = ri; m_first_render_info = ri;

View File

@ -17,7 +17,7 @@
#include "config/user_config.hpp" #include "config/user_config.hpp"
#include "graphics/central_settings.hpp" #include "graphics/central_settings.hpp"
#include "graphics/render_info.hpp" #include <ge_render_info.hpp>
#include "guiengine/engine.hpp" #include "guiengine/engine.hpp"
#include "guiengine/widgets/model_view_widget.hpp" #include "guiengine/widgets/model_view_widget.hpp"
#include "graphics/irr_driver.hpp" #include "graphics/irr_driver.hpp"
@ -49,7 +49,7 @@ m_rtt_size(rtt_size)
m_type = WTYPE_MODEL_VIEW; m_type = WTYPE_MODEL_VIEW;
m_render_target = NULL; m_render_target = NULL;
m_rotation_mode = ROTATE_OFF; m_rotation_mode = ROTATE_OFF;
m_render_info = std::make_shared<RenderInfo>(); m_render_info = std::make_shared<GE::GERenderInfo>();
m_angle = 0; m_angle = 0;
// so that the base class doesn't complain there is no icon defined // so that the base class doesn't complain there is no icon defined

View File

@ -28,7 +28,7 @@
#include "utils/leak_check.hpp" #include "utils/leak_check.hpp"
#include "utils/ptr_vector.hpp" #include "utils/ptr_vector.hpp"
class RenderInfo; namespace GE { class GERenderInfo; }
namespace GUIEngine namespace GUIEngine
{ {
@ -63,7 +63,7 @@ namespace GUIEngine
scene::ISceneNode *m_light; scene::ISceneNode *m_light;
std::shared_ptr<RenderInfo> m_render_info; std::shared_ptr<GE::GERenderInfo> m_render_info;
unsigned m_rtt_size; unsigned m_rtt_size;
@ -107,7 +107,7 @@ namespace GUIEngine
void drawRTTScene(const irr::core::rect<s32>& dest_rect) const; void drawRTTScene(const irr::core::rect<s32>& dest_rect) const;
std::shared_ptr<RenderInfo> getModelViewRenderInfo() { return m_render_info; } std::shared_ptr<GE::GERenderInfo> getModelViewRenderInfo() { return m_render_info; }
}; };
} }

View File

@ -21,7 +21,7 @@
#include "audio/sfx_manager.hpp" #include "audio/sfx_manager.hpp"
#include "config/player_manager.hpp" #include "config/player_manager.hpp"
#include "config/user_config.hpp" #include "config/user_config.hpp"
#include "graphics/render_info.hpp" #include <ge_render_info.hpp>
#include "guiengine/widgets/kart_stats_widget.hpp" #include "guiengine/widgets/kart_stats_widget.hpp"
#include "guiengine/widgets/model_view_widget.hpp" #include "guiengine/widgets/model_view_widget.hpp"
#include "guiengine/widgets/player_name_spinner.hpp" #include "guiengine/widgets/player_name_spinner.hpp"

View File

@ -26,7 +26,7 @@
#include "config/user_config.hpp" #include "config/user_config.hpp"
#include "graphics/explosion.hpp" #include "graphics/explosion.hpp"
#include "graphics/irr_driver.hpp" #include "graphics/irr_driver.hpp"
#include "graphics/render_info.hpp" #include <ge_render_info.hpp>
#include "guiengine/engine.hpp" #include "guiengine/engine.hpp"
#include "items/attachment_manager.hpp" #include "items/attachment_manager.hpp"
#include "items/item_manager.hpp" #include "items/item_manager.hpp"
@ -68,7 +68,7 @@ Attachment::Attachment(AbstractKart* kart)
if (kart->isGhostKart()) if (kart->isGhostKart())
m_node = irr_driver->addAnimatedMesh( m_node = irr_driver->addAnimatedMesh(
attachment_manager->getMesh(Attachment::ATTACH_BOMB), "bomb", attachment_manager->getMesh(Attachment::ATTACH_BOMB), "bomb",
NULL, std::make_shared<RenderInfo>(0.0f, true)); NULL, std::make_shared<GE::GERenderInfo>(0.0f, true));
else else
m_node = irr_driver->addAnimatedMesh( m_node = irr_driver->addAnimatedMesh(
attachment_manager->getMesh(Attachment::ATTACH_BOMB), "bomb"); attachment_manager->getMesh(Attachment::ATTACH_BOMB), "bomb");

View File

@ -42,7 +42,7 @@ AbstractKart::AbstractKart(const std::string& ident,
int world_kart_id, int position, int world_kart_id, int position,
const btTransform& init_transform, const btTransform& init_transform,
HandicapLevel handicap, HandicapLevel handicap,
std::shared_ptr<RenderInfo> ri) std::shared_ptr<GE::GERenderInfo> ri)
: Moveable() : Moveable()
{ {
m_world_kart_id = world_kart_id; m_world_kart_id = world_kart_id;
@ -78,7 +78,7 @@ void AbstractKart::reset()
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
void AbstractKart::loadKartProperties(const std::string& new_ident, void AbstractKart::loadKartProperties(const std::string& new_ident,
HandicapLevel handicap, HandicapLevel handicap,
std::shared_ptr<RenderInfo> ri) std::shared_ptr<GE::GERenderInfo> ri)
{ {
m_kart_properties.reset(new KartProperties()); m_kart_properties.reset(new KartProperties());
const KartProperties* kp = kart_properties_manager->getKart(new_ident); const KartProperties* kp = kart_properties_manager->getKart(new_ident);
@ -149,7 +149,7 @@ void AbstractKart::loadKartProperties(const std::string& new_ident,
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
void AbstractKart::changeKart(const std::string& new_ident, void AbstractKart::changeKart(const std::string& new_ident,
HandicapLevel handicap, HandicapLevel handicap,
std::shared_ptr<RenderInfo> ri) std::shared_ptr<GE::GERenderInfo> ri)
{ {
// Reset previous kart (including delete old animation above) // Reset previous kart (including delete old animation above)
reset(); reset();

View File

@ -46,7 +46,7 @@ class KartModel;
class KartProperties; class KartProperties;
class Material; class Material;
class Powerup; class Powerup;
class RenderInfo; namespace GE { class GERenderInfo; }
class SFXBuffer; class SFXBuffer;
class Skidding; class Skidding;
class SlipStream; class SlipStream;
@ -81,7 +81,7 @@ private:
// ------------------------------------------------------------------------ // ------------------------------------------------------------------------
void loadKartProperties(const std::string& new_ident, void loadKartProperties(const std::string& new_ident,
HandicapLevel handicap, HandicapLevel handicap,
std::shared_ptr<RenderInfo> ri); std::shared_ptr<GE::GERenderInfo> ri);
protected: protected:
btTransform m_starting_transform; btTransform m_starting_transform;
@ -114,7 +114,7 @@ public:
int world_kart_id, int world_kart_id,
int position, const btTransform& init_transform, int position, const btTransform& init_transform,
HandicapLevel handicap, HandicapLevel handicap,
std::shared_ptr<RenderInfo> ri); std::shared_ptr<GE::GERenderInfo> ri);
virtual ~AbstractKart(); virtual ~AbstractKart();
// ------------------------------------------------------------------------ // ------------------------------------------------------------------------
/** Returns a name to be displayed for this kart. */ /** Returns a name to be displayed for this kart. */
@ -144,7 +144,7 @@ public:
/** Change to new kart instancely (used in network live join). */ /** Change to new kart instancely (used in network live join). */
virtual void changeKart(const std::string& new_ident, virtual void changeKart(const std::string& new_ident,
HandicapLevel handicap, HandicapLevel handicap,
std::shared_ptr<RenderInfo> ri); std::shared_ptr<GE::GERenderInfo> ri);
// ======================================================================== // ========================================================================
// Access to the handicap. // Access to the handicap.
// ------------------------------------------------------------------------ // ------------------------------------------------------------------------

View File

@ -23,7 +23,7 @@
#include "karts/kart_gfx.hpp" #include "karts/kart_gfx.hpp"
#include "karts/kart_model.hpp" #include "karts/kart_model.hpp"
#include "graphics/irr_driver.hpp" #include "graphics/irr_driver.hpp"
#include "graphics/render_info.hpp" #include <ge_render_info.hpp>
#include "modes/easter_egg_hunt.hpp" #include "modes/easter_egg_hunt.hpp"
#include "modes/linear_world.hpp" #include "modes/linear_world.hpp"
#include "modes/world.hpp" #include "modes/world.hpp"
@ -38,7 +38,7 @@ GhostKart::GhostKart(const std::string& ident, unsigned int world_kart_id,
: Kart(ident, world_kart_id, : Kart(ident, world_kart_id,
position, btTransform(btQuaternion(0, 0, 0, 1)), position, btTransform(btQuaternion(0, 0, 0, 1)),
HANDICAP_NONE, HANDICAP_NONE,
std::make_shared<RenderInfo>(color_hue, true/*transparent*/)), std::make_shared<GE::GERenderInfo>(color_hue, true/*transparent*/)),
m_replay_data(rd) m_replay_data(rd)
{ {
} // GhostKart } // GhostKart

View File

@ -112,7 +112,7 @@
*/ */
Kart::Kart (const std::string& ident, unsigned int world_kart_id, Kart::Kart (const std::string& ident, unsigned int world_kart_id,
int position, const btTransform& init_transform, int position, const btTransform& init_transform,
HandicapLevel handicap, std::shared_ptr<RenderInfo> ri) HandicapLevel handicap, std::shared_ptr<GE::GERenderInfo> ri)
: AbstractKart(ident, world_kart_id, position, init_transform, : AbstractKart(ident, world_kart_id, position, init_transform,
handicap, ri) handicap, ri)
@ -223,7 +223,7 @@ void Kart::initSound()
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
void Kart::changeKart(const std::string& new_ident, void Kart::changeKart(const std::string& new_ident,
HandicapLevel handicap, HandicapLevel handicap,
std::shared_ptr<RenderInfo> ri) std::shared_ptr<GE::GERenderInfo> ri)
{ {
AbstractKart::changeKart(new_ident, handicap, ri); AbstractKart::changeKart(new_ident, handicap, ri);
m_kart_model->setKart(this); m_kart_model->setKart(this);

View File

@ -294,7 +294,7 @@ public:
Kart(const std::string& ident, unsigned int world_kart_id, Kart(const std::string& ident, unsigned int world_kart_id,
int position, const btTransform& init_transform, int position, const btTransform& init_transform,
HandicapLevel handicap, HandicapLevel handicap,
std::shared_ptr<RenderInfo> ri); std::shared_ptr<GE::GERenderInfo> ri);
virtual ~Kart(); virtual ~Kart();
virtual void init(RaceManager::KartType type) OVERRIDE; virtual void init(RaceManager::KartType type) OVERRIDE;
virtual void kartIsInRestNow() OVERRIDE; virtual void kartIsInRestNow() OVERRIDE;
@ -338,7 +338,7 @@ public:
virtual void setXYZ(const Vec3& a) OVERRIDE; virtual void setXYZ(const Vec3& a) OVERRIDE;
virtual void changeKart(const std::string& new_ident, virtual void changeKart(const std::string& new_ident,
HandicapLevel handicap, HandicapLevel handicap,
std::shared_ptr<RenderInfo> ri) OVERRIDE; std::shared_ptr<GE::GERenderInfo> ri) OVERRIDE;
// ======================================================================================== // ========================================================================================
// SPEED and speed-boost related functions // SPEED and speed-boost related functions

View File

@ -318,7 +318,7 @@ KartModel::~KartModel()
* It is also marked not to be a master copy, so attachModel can be called * It is also marked not to be a master copy, so attachModel can be called
* for this instance. * for this instance.
*/ */
KartModel* KartModel::makeCopy(std::shared_ptr<RenderInfo> ri) KartModel* KartModel::makeCopy(std::shared_ptr<GE::GERenderInfo> ri)
{ {
// Make sure that we are copying from a master objects, and // Make sure that we are copying from a master objects, and
// that there is indeed no animated node defined here ... // that there is indeed no animated node defined here ...
@ -1257,7 +1257,7 @@ void KartModel::resetVisualWheelPosition()
} // resetVisualSuspension } // resetVisualSuspension
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
std::shared_ptr<RenderInfo> KartModel::getRenderInfo() std::shared_ptr<GE::GERenderInfo> KartModel::getRenderInfo()
{ {
return m_support_colorization ? m_render_info : NULL; return m_support_colorization ? m_render_info : NULL;
} // getRenderInfo } // getRenderInfo

View File

@ -37,7 +37,7 @@ using namespace irr;
class AbstractKart; class AbstractKart;
class KartProperties; class KartProperties;
class RenderInfo; namespace GE { class GERenderInfo; }
class XMLNode; class XMLNode;
/** A speed-weighted object is an object whose characteristics are influenced by the kart's speed */ /** A speed-weighted object is an object whose characteristics are influenced by the kart's speed */
@ -307,7 +307,7 @@ private:
AbstractKart* m_kart; AbstractKart* m_kart;
/** For our engine to get the desired hue for colorization. */ /** For our engine to get the desired hue for colorization. */
std::shared_ptr<RenderInfo> m_render_info; std::shared_ptr<GE::GERenderInfo> m_render_info;
/** True if this kart model can be colorization in red / blue (now only /** True if this kart model can be colorization in red / blue (now only
* used in soccer mode). */ * used in soccer mode). */
@ -342,7 +342,7 @@ private:
public: public:
KartModel(bool is_master); KartModel(bool is_master);
~KartModel(); ~KartModel();
KartModel* makeCopy(std::shared_ptr<RenderInfo> ri); KartModel* makeCopy(std::shared_ptr<GE::GERenderInfo> ri);
void reset(); void reset();
void loadInfo(const XMLNode &node); void loadInfo(const XMLNode &node);
bool loadModels(const KartProperties &kart_properties); bool loadModels(const KartProperties &kart_properties);
@ -440,7 +440,7 @@ public:
// ------------------------------------------------------------------------ // ------------------------------------------------------------------------
scene::IAnimatedMeshSceneNode* getAnimatedNode(){ return m_animated_node; } scene::IAnimatedMeshSceneNode* getAnimatedNode(){ return m_animated_node; }
// ------------------------------------------------------------------------ // ------------------------------------------------------------------------
std::shared_ptr<RenderInfo> getRenderInfo(); std::shared_ptr<GE::GERenderInfo> getRenderInfo();
// ------------------------------------------------------------------------ // ------------------------------------------------------------------------
bool supportColorization() const { return m_support_colorization; } bool supportColorization() const { return m_support_colorization; }
// ------------------------------------------------------------------------ // ------------------------------------------------------------------------

View File

@ -389,7 +389,7 @@ void KartProperties::load(const std::string &filename, const std::string &node)
* \param krt The KartRenderType, like default, red, blue or transparent. * \param krt The KartRenderType, like default, red, blue or transparent.
* see the RenderInfo include for details * see the RenderInfo include for details
*/ */
KartModel* KartProperties::getKartModelCopy(std::shared_ptr<RenderInfo> ri) const KartModel* KartProperties::getKartModelCopy(std::shared_ptr<GE::GERenderInfo> ri) const
{ {
return m_kart_model->makeCopy(ri); return m_kart_model->makeCopy(ri);
} // getKartModelCopy } // getKartModelCopy

View File

@ -42,7 +42,7 @@ class CachedCharacteristic;
class CombinedCharacteristic; class CombinedCharacteristic;
class KartModel; class KartModel;
class Material; class Material;
class RenderInfo; namespace GE { class GERenderInfo; }
class XMLNode; class XMLNode;
@ -252,7 +252,7 @@ public:
video::ITexture *getMinimapIcon () const {return m_minimap_icon; } video::ITexture *getMinimapIcon () const {return m_minimap_icon; }
// ------------------------------------------------------------------------ // ------------------------------------------------------------------------
KartModel* getKartModelCopy(std::shared_ptr<RenderInfo> ri=nullptr) const; KartModel* getKartModelCopy(std::shared_ptr<GE::GERenderInfo> ri=nullptr) const;
// ------------------------------------------------------------------------ // ------------------------------------------------------------------------
/** Returns a pointer to the main KartModel object. This copy /** Returns a pointer to the main KartModel object. This copy
* should not be modified, not attachModel be called on it. */ * should not be modified, not attachModel be called on it. */

View File

@ -47,7 +47,7 @@ KartRewinder::KartRewinder(const std::string& ident,
unsigned int world_kart_id, int position, unsigned int world_kart_id, int position,
const btTransform& init_transform, const btTransform& init_transform,
HandicapLevel handicap, HandicapLevel handicap,
std::shared_ptr<RenderInfo> ri) std::shared_ptr<GE::GERenderInfo> ri)
: Rewinder( : Rewinder(
{ {
RN_KART, RN_KART,

View File

@ -36,7 +36,7 @@ public:
KartRewinder(const std::string& ident, unsigned int world_kart_id, KartRewinder(const std::string& ident, unsigned int world_kart_id,
int position, const btTransform& init_transform, int position, const btTransform& init_transform,
HandicapLevel handicap, HandicapLevel handicap,
std::shared_ptr<RenderInfo> ri); std::shared_ptr<GE::GERenderInfo> ri);
~KartRewinder() {} ~KartRewinder() {}
virtual void saveTransform() OVERRIDE; virtual void saveTransform() OVERRIDE;
virtual void computeError() OVERRIDE; virtual void computeError() OVERRIDE;

View File

@ -17,7 +17,7 @@
#include "modes/ctf_flag.hpp" #include "modes/ctf_flag.hpp"
#include "graphics/irr_driver.hpp" #include "graphics/irr_driver.hpp"
#include "graphics/render_info.hpp" #include <ge_render_info.hpp>
#include "graphics/sp/sp_mesh_node.hpp" #include "graphics/sp/sp_mesh_node.hpp"
#include "karts/abstract_kart.hpp" #include "karts/abstract_kart.hpp"
#include "modes/world.hpp" #include "modes/world.hpp"
@ -147,7 +147,7 @@ void CTFFlag::initFlagRenderInfo(irr::scene::IAnimatedMeshSceneNode* flag_node)
SP::SPMeshNode* spmn = dynamic_cast<SP::SPMeshNode*>(flag_node); SP::SPMeshNode* spmn = dynamic_cast<SP::SPMeshNode*>(flag_node);
if (!spmn) if (!spmn)
return; return;
m_flag_render_info = std::make_shared<RenderInfo>(0.0f, true); m_flag_render_info = std::make_shared<GE::GERenderInfo>(0.0f, true);
spmn->resetFirstRenderInfo(m_flag_render_info); spmn->resetFirstRenderInfo(m_flag_render_info);
} // initFlagRenderInfo } // initFlagRenderInfo

View File

@ -31,7 +31,7 @@ enum FlagColor : unsigned int
FC_BLUE = 1 FC_BLUE = 1
}; };
class RenderInfo; namespace GE { class GERenderInfo; }
namespace irr namespace irr
{ {
@ -65,7 +65,7 @@ private:
int m_off_base_compressed[4]; int m_off_base_compressed[4];
/* Determine if the flag should be drawn translucently */ /* Determine if the flag should be drawn translucently */
std::shared_ptr<RenderInfo> m_flag_render_info; std::shared_ptr<GE::GERenderInfo> m_flag_render_info;
uint16_t m_deactivated_ticks; uint16_t m_deactivated_ticks;
public: public:

View File

@ -22,7 +22,7 @@
#include "config/user_config.hpp" #include "config/user_config.hpp"
#include "graphics/camera.hpp" #include "graphics/camera.hpp"
#include "graphics/irr_driver.hpp" #include "graphics/irr_driver.hpp"
#include "graphics/render_info.hpp" #include <ge_render_info.hpp>
#include "io/file_manager.hpp" #include "io/file_manager.hpp"
#include "karts/kart.hpp" #include "karts/kart.hpp"
#include "karts/controller/spare_tire_ai.hpp" #include "karts/controller/spare_tire_ai.hpp"
@ -739,7 +739,7 @@ void ThreeStrikesBattle::loadCustomModels()
{ {
auto sta = std::make_shared<Kart>(sta_list[i], (int)m_karts.size(), auto sta = std::make_shared<Kart>(sta_list[i], (int)m_karts.size(),
(int)m_karts.size() + 1, pos[i], HANDICAP_NONE, (int)m_karts.size() + 1, pos[i], HANDICAP_NONE,
std::make_shared<RenderInfo>(1.0f)); std::make_shared<GE::GERenderInfo>(1.0f));
sta->init(RaceManager::KartType::KT_SPARE_TIRE); sta->init(RaceManager::KartType::KT_SPARE_TIRE);
sta->setController(new SpareTireAI(sta.get())); sta->setController(new SpareTireAI(sta.get()));

View File

@ -29,7 +29,7 @@
#include "graphics/irr_driver.hpp" #include "graphics/irr_driver.hpp"
#include "graphics/material.hpp" #include "graphics/material.hpp"
#include "graphics/material_manager.hpp" #include "graphics/material_manager.hpp"
#include "graphics/render_info.hpp" #include <ge_render_info.hpp>
#include "guiengine/modaldialog.hpp" #include "guiengine/modaldialog.hpp"
#include "guiengine/screen_keyboard.hpp" #include "guiengine/screen_keyboard.hpp"
#include "io/file_manager.hpp" #include "io/file_manager.hpp"
@ -463,7 +463,7 @@ std::shared_ptr<AbstractKart> World::createKart
if (RaceManager::get()->hasGhostKarts()) if (RaceManager::get()->hasGhostKarts())
gk = ReplayPlay::get()->getNumGhostKart(); gk = ReplayPlay::get()->getNumGhostKart();
std::shared_ptr<RenderInfo> ri = std::make_shared<RenderInfo>(); std::shared_ptr<GE::GERenderInfo> ri = std::make_shared<GE::GERenderInfo>();
core::stringw online_name; core::stringw online_name;
if (global_player_id > -1) if (global_player_id > -1)
{ {
@ -1596,9 +1596,9 @@ std::shared_ptr<AbstractKart> World::createKartWithTeam
btTransform init_pos = getStartTransform(pos_index - 1); btTransform init_pos = getStartTransform(pos_index - 1);
m_kart_position_map[index] = (unsigned)(pos_index - 1); m_kart_position_map[index] = (unsigned)(pos_index - 1);
std::shared_ptr<RenderInfo> ri = std::make_shared<RenderInfo>(); std::shared_ptr<GE::GERenderInfo> ri = std::make_shared<GE::GERenderInfo>();
ri = (team == KART_TEAM_BLUE ? std::make_shared<RenderInfo>(0.66f) : ri = (team == KART_TEAM_BLUE ? std::make_shared<GE::GERenderInfo>(0.66f) :
std::make_shared<RenderInfo>(1.0f)); std::make_shared<GE::GERenderInfo>(1.0f));
std::shared_ptr<AbstractKart> new_kart; std::shared_ptr<AbstractKart> new_kart;
if (RewindManager::get()->isEnabled()) if (RewindManager::get()->isEnabled())

View File

@ -24,7 +24,7 @@
#include "guiengine/engine.hpp" #include "guiengine/engine.hpp"
#include "guiengine/message_queue.hpp" #include "guiengine/message_queue.hpp"
#include "guiengine/screen_keyboard.hpp" #include "guiengine/screen_keyboard.hpp"
#include "graphics/render_info.hpp" #include <ge_render_info.hpp>
#include "karts/abstract_kart.hpp" #include "karts/abstract_kart.hpp"
#include "karts/controller/controller.hpp" #include "karts/controller/controller.hpp"
#include "modes/world.hpp" #include "modes/world.hpp"
@ -233,10 +233,10 @@ void LobbyProtocol::addLiveJoiningKart(int kart_id, const RemoteKartInfo& rki,
AbstractKart* k = World::getWorld()->getKart(kart_id); AbstractKart* k = World::getWorld()->getKart(kart_id);
k->changeKart(rki.getKartName(), rki.getHandicap(), k->changeKart(rki.getKartName(), rki.getHandicap(),
rki.getKartTeam() == KART_TEAM_RED ? rki.getKartTeam() == KART_TEAM_RED ?
std::make_shared<RenderInfo>(1.0f) : std::make_shared<GE::GERenderInfo>(1.0f) :
rki.getKartTeam() == KART_TEAM_BLUE ? rki.getKartTeam() == KART_TEAM_BLUE ?
std::make_shared<RenderInfo>(0.66f) : std::make_shared<GE::GERenderInfo>(0.66f) :
std::make_shared<RenderInfo>(rki.getDefaultKartColor())); std::make_shared<GE::GERenderInfo>(rki.getDefaultKartColor()));
k->setLiveJoinKart(live_join_util_ticks); k->setLiveJoinKart(live_join_util_ticks);
World::getWorld()->initTeamArrows(k); World::getWorld()->initTeamArrows(k);
if (!k->getController()->isLocalPlayerController()) if (!k->getController()->isLocalPlayerController())

View File

@ -24,7 +24,7 @@
#include "karts/kart_properties.hpp" #include "karts/kart_properties.hpp"
#include "karts/kart_properties_manager.hpp" #include "karts/kart_properties_manager.hpp"
#include "graphics/irr_driver.hpp" #include "graphics/irr_driver.hpp"
#include "graphics/render_info.hpp" #include <ge_render_info.hpp>
#include "guiengine/engine.hpp" #include "guiengine/engine.hpp"
#include "guiengine/widgets/label_widget.hpp" #include "guiengine/widgets/label_widget.hpp"
#include "guiengine/widgets/model_view_widget.hpp" #include "guiengine/widgets/model_view_widget.hpp"

View File

@ -26,7 +26,7 @@
#include "graphics/irr_driver.hpp" #include "graphics/irr_driver.hpp"
#include "graphics/lod_node.hpp" #include "graphics/lod_node.hpp"
#include "graphics/lod_node.hpp" #include "graphics/lod_node.hpp"
#include "graphics/render_info.hpp" #include <ge_render_info.hpp>
#include "guiengine/engine.hpp" #include "guiengine/engine.hpp"
#include "guiengine/scalable_font.hpp" #include "guiengine/scalable_font.hpp"
#include "guiengine/widgets/button_widget.hpp" #include "guiengine/widgets/button_widget.hpp"
@ -185,7 +185,7 @@ void GrandPrixLose::setKarts(std::vector<std::pair<std::string, float> > ident_a
const KartProperties* kart = kart_properties_manager->getKart(ident_arg[n].first); const KartProperties* kart = kart_properties_manager->getKart(ident_arg[n].first);
if (kart != NULL) if (kart != NULL)
{ {
KartModel* kart_model = kart->getKartModelCopy(std::make_shared<RenderInfo>(ident_arg[n].second)); KartModel* kart_model = kart->getKartModelCopy(std::make_shared<GE::GERenderInfo>(ident_arg[n].second));
m_all_kart_models.push_back(kart_model); m_all_kart_models.push_back(kart_model);
scene::ISceneNode* kart_main_node = kart_model->attachModel(true, false); scene::ISceneNode* kart_main_node = kart_model->attachModel(true, false);
LODNode* lnode = dynamic_cast<LODNode*>(kart_main_node); LODNode* lnode = dynamic_cast<LODNode*>(kart_main_node);

View File

@ -25,7 +25,7 @@
#include "config/stk_config.hpp" #include "config/stk_config.hpp"
#include "graphics/irr_driver.hpp" #include "graphics/irr_driver.hpp"
#include "graphics/lod_node.hpp" #include "graphics/lod_node.hpp"
#include "graphics/render_info.hpp" #include <ge_render_info.hpp>
#include "guiengine/engine.hpp" #include "guiengine/engine.hpp"
#include "guiengine/scalable_font.hpp" #include "guiengine/scalable_font.hpp"
#include "guiengine/widgets/button_widget.hpp" #include "guiengine/widgets/button_widget.hpp"
@ -345,7 +345,7 @@ void GrandPrixWin::setKarts(const std::pair<std::string, float> idents_arg[3])
const KartProperties* kp = kart_properties_manager->getKart(idents[i].first); const KartProperties* kp = kart_properties_manager->getKart(idents[i].first);
if (kp == NULL) continue; if (kp == NULL) continue;
KartModel* kart_model = kp->getKartModelCopy(std::make_shared<RenderInfo>(idents[i].second)); KartModel* kart_model = kp->getKartModelCopy(std::make_shared<GE::GERenderInfo>(idents[i].second));
m_all_kart_models.push_back(kart_model); m_all_kart_models.push_back(kart_model);
scene::ISceneNode* kart_main_node = kart_model->attachModel(true, false); scene::ISceneNode* kart_main_node = kart_model->attachModel(true, false);
LODNode* lnode = dynamic_cast<LODNode*>(kart_main_node); LODNode* lnode = dynamic_cast<LODNode*>(kart_main_node);

View File

@ -23,7 +23,7 @@
#include "config/player_manager.hpp" #include "config/player_manager.hpp"
#include "config/user_config.hpp" #include "config/user_config.hpp"
#include "graphics/irr_driver.hpp" #include "graphics/irr_driver.hpp"
#include "graphics/render_info.hpp" #include <ge_render_info.hpp>
#include "guiengine/message_queue.hpp" #include "guiengine/message_queue.hpp"
#include "guiengine/widgets/bubble_widget.hpp" #include "guiengine/widgets/bubble_widget.hpp"
#include "guiengine/widgets/kart_stats_widget.hpp" #include "guiengine/widgets/kart_stats_widget.hpp"

View File

@ -19,7 +19,7 @@
#include "audio/sfx_manager.hpp" #include "audio/sfx_manager.hpp"
#include "config/user_config.hpp" #include "config/user_config.hpp"
#include "graphics/render_info.hpp" #include <ge_render_info.hpp>
#include "guiengine/widgets/bubble_widget.hpp" #include "guiengine/widgets/bubble_widget.hpp"
#include "guiengine/widgets/button_widget.hpp" #include "guiengine/widgets/button_widget.hpp"
#include "guiengine/widgets/spinner_widget.hpp" #include "guiengine/widgets/spinner_widget.hpp"

View File

@ -57,7 +57,7 @@ void ModelDefinitionLoader::addModelDefinition(const XMLNode* xml)
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
LODNode* ModelDefinitionLoader::instanciateAsLOD(const XMLNode* node, scene::ISceneNode* parent, std::shared_ptr<RenderInfo> ri) LODNode* ModelDefinitionLoader::instanciateAsLOD(const XMLNode* node, scene::ISceneNode* parent, std::shared_ptr<GE::GERenderInfo> ri)
{ {
scene::ISceneManager* sm = irr_driver->getSceneManager(); scene::ISceneManager* sm = irr_driver->getSceneManager();

View File

@ -21,7 +21,7 @@
class LODNode; class LODNode;
class STKInstancedSceneNode; class STKInstancedSceneNode;
class RenderInfo; namespace GE { class GERenderInfo; }
class Track; class Track;
#include <cassert> #include <cassert>
@ -92,7 +92,7 @@ public:
void addModelDefinition(const XMLNode* xml); void addModelDefinition(const XMLNode* xml);
LODNode* instanciateAsLOD(const XMLNode* xml_node, LODNode* instanciateAsLOD(const XMLNode* xml_node,
scene::ISceneNode* parent, scene::ISceneNode* parent,
std::shared_ptr<RenderInfo> ri); std::shared_ptr<GE::GERenderInfo> ri);
void clear(); void clear();

View File

@ -24,7 +24,7 @@
#include "graphics/lod_node.hpp" #include "graphics/lod_node.hpp"
#include "graphics/material.hpp" #include "graphics/material.hpp"
#include "graphics/material_manager.hpp" #include "graphics/material_manager.hpp"
#include "graphics/render_info.hpp" #include <ge_render_info.hpp>
#include "graphics/sp/sp_mesh_buffer.hpp" #include "graphics/sp/sp_mesh_buffer.hpp"
#include "graphics/sp/sp_mesh_node.hpp" #include "graphics/sp/sp_mesh_node.hpp"
#include "io/file_manager.hpp" #include "io/file_manager.hpp"
@ -261,7 +261,7 @@ void TrackObject::init(const XMLNode &xml_node, scene::ISceneNode* parent,
const float hue = colorized->getRandomHue(); const float hue = colorized->getRandomHue();
if (hue > 0.0f) if (hue > 0.0f)
{ {
m_render_info = std::make_shared<RenderInfo>(hue); m_render_info = std::make_shared<GE::GERenderInfo>(hue);
} }
} }
} }

View File

@ -32,7 +32,7 @@
#include <memory> #include <memory>
class ModelDefinitionLoader; class ModelDefinitionLoader;
class RenderInfo; namespace GE { class GERenderInfo; }
class ThreeDAnimation; class ThreeDAnimation;
class XMLNode; class XMLNode;
@ -60,7 +60,7 @@ private:
std::string m_id; std::string m_id;
std::shared_ptr<RenderInfo> m_render_info; std::shared_ptr<GE::GERenderInfo> m_render_info;
protected: protected:

View File

@ -355,7 +355,7 @@ void TrackObjectPresentationLibraryNode::move(const core::vector3df& xyz, const
TrackObjectPresentationLOD::TrackObjectPresentationLOD(const XMLNode& xml_node, TrackObjectPresentationLOD::TrackObjectPresentationLOD(const XMLNode& xml_node,
scene::ISceneNode* parent, scene::ISceneNode* parent,
ModelDefinitionLoader& model_def_loader, ModelDefinitionLoader& model_def_loader,
std::shared_ptr<RenderInfo> ri) std::shared_ptr<GE::GERenderInfo> ri)
: TrackObjectPresentationSceneNode(xml_node) : TrackObjectPresentationSceneNode(xml_node)
{ {
m_node = model_def_loader.instanciateAsLOD(&xml_node, parent, ri); m_node = model_def_loader.instanciateAsLOD(&xml_node, parent, ri);
@ -401,7 +401,7 @@ TrackObjectPresentationMesh::TrackObjectPresentationMesh(
const XMLNode& xml_node, const XMLNode& xml_node,
bool enabled, bool enabled,
scene::ISceneNode* parent, scene::ISceneNode* parent,
std::shared_ptr<RenderInfo> render_info) std::shared_ptr<GE::GERenderInfo> render_info)
: TrackObjectPresentationSceneNode(xml_node) : TrackObjectPresentationSceneNode(xml_node)
{ {
m_is_looped = false; m_is_looped = false;

View File

@ -40,7 +40,7 @@ class ParticleEmitter;
class PhysicalObject; class PhysicalObject;
class ThreeDAnimation; class ThreeDAnimation;
class ModelDefinitionLoader; class ModelDefinitionLoader;
class RenderInfo; namespace GE { class GERenderInfo; }
class STKInstancedSceneNode; class STKInstancedSceneNode;
class XMLNode; class XMLNode;
class TrackObject; class TrackObject;
@ -221,7 +221,7 @@ public:
TrackObjectPresentationLOD(const XMLNode& xml_node, TrackObjectPresentationLOD(const XMLNode& xml_node,
scene::ISceneNode* parent, scene::ISceneNode* parent,
ModelDefinitionLoader& model_def_loader, ModelDefinitionLoader& model_def_loader,
std::shared_ptr<RenderInfo> ri); std::shared_ptr<GE::GERenderInfo> ri);
virtual ~TrackObjectPresentationLOD(); virtual ~TrackObjectPresentationLOD();
virtual void reset() OVERRIDE; virtual void reset() OVERRIDE;
}; };
@ -245,14 +245,14 @@ private:
std::string m_model_file; std::string m_model_file;
std::shared_ptr<RenderInfo> m_render_info; std::shared_ptr<GE::GERenderInfo> m_render_info;
void init(const XMLNode* xml_node, scene::ISceneNode* parent, bool enabled); void init(const XMLNode* xml_node, scene::ISceneNode* parent, bool enabled);
public: public:
TrackObjectPresentationMesh(const XMLNode& xml_node, bool enabled, TrackObjectPresentationMesh(const XMLNode& xml_node, bool enabled,
scene::ISceneNode* parent, scene::ISceneNode* parent,
std::shared_ptr<RenderInfo> render_info); std::shared_ptr<GE::GERenderInfo> render_info);
TrackObjectPresentationMesh(const std::string& model_file, TrackObjectPresentationMesh(const std::string& model_file,
const core::vector3df& xyz, const core::vector3df& xyz,