diff --git a/src/widget/form/settings/avform.cpp b/src/widget/form/settings/avform.cpp index 3fe283cdd..4394a1e11 100644 --- a/src/widget/form/settings/avform.cpp +++ b/src/widget/form/settings/avform.cpp @@ -28,12 +28,12 @@ #include #include "src/audio/audio.h" -#include "src/core/core.h" +#include "src/audio/iaudiosettings.h" #include "src/core/coreav.h" #include "src/core/recursivesignalblocker.h" -#include "src/persistence/settings.h" #include "src/video/cameradevice.h" #include "src/video/camerasource.h" +#include "src/video/ivideosettings.h" #include "src/video/videosurface.h" #include "src/widget/tool/screenshotgrabber.h" #include "src/widget/translator.h" @@ -42,41 +42,42 @@ #define ALC_ALL_DEVICES_SPECIFIER ALC_DEVICE_SPECIFIER #endif -AVForm::AVForm() +AVForm::AVForm(Audio* audio, CoreAV* coreAV, CameraSource& camera, + IAudioSettings* audioSettings, IVideoSettings* videoSettings) : GenericForm(QPixmap(":/img/settings/av.png")) + , audio{audio} + , coreAV{coreAV} + , audioSettings{audioSettings} + , videoSettings{videoSettings} , subscribedToAudioIn(false) , camVideoSurface(nullptr) - , camera(CameraSource::getInstance()) + , camera(camera) { setupUi(this); // block all child signals during initialization const RecursiveSignalBlocker signalBlocker(this); - const Audio& audio = Audio::getInstance(); - const Settings& s = Settings::getInstance(); - - cbEnableTestSound->setChecked(s.getEnableTestSound()); - + cbEnableTestSound->setChecked(audioSettings->getEnableTestSound()); cbEnableTestSound->setToolTip(tr("Play a test sound while changing the output volume.")); #ifndef USE_FILTERAUDIO cbEnableBackend2->setVisible(false); #endif - cbEnableBackend2->setChecked(s.getEnableBackend2()); + cbEnableBackend2->setChecked(audioSettings->getEnableBackend2()); connect(rescanButton, &QPushButton::clicked, this, &AVForm::rescanDevices); playbackSlider->setTracking(false); - playbackSlider->setValue(s.getOutVolume()); + playbackSlider->setValue(audioSettings->getOutVolume()); playbackSlider->installEventFilter(this); microphoneSlider->setToolTip(tr("Use slider to set the gain of your input device ranging" " from %1dB to %2dB.") - .arg(audio.minInputGain()) - .arg(audio.maxInputGain())); - microphoneSlider->setMinimum(qRound(audio.minInputGain()) * 10); - microphoneSlider->setMaximum(qRound(audio.maxInputGain()) * 10); + .arg(audio->minInputGain()) + .arg(audio->maxInputGain())); + microphoneSlider->setMinimum(qRound(audio->minInputGain()) * 10); + microphoneSlider->setMaximum(qRound(audio->maxInputGain()) * 10); microphoneSlider->setTickPosition(QSlider::TicksBothSides); microphoneSlider->setTickInterval( (qAbs(microphoneSlider->minimum()) + microphoneSlider->maximum()) / 4); @@ -104,7 +105,7 @@ void AVForm::hideEvent(QHideEvent* event) { if (subscribedToAudioIn) { // TODO: This should not be done in show/hide events - Audio::getInstance().unsubscribeInput(); + audio->unsubscribeInput(); subscribedToAudioIn = false; } @@ -126,7 +127,7 @@ void AVForm::showEvent(QShowEvent* event) if (!subscribedToAudioIn) { // TODO: This should not be done in show/hide events - Audio::getInstance().subscribeInput(); + audio->subscribeInput(); subscribedToAudioIn = true; } @@ -136,8 +137,8 @@ void AVForm::showEvent(QShowEvent* event) void AVForm::open(const QString& devName, const VideoMode& mode) { QRect rect = mode.toRect(); - Settings::getInstance().setCamVideoRes(rect); - Settings::getInstance().setCamVideoFPS(static_cast(mode.FPS)); + videoSettings->setCamVideoRes(rect); + videoSettings->setCamVideoFPS(static_cast(mode.FPS)); camera.setupDevice(devName, mode); } @@ -150,7 +151,7 @@ void AVForm::rescanDevices() void AVForm::on_cbEnableBackend2_stateChanged() { - Settings::getInstance().setEnableBackend2(cbEnableBackend2->isChecked()); + audioSettings->setEnableBackend2(cbEnableBackend2->isChecked()); } void AVForm::on_videoModescomboBox_currentIndexChanged(int index) @@ -163,8 +164,8 @@ void AVForm::on_videoModescomboBox_currentIndexChanged(int index) VideoMode mode = videoModes[index]; if (CameraDevice::isScreen(devName) && mode == VideoMode()) { - if (Settings::getInstance().getScreenGrabbed()) { - VideoMode mode(Settings::getInstance().getScreenRegion()); + if (videoSettings->getScreenGrabbed()) { + VideoMode mode(videoSettings->getScreenRegion()); open(devName, mode); return; } @@ -182,8 +183,8 @@ void AVForm::on_videoModescomboBox_currentIndexChanged(int index) mode.x += screen.x(); mode.y += screen.y(); - Settings::getInstance().setScreenRegion(mode.toRect()); - Settings::getInstance().setScreenGrabbed(true); + videoSettings->setScreenRegion(mode.toRect()); + videoSettings->setScreenGrabbed(true); open(devName, mode); }; @@ -194,7 +195,7 @@ void AVForm::on_videoModescomboBox_currentIndexChanged(int index) return; } - Settings::getInstance().setScreenGrabbed(false); + videoSettings->setScreenGrabbed(false); open(devName, mode); } @@ -299,8 +300,8 @@ void AVForm::fillCameraModesComboBox() int AVForm::searchPreferredIndex() { - QRect prefRes = Settings::getInstance().getCamVideoRes(); - quint16 prefFPS = Settings::getInstance().getCamVideoFPS(); + QRect prefRes = videoSettings->getCamVideoRes(); + quint16 prefFPS = videoSettings->getCamVideoFPS(); for (int i = 0; i < videoModes.size(); ++i) { VideoMode mode = videoModes[i]; @@ -344,7 +345,7 @@ void AVForm::fillAudioQualityComboBox() audioQualityComboBox->addItem(tr("Low (16 kbps)"), 16); audioQualityComboBox->addItem(tr("Very low (8 kbps)"), 8); - const int currentBitrate = Settings::getInstance().getAudioBitrate(); + const int currentBitrate = audioSettings->getAudioBitrate(); const int index = audioQualityComboBox->findData(currentBitrate); audioQualityComboBox->setCurrentIndex(index); @@ -375,7 +376,7 @@ void AVForm::updateVideoModes(int curIndex) int preferedIndex = searchPreferredIndex(); if (preferedIndex != -1) { - Settings::getInstance().setScreenGrabbed(false); + videoSettings->setScreenGrabbed(false); videoModescomboBox->blockSignals(true); videoModescomboBox->setCurrentIndex(preferedIndex); videoModescomboBox->blockSignals(false); @@ -384,10 +385,10 @@ void AVForm::updateVideoModes(int curIndex) } if (isScreen) { - QRect rect = Settings::getInstance().getScreenRegion(); + QRect rect = videoSettings->getScreenRegion(); VideoMode mode(rect); - Settings::getInstance().setScreenGrabbed(true); + videoSettings->setScreenGrabbed(true); videoModescomboBox->setCurrentIndex(videoModes.size() - 1); open(devName, mode); return; @@ -406,14 +407,14 @@ void AVForm::on_videoDevCombobox_currentIndexChanged(int index) { assert(0 <= index && index < videoDeviceList.size()); - Settings::getInstance().setScreenGrabbed(false); + videoSettings->setScreenGrabbed(false); QString dev = videoDeviceList[index].first; - Settings::getInstance().setVideoDev(dev); + videoSettings->setVideoDev(dev); bool previouslyBlocked = videoModescomboBox->blockSignals(true); updateVideoModes(index); videoModescomboBox->blockSignals(previouslyBlocked); - if (Settings::getInstance().getScreenGrabbed()) + if (videoSettings->getScreenGrabbed()) return; int modeIndex = videoModescomboBox->currentIndex(); @@ -422,18 +423,19 @@ void AVForm::on_videoDevCombobox_currentIndexChanged(int index) mode = videoModes[modeIndex]; camera.setupDevice(dev, mode); - if (dev == "none") - Core::getInstance()->getAv()->sendNoVideo(); + if (dev == "none") { + coreAV->sendNoVideo(); + } } void AVForm::on_audioQualityComboBox_currentIndexChanged(int index) { - Settings::getInstance().setAudioBitrate(audioQualityComboBox->currentData().toInt()); + audioSettings->setAudioBitrate(audioQualityComboBox->currentData().toInt()); } void AVForm::getVideoDevices() { - QString settingsInDev = Settings::getInstance().getVideoDev(); + QString settingsInDev = videoSettings->getVideoDev(); int videoDevIndex = 0; videoDeviceList = CameraDevice::getDeviceList(); // prevent currentIndexChanged to be fired while adding items @@ -457,7 +459,7 @@ int AVForm::getModeSize(VideoMode mode) void AVForm::getAudioInDevices() { QStringList deviceNames; - deviceNames << tr("Disabled") << Audio::getInstance().inDeviceNames(); + deviceNames << tr("Disabled") << audio->inDeviceNames(); inDevCombobox->blockSignals(true); inDevCombobox->clear(); @@ -465,9 +467,9 @@ void AVForm::getAudioInDevices() inDevCombobox->blockSignals(false); int idx = 0; - bool enabled = Settings::getInstance().getAudioInDevEnabled(); + bool enabled = audioSettings->getAudioInDevEnabled(); if (enabled && deviceNames.size() > 1) { - QString dev = Settings::getInstance().getInDev(); + QString dev = audioSettings->getInDev(); idx = qMax(deviceNames.indexOf(dev), 1); } inDevCombobox->setCurrentIndex(idx); @@ -476,7 +478,7 @@ void AVForm::getAudioInDevices() void AVForm::getAudioOutDevices() { QStringList deviceNames; - deviceNames << tr("Disabled") << Audio::getInstance().outDeviceNames(); + deviceNames << tr("Disabled") << audio->outDeviceNames(); outDevCombobox->blockSignals(true); outDevCombobox->clear(); @@ -484,9 +486,9 @@ void AVForm::getAudioOutDevices() outDevCombobox->blockSignals(false); int idx = 0; - bool enabled = Settings::getInstance().getAudioOutDevEnabled(); + bool enabled = audioSettings->getAudioOutDevEnabled(); if (enabled && deviceNames.size() > 1) { - QString dev = Settings::getInstance().getOutDev(); + QString dev = audioSettings->getOutDev(); idx = qMax(deviceNames.indexOf(dev), 1); } outDevCombobox->setCurrentIndex(idx); @@ -494,65 +496,61 @@ void AVForm::getAudioOutDevices() void AVForm::on_inDevCombobox_currentIndexChanged(int deviceIndex) { - Settings::getInstance().setAudioInDevEnabled(deviceIndex != 0); + audioSettings->setAudioInDevEnabled(deviceIndex != 0); QString deviceName; if (deviceIndex > 0) deviceName = inDevCombobox->itemText(deviceIndex); - Settings::getInstance().setInDev(deviceName); + audioSettings->setInDev(deviceName); - Audio& audio = Audio::getInstance(); - audio.reinitInput(deviceName); + audio->reinitInput(deviceName); microphoneSlider->setEnabled(deviceIndex > 0); - microphoneSlider->setSliderPosition(qRound(audio.inputGain() * 10.0)); + microphoneSlider->setSliderPosition(qRound(audio->inputGain() * 10.0)); } void AVForm::on_outDevCombobox_currentIndexChanged(int deviceIndex) { - Settings::getInstance().setAudioOutDevEnabled(deviceIndex != 0); + audioSettings->setAudioOutDevEnabled(deviceIndex != 0); QString deviceName; if (deviceIndex > 0) deviceName = outDevCombobox->itemText(deviceIndex); - Settings::getInstance().setOutDev(deviceName); + audioSettings->setOutDev(deviceName); - Audio& audio = Audio::getInstance(); - audio.reinitOutput(deviceName); + audio->reinitOutput(deviceName); playbackSlider->setEnabled(deviceIndex > 0); - playbackSlider->setSliderPosition(qRound(audio.outputVolume() * 100.0)); + playbackSlider->setSliderPosition(qRound(audio->outputVolume() * 100.0)); } void AVForm::on_playbackSlider_valueChanged(int value) { - Settings::getInstance().setOutVolume(value); + audioSettings->setOutVolume(value); - Audio& audio = Audio::getInstance(); - if (audio.isOutputReady()) { + if (audio->isOutputReady()) { const qreal percentage = value / 100.0; - audio.setOutputVolume(percentage); + audio->setOutputVolume(percentage); if (cbEnableTestSound->isChecked()) - audio.playMono16Sound(Audio::getSound(Audio::Sound::Test)); + audio->playMono16Sound(Audio::getSound(Audio::Sound::Test)); } } void AVForm::on_cbEnableTestSound_stateChanged() { - Settings::getInstance().setEnableTestSound(cbEnableTestSound->isChecked()); + audioSettings->setEnableTestSound(cbEnableTestSound->isChecked()); - Audio& audio = Audio::getInstance(); - if (cbEnableTestSound->isChecked() && audio.isOutputReady()) - audio.playMono16Sound(Audio::getSound(Audio::Sound::Test)); + if (cbEnableTestSound->isChecked() && audio->isOutputReady()) + audio->playMono16Sound(Audio::getSound(Audio::Sound::Test)); } void AVForm::on_microphoneSlider_valueChanged(int value) { const qreal dB = value / 10.0; - Settings::getInstance().setAudioInGainDecibel(dB); - Audio::getInstance().setInputGain(dB); + audioSettings->setAudioInGainDecibel(dB); + audio->setInputGain(dB); } void AVForm::createVideoSurface() diff --git a/src/widget/form/settings/avform.h b/src/widget/form/settings/avform.h index ec5b70c67..f757224a9 100644 --- a/src/widget/form/settings/avform.h +++ b/src/widget/form/settings/avform.h @@ -28,16 +28,20 @@ #include "ui_avform.h" #include "src/video/videomode.h" - +class Audio; class CameraSource; +class CoreAV; +class IAudioSettings; +class IVideoSettings; class VideoSurface; class AVForm : public GenericForm, private Ui::AVForm { Q_OBJECT public: - AVForm(); - ~AVForm(); + AVForm(Audio* audio, CoreAV* coreAV, CameraSource& camera, + IAudioSettings* audioSettings, IVideoSettings* videoSettings); + ~AVForm() override; QString getFormName() final override { return tr("Audio/Video"); @@ -86,6 +90,11 @@ private: void open(const QString& devName, const VideoMode& mode); private: + Audio* audio; + CoreAV* coreAV; + IAudioSettings* audioSettings; + IVideoSettings* videoSettings; + bool subscribedToAudioIn; VideoSurface* camVideoSurface; CameraSource& camera; diff --git a/src/widget/form/settingswidget.cpp b/src/widget/form/settingswidget.cpp index 99487cbe4..1d507facc 100644 --- a/src/widget/form/settingswidget.cpp +++ b/src/widget/form/settingswidget.cpp @@ -19,6 +19,10 @@ #include "settingswidget.h" +#include "src/audio/audio.h" +#include "src/core/coreav.h" +#include "src/core/core.h" +#include "src/persistence/settings.h" #include "src/video/camerasource.h" #include "src/widget/contentlayout.h" #include "src/widget/form/settings/aboutform.h" @@ -39,6 +43,12 @@ SettingsWidget::SettingsWidget(QWidget* parent) : QWidget(parent, Qt::Window) { + Audio* audio = &Audio::getInstance(); + CoreAV* coreAV = Core::getInstance()->getAv(); + IAudioSettings* audioSettings = &Settings::getInstance(); + IVideoSettings* videoSettings = &Settings::getInstance(); + CameraSource& camera = CameraSource::getInstance(); + setAttribute(Qt::WA_DeleteOnClose); QVBoxLayout* bodyLayout = new QVBoxLayout(); @@ -50,7 +60,8 @@ SettingsWidget::SettingsWidget(QWidget* parent) std::unique_ptr gfrm(new GeneralForm(this)); std::unique_ptr uifrm(new UserInterfaceForm(this)); std::unique_ptr pfrm(new PrivacyForm()); - std::unique_ptr avfrm(new AVForm()); + AVForm* rawAvfrm = new AVForm(audio, coreAV, camera, audioSettings, videoSettings); + std::unique_ptr avfrm(rawAvfrm); std::unique_ptr expfrm(new AdvancedForm()); std::unique_ptr abtfrm(new AboutForm());