Another not-quite-there-but-better commit.
[ardour.git] / gtk2_ardour / time_axis_view.h
index 9299562324b740ab7be099a977a4a1903d274eb8..722350594a1c7a46f48dd540e289c87d7fd7da33 100644 (file)
@@ -40,7 +40,6 @@
 #include "enums.h"
 #include "editing.h"
 #include "canvas.h"
-#include "color.h"
 
 namespace ARDOUR {
        class Session;
@@ -62,12 +61,10 @@ class TimeAxisViewItem;
 class Selection;
 class Selectable;
 
-/**
- * TimeAxisView defines the abstract base class for time-axis views.
+/** Abstract base class for time-axis views (horizontal editor 'strips')
  *
  * This class provides the basic LHS controls and display methods. This should be
  * extended to create functional time-axis based views.
- *
  */
 class TimeAxisView : public virtual AxisView
 {
@@ -104,13 +101,13 @@ class TimeAxisView : public virtual AxisView
        PublicEditor& editor;
        
        TrackHeight height_style; 
-       uint32_t height;  /* in canvas units */
-       uint32_t effective_height;  /* in canvas units */
-       double  y_position;
-       int     order;
+       uint32_t    height;  /* in canvas units */
+       uint32_t    effective_height;  /* in canvas units */
+       double      y_position;
+       int         order;
        
-       ArdourCanvas::Group   *canvas_display;
-       Gtk::VBox       *control_parent;
+       ArdourCanvas::Group *canvas_display;
+       Gtk::VBox           *control_parent;
 
        /* The Standard LHS Controls */
        Gtk::Frame    controls_frame;
@@ -122,14 +119,13 @@ class TimeAxisView : public virtual AxisView
        Gtk::HBox     name_hbox;
        Gtk::Frame    name_frame;
        Gtkmm2ext::FocusEntry name_entry;
-
+       
        void hide_name_label ();
        void hide_name_entry ();
        void show_name_label ();
        void show_name_entry ();
 
-       /**
-        * Display this TrackView as the nth component of the parent box, at y.
+       /** Display this TrackView as the nth component of the parent box, at y.
         *
         * @param y 
         * @param nth
@@ -140,9 +136,7 @@ class TimeAxisView : public virtual AxisView
 
        bool touched (double top, double bot);
 
-       /**
-        * Hides this TrackView
-        */
+       /** Hides this TrackView */
        virtual void hide ();
        bool hidden() const { return _hidden; }
 
@@ -215,6 +209,8 @@ class TimeAxisView : public virtual AxisView
        /* call this on the parent */
 
        virtual XMLNode* get_child_xml_node (const string & childname) { return 0; }
+       
+       typedef std::vector<boost::shared_ptr<TimeAxisView> > Children;
 
   protected:
 
@@ -235,49 +231,39 @@ class TimeAxisView : public virtual AxisView
        virtual bool name_entry_focus_in (GdkEventFocus *ev);
        virtual bool name_entry_focus_out (GdkEventFocus *ev);
 
-       /**
-        * Handle mouse relaese on our LHS control name ebox.
+       /** Handle mouse relaese on our LHS control name ebox.
         * 
         *@ param ev the event
         */
        virtual bool controls_ebox_button_release (GdkEventButton *ev);
        virtual bool controls_ebox_scroll (GdkEventScroll *ev);
 
-       /**
-        * Displays the standard LHS control menu at when.
+       /** Display the standard LHS control menu at when.
         *
         * @param when the popup activation time
         */
        virtual void popup_display_menu (guint32 when);
 
-       /**
-        * Build the standard LHS control menu.
+       /** Build the standard LHS control menu.
         * Subclasses should extend this method to add their own menu options.
-        *
         */
        virtual void build_display_menu ();
 
-       /**
-         * Do anything that needs to be done to dynamically reset
-        * the LHS control menu.
+       /** Do whatever needs to be done to dynamically reset the LHS control menu.
         */
        virtual bool handle_display_menu_map_event (GdkEventAny *ev) { return false; }
 
-       /**
-        * Build the standard LHS control size menu for the default heights options.
-        *
+       /** Build the standard LHS control size menu for the default heights options.
         */
        virtual void build_size_menu();
 
-       /**
-        * Displays the standard LHS controls size menu for the track heights
+       /** Displays the standard LHS controls size menu for the track heights
         *
-        * @parem when the popup activation time
+        * @param when the popup activation time
         */
        void popup_size_menu(guint32 when);
 
-       /**
-        * Handle the size option of out main menu.
+       /** Handle the size option of our main menu.
         * 
         * @param ev the event
         */
@@ -292,15 +278,14 @@ class TimeAxisView : public virtual AxisView
 
        TimeAxisView* parent;
 
-       /* find the parent with state */
-
+       /** Find the parent with state */
        TimeAxisView* get_parent_with_state();
 
-       std::vector<TimeAxisView*> children;
+       Children children;
        bool is_child (TimeAxisView*);
 
-       void remove_child (TimeAxisView*);
-       void add_child (TimeAxisView*);
+       void remove_child (boost::shared_ptr<TimeAxisView>);
+       void add_child (boost::shared_ptr<TimeAxisView>);
 
        /* selection display */
 
@@ -321,7 +306,7 @@ class TimeAxisView : public virtual AxisView
        static bool need_size_info;
 
        void set_height_pixels (uint32_t h);
-       void color_handler (ColorID, uint32_t);
+       void color_handler ();
 
 }; /* class TimeAxisView */