rbutil: Remove use of deprecated QSignalMapper.

With Qt5 we can now use lambdas instead.

Change-Id: I00fe9c355d72ef9987c61c7a36a810d6eca311bc
This commit is contained in:
Dominik Riebeling 2022-03-19 22:00:16 +01:00
parent fcffe5fb81
commit e21f80f397
2 changed files with 91 additions and 175 deletions

View file

@ -35,11 +35,10 @@
#include "Logger.h"
EncTtsCfgGui::EncTtsCfgGui(QDialog* parent, EncTtsSettingInterface* iface, QString name)
: QDialog(parent)
: QDialog(parent),
m_settingInterface(iface),
m_busyCnt(0)
{
m_settingInterface = iface;
m_busyCnt=0;
// create a busy Dialog
m_busyDlg= new QProgressDialog("", "", 0, 0,this);
m_busyDlg->setWindowTitle(tr("Waiting for engine..."));
@ -47,8 +46,8 @@ EncTtsCfgGui::EncTtsCfgGui(QDialog* parent, EncTtsSettingInterface* iface, QStri
m_busyDlg->setLabel(nullptr);
m_busyDlg->setCancelButton(nullptr);
m_busyDlg->hide();
connect(iface,&EncTtsSettingInterface::busy,this,&EncTtsCfgGui::showBusy);
connect(iface,&EncTtsSettingInterface::busyEnd,this,&EncTtsCfgGui::hideBusy);
connect(iface, &EncTtsSettingInterface::busy, this, &EncTtsCfgGui::showBusy);
connect(iface, &EncTtsSettingInterface::busyEnd, this, &EncTtsCfgGui::hideBusy);
//setup the window
setWindowTitle(name);
@ -88,17 +87,14 @@ void EncTtsCfgGui::setUpWindow()
groupBox->setLayout(gridLayout);
mainLayout->addWidget(groupBox);
// connect browse btn
connect(&m_browseBtnMap,SIGNAL(mapped(QObject*)),this,SLOT(browse(QObject*)));
// ok - cancel buttons
QPushButton* okBtn = new QPushButton(tr("Ok"),this);
okBtn->setDefault(true);
okBtn->setIcon(QIcon(":icons/go-next.svg"));
QPushButton* cancelBtn = new QPushButton(tr("Cancel"),this);
cancelBtn->setIcon(QIcon(":icons/process-stop.svg"));
connect(okBtn,SIGNAL(clicked()),this,SLOT(accept()));
connect(cancelBtn,SIGNAL(clicked()),this,SLOT(reject()));
connect(okBtn, &QPushButton::clicked, this, &EncTtsCfgGui::accept);
connect(cancelBtn, &QPushButton::clicked, this, &EncTtsCfgGui::reject);
QHBoxLayout *btnbox = new QHBoxLayout;
btnbox->addWidget(okBtn);
@ -124,8 +120,21 @@ QWidget* EncTtsCfgGui::createWidgets(EncTtsSetting* setting)
spinBox->setMaximum(setting->max().toDouble());
spinBox->setSingleStep(0.01);
spinBox->setValue(setting->current().toDouble());
connect(spinBox,SIGNAL(valueChanged(double)),this,SLOT(updateSetting()));
value = spinBox;
connect(spinBox, static_cast<void (QDoubleSpinBox::*)(double)>(&QDoubleSpinBox::valueChanged),
this, [=](double value) {
this->m_settingsWidgetsMap.key(spinBox)->setCurrent(value, false);
});
connect(setting, &EncTtsSetting::updateGui, this,
[spinBox, setting]() {
spinBox->setMinimum(setting->min().toDouble());
spinBox->setMaximum(setting->max().toDouble());
spinBox->blockSignals(true);
spinBox->setValue(setting->current().toDouble());
spinBox->blockSignals(false);
});
break;
}
case EncTtsSetting::eINT:
@ -135,8 +144,19 @@ QWidget* EncTtsCfgGui::createWidgets(EncTtsSetting* setting)
spinBox->setMinimum(setting->min().toInt());
spinBox->setMaximum(setting->max().toInt());
spinBox->setValue(setting->current().toInt());
connect(spinBox,SIGNAL(valueChanged(int)),this,SLOT(updateSetting()));
value = spinBox;
connect(spinBox, static_cast<void (QSpinBox::*)(int)>(&QSpinBox::valueChanged),
this, [=](int value) {
this->m_settingsWidgetsMap.key(spinBox)->setCurrent(value, false);
});
connect(setting, &EncTtsSetting::updateGui, this,
[spinBox, setting]() {
spinBox->setMinimum(setting->min().toInt());
spinBox->setMaximum(setting->max().toInt());
spinBox->blockSignals(true);
spinBox->setValue(setting->current().toInt());
spinBox->blockSignals(false);
});
break;
}
case EncTtsSetting::eSTRING:
@ -144,13 +164,31 @@ QWidget* EncTtsCfgGui::createWidgets(EncTtsSetting* setting)
QLineEdit *lineEdit = new QLineEdit(this);
lineEdit->setAccessibleName(setting->name());
lineEdit->setText(setting->current().toString());
connect(lineEdit,&QLineEdit::textChanged,this,&EncTtsCfgGui::updateSetting);
value = lineEdit;
connect(lineEdit, &QLineEdit::textChanged,
this, [=](QString value) {
this->m_settingsWidgetsMap.key(lineEdit)->setCurrent(value, false);
});
connect(setting, &EncTtsSetting::updateGui, this,
[lineEdit, setting]() {
lineEdit->blockSignals(true);
lineEdit->setText(setting->current().toString());
lineEdit->blockSignals(false);
});
break;
}
case EncTtsSetting::eREADONLYSTRING:
{
value = new QLabel(setting->current().toString(),this);
QLabel *label = new QLabel(setting->current().toString(), this);
label->setWordWrap(true);
value = label;
connect(setting, &EncTtsSetting::updateGui, this,
[label, setting]() {
label->blockSignals(true);
label->setText(setting->current().toString());
label->blockSignals(false);
});
break;
}
case EncTtsSetting::eSTRINGLIST:
@ -160,17 +198,40 @@ QWidget* EncTtsCfgGui::createWidgets(EncTtsSetting* setting)
comboBox->addItems(setting->list());
int index = comboBox->findText(setting->current().toString());
comboBox->setCurrentIndex(index);
connect(comboBox,SIGNAL(currentIndexChanged(QString)),this,SLOT(updateSetting()));
connect(comboBox, static_cast<void (QComboBox::*)(int)>(&QComboBox::currentIndexChanged),
this, [=](int) {
this->m_settingsWidgetsMap.key(comboBox)->setCurrent(comboBox->currentText(), false);
});
value = comboBox;
connect(setting, &EncTtsSetting::updateGui, this,
[comboBox, setting]() {
comboBox->blockSignals(true);
comboBox->clear();
comboBox->addItems(setting->list());
comboBox->setCurrentIndex(comboBox->findText(setting->current().toString()));
comboBox->blockSignals(false);
});
break;
}
case EncTtsSetting::eBOOL:
{
QCheckBox *checkbox = new QCheckBox(this);
checkbox->setAccessibleName(setting->name());
checkbox->setCheckState(setting->current().toBool() == true ? Qt::Checked : Qt::Unchecked);
connect(checkbox,&QCheckBox::stateChanged,this,&EncTtsCfgGui::updateSetting);
checkbox->setCheckState(setting->current().toBool() == true
? Qt::Checked : Qt::Unchecked);
connect(checkbox, &QCheckBox::stateChanged,
this, [=](int value) {
this->m_settingsWidgetsMap.key(checkbox)->setCurrent(value, false);
});
value = checkbox;
connect(setting, &EncTtsSetting::updateGui, this,
[checkbox, setting]() {
checkbox->blockSignals(true);
checkbox->setCheckState(setting->current().toBool() == true
? Qt::Checked : Qt::Unchecked);
checkbox->blockSignals(false);
});
break;
}
default:
@ -183,8 +244,7 @@ QWidget* EncTtsCfgGui::createWidgets(EncTtsSetting* setting)
// remember widget
if(value != nullptr)
{
m_settingsWidgetsMap.insert(setting,value);
connect(setting,&EncTtsSetting::updateGui,this,&EncTtsCfgGui::updateWidget);
m_settingsWidgetsMap.insert(setting, value);
}
return value;
@ -196,148 +256,28 @@ QWidget* EncTtsCfgGui::createButton(EncTtsSetting* setting)
{
QPushButton* browsebtn = new QPushButton(tr("Browse"),this);
browsebtn->setIcon(QIcon(":/icons/system-search.svg"));
m_browseBtnMap.setMapping(browsebtn,setting);
connect(browsebtn,SIGNAL(clicked()),&m_browseBtnMap,SLOT(map()));
connect(browsebtn, &QPushButton::clicked, this,
[this, setting]()
{
QString exe = QFileDialog::getOpenFileName(this, tr("Select executable"),
setting->current().toString(), "*");
if(QFileInfo(exe).isExecutable())
setting->setCurrent(exe);
});
return browsebtn;
}
else if(setting->button() == EncTtsSetting::eREFRESHBTN)
{
QPushButton* refreshbtn = new QPushButton(tr("Refresh"),this);
refreshbtn->setIcon(QIcon(":/icons/view-refresh.svg"));
connect(refreshbtn,&QAbstractButton::clicked,setting,&EncTtsSetting::refresh);
connect(refreshbtn, &QAbstractButton::clicked, setting, &EncTtsSetting::refresh);
return refreshbtn;
}
else
return nullptr;
}
void EncTtsCfgGui::updateSetting()
{
//cast and get the sender widget
QWidget* widget = qobject_cast<QWidget*>(QObject::sender());
if(widget == nullptr) return;
// get the corresponding setting
EncTtsSetting* setting = m_settingsWidgetsMap.key(widget);
// update widget based on setting type
switch(setting->type())
{
case EncTtsSetting::eDOUBLE:
{
setting->setCurrent(((QDoubleSpinBox*)widget)->value(),false);
break;
}
case EncTtsSetting::eINT:
{
setting->setCurrent(((QSpinBox*)widget)->value(),false);
break;
}
case EncTtsSetting::eSTRING:
{
setting->setCurrent(((QLineEdit*)widget)->text(),false);
break;
}
case EncTtsSetting::eREADONLYSTRING:
{
setting->setCurrent(((QLabel*)widget)->text(),false);
break;
}
case EncTtsSetting::eSTRINGLIST:
{
setting->setCurrent(((QComboBox*)widget)->currentText(),false);
break;
}
case EncTtsSetting::eBOOL:
{
setting->setCurrent(((QCheckBox*)widget)->isChecked(),false);
break;
}
default:
{
LOG_WARNING() << "unknown setting type!";
break;
}
}
}
void EncTtsCfgGui::updateWidget()
{
// get sender setting
EncTtsSetting* setting = qobject_cast<EncTtsSetting*>(QObject::sender());
if(setting == nullptr) return;
// get corresponding widget
QWidget* widget = m_settingsWidgetsMap.value(setting);
// update Widget based on setting type
switch(setting->type())
{
case EncTtsSetting::eDOUBLE:
{
QDoubleSpinBox* spinbox = (QDoubleSpinBox*) widget;
spinbox->setMinimum(setting->min().toDouble());
spinbox->setMaximum(setting->max().toDouble());
spinbox->blockSignals(true);
spinbox->setValue(setting->current().toDouble());
spinbox->blockSignals(false);
break;
}
case EncTtsSetting::eINT:
{
QSpinBox* spinbox = (QSpinBox*) widget;
spinbox->setMinimum(setting->min().toInt());
spinbox->setMaximum(setting->max().toInt());
spinbox->blockSignals(true);
spinbox->setValue(setting->current().toInt());
spinbox->blockSignals(false);
break;
}
case EncTtsSetting::eSTRING:
{
QLineEdit* lineedit = (QLineEdit*) widget;
lineedit->blockSignals(true);
lineedit->setText(setting->current().toString());
lineedit->blockSignals(false);
break;
}
case EncTtsSetting::eREADONLYSTRING:
{
QLabel* label = (QLabel*) widget;
label->blockSignals(true);
label->setText(setting->current().toString());
label->blockSignals(false);
break;
}
case EncTtsSetting::eSTRINGLIST:
{
QComboBox* combobox = (QComboBox*) widget;
combobox->blockSignals(true);
combobox->clear();
combobox->addItems(setting->list());
int index = combobox->findText(setting->current().toString());
combobox->setCurrentIndex(index);
combobox->blockSignals(false);
break;
}
case EncTtsSetting::eBOOL:
{
QCheckBox* checkbox = (QCheckBox*) widget;
checkbox->blockSignals(true);
checkbox->setCheckState(setting->current().toBool() == true ? Qt::Checked : Qt::Unchecked);
checkbox->blockSignals(false);
break;
}
default:
{
LOG_WARNING() << "unknown EncTTsSetting";
break;
}
}
}
void EncTtsCfgGui::showBusy()
{
@ -365,20 +305,4 @@ void EncTtsCfgGui::reject(void)
this->done(0);
}
//! takes a QObject because of QsignalMapper
void EncTtsCfgGui::browse(QObject* settingObj)
{
// cast top setting
EncTtsSetting* setting= qobject_cast<EncTtsSetting*>(settingObj);
if(setting == nullptr) return;
//current path
QString curPath = setting->current().toString();
// show file dialog
QString exe = QFileDialog::getOpenFileName(this, tr("Select executable"), curPath, "*");
if(!QFileInfo(exe).isExecutable())
return;
// set new value, gui will update automatically
setting->setCurrent(exe);
}

View file

@ -40,16 +40,10 @@ private slots:
void accept(void);
//! close window and dont save configuration
void reject(void);
//! updates the corresponding setting from the sending Widget
void updateSetting();
//! updates corresponding Widget from the sending Setting.
void updateWidget();
//! shows a busy dialog. counts calls.
void showBusy();
//! hides the busy dialog, counts calls
void hideBusy();
//! used via the SignalMapper for all Browse buttons
void browse(QObject*);
private:
//! creates all dynamic window content
@ -67,9 +61,7 @@ private:
//! List of settings from the TTS or Encoder
QList<EncTtsSetting*> m_settingsList;
//! Maps settings and the correspondig Widget
QMap<EncTtsSetting*,QWidget*> m_settingsWidgetsMap;
//! Maps all browse buttons to the corresponding Setting
QSignalMapper m_browseBtnMap;
QMap<EncTtsSetting*, QWidget*> m_settingsWidgetsMap;
//! counter how often busyShow() is called,
int m_busyCnt;
};