QT手写显示控件如QDockWidget,QTabWidget,QGroupBox组合

在 Qt 中,你可以在 QDockWidget 中添加一个 QTabWidget,然后在其中一个选项卡上添加多个 QGroupBox。每个 QGroupBox 中包含几个 QPushButton、一个 QLabel 和两个 QLineEdit,并使用 QGridLayout 布局来排列这些控件。

以下是一个完整的示例代码,展示了如何实现这个布局:

cpp 复制代码
#include <QApplication>
#include <QMainWindow>
#include <QDockWidget>
#include <QTabWidget>
#include <QWidget>
#include <QVBoxLayout>
#include <QGroupBox>
#include <QPushButton>
#include <QLabel>
#include <QLineEdit>
#include <QGridLayout>

class MainWindow : public QMainWindow {
public:
    MainWindow() {
        // Create central widget and set it as the central widget for the main window
        QWidget *centralWidget = new QWidget(this);
        setCentralWidget(centralWidget);

        // Create a QDockWidget
        QDockWidget *dockWidget = new QDockWidget("Dock Widget", this);
        addDockWidget(Qt::LeftDockWidgetArea, dockWidget);

        // Create a QTabWidget and set it to the dock widget
        QTabWidget *tabWidget = new QTabWidget(dockWidget);
        dockWidget->setWidget(tabWidget);

        // Create the first tab
        QWidget *firstTab = new QWidget(tabWidget);
        tabWidget->addTab(firstTab, "First Tab");

        // Create a vertical layout for the first tab
        QVBoxLayout *vboxLayout = new QVBoxLayout(firstTab);

        // Add four QGroupBox widgets to the vertical layout
        for (int i = 0; i < 4; ++i) {
            QGroupBox *groupBox = new QGroupBox(QString("Group Box %1").arg(i + 1), firstTab);
            vboxLayout->addWidget(groupBox);
            
            // Create a QGridLayout for the group box
            QGridLayout *gridLayout = new QGridLayout(groupBox);
            
            // Add buttons, label, and line edits to the grid layout
            for (int j = 0; j < 5; ++j) {
                QPushButton *button = new QPushButton(QString("Button %1").arg(j + 1), groupBox);
                gridLayout->addWidget(button, j, 0);  // Buttons in the first column
            }
            
            QLabel *label = new QLabel(QString("Label %1").arg(i + 1), groupBox);
            gridLayout->addWidget(label, 0, 1);  // Label in the first row, second column
            
            QLineEdit *lineEdit1 = new QLineEdit(groupBox);
            gridLayout->addWidget(lineEdit1, 1, 1);  // Line Edit 1 in the second row, second column
            
            QLineEdit *lineEdit2 = new QLineEdit(groupBox);
            gridLayout->addWidget(lineEdit2, 2, 1);  // Line Edit 2 in the third row, second column
        }

        setWindowTitle("QDockWidget with QTabWidget Example");
        resize(800, 600);
    }
};

int main(int argc, char *argv[]) {
    QApplication app(argc, argv);

    MainWindow mainWindow;
    mainWindow.show();

    return app.exec();
}

代码解释

  1. 创建主窗口MainWindow 继承自 QMainWindow,是主应用程序窗口。

  2. 设置中央小部件 :创建一个 QWidget 并将其设置为主窗口的中央小部件。

  3. 创建 QDockWidget

    • 使用 QDockWidget 创建一个停靠窗口,并将其添加到主窗口的左侧区域。
  4. 创建 QTabWidget

    • QDockWidget 中创建一个 QTabWidget 并设置为停靠窗口的内容。
  5. 创建第一个选项卡

    • 创建一个 QWidget 作为第一个选项卡,并将其添加到 QTabWidget
  6. 配置布局

    • 在选项卡上创建一个 QVBoxLayout,用于垂直排列 QGroupBox
    • 创建四个 QGroupBox,并将它们添加到垂直布局中。
    • 每个 QGroupBox 中使用 QGridLayout 进行内部布局。
  7. 添加控件到每个 QGroupBox

    • 每个 QGroupBox 内部包含五个 QPushButton、一个 QLabel 和两个 QLineEdit
    • 使用 QGridLayout 将这些控件按网格排列:按钮在第一列,标签和输入框在第二列的不同位置。
相关推荐
lizi888881 小时前
打包Python代码的常用方法实现程序exe应用
开发语言·python
api茶飘香2 小时前
守护应用边界:通过反射API实现安全的输入输出过滤
java·开发语言·python·安全·django·virtualenv·pygame
杀死一只知更鸟debug2 小时前
策略模式的小记
java·开发语言·策略模式
efls1112 小时前
Qt_了解Qt Creator
开发语言·qt
请揣满RMB2 小时前
Qt常用控件——QRadioButton和QCheckBox
开发语言·c++·qt
阿巴~阿巴~2 小时前
C_深入理解指针(五) —— sizeof和strlen的对比、数组和指针笔试题解析、指针运算笔试题解析
c语言·开发语言·数据结构·算法
爱吃桃子的ICer3 小时前
[UVM]3.核心基类 uvm_object 域的自动化 copy() compare() print() pack unpack
开发语言·前端·ic设计
ever_up9734 小时前
EasyExcel的导入与导出及在实际项目生产场景的一下应用例子
java·开发语言·数据库
吴天德少侠4 小时前
c++返回一个pair类型
开发语言·c++
ok!ko5 小时前
设计模式之工厂模式(通俗易懂--代码辅助理解【Java版】)
java·开发语言·设计模式