summaryrefslogtreecommitdiffstats
path: root/src/progs/ingenuity
diff options
context:
space:
mode:
Diffstat (limited to 'src/progs/ingenuity')
-rw-r--r--src/progs/ingenuity/ControlGroups.cpp83
-rw-r--r--src/progs/ingenuity/ControlGroups.h68
-rw-r--r--src/progs/ingenuity/ControlPanel.cpp5
-rw-r--r--src/progs/ingenuity/ControlPanel.h2
4 files changed, 83 insertions, 75 deletions
diff --git a/src/progs/ingenuity/ControlGroups.cpp b/src/progs/ingenuity/ControlGroups.cpp
index ef94b75f..2c067d8d 100644
--- a/src/progs/ingenuity/ControlGroups.cpp
+++ b/src/progs/ingenuity/ControlGroups.cpp
@@ -26,8 +26,41 @@ using namespace LibOmClient;
namespace OmGtk {
-//////////////////// SliderControlGroup ////////////////////////
+// ////////////////////// ControlGroup ///////////////////////////////// //
+
+ControlGroup::ControlGroup(ControlPanel* panel, CountedPtr<PortModel> pm, bool separator)
+: Gtk::VBox(false, 0),
+ m_control_panel(panel),
+ m_port_model(pm),
+ m_has_separator(separator)
+{
+ assert(m_port_model);
+ assert(panel);
+
+ if (separator) {
+ m_separator = new Gtk::HSeparator();
+ pack_start(*m_separator, false, false, 4);
+ } else {
+ m_separator = NULL;
+ }
+
+ pm->metadata_update_sig.connect(sigc::mem_fun(this, &ControlGroup::metadata_update));
+ pm->control_change_sig.connect(sigc::mem_fun(this, &ControlGroup::set_value));
+}
+
+
+void
+ControlGroup::metadata_update(const string& key, const string& value)
+{
+ if (key == "user-min")
+ set_min(atof(value.c_str()));
+ else if (key == "user-max")
+ set_max(atof(value.c_str()));
+}
+
+
+// ////////////////// SliderControlGroup ////////////////////// //
SliderControlGroup::SliderControlGroup(ControlPanel* panel, CountedPtr<PortModel> pm, bool separator)
: ControlGroup(panel, pm, separator),
@@ -97,7 +130,7 @@ SliderControlGroup::SliderControlGroup(ControlPanel* panel, CountedPtr<PortModel
pack_start(m_header_box, false, false, 0);
pack_start(m_slider_box, false, false, 0);
- update_range();
+ m_slider.set_range(m_port_model->user_min(), m_port_model->user_max());
m_enable_signal = true;
@@ -167,7 +200,13 @@ SliderControlGroup::min_changed()
m_min_spinner.set_value(min);
}
- update_range();
+ m_slider.set_range(min, max);
+
+ if (m_enable_signal) {
+ char temp_buf[16];
+ snprintf(temp_buf, 16, "%f", min);
+ Controller::instance().set_metadata(m_port_model->path(), "user-min", temp_buf);
+ }
}
@@ -182,27 +221,11 @@ SliderControlGroup::max_changed()
m_max_spinner.set_value(max);
}
- update_range();
-}
-
-
-void
-SliderControlGroup::update_range()
-{
- const double min = m_min_spinner.get_value();
- const double max = m_max_spinner.get_value();
-
- assert(min < max);
m_slider.set_range(min, max);
-
- m_port_model->user_min(min);
- m_port_model->user_max(max);
-
+
if (m_enable_signal) {
char temp_buf[16];
- snprintf(temp_buf, 16, "%f", m_port_model->user_min());
- Controller::instance().set_metadata(m_port_model->path(), "user-min", temp_buf);
- snprintf(temp_buf, 16, "%f", m_port_model->user_max());
+ snprintf(temp_buf, 16, "%f", max);
Controller::instance().set_metadata(m_port_model->path(), "user-max", temp_buf);
}
}
@@ -229,15 +252,17 @@ SliderControlGroup::update_value_from_spinner()
if (m_enable_signal) {
m_enable_signal = false;
const float value = m_value_spinner.get_value();
- if (value < m_min_spinner.get_value())
+
+ if (value < m_min_spinner.get_value()) {
m_min_spinner.set_value(value);
- if (value > m_max_spinner.get_value())
+ m_slider.set_range(m_min_spinner.get_value(), m_max_spinner.get_value());
+ }
+ if (value > m_max_spinner.get_value()) {
m_max_spinner.set_value(value);
+ m_slider.set_range(m_min_spinner.get_value(), m_max_spinner.get_value());
+ }
- m_enable_signal = false;
- update_range();
m_slider.set_value(m_value_spinner.get_value());
- m_enable_signal = true;
m_control_panel->value_changed(m_port_model->path(), value);
@@ -268,7 +293,7 @@ SliderControlGroup::slider_pressed(GdkEvent* ev)
}
-/////////////// IntegerControlGroup ////////////////
+// ///////////// IntegerControlGroup ////////////// //
IntegerControlGroup::IntegerControlGroup(ControlPanel* panel, CountedPtr<PortModel> pm, bool separator)
@@ -311,7 +336,6 @@ IntegerControlGroup::set_value(float val)
//cerr << "[IntegerControlGroup] Setting value to " << val << endl;
m_enable_signal = false;
m_spinner.set_value(val);
- m_port_model->value(val);
m_enable_signal = true;
}
@@ -343,7 +367,7 @@ IntegerControlGroup::update_value()
}
-/////////////// ToggleControlGroup ////////////////
+// ///////////// ToggleControlGroup ////////////// //
ToggleControlGroup::ToggleControlGroup(ControlPanel* panel, CountedPtr<PortModel> pm, bool separator)
@@ -383,7 +407,6 @@ ToggleControlGroup::set_value(float val)
//cerr << "[ToggleControlGroup] Setting value to " << val << endl;
m_enable_signal = false;
m_checkbutton.set_active( (val > 0.0f) );
- m_port_model->value(val);
m_enable_signal = true;
}
diff --git a/src/progs/ingenuity/ControlGroups.h b/src/progs/ingenuity/ControlGroups.h
index 6bd32c50..0e9d5810 100644
--- a/src/progs/ingenuity/ControlGroups.h
+++ b/src/progs/ingenuity/ControlGroups.h
@@ -33,52 +33,38 @@ namespace OmGtk {
class ControlPanel;
-/** A group of controls in a NodeControlWindow.
+/** A group of controls (for a single Port) in a NodeControlWindow.
*
* \ingroup OmGtk
*/
class ControlGroup : public Gtk::VBox
{
public:
- ControlGroup(ControlPanel* panel, CountedPtr<PortModel> pm, bool separator)
- : Gtk::VBox(false, 0),
- m_control_panel(panel),
- m_port_model(pm),
- m_has_separator(separator)
- {
- assert(m_port_model);
- assert(panel);
-
- if (separator) {
- m_separator = new Gtk::HSeparator();
- pack_start(*m_separator, false, false, 4);
- } else {
- m_separator = NULL;
- }
- }
+ ControlGroup(ControlPanel* panel, CountedPtr<PortModel> pm, bool separator);
~ControlGroup() { delete m_separator; }
- virtual void set_name(const string& name) {}
-
- virtual void set_value(float val) = 0;
-
inline const CountedPtr<PortModel> port_model() const { return m_port_model; }
- virtual void set_min(float val) {}
- virtual void set_max(float val) {}
-
- void remove_separator() { assert(m_has_separator);
- remove(*m_separator); delete m_separator; }
+ void remove_separator() {
+ assert(m_has_separator); remove(*m_separator); delete m_separator;
+ }
virtual void enable() {}
virtual void disable() {}
protected:
- ControlPanel* m_control_panel;
- CountedPtr<PortModel> m_port_model;
- bool m_has_separator;
- Gtk::HSeparator* m_separator;
+ virtual void set_name(const string& name) {}
+ virtual void set_value(float val) = 0;
+ virtual void set_min(float val) {}
+ virtual void set_max(float val) {}
+
+ virtual void metadata_update(const string& key, const string& value);
+
+ ControlPanel* m_control_panel;
+ CountedPtr<PortModel> m_port_model;
+ bool m_has_separator;
+ Gtk::HSeparator* m_separator;
};
@@ -90,17 +76,17 @@ class SliderControlGroup : public ControlGroup
{
public:
SliderControlGroup(ControlPanel* panel, CountedPtr<PortModel> pm, bool separator);
-
+
+ void enable();
+ void disable();
+
+private:
void set_name(const string& name);
inline void set_value(const float val);
void set_min(float val);
void set_max(float val);
- void enable();
- void disable();
-
-private:
void min_changed();
void max_changed();
void update_range();
@@ -150,13 +136,13 @@ class IntegerControlGroup : public ControlGroup
public:
IntegerControlGroup(ControlPanel* panel, CountedPtr<PortModel> pm, bool separator);
- void set_name(const string& name);
- void set_value(float val);
-
void enable();
void disable();
private:
+ void set_name(const string& name);
+ void set_value(float val);
+
void update_value();
bool m_enable_signal;
@@ -175,13 +161,13 @@ class ToggleControlGroup : public ControlGroup
public:
ToggleControlGroup(ControlPanel* panel, CountedPtr<PortModel> pm, bool separator);
- void set_name(const string& name);
- void set_value(float val);
-
void enable();
void disable();
private:
+ void set_name(const string& name);
+ void set_value(float val);
+
void update_value();
bool m_enable_signal;
diff --git a/src/progs/ingenuity/ControlPanel.cpp b/src/progs/ingenuity/ControlPanel.cpp
index ee511e36..bb3e74d4 100644
--- a/src/progs/ingenuity/ControlPanel.cpp
+++ b/src/progs/ingenuity/ControlPanel.cpp
@@ -117,8 +117,6 @@ ControlPanel::add_port(PortController* port)
else
cg = new SliderControlGroup(this, pm, separator);
- // FIXME: ControlGroup constructor should do this
- pm->control_change_sig.connect(sigc::mem_fun(cg, &ControlGroup::set_value));
m_controls.push_back(cg);
m_control_box->pack_start(*cg, false, false, 0);
@@ -168,6 +166,7 @@ ControlPanel::remove_port(const Path& path)
/** Rename the control for the given port.
*/
+/*
void
ControlPanel::rename_port(const Path& old_path, const Path& new_path)
{
@@ -178,7 +177,7 @@ ControlPanel::rename_port(const Path& old_path, const Path& new_path)
}
}
}
-
+*/
/** Enable the control for the given port.
*
diff --git a/src/progs/ingenuity/ControlPanel.h b/src/progs/ingenuity/ControlPanel.h
index 77628156..ea6cede5 100644
--- a/src/progs/ingenuity/ControlPanel.h
+++ b/src/progs/ingenuity/ControlPanel.h
@@ -63,7 +63,7 @@ public:
void add_port(PortController* port);
void remove_port(const Path& path);
- void rename_port(const Path& old_path, const Path& new_path);
+ //void rename_port(const Path& old_path, const Path& new_path);
void enable_port(const Path& path);
void disable_port(const Path& path);