Control Surface  1.1.1
MIDI Control Surface library for Arduino
Public Member Functions | Static Public Member Functions | Public Attributes | Protected Attributes | Private Attributes | Static Private Attributes | List of all members
CCRotaryEncoder Class Reference

A class of MIDIOutputElements that read the input of a quadrature (rotary) encoder and send out relative MIDI Control Change events. More...

#include <MIDI_Outputs/Bankable/CCRotaryEncoder.hpp>

Inheritance diagram for CCRotaryEncoder:
Collaboration diagram for CCRotaryEncoder:

Public Member Functions

 CCRotaryEncoder (const OutputBankConfig &config, const EncoderPinList &pins, const MIDICNChannelAddress &address, int8_t speedMultiplier, uint8_t pulsesPerStep, const RelativeCCSender &sender={})
 Construct a new Bankable CCRotaryEncoder object with the given pins, controller, channel, speed factor, and number of pulses per step. More...
 
void begin () final override
 Initialize this updatable. More...
 
void update () final override
 Update this updatable. More...
 
RelativeMIDICNChannelAddress getAddressOffset () const
 Get the offset relative to the base address. More...
 
setting_t getRawBankSetting () const
 Get the actual bank setting (no matter whether the element is locked or not). More...
 
setting_t getSelection () const
 Get the bank setting. More...
 
void lock ()
 Lock the bank setting. More...
 
void unlock ()
 Unlock the bank setting. More...
 
void enable ()
 Enable this updatable: insert it into the linked list of instances, so it gets updated automatically. More...
 
void disable ()
 Disable this updatable: remove it from the linked list of instances, so it no longer gets updated automatically. More...
 
bool isEnabled ()
 Check if this updatable is enabled. More...
 

Static Public Member Functions

static void enable (Updatable *element)
 
static void enable (Updatable &element)
 
static void enable (U(&array)[N])
 
static void disable (Updatable< NormalUpdatable > *element)
 
static void disable (Updatable< NormalUpdatable > &element)
 
static void disable (U(&array)[N])
 
static void beginAll ()
 Begin all enabled instances of this class. More...
 
static void updateAll ()
 Update all enabled instances of this class. More...
 

Public Attributes

RelativeCCSender sender
 

Protected Attributes

const OutputBankbank
 
Updatable< NormalUpdatable > * next
 
Updatable< NormalUpdatable > * previous
 

Private Attributes

Encoder encoder
 
const MIDICNChannelAddress address
 
const uint8_t speedMultiply
 
const uint8_t pulsesPerStep
 
long previousPosition
 
const BankType type
 
setting_t lockedSetting = UNLOCKED
 

Static Private Attributes

constexpr static setting_t UNLOCKED = NO_SETTING
 
static DoublyLinkedList< Updatable< NormalUpdatable > > updatables
 

Detailed Description

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.

Note
To use this class, include the PJRC Encoder library before the Control-Surface library.

Definition at line 23 of file Bankable/CCRotaryEncoder.hpp.

Constructor & Destructor Documentation

◆ CCRotaryEncoder()

CCRotaryEncoder ( const OutputBankConfig config,
const EncoderPinList pins,
const MIDICNChannelAddress address,
int8_t  speedMultiplier,
uint8_t  pulsesPerStep,
const RelativeCCSender sender = {} 
)
inline

Construct a new Bankable CCRotaryEncoder object with the given pins, controller, channel, speed factor, and number of pulses per step.

Parameters
configThe bank configuration to use: the bank to add this element to, and whether to change the address, channel or cable number.
pinsA list of the two pins connected to the A and B outputs of the encoder.
The internal pull-up resistors will be enabled by the Encoder library.
addressThe MIDI address containing the controller number [0, 119], channel [CHANNEL_1, CHANNEL_16], and optional cable number [0, 15].
speedMultiplierA constant factor to increase the speed of the rotary encoder. The difference in position will just be multiplied by this factor.
pulsesPerStepThe 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 speedMultiplier factor will increase the speed, increasing the number of pulsesPerStep will result in a lower speed.
senderThe MIDI sender to use.

Definition at line 57 of file Bankable/CCRotaryEncoder.hpp.

Member Function Documentation

◆ begin()

void begin ( )
inlinefinaloverridevirtualinherited

Initialize this updatable.

Implements Updatable<>.

Definition at line 51 of file Bankable/Abstract/MIDIRotaryEncoder.hpp.

◆ update()

void update ( )
inlinefinaloverridevirtualinherited

Update this updatable.

Implements Updatable<>.

Definition at line 52 of file Bankable/Abstract/MIDIRotaryEncoder.hpp.

◆ getAddressOffset()

RelativeMIDICNChannelAddress getAddressOffset ( ) const
inlineinherited

