Back out big shared_ptr change. Moving to a branch. Apologies all.
[ardour.git] / gtk2_ardour / automation_line.h
index 2637a0c554dd86cdf194c7bd92418b18ca378e45..136196cd72b3b1755a1094fc71d14f80c309f311 100644 (file)
 #include "canvas.h"
 #include "simplerect.h"
 
-#include <pbd/undo.h>
-#include <pbd/statefuldestructible.h> 
+#include "evoral/TimeConverter.hpp"
 
-#include <ardour/automation_event.h>
+#include "pbd/undo.h"
+#include "pbd/statefuldestructible.h" 
 
-
-using std::vector;
-using std::string;
+#include "ardour/automation_list.h"
+#include "ardour/types.h"
 
 class AutomationLine;
 class ControlPoint;
@@ -53,52 +52,12 @@ namespace Gnome {
        }
 }
 
-class ControlPoint 
-{
-  public:
-        ControlPoint (AutomationLine& al);
-       ControlPoint (const ControlPoint&, bool dummy_arg_to_force_special_copy_constructor);
-       virtual ~ControlPoint ();
-
-       enum ShapeType {
-               Full,
-               Start,
-               End
-       };
-       
-       void move_to (double x, double y, ShapeType);
-       void reset (double x, double y, ARDOUR::AutomationList::iterator, uint32_t, ShapeType);
-       double get_x() const { return _x; }
-       double get_y() const { return _y; }
-
-       void hide (); 
-       void show ();
-       void show_color (bool entered, bool hide_too);
-
-       void set_size (double);
-       void set_visible (bool);
-
-       ArdourCanvas::SimpleRect* item;
-       AutomationLine& line;
-       uint32_t view_index;
-       ARDOUR::AutomationList::iterator model;
-       bool can_slide;
-       bool selected;
-       
-  protected:
-       virtual bool event_handler (GdkEvent*);
-
-  private:
-       double _x;
-       double _y;
-       double _size;
-       ShapeType _shape;
-};
-
 class AutomationLine : public sigc::trackable, public PBD::StatefulThingWithGoingAway
 {
   public:
-        AutomationLine (const string & name, TimeAxisView&, ArdourCanvas::Group&, ARDOUR::AutomationList&);
+       AutomationLine (const std::string& name, TimeAxisView&, ArdourCanvas::Group&,
+                       boost::shared_ptr<ARDOUR::AutomationList>,
+                       const Evoral::TimeConverter<double, ARDOUR::sframes_t>* converter = 0);
        virtual ~AutomationLine ();
 
        void queue_reset ();
@@ -108,14 +67,13 @@ class AutomationLine : public sigc::trackable, public PBD::StatefulThingWithGoin
        void set_selected_points (PointSelection&);
        void get_selectables (nframes_t& start, nframes_t& end,
                              double botfrac, double topfrac, 
-                             list<Selectable*>& results);
-       void get_inverted_selectables (Selection&, list<Selectable*>& results);
+                             std::list<Selectable*>& results);
+       void get_inverted_selectables (Selection&, std::list<Selectable*>& 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*);
@@ -124,18 +82,20 @@ class AutomationLine : public sigc::trackable, public PBD::StatefulThingWithGoin
        ControlPoint* nth (uint32_t);
        uint32_t npoints() const { return control_points.size(); }
 
-       string  name() const { return _name; }
+       std::string  name()    const { return _name; }
        bool    visible() const { return _visible; }
-       guint32 height() const { return _height; }
-       guint32 y_position() const { return _y_position; }
+       guint32 height()  const { return _height; }
 
-       void         set_line_color (uint32_t);
+       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_y_position_and_height (uint32_t, uint32_t);
-       void    set_verbose_cursor_uses_gain_mapping (bool yn);
+       void    set_height (guint32);
+       void    set_uses_gain_mapping (bool yn);
+       bool    get_uses_gain_mapping () const { return _uses_gain_mapping; }
 
        TimeAxisView& trackview;
 
@@ -146,15 +106,21 @@ class AutomationLine : public sigc::trackable, public PBD::StatefulThingWithGoin
        void show_selection();
        void hide_selection ();
 
