QTreeWidget

当然,我们可以为你的代码添加详细的注释,以便更好地理解每一部分的作用。下面是带有详细注释的代码:

cpp 复制代码
#include "mainwindow.h"
#include "ui_mainwindow.h"
#include <QVBoxLayout> // 包含 QVBoxLayout 类,用于布局管理

// MainWindow 构造函数
MainWindow::MainWindow(QWidget *parent) :
    QMainWindow(parent), // 初始化基类 QMainWindow
    ui(new Ui::MainWindow) // 初始化 UI 设计器生成的类
{
    ui->setupUi(this); // 设置 UI

#if 0
    // 使用 QStringList 的 append 方法设置表头标签
    QStringList labels;
    labels.append("姓名");
    labels.append("年龄");
    labels.append("职业");

    // 设置表头标签
    ui->treeWidget->setHeaderLabels(labels);

    // 创建一个新的 QTreeWidgetItem,并设置其文本
    QTreeWidgetItem *item = new QTreeWidgetItem(ui->treeWidget);
    item->setText(0, "zheng"); // 设置姓名列
    item->setText(1, "24");    // 设置年龄列
    item->setText(2, "musicplayer"); // 设置职业列

    // 将创建的项添加到 QTreeWidget 中
    ui->treeWidget->addTopLevelItem(item);

#else
    // 直接使用 QStringList 的构造函数设置表头标签
    ui->treeWidget->setHeaderLabels(QStringList() << "姓名" << "年龄" << "职业");

    // 创建一个新的 QTreeWidgetItem,并设置其文本
    ui->treeWidget->addTopLevelItem(new QTreeWidgetItem(QStringList()
                                                        << "zheng" // 姓名列
                                                        << "24"    // 年龄列
                                                        << "musicplayer")); // 职业列

#endif

    // 创建一个 QVBoxLayout 布局管理器
    QVBoxLayout *layout = new QVBoxLayout;

    // 将 QTreeWidget 添加到布局中
    layout->addWidget(ui->treeWidget);

    // 设置布局对齐方式为居中
    layout->setAlignment(Qt::AlignCenter);

    // 创建一个新的中心部件,并设置布局
    QWidget *centralWidget = new QWidget(this);
    centralWidget->setLayout(layout);

    // 设置中心部件
    setCentralWidget(centralWidget);
}

// MainWindow 析构函数
MainWindow::~MainWindow()
{
    delete ui; // 释放 UI 设计器生成的类的内存
}

代码说明

  1. 构造函数

    • 初始化基类 QMainWindow 和 UI 设计器生成的类 Ui::MainWindow
    • 调用 ui->setupUi(this) 来设置 UI。
  2. 表头标签设置

    • 使用 QStringListappend 方法或构造函数来设置表头标签。
    • 调用 ui->treeWidget->setHeaderLabels 设置 QTreeWidget 的表头。
  3. 添加顶层项

    • 创建一个新的 QTreeWidgetItem,并设置其文本。
    • 使用 addTopLevelItem 方法将新创建的项添加到 QTreeWidget 中。
  4. 布局管理

    • 创建一个 QVBoxLayout 布局管理器。
    • QTreeWidget 添加到布局中。
    • 设置布局对齐方式为居中。
    • 创建一个新的中心部件,并设置布局。
    • 设置中心部件为 MainWindow 的中心部件。
  5. 析构函数

    • 释放 UI 设计器生成的类的内存。

居中显示文本

如果你想让 QTreeWidget 中的文本居中显示,可以在添加项之后设置每一列的文本对齐方式:

cpp 复制代码
#if 0
// ...
#else
// ...

// 创建一个新的 QTreeWidgetItem,并设置其文本
QTreeWidgetItem *item = new QTreeWidgetItem(QStringList()
                                           << "zheng"
                                           << "24"
                                           << "musicplayer");

// 设置每一列的文本对齐方式为居中
for (int i = 0; i < item->columnCount(); ++i) {
    item->setTextAlignment(i, Qt::AlignCenter);
}

// 将创建的项添加到 QTreeWidget 中
ui->treeWidget->addTopLevelItem(item);

#endif

通过这种方式,你可以确保 QTreeWidget 中的所有文本都居中显示。

相关推荐
m0_555762905 天前
不在 qtdesigner中提升,进行主题程序设计
qt·命令模式
秋风&萧瑟10 天前
【QT】练习1
开发语言·qt·命令模式
LoveXming14 天前
Qt 多线程的两种实现方式
开发语言·qt·命令模式
懒大王爱吃狼15 天前
heapq库的使用——python代码
开发语言·数据库·python·mysql·命令模式
Antonio91518 天前
【设计模式】命令模式
设计模式·命令模式
Antonio91518 天前
【Q&A】Qt中有哪些命令模式的运用?
开发语言·qt·命令模式
wenbin_java18 天前
设计模式之命令模式:原理、实现与应用
设计模式·命令模式
laimaxgg21 天前
Qt窗口控件之颜色对话框QColorDialog
开发语言·前端·c++·qt·命令模式·qt6.3
"_rainbow_"23 天前
Qt按钮控件常用的API
qt·命令模式
懒大王爱吃狼25 天前
Python + Qt Designer构建多界面GUI应用程序:Python如何调用多个界面文件
开发语言·数据库·python·qt·mysql·python基础·命令模式