Unity windows10环境下 语音识别

本文介绍了在Unity中使用内置的Windows.Speech.DictationRecognizer接口实现语音识别的过程。通过添加事件处理函数,实现了语音转文字的实时反馈,包括完整识别结果、初步推测结果、识别完成和识别错误的处理。在遇到权限问题时,需在系统隐私设置中开启语音权限才能正常运行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近一直在弄一个实时语音识别的功能,上网查资料的时候才发现unity现在已经有了自带的语音识别的接口

https://docs.unity3d.com/2019.3/Documentation/ScriptReference/Windows.Speech.DictationRecognizer.html

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.Windows.Speech;

public class SpeechRecognition : MonoBehaviour
{

    DictationRecognizer dictationRecognizer;


    // Use this for initialization
    void Start()
    {
        dictationRecognizer = new DictationRecognizer();

        dictationRecognizer.DictationResult += onDictationResult;
        dictationRecognizer.DictationHypothesis += onDictationHypothesis;
        dictationRecognizer.DictationComplete += onDictationComplete;
        dictationRecognizer.DictationError += onDictationError;

        dictationRecognizer.Start();
    }

    private void OnDisable()
    {
        dictationRecognizer.DictationResult -= onDictationResult;
        dictationRecognizer.DictationHypothesis -= onDictationHypothesis;
        dictationRecognizer.DictationComplete -= onDictationComplete;
        dictationRecognizer.DictationError -= onDictationError;

        dictationRecognizer.Stop();
    }


    //该事件在用户说话时暂停时触发,通常是在句子的最后。将在这里返回完整的识别字符串。
    void onDictationResult(string text, ConfidenceLevel confidence)
    {
        Debug.LogFormat( text);
    }

    //此事件在用户说话时连续触发。当识别器侦听时,它将为此提供文本。
    void onDictationHypothesis(string text)
    {
        Debug.LogFormat(text);
    }

    //当听写识别器停止时触发此事件。识别程序可以通过调用stop()方法、超时或遇到任何错误来停止。
    //超时条件:
    //如果识别器启动且5秒钟内没有侦听任何内容,它将超时。
    //如果识别器给出了结果,然后它在20秒内不监听任何内容,它将超时。
    void onDictationComplete(DictationCompletionCause cause)
    {
        if (cause != DictationCompletionCause.Complete)
            Debug.LogErrorFormat("停止", cause);
    }

    //当发生错误时将触发此事件。
    void onDictationError(string error, int hresult)
    {
        Debug.LogErrorFormat("错误", error, hresult);
    }
}


然后美滋滋的运行
在这里插入图片描述
看了一下大概提示是没有语音权限之类的。从隐私里面打开设置。

在这里插入图片描述
打开设置,不过有些W10版本跟我的显示不太一样,反正就是隐私-语音 然后打开

再次运行
在这里插入图片描述
有效果了,完美。

评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值