@minto-ai/xunfei-tts
Version:
借助“讯飞在线语音合成API”实现浏览器端“文本转语音
76 lines (69 loc) • 2.27 kB
text/typescript
import type { BusinessParams, SystemConfig } from './types'
import { isIos } from '@minto-ai/tools'
import TtsController from './tts-controller'
import 'core-js'
let systemConfig: SystemConfig
function requestAudioPermission(): Promise<MediaStream> {
return new Promise((resolve, reject) => {
navigator.mediaDevices
.getUserMedia({ audio: true })
.then((stream) => {
resolve(stream)
})
.catch((error) => {
if (error.name === 'NotAllowedError') {
reject(new Error('用户拒绝了音频权限请求'))
}
else if (error.name === 'NotFoundError') {
reject(new Error('设备上没有可用的音频输入设备'))
}
else {
reject(new Error(`音频权限请求失败: ${error.message}`))
}
})
})
}
/**
* 用于管理文本转语音的配置和创建实例
*/
export default {
/**
* 配置系统参数。
* @param {SystemConfig} _systemConfig - 系统配置参数。
* @returns {object} 返回当前对象,支持链式调用。
*/
config(_systemConfig: SystemConfig) {
systemConfig = _systemConfig
/**
* @iss IOS浏览器无法文字转语音,需要申请权限
*/
if (isIos()) {
requestAudioPermission().catch((error) => {
throw new Error(error.message)
})
}
return this
},
/**
* 创建文本转语音控制器实例。
* @param {Partial<BusinessParams>} [businessParams] - 业务参数,默认为空对象。
* @returns {TtsController} 返回TtsController实例。
* @throws {Error} 如果系统配置未设置或API_KEY、API_SECRET、APPID为空,则抛出错误。
*/
create(businessParams: Partial<BusinessParams> = {}): TtsController {
const { API_KEY, API_SECRET, APPID } = systemConfig
if (!systemConfig) {
throw new Error('请先调用config方法进行配置')
}
if (!API_SECRET) {
throw new Error('API_SECRET不能为空')
}
if (!APPID) {
throw new Error('APPID不能为空')
}
if (!API_KEY) {
throw new Error('API_KEY不能为空')
}
return new TtsController(systemConfig, businessParams)
},
}