X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=gtk2_ardour%2Fstrip_silence_dialog.h;h=8179d2cbe2ee51ab5ba43ddc99574fc343a3938e;hb=abf1f286d49482ade939da7e49863a3d63048b42;hp=18313941c15496835ff148e240826e9ed0d85f15;hpb=83f385d26336f58c1b2e3ce49c609fe86878b56d;p=ardour.git diff --git a/gtk2_ardour/strip_silence_dialog.h b/gtk2_ardour/strip_silence_dialog.h index 18313941c1..8179d2cbe2 100644 --- a/gtk2_ardour/strip_silence_dialog.h +++ b/gtk2_ardour/strip_silence_dialog.h @@ -18,15 +18,14 @@ */ #include -#include +#include #include "ardour/types.h" #include "ardour_dialog.h" -#include "canvas.h" #include "progress_reporter.h" namespace ARDOUR { - class Session; + class Session; } class AudioClock; @@ -36,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 &); @@ -65,29 +67,35 @@ 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; pthread_t _thread; ///< thread to compute silence in the background static void * _detection_thread_work (void *); void * detection_thread_work (); - Glib::Mutex _lock; ///< lock held while the thread is doing work - Glib::Cond _run_cond; ///< condition to wake the thread + Glib::Threads::Mutex _lock; ///< lock held while the thread is doing work + Glib::Threads::Cond _run_cond; ///< condition to wake the thread bool _thread_should_finish; ///< true if the thread should terminate 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; };