X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=gtk2_ardour%2Fpanner2d.h;h=99377bdd509bf8817a855dcd75276e7f6e05bbcd;hb=01d99870ffdefa1a76093c95250f355db11609d1;hp=9df0355518403de1255d7d1e6d4622d389410b8b;hpb=dd4c0e040f83c1d28a2600db8a8bc70dc1fba0d3;p=ardour.git diff --git a/gtk2_ardour/panner2d.h b/gtk2_ardour/panner2d.h index 9df0355518..99377bdd50 100644 --- a/gtk2_ardour/panner2d.h +++ b/gtk2_ardour/panner2d.h @@ -46,14 +46,14 @@ namespace Gtk { } namespace Pango { - class Layout; + class Container; } class Panner2dWindow; class Panner2d : public Gtk::DrawingArea { - public: + public: Panner2d (boost::shared_ptr, int32_t height); ~Panner2d (); @@ -63,16 +63,14 @@ class Panner2d : public Gtk::DrawingArea int add_signal (const char* text, const PBD::AngularVector&); void move_signal (int which, const PBD::AngularVector&); void reset (uint32_t n_inputs); + void set_send_drawing_mode (bool); boost::shared_ptr get_panner_shell() const { return panner_shell; } - sigc::signal PuckMoved; - sigc::signal TargetMoved; - void cart_to_gtk (PBD::CartesianVector&) const; void gtk_to_cart (PBD::CartesianVector&) const; - protected: + protected: bool on_expose_event (GdkEventExpose *); bool on_button_press_event (GdkEventButton *); bool on_button_release_event (GdkEventButton *); @@ -80,9 +78,9 @@ class Panner2d : public Gtk::DrawingArea bool on_scroll_event (GdkEventScroll *); void on_size_allocate (Gtk::Allocation& alloc); - private: + private: class Target { - public: + public: PBD::AngularVector position; bool visible; std::string text; @@ -98,7 +96,7 @@ class Panner2d : public Gtk::DrawingArea return _selected; } - private: + private: bool _selected; }; @@ -108,23 +106,19 @@ class Panner2d : public Gtk::DrawingArea typedef std::vector Targets; Targets speakers; Targets signals; - Target position; + Target position; Target *drag_target; - int drag_x; - int drag_y; - bool allow_speaker_motion; int width; int height; - double radius; - double border; - double hoffset; - double voffset; - double last_width; + double radius; + double border; + double hoffset; + double voffset; + double last_width; bool did_move; - - gint compute_x (float); - gint compute_y (float); + bool have_elevation; + bool _send_mode; Target *find_closest_object (gdouble x, gdouble y, bool& is_signal); @@ -133,10 +127,10 @@ class Panner2d : public Gtk::DrawingArea void toggle_bypass (); void handle_state_change (); void handle_position_change (); - void label_signals (); + void label_signals (); - PBD::ScopedConnectionList connections; - PBD::ScopedConnectionList panconnect; + PBD::ScopedConnectionList panshell_connections; + PBD::ScopedConnectionList panner_connections; /* cartesian coordinates in GTK units ; adjust to same but on a circle of radius 1.0 and centered in the middle of our area @@ -147,12 +141,12 @@ class Panner2d : public Gtk::DrawingArea class Panner2dWindow : public ArdourWindow { - public: + public: Panner2dWindow (boost::shared_ptr, int32_t height, uint32_t inputs); void reset (uint32_t n_inputs); - private: + private: Panner2d widget; Gtk::HBox hpacker; @@ -161,11 +155,19 @@ class Panner2dWindow : public ArdourWindow Gtk::VBox spinner_box; Gtk::VBox left_side; - std::vector spinners; + Gtk::Adjustment width_adjustment; + Gtk::SpinButton width_spinner; + + PBD::ScopedConnectionList panshell_connections; + PBD::ScopedConnectionList panvalue_connections; + void set_bypassed(); + void set_width(); - void bypass_toggled (); - bool on_key_press_event (GdkEventKey*); - bool on_key_release_event (GdkEventKey*); + void pannable_handler (); + void bypass_toggled (); + void width_changed (); + bool on_key_press_event (GdkEventKey*); + bool on_key_release_event (GdkEventKey*); }; #endif /* __ardour_panner_2d_h__ */