From ac21104cd002d21adbfaa17a080d6aea6d1aff6d Mon Sep 17 00:00:00 2001 From: Volker Fischer Date: Tue, 7 Apr 2020 00:20:32 +0200 Subject: [PATCH] only show level meters if the server actually supports it and sends network packets with levels to the client --- src/audiomixerboard.cpp | 28 +++++++++++++++++++++++----- src/audiomixerboard.h | 1 + 2 files changed, 24 insertions(+), 5 deletions(-) diff --git a/src/audiomixerboard.cpp b/src/audiomixerboard.cpp index 98c708ef..20b98e58 100755 --- a/src/audiomixerboard.cpp +++ b/src/audiomixerboard.cpp @@ -190,7 +190,12 @@ void CChannelFader::SetGUIDesign ( const EGUIDesign eNewDesign ) void CChannelFader::SetDisplayChannelLevel ( const bool eNDCL ) { - plbrChannelLevel->setHidden( !eNDCL ); + plbrChannelLevel->setHidden ( !eNDCL ); +} + +bool CChannelFader::GetDisplayChannelLevel() +{ + return !plbrChannelLevel->isHidden(); } void CChannelFader::SetupFaderTag ( const ESkillLevel eSkillLevel ) @@ -678,10 +683,15 @@ void CAudioMixerBoard::SetDisplayChannelLevels ( const bool eNDCL ) { bDisplayChannelLevels = eNDCL; - // apply preference to child GUI controls - for ( int i = 0; i < MAX_NUM_CHANNELS; i++ ) + // only update hiding the levels immediately, showing the levels + // is only applied if the server actually transmits levels + if ( !bDisplayChannelLevels ) { - vecpChanFader[i]->SetDisplayChannelLevel ( bDisplayChannelLevels ); + // hide all level meters + for ( int i = 0; i < MAX_NUM_CHANNELS; i++ ) + { + vecpChanFader[i]->SetDisplayChannelLevel ( false ); + } } } @@ -693,6 +703,7 @@ void CAudioMixerBoard::HideAll() // before hiding the fader, store its level (if some conditions are fullfilled) StoreFaderSettings ( vecpChanFader[i] ); + vecpChanFader[i]->SetDisplayChannelLevel ( false ); vecpChanFader[i]->Hide(); } @@ -915,13 +926,20 @@ bool CAudioMixerBoard::GetStoredFaderSettings ( const CChannelInfo& ChanInfo, void CAudioMixerBoard::SetChannelLevels ( const CVector& vecChannelLevel ) { const int iNumChannelLevels = vecChannelLevel.Size(); - int i = 0; + int i = 0; for ( int iChId = 0; iChId < MAX_NUM_CHANNELS; iChId++ ) { if ( vecpChanFader[iChId]->IsVisible() && i < iNumChannelLevels ) { vecpChanFader[iChId]->SetChannelLevel ( vecChannelLevel[i++] ); + + // show level only if we successfully received levels from the + // server (if server does not support levels, do not show levels) + if ( bDisplayChannelLevels && !vecpChanFader[iChId]->GetDisplayChannelLevel() ) + { + vecpChanFader[iChId]->SetDisplayChannelLevel ( true ); + } } } } diff --git a/src/audiomixerboard.h b/src/audiomixerboard.h index 6ce15c94..f5e790e7 100755 --- a/src/audiomixerboard.h +++ b/src/audiomixerboard.h @@ -57,6 +57,7 @@ public: bool IsMute() { return pcbMute->isChecked(); } void SetGUIDesign ( const EGUIDesign eNewDesign ); void SetDisplayChannelLevel ( const bool eNDCL ); + bool GetDisplayChannelLevel(); void UpdateSoloState ( const bool bNewOtherSoloState ); void SetFaderLevel ( const int iLevel );