From 83bcf2b8ae618b14944530611ef56e2ce5f78146 Mon Sep 17 00:00:00 2001 From: agilob Date: Sat, 10 Oct 2015 14:26:35 +0100 Subject: [PATCH] fix closing video device after changing tab --- src/widget/form/settings/avform.cpp | 37 +++++++++++++++-------------- 1 file changed, 19 insertions(+), 18 deletions(-) diff --git a/src/widget/form/settings/avform.cpp b/src/widget/form/settings/avform.cpp index 1f3bba48c..ebf0af41e 100644 --- a/src/widget/form/settings/avform.cpp +++ b/src/widget/form/settings/avform.cpp @@ -211,7 +211,7 @@ void AVForm::onVideoDevChanged(int index) QSize savedRes = Settings::getInstance().getCamVideoRes(); int savedResIndex = -1; bodyUI->videoModescomboBox->clear(); - bodyUI->videoModescomboBox->blockSignals(true); + bodyUI->videoModescomboBox->blockSignals(true); for (int i=0; iinDevCombobox->clear(); const ALchar *pDeviceList = alcGetString(NULL, ALC_CAPTURE_DEVICE_SPECIFIER); if (pDeviceList) { - //prevent currentIndexChanged to be fired while adding items - bodyUI->inDevCombobox->blockSignals(true); + //prevent currentIndexChanged to be fired while adding items + bodyUI->inDevCombobox->blockSignals(true); while (*pDeviceList) { int len = strlen(pDeviceList); #ifdef Q_OS_WIN QString inDev = QString::fromUtf8(pDeviceList,len); #else - QString inDev = QString::fromLocal8Bit(pDeviceList,len); + QString inDev = QString::fromLocal8Bit(pDeviceList,len); #endif bodyUI->inDevCombobox->addItem(inDev); if (settingsInDev == inDev) - inDevIndex = bodyUI->inDevCombobox->count()-1; + inDevIndex = bodyUI->inDevCombobox->count()-1; pDeviceList += len+1; } - //addItem changes currentIndex -> reset - bodyUI->inDevCombobox->setCurrentIndex(-1); - bodyUI->inDevCombobox->blockSignals(false); + //addItem changes currentIndex -> reset + bodyUI->inDevCombobox->setCurrentIndex(-1); + bodyUI->inDevCombobox->blockSignals(false); } - bodyUI->inDevCombobox->setCurrentIndex(inDevIndex); + bodyUI->inDevCombobox->setCurrentIndex(inDevIndex); } void AVForm::getAudioOutDevices() { QString settingsOutDev = Settings::getInstance().getOutDev(); - int outDevIndex = 0; + int outDevIndex = 0; bodyUI->outDevCombobox->clear(); const ALchar *pDeviceList; if (alcIsExtensionPresent(NULL, "ALC_ENUMERATE_ALL_EXT") != AL_FALSE) @@ -305,15 +305,15 @@ void AVForm::getAudioOutDevices() pDeviceList = alcGetString(NULL, ALC_DEVICE_SPECIFIER); if (pDeviceList) { - //prevent currentIndexChanged to be fired while adding items - bodyUI->outDevCombobox->blockSignals(true); + //prevent currentIndexChanged to be fired while adding items + bodyUI->outDevCombobox->blockSignals(true); while (*pDeviceList) { int len = strlen(pDeviceList); #ifdef Q_OS_WIN QString outDev = QString::fromUtf8(pDeviceList,len); #else - QString outDev = QString::fromLocal8Bit(pDeviceList,len); + QString outDev = QString::fromLocal8Bit(pDeviceList,len); #endif bodyUI->outDevCombobox->addItem(outDev); if (settingsOutDev == outDev) @@ -322,11 +322,11 @@ void AVForm::getAudioOutDevices() } pDeviceList += len+1; } - //addItem changes currentIndex -> reset - bodyUI->outDevCombobox->setCurrentIndex(-1); - bodyUI->outDevCombobox->blockSignals(false); + //addItem changes currentIndex -> reset + bodyUI->outDevCombobox->setCurrentIndex(-1); + bodyUI->outDevCombobox->blockSignals(false); } - bodyUI->outDevCombobox->setCurrentIndex(outDevIndex); + bodyUI->outDevCombobox->setCurrentIndex(outDevIndex); } void AVForm::onInDevChanged(const QString &deviceDescriptor) @@ -388,6 +388,7 @@ void AVForm::killVideoSurface() while ((child = bodyUI->gridLayout->takeAt(0)) != 0) delete child; + camVideoSurface->close(); delete camVideoSurface; camVideoSurface = nullptr; }