vue3实现录音及发送等功能
vue
vuejs/vue: 是一个用于构建用户界面的 JavaScript 框架,具有简洁的语法和丰富的组件库,可以用于开发单页面应用程序和多页面应用程序。
项目地址:https://gitcode.com/gh_mirrors/vu/vue
免费下载资源
·
vue3中实现录音发送等功能
在vue项目中做聊天功能中涉及到语音发送功能,搭配js-audio-recorder插件的使用,能很好的帮助我们开发,下面是具体使用步骤。
第一步
npm安装js-audio-recorder插件包
npm i js-audio-recorder
第二步
在需要使用的组件中导入插件
import Recorder from 'js-audio-recorder'
第三步
在setup中定义响应的方法
const data = reactive({
//用于存储创建的语音对象
recorder: null,
formData: null,
// 控制录音动画的显示隐藏
showAnima: false,
mation: true,
isHistory: true,
// 录音时长
duration: 0,
submit () { // 发送语音的方法
data.recorder.pause() // 暂停录音
data.timer = null
console.log('上传录音')// 上传录音
var formData = new FormData()
var blob = data.recorder.getWAVBlob()//获取wav格式音频数据
//此处获取到blob对象后需要设置fileName满足当前项目上传需求,其它项目可直接传把blob作为 file塞入formData
var newbolb = new Blob([blob], { type: 'audio/wav' })
var fileOfBlob = new File([newbolb], new Date().getTime() + '.wav')
//formData是传给后端的对象,
formData.append('file', fileOfBlob)
//计算出录音时长
data.duration = Math.ceil((new Date() - data.duration) / 1000);
console.log(data.duration);
//发送给后端的方法
sendAudio(formData).then(res => {
console.log(res);
})
},
// 录音按钮的点击事件
voice () {
//实例化语音对象
data.recorder = new Recorder({
sampleBits: 16, // 采样位数,支持 8 或 16,默认是16
sampleRate: 16000, // 采样率,支持 11025、16000、22050、24000、44100、48000,根据浏览器默认值,我的chrome是48000
numChannels: 1 // 声道,支持 1 或 2, 默认是1
})
//记录开始录音的时间
data.duration = new Date();
Recorder.getPermission().then(() => {
console.log('开始录音')
data.recorder.start() // 开始录音
}, (error) => {
console.log(`${error.name} : ${error.message}`)
})
},
handleStop () {
console.log('停止录音')
data.recorder.stop() // 停止录音
data.mation = false;
},
handlePlay () {
console.log('播放录音')
data.recorder.play() // 播放录音
},
handleDestroy () {
console.log('销毁实例')
if (data.recorder) {
data.recorder.destroy() // 毁实例
}
},
})
return {
...toRefs(data)
};
(附)在录音时,如果需要有动画展示,直接使用以下vue组件即可。
<template>
<div class="mation">
<div class="ap">
<div class="box">
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
</div>
</div>
<div class="ap aps">
<div class="box">
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
</div>
</div>
</div>
</template>
<script>
export default {
}
</script>
<style>
.ap {
position: relative;
height: 50px;
width: 30px;
margin: 0 auto;
}
.aps {
transform-origin: center center;
transform: rotate(180deg);
}
.box div {
display: inline-block;
position: absolute;
bottom: 0;
width: 10px;
height: 30px;
//不喜欢该颜色改成想要的动画颜色
background-color: rgb(78, 176, 255);
transform-origin: bottom;
border-radius: 5px 5px 0 0;
}
.aps .box div {
background-color: rgb(0, 141, 255);
bottom: 2px;
}
.box div:nth-child(1) {
left: -60px;
animation: musicWave 0.5s infinite linear both alternate;
}
.box div:nth-child(2) {
left: -40px;
animation: musicWave 0.8s infinite linear both alternate;
}
.box div:nth-child(3) {
left: -20px;
animation: musicWave 0.6s infinite linear both alternate;
}
.box div:nth-child(4) {
left: 0px;
animation: musicWave 0.7s infinite linear both alternate;
}
.box div:nth-child(5) {
left: 20px;
animation: musicWave 0.7s infinite linear both alternate;
}
.box div:nth-child(6) {
left: 40px;
animation: musicWave 0.6s infinite linear both alternate;
}
.box div:nth-child(7) {
left: 60px;
animation: musicWave 0.8s infinite linear both alternate;
}
.box div:nth-child(8) {
left: 80px;
animation: musicWave 0.5s infinite linear both alternate;
}
@keyframes musicWave {
0% {
height: 8px;
}
100% {
height: 30px;
}
}
</style>
js-audio-recorder插件封装操作录音文件的功能还是挺多的,在上面例子中只使用到常见的三四种,有其他需求需要,参考以下方法。
data.recorder.resume() // 恢复录音
data.recorder.play() // 播放录音
data.recorder.pausePlay() // 暂停播放
data.recorder.resumePlay() // 恢复播放
data.recorder.stopPlay() // 停止播放
如有问题,欢迎交流~
GitHub 加速计划 / vu / vue
83
16
下载
vuejs/vue: 是一个用于构建用户界面的 JavaScript 框架,具有简洁的语法和丰富的组件库,可以用于开发单页面应用程序和多页面应用程序。
最近提交(Master分支:4 个月前 )
9e887079
[skip ci] 3 个月前
73486cb5
* chore: fix link broken
Signed-off-by: snoppy <michaleli@foxmail.com>
* Update packages/template-compiler/README.md [skip ci]
---------
Signed-off-by: snoppy <michaleli@foxmail.com>
Co-authored-by: Eduardo San Martin Morote <posva@users.noreply.github.com> 6 个月前
更多推荐
已为社区贡献1条内容
所有评论(0)