Fix ATAV identification by Parameter (2/2) #8201, 8203

Allow to uniquely identify Processor ATAV using the control ID.
This commit is contained in:
Robin Gareus 2020-06-04 21:11:06 +02:00
parent 0ab13e7b29
commit 54ffd92fde
Signed by: rgareus
GPG Key ID: A090BCE02CF57F04
5 changed files with 28 additions and 11 deletions

View File

@ -2749,6 +2749,23 @@ RouteTimeAxisView::remove_child (boost::shared_ptr<TimeAxisView> c)
}
}
boost::shared_ptr<AutomationTimeAxisView>
RouteTimeAxisView::automation_child(Evoral::Parameter param, PBD::ID ctrl_id)
{
if (param.type() != PluginAutomation) {
return StripableTimeAxisView::automation_child (param, ctrl_id);
}
for (list<ProcessorAutomationInfo*>::iterator i = processor_automation.begin(); i != processor_automation.end(); ++i) {
for (vector<ProcessorAutomationNode*>::iterator ii = (*i)->lines.begin(); ii != (*i)->lines.end(); ++ii) {
boost::shared_ptr<AutomationTimeAxisView> atv ((*ii)->view);
if (atv->control()->id() == ctrl_id) {
return atv;
}
}
}
return boost::shared_ptr<AutomationTimeAxisView>();
}
boost::shared_ptr<AutomationLine>
RouteTimeAxisView::automation_child_by_alist_id (PBD::ID alist_id)
{

View File

@ -134,6 +134,7 @@ public:
int set_state (const XMLNode&, int version);
virtual Gtk::CheckMenuItem* automation_child_menu_item (Evoral::Parameter);
virtual boost::shared_ptr<AutomationTimeAxisView> automation_child(Evoral::Parameter param, PBD::ID ctrl_id = PBD::ID(0));
StreamView* view() const { return _view; }
ARDOUR::RouteGroup* route_group() const;

View File

@ -1073,6 +1073,7 @@ Selection::get_state () const
XMLNode* t = node->add_child (X_("AutomationView"));
t->set_property (X_("id"), atv->parent_stripable()->id ());
t->set_property (X_("parameter"), EventTypeMap::instance().to_symbol (atv->parameter ()));
t->set_property (X_("ctrl_id"), atv->control()->id())
}
}
@ -1302,30 +1303,28 @@ Selection::set_state (XMLNode const & node, int)
} else if ((*i)->name() == X_("AutomationView")) {
#if 0
// XXX is this even used? -> StripableAutomationControl
std::string param;
PBD::ID ctrl_id (0);
if (!(*i)->get_property (X_("id"), id) || !(*i)->get_property (X_("parameter"), param)) {
assert (false);
}
// TODO we need additional information Evoral::Parmeter does not uniquely identify an Automation Lane
StripableTimeAxisView* stv = editor->get_stripable_time_axis_by_id (id);
if (stv) {
boost::shared_ptr<AutomationTimeAxisView> atv = stv->automation_child (EventTypeMap::instance().from_symbol (param));
if (stv && (*i)->get_property (X_("control_id"), ctrl_id)) {
boost::shared_ptr<AutomationTimeAxisView> atv = stv->automation_child (EventTypeMap::instance().from_symbol (param), ctrl_id);
/* the automation could be for an entity that was never saved
in the session file. Don't freak out if we can't find
it.
*/
* in the session file. Don't freak out if we can't find
* it.
*/
if (atv) {
add (atv.get());
}
}
#endif
} else if ((*i)->name() == X_("Marker")) {

View File

@ -191,7 +191,7 @@ StripableTimeAxisView::automation_track_hidden (Evoral::Parameter param)
}
boost::shared_ptr<AutomationTimeAxisView>
StripableTimeAxisView::automation_child(Evoral::Parameter param)
StripableTimeAxisView::automation_child(Evoral::Parameter param, PBD::ID)
{
assert (param.type() != PluginAutomation);
AutomationTracks::iterator i = _automation_tracks.find(param);

View File

@ -36,7 +36,7 @@ public:
virtual Gtk::CheckMenuItem* automation_child_menu_item (Evoral::Parameter);
virtual void create_automation_child (const Evoral::Parameter& param, bool show) = 0;
boost::shared_ptr<AutomationTimeAxisView> automation_child(Evoral::Parameter param);
virtual boost::shared_ptr<AutomationTimeAxisView> automation_child (Evoral::Parameter param, PBD::ID ctrl_id = PBD::ID(0));
virtual boost::shared_ptr<AutomationLine> automation_child_by_alist_id (PBD::ID);