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++)
{
}
}
版权归原作者 Adunn 所有, 如有侵权,请联系我们删除。