欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

微信小程序多音頻播放進(jìn)度條問(wèn)題

 更新時(shí)間:2018年08月28日 11:16:35   作者:christalfuller  
小程序的音頻組件居然沒(méi)有進(jìn)度控制的功能,需要我們自己實(shí)現(xiàn),下面腳本之家小編給大家?guī)?lái)了微信小程序多音頻播放進(jìn)度條問(wèn)題,感興趣的朋友一起看看吧

真的腦子疼,小程序的音頻組件居然沒(méi)有進(jìn)度控制的功能,網(wǎng)上的方法又很少,邏輯通了就好寫了。

1.所有音頻播放、停止按鈕使用狀態(tài)切換控制
2.當(dāng)點(diǎn)擊某個(gè)音頻播放時(shí),首先將所有音頻的狀態(tài)置為停止?fàn)顟B(tài),然后將當(dāng)前音頻置為播放狀態(tài)
3.滾動(dòng)條插件配合音頻控件一起使用
4.播放狀態(tài)時(shí)滾動(dòng)條的長(zhǎng)度隨音頻進(jìn)度變化而變化,時(shí)間也要顯示
5.拖動(dòng)滾動(dòng)條時(shí),音頻的當(dāng)前時(shí)間隨滾動(dòng)條變化而變化

1.wxml

<text class="left_text">{{item.currentProcess}}</text>
        <slider class="slider_middle" bindchange="changeSlide" bindtouchstart="start" bindtouchend="end" max="{{item.totalProcessNum}}" min="0" value="{{item.currentProcessNum}}" disabled="{{item.canSlider}}" block-size  ="18" data-index="{{index}}"></slider>
        <text class="right_text">{{item.totalProcess}}</text>
        <image class="audio_btn" wx:if="{{!item.showAudio}}" src="../assets/play.png" data-src="{{item.src}}" bindtap="playAudio" data-index = "{{index}}"></image>
        <image class="audio_btn" wx:else src="../assets/pause.png" bindtap="pauseAudio" data-index = "{{index}}"></image>

