X-Git-Url: https://git.dogcows.com/gitweb?p=chaz%2Fyoink;a=blobdiff_plain;f=src%2FMoof%2FCamera.hh;h=8e28f5420fe4e64de32130e88716abe4e7b515b6;hp=fae25079ec700d88d7e1a5edb1baff0e3324874e;hb=c9e20ac06383b20ceb5404c9237e319c2e90d157;hpb=57b78ebe21b1b48acd337daa5a1cb8c383959cfa diff --git a/src/Moof/Camera.hh b/src/Moof/Camera.hh index fae2507..8e28f54 100644 --- a/src/Moof/Camera.hh +++ b/src/Moof/Camera.hh @@ -31,57 +31,63 @@ #include #include -#include #include +#include namespace Mf { -class Camera +class Camera : public RigidBody3 { - void calculateSecondary(); - public: - Camera() : - position_(0.0, 0.0, 0.0) + + Camera() { - cml::quaternion_rotation_world_y(rotation_, 0.0f); - calculateSecondary(); + mState.init(); + mPrevState.init(); + + cml::quaternion_rotation_world_y(mState.orientation, SCALAR(0.0)); } - void setPosition(const Vector3& point); + void setPosition(const Vector3& position); void setRotation(const Quaternion& rotation); + void lookAt(const Vector3& point); + void setProjection(const Matrix4& projection); void setProjection(Scalar fovy, Scalar aspect, Scalar near, Scalar far); - void uploadProjectionToGL() const; - - void lookAt(const Vector3& point); + const Matrix4& getModelview() const + { + return mModelview; + } - const Matrix4& getModelviewMatrix() const + const Matrix4& getProjection() const { - return modelview_; + return mProjection; } const Frustum& getFrustum() const { - return frustum_; + return mFrustum; } - void handleEvent(const Event& event); + + void uploadToGL(Scalar alpha = 0) const; + void update(Scalar t, Scalar dt); + void draw(Scalar alpha = 0) const; + void handleEvent(const Event& event); private: - Vector3 position_; - Quaternion rotation_; - Matrix4 projection_; - Matrix4 modelview_; - Frustum frustum_; + void calculate(Scalar alpha) const; + + mutable Matrix4 mModelview; + Matrix4 mProjection; - Lerpv3 pInterp_; + mutable Frustum mFrustum; };