X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fardour%2Famp.h;h=20a07c092a3f63f58408a4c528d2b6cb353ce6d5;hb=36ec551a8ad66a99723f54d3149cbcf30d31c077;hp=b811cca17372a1ec6856aab8efffaf32844978c5;hpb=a8bb49e5d89f2689d6aeb61381e3c4bd3560d859;p=ardour.git diff --git a/libs/ardour/ardour/amp.h b/libs/ardour/ardour/amp.h index b811cca173..20a07c092a 100644 --- a/libs/ardour/ardour/amp.h +++ b/libs/ardour/ardour/amp.h @@ -19,6 +19,8 @@ #ifndef __ardour_amp_h__ #define __ardour_amp_h__ +#include "ardour/dB.h" +#include "ardour/libardour_visibility.h" #include "ardour/types.h" #include "ardour/chan_count.h" #include "ardour/processor.h" @@ -27,20 +29,22 @@ namespace ARDOUR { class BufferSet; +class GainControl; class IO; /** Applies a declick operation to all audio inputs, passing the same number of * audio outputs, and passing through any other types unchanged. */ -class Amp : public Processor { +class LIBARDOUR_API Amp : public Processor { public: - Amp(Session& s); + Amp(Session& s, const std::string& display_name, boost::shared_ptr control, bool control_midi_also); - std::string display_name() const; + std::string display_name () const { return _display_name; } + void set_display_name (const std::string& name) { _display_name = name; } bool visible () const; - bool can_support_io_configuration (const ChanCount& in, ChanCount& out) const; + bool can_support_io_configuration (const ChanCount& in, ChanCount& out); bool configure_io (ChanCount in, ChanCount out); void run (BufferSet& bufs, framepos_t start_frame, framepos_t end_frame, pframes_t nframes, bool); @@ -48,6 +52,8 @@ public: bool apply_gain () const { return _apply_gain; } void apply_gain (bool yn) { _apply_gain = yn; } + void set_gain_automation_buffer (gain_t *); + void setup_gain_automation (framepos_t start_frame, framepos_t end_frame, framecnt_t nframes); bool apply_gain_automation() const { return _apply_gain_automation; } @@ -56,40 +62,15 @@ public: XMLNode& state (bool full); int set_state (const XMLNode&, int version); - static void apply_gain (BufferSet& bufs, framecnt_t nframes, gain_t initial, gain_t target); - static void apply_simple_gain(BufferSet& bufs, framecnt_t nframes, gain_t target); + static gain_t apply_gain (BufferSet& bufs, framecnt_t sample_rate, framecnt_t nframes, gain_t initial, gain_t target, bool midi_amp = true); + static void apply_simple_gain(BufferSet& bufs, framecnt_t nframes, gain_t target, bool midi_amp = true); - static void apply_gain (AudioBuffer& buf, framecnt_t nframes, gain_t initial, gain_t target); + static gain_t apply_gain (AudioBuffer& buf, framecnt_t sample_rate, framecnt_t nframes, gain_t initial, gain_t target); static void apply_simple_gain(AudioBuffer& buf, framecnt_t nframes, gain_t target); static void declick (BufferSet& bufs, framecnt_t nframes, int dir); - - gain_t gain () const { return _gain_control->get_value(); } - - void set_gain (gain_t g, void *src); - void inc_gain (gain_t delta, void *src); - static void update_meters(); - /* automation */ - - struct GainControl : public AutomationControl { - GainControl (std::string name, Session& session, Amp* a, const Evoral::Parameter ¶m, - boost::shared_ptr al = boost::shared_ptr() ) - : AutomationControl (session, param, al, name) - , _amp (a) { - set_flags (Controllable::Flag (flags() | Controllable::GainLike)); - } - - void set_value (double val); - double get_value (void) const; - - double user_to_ui (double) const; - double ui_to_user (double) const; - - Amp* _amp; - }; - boost::shared_ptr gain_control() { return _gain_control; } @@ -98,13 +79,22 @@ public: return _gain_control; } + std::string value_as_string (boost::shared_ptr) const; + private: bool _denormal_protection; bool _apply_gain; bool _apply_gain_automation; float _current_gain; + framepos_t _current_automation_frame; + + std::string _display_name; boost::shared_ptr _gain_control; + + /** Buffer that we should use for gain automation */ + gain_t* _gain_automation_buffer; + bool _midi_amp; };