科大讯飞
  1. AI虚拟人技术
科大讯飞
  • iOS SDK接入文档
  • 平台文档
    • 开发者新手指南
      • 平台简介
      • 快速指引
    • 服务协议
      • 讯飞开放平台用户服务协议
      • 讯飞星火认知大模型接口服务协议
      • 开发者应用创建规则
      • 讯飞开放平台隐私政策
      • 开发者用户个人信息保护合规指引
      • 开放平台SDK合规使用说明
      • SDK隐私政策总览
      • SDK合规使用说明总览
      • 科大讯飞儿童隐私保护政策
      • 讯飞开放平台SLA协议
      • 讯飞开放平台订购协议
    • 用户认证须知
      • 用户认证简介
      • 企业实名认证
      • 个人实名认证
      • 初创团队认证
      • 学生认证
      • 公益项目认证
      • 个人升级企业认证
    • 财务
      • 退款规则及退款流程
      • 财务相关说明
    • 账号
      • 账号注销与删除流程
      • 账号与应用说明
    • 会员
      • 会员权益详情
      • 会员时效说明
      • 会员试用版
  • 星火认知大模型
    • SparkDesk
      • SparkDesk使用指南
      • SparkDesk隐私政策
      • SparkDesk用户协议
    • 星火认知大模型
      • 服务说明
      • 通用鉴权URL生成说明
      • Spark Android SDK接入文档
      • Linux SDK接入文档
      • Windows SDK接入文档
      • 讯飞星火认知大模型隐私政策
      • Web 文档
        • 星火认知大模型Web API文档
        • 星火大模型V1.5
        • 星火大模型V2
        • 星火大模型V3
    • 星火知识库
      • 星火知识库 API 文档
        • 星火知识库 API 文档
        • 文档问答
        • 文档上传
        • 文档总结
        • 获取文档总结/概要信息
      • 新版Embedding API文档
    • 图片生成
      • 图片生成 API
    • 图片理解
      • 图片理解 API
    • 大模型定制训练平台
      • 产品使用说明
      • 星火微调服务Web API文档文档
        • 星火微调服务Web API文档文档
        • V1.5版本
        • 微调模型
  • 语音识别
    • 语音唤醒(新版)
    • 语音听写
      • Android SDK 文档
      • iOS SDK 文档
      • Linux SDK 文档
      • Windows SDK 文档
      • Java SDK 文档
      • 音频文件格式说明
      • 语音听写服务说明
      • 语音听写(流式版)SDK隐私政策
      • 语音听写(流式版)SDK合规使用说明
      • HarmonyOS SDK 文档
      • 语音听写自训练平台
      • 语音听写(流式版)WebAPI
    • 语音转写
      • 语音转写服务说明
      • 语音转写 服务协议
      • WebAPI 文档
        • 语音转写 API 文档
        • 文件上传
        • 查询结果
    • 极速语音转写
      • 极速语音转写 API 文档
      • 小文件上传
      • 初始化分块信息
      • 分块上传
      • 分块上传完成
      • 创建任务
      • 查询任务
    • 实时语音转写
      • 实时语音转写服务说明
      • 实时语音转写 API
    • 离线语音听写
      • Android SDK 文档
      • 离线语音听写服务说明
      • 离线语音听写SDK隐私政策
      • 离线语音听写SDK合规使用说明
    • 离线语音听写(新版)
      • Android SDK 文档
      • 离线语音听写隐私政策
    • 语音唤醒
      • Android SDK 文档
      • iOS SDK 文档
      • Linux SDK 文档
      • Windows SDK 文档
      • 语音唤醒服务说明
      • 离线唤醒SDK隐私政策
    • 语音唤醒(新版)
      • Android SDK 文档
      • Linux SDK 文档
      • 语音唤醒隐私政策
    • 离线命令词识别
      • Android SDK 文档
      • iOS SDK 文档
      • Linux SDK 文档
      • Windows SDK 文档
      • 离线命令词识别服务说明
      • 离线命令词识别SDK隐私政策
      • 离线命令词SDK合规使用说明
  • 语音合成
    • 在线语音合成
      • Android SDK 文档
      • iOS SDK 文档
      • Linux SDK 文档
      • Windows SDK 文档
      • Java SDK 文档
      • 服务协议
      • 在线语音合成服务说明
      • 发音人自训练平台使用指南
      • WebAPI
    • 长文本语音合成
      • 长文本语音合成 API 文档
      • 创建任务
      • 查询任务
    • 离线语音合成
      • Android SDK 文档
      • iOS SDK 文档
      • Linux SDK 文档
      • Windows SDK 文档
      • 服务协议
      • 离线语音合成服务说明
    • AI虚拟人技术
      • Web SDK 2.0 接入指南
      • Android-SDK
      • iOS-SDK
      • Web API 文档
        • AI虚拟人技术 API 文档
        • 音频驱动
        • 启动
        • 文本驱动
        • 停止
        • 心跳
  • 语音扩展
    • 语音评测(流式版)
      • 接口说明
      • Android SDK 文档
      • iOS SDK 文档
      • Linux SDK 文档
      • Windows SDK 文档
      • 语音评测SDK隐私政策
      • 语音评测(流式版)API
    • 语音评测suntone
      • 语音评测suntone API
    • 离线变声
      • Android SDK 集成文档
    • 音色转换
      • 音色转换 API
    • 性别年龄识别
      • 性别能力识别 API
    • 声纹识别
      • Web API 文档
      • 声纹识别 API
    • 歌曲识别
      • 歌曲识别 API
    • 歌曲识别 ACRCloud
      • 接口说明
      • 哼唱识别
      • 音乐识别
    • AI 客服中间件
      • 接口说明
      • 获取token
      • 查询配置
      • 直接外呼
      • 创建外呼任务
      • 提交任务数据
      • 启动外呼任务
      • 暂停外呼任务
      • 删除外呼任务
      • 查询任务
      • 结果数据推送
      • 话单推送
      • 录音推送
      • 会话推送
      • 呼入话术上下文动态数据获取
  • 自然语言处理
    • 文本纠错
      • 文本纠错 API
      • 黑白名单上传
    • 公文校队
      • 公文校对 API
    • 文本合规
      • 文本合规 API
      • 新增黑名单词库
      • 根据lib_id添加黑名单词条
      • 根据lib_id查询词条明细
      • 根据lib_id删除词条
      • 根据appid查询账户下所有词库
      • 根据lib_id删除词库
      • 创建白名单库
      • 根据lib_id添加放行词条
      • 根据lib_id查询词条详情
      • 根据lib_id删除词条信息
      • 根据appid查询所有词库列表
      • 根据lib_id删除词库
    • 图片合规
      • 图片合规 API
    • 音频合规
      • 音频合规 API
    • 视频合规
      • 视频合规 API
    • 文本改写
      • 文本改写 API
    • 机器翻译
      • 机器翻译(新) API
    • 机器翻译niutrans
      • 机器翻译niutrans API
    • 同声传译
      • 同声传译 API 
    • 离线分词
      • Android SDK 文档
  • 人脸识别
    • 人脸验证与检索
      • Android SDK 文档
      • iOS SDK 文档
      • 人脸验证与检索SDK隐私政策
      • 人脸验证与检索SDK合规使用说明
    • 人脸对比
      • 人脸比对 API
    • 人脸比对sensetime
      • 人脸比对sensetime API
    • 人脸水印照比对
      • 人脸水印照比对 API
    • 静默活体检测
      • 静默活体检测 API
    • 配合式活体检测
      • 配合式活体检测 API
    • 静默活体检测sensetime
      • 静默活体检测sensetime API
    • 人脸检测和属性分析
      • 人脸检测和属性分析 API
    • 人脸特征分析tuputech
      • 年龄 API
      • 颜值 API
      • 性别 API
      • 表情 API
  • 文字识别
    • 通用文字识别
      • 通用文字识别 API
    • 通用文字识别
      • 通用文字识别 intsig API
    • 手写文字识别
      • 手写文字识别 API
    • 印刷文字识别
      • 印刷文字识别 API
    • 印刷文字识别(多语种)
      • 印刷文字识别(多语种)
    • 印刷文字识别(多语种)intsig
      • 印刷文字识别(多语种)intsig API
    • 图片文档还原
      • 图片文档还原 API 
    • 国内通用票据识别
      • 接口说明
      • 国内通用票据识别 API
    • 离线OCR
      • Android SDK 文档
    • 名片识别 intsig
      • 名片识别 API
    • 身份证识别 intsig
      • 身份证识别 intsig API
    • 银行卡识别 intsig
      • 银行卡识别 API
    • 营业执照识别 intsig
      • 营业执照识别 intsig API
    • 增值税发票识别 intsig
      • 增值税发票识别 intsig API
    • 拍照速算识别
      • 接口说明
      • 拍照速算识别 API
    • 公式识别
      • 接口说明
      • 公式识别 API
    • 指尖文字识别
      • 接口说明
      • 指尖文字识别 API
    • 身份证识别
      • 接口说明
      • 身份证识别 API
    • 增值税发票识别
      • 接口说明
      • 增值税发票识别 API
    • 营业执照识别
      • 接口说明
      • 营业执照识别 API
    • 火车票识别
      • 接口说明
      • 火车票识别 API
    • 出租车发票识别
      • 接口说明
      • 出租车发票识别 API
  • 图像识别
    • 场景识别
      • 场景识别 API
    • 物体识别
      • 物体识别 API
    • 场所识别
      • 场所识别 API 文档
  • 基础服务
    • 云服务器 CVM
      • 云服务器 CVM 产品简介
      • 快速入门
      • 服务协议
  • 解决方案
    • 签到解决方案
      • SaaS操作文档
    • 智能硬件通用方案
      • 智能硬件通用方案说明
      • 麦克风阵列Android SDK
      • 麦克风阵列Linux SDK
      • 双麦阵列设计参考
      • 麦克风阵列录音要求
      • 语音唤醒Android SDK
      • 语音唤醒Linux SDK
      • 离线声纹Android SDK
      • 离线声纹Linux SDK
  • MSC API 文档
    • Android
      • 文件列表
      • SDK初始化
      • 语音识别(Recognizer)
      • 语音合成(Synthesizer)
      • 语音评测(Evaluator)
      • 语音唤醒(Wakeuper)
      • 声纹人脸(Verifier)
      • Android 常量字段值
      • 基础类
    • IOS
      • 文件列表
      • SDK初始化
      • 语音识别(Recognizer)
      • 语音合成(Synthesizer)
      • 语音评测(Evaluator)
      • 语音唤醒(Wakeuper)
      • 声纹人脸(Verifier)
      • 基础类
    • Windows&Linux
      • 文件列表
      • API 文档
    • Java
      • 所有类列表
      • SDK初始化
      • 语音识别(Recognizer)
      • 语音合成(Synthesizer)
      • 常量字段值
      • 基础类
  1. AI虚拟人技术

