X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fautomation_time_axis.h;h=3129ebdc32cc5b3227f84917fbe5f4aa727a1862;hb=e42699600b92db69a428979dc0412c96f7494141;hp=d388419e177ab6d2a30ba4ed838f4859ebb3221f;hpb=580520b12f90251e38d94a1a5d6a199b76142b0b;p=ardour.git diff --git a/gtk2_ardour/automation_time_axis.h b/gtk2_ardour/automation_time_axis.h index d388419e17..3129ebdc32 100644 --- a/gtk2_ardour/automation_time_axis.h +++ b/gtk2_ardour/automation_time_axis.h @@ -32,12 +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" namespace ARDOUR { class Session; - class Route; + class Stripable; class AutomationControl; } @@ -50,29 +53,34 @@ class Selection; class Selectable; 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); + 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); + void add_automation_event (GdkEvent *, samplepos_t, double, bool with_guard_points); void clear_lines (); @@ -83,24 +91,24 @@ class AutomationTimeAxisView : public TimeAxisView { std::list > lines () const; void set_selected_points (PointSelection&); - void get_selectables (ARDOUR::framepos_t start, ARDOUR::framepos_t end, double top, double bot, std::list&); + void get_selectables (ARDOUR::samplepos_t start, ARDOUR::samplepos_t end, double top, double bot, std::list&, bool within = false); void get_inverted_selectables (Selection&, std::list& results); - void show_timestretch (framepos_t /*start*/, framepos_t /*end*/, int /*layers*/, int /*layer*/) {} + void show_timestretch (samplepos_t /*start*/, samplepos_t /*end*/, int /*layers*/, int /*layer*/) {} void hide_timestretch () {} /* editing operations */ void cut_copy_clear (Selection&, Editing::CutCopyOp); - bool paste (ARDOUR::framepos_t, float times, Selection&, size_t nth); + bool paste (ARDOUR::samplepos_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; } @@ -111,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 { @@ -121,31 +129,34 @@ class AutomationTimeAxisView : public TimeAxisView { 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 */ +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. */ + + /** parent strip */ + boost::shared_ptr _stripable; + /** control */ boost::shared_ptr _control; - /** control owner; may be _route, or 0 if we are editing region-based automation */ + /** control owner; may be _stripable, something else (e.g. a pan control), or NULL */ boost::shared_ptr _automatable; - /** controller owner; 0 if we are editing region-based automation */ + /** controller owner */ boost::shared_ptr _controller; Evoral::Parameter _parameter; ArdourCanvas::Rectangle* _base_rect; boost::shared_ptr _line; + std::string _name; + /** AutomationStreamView if we are editing region-based automation (for MIDI), otherwise 0 */ AutomationStreamView* _view; - std::string _name; bool ignore_toggle; - bool first_call_to_set_height; - Gtk::Button hide_button; - Gtk::Button auto_button; - Gtk::Menu* automation_menu; + ArdourWidgets::ArdourButton hide_button; + ArdourWidgets::ArdourDropdown auto_dropdown; Gtk::Label* plugname; bool plugname_packed; @@ -153,9 +164,12 @@ class AutomationTimeAxisView : public TimeAxisView { Gtk::CheckMenuItem* auto_play_item; Gtk::CheckMenuItem* auto_touch_item; Gtk::CheckMenuItem* auto_write_item; + Gtk::CheckMenuItem* auto_latch_item; Gtk::CheckMenuItem* mode_discrete_item; Gtk::CheckMenuItem* mode_line_item; + Gtk::CheckMenuItem* mode_log_item; + Gtk::CheckMenuItem* mode_exp_item; bool _show_regions; @@ -163,16 +177,20 @@ class AutomationTimeAxisView : public TimeAxisView { void clear_clicked (); void hide_clicked (); - void auto_clicked (); + + virtual bool can_edit_name() const {return false;} void build_display_menu (); void cut_copy_clear_one (AutomationLine&, Selection&, Editing::CutCopyOp); - bool paste_one (AutomationLine&, ARDOUR::framepos_t, float times, Selection&, size_t nth); + bool paste_one (ARDOUR::samplepos_t, unsigned, float times, const Selection&, ItemCounts& counts, bool greedy=false); void route_going_away (); void set_automation_state (ARDOUR::AutoState); bool ignore_state_request; + bool ignore_mode_request; + + bool propagate_time_selection () const; void automation_state_changed (); @@ -180,7 +198,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 (); @@ -191,6 +209,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); };