]> git.lizzy.rs Git - minetest.git/blobdiff - src/camera.h
map.cpp: Initialize NodeNeighbor, set NeighborType to u8 & cleanup
[minetest.git] / src / camera.h
index 4b2d9d45ece7ec211501c2e2f928832b1afc3d61..88de3570ae25779ccf65ff6e8dbec570e19f554f 100644 (file)
@@ -17,20 +17,15 @@ with this program; if not, write to the Free Software Foundation, Inc.,
 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
 */
 
-#ifndef CAMERA_HEADER
-#define CAMERA_HEADER
+#pragma once
 
 #include "irrlichttypes_extrabloated.h"
 #include "inventory.h"
-#include "mesh.h"
 #include "client/tile.h"
-#include "util/numeric.h"
 #include <ICameraSceneNode.h>
 #include <ISceneNode.h>
 #include <list>
 
-#include "client.h"
-
 class LocalPlayer;
 struct MapDrawControl;
 class Client;
@@ -39,15 +34,18 @@ class WieldMeshSceneNode;
 struct Nametag {
        Nametag(scene::ISceneNode *a_parent_node,
                        const std::string &a_nametag_text,
-                       const video::SColor &a_nametag_color):
+                       const video::SColor &a_nametag_color,
+                       const v3f &a_nametag_pos):
                parent_node(a_parent_node),
                nametag_text(a_nametag_text),
-               nametag_color(a_nametag_color)
+               nametag_color(a_nametag_color),
+               nametag_pos(a_nametag_pos)
        {
        }
        scene::ISceneNode *parent_node;
        std::string nametag_text;
        video::SColor nametag_color;
+       v3f nametag_pos;
 };
 
 enum CameraMode {CAMERA_MODE_FIRST, CAMERA_MODE_THIRD, CAMERA_MODE_THIRD_FRONT};
@@ -60,8 +58,7 @@ enum CameraMode {CAMERA_MODE_FIRST, CAMERA_MODE_THIRD, CAMERA_MODE_THIRD_FRONT};
 class Camera
 {
 public:
-       Camera(scene::ISceneManager* smgr, MapDrawControl& draw_control,
-                       Client *client);
+       Camera(MapDrawControl &draw_control, Client *client);
        ~Camera();
 
        // Get camera scene node.
@@ -118,7 +115,7 @@ class Camera
        // Update the camera from the local player's position.
        // busytime is used to adjust the viewing range.
        void update(LocalPlayer* player, f32 frametime, f32 busytime,
-                       f32 tool_reload_ratio, ClientEnvironment &c_env);
+                       f32 tool_reload_ratio);
 
        // Update render distance
        void updateViewingRange();
@@ -158,7 +155,8 @@ class Camera
        }
 
        Nametag *addNametag(scene::ISceneNode *parent_node,
-               std::string nametag_text, video::SColor nametag_color);
+               const std::string &nametag_text, video::SColor nametag_color,
+               const v3f &pos);
 
        void removeNametag(Nametag *nametag);
 
@@ -166,7 +164,7 @@ class Camera
 
        void drawNametags();
 
-       inline void addArmInertia(f32 player_yaw, f32 frametime);
+       inline void addArmInertia(f32 player_yaw);
 
 private:
        // Nodes
@@ -181,7 +179,6 @@ class Camera
        MapDrawControl& m_draw_control;
 
        Client *m_client;
-       video::IVideoDriver *m_driver;
 
        // Absolute camera position
        v3f m_camera_position;
@@ -191,7 +188,7 @@ class Camera
        v3s16 m_camera_offset;
 
        v2f m_wieldmesh_offset = v2f(55.0f, -35.0f);
-       v2f m_timer;
+       v2f m_arm_dir;
        v2f m_cam_vel;
        v2f m_cam_vel_old;
        v2f m_last_cam_pos;
@@ -228,10 +225,7 @@ class Camera
        f32 m_cache_fall_bobbing_amount;
        f32 m_cache_view_bobbing_amount;
        f32 m_cache_fov;
-       f32 m_cache_zoom_fov;
        bool m_arm_inertia;
 
        std::list<Nametag *> m_nametags;
 };
-
-#endif