Day39 QTableWidget类的使用

1.简介

        介绍QtableWidget各种属性的用法,以及常用的一些信号,最后利用这些特性,制作一个用于下发设备运行参数的表格。该表格可以实现折叠和取消折叠,在源代码中用了事件过滤器实现,也可以用自带的click信号。显示了图标,添加了editline控件和combox控件;设置了简洁的样子,可以在自己工程中将其添加为c++类作为模块的一部分,或者添加为Qt界面师类,在主界面使用“提升为”完成界面类的实例化。

2.属性介绍

1.隐藏表头,由于表头是QheaderView类,同时在没有表头的情况下,可以用第一行和第一列作为表头,因此在相对简单的场合可以考虑隐藏。

QHeaderView *horizontalHeader = ui->tableWidget->horizontalHeader();
horizontalHeader->setVisible(false);
QHeaderView *verticalHeader = ui->tableWidget->verticalHeader();
verticalHeader->setVisible(false);

2.表格框线的样式

    ui->tableWidget->setStyleSheet("QTableWidget{ gridline-color:black;border: 1px solid black; }");
    ui->tableWidget->setFrameShape(QFrame::Box);//设置外边框
    ui->tableWidget->horizontalHeader()->setSectionResizeMode(QHeaderView::Stretch);//宽度自适应(父对象)
    ui->tableWidget->setSizeAdjustPolicy(QAbstractScrollArea::AdjustToContents);// 设置水平和垂直方向的拉伸因子

3.创建表格

 ui->tableWidget->setColumnCount(2);
 ui->tableWidget->setRowCount(15);

4.设置表格字体属性

    QFont font;
    font.setFamily("Arial");
    font.setPointSize(10);
    QPalette palette;
    palette.setColor(QPalette::Text, QColor(Qt::black));

5.设置内容,居中属性

ui->tableWidget->setItem(0, 0, new QTableWidgetItem("属性"));
ui->tableWidget->item(0,1)->setTextAlignment(Qt::AlignCenter);

6.设置背景色,选中属性

    ui->tableWidget->setItem(11, 0, new QTableWidgetItem(u8"上端位置"));
    ui->tableWidget->setItem(11, 1, new QTableWidgetItem(""));
    ui->tableWidget->item(11,1)->setFlags(Qt::ItemIsEditable|Qt::ItemIsEnabled);

7.设置combox控件

    comboMode = new QComboBox(ui->tableWidget);
    comboMode->addItem(u8"模式1");
    comboMode->addItem(u8"模式2");
    comboMode->addItem(u8"模式3");
    comboMode->setCurrentIndex(0);
    connect(comboMode, &QComboBox::currentTextChanged, [=](const QString& text){
        if(text == "模式1" || text == "模式2"){
            ui->tableWidget->item(9,1)->setText("");
            ui->tableWidget->item(9,1)->setFlags(Qt::NoItemFlags);
        }
        else{
            ui->tableWidget->item(9,1)->setFlags(Qt::ItemIsEnabled|Qt::ItemIsEditable);
        }
    });

8.设置lineedit、label的控件作为表格内容

    QWidget* wCell0 = new QWidget(ui->tableWidget);
    QHBoxLayout* subExposeLayout = new QHBoxLayout(wCell0);
    edit1 = new QLineEdit(wCell0);
    QLabel* lab1  = new QLabel(wCell0);
    edit1->setSizePolicy(QSizePolicy::Expanding,QSizePolicy::Expanding);//填充整个空间
    wCell0->setStyleSheet("QLineEdit { background:transparent ;border: none; }");
    subExposeLayout->addWidget(edit1, 2);
    subExposeLayout->addWidget(lab1, 1);
    lab1->setText("us");
    subExposeLayout->setMargin(0);
    subExposeLayout->setSpacing(0);
    ui->tableWidget->setCellWidget(7, 1, wCell0);

9.添加图标

ui->tableWidget->item(1,0)->setIcon(QIcon(":/res/pullDown.jpg"));

3.常见信号

Cell开头的信号携带的参数是行x列,Item开头的信号携带的参数是item,每一项,各信号的名字也都可顾名思义,在源代码中,使用事件过滤器实现鼠标的单击事件,没有用自带的click信号。生成的界面效果如图:

Day39 QTableWidget类的使用_第1张图片

你可能感兴趣的:(Qt积累——基础篇,qt,c++,QTableWidget)