我正在建立一个不同级别QWidget
的QRadioButton
s。换句话说,我的小部件包含一些单选按钮和一个子小部件(groupBox
在屏幕截图中标记),其中还包含单选按钮。
这是我的问题:里面的单选按钮groupBox
似乎干扰了顶级单选按钮(radioButton_1
和radioButton_2
)。我希望在任何给定时间都选中和中的一个,但现在可以通过单击当前选中的单选按钮来取消选中这些。radioButton_1
radioButton_2
我想出的解决方法是为 and 添加到setChecked(true)
信号处理程序中,但这似乎有点 hacky。radioButton_1.clicked()
radioButton_2.clicked()
connect(ui->radioButton_1, &RadioButton::clicked, [this]() {
ui->radioButton_1.setChecked(true);
});
connect(ui->radioButton_2, &RadioButton::clicked, [this]() {
ui->radioButton_2.setChecked(true);
});
有没有更好的方法来恢复功能?也许像setRadioButtonGroup({ui->radioButton_1, ui->radioButton_2})
.
编辑:
根据对 MCVE 的请求,以下是表格mainwindow.ui
。其他文件 ( mainwindow.cpp
, main.cpp
, mainwindow.h
) 只是在 Qt Creator 中创建 QWidget 应用程序时提供的样板文件。
<?xml version="1.0" encoding="UTF-8"?>
<ui version="4.0">
<class>MainWindow</class>
<widget class="QMainWindow" name="MainWindow">
<property name="geometry">
<rect>
<x>0</x>
<y>0</y>
<width>400</width>
<height>300</height>
</rect>
</property>
<property name="windowTitle">
<string>MainWindow</string>
</property>
<widget class="QWidget" name="centralWidget">
<layout class="QVBoxLayout" name="verticalLayout">
<item>
<widget class="QRadioButton" name="radioButton_1">
<property name="text">
<string>radioButton_1</string>
</property>
</widget>
</item>
<item>
<widget class="QRadioButton" name="radioButton_2">
<property name="text">
<string>radioButton_2</string>
</property>
</widget>
</item>
<item>
<widget class="QGroupBox" name="groupBox">
<property name="title">
<string>groupBox</string>
</property>
<layout class="QVBoxLayout" name="verticalLayout_2">
<item>
<widget class="QRadioButton" name="radioButton_3">
<property name="text">
<string>radioButton_3</string>
</property>
</widget>
</item>
<item>
<widget class="QRadioButton" name="radioButton_4">
<property name="text">
<string>radioButton_4</string>
</property>
</widget>
</item>
</layout>
</widget>
</item>
</layout>
</widget>
<widget class="QStatusBar" name="statusBar"/>
</widget>
<layoutdefault spacing="6" margin="11"/>
<resources/>
<connections/>
</ui>