Control Surface  1.1.0
MIDI Control Surface library for Arduino
CCButtons.hpp
Go to the documentation of this file.
1 #pragma once
2 
5 
7 
8 /**
9  * @brief A class of MIDIOutputElement%s that read the input of a **collection
10  * of momentary push buttons or switches**, and send out MIDI **Control
11  * Change** events.
12  *
13  * A value of 0x7F is sent when a button is pressed, and a value of 0x00 is sent
14  * when a button is released.
15  * The buttons are debounced in software.
16  * This version cannot be banked.
17  *
18  * @tparam NUMBER_OF_BUTTONS
19  * The number of buttons in the collection.
20  *
21  * @ingroup MIDIOutputElements
22  */
23 template <uint8_t NUMBER_OF_BUTTONS>
24 class CCButtons : public MIDIButtons<DigitalCCSender, NUMBER_OF_BUTTONS> {
25  public:
26  /**
27  * @brief Create a new CCButtons object with the given pins,
28  * the given controller number and channel.
29  *
30  * @param buttons
31  * An list of digital input pins with the buttons connected.
32  * The internal pull-up resistors will be enabled.
33  * @param baseAddress
34  * The MIDI address of the first button, containing the controller
35  * number [0, 119], channel [CHANNEL_1, CHANNEL_16], and optional
36  * cable number [0, 15].
37  * @param incrementAddress
38  * The number of addresses to increment for each next button.
39  * E.g. if `baseAddress` is 8, and `incrementAddress` is 2,
40  * then the first button will send on address 8, the second
41  * button will send on address 10, button three on address 12, etc.
42  * @param sender
43  * The MIDI sender to use.
44  */
48  const DigitalCCSender &sender = {})
51 };
52 
Bankable::MIDIButtons< DigitalCCSender, NUMBER_OF_BUTTONS >::baseAddress
const MIDICNChannelAddress baseAddress
Definition: Bankable/Abstract/MIDIButtons.hpp:78
Bankable::MIDIButtons< DigitalCCSender, NUMBER_OF_BUTTONS >::buttons
Array< AH::Button, NUMBER_OF_BUTTONS > buttons
Definition: Bankable/Abstract/MIDIButtons.hpp:77
Bankable::MIDIButtons< DigitalCCSender, NUMBER_OF_BUTTONS >::incrementAddress
const RelativeMIDICNChannelAddress incrementAddress
Definition: Bankable/Abstract/MIDIButtons.hpp:79
DigitalCCSender.hpp
BEGIN_CS_NAMESPACE
#define BEGIN_CS_NAMESPACE
Definition: Settings/NamespaceSettings.hpp:9
RelativeMIDICNChannelAddress
A class for saving an offset to a MIDI address.
Definition: MIDICNChannelAddress.hpp:58
DigitalCCSender
Definition: DigitalCCSender.hpp:7
END_CS_NAMESPACE
#define END_CS_NAMESPACE
Definition: Settings/NamespaceSettings.hpp:10
MIDIButtons
An abstract class for momentary push buttons that send MIDI events.
Definition: Abstract/MIDIButtons.hpp:17
Bankable::MIDIButtons< DigitalCCSender, NUMBER_OF_BUTTONS >::sender
DigitalCCSender sender
Definition: Bankable/Abstract/MIDIButtons.hpp:83
MIDICNChannelAddress
A type-safe utility class for saving a MIDI address consisting of a 7-bit address,...
Definition: MIDICNChannelAddress.hpp:82
AH::Array
An array wrapper for easy copying, comparing, and iterating.
Definition: Array.hpp:36
CCButtons::CCButtons
CCButtons(const Array< AH::Button, NUMBER_OF_BUTTONS > &buttons, const MIDICNChannelAddress &baseAddress, const RelativeMIDICNChannelAddress &incrementAddress, const DigitalCCSender &sender={})
Create a new CCButtons object with the given pins, the given controller number and channel.
Definition: CCButtons.hpp:45
MIDIButtons.hpp
CCButtons
A class of MIDIOutputElements that read the input of a collection of momentary push buttons or switch...
Definition: CCButtons.hpp:24