微信小程序 扭蛋抽獎(jiǎng)機(jī)css3動(dòng)畫實(shí)現(xiàn)詳解
前言
最近快速上線一個(gè)抽獎(jiǎng)活動(dòng),又不想用canvas做,思考了很久,還是決定使用css3的動(dòng)畫來做,只要小球動(dòng)得快,就沒人發(fā)現(xiàn)我這些個(gè)小球的運(yùn)動(dòng)路徑都是一樣的了。先上動(dòng)圖

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>
這個(gè)做得我頭皮發(fā)麻,但是寫這篇文章時(shí)突然想到,為啥不用個(gè)for循環(huán)來做呢?!
<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>
這樣看起來是不是舒服多了,因?yàn)槭沁@段代碼現(xiàn)場手寫,如果有啥bug也不好說。
wxss文件:
.weiyi_1 {
animation: around1 1.5s linear infinite;
-webkit-animation: around1 1.5s linear infinite;
}
簡單的動(dòng)畫
/* 位移 */
@-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)
}
}
簡單的位移
其他就不一一列出來了,反正都差不多,改變一下運(yùn)動(dòng)軌跡就行了。
js文件:
相比喪病的樣式,js文件就簡單多了。
_this.setData({
start: true
})
控制抽獎(jiǎng)開始
setTimeout(() => {
_this.setData({
start: false,
end: true
})
//其他代碼部分
//time是接口請求開始到結(jié)束的時(shí)間
}, Math.ceil(time / 1500) * 1500 - time)
這里用了一個(gè)setTimeout,用于設(shè)置動(dòng)畫結(jié)束時(shí)間,優(yōu)化一下動(dòng)畫,不讓結(jié)束看起來太突兀。
1500是wxss里這是的動(dòng)畫時(shí)間。
總結(jié):
簡單的扭蛋機(jī),有時(shí)間用canvas來做做。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 微信小程序?qū)崿F(xiàn)轉(zhuǎn)盤抽獎(jiǎng)
- 微信小程序開發(fā)之大轉(zhuǎn)盤 仿天貓超市抽獎(jiǎng)實(shí)例
- 微信小程序?qū)崿F(xiàn)簡單九宮格抽獎(jiǎng)
- 微信小程序?qū)崿F(xiàn)走馬燈式抽獎(jiǎng)
- 微信小程序抽獎(jiǎng)組件的使用步驟
- 微信小程序?qū)崿F(xiàn)翻牌抽獎(jiǎng)動(dòng)畫
- 微信小程序?qū)崿F(xiàn)九宮格抽獎(jiǎng)
- 微信小程序?qū)崿F(xiàn)多宮格抽獎(jiǎng)活動(dòng)
- 微信小程序 搖一搖抽獎(jiǎng)簡單實(shí)例實(shí)現(xiàn)代碼
- 微信小程序轉(zhuǎn)盤抽獎(jiǎng)的實(shí)現(xiàn)方法
相關(guān)文章
js實(shí)現(xiàn)html滑動(dòng)圖片拼圖驗(yàn)證
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)html滑動(dòng)圖片拼圖驗(yàn)證,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-06-06
WebStorm中如何將自己的代碼上傳到github示例詳解
這篇文章主要介紹了WebStorm中如何將自己的代碼上傳到github,本文分步驟通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-10-10
koa2服務(wù)端使用jwt進(jìn)行鑒權(quán)及路由權(quán)限分發(fā)的流程分析
這篇文章主要介紹了koa2服務(wù)端使用jwt進(jìn)行鑒權(quán)及路由權(quán)限分發(fā) ,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-07-07
javascript 表格排序和表頭浮動(dòng)效果(擴(kuò)展SortTable)
前段時(shí)間一個(gè)項(xiàng)目有大量頁面用到表格排序和表頭浮動(dòng)的效果,在網(wǎng)上找了幾個(gè)表格排序的js代碼,最后選擇了 Stuart Langridge的SortTable,在SortTable基礎(chǔ)上做了些擴(kuò)展,加上了表頭浮動(dòng)效果及一些小功能。2009-04-04
前端接口報(bào)錯(cuò)Required?request?body?is?missing解決辦法
這篇文章主要給大家介紹了關(guān)于前端接口報(bào)錯(cuò)Required?request?body?is?missing的解決辦法,文中通過代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-12-12
Javascript與vbscript數(shù)據(jù)共享
Javascript與vbscript數(shù)據(jù)共享...2007-01-01

