X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fregion_view.h;h=98329ee77bd74e03e72e2d3772d28651d9a71003;hb=4f3bddf7ef163c3106ba973123cbc657ebaf4b74;hp=74073b404e7ad9029e1f10b58141ccff0c2b5df3;hpb=99904735e066804358f1d0bd138a84f1e9ecda91;p=ardour.git diff --git a/gtk2_ardour/region_view.h b/gtk2_ardour/region_view.h index 74073b404e..98329ee77b 100644 --- a/gtk2_ardour/region_view.h +++ b/gtk2_ardour/region_view.h @@ -24,19 +24,19 @@ #include #include #include -#include +#include "ardour/region.h" +#include "ardour/beats_frames_converter.h" #include "time_axis_view_item.h" #include "automation_line.h" #include "enums.h" -#include "waveview.h" #include "canvas.h" -#include "color.h" class TimeAxisView; class RegionEditor; class GhostRegion; class AutomationTimeAxisView; +class AutomationRegionView; class RegionView : public TimeAxisViewItem { @@ -45,90 +45,95 @@ class RegionView : public TimeAxisViewItem TimeAxisView& time_view, boost::shared_ptr region, double samples_per_unit, - Gdk::Color& basic_color); + Gdk::Color const & basic_color); RegionView (const RegionView& other); + RegionView (const RegionView& other, boost::shared_ptr other_region); ~RegionView (); - virtual void init (Gdk::Color& base_color, bool wait_for_data); + virtual void init (Gdk::Color const & base_color, bool wait_for_data); boost::shared_ptr region() const { return _region; } bool is_valid() const { return valid; } - void set_valid (bool yn) { valid = yn; } - virtual void set_height (double); - virtual void set_samples_per_unit (double); - virtual bool set_duration (nframes_t, void*); - - void move (double xdelta, double ydelta); - - void raise (); - void raise_to_top (); - void lower (); - void lower_to_bottom (); - - bool set_position(nframes_t pos, void* src, double* delta = 0); - void fake_set_opaque (bool yn); - - virtual void show_region_editor () = 0; - virtual void hide_region_editor(); - - virtual void region_changed (ARDOUR::Change); - - virtual GhostRegion* add_ghost (AutomationTimeAxisView&) = 0; - void remove_ghost (GhostRegion*); + void set_valid (bool yn) { valid = yn; } + + virtual void set_height (double); + virtual void set_samples_per_unit (double); + virtual bool set_duration (nframes_t, void*); + + void move (double xdelta, double ydelta); + + void raise_to_top (); + void lower_to_bottom (); - uint32_t get_fill_color (); + bool set_position(nframes_t pos, void* src, double* delta = 0); + void fake_set_opaque (bool yn); + + virtual void show_region_editor () {} + virtual void hide_region_editor(); + + virtual void region_changed (ARDOUR::Change); + + virtual GhostRegion* add_ghost (TimeAxisView&) = 0; + void remove_ghost_in (TimeAxisView&); + void remove_ghost (GhostRegion*); + + uint32_t get_fill_color (); - virtual void entered () {} - virtual void exited () {} - - static sigc::signal RegionViewGoingAway; - sigc::signal GoingAway; + virtual void entered () {} + virtual void exited () {} + void enable_display(bool yn) { _enable_display = yn; } + void update_coverage_frames (LayerDisplay); + + static sigc::signal RegionViewGoingAway; + protected: - - /** Allows derived types to specify their visibility requirements + + /** Allows derived types to specify their visibility requirements * to the TimeAxisViewItem parent class */ RegionView (ArdourCanvas::Group *, TimeAxisView&, boost::shared_ptr, - double samples_per_unit, - Gdk::Color& basic_color, + double samples_per_unit, + Gdk::Color const & basic_color, + bool recording, TimeAxisViewItem::Visibility); virtual void region_resized (ARDOUR::Change); - void region_moved (void *); virtual void region_muted (); void region_locked (); void region_opacity (); - void region_layered (); virtual void region_renamed (); void region_sync_changed (); + Glib::ustring make_name () const; + static gint _lock_toggle (ArdourCanvas::Item*, GdkEvent*, void*); void lock_toggle (); virtual void set_colors (); - virtual void compute_colors (Gdk::Color&); virtual void set_frame_color (); virtual void reset_width_dependent_items (double pixel_width); - virtual void color_handler (ColorID, uint32_t) {} + 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; - vector control_points; + std::vector control_points; double current_visible_sync_position; - bool valid; ///< see StreamView::redisplay_diskstream() + bool valid; ///< see StreamView::redisplay_diskstream() + bool _enable_display; ///< see StreamView::redisplay_diskstream() double _pixel_width; double _height; bool in_destructor; @@ -136,7 +141,15 @@ class RegionView : public TimeAxisViewItem bool wait_for_data; sigc::connection data_ready_connection; - vector ghosts; + 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; }; #endif /* __gtk_ardour_region_view_h__ */