当前位置:   article > 正文

C++语音识别接口快速入门(Microsoft Speech SDK)_c++语音识别接口快速入门(microsoft speech sdk)

c++语音识别接口快速入门(microsoft speech sdk)

目录

一、安装SDK

安装MicrosoftSpeechPlatformSDK.msi,默认路径安装即可。 
下载路径: 
http://download.csdn.net/detail/michaelliang12/9510691

二、新建工程,配置环境

设置: 
1,属性–配置属性–C/C++–常规–附加包含目录:C:\Program Files\Microsoft SDKs\Speech\v11.0\Include(具体路径与安装路径有关) 
2,属性–配置属性–链接器–输入–附加依赖项:sapi.lib;

三、语音识别代码

语音识别接口可分为文字转语音和语音转文字

1、文字转语音

需要添加的头文件:

  1. #include <sapi.h> //导入语音头文件
  2. #pragma comment(lib,"sapi.lib") //导入语音头文件库
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3

函数:

  1. void CBodyBasics::MSSSpeak(LPCTSTR speakContent)// speakContent为LPCTSTR型的字符串,调用此函数即可将文字转为语音
  2. {
  3. ISpVoice *pVoice = NULL;
  4. //初始化COM接口
  5. if (FAILED(::CoInitialize(NULL)))
  6. MessageBox(NULL, (LPCWSTR)L"COM接口初始化失败!", (LPCWSTR)L"提示", MB_ICONWARNING | MB_CANCELTRYCONTINUE | MB_DEFBUTTON2);
  7. //获取SpVoice接口
  8. HRESULT hr = CoCreateInstance(CLSID_SpVoice, NULL, CLSCTX_ALL, IID_ISpVoice, (void**)&pVoice);
  9. if (SUCCEEDED(hr))
  10. {
  11. pVoice->SetVolume((USHORT)100); //设置音量,范围是 0 -100
  12. pVoice->SetRate(2); //设置速度,范围是 -10 - 10
  13. hr = pVoice->Speak(speakContent, 0, NULL); //Speak函数的第二个参数如果设置成SPF_IS_FILENAME 则第一个参数指向一个文本(txt)文件
  14. pVoice->Release();
  15. pVoice = NULL;
  16. }
  17. //释放com资源
  18. ::CoUninitialize();
  19. }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30

2、语音转文字

这个稍微麻烦一点,因为需要实时监控麦克风,涉及到windows的消息机制。 
(1)首先设置工程属性: 
属性–配置属性–C/C++–预处理器–预处理器定义:_WIN32_DCOM;

(2)需要添加的头文件:

  1. #include <sapi.h> //导入语音头文件
  2. #pragma comment(lib,"sapi.lib") //导入语音头文件库
  3. #include <sphelper.h>//语音识别头文件
  4. #include <atlstr.h>//要用到CString
  5. #pragma once
  6. const int WM_RECORD = WM_USER + 100;//定义消息
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

(3)在程序的.h头文件中定义变量

  1. //定义变量
  2. CComPtr<ISpRecognizer>m_cpRecoEngine;// 语音识别引擎(recognition)的接口。
  3. CComPtr<ISpRecoContext>m_cpRecoCtxt;// 识别引擎上下文(context)的接口。
  4. CComPtr<ISpRecoGrammar>m_cpCmdGrammar;// 识别文法(grammar)的接口。
  5. CComPtr<ISpStream>m_cpInputStream;// 流()的接口。
  6. CComPtr<ISpObjectToken>m_cpToken;// 语音特征的(token)接口。
  7. CComPtr<ISpAudio>m_cpAudio;// 音频(Audio)的接口。(用来保存原来默认的输入流)
  8. ULONGLONG ullGrammerID;
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

