QT(3)-QTableView
创始人
2024-03-24 12:13:37
0

QTableView

  • 1 说明
  • 2 常用函数
    • 2.1 clearSpans
    • 2.2 setSpan
    • 2.3 columnAt
    • 2.4 rowAt
    • 2.5 columnSpan
    • 2.6 rowSpan
    • 2.7 columnViewportPosition
    • 2.8 rowViewportPosition
    • 2.9 列宽、行高
      • 2.9.1 columnWidth
      • 2.9.2 rowHeight
      • 2.9.3 setColumnWidth
      • 2.9.4 setRowHeight
      • 2.9.5 resizeColumnToContents(int column)
      • 2.9.6 resizeColumnsToContents()
      • 2.9.7 resizeRowToContents(int row)
      • 2.9.8 resizeRowsToContents()
    • 2.10 网格线
      • 2.10.1 gridStyle()
      • 2.10.2 setGridStyle
      • 2.10.3 showGrid()
      • 2.10.4 setShowGrid
    • 2.11 标题栏
      • 2.11.1 horizontalHeader
      • 2.11.2 setHorizontalHeader
      • 2.11.3 verticalHeader()
      • 2.11.4 setVerticalHeader
    • 2.12 表格的显示和隐藏
      • 2.12.1 isColumnHidden
      • 2.12.2 setColumnHidden
      • 2.12.3 hideColumn
      • 2.12.4 showColumn
      • 2.12.5 isRowHidden
      • 2.12.6 setRowHidden
      • 2.12.7 hideRow
      • 2.12.8 showRow
      • 2.12.9 hide
      • 2.12.10 show
    • 2.13 setCornerButtonEnabled
    • 2.14 setSortingEnabled

1 说明

QTableView是Qt中用于显示表格数据的小部件。它与QTableWidget类似,但是它使用模型/视图架构来存储和显示数据,而QTableWidget则直接将数据存储在小部件内部。

使用QTableView的优点在于,可以使用不同的数据模型来显示表格数据,而不仅仅是Qt提供的QStandardItemModel。这使能够以更灵活的方式处理和显示数据,例如可以将表格数据与数据库相关联。

2 常用函数

2.1 clearSpans

void QTableView::clearSpans()
它用于一次性清除表格中所有跨度。表格跨度是指一个单元格占据多个行和/或列的情况。也可以理解为我们在Excel中的取消合并单元格。如果想要移除表格中的某个特定跨度,也可以使用setSpan()函数并将行跨度和列跨度设置为1。

2.2 setSpan

void QTableView::setSpan(int row, int column, int rowSpanCount, int columnSpanCount)
将位于(row,column)的元素的范围扩展唯rowSpanCount行和 columnSpanCount列。例如:
ui->tableView->setSpan(3, 0, 2, 2);我们将第3行第0列的单元格设置为跨越2行2列。这意味着该单元格将占据第3行的第0和1列和第4行的第0,1列。
在这里插入图片描述

2.3 columnAt

int QTableView::columnAt(int x) const
它用于获取表格中给定坐标x处的列索引。如果给定的坐标不在表格中,则返回-1。

// Create a QTableView object
QTableView *table = new QTableView();// Set the row and column spans for some cells
table->setSpan(0, 0, 2, 1);
table->setSpan(0, 1, 1, 2);// Get the column index at x coordinate 100
int col = table->columnAt(100);// Print the column index
qDebug() << "Column index at x=100: " << col;

columnAt()帮助确定表格中某个特定坐标处的单元格。它可以用于处理用户的鼠标点击事件,或者执行其他与单元格位置有关的操作。

2.4 rowAt

int QTableView::rowAt(int y) const
同上

2.5 columnSpan

int QTableView::columnSpan(int row, int column) const
它返回表格中指定行和列的单元格所跨越的列数。如果指定的单元格不跨越任何列,则函数返回1。就是这个元素的列占了几列

// Create a QTableView object
QTableView *table = new QTableView();// Set the row and column spans for some cells
table->setSpan(0, 0, 2, 1);
table->setSpan(0, 1, 1, 2);
qDebug()<columnSpan(0,1);//2

因为它允许快速查找表格中指定单元格跨越的列数。例如,可以使用它来计算表格的宽度,或者确定表格中某个单元格是否跨越多列。

2.6 rowSpan

int QTableView::rowSpan(int row, int column) const
同上

2.7 columnViewportPosition

int QTableView::columnViewportPosition(int column) const
返回指定列所处的x坐标(该列左上角的坐标)

2.8 rowViewportPosition

int QTableView::rowViewportPosition(int row) const
返回指定行所处的y坐标(该列左上角的坐标)

2.9 列宽、行高

2.9.1 columnWidth

int QTableView::columnWidth(int column) const
返回指定列的宽度

2.9.2 rowHeight

int QTableView::rowHeight(int row) const
返回指定行的高度

2.9.3 setColumnWidth

void QTableView::setColumnWidth(int column, int width)
将指定列的宽度设置为指定宽度

2.9.4 setRowHeight

void QTableView::setRowHeight(int row, int height)
将指定行的高度设置为指定高度

2.9.5 resizeColumnToContents(int column)

