X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Fwx%2Fcontrols.h;h=7ffe0c4ea5b1c8ebeaabc0c17a4e78230b7de64c;hb=9153a8a53ada73b4b016e7bb6faf1c2ed99f011b;hp=d916beaf8603d212566007883f072e053a5d1934;hpb=5feadb30fc839601345c4553c5a954ffc37bc1c7;p=dcpomatic.git diff --git a/src/wx/controls.h b/src/wx/controls.h index d916beaf8..7ffe0c4ea 100644 --- a/src/wx/controls.h +++ b/src/wx/controls.h @@ -18,9 +18,13 @@ */ +#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 #include #include @@ -32,6 +36,7 @@ class Content; class PlayerVideo; class wxToggleButton; class wxListCtrl; +class ContentView; namespace dcp { class CPL; @@ -46,14 +51,27 @@ public: bool editor_controls = true ); + virtual void log (wxString) {} + virtual void set_film (boost::shared_ptr film); boost::shared_ptr film () const; void back_frame (); void forward_frame (); - void show_extended_player_controls (bool s); - void log (wxString s); +protected: + virtual void started (); + virtual void stopped (); + virtual void setup_sensitivity (); + virtual void config_changed (int property); + + wxSizer* _v_sizer; + wxBoxSizer* _button_sizer; + boost::shared_ptr _film; + wxSlider* _slider; + boost::shared_ptr _viewer; + boost::optional _active_job; private: + void update_position_label (); void update_position_slider (); void rewind_clicked (wxMouseEvent &); @@ -61,80 +79,35 @@ private: void forward_clicked (wxKeyboardState &); void slider_moved (bool page); void slider_released (); - void play_clicked (); void frame_number_clicked (); void jump_to_selected_clicked (); - void setup_sensitivity (); void timecode_clicked (); -#ifndef DCPOMATIC_PLAYER_SWAROOP - void check_play_state (); -#endif void active_jobs_changed (boost::optional); DCPTime nudge_amount (wxKeyboardState& ev); void image_changed (boost::weak_ptr); - void film_change (ChangeType type, Film::Property p); void outline_content_changed (); void eye_changed (); void position_changed (); - void started (); - void stopped (); - void film_changed (); - void update_content_directory (); - void update_playlist_directory (); - void config_changed (int property); + void film_change (ChangeType, Film::Property); typedef std::pair, boost::filesystem::path> CPL; - boost::shared_ptr selected_content () const; -#ifdef DCPOMATIC_VARIANT_SWAROOP - void pause_clicked (); - void stop_clicked (); -#endif - void add_clicked (); - void save_clicked (); - void load_clicked (); - void add_content_to_list (boost::shared_ptr content, wxListCtrl* list); - void add_playlist_to_list (boost::shared_ptr film); - - boost::shared_ptr _film; - boost::shared_ptr _viewer; - - wxSizer* _v_sizer; bool _slider_being_moved; bool _was_running_before_slider; wxCheckBox* _outline_content; wxChoice* _eye; wxCheckBox* _jump_to_selected; - wxListCtrl* _content_view; - wxListCtrl* _spl_view; - wxListCtrl* _current_spl_view; - wxTextCtrl* _log; - wxButton* _add_button; - wxButton* _save_button; - wxButton* _load_button; - std::vector > _content; - std::vector > _playlists; - wxSlider* _slider; wxButton* _rewind_button; wxButton* _back_button; wxButton* _forward_button; wxStaticText* _frame_number; wxStaticText* _timecode; -#ifdef DCPOMATIC_VARIANT_SWAROOP - wxButton* _play_button; - wxButton* _pause_button; - wxButton* _stop_button; -#else - wxToggleButton* _play_button; -#endif - boost::optional _active_job; ClosedCaptionsDialog* _closed_captions_dialog; -#ifdef DCPOMATIC_VARIANT_SWAROOP - boost::optional _current_kind; -#endif - + boost::signals2::scoped_connection _film_change_connection; boost::signals2::scoped_connection _config_changed_connection; }; + +#endif