First "it seems to work for me" version for initial testing of MIDI buttons.

pull/365/head
diyelectromusic 3 years ago
parent db808d4cfc
commit 70c0f8b54f
  1. 2
      src/config.cpp
  2. 4
      src/mididevice.h
  3. 4
      src/midipin.cpp
  4. 6
      src/midipin.h
  5. 6
      src/minidexed.cpp
  6. 64
      src/uibuttons.cpp
  7. 2
      src/uibuttons.h
  8. 26
      src/userinterface.cpp
  9. 1
      src/userinterface.h

@ -104,7 +104,7 @@ void CConfig::Load (void)
m_nDoubleClickTimeout = m_Properties.GetNumber ("DoubleClickTimeout", 400); m_nDoubleClickTimeout = m_Properties.GetNumber ("DoubleClickTimeout", 400);
m_nLongPressTimeout = m_Properties.GetNumber ("LongPressTimeout", 600); m_nLongPressTimeout = m_Properties.GetNumber ("LongPressTimeout", 600);
m_nMIDIButtonCh = m_Properties.GetNumber ("MIDIButtonCh", 255); m_nMIDIButtonCh = m_Properties.GetNumber ("MIDIButtonCh", 0);
m_nMIDIButtonPrev = m_Properties.GetNumber ("MIDIButtonPrev", 0); m_nMIDIButtonPrev = m_Properties.GetNumber ("MIDIButtonPrev", 0);
m_nMIDIButtonNext = m_Properties.GetNumber ("MIDIButtonNext", 0); m_nMIDIButtonNext = m_Properties.GetNumber ("MIDIButtonNext", 0);
m_nMIDIButtonBack = m_Properties.GetNumber ("MIDIButtonBack", 0); m_nMIDIButtonBack = m_Properties.GetNumber ("MIDIButtonBack", 0);

@ -28,6 +28,7 @@
#include <unordered_map> #include <unordered_map>
#include <circle/types.h> #include <circle/types.h>
#include <circle/spinlock.h> #include <circle/spinlock.h>
#include "userinterface.h"
class CMiniDexed; class CMiniDexed;
@ -43,7 +44,7 @@ public:
}; };
public: public:
CMIDIDevice (CMiniDexed *pSynthesizer, CConfig *pConfig); CMIDIDevice (CMiniDexed *pSynthesizer, CConfig *pConfig, CUserInterface *pUI);
virtual ~CMIDIDevice (void); virtual ~CMIDIDevice (void);
void SetChannel (u8 ucChannel, unsigned nTG); void SetChannel (u8 ucChannel, unsigned nTG);
@ -59,6 +60,7 @@ protected:
private: private:
CMiniDexed *m_pSynthesizer; CMiniDexed *m_pSynthesizer;
CConfig *m_pConfig; CConfig *m_pConfig;
CUserInterface *m_pUI;
u8 m_ChannelMap[CConfig::ToneGenerators]; u8 m_ChannelMap[CConfig::ToneGenerators];