void QTableView::resizeColumnToContents(int column) slot[]
函数可以调整指定列的大小,以便适应其中的内容。
该函数接受一个 int 类型的参数,表示需要调整大小的列。调用该函数后,指定列的宽度会自动调整为适应其中的内容。

这是一个公有的槽函数,可以设计一个边输入内容边调整列宽

2.9.6 resizeColumnsToContents()

void QTableView::resizeColumnsToContents() slot[]
函数可以调整所有列的大小,以便适应其中的内容。

2.9.7 resizeRowToContents(int row)

void QTableView::resizeRowToContents(int row) slot[]
函数可以调整指定行的高度,以便适应其中的内容。

2.9.8 resizeRowsToContents()

void QTableView::resizeRowsToContents()
函数可以调整所有行的高度,以便适应其中的内容。

2.10 网格线

2.10.1 gridStyle()

Qt::PenStyle gridStyle() const
Qt::PenStyle 是一种枚举类型,用于表示画笔样式。Qt::PenStyle 类型定义了一些常用的画笔样式,如实线、虚线、点线等。
在这里插入图片描述
在这里插入图片描述

QTableView 类提供了 gridStyle() 函数,用于获取表格的网格线样式。该函数返回一个 Qt::PenStyle 类型的值,表示表格的网格线样式。

2.10.2 setGridStyle

void setGridStyle(Qt::PenStyle style)
设置网格网格线的样式

//获取样式
Qt::PenStyle style = ui->tableView->gridStyle();
qDebug()<tableView->setGridStyle(Qt::DashLine);

2.10.3 showGrid()

bool showGrid() const
如果当前网格线是显示的则返回true,否则返回false

2.10.4 setShowGrid

void setShowGrid(bool show) slot[]
设置是否显示网格线,是公有的槽函数,可以关联一些QChexkBox

2.11 标题栏

2.11.1 horizontalHeader

QHeaderView *QTableView::horizontalHeader() const
QTableView::horizontalHeader() 函数返回表格的水平标题栏。

该函数返回一个指向 QHeaderView 类型对象的指针,表示表格的水平标题栏。可以使用这个指针来操作表格的水平标题栏,如设置调整标题栏高度等。

2.11.2 setHorizontalHeader

void QTableView::setHorizontalHeader(QHeaderView *header)
设置水平标题栏

2.11.3 verticalHeader()

QHeaderView *QTableView::verticalHeader() const
同上

2.11.4 setVerticalHeader

void QTableView::setVerticalHeader(QHeaderView *header)
同上

2.12 表格的显示和隐藏

2.12.1 isColumnHidden

bool QTableView::isColumnHidden(int column) const
该函数接受一个 int 类型的参数,表示要检查的列。如果指定的列被隐藏,该函数会返回 true;否则返回 false。

2.12.2 setColumnHidden

void QTableView::setColumnHidden(int column, bool hide)
QTableView::setColumnHidden() 函数用于设置表格的指定列是否被隐藏。

该函数接受两个参数,分别表示要隐藏的列和是否隐藏。如果将 hide 参数设置为 true,则指定的列会被隐藏;如果将 hide 参数设置为 false,则指定的列会显示出来。

2.12.3 hideColumn

void QTableView::hideColumn(int column) slot[]
公有槽函数,隐藏指定的列

2.12.4 showColumn

void QTableView::showColumn(int column) slot[]
公有槽函数,显示指定的列

下面是一个简单的示例,展示了如何使用 QTableView::setColumnHidden() 函数:

2.12.5 isRowHidden

bool QTableView::isRowHidden(int row) const
同上

2.12.6 setRowHidden

void QTableView::setRowHidden(int row, bool hide)
是否隐藏指定的行

2.12.7 hideRow

void QTableView::hideRow(int row) slot[]
同上

2.12.8 showRow

void QTableView::showRow(int row) slot[]
同上

2.12.9 hide

void QWidget::hide()
隐藏整个表格和setVisible(false)效果一样

2.12.10 show

显示整个表格

2.13 setCornerButtonEnabled

QTableView::setCornerButtonEnabled(bool enable)
QTableView::setCornerButtonEnabled() 函数用于设置表格的角落按钮是否可用。

表格的角落按钮通常位于表格的左上角,用于选择整个表格或所有列/行。如果将参数 enable 设置为 true,则表格的角落按钮会变为可用状态,用户可以通过点击该按钮来选择整个表格。如果将参数 enable 设置为 false,则表格的角落按钮会被禁用,用户无法通过点击该按钮来选择整个表格。

bool isCornerButtonEnabled() const
判断左上角按钮是否被禁用

2.14 setSortingEnabled

void QTableView::setSortingEnabled(bool enable)
QTableView 类提供了 setSortingEnabled() 函数,用于设置表格是否支持排序。

如果将参数 enable 设置为 true,则表格会支持排序,即用户可以点击表格的标题栏进行排序;如果将参数 enable 设置为 false,则表格不支持排序,用户无法对表格进行排序。

相关内容

热门资讯

AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...
AWR报告解读 WORKLOAD REPOSITORY PDB report (PDB snapshots) AW...