【web音频学习(七)】科大讯飞Web端语音合成

🎤 基于讯飞语音识别 API 的实时语音转文字 JavaScript SDK

码云地址

特性

  • 🎯 实时语音识别 - 支持实时音频流识别
  • 🔄 智能音量监听 - 自动检测音量变化并启动识别
  • 🌐 WebSocket 连接 - 基于 WebSocket 的实时通信
  • 🎛️ 灵活配置 - 支持多种语言、领域和音频格式
  • 📦 TypeScript 支持 - 完整的类型定义
  • 🔧 模块化设计 - 采用处理器链模式,易于扩展

安装

bash 复制代码
npm install xunfei-lat
# 或
pnpm install xunfei-lat
# 或
yarn add xunfei-lat

快速开始

1. 配置系统参数

首先需要在讯飞开放平台申请相关密钥:

javascript 复制代码
import xunfeiLat from 'xunfei-lat'

// 配置系统参数
xunfeiLat.config({
  API_SECRET: 'your_api_secret',
  APPID: 'your_appid',
  API_KEY: 'your_api_key'
})

2. 创建实例

javascript 复制代码
// 创建语音识别实例
const latInstance = xunfeiLat.create()

3. 监听事件

javascript 复制代码
// 监听识别结果
latInstance.on('appResultText', (text) => {
  console.log('最终识别结果:', text)
})

// 监听实时识别过程
latInstance.on('appResponseText', (text) => {
  console.log('实时识别结果:', text)
})

// 监听识别完成
latInstance.on('appFinish', () => {
  console.log('识别完成')
})

4. 开始识别

javascript 复制代码
// 手动开始录音识别
latInstance.start()

API 参考

配置参数

SystemConfig(系统配置)

参数 类型 必填 说明
API_SECRET string 讯飞平台申请的密钥
APPID string 讯飞平台申请的应用ID
API_KEY string 讯飞平台申请的API密钥

BusinessParams(业务参数)

参数 类型 默认值 说明
language `'zh_cn' 'en_us'` 'zh_cn'
domain string 'iat' 应用领域
accent 'mandarin' 'mandarin' 方言类型
vad_eos number 3600000 静默检测时间(ms)
dwa 'wpgs' 'wpgs' 动态修正
ptt `0 1` 1
rlang `'zh-cn' 'zh-hk'` 'zh-cn'
nunum `0 1` 1

SectionDelayParams(延迟控制参数)

参数 类型 默认值 说明
autoControl boolean true 是否自动控制延迟
initialDelay number 3500 初始延迟时间(ms)
subsequentDelay number 3000 后续延迟时间(ms)

实例方法

start(): void

手动开始录音和语音识别。


watch(): void

启动智能音量监听模式。当检测到音量大于20%且系统处于离线状态时自动开始识别。


finish(): void

结束当前的录音和识别过程。


on(eventName: string, callback: Function): void

监听事件。

事件

事件名 参数 说明
appResultText text: string 最终识别结果
appResponseText text: string 实时识别过程中的文本
appFinish - 识别完成

完整示例

javascript 复制代码
import xunfeiLat from 'xunfei-lat'

// 1. 配置系统参数
xunfeiLat.config({
  API_SECRET: 'your_api_secret',
  APPID: 'your_appid',
  API_KEY: 'your_api_key'
})

// 2. 创建实例
const latInstance = xunfeiLat.create({}, {
  autoControl: false
})

// 3. 监听事件
latInstance.on('appResultText', (text) => {
  console.log('识别完成:', text)
})

latInstance.on('appResponseText', (text) => {
  console.log('实时结果:', text)
})

latInstance.on('appFinish', () => {
  console.log('识别结束')
})

// 4. 开始识别
const startBtn = document.createElement('button')
startBtn.id = 'startBtn'
startBtn.textContent = '开始识别'
document.body.appendChild(startBtn)

const stopBtn = document.createElement('button')
stopBtn.id = 'stopBtn'
stopBtn.textContent = '结束识别'
document.body.appendChild(stopBtn)

startBtn.addEventListener('click', () => {
  latInstance.start()
})

stopBtn.addEventListener('click', () => {
  latInstance.end()
})

常见问题

Q: 为什么无法录音?

A: 请确保:

  1. 使用 HTTPS 协议访问
  2. 浏览器已授权麦克风权限
  3. 设备有可用的音频输入设备

许可证

ISC

相关推荐
豆苗学前端26 分钟前
你所不知道的前端知识,html篇(更新中)
前端·javascript·面试
一 乐27 分钟前
绿色农产品销售|基于springboot + vue绿色农产品销售系统(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·后端·宠物
zzjyr28 分钟前
Webpack 生命周期原理深度解析
前端
xiaohe060130 分钟前
💘 霸道女总裁爱上前端开发的我
前端·游戏开发·trae
sophie旭33 分钟前
内存泄露排查之我的微感受
前端·javascript·性能优化
k***19541 分钟前
Spring 核心技术解析【纯干货版】- Ⅶ:Spring 切面编程模块 Spring-Instrument 模块精讲
前端·数据库·spring
rgeshfgreh1 小时前
Spring事务传播机制深度解析
java·前端·数据库
Hilaku2 小时前
我用 Gemini 3 Pro 手搓了一个并发邮件群发神器(附源码)
前端·javascript·github
IT_陈寒2 小时前
Java性能调优实战:5个被低估却提升30%效率的JVM参数
前端·人工智能·后端
快手技术2 小时前
AAAI 2026|全面发力!快手斩获 3 篇 Oral,12 篇论文入选!
前端·后端·算法