本文为大家分享了vue中音频wavesurfer.js的使用方法,供大家参考,具体内容如下
效果图
首先引入wavesurfer.js
其次 封装 wavesurfer.js`
<template>
<div class="waveformOuter">
<div id="waveform" ref="waveform" />
<div class="play" @click="playMusic">
<svg-icon v-if="!isPlaying" icon-class="play" class="icon myplay" />
<svg-icon v-else icon-class="stop" class="icon mystop" />
<p>{{ time }}</p>
</div>
<!-- <p>{{ url }}</p> -->
</div>
</template>
<script>
import WaveSurfer from '@/assets/js/wavesurfer'
export default {
props: ['url', 'toStopMusic', 'loadWave'],
data() {
return {
isPlaying: false,
time: '00:00',
wavesurfer: null,
}
},
watch: {
'loadWave': function() {
this.loadMusic()
},
'url': function() {
// return this.wavesurfer.getCurrentTime()
this.loadMusic(true)
console.log('url---------------------------------------')
},
'toStopMusic': function() {
console.log('toStopMusic---------------------------------------')
if (this.wavesurfer) {
this.wavesurfer.pause()
}
}
},
mounted() {
this.$nextTick(() => {
if (this.loadWave) {
console.log('haha')
this.loadMusic()
}
})
},
methods: {
itemClick(node) {
console.log(node.model.id)
},
buZero(num) {
return num > 9 "开始")
console.log(this.wavesurfer)
console.log("点击开始播放按钮",this.url)
if (this.wavesurfer) {
if (this.wavesurfer.isPlaying()) {
this.isPlaying = false
debugger
this.wavesurfer.pause()
} else {
this.isPlaying = true
this.wavesurfer.play()
}
}
}
}
}
</script>
<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped>
.myplay{
position: absolute;
top: 50%;
font-size: 17px;
margin: -10px 0 0 -9px;
left: 50%;
}
.mystop{
position: absolute;
top: 50%;
margin: -15px 0 0 -18px;
left: 50%;
font-size: 25px;
}
#waveform{
width: calc(100% - 150px);
height:128px;
float: left;
margin-right: 22px;
background: black;
}
.play{
position: relative;
width: 128px;
height:128px;
border-radius:3px;
background-color:#EBEEF5;
float: left;
text-align: center;
}
.play p{
margin-top: 85px;
color: #3683FA;
}
.waveformOuter{
margin-bottom: 20px;
overflow: hidden;
}
</style>
再然后 在需要的组件中引入
<div class="luyin" v-if="this.isYinyin">
<!-- {{this.isYinyin}} -->
<my-wave-sufer ref="handleDialogClose" :url="luyinUrl" :load-wave="showDialog" :to-stop-music="!showDialog" />
</div>
isYinyin: false,//是否加载录音组件
showDialog: true, //是否初始化录音组件
luyinUrl: "", //录音url
数据库录音格式 123.wav
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“vue中音频wavesurfer.js的使用方法”评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新动态
2025年11月01日
2025年11月01日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]

