接入须知:必须提前在腾讯云API密钥管理申请创建相关参数 :appid、secretId、secretKey 、projectId
本插件封装了腾讯云实时语音识别的SDK。使用本插件要先调用init初始化接口。保证初始化成功后再调用start开始录音并实时上传腾讯云端识别实时返回识别结果,可通过addEventListener接口回调获取识别结果及其相关事件。
注意:本插件 iOS 平台上最低适配系统版本为 iOS 9.0
初始化
init({params})
appid:
secretId:
secretKey:
projectId:
sliceTime:
enableDetectVolume:
endRecognizeWhenDetectSilence:
authorize:
sn:
deviceId:
var txRealTimeRecognizer = api.require('txRealTimeRecognizer');
txRealTimeRecognizer.init({
appid:'',
secretId:'',
secretKey:'',
projectId:''
});
iOS系统,Android系统
可提供的1.0.0及更高版本
开始实时语音识别
start()
var txRealTimeRecognizer = api.require('txRealTimeRecognizer');
txRealTimeRecognizer.start();
iOS系统,Android系统
可提供的1.0.0及更高版本
停止实时语音识别
stop()
var txRealTimeRecognizer = api.require('txRealTimeRecognizer');
txRealTimeRecognizer.stop();
iOS系统,Android系统
可提供的1.0.0及更高版本
关闭麦克风 (Android 不支持该接口)
stopMicrophone()
var txRealTimeRecognizer = api.require('txRealTimeRecognizer');
txRealTimeRecognizer.stopMicrophone();
iOS系统
可提供的1.0.0及更高版本
添加监听
addEventListener(callback(ret))
ret:
{
eventType:'', //字符串类型;事件回调,取值范围如下:
//realTimeRecognizerOnSliceRecognize:每个语音包分片识别结果
//realTimeRecognizerDidFinish:一次识别成功
//realTimeRecognizerDidError:一次识别失败
//realTimeRecognizerDidStartRecordSuccess:开始录音成功
//realTimeRecognizerDidStartRecordError:开始录音失败
//realTimeRecognizerDidStopRecord:结束录音
//realTimeRecognizerDidUpdateVolume:录音音量实时回调用
//realTimeRecognizerOnFlowRecognizeStart:语音流的开始识别
//realTimeRecognizerOnFlowRecognizeEnd:语音流的结束识别
//realTimeRecognizerOnSegmentSuccessRecognize:语音流的识别结果
//realTimeRecognizerOnFlowStart:语音流开始识别
//realTimeRecognizerOnFlowEnd:语音流结束识别
//realTimeRecognizerDidSaveAudioDataAsFile:录音停止后回调一次,再次开始录音会清空上一次保存的文件 (android不支持改参数)
response:{//json对象;语音分片的识别结果,realTimeRecognizerOnSliceRecognize、realTimeRecognizerOnSegmentSuccessRecognize返回
code:0, //数字类型;任务描述代码,为code = 0时标示成功,其他表示为失败
message:'', //字符串类型;code对应的描述信息
voiceId:'', //字符串类型;语音流的识别id
text:'', //字符串类型;当前语音流的识别结果
seq:1, //数字类型;语音包序列号,注意:不是语音流序列号
resultNumber:1, //数字类型;表示后面的 resultList 里面有几段结果,如果是0表示没有结果,遇到中间是静音。如果是1表示 result_list 有一个结果, 在发给服务器分片很大的情况下可能会出现多个结果,正常情况下都是1个结果
resultList:'', //字符串类型;结果
recognizedText:'', //字符串类型;识别到的总文本
requestParameters :{}, //json对象;语音分片请求参数
messageId :'', //字符串类型;本 message 唯一 id
},
result:'', //字符串类型;一次识别出的总文本;realTimeRecognizerDidFinish返回
msg:'', //字符串类型;错误信息;realTimeRecognizerDidError、realTimeRecognizerDidStartRecordError返回
volume:0 //数字类型;声音音量,取值范围(-40-0);realTimeRecognizerDidUpdateVolume返回
voiceId:'', //字符串类型;语音流对应的voiceId,唯一标识;realTimeRecognizerOnFlowRecognizeStart、realTimeRecognizerOnFlowRecognizeEnd、realTimeRecognizerOnFlowStart、realTimeRecognizerOnFlowEnd返回
seq:0, //数字类型;flow的序列号;realTimeRecognizerOnFlowRecognizeStart、realTimeRecognizerOnFlowRecognizeEnd、realTimeRecognizerOnFlowStart、realTimeRecognizerOnFlowEnd返回
audioFilePath:'' //字符串类型;音频文件路径;realTimeRecognizerDidSaveAudioDataAsFile返回 (android不支持改参数)
}
var txRealTimeRecognizer = api.require('txRealTimeRecognizer');
txRealTimeRecognizer.addEventListener(function(ret) {
api.alert({ msg:JSON.stringify(ret)});
});
iOS系统,Android系统
可提供的1.0.0及更高版本
移除监听
removeEventListener()
var txRealTimeRecognizer = api.require('txRealTimeRecognizer');
txRealTimeRecognizer.removeEventListener();
iOS系统,Android系统
可提供的1.0.0及更高版本