X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fautomation_region_view.h;h=a41c57c7823b0d861a97741a8d85e5f777fff541;hb=d953f1ce0e65d59c529f40ddc8da0e80db0dfbfb;hp=571a80709a3149d246bb339d6697191fa5c95832;hpb=ea1ccb869a152d7344f498d2a062867f5bcf9d0b;p=ardour.git diff --git a/gtk2_ardour/automation_region_view.h b/gtk2_ardour/automation_region_view.h index 571a80709a..a41c57c782 100644 --- a/gtk2_ardour/automation_region_view.h +++ b/gtk2_ardour/automation_region_view.h @@ -37,17 +37,30 @@ class TimeAxisView; class AutomationRegionView : public RegionView { public: - AutomationRegionView(ArdourCanvas::Group*, + AutomationRegionView(ArdourCanvas::Container*, AutomationTimeAxisView&, boost::shared_ptr, const Evoral::Parameter& parameter, boost::shared_ptr, double initial_samples_per_pixel, - Gdk::Color const & basic_color); + uint32_t basic_color); ~AutomationRegionView(); - void init (Gdk::Color const & basic_color, bool wfd); + void init (bool wfd); + + bool paste (framepos_t pos, + unsigned paste_count, + float times, + boost::shared_ptr slist); + + ARDOUR::DoubleBeatsFramesConverter const & region_relative_time_converter () const { + return _region_relative_time_converter; + } + + ARDOUR::DoubleBeatsFramesConverter const & source_relative_time_converter () const { + return _source_relative_time_converter; + } inline AutomationTimeAxisView* automation_view() const { return dynamic_cast(&trackview); } @@ -55,7 +68,7 @@ public: boost::shared_ptr line() { return _line; } // We are a ghost. Meta ghosts? Crazy talk. - virtual GhostRegion* add_ghost(TimeAxisView&) { return NULL; } + virtual GhostRegion* add_ghost(TimeAxisView&) { return 0; } void set_height (double); void reset_width_dependent_items(double pixel_width); @@ -64,14 +77,16 @@ protected: void create_line(boost::shared_ptr list); bool set_position(framepos_t pos, void* src, double* ignored); void region_resized (const PBD::PropertyChange&); - bool canvas_event(GdkEvent* ev); - void add_automation_event (GdkEvent* event, framepos_t when, double y); + bool canvas_group_event(GdkEvent* ev); + void add_automation_event (GdkEvent* event, framepos_t when, double y, bool with_guard_points); void entered (bool); void exited(); private: - Evoral::Parameter _parameter; - boost::shared_ptr _line; + ARDOUR::DoubleBeatsFramesConverter _region_relative_time_converter; + ARDOUR::DoubleBeatsFramesConverter _source_relative_time_converter; + Evoral::Parameter _parameter; + boost::shared_ptr _line; }; #endif /* __gtk_ardour_automation_region_view_h__ */