add new clear-gray color theme
[ardour.git] / gtk2_ardour / axis_view.h
index e3e90325d30a39ece61aaddc2cbb1ae2072a926c..2a7c3781978d92d8ea5e959c4ed794a2a9fe3cf5 100644 (file)
@@ -21,6 +21,7 @@
 #define __ardour_gtk_axis_view_h__
 
 #include <list>
+#include <boost/unordered_map.hpp>
 
 #include <gtkmm/label.h>
 #include <gdkmm/color.h>
 
 #include "ardour/session_handle.h"
 
+#include "gui_object.h"
 #include "prompter.h"
 #include "selectable.h"
 
 namespace ARDOUR {
        class Session;
+       class Stripable;
+       class PresentationInfo;
 }
 
 /**
- * AxisView defines the abstract base class for time-axis trackviews and routes.
+ * AxisView defines the abstract base class for horizontal and vertical
+ * presentations of Stripables.
  *
  */
-class AxisView : public virtual Selectable, public PBD::ScopedConnectionList, public ARDOUR::SessionHandlePtr
+class AxisView : public virtual PBD::ScopedConnectionList, public virtual ARDOUR::SessionHandlePtr, public virtual Selectable
 {
   public:
-       /**
-        * Returns the current 'Track' Color
-        *
-        * @return the current Track Color
-        */
-       Gdk::Color color() const { return _color; }
-
        ARDOUR::Session* session() const { return _session; }
 
        virtual std::string name() const = 0;
+       virtual Gdk::Color color() const = 0;
 
-       virtual bool marked_for_display() const { return _marked_for_display; }
-       virtual void set_marked_for_display (bool yn) {
-               _marked_for_display = yn;
+       sigc::signal<void> Hiding;
+
+       virtual boost::shared_ptr<ARDOUR::Stripable> stripable() const = 0;
+
+       virtual std::string state_id() const = 0;
+       /* for now, we always return properties in string form.
+        */
+       std::string gui_property (const std::string& property_name) const;
+
+       template<typename T> void set_gui_property (const std::string& property_name, const T& value) {
+               std::stringstream s;
+               s << value;
+               property_hashtable.erase(property_name);
+               property_hashtable.emplace(property_name, s.str());
+               gui_object_state().set_property<T> (state_id(), property_name, value);
        }
 
-       sigc::signal<void> Hiding;
+       void cleanup_gui_properties () {
+               /* remove related property node from the GUI state */
+               gui_object_state().remove_node (state_id());
+               property_hashtable.clear ();
+       }
 
-       void set_old_order_key (uint32_t ok) { _old_order_key = ok; }
-       uint32_t old_order_key() const { return _old_order_key; }
+       void set_selected (bool yn);
 
-  protected:
+       virtual bool marked_for_display () const;
+       virtual bool set_marked_for_display (bool);
 
-       AxisView (ARDOUR::Session* sess);
-       virtual ~AxisView();
+       static GUIObjectState& gui_object_state();
+       void clear_property_cache() { property_hashtable.clear(); }
 
        /**
         * Generate a new random TrackView color, unique from those colors already used.
@@ -77,17 +92,15 @@ class AxisView : public virtual Selectable, public PBD::ScopedConnectionList, pu
         */
        static Gdk::Color unique_random_color();
 
-
-       Gdk::Color _color;
+  protected:
+       AxisView ();
+       virtual ~AxisView();
 
        static std::list<Gdk::Color> used_colors;
 
        Gtk::Label name_label;
 
-       bool _marked_for_display;
-       uint32_t _old_order_key;
-
+       mutable boost::unordered_map<std::string, std::string> property_hashtable;
 }; /* class AxisView */
 
 #endif /* __ardour_gtk_axis_view_h__ */
-