remove visible "sound notes" button,add Config parameter to control this (which then...
authorPaul Davis <paul@linuxaudiosystems.com>
Wed, 7 Dec 2011 14:23:32 +0000 (14:23 +0000)
committerPaul Davis <paul@linuxaudiosystems.com>
Wed, 7 Dec 2011 14:23:32 +0000 (14:23 +0000)
git-svn-id: svn://localhost/ardour2/branches/3.0@10934 d708f5d6-7413-0410-9779-e7cbd77b26cf

gtk2_ardour/editor.cc
gtk2_ardour/editor.h
gtk2_ardour/midi_region_view.cc
gtk2_ardour/public_editor.h
gtk2_ardour/rc_option_editor.cc
libs/ardour/ardour/rc_configuration_vars.h
libs/ardour/send.cc

index a6d16fa9e967df5e61364a97be444333433abd95..31d5b495fecf6ea1053a127cfa061de0a085d29d 100644 (file)
@@ -642,7 +642,6 @@ Editor::Editor ()
        // load_bindings ();
 
        setup_toolbar ();
-       setup_midi_toolbar ();
 
        _snap_type = SnapToBeat;
        set_snap_to (_snap_type);
@@ -2982,27 +2981,9 @@ Editor::setup_tooltips ()
        ARDOUR_UI::instance()->set_tip (snap_type_selector, _("Snap/Grid Units"));
        ARDOUR_UI::instance()->set_tip (snap_mode_selector, _("Snap/Grid Mode"));
        ARDOUR_UI::instance()->set_tip (edit_point_selector, _("Edit point"));
-       ARDOUR_UI::instance()->set_tip (midi_sound_notes, _("Sound Notes"));
        ARDOUR_UI::instance()->set_tip (edit_mode_selector, _("Edit Mode"));
 }
 
-
-void
-Editor::setup_midi_toolbar ()
-{
-       RefPtr<Action> act;
-
-       /* Midi sound notes */
-       midi_sound_notes.add (*(manage (new Image (::get_icon("midi_sound_notes")))));
-       midi_sound_notes.unset_flags (CAN_FOCUS);
-       midi_sound_notes.set_name (X_("MidiSoundNotesButton"));
-
-       /* Panic */
-
-       panic_box.pack_start (midi_sound_notes , true, true);
-       // panic_box.pack_start (midi_panic_button, true, true);
-}
-
 int
 Editor::convert_drop_to_paths (
                vector<string>&                paths,
index a87e1d1ce4e1f85e5318e59377b138952e3ade77..c8d4efd4e8774d9a6b67bb58263c295bc791b3c2 100644 (file)
@@ -1607,8 +1607,6 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        /* midi toolbar */
 
        Gtk::HBox                panic_box;
-       Gtkmm2ext::StatefulToggleButton midi_sound_notes;
-       bool                     sound_notes () const { return midi_sound_notes.get_active(); }
 
        void setup_midi_toolbar ();
 
index 51e96e34b2f893ff17d8024bea401137be7bcff1..b295e55733c01ea7915daafb0c09251919b53c33 100644 (file)
@@ -1541,7 +1541,7 @@ MidiRegionView::extend_active_notes()
 void
 MidiRegionView::play_midi_note(boost::shared_ptr<NoteType> note)
 {
-       if (_no_sound_notes || !trackview.editor().sound_notes()) {
+       if (_no_sound_notes || !Config->get_sound_midi_notes()) {
                return;
        }
 
@@ -1559,7 +1559,7 @@ MidiRegionView::play_midi_note(boost::shared_ptr<NoteType> note)
 void
 MidiRegionView::play_midi_chord (vector<boost::shared_ptr<NoteType> > notes)
 {
-       if (_no_sound_notes || !trackview.editor().sound_notes()) {
+       if (_no_sound_notes || !Config->get_sound_midi_notes()) {
                return;
        }
 
@@ -2341,7 +2341,7 @@ MidiRegionView::move_selection(double dx, double dy, double cumulative_dy)
                (*i)->move_event(dx, dy);
        }
 
-       if (dy && !_selection.empty() && !_no_sound_notes && trackview.editor().sound_notes()) {
+       if (dy && !_selection.empty() && !_no_sound_notes && Config->get_sound_midi_notes()) {
 
                if (to_play.size() > 1) {
 
index 4107097236c6bcaf6b89e814efe0ca865eaeddae..0d8bbbacef78df905de4265362bc26c650da8d9f 100644 (file)
@@ -181,10 +181,6 @@ class PublicEditor : public Gtk::Window, public PBD::StatefulDestructible {
 
        virtual bool internal_editing() const = 0;
 
-       /** @return Sound edited notes in MIDI regions while editing
-        */
-       virtual bool sound_notes () const = 0;
-
        /** Possibly start the audition of a region.  If @param r is 0, or not an AudioRegion
         * any current audition is cancelled.  If we are currently auditioning @param r,
         * the audition will be cancelled.  Otherwise an audition of @param r will start.
index 83051fc5a77aa07fdb29a5b8bc58936ebd953050..ec3dd466f431bb9f65b20c7f0669cffb08fba75d 100644 (file)
@@ -1486,6 +1486,14 @@ RCOptionEditor::RCOptionEditor ()
                     sigc::mem_fun (*_rc_config, &RCConfiguration::set_never_display_periodic_midi)
                     ));
 
+       add_option (_("MIDI"),
+            new BoolOption (
+                    "sound-midi-notes",
+                    _("Sound MIDI notes as they are selected"),
+                    sigc::mem_fun (*_rc_config, &RCConfiguration::get_sound_midi_notes),
+                    sigc::mem_fun (*_rc_config, &RCConfiguration::set_sound_midi_notes)
+                    ));
+
        /* USER INTERACTION */
 
        add_option (_("User interaction"), new OptionEditorHeading (_("Keyboard")));
index d84f31d85691cdc1f466ac3ca670e51a83ba3fcc..e621225171a5e9b99a92d9655f46dfa8c668483b 100644 (file)
@@ -170,6 +170,7 @@ CONFIG_VARIABLE (bool, color_regions_using_track_color, "color-regions-using-tra
 CONFIG_VARIABLE (gain_t, max_gain, "max-gain", 2.0) /* +6.0dB */
 CONFIG_VARIABLE (bool, update_editor_during_summary_drag, "update-editor-during-summary-drag", true)
 CONFIG_VARIABLE (bool, never_display_periodic_midi, "never-display-periodic-midi", true)
+CONFIG_VARIABLE (bool, sound_midi_notes, "sound-midi-notes", false)
 
 /* denormal management */
 
index f537c9dfdfc7b21fb45d93103800c039f6950b2b..f299995ffaef2af29f0d40ad966e7c5dbfc5a0a8 100644 (file)
@@ -21,6 +21,7 @@
 #include <algorithm>
 
 #include "pbd/xml++.h"
+#include "pbd/boost_debug.h"
 
 #include "ardour/amp.h"
 #include "ardour/send.h"
@@ -42,6 +43,8 @@ Send::Send (Session& s, boost::shared_ptr<Pannable> p, boost::shared_ptr<MuteMas
        : Delivery (s, p, mm, string_compose (_("send %1"), (_bitslot = s.next_send_id()) + 1), r)
        , _metering (false)
 {
+       boost_debug_shared_ptr_mark_interesting (this, "send");
+
        _amp.reset (new Amp (_session));
        _meter.reset (new PeakMeter (_session));
 }