Optimize updateFastFaceRow processing by removing some TileSpec copy (#5678)
[oweals/minetest.git] / src / particles.h
index 6d8c6139f2debc8ffb8707421039551a5061dc80..eaec1f0fa784a4d942bc973875f9d24c10e7e1c5 100644 (file)
@@ -20,17 +20,18 @@ with this program; if not, write to the Free Software Foundation, Inc.,
 #ifndef PARTICLES_HEADER
 #define PARTICLES_HEADER
 
-#define DIGGING_PARTICLES_AMOUNT 10
-
 #include <iostream>
 #include "irrlichttypes_extrabloated.h"
 #include "client/tile.h"
 #include "localplayer.h"
 #include "environment.h"
+#include "tileanimation.h"
 
 struct ClientEvent;
 class ParticleManager;
 class ClientEnvironment;
+struct MapNode;
+struct ContentFeatures;
 
 class Particle : public scene::ISceneNode
 {
@@ -51,13 +52,9 @@ class Particle : public scene::ISceneNode
                video::ITexture *texture,
                v2f texpos,
                v2f texsize,
-               u32 material_type_param,
-               u16 vertical_frame_num,
-               u16 horizontal_frame_num,
-               u16 first_frame,
-               float frame_length,
-               bool loop_animation,
-               u8 glow
+               const struct TileAnimationParams &anim,
+               u8 glow,
+               video::SColor color = video::SColor(0xFFFFFFFF)
        );
        ~Particle();
 
@@ -104,16 +101,17 @@ private:
        v3f m_acceleration;
        LocalPlayer *m_player;
        float m_size;
-       u8 m_light;
+       //! Color without lighting
+       video::SColor m_base_color;
+       //! Final rendered color
+       video::SColor m_color;
        bool m_collisiondetection;
        bool m_collision_removal;
        bool m_vertical;
        v3s16 m_camera_offset;
-       u16 m_vertical_frame_num;
-       u16 m_horizontal_frame_num;
-       u16 m_first_frame;
-       float m_frame_length;
-       bool m_loop_animation;
+       struct TileAnimationParams m_animation;
+       float m_animation_time;
+       int m_animation_frame;
        u8 m_glow;
 };
 
@@ -136,15 +134,9 @@ class ParticleSpawner
                bool vertical,
                video::ITexture *texture,
                u32 id,
-               u32 material_type_param,
-               u16 vertical_frame_num,
-               u16 horizontal_frame_num,
-               u16 min_first_frame,
-               u16 max_first_frame,
-               float frame_length,
-               bool loop_animation,
-               u8 glow,
+               const struct TileAnimationParams &anim, u8 glow,
                ParticleManager* p_manager);
+
        ~ParticleSpawner();
 
        void step(float dtime, ClientEnvironment *env);
@@ -176,13 +168,7 @@ class ParticleSpawner
        bool m_collision_removal;
        bool m_vertical;
        u16 m_attached_id;
-       u32 m_material_type_param;
-       u16 m_vertical_frame_num;
-       u16 m_horizontal_frame_num;
-       u16 m_min_first_frame;
-       u16 m_max_first_frame;
-       float m_frame_length;
-       bool m_loop_animation;
+       struct TileAnimationParams m_animation;
        u8 m_glow;
 };
 
@@ -198,17 +184,20 @@ public:
 
        void step (float dtime);
 
-       void handleParticleEvent(ClientEvent *event,IGameDef *gamedef,
+       void handleParticleEvent(ClientEvent *event, Client *client,
                        scene::ISceneManager* smgr, LocalPlayer *player);
 
        void addDiggingParticles(IGameDef* gamedef, scene::ISceneManager* smgr,
-               LocalPlayer *player, v3s16 pos, const TileSpec tiles[]);
+               LocalPlayer *player, v3s16 pos, const MapNode &n,
+               const ContentFeatures &f);
 
        void addPunchingParticles(IGameDef* gamedef, scene::ISceneManager* smgr,
-               LocalPlayer *player, v3s16 pos, const TileSpec tiles[]);
+               LocalPlayer *player, v3s16 pos, const MapNode &n,
+               const ContentFeatures &f);
 
        void addNodeParticle(IGameDef* gamedef, scene::ISceneManager* smgr,
-               LocalPlayer *player, v3s16 pos, const TileSpec tiles[]);
+               LocalPlayer *player, v3s16 pos, const MapNode &n,
+               const ContentFeatures &f);
 
 protected:
        void addParticle(Particle* toadd);