#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
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 multiple_reels_toggled (wxCommandEvent &);
+ void reel_size_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_reel_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;
/** 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 */
wxButton* _filters_button;
/** The Film's scaler */
wxComboBox* _scaler;
+ wxRadioButton* _use_content_audio;
+ wxComboBox* _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;
+ wxComboBox* _subtitle_stream;
+ wxSpinCtrl* _subtitle_offset;
+ wxSpinCtrl* _subtitle_scale;
+ wxComboBox* _colour_lut;
+ wxSpinCtrl* _j2k_bandwidth;
/** 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 */
/** 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;
+ wxCheckBox* _multiple_reels;
+ wxSpinCtrl* _reel_size;
/** 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;
};