微信小程序组件:audio及api

一、audio标签

audio为小程序中的音频组件,我们可以轻松的在小程序中播放音频。

  • 下面是组件的相关属性的说明
属性类型默认值说明
idStringvideo 组件的唯一标识符
srcString要播放音频的资源地址
loopBooleanfalse是否循环播放
controlsBooleantrue是否显示默认控件
posterString默认控件上的音频封面的图片资源地址,如果 controls 属性值为 false 则设置 poster 无效
nameString未知音频默认控件上的音频名字,如果 controls 属性值为 false 则设置 name 无效
authorString未知作者默认控件上的作者名字,如果 controls 属性值为 false 则设置 author 无效
binderrorEventHandle当发生错误时触发 error 事件,detail = {errMsg: MediaError.code}
bindplayEventHandle当开始/继续播放时触发play事件
bindpauseEventHandle当暂停播放时触发 pause 事件
bindtimeupdateEventHandle当播放进度改变时触发 timeupdate 事件,detail = {currentTime, duration}
bindendedEventHandle当播放到末尾时触发 ended 事件

备注:loop和controls属性的值尽管是boolean,但是需要加{{}}才是生效,而id则不需要,这是小程序的设计bug

二、audio对应的api

前面我们介绍了一下audio标签的属性及事件监听,那么用这些属性能够实现我们正常的音频操作呢?显然是不行的,要进行音频操作就需要使用到微信小程序给audio提供的对应的api了。下面我们来看看都有哪些常用的api吧。

第一步:我们要获取到audio的上下文对相关,就像canvas的使用一样哦。

this.audioContext = wx.createAudioContext('audio');//参数就是audio属性的id值

audioContext 通过 audioId 跟一个 组件绑定,通过它可以操作对应的 组件,这样我们就可以通过这个对象操作音频了。

第二步:对应的操作方法

  1. play():播放;
  2. pause():暂停;
  3. seek(postion):设置当前播放位置点,postion的单位是s;
  4. setSrc(src):设置要播放的音频地址;

以上就是audio音频组件的常用属性以及常用api了。下面我们将用这些属性方法,做一个简单的音频播放。

三、音频播放小案例

需求

  1. 能够正常开始暂停播放;
  2. 循环播放;
  3. 快进暂停;
//对应的audio.js
Page({
  data:{
    audioContext:'', 
    audio:{
        poster: 'http://y.gtimg.cn/music/photo_new/T002R300x300M000003rsKF44GyaSk.jpg?max_age=2592000',
        name: '此时此刻',
        author: '许巍',
        src: 'http://ws.stream.qqmusic.qq.com/M500001VfvsJ21xFqb.mp3?guid=ffffffff82def4af4b12b3cd9337d5e7&uin=346897220&vkey=6292F51E1E384E06DCBDC9AB7C49FD713D632D313AC4858BACB8DDD29067D3C601481D36E62053BF8DFEAF74C0A5CCFADD6471160CAF3E6A&fromtag=4',
        currentTime:0,
        currtRate:0

    }
  },
  //以下是状态监听
  audioError:function(resp){
      console.log(resp);
  },
  audioPlay:function(resp){
      console.log(resp);
      console.log('开始播放');
  },
  playEnd:function(resp){
      console.log(resp);
      console.log('播放结束');
  },
  timeUpdate:function(resp){
      this.setData({
          currtRate:(100*resp.detail.currentTime/resp.detail.duration)
      });//总时长
      this.currentTime = resp.detail.currentTime;//当前时长
      console.log(resp);
      console.log('播放进度变化');
  },
  //以下是操作
  play:function(){
      this.audioContext.play();
  },
  pause:function(){
      this.audioContext.pause();
  },
  goFast:function(){
      this.audioContext.seek(this.currentTime+20);
  },
  onLoad:function(options){
    // 生命周期函数--监听页面加载
    this.audioContext=wx.createAudioContext('audio');

  },
  onShareAppMessage: function() {
    // 用户点击右上角分享
    return {
      title: 'title', // 分享标题
      desc: 'desc', // 分享描述
      path: 'path' // 分享路径
    }
  }
})
//对应的audio.wxml
<view class="title text-center">
  audio音频组件示例</view>
<view class="text-center">
  <audio id="audio" src="{{audio.src}}" loop="{{true}}" controls="{{true}}" poster="{{audio.poster}}" name="{{audio.name}}" author="{{audio.author}}" binderror="audioError" bindplay="audioPlay" bindeneded="playEnd" bindtimeupdate="timeUpdate"></audio>
</view>
<view class="row">
  <button class="col" type="primary" size="mini" bindtap="play">播放</button>
  <button class="col" type="primary" size="mini" bindtap="pause">暂停</button>
  <button class="col" type="primary" size="mini" bindtap="goFast">快进</button>
</view>

本来想搞个播放进度条展示到下面的,可是发现slider的value不能动态设置。等后面找到解决方案了在补充吧。

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Small_Teemo

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值