add nominal owners for all action groups
[ardour.git] / gtk2_ardour / gain_meter.h
index 4bd54af6e90ad6711dc5ed55f67c588016c29d2e..cd8c1b552f380e6a18b0be1e959e27ca483a8390 100644 (file)
 #include <vector>
 #include <map>
 
-#include <gtkmm/box.h>
 #include <gtkmm/adjustment.h>
-#include <gtkmm/frame.h>
-#include <gtkmm/eventbox.h>
+#include <gtkmm/alignment.h>
+#include <gtkmm/box.h>
 #include <gtkmm/button.h>
-#include <gtkmm/table.h>
 #include <gtkmm/drawingarea.h>
-#include <gdkmm/colormap.h>
+#include <gtkmm/eventbox.h>
+#include <gtkmm/frame.h>
+#include <gtkmm/table.h>
+
+//#include <gdkmm/colormap.h>
 
 #include "pbd/signals.h"
 
 #include "ardour/types.h"
 #include "ardour/session_handle.h"
 
-#include "ardour_button.h"
-
-#include "gtkmm2ext/click_box.h"
-#include "gtkmm2ext/focus_entry.h"
-#include "gtkmm2ext/slider_controller.h"
+#include "widgets/ardour_button.h"
+#include "widgets/focus_entry.h"
+#include "widgets/slider_controller.h"
 
 #include "enums.h"
 #include "level_meter.h"
@@ -57,21 +57,25 @@ namespace ARDOUR {
        class Amp;
        class Automatable;
 }
-namespace Gtkmm2ext {
-       class FastMeter;
-}
+
 namespace Gtk {
        class Menu;
 }
 
