vue 实现文字转语音tts

  1. 调用本地方法实现文字转语音 。缺点:win7系统部分版本不发声音,优点:不需要外网支持
const synth = window.speechSynthesis
const msg = new SpeechSynthesisUtterance()
 created() {
    this.handleSpeak('要合成的文字')
  },

/**
     *  text – 要合成的文字内容,字符串
     * lang – 使用的语言,字符串, 例如:“zh-cn”
     * voiceURI – 指定希望使用的声音和服务,字符串
     * volume – 声音的音量,区间范围是0到1,默认是1
     * rate – 语速,数值,默认值是1,范围是0.1到10,表示语速的倍数,例如2表示正常语速的两倍。
     * pitch – 表示说话的音高,数值,范围从0(最小)到2(最大)。默认值为1
     */
    handleSpeak(text) {
      console.log(text)
      msg.text = text
      msg.lang = 'zh-CN'
      msg.volume = 1
      msg.rate = 0.8
      msg.pitch = 2
      synth.speak(msg)
    },

2.使用百度开发api实现。 优点:系统可以兼容。缺点:必须使用外网支持
spd:说话的速度
template:

<template>
    <div id="wrapp" />

script:

 var ttsDiv = document.getElementById('wrapp')
    var au1 = '<audio id="wrapp_aud" autoplay="autoplay">'
    var sss = '<source src="http://tts.baidu.com/text2audio?lan=zh&ie=UTF-8&spd=4&per=0&text=' + '要合成的文字' + '" type="audio/mpeg">'
    var au2 = '</audio>'
    console.log(ttsDiv)
    ttsDiv.innerHTML = au1 + sss + au2
    const wrappAudio = document.getElementById('wrapp_aud')
    console.log('开始播放')
    wrappAudio.play()
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值