How to play a base64 response from Google Text to Speech as an mp3 audio in browser using Javascript(如何使用Java脚本在浏览器中将从Google文本到语音的Base64响应作为mp3音频播放)
本文介绍了如何使用Java脚本在浏览器中将从Google文本到语音的Base64响应作为mp3音频播放的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我编写此代码是为了在单击按钮时播放音频,但我无法使其工作。 谷歌文档在处理回复方面帮不上忙。 有谁能帮帮忙吗?
async function playVoiceover() {
const url ='https://texttospeech.googleapis.com/v1/text:synthesize?key=XXXXXXX'
const rawResponse = await fetch(url, {
method: 'POST',
headers: {
'Accept': 'application/json',
'Content-Type': 'application/json',
},
body: JSON.stringify({
'input':{
'ssml':`<speak>The <say-as interpret-as="characters">SSML</say-as>
standard <break time="1s"/>is defined by the
<sub alias="World Wide Web Consortium">W3C</sub>.</speak>`
},
'voice':{
'languageCode':'en-us',
'name':'en-US-Standard-B',
'ssmlGender':'MALE'
},
'audioConfig':{
'audioEncoding':'MP3'
}
})
});
const content = await rawResponse.json();
const mp3 = 'data:audio/mp3;base64,'+window.atob(content.audioContent)
const audio = new Audio(mp3);
audio.play();
}
推荐答案
我将此答案作为有关此案例的信息留给社区:
window.atob()
方法的作用是:对base-64编码的字符串进行解码。
texttospeech.googleapis.com(响应结构)
{";audioContent&Quot;:字符串} //Base64编码的字符串。
在使用编解码器结构格式化mp3字符串时,不需要对其进行解码。您可以看到类似的回复here。
有关exttospeech接口响应的其他详细信息:
- text-to-speech -> synthesize -> response-body
这篇关于如何使用Java脚本在浏览器中将从Google文本到语音的Base64响应作为mp3音频播放的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:如何使用Java脚本在浏览器中将从Google文本到语音的Base64响应作为mp3音频播放
猜你喜欢
- 400或500级别的HTTP响应 2022-01-01
- 如何使用 JSON 格式的 jQuery AJAX 从 .cfm 页面输出查 2022-01-01
- CSS媒体查询(最大高度)不起作用,但为什么? 2022-01-01
- Quasar 2+Apollo:错误:找不到ID为默认的Apollo客户端。如果您在组件设置之外,请使用ProvideApolloClient() 2022-01-01
- Css:将嵌套元素定位在父元素边界之外一点 2022-09-07
- 失败的 Canvas 360 jquery 插件 2022-01-01
- addEventListener 在 IE 11 中不起作用 2022-01-01
- 使用RSelum从网站(报纸档案)中抓取多个网页 2022-09-06
- Fetch API 如何获取响应体? 2022-01-01
- Flexslider 箭头未正确显示 2022-01-01