相思资源网 Design By www.200059.com
前言
这篇文章上一版本是用audio组件开发的播放器,随后反应音频加载速度慢的问题
又用小程序内置的背景音乐播放的方法写了一遍,逻辑是一样的逻辑,希望对大家有所帮助!
<view class='audiosBox'> <view class="audioOpen" bindtap="listenerButtonPlay" wx:if="{{!isOpen}}"> <image class='image2' src="/UploadFiles/2021-04-02/play.png">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" }, // 播放 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; /* 00:00 */ 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; }以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
标签:
微信小程序,播放器
相思资源网 Design By www.200059.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
相思资源网 Design By www.200059.com
暂无微信小程序音乐播放器开发的评论...
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。