X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fautomation_time_axis.h;h=f1a9a8bd57327a35a7da6c81d9b4cb02f53a6196;hb=f80859f3bdcb5c3b982379481ae3999446f35e81;hp=f6239314abdfde6381f93c50a47ed17fcc048883;hpb=79f91c7a205d981d2b8cc15e32a6da02d8423065;p=ardour.git diff --git a/gtk2_ardour/automation_time_axis.h b/gtk2_ardour/automation_time_axis.h index f6239314ab..f1a9a8bd57 100644 --- a/gtk2_ardour/automation_time_axis.h +++ b/gtk2_ardour/automation_time_axis.h @@ -54,10 +54,11 @@ class AutomationController; class AutomationTimeAxisView : public TimeAxisView { public: - AutomationTimeAxisView (ARDOUR::Session&, + AutomationTimeAxisView (ARDOUR::Session*, boost::shared_ptr, boost::shared_ptr, boost::shared_ptr, + Evoral::Parameter, PublicEditor&, TimeAxisView& parent, bool show_regions, @@ -71,45 +72,71 @@ class AutomationTimeAxisView : public TimeAxisView { void set_samples_per_unit (double); std::string name() const { return _name; } - void add_automation_event (ArdourCanvas::Item *item, GdkEvent *event, nframes_t, double); + void add_automation_event (GdkEvent *, framepos_t, double); void clear_lines (); + + /** @return Our AutomationLine, if this view has one, or 0 if it uses AutomationRegionViews */ boost::shared_ptr line() { return _line; } + /** @return All AutomationLines associated with this view */ + std::list > lines () const; + void set_selected_points (PointSelection&); - void get_selectables (nframes_t start, nframes_t end, double top, double bot, std::list&); + void get_selectables (ARDOUR::framepos_t start, ARDOUR::framepos_t end, double top, double bot, std::list&); void get_inverted_selectables (Selection&, std::list& results); - void show_timestretch (nframes_t /*start*/, nframes_t /*end*/) {} + void show_timestretch (framepos_t /*start*/, framepos_t /*end*/, int /*layers*/, int /*layer*/) {} void hide_timestretch () {} /* editing operations */ - bool cut_copy_clear (Selection&, Editing::CutCopyOp); - bool cut_copy_clear_objects (PointSelection&, Editing::CutCopyOp); - bool paste (nframes_t, float times, Selection&, size_t nth); - void reset_objects (PointSelection&); + void cut_copy_clear (Selection&, Editing::CutCopyOp); + bool paste (ARDOUR::framepos_t, float times, Selection&, size_t nth); - int set_state (const XMLNode&, int version = 3000); - guint32 show_at (double y, int& nth, Gtk::VBox *parent); - void hide (); + int set_state (const XMLNode&, int version); - static const std::string state_node_name; - XMLNode* get_state_node(); + std::string state_id() const; + static bool parse_state_id (std::string const &, PBD::ID &, bool &, Evoral::Parameter &); boost::shared_ptr control() { return _control; } boost::shared_ptr controller() { return _controller; } + Evoral::Parameter parameter () const { + return _parameter; + } - protected: - boost::shared_ptr _route; ///< Parent route - boost::shared_ptr _control; ///< Control - boost::shared_ptr _automatable; ///< Control owner, maybe = _route + ArdourCanvas::Item* base_item () const { + return _base_rect; + } + + bool has_automation () const; + + boost::shared_ptr parent_route () { + return _route; + } + + bool show_regions () const { + return _show_regions; + } + static void what_has_visible_automation (const boost::shared_ptr& automatable, std::set& visible); + + protected: + /** parent route */ + boost::shared_ptr _route; + /** control; 0 if we are editing region-based automation */ + boost::shared_ptr _control; + /** control owner; may be _route, or 0 if we are editing region-based automation */ + boost::shared_ptr _automatable; + /** controller owner; 0 if we are editing region-based automation */ boost::shared_ptr _controller; + Evoral::Parameter _parameter; ArdourCanvas::SimpleRect* _base_rect; boost::shared_ptr _line; - AutomationStreamView* _view; + + /** AutomationStreamView if we are editing region-based automation (for MIDI), otherwise 0 */ + AutomationStreamView* _view; std::string _name; bool ignore_toggle; @@ -130,6 +157,8 @@ class AutomationTimeAxisView : public TimeAxisView { Gtk::CheckMenuItem* mode_discrete_item; Gtk::CheckMenuItem* mode_line_item; + bool _show_regions; + void add_line (boost::shared_ptr); void clear_clicked (); @@ -138,10 +167,9 @@ class AutomationTimeAxisView : public TimeAxisView { void build_display_menu (); - bool cut_copy_clear_one (AutomationLine&, Selection&, Editing::CutCopyOp); - bool cut_copy_clear_objects_one (AutomationLine&, PointSelection&, Editing::CutCopyOp); - bool paste_one (AutomationLine&, nframes_t, float times, Selection&, size_t nth); - void reset_objects_one (AutomationLine&, PointSelection&); + void cut_copy_clear_one (AutomationLine&, Selection&, Editing::CutCopyOp); + bool paste_one (AutomationLine&, ARDOUR::framepos_t, float times, Selection&, size_t nth); + void route_going_away (); void set_automation_state (ARDOUR::AutoState); bool ignore_state_request; @@ -149,11 +177,10 @@ class AutomationTimeAxisView : public TimeAxisView { void automation_state_changed (); void set_interpolation (ARDOUR::AutomationList::InterpolationStyle); - void interpolation_changed (); - - sigc::connection automation_connection; + void interpolation_changed (ARDOUR::AutomationList::InterpolationStyle); - void update_extra_xml_shown (bool editor_shown); + PBD::ScopedConnectionList _list_connections; + PBD::ScopedConnectionList _route_connections; void entered (); void exited (); @@ -161,8 +188,11 @@ class AutomationTimeAxisView : public TimeAxisView { //void set_colors (); void color_handler (); - static Pango::FontDescription* name_font; + static Pango::FontDescription name_font; static bool have_name_font; + +private: + int set_state_2X (const XMLNode &, int); }; #endif /* __ardour_gtk_automation_time_axis_h__ */