原因:
(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类设置表格 实例的内容介绍完了,希望本文对你有所帮助,关于相关内容的资料请参考编辑推荐。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)