summaryrefslogtreecommitdiffstats
path: root/src/progs/ingenuity/ControlGroups.cpp
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2007-05-04 03:59:38 +0000
committerDavid Robillard <d@drobilla.net>2007-05-04 03:59:38 +0000
commita96166710faf2447ed10194d1829db5564b0dff9 (patch)
tree4eb792fcceee17f188566fc6e6bee11e5a8c4336 /src/progs/ingenuity/ControlGroups.cpp
parentcf14d321e8f084f742b03e09c086d5ef30297492 (diff)
downloadingen-a96166710faf2447ed10194d1829db5564b0dff9.tar.gz
ingen-a96166710faf2447ed10194d1829db5564b0dff9.tar.bz2
ingen-a96166710faf2447ed10194d1829db5564b0dff9.zip
Made engine, serialisation, client library, and GUI all dynamically loaded modules.
Combined all executables into a single "ingen" program which can do everything. git-svn-id: http://svn.drobilla.net/lad/ingen@493 a436a847-0d15-0410-975c-d299462d15a1
Diffstat (limited to 'src/progs/ingenuity/ControlGroups.cpp')
-rw-r--r--src/progs/ingenuity/ControlGroups.cpp428
1 files changed, 0 insertions, 428 deletions
diff --git a/src/progs/ingenuity/ControlGroups.cpp b/src/progs/ingenuity/ControlGroups.cpp
deleted file mode 100644
index 2cdbf0a3..00000000
--- a/src/progs/ingenuity/ControlGroups.cpp
+++ /dev/null
@@ -1,428 +0,0 @@
-/* This file is part of Ingen.
- * Copyright (C) 2007 Dave Robillard <http://drobilla.net>
- *
- * Ingen is free software; you can redistribute it and/or modify it under the
- * terms of the GNU General Public License as published by the Free Software
- * Foundation; either version 2 of the License, or (at your option) any later
- * version.
- *
- * Ingen is distributed in the hope that it will be useful, but WITHOUT ANY
- * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
- * FOR A PARTICULAR PURPOSE. See the GNU General Public License for details.
- *
- * You should have received a copy of the GNU General Public License along
- * with this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
- */
-
-#include <cmath>
-#include <iostream>
-#include "interface/EngineInterface.h"
-#include "client/PluginModel.h"
-#include "client/NodeModel.h"
-#include "client/PortModel.h"
-#include "ControlGroups.h"
-#include "ControlPanel.h"
-#include "PortPropertiesWindow.h"
-#include "GladeFactory.h"
-#include "App.h"
-
-using std::cerr; using std::cout; using std::endl;
-
-using namespace Ingen::Client;
-
-namespace Ingenuity {
-
-
-// ////////////////////// ControlGroup ///////////////////////////////// //
-
-ControlGroup::ControlGroup(BaseObjectType* cobject, const Glib::RefPtr<Gnome::Glade::Xml>& glade_xml)
-: Gtk::VBox(cobject),
- _control_panel(NULL),
- _enable_signal(false)
-{
-}
-
-
-void
-ControlGroup::init(ControlPanel* panel, SharedPtr<PortModel> pm)
-{
- _control_panel = panel;
- _port_model = pm,
-
- assert(_port_model);
- assert(panel);
-
- pm->control_change_sig.connect(sigc::mem_fun(this, &ControlGroup::set_value));
-}
-
-
-// ////////////////// SliderControlGroup ////////////////////// //
-
-
-SliderControlGroup::SliderControlGroup(BaseObjectType* cobject, const Glib::RefPtr<Gnome::Glade::Xml>& xml)
-: ControlGroup(cobject, xml),
- _enabled(true)
-{
- xml->get_widget("control_strip_name_label", _name_label);
- xml->get_widget("control_strip_slider", _slider);
- xml->get_widget("control_strip_spinner", _value_spinner);
-
- Glib::RefPtr<Gnome::Glade::Xml> menu_xml = GladeFactory::new_glade_reference("port_control_menu");
- menu_xml->get_widget("port_control_menu", _menu);
- menu_xml->get_widget("port_control_menu_properties", _menu_properties);
-
- _menu_properties->signal_activate().connect(
- sigc::mem_fun(this, &SliderControlGroup::menu_properties));
-}
-
-
-void
-SliderControlGroup::init(ControlPanel* panel, SharedPtr<PortModel> pm)
-{
- _enable_signal = false;
- _enabled = true;
-
- ControlGroup::init(panel, pm);
-
- assert(_name_label);
- assert(_slider);
-
- set_name(pm->path().name());
-
- _slider->set_draw_value(false);
-
- _name_label->signal_button_press_event().connect(sigc::mem_fun(*this, &SliderControlGroup::clicked));
- _slider->signal_button_press_event().connect(sigc::mem_fun(*this, &SliderControlGroup::clicked));
-
- _slider->signal_event().connect(
- sigc::mem_fun(*this, &SliderControlGroup::slider_pressed));
-
- _slider->signal_value_changed().connect(
- sigc::mem_fun(*this, &SliderControlGroup::update_value_from_slider));
-
- _value_spinner->signal_value_changed().connect(
- sigc::mem_fun(*this, &SliderControlGroup::update_value_from_spinner));
-
- // FIXME: code duplication w/ PortPropertiesWindow.cpp
- float min = 0.0f;
- float max = 1.0f;
-
- const Atom& min_atom = pm->get_metadata("ingen:minimum");
- const Atom& max_atom = pm->get_metadata("ingen:maximum");
- if (min_atom.type() == Atom::FLOAT && max_atom.type() == Atom::FLOAT) {
- min = min_atom.get_float();
- max = max_atom.get_float();
- }
-
- const SharedPtr<NodeModel> parent = PtrCast<NodeModel>(pm->parent());
-
- if (parent && parent->plugin() && parent->plugin()->type() == PluginModel::LV2) {
- min = slv2_port_get_minimum_value(
- parent->plugin()->slv2_plugin(),
- slv2_plugin_get_port_by_symbol(parent->plugin()->slv2_plugin(),
- pm->path().name().c_str()));
- max = slv2_port_get_maximum_value(
- parent->plugin()->slv2_plugin(),
- slv2_plugin_get_port_by_symbol(parent->plugin()->slv2_plugin(),
- pm->path().name().c_str()));
- }
-
- if (max <= min)
- max = min + 1.0f;
-
- _slider->set_increments(0, 0);
- _slider->set_range(min, max);
- _value_spinner->set_range(min, max);
-
- set_value(pm->value());
-
- _enable_signal = true;
-
- show_all();
-}
-
-
-bool
-SliderControlGroup::clicked(GdkEventButton* ev)
-{
- if (ev->button == 3) {
- _menu->popup(ev->button, ev->time);
- return true;
- } else {
- return false;
- }
-}
-
-
-void
-SliderControlGroup::menu_properties()
-{
- Glib::RefPtr<Gnome::Glade::Xml> xml = GladeFactory::new_glade_reference();
-
- PortPropertiesWindow* dialog;
- xml->get_widget_derived("port_properties_win", dialog);
- dialog->init(this, _port_model);
- dialog->run();
-}
-
-
-void
-SliderControlGroup::set_value(float val)
-{
- _enable_signal = false;
- if (_enabled) {
- if (_slider->get_value() != val)
- _slider->set_value(val);
- if (_value_spinner->get_value() != val)
- _value_spinner->set_value(val);
- }
- _enable_signal = true;
-}
-
-
-void
-SliderControlGroup::set_range(float min, float max)
-{
- _slider->set_range(min, max);
- _value_spinner->set_range(min, max);
-}
-
-
-void
-SliderControlGroup::set_name(const string& name)
-{
- string name_label = "<span weight=\"bold\">";
- name_label += name + "</span>";
- _name_label->set_markup(name_label);
-}
-
-
-void
-SliderControlGroup::enable()
-{
- _slider->property_sensitive() = true;
- //_min_spinner->property_sensitive() = true;
- //_max_spinner->property_sensitive() = true;
- _value_spinner->property_sensitive() = true;
- _name_label->property_sensitive() = true;
-}
-
-
-void
-SliderControlGroup::disable()
-{
- _slider->property_sensitive() = false;
- //_min_spinner->property_sensitive() = false;
- //_max_spinner->property_sensitive() = false;
- _value_spinner->property_sensitive() = false;
- _name_label->property_sensitive() = false;
-}
-
-
-void
-SliderControlGroup::update_value_from_slider()
-{
- if (_enable_signal) {
- const float value = _slider->get_value();
- _enable_signal = false;
-
- _value_spinner->set_value(value);
- _control_panel->value_changed(_port_model, value);
-
- _enable_signal = true;
- }
-}
-
-
-void
-SliderControlGroup::update_value_from_spinner()
-{
- if (_enable_signal) {
- _enable_signal = false;
- const float value = _value_spinner->get_value();
-
- /*if (value < _min_spinner->get_value()) {
- _min_spinner->set_value(value);
- _slider->set_range(_min_spinner->get_value(), _max_spinner->get_value());
- }
- if (value > _max_spinner->get_value()) {
- _max_spinner->set_value(value);
- _slider->set_range(_min_spinner->get_value(), _max_spinner->get_value());
- }*/
-
- _slider->set_value(value);
-
- _control_panel->value_changed(_port_model, value);
-
- //m_port_model->value(value);
- _enable_signal = true;
- }
-}
-
-
-/** Callback for when slider is grabbed so we can ignore set_control
- * events for this port (and avoid nasty feedback issues).
- */
-bool
-SliderControlGroup::slider_pressed(GdkEvent* ev)
-{
- //cerr << "Pressed: " << ev->type << endl;
- if (ev->type == GDK_BUTTON_PRESS) {
- _enabled = false;
- //GtkClientInterface::instance()->set_ignore_port(_port_model->path());
- } else if (ev->type == GDK_BUTTON_RELEASE) {
- _enabled = true;
- //GtkClientInterface::instance()->clear_ignore_port();
- }
-
- return false;
-}
-
-
-// ///////////// IntegerControlGroup ////////////// //
-
-#if 0
-IntegerControlGroup::IntegerControlGroup(ControlPanel* panel, SharedPtr<PortModel> pm)
-: ControlGroup(panel, pm),
- _enable_signal(false),
- _alignment(0.5, 0.5, 0.0, 0.0),
- _name_label(pm->path().name()),
- _spinner(1.0, 0)
-{
- set_name(pm->path().name());
-
- _spinner.set_range(-99999, 99999);
- _spinner.set_value(_port_model->value());
- _spinner.signal_value_changed().connect(
- sigc::mem_fun(*this, &IntegerControlGroup::update_value));
- _spinner.set_increments(1, 10);
-
- _alignment.add(_spinner);
- pack_start(_name_label);
- pack_start(_alignment);
-
- _enable_signal = true;
-
- show_all();
-}
-
-
-void
-IntegerControlGroup::set_name(const string& name)
-{
- string name_label = "<span weight=\"bold\">";
- name_label += name + "</span>";
- _name_label->set_markup(name_label);
-}
-
-
-void
-IntegerControlGroup::set_value(float val)
-{
- //cerr << "[IntegerControlGroup] Setting value to " << val << endl;
- _enable_signal = false;
- _spinner.set_value(val);
- _enable_signal = true;
-}
-
-
-void
-IntegerControlGroup::enable()
-{
- _spinner.property_sensitive() = true;
- _name_label->property_sensitive() = true;
-}
-
-
-void
-IntegerControlGroup::disable()
-{
- _spinner.property_sensitive() = false;
- _name_label->property_sensitive() = false;
-}
-
-
-void
-IntegerControlGroup::update_value()
-{
- if (_enable_signal) {
- float value = _spinner.get_value();
- _control_panel->value_changed(_port_model, value);
- //m_port_model->value(value);
- }
-}
-
-
-// ///////////// ToggleControlGroup ////////////// //
-
-
-ToggleControlGroup::ToggleControlGroup(ControlPanel* panel, SharedPtr<PortModel> pm)
-: ControlGroup(panel, pm),
- _enable_signal(false),
- _alignment(0.5, 0.5, 0.0, 0.0),
- _name_label(pm->path().name())
-{
- set_name(pm->path().name());
-
- set_value(_port_model->value());
- _checkbutton.signal_toggled().connect(
- sigc::mem_fun(*this, &ToggleControlGroup::update_value));
-
- _alignment.add(_checkbutton);
- pack_start(_name_label);
- pack_start(_alignment);
-
- _enable_signal = true;
-
- show_all();
-}
-
-
-void
-ToggleControlGroup::set_name(const string& name)
-{
- string name_label = "<span weight=\"bold\">";
- name_label += name + "</span>";
- _name_label->set_markup(name_label);
-}
-
-
-void
-ToggleControlGroup::set_value(float val)
-{
- //cerr << "[ToggleControlGroup] Setting value to " << val << endl;
- _enable_signal = false;
- _checkbutton.set_active( (val > 0.0f) );
- _enable_signal = true;
-}
-
-
-void
-ToggleControlGroup::enable()
-{
- _checkbutton.property_sensitive() = true;
- _name_label->property_sensitive() = true;
-}
-
-
-void
-ToggleControlGroup::disable()
-{
- _checkbutton.property_sensitive() = false;
- _name_label->property_sensitive() = false;
-}
-
-
-void
-ToggleControlGroup::update_value()
-{
- if (_enable_signal) {
- float value = _checkbutton.get_active() ? 1.0f : 0.0f;
- _control_panel->value_changed(_port_model, value);
- //m_port_model->value(value);
- }
-}
-#endif
-
-} // namespace Ingenuity