QT之QListView的简介

QT之QListView的简介

成员函数

显示列表或网格中的数据。以下是一些常用成员函数的介绍:
1)QListView(QWidget *parent = nullptr)

构造函数,创建一个 QListView 对象。

2)void setModel(QAbstractItemModel *model):

设置要显示的数据模型。

3)QAbstractItemModel *model() const

返回当前设置的数据模型。

4)void setRootIndex(const QModelIndex &index)

设置根索引。

5)QModelIndex rootIndex() const

返回根索引。

6)void setSelectionModel(QItemSelectionModel *selectionModel)

设置选择模型。

7)QItemSelectionModel *selectionModel() const

返回当前设置的选择模型。

8)void setItemDelegate(QAbstractItemDelegate *delegate):

设置项目代理。

9)QAbstractItemDelegate *itemDelegate() const

返回当前设置的项目代理。

10)void setEditTriggers(EditTriggers triggers)

设置编辑触发器。

11)EditTriggers editTriggers() const

返回编辑触发器。

12)void setSelectionMode(SelectionMode mode)

设置选择模式。

13)SelectionMode selectionMode() const

返回选择模式。

14)void setViewMode(ViewMode mode)

设置视图模式。

15)ViewMode viewMode() const

返回视图模式。

16)void setMovement(Movement movement)

设置滚动方式。

17)Movement movement() const

返回滚动方式

18)void setSortingEnabled(bool enable)

设置是否启用排序。

19)bool isSortingEnabled() const

返回是否启用排序。

20)void setAllColumnsShowFocus(bool enable)

设置是否显示焦点。

21)bool allColumnsShowFocus() const

返回是否显示焦点。

22)void setWordWrap(bool enable)

设置是否启用文字换行。

23)bool wordWrap() const

返回是否启用文字换行。

24)void setCornerButtonEnabled(bool enable)

设置是否启用角落按钮。

25)bool isCornerButtonEnabled() const

返回是否启用角落按钮。

26)void setUniformItemSizes(bool enable)

设置是否启用统一项目大小。

27)bool uniformItemSizes() const

返回是否启用统一项目大小。

28)void setGridSize(const QSize &size)

设置网格大小。

29)QSize gridSize() const

返回网格大小。

30)void setSpacing(int space)

设置间距。

31)int spacing() const

返回间距。

32)void setBatchSize(int size)

设置批量大小,用于优化大数据量的显示。

33)int batchSize() const

返回批量大小。

34)void clear()

清除所有数据和视图设置。

35)void reset()

恢复默认设置。

36)void sortByColumn(int column, Qt::SortOrder order = Qt::AscendingOrder)

根据指定列排序。

37)void ensureVisible(const QModelIndex &index, int role = Qt::NoRole)

确保指定索引在视图中可见。

38)QModelIndex indexAt(const QPoint &pos) const

返回指定位置的模型索引。

39)QRect visualRect(const QModelIndex &index) const

返回指定索引的视觉矩形。

40)void scrollTo(const QModelIndex &index, ScrollHint hint = EnsureVisible)

滚动到指定索引位置。

41)QModelIndex moveCursor(CursorAction cursorAction, Qt::KeyboardModifiers modifiers)

移动光标。

42)QModelIndex currentIndex() const

返回当前光标位置的模型索引。

43)void setCurrentIndex(const QModelIndex &index, QItemSelectionModel::SelectionFlags command = QItemSelectionModel::NoUpdate)

设置当前光标位置。

44)bool isIndexHidden(const QModelIndex &index) const

返回指定索引是否被隐藏。

45)void hideColumn(int column)

隐藏指定列。

46)void showColumn(int column)

显示指定列。

47)bool isColumnHidden(int column) const

返回指定列是否被隐藏。

48)void setColumnWidth(int column, int width)

设置指定列的宽度。

49)int columnWidth(int column) const

返回指定列的宽度。

50)void resizeColumnToContents(int column)

根据内容调整指定列的宽度。

使用例程

QListView的数据刷新需要用到QAbstractListModel、QStandardItemModel等

以下是一个使用QStandardItemModel刷新QListView数据的示例代码:

cpp 复制代码
#include <QApplication>  
#include <QListView>  
#include <QStandardItemModel>  
  
int main(int argc, char **argv)  
{  
    QApplication app(argc, argv);  
  
    // 创建模型  
    QStandardItemModel model;  
  
    // 添加数据到模型中  
    QStandardItem *item1 = new QStandardItem("Item 1");  
    QStandardItem *item2 = new QStandardItem("Item 2");  
    QStandardItem *item3 = new QStandardItem("Item 3");  
  
    model.appendRow(item1);  
    model.appendRow(item2);  
    model.appendRow(item3);  
  
    // 创建列表视图并设置模型  
    QListView listView;  
    listView.setModel(&model);  
    listView.show();  
  
    // 刷新数据  
    item1->setText("New Item 1");  
    item2->setText("New Item 2");  
    item3->setText("New Item 3");  
  
    // 更新视图  
    listView.setModel(&model);  
  
    return app.exec();  
}

在上面的示例中,我们首先创建了一个QStandardItemModel模型,并向其中添加了三个项目。然后,我们创建了一个QListView,并将其模型设置为之前创建的模型。接下来,我们更新了模型中的数据,并通过调用listView.setModel(&model)来刷新视图中的数据。

当模型的数据发生更改时,调用setModel()方法将重新建立视图与模型之间的连接,并刷新视图以反映最新的数据。

相关推荐
漂亮的小碎步丶9 分钟前
【6】数据库事务与锁机制详解(附并发结算案例)
数据库·事务·锁机制
合方圆~小文18 分钟前
4G定焦球机摄像头综合介绍产品指南
数据结构·数据库·人工智能
zxrhhm19 分钟前
数据库中的COALESCE函数用于返回参数列表中第一个非NULL值,若所有参数均为NULL则返回NULL
数据库·postgresql·oracle
小学鸡!22 分钟前
DBeaver连接InfluxDB数据库
数据库
Yeniden26 分钟前
Deepeek用大白话讲解 --> 迭代器模式(企业级场景1,多种遍历方式2,隐藏集合结构3,Java集合框架4)
java·开发语言·迭代器模式
running up30 分钟前
MyBatis 核心知识点与实战
数据库·oracle·mybatis
SmoothSailingT35 分钟前
C#——LINQ方法
开发语言·c#·linq
景川呀35 分钟前
Java的类加载器
java·开发语言·java类加载器
薛不痒35 分钟前
MySQL中使用SQL语言
数据库·sql·mysql
k***921639 分钟前
Python 科学计算有哪些提高运算速度的技巧
开发语言·python