Unify the canvases by moving groups around rather than using set_scrolling_region...
[ardour.git] / gtk2_ardour / time_axis_view.h
index f064359e408f055a98b96bde3b8c53fd8c7f6f7c..2f014c7a166ecb25d959e5a4c4f771077577f3ad 100644 (file)
@@ -25,6 +25,7 @@
 
 #include <gtkmm/box.h>
 #include <gtkmm/frame.h>
+#include <gtkmm/drawingarea.h>
 #include <gtkmm/eventbox.h>
 #include <gtkmm/table.h>
 #include <gtkmm/entry.h>
@@ -32,6 +33,8 @@
 
 #include <gtkmm2ext/focus_entry.h>
 
+#include <pbd/stateful.h>
+
 #include <ardour/types.h>
 #include <ardour/region.h>
 
@@ -68,7 +71,7 @@ class Selectable;
  * extended to create functional time-axis based views.
  *
  */
-class TimeAxisView : public virtual AxisView
+class TimeAxisView : public virtual AxisView, public Stateful
 {
   private:
        enum NamePackingBits {
@@ -87,15 +90,19 @@ class TimeAxisView : public virtual AxisView
        TimeAxisView(ARDOUR::Session& sess, PublicEditor& ed, TimeAxisView* parent, ArdourCanvas::Canvas& canvas);
        virtual ~TimeAxisView ();
 
+       XMLNode& get_state (void);
+       int set_state (const XMLNode&);
+
        /* public data: XXX create accessor/mutators for these ?? */
 
        PublicEditor& editor;
        
-       uint32_t height;  /* in canvas units */
        uint32_t effective_height;  /* in canvas units */
-       double  y_position;
-       int     order;
+       double   y_position;
+       int      order;
        
+       uint32_t current_height() const { return height; }
+
        ArdourCanvas::Group   *canvas_display;
        Gtk::VBox       *control_parent;
 
@@ -106,7 +113,7 @@ class TimeAxisView : public virtual AxisView
        Gtk::Table    controls_table;
        Gtk::EventBox controls_ebox;
        Gtk::VBox     controls_vbox;
-       Gtk::EventBox resizer;
+       Gtk::DrawingArea resizer;
        Gtk::HBox     resizer_box;
        Gtk::HBox     name_hbox;
        Gtk::Frame    name_frame;
@@ -119,8 +126,7 @@ class TimeAxisView : public virtual AxisView
 
        double resize_drag_start;
        int32_t resize_idle_target;
-       int32_t resize_idle_id;
-       bool idle_resize();
+       void idle_resize (uint32_t);
 
        void hide_name_label ();
        void hide_name_entry ();
@@ -217,14 +223,12 @@ class TimeAxisView : public virtual AxisView
        void set_parent (TimeAxisView& p);
        bool has_state () const;
 
-       virtual void set_state (const XMLNode&);
-       virtual XMLNode* get_state_node () { return 0; }
-
        /* call this on the parent */
 
        virtual XMLNode* get_child_xml_node (const string & childname) { return 0; }
 
   protected:
+       uint32_t height;  /* in canvas units */
 
        string controls_base_unselected_name;
        string controls_base_selected_name;