Merge master.
[dcpomatic.git] / src / wx / film_editor.h
index be4d14f99450731ba80c89a89f6b965ab42b517f..dadb583ae07b028f1c8324b1a0f30db6513c426e 100644 (file)
@@ -33,13 +33,11 @@ class wxNotebook;
 class wxListCtrl;
 class wxListEvent;
 class Film;
-class AudioDialog;
-class TimelineDialog;
-class AudioMappingView;
+class DCPTimelineDialog;
 class Ratio;
-class Timecode;
-class TimingPanel;
-class SubtitlePanel;
+class DCPTimecode;
+class FilmEditorPanel;
+class SubtitleContent;
 
 /** @class FilmEditor
  *  @brief A wx widget to edit a film's metadata, and perform various functions.
@@ -52,7 +50,7 @@ public:
        void set_film (boost::shared_ptr<Film>);
        void set_selection (boost::weak_ptr<Content>);
 
-       boost::signals2::signal<void (std::string)> FileChanged;
+       boost::signals2::signal<void (boost::filesystem::path)> FileChanged;
 
        /* Stuff for panels */
        
@@ -64,74 +62,60 @@ public:
                return _film;
        }
 
-       boost::shared_ptr<Content> selected_content ();
-       boost::shared_ptr<SubtitleContent> selected_subtitle_content ();
+       ContentList selected_content ();
+       VideoContentList selected_video_content ();
+       AudioContentList selected_audio_content ();
+       SubtitleContentList selected_subtitle_content ();
+       FFmpegContentList selected_ffmpeg_content ();
        
-       bool generally_sensitive () const {
-               return _generally_sensitive;
-       }
-
 private:
        void make_dcp_panel ();
        void make_content_panel ();
-       void make_video_panel ();
-       void make_audio_panel ();
        void connect_to_widgets ();
        
        /* Handle changes to the view */
-       void name_changed (wxCommandEvent &);
-       void use_dci_name_toggled (wxCommandEvent &);
-       void edit_dci_button_clicked (wxCommandEvent &);
-       void left_crop_changed (wxCommandEvent &);
-       void right_crop_changed (wxCommandEvent &);
-       void top_crop_changed (wxCommandEvent &);
-       void bottom_crop_changed (wxCommandEvent &);
-       void trust_content_headers_changed (wxCommandEvent &);
-       void content_selection_changed (wxListEvent &);
-       void content_add_clicked (wxCommandEvent &);
-       void content_remove_clicked (wxCommandEvent &);
-       void imagemagick_video_length_changed (wxCommandEvent &);
-       void container_changed (wxCommandEvent &);
-       void dcp_content_type_changed (wxCommandEvent &);
-       void scaler_changed (wxCommandEvent &);
-       void audio_gain_changed (wxCommandEvent &);
-       void audio_gain_calculate_button_clicked (wxCommandEvent &);
-       void show_audio_clicked (wxCommandEvent &);
-       void audio_delay_changed (wxCommandEvent &);
-       void j2k_bandwidth_changed (wxCommandEvent &);
-       void dcp_frame_rate_changed (wxCommandEvent &);
-       void best_dcp_frame_rate_clicked (wxCommandEvent &);
-       void edit_filters_clicked (wxCommandEvent &);
-       void content_timeline_clicked (wxCommandEvent &);
-       void audio_stream_changed (wxCommandEvent &);
-       void audio_mapping_changed (AudioMapping);
-       void start_changed ();
-       void length_changed ();
-       void ratio_changed (wxCommandEvent &);
-       void dcp_audio_channels_changed (wxCommandEvent &);
-       void dcp_resolution_changed (wxCommandEvent &);
-       void sequence_video_changed (wxCommandEvent &);
+       void name_changed ();
+       void use_dci_name_toggled ();
+       void edit_dci_button_clicked ();
+       void content_selection_changed ();
+       void content_add_file_clicked ();
+       void content_add_folder_clicked ();
+       void content_remove_clicked ();
+       void content_earlier_clicked ();
+       void content_later_clicked ();
+       void container_changed ();
+       void dcp_content_type_changed ();
+       void scaler_changed ();
+       void j2k_bandwidth_changed ();
+       void frame_rate_changed ();
+       void best_frame_rate_clicked ();
+       void content_timeline_clicked ();
+       void audio_channels_changed ();
+       void resolution_changed ();
+       void sequence_video_changed ();
        void content_right_click (wxListEvent &);
