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

这几天在做小程序时遇到了一些问题:想要实现一个答对题目+5秒、答错题目-5秒的提示动画效果,但是关于微信小程序的animation自定义动画自己没有系统的学习过

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

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

先了解基础部分:

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

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

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

3)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%

动画组及动画方法:

样式: 

 旋转:

 缩放:

偏移:

倾斜:

矩形变形:

官方是这样介绍的:

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

使用步骤:

  1)创建一个animation实例

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

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

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

下面是代码实例:

         HTML

 <view class="header-text {{currentTopicIsCorrect != 0 ? currentTopicIsCorrect == 1 ? 'header-text-yes' : 'header-text-no' : ''}}" animation="{{animationData}}">{{currentTopicIsCorrect == 1 ?'+5' : '-5'}}</view>

JS  


Page({

  /**
   * 页面的初始数据
   */
  data: {
    currentTopicIsCorrect: 0, //当前题是否答对
    animationData: null, //
  },

  //动画效果--淡入淡出
  ani_smallbigOut: function (correct) {
    let that = this

    //实例化一个animation
    var animation = wx.createAnimation({
      duration: 450,// 动画持续时间,单位ms,默认值 400
      /**  
       *  linear  动画一直较为均匀
       *  ease    从匀速到加速在到匀速
       *  ease-in 缓慢到匀速
       *  ease-in-out 从缓慢到匀速再到缓慢
       *  step-start 动画一开始就跳到 100% 直到动画持续时间结束 一闪而过
       *  step-end   保持 0% 的样式直到动画持续时间结束        一闪而过
       */
      timingFunction: 'ease',
    })

    this.animation = animation
    animation.scale(3, 3).opacity(1).step()
    animation.scale(0).step()
    that.setData({
      animationData: animation.export(),
    })

    that.setData({
      currentTopicIsCorrect: 0,
    })

    setTimeout(function () {
      that.setData({
        flag: false,
      })
    }, 1500)

  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad(options) {
    this.ani_smallbigOut(1)
  },

})

 wxss

.header-text {
  margin-top: 12%;
  margin-left: 2%;
  opacity: 0;
}

.header-text-yes {
  color: green;
}

.header-text-no {
  color: red;
}

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值