QTableView/QTableWidget设置单元格文字边距 您所在的位置:网站首页 单元格的上下边距 QTableView/QTableWidget设置单元格文字边距

QTableView/QTableWidget设置单元格文字边距

2023-08-04 00:46| 来源: 网络整理| 查看: 265

QTableView/QTableWidget设置单元格文字边距

1、用样式表尝试一下,发现没有效果

QTableView::item{ padding-left:10px; }

2、继承QStyledItemDelegate,重写paint函数

void Delegate::paint(QPainter *painter, const QStyleOptionViewItem &option, const QModelIndex &index) const { QStyleOptionViewItem opt(option); opt.rect.adjust(10, 0, 0, 0); QStyledItemDelegate::paint(painter, opt, index); }

发现这样做导致单元格的背景也会有边距,不过在该函数内用painter自绘文字,是可以实现效果的。

3、这里提供另一种方法,子类化QProxyStyle,重写pixelMetric函数。

int pixelMetric(QStyle::PixelMetric metric, const QStyleOption *option, const QWidget *widget) const { switch (metric) { case PM_FocusFrameHMargin: return 10; default: break; } return QProxyStyle::pixelMetric(metric, option, widget); }

然后

ui->tableWidget->setStyle(new TableItemSpaceStyle);

修改style前 在这里插入图片描述 修改style后 在这里插入图片描述



【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有