X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Faxis_view.h;h=2a7c3781978d92d8ea5e959c4ed794a2a9fe3cf5;hb=cf89f645ab4a7fae37abd0241c02203353f359ff;hp=4ce76c92ce52b74c74135614acd40075879011cb;hpb=e5e12acc5698090f2c0c614385e457cc0b46fbb0;p=ardour.git diff --git a/gtk2_ardour/axis_view.h b/gtk2_ardour/axis_view.h index 4ce76c92ce..2a7c378197 100644 --- a/gtk2_ardour/axis_view.h +++ b/gtk2_ardour/axis_view.h @@ -37,32 +37,32 @@ 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; } 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 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; @@ -71,15 +71,19 @@ class AxisView : public virtual Selectable, public PBD::ScopedConnectionList, pu gui_object_state().set_property (state_id(), property_name, value); } - bool marked_for_display () const; + void cleanup_gui_properties () { + /* remove related property node from the GUI state */ + gui_object_state().remove_node (state_id()); + property_hashtable.clear (); + } + + void set_selected (bool yn); + + virtual bool marked_for_display () const; virtual bool set_marked_for_display (bool); static GUIObjectState& gui_object_state(); - - protected: - - AxisView (ARDOUR::Session* sess); - virtual ~AxisView(); + void clear_property_cache() { property_hashtable.clear(); } /** * Generate a new random TrackView color, unique from those colors already used. @@ -88,15 +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 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__ */ -