溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

better-scroll如何實現歌詞聯動功能

發布時間:2020-07-28 15:05:22 來源:億速云 閱讀:292 作者:小豬 欄目:web開發

這篇文章主要講解了better-scroll如何實現歌詞聯動功能,內容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。

BetterScroll 是一款重點解決移動端(已支持 PC)各種滾動場景需求的插件。它的核心是借鑒的 iscroll 的實現,它的 API 設計基本兼容 iscroll,在 iscroll 的基礎上又擴展了一些 feature 以及做了一些性能優化。

BetterScroll 是使用純 JavaScript 實現的,這意味著它是無依賴的。

正文

前段時間公司要做個歌詞標記功能,標記副歌、前奏、無效內容等等。找了找沒有找到類似的實現,只能自己實現一把。

功能已經上線了,這里記錄一下用到的相關內容。

需求

  • 可以拖動進度條修改播放進度
  • 可以拖動歌詞來修改播放進度
  • 播放時滾動歌詞
  • 標記功能

測試地址:https://www.lilnong.top/stati ...

better-scroll如何實現歌詞聯動功能

實現

技術棧是 Vue + vant + better-scroll。
開始調研的時候使用 vantPicker 來實現了一下,發現滾動歌詞的時候沒有動畫,很難受改用了 better-scroll。

better-scroll

better-scroll 文檔

betterScrollList = new BScroll(wrapper,{
 probeType: 2, // 因為默認是不會調用 scroll 回調的,所以需要設置
 swipeTime: 300
})
betterScrollList.on('scroll', ()=>{
 //暫停歌曲
 //獲取當前用戶拖動的歌詞,計算規則如下
  // 當前y / 最大y * 歌詞行數
  // 當前y就是滾動的了多少
  // 最大y可以理解為高度
  // 上面計算出來就是進度比例。然后換算到行數就ok
})
betterScrollList.on('scrollEnd', ()=>{
 // 這里是校準到拖動歌詞的位置
 // 播放歌曲
})

probeType

描述
0不派發
1會非實時(屏幕滑動超過一定時間后)派發scroll 事件
2會在屏幕滑動的過程中實時的派發 scroll 事件
3不僅在屏幕滑動的過程中,而且在 momentum 滾動動畫運行過程中實時派發 scroll 事件

解析歌詞

這里我是基于lyric-parser 這個庫實現的。

因為我在網上找了幾個庫他們都使用的這個,所以我也就沒找我們公司內部的解析代碼。

lrc 歌詞規則: [分:秒.毫秒]歌詞。

better-scroll如何實現歌詞聯動功能

聯動

修改播放進度

這里我是直接改的 currentTime 來實現。

監聽播放進度

這里我是監聽 timeupdate 回調,然后獲取 currentTime,再去遍歷歌詞中對應時間的歌詞,觸發滾動效果。

修改音量

安卓是好的。ios 不行,然后被砍了。
這里是通過 volume 來操作。

看完上述內容,是不是對better-scroll如何實現歌詞聯動功能有進一步的了解,如果還想學習更多內容,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女