@ -33,12 +33,12 @@ CMIDIPin::~CMIDIPin (void)
{ {
} }
unsigned CMIDIPin::read (void) unsigned CMIDIPin::Read (void)
{ {
return m_nValue; return m_nValue;
} }
void CMIDIPin::write (unsigned nValue) void CMIDIPin::Write (unsigned nValue)
{ {
// Takes values in the MIDI controller range 0 to 127 // Takes values in the MIDI controller range 0 to 127
// and OFF < 64 < ON. // and OFF < 64 < ON.

@ -31,7 +31,7 @@
#define MidiPinToCC(p) ((p)-MIDI_PINS) #define MidiPinToCC(p) ((p)-MIDI_PINS)
#define isMidiPin(p) (((p)>=MIDI_PINS)?1:0) #define isMidiPin(p) (((p)>=MIDI_PINS)?1:0)
class CMIDIPin : public CGPIOPin class CMIDIPin
{ {
public: public:
CMIDIPin (unsigned nPinNumber); // pinNumber = ccToMidiPin (MIDI CC number) CMIDIPin (unsigned nPinNumber); // pinNumber = ccToMidiPin (MIDI CC number)
@ -40,11 +40,11 @@ public:
// Will return MP_HIGH or MP_LOW. // Will return MP_HIGH or MP_LOW.
// Should be treated as a PULLED UP IO pin // Should be treated as a PULLED UP IO pin
// i.e. treated as "active low" (LOW) when pressed. // i.e. treated as "active low" (LOW) when pressed.
unsigned read (void); unsigned Read (void);
// MIDI CC values >=64 will set the MIDI pin to LOW ("on") // MIDI CC values >=64 will set the MIDI pin to LOW ("on")
// MIDI CC values <= 63 will set the MIDI pin to HIGH ("off") // MIDI CC values <= 63 will set the MIDI pin to HIGH ("off")
void write (unsigned nValue); void Write (unsigned nValue);
private: private:
unsigned m_nPinNumber; unsigned m_nPinNumber;

@ -39,8 +39,8 @@ CMiniDexed::CMiniDexed (CConfig *pConfig, CInterruptSystem *pInterrupt,
m_pConfig (pConfig), m_pConfig (pConfig),
m_UI (this, pGPIOManager, pI2CMaster, pConfig), m_UI (this, pGPIOManager, pI2CMaster, pConfig),
m_PerformanceConfig (pFileSystem), m_PerformanceConfig (pFileSystem),
m_PCKeyboard (this, pConfig), m_PCKeyboard (this, pConfig, &m_UI),
m_SerialMIDI (this, pInterrupt, pConfig), m_SerialMIDI (this, pInterrupt, pConfig, &m_UI),
m_bUseSerial (false), m_bUseSerial (false),
m_pSoundDevice (0), m_pSoundDevice (0),
m_bChannelsSwapped (pConfig->GetChannelsSwapped ()), m_bChannelsSwapped (pConfig->GetChannelsSwapped ()),
@ -98,7 +98,7 @@ CMiniDexed::CMiniDexed (CConfig *pConfig, CInterruptSystem *pInterrupt,
for (unsigned i = 0; i < CConfig::MaxUSBMIDIDevices; i++) for (unsigned i = 0; i < CConfig::MaxUSBMIDIDevices; i++)
{ {
m_pMIDIKeyboard[i] = new CMIDIKeyboard (this, pConfig, i); m_pMIDIKeyboard[i] = new CMIDIKeyboard (this, pConfig, &m_UI, i);
assert (m_pMIDIKeyboard[i]); assert (m_pMIDIKeyboard[i]);
} }

@ -28,6 +28,7 @@ LOGMODULE ("uibuttons");
CUIButton::CUIButton (void) CUIButton::CUIButton (void)
: m_pinNumber (0), : m_pinNumber (0),
m_pin (0), m_pin (0),
m_midipin (0),
m_lastValue (1), m_lastValue (1),
m_timer (0), m_timer (0),
m_debounceTimer (0), m_debounceTimer (0),
@ -46,6 +47,10 @@ CUIButton::~CUIButton (void)
{ {
delete m_pin; delete m_pin;
} }
if (m_midipin)
{
delete m_midipin;
}
} }
void CUIButton::reset (void) void CUIButton::reset (void)
@ -71,8 +76,10 @@ boolean CUIButton::Initialize (unsigned pinNumber, unsigned doubleClickTimeout,
{ {
if (isMidiPin(m_pinNumber)) if (isMidiPin(m_pinNumber))
{ {
m_pin = new CMIDIPin (m_pinNumber); LOGDBG("MIDI Button on pin: %d (%x)", m_pinNumber, m_pinNumber);
m_midipin = new CMIDIPin (m_pinNumber);
} else { } else {
LOGDBG("GPIO Button on pin: %d (%x)", m_pinNumber, m_pinNumber);
m_pin = new CGPIOPin (m_pinNumber, GPIOModeInputPullUp); m_pin = new CGPIOPin (m_pinNumber, GPIOModeInputPullUp);
} }
} }
@ -101,13 +108,25 @@ unsigned CUIButton::getPinNumber(void)
CUIButton::BtnTrigger CUIButton::ReadTrigger (void) CUIButton::BtnTrigger CUIButton::ReadTrigger (void)
{ {
if (!m_pin) unsigned value;
if (isMidiPin(m_pinNumber))
{ {
// Always return "not pressed" if not configured if (!m_midipin)
return BtnTriggerNone; {
// Always return "not pressed" if not configured
return BtnTriggerNone;
}
value = m_midipin->Read();
}
else
{
if (!m_pin)
{
// Always return "not pressed" if not configured
return BtnTriggerNone;
}
value = m_pin->Read();
} }
unsigned value = m_pin->Read();
if (m_timer < m_longPressTimeout) { if (m_timer < m_longPressTimeout) {
m_timer++; m_timer++;
@ -192,14 +211,10 @@ CUIButton::BtnTrigger CUIButton::ReadTrigger (void)
void CUIButton::Write (unsigned nValue) { void CUIButton::Write (unsigned nValue) {
// This only makes sense for MIDI buttons. // This only makes sense for MIDI buttons.
unsigned pin = getPinNumber(); if (m_midipin && isMidiPin(m_pinNumber))
if (isMidiPin(pin))
{ {
if (m_pin) // Update the "MIDI Pin"
{ m_midipin->Write(nValue);
// Update the "MIDI Pin"
m_pin->Write(nValue);
}
} }
} }
@ -263,11 +278,11 @@ CUIButtons::CUIButtons (
m_selectAction(CUIButton::triggerTypeFromString(selectAction)), m_selectAction(CUIButton::triggerTypeFromString(selectAction)),
m_homePin(homePin), m_homePin(homePin),
m_homeAction(CUIButton::triggerTypeFromString(homeAction)), m_homeAction(CUIButton::triggerTypeFromString(homeAction)),
m_prevMidi(prevMidi), m_prevMidi(ccToMidiPin(prevMidi)),
m_nextMidi(nextMidi), m_nextMidi(ccToMidiPin(nextMidi)),
m_backMidi(backMidi), m_backMidi(ccToMidiPin(backMidi)),
m_selectMidi(selectMidi), m_selectMidi(ccToMidiPin(selectMidi)),
m_homeMidi(homeMidi), m_homeMidi(ccToMidiPin(homeMidi)),
m_eventHandler (0), m_eventHandler (0),
m_lastTick (0) m_lastTick (0)
{ {
@ -354,9 +369,16 @@ boolean CUIButtons::Initialize (void)
continue; continue;
} }
// doubleClickTimeout and longPressTimeout are ignored for MIDI buttons at present // Carry on in the list from where GPIO buttons left off
m_buttons[i].Initialize(pins[i], doubleClickTimeout, longPressTimeout); for (unsigned j=0; j<MAX_BUTTONS; j++) {
} if (m_buttons[j].getPinNumber() == 0) {
// This is un-initialised so can be assigned
// doubleClickTimeout and longPressTimeout are ignored for MIDI buttons at present
m_buttons[j].Initialize(pins[i], doubleClickTimeout, longPressTimeout);
break;
}
}
}
// All of the buttons are now initialised, they just need to have their // All of the buttons are now initialised, they just need to have their
// events assigned to them // events assigned to them

@ -78,6 +78,8 @@ private:
unsigned m_pinNumber; unsigned m_pinNumber;
// GPIO pin // GPIO pin
CGPIOPin *m_pin; CGPIOPin *m_pin;
// MIDI pin
CMIDIPin *m_midipin;
// The value of the pin at the end of the last loop // The value of the pin at the end of the last loop
unsigned m_lastValue; unsigned m_lastValue;
// Set to 0 on press, increment each read, use to trigger events // Set to 0 on press, increment each read, use to trigger events

@ -129,7 +129,7 @@ bool CUserInterface::Initialize (void)
} }
m_pUIButtons->RegisterEventHandler (UIButtonsEventStub, this); m_pUIButtons->RegisterEventHandler (UIButtonsEventStub, this);
m_nMIDIButtonCh = m_pConfig->GetMIDIButtonCh (); UISetMIDICCChannel (m_pConfig->GetMIDIButtonCh ());
LOGDBG ("Button User Interface initialized"); LOGDBG ("Button User Interface initialized");
@ -332,7 +332,12 @@ void CUserInterface::UIButtonsEventStub (CUIButton::BtnEvent Event, void *pParam
void CUserInterface::UIMIDICCHandler (unsigned nMidiCh, unsigned nMidiCC, unsigned nMidiData) void CUserInterface::UIMIDICCHandler (unsigned nMidiCh, unsigned nMidiCC, unsigned nMidiData)
{ {
if ((m_nMIDIButtonCh != nMidiCh) && (m_nMIDIButtonCh != 0)) if (m_nMIDIButtonCh == CMIDIDevice::Disabled)
{
// MIDI buttons are not enabled
return;
}
if ((m_nMIDIButtonCh != nMidiCh) && (m_nMIDIButtonCh != CMIDIDevice::OmniMode))
{ {
// Message not on the MIDI Button channel and MIDI buttons not in OMNI mode // Message not on the MIDI Button channel and MIDI buttons not in OMNI mode
return; return;
@ -343,3 +348,20 @@ void CUserInterface::UIMIDICCHandler (unsigned nMidiCh, unsigned nMidiCC, unsign
m_pUIButtons->BtnMIDICCHandler (nMidiCC, nMidiData); m_pUIButtons->BtnMIDICCHandler (nMidiCC, nMidiData);
} }
} }
void CUserInterface::UISetMIDICCChannel (unsigned uCh)
{
// Mirrors the logic in Performance Config for handling MIDI channel configuration
if (uCh == 0)
{
m_nMIDIButtonCh = CMIDIDevice::Disabled;
}
else if (uCh < CMIDIDevice::Channels)
{
m_nMIDIButtonCh = uCh - 1;
}
else
{
m_nMIDIButtonCh = CMIDIDevice::OmniMode;
}
}

@ -62,6 +62,7 @@ private:
static void EncoderEventStub (CKY040::TEvent Event, void *pParam); static void EncoderEventStub (CKY040::TEvent Event, void *pParam);
void UIButtonsEventHandler (CUIButton::BtnEvent Event); void UIButtonsEventHandler (CUIButton::BtnEvent Event);
static void UIButtonsEventStub (CUIButton::BtnEvent Event, void *pParam); static void UIButtonsEventStub (CUIButton::BtnEvent Event, void *pParam);
void UISetMIDICCChannel (unsigned uCh);
private: private:
CMiniDexed *m_pMiniDexed; CMiniDexed *m_pMiniDexed;

Loading…
Cancel
Save