Qt-Qlabel 自定义鼠标点击事件以及文本样式效果设计

本文介绍了在Qt项目中实现消息推送功能,特别是如何为QLabel添加鼠标点击事件和文本样式效果。遇到的问题包括QLabel缺少click信号、鼠标hover效果以及超链接样式。解决方案包括自定义QLabel类、使用qss设置样式和hover效果,以及处理中文乱码。
摘要由CSDN通过智能技术生成

最近项目中需要实现一个消息推送的功能,模仿QQ消息弹窗的方式实现,界面开发的工具为Qt。对桌面应用开发这块不太熟悉,通过摸索尝试也算是把这个功能实现了,其中也碰到了一些比较麻烦的问题,这些问题我看也具有一定的普遍性,就把我摸索出来的解决方法和大家分享下(可能有更好的方法我没想到)!
Qt虽说支持CSS2的所有样式效果,但真正实现起来可并不如html那般简单。这个消息弹窗中的文字链接以及点击效果的设置就把我折腾了好久。需要设计的效果是:

1、标题、内容以及图片均具有点击的效果;
2、鼠标放置在标题和内容上,文字变色并且高亮显示,无需下划线;
3、鼠标的形状:在放置在标题和内容上时由箭头变成小手指。

整个窗体采用QWidget类型,标题、内容、图片采用QLabel类型。当我实现文本点击时,发现QLabel没有像button那样的clicked信号,网上推荐了如下两种方法:

1、在标题中嵌入html标签:

     QString title = "<a href=' " + url + "  '>" + content + " </a> 
     ui.Title->setText(title)
     setOpenExternalLinks(true) // 允许打开外部链接,这个可在ui文件中通过可视化工具设置(我用的是VS插件Qt设计师)

    但这种方式存在两个个问题:1)无法支持鼠标hover效果;2&#

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值