X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Fwx%2Fcontrols.h;h=377960425ba2807e5982ede7f25ffd4ec8e376a5;hb=c76a7e968f54eb0e6c8da9c1ae6bc069ed05fdda;hp=1b6a379cce5a8fc6db9e8b1fadb0b3c373660a76;hpb=1d796edf59da644e91bd443505fb76e0397a1439;p=dcpomatic.git diff --git a/src/wx/controls.h b/src/wx/controls.h index 1b6a379cc..377960425 100644 --- a/src/wx/controls.h +++ b/src/wx/controls.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2018 Carl Hetherington + Copyright (C) 2018-2021 Carl Hetherington This file is part of DCP-o-matic. @@ -18,17 +18,21 @@ */ + #ifndef DCPOMATIC_CONTROLS_H #define DCPOMATIC_CONTROLS_H + #include "lib/dcpomatic_time.h" #include "lib/types.h" #include "lib/film.h" -#include "lib/spl.h" +#include "lib/warnings.h" +DCPOMATIC_DISABLE_WARNINGS #include -#include +DCPOMATIC_ENABLE_WARNINGS #include + class FilmViewer; class Film; class ClosedCaptionsDialog; @@ -38,31 +42,34 @@ class wxToggleButton; class wxListCtrl; class ContentView; + namespace dcp { class CPL; } + class Controls : public wxPanel { public: Controls ( wxWindow* parent, - boost::shared_ptr, + std::shared_ptr, bool editor_controls = true ); virtual void log (wxString) {} - virtual void set_film (boost::shared_ptr film); -#ifdef DCPOMATIC_PLAYER_STRESS_TEST + virtual void set_film (std::shared_ptr film); + virtual void play () {}; virtual void stop () {}; void seek (int slider); -#endif - boost::shared_ptr film () const; + + std::shared_ptr film () const; void back_frame (); void forward_frame (); protected: + virtual void started (); virtual void stopped (); virtual void setup_sensitivity (); @@ -70,9 +77,9 @@ protected: wxSizer* _v_sizer; wxBoxSizer* _button_sizer; - boost::shared_ptr _film; + std::shared_ptr _film; wxSlider* _slider; - boost::shared_ptr _viewer; + std::weak_ptr _viewer; boost::optional _active_job; private: @@ -89,13 +96,13 @@ private: void timecode_clicked (); void active_jobs_changed (boost::optional); dcpomatic::DCPTime nudge_amount (wxKeyboardState& ev); - void image_changed (boost::weak_ptr); + void image_changed (std::weak_ptr); void outline_content_changed (); void eye_changed (); void update_position (); void film_change (ChangeType, Film::Property); - typedef std::pair, boost::filesystem::path> CPL; + typedef std::pair, boost::filesystem::path> CPL; bool _slider_being_moved; @@ -116,4 +123,5 @@ private: boost::signals2::scoped_connection _config_changed_connection; }; + #endif