前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >缩放|位移|渐变简单动画

缩放|位移|渐变简单动画

作者头像
Qt君
发布2020-07-24 09:50:03
2.7K0
发布2020-07-24 09:50:03
举报
文章被收录于专栏:跟Qt君学编程

本文简单介绍Qt的一些动画效果(缩放,位移,渐变)。

缩放动画

  • 将窗口的geometry(位置,大小)属性作为动画参考实现缩放动画。
  • 代码
代码语言:javascript
复制
QWidget *w= new QWidget;
w->setWindowTitle(QStringLiteral("缩放动画@Qt君"));
w->resize(320, 240);

QLabel *label = new QLabel(w);
/* 创建一个动画对象 */
QPropertyAnimation *animation = new QPropertyAnimation(label);
/* 设置动画持续时长 */
animation->setDuration(3000);

/* 设置动画目标 */
animation->setTargetObject(label);

/* 设置窗口几何属性(位置,大小)作为动画参考 */
animation->setPropertyName("geometry");

/* 设置动画开始坐标和大小(QRect) */
/* 居中显示数值计算:160 => (320/2 - 100); 120 => (240/2 - 100) */
animation->setStartValue(QRect(160, 120, 0, 0));

/* 设置动画结束坐标和大小(QRect) */
/* 居中显示数值计算(差值是基于开始动画的100/2):160 => (160 - 100/2); 70 => (120 - 100/2) */
animation->setEndValue(QRect(110, 70, 100, 100));

/* 设置循环次数:-1为无限次 */
animation->setLoopCount(-1);
/* 开始动画 */
animation->start();

w->show();

位移动画

  • 将窗口的pos位置作为动画参考实现位移动画。
  • 代码
代码语言:javascript
复制
QWidget *w= new QWidget;
w->setWindowTitle(QStringLiteral("位移动画@Qt君"));
w->resize(320, 240);

QLabel *label = new QLabel(w);
label->resize(100, 100);

/* 创建一个动画对象 */
QPropertyAnimation *animation = new QPropertyAnimation(label);
/* 设置动画目标 */
animation->setTargetObject(label);

/* 设置窗口的位置作为动画参考 */
animation->setPropertyName("pos");

/* 设置动画持续时长 */
animation->setDuration(3000);

/* 设置动画开始位置 */
animation->setStartValue(QPoint(0, 70));

/* 设置动画结束位置 */
animation->setEndValue(QPoint(220, 70));

/* 设置循环次数:-1为无限次 */
animation->setLoopCount(-1);

/* 开始动画 */
animation->start();

w->show();

渐变动画

  • 使用QGraphicsOpacityEffect配合QPropertyAnimation实现渐变动画。
  • 代码
代码语言:javascript
复制
QWidget *w = new QWidget;
w->setWindowTitle(QStringLiteral("渐变动画@Qt君"));
w->resize(320, 240);

/* 创建一个不透明效果对象 */
QGraphicsOpacityEffect *opacityEffect = new QGraphicsOpacityEffect;
opacityEffect->setOpacity(1);

QLabel *label = new QLabel(w);
label->setGeometry(110, 70, 100, 100);
/* 设置控件的图形效果 */
label->setGraphicsEffect(opacityEffect);

/* 创建一个动画对象 */
QPropertyAnimation *animation= new QPropertyAnimation(label);

/* 设置动画目标 */
animation->setTargetObject(opacityEffect);

/* 设置窗口的不透明度作为动画参考 */
animation->setPropertyName("opacity");

/* 设置动画持续时长 */
animation->setDuration(3000);

/* 设置动画开始的不透明度 */
animation->setStartValue(0);

/* 设置动画结束的不透明度 */
animation->setEndValue(1);

/* 设置循环次数:-1为无限次 */
animation->setLoopCount(-1);

/* 开始动画 */
animation->start();

w->show();

动画的几点要素

  1. 动画的目标(setTargetObject);
  2. 动画目标的参考属性(setPropertyName);
  3. 动画的持续时间(setDuration);
  4. 动画的开始状态(setStartValue);
  5. 动画的结束状态(setEndValue);
  6. 动画循环次数(setLoopCount);
  7. 动画的启动与暂停(start/stop)。
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-07-22,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Qt君 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 缩放动画
  • 位移动画
  • 渐变动画
  • 动画的几点要素
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档