X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Fwx%2Ffilm_editor.h;h=576cd5ba1b251bab083dec3cab431049bda02ca4;hb=15a5f157f7867a05211ce494d9d86b9c47fdf72b;hp=c2d064ca202bc1d3305c52182b35092ecaa088e1;hpb=aabf54736d7401437af7f066c51fee91be64e809;p=dcpomatic.git diff --git a/src/wx/film_editor.h b/src/wx/film_editor.h index c2d064ca2..576cd5ba1 100644 --- a/src/wx/film_editor.h +++ b/src/wx/film_editor.h @@ -1,36 +1,36 @@ /* - Copyright (C) 2012 Carl Hetherington + Copyright (C) 2012-2015 Carl Hetherington - This program is free software; you can redistribute it and/or modify + This file is part of DCP-o-matic. + + DCP-o-matic is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. - This program is distributed in the hope that it will be useful, + DCP-o-matic is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + along with DCP-o-matic. If not, see . */ -/** @file src/film_editor.h - * @brief A wx widget to edit a film's metadata, and perform various functions. +/** @file src/wx/film_editor.h + * @brief FilmEditor class. */ +#include "lib/film.h" #include -#include -#include -#include #include -#include "lib/film.h" class wxNotebook; class Film; -class AudioDialog; +class ContentPanel; +class DCPPanel; +class FilmViewer; /** @class FilmEditor * @brief A wx widget to edit a film's metadata, and perform various functions. @@ -38,161 +38,34 @@ class AudioDialog; class FilmEditor : public wxPanel { public: - FilmEditor (boost::shared_ptr, wxWindow *); + FilmEditor (wxWindow *, FilmViewer* viewer); void set_film (boost::shared_ptr); - void setup_visibility (); - - boost::signals2::signal 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 trust_content_header_changed (wxCommandEvent &); - void format_changed (wxCommandEvent &); - void trim_start_changed (wxCommandEvent &); - void trim_end_changed (wxCommandEvent &); - void trim_type_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 show_audio_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 &); - void dcp_frame_rate_changed (wxCommandEvent &); - void best_dcp_frame_rate_clicked (wxCommandEvent &); - void pad_with_silence_toggled (wxCommandEvent &); - void minimum_audio_channels_changed (wxCommandEvent &); + + boost::signals2::signal FileChanged; + boost::signals2::signal SelectionChanged; + + /* Stuff for panels */ + + ContentPanel* content_panel () const { + return _content_panel; + } + + boost::shared_ptr film () const { + return _film; + } /* Handle changes to the model */ void film_changed (Film::Property); + void film_content_changed (int); + + void set_general_sensitivity (bool); + void active_jobs_changed (boost::optional); - /* Button clicks */ - void edit_filters_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 (); - void setup_dcp_name (); - void setup_show_audio_sensitivity (); - void setup_scaling_description (); - void setup_notebook_size (); - void setup_frame_rate_description (); - void setup_minimum_audio_channels (); - - 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; + wxNotebook* _main_notebook; + ContentPanel* _content_panel; + DCPPanel* _dcp_panel; /** The film we are editing */ boost::shared_ptr _film; - /** The Film's name */ - wxTextCtrl* _name; - wxStaticText* _dcp_name; - wxCheckBox* _use_dci_name; - wxButton* _edit_dci_button; - /** The Film's format */ - wxChoice* _format; - wxStaticText* _scaling_description; - /** The Film's content file */ - wxFilePickerCtrl* _content; - wxCheckBox* _trust_content_header; - /** The Film's left crop */ - wxSpinCtrl* _left_crop; - /** The Film's right crop */ - wxSpinCtrl* _right_crop; - /** The Film's top crop */ - wxSpinCtrl* _top_crop; - /** The Film's bottom crop */ - wxSpinCtrl* _bottom_crop; - /** Currently-applied filters */ - wxStaticText* _filters; - /** Button to open the filters dialogue */ - wxButton* _filters_button; - /** The Film's 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; - wxButton* _show_audio; - /** 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 */ - wxChoice* _dcp_content_type; - /** The Film's source frame rate */ - wxStaticText* _source_frame_rate; - wxChoice* _dcp_frame_rate; - wxButton* _best_dcp_frame_rate; - wxCheckBox* _pad_with_silence; - wxSpinCtrl* _minimum_audio_channels; - wxStaticText* _frame_rate_description; - /** The Film's length */ - wxStaticText* _length; - /** The Film's audio details */ - wxStaticText* _audio; - /** The Film's duration for still sources */ - wxSpinCtrl* _still_duration; - - wxSpinCtrl* _trim_start; - wxSpinCtrl* _trim_end; - wxChoice* _trim_type; - /** Selector to generate an A/B comparison DCP */ - wxCheckBox* _dcp_ab; - - std::list _video_controls; - std::list _still_controls; - - std::vector _formats; - - bool _generally_sensitive; - AudioDialog* _audio_dialog; };