projects
/
dcpomatic.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Barely-functioning GL playback with new arrangement.
[dcpomatic.git]
/
src
/
wx
/
gl_video_view.h
diff --git
a/src/wx/gl_video_view.h
b/src/wx/gl_video_view.h
index cdc9fd530ae3045157cdcf003d19421355df145d..e32a1ede95eeea421b808733ea4b0a91058c5a6f 100644
(file)
--- a/
src/wx/gl_video_view.h
+++ b/
src/wx/gl_video_view.h
@@
-23,26
+23,40
@@
#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;
};
};