X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fautomation_time_axis.h;h=4e21d281a3613e9f547a5d1e56652fad2feff75d;hb=f7f9d6fdc40248b190ec9c6e1a886261d55777ae;hp=e302e14ebb537bac60cd31bb50772e2b9361da06;hpb=789cbb21810802adc478de3134fa42950c5e8569;p=ardour.git diff --git a/gtk2_ardour/automation_time_axis.h b/gtk2_ardour/automation_time_axis.h index e302e14ebb..4e21d281a3 100644 --- a/gtk2_ardour/automation_time_axis.h +++ b/gtk2_ardour/automation_time_axis.h @@ -23,14 +23,17 @@ #include #include #include +#include #include #include +#include #include "canvas.h" #include "time_axis_view.h" #include "simplerect.h" +#include "automation_controller.h" using std::vector; using std::list; @@ -39,6 +42,7 @@ using std::string; namespace ARDOUR { class Session; class Route; + class AutomationControl; } class PublicEditor; @@ -49,30 +53,33 @@ class AutomationLine; class GhostRegion; class Selection; class Selectable; +class AutomationStreamView; +class AutomationController; + class AutomationTimeAxisView : public TimeAxisView { public: AutomationTimeAxisView (ARDOUR::Session&, boost::shared_ptr, + boost::shared_ptr, + boost::shared_ptr, PublicEditor&, TimeAxisView& parent, + bool show_regions, ArdourCanvas::Canvas& canvas, const string & name, /* translatable */ - const string & state_name, /* not translatable */ const string & plug_name = ""); ~AutomationTimeAxisView(); - virtual void set_height (TimeAxisView::TrackHeight); + void set_height (TimeAxisView::TrackHeight); void set_samples_per_unit (double); std::string name() const { return _name; } - virtual void add_automation_event (ArdourCanvas::Item *item, GdkEvent *event, nframes_t, double) = 0; - - virtual void clear_lines (); - virtual void add_line (AutomationLine&); + void add_automation_event (ArdourCanvas::Item *item, GdkEvent *event, nframes_t, double); - vector lines; + void clear_lines (); + boost::shared_ptr line() { return _line; } void set_selected_points (PointSelection&); void get_selectables (nframes_t start, nframes_t end, double top, double bot, list&); @@ -91,17 +98,31 @@ class AutomationTimeAxisView : public TimeAxisView { void add_ghost (GhostRegion*); void remove_ghost (GhostRegion*); - void show_all_control_points (); - void hide_all_but_selected_control_points (); void set_state (const XMLNode&); - XMLNode* get_state_node (); + + guint32 show_at (double y, int& nth, Gtk::VBox *parent); + void hide (); + + static const string state_node_name; + XMLNode* get_state_node(); + + boost::shared_ptr control() { return _control; } + boost::shared_ptr controller() { return _controller; } protected: - boost::shared_ptr route; - ArdourCanvas::SimpleRect* base_rect; + boost::shared_ptr _route; ///< Parent route + boost::shared_ptr _control; ///< Control + boost::shared_ptr _automatable; ///< Control owner, maybe = _route + + boost::shared_ptr _controller; + + ArdourCanvas::SimpleRect* _base_rect; + boost::shared_ptr _line; + AutomationStreamView* _view; + string _name; - string _state_name; bool in_destructor; + bool ignore_toggle; bool first_call_to_set_height; @@ -118,12 +139,17 @@ class AutomationTimeAxisView : public TimeAxisView { Gtk::CheckMenuItem* auto_touch_item; Gtk::CheckMenuItem* auto_write_item; + Gtk::CheckMenuItem* mode_discrete_item; + Gtk::CheckMenuItem* mode_line_item; + + void add_line (boost::shared_ptr); + void clear_clicked (); void height_clicked (); void hide_clicked (); void auto_clicked (); - virtual void build_display_menu (); + void build_display_menu (); list ghosts; @@ -132,19 +158,25 @@ class AutomationTimeAxisView : public TimeAxisView { bool paste_one (AutomationLine&, nframes_t, float times, Selection&, size_t nth); void reset_objects_one (AutomationLine&, PointSelection&); - virtual void set_automation_state (ARDOUR::AutoState) = 0; + void set_automation_state (ARDOUR::AutoState); bool ignore_state_request; void automation_state_changed (); + + void set_interpolation (ARDOUR::AutomationList::InterpolationStyle); + void interpolation_changed (); + sigc::connection automation_connection; + void update_extra_xml_shown (bool editor_shown); + void entered (); void exited (); void set_colors (); void color_handler (); - static Pango::FontDescription name_font; + static Pango::FontDescription* name_font; static bool have_name_font; };