Merge master into direct-mxf.
[dcpomatic.git] / src / wx / film_editor.h
index c0e4ec3b4fd477c70f088a38bcab96d0c14d2a24..90be752d832a84d20611a9164016294bcab53607 100644 (file)
 
 #include <wx/wx.h>
 #include <wx/spinctrl.h>
-#include "lib/trim_action.h"
+#include <wx/filepicker.h>
+#include <wx/collpane.h>
+#include <boost/signals2.hpp>
 #include "lib/film.h"
 
+class wxNotebook;
+
 class Film;
 
 /** @class FilmEditor
@@ -34,53 +38,90 @@ class Film;
 class FilmEditor : public wxPanel
 {
 public:
-       FilmEditor (Film *, wxWindow *);
+       FilmEditor (boost::shared_ptr<Film>, wxWindow *);
 
-       void set_film (Film *);
+       void set_film (boost::shared_ptr<Film>);
        void setup_visibility ();
 
-//XXX  sigc::signal1<void, std::string> FileChanged;
+       boost::signals2::signal<void (std::string)> FileChanged;
 
 private:
+       void make_film_panel ();
+       void make_video_panel ();
+       void make_audio_panel ();
+       void make_subtitle_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 content_changed (wxCommandEvent &);
-       void frames_per_second_changed (wxCommandEvent &);
+       void trust_content_header_changed (wxCommandEvent &);
        void format_changed (wxCommandEvent &);
-       void dcp_range_changed (int, TrimAction);
+       void trim_start_changed (wxCommandEvent &);
+       void trim_end_changed (wxCommandEvent &);
        void dcp_content_type_changed (wxCommandEvent &);
        void dcp_ab_toggled (wxCommandEvent &);
        void scaler_changed (wxCommandEvent &);
        void audio_gain_changed (wxCommandEvent &);
+       void audio_gain_calculate_button_clicked (wxCommandEvent &);
        void audio_delay_changed (wxCommandEvent &);
+       void with_subtitles_toggled (wxCommandEvent &);
+       void subtitle_offset_changed (wxCommandEvent &);
+       void subtitle_scale_changed (wxCommandEvent &);
+       void colour_lut_changed (wxCommandEvent &);
+       void j2k_bandwidth_changed (wxCommandEvent &);
        void still_duration_changed (wxCommandEvent &);
+       void audio_stream_changed (wxCommandEvent &);
+       void subtitle_stream_changed (wxCommandEvent &);
+       void use_audio_changed (wxCommandEvent &);
+       void external_audio_changed (wxCommandEvent &);
 
        /* Handle changes to the model */
        void film_changed (Film::Property);
 
        /* Button clicks */
        void edit_filters_clicked (wxCommandEvent &);
-       void change_dcp_range_clicked (wxCommandEvent &);
 
        void set_things_sensitive (bool);
-
+       void setup_formats ();
+       void setup_subtitle_control_sensitivity ();
+       void setup_audio_control_sensitivity ();
+       void setup_streams ();
+       void setup_audio_details ();
+       
        wxControl* video_control (wxControl *);
        wxControl* still_control (wxControl *);
 
+       void active_jobs_changed (bool);
+
+       wxNotebook* _notebook;
+       wxPanel* _film_panel;
+       wxSizer* _film_sizer;
+       wxPanel* _video_panel;
+       wxSizer* _video_sizer;
+       wxPanel* _audio_panel;
+       wxSizer* _audio_sizer;
+       wxPanel* _subtitle_panel;
+       wxSizer* _subtitle_sizer;
+
        /** The film we are editing */
-       Film* _film;
+       boost::shared_ptr<Film> _film;
        /** The Film's name */
        wxTextCtrl* _name;
-       /** The Film's frames per second */
-       wxSpinCtrl* _frames_per_second;
+       wxStaticText* _dcp_name;
+       wxCheckBox* _use_dci_name;
+       wxButton* _edit_dci_button;
        /** The Film's format */
-       wxComboBox* _format;
+       wxChoice* _format;
        /** The Film's content file */
-       wxFileCtrl* _content;
+       wxFilePickerCtrl* _content;
+       wxCheckBox* _trust_content_header;
        /** The Film's left crop */
        wxSpinCtrl* _left_crop;
        /** The Film's right crop */
@@ -94,13 +135,27 @@ private:
        /** Button to open the filters dialogue */
        wxButton* _filters_button;
        /** The Film's scaler */
-       wxComboBox* _scaler;
+       wxChoice* _scaler;
+       wxRadioButton* _use_content_audio;
+       wxChoice* _audio_stream;
+       wxRadioButton* _use_external_audio;
+       wxFilePickerCtrl* _external_audio[MAX_AUDIO_CHANNELS];
        /** The Film's audio gain */
        wxSpinCtrl* _audio_gain;
+       /** A button to open the gain calculation dialogue */
+       wxButton* _audio_gain_calculate_button;
        /** The Film's audio delay */
        wxSpinCtrl* _audio_delay;
+       wxCheckBox* _with_subtitles;
+       wxChoice* _subtitle_stream;
+       wxSpinCtrl* _subtitle_offset;
+       wxSpinCtrl* _subtitle_scale;
+       wxChoice* _colour_lut;
+       wxSpinCtrl* _j2k_bandwidth;
        /** The Film's DCP content type */
-       wxComboBox* _dcp_content_type;
+       wxChoice* _dcp_content_type;
+       /** The Film's frames per second */
+       wxStaticText* _frames_per_second;
        /** The Film's original size */
        wxStaticText* _original_size;
        /** The Film's length */
@@ -110,27 +165,15 @@ private:
        /** The Film's duration for still sources */
        wxSpinCtrl* _still_duration;
 
-       /** Display of the range of frames that will be used */
-       wxStaticText* _dcp_range;
-       /** Button to change the range */
-       wxButton* _change_dcp_range_button;
+       wxSpinCtrl* _trim_start;
+       wxSpinCtrl* _trim_end;
        /** Selector to generate an A/B comparison DCP */
        wxCheckBox* _dcp_ab;
 
-       wxFlexGridSizer* _sizer;
-       wxPanel* _audio_gain_panel;
-       wxBoxSizer* _audio_gain_sizer;
-       wxPanel* _audio_delay_panel;
-       wxBoxSizer* _audio_delay_sizer;
-       wxPanel* _filters_panel;
-       wxSizer* _filters_sizer;
-       wxSizer* _crop_sizer;
-       wxPanel* _crop_panel;
-       wxPanel* _dcp_range_panel;
-       wxSizer* _dcp_range_sizer;
-
        std::list<wxControl*> _video_controls;
        std::list<wxControl*> _still_controls;
 
-       std::list<wxControl*> _labels;
+       std::vector<Format const *> _formats;
+
+       bool _generally_sensitive;
 };