代码拉取完成,页面将自动刷新
/**
* @文件名 push_button.h
* @版本信息 copyright 2012-2013 Sugon. All rights reserved.
* @功能描述
* PushButton类包含最小化、最大化、关闭、主菜单等按钮的特效
* @作者 王亮<wangliang@sugon.com>
* @日期 2012-01-06
*/
#ifndef CS_CSVIEW_PUSHBUTTON_H
#define CS_CSVIEW_PUSHBUTTON_H
#include <QPushButton>
#include <QPainter>
#include <QMouseEvent>
/**
* @功能描述 主要设置按钮样式、特效
* @作者 王亮 <wangliang@sugon.com>
**/
class PushButton : public QPushButton
{
Q_OBJECT
public:
/**
*
* 功能说明
* 构造函数
*
* 参数说明
* QWidget *parent = 0 父窗体
*
* 返回值
* 无
*
*/
explicit PushButton(QWidget *parent = 0);
/**
*
* 功能说明
* 析构函数
*
* 参数说明
* 无
*
* 返回值
* 无
*
*/
~PushButton();
/**
*
* 功能说明
* 加载图标
*
* 参数说明
* QString pic_name 图标名称
*
* 返回值
* 无
*
*/
void loadPixmap(QString pic_name);
protected:
/**
*
* 功能说明
* 鼠标移进事件
*
* 参数说明
* QEvent * event 事件
*
* 返回值
* 无
*
*/
void enterEvent(QEvent *);
/**
*
* 功能说明
* 鼠标移出事件
*
* 参数说明
* QEvent * event 事件
*
* 返回值
* 无
*
*/
void leaveEvent(QEvent *);
/**
*
* 功能说明
* 鼠标按下事件
*
* 参数说明
* QMouseEvent *event 鼠标事件
*
* 返回值
* 无
*
*/
void mousePressEvent(QMouseEvent *event);
/**
*
* 功能说明
* 鼠标释放事件
*
* 参数说明
* QMouseEvent *event 鼠标事件
*
* 返回值
* 无
*
*/
void mouseReleaseEvent(QMouseEvent *event);
/**
*
* 功能说明
* 绘图事件
*
* 参数说明
* QPaintEvent * event 绘图事件
*
* 返回值
* 无
*
*/
void paintEvent(QPaintEvent *);
private:
//枚举按钮的几种状态
enum ButtonStatus{NORMAL, ENTER, PRESS, NOSTATUS};
ButtonStatus status;
QPixmap pixmap;
int btn_width; //按钮宽度
int btn_height; //按钮高度
bool mouse_press; //按钮左键是否按下
};
#endif //CS_CSVIEW_PUSHBUTTON_H
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。