我使用Microsoft Speech Platform在屏幕输出时识别语音。但是,我有问题:例如,我有语法(由GrammarBuilder和Choices构建 - " red"," green"," black")
当我说 - "红绿黑" - 我只能得到"红色",也许"红绿" ,但不是"红绿黑"。
一些代码:
Thread.CurrentThread.CurrentCulture = new CultureInfo("ru-RU");
Thread.CurrentThread.CurrentUICulture = new CultureInfo("ru-RU");
// Create a new SpeechRecognitionEngine instance.
_sre = new SpeechRecognitionEngine(new System.Globalization.CultureInfo("ru-RU"));
_sre.SpeechHypothesized += _sre_SpeechHypothesized;
_sre.SpeechDetected += _sre_SpeechDetected;
//_sre.SetInputToWaveFile(@"c:\Test\Wavs\Wavs-converted\file.wav");
_sre.SetInputToDefaultAudioDevice();
public void LoadGrammarIntoEngine(IEnumerable<String> textColl)
{
Choices choices = new Choices();
GrammarBuilder gb = new GrammarBuilder();
gb.Culture = new CultureInfo("ru-RU");
if (choices != null && textColl != null)
{
choices.Add(textColl.ToArray());
gb.Append(choices);
}
}
public void Recognize() {
if (_sre != null && _sre.Grammars.Count != 0) {
_sre.RecognizeAsync(RecognizeMode.Multiple);
}
}
那么,如何解决这个问题呢?我应该用规则制作SGRS语法吗? 语法文件是txt文件,其中包含以下单词:
Dictionary.txt
green
black
yellow
red
some other words