| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231 |
- /**
- * Copyright FunASR (https://github.com/alibaba-damo-academy/FunASR). All Rights
- * Reserved. MIT License (https://opensource.org/licenses/MIT)
- */
- /* 2022-2023 by zhaoming,mali aihealthx.com */
- // 连接; 定义socket连接类对象与语音对象
- var wsconnecter = new WebSocketConnectMethod({msgHandle:getJsonMessage,stateHandle:getConnState});
- var audioBlob;
- // 录音; 定义录音对象,wav格式
- var rec = Recorder({
- type:"pcm",
- bitRate:16,
- sampleRate:16000,
- onProcess:recProcess
- });
-
-
-
- var sampleBuf=new Int16Array();
- // 定义按钮响应事件
- var btnStart = document.getElementById('btnStart');
- btnStart.onclick = record;
- var btnStop = document.getElementById('btnStop');
- btnStop.onclick = stop;
- btnStop.disabled = true;
- btnStart.disabled = true;
-
- btnConnect= document.getElementById('btnConnect');
- btnConnect.onclick = start;
-
- var rec_text="";
- var offline_text="";
- var info_div = document.getElementById('info_div');
- //var now_ipaddress=window.location.href;
- //now_ipaddress=now_ipaddress.replace("https://","wss://");
- //now_ipaddress=now_ipaddress.replace("static/index.html","");
- //document.getElementById('wssip').value=now_ipaddress;
-
- function getAsrMode(){
- var item = null;
- var obj = document.getElementsByName("asr_mode");
- for (var i = 0; i < obj.length; i++) { //遍历Radio
- if (obj[i].checked) {
- item = obj[i].value;
- break;
- }
-
- }
- console.log("asr mode"+item);
- return item;
- }
-
- // 语音识别结果; 对jsonMsg数据解析,将识别结果附加到编辑框中
- function getJsonMessage( jsonMsg ) {
- //console.log(jsonMsg);
- console.log( "message: " + JSON.parse(jsonMsg.data)['text'] );
- var rectxt=""+JSON.parse(jsonMsg.data)['text'];
- var asrmodel=JSON.parse(jsonMsg.data)['mode'];
- if(asrmodel=="2pass-offline")
- {
- offline_text=offline_text+rectxt; //.replace(/ +/g,"");
- rec_text=offline_text;
- }
- else
- {
- rec_text=rec_text+rectxt; //.replace(/ +/g,"");
- }
- var varArea=document.getElementById('varArea');
-
- varArea.value=rec_text;
- console.log( "offline_text: " + asrmodel+","+offline_text);
- console.log( "rec_text: " + rec_text);
-
-
- }
- // 连接状态响应
- function getConnState( connState ) {
- if ( connState === 0 ) {
-
- //rec.open( function(){
- // rec.start();
- // console.log("开始录音");
-
- //});
- btnStart.disabled = false;
- btnConnect.disabled = true;
- info_div.innerHTML='连接成功!请点击开始';
- } else if ( connState === 1 ) {
- //stop();
- } else if ( connState === 2 ) {
- stop();
- console.log( 'connecttion error' );
-
- alert("连接地址"+document.getElementById('wssip').value+"失败,请检查asr地址和端口,并确保h5服务和asr服务在同一个域内。或换个浏览器试试。");
- btnStart.disabled = true;
- info_div.innerHTML='请点击连接';
- }
- }
- function record()
- {
- rec.open( function(){
- rec.start();
- console.log("开始");
- btnStart.disabled = true;
- });
- }
- // 识别启动、停止、清空操作
- function start() {
-
- // 清除显示
- clear();
- //控件状态更新
-
- info_div.innerHTML="正在连接asr服务器,请等待...";
- //启动连接
- var ret=wsconnecter.wsStart();
- if(ret==1){
- isRec = true;
- btnStart.disabled = true;
- btnStop.disabled = false;
- btnConnect.disabled=true;
- }
- }
-
- function stop() {
- var chunk_size = new Array( 5, 10, 5 );
- var request = {
- "chunk_size": chunk_size,
- "wav_name": "h5",
- "is_speaking": false,
- "chunk_interval":10,
- "mode":getAsrMode(),
- };
- console.log(request);
- if(sampleBuf.length>0){
- wsconnecter.wsSend(sampleBuf,false);
- console.log("sampleBuf.length"+sampleBuf.length);
- sampleBuf=new Int16Array();
- }
- wsconnecter.wsSend( JSON.stringify(request) ,false);
-
-
-
-
-
- // 控件状态更新
- isRec = false;
- info_div.innerHTML="请等候...";
- btnStop.disabled = true;
- setTimeout(function(){
- console.log("call stop ws!");
- wsconnecter.wsStop();
- btnStart.disabled = true;
- btnConnect.disabled=false;
- info_div.innerHTML="请点击连接";}, 3000 );
- rec.stop(function(blob,duration){
-
- console.log(blob);
- var audioBlob = Recorder.pcm2wav(data = {sampleRate:16000, bitRate:16, blob:blob},
- function(theblob,duration){
- console.log(theblob);
- var audio_record = document.getElementById('audio_record');
- audio_record.src = (window.URL||webkitURL).createObjectURL(theblob);
- audio_record.controls=true;
- audio_record.play();
-
- } ,function(msg){
- console.log(msg);
- }
- );
-
-
- },function(errMsg){
- console.log("errMsg: " + errMsg);
- });
- // 停止连接
-
-
- }
- function clear() {
-
- var varArea=document.getElementById('varArea');
-
- varArea.value="";
- rec_text="";
- offline_text="";
-
- }
-
- function recProcess( buffer, powerLevel, bufferDuration, bufferSampleRate,newBufferIdx,asyncEnd ) {
- if ( isRec === true ) {
- var data_48k = buffer[buffer.length-1];
-
- var array_48k = new Array(data_48k);
- var data_16k=Recorder.SampleData(array_48k,bufferSampleRate,16000).data;
-
- sampleBuf = Int16Array.from([...sampleBuf, ...data_16k]);
- var chunk_size=960; // for asr chunk_size [5, 10, 5]
- info_div.innerHTML=""+bufferDuration/1000+"s";
- while(sampleBuf.length>=chunk_size){
- sendBuf=sampleBuf.slice(0,chunk_size);
- sampleBuf=sampleBuf.slice(chunk_size,sampleBuf.length);
- wsconnecter.wsSend(sendBuf,false);
-
-
-
- }
-
-
-
- }
- }
|