
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)//要先设置表头高度
-(CGSize)collectionView:(UICollectionView*)collectionView layout:(UICollectionViewLayout*)collectionViewLayout referenceSizeForHeaderInSection:(NSInteger)section
{
CGSize size = {kScreenWidth, 50}
return size
}
//在表头内添加内容,需要创建一个继承collectionReusableView的类,用法类比tableViewcell
- (UICollectionReusableView *)collectionView:(UICollectionView *)collectionView viewForSupplementaryElementOfKind:(NSString *)kind atIndexPath:(NSIndexPath *)indexPath
{
// 注册表头
[collectionView registerClass:[MCClassifyCollectionReusableView class] forSupplementaryViewOfKind:UICollectionElementKindSectionHeader withReuseIdentifier:@"HeaderView"]
// 初始化表头
MCClassifyCollectionReusableView *headerView = [collectionView dequeueReusableSupplementaryViewOfKind:UICollectionElementKindSectionHeader withReuseIdentifier:@"HeaderView" forIndexPath:indexPath]
NSArray * array = @[@"1",@"2",@"3",@"4",@"5",@"6",@"7"]
headerView.hotSingerName.text = array[indexPath.section]
return headerView
}
评论列表(0条)