QT学习笔记之QTableView设置属性的方法
来源:互联网 发布:qq假红包软件 编辑:程序博客网 时间:2024/06/05 10:33
写在前面
这是在网上找到的,因为抄袭的人太多,我也不知道原创是谁了,不好意思贴出原博客的地址了,博主请原谅我!!
方法
一 添加表头 //准备数据模型 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);
自己的试验品
自己根据需求以及上述的帮助写了个功能块,可以借大家参考下
这是截图:
以下是这部分的代码:
//这里根据房间状态的不同分别显示不同的颜色//设置单元格的颜色void setRowColor(int index, int status, QStandardItemModel* itemModel){ if (status == -1) { itemModel->item(index, 0)->setBackground(QBrush(QColor(200,200,169))); itemModel->item(index, 0)->setForeground(QBrush(Qt::white)); itemModel->item(index, 1)->setBackground(QBrush(QColor(200, 200, 169))); itemModel->item(index, 1)->setForeground(QBrush(Qt::white)); itemModel->item(index, 2)->setBackground(QBrush(QColor(200, 200, 169))); itemModel->item(index, 2)->setForeground(QBrush(Qt::white)); itemModel->item(index, 3)->setBackground(QBrush(QColor(200, 200, 169))); itemModel->item(index, 3)->setForeground(QBrush(Qt::white)); } if (status == 0) { itemModel->item(index, 0)->setBackground(QBrush(QColor(131, 175, 155))); itemModel->item(index, 0)->setForeground(QBrush(Qt::white)); itemModel->item(index, 1)->setBackground(QBrush(QColor(131, 175, 155))); itemModel->item(index, 1)->setForeground(QBrush(Qt::white)); itemModel->item(index, 2)->setBackground(QBrush(QColor(131, 175, 155))); itemModel->item(index, 2)->setForeground(QBrush(Qt::white)); itemModel->item(index, 3)->setBackground(QBrush(QColor(131, 175, 155))); itemModel->item(index, 3)->setForeground(QBrush(Qt::white)); } if (status == 1) { itemModel->item(index, 0)->setBackground(QBrush(QColor(254, 67, 101))); itemModel->item(index, 0)->setForeground(QBrush(Qt::white)); itemModel->item(index, 1)->setBackground(QBrush(QColor(254, 67, 101))); itemModel->item(index, 1)->setForeground(QBrush(Qt::white)); itemModel->item(index, 2)->setBackground(QBrush(QColor(254, 67, 101))); itemModel->item(index, 2)->setForeground(QBrush(Qt::white)); itemModel->item(index, 3)->setBackground(QBrush(QColor(254, 67, 101))); itemModel->item(index, 3)->setForeground(QBrush(Qt::white)); }}
另外,附上QTableView获取某个单元格的数据的操作:
int curRow=ui->tableView->currentIndex().row(); //选中行QAbstractItemModel *modessl = ui->tableView->model();QModelIndex indextemp = modessl->index(curRow,i);//遍历第一行的所有列i 是你要取值的列的下标//这个是一个单元格的值。tostring()----okQVariant datatemp = modessl->data(indextemp);
再次声明,这不是我的原创,因为不知道原作者所以没有贴出原地址,希望大家原谅我没有贴出原博客的地址!
0 0
- QT学习笔记之QTableView设置属性的方法
- Qt 下 QtableView的属性设置
- qt学习之qtableview
- QT学习笔记-31.QTABLEVIEW只显示横格,不显示点击虚框的方法
- Qt之QTableView的使用
- Qt学习之QTableView和QTableWidget的具体区别
- Qt QTableView设置各行的背景颜色
- qt qtableview 样式设置
- Qt学习笔记,设置QTabWidget的TabBar的属性
- Qt之QTableView
- Qt之QTableView
- Qt之QTableView
- qt QTableView/QTableWidget样式设置
- QTableView和QTableWidget翻页功能实现---Qt学习笔记5
- qt的QTableView使用
- QT::QTableView的使用
- Qt笔记:设置控件的基本属性
- QT - QTableView表格视图的列宽设置
- 关于ERP
- 思维修炼——总论
- 实现一个操作集合的类
- 个人感悟
- 深入理解Java之垃圾回收
- QT学习笔记之QTableView设置属性的方法
- 小程序
- JSON的三种解析方式
- JavaScript indexOf() 方法
- MySQL 插入更新删除
- RPM Provides命令
- 数组相关的运算(sizeof,strlen)
- 字符串相关(字符串数组,字符串处理相关函数、自实现函数)
- MySQL权限管理