Get the offset relative to the base address.

Definition at line 111 of file BankableMIDIOutput.hpp.

◆ getRawBankSetting()

setting_t getRawBankSetting ( ) const
inlineinherited

Get the actual bank setting (no matter whether the element is locked or not).

Definition at line 26 of file BankableMIDIOutput.hpp.

◆ getSelection()

setting_t getSelection ( ) const
inlineinherited

Get the bank setting.

If the element is locked, the bank setting from the moment it was locked is returned.

Definition at line 34 of file BankableMIDIOutput.hpp.

◆ lock()

void lock ( )
inlineinherited

Lock the bank setting.

As long as it's locked, getSelection will return the current setting, independent from the actual bank setting.

Definition at line 44 of file BankableMIDIOutput.hpp.

◆ unlock()

void unlock ( )
inlineinherited

Unlock the bank setting.

After unlocking, getSelection will return the actual bank setting again.

Definition at line 55 of file BankableMIDIOutput.hpp.

◆ enable() [1/4]

void enable ( )
inlineinherited

Enable this updatable: insert it into the linked list of instances, so it gets updated automatically.

Definition at line 45 of file Updatable.hpp.

◆ enable() [2/4]

static void enable ( Updatable<> *  element)
inlinestaticinherited

Definition at line 85 of file Updatable.hpp.

◆ enable() [3/4]

static void enable ( Updatable<> &  element)
inlinestaticinherited

Definition at line 87 of file Updatable.hpp.

◆ enable() [4/4]

static void enable ( U(&)  array[N])
inlinestaticinherited

Definition at line 90 of file Updatable.hpp.

◆ disable() [1/4]

void disable ( )
inlineinherited

Disable this updatable: remove it from the linked list of instances, so it no longer gets updated automatically.

Definition at line 55 of file Updatable.hpp.

◆ disable() [2/4]

static void disable ( Updatable< NormalUpdatable<> > *  element)
inlinestaticinherited

Definition at line 95 of file Updatable.hpp.

◆ disable() [3/4]

static void disable ( Updatable< NormalUpdatable<> > &  element)
inlinestaticinherited

Definition at line 97 of file Updatable.hpp.

◆ disable() [4/4]

static void disable ( U(&)  array[N])
inlinestaticinherited

Definition at line 100 of file Updatable.hpp.

◆ isEnabled()

bool isEnabled ( )
inlineinherited

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 69 of file Updatable.hpp.

◆ beginAll()

static void beginAll ( )
inlinestaticinherited

Begin all enabled instances of this class.

See also
begin()

Definition at line 73 of file Updatable.hpp.

◆ updateAll()

static void updateAll ( )
inlinestaticinherited

Update all enabled instances of this class.

See also
update()

Definition at line 80 of file Updatable.hpp.

Member Data Documentation

◆ encoder

Encoder encoder
privateinherited

Definition at line 64 of file Bankable/Abstract/MIDIRotaryEncoder.hpp.

◆ address

const MIDICNChannelAddress address
privateinherited

Definition at line 65 of file Bankable/Abstract/MIDIRotaryEncoder.hpp.

◆ speedMultiply

const uint8_t speedMultiply
privateinherited

Definition at line 66 of file Bankable/Abstract/MIDIRotaryEncoder.hpp.

◆ pulsesPerStep

const uint8_t pulsesPerStep
privateinherited

Definition at line 67 of file Bankable/Abstract/MIDIRotaryEncoder.hpp.

◆ previousPosition

long previousPosition
privateinherited

Definition at line 68 of file Bankable/Abstract/MIDIRotaryEncoder.hpp.

◆ sender

RelativeCCSender sender
inherited

Definition at line 71 of file Bankable/Abstract/MIDIRotaryEncoder.hpp.

◆ type

const BankType type
privateinherited

Definition at line 122 of file BankableMIDIOutput.hpp.

◆ bank

const OutputBank& bank
protectedinherited

Definition at line 58 of file BankableMIDIOutput.hpp.

◆ UNLOCKED

constexpr static setting_t UNLOCKED = NO_SETTING
staticconstexprprivateinherited

Definition at line 61 of file BankableMIDIOutput.hpp.

◆ lockedSetting

setting_t lockedSetting = UNLOCKED
privateinherited

Definition at line 62 of file BankableMIDIOutput.hpp.

◆ updatables

DoublyLinkedList< Updatable< NormalUpdatable > > updatables
staticprivateinherited

Definition at line 106 of file Updatable.hpp.

◆ next

Updatable< NormalUpdatable > * next
protectedinherited

Definition at line 305 of file LinkedList.hpp.

◆ previous

Updatable< NormalUpdatable > * previous
protectedinherited

Definition at line 306 of file LinkedList.hpp.


The documentation for this class was generated from the following file: