Preference Dropdown to limit Automatable Parameters
[ardour.git] / gtk2_ardour / strip_silence_dialog.h
index 8b2e43ac6470a31dc3b65274b9ff7f09545486ed..8179d2cbe2ee51ab5ba43ddc99574fc343a3938e 100644 (file)
@@ -25,7 +25,7 @@
 #include "progress_reporter.h"
 
 namespace ARDOUR {
-        class Session;
+       class Session;
 }
 
 class AudioClock;
@@ -35,26 +35,29 @@ class RegionView;
 class StripSilenceDialog : public ArdourDialog, public ProgressReporter
 {
 public:
-        StripSilenceDialog (ARDOUR::Session*, std::list<RegionView*> const &);
+       StripSilenceDialog (ARDOUR::Session*, std::list<RegionView*> const &);
        ~StripSilenceDialog ();
 
        double threshold () const {
                return _threshold.get_value ();
        }
 
-        void drop_rects ();
+       void drop_rects ();
 
-        void silences (ARDOUR::AudioIntervalMap&);
+       void silences (ARDOUR::AudioIntervalMap&);
 
-       ARDOUR::framecnt_t minimum_length () const;
-        ARDOUR::framecnt_t fade_length () const;
+       ARDOUR::samplecnt_t minimum_length () const;
+       ARDOUR::samplecnt_t fade_length () const;
+
+       void on_response (int response_id) {
+               Gtk::Dialog::on_response (response_id);
+       }
 
 private:
        void create_waves ();
-       void peaks_ready ();
        void canvas_allocation (Gtk::Allocation &);
        void update_silence_rects ();
-        void resize_silence_rects ();
+       void resize_silence_rects ();
        void update ();
        void update_threshold_line ();
        void update_stats (ARDOUR::AudioIntervalResult const &);
@@ -64,19 +67,20 @@ private:
 
        Gtk::SpinButton _threshold;
        AudioClock*      _minimum_length;
-        AudioClock*      _fade_length;
+       AudioClock*      _fade_length;
        Gtk::ProgressBar _progress_bar;
 
-        struct ViewInterval {
-            RegionView* view;
-            ARDOUR::AudioIntervalResult intervals;
+       Gtk::Button* cancel_button;
+       Gtk::Button* apply_button;
 
-            ViewInterval (RegionView* rv) : view (rv) {}
-        };
+       struct ViewInterval {
+               RegionView* view;
+               ARDOUR::AudioIntervalResult intervals;
 
-        std::list<ViewInterval> views;
+               ViewInterval (RegionView* rv) : view (rv) {}
+       };
 
-       PBD::ScopedConnection* _peaks_ready_connection;
+       std::list<ViewInterval> views;
 
        bool _destroying;
 
@@ -89,4 +93,9 @@ private:
        PBD::Signal0<void> Completed; ///< emitted when a silence detection has completed
        PBD::ScopedConnection _completed_connection;
        ARDOUR::InterThreadInfo _interthread_info;
+
+       sigc::connection progress_idle_connection;
+       bool idle_update_progress(); ///< GUI-thread progress updates of background silence computation
+       int analysis_progress_cur;
+       int analysis_progress_max;
 };