X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fautomation_line.h;h=a05a7b918058b493def596db721c278c5f9d5d1c;hb=1c5f395c01270cfae0397d56ceb63a104d34b1a0;hp=c8c265c30715ea843b4122e1526fe3a24a07d0b8;hpb=8713667ec1a6cc9ba56c07f763e5a422cc47fbef;p=ardour.git diff --git a/gtk2_ardour/automation_line.h b/gtk2_ardour/automation_line.h index c8c265c307..a05a7b9180 100644 --- a/gtk2_ardour/automation_line.h +++ b/gtk2_ardour/automation_line.h @@ -34,6 +34,7 @@ #include "pbd/undo.h" #include "pbd/statefuldestructible.h" +#include "pbd/memento_command.h" #include "ardour/automation_list.h" #include "ardour/types.h" @@ -52,34 +53,36 @@ namespace Gnome { } } -class AutomationLine : public sigc::trackable, public PBD::StatefulThingWithGoingAway +/** A GUI representation of an ARDOUR::AutomationList */ +class AutomationLine : public sigc::trackable, public PBD::StatefulDestructible { public: AutomationLine (const std::string& name, TimeAxisView&, ArdourCanvas::Group&, boost::shared_ptr, - const Evoral::TimeConverter* converter = 0); + const Evoral::TimeConverter* converter = 0); virtual ~AutomationLine (); void queue_reset (); void reset (); - void clear(); + void clear (); + std::list point_selection_to_control_points (PointSelection const &); void set_selected_points (PointSelection&); - void get_selectables (nframes_t& start, nframes_t& end, - double botfrac, double topfrac, - std::list& results); + void get_selectables (ARDOUR::framepos_t, ARDOUR::framepos_t, double, double, std::list&); void get_inverted_selectables (Selection&, std::list& results); virtual void remove_point (ControlPoint&); bool control_points_adjacent (double xval, uint32_t& before, uint32_t& after); /* dragging API */ - virtual void start_drag (ControlPoint*, nframes_t x, float fraction); - virtual void point_drag(ControlPoint&, nframes_t x, float, bool with_push); - virtual void end_drag (ControlPoint*); - virtual void line_drag(uint32_t i1, uint32_t i2, float, bool with_push); + virtual void start_drag_single (ControlPoint*, double, float); + virtual void start_drag_line (uint32_t, uint32_t, float); + virtual void start_drag_multiple (std::list, float, XMLNode *); + virtual std::pair drag_motion (double, float, bool, bool); + virtual void end_drag (); ControlPoint* nth (uint32_t); + ControlPoint const * nth (uint32_t) const; uint32_t npoints() const { return control_points.size(); } std::string name() const { return _name; } @@ -89,8 +92,6 @@ class AutomationLine : public sigc::trackable, public PBD::StatefulThingWithGoin void set_line_color (uint32_t); uint32_t get_line_color() const { return _line_color; } - void set_interpolation(ARDOUR::AutomationList::InterpolationStyle style); - void show (); void hide (); void set_height (guint32); @@ -103,13 +104,11 @@ class AutomationLine : public sigc::trackable, public PBD::StatefulThingWithGoin ArdourCanvas::Item& parent_group() const { return _parent_group; } ArdourCanvas::Item& grab_item() const { return *line; } - void show_selection(); - void hide_selection (); - std::string get_verbose_cursor_string (double) const; std::string fraction_to_string (double) const; double string_to_fraction (std::string const &) const; void view_to_model_coord (double& x, double& y) const; + void view_to_model_coord_y (double &) const; void model_to_view_coord (double& x, double& y) const; void set_list(boost::shared_ptr list); @@ -130,6 +129,25 @@ class AutomationLine : public sigc::trackable, public PBD::StatefulThingWithGoin void modify_point_y (ControlPoint&, double); + void add_always_in_view (double); + void clear_always_in_view (); + + virtual MementoCommandBinder* memento_command_binder (); + + const Evoral::TimeConverter& time_converter () const { + return _time_converter; + } + + std::pair get_point_x_range () const; + + void set_maximum_time (ARDOUR::framecnt_t); + ARDOUR::framecnt_t maximum_time () const { + return _maximum_time; + } + + void set_offset (ARDOUR::framecnt_t); + void set_width (ARDOUR::framecnt_t); + protected: std::string _name; @@ -143,6 +161,7 @@ class AutomationLine : public sigc::trackable, public PBD::StatefulThingWithGoin bool terminal_points_can_slide : 1; bool update_pending : 1; bool no_draw : 1; + bool _is_boolean : 1; bool points_visible : 1; bool did_push; @@ -164,8 +183,9 @@ class AutomationLine : public sigc::trackable, public PBD::StatefulThingWithGoin static bool invalid_point (ALPoints&, uint32_t index); void determine_visible_control_points (ALPoints&); - void sync_model_with_view_point (ControlPoint&, bool did_push, int64_t distance); - void sync_model_with_view_line (uint32_t, uint32_t); + void sync_model_with_view_point (ControlPoint&, bool, int64_t); + void sync_model_with_view_points (std::list, bool, int64_t); + void start_drag_common (double, float); virtual void change_model (ARDOUR::AutomationList::iterator, double x, double y); @@ -173,24 +193,27 @@ class AutomationLine : public sigc::trackable, public PBD::StatefulThingWithGoin void list_changed (); virtual bool event_handler (GdkEvent*); - virtual void add_model_point (ALPoints& tmp_points, double frame, double yfract); private: - uint32_t drags; - double first_drag_fraction; - double last_drag_fraction; - uint32_t line_drag_cp1; - uint32_t line_drag_cp2; - int64_t drag_x; - int64_t drag_distance; - - const Evoral::TimeConverter& _time_converter; - ARDOUR::AutomationList::InterpolationStyle _interpolation; - - void modify_view_point (ControlPoint&, double, double, bool with_push); - void reset_line_coords (ControlPoint&); + std::list _drag_points; ///< points we are dragging + std::list _push_points; ///< additional points we are dragging if "push" is enabled + bool _drag_had_movement; ///< true if the drag has seen movement, otherwise false + double _drag_x; ///< last x position of the drag, in units + double _drag_distance; ///< total x movement of the drag, in units + double _last_drag_fraction; ///< last y position of the drag, as a fraction + std::list _always_in_view; + /** offset from the start of the automation list to the start of the line, so that + * a +ve offset means that the 0 on the line is at _offset in the list + */ + ARDOUR::framecnt_t _offset; + + const Evoral::TimeConverter& _time_converter; + void reset_line_coords (ControlPoint&); + void add_visible_control_point (uint32_t, uint32_t, double, double, ARDOUR::AutomationList::iterator, uint32_t); double control_point_box_size (); + void connect_to_list (); + void interpolation_changed (ARDOUR::AutomationList::InterpolationStyle); struct ModelRepresentation { ARDOUR::AutomationList::iterator start; @@ -207,6 +230,11 @@ class AutomationLine : public sigc::trackable, public PBD::StatefulThingWithGoin void model_representation (ControlPoint&, ModelRepresentation&); + PBD::ScopedConnectionList _list_connections; + + /** maximum time that a point on this line can be at, relative to the position of its region or start of its track */ + ARDOUR::framecnt_t _maximum_time; + friend class AudioRegionGainLine; };