Emit no audio from DCPs if none is mapped
[dcpomatic.git] / src / wx / audio_panel.h
index bc3bd97553ef114200f3ac72e572d50f3b9ff6fb..61dd2783ac8cd54d4ad5e20f8a884490ca7c3ffd 100644 (file)
 */
 
 
-#include "lib/audio_mapping.h"
 #include "content_sub_panel.h"
 #include "content_widget.h"
 #include "timecode.h"
+#include "lib/audio_mapping.h"
 
 
-class wxSpinCtrlDouble;
+class AudioDialog;
+class AudioMappingView;
+class CheckBox;
+class LanguageTagWidget;
 class wxButton;
 class wxChoice;
+class wxSpinCtrlDouble;
 class wxStaticText;
-class AudioMappingView;
-class AudioDialog;
-class LanguageTagWidget;
 
 
 class AudioPanel : public ContentSubPanel
 {
 public:
        explicit AudioPanel (ContentPanel *);
-       ~AudioPanel ();
 
        void create () override;
-       void film_changed (Film::Property) override;
+       void film_changed(FilmProperty) override;
        void film_content_changed (int) override;
        void content_selection_changed () override;
        void set_film (std::shared_ptr<Film>);
@@ -59,8 +59,9 @@ private:
        boost::optional<float> peak () const;
        void fade_in_changed ();
        void fade_out_changed ();
+       void use_same_fades_as_video_changed ();
 
-       wxCheckBox* _reference;
+       CheckBox* _reference;
        wxStaticText* _reference_note;
        wxButton* _show;
        wxStaticText* _gain_label;
@@ -75,10 +76,13 @@ private:
        Timecode<dcpomatic::ContentTime>* _fade_in;
        wxStaticText* _fade_out_label;
        Timecode<dcpomatic::ContentTime>* _fade_out;
+       CheckBox* _use_same_fades_as_video;
        AudioMappingView* _mapping;
        wxStaticText* _description;
-       AudioDialog* _audio_dialog;
+       wx_ptr<AudioDialog> _audio_dialog;
 
        boost::signals2::scoped_connection _mapping_connection;
        boost::signals2::scoped_connection _active_jobs_connection;
+
+       static std::map<boost::filesystem::path, float> _peak_cache;
 };