diff options
-rw-r--r-- | src/gui/PatchWindow.hpp | 5 | ||||
-rw-r--r-- | src/gui/Port.cpp | 36 | ||||
-rw-r--r-- | src/gui/Port.hpp | 3 |
3 files changed, 35 insertions, 9 deletions
diff --git a/src/gui/PatchWindow.hpp b/src/gui/PatchWindow.hpp index b3f7ad55..fcb0e3f7 100644 --- a/src/gui/PatchWindow.hpp +++ b/src/gui/PatchWindow.hpp @@ -70,6 +70,9 @@ public: void show_port_status(const PortModel* model, const Raul::Atom& value); + void object_entered(const ObjectModel* model); + void object_left(const ObjectModel* model); + protected: void on_show(); void on_hide(); @@ -79,8 +82,6 @@ private: void patch_port_added(SharedPtr<const PortModel> port); void patch_port_removed(SharedPtr<const PortModel> port); void show_status(const ObjectModel* model); - void object_entered(const ObjectModel* model); - void object_left(const ObjectModel* model); void editable_changed(bool editable); void event_import(); diff --git a/src/gui/Port.cpp b/src/gui/Port.cpp index 950a1df9..eafc6392 100644 --- a/src/gui/Port.cpp +++ b/src/gui/Port.cpp @@ -150,7 +150,20 @@ Port::value_changed(const Atom& value) bool Port::on_event(GdkEvent* ev) { + PatchWindow* win = NULL; switch (ev->type) { + case GDK_ENTER_NOTIFY: + win = get_patch_window(); + if (win) { + win->object_entered(model().get()); + } + break; + case GDK_LEAVE_NOTIFY: + win = get_patch_window(); + if (win) { + win->object_left(model().get()); + } + break; case GDK_BUTTON_PRESS: if (ev->button.button == 1) _pressed = true; @@ -233,6 +246,17 @@ Port::activity(const Raul::Atom& value) } } +PatchWindow* +Port::get_patch_window() const +{ + SharedPtr<const PatchModel> patch = PtrCast<const PatchModel>(model()->parent()); + if (!patch) { + patch = PtrCast<const PatchModel>(model()->parent()->parent()); + } + + return _app.window_factory()->patch_window(patch); +} + void Port::set_control(float value, bool signal) { @@ -240,13 +264,11 @@ Port::set_control(float value, bool signal) Ingen::Shared::World* const world = _app.world(); _app.engine()->set_property(model()->path(), world->uris()->ingen_value, Atom(value)); - PatchWindow* pw = _app.window_factory()->patch_window( - PtrCast<const PatchModel>(model()->parent())); - if (!pw) - pw = _app.window_factory()->patch_window( - PtrCast<const PatchModel>(model()->parent()->parent())); - if (pw) - pw->show_port_status(model().get(), value); + } + + PatchWindow* pw = get_patch_window(); + if (pw) { + pw->show_port_status(model().get(), value); } Ganv::Port::set_control_value(value); diff --git a/src/gui/Port.hpp b/src/gui/Port.hpp index 3cea7bc5..465fc783 100644 --- a/src/gui/Port.hpp +++ b/src/gui/Port.hpp @@ -34,6 +34,7 @@ using Ingen::Client::PortModel; namespace GUI { class App; +class PatchWindow; /** A Port on an Module. * @@ -71,6 +72,8 @@ private: const std::string& name, bool flip = false); + PatchWindow* get_patch_window() const; + void property_changed(const Raul::URI& key, const Raul::Atom& value); bool on_event(GdkEvent* ev); |