fixed back->front channel bar desync
This commit is contained in:
parent
1797b39b30
commit
b15e5d6df7
4 changed files with 22 additions and 12 deletions
|
|
@ -80,10 +80,10 @@ std::wstring Endpoint::getName(){
|
||||||
|
|
||||||
float Endpoint::getVolume(int channel){
|
float Endpoint::getVolume(int channel){
|
||||||
float volume;
|
float volume;
|
||||||
if (channel == ENDPOINT_MASTER_VOLUME) {
|
if (channel == AudioChannel::CHANNEL_MAIN) {
|
||||||
if(FAILED(endpointVolume->GetMasterVolumeLevelScalar(&volume))) { log_debugcpp("si");}
|
if(FAILED(endpointVolume->GetMasterVolumeLevelScalar(&volume))) { /* log_debugcpp("si") */;}
|
||||||
} else {
|
} else {
|
||||||
if(FAILED(endpointVolume->GetChannelVolumeLevelScalar(channel, &volume))) { log_debugcpp("si");}
|
if(FAILED(endpointVolume->GetChannelVolumeLevelScalar(channel, &volume))) { /* log_debugcpp("si"); */}
|
||||||
}
|
}
|
||||||
return volume;
|
return volume;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -7,7 +7,7 @@
|
||||||
|
|
||||||
#include "debug.h"
|
#include "debug.h"
|
||||||
|
|
||||||
#define ENDPOINT_MASTER_VOLUME -1
|
//#define ENDPOINT_MASTER_VOLUME -1
|
||||||
/* #define ENDPOINT_LEFT_CHANNEL_VOLUME 0 */
|
/* #define ENDPOINT_LEFT_CHANNEL_VOLUME 0 */
|
||||||
/* #define ENDPOINT_RIGHT_CHANNEL_VOLUME 1 */
|
/* #define ENDPOINT_RIGHT_CHANNEL_VOLUME 1 */
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -39,9 +39,9 @@ EndpointWidget::EndpointWidget(uint64_t idx, EndpointHandler* eph, QWidget *pare
|
||||||
osh->callbackInfo[idx]->muted = eph->getMute();
|
osh->callbackInfo[idx]->muted = eph->getMute();
|
||||||
muteButton->setCheckState((eph->getMute() == false ? Qt::Unchecked : Qt::Checked));
|
muteButton->setCheckState((eph->getMute() == false ? Qt::Unchecked : Qt::Checked));
|
||||||
muteButton->setText(eph->getMute() ? STRING_UNMUTE : STRING_MUTE);
|
muteButton->setText(eph->getMute() ? STRING_UNMUTE : STRING_MUTE);
|
||||||
float volume = eph->getVolume(ENDPOINT_MASTER_VOLUME) * 100;
|
float volume = eph->getVolume(AudioChannel::CHANNEL_MAIN) * 100;
|
||||||
//TODO: APARTE
|
//TODO: APARTE
|
||||||
osh->callbackInfo[idx]->mainVolume = eph->getVolume(ENDPOINT_MASTER_VOLUME);
|
osh->callbackInfo[idx]->mainVolume = eph->getVolume(AudioChannel::CHANNEL_MAIN);
|
||||||
mainSlider->setValue((int)volume);
|
mainSlider->setValue((int)volume);
|
||||||
log_debugcpp("ENDPOINT SET WITH VOLUME " << volume);
|
log_debugcpp("ENDPOINT SET WITH VOLUME " << volume);
|
||||||
|
|
||||||
|
|
@ -75,21 +75,30 @@ EndpointWidget::EndpointWidget(uint64_t idx, EndpointHandler* eph, QWidget *pare
|
||||||
this->channelLabels.push_back(tmpLb);
|
this->channelLabels.push_back(tmpLb);
|
||||||
layout->addWidget(tmp, 1, i);
|
layout->addWidget(tmp, 1, i);
|
||||||
layout->addWidget(tmpLb, 2, i);
|
layout->addWidget(tmpLb, 2, i);
|
||||||
//TODO: check if there's a need to prevent deadlocks; probably this will eventually turn into its own func
|
//TODO: check if there's a need to prevent deadlocks; probably this will eventually turn into its own func
|
||||||
connect(tmp, &QSlider::valueChanged, [this, i](int newValue){ this->eph->setVolume(osh->getGuid(), i, newValue); this->channelLabels.at(i)->setText(QString::number(newValue)); });
|
//this causes channel bar desync when back -> front. blocksignals below fix it. huh.
|
||||||
|
connect(tmp, &QSlider::valueChanged, [this, i](int newValue){ this->eph->setVolume(osh->getGuid(), i, newValue); this->channelLabels.at(i)->setText(QString::number(newValue)); });
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
QTimer *timer = new QTimer(this);
|
timer = new QTimer(this);
|
||||||
connect(timer, &QTimer::timeout, [this, idx](){
|
connect(timer, &QTimer::timeout, [this, idx](){
|
||||||
if (memcmp(osh->callbackInfo[idx]->caller, osh->getGuid(), sizeof(NGuid)) == 0) return;
|
if (memcmp(osh->callbackInfo[idx]->caller, osh->getGuid(), sizeof(NGuid)) == 0) return;
|
||||||
|
mainSlider->blockSignals(true);
|
||||||
|
muteButton->blockSignals(true);
|
||||||
mainSlider->setValue((int)(osh->callbackInfo[idx]->mainVolume * 100));
|
mainSlider->setValue((int)(osh->callbackInfo[idx]->mainVolume * 100));
|
||||||
muteButton->setCheckState((osh->callbackInfo[idx]->muted == false ? Qt::Unchecked : Qt::Checked));
|
muteButton->setCheckState((osh->callbackInfo[idx]->muted == false ? Qt::Unchecked : Qt::Checked));
|
||||||
muteButton->setText(osh->callbackInfo[idx]->muted ? STRING_UNMUTE : STRING_MUTE);
|
muteButton->setText(osh->callbackInfo[idx]->muted ? STRING_UNMUTE : STRING_MUTE);
|
||||||
for(uint32_t i = 0; i < osh->callbackInfo[idx]->channels; i++){
|
for(uint32_t i = 0; i < osh->callbackInfo[idx]->channels; i++){
|
||||||
this->channelSliders.at(i)->setValue((int)(osh->callbackInfo[idx]->channelVolumes[i] * 100));
|
this->channelSliders.at(i)->blockSignals(true);
|
||||||
this->channelLabels.at(i)->setText(QString::number((int)(osh->callbackInfo[idx]->channelVolumes[i] * 100)));
|
this->channelSliders.at(i)->setValue((int)(osh->callbackInfo[idx]->channelVolumes[i] * 100));
|
||||||
|
this->channelLabels.at(i)->setText(QString::number((int)(osh->callbackInfo[idx]->channelVolumes[i] * 100)));
|
||||||
|
this->channelSliders.at(i)->blockSignals(false);
|
||||||
}
|
}
|
||||||
|
//memcpy(osh->callbackInfo[idx]->caller, osh->getGuid(), sizeof(NGuid));
|
||||||
|
*osh->callbackInfo[idx]->caller = *osh->getGuid();
|
||||||
|
mainSlider->blockSignals(false);
|
||||||
|
muteButton->blockSignals(false);
|
||||||
});
|
});
|
||||||
timer->start(10);
|
timer->start(10);
|
||||||
|
|
||||||
|
|
@ -117,7 +126,7 @@ void EndpointWidget::updateMute(int checked){
|
||||||
}
|
}
|
||||||
|
|
||||||
void EndpointWidget::updateMainVolume(int newValue){
|
void EndpointWidget::updateMainVolume(int newValue){
|
||||||
this->eph->setVolume(osh->getGuid(), ENDPOINT_MASTER_VOLUME, newValue);
|
this->eph->setVolume(osh->getGuid(), AudioChannel::CHANNEL_MAIN, newValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
void EndpointWidget::updateVolume(uint32_t channel, float newValue){
|
void EndpointWidget::updateVolume(uint32_t channel, float newValue){
|
||||||
|
|
|
||||||
|
|
@ -81,6 +81,7 @@ public slots:
|
||||||
void updateMute(int checked);
|
void updateMute(int checked);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
QTimer* timer = nullptr;
|
||||||
uint64_t idx;
|
uint64_t idx;
|
||||||
//std::vector<EndpointHandler*> *ephs;
|
//std::vector<EndpointHandler*> *ephs;
|
||||||
//std::vector<QSlider> *sliders;
|
//std::vector<QSlider> *sliders;
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue