这篇文章将为大家详细讲解有关Qt如何实现苹果状态切换按钮的方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
代码如下
#include "button.h"
#include <QDebug>
Button::Button(QWidget *parent) :
QPushButton(parent)
{
status = 0;
span_length = 0;
rl_flag = false;
release_flag =true;
timeline = new QTimeLine;
connect(timeline,SIGNAL(frameChanged(int)),this,SLOT(timeOut(int)));
}
void Button::paintEvent(QPaintEvent *e)
{
QPainter painter(this);
painter.setRenderHint(QPainter::Antialiasing, true);
QPen pen;
pen.setWidth(2);
pen.setColor(QColor(219,219,219));
painter.setPen(pen);
painter.setBrush(Qt::green);
painter.drawRoundedRect(1,1,this->width()-2,this->height()-2,30,30);
painter.setBrush(Qt::white);
painter.setPen(pen);
if(!rl_flag){
switch(status)
{
case 0:painter.drawEllipse(1,1,this->height()-3,this->height()-3);break;
case 1:painter.drawRoundedRect(1,1,span_length,this->height()-2,30,30);break;
case 2:painter.drawEllipse(this->width()+3-this->height(),1,this->height()-3,this->height()-3);rl_flag=true;status=0;break;
}
}else{
switch(status)
{
case 0:painter.drawEllipse(this->width()+3-this->height(),1,this->height()-3,this->height()-3);break;
case 1:painter.drawRoundedRect(this->width()-1-span_length,1,span_length,this->height()-2,30,30);break;
case 2:painter.drawEllipse(1,1,this->height()-3,this->height()-3);rl_flag=false;status=0;break;
}
}
}
void Button::drawSpan(QPainter painter,int s)
{
}
void Button::mousePressEvent(QMouseEvent *e)
{
timeline->setDuration(400);
span_length = 0;
status=1;
if(!rl_flag){
int r1 = this->height()-3;
int r2 = (this->width()/4*3)>r1?(this->width()/4*3):r1;
timeline->setFrameRange(r1,r2);
}else{
int r1 = this->height()-3;
int r2 = (this->width()/4*3)>r1?(this->width()/4*3):r1;//(this->width()/4*1)>r1?(this->width()/4*1):r1;
timeline->setFrameRange(r1,r2);
}
timeline->start();
}
void Button::mouseMoveEvent(QMouseEvent *e)
{
}
void Button::mouseReleaseEvent(QMouseEvent *e)
{
timeline->stop();
status = 2;
update();
}
void Button::timeOut(int x)
{
status = 1;
span_length = x;
update();
}
关于Qt如何实现苹果状态切换按钮的方法就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。