X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fautomation_region_view.h;h=ce34e763d3b29ce15acd385630bda98e98cc9ce4;hb=4dc65e6613a375a836de4dd9901ac50a4ab43be6;hp=571a80709a3149d246bb339d6697191fa5c95832;hpb=664e715a002450ac0f079411f6f051c122a4322a;p=ardour.git diff --git a/gtk2_ardour/automation_region_view.h b/gtk2_ardour/automation_region_view.h index 571a80709a..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); } @@ -55,23 +68,29 @@ 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; } + + 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__ */