Web SDK 2.0 接入指南

一、集成指南#

#1. 兼容性说明#

目前仅支持 XRTC 协议,兼容性请参照 xrtc web sdk 兼容性 https://voipconference.xfyun.cn/book/#/web/README?id=%e6%94%af%e6%8c%81%e7%9a%84%e5%b9%b3%e5%8f%b0

#2. 引入 SDK 库#

①、复制 vms-web-sdk-2.0.0 文件夹到项目的 JS 第三方库(如 src/libs)目录下
②、因虚拟人相关服务不支持跨域,故本地开发和上线部署时,都需要配置代理,本地代理具体如下:
ReactJS版本:
VueJS版本:
部署上线 nginx 配置代理可参照如下:
location ^~/vmss/ {
  proxy_pass http://vms.cn-huadong-1.xf-yun.com/;
  proxy_set_header Host $proxy_host;
  proxy_http_version 1.1;
}
其他方式代理,本意如上所示,形式不限,根据技术方案做具体调整即可_
③、在需要的页面引入 sdk js 文件:

#二、接口使用及调用流程#

#1. 启动#

启动虚拟人服务
#1)接口#
如上代码所示,SDK 初始化参数中vmsConfig必填,其中appId、apiKey、apiSecret和avatarId、streamDomId为必填项。
如需设置背景或者开启后处理,请先上传资源,请参考 “7.上传个性化资源” 完成上传,再将得到的 res_id 传入 start 方法
#2)参数#
参数类型必填说明默认值
appIDString是应用 ID
apiKeyString是引擎托管平台创建应用后,生成的唯一应用标识
apiSecretString是引擎托管平台创建应用后,生成的唯一应用秘钥
streamDomIdString是虚拟人视频流要渲染的 Dom Id
avatarIdString是形象 ID
widthnumber否宽度,可取 1920、1280、7201920
heightnumber否高度,可取 1080、720、4051080
moveHnumber否水平位移
moveVnumber否纵向位移
scalenumber否缩放
maskRegionstring否裁切,如:'[0,154,1080,1472]'
resIdstring否背景资源 id,上传图片至个性化系统返回得到
isSslboolean否是否启用 ssl(https,wss)否
interactiveScenestring否交互场景
templateIdstring否后处理模板id
transparentboolean否是否开启透明通道否
#3)调用示例#

