如何使用vue3+uni-app封裝音樂播放插件
1、初始化一個音樂實例
let AUDIO = '' export const initAudio = function (url) { AUDIO = uni.createInnerAudioContext() AUDIO.src = url return AUDIO }
2、將這個初始化的方法添加到全局
app.config.globalProperties.initAudio = initAudio // main.ts/js 文件中
3、封裝組件寫好樣式
<view class="audio-play"> <view class="audio-background"></view> <img class="controls" @click="playAudio" :src="data.isPlay ? data.pauseIcon : data.playIcon" alt="" /> <view class="progress-container"> <view class="playTime">{{ formatTime(data.playTime) }}</view> <!-- value的總數(shù)是100 通過value控制進度條進度 直到最后19/19*100就是進度條滿了 強行進度條總數(shù)規(guī)定成100 --> <slider class="progress" block-size="10" block-color="#69bfbe" activeColor="#ffffff" backgroundColor="#119b9a" :value="(data.playTime / data.trueTime) * 100" @change="sliderChange" /> <view class="totalTime">{{ data.totalTime }}</view> </view> </view>
4、調(diào)用我們放在全局的init方法
import { reactive, onMounted, getCurrentInstance } from 'vue' const { proxy } = getCurrentInstance() as any
通過proxy 可以在vue3中那個我們配置在全局的方法
let a = proxy.initAudio('音頻地址')
此時a就是我們獲取到的音頻實例,并且設(shè)置了我們需要播放的音頻鏈接
5、接下來就是我們可能用到的一些API的介紹
startTime | 開始播放的位置 |
autoplay | 是否自動開始播放,默認(rèn)為false |
loop | 是否循環(huán)播放,默認(rèn)為false |
duration | 當(dāng)前音頻的長度是通過src中音頻返回的,需要在onCanplay中獲取 |
currentTime | 當(dāng)前音頻的播放位置 |
paused | 當(dāng)前是否為暫停或停止?fàn)顟B(tài) true為暫?;蛲V?,false表示正在播放 |
6、需要使用到的方法
play | 播放 |
pause | 暫停 |
seek | 跳轉(zhuǎn)到指定位置 s |
onCanplay | 音頻可以進入播放狀態(tài) |
stop | 停止 |
7、創(chuàng)建音頻
這一步設(shè)置一些關(guān)于播放的配置,例如是否自動播放,但是最重要的是獲取我們時長,但是我在使用的時候發(fā)現(xiàn)直接獲取duration的時候無法成功獲取到,通過百度發(fā)現(xiàn)了下面的方法,通過設(shè)置定時器。
// 創(chuàng)建音頻 const createAudio = function () { a.autoplay = false a.onCanplay(() => { let intervalID = setInterval(function () { if (a.duration !== 0) { console.log(a.duration, '測試') // 設(shè)置總時長 data.totalTime = formatTime(a.duration) data.trueTime = a.duration clearInterval(intervalID) } }, 500) }) }
因為音樂播放時長的展示形式一般為 00:00 形式的,而我們獲取的時長是以s為單位結(jié)束的所以還需要將時間進行格式化處理
// 格式化時間 ---- (00:00的格式) const formatTime = function (data: any) { let minute = '' let second = '' minute = `${Math.floor(data / 60)}` second = `${Math.floor(data % 60)}` if (minute.toString().length === 1) minute = `0${minute}` if (second.toString().length === 1) second = `0${second}` return `${minute}:${second}` }
8、完成播放和暫停功能
定義一個方法用于控制音頻的播放和暫停,isPlay是用于控制我們按鈕切換的狀態(tài),playTime就是當(dāng)前播放時長,trueTime也是總時長
// 播放和暫停 const playAudio = function () { if (data.isPlay) { if (data.trueTime > 0) { console.log('暫停') clearInterval(data.timeupdata) a.pause() data.isPlay = !data.isPlay } } else { console.log('播放') data.timeupdata = setInterval(() => { // 播放時長 data.playTime += 1 // 播放時長超過總時長(秒 ) if (data.playTime >= data.trueTime) { // 不循環(huán)播放 a.stop() data.isPlay = false data.playTime = 0 clearInterval(data.timeupdata) // 循環(huán)播放 // this.isPlay = false // this.playTime = 0 // clearInterval(this.timeupdata) // this.playAudio() } }, 1000) a.play() data.isPlay = !data.isPlay } }
9、進度條設(shè)置
直接使用uni-app的內(nèi)置組件slider就可以實現(xiàn)進度條的效果
slider的value屬性需要傳的是數(shù)字,進度條的最大值為100
我們可以使用(data.playTime / data.trueTime) * 100 計算當(dāng)前的時長
就是相當(dāng)于將data.trueTime分成data.trueTime等份
<slider class="progress" block-size="10" block-color="#ffb218" activeColor="#ffffff" backgroundColor="#d27e4a" :value="(data.playTime / data.trueTime) * 100" @change="sliderChange" />
通過sidler的change的方法控制進度條的拖動,并且改變音樂的進度
這里的second將就是將總時長播放到百分之幾賦值給second
// 控制進度條 const sliderChange = function (e: any) { console.log('value 發(fā)生變化:' + e.detail.value) // 直到進度條到達100的時候才能獲得總時長 const second = (e.detail.value / 100) * data.trueTime data.playTime = second // 跳轉(zhuǎn)到某一秒 a.seek(second) }
總結(jié)
到此這篇關(guān)于如何使用vue3+uni-app封裝音樂播放插件的文章就介紹到這了,更多相關(guān)vue3 uni-app封裝音樂播放插件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue-element-admin登錄攔截設(shè)置白名單方式
這篇文章主要介紹了vue-element-admin登錄攔截設(shè)置白名單方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-03-03Vue3?Radio單選切換展示不同內(nèi)容實現(xiàn)代碼
這篇文章主要介紹了Vue3?Radio單選切換展示不同內(nèi)容,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-07-07Vue2.0 v-for filter列表過濾功能的實現(xiàn)
今天小編就為大家分享一篇Vue2.0 v-for filter列表過濾功能的實現(xiàn),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-09-09詳解vue-router2.0動態(tài)路由獲取參數(shù)
本篇文章主要介紹了詳解vue-router2.0動態(tài)路由獲取參數(shù),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-06-06nuxt.js 在middleware(中間件)中實現(xiàn)路由鑒權(quán)操作
這篇文章主要介紹了nuxt.js 在middleware(中間件)中實現(xiàn)路由鑒權(quán)操作,具有很好的參考價值,希望大家有所幫助。一起跟隨小編過來看看吧2020-11-11