]> git.tdb.fi Git - libs/vr.git/blobdiff - source/stereoview.h
Fix memory leaks
[libs/vr.git] / source / stereoview.h
index 63ee1834db7b27b2c9f67ea202c32bbf616198ba..75361ba13abd56acf8cc50feb0585e75daa41f24 100644 (file)
@@ -1,32 +1,35 @@
-#ifndef MSP_GL_STEREOVIEW_H_
-#define MSP_GL_STEREOVIEW_H_
+#ifndef MSP_VR_STEREOVIEW_H_
+#define MSP_VR_STEREOVIEW_H_
 
-#include "camera.h"
-#include "framebuffer.h"
-#include "renderable.h"
-#include "renderbuffer.h"
-#include "texture2d.h"
+#include <msp/geometry/angle.h>
+#include <msp/gl/camera.h>
+#include <msp/gl/framebuffer.h>
+#include <msp/gl/renderable.h>
+#include <msp/gl/renderbuffer.h>
+#include <msp/gl/texture2d.h>
 
 namespace Msp {
-namespace GL {
+namespace VR {
 
+class HeadTrackingCamera;
+class MotionController;
 class StereoCombiner;
 
-class StereoView: public Renderable
+class StereoView
 {
 private:
        struct RenderTarget
        {
-               Framebuffer fbo;
-               Texture2D color;
-               Renderbuffer depth;
+               GL::Framebuffer fbo;
+               GL::Texture2D color;
+               GL::Renderbuffer depth;
 
                RenderTarget(unsigned, unsigned);
        };
 
        struct EyeParams
        {
-               float fov;
+               Geometry::Angle<float> fov;
                float aspect;
                float near_clip;
                float far_clip;
@@ -34,40 +37,51 @@ private:
 
        struct Eye
        {
-               mutable Camera camera;
+               mutable GL::Camera camera;
+               GL::Matrix offset_matrix;
                RenderTarget *target;
 
                Eye();
+               ~Eye();
 
                void create_target(unsigned, unsigned);
-               void setup_frame(const Camera &, const Vector3 &, const EyeParams &) const;
-               void render(const Renderable &, const Tag &) const;
+               void setup_frame(const GL::Camera &, float, const EyeParams &) const;
+               void render(const GL::Renderable &) const;
        };
 
-       unsigned width;
-       unsigned height;
-       const Camera &base_camera;
-       const Renderable &renderable;
-       const StereoCombiner *combiner;
+       const StereoCombiner &combiner;
+       const GL::Camera &base_camera;
+       HeadTrackingCamera *head_camera;
+       const GL::Renderable *content;
        Eye left;
        Eye right;
-       float eye_spacing;
-       mutable Vector3 offset_axis;
+       Geometry::Angle<float> strabismus;
+       std::vector<MotionController *> controllers;
 
 public:
-       StereoView(unsigned, unsigned, const Camera &, const Renderable &, const StereoCombiner &);
+       StereoView(const StereoCombiner &, const GL::Camera &);
+       StereoView(const StereoCombiner &, HeadTrackingCamera &);
+private:
+       void init();
 
-       void set_combiner(const StereoCombiner &);
+public:
+       const GL::Camera &get_base_camera() const { return base_camera; }
+       const HeadTrackingCamera *get_head_camera() const { return head_camera; }
+       void set_content(const GL::Renderable *);
        void set_eye_spacing(float);
+       void set_eye_matrices(const GL::Matrix &, const GL::Matrix &);
+       void set_strabismus(const Geometry::Angle<float> &);
 
-       virtual void setup_frame() const;
-       virtual void finish_frame() const;
+       void add_controller(MotionController &);
+       void remove_controller(MotionController &);
 
-       virtual void render(const Tag & = Tag()) const;
-       virtual void render(Renderer &, const Tag & = Tag()) const;
+private:
+       void setup_frame() const;
+public:
+       void render() const;
 };
 
-} // namespace GL
+} // namespace VR
 } // namespace Msp
 
 #endif