Qt 自定义PushButton
http://blog.csdn.net/zddblog/article/details/11116191
功能:鼠标弹起并在按键区域内时,按键响应。并实现normal、hover、pressed效果,PushButton大小默认为传入图片大小。
PushButton的normal、hover、pressed效果没有使用QSS实现,因为重写mouseReleaseEvent后,qss的hover效果混乱。
用法:
- loginButton = new PushButton(":/button/login_button_normal",
- ":/button/login_button_hover",
- ":/button/login_button_pressed");
loginButton = new PushButton(":/button/login_button_normal",
":/button/login_button_hover",
":/button/login_button_pressed");
或者:
- loginButton = new PushButton(":/button/login_button");
loginButton = new PushButton(":/button/login_button");
效果:
具体实现:
- #include "pushbutton.h"
- #include <QPainter>
- #include <QMouseEvent>
- #include <QFontMetrics>
- #include <QLabel>
- PushButton::PushButton(QString normal, QString hover, QString pressed, QWidget *parent) :
- QPushButton(parent)
- {
- buttonState = Normal;
- normalPixmap.load(normal);
- hoverPixmap.load(hover);
- pressPixmap.load(pressed);
- this->setFixedSize(normalPixmap.size());
- this->setContentsMargins(0, 0, 0, 0);
- }
- PushButton::PushButton(QString background, QWidget *parent) :
- QPushButton(parent)
- {
- buttonState = Normal;
- normalPixmap.load(background);
- hoverPixmap.load(background);
- pressPixmap.load(background);
- this->setFixedSize(normalPixmap.size());
- this->setContentsMargins(0, 0, 0, 0);
- }
- void PushButton::paintEvent(QPaintEvent *)
- {
- QPainter painter(this);
- switch(buttonState)
- {
- case Normal:
- painter.drawPixmap(this->rect(), normalPixmap);
- break;
- case Hover:
- painter.drawPixmap(this->rect(), hoverPixmap);
- break;
- case Pressed:
- painter.drawPixmap(this->rect(), pressPixmap);
- }
- painter.drawText(this->rect(), Qt::AlignCenter, this->text());
- }
- void PushButton::enterEvent(QEvent *)
- {
- buttonState = Hover;
- update();
- }
- void PushButton::leaveEvent(QEvent *)
- {
- buttonState = Normal;
- update();
- }
- void PushButton::mousePressEvent(QMouseEvent *e)
- {
- if(e->button() == Qt::LeftButton)
- {
- buttonState = Pressed;
- update();
- }
- }
- bool isOnPushButton(const QPoint &point, const PushButton *pushButton)
- {
- if(point.x() < 0 || point.x() > pushButton->width() ||
- point.y() < 0 || point.y() > pushButton->height())
- {
- return false;
- }
- return true;
- }
- void PushButton::mouseReleaseEvent(QMouseEvent *e)
- {
- if(e->button() == Qt::LeftButton)
- {
- //判断鼠标抬起时是否在PushButton之上
- if(isOnPushButton(e->pos(), this))
- {
- emit clicked();
- }
- buttonState = Hover;
- update();
- }
- }
Qt 自定义PushButton的更多相关文章
- Qt自定义插件编程小结
qt自定义组件开发步骤演示.以下所有步骤的前提是自己先编译Qtcreator源码,最好生成release版的QtCreator,否则自定义的插件嵌入QtCreator会失败!!!(这个网上教程很多) ...
- paip.提升用户体验---c++ qt自定义窗体(1)---标题栏的绘制
源地址:http://blog.csdn.net/attilax/article/details/12343625 paip.提升用户体验---c++ qt自定义窗体(1)---标题栏的绘制 效果图: ...
- QSet使用及Qt自定义类型使用QHash等算法
版权声明:若无来源注明,Techie亮博客文章均为原创. 转载请以链接形式标明本文标题和地址: 本文标题:QSet使用及Qt自定义类型使用QHash等算法 本文地址:http://techie ...
- Qt自定义标题栏
版权声明:若无来源注明,Techie亮博客文章均为原创. 转载请以链接形式标明本文标题和地址: 本文标题:Qt自定义标题栏 本文地址:http://techieliang.com/2017/1 ...
- Qt 自定义事件(三种方法:继承QEvent,然后Send Post就都可以了,也可以覆盖customEvent函数,也可覆盖event()函数)
Qt 自定义事件很简单,同其它类库的使用很相似,都是要继承一个类进行扩展.在 Qt 中,你需要继承的类是 QEvent. 继承QEvent类,你需要提供一个QEvent::Type类型的参数,作为自定 ...
- Qt中PushButton的pressed,released,clicked三种响应的区别
Qt的PushButton的常用的三种响应有pressed,released和clicked. 优先级:pressed>released>clicked 按下按钮pressed函数的内容, ...
- Qt 自定义事件
Qt 自定义事件很简单,同其它类库的使用很相似,都是要继承一个类进行扩展.在 Qt 中,你需要继承的类是 QEvent. 继承QEvent类,你需要提供一个QEvent::Type类型的参数,作为自定 ...
- qt 中的自定义pushbutton
- Qt自定义窗口部件
QtDesigner自定义窗口部件有两种方法:改进法(promotion)和插件法(plugin) 改进法 1.改进法之前,要先写好子类化QSpinBox后的HexspinBox.h和Hexs ...
随机推荐
- FZU 2099 魔法阵(计算几何)
Problem 2099 魔法阵 Accept: 120 Submit: 289 Time Limit: 1000 mSec Memory Limit : 32768 KB Probl ...
- 通过spring boot提供restful api
1 将返回设置为produces = "application/json" 返回给客户端json格式的response. 2 对各种异常的处理 各种异常如何返回给客户端? 各种异常 ...
- JFrame 居中显示
场景: 在利用 JAVA 的 Swing 开发 C/S 架构 的前端界面 目的: 想让 JFrame 居中显示在整个 屏幕的正中位置 方法一:计算窗体的左上角坐标 JFrame fram ...
- 自定义log4j日志级别
转载自: http://blog.csdn.net/seven_cm/article/details/26849821 自定义log4j日志级别 参考了网上资料:http://www.360doc. ...
- Webstorm如何设置背景色为护眼色(豆绿色)
本文主要讲webstorm如何设置背景色. 1.打开idea Settings 选择 Editor——Color Scheme——General 注意:如果是Mac,在webstorm界面按键:“co ...
- nodejs post请求
const http = require('http'); const querystring = require('querystring'); const postData = querystri ...
- chrome浏览器自动填充失效问题
现在浏览器带有自动填充,一般在input标签中增加autocomplete="off" 可以进行控制,off代表不填充,on代表填充,这个属性也可以放在form标签中,对所有的in ...
- spring 登录提示 Bad credentials
spring 日志输出:Authentication failed: password does not match stored value in spring security 3.2,检查密码发 ...
- php 数组 高效随机抽取指定条记录的算法
php使用数组array_rand()函数进行高效随机抽取指定条数的记录,可以随机抽取数据库中的记录,适合进行随机展示和抽奖程序. 该算法主要是利用php的array_rand()函数,下面看一下ar ...
- python3 多线程编程
python / 并发 / 线程 / 对象 / 编程 0.什么是线程 1. 多线程模块 2. 创建线程的方法 3. join()方法 4.isAlive()方法 5. name属性和daemon属 ...