X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fmidi_streamview.h;h=2f8e63ab9dae5787e9399fa8135555f7df79146b;hb=900309993c485527145be4265247bd521073ee61;hp=5c0ee47c3065e982e6326f0187bd75fbeba04294;hpb=2db91c126edc8fcaeda711d35369970576715719;p=ardour.git diff --git a/gtk2_ardour/midi_streamview.h b/gtk2_ardour/midi_streamview.h index 5c0ee47c30..2f8e63ab9d 100644 --- a/gtk2_ardour/midi_streamview.h +++ b/gtk2_ardour/midi_streamview.h @@ -67,59 +67,75 @@ 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; } + inline uint8_t lowest_note() const { return _lowest_note; } + inline uint8_t highest_note() const { return _highest_note; } - void update_bounds(uint8_t note_num); + void update_note_range(uint8_t note_num); void redisplay_diskstream (); inline double contents_height() const - { return (_trackview.height - TimeAxisViewItem::NAME_HIGHLIGHT_SIZE - 2); } + { 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 NoteRangeChanged; private: void setup_rec_box (); - void rec_data_range_ready (jack_nframes_t start, jack_nframes_t dur, boost::weak_ptr src); - void update_rec_regions (boost::shared_ptr data, jack_nframes_t start, jack_nframes_t dur); + + void rec_data_range_ready ( + jack_nframes_t start, + jack_nframes_t dur, + boost::weak_ptr src); + + void update_rec_regions ( + boost::shared_ptr data, + jack_nframes_t start, + jack_nframes_t dur); - RegionView* add_region_view_internal (boost::shared_ptr, bool wait_for_waves); - void display_region(MidiRegionView* region_view, bool load_model); - void display_diskstream (boost::shared_ptr ds); + RegionView* add_region_view_internal ( + boost::shared_ptr, + bool wait_for_waves, + bool recording = false); + + void display_region(MidiRegionView* region_view, bool load_model); + void display_diskstream (boost::shared_ptr ds); - void update_contents_y_position_and_height (); + 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 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__ */