自定义QHeaderView后,点击表头排序失效的解决办法

自定义QHeaderView后,点击表头排序失效的解决办法,第1张

在自定义QHeaderView的构造函数中加上:

原因:

(1)当QHeaderView的clickableSections属性为true时,表头才能响应点击事件。

(2)QHeaderView的clickableSections属性并没有在QHeaderView的初始化构造中默认设置为true,而是在QTableView等构造初始化时,构建默认的表头后通过setSectionsClickable(true)显式地设置为true,因此用自定义的QHeaderView代替QTableView的默认表头后,不会响应表头点击事件。

QTableView常用于实现数据的表格显示。下面我们如何按步骤实现学生信息表格:一 添加表头//准备数据模型QStandardItemModel *student_model = new QStandardItemModel()student_model->setHorizontalHeaderItem(0, new QStandardItem(QObject::tr("Name")))student_model->setHorizontalHeaderItem(1, new QStandardItem(QObject::tr("NO.")))student_model->setHorizontalHeaderItem(2, new QStandardItem(QObject::tr("Sex")))student_model->setHorizontalHeaderItem(3, new QStandardItem(QObject::tr("Age")))student_model->setHorizontalHeaderItem(4, new QStandardItem(QObject::tr("College")))//利用setModel()方法将数据模型与QTableView绑定ui->student_tableview->setModel(student_model)二 设置表格属性//设置列宽不可变动,即不能通过鼠标拖动增加列宽ui->student_tableview->horizontalHeader()->setResizeMode(0, QHeaderView::Fixed) ui->student_tableview->horizontalHeader()->setResizeMode(1, QHeaderView::Fixed) ui->student_tableview->horizontalHeader()->setResizeMode(2, QHeaderView::Fixed) ui->student_tableview->horizontalHeader()->setResizeMode(3, QHeaderView::Fixed) ui->student_tableview->horizontalHeader()->setResizeMode(4, QHeaderView::Fixed) //设置表格的各列的宽度值ui->student_tableview->setColumnWidth(0,100) ui->student_tableview->setColumnWidth(1,100) ui->student_tableview->setColumnWidth(2,100) ui->student_tableview->setColumnWidth(3,100) ui->student_tableview->setColumnWidth(4,100) //默认显示行头,如果你觉得不美观的话,我们可以将隐藏ui->student_tableview->verticalHeader()->hide() //设置选中时为整行选中ui->student_tableview->setSelectionBehavior(QAbstractItemView::SelectRows) //设置表格的单元为只读属性,即不能编辑ui->student_tableview->setEditTriggers(QAbstractItemView::NoEditTriggers) //如果你用在QTableView中使用右键菜单,需启用该属性ui->tstudent_tableview->setContextMenuPolicy(Qt::CustomContextMenu) 三 动态添加行在表格中添加行时,我们只需要在model中插入数据即可,一旦model中的数据发生变化,QTabelView显示就会做相应的变动//在第一行添加学生张三的个人信息(setItem函数的第一个参数表示行号,第二个表示列号,第三个为要显示的数据)student_model->setItem(0, 0, new QStandardItem(“张三"))student_model->setItem(0, 1, new QStandardItem("20120202"))student_model->setItem(0, 2, new QStandardItem("男"))student_model->setItem(0, 3, new QStandardItem("18"))student_model->setItem(0, 4, new QStandardItem("土木学院"))四 设置数据显示的样式//设置单元格文本居中,张三的数据设置为居中显示student_model->item(0, 0)->setTextAlignment(Qt::AlignCenter)student_model->item(0, 1)->setTextAlignment(Qt::AlignCenter)student_model->item(0, 2)->setTextAlignment(Qt::AlignCenter)student_model->item(0, 3)->setTextAlignment(Qt::AlignCenter)student_model->item(0, 4)->setTextAlignment(Qt::AlignCenter)//设置单元格文本颜色,张三的数据设置为红色student_model->item(0, 0)->setForeground(QBrush(QColor(255, 0, 0)))student_model->item(0, 1)->setForeground(QBrush(QColor(255, 0, 0)))student_model->item(0, 2)->setForeground(QBrush(QColor(255, 0, 0)))student_model->item(0, 3)->setForeground(QBrush(QColor(255, 0, 0)))student_model->item(0, 4)->setForeground(QBrush(QColor(255, 0, 0)))//将字体加粗student_model->item(0, 0)->setFont( QFont( "Times", 10, QFont::Black ) )student_model->item(0, 1)->setFont( QFont( "Times", 10, QFont::Black ) )student_model->item(0, 2)->setFont( QFont( "Times", 10, QFont::Black ) )student_model->item(0, 3)->setFont( QFont( "Times", 10, QFont::Black ) )student_model->item(0, 4)->setFont( QFont( "Times", 10, QFont::Black ) )//设置排序方式,按年龄降序显示student_model->sort(3, Qt::DescendingOrder)

Qt 中 QTableWidget类设置表格 实例是本文要介绍的内容,如果不是很清楚可以查阅QT类相关的资料,本文也有推荐。不多说,先来看内容。在Qt的Help里面查询相关介绍与使用。

QTableWidget类设置表格

头文件包含:

#include<QTableWidget>

具体使用:

//构造一个QTableWidget类的实体对象tableWidget

tableWidget=newQTableWidget(ui->textBrowser)

tableWidget->setRowCount(7)//设置行数为7

tableWidget->setColumnCount(5)//设置列数为5

tableWidget->setGeometry(QRect(0,0,401,241))//设置tableWidget的大小

tableWidget->setItem(0,0,newQTableWidgetItem("abc"))//第一行第一列的内容设置为abc

tableWidget->setItem(1,0,newQTableWidgetItem("def"))//第二行第一列的内容设置为abc

//40,110,100,60,85

tableWidget->setColumnWidth(0,40)//设置第一列的列宽

tableWidget->setColumnWidth(1,110)//设置第二列的列宽

tableWidget->setColumnWidth(2,100)//设置第三列的列宽

tableWidget->setColumnWidth(3,60)//设置第四列的列宽

tableWidget->setColumnWidth(4,85)//设置第五列的列宽

QTextCodec::setCodecForTr(QTextCodec::codecForName("GB18030"))//编码设置为GB18030

//列表的标题----车次车牌支付卡金额累计金额

tableWidget->setHorizontalHeaderLabels(QStringList()<<tr("车次")<<tr("车牌")<<tr("支付卡")<<tr("金额")<<tr("累计金额"))

tableWidget->setFont(QFont("wenquanyi",12,3))//设置字体

QHeaderView*headerView=tableWidget->verticalHeader()

headerView->setHidden(true)//行名隐藏

由于使用了QTextCodec,所以在上面还应该包含头文件:

#include<QTextCodec>

小结:Qt中 QTableWidget类设置表格 实例的内容介绍完了,希望本文对你有所帮助,关于相关内容的资料请参考编辑推荐。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/11267262.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-14
下一篇 2023-05-14

发表评论

登录后才能评论

评论列表(0条)

保存