一个Nuance 的语音识别的例子
- #include "stdafx.h"
- #include "GetToken.h"
- #ifdef _DEBUG
- #define new DEBUG_NEW
- #undef THIS_FILE
- static char THIS_FILE[] = __FILE__;
- #endif
- /////////////////////////////////////////////////////////////////////////////
- // The one and only application object
- //CWinApp theApp;
- //using namespace std;
- #ifdef __UNICODE__
- #undef __UNICODE__
- #endif
- //#define __UNICODE__
- #ifdef __UNICODE__
- #define dictName "dict.uni"
- #define alpha "freepy.uni"
- #else//gb2312
- #define dictName "dict.gb"
- #define alpha "freepy.gb"
- #endif
- const int maxlength = 256;
- #define dictSize 0x10000
- const char pyIndex[] = "pyindex";
- BOOL ISHanzi(char *src)
- {
- int asc=*src;
- if(asc<0) asc+=256;
- if(asc>127)
- return TRUE;
- return FALSE;
- }
- char * GetPhoneticByWideString(WCHAR * str,const WORD * dict,const char * pyTable)
- {
- char phonetic[10];
- char * widestr = (char*)str;
- char *returnvalue=NULL;
- BOOL hz;
- hz=FALSE;
- while (*widestr != 0)
- {
- memset(phonetic,0,10);
- bool bEnglish = true;
- if(*widestr <= 'Z' && *widestr >='A')
- {
- if(hz)
- {
- *phonetic=' ';
- *(phonetic+1) = *widestr + 'a' - 'A';
- *(phonetic+2) = NULL;
- }else
- {
- *phonetic = *widestr + 'a' - 'A';
- *(phonetic+1) = NULL;
- }
- hz=FALSE;
- widestr ++;
- }
- else if(*widestr <= 'z' && *widestr >='a' || *widestr == ' ')
- {
- if(hz&&*widestr != ' ')
- {
- *(phonetic)=' ';
- *(phonetic+1) = *widestr;
- *(phonetic+2) = NULL;
- }
- else
- {
- *phonetic = *widestr;
- *(phonetic+1) = NULL;
- }
- hz=FALSE;
- widestr ++;
- }
- else if(*widestr >= '0' && *widestr <='9')
- {
- /* *phonetic = *widestr;
- *(phonetic+1) = NULL;
- hz=FALSE;
- widestr ++;
- */
- GetDigits(*widestr,phonetic);
- hz=TRUE;
- bEnglish = false;
- widestr++;
- }
- else if(ISHanzi(widestr))
- {
- if (-1 == GetPhoneticByHanZi(*(WCHAR*)widestr,dict,pyTable,phonetic))
- return NULL;
- widestr ++;
- if(!((*widestr <= 'Z' && *widestr >='A') || (*widestr <= 'a' && *widestr >='a') || *widestr == ' '))
- widestr ++;
- hz=TRUE;
- bEnglish = false;
- }else
- {
- widestr ++;
- continue;
- }
- if (!returnvalue)
- {
- int i = strlen(phonetic);
- returnvalue = strdup(phonetic);
- }
- else
- {
- if(!bEnglish && returnvalue[strlen(returnvalue)-1] != ' ')
- {
- returnvalue = (char*)realloc(returnvalue,strlen(returnvalue)+strlen(phonetic)+2);
- strcat(returnvalue," ");
- }
- else
- {
- returnvalue = (char*)realloc(returnvalue,strlen(returnvalue)+strlen(phonetic)+1);
- }
- strcat(returnvalue,phonetic);
- }
- }
- return returnvalue;
- }
- void LoadDictAndPYTable(WORD* pDict,char** pPyTable)
- {
- CFile dictFile(dictName,CFile::modeRead|CFile::typeBinary);
- //for (int i = 0;i<DICTSIZE;I++){ (a if a="wch" (m
- {
- b=*(Big5Source+1);
- if (b<0x7e) b=b - 0x40;
- if (b>=0x80) b = b - 0x80 + 0x7e - 0x40 + 1;
- fseek(tabfile, 2 * ((a -0x81) * (0xfe - 0x80 + 1 + 0x7e - 0x40 + 1 ) + b), SEEK_SET);
- fread(& a,1,1,tabfile);
- fread(& b,1,1,tabfile);
- fwrite(&a,1,1,destfile);
- fwrite(&b,1,1,destfile);
- *outString=a;
- *(outString+1)=b;
- outString+=2;
- Big5Source+=2;
- m+=2;
- }
- else
- {
- fwrite(&a,1,1,destfile);
- *outString=a;
- outString++;
- Big5Source++;
- m++;
- }
- }
- fclose(destfile);
- fclose(tabfile);
- Big5Source=BigSource;
- outString[lstr-1]='/0';
- delete[] Big5Source;
- delete[] WidecharStr;
- return GBString;
- }
- #include "stdafx.h"
- #include "GrammarThread.h"
- #include "GetToken.h"
- #include "HandleDataThread.h"
- #include "process.h"
- #ifdef _DEBUG
- #define new DEBUG_NEW
- #undef THIS_FILE
- static char THIS_FILE[] = __FILE__;
- #endif
- #define MAX_STRING_PARAM_LEN 300
- /////////////////////////////////////////////////////////////////////////////
- // CGrammarThread
- using namespace std;
- extern WORD dictArray[0X10000];
- extern char* pyTable;
- void ShowMsg(CString msg);
- CGrammarThread::CGrammarThread()
- {
- }
- CGrammarThread::CGrammarThread(NuanceConfig &config,
- DispatcherInterface & d,
- DBDescriptor * db_desc,CHandleDataThread* _p): m_pConfig(&config), m_pDispatcher(&d), m_pRcEngine(NULL),// m_kb(NULL),
- m_pDynagram_Db_Desc(db_desc)
- {
- m_parent=_p;
- NuanceStatus status;
- for(int i=0;i<MAX_SLOT_CNT;I++) m_pRcEngine- { CGrammarThread::~CGrammarThread() } -------- NotifiableAdapter from inherited WarnForUnhandledNotifications(); m_uRecord_ID="0;" m_uRecognition_ID="0;" m_specdtmf="0;" ; m_termno="#" m_iddtime="0;" m_firsttime="0;" m_dtmflen="40;" m_dtmfreason="0;" m_dtmfcnt="0;" memset(m_dtmfbuf,0,200); m_uPlay_Prompt_ID="0;" m_playreason="0;" h_recordevent="CreateEvent(NULL,FALSE,TRUE,NULL);" h_parameterevent="CreateEvent(NULL,FALSE,TRUE,NULL);" h_recognevent="CreateEvent(NULL,FALSE,TRUE,NULL);" h_dtmfevent="CreateEvent(NULL,FALSE,TRUE,NULL);" h_playevent="CreateEvent(NULL,FALSE,TRUE,NULL);" h_insertevent="CreateEvent(NULL,FALSE,FALSE,NULL);" h_closedbevent="CreateEvent(NULL,FALSE,FALSE,NULL);" h_delevent="CreateEvent(NULL,FALSE,FALSE,NULL);" h_queryevent="CreateEvent(NULL,FALSE,FALSE,NULL);" h_newevent="CreateEvent(NULL,FALSE,FALSE,NULL);" return; !="status)" (NUANCE_OK if status="NLGetSlotNamesFromConfig(m_pConfig,slotname);" m_pRcEngine) (NULL="=" status); *this, *m_pDispatcher, RCEngine(m_pConfig, m_pRcEngine="new" NLFreeValue(slotname); NLFreeValue(slotstr); strcpy(slotnamelist[i],slot); slotnamelist[i]="NULL;" NLGetStringFromValue(slotstr,slot,200); for(i="0;i<slen;i++)" slotstr="NLNewValue(&status);" NLValue* slotname="NLNewValue(&status);" slot[200]; char slen="0;" int>Abort(NullID);
- if (m_pDynagram_Db_Desc) {
- DeleteDBDescriptor(m_pDynagram_Db_Desc);
- }
- m_pDynagram_Db_Desc = NULL;
- delete m_pRcEngine;
- m_pRcEngine = NULL;
- CloseHandle(h_newevent);
- CloseHandle(h_queryevent);
- CloseHandle(h_delevent);
- CloseHandle(h_closedbevent);
- CloseHandle(h_insertevent);
- CloseHandle(h_playevent);
- CloseHandle(h_dtmfevent);
- CloseHandle(h_recognevent);
- CloseHandle(h_parameterevent);
- CloseHandle(h_recordevent);
- for(int i=0;slotnamelist[i]!=NULL;i++)
- {
- free(slotnamelist[i]);
- }
- }
- void NUANCE_MEMBER_FUNCTION
- CGrammarThread::HandleCallTransferFailed(CallTransferFailedNotification const & n)
- {
- }
- void NUANCE_MEMBER_FUNCTION
- CGrammarThread::HandleNuanceDBRecordDeleted(NuanceDBRecordDeletedNotification const & n)
- {
- NuanceStatus status = n.GetStatus();
- if (NUANCE_OK != status) {
- }else
- {
- CString msg;
- msg="记录删除";
- ShowMsg(msg);
- }
- SetEvent(h_delevent);
- }
- void NUANCE_MEMBER_FUNCTION
- CGrammarThread::HandleNuanceDBRecordModified(NuanceDBRecordModifiedNotification const & n)
- {
- CString msg;
- NuanceStatus status = n.GetStatus();
- if (NUANCE_OK != status) {
- msg.Format("Dynamic Grammar Modified 失败:%s",n.GetErrorString());
- ShowMsg(msg);
- }else
- {
- msg="Dynamic Grammar Modified";
- ShowMsg(msg);
- }
- SetEvent(h_newevent);
- }
- void NUANCE_MEMBER_FUNCTION
- CGrammarThread::HandleNuanceDBRecordCreated(NuanceDBRecordCreatedNotification const & n)
- {
- CString msg;
- NuanceStatus status = n.GetStatus();
- if (NUANCE_OK != status) {
- msg.Format("Dynamic Grammar Create 失败:%s",n.GetErrorString());
- ShowMsg(msg);
- }else
- {
- msg="Dynamic Grammar Create";
- ShowMsg(msg);
- }
- SetEvent(h_newevent);
- }
- void NUANCE_MEMBER_FUNCTION
- CGrammarThread::HandleConferenceCallStarted(ConferenceCallStartedNotification const & n)
- {
- }
- void NUANCE_MEMBER_FUNCTION
- CGrammarThread::HandleConferenceEnded(ConferenceEndedNotification const & n)
- {
- }
- void NUANCE_MEMBER_FUNCTION
- CGrammarThread::HandleDTMFTones(DTMFTonesNotification const & dn)
- {
- char const *m_cNum = dn.GetTones();
- printf("have gotten dtmf :%c/r/n",*m_cNum);
- if(m_uRecord_ID>0)
- {
- if(m_termdtmf!='a'&&m_termdtmf!='A')
- {
- if(*m_cNum==m_termdtmf)
- StopRecord();
- }else
- {
- StopRecord();
- }
- }
- if(m_dtmfstate==1)
- {
- if(m_uRecognition_ID>0)
- StopRecognize(8);
- StopPrompt();
- if(*m_cNum==m_termno)
- {
- m_dtmfreason=1;
- m_dtmfstate=0;
- return;
- }
- memcpy(m_dtmfbuf+m_dtmfcnt,m_cNum,strlen(m_cNum));
- m_dtmfcnt+=strlen(m_cNum);
- time(&m_dt);
- if(m_dtmfcnt==1&&*m_cNum==m_specdtmf)
- {
- m_dtmfreason=1;
- m_dtmfstate=0;
- }else if(m_dtmfcnt==m_dtmflen)
- {
- m_dtmfreason=1;
- m_dtmfstate=0;
- }
- }
- }
- void NUANCE_MEMBER_FUNCTION
- CGrammarThread::HandleAcknowledgment (AcknowledgmentNotification const & an)
- {
- CString strfname;
- strfname.Format("%s",an.GetRequestTypeAsString(an.GetRequestType()));
- NuanceStatus status = an.GetStatus();
- if (NUANCE_OK != status) {
- switch(an.GetRequestType())
- {
- case AcknowledgmentNotification::RequestType::StartRecording:
- m_recordreason=2;
- m_uRecord_ID=0;
- SetEvent(h_recordevent);
- break;
- case AcknowledgmentNotification::RequestType::RecognizeUtterance:
- m_uRecognition_ID=0;
- SetEvent(h_recognevent);
- break;
- case AcknowledgmentNotification::RequestType::SetParameter:
- SetEvent(h_parameterevent);
- break;
- case AcknowledgmentNotification::RequestType::PlayPrompts:
- if(m_dtmfstate==1) time(&m_ft);
- m_uPlay_Prompt_ID=0;
- m_parent->RemoveAllWav();
- ShowMsg("***playback Stop for error");
- SetEvent(h_playevent);
- break;
- case AcknowledgmentNotification::RequestType::DeleteRecord:
- SetEvent(h_delevent);
- break;
- case AcknowledgmentNotification::RequestType::CloseDatabase:
- SetEvent(h_closedbevent);
- break;
- case AcknowledgmentNotification::RequestType::NewDynamicGrammar:
- case AcknowledgmentNotification::RequestType::NewDynamicGrammarFromGSL:
- case AcknowledgmentNotification::RequestType::NewDynamicGrammarFromPhraseList:
- case AcknowledgmentNotification::RequestType::AddPhraseListToDynamicGrammar:
- case AcknowledgmentNotification::RequestType::AddPhraseToDynamicGrammar:
- case AcknowledgmentNotification::RequestType::RemovePhraseFromDynamicGrammar:
- SetEvent(h_newevent);
- break;
- case AcknowledgmentNotification::RequestType::InsertDynamicGrammar:
- SetEvent(h_insertevent);
- break;
- case AcknowledgmentNotification::RequestType::QueryDynamicGrammarContents:
- case AcknowledgmentNotification::RequestType::QueryRecordExists:
- SetEvent(h_queryevent);
- break;
- }
- }
- }
- void NUANCE_MEMBER_FUNCTION
- CGrammarThread::HandleInitializationCompleted (InitializationCompletedNotification const & icn)
- {
- StateDynagramOpenDB();
- }
- void NUANCE_MEMBER_FUNCTION
- CGrammarThread::HandlePlaybackStopped (PlaybackStoppedNotification const & pcn)
- {
- PlaybackStoppedNotification::Reason reason = pcn.GetReason();
- switch (reason)
- {
- //完全播放结束
- case PlaybackStoppedNotification::PLAYBACK_COMPLETED:
- {
- m_playreason=1;
- }
- break;
- //若是调用了 Abort 函数 或 挂断电话
- case PlaybackStoppedNotification::PLAYBACK_ABORTED:
- {
- m_playreason=2;
- }
- break;
- case PlaybackStoppedNotification::HANG_UP:
- {
- m_playreason=3;
- }
- break;
- default:
- {
- m_playreason=4;
- }
- }//end of case
- if(m_dtmfstate==1) time(&m_ft);
- m_uPlay_Prompt_ID=0;
- m_parent->RemoveAllWav();
- ShowMsg("***playback Stop");
- SetEvent(h_playevent);
- }
- void NUANCE_MEMBER_FUNCTION
- CGrammarThread::HandleRecordingStopped (RecordingStoppedNotification const & rsn)
- {
- m_uRecord_ID=0;
- SetEvent(h_recordevent);
- }
- void NUANCE_MEMBER_FUNCTION
- CGrammarThread::HandleStartOfSpeech (StartOfSpeechNotification const & sosn)
- {
- printf("^^^^^^^^^HandleStartOfSpeech/r/n");
- if(m_dtmfstate==1) StopDtmf(8);
- }
- void NUANCE_MEMBER_FUNCTION
- CGrammarThread::HandleEndOfSpeech (EndOfSpeechNotification const & eosn)
- {
- }
- void NUANCE_MEMBER_FUNCTION
- CGrammarThread::HandlePartialResult (PartialResultNotification const & prn)
- {
- }
- void NUANCE_MEMBER_FUNCTION
- CGrammarThread::HandleRecognitionStopped (RecognitionStoppedNotification const & rsn)
- {
- //取的识别 ID
- unsigned id = rsn.GetUtteranceID();
- //判断识别结束原因
- int iReason = rsn.GetReason();
- switch (iReason)
- {
- //识别顺利完成
- case RecognitionStoppedNotification::COMPLETED:
- {
- RecResult const * rr = rsn.GetRecResult();
- RecognizeNotify((RecResult*)rr);
- }
- break;
- //挂断电话
- case RecognitionStoppedNotification::HANG_UP:
- {
- }
- break;
- //调用 Abort
- case RecognitionStoppedNotification::ABORTED:
- {
- ShowMsg("00000000000000000");
- }
- break;
- default:
- {
- ShowMsg("111111111111111111111");
- }
- }
- ShowMsg("Recognize Stop");
- m_uRecognition_ID=0;
- SetEvent(h_recognevent);
- }
- void NUANCE_MEMBER_FUNCTION
- CGrammarThread::HandleIncomingCall (IncomingCallNotification const & icn)
- {
- ShowMsg("Incoming call--------------");
- strcpy(m_parent->m_callingID,icn.GetCallerID());
- strcpy(m_parent->m_calledID,icn.GetDID());
- unsigned id = icn.GetCallID();
- m_uAnswer_Call_ID=id;
- m_pRcEngine->AnswerCall(m_uAnswer_Call_ID);
- }
- void NUANCE_MEMBER_FUNCTION
- CGrammarThread::HandleOutgoingCallConnected (OutgoingCallConnectedNotification const & occn)
- {
- }
- void NUANCE_MEMBER_FUNCTION
- CGrammarThread::HandleCallAnswered (CallAnsweredNotification const & can)
- {
- ShowMsg("Call Answered--------------");
- m_parent->m_callstate=1;
- m_parent->PostThreadMessage(WM_CALL_CONNECT,0,0);
- }
- void NUANCE_MEMBER_FUNCTION
- CGrammarThread::HandleCallEnded (CallEndedNotification const & cen)
- {
- ShowMsg("Call Ended--------------");
- m_parent->m_callstate=2;
- StopAll();
- m_parent->PostThreadMessage(WM_CALL_DISCONNECT,0,0);
- }
- void NUANCE_MEMBER_FUNCTION
- CGrammarThread::HandleNuanceDBOpened (NuanceDBOpenedNotification const & ndbon)
- {
- // check status
- NuanceStatus status = ndbon.GetStatus();
- if (NUANCE_OK != status) {
- CString msg="OpenDB 失败";
- ShowMsg(msg);
- m_pRcEngine->Abort(NullID);
- return;
- }
- unsigned id = ndbon.GetID();
- if (m_uDynagram_Db_ID != id) {
- CString msg="OpenDB ID 失败";
- ShowMsg(msg);
- m_pRcEngine->Abort(NullID);
- return;
- }
- CString msg="Open DB 成功";
- ShowMsg(msg);
- }
- void NUANCE_MEMBER_FUNCTION
- CGrammarThread::HandleNuanceDBClosed (NuanceDBClosedNotification const & ndbcn)
- {
- NuanceStatus status = ndbcn.GetStatus();
- if (NUANCE_OK != status) {
- CString msg="CloseDB 失败";
- ShowMsg(msg);
- }else
- {
- CString msg="CloseDB 成功";
- ShowMsg(msg);
- }
- SetEvent(h_closedbevent);
- }
- void NUANCE_MEMBER_FUNCTION
- CGrammarThread::HandleNuanceDBRecordExists (NuanceDBRecordExistsNotification const & ndben)
- {
- NuanceStatus status = ndben.GetStatus();
- if (NUANCE_OK != status) {
- CString msg="Grammar 记录不存在";
- ShowMsg(msg);
- r_exist=false;
- }else
- {
- CString msg="Grammar 记录存在";
- ShowMsg(msg);
- r_exist=true;
- }
- SetEvent(h_queryevent);
- }
- void NUANCE_MEMBER_FUNCTION
- CGrammarThread::HandleDynamicGrammarInserted (DynamicGrammarInsertedNotification const & dgin)
- {
- NuanceStatus status = dgin.GetStatus();
- if (NUANCE_OK != status) {
- ShowMsg("Grammar insert 失败");
- }else
- {
- ShowMsg("Grammar insert 成功");
- }
- SetEvent(h_insertevent);
- }
- void NUANCE_MEMBER_FUNCTION
- CGrammarThread::HandleParameterSet (ParameterSetNotification const & psn)
- {
- SetEvent(h_parameterevent);
- }
- void NUANCE_MEMBER_FUNCTION
- CGrammarThread::HandleParameterGotten (ParameterGottenNotification const & pgn)
- {
- }
- void NUANCE_MEMBER_FUNCTION
- CGrammarThread::HandleException (ExceptionNotification const & en)
- {
- }
- void
- CGrammarThread::
- StateDynagramOpenDB (void)
- {
- m_uDynagram_Db_ID = m_pRcEngine->GetUniqueID();
- m_pRcEngine->OpenDynamicGrammarDatabase(m_pDynagram_Db_Desc, m_uDynagram_Db_ID);
- }
- int CGrammarThread::NewDynaGrammar(char *key,char *text,bool overwrite)
- {
- bool t_ret=false;
- PhraseList* m_pPhrase_List;
- m_pPhrase_List=NewPhraseList();
- char* token = strtok(text, "|");
- while( token != NULL )
- {
- CString tmpstr;
- tmpstr.Format("%s",token);
- bool ret=CreatePhraseList(m_pPhrase_List,(char*)(LPCTSTR)tmpstr);
- if(ret) t_ret=ret;
- token = strtok( NULL, "|" );
- }
- if(!t_ret)
- {
- SetEvent(h_newevent);
- DeletePhraseList(m_pPhrase_List);
- return 1;
- }
- unsigned m_uDynagram_New_ID = m_pRcEngine->GetUniqueID();
- if(overwrite)
- {
- ResetEvent(h_newevent);
- m_pRcEngine->NewDynamicGrammar(m_uDynagram_Db_ID,key,
- m_uDynagram_New_ID,m_pPhrase_List,NULL,1);
- }else
- {
- if(QueryRecord(key))
- {
- ResetEvent(h_newevent);
- m_pRcEngine->AddPhraseListToDynamicGrammar(m_uDynagram_Db_ID,key,
- m_uDynagram_New_ID,m_pPhrase_List,NULL);
- }
- else
- {
- ResetEvent(h_newevent);
- m_pRcEngine->NewDynamicGrammar(m_uDynagram_Db_ID,key,
- m_uDynagram_New_ID,m_pPhrase_List,NULL,1);
- }
- }
- DeletePhraseList(m_pPhrase_List);
- WaitForSingleObject(h_newevent,INFINITE);
- return 0;
- }
- CString ParseGrammar(CString src)
- {
- CString result="";
- CString tmp="";
- char ch;
- bool haso=false;
- for(int i=0;i<SRC.GETLENGTH();I++) { } ; slotname="" char int if(i="=0)" break; if(!mrun) i++; slotname.TrimRight(); slotname.TrimLeft(); ntext.TrimRight(); ntext.TrimLeft(); ntext="" ptext.TrimRight(); ptext.TrimLeft(); ptext="" stext.TrimRight(); stext.TrimLeft(); stext="" pos1='srctext.Find("*",0);' pos2="0;" ttext="" }else mrun="true;" if(pos1<0) CString while(1) i="0;" bool srctext.Format(?%s?,text); srctext; status; NuanceStatus *text) *p_list, CGrammarThread::CreatePhraseList(PhraseList result; return ?); result.TrimRight(? tmp="" free(phFood); result+="tmp;" ?,phFood); tmp.Format(?%s if(phFood) pyTable); *phFood="GetPhoneticByWideString((WCHAR*)(char*)(LPCTSTR)tmp,dictArray," tmp.Format(??(%s) if(haso) ) if(tmp!="" tmp+="ch;" haso="true;" if(ch="='[')" ch="src.GetAt(i);">3) break;
- }
- if(stext=="") return false;
- bool srcz=false;
- if (ntext.Left(2)=="c:"||ntext.Left(2)=="C:")
- {
- ntext=ntext.Right(ntext.GetLength()-2);
- srcz=true;
- }
- if(ntext=="")
- {
- char *phFood =GetPhoneticByWideString((WCHAR*)(char*)(LPCTSTR)stext,dictArray,
- pyTable);
- if(!phFood)
- {
- return false;
- }
- ntext.Format("%s",phFood);
- free(phFood);
- }else
- {
- if(srcz)
- {
- ntext=ParseGrammar(ntext);
- srcz=false;
- }
- }
- if(ptext=="")
- {
- ptext=ntext;
- ptext.Replace(" ","");
- }
- CString ctmp=ntext;
- ntext="("+ctmp+")";
- ctmp=stext;
- if(slotname=="")
- {
- slotname="peoplename";
- }
- stext="{<" + slotname+" /""+ctmp+"/">}";
- status = PhraseListAdd(
- p_list, // phrase list pointer
- ptext, // used to reference phrase in db
- ntext, // actual text to pronounce
- stext, // nl entry
- 1.0 // probability
- );
- if(status == NUANCE_OK)
- return true;
- return false;
- }
- bool CGrammarThread::QueryRecord(char *key)
- {
- ResetEvent(h_queryevent);
- r_exist=false;
- unsigned m_uDynagram_Query_ID = m_pRcEngine->GetUniqueID();
- m_pRcEngine->QueryRecordExists(m_uDynagram_Db_ID,key,m_uDynagram_Query_ID);
- WaitForSingleObject(h_queryevent,INFINITE);
- return r_exist;
- }
- void CGrammarThread::RemovePhrase(char *key, char *phraseid)
- {
- char* token = strtok(phraseid, "|");
- while( token != NULL )
- {
- if(QueryDGrmContents(key,token))
- {
- ResetEvent(h_newevent);
- unsigned m_uDynagram_Remove_ID = m_pRcEngine->GetUniqueID();
- m_pRcEngine->RemovePhraseFromDynamicGrammar(m_uDynagram_Db_ID,key,m_uDynagram_Remove_ID,token);
- WaitForSingleObject(h_newevent,INFINITE);
- }
- token = strtok( NULL, "|" );
- }
- }
- bool CGrammarThread::QueryDGrmContents(char *key, char *phraseid)
- {
- ResetEvent(h_queryevent);
- r_exist=false;
- unsigned m_uDynagram_Query_ID = m_pRcEngine->GetUniqueID();
- m_pRcEngine->QueryDynamicGrammarContents(m_uDynagram_Db_ID,key,m_uDynagram_Query_ID,phraseid);
- WaitForSingleObject(h_queryevent,INFINITE);
- return r_exist;
- }
- void NUANCE_MEMBER_FUNCTION
- CGrammarThread::HandleNuanceDBRecordContents(NuanceDBRecordContentsNotification const & n)
- {
- NuanceStatus status = n.GetStatus();
- if (NUANCE_OK != status) {
- ShowMsg("Grammar中内容不存在");
- r_exist=false;
- }else
- {
- char* str=(char*)n.GetPhraseString();
- if(strlen(str)>0)
- {
- //--避免CString 的长度限制,所以没用ShowMsg
- cout<<"Grammar中内容存在:"<<ENDL; { } }else m_uDynagram_Del_ID="m_pRcEngine-" unsigned ResetEvent(h_delevent); *key) CGrammarThread::DeleteGrm(char void SetEvent(h_queryevent); r_exist="true;" ShowMsg(?Grammar中内容不存在?); cout<<str<
- m_pRcEngine->DeleteRecord(m_uDynagram_Db_ID,key,m_uDynagram_Del_ID);
- WaitForSingleObject(h_delevent,INFINITE);
- }
- void CGrammarThread::CloseDB()
- {
- ResetEvent(h_closedbevent);
- m_pRcEngine->CloseDatabase(m_uDynagram_Db_ID);
- WaitForSingleObject(h_closedbevent,INFINITE);
- }
- void CGrammarThread::InsertGrammer(char *key, char *lable,bool tp)
- {
- ResetEvent(h_insertevent);
- unsigned m_uDynagram_Insert_ID = m_pRcEngine->GetUniqueID();
- m_pRcEngine->InsertDynamicGrammar(m_uDynagram_Db_ID,key,m_uDynagram_Insert_ID,lable,((tp)?DURATION_CALL:DURATION_PERMANENT));
- WaitForSingleObject(h_insertevent,INFINITE);
- }
- BYTE CGrammarThread::StatePrompt(bool _wait)
- {
- /*for(int i=0;i
- { ShowMsg("******");
- ShowMsg(m_parent->m_playlist[i]);
- }
- */
- if(m_parent->m_currentprompt<=0)
- {
- if(m_dtmfstate==1) time(&m_ft);
- SetEvent(h_playevent);
- return 1;
- }
- m_playreason=0;
- ResetEvent(h_playevent);
- m_uPlay_Prompt_ID= m_pRcEngine->GetUniqueID();
- m_pRcEngine->PlayPrompts(m_parent->m_playlist,m_uPlay_Prompt_ID);
- if(_wait) WaitForSingleObject(h_playevent,INFINITE);
- return m_playreason;
- }
- void DtmfThread(LPVOID lp)
- {
- CGrammarThread* p=(CGrammarThread*)lp;
- while(p->m_dtmfstate)
- {
- if(p->m_firsttime>0&&p->m_dtmfcnt==0&&p->m_uPlay_Prompt_ID==0)
- {
- time_t nt;
- time(&nt);
- if(nt-p->m_ft>=p->m_firsttime)
- {
- p->m_dtmfreason=1;
- p->m_dtmfstate=0;
- break;
- }
- }
- if(p->m_iddtime>0&&p->m_dtmfcnt>0)
- {
- time_t nt;
- time(&nt);
- if(nt-p->m_dt>=p->m_iddtime)
- {
- p->m_dtmfreason=1;
- p->m_dtmfstate=0;
- break;
- }
- }
- Sleep(1);
- }
- p->StopPrompt();
- SetEvent(p->h_dtmfevent);
- }
- BYTE CGrammarThread::RunDtmf(int dtmflen, int firsttime,int iddtime, char termno,char specdtmf)
- {
- ResetEvent(h_dtmfevent);
- memset(m_dtmfbuf,0,40);
- m_dtmfcnt=0;
- m_dtmfreason=0;
- m_dtmflen=dtmflen;
- m_firsttime=firsttime;
- m_iddtime=iddtime;
- m_termno=termno;
- m_specdtmf=specdtmf;
- time(&m_dt);
- m_dtmfstate=1;
- StatePrompt(false);
- _beginthread(DtmfThread,0,this);
- WaitForSingleObject(h_dtmfevent,INFINITE);
- WaitForSingleObject(h_playevent,INFINITE);
- return m_dtmfreason;
- }
- void CGrammarThread::StopDtmf(BYTE _r)
- {
- m_dtmfreason=_r;
- m_dtmfstate=0;
- }
- void CGrammarThread::StopPrompt()
- {
- if(m_uPlay_Prompt_ID>0)
- {
- m_pRcEngine->AbortPlayback(m_uPlay_Prompt_ID);
- }else
- {
- SetEvent(h_playevent);
- }
- }
- BYTE CGrammarThread::RecognizeUttr(bool hotword,WORD nbest, WORD nospeechtimeout,
- WORD toomuchms,WORD tooslowms, WORD rejthreshold,
- char* resultbuf,char *pText, char *_grammar,
- bool _overwrite, char *key,int dtmflen,
- int iddtime,char termno,char specdtmf)
- {
- BYTE ret=0;
- m_resultbuf=resultbuf;
- int m_nbest=nbest;
- double m_nospeechtimeout=nospeechtimeout*1.00;
- int m_toomuchms=toomuchms;
- int m_tooslowms=tooslowms;
- int m_rejthreshold=rejthreshold;
- SetParameters("rec.NumNBest",&m_nbest,0);
- SetParameters("client.NoSpeechTimeoutSecs",&m_nospeechtimeout,1);
- SetParameters("rec.ConfidenceRejectionThreshold",&m_rejthreshold,0);
- char glable[150];
- char f_grammar[150];
- char gkey[150];
- strcpy(glable,"DynaPeople0");
- if(key) strcpy(gkey,key);
- else sprintf(gkey,"nasr%d",m_parent->m_index);
- if(_grammar) strcpy(f_grammar,_grammar);
- else strcpy(f_grammar,".PEOPLE0");
- if(!_grammar)
- {
- if(strlen(pText)>0)
- {
- int ret=NewDynaGrammar(gkey,pText,_overwrite);
- if(ret!=0)
- {
- return 2;
- }
- }
- InsertGrammer(gkey,glable);
- }
- ResetEvent(h_recognevent);
- m_uRecognition_ID=m_pRcEngine->GetUniqueID();
- m_pRcEngine->RecognizeUtterance(f_grammar,m_uRecognition_ID);
- if(dtmflen<=0)
- {
- StatePrompt(false);
- WaitForSingleObject(h_playevent,INFINITE);
- WaitForSingleObject(h_recognevent,INFINITE);
- }
- else
- {
- ret=RunDtmf(dtmflen, 0,iddtime, termno, specdtmf);
- WaitForSingleObject(h_recognevent,INFINITE);
- if(ret!=8)
- {
- strcpy(resultbuf,m_dtmfbuf);
- }
- }
- return 1;
- }
- void CGrammarThread::SetParameters(char *pname, void *value, BYTE vtype)
- {
- ResetEvent(h_parameterevent);
- m_uParameter_ID=m_pRcEngine->GetUniqueID();
- switch(vtype)
- {
- case 0://INT
- m_pRcEngine->SetParameter(pname,*((int*)value),m_uParameter_ID);
- break;
- case 1://double
- m_pRcEngine->SetParameter(pname,*((double*)value),m_uParameter_ID);
- break;
- case 2://char*
- m_pRcEngine->SetParameter(pname,*((char**)value),m_uParameter_ID);
- break;
- }
- WaitForSingleObject(h_parameterevent,INFINITE);
- }
- HRESULT CGrammarThread::RecognizeNotify(RecResult *rr)
- {
- //判断结果是否合法,记录在 rec_result_type 中
- //jb 2001.12.07
- NuanceStatus status;
- RecResultType rec_result_type;
- status = RecResultGetType(rr,&rec_result_type);
- if (NUANCE_OK != status)
- {
- strcpy(m_resultbuf,"error");
- return 0;
- }
- //若是 不说话超时,则重播刚才的 Prompt
- if(rec_result_type == NO_SPEECH_TIMEOUT)
- {
- m_resultbuf[0]=0;
- return 0;
- }
- //若识别不成功
- if(rec_result_type != RECOGNITION)
- {
- strcpy(m_resultbuf,"nomatch");
- return 0;
- }
- // 得到结果的个数
- int num_results;
- status = RecResultNumAnswers(rr, &num_results);
- // nlresult for natural language interpretion
- m_resultbuf[0]=0;
- // 取得每一个结果
- for (int index = 0; index < num_results; ++index)
- {
- NLResult * m_pNl_Result=NULL;
- m_pNl_Result = NLInitializeResult(&status);
- char result_buf[MAX_STRING_PARAM_LEN];
- int confidence_score; //识别结果的确定性分数
- // 得到结果的 string 型
- status = RecResultString(rr, index, result_buf, sizeof(result_buf));
- if (NUANCE_OK != status)
- {
- strcpy(m_resultbuf,"error");
- return 0;
- }
- // 得到结果的 Confidence
- status = RecResultOverallConfidence(rr, index, &confidence_score);
- if (NUANCE_OK != status)
- {
- strcpy(m_resultbuf,"error");
- return 0;
- }
- status = RecResultNLResult(rr, index, m_pNl_Result);
- // 得到 NL Result 的个数
- int num_nl_results =
- NLGetNumberOfInterpretations(m_pNl_Result, &status);
- if (NUANCE_OK != status)
- {
- strcpy(m_resultbuf,"error");
- return 0;
- }
- for (int nl_index = 0; nl_index < num_nl_results; nl_index++)
- {
- //激活当前的 NL Result
- status = NLMakeIthInterpretationActive(m_pNl_Result,
- nl_index);
- if (NUANCE_OK != status)
- {
- strcpy(m_resultbuf,"error");
- return 0;
- }
- char nlvalue[300];
- for(int i=0;slotnamelist[i]!=NULL;i++)
- {
- status = NLGetSlotValueAsString(m_pNl_Result,slotnamelist[i],nlvalue,300);
- if(nlvalue[0]!=0)
- {
- strcat(m_resultbuf,nlvalue);
- strcat(m_resultbuf,";");
- }
- }
- }
- NLFreeResult(m_pNl_Result);
- }
- m_resultbuf[strlen(m_resultbuf)-1]=0;
- return 0;
- }
- void CGrammarThread::StopRecognize(BYTE r)
- {
- if(m_uRecognition_ID>0)
- {
- m_pRcEngine->Abort(m_uRecognition_ID);
- }else
- {
- SetEvent(h_recognevent);
- }
- }
- void CGrammarThread::StopAll()
- {
- StopPrompt();
- StopRecord();
- StopRecognize(0);
- if(m_dtmfstate==1) StopDtmf(0);
- }
- void CheckRecordTime(LPVOID lp)
- {
- CGrammarThread* p=(CGrammarThread*)lp;
- time_t ft;
- time(&ft);
- while(p->m_uRecord_ID>0)
- {
- time_t nt;
- time(&nt);
- if(nt-ft>=p->m_maxtime)
- {
- p->StopRecord();
- break;
- }
- Sleep(1);
- }
- }
- BYTE CGrammarThread::StateRecord(char* filename,BOOL beep,int maxtime,int stime,CString dtmf,int type,CString bgwav,int mtype)
- {
- m_recordreason=1;
- m_maxtime=maxtime;
- m_termdtmf=dtmf.GetAt(0);
- ResetEvent(h_recordevent);
- m_uRecord_ID=m_pRcEngine->GetUniqueID();
- //m_pRcEngine->RecordUtterance();
- m_pRcEngine->StartRecording(filename,m_uRecord_ID);
- if(m_maxtime>0)
- {
- _beginthread(CheckRecordTime,0,this);
- }
- WaitForSingleObject(h_recordevent,INFINITE);
- return m_recordreason;
- }
- void CGrammarThread::StopRecord()
- {
- if(m_uRecord_ID>0)
- {
- m_pRcEngine->StopRecording(m_uRecord_ID);
- }else
- {
- SetEvent(h_recordevent);
- }
- }
- void CGrammarThread::StateDisconnect()
- {
- m_pRcEngine->Hangup();
- }
- void CGrammarThread::StateTransfer(char *dest, char *src)
- {
- m_pRcEngine->TransferCall(dest,m_uAnswer_Call_ID);
- Sleep(1000);
- StateDisconnect();
- }
- #include "stdafx.h"
- #include "HandleDataThread.h"
- #include "process.h"
- #include "datastr.h"
- #ifdef _DEBUG
- #define new DEBUG_NEW
- #undef THIS_FILE
- static char THIS_FILE[] = __FILE__;
- #endif
- using namespace std;
- char m_tempwavdir[250];
- /////////////////////////////////////////////////////////////////////////////
- // CHandleDataThread
- void ShowMsg(CString msg);
- void DispatherThread(void* lp);
- CString ParseParString(char* src,char*pname,bool last=false);
- char ParseParChar(char* src,char*pname);
- int ParseParInt(char* src,char*pname);
- BOOL ParseParBool(char* src,char*pname);
- extern CONFIG_PARAM config_params[MAX_HANDLE_THREADS];
- extern HANDLE m_endevents [MAX_HANDLE_THREADS];
- IMPLEMENT_DYNCREATE(CHandleDataThread, CWinThread)
- BOOL MyPostThreadMessage(DWORD id,UINT tmsg,WPARAM wParam,LPARAM lParam);
- BOOL MyPostThreadMessage(DWORD id,UINT tmsg,WPARAM wParam,LPARAM lParam)
- {
- if(!(::PostThreadMessage(id,tmsg,wParam,lParam)))
- {
- NOTIFY_MESSAGE* ps=(NOTIFY_MESSAGE*)lParam;
- delete ps;
- return FALSE;
- }
- return TRUE;
- }
- char ParseParChar(char* src,char*pname)
- {
- CString ret=ParseParString(src,pname);
- if(ret.GetLength()>0)
- return (char)ret.GetAt(0);
- return 0;
- }
- BOOL ParseParBool(char* src,char*pname)
- {
- CString ret=ParseParString(src,pname);
- ret.TrimLeft();
- ret.TrimRight();
- if(ret.CompareNoCase("true")==0)
- return TRUE;
- return FALSE;
- }
- CString ParseParString(char* src,char*pname,bool last)
- {
- CString ret="";
- CString strsrc="";
- strsrc.Format("%s",src);
- int pstart=0;
- int pos=0;
- while(pstart<STRSRC.GETLENGTH()) if(ret.GetLength() ret="strsrc.Mid(pstart+strlen(pname)+1);" CString { src,char*pname) ParseParInt(char* int } ret; return pstart="pos+2;" break; else if(last) if(tpname.CompareNoCase(CString(pname)+?:?)="=0)" tpname="tmpName.Left(strlen(pname)+1);" ) if(tmpName!="" tmpName="strsrc.Mid(pstart,pos-pstart);" pos='strsrc.Find("@@",pstart);' if(pos="=-1)">0)
- {
- return atoi(ret);
- }
- return 0;
- }
- DWORD execmdline(char* cmdline)
- {
- DWORD Result=100;
- STARTUPINFO StartupInfo={0};
- PROCESS_INFORMATION ProcessInfo;
- StartupInfo.cb = sizeof(StartupInfo);
- StartupInfo.dwFlags = STARTF_USESHOWWINDOW;
- StartupInfo.wShowWindow = SW_HIDE;
- if(CreateProcess(NULL,cmdline,
- NULL,NULL,FALSE,
- 0,NULL,NULL,
- &StartupInfo,&ProcessInfo
- ))
- {
- WaitForSingleObject(ProcessInfo.hProcess,INFINITE);
- GetExitCodeProcess(ProcessInfo.hProcess,&Result);
- }
- return Result;
- }
- CHandleDataThread::CHandleDataThread()
- {
- }
- CHandleDataThread::CHandleDataThread(int _index)
- {
- m_callstate=0;
- m_currentprompt=0;
- for(int i=0;i<MAX_PROMPT;I++) { int } return p_rc- CHandleDataThread::ExitInstance() TRUE; CHandleDataThread::InitInstance() BOOL CHandleDataThread::~CHandleDataThread() _beginthread(DispatherThread,0,this); m_index="_index;" m_eevent="CreateEvent(NULL,FALSE,FALSE,NULL);" sprintf(m_desc,?%d?,_index); m_playlist[i]="0;">CloseDB();
- delete p_rc;
- WaitForSingleObject(m_eevent,INFINITE);
- CloseHandle(m_eevent);
- SetEvent(m_endevents[m_index]);
- return CWinThread::ExitInstance();
- }
- BEGIN_MESSAGE_MAP(CHandleDataThread, CWinThread)
- //{{AFX_MSG_MAP(CHandleDataThread)
- // NOTE - the ClassWizard will add and remove mapping macros here.
- //}}AFX_MSG_MAP
- ON_THREAD_MESSAGE(IVR_NOTIFY,OnXmlMsgEvent)
- ON_THREAD_MESSAGE(WM_HANDLE_PACKAGE,HandleData)
- ON_THREAD_MESSAGE(WM_CALL_CONNECT,OnCallConnect)
- ON_THREAD_MESSAGE(WM_CALL_DISCONNECT,OnCallDisConnect)
- END_MESSAGE_MAP()
- /////////////////////////////////////////////////////////////////////////////
- // CHandleDataThread message handlers
- void CHandleDataThread::HandleData(WPARAM wPa,LPARAM lPa)
- {
- }
- void CHandleDataThread::OnXmlMsgEvent(WPARAM wPa,LPARAM lPa)
- {
- CString Msgstring;
- NOTIFY_MESSAGE* p=(NOTIFY_MESSAGE*)lPa;
- if(m_callstate==0||m_callstate==2)
- {
- if(p->command!=DEBUG_MESSAGE)
- {
- delete p;
- TerminalBrowser();
- return;
- }else
- {
- ShowMsg(p->szData);
- delete p;
- TerminalBrowser();
- return;
- }
- }
- switch(p->command)
- {
- case DEBUG_MESSAGE:
- {
- ShowMsg(p->szData);
- CString msgx=p->szData;
- delete p;
- if(msgx=="vxml thread quit...")
- {
- p_rc->StateDisconnect();
- }
- }
- break;
- case OUTPUT_AUDIO:
- {
- Msgstring.Format("OUTPUT_AUDIO:%s",p->szData);
- ShowMsg((char*)(LPCTSTR)Msgstring);
- m_playlist[m_currentprompt]=(char*)malloc(strlen(p->szData)+1);
- strcpy(m_playlist[m_currentprompt],p->szData);
- m_currentprompt++;
- delete p;
- NOTIFY_MESSAGE* ps=new NOTIFY_MESSAGE;
- ps->command=ACTION_COMPLETE;
- MyPostThreadMessage(m_browserThreadId,IVR_NOTIFY,0,LPARAM(ps));
- }
- break;
- case EDIT_WAV:
- Msgstring.Format("EDIT_WAV:%s",p->szData);
- ShowMsg((char*)(LPCTSTR)Msgstring);
- break;
- case ACTION_CHAT:
- Msgstring.Format("ACTON_CHAT:%s",p->szData);
- ShowMsg((char*)(LPCTSTR)Msgstring);
- break;
- case WAV_INFO:
- Msgstring.Format("WAV_INFO:%s",p->szData);
- ShowMsg((char*)(LPCTSTR)Msgstring);
- break;
- case ACTION_EXEC:
- {
- Msgstring.Format("ACTION_EXEC:%s",p->szData);
- ShowMsg((char*)(LPCTSTR)Msgstring);
- CString cmd=ParseParString(p->szData,"cmd");
- CString params=ParseParString(p->szData,"params");
- delete p;
- cmd=cmd + " " + params;
- int ret=(int)execmdline((char*)(LPCTSTR)cmd);
- CString dStr;
- dStr.Format("%d",ret);
- NOTIFY_MESSAGE* ps=new NOTIFY_MESSAGE;
- ps->command=ACTION_COMPLETE;
- ps->szData=new char[dStr.GetLength()+1];
- strcpy(ps->szData,dStr);
- MyPostThreadMessage(m_browserThreadId,IVR_NOTIFY,0,LPARAM(ps));
- }
- break;
- case ACTION_CVTWAVE:
- {
- Msgstring.Format("ACTION_CVTWAVE:%s",p->szData);
- ShowMsg((char*)(LPCTSTR)Msgstring);
- CString action=ParseParString(p->szData,"action");
- CString src=ParseParString(p->szData,"src");
- CString dest=ParseParString(p->szData,"dest");
- delete p;
- CString dStr="error";
- action.MakeLower();
- FILE* fp=NULL;
- if((fp=fopen((char*)(LPCTSTR)src,"r"))!=NULL)
- {
- fclose(fp);
- if(action=="p8k16b2a8k8b")
- {
- }
- else if(action=="a8k8b2p8k16b")
- {
- }
- dStr="success";
- }
- NOTIFY_MESSAGE* ps=new NOTIFY_MESSAGE;
- ps->command=ACTION_COMPLETE;
- ps->szData=new char[dStr.GetLength()+1];
- strcpy(ps->szData,dStr);
- MyPostThreadMessage(m_browserThreadId,IVR_NOTIFY,0,LPARAM(ps));
- }
- break;
- case OUTPUT_CATWAV:
- Msgstring.Format("OUTPUT_CATWAV:%s",p->szData);
- ShowMsg((char*)(LPCTSTR)Msgstring);
- break;
- case OUTPUT_DISCONNECT:
- ShowMsg("OUTPUT_DISCONNECT");
- delete p;
- PlayPrompt(true);
- p_rc->StateDisconnect();
- break;
- case INPUT_DTMF_M:
- {
- Msgstring.Format("INPUT_DTMF_M:%s",p->szData);
- ShowMsg((char*)(LPCTSTR)Msgstring);
- Handle_DTMF_M(p);
- }
- break;
- case INPUT_ENROLL:
- {
- Msgstring.Format("INPUT_ENROLL:%s",p->szData);
- ShowMsg((char*)(LPCTSTR)Msgstring);
- }
- break;
- case COPY_DYNAGRAMMAR:
- {
- Msgstring.Format("COPY_DYNAGRAMMAR:%s",p->szData);
- ShowMsg((char*)(LPCTSTR)Msgstring);
- }
- break;
- case ACTION_DYNAGRAMMAR:
- {
- Msgstring.Format("ACTION_DYNAGRAMMAR:%s",p->szData);
- ShowMsg((char*)(LPCTSTR)Msgstring);
- }
- break;
- case INPUT_SPOKEN_RECORD:
- {
- Msgstring.Format("INPUT_SPOKEN_RECORD:%s",p->szData);
- ShowMsg((char*)(LPCTSTR)Msgstring);
- Hand_INPUT_SPOKEN_RECORD(p);
- }
- break;
- case START_PROMPT:
- {
- delete p;
- ShowMsg("START_PROMPT");
- PlayPrompt(true);
- NOTIFY_MESSAGE* ps=new NOTIFY_MESSAGE;
- ps->command=ACTION_COMPLETE;
- MyPostThreadMessage(m_browserThreadId,IVR_NOTIFY,0,LPARAM(ps));
- }
- break;
- case OUTPUT_DIALOUT:
- Msgstring.Format("OUTPUT_DIALOUT:%s",p->szData);
- ShowMsg((char*)(LPCTSTR)Msgstring);
- break;
- case OUTPUT_TRANSFER:
- Msgstring.Format("OUTPUT_TRANSFER:%s",p->szData);
- ShowMsg((char*)(LPCTSTR)Msgstring);
- Hand_TRANSFER(p);
- break;
- case SEND_SMS:
- Msgstring.Format("SEND_SMS:%s",p->szData);
- ShowMsg((char*)(LPCTSTR)Msgstring);
- break;
- case EMAIL_SMTP:
- Msgstring.Format("EMAIL_SMTP:%s",p->szData);
- ShowMsg((char*)(LPCTSTR)Msgstring);
- break;
- case TTS_FILE:
- Msgstring.Format("TTS:%s",p->szData);
- ShowMsg((char*)(LPCTSTR)Msgstring);
- break;
- case INPUT_SR_M:
- {
- Msgstring.Format("INPUT_SR_M:%s",p->szData);
- ShowMsg((char*)(LPCTSTR)Msgstring);
- Handle_INPUT_SR_M(p);
- }
- break;
- case INPUT_SRDTMF_M:
- {
- Msgstring.Format("INPUT_SRDTMF_M:%s",p->szData);
- ShowMsg((char*)(LPCTSTR)Msgstring);
- Hand_INPUT_SRDTMF_M(p);
- }
- break;
- default:
- delete p;
- break;
- }
- }
- void DispatherThread(void* lp)
- {
- CHandleDataThread* p=(CHandleDataThread*)lp;
- p->InitRc();
- }
- bool CHandleDataThread::InitRc()
- {
- CString msg;
- NuanceStatus status;
- NuanceConfig * config =
- NuanceConfigBuildFromCommandLine(&(config_params[m_index].argc), config_params[m_index].argv, 1, &status);
- if ( (NULL == config) || (NUANCE_OK != status) ) {
- msg.Format("T%d: NuanceConfigBuildFromCommandLine 失败",m_index);
- ShowMsg(msg);
- return 0;
- }
- int silent_flag = 1;
- DBDescriptor * dynagram_db_desc =
- NewDBDescriptorFromCommandLine(&(config_params[m_index].argc), config_params[m_index].argv, "", &silent_flag);
- Dispatcher * d = new Dispatcher(config, status);
- if (NUANCE_OK != status) {
- msg.Format("T%d: Dispatcher create 失败",m_index);
- ShowMsg(msg);
- delete d;
- NuanceConfigFree(config);
- return 0;
- }
- p_rc=new CGrammarThread(*config,*d,dynagram_db_desc,this);
- msg.Format("T%d: Dispatcher listening......",m_index);
- ShowMsg(msg);
- SetEvent(m_endevents[m_index]);
- d->Dispatch();
- delete d;
- d = NULL;
- NuanceConfigFree(config);
- config = NULL;
- msg.Format("T%d: Dispatcher Close......",m_index);
- ShowMsg(msg);
- msg.Empty();
- SetEvent(m_eevent);
- return true;
- }
- void sss(LPVOID lp)
- {
- CHandleDataThread* p=(CHandleDataThread*)lp;
- Sleep(10000);
- p->p_rc->StopPrompt();
- }
- void CHandleDataThread::PlayPrompt(bool _wait)
- {
- p_rc->StatePrompt(_wait);
- }
- void CHandleDataThread::CreateBrowser()
- {
- CreateBrowserThread(m_homepage,m_nThreadID,&m_browserThreadId,m_callingID,m_calledID,m_desc,m_tempwavdir);
- }
- void CHandleDataThread::OnCallConnect(WPARAM wPa,LPARAM lPa)
- {
- RemoveAllWav();
- CreateBrowser();
- }
- void CHandleDataThread::RemoveAllWav()
- {
- for(int i=0;i<M_CURRENTPROMPT;I++) { int } m_playlist[i]="NULL;" len="ParseParInt(p-" *p) CHandleDataThread::Handle_DTMF_M(NOTIFY_MESSAGE void m_currentprompt="0;" ; free(m_playlist[i])>szData,"len");
- int finalsilence=ParseParInt(p->szData,"finalsilence");
- int firsttimeout=ParseParInt(p->szData,"firsttime");
- char termdtmf=ParseParChar(p->szData,"termdtmf");
- char sdtmf=ParseParChar(p->szData,"sdtmf");
- if(finalsilence==0) finalsilence=4;
- if(len==0) len=40;
- delete p;
- BYTE ret=p_rc->RunDtmf(len,firsttimeout,finalsilence,termdtmf,sdtmf);
- if(ret==1)
- {
- ShowMsg(p_rc->m_dtmfbuf);
- NOTIFY_MESSAGE* ps=new NOTIFY_MESSAGE;
- ps->command=ACTION_COMPLETE;
- ps->szData=new char[p_rc->m_dtmfcnt+1];
- strcpy(ps->szData,p_rc->m_dtmfbuf);
- MyPostThreadMessage(m_browserThreadId,IVR_NOTIFY,0,LPARAM(ps));
- }
- }
- void CHandleDataThread::Handle_INPUT_SR_M(NOTIFY_MESSAGE *p)
- {
- CString gkey=ParseParString(p->szData,"gkey");
- BOOL _overwrite=ParseParBool(p->szData,"gover");
- CString grammar=ParseParString(p->szData,"grammar");
- WORD nbest=(WORD)ParseParInt(p->szData,"nbest");
- if(nbest==0) nbest=1;
- WORD nospeechtimeout=(WORD)ParseParInt(p->szData,"nospeechtimeout");
- if(nospeechtimeout==0) nospeechtimeout=7;
- WORD toomuchms=(WORD)ParseParInt(p->szData,"toomuchms");
- if(toomuchms==0) toomuchms=60;
- WORD tooslowms=(WORD)ParseParInt(p->szData,"tooslowms");
- if(tooslowms==0) tooslowms=0;
- WORD rejthreshold=(WORD)ParseParInt(p->szData,"rejthreshold");
- if(rejthreshold==0) rejthreshold=38;
- BOOL hot=(WORD)ParseParBool(p->szData,"hotword");
- bool hotword=false;
- if(hot) hotword=true;
- delete p;
- char r[100];
- memset(r,0,100);
- strcpy(r,"error");
- BYTE ret;
- if(grammar.Left(1)==".")
- ret=p_rc->RecognizeUttr(hotword,nbest, nospeechtimeout, toomuchms, tooslowms, rejthreshold,r,NULL,(char*)(LPCTSTR)grammar,(_overwrite?true:false),((gkey.GetLength()>0)?((char*)(LPCTSTR)gkey):NULL),0,10,'#');
- else
- ret=p_rc->RecognizeUttr(hotword,nbest, nospeechtimeout, toomuchms, tooslowms, rejthreshold,r,(char*)(LPCTSTR)grammar,NULL,(_overwrite?true:false),((gkey.GetLength()>0)?((char*)(LPCTSTR)gkey):NULL),0,10,'#');
- ShowMsg(r);
- NOTIFY_MESSAGE* ps=new NOTIFY_MESSAGE;
- ps->command=ACTION_COMPLETE;
- ps->szData=new char[strlen(r)+1];
- strcpy(ps->szData,r);
- MyPostThreadMessage(m_browserThreadId,IVR_NOTIFY,0,LPARAM(ps));
- }
- void CHandleDataThread::Hand_INPUT_SRDTMF_M(NOTIFY_MESSAGE *p)
- {
- CString gkey=ParseParString(p->szData,"gkey");
- BOOL _overwrite=ParseParBool(p->szData,"gover");
- CString grammar=ParseParString(p->szData,"grammar");
- int len=ParseParInt(p->szData,"len");
- int finalsilence=ParseParInt(p->szData,"finalsilence");
- int firsttimeout=ParseParInt(p->szData,"firsttime");
- char termdtmf=ParseParChar(p->szData,"termdtmf");
- char sdtmf=ParseParChar(p->szData,"sdtmf");
- if(finalsilence==0) finalsilence=4;
- if(len==0) len=40;
- WORD nbest=(WORD)ParseParInt(p->szData,"nbest");
- if(nbest==0) nbest=1;
- WORD nospeechtimeout=(WORD)ParseParInt(p->szData,"nospeechtimeout");
- if(nospeechtimeout==0) nospeechtimeout=7;
- WORD toomuchms=(WORD)ParseParInt(p->szData,"toomuchms");
- if(toomuchms==0) toomuchms=60;
- WORD tooslowms=(WORD)ParseParInt(p->szData,"tooslowms");
- if(tooslowms==0) tooslowms=0;
- WORD rejthreshold=(WORD)ParseParInt(p->szData,"rejthreshold");
- if(rejthreshold==0) rejthreshold=38;
- BOOL hot=(WORD)ParseParBool(p->szData,"hotword");
- bool hotword=false;
- if(hot) hotword=true;
- delete p;
- char r[100];
- memset(r,0,100);
- strcpy(r,"error");
- BYTE ret;
- if(grammar.Left(1)==".")
- ret=p_rc->RecognizeUttr(hotword,nbest, nospeechtimeout, toomuchms, tooslowms, rejthreshold,r,NULL,(char*)(LPCTSTR)grammar,(_overwrite?true:false),((gkey.GetLength()>0)?((char*)(LPCTSTR)gkey):NULL),len,finalsilence,termdtmf,sdtmf);
- else
- ret=p_rc->RecognizeUttr(hotword,nbest, nospeechtimeout, toomuchms, tooslowms, rejthreshold,r,(char*)(LPCTSTR)grammar,NULL,(_overwrite?true:false),((gkey.GetLength()>0)?((char*)(LPCTSTR)gkey):NULL),len,finalsilence,termdtmf,sdtmf);
- ShowMsg(r);
- NOTIFY_MESSAGE* ps=new NOTIFY_MESSAGE;
- ps->command=ACTION_COMPLETE;
- ps->szData=new char[strlen(r)+1];
- strcpy(ps->szData,r);
- MyPostThreadMessage(m_browserThreadId,IVR_NOTIFY,0,LPARAM(ps));
- }
- void CHandleDataThread::OnCallDisConnect(WPARAM wPa,LPARAM lPa)
- {
- printf("disconnected/r/n");
- TerminalBrowser();
- }
- void CHandleDataThread::Hand_INPUT_SPOKEN_RECORD(NOTIFY_MESSAGE *p)
- {
- int maxtime=ParseParInt(p->szData,"maxtime");
- int iddtime=ParseParInt(p->szData,"finalsilence");
- CString dtmf=ParseParString(p->szData,"dtmfterm");
- BOOL beep=ParseParBool(p->szData,"beep");
- CString type=ParseParString(p->szData,"type");
- CString bgmusic=ParseParString(p->szData,"bgmusic");
- int mixtype=ParseParInt(p->szData,"mixtype");
- int rtype=0;
- if(dtmf=="") dtmf="a";
- if(type=="audio/vox") rtype=1;
- delete p;
- PlayPrompt(true);
- CString filename=GenuniqueRecFileName(rtype);
- BYTE ret=p_rc->StateRecord((char*)(LPCTSTR)filename,beep,maxtime,iddtime,dtmf,rtype,bgmusic,mixtype);
- if(ret!=1) filename="";
- NOTIFY_MESSAGE* ps=new NOTIFY_MESSAGE;
- ps->command=ACTION_COMPLETE;
- ps->szData=new char[filename.GetLength()+1];
- strcpy(ps->szData,filename);
- MyPostThreadMessage(m_browserThreadId,IVR_NOTIFY,0,LPARAM(ps));
- }
- CString CHandleDataThread::GenuniqueRecFileName(int type)
- {
- int index=0;
- CString _filter="";
- if(type==0) _filter="wav";
- else _filter="vox";
- time_t _t=0;
- time(&_t);
- CString _newfile;
- CString _tmpdir("e://app");
- _tmpdir.TrimRight("//");
- _newfile.Format("%s//rec%d%ld.%s",_tmpdir,m_index,_t,_filter);
- CFileFind file;
- while(file.FindFile(_newfile))
- {
- index+=1;
- _newfile.Format("%s//rec%d%ld%d.%s",_tmpdir,m_index,_t,index,_filter);
- file.Close ();
- }
- return _newfile;
- }
- void CHandleDataThread::Hand_TRANSFER(NOTIFY_MESSAGE *p)
- {
- CString dest=ParseParString(p->szData,"dest");
- BOOL bridge=ParseParBool(p->szData,"bridge");
- int chindex=ParseParInt(p->szData,"chindex");
- int delay=ParseParInt(p->szData,"delay");
- CString src=ParseParString(p->szData,"src");
- delete p;
- if(!bridge)
- {
- }else
- {
- }
- p_rc->StateTransfer((char*)(LPCTSTR)dest,(char*)(LPCTSTR)src);
- }
- void CHandleDataThread::TerminalBrowser()
- {
- if(m_browserThreadId!=0)
- {
- ::PostThreadMessage(m_browserThreadId,WM_QUIT,0,0);
- m_browserThreadId=0;
- }
- }
需要源码的留下Email