X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Faxis_view.h;h=bacaa8410de8bfb6ff6c7d05d84ee423751ad352;hb=b94c9ef8e09d41c28e44baae36e67bdf06e3758e;hp=7334945c2ca819ebc2d1491ad7813cf842f0930c;hpb=614fc8c7bbc56c160a95de48a27e3d662dc56cac;p=ardour.git diff --git a/gtk2_ardour/axis_view.h b/gtk2_ardour/axis_view.h index 7334945c2c..bacaa8410d 100644 --- a/gtk2_ardour/axis_view.h +++ b/gtk2_ardour/axis_view.h @@ -32,55 +32,77 @@ #include "ardour/session_handle.h" #include "gui_object.h" -#include "prompter.h" #include "selectable.h" +namespace PBD { + class Controllable; +} + 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: - /** @return the track's own color */ - Gdk::Color color () const { return _color; } - - ARDOUR::Session* session() const { return _session; } - +public: virtual std::string name() const = 0; + virtual Gdk::Color color() const = 0; sigc::signal Hiding; - - void set_old_order_key (uint32_t ok) { _old_order_key = ok; } - uint32_t old_order_key() const { return _old_order_key; } + + virtual boost::shared_ptr stripable() const = 0; + virtual boost::shared_ptr control() const { return boost::shared_ptr(); } 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 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 (state_id(), property_name, value); + + bool get_gui_property (const std::string& property_name, std::string& value) const; + + template + bool get_gui_property (const std::string& property_name, T& value) const + { + std::string str = gui_property (property_name); + + if (!str.empty ()) { + return PBD::string_to(str, value); + } + return false; + } + + void set_gui_property (const std::string& property_name, const std::string& value); + + void set_gui_property (const std::string& property_name, const char* value) { + set_gui_property (property_name, std::string(value)); + } + + template + void set_gui_property (const std::string& property_name, const T& value) + { + set_gui_property (property_name, PBD::to_string(value)); + } + + void cleanup_gui_properties () { + /* remove related property node from the GUI state */ + gui_object_state().remove_node (state_id()); + property_hashtable.clear (); } - bool marked_for_display () const; + void set_selected (bool yn); + + virtual bool marked_for_display () const; virtual bool set_marked_for_display (bool); static GUIObjectState& gui_object_state(); void clear_property_cache() { property_hashtable.clear(); } - - protected: - - AxisView (ARDOUR::Session* sess); - virtual ~AxisView(); /** * Generate a new random TrackView color, unique from those colors already used. @@ -89,15 +111,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 used_colors; Gtk::Label name_label; mutable boost::unordered_map property_hashtable; - uint32_t _old_order_key; }; /* class AxisView */ #endif /* __ardour_gtk_axis_view_h__ */ -