微信小程序 Animation实现图片旋转动画示例


Posted in Javascript onAugust 22, 2018

最近小程序中有一个图片旋转的需求,最初是想着通过切换多张图片达到旋转的效果,后来发现微信小程序带有动画api,然后就改由image+Animation来实现。

首先在wxml中定义image

<image class="bth_image2" mode="aspectFit" animation="{{animation}}" src='../../images/***.png'></image>

注意其中的animation属性,image就由它来实现动画。

而{{animation}}我们在js的data中定义

data: {
  animation: ''
},

改变animation的值(官网提供角度范围是-180~180,但是我发现角度越大会一直旋转)

onShow: function() {
    console.log('index---------onShow()')
     this.animation = wx.createAnimation({
     duration: 1400,
     timingFunction: 'linear', // "linear","ease","ease-in","ease-in-out","ease-out","step-start","step-end"
     delay: 0,
     transformOrigin: '50% 50% 0',
     success: function(res) {
      console.log("res")
     }
    })
   },
   rotateAni: function (n) {
    console.log("rotate=="+n)
    this.animation.rotate(180*(n)).step()
    this.setData({
     animation: this.animation.export()
    })
   },

相关代码

var _animation;
var _animationIndex
const _ANIMATION_TIME = 500;
pages {
...
 onShow: function () {
  _animation = wx.createAnimation({
   duration: _ANIMATION_TIME,
   timingFunction: 'linear', // "linear","ease","ease-in","ease-in-out","ease-out","step-start","step-end"
   delay: 0,
   transformOrigin: '50% 50% 0'
})
},

/**
 * 实现image旋转动画,每次旋转 120*n度
 */
 rotateAni: function (n) {
  _animation.rotate(120 * (n)).step()
this.setData({
   animation: _animation.export()
})
},

/**
 * 开始旋转
 */
 startAnimationInterval: function () {
var that = this;
  that.rotateAni(++_loadImagePathIndex); // 进行一次旋转
  _animationIntervalId = setInterval(function () {
   that.rotateAni(++_loadImagePathIndex);
}, _ANIMATION_TIME); // 没间隔_ANIMATION_TIME进行一次旋转
},

/**
 * 停止旋转
 */
 stopAnimationInterval: function () {
if (_animationIntervalId> 0) {
   clearInterval(_animationIntervalId);
   _animationIntervalId = 0;
}
},
}

微信自带的Animation可以实现一次动画,然后可以通过setInterval来达到不断旋转的目的,在使用时,控制startAnimationInterval和stopAnimationInterval即可。

注意:

这里为什么不直接给_animation.rotate(120 * (n)).step()设置一个足够大的值,原因有两点:

1、我们需要便利的控制开始和停止,

2、animation在小程序进入后台后,会持续运行,占用手机内存和cpu,而小程序依赖于微信,在iphone上会导致微信被终止运行

在使用animation时,会发现有时候出现旋转速度很快或者反向旋转再正向旋转的清空,这都是由于rotate的值设置有问题。

1、rotate的值应该是上一次结束时的值,
2、如果设置了全局变量,记得在oncreate时初始化,不然第二次打开同一页面会有问题。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript 获取事件对象的注意点
Jul 29 Javascript
jquery 获取 outerHtml 包含当前节点本身的代码
Oct 30 Javascript
javascript的 {} 语句块详解
Feb 27 Javascript
JS获取当前脚本文件的绝对路径
Mar 02 Javascript
BootStrap表单宽度设置方法
Mar 10 Javascript
从零开始做一个pagination分页组件
Mar 15 Javascript
Bootstrap 3浏览器兼容性问题及解决方案
Apr 11 Javascript
微信小程序实现折叠展开效果
Jul 19 Javascript
vue的style绑定background-image的方式和其他变量数据的区别详解
Sep 03 Javascript
JavaScript中this函数使用实例解析
Feb 21 Javascript
Vue+Element UI 树形控件整合下拉功能菜单(tree + dropdown +input)
Aug 28 Javascript
vue任意关系组件通信与跨组件监听状态vue-communication
Oct 18 Javascript
Vue动态获取width的方法
Aug 22 #Javascript
微信小程序调用摄像头隐藏式拍照功能
Aug 22 #Javascript
Vue2.2.0+新特性整理及注意事项
Aug 22 #Javascript
Vue之mixin全局的用法详解
Aug 22 #Javascript
React中使用UEditor百度富文本的方法
Aug 22 #Javascript
VUE 全局变量的几种实现方式
Aug 22 #Javascript
详解使用VUE搭建后台管理系统(vue-cli更新至3.0)
Aug 22 #Javascript
You might like
PHP中cookie和session的区别实例分析
2014/08/28 PHP
php表单加入Token防止重复提交的方法分析
2016/10/10 PHP
PHP结合Ueditor并修改图片上传路径
2016/10/16 PHP
tp5实现微信小程序多图片上传到服务器功能
2018/07/16 PHP
Laravel框架Request、Response及Session操作示例
2019/05/06 PHP
PHP使用DOM对XML解析处理操作示例
2019/07/04 PHP
Centos7安装swoole扩展操作示例
2020/03/26 PHP
JavaScript入门学习书籍推荐
2008/06/12 Javascript
基于JavaScript实现继承机制之构造函数方法对象冒充的使用详解
2013/05/07 Javascript
JQuery实现左右滚动菜单特效
2015/09/28 Javascript
jQuery插件Validate实现自定义校验结果样式
2016/01/18 Javascript
js如何准确获取当前页面url网址信息
2020/09/13 Javascript
详解vue父子模版嵌套案例
2017/03/04 Javascript
Vue中的$set的使用实例代码
2018/10/08 Javascript
深入浅析nuxt.js基于ssh的vue通用框架
2019/05/21 Javascript
python append、extend与insert的区别
2016/10/13 Python
浅谈flask截获所有访问及before/after_request修饰器
2018/01/18 Python
Python实现的随机森林算法与简单总结
2018/01/30 Python
利用Pyhton中的requests包进行网页访问测试的方法
2018/12/26 Python
python3使用flask编写注册post接口的方法
2018/12/28 Python
python定时截屏实现
2020/11/02 Python
Django多个app urls配置代码实例
2020/11/26 Python
Python urllib request模块发送请求实现过程解析
2020/12/10 Python
纯CSS绘制漂亮的圆形图案效果
2014/05/07 HTML / CSS
美国皮靴公司自1863年:The Frye Company
2016/11/30 全球购物
AC Lens:购买隐形眼镜
2017/02/26 全球购物
双立人美国官方商店:ZWILLING集团餐具和炊具
2020/05/07 全球购物
金融专业个人求职信
2013/09/22 职场文书
创先争优制度
2014/01/21 职场文书
保密工作实施方案
2014/02/24 职场文书
学历公证书范本
2014/04/09 职场文书
保护水资源的标语
2014/06/17 职场文书
机械机修工岗位职责
2014/08/03 职场文书
公司管理建议书
2015/09/14 职场文书
2016年大学迎新晚会工作总结
2015/10/15 职场文书
python爬虫请求库httpx和parsel解析库的使用测评
2021/05/10 Python