X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fstrip_silence_dialog.h;h=8179d2cbe2ee51ab5ba43ddc99574fc343a3938e;hb=63a4cc9cf6e02153a6c647867abfec6b013e0708;hp=8b2e43ac6470a31dc3b65274b9ff7f09545486ed;hpb=b880a381523b2cfdb7ebd17c27fff1adf90fa028;p=ardour.git diff --git a/gtk2_ardour/strip_silence_dialog.h b/gtk2_ardour/strip_silence_dialog.h index 8b2e43ac64..8179d2cbe2 100644 --- a/gtk2_ardour/strip_silence_dialog.h +++ b/gtk2_ardour/strip_silence_dialog.h @@ -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 const &); + StripSilenceDialog (ARDOUR::Session*, std::list 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 views; + ViewInterval (RegionView* rv) : view (rv) {} + }; - PBD::ScopedConnection* _peaks_ready_connection; + std::list views; bool _destroying; @@ -89,4 +93,9 @@ private: PBD::Signal0 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; };