X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fardour%2Fautomatable.h;h=c9e14cfae5170f00ad660d3a1240987bc106c99c;hb=424cacfbc83516d9e935bd93135e58b34dcfc002;hp=c9e900e6a9d908f07a1a81c6381fe87d22e88c37;hpb=15b5fce90480490455237da917167b0bcb5ce946;p=ardour.git diff --git a/libs/ardour/ardour/automatable.h b/libs/ardour/ardour/automatable.h index c9e900e6a9..c9e14cfae5 100644 --- a/libs/ardour/ardour/automatable.h +++ b/libs/ardour/ardour/automatable.h @@ -26,6 +26,7 @@ #include #include "pbd/signals.h" #include "evoral/ControlSet.hpp" +#include "ardour/libardour_visibility.h" #include "ardour/types.h" class XMLNode; @@ -35,17 +36,16 @@ namespace ARDOUR { class Session; class AutomationControl; - -/** Note this class is abstract, actual objects must either be - * an AutomatableControls or an AutomatableSequence +/* The inherited ControlSet is virtual because AutomatableSequence inherits + * from this AND EvoralSequence, which is also a ControlSet */ -class Automatable : virtual public Evoral::ControlSet +class LIBARDOUR_API Automatable : virtual public Evoral::ControlSet { public: Automatable(Session&); - Automatable (const Automatable& other); + Automatable (const Automatable& other); - virtual ~Automatable() {} + virtual ~Automatable(); boost::shared_ptr control_factory(const Evoral::Parameter& id); @@ -57,12 +57,14 @@ public: automation_control (const Evoral::Parameter& id) const; virtual void add_control(boost::shared_ptr); + virtual bool find_next_event(double start, double end, Evoral::ControlEvent& ev, bool only_active = true) const; void clear_controls (); - virtual void automation_snapshot (framepos_t now, bool force); + virtual void transport_located (framepos_t now); virtual void transport_stopped (framepos_t now); virtual std::string describe_parameter(Evoral::Parameter param); + virtual std::string value_as_string (boost::shared_ptr) const; AutoState get_parameter_automation_state (Evoral::Parameter param); virtual void set_parameter_automation_state (Evoral::Parameter param, AutoState); @@ -72,31 +74,16 @@ public: void protect_automation (); - void what_has_visible_data(std::set&) const; const std::set& what_can_be_automated() const { return _can_automate_list; } + void what_has_existing_automation (std::set&) const; - void mark_automation_visible(Evoral::Parameter, bool); - - inline bool should_snapshot (framepos_t now) { - return (_last_automation_snapshot > now - || (now - _last_automation_snapshot) > _automation_interval); - } - - static void set_automation_interval (framecnt_t frames) { - _automation_interval = frames; - } - - static framecnt_t automation_interval() { - return _automation_interval; - } - - typedef Evoral::ControlSet::Controls Controls; - - static const std::string xml_node_name; + static const std::string xml_node_name; int set_automation_xml_state (const XMLNode&, Evoral::Parameter default_param); XMLNode& get_automation_xml_state(); - + + PBD::Signal0 AutomationStateChanged; + protected: Session& _a_session; @@ -107,11 +94,9 @@ public: int load_automation (const std::string& path); int old_set_automation_state(const XMLNode&); - std::set _visible_controls; std::set _can_automate_list; framepos_t _last_automation_snapshot; - static framecnt_t _automation_interval; private: PBD::ScopedConnectionList _control_connections; ///< connections to our controls' signals