-       virtual string  get_verbose_cursor_string (float);
-       virtual void view_to_model_y (double&) = 0;
-       virtual void model_to_view_y (double&) = 0;
+       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   model_to_view_coord (double& x, double& y) const;
 
-       ARDOUR::AutomationList& the_list() const { return alist; }
+       void set_list(boost::shared_ptr<ARDOUR::AutomationList> list);
+       boost::shared_ptr<ARDOUR::AutomationList> the_list() const { return alist; }
 
        void show_all_control_points ();
        void hide_all_but_selected_control_points ();
 
+       void track_entered();
+       void track_exited();
+
        bool is_last_point (ControlPoint &);
        bool is_first_point (ControlPoint &);
 
@@ -162,27 +128,29 @@ class AutomationLine : public sigc::trackable, public PBD::StatefulThingWithGoin
        int set_state (const XMLNode&);
        void set_colors();
 
+       void modify_point_y (ControlPoint&, double);
+       
   protected:
 
-       string _name;
-       guint32 _y_position;
-       guint32 _height;
-       uint32_t _line_color;
-       ARDOUR::AutomationList& alist;
+       std::string    _name;
+       guint32   _height;
+       uint32_t  _line_color;
+       
+       boost::shared_ptr<ARDOUR::AutomationList> alist;
 
-       bool    _visible  : 1;
-       bool    _vc_uses_gain_mapping : 1;
+       bool    _visible                  : 1;
+       bool    _uses_gain_mapping        : 1;
        bool    terminal_points_can_slide : 1;
-       bool    update_pending : 1;
-       bool    no_draw : 1;
-       bool    points_visible : 1;
+       bool    update_pending            : 1;
+       bool    no_draw                   : 1;
+       bool    points_visible            : 1;
        bool    did_push;
 
-       ArdourCanvas::Group&  _parent_group;
-       ArdourCanvas::Group*   group;
-       ArdourCanvas::Line*   line; /* line */
-       ArdourCanvas::Points  line_points; /* coordinates for canvas line */
-       vector<ControlPoint*>  control_points; /* visible control points */
+       ArdourCanvas::Group&        _parent_group;
+       ArdourCanvas::Group*        group;
+       ArdourCanvas::Line*         line; /* line */
+       ArdourCanvas::Points        line_points; /* coordinates for canvas line */
+       std::vector<ControlPoint*>  control_points; /* visible control points */
 
        struct ALPoint {
            double x;
@@ -200,12 +168,12 @@ class AutomationLine : public sigc::trackable, public PBD::StatefulThingWithGoin
        void sync_model_with_view_line (uint32_t, uint32_t);
        
        virtual void change_model (ARDOUR::AutomationList::iterator, double x, double y);
-       virtual void change_model_range (ARDOUR::AutomationList::iterator,ARDOUR::AutomationList::iterator, double delta, float ydelta);
 
-       void reset_callback (const ARDOUR::AutomationList&);
+       void reset_callback (const Evoral::ControlList&);
        void list_changed ();
 
        virtual bool event_handler (GdkEvent*);
+       virtual void add_model_point (ALPoints& tmp_points, double frame, double yfract);
        
   private:
        uint32_t drags;
@@ -216,7 +184,10 @@ class AutomationLine : public sigc::trackable, public PBD::StatefulThingWithGoin
        int64_t  drag_x;
        int64_t  drag_distance;
 
-       void modify_view_point(ControlPoint&, double, double, bool with_push);
+       const Evoral::TimeConverter<double, ARDOUR::sframes_t>& _time_converter;
+       ARDOUR::AutomationList::InterpolationStyle              _interpolation;
+
+       void modify_view_point (ControlPoint&, double, double, bool with_push);
        void reset_line_coords (ControlPoint&);
 
        double control_point_box_size ();
@@ -224,13 +195,13 @@ class AutomationLine : public sigc::trackable, public PBD::StatefulThingWithGoin
        struct ModelRepresentation {
            ARDOUR::AutomationList::iterator start;
            ARDOUR::AutomationList::iterator end;
-           nframes_t xpos;
+           double xpos;
            double ypos;
-           nframes_t xmin;
+           double xmin;
            double ymin;
-           nframes_t xmax;
+           double xmax;
            double ymax;
-           nframes_t xval;
+           double xval;
            double yval;
        };