Clumsy DCI naming dialog.
[dcpomatic.git] / src / wx / film_editor.h
index 2227a6d647544d8ce85032a550110d0c45e6c3ba..2d13d2dc9fbc91d6727a4bc86e6a3554e5192294 100644 (file)
@@ -23,6 +23,8 @@
 
 #include <wx/wx.h>
 #include <wx/spinctrl.h>
+#include <wx/filepicker.h>
+#include <wx/collpane.h>
 #include "lib/trim_action.h"
 #include "lib/film.h"
 
@@ -39,24 +41,29 @@ public:
        void set_film (Film *);
        void setup_visibility ();
 
-//XXX  sigc::signal1<void, std::string> FileChanged;
+       sigc::signal1<void, std::string> FileChanged;
 
 private:
        /* 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 format_changed (wxCommandEvent &);
        void dcp_range_changed (int, TrimAction);
        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 still_duration_changed (wxCommandEvent &);
 
        /* Handle changes to the model */
@@ -67,20 +74,24 @@ private:
        void change_dcp_range_clicked (wxCommandEvent &);
 
        void set_things_sensitive (bool);
-
+       void setup_formats ();
+       void setup_subtitle_button ();
+       
        wxControl* video_control (wxControl *);
        wxControl* still_control (wxControl *);
 
+       Film::Property _ignore_changes;
+
        /** The film we are editing */
        Film* _film;
        /** The Film's name */
        wxTextCtrl* _name;
-       /** The Film's frames per second */
-       wxSpinCtrl* _frames_per_second;
+       wxCheckBox* _use_dci_name;
+       wxButton* _edit_dci_button;
        /** The Film's format */
        wxComboBox* _format;
        /** The Film's content file */
-       wxFileCtrl* _content;
+       wxFilePickerCtrl* _content;
        /** The Film's left crop */
        wxSpinCtrl* _left_crop;
        /** The Film's right crop */
@@ -97,10 +108,17 @@ private:
        wxComboBox* _scaler;
        /** 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;
+       wxSpinCtrl* _subtitle_offset;
+       wxSpinCtrl* _subtitle_scale;
        /** The Film's DCP content type */
        wxComboBox* _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 */
@@ -117,24 +135,10 @@ private:
        /** Selector to generate an A/B comparison DCP */
        wxCheckBox* _dcp_ab;
 
-       wxFlexGridSizer* _sizer;
-       wxStaticText* _name_label;
-       wxStaticText* _content_label;
-       wxStaticText* _dcp_content_type_label;
-       wxStaticText* _frames_per_second_label;
-       wxStaticText* _format_label;
-       wxStaticText* _crop_label;
-       wxSizer* _crop_sizer;
-       wxPanel* _crop_panel;
-       wxStaticText* _left_crop_label;
-       wxStaticText* _right_crop_label;
-       wxStaticText* _top_crop_label;
-       wxStaticText* _bottom_crop_label;
-       wxStaticText* _filters_label;
-       wxStaticText* _scaler_label;
-
        std::list<wxControl*> _video_controls;
        std::list<wxControl*> _still_controls;
 
-       std::list<wxControl*> _labels;
+       std::vector<Format const *> _formats;
+
+       wxSizer* _sizer;
 };