X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fgain_meter.h;h=83f51ab946ced2fa8593cfe18446f4750a5e10f2;hb=d08e3b94c5ef75ce5d4d28f3636faa8af4661e17;hp=447271ed5538a723b1825fcd39264d6e203d0f84;hpb=7092ef3d08f3c5e0017ea5c40355404768a33ad4;p=ardour.git diff --git a/gtk2_ardour/gain_meter.h b/gtk2_ardour/gain_meter.h index 447271ed55..83f51ab946 100644 --- a/gtk2_ardour/gain_meter.h +++ b/gtk2_ardour/gain_meter.h @@ -32,19 +32,27 @@ #include #include -#include +#include "pbd/signals.h" -#include -#include -#include +#include "ardour/chan_count.h" +#include "ardour/types.h" +#include "ardour/session_handle.h" + +#include "gtkmm2ext/click_box.h" +#include "gtkmm2ext/focus_entry.h" +#include "gtkmm2ext/slider_controller.h" #include "enums.h" +#include "level_meter.h" namespace ARDOUR { class IO; class Session; class Route; class RouteGroup; + class PeakMeter; + class Amp; + class Automatable; } namespace Gtkmm2ext { class FastMeter; @@ -54,43 +62,50 @@ namespace Gtk { class Menu; } -class GainMeter : public Gtk::VBox +class GainMeterBase : virtual public sigc::trackable, ARDOUR::SessionHandlePtr { public: - GainMeter (boost::shared_ptr, ARDOUR::Session&); - ~GainMeter (); + GainMeterBase (ARDOUR::Session*, const Glib::RefPtr& pix, + bool horizontal, int); + virtual ~GainMeterBase (); - void update_gain_sensitive (); + virtual void set_controls (boost::shared_ptr route, + boost::shared_ptr meter, + boost::shared_ptr amp); + void update_gain_sensitive (); void update_meters (); - void update_meters_falloff (); void effective_gain_display (); + void set_width (Width, int len=0); + void set_meter_strip_name (const char * name); + void set_fader_name (const char * name); - void set_width (Width); - void setup_meters (); + virtual void setup_meters (int len=0); - int get_gm_width (); + boost::shared_ptr get_controllable(); - void set_meter_strip_name (const char * name); - void set_fader_name (const char * name); + LevelMeter& get_level_meter() const { return *level_meter; } + Gtkmm2ext::SliderController& get_gain_slider() const { return *gain_slider; } - private: + protected: friend class MixerStrip; - boost::shared_ptr _io; - ARDOUR::Session& _session; + boost::shared_ptr _route; + boost::shared_ptr _meter; + boost::shared_ptr _amp; + std::vector connections; + PBD::ScopedConnectionList model_connections; bool ignore_toggle; bool next_release_selects; - Gtkmm2ext::VSliderController *gain_slider; + Gtkmm2ext::SliderController *gain_slider; Gtk::Adjustment gain_adjustment; Gtkmm2ext::FocusEntry gain_display; Gtk::Button peak_display; - Gtk::HBox gain_display_box; - Gtk::HBox fader_box; Gtk::DrawingArea meter_metric_area; + LevelMeter *level_meter; sigc::connection gain_watching; @@ -116,59 +131,34 @@ class GainMeter : public Gtk::VBox std::string short_astyle_string (ARDOUR::AutoStyle); std::string _astyle_string (ARDOUR::AutoStyle, bool); - Width _width; - - static std::map > metric_pixmaps; - static Glib::RefPtr render_metrics (Gtk::Widget&); - - gint meter_metrics_expose (GdkEventExpose *); + Width _width; void show_gain (); void gain_activated (); bool gain_focused (GdkEventFocus*); - struct MeterInfo { - Gtkmm2ext::FastMeter *meter; - gint16 width; - bool packed; - - MeterInfo() { - meter = 0; - width = 0; - packed = false; - } - }; - - static const guint16 regular_meter_width = 5; - static const guint16 thin_meter_width = 2; - vector meters; - float max_peak; - - Gtk::VBox* fader_vbox; - Gtk::HBox hbox; - Gtk::HBox meter_packer; + float max_peak; void gain_adjusted (); - void gain_changed (void *); - + void gain_changed (); + void meter_point_clicked (); void gain_unit_changed (); - - void hide_all_meters (); + + virtual void hide_all_meters (); gint meter_button_press (GdkEventButton*, uint32_t); - gint meter_button_release (GdkEventButton*, uint32_t); bool peak_button_release (GdkEventButton*); bool gain_key_press (GdkEventKey*); - + Gtk::Menu* meter_menu; void popup_meter_menu (GdkEventButton*); - gint start_gain_touch (GdkEventButton*); - gint end_gain_touch (GdkEventButton*); + bool gain_slider_button_press (GdkEventButton *); + bool gain_slider_button_release (GdkEventButton *); - void set_mix_group_meter_point (ARDOUR::Route&, ARDOUR::MeterPoint); + void set_route_group_meter_point (ARDOUR::Route&, ARDOUR::MeterPoint); void set_meter_point (ARDOUR::Route&, ARDOUR::MeterPoint); gint meter_release (GdkEventButton*); gint meter_press (GdkEventButton*); @@ -183,12 +173,48 @@ class GainMeter : public Gtk::VBox static sigc::signal ResetAllPeakDisplays; static sigc::signal ResetGroupPeakDisplays; - static Glib::RefPtr slider; - static Glib::RefPtr rail; - static int setup_slider_pix (); - void on_theme_changed (); bool style_changed; + bool dpi_changed; + bool color_changed; + void color_handler(bool); + bool _is_midi; +}; + +class GainMeter : public GainMeterBase, public Gtk::VBox +{ + public: + GainMeter (ARDOUR::Session*, int); + ~GainMeter () {} + + virtual void set_controls (boost::shared_ptr route, + boost::shared_ptr meter, + boost::shared_ptr amp); + + int get_gm_width (); + void setup_meters (int len=0); + + static void setup_slider_pix (); + + protected: + void hide_all_meters (); + + gint meter_metrics_expose (GdkEventExpose *); + + static std::map > metric_pixmaps; + static Glib::RefPtr render_metrics (Gtk::Widget &, std::vector); + + private: + + void meter_configuration_changed (ARDOUR::ChanCount); + + Gtk::HBox gain_display_box; + Gtk::HBox fader_box; + Gtk::VBox* fader_vbox; + Gtk::HBox hbox; + std::vector _types; + + static Glib::RefPtr slider; }; #endif /* __ardour_gtk_gain_meter_h__ */