X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fautomation_region_view.h;h=ce34e763d3b29ce15acd385630bda98e98cc9ce4;hb=b68b4d10a2f5a9d630b6ad22674f5fdf39a67aae;hp=21c1bfcd878b0b7fa783ce525976573bc45e7028;hpb=c0e6f8e4c324c3f44613949b59acd9e864ab263d;p=ardour.git diff --git a/gtk2_ardour/automation_region_view.h b/gtk2_ardour/automation_region_view.h index 21c1bfcd87..ce34e763d3 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 (samplepos_t pos, + unsigned paste_count, + float times, + boost::shared_ptr slist); + + ARDOUR::DoubleBeatsSamplesConverter const & region_relative_time_converter () const { + return _region_relative_time_converter; + } + + ARDOUR::DoubleBeatsSamplesConverter const & source_relative_time_converter () const { + return _source_relative_time_converter; + } inline AutomationTimeAxisView* automation_view() const { return dynamic_cast(&trackview); } @@ -57,21 +70,27 @@ public: // We are a ghost. Meta ghosts? Crazy talk. virtual GhostRegion* add_ghost(TimeAxisView&) { return 0; } + uint32_t get_fill_color() const; + void set_height (double); void reset_width_dependent_items(double pixel_width); protected: void create_line(boost::shared_ptr list); - bool set_position(framepos_t pos, void* src, double* ignored); + bool set_position(samplepos_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); - void entered (bool); + bool canvas_group_event(GdkEvent* ev); + void add_automation_event (GdkEvent* event, samplepos_t when, double y, bool with_guard_points); + void mouse_mode_changed (); + void entered(); void exited(); private: - Evoral::Parameter _parameter; - boost::shared_ptr _line; + ARDOUR::DoubleBeatsSamplesConverter _region_relative_time_converter; + ARDOUR::DoubleBeatsSamplesConverter _source_relative_time_converter; + Evoral::Parameter _parameter; + boost::shared_ptr _line; + PBD::ScopedConnection _mouse_mode_connection; }; #endif /* __gtk_ardour_automation_region_view_h__ */