_uses_gain_mapping = false;
no_draw = false;
_visible = true;
+ _is_boolean = false;
terminal_points_can_slide = true;
_height = 0;
void
AutomationLine::show_all_control_points ()
{
+ if (_is_boolean) {
+ // show the line but don't allow any control points
+ return;
+ }
+
points_visible = true;
for (vector<ControlPoint*>::iterator i = control_points.begin(); i != control_points.end(); ++i) {
bool terminal_points_can_slide : 1;
bool update_pending : 1;
bool no_draw : 1;
+ bool _is_boolean : 1;
bool points_visible : 1;
bool did_push;
control_ui->pack_start (control_ui->label, true, true);
control_ui->pack_start (*control_ui->button, false, true);
- // control_ui->pack_start (control_ui->automate_button, false, false);
+ control_ui->pack_start (control_ui->automate_button, false, false);
control_ui->button->signal_clicked().connect (sigc::bind (sigc::mem_fun(*this, &GenericPluginUI::control_port_toggled), control_ui));
- mcontrol->Changed.connect (control_connections, invalidator (*this), boost::bind (&GenericPluginUI::toggle_parameter_changed, this, control_ui), gui_context());
+ control_ui->automate_button.signal_clicked().connect (bind (mem_fun(*this, &GenericPluginUI::astate_clicked), control_ui, (uint32_t) port_index));
+ mcontrol->Changed.connect (control_connections, invalidator (*this), boost::bind (&GenericPluginUI::toggle_parameter_changed, this, control_ui), gui_context());
+ mcontrol->alist()->automation_state_changed.connect (control_connections, invalidator (*this), boost::bind (&GenericPluginUI::automation_state_changed, this, control_ui), gui_context());
+
if (plugin->get_parameter (port_index) > 0.5){
control_ui->button->set_active(true);
}
+ automation_state_changed (control_ui);
+
return control_ui;
}
/* create the controller */
control_ui->controller = AutomationController::create(insert, mcontrol->parameter(), mcontrol);
+
/* XXX this code is not right yet, because it doesn't handle
the absence of bounds in any sensible fashion.
*/
-//#if 0
- control_ui->controller->adjustment()->set_lower (desc.lower);
- control_ui->controller->adjustment()->set_upper (desc.upper);
+ Adjustment* adj = control_ui->controller->adjustment();
+
+ adj->set_lower (desc.lower);
+ adj->set_upper (desc.upper);
- control_ui->logarithmic = false; // just disable it for now
- /*
control_ui->logarithmic = desc.logarithmic;
+
if (control_ui->logarithmic) {
- if (control_ui->controller->adjustment()->get_lower() == 0.0) {
- control_ui->controller->adjustment()->set_lower (control_ui->controller->adjustment()->get_upper()/10000);
+ if (adj->get_lower() == 0.0) {
+ adj->set_lower (adj->get_upper()/10000);
}
- control_ui->controller->adjustment()->set_upper (log(control_ui->controller->adjustment()->get_upper()));
- control_ui->controller->adjustment()->set_lower (log(control_ui->controller->adjustment()->get_lower()));
- }*/
-
+ adj->set_upper (log(adj->get_upper()));
+ adj->set_lower (log(adj->get_lower()));
+ }
- control_ui->controller->adjustment()->set_step_increment (desc.step);
- control_ui->controller->adjustment()->set_page_increment (desc.largestep);
-//#endif
+ adj->set_step_increment (desc.step);
+ adj->set_page_increment (desc.largestep);
if (desc.integer_step) {
- control_ui->clickbox = new ClickBox (control_ui->controller->adjustment(), "PluginUIClickBox");
+ control_ui->clickbox = new ClickBox (adj, "PluginUIClickBox");
Gtkmm2ext::set_size_request_to_display_given_text (*control_ui->clickbox, "g9999999", 2, 2);
control_ui->clickbox->set_print_func (integer_printer, 0);
} else {
}
if (control_ui->logarithmic) {
- control_ui->controller->adjustment()->set_value(log(plugin->get_parameter(port_index)));
+ adj->set_value(log(plugin->get_parameter(port_index)));
} else{
- control_ui->controller->adjustment()->set_value(plugin->get_parameter(port_index));
+ adj->set_value(plugin->get_parameter(port_index));
}
/* XXX memory leak: SliderController not destroyed by ControlUI
{
bool to_list = _list && _session.transport_stopped()
&& ((AutomationList*)_list.get())->automation_write();
+
+ if (to_list && parameter().toggled()) {
- Control::set_double(value, to_list, _session.transport_frame());
+ //store the previous value just before this so any
+ // interpolation works right
+
+ _list->add (get_double(), _session.transport_frame()-1);
+ }
+
+ Control::set_double (value, to_list, _session.transport_frame());
Changed(); /* EMIT SIGNAL */
}
return p;
}
- p.set_range(type, min, max, normal);
+ p.set_range(type, min, max, normal, false);
return p;
}
but we want the Controllable related to this Parameter to have those limits.
*/
- param.set_range (desc.lower, desc.upper, _plugins.front()->default_value(i->id()));
+ param.set_range (desc.lower, desc.upper, _plugins.front()->default_value(i->id()), desc.toggled);
can_automate (param);
boost::shared_ptr<AutomationList> list(new AutomationList(param));
add_control (boost::shared_ptr<AutomationControl>(new PluginControl(this, param, list)));
void
PluginInsert::set_parameter (Evoral::Parameter param, float val)
{
- if (param.type() != PluginAutomation)
+ if (param.type() != PluginAutomation) {
return;
+ }
/* the others will be set from the event triggered by this */
/** Not used in indentity/comparison */
struct Metadata {
- Metadata(double low=0.0, double high=1.0, double mid=0.0)
- : min(low), max(high), normal(mid)
+ Metadata(double low=0.0, double high=1.0, double mid=0.0, bool tog=false)
+ : min(low), max(high), normal(mid), toggled(tog)
{}
double min;
double max;
double normal;
+ bool toggled;
};
- inline static void set_range(uint32_t type, double min, double max, double normal) {
- _type_metadata[type] = Metadata(min, max, normal);
+ inline static void set_range(uint32_t type, double min, double max, double normal, bool toggled) {
+ _type_metadata[type] = Metadata(min, max, normal, toggled);
}
- inline void set_range(double min, double max, double normal) {
- _metadata = boost::shared_ptr<Metadata>(new Metadata(min, max, normal));
+ inline void set_range(double min, double max, double normal, bool toggled) {
+ _metadata = boost::shared_ptr<Metadata>(new Metadata(min, max, normal, toggled));
}
-
+
inline Metadata& metadata() const {
if (_metadata)
return *_metadata.get();
return _type_metadata[_type];
}
- inline double min() const { return metadata().min; }
- inline double max() const { return metadata().max; }
- inline double normal() const { return metadata().normal; }
+ inline double min() const { return metadata().min; }
+ inline double max() const { return metadata().max; }
+ inline double normal() const { return metadata().normal; }
+ inline double toggled() const { return metadata().toggled; }
protected:
// Default copy constructor is ok