X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Fwx%2Fvideo_view.h;h=cf5e09da0a8ff9444a05839cc6bce12ad4cbe5f9;hb=b9a1ad3df5f9d85fb7439efd93fede72b9b078af;hp=2b4bd47179ae861c4bc5e68055a98a339cb47b7e;hpb=f7c43baf9b67505f04bb0954ab6e9e36f88efced;p=dcpomatic.git diff --git a/src/wx/video_view.h b/src/wx/video_view.h index 2b4bd4717..cf5e09da0 100644 --- a/src/wx/video_view.h +++ b/src/wx/video_view.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2019 Carl Hetherington + Copyright (C) 2019-2021 Carl Hetherington This file is part of DCP-o-matic. @@ -18,30 +18,40 @@ */ + #ifndef DCPOMATIC_VIDEO_VIEW_H #define DCPOMATIC_VIDEO_VIEW_H + #include "lib/dcpomatic_time.h" +#include "lib/exception_store.h" +#include "lib/signaller.h" #include "lib/timer.h" #include "lib/types.h" -#include "lib/exception_store.h" -#include +#include "lib/warnings.h" +DCPOMATIC_DISABLE_WARNINGS +#include +DCPOMATIC_ENABLE_WARNINGS #include #include -#include -class Image; -class wxWindow; + class FilmViewer; +class Image; class Player; class PlayerVideo; +class wxWindow; -class VideoView : public ExceptionStore, public boost::noncopyable + +class VideoView : public ExceptionStore, public Signaller { public: VideoView (FilmViewer* viewer); virtual ~VideoView () {} + VideoView (VideoView const&) = delete; + VideoView& operator= (VideoView const&) = delete; + /** @return the thing displaying the image */ virtual wxWindow* get () const = 0; /** Re-make and display the image from the current _player_video */ @@ -50,14 +60,23 @@ public: virtual void start (); /** Called when playback stops */ virtual void stop () {} + + enum NextFrameResult { + FAIL, + AGAIN, + SUCCESS + }; + /** Get the next frame and display it; used after seek */ - virtual bool display_next_frame (bool) = 0; + virtual NextFrameResult display_next_frame (bool) = 0; void clear (); - bool reset_metadata (boost::shared_ptr film, dcp::Size player_video_container_size); + bool reset_metadata (std::shared_ptr film, dcp::Size player_video_container_size); /** Emitted from the GUI thread when our display changes in size */ boost::signals2::signal Sized; + /** Emitted from the GUI thread when a lot of frames are being dropped */ + boost::signals2::signal TooManyDropped; /* Accessors for FilmViewer */ @@ -111,11 +130,25 @@ public: _three_d = t; } + void set_optimise_for_j2k (bool o) { + _optimise_for_j2k = o; + } + protected: - bool get_next_frame (bool non_blocking); + NextFrameResult get_next_frame (bool non_blocking); boost::optional time_until_next_frame () const; dcpomatic::DCPTime one_video_frame () const; + wxColour pad_colour () const; + + wxColour outline_content_colour () const { + return wxColour(255, 0, 0); + } + + wxColour outline_subtitles_colour () const { + return wxColour(0, 255, 0); + } + int video_frame_rate () const { boost::mutex::scoped_lock lm (_mutex); return _video_frame_rate; @@ -126,15 +159,12 @@ protected: return _length; } - std::pair, dcpomatic::DCPTime> player_video () const { + std::pair, dcpomatic::DCPTime> player_video () const { boost::mutex::scoped_lock lm (_mutex); return _player_video; } - void add_dropped () { - boost::mutex::scoped_lock lm (_mutex); - ++_dropped; - } + void add_dropped (); void add_get () { boost::mutex::scoped_lock lm (_mutex); @@ -145,20 +175,24 @@ protected: StateTimer _state_timer; + bool _optimise_for_j2k = false; + private: /** Mutex protecting all the state in this class */ mutable boost::mutex _mutex; - std::pair, dcpomatic::DCPTime> _player_video; - int _video_frame_rate; + std::pair, dcpomatic::DCPTime> _player_video; + int _video_frame_rate = 0; /** length of the film we are playing, or 0 if there is none */ dcpomatic::DCPTime _length; - Eyes _eyes; - bool _three_d; + Eyes _eyes = Eyes::LEFT; + bool _three_d = false; - int _dropped; - int _errored; - int _gets; + int _dropped = 0; + struct timeval _dropped_check_period_start; + int _errored = 0; + int _gets = 0; }; + #endif