diff options
author | nick_m <mainsbridge@gmail.com> | 2015-10-04 01:19:38 +1000 |
---|---|---|
committer | nick_m <mainsbridge@gmail.com> | 2015-10-20 00:53:28 +1100 |
commit | 202a23d513235120b03ffdc2d0ceba1cb7d0c93d (patch) | |
tree | 0237d513f779446397bd22c32e9c835df2842a84 /gtk2_ardour/selection.cc | |
parent | cc7de475f2e9ea819de56fcb695ef098e29a7ead (diff) |
Add region gain point selection undo.
Diffstat (limited to 'gtk2_ardour/selection.cc')
-rw-r--r-- | gtk2_ardour/selection.cc | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/gtk2_ardour/selection.cc b/gtk2_ardour/selection.cc index 822aca0384..ac62201db3 100644 --- a/gtk2_ardour/selection.cc +++ b/gtk2_ardour/selection.cc @@ -26,8 +26,10 @@ #include "ardour/playlist.h" #include "ardour/rc_configuration.h" +#include "audio_region_view.h" #include "gui_thread.h" #include "midi_cut_buffer.h" +#include "region_gain_line.h" #include "region_view.h" #include "selection.h" #include "selection_templates.h" @@ -1278,8 +1280,18 @@ Selection::get_state () const snprintf(buf, sizeof(buf), "%d", (*i)->view_index()); r->add_property (X_("view-index"), string(buf)); + continue; + } + AudioRegionGainLine* argl = dynamic_cast<AudioRegionGainLine*> (&(*i)->line()); + if (argl) { + XMLNode* r = node->add_child (X_("ControlPoint")); + r->add_property (X_("type"), "region"); + r->add_property (X_("region-id"), atoi (argl->region_view ().region ()->id ().to_s ().c_str())); + snprintf(buf, sizeof(buf), "%d", (*i)->view_index()); + r->add_property (X_("view-index"), string(buf)); } + } for (TimeSelection::const_iterator i = time.begin(); i != time.end(); ++i) { @@ -1440,6 +1452,31 @@ Selection::set_state (XMLNode const & node, int) if (!cps.empty()) { add (cps); } + } else if (prop_type->value () == "region") { + XMLProperty* prop_region_id = (*i)->property (X_("region-id")); + XMLProperty* prop_view_index = (*i)->property (X_("view-index")); + + PBD::ID region_id (prop_region_id->value ()); + RegionSelection rs; + editor->get_regionviews_by_id (region_id, rs); + + if (!rs.empty ()) { + vector <ControlPoint *> cps; + for (RegionSelection::iterator rsi = rs.begin(); rsi != rs.end(); ++rsi) { + AudioRegionView* arv = dynamic_cast<AudioRegionView*> (*rsi); + if (arv) { + boost::shared_ptr<AudioRegionGainLine> gl = arv->get_gain_line (); + ControlPoint* cp = gl->nth(atol(prop_view_index->value().c_str())); + if (cp) { + cps.push_back (cp); + cp->show(); + } + } + } + if (!cps.empty()) { + add (cps); + } + } } } else if ((*i)->name() == X_("AudioRange")) { |