详解Unity 实现语音识别功能
作者:Mr-Miracle 时间:2023-11-30 22:01:11
现在语音识别已经被广泛的应用到各个领域中,在Unity开发中,语音识别也非常受欢迎。大部分人都会选择科大讯飞的语音识别功能,但是在一些小的项目中,使用科大讯飞的就有点大材小用了。今天就介绍一下Unity自带的语音识别功能。说是语音识别,其实unity本身还是做不到的,Unity自带的语音识别功能其实是关键字识别。比如我在Unity中设定好一句话汇总的几个关键词。当我再说这句话的时候就会和识别到。经过测试发现当一句话中有八个关键字,这句话就会非常好的被识别出来。
接下来就一起来实现一下:
首先贴一张效果图:
场景我们沿用的是音频可视化那篇文章里用到的场景。这里就不多做介绍了。Unity自带的语音识别功能官方有API供参考,地址在这里(戳这里)
这里大家可以自行去看一下。下面开始介绍一下我们要实现的功能:
想要识别语音识别功能我们首先由先引用个命名空间
using UnityEngine.Windows.Speech;//引入命名空间
然后定义一个string类型数组,这个数组就是存放那些我们要识别关键字。
// 关键字
public string[] keywords = { "你好", "开始","停止" };
紧接着我们要在start方法中先创建一个语音识别器,这样才能够进行语音识别
//创建一个识别器
m_PhraseRecognizer = new KeywordRecognizer(keywords, m_confidenceLevel);
//通过注册监听的方法
m_PhraseRecognizer.OnPhraseRecognized += M_PhraseRecognizer_OnPhraseRecognized;
//开启识别器
m_PhraseRecognizer.Start();
接着是一个方法,这个方法主要就是用于识别到关键字后要做的事情
/// <summary>
/// 当识别到关键字时,会调用这个方法
/// </summary>
/// <param name="args"></param>
private void M_PhraseRecognizer_OnPhraseRecognized(PhraseRecognizedEventArgs args)
{
print(args.text);
}
这样基本上重要的部分就完成。下面是全部的代码,在底部还有一个小Demo,感兴趣的可以下载下来自行体验一下
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.Windows.Speech;//引入命名空间 利用
/// <summary>
/// 语音识别(主要是别关键字)
/// </summary>
public class speechKey : MonoBehaviour
{
// 短语识别器
private PhraseRecognizer m_PhraseRecognizer;
// 关键字
public string[] keywords = { "你好", "开始","停止" };
// 可信度
public ConfidenceLevel m_confidenceLevel = ConfidenceLevel.Medium;
// Use this for initialization
void Start()
{
if (m_PhraseRecognizer == null)
{
//创建一个识别器
m_PhraseRecognizer = new KeywordRecognizer(keywords, m_confidenceLevel);
//通过注册监听的方法
m_PhraseRecognizer.OnPhraseRecognized += M_PhraseRecognizer_OnPhraseRecognized;
//开启识别器
m_PhraseRecognizer.Start();
Debug.Log("创建识别器成功");
}
}
/// <summary>
/// 当识别到关键字时,会调用这个方法
/// </summary>
/// <param name="args"></param>
private void M_PhraseRecognizer_OnPhraseRecognized(PhraseRecognizedEventArgs args)
{
SpeechRecognition();
print(args.text);
}
private void OnDestroy()
{
//判断场景中是否存在语音识别器,如果有,释放
if (m_PhraseRecognizer != null)
{
//用完应该释放,否则会带来额外的开销
m_PhraseRecognizer.Dispose();
}
}
// Update is called once per frame
void Update()
{
}
/// <summary>
/// 识别到语音的操作
/// </summary>
void SpeechRecognition()
{
}
}
Demo下载地址:https://github.com/ShuxinWen/AutomaticSpeechRecognition-ASR-
来源:https://blog.csdn.net/sinat_39291423/article/details/93871053
标签:Unity,语音,识别
0
投稿
猜你喜欢
c#如何用好垃圾回收机制GC
2023-03-21 08:48:22
Spring中校验器(Validator)的深入讲解
2022-03-05 11:58:35
Android之网络通信案例分析
2023-10-21 02:13:20
IDEA插件之Mybatis Log plugin 破解及安装方法
2023-09-24 22:30:16
RocketMQ4.5.2 修改mqnamesrv 和 mqbroker的日志路径操作
2023-11-28 14:03:18
C#采用OpenXml给Word文档添加表格
2023-03-10 14:07:13
Java基于对象流实现银行系统
2023-09-10 02:54:21
selenium+java破解极验滑动验证码的示例代码
2022-11-19 21:52:01
了解Java线程池执行原理
2022-10-12 13:00:23
Android开发实现的简单五子棋游戏示例
2022-10-26 04:47:59
MyBatis-Plus拦截器实现数据权限控制的示例
2022-12-10 05:10:17
Android AS创建自定义布局案例详解
2022-04-28 22:20:41
Mybatis 入参类型方式全面详解
2023-10-16 20:03:40
SpringBoot自定义注解实现Token校验的方法
2023-11-13 23:17:52
Java使用wait和notify实现线程之间的通信
2022-07-20 16:05:02
C#委托用法详解
2023-06-04 22:46:43
Java 回调函数详解及使用
2023-11-03 02:32:35
spring基础概念AOP与动态代理理解
2022-01-29 20:55:13
c#定时运行程序分享(定时程序)
2023-12-11 20:47:31
Java数据结构与算法之循环队列的实现
2023-11-02 11:51:29