From 5f8d8687776b057f35ad368c3fba4347dcd9a8c2 Mon Sep 17 00:00:00 2001 From: Anders Goran Date: Wed, 2 Oct 2024 17:48:38 +0100 Subject: [PATCH 1/5] Add ctrlmidich option for "own channel" regardless of number --- src/audiomixerboard.cpp | 10 ++++++++++ src/sound/soundbase.cpp | 8 ++++++++ src/sound/soundbase.h | 1 + 3 files changed, 19 insertions(+) diff --git a/src/audiomixerboard.cpp b/src/audiomixerboard.cpp index db6cab14e4..16c96416f2 100644 --- a/src/audiomixerboard.cpp +++ b/src/audiomixerboard.cpp @@ -1351,6 +1351,16 @@ void CAudioMixerBoard::SetFaderLevel ( const int iChannelIdx, const int iValue ) vecpChanFader[static_cast ( iChannelIdx )]->SetFaderLevel ( iValue ); } } + // Proposed change: if iChannelIdx is -1 and our own channel ID is a valid index + // then we adjust our own fader level: + if((iChannelIdx == -1) && iMyChannelID != INVALID_INDEX) + { + if ( vecpChanFader[static_cast ( iMyChannelID )]->IsVisible() ) + { + //printf("debug: set our own fader(%d) level to %d\n", iMyChannelID, iValue); + vecpChanFader[static_cast ( iMyChannelID )]->SetFaderLevel ( iValue ); + } + } } void CAudioMixerBoard::SetPanValue ( const int iChannelIdx, const int iValue ) diff --git a/src/sound/soundbase.cpp b/src/sound/soundbase.cpp index 464b81bd41..3a315e0223 100644 --- a/src/sound/soundbase.cpp +++ b/src/sound/soundbase.cpp @@ -33,6 +33,7 @@ char const sMidiCtlChar[] = { /* [EMidiCtlType::Solo] = */ 's', /* [EMidiCtlType::Mute] = */ 'm', /* [EMidiCtlType::MuteMyself] = */ 'o', + /* [EMidiCtlType::OurFader] = */ 'z', // Proposed addition: a new enum value for "our fader" /* [EMidiCtlType::None] = */ '\0' }; /* Implementation *************************************************************/ @@ -372,6 +373,13 @@ void CSoundBase::ParseMIDIMessage ( const CVector& vMIDIPaketBytes ) emit ControllerInFaderLevel ( cCtrl.iChannel, iFaderLevel ); } break; + case OurFader: + { + // special message about our own fader - emit a fader level whatever-it-is-called with channel id -1 + const int iFaderLevel = static_cast ( static_cast ( iValue ) / 127*AUD_MIX_FADER_MAX ); + emit ControllerInFaderLevel ( -1, iFaderLevel); + } + break; case Pan: { // Pan levels need to be symmetric between 1 and 127 diff --git a/src/sound/soundbase.h b/src/sound/soundbase.h index 4aa6c629bc..fa7090b51a 100644 --- a/src/sound/soundbase.h +++ b/src/sound/soundbase.h @@ -49,6 +49,7 @@ enum EMidiCtlType Solo, Mute, MuteMyself, + OurFader, // Proposed addition: a MidiCtrlType for our own fader level None }; From f4b7dd52cc77311b164219f99198a36bea7dd725 Mon Sep 17 00:00:00 2001 From: Peter L Jones Date: Tue, 8 Oct 2024 20:53:10 +0100 Subject: [PATCH 2/5] Use I_MY_CHANNEL for "my channel" special value --- src/audiomixerboard.cpp | 20 +++++++------------- src/sound/soundbase.cpp | 2 +- src/sound/soundbase.h | 1 + 3 files changed, 9 insertions(+), 14 deletions(-) diff --git a/src/audiomixerboard.cpp b/src/audiomixerboard.cpp index 16c96416f2..174a61d082 100644 --- a/src/audiomixerboard.cpp +++ b/src/audiomixerboard.cpp @@ -1343,22 +1343,16 @@ void CAudioMixerBoard::ApplyNewConClientList ( CVector& vecChanInf void CAudioMixerBoard::SetFaderLevel ( const int iChannelIdx, const int iValue ) { + // If iChannelIdx is I_MY_CHANNEL and our own channel ID is a valid index + // then we adjust our own fader level + const int iTheChannelIdx = ( iChannelIdx == I_MY_CHANNEL ) ? iMyChannelID : iChannelIdx; + // only apply new fader level if channel index is valid and the fader is visible - if ( ( iChannelIdx >= 0 ) && ( iChannelIdx < MAX_NUM_CHANNELS ) ) - { - if ( vecpChanFader[static_cast ( iChannelIdx )]->IsVisible() ) - { - vecpChanFader[static_cast ( iChannelIdx )]->SetFaderLevel ( iValue ); - } - } - // Proposed change: if iChannelIdx is -1 and our own channel ID is a valid index - // then we adjust our own fader level: - if((iChannelIdx == -1) && iMyChannelID != INVALID_INDEX) + if ( ( iTheChannelIdx >= 0 ) && ( iTheChannelIdx < MAX_NUM_CHANNELS ) ) { - if ( vecpChanFader[static_cast ( iMyChannelID )]->IsVisible() ) + if ( vecpChanFader[static_cast ( iTheChannelIdx )]->IsVisible() ) { - //printf("debug: set our own fader(%d) level to %d\n", iMyChannelID, iValue); - vecpChanFader[static_cast ( iMyChannelID )]->SetFaderLevel ( iValue ); + vecpChanFader[static_cast ( iTheChannelIdx )]->SetFaderLevel ( iValue ); } } } diff --git a/src/sound/soundbase.cpp b/src/sound/soundbase.cpp index 3a315e0223..b56d8b4820 100644 --- a/src/sound/soundbase.cpp +++ b/src/sound/soundbase.cpp @@ -377,7 +377,7 @@ void CSoundBase::ParseMIDIMessage ( const CVector& vMIDIPaketBytes ) { // special message about our own fader - emit a fader level whatever-it-is-called with channel id -1 const int iFaderLevel = static_cast ( static_cast ( iValue ) / 127*AUD_MIX_FADER_MAX ); - emit ControllerInFaderLevel ( -1, iFaderLevel); + emit ControllerInFaderLevel ( I_MY_CHANNEL, iFaderLevel); } break; case Pan: diff --git a/src/sound/soundbase.h b/src/sound/soundbase.h index fa7090b51a..ceacd1d429 100644 --- a/src/sound/soundbase.h +++ b/src/sound/soundbase.h @@ -32,6 +32,7 @@ #endif #include "../global.h" #include "../util.h" +#define I_MY_CHANNEL -1 // TODO better solution with enum definition // problem: in signals it seems not to work to use CSoundBase::ESndCrdResetType From f38942dd7874f981f94feb5248a091e3184a06e2 Mon Sep 17 00:00:00 2001 From: Peter L Jones Date: Wed, 2 Oct 2024 19:01:42 +0100 Subject: [PATCH 3/5] Factor out common code --- src/sound/soundbase.cpp | 11 +++-------- 1 file changed, 3 insertions(+), 8 deletions(-) diff --git a/src/sound/soundbase.cpp b/src/sound/soundbase.cpp index b56d8b4820..56fff6a86d 100644 --- a/src/sound/soundbase.cpp +++ b/src/sound/soundbase.cpp @@ -363,21 +363,16 @@ void CSoundBase::ParseMIDIMessage ( const CVector& vMIDIPaketBytes ) switch ( cCtrl.eType ) { case Fader: + case OurFader: { // we are assuming that the controller number is the same // as the audio fader index and the range is 0-127 const int iFaderLevel = static_cast ( static_cast ( iValue ) / 127 * AUD_MIX_FADER_MAX ); + const int iTheChannel = cCtrl.eType == OurFader ? I_MY_CHANNEL : cCtrl.iChannel; // consider offset for the faders - emit ControllerInFaderLevel ( cCtrl.iChannel, iFaderLevel ); - } - break; - case OurFader: - { - // special message about our own fader - emit a fader level whatever-it-is-called with channel id -1 - const int iFaderLevel = static_cast ( static_cast ( iValue ) / 127*AUD_MIX_FADER_MAX ); - emit ControllerInFaderLevel ( I_MY_CHANNEL, iFaderLevel); + emit ControllerInFaderLevel ( iTheChannel, iFaderLevel ); } break; case Pan: From 1e5ac8b873c3ba846e4231277cce35e3df25aa13 Mon Sep 17 00:00:00 2001 From: Peter L Jones Date: Fri, 4 Oct 2024 20:24:31 +0100 Subject: [PATCH 4/5] Make "My Channel" work for all controls --- src/audiomixerboard.cpp | 35 ++++--- src/audiomixerboard.h | 9 ++ src/sound/soundbase.cpp | 210 ++++++++++++++++++++++++---------------- src/sound/soundbase.h | 16 ++- 4 files changed, 170 insertions(+), 100 deletions(-) diff --git a/src/audiomixerboard.cpp b/src/audiomixerboard.cpp index 174a61d082..205e977e4c 100644 --- a/src/audiomixerboard.cpp +++ b/src/audiomixerboard.cpp @@ -1343,53 +1343,56 @@ void CAudioMixerBoard::ApplyNewConClientList ( CVector& vecChanInf void CAudioMixerBoard::SetFaderLevel ( const int iChannelIdx, const int iValue ) { - // If iChannelIdx is I_MY_CHANNEL and our own channel ID is a valid index - // then we adjust our own fader level - const int iTheChannelIdx = ( iChannelIdx == I_MY_CHANNEL ) ? iMyChannelID : iChannelIdx; + const int iRealChannelIdx = getRealChannelIdx ( iChannelIdx ); // only apply new fader level if channel index is valid and the fader is visible - if ( ( iTheChannelIdx >= 0 ) && ( iTheChannelIdx < MAX_NUM_CHANNELS ) ) + if ( ( iRealChannelIdx >= 0 ) && ( iRealChannelIdx < MAX_NUM_CHANNELS ) ) { - if ( vecpChanFader[static_cast ( iTheChannelIdx )]->IsVisible() ) + if ( vecpChanFader[static_cast ( iRealChannelIdx )]->IsVisible() ) { - vecpChanFader[static_cast ( iTheChannelIdx )]->SetFaderLevel ( iValue ); + vecpChanFader[static_cast ( iRealChannelIdx )]->SetFaderLevel ( iValue ); } } } void CAudioMixerBoard::SetPanValue ( const int iChannelIdx, const int iValue ) { + const int iRealChannelIdx = getRealChannelIdx ( iChannelIdx ); + // only apply new pan value if channel index is valid and the panner is visible - if ( ( iChannelIdx >= 0 ) && ( iChannelIdx < MAX_NUM_CHANNELS ) && bDisplayPans ) + if ( ( iRealChannelIdx >= 0 ) && ( iRealChannelIdx < MAX_NUM_CHANNELS ) && bDisplayPans ) { - if ( vecpChanFader[static_cast ( iChannelIdx )]->IsVisible() ) + if ( vecpChanFader[static_cast ( iRealChannelIdx )]->IsVisible() ) { - vecpChanFader[static_cast ( iChannelIdx )]->SetPanValue ( iValue ); + vecpChanFader[static_cast ( iRealChannelIdx )]->SetPanValue ( iValue ); } } } void CAudioMixerBoard::SetFaderIsSolo ( const int iChannelIdx, const bool bIsSolo ) { - // only apply solo if channel index is valid and the fader is visible - if ( ( iChannelIdx >= 0 ) && ( iChannelIdx < MAX_NUM_CHANNELS ) ) + const int iRealChannelIdx = getRealChannelIdx ( iChannelIdx ); + // only apply solo if channel index is valid and the fader is visible + if ( ( iRealChannelIdx >= 0 ) && ( iRealChannelIdx < MAX_NUM_CHANNELS ) ) { - if ( vecpChanFader[static_cast ( iChannelIdx )]->IsVisible() ) + if ( vecpChanFader[static_cast ( iRealChannelIdx )]->IsVisible() ) { - vecpChanFader[static_cast ( iChannelIdx )]->SetFaderIsSolo ( bIsSolo ); + vecpChanFader[static_cast ( iRealChannelIdx )]->SetFaderIsSolo ( bIsSolo ); } } } void CAudioMixerBoard::SetFaderIsMute ( const int iChannelIdx, const bool bIsMute ) { + const int iRealChannelIdx = getRealChannelIdx ( iChannelIdx ); + // only apply mute if channel index is valid and the fader is visible - if ( ( iChannelIdx >= 0 ) && ( iChannelIdx < MAX_NUM_CHANNELS ) ) + if ( ( iRealChannelIdx >= 0 ) && ( iRealChannelIdx < MAX_NUM_CHANNELS ) ) { - if ( vecpChanFader[static_cast ( iChannelIdx )]->IsVisible() ) + if ( vecpChanFader[static_cast ( iRealChannelIdx )]->IsVisible() ) { - vecpChanFader[static_cast ( iChannelIdx )]->SetFaderIsMute ( bIsMute ); + vecpChanFader[static_cast ( iRealChannelIdx )]->SetFaderIsMute ( bIsMute ); } } } diff --git a/src/audiomixerboard.h b/src/audiomixerboard.h index 6b42d35085..55731e8f9e 100644 --- a/src/audiomixerboard.h +++ b/src/audiomixerboard.h @@ -288,6 +288,15 @@ class CAudioMixerBoard : public QGroupBox, public CAudioMixerBoardSlots inline void connectFaderSignalsToMixerBoardSlots(); + // When handling MIDI controllers for adjusting Jamulus channel controls, + // each channel is assigned by the server. As a user's Jamulus channel + // will vary on each server connection, to enable the assignment of MIDI + // controllers to the user's own Jamulus channel, the constant I_MY_CHANNEL + // is passed into the methods used to handle the requests. This method then + // maps I_MY_CHANNEL to the current value of the user's Jamulus channel, + // held in iMyChannel. + inline int getRealChannelIdx ( const int iChannelIdx ) const { return iChannelIdx == I_MY_CHANNEL ? iMyChannelID : iChannelIdx; } + signals: void ChangeChanGain ( int iId, float fGain, bool bIsMyOwnFader ); void ChangeChanPan ( int iId, float fPan ); diff --git a/src/sound/soundbase.cpp b/src/sound/soundbase.cpp index 56fff6a86d..94b3c01ab3 100644 --- a/src/sound/soundbase.cpp +++ b/src/sound/soundbase.cpp @@ -24,18 +24,6 @@ #include "soundbase.h" -// This is used as a lookup table for parsing option letters, mapping -// a single character to an EMidiCtlType -char const sMidiCtlChar[] = { - // Has to follow order of EMidiCtlType - /* [EMidiCtlType::Fader] = */ 'f', - /* [EMidiCtlType::Pan] = */ 'p', - /* [EMidiCtlType::Solo] = */ 's', - /* [EMidiCtlType::Mute] = */ 'm', - /* [EMidiCtlType::MuteMyself] = */ 'o', - /* [EMidiCtlType::OurFader] = */ 'z', // Proposed addition: a new enum value for "our fader" - /* [EMidiCtlType::None] = */ '\0' }; - /* Implementation *************************************************************/ CSoundBase::CSoundBase ( const QString& strNewSystemDriverTechniqueName, void ( *fpNewProcessCallback ) ( CVector& psData, void* pParg ), @@ -233,98 +221,156 @@ QVector CSoundBase::LoadAndInitializeFirstValidDriver ( const bool bOpe } /******************************************************************************\ -* MIDI handling * +* Command Line Handling * \******************************************************************************/ void CSoundBase::ParseCommandLineArgument ( const QString& strMIDISetup ) { - int iMIDIOffsetFader = 70; // Behringer X-TOUCH: offset of 0x46 - - // parse the server info string according to definition: there is - // the legacy definition with just one or two numbers that only - // provides a definition for the controller offset of the level - // controllers (default 70 for the sake of Behringer X-Touch) - // [MIDI channel];[offset for level] - // - // The more verbose new form is a sequence of offsets for various - // controllers: at the current point, 'f', 'p', 's', and 'm' are - // parsed for fader, pan, solo, mute controllers respectively. - // However, at the current point of time only 'f' and 'p' - // controllers are actually implemented. The syntax for a Korg - // nanoKONTROL2 with 8 fader controllers starting at offset 0 and - // 8 pan controllers starting at offset 16 would be - // - // [MIDI channel];f0*8;p16*8 - // - // Namely a sequence of letters indicating the kind of controller, - // followed by the offset of the first such controller, followed - // by * and a count for number of controllers (if more than 1) - if ( !strMIDISetup.isEmpty() ) + if ( strMIDISetup.isEmpty() ) { - // split the different parameter strings - const QStringList slMIDIParams = strMIDISetup.split ( ";" ); + // should be caught in main.cpp + return; + } + + // Parse the --ctrlmidich string. There are two formats. + // Default to the legacy kind of specifying the fader controller offset + // without an indication of the count of controllers. + bool bSimple = true; - // [MIDI channel] - if ( slMIDIParams.count() >= 1 ) + // split the different parameter strings + const QStringList slMIDIParams = strMIDISetup.split ( ";" ); + int iNumParams = slMIDIParams.count(); + + if ( iNumParams >= 1 ) + { + bool bChOK = false; + int i = slMIDIParams[0].toUInt ( &bChOK ); + if ( bChOK ) { - iCtrlMIDIChannel = slMIDIParams[0].toUInt(); + // [MIDI channel] supplied (else use default) + iCtrlMIDIChannel = i; } + else + { + // iCtrlMIDIChannel == INVALID_MIDI_CH, so no point continuing + return; + } + } - bool bSimple = true; // Indicates the legacy kind of specifying - // the fader controller offset without an - // indication of the count of controllers + // Use Behringer X-TOUCH as default offset of 0x46 + int iMIDIOffsetFader = 70; + if ( iNumParams >= 2 ) + { + // if there is a second parameter that can be parsed as a number, + // we have the legacy specification of controllers. + int i = slMIDIParams[1].toUInt ( &bSimple ); + if ( bSimple ) + { + // [offset for fader] supplied (else use default) + iMIDIOffsetFader = i; + } + } - // [offset for level] - if ( slMIDIParams.count() >= 2 ) + if ( bSimple ) + { + // For the legacy specification, we consider every controller + // up to the maximum number of channels (or the maximum + // controller number) a fader. + for ( int i = 0; i + iMIDIOffsetFader <= 127 && i < MAX_NUM_CHANNELS; i++ ) { - int i = slMIDIParams[1].toUInt ( &bSimple ); - // if the second parameter can be parsed as a number, we - // have the legacy specification of controllers. - if ( bSimple ) - iMIDIOffsetFader = i; + // add a list entry for the CMidiCtlEntry + aMidiCtls[i + iMIDIOffsetFader] = { EMidiCtlType::Fader, i }; } + return; + } - if ( bSimple ) + // We have named controllers + // Validate and see whether "MyChannel" option is present + + bool bMyChannel = false; + QStringList slValid; // keep track of valid entries to make later processing simple + + for ( int i = 0; i < iNumParams; i++ ) + { + QString sParm = slMIDIParams[i].trimmed(); + + if ( sParm.isEmpty() ) + { + // skip empty entries silently + continue; + } + + int iCtrl = sMidiCtl.indexOf ( sParm[0] ); + if ( iCtrl < 0 ) + { + // skip unknown entries silently + continue; + } + + if ( static_cast ( iCtrl ) == EMidiCtlType::MyChannel ) { - // For the legacy specification, we consider every controller - // up to the maximum number of channels (or the maximum - // controller number) a fader. - for ( int i = 0; i < MAX_NUM_CHANNELS; i++ ) + // once seen, just remember this + bMyChannel = true; + continue; + } + + const QStringList slP = sParm.mid ( 1 ).split ( '*' ); + + if ( slP.count() > 2 ) + { + // skip invalid entries silently + continue; + } + + bool bIsUInt = false; + + unsigned int u = slP[0].toUInt ( &bIsUInt ); + if ( !bIsUInt ) + { + // skip invalid entries silently + continue; + } + int iFirst = u; + + // silently default incoherent count to 1 + int iNum = 1; + if ( static_cast ( iCtrl ) != EMidiCtlType::MuteMyself && slP.count() == 2 ) + { + bIsUInt = false; + unsigned int u = slP[1].toUInt ( &bIsUInt ); + if ( bIsUInt ) { - if ( i + iMIDIOffsetFader > 127 ) - break; - aMidiCtls[i + iMIDIOffsetFader] = { EMidiCtlType::Fader, i }; + iNum = u; } - return; } - // We have named controllers + // store the valid entry in a more splittable format + slValid.append ( QString ( "%1*%2*%3" ).arg ( iCtrl ).arg ( iFirst ).arg ( iNum ) ); + } - for ( int i = 1; i < slMIDIParams.count(); i++ ) + foreach ( QString sParm, slValid ) + { + const QStringList slP = sParm.split ( '*' ); + const EMidiCtlType eTyp = static_cast ( slP[0].toInt() ); + const int iFirst = slP[1].toUInt(); + const int iNum = slP[2].toUInt(); + for ( int iOff = 0; iOff < iNum && iOff + iFirst <= 127 && iOff < MAX_NUM_CHANNELS; iOff++ ) { - QString sParm = slMIDIParams[i].trimmed(); - if ( sParm.isEmpty() ) - continue; - - int iCtrl = QString ( sMidiCtlChar ).indexOf ( sParm[0] ); - if ( iCtrl < 0 ) - continue; - EMidiCtlType eTyp = static_cast ( iCtrl ); - - const QStringList slP = sParm.mid ( 1 ).split ( '*' ); - int iFirst = slP[0].toUInt(); - int iNum = ( slP.count() > 1 ) ? slP[1].toUInt() : 1; - for ( int iOff = 0; iOff < iNum; iOff++ ) + // For MyChannel option, first offset is "MyChannel", then the rest are 0 to iNum-1 channels + if ( bMyChannel ) + { + aMidiCtls[iFirst + iOff] = { eTyp, iOff == 0 ? I_MY_CHANNEL : iOff - 1 }; + } + else { - if ( iOff >= MAX_NUM_CHANNELS ) - break; - if ( iFirst + iOff >= 128 ) - break; aMidiCtls[iFirst + iOff] = { eTyp, iOff }; } } } } +/******************************************************************************\ +* MIDI handling * +\******************************************************************************/ void CSoundBase::ParseMIDIMessage ( const CVector& vMIDIPaketBytes ) { if ( vMIDIPaketBytes.Size() > 0 ) @@ -357,22 +403,22 @@ void CSoundBase::ParseMIDIMessage ( const CVector& vMIDIPaketBytes ) // make sure packet is long enough if ( vMIDIPaketBytes.Size() > 2 && vMIDIPaketBytes[1] <= uint8_t ( 127 ) && vMIDIPaketBytes[2] <= uint8_t ( 127 ) ) { + // Where "MyChannel" is in effect, cCtrl.iChannel will be I_MY_CHANNEL + // for the first CC number in the range for a cCtrl.eType and then zero upwards. const CMidiCtlEntry& cCtrl = aMidiCtls[vMIDIPaketBytes[1]]; const int iValue = vMIDIPaketBytes[2]; - ; + switch ( cCtrl.eType ) { case Fader: - case OurFader: { // we are assuming that the controller number is the same // as the audio fader index and the range is 0-127 const int iFaderLevel = static_cast ( static_cast ( iValue ) / 127 * AUD_MIX_FADER_MAX ); - const int iTheChannel = cCtrl.eType == OurFader ? I_MY_CHANNEL : cCtrl.iChannel; // consider offset for the faders - emit ControllerInFaderLevel ( iTheChannel, iFaderLevel ); + emit ControllerInFaderLevel ( cCtrl.iChannel, iFaderLevel ); } break; case Pan: diff --git a/src/sound/soundbase.h b/src/sound/soundbase.h index ceacd1d429..0c3adb3b93 100644 --- a/src/sound/soundbase.h +++ b/src/sound/soundbase.h @@ -50,7 +50,7 @@ enum EMidiCtlType Solo, Mute, MuteMyself, - OurFader, // Proposed addition: a MidiCtrlType for our own fader level + MyChannel, None }; @@ -160,7 +160,19 @@ class CSoundBase : public QThread QMutex MutexAudioProcessCallback; QMutex MutexDevProperties; - QString strSystemDriverTechniqueName; + QString strSystemDriverTechniqueName; + + // This is used as a lookup table for parsing option letters, mapping + // a single character to an EMidiCtlType. Has to follow order of EMidiCtlType. + const QString sMidiCtl = QString ( "f" // [EMidiCtlType::Fader] + "p" // [EMidiCtlType::Pan] + "s" // [EMidiCtlType::Solo] + "m" // [EMidiCtlType::Mute] + "o" // [EMidiCtlType::MuteMyself] + "z" // [EMidiCtlType::MyChannel] + "\0" // [EMidiCtlType::None] + ); + int iCtrlMIDIChannel; QVector aMidiCtls; From 847fc24200a8e9c50c287ba757db918c681b4fb2 Mon Sep 17 00:00:00 2001 From: Peter L Jones Date: Sat, 26 Oct 2024 11:32:41 +0100 Subject: [PATCH 5/5] Use INVALID_MIDI_CH for Mixer UI switch --- src/client.h | 2 ++ src/clientdlg.cpp | 3 +-- src/clientdlg.h | 1 - src/main.cpp | 1 - src/sound/soundbase.h | 2 ++ 5 files changed, 5 insertions(+), 4 deletions(-) diff --git a/src/client.h b/src/client.h index 3f9e30be6d..ca017a9147 100644 --- a/src/client.h +++ b/src/client.h @@ -272,6 +272,8 @@ class CClient : public QObject Channel.GetBufErrorRates ( vecErrRates, dLimit, dMaxUpLimit ); } + bool IsMIDIEnabled() { return Sound.IsMIDIEnabled(); } + // settings CChannelCoreInfo ChannelInfo; QString strClientName; diff --git a/src/clientdlg.cpp b/src/clientdlg.cpp index cb6b134bf7..a5d491012f 100644 --- a/src/clientdlg.cpp +++ b/src/clientdlg.cpp @@ -28,7 +28,6 @@ CClientDlg::CClientDlg ( CClient* pNCliP, CClientSettings* pNSetP, const QString& strConnOnStartupAddress, - const QString& strMIDISetup, const bool bNewShowComplRegConnList, const bool bShowAnalyzerConsole, const bool bMuteStream, @@ -219,7 +218,7 @@ CClientDlg::CClientDlg ( CClient* pNCliP, MainMixerBoard->SetNumMixerPanelRows ( pSettings->iNumMixerPanelRows ); // Pass through flag for MIDICtrlUsed - MainMixerBoard->SetMIDICtrlUsed ( !strMIDISetup.isEmpty() ); + MainMixerBoard->SetMIDICtrlUsed ( pClient->IsMIDIEnabled() ); // reset mixer board MainMixerBoard->HideAll(); diff --git a/src/clientdlg.h b/src/clientdlg.h index 2a9062a58d..f0e0d3292d 100644 --- a/src/clientdlg.h +++ b/src/clientdlg.h @@ -77,7 +77,6 @@ class CClientDlg : public CBaseDlg, private Ui_CClientDlgBase CClientDlg ( CClient* pNCliP, CClientSettings* pNSetP, const QString& strConnOnStartupAddress, - const QString& strMIDISetup, const bool bNewShowComplRegConnList, const bool bShowAnalyzerConsole, const bool bMuteStream, diff --git a/src/main.cpp b/src/main.cpp index 42d17a8dea..a306257b18 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -953,7 +953,6 @@ int main ( int argc, char** argv ) CClientDlg ClientDlg ( &Client, &Settings, strConnOnStartupAddress, - strMIDISetup, bShowComplRegConnList, bShowAnalyzerConsole, bMuteStream, diff --git a/src/sound/soundbase.h b/src/sound/soundbase.h index 0c3adb3b93..a37e2066bd 100644 --- a/src/sound/soundbase.h +++ b/src/sound/soundbase.h @@ -115,6 +115,8 @@ class CSoundBase : public QThread // in a callback function it has to be public -> better solution void EmitReinitRequestSignal ( const ESndCrdResetType eSndCrdResetType ) { emit ReinitRequest ( eSndCrdResetType ); } + bool IsMIDIEnabled() { return iCtrlMIDIChannel != INVALID_MIDI_CH; } + protected: virtual QString LoadAndInitializeDriver ( QString, bool ) { return ""; } virtual void UnloadCurrentDriver() {}