时间:2021-05-18
前言
这篇文章上一版本是用audio组件开发的播放器,随后反应音频加载速度慢的问题
又用小程序内置的背景音乐播放的方法写了一遍,逻辑是一样的逻辑,希望对大家有所帮助!
<view class='audiosBox'> <view class="audioOpen" bindtap="listenerButtonPlay" wx:if="{{!isOpen}}"> <image class='image2' src="../../images/play.png" /> </view> <view class="audioOpen" bindtap="listenerButtonPause" wx:if="{{isOpen}}"> <image src="../../images/pauses.png" /> </view> <view class='slid'> <slider bindchange="sliderChange" block-size="12px" step="2" value="{{offset}}" max="{{max}}" selected-color="#4c9dee" /> <view> <text class='times'>{{starttime}}</text> <!-- 进度时长 --> <text class='times'>{{duration}}</text> <!-- 总时长 --> </view> </view></view>js部分注意了:bug ios 播放时必须加title 不然会报错导致音乐不播放
//index.js//获取应用实例const bgMusic = wx.getBackgroundAudioManager()const app = getApp() Page({ data: { isOpen: false,//播放开关 starttime: '00:00', //正在播放时长 duration: '06:41', //总时长 src:"http://ws.stream.qqmusic.qq.com/M500001VfvsJ21xFqb.mp3?guid=ffffffff82def4af4b12b3cd9337d5e7&uin=346897220&vkey=6292F51E1E384E061FF02C31F716658E5C81F5594D561F2E88B854E81CAAB7806D5E4F103E55D33C16F3FAC506D1AB172DE8600B37E43FAD&fromtag=46" }, // 播放 listenerButtonPlay: function () { var that = this //bug ios 播放时必须加title 不然会报错导致音乐不播放 bgMusic.title = '此时此刻' bgMusic.epname = '此时此刻' bgMusic.src = that.data.src; bgMusic.onTimeUpdate(() => { //bgMusic.duration总时长 bgMusic.currentTime当前进度 console.log(bgMusic.currentTime) var duration = bgMusic.duration; var offset = bgMusic.currentTime; var currentTime = parseInt(bgMusic.currentTime); var min = "0" + parseInt(currentTime / 60); var max = parseInt(bgMusic.duration); var sec = currentTime % 60; if (sec < 10) { sec = "0" + sec; }; var starttime = min + ':' + sec; that.setData({ offset: currentTime, starttime: starttime, max: max, changePlay: true }) }) //播放结束 bgMusic.onEnded(() => { that.setData({ starttime: '00:00', isOpen: false, offset: 0 }) console.log("音乐播放结束"); }) bgMusic.play(); that.setData({ isOpen: true, }) }, //暂停播放 listenerButtonPause(){ var that = this bgMusic.pause() that.setData({ isOpen: false, }) }, listenerButtonStop(){ var that = this bgMusic.stop() }, // 进度条拖拽 sliderChange(e) { var that = this var offset = parseInt(e.detail.value); bgMusic.play(); bgMusic.seek(offset); that.setData({ isOpen: true, }) }, // 页面卸载时停止播放 onUnload() { var that = this that.listenerButtonStop()//停止播放 console.log("离开") },})css部分
/**index.wxss**/.audiosBox{ width: 92%; margin: auto; height: 130rpx; display: flex; justify-content: space-between; align-items: center; background: #f6f7f7; border-radius: 10rpx;}.audioOpen{ width: 70rpx; height: 70rpx; border: 2rpx solid #4c9dee; border-radius: 50%; display: flex; align-items: center; justify-content: center; margin-left: 20rpx;} image{ width: 30rpx; height: 40rpx;}.image2{ margin-left: 10%;}.slid{ flex: 1; position: relative;}.slid view{ display: flex; justify-content: space-between;}.slid view>text:nth-child(1){ color: #4c9dee; margin-left:6rpx; }.slid view>text:nth-child(2){ margin-right:6rpx; }slider{ width: 520rpx; margin: 0; margin-left: 35rpx;}.times{ width: 100rpx; text-align: center; display: inline-block; font-size: 24rpx; color:#999999; margin-top: 5rpx;}.title view{ text-indent: 2em; }以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
很多时候人们会把自己喜欢听的歌分享给微信好友或是朋友圈里,小编也有这个习惯,但是每次用一些音乐播放器根本没法分享,今天小编心血来潮用了虾米音乐播放器分享音乐到朋
苹果6音乐播放器哪个好呢?相信很多用户对于iphone6音乐播放器哪个好还不太清楚,下面小编来跟大家推荐一下苹果6音乐播放器,各位机友们赶紧来看看哦。苹果6音乐
QQ音乐播放器中的定时停止播放音乐怎么设置?在QQ音乐播放器中,有个停止播放音乐的功能,可以对计算机设置定时停止播放音乐。那么,具体在QQ音乐播放器中该怎么设置
很多学员在开发音乐播放器的时候,只有点击歌曲列表某一首歌,然后再点击播放按钮才能播放,没法单击一下就播放的功能。这个音乐播放器开发出来,会给很多用户用起来感觉太
本文主要介绍了原生JS实现音乐播放器的示例代码,分享给大家,具体如下:效果图音乐播放器播放控制播放进度条控制歌词显示及高亮播放模式设置播放器属性归类按照播放器的