小程序教程

微信小程序把玩(四十)animation API

字号+ 作者: 来源: 2016-11-23 09:49 我要评论( )

动画水还是比较深的,这里只是简单介绍下小程序中动画的一些属性和注意事项,做动画前一定要整理好思路将动画一步步分解,再进行组合!这里只做引入。

wx.createAnimation(object)

  • 看官方介绍

    • 1.创建一个动画实例animation。调用实例的方法来描述动画。最后通过动画实例的export方法导出动画数据传递给组件的animation属性。
    • 2.调用动画操作方法后要调用 step() 来表示一组动画完成,可以在一组动画中调用任意多个动画方法,一组动画中的所有动画会同时开始,一组动画完成后才会进行下一组动画。step 可以传入一个跟 wx.createAnimation() 一样的配置参数用于指定当前组动画的属性


这还是比较好理解的比如第一条对应代码animation: this.animation.export()
第二条比如缩放动画,也就说是一组scale,scaleX, scaleY…为一缩放动画组的一个动画方法,缩放动画组和旋转动画组通过step()链接,按顺序执行。代码中体验吧!看效果反过来看会更容易理解

主要属性:

这里主要树下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%

动画组及动画方法

样式:

旋转:

缩放:

偏移:

倾斜:

矩阵变形:

演示单个动画组效果

wxml


  1. <view class="container">
  2.   <view animation="{{animation}}" class="view">我在做动画</view>
  3. </view>
  4. <button type="primary" bindtap="rotate">旋转</button>
复制代码

js

  1. Page({
  2.   data:{
  3.     text:"Page animation",
  4.     animation: ''
  5.   },
  6.   onLoad:function(options){
  7.     // 页面初始化 options为页面跳转所带来的参数
  8.   },
  9.   onReady:function(){
  10.     // 页面渲染完成
  11.     //实例化一个动画
  12.     this.animation = wx.createAnimation({
  13.       // 动画持续时间,单位ms,默认值 400
  14.       duration: 1000,
  15.       /**
  16.        * http://cubic-bezier.com/#0,0,.58,1  
  17.        *  linear  动画一直较为均匀
  18.        *  ease    从匀速到加速在到匀速
  19.        *  ease-in 缓慢到匀速
  20.        *  ease-in-out 从缓慢到匀速再到缓慢
  21.        *
  22.        *  http://www.tuicool.com/articles/neqMVr
  23.        *  step-start 动画一开始就跳到 100% 直到动画持续时间结束 一闪而过
  24.        *  step-end   保持 0% 的样式直到动画持续时间结束        一闪而过
  25.        */
  26.       timingFunction: 'linear',
  27.       // 延迟多长时间开始
  28.       delay: 100,
  29.       /**
  30.        * 以什么为基点做动画  效果自己演示
  31.        * left,center right是水平方向取值,对应的百分值为left=0%;center=50%;right=100%
  32.        * top center bottom是垂直方向的取值,其中top=0%;center=50%;bottom=100%
  33.        */
  34.       transformOrigin: 'left top 0',
  35.       success: function(res) {
  36.         console.log(res)
  37.       }
  38.     })
  39.   },

  40.   /**
  41.    * 旋转
  42.    */
  43.   rotate: function() {
  44.     //顺时针旋转10度
  45.     //
  46.     this.animation.rotate(150).step()
  47.     this.setData({
  48.       //输出动画
  49.       animation: this.animation.export()
  50.     })
  51.   },

  52.   onShow:function(){
  53.     // 页面显示
  54.   },
  55.   onHide:function(){
  56.     // 页面隐藏
  57.   },
  58.   onUnload:function(){
  59.     // 页面关闭
  60.   }
  61. })
复制代码

演示多个动画组效果

这里我们只需要更改以下代码即可

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


 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • 微信小程序 轮播图 swiper图片组件

    微信小程序 轮播图 swiper图片组件

    2016-11-23 09:49

  • 微信小程序 开发 微信开发者工具 快捷键

    微信小程序 开发 微信开发者工具 快捷键

    2016-11-23 09:49

  • 微信小程序 页面跳转 传递参数

    微信小程序 页面跳转 传递参数

    2016-11-23 09:49

  • 微信小程序 如何获取时间

    微信小程序 如何获取时间

    2016-11-23 09:49

网友点评