亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

如何使用vue3+uni-app封裝音樂播放插件

 更新時間:2023年11月22日 15:12:28   作者:Destinynever  
UniApp是一個基于Vue.js開發(fā)的跨平臺應(yīng)用開發(fā)框架,它可以使用一套代碼同時構(gòu)建iOS、Android和Web應(yīng)用,這篇文章主要給大家介紹了關(guān)于如何使用vue3+uni-app封裝音樂播放插件的相關(guān)資料,需要的朋友可以參考下

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)文章

最新評論