SpeechRecognitionEngine.Recognize Método
Definição
Importante
Algumas informações se referem a produtos de pré-lançamento que podem ser substancialmente modificados antes do lançamento. A Microsoft não oferece garantias, expressas ou implícitas, das informações aqui fornecidas.
Inicia uma operação de reconhecimento de fala síncrono.
Sobrecargas
Recognize() |
Executa uma operação de reconhecimento de fala síncrona. |
Recognize(TimeSpan) |
Executa uma operação síncrona de reconhecimento de fala com um período de tempo limite de silêncio inicial especificado. |
Comentários
Esses métodos executam uma única operação de reconhecimento síncrono. O reconhecedor executa essa operação em relação às gramáticas de reconhecimento de fala carregadas e habilitadas.
Durante uma chamada para esse método, o reconhecedor pode gerar os seguintes eventos:
SpeechDetected. Gerado quando o reconhecedor detecta a entrada que ele pode identificar como fala.
SpeechHypothesized. Gerado quando a entrada cria uma correspondência ambígua com uma das gramáticas ativas.
SpeechRecognitionRejected ou SpeechRecognized. Gerado quando o reconhecedor finaliza uma operação de reconhecimento.
O reconhecedor não gera o RecognizeCompleted evento ao usar um dos Recognize métodos .
Os Recognize métodos retornam um RecognitionResult objeto ou null
se a operação não for bem-sucedida ou se o reconhecedor não estiver habilitado.
Uma operação de reconhecimento síncrono pode falhar pelos seguintes motivos:
A fala não é detectada antes que os intervalos de tempo limite expirem para as BabbleTimeout propriedades ou InitialSilenceTimeout ou para o
initialSilenceTimeout
parâmetro do Recognize método .O mecanismo de reconhecimento detecta fala, mas não encontra correspondências em nenhum de seus objetos carregados e habilitados Grammar .
Para modificar como o reconhecedor lida com o tempo de fala ou silêncio em relação ao reconhecimento, use as BabbleTimeoutpropriedades , EndSilenceTimeoutInitialSilenceTimeout, e EndSilenceTimeoutAmbiguous .
O SpeechRecognitionEngine deve ter pelo menos um Grammar objeto carregado antes de executar o reconhecimento. Para carregar uma gramática de reconhecimento de fala, use o LoadGrammar método ou LoadGrammarAsync .
Para executar o reconhecimento assíncrono, use um dos RecognizeAsync métodos .
Recognize()
- Origem:
- SpeechRecognitionEngine.cs
- Origem:
- SpeechRecognitionEngine.cs
Executa uma operação de reconhecimento de fala síncrona.
public:
System::Speech::Recognition::RecognitionResult ^ Recognize();
public System.Speech.Recognition.RecognitionResult Recognize ();
member this.Recognize : unit -> System.Speech.Recognition.RecognitionResult
Public Function Recognize () As RecognitionResult
Retornos
O resultado do reconhecimento para a entrada ou null
se a operação não for bem-sucedida ou o reconhecedor não estiver habilitado.
Exemplos
O exemplo a seguir mostra parte de um aplicativo de console que demonstra o reconhecimento de fala básico. O exemplo cria um DictationGrammar, carrega-o em um reconhecedor de fala em processo e executa uma operação de reconhecimento.
using System;
using System.Speech.Recognition;
namespace SynchronousRecognition
{
class Program
{
static void Main(string[] args)
{
// Create an in-process speech recognizer for the en-US locale.
using (SpeechRecognitionEngine recognizer =
new SpeechRecognitionEngine(
new System.Globalization.CultureInfo("en-US")))
{
// Create and load a dictation grammar.
recognizer.LoadGrammar(new DictationGrammar());
// Configure input to the speech recognizer.
recognizer.SetInputToDefaultAudioDevice();
// Modify the initial silence time-out value.
recognizer.InitialSilenceTimeout = TimeSpan.FromSeconds(5);
// Start synchronous speech recognition.
RecognitionResult result = recognizer.Recognize();
if (result != null)
{
Console.WriteLine("Recognized text = {0}", result.Text);
}
else
{
Console.WriteLine("No recognition result available.");
}
}
Console.WriteLine();
Console.WriteLine("Press any key to continue...");
Console.ReadKey();
}
}
}
Comentários
Esse método executa uma única operação de reconhecimento. O reconhecedor executa essa operação em relação às gramáticas de reconhecimento de fala carregadas e habilitadas.
Durante uma chamada para esse método, o reconhecedor pode gerar os seguintes eventos:
SpeechDetected. Gerado quando o reconhecedor detecta a entrada que ele pode identificar como fala.
SpeechHypothesized. Gerado quando a entrada cria uma correspondência ambígua com uma das gramáticas ativas.
SpeechRecognitionRejected ou SpeechRecognized. Gerado quando o reconhecedor finaliza uma operação de reconhecimento.
O reconhecedor não aciona o RecognizeCompleted evento ao usar esse método.
O Recognize() método retornará um RecognitionResult objeto ou null
se a operação não for bem-sucedida.
Uma operação de reconhecimento síncrono pode falhar pelos seguintes motivos:
A fala não é detectada antes que os intervalos de tempo limite expirem para as BabbleTimeout propriedades ou InitialSilenceTimeout .
O mecanismo de reconhecimento detecta fala, mas não encontra correspondências em nenhum de seus objetos carregados e habilitados Grammar .
Para executar o reconhecimento assíncrono, use um dos RecognizeAsync métodos .
Confira também
- BabbleTimeout
- InitialSilenceTimeout
- EndSilenceTimeout
- EndSilenceTimeoutAmbiguous
- SpeechDetected
- SpeechHypothesized
- SpeechRecognitionRejected
- SpeechRecognized
- RecognizeAsync()
- EmulateRecognize(String)
Aplica-se a
Recognize(TimeSpan)
- Origem:
- SpeechRecognitionEngine.cs
- Origem:
- SpeechRecognitionEngine.cs
Executa uma operação síncrona de reconhecimento de fala com um período de tempo limite de silêncio inicial especificado.
public:
System::Speech::Recognition::RecognitionResult ^ Recognize(TimeSpan initialSilenceTimeout);
public System.Speech.Recognition.RecognitionResult Recognize (TimeSpan initialSilenceTimeout);
member this.Recognize : TimeSpan -> System.Speech.Recognition.RecognitionResult
Public Function Recognize (initialSilenceTimeout As TimeSpan) As RecognitionResult
Parâmetros
- initialSilenceTimeout
- TimeSpan
O intervalo de tempo durante o qual um reconhecedor de fala aceita uma entrada contendo apenas silêncio antes de finalizar o reconhecimento.
Retornos
O resultado do reconhecimento para a entrada ou null
se a operação não for bem-sucedida ou o reconhecedor não estiver habilitado.
Exemplos
O exemplo a seguir mostra parte de um aplicativo de console que demonstra o reconhecimento de fala básico. O exemplo cria um DictationGrammar, carrega-o em um reconhecedor de fala em processo e executa uma operação de reconhecimento.
using System;
using System.Speech.Recognition;
namespace SynchronousRecognition
{
class Program
{
static void Main(string[] args)
{
// Create an in-process speech recognizer for the en-US locale.
using (SpeechRecognitionEngine recognizer =
new SpeechRecognitionEngine(
new System.Globalization.CultureInfo("en-US")))
{
// Create and load a dictation grammar.
recognizer.LoadGrammar(new DictationGrammar());
// Configure input to the speech recognizer.
recognizer.SetInputToDefaultAudioDevice();
// Start synchronous speech recognition.
RecognitionResult result = recognizer.Recognize(TimeSpan.FromSeconds(5));
if (result != null)
{
Console.WriteLine("Recognized text = {0}", result.Text);
}
else
{
Console.WriteLine("No recognition result available.");
}
}
Console.WriteLine();
Console.WriteLine("Press any key to continue...");
Console.ReadKey();
}
}
}
Comentários
Se o mecanismo de reconhecimento de fala detectar fala dentro do intervalo de tempo especificado pelo initialSilenceTimeout
argumento, Recognize(TimeSpan) executará uma única operação de reconhecimento e terminará. O initialSilenceTimeout
parâmetro substitui a propriedade do InitialSilenceTimeout reconhecedor.
Durante uma chamada para esse método, o reconhecedor pode gerar os seguintes eventos:
SpeechDetected. Gerado quando o reconhecedor detecta a entrada que ele pode identificar como fala.
SpeechHypothesized. Gerado quando a entrada cria uma correspondência ambígua com uma das gramáticas ativas.
SpeechRecognitionRejected ou SpeechRecognized. Gerado quando o reconhecedor finaliza uma operação de reconhecimento.
O reconhecedor não aciona o RecognizeCompleted evento ao usar esse método.
O Recognize() método retornará um RecognitionResult objeto ou null
se a operação não for bem-sucedida.
Uma operação de reconhecimento síncrono pode falhar pelos seguintes motivos:
A fala não é detectada antes que os intervalos de tempo limite expirem para o BabbleTimeout parâmetro ou .
initialSilenceTimeout
O mecanismo de reconhecimento detecta fala, mas não encontra correspondências em nenhum de seus objetos carregados e habilitados Grammar .
Para executar o reconhecimento assíncrono, use um dos RecognizeAsync métodos .
Confira também
- BabbleTimeout
- InitialSilenceTimeout
- EndSilenceTimeout
- EndSilenceTimeoutAmbiguous
- SpeechDetected
- SpeechHypothesized
- SpeechRecognitionRejected
- SpeechRecognized
- RecognizeAsync()
- EmulateRecognize(String)