X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fstrip_silence_dialog.h;h=7445b723277586767b28bff38bf3820839fed10d;hb=d4190d37612ac1b9f12f83d3952ed6584c085923;hp=1264525ff2236c5e1e84d6d163874774e7e17011;hpb=ed626628b54e67dd9621c08d82a42afaed00c7ac;p=ardour.git diff --git a/gtk2_ardour/strip_silence_dialog.h b/gtk2_ardour/strip_silence_dialog.h index 1264525ff2..7445b72327 100644 --- a/gtk2_ardour/strip_silence_dialog.h +++ b/gtk2_ardour/strip_silence_dialog.h @@ -18,43 +18,42 @@ */ #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; class RegionView; /// Dialog box to set options for the `strip silence' filter 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::framecnt_t fade_length () const; 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 &); @@ -63,30 +62,36 @@ private: void restart_thread (); Gtk::SpinButton _threshold; - AudioClock _minimum_length; - AudioClock _fade_length; + AudioClock* _minimum_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; };