微信小程序開發(fā)之麥克風(fēng)動(dòng)畫 幀動(dòng)畫 放大 淡出
想做個(gè)錄音機(jī),第一步就卡在麥克風(fēng)動(dòng)畫這里了.
先上gif.再吐槽.
① 上面gif中聲波的動(dòng)畫是個(gè)半成品.沒有循環(huán)播放.在微信小程序的開發(fā)文檔上找了很久,也沒找到循環(huán)模式的參數(shù)設(shè)置.用setInterval()并不執(zhí)行動(dòng)畫.我在微信小程序文檔 動(dòng)畫最下面找到這么一行字.這個(gè)鍋是不是可以甩出去了?
ps:如果有同學(xué)能實(shí)現(xiàn)動(dòng)畫循環(huán),一定告訴我.
② 麥克風(fēng)里面是個(gè)幀動(dòng)畫.沒有前端的基礎(chǔ),只能用非主流的辦法湊合了.
用wx:if{{}}判斷js中定義的值是不是等于圖片對應(yīng)的數(shù)字來控制圖片的顯示和隱藏.css中應(yīng)該有更好的方法.我css基礎(chǔ)不牢,就不說了.
上代碼:
1.index.wxml
<!--index.wxml--> <view class="voice-style" bindtap="startSpeak"> <image class="bg-style" src="../../images/voice_icon_speaking_bg_normal.png" ></image> <image class="bg-style" animation="{{spreakingAnimation}}" src="../../images/voice_video_loading_0.png"></image> <image class="bg-style" animation="{{spreakingAnimation_1}}" src="../../images/voice_video_loading_0.png"></image> <image class="bg-style" animation="{{spreakingAnimation_2}}" src="../../images/voice_video_loading_0.png"></image> <image class="sound-style" src="../../images/voice_icon_speech_sound_1.png" ></image> <image wx:if="{{j==2}}" class="sound-style" src="../../images/voice_icon_speech_sound_2.png" ></image> <image wx:if="{{j==3}}" class="sound-style" src="../../images/voice_icon_speech_sound_3.png" ></image> <image wx:if="{{j==4}}" class="sound-style" src="../../images/voice_icon_speech_sound_4.png" ></image> <image wx:if="{{j==5}}"class="sound-style" src="../../images/voice_icon_speech_sound_5.png" ></image> </view>
2.index.js
//index.js //獲取應(yīng)用實(shí)例 var app = getApp() Page({ data: { spreakingAnimation: {},//放大動(dòng)畫 j: 1,//幀動(dòng)畫初始圖片 isSpeaking: false,//是否在錄音狀態(tài) }, onLoad: function () { }, //點(diǎn)擊開始說話 startSpeak: function () { var _this = this; if (!this.data.isSpeaking) { speaking.call(this); this.setData({ isSpeaking: true }) } else { //去除幀動(dòng)畫循環(huán) clearInterval(this.timer) this.setData({ isSpeaking: false, j: 1 }) } }, }) function speaking() { //話筒幀動(dòng)畫 var i = 1; this.timer = setInterval(function () { i++; i = i % 5; _this.setData({ j: i }) return }, 200); //波紋放大,淡出動(dòng)畫 var _this = this; var animation = wx.createAnimation({ duration: 1000 }) animation.opacity(0).scale(3, 3).step();//修改透明度,放大 this.setData({ spreakingAnimation: animation.export() }) setTimeout(function(){ //波紋放大,淡出動(dòng)畫 var animation = wx.createAnimation({ duration: 1000 }) animation.opacity(0).scale(3, 3).step();//修改透明度,放大 _this.setData({ spreakingAnimation_1: animation.export() }) },250) setTimeout(function(){ //波紋放大,淡出動(dòng)畫 var animation = wx.createAnimation({ duration: 1000 }) animation.opacity(0).scale(3, 3).step();//修改透明度,放大 _this.setData({ spreakingAnimation_2: animation.export() }) },500) }
3.index.wxss
/**index.wxss**/ .voice-style { margin-top: 400px; display: flex; position: relative; flex-direction: column; align-items: center; } .bg-style { position: absolute; width: 100px; height: 100px; } .sound-style{ position: absolute; width: 37.6px; height: 60px; margin-top: 20px; }
以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時(shí)也希望多多支持腳本之家!
相關(guān)文章
javaScript代碼飄紅報(bào)錯(cuò)看不懂?讀完這篇文章再試試
這篇文章主要介紹了javaScript代碼飄紅報(bào)錯(cuò)看不懂?讀完這篇文章再試試,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08博客側(cè)邊欄模塊跟隨滾動(dòng)條滑動(dòng)固定效果的實(shí)現(xiàn)方法(js+jquery等)
現(xiàn)在很多的獨(dú)立博客和網(wǎng)站如人人網(wǎng)等,都使用了讓側(cè)邊欄模塊隨滾動(dòng)條滑動(dòng)而位置固定的效果2013-03-03完美兼容各大瀏覽器獲取HTTP_REFERER方法總結(jié)
發(fā)現(xiàn)一個(gè)關(guān)于瀏覽器兼容的問題,當(dāng)用JS 執(zhí)行代碼 window.location.href=”http://www.dbjr.com.cn” 來進(jìn)行跳轉(zhuǎn)的時(shí)候,F(xiàn)irefox 可以獲取到到HTTP_REFERER頁面,但是在IE中這一項(xiàng)為空2014-06-06table insertRow、deleteRow定義和用法總結(jié)
這篇文章主要對table insertRow、deleteRow定義和用法做下總結(jié),需要的朋友可以參考下2014-05-05面向?qū)ο罄^承實(shí)例(a如何繼承b問題)(自寫)
經(jīng)常會(huì)看到a如何繼承b的問題;決定寫一下,其實(shí)繼承就是繼承父級(jí)的屬性和方法,感興趣的朋友可以參考下哈,希望對大家有所幫助2013-07-07javascript實(shí)現(xiàn)PC網(wǎng)頁里的拖拽效果
這篇文章主要介紹了javascript實(shí)現(xiàn)PC網(wǎng)頁里的拖拽效果的相關(guān)資料,需要的朋友可以參考下2016-03-03