+enum MeterPointChangeTarget {
+       MeterPointChangeAll,
+       MeterPointChangeGroup,
+       MeterPointChangeSingle
+};
+
 class GainMeterBase : virtual public sigc::trackable, ARDOUR::SessionHandlePtr
 {
-  public:
-        GainMeterBase (ARDOUR::Session*, bool horizontal, int, int);
+public:
+       GainMeterBase (ARDOUR::Session*, bool horizontal, int, int);
        virtual ~GainMeterBase ();
 
        virtual void set_controls (boost::shared_ptr<ARDOUR::Route> route,
-                                  boost::shared_ptr<ARDOUR::PeakMeter> meter,
+                                  boost::shared_ptr<ARDOUR::PeakMeter> meter,
                                   boost::shared_ptr<ARDOUR::Amp> amp,
                                   boost::shared_ptr<ARDOUR::GainControl> control);
 
@@ -91,18 +95,23 @@ class GainMeterBase : virtual public sigc::trackable, ARDOUR::SessionHandlePtr
        boost::shared_ptr<PBD::Controllable> get_controllable();
 
        LevelMeterHBox& get_level_meter() const { return *level_meter; }
-       Gtkmm2ext::SliderController& get_gain_slider() const { return *gain_slider; }
+       ArdourWidgets::SliderController& get_gain_slider() const { return *gain_slider; }
 
        /** Emitted in the GUI thread when a button is pressed over the level meter;
         *  return true if the event is handled.
         */
        PBD::Signal1<bool, GdkEventButton *> LevelMeterButtonPress;
 
-  protected:
+       static std::string astate_string (ARDOUR::AutoState);
+       static std::string short_astate_string (ARDOUR::AutoState);
+       static std::string _astate_string (ARDOUR::AutoState, bool);
+
+protected:
 
        friend class MixerStrip;
        friend class MeterStrip;
        friend class RouteTimeAxisView;
+       friend class VCAMasterStrip;
        boost::shared_ptr<ARDOUR::Route> _route;
        boost::shared_ptr<ARDOUR::PeakMeter> _meter;
        boost::shared_ptr<ARDOUR::Amp> _amp;
@@ -113,46 +122,35 @@ class GainMeterBase : virtual public sigc::trackable, ARDOUR::SessionHandlePtr
        bool ignore_toggle;
        bool next_release_selects;
 
-       Gtkmm2ext::SliderController *gain_slider;
-       Gtk::Adjustment              gain_adjustment;
-       Gtkmm2ext::FocusEntry        gain_display;
-       Gtkmm2ext::FocusEntry        peak_display;
-//     Gtk::Button                  peak_display;
-       Gtk::DrawingArea             meter_metric_area;
-       Gtk::DrawingArea             meter_ticks1_area;
-       Gtk::DrawingArea             meter_ticks2_area;
-       LevelMeterHBox              *level_meter;
+       ArdourWidgets::SliderController* gain_slider;
+       Gtk::Adjustment                  gain_adjustment;
+       ArdourWidgets::FocusEntry        gain_display;
+       ArdourWidgets::FocusEntry        peak_display;
+       Gtk::DrawingArea                 meter_metric_area;
+       Gtk::DrawingArea                 meter_ticks1_area;
+       Gtk::DrawingArea                 meter_ticks2_area;
+       LevelMeterHBox*                  level_meter;
 
        sigc::connection gain_watching;
 
-       ArdourButton gain_automation_style_button;
-       ArdourButton gain_automation_state_button;
+       ArdourWidgets::ArdourButton gain_automation_state_button;
 
        Gtk::Menu gain_astate_menu;
-       Gtk::Menu gain_astyle_menu;
+
+       ArdourWidgets::ArdourButton meter_point_button;
+
+       Gtk::Menu meter_point_menu;
 
        void set_gain_astate (ARDOUR::AutoState);
        bool gain_astate_propagate;
        static sigc::signal<void, ARDOUR::AutoState> ChangeGainAutomationState;
 
-       gint gain_automation_style_button_event (GdkEventButton *);
        gint gain_automation_state_button_event (GdkEventButton *);
-       gint pan_automation_style_button_event (GdkEventButton *);
        gint pan_automation_state_button_event (GdkEventButton *);
 
        void gain_automation_state_changed();
-       void gain_automation_style_changed();
 
        void setup_gain_adjustment ();
-
-       std::string astate_string (ARDOUR::AutoState);
-       std::string short_astate_string (ARDOUR::AutoState);
-       std::string _astate_string (ARDOUR::AutoState, bool);
-
-       std::string astyle_string (ARDOUR::AutoStyle);
-       std::string short_astyle_string (ARDOUR::AutoStyle);
-       std::string _astyle_string (ARDOUR::AutoStyle, bool);
-
        Width _width;
 
        void show_gain ();
@@ -164,13 +162,14 @@ class GainMeterBase : virtual public sigc::trackable, ARDOUR::SessionHandlePtr
        void fader_moved ();
        void gain_changed ();
 
-       void meter_point_clicked ();
+       void meter_point_clicked (ARDOUR::MeterPoint);
        void gain_unit_changed ();
 
        virtual void hide_all_meters ();
 
        gint meter_button_press (GdkEventButton*, uint32_t);
 
+       bool peak_button_press (GdkEventButton*);
        bool peak_button_release (GdkEventButton*);
        bool gain_key_press (GdkEventKey*);
 
@@ -182,11 +181,11 @@ class GainMeterBase : virtual public sigc::trackable, ARDOUR::SessionHandlePtr
 
        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*);
-       bool wait_for_release;
        ARDOUR::MeterPoint old_meter_point;
 
+       MeterPointChangeTarget meter_point_change_target;
+
        void parameter_changed (const char*);
 
        void reset_peak_display ();
@@ -212,9 +211,9 @@ class GainMeter : public GainMeterBase, public Gtk::VBox
        virtual ~GainMeter ();
 
        virtual void set_controls (boost::shared_ptr<ARDOUR::Route> route,
-                                  boost::shared_ptr<ARDOUR::PeakMeter> meter,
+                                  boost::shared_ptr<ARDOUR::PeakMeter> meter,
                                   boost::shared_ptr<ARDOUR::Amp> amp,
-                                  boost::shared_ptr<ARDOUR::GainControl> control);
+                                  boost::shared_ptr<ARDOUR::GainControl> control);
 
        int get_gm_width ();
        void setup_meters (int len=0);