X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=gtk2_ardour%2Fmidi_time_axis.h;h=fb95ae94fb3bbaf35c446e968c69ab8d007ab23e;hb=ad4ae3df85d685546a4aaf6e976d3a03f6a6f45b;hp=d61b64f36c238a99e384f9ceab0304653be7d0da;hpb=88de45b7ccc933ee46a13d4e4e21caf9e5fb379e;p=ardour.git diff --git a/gtk2_ardour/midi_time_axis.h b/gtk2_ardour/midi_time_axis.h index d61b64f36c..fb95ae94fb 100644 --- a/gtk2_ardour/midi_time_axis.h +++ b/gtk2_ardour/midi_time_axis.h @@ -19,6 +19,8 @@ #ifndef __ardour_midi_time_axis_h__ #define __ardour_midi_time_axis_h__ +#include + #include #include #include @@ -27,19 +29,24 @@ #include #include -#include -#include +#include "gtkmm2ext/selector.h" #include "ardour/types.h" #include "ardour/region.h" #include "ardour_dialog.h" +#include "ardour_dropdown.h" #include "route_ui.h" #include "enums.h" #include "route_time_axis.h" -#include "canvas.h" #include "midi_streamview.h" -#include "midi_channel_selector.h" + +namespace MIDI { +namespace Name { +class MasterDeviceNames; +class CustomDeviceMode; +} +} namespace ARDOUR { class Session; @@ -49,27 +56,31 @@ namespace ARDOUR { class MidiPlaylist; } +namespace Evoral { + template class Note; +} + class PublicEditor; class MidiStreamView; class MidiScroomer; class PianoRollHeader; class StepEntry; class StepEditor; +class MidiChannelSelectorWindow; + +#define NO_MIDI_NOTE 0xff class MidiTimeAxisView : public RouteTimeAxisView { - public: - MidiTimeAxisView (PublicEditor&, ARDOUR::Session*, ArdourCanvas::Canvas& canvas); - virtual ~MidiTimeAxisView (); +public: + MidiTimeAxisView (PublicEditor&, ARDOUR::Session*, ArdourCanvas::Canvas& canvas); + virtual ~MidiTimeAxisView (); void set_route (boost::shared_ptr); MidiStreamView* midi_view(); - void set_height (uint32_t); - - void enter_internal_edit_mode (); - void leave_internal_edit_mode (); + void set_height (uint32_t, TrackHeightMode m = OnlySelf); boost::shared_ptr add_region (ARDOUR::framepos_t, ARDOUR::framecnt_t, bool); @@ -77,6 +88,8 @@ class MidiTimeAxisView : public RouteTimeAxisView void show_existing_automation (bool apply_to_selection = false); void create_automation_child (const Evoral::Parameter& param, bool show); + bool paste (ARDOUR::framepos_t, const Selection&, PasteContext& ctx); + ARDOUR::NoteMode note_mode() const { return _note_mode; } ARDOUR::ColorMode color_mode() const { return _color_mode; } @@ -85,36 +98,33 @@ class MidiTimeAxisView : public RouteTimeAxisView void update_range(); - sigc::signal& signal_channel_mode_changed() { - return _channel_selector.mode_changed; - } - - const MidiMultipleChannelSelector& channel_selector() { return _channel_selector; } - Gtk::CheckMenuItem* automation_child_menu_item (Evoral::Parameter); - StepEditor* step_editor() { return _step_editor; } - void check_step_edit (); + StepEditor* step_editor() { return _step_editor; } + void check_step_edit (); void first_idle (); + void set_note_highlight (uint8_t note); uint8_t get_channel_for_add () const; - protected: + void get_per_region_note_selection (std::list > > > >&); + +protected: void start_step_editing (); void stop_step_editing (); - private: +private: sigc::signal _midi_patch_settings_changed; - void model_changed(); - void custom_device_mode_changed(); + void model_changed(const std::string& model); + void custom_device_mode_changed(const std::string& mode); void append_extra_display_menu_items (); void build_automation_action_menu (bool); Gtk::Menu* build_note_mode_menu(); Gtk::Menu* build_color_mode_menu(); - + void set_note_mode (ARDOUR::NoteMode mode, bool apply_to_selection = false); void set_color_mode (ARDOUR::ColorMode, bool force = false, bool redisplay = true, bool apply_to_selection = false); void set_note_range (MidiStreamView::VisibleNoteRange range, bool apply_to_selection = false); @@ -133,10 +143,13 @@ class MidiTimeAxisView : public RouteTimeAxisView Gtk::RadioMenuItem* _meter_color_mode_item; Gtk::RadioMenuItem* _channel_color_mode_item; Gtk::RadioMenuItem* _track_color_mode_item; - Gtk::Table _midi_controls_box; - MidiMultipleChannelSelector _channel_selector; - Gtk::ComboBoxText _midnam_model_selector; - Gtk::ComboBoxText _midnam_custom_device_mode_selector; + Gtk::Label _playback_channel_status; + Gtk::Label _capture_channel_status; + Gtk::HBox _channel_status_box; + Gtk::VBox _midi_controls_box; + MidiChannelSelectorWindow* _channel_selector; + ArdourDropdown _midnam_model_selector; + ArdourDropdown _midnam_custom_device_mode_selector; Gtk::CheckMenuItem* _step_edit_item; Gtk::Menu* default_channel_menu; @@ -150,6 +163,8 @@ class MidiTimeAxisView : public RouteTimeAxisView void add_single_channel_controller_item (Gtk::Menu_Helpers::MenuList& ctl_items, int ctl, const std::string& name); void add_multi_channel_controller_item (Gtk::Menu_Helpers::MenuList& ctl_items, int ctl, const std::string& name); void build_controller_menu (); + void toggle_channel_selector (); + void channel_selector_hidden (); void set_channel_mode (ARDOUR::ChannelMode, uint16_t); void set_note_selection (uint8_t note); @@ -160,6 +175,7 @@ class MidiTimeAxisView : public RouteTimeAxisView void add_note_selection_region_view (RegionView* rv, uint8_t note, uint16_t chn_mask); void extend_note_selection_region_view (RegionView*, uint8_t note, uint16_t chn_mask); void toggle_note_selection_region_view (RegionView*, uint8_t note, uint16_t chn_mask); + void get_per_region_note_selection_region_view (RegionView*, std::list > > > >&); void ensure_step_editor (); @@ -168,8 +184,10 @@ class MidiTimeAxisView : public RouteTimeAxisView /** parameter -> menu item map for the controller menu */ ParameterMenuMap _controller_menu_map; - StepEditor* _step_editor; + StepEditor* _step_editor; + + void capture_channel_mode_changed(); + void playback_channel_mode_changed(); }; #endif /* __ardour_midi_time_axis_h__ */ -