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);。
显示科学技术法是float的显示,
需要用QString number(double, char f='g', int prec=6);将float装换为QString显示,如:
QString::number(fTotalMoney,'f',2);。
// QTableView配合使用的是QStandIterModel,你可以从这个model里面取数据。
QTableView *tableView = new QTableView();。
QStandarItermModel *model = new QStandarItemModel();。
// 绑定model
tableView->setModel(model);。
// 填充数据
model->setData(model->index(row, col), QString("110"));。
// 获取数据
model->data(model->index(row, col))->toInt();。
在你重载QSqlTableModel的data函数里合适的位置加上下面这段对role的类型进行判断:
QVariant SqlTableModel::data(const QModelIndex & item, int role) const{。
//其他代码。。。
if (role == Qt::TextAlignmentRole){。
return Qt::AlignCenter;。
}
//其他代码。。。
你说的是不是gridView控件?设置其某行被选中,其实可以使用该控件自带的功能。具体做法是,打开编辑列功能,向列集合中添加一个字段,字段为CommandField下的”选择“字段。为了让其有显示效果,请将GridView控件中的选中行的背景色设为比较醒目的颜色,如Red。编译并运行,单击选择项之后,该行会被选中,在后台处理gridView控件中RowSelectChanging事件时,可以实现很多的效果。
原文地址:http://www.qianchusai.com/qtableview%E5%B1%85%E4%B8%AD%E6%98%BE%E7%A4%BA.html