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);
1.QGridLayoutet用法
QGridLayout::addWidget(widget,row,column,rowSpan,columnSpan);widget为控件,row,column)为控件占据的左上角单元格位置,
rowSpan是控件占据的行数,colunmSpan是控件占据的列的个数。
rowSpan和colunmSpan默认值为1。
2.设置标签字体颜色
QLabel *msgLabel = new QLabel;
msgLabel->setText(tr("<h2><font color = red>此处为消息提示标签</font></h2>"));
3.设置控件与Layout的距离
dowLayout->setMargin(50);
4.设置控件之间的距离
dowLayout->setSpacing(20);
5.创建表格并给值
QStringList fonts;
fonts <<tr("进货单号")<< tr("商品ID") ;
iTableView = new QTableView(this); //显示表格的控件
table = new QStandardItemModel(v_table.size(), 10); //创建的表格
iTableView->setEditTriggers(QAbstractItemView::NoEditTriggers); //不能对表格进行编写
iTableView->setSelectionBehavior(QAbstractItemView::SelectRows); //只能选择表格的一行
table->setHorizontalHeaderLabels(fonts); //表格的列名
this->iTableView->setModel(table);
table->setData(table->index(i, 0), tem.goods_i_id);
6.给QListWidget改颜色,点中某列时颜色会发生改变
QBrush brush1(QColor(150, 181, 218, 255));
brush1.setStyle(Qt::SolidPattern);
palette.setBrush(QPalette::Disabled, QPalette::Highlight, brush1);
list->setPalette(palette);
7.导入数据到EXCEL表格中
void MainWindow::inputExcel(QString data)
{
QString fileName = QFileDialog::getSaveFileName(this, tr("Save File"), "", tr("file ( *.csv)"));
if(fileName == "")
return;
QTextCodec *code;
code = QTextCodec::codecForName("gb18030");
std::string strCountBuffer = (code->fromUnicode(data)).data();
std::string strbuffer = (code->fromUnicode(fileName)).data();
FILE *fileWrite = fopen( strbuffer.c_str(),"w");
QFile file;
file.open(fileWrite, QIODevice::WriteOnly);
file.write(strCountBuffer.c_str(), qstrlen(strCountBuffer.c_str()));
file.close();
}
8.将table中的数据提取出来转化成被*.CVS可以接受的字符流
//此字符流中已经包含了列的头和数据
QString getTableData(QStandardItemModel* table)
{
QString stringData;
int i=0, j=0;
for(int i=0; i<table->columnCount(); i++)
{
stringData+= table->headerData(i, Qt::Horizontal, 0).toString();
stringData+=",";
}
stringData = stringData+"\n";
for(i=0; i<table->rowCount(); i++)
{
for(j=0; j<table->columnCount(); j++)
{
stringData+=table->data(table->index(i, j)).toString()+",";
}
stringData+="\n";
}
return stringData;
}
9.改变table间隔颜色
tableView->setAlternatingRowColors(true);
tableView->setStyleSheet("alternate-background-color: rgb(170, 255, 255);");
10.
使某格字体变成红色
model->item(row, column)->setForeground(QBrush(QColor(255, 0, 0)));
使某格背景成为红色
table->item(i,j)->setForeground(QBrush(QColor(255, 0, 0)));
11.Qt使用sleep函数
QTime t;
t.start();
while(t.elapsed()<1000)
QCoreApplication::processEvents();
12.Qt中相对路径和绝对路径问题
(1).资源文件要放在程序运行目录下,而不是程序代码目录下如:test-build-desktop
(2).其格式为 .\\imag\\MacQQ.png只有一个上点。
(3).更改工作目录_chdir("D:\\program\\Qt\\test");
13.设置LineEdit不可编辑
lineEdit->setEnabled(false);
14.设置QLabel文字居中
textLabel->setAlignment(Qt::AlignCenter);
15.LineEdit 获得焦点LineEdit-》forcurinEvet;
17.加入底盘标签
trayIcon = new QSystemTrayIcon(QIcon(".\\MacQQ.png"));
this->trayIcon->setVisible(true);