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

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后
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值