change note colors on the fly, to permit user-definition of colors more easily; remov...
[ardour.git] / gtk2_ardour / midi_streamview.h
index 33eb9e5b7d952a64f40d8aae146731e35454717e..b9ce5a0ae828c22bb9d620d6826a76e5c3bfe9aa 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
@@ -22,7 +22,7 @@
 #include <list>
 #include <cmath>
 
-#include <ardour/location.h>
+#include "ardour/location.h"
 #include "enums.h"
 #include "streamview.h"
 #include "time_axis_view_item.h"
@@ -35,7 +35,6 @@ namespace Gdk {
 
 namespace ARDOUR {
        class Route;
-       class Diskstream;
        class Crossfade;
        class PeakData;
        class MidiRegion;
@@ -58,8 +57,8 @@ class MidiStreamView : public StreamView
        ~MidiStreamView ();
 
        void set_selected_regionviews (RegionSelection&);
-       void get_selectables (jack_nframes_t start, jack_nframes_t end, list<Selectable* >&);
-       void get_inverted_selectables (Selection&, list<Selectable* >& results);
+       void get_selectables (nframes_t start, nframes_t end, std::list<Selectable* >&);
+       void get_inverted_selectables (Selection&, std::list<Selectable* >& results);
 
        enum VisibleNoteRange {
                FullRange,
@@ -69,58 +68,76 @@ class MidiStreamView : public StreamView
        Gtk::Adjustment note_range_adjustment;
        ArdourCanvas::Group* midi_underlay_group;
 
-       VisibleNoteRange note_range() { return _range; }
        void set_note_range(VisibleNoteRange r);
-       void set_note_range(uint8_t lowest, uint8_t highest);
-
-       uint8_t lowest_note()  const { return (_range == FullRange) ? 0 : _lowest_note; }
-       uint8_t highest_note() const { return (_range == FullRange) ? 127 : _highest_note; }
-       
-       void update_bounds(uint8_t note_num);
-       
-       void redisplay_diskstream ();
-       
+
+       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_track ();
+
        inline double contents_height() const
        { return (_trackview.current_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; }
-       
+                       - (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; }
-       
+                               + 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; }
-       
+               { return highest_note() - lowest_note() + 1; }
+
        sigc::signal<void> NoteRangeChanged;
 
+       RegionView* create_region_view (boost::shared_ptr<ARDOUR::Region>, bool, bool);
+
   private:
        void setup_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);
-       void        display_region(MidiRegionView* region_view, bool load_model);
-       void        display_diskstream (boost::shared_ptr<ARDOUR::Diskstream> ds);
-       
+
+       void rec_data_range_ready (
+                       nframes_t start,
+                       nframes_t dur,
+                       boost::weak_ptr<ARDOUR::Source> src);
+
+       void update_rec_regions (
+                       boost::shared_ptr<ARDOUR::MidiModel> data,
+                       nframes_t start,
+                       nframes_t dur);
+
+       RegionView* add_region_view_internal (
+                       boost::shared_ptr<ARDOUR::Region>,
+                       bool wait_for_waves,
+                       bool recording = false);
+
+       void display_region(MidiRegionView* region_view, bool load_model);
+       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);
 
        void color_handler ();
 
        void note_range_adjustment_changed();
 
-       VisibleNoteRange          _range;
+       bool                      _range_dirty;
        double                    _range_sum_cache;
-       uint8_t                   _lowest_note;
-       uint8_t                   _highest_note;
-       ArdourCanvas::Lineset*    _note_lines;
+       uint8_t                   _lowest_note;   ///< currently visible
+       uint8_t                   _highest_note;  ///< currently visible
+       uint8_t                   _data_note_min; ///< in data
+       uint8_t                   _data_note_max; ///< in data
+       ArdourCanvas::LineSet*    _note_lines;
 };
 
 #endif /* __ardour_midi_streamview_h__ */