summaryrefslogtreecommitdiffstats
path: root/src/progs/ingenuity/ControlPanel.cpp
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2006-10-15 17:05:52 +0000
committerDavid Robillard <d@drobilla.net>2006-10-15 17:05:52 +0000
commit14542a4634cb211be5bdf590574ae3b8e1715486 (patch)
tree16cd399476bbe88a8160f58a6af33e83dc391744 /src/progs/ingenuity/ControlPanel.cpp
parent4de1556353332eeb98a50bf46a51771702231bd4 (diff)
downloadingen-14542a4634cb211be5bdf590574ae3b8e1715486.tar.gz
ingen-14542a4634cb211be5bdf590574ae3b8e1715486.tar.bz2
ingen-14542a4634cb211be5bdf590574ae3b8e1715486.zip
Vertical control strips in Ingen (loaded from Glade now)
git-svn-id: http://svn.drobilla.net/lad/ingen@174 a436a847-0d15-0410-975c-d299462d15a1
Diffstat (limited to 'src/progs/ingenuity/ControlPanel.cpp')
-rw-r--r--src/progs/ingenuity/ControlPanel.cpp60
1 files changed, 19 insertions, 41 deletions
diff --git a/src/progs/ingenuity/ControlPanel.cpp b/src/progs/ingenuity/ControlPanel.cpp
index 73317bd9..eb316860 100644
--- a/src/progs/ingenuity/ControlPanel.cpp
+++ b/src/progs/ingenuity/ControlPanel.cpp
@@ -21,12 +21,13 @@
#include "NodeModel.h"
#include "PortModel.h"
#include "ControlGroups.h"
+#include "GladeFactory.h"
namespace Ingenuity {
ControlPanel::ControlPanel(BaseObjectType* cobject, const Glib::RefPtr<Gnome::Glade::Xml>& xml)
-: Gtk::VBox(cobject),
+: Gtk::HBox(cobject),
m_callback_enabled(true)
{
xml->get_widget("control_panel_controls_box", m_control_box);
@@ -95,23 +96,30 @@ ControlPanel::add_port(SharedPtr<PortModel> pm)
// Add port
if (pm->is_control() && pm->is_input()) {
bool separator = (m_controls.size() > 0);
- ControlGroup* cg = NULL;
+ SliderControlGroup* cg = NULL;
if (pm->is_integer())
- cg = new IntegerControlGroup(this, pm, separator);
+ cerr << "FIXME: integer\n";
+ //cg = new IntegerControlGroup(this, pm, separator);
else if (pm->is_toggle())
- cg = new ToggleControlGroup(this, pm, separator);
- else
- cg = new SliderControlGroup(this, pm, separator);
+ cerr << "FIXME: toggle\n";
+ //cg = new ToggleControlGroup(this, pm, separator);
+ else {
+ Glib::RefPtr<Gnome::Glade::Xml> xml = GladeFactory::new_glade_reference("control_strip");
+ xml->get_widget_derived("control_strip", cg);
+ cg->init(this, pm, separator);
+ }
m_controls.push_back(cg);
m_control_box->pack_start(*cg, false, false, 0);
- if (pm->connected())
+ /*if (pm->connected())
cg->disable();
else
- cg->enable();
+ cg->enable();*/
+
+ cg->show();
- cerr << "FIXME: Control panel add port\n";
+ cerr << "FIXME: control panel connected port tracking\n";
// pm->connection_sig.connect(bind(sigc::mem_fun(this, &ControlPanel::connection), pm))
// pm->disconnection_sig.connect(bind(sigc::mem_fun(this, &ControlPanel::disconnection), pm))
}
@@ -167,6 +175,7 @@ ControlPanel::rename_port(const Path& old_path, const Path& new_path)
}
*/
+#if 0
/** Enable the control for the given port.
*
* Used when all connections to port are un-made.
@@ -197,7 +206,7 @@ ControlPanel::disable_port(const Path& path)
}
}
}
-
+#endif
/** Callback for ControlGroups to notify this of a change.
*/
@@ -214,37 +223,6 @@ ControlPanel::value_changed(const Path& port_path, float val)
}
}
-/*
-void
-ControlPanel::set_range_min(const Path& port_path, float val)
-{
- bool found = false;
- for (vector<ControlGroup*>::iterator i = m_controls.begin(); i != m_controls.end(); ++i) {
- if ((*i)->port_model()->path() == port_path) {
- found = true;
- (*i)->set_min(val);
- }
- }
- if (found == false)
- cerr << "[ControlPanel::set_range_min] Unable to find control " << port_path << endl;
-}
-
-
-void
-ControlPanel::set_range_max(const Path& port_path, float val)
-{
- bool found = false;
- for (vector<ControlGroup*>::iterator i = m_controls.begin(); i != m_controls.end(); ++i) {
- if ((*i)->port_model()->path() == port_path) {
- found = true;
- (*i)->set_max(val);
- }
- }
- if (found == false)
- cerr << "[ControlPanel::set_range_max] Unable to find control " << port_path << endl;
-}
-*/
-
void
ControlPanel::all_voices_selected()
{