QT学习笔记之QTableView设置属性的方法
2017-04-04 22:36
615 查看
写在前面
这是在网上找到的,因为抄袭的人太多,我也不知道原创是谁了,不好意思贴出原博客的地址了,博主请原谅我!!方法
一 添加表头 //准备数据模型 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)-&g b926 t;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()----ok QVariant datatemp = modessl->data(indextemp);
再次声明,这不是我的原创,因为不知道原作者所以没有贴出原地址,希望大家原谅我没有贴出原博客的地址!
相关文章推荐
- ios开发笔记之十一 --viewDidload的方法的基本介绍用代码设置按钮的属性
- Qt学习笔记,设置QTabWidget的TabBar的属性
- Qt学习笔记,设置QTabWidget的TabBar的属性
- iOS学习笔记---UIScrollView 常见属性 不能滚动 常见代理方法
- iOS学习笔记------UIButton、UIImageView、UILabel的属性与方法
- ios开发笔记之十二 --viewDidload的方法的基本介绍用代码设置按钮的属性
- QTableView和QTableWidget翻页功能实现---Qt学习笔记5
- iOS学习笔记--UIPickerView常见方法,属性,数据源代理方法。UIDatePicker属性
- QT学习笔记-31.QTABLEVIEW只显示横格,不显示点击虚框的方法
- Silverlight学习笔记三(鼠标点击动态画直线|动态设置Ellipse的Canvas.Top与Canvas.Left|动态设置Stroke属性的方法。)
- Qt 下 QtableView的属性设置
- Qt Model/View 学习笔记 (六)
- WPF学习笔记6: 依赖属性设置优先级
- Qt Model/View 学习笔记 (七)
- Qt Model/View 学习笔记 (三)
- ExtJS学习笔记(一):ExtJS程序的结构及如何定义js的private, public属性、方法
- Qt Model/View 学习笔记 (二)
- Qt Model/View 学习笔记 (三)
- Qt Model/View 学习笔记 (二)
- Qt Model/View 学习笔记 (三)