相关文章推荐
灰常酷的柳树  ·  C# ...·  1 年前    · 

下面直接上代码,完全可以直接拷贝用:

 QString qssTV = "QTableWidget::item:hover{background-color:rgb(92,188,227,200)}"
                    "QTableWidget::item:selected{background-color:#1B89A1}"
                    "QHeaderView::section,QTableCornerButton:section{ \
            padding:3px; margin:0px; color:#DCDCDC;  border:1px solid #242424; \
    border-left-width:0px; border-right-width:1px; border-top-width:0px; border-bottom-width:1px; \
background:qlineargradient(spread:pad,x1:0,y1:0,x2:0,y2:1,stop:0 #646464,stop:1 #525252); }"
"QTableWidget{background-color:white;border:none;}";
//ui->tableWidget->setShowGrid(true); //设置显示格子线
ui->tableWidget->setSelectionBehavior(QAbstractItemView::SelectRows); //整行选中的方式
ui->tableWidget->setEditTriggers(QAbstractItemView::NoEditTriggers); //禁止编辑
ui->tableWidget->horizontalHeader()->setStretchLastSection(true); //行头自适应表格
ui->tableWidget->horizontalHeader()->setFont(QFont("song", 12));
//点击表时不对表头行光亮(获取焦点)
ui->tableWidget->horizontalHeader()->setHighlightSections(false);
//设置表头字体加粗
QFont font =  ui->tableWidget->horizontalHeader()->font();
font.setBold(true);
ui->tableWidget->horizontalHeader()->setFont(font);
//ui->tableWidget->horizontalHeader()->setStyleSheet("QHeaderView::section{background:lightblue;}"); //skyblue设置表头背景色
//ui->tableWidget->setStyleSheet("selection-background-color:lightblue;"); //设置选中背景色
ui->tableWidget->setStyleSheet(qssTV);
ui->tableWidget->horizontalHeader()->setHighlightSections(false);         //点击表头时不对表头光亮
ui->tableWidget->setSelectionMode(QAbstractItemView::ContiguousSelection);//选中模式为多行选中
ui->tableWidget->setSelectionBehavior(QAbstractItemView::SelectRows);
//所有单元格的字体  设置成一样
ui->tableWidget->setFont(QFont("song", 12)); 
ui->tableWidget->setRowCount(1); //设置行数
ui->tableWidget->setColumnCount(8); //设置列数
ui->tableWidget->setWindowTitle("TABLE演示");
QStringList header;
header<<"序号"<<"名称"<<"设备ID"<<"设备IP"<<"设备端口"<<"型号"<<"厂家"<<"备注";
ui->tableWidget->setHorizontalHeaderLabels(header);
//去掉默认行号 可以用horizontalHeader() ->setVisible(false)隐藏横向表头
QHeaderView *header1 =   ui->tableWidget->verticalHeader();
header1->setHidden(true);
//设置单元格大小
ui->tableWidget->horizontalHeader()->setDefaultSectionSize(50);  //设置默认宽度
ui->tableWidget->verticalHeader()->setDefaultSectionSize(30);   //设置一行默认高度
ui->tableWidget->setColumnWidth(1,110);
ui->tableWidget->setColumnWidth(2,110);
ui->tableWidget->setColumnWidth(4,180);
ui->tableWidget->setColumnWidth(5,110);
ui->tableWidget->setColumnWidth(6,80);
ui->tableWidget->setColumnWidth(7,80);
ui->tableWidget->setSortingEnabled(true);  //启动排序
for (int crowCount = 0; crowCount < 20; ++crowCount)
    //插入数据
    QTableWidgetItem *check=new QTableWidgetItem(QString::number(crowCount)); 
    check->setCheckState(Qt::Unchecked);  //是否设置选中框
    ui->tableWidget->insertRow(crowCount);
    check->setText(QString::number(crowCount));  //显示序号
    ui->tableWidget->setItem(crowCount,0,check); //插入复选框
    for(int j=1; j<8; j++ )
        ui->tableWidget->setItem(crowCount,j,new QTableWidgetItem(QString::number(j)));

单元格单独设置字体方法:

                QTableWidgetItem *item = new QTableWidgetItem;

                item->setText(strDev);

                item->setFont(QFont("song", 14));

                ui->tableWidget->setItem(crowCount,j,item);

备注:实战示例,解疑答惑。

           --不间端地思考,实时地批判你的工作!

QTableWidget表头、内容字体大小、颜色、背景颜色等设置主要设置:1、是否显示格子线。2、禁止编辑3、默认高度,宽度4、选中模式5、排序6、样式设置示例等。下面直接上代码: QString qssTV = "QTableView::item:hover{background-color:rgb(92,188,227,200)}" ...
如下是对tabwidget表头设置。background-color是对表头背景颜色设置。font是对字体大小字体颜色字体格式设置。 ui.tableWidget_grid->horizontalHeader()->setStyleSheet("QHeaderView::section{background-color:rgb(40,143,218);font:13pt '宋体';col
QTableWidget 设置表头颜色 setStyleSheet( "QHeaderView::section {background-color: qlineargradient(x1:0, y1:0, x2:0, y2:1,stop:0 #00007f, stop: 0.5 #00007f,stop: 0.6 #00007f, stop:1 #00007f);color: white;}"); setStyleSheet( "QTableWidget{ color:black
一、说明:一年没有搞Qt啦,一个同事问我QTableWidget相关字体颜色设置问题,特别是表头怎么设置都不成功。网上一堆说用setStyleSheet设置background-color,然而没有卵用。 二、设置成功的方法如下: ui-&gt;tableWidget-&gt;horizontalHeader()-&gt;setStyleSheet( "QHeaderView::section ...
最近发现在QTableWidget表头中加入复选框这个需求较为普遍,网上相关的资料却很少,实现此功能所需相关的Qt方法也较为冷门,特作此分享。 主要实现方法为重写QHeaderView类的*void paintSection(QPainter painter, const QRect &rect, int logicalIndex) const; 函数和 *void mousePressEvent(QMouseEvent event); 函数,下面直接贴完整代码和示例,方便大家使用。 1.头文件如
有些博客上写的是调用QTableWidgetItem的setTextColor方法,但是实际开发却找不到该方法,可能是版本问题 代码示例: item = QTableWidgetItem("登录成功") item.setForeground(QBrush(Qt.green))#设置字体颜色为绿色 ui.tableWidget.setItem(0, 1, item)