X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fautomation_time_axis.h;h=7706ed7ee31469bb97f4429468857c03d8232dfa;hb=3aa7dacfdf214f0db9330d975e94b7697a0259eb;hp=195511d333ad7c8525856e8c06d8a7eab492ddfb;hpb=ca2f505ec16f69ef1b5090e48b93f7ded6ae795a;p=ardour.git diff --git a/gtk2_ardour/automation_time_axis.h b/gtk2_ardour/automation_time_axis.h index 195511d333..7706ed7ee3 100644 --- a/gtk2_ardour/automation_time_axis.h +++ b/gtk2_ardour/automation_time_axis.h @@ -58,6 +58,7 @@ class AutomationTimeAxisView : public TimeAxisView { boost::shared_ptr, boost::shared_ptr, boost::shared_ptr, + Evoral::Parameter, PublicEditor&, TimeAxisView& parent, bool show_regions, @@ -69,52 +70,75 @@ class AutomationTimeAxisView : public TimeAxisView { virtual void set_height (uint32_t); void set_samples_per_unit (double); - bool set_visibility (bool yn); 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*/) {} 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 cut_copy_clear (Selection&, Editing::CutCopyOp); + void cut_copy_clear_objects (PointSelection&, Editing::CutCopyOp); + bool paste (ARDOUR::framepos_t, float times, Selection&, size_t nth); void reset_objects (PointSelection&); int set_state (const XMLNode&, int version); - guint32 show_at (double y, int& nth, Gtk::VBox *parent); - void hide (); - 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; + } ArdourCanvas::Item* base_item () const { return _base_rect; } - protected: - boost::shared_ptr _route; ///< Parent route - boost::shared_ptr _control; ///< Control - boost::shared_ptr _automatable; ///< Control owner, maybe = _route + 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; @@ -135,6 +159,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 (); @@ -143,10 +169,11 @@ 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 cut_copy_clear_one (AutomationLine&, Selection&, Editing::CutCopyOp); + void cut_copy_clear_objects_one (AutomationLine&, PointSelection&, Editing::CutCopyOp); + bool paste_one (AutomationLine&, ARDOUR::framepos_t, float times, Selection&, size_t nth); void reset_objects_one (AutomationLine&, PointSelection&); + void route_going_away (); void set_automation_state (ARDOUR::AutoState); bool ignore_state_request; @@ -154,11 +181,10 @@ class AutomationTimeAxisView : public TimeAxisView { void automation_state_changed (); void set_interpolation (ARDOUR::AutomationList::InterpolationStyle); - void interpolation_changed (); - - PBD::ScopedConnection 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 (); @@ -166,8 +192,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__ */