2.js

 videoControl(e) {//控制視頻播放,需求更改后暫時(shí)無(wú)用
  let src = e.currentTarget.dataset.src
  let img = e.currentTarget.dataset.post
  let data = this.data.cc
  let that = this
  if (this.data.innerAudioContext2){
   that.data.innerAudioContext2.stop()
  }
  if (this.data.innerAudioContext) {
   that.data.innerAudioContext.stop()
   that.setUser(that.data.oldid, false)
  }
  for(var i = 0;i<data.length;i++){
   if (data[i].type == '2'){
    data[i].play = true
   }
  }
  this.setData({
   cc:data
  })
  if(this.data.type){
   wx.navigateTo({
    url: '/pages/record/record?cid=' + this.data.cid + '&src=' + src + '&img=' + img + '&type="share"'
   })
  }else{
   wx.navigateTo({
    url: '/pages/record/record?cid=' + this.data.cid + '&src=' + src + '&img=' + img
   })
  }
 },
 audioControl(e) {//控制課程音頻播放,需求更改后暫時(shí)無(wú)用
  let index = e.currentTarget.dataset.index
  let that = this
  let data = this.data.cc
  if (this.data.innerAudioContext) {
   that.data.innerAudioContext.stop()
   that.setUser(that.data.oldid, false)
  }
   for (var i = 0; i < data.length; i++) {
    if (data[i].type == '2' && i != index) {
     data[i].play = true
    } else if (data[i].type == '2') {
     data[i].play = false
    } if (data[i].type == '3') {
     data[i].play = true
    } 
   }
  if (!that.data.innerAudioContext2) {//第一次點(diǎn)擊音頻
   that.data.innerAudioContext2 = wx.createInnerAudioContext();
   that.data.innerAudioContext2.src = e.currentTarget.dataset.srcs
   that.data.innerAudioContext2.play()
   that.data.innerAudioContext2.onPlay(()=>{
   })
   that.data.innerAudioContext2.onStop(() => {
   })
   that.setData({//記錄當(dāng)前點(diǎn)擊項(xiàng)和上次點(diǎn)擊項(xiàng)
    newid2: e.currentTarget.dataset.index,
    oldid2: that.data.newid2 ? that.data.newid2 : index
   })  
  } else {//非第一次點(diǎn)擊
   let old = that.data.newid2
   that.setData({
    newid2: index,
    oldid2: old
   })
   if (that.data.oldid2 != index ) {
    that.data.innerAudioContext2.stop()
    that.data.innerAudioContext2.src = e.currentTarget.dataset.srcs
    that.data.innerAudioContext2.play()
   }else{
    if (that.data.innerAudioContext2.paused){
     that.data.innerAudioContext2.stop()
     that.data.innerAudioContext2.src = e.currentTarget.dataset.srcs
     that.data.innerAudioContext2.play()
    }else{
     that.data.innerAudioContext2.stop() 
     for (var i = 0; i < data.length; i++) {
      data[i].play = true
     }
    }
   }
  }
  this.setData({
   cc: data
  })
 },
 playAudio(e){//帶滾動(dòng)條多個(gè)音頻處理問(wèn)題
  let that = this
  let arr = that.data.cc
  let index = e.currentTarget.dataset.index
  if (that.data.audio) {//將所有的音頻停止
   that.data.audio.pause()
  }
  for(let i=0;i<arr.length;i++){//將所有的音頻置為停止?fàn)顟B(tài)
   that.setAudioType(i,false,true)
  }
  that.setAudioType(index,true,false)//將當(dāng)前音頻置為播放狀態(tài)
  that.data.audio = wx.getBackgroundAudioManager();//初始化音頻并播放
  that.data.audio.src = e.currentTarget.dataset.src
  that.data.audio.title = '泰格英語(yǔ)'
  that.data.audio.epname = '泰格英語(yǔ)'
  that.data.audio.autoplay = true
  that.data.audio.play();
  //音頻開(kāi)始播放的時(shí)間
  if (arr[index].currentProcessNum != 0){
   that.data.audio.startTime = arr[index].currentProcessNum
  }
  //音頻自然播放結(jié)束
  that.data.audio.onEnded(function name(params) {
   that.setCurrent(index, "00:00", 0)
   that.setAudioType(index,false,false)
  })
  //音頻進(jìn)度播放更新
  that.data.audio.onTimeUpdate(function () {
   //設(shè)置總時(shí)長(zhǎng)
   if(arr[index].totalProcess == '00:00' || arr[index].totalProcessNum == '00:00'){
    that.setTotal(index,that.time_to_sec(that.data.audio.duration), that.data.audio.duration)
   }
   //沒(méi)有觸動(dòng)滑動(dòng)事件更新進(jìn)度
   if(!arr[index].isMove){
    that.setCurrent(index,that.time_to_sec(that.data.audio.currentTime), that.data.audio.currentTime)
   }
  })
 },
 //開(kāi)始滑動(dòng)觸發(fā)
 start : function (e) {
  let arr = this.data.cc
  let index = e.currentTarget.dataset.index
  this.move(index,true)
 },
 //觸發(fā)滑動(dòng)條
 changeSlide : function (e) {
  let that = this
  let arr = that.data.cc
  let index = e.currentTarget.dataset.index
  const position = e.detail.value
  let seek = arr[index].seek
  seek = position
  if (seek != -1) {
   wx.seekBackgroundAudio({
    position: Math.floor(position),
   })
   seek = -1
  }
  that.setCurrent(index,that.time_to_sec(position), position)
  that.seek(index,seek)
 },
 //結(jié)束滑動(dòng)觸發(fā)
 end : function (e) {
  let arr = this.data.cc
  let index = e.currentTarget.dataset.index
  this.move(index, false)
 },
 //停止播放音頻
 pauseAudio:function (e) {
  let that = this
  let index = e.currentTarget.dataset.index
  that.data.audio.pause()
  that.setAudioType(index,false,true)
 },
 //設(shè)置音頻圖片狀態(tài)以及滾動(dòng)條可播放狀態(tài)函數(shù)
 setAudioType: function (index, tag, tagSlide, ) {
  let that = this
  let arrs = that.data.cc
  arrs[index].showAudio = tag
  arrs[index].canSlider = tagSlide
  that.setData({
   cc:arrs
  })
 },
 //設(shè)置音頻當(dāng)前播放時(shí)間以及滾動(dòng)條當(dāng)前位置函數(shù)
 setCurrent: function (index,currentProcess, currentProcessNum) {
  let that = this
  let arrs = that.data.cc
  arrs[index].currentProcess = currentProcess
  arrs[index].currentProcessNum = currentProcessNum
  that.setData({
   cc: arrs
  })
 },
 //設(shè)置音頻總播放時(shí)間以及滾動(dòng)條總位置函數(shù)
 setTotal: function (index,totalProcess, totalProcessNum) {
  let that = this
  let arrs = that.data.cc
  arrs[index].totalProcess = totalProcess
  arrs[index].totalProcessNum = totalProcessNum
  that.setData({
   cc: arrs
  })
 },
 //設(shè)置滾動(dòng)條是否滾動(dòng)狀態(tài)函數(shù)
 move:function (index,isMove) {
  let that = this
  let arrs = that.data.cc
  arrs[index].isMove = isMove
  that.setData({
   cc: arrs
  })
 },
 //設(shè)置音頻時(shí)間點(diǎn)函數(shù)
 seek: function (index, seek) {
  let that = this
  let arrs = that.data.cc
  arrs[index].seek = seek
  that.setData({
   cc: arrs
  })
 },

