当前位置: 首页 >服务端 > 微信小程序animation有趣的自定义动画

微信小程序animation有趣的自定义动画

这几天在看代码时遇到了一些问题:关于微信小程序的animation自定义动画自己没有系统的学习过

做动画需要我们将一个复杂的动作过程,拆解为一步一步的小节过程

微信中已经为我们写好了端口我们只需要实例化一个动画实例(实例代码如下)

先了解基础部分:

在看代码之前要先有个下面的基础了解

1)wx.createAnimation(object) 微信小程序实例化一个动画效果

2)export( ) 这个方法是导出动画数据(传递给animation属性)

3)step( ) 来表示一组动画完成

微信官网主要属性设置:

微信小程序animation有趣的自定义动画 _ JavaClub全栈架构师技术笔记

这里主要树下timingFunction和transformOrigin

  • timingFunction 设置动画效果

    • linear 默认为linear 动画一直较为均匀
    • ease 开始时缓慢中间加速到快结束时减速
    • ease-in 开始的时候缓慢
    • ease-in-out 开始和结束时减速
    • ease-out 结束时减速
    • step-start 动画一开始就跳到 100% 直到动画持续时间结束 一闪而过
    • step-end 保持 0% 的样式直到动画持续时间结束 一闪而过
  • transformOrigin 设置动画的基点 默认%50 %50 0

    • left,center right是水平方向取值,对应的百分值为left=0%;center=50%;right=100%
    • top center bottom是垂直方向的取值,其中top=0%;center=50%;bottom=100%

动画组及动画方法:

样式:

微信小程序animation有趣的自定义动画 _ JavaClub全栈架构师技术笔记

旋转:

微信小程序animation有趣的自定义动画 _ JavaClub全栈架构师技术笔记

缩放:

微信小程序animation有趣的自定义动画 _ JavaClub全栈架构师技术笔记

偏移:

微信小程序animation有趣的自定义动画 _ JavaClub全栈架构师技术笔记

倾斜:

微信小程序animation有趣的自定义动画 _ JavaClub全栈架构师技术笔记

矩形变形:

微信小程序animation有趣的自定义动画 _ JavaClub全栈架构师技术笔记

官方是这样介绍的:

 1.创建一个动画实例animation。调用实例的方法来描述动画。最后通过动画实例的export方法导出动画数据传递给组件的animation属性。

  这一步是基础:

  1)创建一个animation实例

  2) 调用实例化的方法描述动画

  3)最后通过动画实例的export( )方法导出动画数据传递给{{animation}}

 2.调用动画操作方法后要调用 step( ) 来表示一组动画完成,可以在一组动画中调用任意多个动画方法,一组动画中的所有动画会同时开始,一组动画完成后才会进行下一组动画。step 可以传入一个跟 wx.createAnimation() 一样的配置参数用于指定当前组动画的属性

下面是代码实例:

  HTML

<view class="container">  <view animation="{{animation}}" class="view">我在做动画</view></view><button type="primary" bindtap="rotate">旋转</button>

  JS  

Page({  data:{text:"Page animation",animation: ''  },  onLoad:function(options){// 页面初始化 options为页面跳转所带来的参数  },  onReady:function(){// 页面渲染完成//实例化一个动画this.animation = wx.createAnimation({  // 动画持续时间,单位ms,默认值 400  duration: 1000,/*** http://cubic-bezier.com/#0,0,.58,1 *  linear  动画一直较为均匀*  ease从匀速到加速在到匀速*  ease-in 缓慢到匀速*  ease-in-out 从缓慢到匀速再到缓慢**  http://www.tuicool.com/articles/neqMVr*  step-start 动画一开始就跳到 100% 直到动画持续时间结束 一闪而过*  step-end保持 0% 的样式直到动画持续时间结束一闪而过*/  timingFunction: 'linear',  // 延迟多长时间开始  delay: 100,  /*** 以什么为基点做动画  效果自己演示* left,center right是水平方向取值,对应的百分值为left=0%;center=50%;right=100%* top center bottom是垂直方向的取值,其中top=0%;center=50%;bottom=100%*/  transformOrigin: 'left top 0',  success: function(res) {console.log(res)  }})  },  /*** 旋转*/  rotate: function() {//顺时针旋转10度//this.animation.rotate(150).step()this.setData({  //输出动画  animation: this.animation.export()})  }})

下面是多个动画效果连续执行的效果(有文字描述动画效果)

  /*** 旋转*/  rotate: function() {//两个动画组 一定要以step()结尾/** * 动画顺序 顺时针旋转150度>x,y 放大二倍>x,y平移10px>x,y顺时针倾斜>改变样式和设置宽度宽度 */this.animation.rotate(150).step().scale(2).step().translate(10).step().skew(10).step().opacity(0.5).width(10).step({ducation: 8000})this.setData({  //输出动画  animation: this.animation.export()})  }

 

作者:周十发
来源链接:https://www.cnblogs.com/Webzhoushifa/p/9509997.html

版权声明:
1、JavaClub(https://www.javaclub.cn)以学习交流为目的,由作者投稿、网友推荐和小编整理收藏优秀的IT技术及相关内容,包括但不限于文字、图片、音频、视频、软件、程序等,其均来自互联网,本站不享有版权,版权归原作者所有。

2、本站提供的内容仅用于个人学习、研究或欣赏,以及其他非商业性或非盈利性用途,但同时应遵守著作权法及其他相关法律的规定,不得侵犯相关权利人及本网站的合法权利。
3、本网站内容原作者如不愿意在本网站刊登内容,请及时通知本站(javaclubcn@163.com),我们将第一时间核实后及时予以删除。





本文链接:https://www.javaclub.cn/server/113372.html

分享给朋友:

“微信小程序animation有趣的自定义动画” 的相关文章