Qt 之 QPushButton同时显示图片和文字

本文详细介绍了一种自定义QPushButton控件的方法,该控件能够同时显示图标和文本,并通过重写paintEvent来实现绘图功能。代码示例展示了如何设置按钮的高度、宽度以及图标的位置,为用户提供了一个灵活且美观的界面元素。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#include <QPushButton>
#include <QPixmap>
#include <QWidget>
#include <QPainter>
#include <QPaintEvent>

class CustomPushButton
{
    CustomPushButton(const QString& iconPath, const QString& text, QWidget* parent)
        : public QPushButton(parent)

    {

        m_text = text;

        m_icon = QPixmap(iconPath);

    

        setFixedHeight(m_icon.size().height() + 15);

        setMinimumWidth(m_icon.size().width());

    

        m_drawedIconRect.setX( (rect().x() - m_icon.rect().x()) / 2);

        m_drawedIconRect.setY(rect().y());

        m_drawedIconRect.setWidth(m_icon.rect().width());

        m_drawedIconRect.setHeight(m_icon.rect().height());

    }

 

    void paintEvent(QPaintEvent* event)

    {

        QPainter painter(this);

        painter.drawPixmap(m_drawedIconRect, m_icon);

        painter.drawText(event->rect(), Qt::AlignHCenter | Qt::AlignBottom, m_text);

    }   
}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值