]> git.lizzy.rs Git - minetest.git/blobdiff - src/camera.h
Remove `mathconstants.h` and use the correct way to get `M_PI` in MSVC. (#5072)
[minetest.git] / src / camera.h
index b5373886087b6e5d6ea2e99a661f4cd9beeae920..b5be26718fc5f7fa09d8c1d8ccbbd37480b7887c 100644 (file)
@@ -26,14 +26,30 @@ with this program; if not, write to the Free Software Foundation, Inc.,
 #include "client/tile.h"
 #include "util/numeric.h"
 #include <ICameraSceneNode.h>
+#include <ISceneNode.h>
+#include <list>
 
 #include "client.h"
 
 class LocalPlayer;
 struct MapDrawControl;
-class IGameDef;
+class Client;
 class WieldMeshSceneNode;
 
+struct Nametag {
+       Nametag(scene::ISceneNode *a_parent_node,
+                       const std::string &a_nametag_text,
+                       const video::SColor &a_nametag_color):
+               parent_node(a_parent_node),
+               nametag_text(a_nametag_text),
+               nametag_color(a_nametag_color)
+       {
+       }
+       scene::ISceneNode *parent_node;
+       std::string nametag_text;
+       video::SColor nametag_color;
+};
+
 enum CameraMode {CAMERA_MODE_FIRST, CAMERA_MODE_THIRD, CAMERA_MODE_THIRD_FRONT};
 
 /*
@@ -45,7 +61,7 @@ class Camera
 {
 public:
        Camera(scene::ISceneManager* smgr, MapDrawControl& draw_control,
-                       IGameDef *gamedef);
+                       Client *client);
        ~Camera();
 
        // Get player scene node.
@@ -84,7 +100,7 @@ class Camera
        {
                return m_camera_direction;
        }
-       
+
        // Get the camera offset
        inline v3s16 getOffset() const
        {
@@ -110,7 +126,7 @@ class Camera
        }
 
        // Checks if the constructor was able to create the scene nodes
-       bool successfullyCreated(std::wstring& error_message);
+       bool successfullyCreated(std::string &error_message);
 
        // Step the camera: updates the viewing range and view bobbing.
        void step(f32 dtime);
@@ -120,8 +136,8 @@ class Camera
        void update(LocalPlayer* player, f32 frametime, f32 busytime,
                        f32 tool_reload_ratio, ClientEnvironment &c_env);
 
-       // Render distance feedback loop
-       void updateViewingRange(f32 frametime_in, f32 busytime_in);
+       // Update render distance
+       void updateViewingRange();
 
        // Start digging animation
        // Pass 0 for left click, 1 for right click
@@ -151,6 +167,16 @@ class Camera
                return m_camera_mode;
        }
 
+       Nametag *addNametag(scene::ISceneNode *parent_node,
+               std::string nametag_text, video::SColor nametag_color);
+
+       void removeNametag(Nametag *nametag);
+
+       std::list<Nametag *> *getNametags()
+       { return &m_nametags; }
+
+       void drawNametags();
+
 private:
        // Nodes
        scene::ISceneNode* m_playernode;
@@ -159,12 +185,12 @@ class Camera
 
        scene::ISceneManager* m_wieldmgr;
        WieldMeshSceneNode* m_wieldnode;
-       scene::ILightSceneNode* m_wieldlightnode;
 
        // draw control
        MapDrawControl& m_draw_control;
-       
-       IGameDef *m_gamedef;
+
+       Client *m_client;
+       video::IVideoDriver *m_driver;
 
        // Absolute camera position
        v3f m_camera_position;
@@ -178,14 +204,6 @@ class Camera
        f32 m_fov_x;
        f32 m_fov_y;
 
-       // Stuff for viewing range calculations
-       f32 m_added_busytime;
-       s16 m_added_frames;
-       f32 m_range_old;
-       f32 m_busytime_old;
-       f32 m_frametime_counter;
-       f32 m_time_per_range;
-
        // View bobbing animation frame (0 <= m_view_bobbing_anim < 1)
        f32 m_view_bobbing_anim;
        // If 0, view bobbing is off (e.g. player is standing).
@@ -212,9 +230,11 @@ class Camera
 
        f32 m_cache_fall_bobbing_amount;
        f32 m_cache_view_bobbing_amount;
-       f32 m_cache_wanted_fps;
        f32 m_cache_fov;
+       f32 m_cache_zoom_fov;
        bool m_cache_view_bobbing;
+
+       std::list<Nametag *> m_nametags;
 };
 
 #endif