我遵循了一个非常基本的教程(忘记了链接),这一切看起来很简单,但我似乎没有得到我想要的输出。这是我的主要表单类:
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Speech.Recognition;
namespace OralNotes.Alpha
{
public partial class MainForm : Form
{
private SpeechRecognitionEngine recognitionEngine;
public MainForm()
{
InitializeComponent();
recognitionEngine = new SpeechRecognitionEngine();
recognitionEngine.SetInputToDefaultAudioDevice();
recognitionEngine.SpeechRecognized += (s, args) =>
{
foreach (RecognizedWordUnit word in args.Result.Words)
{
if (word.Confidence > 0.8f)
txtNotes.Text += word.Text + " ";
}
txtNotes.Text += Environment.NewLine;
};
recognitionEngine.LoadGrammar(new DictationGrammar());
}
private void btnStart_Click(object sender, EventArgs e)
{
recognitionEngine.RecognizeAsync();
}
private void btnStop_Click(object sender, EventArgs e)
{
recognitionEngine.RecognizeAsyncStop();
}
}
}
你可能不需要这个,但无论如何它都在这里:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Windows.Forms;
namespace OralNotes.Alpha
{
static class Program
{
/// <summary>
/// The main entry point for the application.
/// </summary>
[STAThread]
static void Main()
{
Application.EnableVisualStyles();
Application.SetCompatibleTextRenderingDefault(false);
Application.Run(new MainForm());
}
}
}
我点击开始和说话,没有任何反应。
的更新 的 *
好的,如果我调整此行
,这是有效的if (word.Confidence > 0.8f)
到一个较低的数字我得到一两个字。没有抄写句子或任何东西,有没有办法让这个有更好的识别?
答案 0 :(得分:1)
您正在使用的引擎似乎会在其听到的每个单词上返回置信度值。
我怀疑置信度值的范围是0-1。这意味着如果你将值从0.8降低,那么你就会让引擎对单词更加宽容。也许这是你麦克风的质量?