Barely-functioning GL playback with new arrangement.
[dcpomatic.git] / src / wx / gl_video_view.h
index cdc9fd530ae3045157cdcf003d19421355df145d..e32a1ede95eeea421b808733ea4b0a91058c5a6f 100644 (file)
 #include <wx/glcanvas.h>
 #include <dcp/util.h>
 #include <boost/shared_ptr.hpp>
 #include <wx/glcanvas.h>
 #include <dcp/util.h>
 #include <boost/shared_ptr.hpp>
-
+#include <boost/thread.hpp>
 #undef None
 #undef Success
 
 class GLVideoView : public VideoView
 {
 public:
 #undef None
 #undef Success
 
 class GLVideoView : public VideoView
 {
 public:
-       GLVideoView (wxWindow* parent);
+       GLVideoView (FilmViewer* viewer, wxWindow* parent);
        ~GLVideoView ();
 
        void set_image (boost::shared_ptr<const Image> image);
        wxWindow* get () const {
                return _canvas;
        }
        ~GLVideoView ();
 
        void set_image (boost::shared_ptr<const Image> image);
        wxWindow* get () const {
                return _canvas;
        }
+       void update ();
+       void start ();
+
+       bool vsync_enabled () const {
+               return _vsync_enabled;
+       }
 
 private:
 
 private:
-        void paint (wxPaintEvent& event);
+       void paint ();
+       void draw ();
+       void thread ();
+       wxGLContext* context () const;
 
        wxGLCanvas* _canvas;
 
        wxGLCanvas* _canvas;
-        wxGLContext* _context;
-        GLuint _id;
-        boost::optional<dcp::Size> _size;
+
+       wxGLContext* _context;
+       mutable boost::mutex _context_mutex;
+
+       GLuint _id;
+       boost::optional<dcp::Size> _size;
+       bool _vsync_enabled;
+       boost::thread* _thread;
 };
 };