#include <MIDI_Outputs/Bankable/CCRotaryEncoder.hpp>
A class of MIDIOutputElements that read the input of a quadrature (rotary) encoder and send out relative MIDI Control Change events.
This version can be banked.
Definition at line 20 of file Bankable/CCRotaryEncoder.hpp.
|
void | enable () |
| Enable this updatable: insert it into the linked list of instances, so it gets updated automatically.
|
|
void | disable () |
| Disable this updatable: remove it from the linked list of instances, so it no longer gets updated automatically.
|
|
bool | isEnabled () const |
| Check if this updatable is enabled.
|
|
void | moveDown () |
| Move down this element in the list.
|
|
static void | enable (UpdatableCRTP *element) |
| Enable this updatable: insert it into the linked list of instances, so it gets updated automatically.
|
|
static void | enable (UpdatableCRTP &element) |
| Enable this updatable: insert it into the linked list of instances, so it gets updated automatically.
|
|
template<class U , size_t N> |
static void | enable (U(&array)[N]) |
| Enable this updatable: insert it into the linked list of instances, so it gets updated automatically.
|
|
static void | disable (UpdatableCRTP *element) |
| Disable this updatable: remove it from the linked list of instances, so it no longer gets updated automatically.
|
|
static void | disable (UpdatableCRTP &element) |
| Disable this updatable: remove it from the linked list of instances, so it no longer gets updated automatically.
|
|
template<class U , size_t N> |
static void | disable (U(&array)[N]) |
| Disable this updatable: remove it from the linked list of instances, so it no longer gets updated automatically.
|
|
|
static void | beginAll () |
| Begin all enabled instances of this class.
|
|
static void | updateAll () |
| Update all enabled instances of this class.
|
|
◆ CCRotaryEncoder()
Construct a new Bankable CCRotaryEncoder object with the given pins, controller, channel, speed factor, and number of pulses per step.
- Parameters
-
config | The bank configuration to use: the bank to add this element to, and whether to change the address, channel or cable number. |
encoder | The Encoder object to use.
Usually passed as a list of the two pins connected to the A and B outputs of the encoder, e.g. {2, 3} .
The internal pull-up resistors will be enabled by the Encoder library. |
address | The MIDI address containing the controller number [0, 119], channel [Channel_1, Channel_16], and optional cable number [Cable_1, Cable_16]1, Cable_16]. |
speedMultiply | A constant factor to increase the speed of the rotary encoder. The difference in position will just be multiplied by this factor. |
pulsesPerStep | The number of pulses per physical click of the encoder. For a normal encoder, this is 4. If you want to increase the resolution, for the use of Jog wheels, for example, you can go as 1.
Whereas a greater speedMultiply factor will increase the speed, increasing the number of pulsesPerStep will result in a lower speed. |
Definition at line 54 of file Bankable/CCRotaryEncoder.hpp.
◆ begin()
template<class Enc , class BankAddress , class Sender >
|
inlineoverridevirtualinherited |
◆ update()
template<class Enc , class BankAddress , class Sender >
|
inlineoverridevirtualinherited |
◆ setSpeedMultiply()
template<class Enc , class BankAddress , class Sender >
void setSpeedMultiply |
( |
int16_t | speedMultiply | ) |
|
|
inlineinherited |
◆ getSpeedMultiply()
template<class Enc , class BankAddress , class Sender >
int16_t getSpeedMultiply |
( |
| ) |
const |
|
inlineinherited |
◆ resetPositionOffset()
template<class Enc , class BankAddress , class Sender >
int16_t resetPositionOffset |
( |
| ) |
|
|
inlineinherited |
◆ beginAll()
template<class T = NormalUpdatable>
◆ updateAll()
template<class T = NormalUpdatable>
static void updateAll |
( |
| ) |
|
|
inlinestaticinherited |
◆ enable() [1/4]
Enable this updatable: insert it into the linked list of instances, so it gets updated automatically.
Definition at line 96 of file Updatable.hpp.
◆ enable() [2/4]
Enable this updatable: insert it into the linked list of instances, so it gets updated automatically.
Definition at line 125 of file Updatable.hpp.
◆ enable() [3/4]
Enable this updatable: insert it into the linked list of instances, so it gets updated automatically.
Definition at line 127 of file Updatable.hpp.
◆ enable() [4/4]
template<class Derived >
template<class U , size_t N>
static void enable |
( |
U(&) | array[N] | ) |
|
|
inlinestaticinherited |
Enable this updatable: insert it into the linked list of instances, so it gets updated automatically.
Definition at line 130 of file Updatable.hpp.
◆ disable() [1/4]
Disable this updatable: remove it from the linked list of instances, so it no longer gets updated automatically.
Definition at line 106 of file Updatable.hpp.
◆ disable() [2/4]
Disable this updatable: remove it from the linked list of instances, so it no longer gets updated automatically.
Definition at line 136 of file Updatable.hpp.
◆ disable() [3/4]
Disable this updatable: remove it from the linked list of instances, so it no longer gets updated automatically.
Definition at line 138 of file Updatable.hpp.
◆ disable() [4/4]
template<class Derived >
template<class U , size_t N>
static void disable |
( |
U(&) | array[N] | ) |
|
|
inlinestaticinherited |
Disable this updatable: remove it from the linked list of instances, so it no longer gets updated automatically.
Definition at line 141 of file Updatable.hpp.
◆ isEnabled()
Check if this updatable is enabled.
- Note
- Assumes that the updatable is not added to a different linked list by the user.
Definition at line 120 of file Updatable.hpp.
◆ moveDown()
Move down this element in the list.
Definition at line 147 of file Updatable.hpp.
◆ address
template<class Enc , class BankAddress , class Sender >
◆ encoder
template<class Enc , class BankAddress , class Sender >
◆ encstate
template<class Enc , class BankAddress , class Sender >
◆ sender
template<class Enc , class BankAddress , class Sender >
◆ updatables
◆ next
◆ previous
The documentation for this class was generated from the following file: