《QT从基础到进阶·七》QTableView的使用

简介: 《QT从基础到进阶·七》QTableView的使用

1、自定义控件继承问题

DisplayWidget::DisplayWidget(QWidget* parent)
    : QTableView(parent) 
{
    // 创建数据模型
m_standItemModel = new QStandardItemModel();
……
setModel(m_standItemModel);
}

这个就相当于自定义控件DisplayWidget类,继承QTableView, 创建DisplayWidget对象时就相当于创建QTableView对象,内部实现中数据模型不需要指定挂载到哪个表格上,本身DisplayWidget已经继承了QTableView,代表是一个表格,内部的数据模型自然是挂载到这个类上,只要创建DisplayWidget对象,表格就能显示。

拓展:在Ui界面中拖入一个QTableView的表格并提升为DisplayWidget,这样DisplayWidget就代表这个拖入的表格

右击QTableView选择提升,把QTableView提升为我们的自定义类型

使用我们自定义类型时可以直接ui.tableView调用。

2、QTableView的一些函数使用:

tableView->setShowGrid(false); //设置网格线不可见
tableView->setFocusPolicy(Qt::NoFocus); //去掉选中单元格时的虚框
// 设置表头不可见,需要添加QHeadView头文件
tableView->horizontalHeader()->setVisible(false);// 水平不可见
tableView->verticalHeader()->setVisible(false);// 垂直不可见
m_standItemModel->setColumnCount(1); //设置几列表头
m_standItemModel->setHeaderData(0, Qt::Horizontal, "X"); //第一列表头名称为X
m_standItemModel->setVerticalHeaderItem(0,new QStandardItem("D1"));//第一行表头名称为D1
m_standItemModel->verticalHeaderItem(0)->setTextAlignment(Qt::AlignCenter);//第一行表头居中
QApplication::setStyle(QStyleFactory::create("Fusion"));//表格设置为Fusion风格
setSpan(0, 4, 4, 1);//合并单元格,0行4列这个单元格为起点,往下的4行单元格合并成一行,1代表合并的列数
horizontalHeader()->setSectionResizeMode(QHeaderView::Stretch); //均匀拉直列表头
verticalHeader()->setSectionResizeMode(QHeaderView::Stretch); //均匀拉直行表头
setEditTriggers(QAbstractItemView::NoEditTriggers);//禁止编辑表格
m_standItemModel->setItem(0, 2, new QStandardItem(QString::number(d1))); //填写表格内容
m_standItemModel->item(0, 2)->setTextAlignment(Qt::AlignCenter);//表格内容居中
verticalHeader()->setDefaultAlignment(Qt::AlignCenter); //行表头所有名称默认居中,要用到从tableview获取数据
QStandardItemModel* itemModel = (QStandardItemModel*)ui.tableView->model();
QString str = itemModel->item(0, 0)->text();
//如果表格内容为空,那么itemModel->item(0, 0) == NULL
//把单元格设置成下拉框:需在放在setmodel后面
tableView->setIndexWidget(m_standItemModel->index(0, 0), m_comboBox);

下面信号槽可以接受单元格被手动编辑收到信号和通过程序给值也能收到信号,整个单元格组成QStandardItemModel,每个单元格是一个QStandardItem

connect(m_standItemModel, SIGNAL(itemChanged(QStandardItem*)), this, SLOT(dataChanged(QStandardItem*)));

案例使用:

m_standItemModel->verticalHeaderItem(0)->setTextAlignment(Qt::AlignCenter); //列表头居中

相关文章
|
2月前
|
数据库 开发者 Windows
QT 项目视图(QListView&QTreeView&QTableView)和项目部件(QListWidget&QTreeWidget&QTableWidget)详解-2
QT 项目视图(QListView&QTreeView&QTableView)和项目部件(QListWidget&QTreeWidget&QTableWidget)详解
|
2月前
|
XML 设计模式 JSON
QT 项目视图(QListView&QTreeView&QTableView)和项目部件(QListWidget&QTreeWidget&QTableWidget)详解-1
QT 项目视图(QListView&QTreeView&QTableView)和项目部件(QListWidget&QTreeWidget&QTableWidget)详解
|
C语言
QT QtableView操作详解
本文实现了使用QtableView控件来显示数据,数据源使用txt文本作为数据源,使用了QStandardItemModel作为数据模型来实现了对TableView空间的初始化,和对txt数据源的增删改查功能。
465 0
QT QtableView操作详解
|
8月前
《QT从基础到进阶·十》QTableView,QTableWidget,QLineEdit设置只读和输入限制
《QT从基础到进阶·十》QTableView,QTableWidget,QLineEdit设置只读和输入限制
176 0
|
SQL 数据库 计算机视觉
Qt实用技巧:使用QTableView、QSqlTableMode与QSqlDatabase对数据库数据进行操作
Qt实用技巧:使用QTableView、QSqlTableMode与QSqlDatabase对数据库数据进行操作
Qt实用技巧:使用QTableView、QSqlTableMode与QSqlDatabase对数据库数据进行操作
|
Web App开发 索引
Qt之QTableView显示富文本
简述 对于QTableView中的显示,我们前面介绍过很多种,其中包括:文本、进度条、复选框等,今天我们介绍一下关于富文本的显示。 可能绝大多数小伙伴会通过QAbstractTableModel中的data来实现,可是现实告诉我们,那是行不通的,那么我们如何去显示呢?请看正文。 简述 效果 源码 分析 效果 源码 下面我们使用QAbstrac
999 0
|
存储 程序员 C#
Python Qt GUI设计:QTableView、QListView、QListWidet、QTableWidget、QTreeWidget和QTreeWidgetltem表格和树类(提升篇—1)
Python Qt GUI设计:QTableView、QListView、QListWidet、QTableWidget、QTreeWidget和QTreeWidgetltem表格和树类(提升篇—1)
Python Qt GUI设计:QTableView、QListView、QListWidet、QTableWidget、QTreeWidget和QTreeWidgetltem表格和树类(提升篇—1)
转载:QT QTableView用法小结
出自:   http://blog.chinaunix.net/uid-20382483-id-3518513.html   QTableView常用于实现数据的表格显示。下面我们如何按步骤实现学生信息表格: 一 添加表头     //准备数据模型     QStandardIte...
1213 0