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)QHeaderView *headerView = tableView->verticalHeader()
headerView->setHidden(true)
QStringList header
header<<tr("Name")<<tr("Path")<<tr("随便改")
tableView->setHorizontalHeaderLabels(header)
1、手动设置定长的表头数据。比如表头可能出现的数据是1到100000,那么我们就以最长的为标准,不够长度的补空格。这样不用需要设置自适应,表格刷新和切换可以瞬间完成。但代价是表头很丑,在数据小时有大片空白2、使用当前最大的表头数据,仅对该数据用QFontMetrics计算宽度,然后对表头设置fixedWidth()。这样理论可行,然而实际很丑陋,调整宽度后多出来的部分只有QWidget底色,文本信息并没有绘制上去,导致表头文本显示不完全,且表头效果绘制错误。然后尝试搜索了"QTableView VerticalHeader width"关键字之后,在Qt论坛搜到一篇帖子,里面给了一个脑洞清奇的解法——设置表头宽度后,将首列宽度设置为0,再重置,即代码如下:ui->tableView->verticalHeader()->setFixedWidth(width)
width = ui->tableView->columnWidth(0)
ui->tableView->setColumnWidth(0, 0)
ui->tableView->setColumnWidth(0, width)
上述代码,会导致表格布局改变,从而触发表格的全局重绘,在这次重绘里,重设宽度过后的表头也能正常显示了。由于所有column和表头都没有设置自适应,所以这个重绘效率很高。最后profile结果如下: - 在设置自适应后,表格刷新耗时10ms内。但若要重新适配表头,则需要耗时10s左右。 - 关闭自适应,通过手动设置fixedWidth方式适配表头,数据刷新加适配表头,总体耗时不超过20ms。
评论列表(0条)