1000字范文,内容丰富有趣,学习的好帮手!
1000字范文 > css3扭蛋机 微信小程序 扭蛋抽奖机CSS3动画实现详解_咋地 _前端开发者

css3扭蛋机 微信小程序 扭蛋抽奖机CSS3动画实现详解_咋地 _前端开发者

时间:2020-01-04 03:38:22

相关推荐

css3扭蛋机 微信小程序 扭蛋抽奖机CSS3动画实现详解_咋地 _前端开发者

前言

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

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)

}

}

简单的位移

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

相比丧病的样式,

_this.setData({

start: true

})

控制抽奖开始

setTimeout(() => {

_this.setData({

start: false,

end: true

})

//其他代码部分

//time是接口请求开始到结束的时间

}, Math.ceil(time / 1500) * 1500 - time)

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

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

总结:

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

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

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。