Qt自定义圆周动画(360 10.0 的模仿作者写的)
由于项目需求,需要把一张图片做圆周运动,用到了属性动画,坐标计算等。
在编写代码的过程中,由于太长时间没用sin,cos函数忘了是用弧度为单位,汗呀
下面把代码贴出来
- /*
- * 圆周运动动画
- * */
- #ifndef CircleAnimationWidget_H
- #define CircleAnimationWidget_H
- #include <QWidget>
- #define PI 3.1415
- class QPropertyAnimation;
- class CircleAnimationWidget : public QWidget
- {
- Q_OBJECT
- //注册属性,用于动画
- Q_PROPERTY(qreal percent READ percent WRITE setPercent)
- public:
- explicit CircleAnimationWidget(QWidget *parent = 0);
- explicit CircleAnimationWidget(const QString &icon, \
- const qreal &radius, QWidget *parent = 0);
- void setCircleInfo(const QString &icon, const qreal &radius);
- void startAnimation();
- void stopAnimation();
- void setPercent(const qreal &per);
- const qreal &percent()
- {
- return m_percent;
- }
- protected:
- void paintEvent(QPaintEvent *);
- private slots:
- //更新坐标值
- void updatePos();
- private:
- //计算坐标值
- QPoint mathPoint();
- QPoint mathPoint(const QPoint ¢erPos, const qreal &percent, const qreal &radius);
- void initAnimation();
- private:
- qreal m_percent;//百分比
- qreal m_radius;//半径
- QPoint m_centerPos;//圆点坐标
- QPropertyAnimation *m_percentAnimation;
- QPixmap m_pix;
- QPoint m_point;//图片坐标
- QPoint m_originPoint;//图片原始坐标
- };
- #endif // CircleAnimationWidget_H
- #include "circleanimationwidget.h"
- #include <QPainter>
- #include <QPropertyAnimation>
- #include <qmath.h>
- CircleAnimationWidget::CircleAnimationWidget(QWidget *parent) :
- QWidget(parent)
- {
- this->setAttribute(Qt::WA_TranslucentBackground);
- }
- CircleAnimationWidget::CircleAnimationWidget(const QString &icon,\
- const qreal &radius, QWidget *parent) : QWidget(parent)
- {
- this->setAttribute(Qt::WA_TranslucentBackground);
- this->setCircleInfo(icon, radius);
- }
- void CircleAnimationWidget::initAnimation()
- {
- m_percentAnimation = new QPropertyAnimation(this, "percent");
- m_percentAnimation->setDuration(2000);
- m_percentAnimation->setStartValue(0.0);
- m_percentAnimation->setEndValue(1.0);
- m_percentAnimation->setLoopCount(-1); //无限循环,只有调用stop才会停止
- }
- void CircleAnimationWidget::startAnimation()
- {
- m_percentAnimation->start();
- }
- void CircleAnimationWidget::stopAnimation()
- {
- m_percentAnimation->stop();
- m_point = m_originPoint;
- m_percent = 0;
- update();
- }
- void CircleAnimationWidget::setCircleInfo(const QString &icon, const qreal &radius)
- {
- m_pix.load(icon);
- m_percent = 0;
- m_radius = radius;
- int pixW = m_pix.width();
- int pixH = m_pix.height();
- m_centerPos.setX(radius);
- m_centerPos.setY(radius);
- m_originPoint.setX(radius*2);
- m_originPoint.setY(radius);
- m_point = m_originPoint;
- this->setFixedSize(pixW + radius*2, pixH + radius*2);
- this->initAnimation();
- }
- void CircleAnimationWidget::setPercent(const qreal &per)
- {
- m_percent = per;
- updatePos();
- }
- void CircleAnimationWidget::updatePos()
- {
- m_point = mathPoint();
- update();
- }
- QPoint CircleAnimationWidget::mathPoint()
- {
- return this->mathPoint(m_centerPos, m_percent, m_radius);
- }
- QPoint CircleAnimationWidget::mathPoint(const QPoint ¢erPos, const qreal &percent, const qreal &radius)
- {
- qreal dx = radius * qCos(percent * ( 2 * PI)) + centerPos.x();//计算x坐标
- qreal dy = radius * qSin(percent * ( 2 * PI)) + centerPos.y(); // 计算y坐标
- return QPoint(dx, dy);
- }
- void CircleAnimationWidget::paintEvent(QPaintEvent *)
- {
- QPainter painter(this);
- painter.drawPixmap(m_point, m_pix);
- }
http://blog.csdn.net/zhjun5337/article/details/40789979
http://www.qtcn.org/bbs/read-htm-tid-57817-page-1.html
Qt自定义圆周动画(360 10.0 的模仿作者写的)的更多相关文章
- paip.提升用户体验---c++ qt自定义窗体(1)---标题栏的绘制
源地址:http://blog.csdn.net/attilax/article/details/12343625 paip.提升用户体验---c++ qt自定义窗体(1)---标题栏的绘制 效果图: ...
- kafka_2.11-0.10.0.1生产者producer的Java实现
转载自:http://blog.csdn.net/qq_26479655/article/details/52555283 首先导入包 将kafka目录下的libs中的jar包导入 用maven建立 ...
- iOS 10.0 更新点(开发者视角)
html, body {overflow-x: initial !important;}html { font-size: 14px; } body { margin: 0px; padding: 0 ...
- ViewPager无限轮播与自定义切换动画
一直在寻求一个能用得长久的ViewPager,寻寻觅觅终于发现,ViewPager有这一个就够了. 注:并非完全原创 先看一下效果: 淡入淡出: 旋转: 无限轮播的ViewPager 主要设计思路(以 ...
- 还在期待安卓9.0吗?Android 10.0要来了
目前,美国 Google公司的 AndroidP (安卓9.0),已经正式全面推出有几个多月了.众多手机品牌厂商也都在积极的进行更新适配 Android 9.0 系统(修改UI界面也算是二次开发,嗯) ...
- Qt 创建按钮动画
1 封装自定义按钮 myPushBttton 2 构造函数 (默认图片,按下后显示图片) 3 测试开始按钮 4 开始制作特效 5 zoom1 向下弹跳 6 zoom2 向上弹跳 代码如下 main.h ...
- 自定义带动画的Toast
一.style样式: 1. // 移动和透明渐变结合的动画 <style name="anim_view"> <item name="@ ...
- Android 自定义波浪动画 --"让进度浪起来~"
原文链接:http://www.jianshu.com/p/0e25a10cb9f5 一款效果不错的动画,实现也挺简单的,推荐阅读学习~ -- 由 傻小孩b 分享 waveview <Andro ...
- Kafka-0.10.0.0入门
搭建环境略(伪集群即可以),但要注意Kafka的配置必须配置的,少配了也一样可以用,但是只能单机使用,外部机器无法连接,网上也有说. host.name=192.168.1.30 advertised ...
随机推荐
- 如何将Icon转成Bitmap(对ICON的内部格式讲的比较清楚)
最近工作中有个需求是将Icon转成带Alpha通道的Bitmap, 虽然网上有不少这方面的文章,但很多都是错的, 这里记录下,或许对后来人有用. 要实现这个功能,我们首先需要理解Icon的格式,我 ...
- 文本编辑BOM标记(Byte Order Mark)
微软的自带记事本程序notepad.exe会给UTF-8编码的文件头加入三个隐藏的字节(即BOM).这是一种很愚蠢的做法.就是为了让编辑器不去猜测文件本身是ASCII码还是UTF-8. 什么是BOM ...
- (7)如何得到所有的 "水仙花数" ?
本程序转载自:如何得到所有的水仙花数 感谢Android_iPhone(日知己所无),preferme(冰思雨)等人: package test; import java.math.BigIntege ...
- 2015第24周三Spring事务3
在一个典型的事务处理场景中,有以下几个参与者: Resource Manager(RM) ResourceManager简称RM,它负责存储并管理系统数据资源的状态,比如数据库服务器,JMS消息服务器 ...
- C与C++中的const
同样,有下面一段代码: #include <iostream> using namespace std; int main() { ; int *j = (int *) &i; * ...
- programData
以.结束语句输入;
- dbda封装类(包括:返回二维数组、Ajax调用返回字符串、Ajax调用返回JSON)
<?php class DBDA { public $host = "localhost"; public $uid = "root"; public $ ...
- JDBC中Statement接口提供的execute、executeQuery和executeUpdate之间的区别
Statement 接口提供了三种执行 SQL 语句的方法:executeQuery.executeUpdate 和 execute.使用哪一个方法由 SQL 语句所产生的内容决定. 方法execut ...
- hdu 5391 Zball in Tina Town(打表找规律)
问题描述 Tina Town 是一个善良友好的地方,这里的每一个人都互相关心. Tina有一个球,它的名字叫zball.zball很神奇,它会每天变大.在第一天的时候,它会变大11倍.在第二天的时候, ...
- web.xml配置DispatcherServlet
1. org.springframework.web.servlet.DispatcherServlet 所在jar包: <dependency> <groupId>org.s ...