Qt实现自定义按钮的三态效果

Qt实现自定义按钮的三态效果

好久之前做的一个小软件,好长时间没动过了,在不记录下有些细节可能都忘了,这里整理下部分功能的实现。 按钮的三态,指的是普通态、鼠标的停留态、点击态,三态是界面交互非常基本的一项功能,Qt中如果使用的是原始的按钮,三态的效果是有的,鼠标放上去会变色,点击的时候有凹陷的效果,工具栏中的图标也具备三态效果,但是如果自定义的图标这个效果就没有了。 下面整理下自定义按钮图标的方法,先看下我做的效果图: 图中表示了鼠标放在按钮上和按下的效果,完成了基本的三态,下面说下我的具体实现过程。 资源准备 首先要准备好对应状态的按钮图标,按钮图标可以从网上搜集,图标需要找png格式的,ico格式的可以使用工具转换为png格式的,而且是背景透明的png格式,要想实现不同状态对应不同的效果还需要处理出其他状态,这就得靠PS来完成了,使用PS也非常简单,我这里使用PS的内阴影来实现按下的效果,用斜面和浮雕来实现鼠标停留效果。具体设置如下面两幅图所示: 图:使用内阴影实现的按下效果 图:使用斜面和浮雕实现的鼠标停留效果 处理好后的图标如下图。 加入工程 将处理好的图标文件放入工程文件夹下,新建Qt-Qt资源文件。 输入文件名保存并加入工程。依次添加前缀,添加文件将文件

加入工程,如下图所示。 这些文件添加到工程后就可以在界面设计中使用,很多人在界面设计中改变按钮的样式会直接选择按钮图标,如下图所示。 通过选择按钮的icon设置对应大小来实现,然而这样的一个效果就是按钮仍然是有背景和边框的,效果如下图所示。 因此很多人的实现方法是通过继承QToolButton或者重绘按钮来实现,然而这些操作仍然相对麻烦,经过对比和查找,这里使用StyleSheet来实现。 找到对应的按钮,先在界面编辑中编辑对应的样式表,这里添加border-image,对应普通情况下的按钮图标。 然后在主程序中在按钮使用之前指定其他两种状态所对应的图标,代码非常直接,就是指定每种状态对应的文件,QPushButton:hover标示鼠标悬停所对应的状态,QPushButton:pressed则对应鼠标点击的状态,代码如下,注意包含的头文件。 #include

ui->play_button->setStyleSheet(\ge: url(:/new/icons/icons/play-pause.png);}\ \

url(:/new/icons/icons/play-pause-hover.png);}\ \

url(:/new/icons/icons/play-pause-pressed.png);}\

void MainWindow::button_init() {

ui->play_button->setStyleSheet(\ge: url(:/new/icons/icons/play.png);}\ %url(:/new/icons/icons/play-hover.png);}\ %url(:/new/icons/icons/play-pressed.png);}\

ui->rec_button->setStyleSheet(\e: url(:/new/icons/icons/play-rec.png);}\ %url(:/new/icons/icons/play-rec-hover.png);}\ %url(:/new/icons/icons/play-rec-pressed.png);}\

联系客服:779662525#qq.com(#替换为@) 苏ICP备20003344号-4