带有下划线的按钮

继承QLabel,话不多说,直接上代码 

underlinebutton.h
#ifndef UNDERLINEBUTTON_H
#define UNDERLINEBUTTON_H

#include <QLabel>
#include <QMouseEvent>

class UnderlineButton : public QLabel
{
    Q_OBJECT
public:
    explicit UnderlineButton(QWidget *parent = 0);
    explicit UnderlineButton(const QString &text, QWidget *parent=0);

    bool isPress;

Q_SIGNALS:
    void clicked();

public slots:
    bool enterBtn(QPoint pp);

protected:
    void mousePressEvent(QMouseEvent *event);
    void mouseReleaseEvent(QMouseEvent *event);
};

#endif // UNDERLINEBUTTON_H
underlinebutton.cpp
#include "underlinebutton.h"

UnderlineButton::UnderlineButton(QWidget *parent) : QLabel(parent)
{
    isPress = false;
}

UnderlineButton::UnderlineButton(const QString &text, QWidget *parent) : QLabel(parent)
{
    setText("<U>" + text + "</U>");
    setStyleSheet("color:blue");
}

bool UnderlineButton::enterBtn(QPoint pp)
{
    int height = this->height();
    int width = this->width();

    QPoint btnMaxPos;
    btnMaxPos.setX(width);
    btnMaxPos.setY(height);

    if(pp.x() >= 0 && pp.y() >= 0 && pp.x() <= btnMaxPos.x() && pp.y() <= btnMaxPos.y())
       return true;
    else
       return false;
}

void UnderlineButton::mousePressEvent(QMouseEvent *event)
{
    if(event->button() == Qt::LeftButton)
    {
        isPress = true;
        setStyleSheet("color:red");
    }
}

void UnderlineButton::mouseReleaseEvent(QMouseEvent *event)
{
    if(event->button() == Qt::LeftButton)
    {
        isPress = false;
        setStyleSheet("color:blue");
        if (enterBtn(event->pos()))
        {
            emit clicked();
        }
    }
}

效果图:

可当按钮使用

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值