X-Git-Url: https://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fgraphics%2FCamera.hpp;h=a3a9e577a8a5dd5cbfadbf0a405a76abb45c38b5;hb=refs%2Fheads%2Fmaster;hp=f4a98d50cc0eefe80d5294f6f3c0c934c97c0377;hpb=cacc0641e5174d8b46e7a7086be6a45c87ab3642;p=blobs.git diff --git a/src/graphics/Camera.hpp b/src/graphics/Camera.hpp index f4a98d5..a3a9e57 100644 --- a/src/graphics/Camera.hpp +++ b/src/graphics/Camera.hpp @@ -1,7 +1,7 @@ #ifndef BLOBS_GRAPHICS_CAMERA_HPP_ #define BLOBS_GRAPHICS_CAMERA_HPP_ -#include "glm.hpp" +#include "../math/glm.hpp" namespace blobs { @@ -31,17 +31,15 @@ public: const world::Body &Reference() const noexcept { return *ref; } Camera &Reference(const world::Body &) noexcept; - /// standing on given surface, with pos.z being elevation over NN - /// looking at given coordinates - Camera &FirstPerson(int surface, const glm::vec3 &pos, const glm::vec3 &at) noexcept; - /// looking straight down at surface from above - Camera &MapView(int surface, const glm::vec3 &pos, float roll = 0.0f) noexcept; - /// look at center, position relative to orbital reference plane for children - Camera &Orbital(const glm::vec3 &pos) noexcept; + Camera &LookAt(const glm::vec3 &pos, const glm::vec3 &tgt, const glm::vec3 &up) noexcept; + + /// track orientation of reference body + void TrackOrientation(bool b = true) noexcept { track_orient = b; } const glm::mat4 &Projection() const noexcept { return projection; } const glm::mat4 &View() const noexcept { return view; } glm::mat4 Model(const world::Body &) const noexcept; + glm::mat4 Universe() const noexcept; private: void UpdateProjection() noexcept;