uniapp 实现录音上传

html部分

我是写了个录音的图片
点击之后弹出一个弹出层(仿了下qq的样式)
在这里插入图片描述
样式怎么写我就不赘述了大家都会
在这里插入图片描述

js部分

这是重点敲黑板!!!
在这里插入图片描述

创建实例

为了全局都好获取到,可以随时开始录音,随时停止录音,我把他扔进全局了

	const recorderManager = uni.getRecorderManager();//创建一个录音实例
	const innerAudioContext = uni.createInnerAudioContext();//用来播放的实例
	// 为了防止苹果手机静音无法播放
	uni.setInnerAudioOption({
   
		obeyMuteSwitch: false
	})
	innerAudioContext.autoplay = true;
	export default {
   

开始录音

this.timecount = '00:00:00';//初始化录音时间
this.hour = 0;
this.minute = 0;
this.second = 0;
this.getTimeIntervalplus();//封装的一个计时器,调用开始计时
const options = {
   //参数
	duration: 600000,
	sampleRate: 44100,
	numberOfChannels: 1,
	encodeBitRate: 192000,
	format: 'mp3',
	frameSize: 50
}
recorderManager.start(options);

在这里插入图片描述

结束录音

需要限制最短时长的可以做下判断,我这边没写

recorderManager.stop();//结束录音
clearInterval(this.timer);//结束计时

播放录音

innerAudioContext.src = this.voicePath;//播放的地址(上面录的本地地址)
innerAudioContext.play();//播放

暂停播放

innerAudioContext.pause();//暂停播放
clearInterval(this.timer);//清除定时器

提交录音到后端

//结束录音提交录音
submitrecord: function() {
   
	this.count += 1;//这是定义了一个全局的变量
  • 9
    点赞
  • 34
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
Uniapp实现录音上传,你可以按照以下步骤进行操作: 1. 首先,需要使用 `uni.startRecord` 方法开始录音。你可以在点击录音按钮时调用该方法。例如: ```javascript uni.startRecord({ success: function(res) { // 录音开始成功 console.log('录音开始成功'); }, fail: function(res) { // 录音开始失败 console.log('录音开始失败'); } }); ``` 2. 接下来,可以使用 `uni.stopRecord` 方法停止录音。你可以在点击停止按钮时调用该方法。例如: ```javascript uni.stopRecord({ success: function(res) { // 录音停止成功,录音文件的临时路径为 res.tempFilePath console.log('录音停止成功'); console.log('录音文件的临时路径为:' + res.tempFilePath); // 在这里可以调用上传录音文件的方法 uploadRecord(res.tempFilePath); }, fail: function(res) { // 录音停止失败 console.log('录音停止失败'); } }); ``` 3. 最后,实现上传录音文件的方法 `uploadRecord`。你可以使用 `uni.uploadFile` 方法来上传录音文件。例如: ```javascript function uploadRecord(filePath) { uni.uploadFile({ url: 'http://example.com/upload', // 替换为你的上传接口地址 filePath: filePath, name: 'file', success: function(res) { // 上传成功 console.log('上传成功'); console.log(res.data); }, fail: function(res) { // 上传失败 console.log('上传失败'); } }); } ``` 在上述代码中,`url` 参数需要替换为你的上传接口地址,`filePath` 参数为录音文件的临时路径,`name` 参数为上传文件的字段名。 通过以上步骤,你可以在 Uniapp实现录音上传功能。请注意保证录音文件的格式和大小符合你的上传需求,并在接口中进行相应处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值