欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

微信小程序开发之animation循环动画实现的让云朵飘效果

程序员文章站 2023-09-08 19:58:21
本文实例讲述了微信小程序开发之animation循环动画实现的让云朵飘效果。分享给大家供大家参考,具体如下: 微信小程序提供了实现动画的api——animation,但却...

本文实例讲述了微信小程序开发之animation循环动画实现的让云朵飘效果。分享给大家供大家参考,具体如下:

微信小程序提供了实现动画的api——animation,但却不能循环播放,都是一次性的,动完就over了,下面提供一个用微信小程序的animation来实现循环动画的玩具,抛砖引玉,希望大家能想出更好的方法来实现真正的循环。说是玩具是因为这个循环动画通过js脚本的setinterval来实现的,但'setinterval'在实际运行中会出现越来越严重的延迟,这是由于js的单线程运行模式所决定的(具体可以搜本关资料看),所以动画间隙并不是那么流畅,所以先玩玩吧,让我们来实现让云朵飘……

截图如下:

微信小程序开发之animation循环动画实现的让云朵飘效果

实现代码:

index.wxml

<view class="clouds">
   <image animation="{{animationclouddata}}" class="yun1" src="../../img/yun1.png"></image>
  </view>

index.js

onready: function () {
  // 页面渲染完成
  // 实例化一个动画
  var that = this;
  var i = 0
  var ii = 0
  var animationdata = wx.createanimation({
   duration: 1000, // 默认为400   动画持续时间,单位ms
   timingfunction: 'ease-in-out',
   //transformorigin: '4px 91px'
  });
  var animationclouddata = wx.createanimation({
   duration: 1000, // 默认为400   动画持续时间,单位ms
   timingfunction: 'ease-in-out',
   //transformorigin: '4px 91px'
  });
  // 顺序执行,当已经执行完上面的代码就会开启定时器
  // 循环执行代码
  //dotanfun = setinterval(function () {});  
  /*setinterval(function () {
   // 动画脚本定义
   //animationdata.rotate(6 * (++i)).step()
   //animationdata.scale(2, 2).rotate(45).step().scale(1, 1).step();
   animationdata.translatey(10).step({ duration: 500 }).translatey(-10).step({ duration: 500 });
   // 更新数据
   that.setdata({
    // 导出动画示例
    animationdata: animationdata.export(),
    //animationclouddata: animationclouddata.export(),    
   })
   ++i;
   console.log(i);
  }.bind(that), 2000);//循环时间 这里1000是1秒
  */
  //动画的脚本定义必须每次都重新生成,不能放在循环外
  animationclouddata.translatex(200).step({ duration: 5000 }).translatex(0).step({ duration: 5000 });
  // 更新数据
  that.setdata({
   // 导出动画示例
   //animationdata: animationdata.export(),
   animationclouddata: animationclouddata.export(),
  })
  setinterval(function () {
   //动画的脚本定义必须每次都重新生成,不能放在循环外
   animationclouddata.translatex(300).step({ duration: 5000 }).translatex(-100).step({ duration: 5000 });
   // 更新数据
   that.setdata({
    // 导出动画示例
    //animationdata: animationdata.export(),
    animationclouddata: animationclouddata.export(),
   })
   ++ii;
   console.log(ii);
  }.bind(that),10000);//3000这里的设置如果小于动画step的持续时间的话会导致执行一半后出错
}

index.wxss

.clouds{
 margin-top:320rpx; 
}
.yun1{
 width:320rpx;
 height: 120rpx;
}

附:参考备用:

/*
  var that = this;
  // 页面渲染完成
  //实例化一个动画
  var animation = wx.createanimation({
   duration: 1000,
   timingfunction: 'ease',
  })
  this.animation = animation
  animation.scale(2, 2).rotate(45).step().scale(1,1).step();
  //导出动画
  this.setdata({
   animationdata: animation.export()
  })
  var i = 0;
  // 顺序执行,当已经执行完上面的代码就会开启定时器
  /*settimeout(function () {
   that.setdata({
    animationdata: animation.export()
   });
   i++;
   console.log(i);
  }, 1000);*/
  /*setinterval(function () {
   //循环执行代码 
    that.setdata({
     animationdata: animation.export()
    });
   i++;
   console.log(i); 
  }, 1000) //循环时间 这里是1秒  
 }*/

更多关于javascript

更多关于javascript相关内容感兴趣的读者可查看本站专题:《javascript中json操作技巧总结》、《javascript切换特效与技巧总结》、《javascript错误与调试技巧总结》、《javascript数据结构与算法技巧总结》、《javascript遍历算法与技巧总结》及《javascript数学运算用法总结

希望本文所述对大家javascript程序设计有所帮助。