/*
- Copyright (C) 2019 Carl Hetherington <cth@carlh.net>
+ Copyright (C) 2020 Carl Hetherington <cth@carlh.net>
This file is part of DCP-o-matic.
*/
#include "video_view.h"
-#include <wx/wx.h>
+#include "lib/signaller.h"
+#include "lib/position.h"
+#include "lib/warnings.h"
+DCPOMATIC_DISABLE_WARNINGS
#include <wx/glcanvas.h>
+#include <wx/wx.h>
+DCPOMATIC_ENABLE_WARNINGS
#include <dcp/util.h>
-#include <boost/shared_ptr.hpp>
+#include <boost/atomic.hpp>
#include <boost/thread.hpp>
+#include <boost/thread/condition.hpp>
#undef None
#undef Success
+#undef Status
class GLVideoView : public VideoView
{
GLVideoView (FilmViewer* viewer, wxWindow* parent);
~GLVideoView ();
- void set_image (boost::shared_ptr<const Image> image);
wxWindow* get () const {
return _canvas;
}
void update ();
void start ();
+ void stop ();
+
+ NextFrameResult display_next_frame (bool);
bool vsync_enabled () const {
return _vsync_enabled;
}
private:
- void paint ();
- void draw ();
+ void set_image (std::shared_ptr<const Image> image);
+ void set_image_and_draw ();
+ void draw (Position<int> inter_position, dcp::Size inter_size);
void thread ();
- wxGLContext* context () const;
+ void thread_playing ();
+ void request_one_shot ();
+ void check_for_butler_errors ();
+ void ensure_context ();
+ void size_changed (wxSizeEvent const &);
wxGLCanvas* _canvas;
-
wxGLContext* _context;
- mutable boost::mutex _context_mutex;
+
+ boost::atomic<wxSize> _canvas_size;
GLuint _id;
boost::optional<dcp::Size> _size;
+ bool _have_storage;
bool _vsync_enabled;
- boost::thread* _thread;
+ boost::thread _thread;
+
+ boost::mutex _playing_mutex;
+ boost::condition _thread_work_condition;
+ boost::atomic<bool> _playing;
+ boost::atomic<bool> _one_shot;
+
+ std::shared_ptr<wxTimer> _timer;
};