mirror of
https://github.com/Ardour/ardour.git
synced 2025-12-06 06:44:57 +01:00
Show panner drag information tool-tip style, and also show
it when the button is pressed to start a drag (#4584 and #4585). git-svn-id: svn://localhost/ardour2/branches/3.0@11072 d708f5d6-7413-0410-9779-e7cbd77b26cf
This commit is contained in:
parent
6e79521e8b
commit
2adb3fb579
5 changed files with 50 additions and 23 deletions
|
|
@ -59,7 +59,6 @@ bool MonoPanner::have_colors = false;
|
|||
MonoPanner::MonoPanner (boost::shared_ptr<ARDOUR::Panner> panner)
|
||||
: PannerInterface (panner)
|
||||
, position_control (_panner->pannable()->pan_azimuth_control)
|
||||
, dragging (false)
|
||||
, drag_start_x (0)
|
||||
, last_drag_x (0)
|
||||
, accumulated_delta (0)
|
||||
|
|
@ -251,7 +250,7 @@ MonoPanner::on_button_press_event (GdkEventButton* ev)
|
|||
drag_start_x = ev->x;
|
||||
last_drag_x = ev->x;
|
||||
|
||||
dragging = false;
|
||||
_dragging = false;
|
||||
accumulated_delta = 0;
|
||||
detented = false;
|
||||
|
||||
|
|
@ -286,7 +285,7 @@ MonoPanner::on_button_press_event (GdkEventButton* ev)
|
|||
position_control->set_value (0.5);
|
||||
}
|
||||
|
||||
dragging = false;
|
||||
_dragging = false;
|
||||
|
||||
} else if (ev->type == GDK_BUTTON_PRESS) {
|
||||
|
||||
|
|
@ -295,8 +294,9 @@ MonoPanner::on_button_press_event (GdkEventButton* ev)
|
|||
return true;
|
||||
}
|
||||
|
||||
dragging = true;
|
||||
_dragging = true;
|
||||
StartGesture ();
|
||||
show_drag_data_window ();
|
||||
}
|
||||
|
||||
return true;
|
||||
|
|
@ -309,13 +309,11 @@ MonoPanner::on_button_release_event (GdkEventButton* ev)
|
|||
return false;
|
||||
}
|
||||
|
||||
dragging = false;
|
||||
_dragging = false;
|
||||
accumulated_delta = 0;
|
||||
detented = false;
|
||||
|
||||
if (_drag_data_window) {
|
||||
_drag_data_window->hide ();
|
||||
}
|
||||
hide_drag_data_window ();
|
||||
|
||||
if (Keyboard::modifier_state_contains (ev->state, Keyboard::TertiaryModifier)) {
|
||||
_panner->reset ();
|
||||
|
|
@ -358,12 +356,10 @@ MonoPanner::on_scroll_event (GdkEventScroll* ev)
|
|||
bool
|
||||
MonoPanner::on_motion_notify_event (GdkEventMotion* ev)
|
||||
{
|
||||
if (!dragging) {
|
||||
if (!_dragging) {
|
||||
return false;
|
||||
}
|
||||
|
||||
show_drag_data_window ();
|
||||
|
||||
int w = get_width();
|
||||
double delta = (ev->x - last_drag_x) / (double) w;
|
||||
|
||||
|
|
|
|||
|
|
@ -54,7 +54,6 @@ class MonoPanner : public PannerInterface
|
|||
private:
|
||||
boost::shared_ptr<PBD::Controllable> position_control;
|
||||
PBD::ScopedConnectionList connections;
|
||||
bool dragging;
|
||||
int drag_start_x;
|
||||
int last_drag_x;
|
||||
double accumulated_delta;
|
||||
|
|
|
|||
|
|
@ -24,6 +24,7 @@
|
|||
|
||||
#include "i18n.h"
|
||||
|
||||
using namespace std;
|
||||
using namespace Gtk;
|
||||
using namespace ARDOUR;
|
||||
using namespace Gtkmm2ext;
|
||||
|
|
@ -32,6 +33,7 @@ PannerInterface::PannerInterface (boost::shared_ptr<Panner> p)
|
|||
: _panner (p)
|
||||
, _drag_data_window (0)
|
||||
, _drag_data_label (0)
|
||||
, _dragging (false)
|
||||
{
|
||||
set_flags (Gtk::CAN_FOCUS);
|
||||
|
||||
|
|
@ -69,6 +71,8 @@ PannerInterface::show_drag_data_window ()
|
|||
_drag_data_window->set_transient_for (*toplevel);
|
||||
}
|
||||
}
|
||||
|
||||
set_drag_data ();
|
||||
|
||||
if (!_drag_data_window->is_visible ()) {
|
||||
/* move the window a little away from the mouse */
|
||||
|
|
@ -79,11 +83,29 @@ PannerInterface::show_drag_data_window ()
|
|||
}
|
||||
}
|
||||
|
||||
void
|
||||
PannerInterface::hide_drag_data_window ()
|
||||
{
|
||||
if (_drag_data_window) {
|
||||
_drag_data_window->hide ();
|
||||
}
|
||||
}
|
||||
|
||||
bool
|
||||
PannerInterface::on_enter_notify_event (GdkEventCrossing *)
|
||||
{
|
||||
grab_focus ();
|
||||
Keyboard::magic_widget_grab_focus ();
|
||||
|
||||
_drag_data_timeout = Glib::signal_timeout().connect (sigc::mem_fun (*this, &PannerInterface::drag_data_timeout), 500);
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
bool
|
||||
PannerInterface::drag_data_timeout ()
|
||||
{
|
||||
show_drag_data_window ();
|
||||
return false;
|
||||
}
|
||||
|
||||
|
|
@ -91,6 +113,12 @@ bool
|
|||
PannerInterface::on_leave_notify_event (GdkEventCrossing *)
|
||||
{
|
||||
Keyboard::magic_widget_drop_focus ();
|
||||
|
||||
_drag_data_timeout.disconnect ();
|
||||
if (!_dragging) {
|
||||
hide_drag_data_window ();
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -39,7 +39,9 @@ protected:
|
|||
virtual void set_drag_data () = 0;
|
||||
|
||||
void show_drag_data_window ();
|
||||
void hide_drag_data_window ();
|
||||
void value_change ();
|
||||
|
||||
bool on_enter_notify_event (GdkEventCrossing *);
|
||||
bool on_leave_notify_event (GdkEventCrossing *);
|
||||
bool on_key_release_event (GdkEventKey *);
|
||||
|
|
@ -47,6 +49,11 @@ protected:
|
|||
boost::shared_ptr<ARDOUR::Panner> _panner;
|
||||
Gtk::Window* _drag_data_window;
|
||||
Gtk::Label* _drag_data_label;
|
||||
bool _dragging;
|
||||
|
||||
private:
|
||||
bool drag_data_timeout ();
|
||||
sigc::connection _drag_data_timeout;
|
||||
};
|
||||
|
||||
#endif
|
||||
|
|
|
|||
|
|
@ -60,7 +60,6 @@ StereoPanner::StereoPanner (boost::shared_ptr<Panner> panner)
|
|||
: PannerInterface (panner)
|
||||
, position_control (_panner->pannable()->pan_azimuth_control)
|
||||
, width_control (_panner->pannable()->pan_width_control)
|
||||
, dragging (false)
|
||||
, dragging_position (false)
|
||||
, dragging_left (false)
|
||||
, dragging_right (false)
|
||||
|
|
@ -270,7 +269,7 @@ StereoPanner::on_button_press_event (GdkEventButton* ev)
|
|||
dragging_position = false;
|
||||
dragging_left = false;
|
||||
dragging_right = false;
|
||||
dragging = false;
|
||||
_dragging = false;
|
||||
accumulated_delta = 0;
|
||||
detented = false;
|
||||
|
||||
|
|
@ -347,7 +346,7 @@ StereoPanner::on_button_press_event (GdkEventButton* ev)
|
|||
}
|
||||
}
|
||||
|
||||
dragging = false;
|
||||
_dragging = false;
|
||||
|
||||
} else if (ev->type == GDK_BUTTON_PRESS) {
|
||||
|
||||
|
|
@ -356,6 +355,8 @@ StereoPanner::on_button_press_event (GdkEventButton* ev)
|
|||
return true;
|
||||
}
|
||||
|
||||
show_drag_data_window ();
|
||||
|
||||
if (ev->y < 20) {
|
||||
/* top section of widget is for position drags */
|
||||
dragging_position = true;
|
||||
|
|
@ -388,7 +389,7 @@ StereoPanner::on_button_press_event (GdkEventButton* ev)
|
|||
StartWidthGesture ();
|
||||
}
|
||||
|
||||
dragging = true;
|
||||
_dragging = true;
|
||||
}
|
||||
|
||||
return true;
|
||||
|
|
@ -403,16 +404,14 @@ StereoPanner::on_button_release_event (GdkEventButton* ev)
|
|||
|
||||
bool const dp = dragging_position;
|
||||
|
||||
dragging = false;
|
||||
_dragging = false;
|
||||
dragging_position = false;
|
||||
dragging_left = false;
|
||||
dragging_right = false;
|
||||
accumulated_delta = 0;
|
||||
detented = false;
|
||||
|
||||
if (_drag_data_window) {
|
||||
_drag_data_window->hide ();
|
||||
}
|
||||
hide_drag_data_window ();
|
||||
|
||||
if (Keyboard::modifier_state_contains (ev->state, Keyboard::TertiaryModifier)) {
|
||||
_panner->reset ();
|
||||
|
|
@ -466,12 +465,10 @@ StereoPanner::on_scroll_event (GdkEventScroll* ev)
|
|||
bool
|
||||
StereoPanner::on_motion_notify_event (GdkEventMotion* ev)
|
||||
{
|
||||
if (!dragging) {
|
||||
if (!_dragging) {
|
||||
return false;
|
||||
}
|
||||
|
||||
show_drag_data_window ();
|
||||
|
||||
int w = get_width();
|
||||
double delta = (ev->x - last_drag_x) / (double) w;
|
||||
double current_width = width_control->get_value ();
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue