QPushButton

简介

QPushButton是一个按钮类,基类是QAbstractButton:提供通用的按钮功能;

常用函数

常用属性详解
void setText(const QString &text)设置按钮文本
QString text() const返回按钮上的文本
void setIcon(const QIcon &icon)设置按钮图表
QIcon icon() const;返回按钮图表
void setMenu(QMenu* menu)设置菜单
void setFlat(bool);设置按钮是否有边框,默认false表示有,true表示无
void setCheckable(bool)默认是false为触发式按钮,true为切换按钮(可以使用toggled(bool)信号)
move(int x, int y)指定按钮基于父窗口的位置
void setDisabled(bool)禁用按钮
void setEnabled(bool)可用按钮

信号和槽

信号详解
pressed()按钮按下时触发
released()按钮松开时触发
clicked(bool checked = false)按钮按下并松开后触发
toggled(bool checked)只有当切换按钮被按下时才会触发此信号
槽函数详解
click()单击按钮
toggle()单击切换按钮
setIconSize(const QSize &size)设置图表大小
setChecked(bool)设置按钮是否被选中
setMenu(QMenu *menu)设置菜单

示例

请添加图片描述

//创建按钮
QPushButton *pBtn = new QPushButton;
//设置父类
pBtn->setParent(this);
//设置按钮的文本
pBtn->setText("测试按钮");
//设置图标
pBtn->setIcon(QIcon(":/images/1.png"));
//设置图标大小
pBtn->setIconSize(QSize(48,48));
//设置按钮大小
pBtn->resize(125,48);
//移动位置
pBtn->move(100,100);


//添加菜单项
QMenu *menu = new QMenu();
menu->addAction("我是谁");
menu->addAction("我在哪");
menu->addAction("关闭");
pBtn->setMenu(menu);

//绑定信号槽
connect(pBtn,&QPushButton::pressed,pBtn,&QPushButton::hide);

QSS

常见

在这里插入图片描述

QPushButton{  /*常态*/
        border-radius: 4px; 
        border: none;
        width: 75px;
        height: 25px;
		color:white;
		background:rgb(96,96,96);

}
QPushButton:hover{  /*鼠标悬浮时*/
        background: rgb(49,106,234);
}
QPushButton:pressed{  /*鼠标按下时*/
        background:rgb(96,96,96);
}
QPushButton:!enabled {   /*按钮禁用时*/
        background: rgb(100, 100, 100);
        color: rgb(200, 200, 200);
}

不规则按钮

在这里插入图片描述

//创建按钮
QPushButton *pBtn = new QPushButton(this);
//设置按钮大小
pBtn->resize(48,48);
//设置样式,通过border-image设置图片,又因为图片本身背景色透明,所以产生不规则按钮效果
pBtn->setStyleSheet("QPushButton{ border-image:url(:/images/2.png)}"
                    "QPushButton::pressed{border-image:url(:/images/3.png)}");

鼠标悬停按钮放大

在这里插入图片描述

QPushButton{
	border-image: url(:/bcp.png); /*必须设置图片*/
	background:transparent;
}
QPushButton:hover{
	border-width: -5px -5px -5px -5px; /*负数变大,正数变小*/
}
  • 2
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值