experiment with making MIDI region boxes vanish when in note/internal edit mode ...
[ardour.git] / gtk2_ardour / midi_streamview.h
index 925843075b4f44e3c2d1d3084d78fe49dacce7d6..8acb62b51ec1e1fa4e7289755a365a51d33de32d 100644 (file)
@@ -1,5 +1,5 @@
 /*
-    Copyright (C) 2001, 2006 Paul Davis 
+    Copyright (C) 2001, 2006 Paul Davis
 
     This program is free software; you can redistribute it and/or modify
     it under the terms of the GNU General Public License as published by
@@ -35,7 +35,6 @@ namespace Gdk {
 
 namespace ARDOUR {
        class Route;
-       class Diskstream;
        class Crossfade;
        class PeakData;
        class MidiRegion;
@@ -54,11 +53,13 @@ class Selection;
 class MidiStreamView : public StreamView
 {
   public:
-       MidiStreamView (MidiTimeAxisViewPtr);
+       MidiStreamView (MidiTimeAxisView&);
        ~MidiStreamView ();
 
+        void enter_internal_edit_mode ();
+        void leave_internal_edit_mode ();
+
        void set_selected_regionviews (RegionSelection&);
-       void get_selectables (jack_nframes_t start, jack_nframes_t end, std::list<Selectable* >&);
        void get_inverted_selectables (Selection&, std::list<Selectable* >& results);
 
        enum VisibleNoteRange {
@@ -73,57 +74,50 @@ class MidiStreamView : public StreamView
 
        inline uint8_t lowest_note()  const { return _lowest_note; }
        inline uint8_t highest_note() const { return _highest_note; }
-       
+
        void update_note_range(uint8_t note_num);
-       
-       void redisplay_diskstream ();
-       
+
+       void redisplay_track ();
+
        inline double contents_height() const
-       { return (_trackview->current_height() - TimeAxisViewItem::NAME_HIGHLIGHT_SIZE - 2); }
-       
+       { return (child_height() - TimeAxisViewItem::NAME_HIGHLIGHT_SIZE - 2); }
+
        inline double note_to_y(uint8_t note) const
                { return contents_height()
                        - (note + 1 - lowest_note()) * note_height() + 1; }
-       
+
        inline uint8_t y_to_note(double y) const
                { return (uint8_t)((contents_height() - y - 1)
                                / contents_height() * (double)contents_note_range())
                                + lowest_note(); }
-       
+
        inline double note_height() const
                { return contents_height() / (double)contents_note_range(); }
-       
+
        inline uint8_t contents_note_range() const
                { return highest_note() - lowest_note() + 1; }
-       
+
        sigc::signal<void> NoteRangeChanged;
 
        RegionView* create_region_view (boost::shared_ptr<ARDOUR::Region>, bool, bool);
 
+       void apply_note_range(uint8_t lowest, uint8_t highest, bool to_region_views);
+
   private:
        void setup_rec_box ();
+       void update_rec_box ();
 
-       void rec_data_range_ready (
-                       jack_nframes_t start,
-                       jack_nframes_t dur,
-                       boost::weak_ptr<ARDOUR::Source> src); 
-
-       void update_rec_regions (
-                       boost::shared_ptr<ARDOUR::MidiModel> data,
-                       jack_nframes_t start,
-                       jack_nframes_t dur);
-       
        RegionView* add_region_view_internal (
-                       boost::shared_ptr<ARDOUR::Region>,
-                       bool wait_for_waves,
-                       bool recording = false);
+               boost::shared_ptr<ARDOUR::Region>,
+               bool wait_for_waves,
+               bool recording = false);
 
        void display_region(MidiRegionView* region_view, bool load_model);
-       void display_diskstream (boost::shared_ptr<ARDOUR::Diskstream> ds);
-       
+       void display_track (boost::shared_ptr<ARDOUR::Track> tr);
+
        void update_contents_height ();
+
        void draw_note_lines();
-       void apply_note_range(uint8_t lowest, uint8_t highest, bool to_region_views);
        bool update_data_note_range(uint8_t min, uint8_t max);
        void update_contents_metrics(boost::shared_ptr<ARDOUR::Region> r);