X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fautomation_time_axis.h;h=aae1ec5657317138493a09aec52d7a89ed61f238;hb=735d791e420c3e4944fdbc8ac7f6a26251d90d87;hp=aef1300405c771c7aa9457d1fb9562848dd5087f;hpb=ced4378d0914bcfb926267772c45d1d23f3bed38;p=ardour.git diff --git a/gtk2_ardour/automation_time_axis.h b/gtk2_ardour/automation_time_axis.h index aef1300405..aae1ec5657 100644 --- a/gtk2_ardour/automation_time_axis.h +++ b/gtk2_ardour/automation_time_axis.h @@ -32,13 +32,15 @@ #include "canvas/rectangle.h" +#include "widgets/ardour_button.h" +#include "widgets/ardour_dropdown.h" + #include "time_axis_view.h" #include "automation_controller.h" -#include "ardour_button.h" namespace ARDOUR { class Session; - class Route; + class Stripable; class AutomationControl; } @@ -53,27 +55,32 @@ class AutomationStreamView; class AutomationController; class ItemCounts; -class AutomationTimeAxisView : public TimeAxisView { - public: +class AutomationTimeAxisView : public TimeAxisView +{ +public: AutomationTimeAxisView (ARDOUR::Session*, - boost::shared_ptr, - boost::shared_ptr, - boost::shared_ptr, - Evoral::Parameter, - PublicEditor&, - TimeAxisView& parent, - bool show_regions, - ArdourCanvas::Canvas& canvas, - const std::string & name, /* translatable */ - const std::string & plug_name = ""); + boost::shared_ptr, + boost::shared_ptr, + boost::shared_ptr, + Evoral::Parameter, + PublicEditor&, + TimeAxisView& parent, + bool show_regions, + ArdourCanvas::Canvas& canvas, + const std::string & name, /* translatable */ + const std::string & plug_name = ""); ~AutomationTimeAxisView(); virtual void set_height (uint32_t, TrackHeightMode m = OnlySelf); void set_samples_per_pixel (double); std::string name() const { return _name; } + Gdk::Color color () const; + + boost::shared_ptr stripable() const; + ARDOUR::PresentationInfo const & presentation_info () const; - void add_automation_event (GdkEvent *, framepos_t, double, bool with_guard_points); + void add_automation_event (GdkEvent *, framepos_t, double, bool with_guard_points); void clear_lines (); @@ -93,15 +100,15 @@ class AutomationTimeAxisView : public TimeAxisView { /* editing operations */ void cut_copy_clear (Selection&, Editing::CutCopyOp); - bool paste (ARDOUR::framepos_t, const Selection&, PasteContext&); + bool paste (ARDOUR::framepos_t, const Selection&, PasteContext&, const int32_t sub_num); int set_state (const XMLNode&, int version); 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; } + boost::shared_ptr control() const { return _control; } + boost::shared_ptr controller() const { return _controller; } Evoral::Parameter parameter () const { return _parameter; } @@ -112,8 +119,8 @@ class AutomationTimeAxisView : public TimeAxisView { bool has_automation () const; - boost::shared_ptr parent_route () { - return _route; + boost::shared_ptr parent_stripable () { + return _stripable; } bool show_regions () const { @@ -122,16 +129,16 @@ class AutomationTimeAxisView : public TimeAxisView { static void what_has_visible_automation (const boost::shared_ptr& automatable, std::set& visible); - protected: +protected: /* Note that for MIDI controller "automation" (in regions), all of these - may be set. In this case, _automatable is likely _route so the - controller will send immediate events out the route's MIDI port. */ + * may be set. In this case, _automatable is likely _route so the + * controller will send immediate events out the route's MIDI port. */ - /** parent route */ - boost::shared_ptr _route; + /** parent strip */ + boost::shared_ptr _stripable; /** control */ boost::shared_ptr _control; - /** control owner; may be _route, something else (e.g. a pan control), or NULL */ + /** control owner; may be _stripable, something else (e.g. a pan control), or NULL */ boost::shared_ptr _automatable; /** controller owner */ boost::shared_ptr _controller; @@ -148,9 +155,8 @@ class AutomationTimeAxisView : public TimeAxisView { bool ignore_toggle; bool first_call_to_set_height; - ArdourButton hide_button; - ArdourButton auto_button; - Gtk::Menu* automation_menu; + ArdourWidgets::ArdourButton hide_button; + ArdourWidgets::ArdourDropdown auto_dropdown; Gtk::Label* plugname; bool plugname_packed; @@ -161,6 +167,8 @@ class AutomationTimeAxisView : public TimeAxisView { Gtk::CheckMenuItem* mode_discrete_item; Gtk::CheckMenuItem* mode_line_item; + Gtk::CheckMenuItem* mode_log_item; + Gtk::CheckMenuItem* mode_exp_item; bool _show_regions; @@ -168,7 +176,6 @@ class AutomationTimeAxisView : public TimeAxisView { void clear_clicked (); void hide_clicked (); - void auto_clicked (); virtual bool can_edit_name() const {return false;} @@ -180,6 +187,9 @@ class AutomationTimeAxisView : public TimeAxisView { void set_automation_state (ARDOUR::AutoState); bool ignore_state_request; + bool ignore_mode_request; + + bool propagate_time_selection () const; void automation_state_changed (); @@ -187,7 +197,7 @@ class AutomationTimeAxisView : public TimeAxisView { void interpolation_changed (ARDOUR::AutomationList::InterpolationStyle); PBD::ScopedConnectionList _list_connections; - PBD::ScopedConnectionList _route_connections; + PBD::ScopedConnectionList _stripable_connections; void entered (); void exited (); @@ -198,6 +208,8 @@ class AutomationTimeAxisView : public TimeAxisView { static Pango::FontDescription name_font; static bool have_name_font; + std::string automation_state_off_string () const; + private: int set_state_2X (const XMLNode &, int); };