(4)创建语音识别初始化函数(程序刚开始执行的时候调用,例如文末示例代码中,将此初始化函数放在对话框初始化消息WM_INITDIALOG的响应代码里)

  1. //语音识别初始化函数
  2. void CBodyBasics::MSSListen()
  3. {
  4. //初始化COM接口
  5. if (FAILED(::CoInitialize(NULL)))
  6. MessageBox(NULL, (LPCWSTR)L"COM接口初始化失败!", (LPCWSTR)L"提示", MB_ICONWARNING | MB_CANCELTRYCONTINUE | MB_DEFBUTTON2);
  7. HRESULT hr = m_cpRecoEngine.CoCreateInstance(CLSID_SpSharedRecognizer);//创建Share型识别引擎
  8. if (SUCCEEDED(hr))
  9. {
  10. hr = m_cpRecoEngine->CreateRecoContext(&m_cpRecoCtxt);//创建识别上下文接口
  11. hr = m_cpRecoCtxt->SetNotifyWindowMessage(m_hWnd, WM_RECORD, 0, 0);//设置识别消息
  12. const ULONGLONG ullInterest = SPFEI(SPEI_SOUND_START) | SPFEI(SPEI_SOUND_END) | SPFEI(SPEI_RECOGNITION);//设置我们感兴趣的事件
  13. hr = m_cpRecoCtxt->SetInterest(ullInterest, ullInterest);
  14. hr = SpCreateDefaultObjectFromCategoryId(SPCAT_AUDIOIN, &m_cpAudio);
  15. m_cpRecoEngine->SetInput(m_cpAudio, true);
  16. //创建语法规则
  17. //dictation听说式
  18. //hr = m_cpRecoCtxt->CreateGrammar(GIDDICTATION, &m_cpDictationGrammar);
  19. //if (SUCCEEDED(hr))
  20. //{
  21. // hr = m_cpDictationGrammar->LoadDictation(NULL, SPLO_STATIC);//加载词典
  22. //}
  23. //C&C命令式,此时语法文件使用xml格式
  24. ullGrammerID = 1000;
  25. hr = m_cpRecoCtxt->CreateGrammar(ullGrammerID, &m_cpCmdGrammar);
  26. WCHAR wszXMLFile[20] = L"";//加载语法
  27. MultiByteToWideChar(CP_ACP, 0, (LPCSTR)"CmdCtrl.xml", -1, wszXMLFile, 256);//ANSI转UNINCODE
  28. hr = m_cpCmdGrammar->LoadCmdFromFile(wszXMLFile, SPLO_DYNAMIC);
  29. //MessageBox(NULL, (LPCWSTR)L"语音识别已启动!", (LPCWSTR)L"提示", MB_CANCELTRYCONTINUE );
  30. //激活语法进行识别
  31. //hr = m_cpDictationGrammar->SetDictationState(SPRS_ACTIVE);//dictation
  32. hr = m_cpCmdGrammar->SetRuleState(NULL, NULL, SPRS_ACTIVE);//C&C
  33. hr = m_cpRecoEngine->SetRecoState(SPRST_ACTIVE);
  34. }
  35. else
  36. {
  37. MessageBox(NULL, (LPCWSTR)L"语音识别引擎启动出错!", (LPCWSTR)L"警告", MB_OK);
  38. exit(0);
  39. }
  40. //释放com资源
  41. ::CoUninitialize();
  42. //hr = m_cpCmdGrammar->SetRuleState(NULL, NULL, SPRS_INACTIVE);//C&C
  43. }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67

(5)定义消息处理函数 
需要和其他的消息处理代码放在一起,如本文代码中,放在文末示例代码的DlgProc()函数尾部。本文整个其他的代码块都可以直接照搬,只需要更改如下的消息反应模块即可

  1. //消息处理函数
  2. USES_CONVERSION;
  3. CSpEvent event;
  4. if (m_cpRecoCtxt)
  5. {
  6. while (event.GetFrom(m_cpRecoCtxt) == S_OK){
  7. switch (event.eEventId)
  8. {
  9. case SPEI_RECOGNITION:
  10. {
  11. //识别出了语音
  12. m_bGotReco = TRUE;
  13. static const WCHAR wszUnrecognized[] = L"<Unrecognized>";
  14. CSpDynamicString dstrText;
  15. ////取得识别结果
  16. if (FAILED(event.RecoResult()->GetText(SP_GETWHOLEPHRASE, SP_GETWHOLEPHRASE, TRUE, &dstrText, NULL)))
  17. {
  18. dstrText = wszUnrecognized;
  19. }
  20. BSTR SRout;
  21. dstrText.CopyToBSTR(&SRout);
  22. CString Recstring;
  23. Recstring.Empty();
  24. Recstring = SRout;
  25. //做出反应(*****消息反应模块*****)
  26. if (Recstring == "发短信")
  27. {
  28. //MessageBox(NULL, (LPCWSTR)L"好的", (LPCWSTR)L"提示", MB_OK);
  29. MSSSpeak(LPCTSTR(_T("好,马上发短信!")));
  30. }
  31. else if (Recstring == "李雷")
  32. {
  33. MSSSpeak(LPCTSTR(_T("好久没看见他了,真是 long time no see")));
  34. }
  35. }
  36. break;
  37. }
  38. }
  39. }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51

