《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); //列表头居中
在这里插入图片描述

📢博客主页: 主页
📢欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指正!
📢本文由 梦回阑珊 原创,首发于 优快云,转载注明出处🙉
📢代码改变世界,你来改变代码!✨

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

梦回阑珊

一毛不嫌多,一分也是爱

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值