added RCU handling of Session route list, and major use of shared_ptr<T> everywhere...
[ardour.git] / gtk2_ardour / panner_ui.h
index e13be3684f2d95b8467a217115d3f9cc44675fd5..76589782331ea7e4f53ff063291ae765e2117f93 100644 (file)
 #define __ardour_gtk_panner_ui_h__
 
 #include <vector>
-#include <gtkmm.h>
-#include <gtkmm2ext/slider_controller.h>
+
+#include <gtkmm/box.h>
+#include <gtkmm/adjustment.h>
+#include <gtkmm/viewport.h>
+#include <gtkmm/eventbox.h>
+#include <gtkmm/arrow.h>
+#include <gtkmm/togglebutton.h>
+#include <gtkmm/button.h>
+
 #include <gtkmm2ext/click_box.h>
+#include <gtkmm2ext/slider_controller.h>
 
 #include "enums.h"
 
@@ -39,10 +47,15 @@ namespace Gtkmm2ext {
        class BarController;
 }
 
+namespace Gtk {
+       class Menu;
+       class Menuitem;
+}
+
 class PannerUI : public Gtk::HBox
 {
   public:
-       PannerUI (ARDOUR::IO&, ARDOUR::Session&);
+       PannerUI (boost::shared_ptr<ARDOUR::IO>, ARDOUR::Session&);
        ~PannerUI ();
 
        void pan_changed (void *);
@@ -58,7 +71,8 @@ class PannerUI : public Gtk::HBox
        void set_meter_strip_name (string name);
 
   private:
-       ARDOUR::IO& _io;
+       friend class MixerStrip;
+       boost::shared_ptr<ARDOUR::IO> _io;
        ARDOUR::Session& _session;
 
        bool ignore_toggle;
@@ -77,15 +91,19 @@ class PannerUI : public Gtk::HBox
        Gtk::VBox           pan_vbox;
        Width              _width;
 
-       gint panning_scroll_button_press_event (GdkEventButton*, int32_t dir);
-       gint panning_scroll_button_release_event (GdkEventButton*, int32_t dir);
-       
        Gtk::ToggleButton   panning_link_button;
        Gtk::Button         panning_link_direction_button;
        Gtk::HBox           panning_link_box;
 
-       gint panning_link_button_press (GdkEventButton*);
-       gint panning_link_button_release (GdkEventButton*);
+       bool panning_link_button_press (GdkEventButton*);
+       bool panning_link_button_release (GdkEventButton*);
+
+       Gtk::Menu pan_astate_menu;
+       Gtk::Menu pan_astyle_menu;
+
+       Gtk::Button pan_automation_style_button;
+       Gtk::ToggleButton pan_automation_state_button;
+
        void panning_link_direction_clicked ();
 
        vector<Gtk::Adjustment*> pan_adjustments;
@@ -108,15 +126,28 @@ class PannerUI : public Gtk::HBox
        gint start_pan_touch (GdkEventButton*);
        gint end_pan_touch (GdkEventButton*);
 
-       gint entry_focus_event (GdkEventFocus* ev);
+       bool pan_button_event (GdkEventButton*, uint32_t which);
 
-       gint pan_button_event (GdkEventButton*, uint32_t which);
        Gtk::Menu* pan_menu;
        Gtk::CheckMenuItem* bypass_menu_item;
        void build_pan_menu (uint32_t which);
        void pan_mute (uint32_t which);
        void pan_reset ();
        void pan_bypass_toggle ();
+
+       void pan_automation_state_changed();
+       void pan_automation_style_changed();
+       gint pan_automation_style_button_event (GdkEventButton *);
+       gint pan_automation_state_button_event (GdkEventButton *);
+       sigc::connection pan_watching;
+
+       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);
 };
 
 #endif /* __ardour_gtk_panner_ui_h__ */