#2. 结束#

结束虚拟人服务
#1)接口#
无必填参数
#2)调用示例#

#3. 音频驱动#

输入音频数据,驱动虚拟人,音频驱动需先进行初始化,在间隔合适的时间(默认 40ms)流式传入音频数据

#3.1 初始化音频驱动#

#1)接口#
#2)参数#
参数类型必填说明默认值
frameSizenumber否每帧数据大小1280
sendIntervalnumber否数据发送间隔40
#3)调用示例#

#3.2 发送音频数据#

#1)接口#
#2)参数#
① parameter,非必填
参数类型取值范围必填说明默认值
vms_dispatchObject否服务别名
realtime_statusObject否实时返回状态数据
vmr_statusnumber0,1否渲染引擎文本实时响应状态 0 关闭 1 打开0
vmr_action_statusnumber0,1否渲染引擎动作实时响应状态 0 关闭 1 打开0
② payload,必填
参数类型必填说明
audioObject是音频数据
ctrl_tObject否动作控制段
ctrl_postprocObject否后处理控制段
audio
参数类型取值范围必填说明默认值
encodingstringraw,lame, opus-wb, speex-wb否音频编码raw
sample_ratenumber16000否采样率16000
audioArray最小尺寸:1B, 最大尺寸:10485760B是音频数据
ctrl_t
参数类型取值范围必填说明默认值
encodingstringutf8否文本编码utf8
compressstringraw否文本压缩格式raw
formatstringjson否压缩格式json
textstring最小尺寸:0B, 最大尺寸:1048576B是驱动指令,base64 字符串,如:Base64.encode({avatar:[{ type: 'action', value: 'A_LH_introduced_O', wb: 3, we: 5 }]})
具体动作指令参数,请参照虚拟人服务接口文档 https://aidocs.xfyun.cn/docs/vms/实时交互服务接口文档.html
ctrl_postproc
参数类型取值范围必填说明默认值
encodingstringutf8否音频编码utf8
compressstringraw否采样率raw
formatstringjson否采样率json
textstring最小尺寸:0B, 最大尺寸:1048576B是后处理控制指令
#3)调用示例#

#4. 文本驱动#

输入文本数据,驱动虚拟人
#1)接口#
#2)参数#
① parameter,必传:
属性类型必填说明
ttsObject是合成控制段参数
tts
参数类型取值范围必填说明默认值
vcnstringx4_xiaoxuan x4_panting x4_yezi x4_xiaoguo x4_yifei x4_mingge x4_chaoge是合成发言人
speednumber最小值:0, 最大值:100否语速:50 正常语速,0 对应默认语速的 1/2,100 对应默认语速的 2 倍50
volumenumber最小值:0, 最大值:100否音量:50 正常音量,0 是静音,1 对应默认音量 1/2,100 对应默认音量的 2 倍50
pitchnumber最小值:0, 最大值:100否语调:50 正常语调,0 对应默认语速的 1/2,100 对应默认语速的 2 倍50
rhynumber可选0,1,3否控制是否返回拼音标注。0: 不返回拼音,1: 返回拼音(支持的引擎: xtts1.0-cpu, xtts1.0-gpu, xtts2.0-gpu, xtts2-gpu中是每句话一次性返回)拼音标注的时间xtts2.0要乘以5ms1
② payload,必填
参数类型必填说明
textObject是文本数据描述数据
ctrl_wObject否动作控制段
ctrl_postprocObject否后处理控制段
text
参数类型取值范围必填说明默认值
encodingstringutf8否文本编码utf8
compressstringraw否文本压缩格式raw
formatstringjson否文本格式json
textstring最小尺寸:0B, 最大尺寸:65536B是合成的文本数据,文本大小:0-64k
ctrl_w
参数类型取值范围必填说明默认值
encodingstringutf8否文本编码utf8
compressstringraw否文本压缩格式raw
formatstringjson否文本格式json
textstring最小尺寸:0B, 最大尺寸:1048576B是驱动指令,base64 字符串,如:Base64.encode({avatar:[{ type: 'action', value: 'A_LH_introduced_O', wb: 3, we: 5 }]})
具体动作指令参数,请参照虚拟人服务接口文档 https://aidocs.xfyun.cn/docs/vms/实时交互服务接口文档.html
ctrl_postproc
参数类型取值范围必填说明默认值
encodingstringutf8否文本编码utf8
compressstringraw否文本压缩格式raw
formatstringjson否文本格式json
textstring最小尺寸:0B, 最大尺寸:1048576B是后处理控制指令
#3)调用示例#

#5. 流式文本驱动#

适用于大模型场景下,流式交互,输入文本数据,驱动虚拟人
####5.1 文本驱动初始化
#1)接口#
#2)参数#
#3)调用示例#
####5.2 发送数据
#1)接口#
#2)参数#
① parameter,必传:
属性类型必填说明
ttsObject是合成控制段参数
vms_dispatchObject否流式控制参数
tts
参数类型取值范围必填说明默认值
vcnstringx4_xiaoxuan x4_panting x4_yezi x4_xiaoguo x4_yifei x4_mingge x4_chaoge是合成发言人
speednumber最小值:0, 最大值:100否语速:50 正常语速,0 对应默认语速的 1/2,100 对应默认语速的 2 倍50
volumenumber最小值:0, 最大值:100否音量:50 正常音量,0 是静音,1 对应默认音量 1/2,100 对应默认音量的 2 倍50
pitchnumber最小值:0, 最大值:100否语调:50 正常语调,0 对应默认语速的 1/2,100 对应默认语速的 2 倍50
rhynumber可选0,1,3否控制是否返回拼音标注。0: 不返回拼音,1: 返回拼音(支持的引擎: xtts1.0-cpu, xtts1.0-gpu, xtts2.0-gpu, xtts2-gpu中是每句话一次性返回)拼音标注的时间xtts2.0要乘以5ms1
vms_dispatch
参数类型取值范围必填说明默认值
realtime_statusObject否实时返回状态数据
tts_statusnumber0,1否文本合成状态 0 关闭 1 打开0
vmr_statusnumber0,1否渲染引擎文本实时响应状态 0 关闭 1 打开0
vmr_action_statusnumber0,1否渲染引擎动作实时响应状态 0 关闭 1 打开0
interactive_modenumber0,1否是否打断模式 1 打断 0 追加1
② payload,必填
参数类型必填说明
textObject是文本数据描述数据
ctrl_wObject否动作控制段
ctrl_postprocObject否后处理控制段
text
参数类型取值范围必填说明默认值
encodingstringutf8否文本编码utf8
compressstringraw否文本压缩格式raw
formatstringjson否文本格式json
textstring最小尺寸:0B, 最大尺寸:65536B是合成的文本数据,文本大小:0-64k
ctrl_w
参数类型取值范围必填说明默认值
encodingstringutf8否文本编码utf8
compressstringraw否文本压缩格式raw
formatstringjson否文本格式json
textstring最小尺寸:0B, 最大尺寸:1048576B是驱动指令,base64 字符串,如:Base64.encode({avatar:[{ type: 'action', value: 'A_LH_introduced_O', wb: 3, we: 5 }]})
具体动作指令参数,请参照虚拟人服务接口文档 https://aidocs.xfyun.cn/docs/vms/实时交互服务接口文档.html
ctrl_postproc
参数类型取值范围必填说明默认值
encodingstringutf8否文本编码utf8
compressstringraw否文本压缩格式raw
formatstringjson否文本格式json
textstring最小尺寸:0B, 最大尺寸:1048576B是后处理控制指令
#3)调用示例#

#6. 打断/重置接口#

中断驱动,如果是流式驱动则会断开ws连接
#1)接口#
#2)参数#
无
#3)调用示例#
_注意:如需使用 uploadResourceData 需配置代理 _ 本地开发代理配置 如下:
部署上线 nginx 配置可参考如下:
Location ^~/individuation/ {
  proxy_pass http://evo-hu.xf-yun.com;
  proxy_set_header Host $proxy_host;
  proxy_http_version 1.1;
}

#7. 上传个性化资源#

上传个性化资源,如背景或者画中画 图片、视频以及后处理模板
#1)接口#
如上代码所示,参数vmsConfig为必填项。
#2)参数#
① 鉴权参数 vmsConfig,必传:
属性类型必填说明
appIdString是应用 id
apiKeyString是apiKey
appSecretString是appSecret
resourceBase64StrString是资源 base64 字符串
typeString否资源描述信息,可选:,默认图片:'background_data'
② 个性化参数 resId,非必传 支持自定义,如果不传,服务返回一个生成的 res_id
#3)调用示例#
_注意:如需使用 uploadResourceData 需配置代理 _ 本地开发代理配置 如下:
部署上线 nginx 配置可参考如下:
Location ^~/individuation/ {
  proxy_pass http://evo-hu.xf-yun.com;
  proxy_set_header Host $proxy_host;
  proxy_http_version 1.1;
}

#三、错误码#

错误码描述
29001加入房间失败
29002播放视频流失败
29003订阅远端流失败
29004启动虚拟人服务失败,具体失败原因可查看错误返回信息
29005上传资源失败
29006停止虚拟人服务失败
29007浏览器不支持WebSocket
29008WebSocket连接异常
29010文本驱动文本不可为空
29011非流式文本驱动异常
0x4043此项错误比较特殊:浏览器安全限制,需用户与页面交互才可启动播放

#四、移动端兼容性#

此版本目前仅完整支持 pc web,不支持移动端,安卓、IOS请请使用对应的SDK
上一页
离线语音合成服务说明
下一页
Android-SDK
Built with