總結(jié)

以上所述是小編給大家介紹的微信小程序多音頻播放進(jìn)度條問(wèn)題,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • Bootstrap table右鍵功能實(shí)現(xiàn)方法

    Bootstrap table右鍵功能實(shí)現(xiàn)方法

    這篇文章主要為大家詳細(xì)介紹了Bootstrap table右鍵功能的實(shí)現(xiàn)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • JavaScript如何實(shí)現(xiàn)圖片處理與合成

    JavaScript如何實(shí)現(xiàn)圖片處理與合成

    這篇文章主要介紹了JavaScript如何實(shí)現(xiàn)圖片處理與合成,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-05-05
  • Python要求每行輸出5個(gè)的示例代碼

    Python要求每行輸出5個(gè)的示例代碼

    本文從列表、字符串和數(shù)字三個(gè)方面詳細(xì)闡述了Python中要求每行輸出5個(gè)的相關(guān)內(nèi)容,并給出了相應(yīng)的代碼示例,在實(shí)際開(kāi)發(fā)中,我們可以根據(jù)具體的需求靈活運(yùn)用這些方法,以提高程序的輸出效率和可讀性,需要的朋友可以參考下
    2020-05-05
  • JS 數(shù)組和對(duì)象的深拷貝操作示例

    JS 數(shù)組和對(duì)象的深拷貝操作示例

    這篇文章主要介紹了JS 數(shù)組和對(duì)象的深拷貝操作,結(jié)合實(shí)例形式分析了JS 數(shù)組和對(duì)象的深拷貝基本原理與操作技巧,需要的朋友可以參考下
    2020-06-06
  • require.js 加載過(guò)程與使用方法介紹

    require.js 加載過(guò)程與使用方法介紹

    require.js是javascript模塊化編程中常用的一個(gè)JS庫(kù)。這篇文章主要介紹了require.js 加載過(guò)程與使用方法,需要的朋友可以參考下
    2018-10-10
  • JavaScript之不可靠的undefined

    JavaScript之不可靠的undefined

    這篇文章主要介紹了JavaScript之不可靠的undefined,想深入JS的同學(xué),可以參考下
    2021-05-05
  • js去字符串前后空格的實(shí)現(xiàn)方法

    js去字符串前后空格的實(shí)現(xiàn)方法

    這篇文章主要介紹了js去字符串前后空格的實(shí)現(xiàn)方法,重點(diǎn)推薦使用正則的方式,感興趣的小伙伴們可以參考一下
    2016-02-02
  • 微信小程序?qū)崿F(xiàn)橫屏和豎屏簽名功能

    微信小程序?qū)崿F(xiàn)橫屏和豎屏簽名功能

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)橫屏和豎屏簽名功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • JS動(dòng)態(tài)添加元素及綁定事件造成程序重復(fù)執(zhí)行解決

    JS動(dòng)態(tài)添加元素及綁定事件造成程序重復(fù)執(zhí)行解決

    這篇文章主要給大家介紹了關(guān)于JS動(dòng)態(tài)添加元素及綁定事件造成程序重復(fù)執(zhí)行的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。
    2017-12-12
  • 簡(jiǎn)單談?wù)刯avascript高級(jí)特性

    簡(jiǎn)單談?wù)刯avascript高級(jí)特性

    看過(guò)很多關(guān)于js高級(jí)特性介紹的文章,本文是個(gè)人感覺(jué)最通俗易懂的,這里分享給大家,希望大家能夠喜歡
    2019-09-09

最新評(píng)論