当前位置: 首页> 财经> 访谈 > qt可点击的QLabel

qt可点击的QLabel

时间:2025/8/26 22:09:18来源:https://blog.csdn.net/weixin_32155265/article/details/140007278 浏览次数:0次

需求——问题与思路

使用wpf实现一个可点击的超链接label相当简单(如下图),但是qt的QLabel不会响应点击事件,那就从QLabel继承一个类,然后在该类中重写mousePressEvent函数,并在该函数中对左键点击事件做响应处理即可,这里只是发送自定义的clicked信号,以便让QLabel像普通的QPushButton一样响应用户的点击事件。
请添加图片描述

代码

只有一个头文件ClickLabel.h

#pragma once#include <QObject>
#include <QLabel>
#include <QMouseEvent>//超链接样式、响应点击信号的自定义label
class ClickLabel : public QLabel {Q_OBJECT
public:explicit ClickLabel(QWidget* parent = nullptr) : QLabel(parent) {}signals:// 自定义的点击信号void clicked();protected:void mousePressEvent(QMouseEvent* event) override {// 检查鼠标左键点击事件if (event->button() == Qt::LeftButton) {// 发出自定义的点击信号emit clicked();}// 将事件传递给父类处理QLabel::mousePressEvent(event);}//在 mouseEnterEvent() 中设置下划线字体,并更新标志位以指示鼠标进入状态。
//在 mouseLeaveEvent() 中恢复正常字体,并更新标志位以指示鼠标离开状态。
protected:void enterEvent(QEvent* event) override{setFontUnderline(true);isMouseEntered = true;QLabel::enterEvent(event);}void leaveEvent(QEvent* event) override{setFontUnderline(false);isMouseEntered = false;QLabel::leaveEvent(event);}private:bool isMouseEntered;void setFontUnderline(bool underline){QFont font = this->font();font.setUnderline(underline);this->setFont(font);}
};

用法

将一个普通的QLabel控件提升为ClickLabel即可。

在这里插入图片描述

关键字:qt可点击的QLabel

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: