微信小程序 扭蛋抽奖机css3动画实现详解


Posted in Javascript onJuly 19, 2019

前言

最近快速上线一个抽奖活动,又不想用canvas做,思考了很久,还是决定使用css3的动画来做,只要小球动得快,就没人发现我这些个小球的运动路径都是一样的了。先上动图

微信小程序 扭蛋抽奖机css3动画实现详解

wxml文件:

<view class="ball-box">
  <image class="ball ball_1 {{start?'weiyi_1':''}}" src="https://acceleratepic.miniso.com/miniso/ball1.png"></image>
  <image class="ball ball_2 {{start?'weiyi_2':''}}" src="https://acceleratepic.miniso.com/miniso/ball1.png"></image>
  <image class="ball ball_3 {{start?'weiyi_3':''}}" src="https://acceleratepic.miniso.com/miniso/ball2.png"></image>
  <image class="ball ball_4 {{start?'weiyi_4':''}}" src="https://acceleratepic.miniso.com/miniso/ball2.png"></image>
  <image class="ball ball_5 {{start?'weiyi_5':''}}" src="https://acceleratepic.miniso.com/miniso/ball1.png"></image>
  <image class="ball ball_6 {{start?'weiyi_6':''}}" src="https://acceleratepic.miniso.com/miniso/ball2.png"></image>
  <image class="ball ball_7 {{start?'weiyi_7':''}}" src="https://acceleratepic.miniso.com/miniso/ball3.png"></image>
  <image class="ball ball_8 {{start?'weiyi_8':''}}" src="https://acceleratepic.miniso.com/miniso/ball3.png"></image>
  <image class="ball ball_9 {{start?'weiyi_9':''}}" src="https://acceleratepic.miniso.com/miniso/ball3.png"></image>
  <image class="ball ball_10 {{start?'weiyi_10':''}}" src="https://acceleratepic.miniso.com/miniso/ball4.png"></image>
  <image class="ball ball_11 {{start?'weiyi_11':''}}" src="https://acceleratepic.miniso.com/miniso/ball4.png"></image>
</view>

这个做得我头皮发麻,但是写这篇文章时突然想到,为啥不用个for循环来做呢?!

<view class="ball-box">
 <image wx:for="ballList" wx:for-index="i" class="ball ball_{{i}} {{start?'weiyi_{{i}}':''}}" src="https://acceleratepic.miniso.com/miniso/ball{{i}}.png"></image>
</view>

这样看起来是不是舒服多了,因为是这段代码现场手写,如果有啥bug也不好说。

wxss文件:

.weiyi_1 {
 animation: around1 1.5s linear infinite;
 -webkit-animation: around1 1.5s linear infinite;
}

简单的动画

/* 位移 */

@-webkit-keyframes around1 {
 0% {
 -webkit-transform: translate(0rpx, 0rpx)
 }
 20% {
 -webkit-transform: translate(100rpx, -250rpx)
 }
 40% {
 -webkit-transform: translate(200rpx, -100rpx)
 }
 60% {
 -webkit-transform: translate(50rpx, -230rpx)
 }
 80% {
 -webkit-transform: translate(300rpx, -50rpx)
 }
 100% {
 -webkit-transform: translate(0, 0)
 }
}

@keyframes around1 {
 0% {
 transform: translate(0rpx, 0rpx)
 }
 20% {
 transform: translate(100rpx, -250rpx)
 }
 40% {
 transform: translate(200rpx, -100rpx)
 }
 60% {
 transform: translate(50rpx, -230rpx)
 }
 80% {
 transform: translate(300rpx, -50rpx)
 }
 100% {
 transform: translate(0, 0)
 }
}

简单的位移

其他就不一一列出来了,反正都差不多,改变一下运动轨迹就行了。

js文件:

相比丧病的样式,js文件就简单多了。

_this.setData({
 start: true
})

控制抽奖开始

setTimeout(() => {
  _this.setData({
   start: false,
   end: true
  })
  //其他代码部分
  //time是接口请求开始到结束的时间
}, Math.ceil(time / 1500) * 1500 - time)

这里用了一个setTimeout,用于设置动画结束时间,优化一下动画,不让结束看起来太突兀。

1500是wxss里这是的动画时间。

总结:

简单的扭蛋机,有时间用canvas来做做。

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

