2 Copyright (C) 2008 Paul Davis
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version.
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details.
15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software
17 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20 #ifndef __ardour_ui_midi_channel_selector_h__
21 #define __ardour_ui_midi_channel_selector_h__
24 #include "boost/shared_ptr.hpp"
25 #include "sigc++/trackable.h"
27 #include "gtkmm/table.h"
28 #include "gtkmm/button.h"
29 #include "gtkmm/label.h"
30 #include "gtkmm2ext/stateful_button.h"
32 #include "ardour/types.h"
34 class MidiChannelSelector : public Gtk::Table
37 MidiChannelSelector(int n_rows = 4, int n_columns = 4, int start_row = 0, int start_column = 0);
38 virtual ~MidiChannelSelector() = 0;
40 sigc::signal<void> clicked;
42 void set_channel_colors(const uint32_t new_channel_colors[16]);
43 void set_default_channel_color();
46 virtual void button_toggled(Gtk::ToggleButton* button, uint8_t button_nr) = 0;
47 Gtk::Label _button_labels[4][4];
48 Gtkmm2ext::StatefulToggleButton _buttons[4][4];
49 int _recursion_counter;
51 bool was_clicked (GdkEventButton*);
54 class SingleMidiChannelSelector : public MidiChannelSelector
57 SingleMidiChannelSelector(uint8_t active_channel = 0);
59 uint8_t get_active_channel() const { return _active_channel; }
61 sigc::signal<void, uint8_t> channel_selected;
64 virtual void button_toggled(Gtk::ToggleButton* button, uint8_t button_nr);
66 Gtk::ToggleButton* _last_active_button;
67 uint8_t _active_channel;
70 class MidiMultipleChannelSelector : public MidiChannelSelector
73 MidiMultipleChannelSelector(ARDOUR::ChannelMode mode = ARDOUR::FilterChannels,
74 uint16_t initial_selection = 0xFFFF);
76 virtual ~MidiMultipleChannelSelector();
78 /** The channel mode or selected channel(s) has changed.
79 * First parameter is the new channel mode, second parameter is a bitmask
80 * of the currently selected channels.
82 sigc::signal<void, ARDOUR::ChannelMode, uint16_t> mode_changed;
84 void set_channel_mode(ARDOUR::ChannelMode mode, uint16_t mask);
85 ARDOUR::ChannelMode get_channel_mode () const { return _channel_mode; }
88 * @return each bit in the returned word represents a midi channel, eg.
89 * bit 0 represents channel 0 and bit 15 represents channel 15
92 uint16_t get_selected_channels() const;
93 void set_selected_channels(uint16_t selected_channels);
96 ARDOUR::ChannelMode _channel_mode;
97 ARDOUR::NoteMode _note_mode;
99 virtual void button_toggled(Gtk::ToggleButton* button, uint8_t button_nr);
100 void force_channels_button_toggled();
102 void select_all(bool on);
103 void invert_selection(void);
105 Gtk::Button _select_all;
106 Gtk::Button _select_none;
107 Gtk::Button _invert_selection;
108 Gtk::ToggleButton _force_channel;
111 #endif /*__ardour_ui_midi_channel_selector_h__*/