+       void three_d_changed ();
+       void standard_changed ();
+       void signed_toggled ();
+       void encrypted_toggled ();
 
        /* Handle changes to the model */
        void film_changed (Film::Property);
-       void film_content_changed (boost::weak_ptr<Content>, int);
+       void film_content_changed (int);
 
-       void set_things_sensitive (bool);
-       void setup_ratios ();
+       void set_general_sensitivity (bool);
        void setup_dcp_name ();
-       void setup_show_audio_sensitivity ();
-       void setup_scaling_description ();
        void setup_content ();
        void setup_container ();
        void setup_content_sensitivity ();
        
        void active_jobs_changed (bool);
-       boost::shared_ptr<VideoContent> selected_video_content ();
-       boost::shared_ptr<AudioContent> selected_audio_content ();
 
-       SubtitlePanel* _subtitle_panel;
-       TimingPanel* _timing_panel;
+       FilmEditorPanel* _video_panel;
+       FilmEditorPanel* _audio_panel;
+       FilmEditorPanel* _subtitle_panel;
+       FilmEditorPanel* _timing_panel;
+       std::list<FilmEditorPanel *> _panels;
 
        wxNotebook* _main_notebook;
        wxNotebook* _content_notebook;
@@ -139,8 +123,6 @@ private:
        wxSizer* _dcp_sizer;
        wxPanel* _content_panel;
        wxSizer* _content_sizer;
-       wxPanel* _video_panel;
-       wxPanel* _audio_panel;
 
        /** The film we are editing */
        boost::shared_ptr<Film> _film;
@@ -149,42 +131,30 @@ private:
        wxCheckBox* _use_dci_name;
        wxChoice* _container;
        wxListCtrl* _content;
-       wxButton* _content_add;
+       wxButton* _content_add_file;
+       wxButton* _content_add_folder;
        wxButton* _content_remove;
        wxButton* _content_earlier;
        wxButton* _content_later;
        wxButton* _content_timeline;
        wxCheckBox* _sequence_video;
        wxButton* _edit_dci_button;
-       wxChoice* _ratio;
-       wxStaticText* _ratio_description;
-       wxStaticText* _scaling_description;
-       wxSpinCtrl* _left_crop;
-       wxSpinCtrl* _right_crop;
-       wxSpinCtrl* _top_crop;
-       wxSpinCtrl* _bottom_crop;
-       wxStaticText* _filters;
-       wxButton* _filters_button;
        wxChoice* _scaler;
-       wxSpinCtrl* _audio_gain;
-       wxButton* _audio_gain_calculate_button;
-       wxButton* _show_audio;
-       wxSpinCtrl* _audio_delay;
-       wxSpinCtrl* _j2k_bandwidth;
+       wxSpinCtrl* _j2k_bandwidth;
        wxChoice* _dcp_content_type;
-       wxChoice* _dcp_frame_rate;
-       wxSpinCtrl* _dcp_audio_channels;
-       wxButton* _best_dcp_frame_rate;
-       wxChoice* _audio_stream;
-       wxStaticText* _audio_description;
-       AudioMappingView* _audio_mapping;
-       wxChoice* _dcp_resolution;
+       wxChoice* _frame_rate;
+       wxSpinCtrl* _audio_channels;
+       wxButton* _best_frame_rate;
+       wxCheckBox* _three_d;
+       wxChoice* _resolution;
+       wxChoice* _standard;
+       wxCheckBox* _signed;
+       wxCheckBox* _encrypted;
 
        ContentMenu _menu;
 
        std::vector<Ratio const *> _ratios;
 
        bool _generally_sensitive;
-       AudioDialog* _audio_dialog;
-       TimelineDialog* _timeline_dialog;
+       DCPTimelineDialog* _timeline_dialog;
 };