(6)修改语法文件 
修改CmdCtrl.xml文件,可以提高某些词汇的识别度,对里面的词识别效果会很好多,如人名等。(此外,单独运行exe时也需要将此文件和exe放在同一文件夹内,不放也不会报错,只是语法文件里的词汇识别效果变差)

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <GRAMMAR LANGID="804">
  3. <DEFINE>
  4. <ID NAME="VID_SubName1" VAL="4001"/>
  5. <ID NAME="VID_SubName2" VAL="4002"/>
  6. <ID NAME="VID_SubName3" VAL="4003"/>
  7. <ID NAME="VID_SubName4" VAL="4004"/>
  8. <ID NAME="VID_SubName5" VAL="4005"/>
  9. <ID NAME="VID_SubName6" VAL="4006"/>
  10. <ID NAME="VID_SubName7" VAL="4007"/>
  11. <ID NAME="VID_SubName8" VAL="4008"/>
  12. <ID NAME="VID_SubName9" VAL="4009"/>
  13. <ID NAME="VID_SubNameRule" VAL="3001"/>
  14. <ID NAME="VID_TopLevelRule" VAL="3000"/>
  15. </DEFINE>
  16. <RULE ID="VID_TopLevelRule" TOPLEVEL="ACTIVE">
  17. <O>
  18. <L>
  19. <P>我要</P>
  20. <P>运行</P>
  21. <P>执行</P>
  22. </L>
  23. </O>
  24. <RULEREF REFID="VID_SubNameRule" />
  25. </RULE>
  26. <RULE ID="VID_SubNameRule" >
  27. <L PROPID="VID_SubNameRule">
  28. <P VAL="VID_SubName1">发短信</P>
  29. <P VAL="VID_SubName2">是的</P>
  30. <P VAL="VID_SubName3">好的</P>
  31. <P VAL="VID_SubName4">不用</P>
  32. <P VAL="VID_SubName5">李雷</P>
  33. <P VAL="VID_SubName6">韩梅梅</P>
  34. <P VAL="VID_SubName7">中文界面</P>
  35. <P VAL="VID_SubName8">英文界面</P>
  36. <P VAL="VID_SubName9">English</P>
  37. </L>
  38. </RULE>
  39. </GRAMMAR>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40

源代码下载

注意,本代码是在原来的项目中截取出来的,但可以独立运行。 
Microsoft Speech SDK 安装包下载: 
http://download.csdn.net/detail/michaelliang12/9510691 
文中示例程序下载(之前下载分数太高,我已经重新上传了新版本,也解决了kincect20.lib报错的问题。由于自己经常在csdn上下东西,也需要积分,需要还是需要各位捧场,2积分。。): 
http://download.csdn.net/detail/michaelliang12/9766783

存在的bug:每次运行完程序,Windows的语音识别助手不会自动关闭,需要自己手动关闭。若不关闭,则下次启动程序可能会出错。大家如果有好的解决办法,请联系我,谢了!

参考网站

1,http://www.cnblogs.com/eping/archive/2010/05/23/1742201.html 
2,http://blog.csdn.net/pamchen/article/details/7856207 
3,http://blog.csdn.net/jmxiaocai/article/details/7036033 
4,http://blog.csdn.net/buaalei/article/details/5372544(主要参考) 
5,http://blog.csdn.net/itcastcpp/article/details/5313204 
6,http://blog.csdn.net/artemisrj/article/details/8723095(MFC的消息处理响应版本)

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家自动化/article/detail/949932
推荐阅读
相关标签
  

闽ICP备14008679号