Javascript 相关文章推荐
JavaScript 入门基础知识 想学习js的朋友可以参考下
Dec 26 Javascript
js动态在form上插入enctype=multipart/form-data的问题
May 24 Javascript
JavaScript中的getDay()方法使用详解
Jun 09 Javascript
浅谈JavaScript异常处理语句
Jun 26 Javascript
JavaScript File API实现文件上传预览
Feb 02 Javascript
webpack+react+antd脚手架优化的方法
Apr 02 Javascript
微信小程序实现折叠与展开文章功能
Jun 12 Javascript
Vuejs开发环境搭建及热更新【推荐】
Sep 07 Javascript
vue使用v-if v-show页面闪烁,div闪现的解决方法
Oct 12 Javascript
js实现百度淘宝搜索功能
Feb 17 Javascript
js实现车辆管理系统
Aug 26 Javascript
vue组件实现移动端九宫格转盘抽奖
Oct 16 Javascript
Vue配置marked链接添加target=&quot;_blank&quot;的方法
Jul 19 #Javascript
vue-cli 项目打包完成后运行文件路径报错问题
Jul 19 #Javascript
Smartour 让网页导览变得更简单(推荐)
Jul 19 #Javascript
bootstrap Table实现合并相同行
Jul 19 #Javascript
Element-ui DatePicker显示周数的方法示例
Jul 19 #Javascript
element-ui 中使用upload多文件上传只请求一次接口
Jul 19 #Javascript
深入浅析ng-bootstrap 组件集中 tabset 组件的实现分析
Jul 19 #Javascript
You might like
推荐几部必看的DC动画电影
2020/03/03 欧美动漫
Body是什么,该怎么喝出咖啡里的口感
2021/03/03 咖啡文化
PHPMailer安装方法及简单实例
2008/11/25 PHP
PHPMailer 中文使用说明小结
2010/01/22 PHP
php使用exec shell命令注入的方法讲解
2013/11/12 PHP
Zend Framework基本页面布局分析
2016/03/19 PHP
用javascript实现读取txt文档的脚本
2007/07/20 Javascript
js网页版计算器的简单实现
2013/07/02 Javascript
兼容所有浏览器的js复制插件Zero使用介绍
2014/03/19 Javascript
jquery实现带二级菜单的导航示例
2014/04/28 Javascript
JavaScript获取当前url根目录(路径)
2016/06/17 Javascript
javascript 常用验证函数总结
2016/06/28 Javascript
JS如何设置cookie有效期为当天24点并弹出欢迎登陆界面
2016/08/04 Javascript
JS实现自动阅读单词(有道单词本添加功能)
2016/11/14 Javascript
Angular.js前台传list数组由后台spring MVC接收数组示例代码
2017/07/31 Javascript
EasyUI创建人员树的实例代码
2017/09/15 Javascript
微信小程序wx.previewImage预览图片实例详解
2017/12/07 Javascript
使用javascript做在线算法编程
2018/05/25 Javascript
angularjs性能优化的方法
2018/09/05 Javascript
vue实现添加与删除图书功能
2018/10/07 Javascript
jquery.param()实现数组或对象的序列化方法
2018/10/08 jQuery
浅析vue cli3 封装Svgicon组件正确姿势(推荐)
2020/04/27 Javascript
JavaScript字符和ASCII实现互相转换
2020/06/03 Javascript
Python的Bottle框架中实现最基本的get和post的方法的教程
2015/04/30 Python
python实现BP神经网络回归预测模型
2019/08/09 Python
python爬虫 urllib模块反爬虫机制UA详解
2019/08/20 Python
Python线程障碍对象Barrier原理详解
2019/12/02 Python
Python实现aes加密解密多种方法解析
2020/05/15 Python
CSS图片翻转动画技术详解(IE也实现了)
2014/04/03 HTML / CSS
Vita Fede官网:在意大利手工制作,在纽约市设计
2019/10/25 全球购物
创新社会管理心得体会
2014/09/12 职场文书
欢送会主持词
2015/07/01 职场文书
医院病假条怎么写
2015/08/17 职场文书
幼儿体育课教学反思
2016/02/16 职场文书
python生成随机数、随机字符、随机字符串
2021/04/06 Python
Android Flutter实现3D动画效果示例详解
2022/04/07 Java/Android