0


QTableWidget 使用示例详细说明

QTableWidget 使用示例详细说明

本文从以下几个方面对 QTableWidget 进行详细介绍。

  • QTableWidget.setColumnWidth() 设置每列宽度 QTableWidget.setRowHeight()
  • 设置每行高度 QTableWidget.setShowGrid(true) 显示表格线
  • QTableWidget.setEditTriggers()设置表格内容不可编辑
  • QTableWidget.horizontalHeader()->setFont() 设置表格内表头字体(如:加粗等)
  • QTableWidget.setFont() 设置整个表格字体(如:加粗等)
  • QTableWidget.horizontalHeader()->setStyleSheet()设置表头背景色
  • QTableWidget.horizontalHeader()->setSectionResizeMode() 设置表格列宽均等分
  • QTableWidget.item(row,col)->setBackgroundColor (Qt::green) 设置单元格背景颜色
  • QTableWidget.item(row,col)->setTextColor (Qt::green) 设置单元格文本颜色
  • QTableWidget.setItem(int row, int column, QTableWidgetItem *item) 设置表格某单元块内容 -方案1
  • QTableWidget.setCellWidget(int row, int column, QWidget *item) 设置表格某单元块 - 方案2
  • QTableWidgetItem.setTextAlignment(Qt::AlignCenter) 表格单元格内字体对齐方式
  • QTableWidgetItem.item(row_index, 2)->text().toStdString()获取单元格内容
  • rowCount() 和 .columnCount(); 遍历 QTableWidgetItem

1. QTableWidget.setColumnWidth() 设置每列宽度

QTableWidget提供了setColumnWidth()和setRowHeight()两个方法来设置某列(或某行)大小。

ui.tbwgtTopicList->setColumnWidth(indexOfGridColumn, ui.tbwgtTopicList->size().width() * 0.13);

2. QTableWidget.setRowHeight() 设置每行高度

ui.tbwgtTopicList->setRowHeight(indexOfGridRow, ui.tbwgtTopicList->size().height() * 0.2); //设置每行的高度

3. QTableWidget.setShowGrid(true) 显示表格线

ui.tbwgtTopicList->setShowGrid(true);   //(QTableWidget提供了此方法)`

设置为:false

设置为:true

4. QTableWidget.setEditTriggers()设置表格内容不可编辑

QTableWidget.setEditTriggers(QAbstractItemView::NoEditTriggers);

设置表格内容不可编辑(QTableWidget提供了此方法)

5. QTableWidget.horizontalHeader()->setFont() 设置表格内表头字体(如:加粗等)

    QFont font = ui.tbwgtTopicList->horizontalHeader()->font();
    font.setBold(true);
    ui.tbwgtTopicList->horizontalHeader()->setFont(font);

6. QTableWidget.setFont() 设置整个表格字体(如:加粗等)

    QFont font = ui.tbwgtTopicList->horizontalHeader()->font();
    font.setBold(true);
    ui.tbwgtTopicList->setFont(font)

7. QTableWidget.horizontalHeader()->setStyleSheet()设置表头背景色

ui.tbwgtTopicList->horizontalHeader()->setStyleSheet("QHeaderView::section{background:skyblue;}");

8. QTableWidget.horizontalHeader()->setSectionResizeMode() 设置表格列宽均等分

ui.tbwgtTopicList->horizontalHeader()->setSectionResizeMode(QHeaderView::Stretch);//使列完全填充并平分

9. QTableWidget.item(row,col)->setBackgroundColor (Qt::green) 设置单元格背景颜色

ui->setting_tableWidget->item(row,col)->setBackgroundColor (Qt::green);

10. QTableWidget.item(row,col)->setTextColor (Qt::green) 设置单元格文本颜色

ui->setting_tableWidget->item(row,col)->setTextColor (Qt::green);

11. QTableWidget.setItem(int row, int column, QTableWidgetItem *item) 设置表格某单元块内容方案1

QTableWidgetItem *item5_check = new QTableWidgetItem();
item5_check->setCheckState (Qt::Checked); //Qt::Unchecked
ui.tbwgtTopicList->setItem(indexOfGridRow, indexOfGridColumn, item5_check);

QTableWidgetItem *item1 = new QTableWidgetItem(QString::fromStdString(iter->topic_name));
item1->setTextAlignment(Qt::AlignLeft | Qt::AlignVCenter);
 ui.tbwgtTopicList->setItem(indexOfGridRow, indexOfGridColumn, item1); //

可以自己添加QWidget中的内容,比如文本复选框、按钮。

12. QTableWidget.setCellWidget(int row, int column, QWidget *item) 设置表格某单元块方案2

QChecbox *check = new QChecbox();
check->setCheckState (Qt::Checked); //Qt::Unchecked
ui.tbwgtTopicList->setItem(indexOfGridRow, indexOfGridColumn, check);

QTableWidgetItem *item3 = new QTableWidgetItem(QString("%1HZ").arg(0, 0, 10));
item3->setTextAlignment(Qt::AlignHCenter | Qt::AlignVCenter);
ui.tbwgtTopicList->setItem(indexOfGridRow, indexOfGridColumn, item3); //

可以自己添加QWidget中的内容,比如文本复选框、按钮。

13. QTableWidgetItem.setTextAlignment(Qt::AlignCenter) 表格单元格内字体对齐方式

QTableWidgetItem* item = new QTableWidgetItem(str);
  item->setTextAlignment(Qt::AlignCenter);

14. QTableWidgetItem.item(row_index, 2)->text().toStdString()获取单元格内容

std::srting topic_name_en = ui.tbwgtTopicList->item(row_index, 2)->text().toStdString();

15. .rowCount() 和 .columnCount(); 遍历 QTableWidgetItem

 int row_count = ui.tbwgtTopicList->rowCount();
 int column_count = ui.tbwgtTopicList->columnCount();

  std::string topic_type_en = "";
  std::string topic_name_en = "";

  for(int row_index = 0; row_index < row_count; row_index++)
  {
  
        for(int column_index = 0; column_index <  column_count; column_index++)
        {
        
        }
  
  }
标签: qt ui QTableWidget

本文转载自: https://blog.csdn.net/limeigui/article/details/126246221
版权归原作者 Adunn 所有, 如有侵权,请联系我们删除。

“QTableWidget 使用示例详细说明”的评论:

还没有评论