aboutsummaryrefslogtreecommitdiffstats
path: root/src/gui
diff options
context:
space:
mode:
Diffstat (limited to 'src/gui')
-rw-r--r--src/gui/MachinaCanvas.cpp4
-rw-r--r--src/gui/NodeView.cpp21
-rw-r--r--src/gui/NodeView.hpp4
3 files changed, 18 insertions, 11 deletions
diff --git a/src/gui/MachinaCanvas.cpp b/src/gui/MachinaCanvas.cpp
index b0ea6b4..b961a0c 100644
--- a/src/gui/MachinaCanvas.cpp
+++ b/src/gui/MachinaCanvas.cpp
@@ -67,12 +67,12 @@ MachinaCanvas::node_clicked(WeakPtr<NodeView> item, GdkEventButton* event)
action_connect(last, node);
}
- last->set_default_base_color();
+ last->set_default_colors();
_last_clicked.reset();
} else {
_last_clicked = node;
- node->set_base_color(0xFF0000FF);
+ node->set_fill_color(0xFF0000FF);
}
return true;
diff --git a/src/gui/NodeView.cpp b/src/gui/NodeView.cpp
index 4e27594..407961c 100644
--- a/src/gui/NodeView.cpp
+++ b/src/gui/NodeView.cpp
@@ -37,8 +37,8 @@ NodeView::NodeView(Gtk::Window* window,
: FlowCanvas::Ellipse(canvas, "", x, y, 20, 20, false)
, _window(window)
, _node(node)
- , _default_border_color(_border_color)
- , _old_color(_color)
+ , _default_border_color(get_border_color())
+ , _default_fill_color(get_fill_color())
{
signal_click().connect(
sigc::mem_fun(this, &NodeView::on_click));
@@ -133,14 +133,12 @@ NodeView::on_property(Machina::URIInt key, const Raul::Atom& value)
set_border_width(value.get_bool() ? 4.0 : 1.0);
} else if (key == URIs::instance().machina_active) {
if (value.get_bool()) {
- if (_color != active_color) {
- _old_color = _color;
- set_base_color(active_color);
+ if (get_fill_color() != active_color) {
+ set_fill_color(active_color);
set_border_color(active_border_color);
}
- } else if (_color == active_color) {
- set_base_color(_old_color);
- set_border_color(_default_border_color);
+ } else if (get_fill_color() == active_color) {
+ set_default_colors();
}
} else if (key == URIs::instance().machina_enter_action) {
const uint64_t action_id = value.get_int32();
@@ -160,3 +158,10 @@ NodeView::on_action_property(Machina::URIInt key, const Raul::Atom& value)
if (key == URIs::instance().machina_note_number)
show_label(true);
}
+
+void
+NodeView::set_default_colors()
+{
+ set_fill_color(_default_fill_color);
+ set_border_color(_default_border_color);
+}
diff --git a/src/gui/NodeView.hpp b/src/gui/NodeView.hpp
index 9b827c1..b37b73b 100644
--- a/src/gui/NodeView.hpp
+++ b/src/gui/NodeView.hpp
@@ -40,6 +40,8 @@ public:
void update_state(bool show_labels);
+ void set_default_colors();
+
private:
bool on_click(GdkEventButton* ev);
void on_double_click(GdkEventButton* ev);
@@ -52,7 +54,7 @@ private:
Gtk::Window* _window;
SharedPtr<Machina::Client::ClientObject> _node;
uint32_t _default_border_color;
- uint32_t _old_color;
+ uint32_t _default_fill_color;
SharedPtr<Machina::Client::ClientObject> _enter_action;
sigc::connection _enter_action_connection;