summaryrefslogtreecommitdiff
path: root/gtk2_ardour/edit_note_dialog.cc
diff options
context:
space:
mode:
authorCarl Hetherington <carl@carlh.net>2012-06-09 01:51:34 +0000
committerCarl Hetherington <carl@carlh.net>2012-06-09 01:51:34 +0000
commita766fe1fd9852ea6b041ba257e588fca7a032cb9 (patch)
treeaecac737ab5cf23d02d0bec378af24466cc87ff1 /gtk2_ardour/edit_note_dialog.cc
parent0ac73d8513dff0566b290b49127776b28859e69a (diff)
Somewhat primitive implementation of allowing the edit note dialog to handle multiple notes (#4096).
git-svn-id: svn://localhost/ardour2/branches/3.0@12623 d708f5d6-7413-0410-9779-e7cbd77b26cf
Diffstat (limited to 'gtk2_ardour/edit_note_dialog.cc')
-rw-r--r--gtk2_ardour/edit_note_dialog.cc119
1 files changed, 94 insertions, 25 deletions
diff --git a/gtk2_ardour/edit_note_dialog.cc b/gtk2_ardour/edit_note_dialog.cc
index 3c866cfe6f..17827693e7 100644
--- a/gtk2_ardour/edit_note_dialog.cc
+++ b/gtk2_ardour/edit_note_dialog.cc
@@ -28,21 +28,27 @@
#include "i18n.h"
+using namespace std;
using namespace Gtk;
using namespace Gtkmm2ext;
/**
* EditNoteDialog constructor.
*
- * @param n Note to edit.
+ * @param n Notes to edit.
*/
-EditNoteDialog::EditNoteDialog (MidiRegionView* rv, Gnome::Canvas::CanvasNoteEvent* ev)
+EditNoteDialog::EditNoteDialog (MidiRegionView* rv, set<ArdourCanvas::CanvasNoteEvent*> n)
: ArdourDialog (_("Note"))
, _region_view (rv)
- , _event (ev)
+ , _events (n)
+ , _channel_all (_("Set selected notes to this channel"))
+ , _pitch_all (_("Set selected notes to this pitch"))
+ , _velocity_all (_("Set selected notes to this velocity"))
, _time_clock (X_("notetime"), true, "", true, false)
+ , _time_all (_("Set selected notes to this time"))
, _length_clock (X_("notelength"), true, "", true, false, true)
+ , _length_all (_("Set selected notes to this length"))
{
Table* table = manage (new Table (4, 2));
table->set_spacings (6);
@@ -52,48 +58,89 @@ EditNoteDialog::EditNoteDialog (MidiRegionView* rv, Gnome::Canvas::CanvasNoteEve
Label* l = manage (left_aligned_label (_("Channel")));
table->attach (*l, 0, 1, r, r + 1);
table->attach (_channel, 1, 2, r, r + 1);
+ table->attach (_channel_all, 2, 3, r, r + 1);
++r;
_channel.set_range (1, 16);
_channel.set_increments (1, 2);
- _channel.set_value (ev->note()->channel () + 1);
+ _channel.set_value ((*_events.begin())->note()->channel () + 1);
l = manage (left_aligned_label (_("Pitch")));
table->attach (*l, 0, 1, r, r + 1);
table->attach (_pitch, 1, 2, r, r + 1);
+ table->attach (_pitch_all, 2, 3, r, r + 1);
++r;
_pitch.set_range (0, 127);
_pitch.set_increments (1, 10);
- _pitch.set_value (ev->note()->note ());
+ _pitch.set_value ((*_events.begin())->note()->note());
l = manage (left_aligned_label (_("Velocity")));
table->attach (*l, 0, 1, r, r + 1);
table->attach (_velocity, 1, 2, r, r + 1);
+ table->attach (_velocity_all, 2, 3, r, r + 1);
++r;
_velocity.set_range (0, 127);
_velocity.set_increments (1, 10);
- _velocity.set_value (ev->note()->velocity ());
+ _velocity.set_value ((*_events.begin())->note()->velocity ());
l = manage (left_aligned_label (_("Time")));
table->attach (*l, 0, 1, r, r + 1);
table->attach (_time_clock, 1, 2, r, r + 1);
+ table->attach (_time_all, 2, 3, r, r + 1);
++r;
_time_clock.set_session (_region_view->get_time_axis_view().session ());
_time_clock.set_mode (AudioClock::BBT);
- _time_clock.set (_region_view->source_relative_time_converter().to (ev->note()->time ()), true);
+ _time_clock.set (_region_view->source_relative_time_converter().to ((*_events.begin())->note()->time ()), true);
l = manage (left_aligned_label (_("Length")));
table->attach (*l, 0, 1, r, r + 1);
table->attach (_length_clock, 1, 2, r, r + 1);
+ table->attach (_length_all, 2, 3, r, r + 1);
++r;
_length_clock.set_session (_region_view->get_time_axis_view().session ());
_length_clock.set_mode (AudioClock::BBT);
- _length_clock.set (_region_view->region_relative_time_converter().to (ev->note()->length ()), true);
-
+ _length_clock.set (_region_view->region_relative_time_converter().to ((*_events.begin())->note()->length ()), true);
+
+ /* Set up `set all notes...' buttons' sensitivity */
+
+ _channel_all.set_sensitive (false);
+ _pitch_all.set_sensitive (false);
+ _velocity_all.set_sensitive (false);
+ _time_all.set_sensitive (false);
+ _length_all.set_sensitive (false);
+
+ int test_channel = (*_events.begin())->note()->channel ();
+ int test_pitch = (*_events.begin())->note()->note ();
+ int test_velocity = (*_events.begin())->note()->velocity ();
+ double test_time = (*_events.begin())->note()->time ();
+ double test_length = (*_events.begin())->note()->length ();
+
+ for (set<ArdourCanvas::CanvasNoteEvent*>::iterator i = _events.begin(); i != _events.end(); ++i) {
+ if ((*i)->note()->channel() != test_channel) {
+ _channel_all.set_sensitive (true);
+ }
+
+ if ((*i)->note()->note() != test_pitch) {
+ _pitch_all.set_sensitive (true);
+ }
+
+ if ((*i)->note()->velocity() != test_velocity) {
+ _velocity_all.set_sensitive (true);
+ }
+
+ if ((*i)->note()->time () != test_time) {
+ _time_all.set_sensitive (true);
+ }
+
+ if ((*i)->note()->length () != test_length) {
+ _length_all.set_sensitive (true);
+ }
+ }
+
get_vbox()->pack_start (*table);
add_button (Gtk::Stock::CANCEL, Gtk::RESPONSE_CANCEL);
@@ -122,33 +169,53 @@ EditNoteDialog::run ()
bool had_change = false;
- if (_channel.get_value_as_int() - 1 != _event->note()->channel()) {
- _region_view->change_note_channel (_event, _channel.get_value_as_int () - 1);
- had_change = true;
+ if (!_channel_all.get_sensitive() || _channel_all.get_active ()) {
+ for (set<ArdourCanvas::CanvasNoteEvent*>::iterator i = _events.begin(); i != _events.end(); ++i) {
+ if (_channel.get_value_as_int() - 1 != (*i)->note()->channel()) {
+ _region_view->change_note_channel (*i, _channel.get_value_as_int () - 1);
+ had_change = true;
+ }
+ }
}
- if (_pitch.get_value_as_int() != _event->note()->note()) {
- _region_view->change_note_note (_event, _pitch.get_value_as_int (), false);
- had_change = true;
+ if (!_pitch_all.get_sensitive() || _pitch_all.get_active ()) {
+ for (set<ArdourCanvas::CanvasNoteEvent*>::iterator i = _events.begin(); i != _events.end(); ++i) {
+ if (_pitch.get_value_as_int() != (*i)->note()->note()) {
+ _region_view->change_note_note (*i, _pitch.get_value_as_int ());
+ had_change = true;
+ }
+ }
}
- if (_velocity.get_value_as_int() != _event->note()->velocity()) {
- _region_view->change_note_velocity (_event, _velocity.get_value_as_int (), false);
- had_change = true;
+ if (!_velocity_all.get_sensitive() || _velocity_all.get_active ()) {
+ for (set<ArdourCanvas::CanvasNoteEvent*>::iterator i = _events.begin(); i != _events.end(); ++i) {
+ if (_velocity.get_value_as_int() != (*i)->note()->velocity()) {
+ _region_view->change_note_velocity (*i, _velocity.get_value_as_int ());
+ had_change = true;
+ }
+ }
}
double const t = _region_view->source_relative_time_converter().from (_time_clock.current_time ());
- if (t != _event->note()->time()) {
- _region_view->change_note_time (_event, t);
- had_change = true;
+ if (!_time_all.get_sensitive() || _time_all.get_active ()) {
+ for (set<ArdourCanvas::CanvasNoteEvent*>::iterator i = _events.begin(); i != _events.end(); ++i) {
+ if (t != (*i)->note()->time()) {
+ _region_view->change_note_time (*i, t);
+ had_change = true;
+ }
+ }
}
double const d = _region_view->region_relative_time_converter().from (_length_clock.current_duration ());
- if (d != _event->note()->length()) {
- _region_view->change_note_length (_event, d);
- had_change = true;
+ if (!_length_all.get_sensitive() || _length_all.get_active ()) {
+ for (set<ArdourCanvas::CanvasNoteEvent*>::iterator i = _events.begin(); i != _events.end(); ++i) {
+ if (d != (*i)->note()->length()) {
+ _region_view->change_note_length (*i, d);
+ had_change = true;
+ }
+ }
}
if (!had_change) {
@@ -157,7 +224,9 @@ EditNoteDialog::run ()
_region_view->apply_diff ();
- _event->set_selected (_event->selected()); // change color
+ for (set<ArdourCanvas::CanvasNoteEvent*>::iterator i = _events.begin(); i != _events.end(); ++i) {
+ (*i)->set_selected ((*i)->selected()); // change color
+ }
return r;
}