X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fregion_view.h;h=1eda8fd3606c5f4d80193d4686326e4bc2035b1b;hb=25eb9f406960aa8e36ccd90e2cd4397f372bd0fa;hp=60de56d76f329832ecaeebc3cb389b74e2773c54;hpb=e131fd391ded68c2a0634f26edb03410b5f46349;p=ardour.git diff --git a/gtk2_ardour/region_view.h b/gtk2_ardour/region_view.h index 60de56d76f..1eda8fd360 100644 --- a/gtk2_ardour/region_view.h +++ b/gtk2_ardour/region_view.h @@ -38,6 +38,10 @@ class GhostRegion; class AutomationTimeAxisView; class AutomationRegionView; +namespace Gnome { namespace Canvas { + class NoEventText; +} } + class RegionView : public TimeAxisViewItem { public: @@ -92,22 +96,32 @@ class RegionView : public TimeAxisViewItem static PBD::Signal1 RegionViewGoingAway; - ARDOUR::BeatsFramesConverter const & time_converter () { - return _time_converter; + ARDOUR::BeatsFramesConverter const & region_relative_time_converter () const { + return _region_relative_time_converter; + } + + ARDOUR::BeatsFramesConverter const & source_relative_time_converter () const { + return _source_relative_time_converter; } - /** Called when a start trim is about to begin */ - virtual void trim_start_starting () {} + /** Called when a front trim is about to begin */ + virtual void trim_front_starting () {} - void trim_start (framepos_t, bool); + bool trim_front (framepos_t, bool); /** Called when a start trim has finished */ - virtual void trim_start_ending () {} - - void trim_end (framepos_t, bool); + virtual void trim_front_ending () {} + + bool trim_end (framepos_t, bool); void trim_contents (framepos_t, bool, bool); virtual void thaw_after_trim (); + void set_silent_frames (const ARDOUR::AudioIntervalResult&, double threshold); + void drop_silent_frames (); + void hide_silent_frames (); + + ARDOUR::frameoffset_t snap_frame_to_frame (ARDOUR::frameoffset_t) const; + protected: /** Allows derived types to specify their visibility requirements @@ -120,32 +134,32 @@ class RegionView : public TimeAxisViewItem Gdk::Color const & basic_color, bool recording, TimeAxisViewItem::Visibility); - + virtual void region_resized (const PBD::PropertyChange&); virtual void region_muted (); void region_locked (); void region_opacity (); virtual void region_renamed (); void region_sync_changed (); - + std::string make_name () const; - + static gint _lock_toggle (ArdourCanvas::Item*, GdkEvent*, void*); void lock_toggle (); - + virtual void set_colors (); virtual void set_frame_color (); virtual void reset_width_dependent_items (double pixel_width); - + virtual void color_handler () {} - + boost::shared_ptr _region; - + ArdourCanvas::Polygon* sync_mark; ///< polgyon for sync position ArdourCanvas::Line* sync_line; ///< polgyon for sync position - + RegionEditor* editor; - + std::vector control_points; double current_visible_sync_position; @@ -153,18 +167,29 @@ class RegionView : public TimeAxisViewItem bool _enable_display; ///< see StreamView::redisplay_diskstream() double _pixel_width; bool in_destructor; - + bool wait_for_data; - + std::vector ghosts; - + /** a list of rectangles which are used in stacked display mode to colour different bits of regions according to whether or not they are the one that will be played at any given time. */ std::list _coverage_frames; - ARDOUR::BeatsFramesConverter _time_converter; + /** a list of rectangles used to show silent segments + */ + std::list _silent_frames; + /** a list of rectangles used to show the current silence threshold + */ + std::list _silent_threshold_frames; + /** a text item to display strip silence statistics + */ + ArdourCanvas::NoEventText* _silence_text; + + ARDOUR::BeatsFramesConverter _region_relative_time_converter; + ARDOUR::BeatsFramesConverter _source_relative_time_converter; }; #endif /* __gtk_ardour_region_view_h__ */