微信小程序实现录音与音频播放功能

网友投稿 361 2023-11-12

目录1、录音1.1 案例2、音频播放控制2.1 案例

小程序继承了微信强大的语音处理功能,提供了录音、音频播放控制和背景音乐等功能,它们的功能不同,但有相似性。

1、录音

微信小程序实现录音与音频播放功能

小程序提供了wx.startRecord(Object object)开始录音、wx.stopRecord()停止录音和RecorderManager录音管理器等接口对录音功能进行控制。因为RecorderManager录音管理器包含前两个接口的功能,所以这里只介绍RecorderManager。

接口功能和用途RecorderManager.resume()继续录音RecorderManager.stop()停止录音RecorderManager.onStart(function callback)监听录音开始事件RecorderManager.onResume(function callback)监听录音继续事件RecorderManager.onPause(function callback)监听录音暂停事件RecorderManager.onStop(function callback)监听录音结束事件RecorderManager.onFrameRecorded(function callback)监听已录制完指定帧大小的文件事件。如果设置了 frameSize,则会回调此事件。RecorderManager.onError(function callback)监听录音错误事件

在使用录音接口时,需要先授权开放录音功能。

1.1 案例

本例使用RecorderManager录音管理器实现录音、暂停、继续录音、停止录音和播放录音等功能。

redorderManager.wxml

?
1
2
3
4
5
<button bindtap="start" class=btn>开始录音</button>
<button bindtap="pause" class=btn>暂停录音</button>
<button bindtap="resume" class=btn>继续录音</button>
<button bindtap="stop" class=btn>停止录音</button>
<button bindtap="play" class=btn>播放录音</button>

redorderManager.js

通过recorderManager.wxml中的5个按钮来调用RecorderManager录音管理器的录音、暂停、继续录音、停止录音和播放录音功能。在录制好音频之后也可以上传到服务器,本例只是把录制好的音频存放在手机临时目录,然后用来播放。

这个功能不好再文章中展示,暂时不加视频了,直到原理就行。

2、音频播放控制

wx.createAudioContext()接口和wx.createInnerAudioContext接口包含了大多数音频控制功能。这里主要介绍wx.createAudioContext()接口。wx.createAudioContext()是以组件<audio>为基础的操作。

AudioContext实例对象可通过wx.createAudioContext接口获取,它通过id跟一个<audio>组件绑定,操作对应的<audio>组件。AudioContext对象常用的函数如下所示。

接口功能和用途AudioContext.setSrc(string src)设置音频地址AudioContext.play()播放音频。AudioContext.pause()暂停音频。AudioContext.seek(number position)跳转到指定位置(单位,s)。

2.1 案例

本例通过wx.createAudioContext()接口湖区AudioContext实例,然后调用播放和暂停功能,最后用slider组件来定位播放位置。

AudioContext.wxml:

?
1
2
3
4
<audio poster="{{poster}}" name="{{name}}" author="{{author}}" src="{{src}}" id="myAudio" controls loop></audio>
<slider bindchange=change min="0" max="160" value="{{time}}" color="blue" selected-color="red" show-value="true"></slider>
<button class=b1 type="primary" size="mini" bindtap="audioPlay">播放</button>
<button class=b1 type="primary" size="mini"  bindtap="audioPause">暂停</button>

AudioContext.js:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
Page({
onReady: function (e) {
// 使用 wx.createAudioContext 获取 audio 上下文 context
this.audioCtx = wx.createAudioContext(myAudio)
},
data: {
time:0,
poster: https://y.qq.com/music/photo_new/T002R300x300M000002Neh8l0uciQZ_1.jpg?max_age=2592000,
name: 稻香,
author: 周杰伦,
src: https://dl.stream.qqmusic.qq.com/RS020643ANK71H36gh.mp3?guid=5172738896&vkey=0B819C7570AAF78CC43A7C651E2C8C33FC76A07422EA718B9F8CAFD013F1BCF9E2DAF271064E05939716E400CE460A04669DFAC314460BB9&uin=1144722582&fromtag=66,
},
audioPlay: function () {
this.audioCtx.play()
},
audioPause: function () {
this.audioCtx.pause()
},
audio14: function () {
this.audioCtx.seek(0)
},
change: function (e) {
console.log(e)
this.audioCtx.seek(e.detail.value)
}
})

点击播放之后,就有一首免费的稻香了。

以上就是微信小

您可能感兴趣的文章:微信js-sdk 录音功能的示例代码基于JS开发微信网页录音功能的实例代码微信开发之微信jssdk录音功能开发示例微信小程序用户后台定位及录音授权及请求示例微信公众号录音文件的播放与保存(amr文件转mp3)JS实现一个微信录音功能过程示例详解

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:哪个券商的app好用 - 2021最全评测推荐
下一篇:详解微信小程序中数据双向绑定如何实现
相关文章

 发表评论

暂时没有评论,来抢沙发吧~