`
kevin19900306
  • 浏览: 448928 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

C#调用SAPI实现语音识别的两种方法

阅读更多
通过微软的SAPI,不仅仅可以实现语音合成TTS,同样可以实现语音识别SR。下面我们就介绍并贴出相关代码。主要有两种方式:
1、使用COM组件技术,不管是C++,C#,Delphi都能玩的转,开发出来的东西在XP和WIN7都能跑。(注意要引入系统组件SpeechLib,XP要安装识别引擎)
2、使用WIN7的windows api,其实最终还是调用了SAPI,所以开发出来的东西就只能在WIN7上面跑。

其实不管是哪一种,都是调用SAPI,可能后一种代码比较简单。

使用第一种方式,需要注意在COM选项卡里面的Microsoft Speech  object  library引用
public class SpRecognition
    {
        private static SpRecognition _Instance = null;
        private SpeechLib.ISpeechRecoGrammar isrg;
        private SpeechLib.SpSharedRecoContextClass ssrContex = null;

        public delegate void StringEvent(string str);
        public StringEvent SetMessage;

        private SpRecognition()
        {
            ssrContex = new SpSharedRecoContextClass();
            isrg = ssrContex.CreateGrammar(1);
            SpeechLib._ISpeechRecoContextEvents_RecognitionEventHandler recHandle =
                 new _ISpeechRecoContextEvents_RecognitionEventHandler(ContexRecognition);
            ssrContex.Recognition += recHandle;
        }
        public void BeginRec()
        {
            isrg.DictationSetState(SpeechRuleState.SGDSActive);
        }
        public static SpRecognition instance()
        {
            if (_Instance == null)
                _Instance = new SpRecognition();
            return _Instance;
        }
        public void CloseRec()
        {
            isrg.DictationSetState(SpeechRuleState.SGDSInactive);
        }
        private void ContexRecognition(int iIndex, object obj, SpeechLib.SpeechRecognitionType type, SpeechLib.ISpeechRecoResult result)
        {
            if (SetMessage != null)
            {
                SetMessage(result.PhraseInfo.GetText(0, -1, true));
            }
        }
    }

第二种同样需要引入,不过引入的是Win7中的.NET3.5类库
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Speech;
using System.Speech.Recognition;
using System.Globalization;
using System.Windows.Forms;

namespace StudyBeta
{
    public class SRecognition
    {
        public SpeechRecognitionEngine recognizer = null;//语音识别引擎
        public DictationGrammar dictationGrammar = null; //自然语法
        public System.Windows.Forms.Control cDisplay; //显示控件

        public SRecognition(string[] fg) //创建关键词语列表
        {
            CultureInfo myCIintl = new CultureInfo("en-US");
            foreach (RecognizerInfo config in SpeechRecognitionEngine. InstalledRecognizers())//获取所有语音引擎
            {
        if (config.Culture.Equals(myCIintl) && config.Id == "MS-1033-80-DESK" )
                {
                    recognizer = new SpeechRecognitionEngine(config);
                    break;
                }//选择美国英语的识别引擎
            }
            if (recognizer != null)
            {
                InitializeSpeechRecognitionEngine(fg);//初始化语音识别引擎
                dictationGrammar = new DictationGrammar();
            }
            else
            {
                MessageBox.Show("创建语音识别失败");
            }
        }
        private void InitializeSpeechRecognitionEngine(string[] fg)
        {
            recognizer.SetInputToDefaultAudioDevice();//选择默认的音频输入设备
            Grammar customGrammar = CreateCustomGrammar(fg);
			//根据关键字数组建立语法
            recognizer.UnloadAllGrammars();
            recognizer.LoadGrammar(customGrammar);
			//加载语法
recognizer.SpeechRecognized += new EventHandler <SpeechRecognizedEventArgs>(recognizer_SpeechRecognized);
recognizer.SpeechHypothesized += new EventHandler <SpeechHypothesizedEventArgs>(recognizer_SpeechHypothesized);
        }
        public void BeginRec(Control tbResult)//关联窗口控件
        {
            TurnSpeechRecognitionOn();
            TurnDictationOn();
            cDisplay = tbResult;
        }
        public void over()//停止语音识别引擎
        {
            TurnSpeechRecognitionOff();
        }
        public virtual Grammar CreateCustomGrammar(string[] fg) //创造自定义语法
        {
            GrammarBuilder grammarBuilder = new GrammarBuilder();
            grammarBuilder.Append(new Choices(fg));
            return new Grammar(grammarBuilder);
        }
        private void TurnSpeechRecognitionOn()//启动语音识别函数
        {
            if (recognizer != null)
            {
                recognizer.RecognizeAsync(RecognizeMode.Multiple); 
//识别模式为连续识别
            }
            else
            {
                MessageBox.Show("创建语音识别失败");
            }
        }
        private void TurnSpeechRecognitionOff()//关闭语音识别函数
        {
            if (recognizer != null)
            {
                recognizer.RecognizeAsyncStop();
                TurnDictationOff();
            }
            else
            {
                MessageBox.Show("创建语音识别失败");
            }
        }
private void recognizer_SpeechRecognized(object sender, SpeechRecognized EventArgs e)
        {
			//识别出结果完成的动作,通常把识别结果传给某一个控件
            string text = e.Result.Text;
            cDisplay.Text = text;
        }
        private void TurnDictationOn()
        {
            if (recognizer != null)
            {
                recognizer.LoadGrammar(dictationGrammar);
				//加载自然语法
            }
            else
            {
                MessageBox.Show("创建语音识别失败");
            }
        }
        private void TurnDictationOff()
        {
            if (dictationGrammar != null)
            {
                recognizer.UnloadGrammar(dictationGrammar);
				//卸载自然语法
            }
            else
            {
                MessageBox.Show("创建语音识别失败");
            }
        }
    }
}
分享到:
评论

相关推荐

    c# 用SAPI实现语音识别及文本转换的详细教程

    在C#中实现语音识别和文本转换,通常我们会利用微软的Speech API(SAPI),这是一个强大的接口,允许开发者集成自然语言处理功能,包括语音识别和语音合成。本教程将深入探讨如何利用SAPI来实现这些功能。 首先,...

    C#中调用SAPI实现语音识别的2种方法

    通过微软的SAPI,不仅仅可以实现语音合成TTS,同样可以实现语音识别SR。下面我们就介绍并贴出相关代码。主要有两种方式: 1、使用COM组件技术,不管是C++,C#,Delphi都能玩的转,开发出来的东西在XP和WIN7都能跑。...

    C#中调用SAPI实现语音合成的2种方法

    以下是两种利用C#调用SAPI实现语音合 成的方法: 1. 使用COM组件技术: 这种方法适用于XP和Win7等较旧的操作系统。首先,你需要在项目中引用`SpeechLib`,这是一个COM组件,通常可以在项目属性的"引用"选项中找到并...

    C# SAPI 语音交互系统

    C#中的SAPI库主要由两个关键部分组成:语音合成(ISpVoice)和语音识别(ISpRecognizer)接口。 ### 语音合成(TTS) 使用ISpVoice接口,我们可以将文本转换为自然流畅的语音输出。以下是一些关键步骤: 1. **初始化...

    C++语音识别

    总的来说,C++实现Windows语音识别虽然相比C#或其他现代语言可能较为复杂,但它提供了更多的底层控制和灵活性。通过熟悉和掌握Windows API的语音识别接口,开发者可以构建高效且定制化的语音识别系统。在实践中,...

    c#中SAPI使用总结——SpVoice的使用方法

    在C#编程中,SAPI(Speech API,语音应用程序编程接口)是由微软提供的一套用于实现文本转语音(TTS)和语音识别的库。在本文中,我们将深入探讨如何使用SAPI中的SpVoice类来实现一个简单的点名系统。 首先,为了在...

    解决sapi不能再win7上运行。报组件未注册的错误。两种解决方案

    SAPI(Speech Application Programming Interface)是微软提供的一种用于开发语音识别和合成应用的接口,它允许程序员集成自然语言处理功能到他们的应用程序中。在Windows 7操作系统中,如果你遇到“组件未注册”的...

    CSHARP语音识别

    `SAPI.SpVoice`虽然主要涉及语音合成,但在了解了语音识别的基本原理和流程后,结合这两个方面的知识,可以实现更完整的语音应用解决方案。记得在实际项目中,不断尝试和优化,以提升用户体验。

    一个基于Windows Vista speech API5.3以及WPF技术的语音识别代码

    3. 开始语音识别:调用ISpRecognizer的SetInput方法指定音频输入源,然后启动识别。 4. 处理识别事件:订阅ISpeechRecoResult事件,如Result事件,当有新的识别结果时进行处理。 5. 结合WPF:将识别结果绑定到WPF UI...

    用C_开发基于MicrosoftSpeechSDK的语音应用程序

    ### 用C#开发基于Microsoft Speech SDK的语音应用程序 #### 0. 引言 长久以来,人类一直在努力实现让...无论是语音合成还是语音识别,都可以通过调用SDK中的接口来实现,极大地降低了开发门槛,提高了开发效率。

    文字语音转换

    在IT领域,文字语音转换(Text-to-Speech, TTS)和语音识别(Speech Recognition, SR)是两个关键的技术方向,它们在人机交互、无障碍技术、智能客服等多个场景中有着广泛的应用。本项目利用C#语言实现了这些功能,...

    tts 例子(web例子和控制台例子)

    控制台例子通常更直接,可能使用C#、VB.NET等.NET语言调用SAPI接口实现TTS。通过Console.WriteLine命令输出的文本可以被转换成语音,这对于自动化脚本或者没有图形界面的应用场景非常有用。控制台应用还可能支持...

    文字转语音(可转Mp3格式)

    微软的Microsoft Speech API是一个综合性的语音技术平台,它包含了语音识别和TTS两个主要部分。对于文字转语音,我们主要关注的是TTS引擎。这个引擎可以读取输入的文本,并将其转换成音频流,支持多种语言和发音风格...

Global site tag (gtag.js) - Google Analytics