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

前言

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

804db18ca24b98e125846c5bebb27c76.gif

wxml文件:

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

这样看起来是不是舒服多了,因为是这段代码现场手写,如果有啥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来做做。

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值