Android开发之语音识别

  • 开发背景
  • RecognizerIntent相关知识
  • 代码解释
  • 完整代码
  • 项目运行及问题解决

开发背景

最近了解了一下Android Q(安卓10),得知Android Q基于语音识别技术,不需要联网就可以将视频中的语音实时转化成字幕这一功能。其实,在安卓中实现语音识别的代码很简单,我们要实现的就是调用谷歌API获取搜索结果,然后根据这个结果做自己想要的功能。
Android 中主要通过RecognizerIntent来实现语音识别。

RecognizerIntent相关知识

常量 简介
ACTION_RECOGNIZE_SPEECH 开启语音识别调用
ACTION_WEB_SEARCH 开启网络语音识别,结果以网页的形式显示
EXTRA_LANGUAGE_MODEL 语音识别的模式
EXTRA_MAX_RESULTS 返回的最大结果
EXTRA_PROMPT 设置用户可以开始语音的提示语
EXTRA_RESULTS 将返回的字符串集中到一个list
LANGUAGE_MODEL_FREE_FORM 在一种模式上的自由语音
LANGUAGE_MODEL_WEB_SEARCH 使用语言模型在web上搜索
RESULT_AUDIO_ERROR 返回结果时,音频遇到错误
RESULT_CLIENT_ERROR 返回结果时,客户端遇到错误
RESULT_NETWORK_ERROR 返回结果时,网络遇到错误
RESULT_NO_MATCH 未知错误
RESULT_SERVER_ERROR 返回结果时,服务端遇到错误

代码解释

1.​ 首先在AndroidManifest中设置网络权限,Android 6.0以后还需要动态请求权限

 <uses-permission android:name="android.permission.INTERNET" /><uses-permission android:name="android.permission.RECORD_AUDIO" />

2.调用Google原生语音识别

             @Overridepublic void onClick(View v) {//开启语音识别功能Intent intent = new Intent(RecognizerIntent.ACTION_RECOGNIZE_SPEECH);//设置模式,这里设置成自由模式intent.putExtra(RecognizerIntent.EXTRA_LANGUAGE_MODEL,RecognizerIntent.LANGUAGE_MODEL_FREE_FORM);//提示语音开始文字intent.putExtra(RecognizerIntent.EXTRA_PROMPT,"Please start your voice");//开始进行语音识别,这里先检测手机(模拟器)是否支持语音识别并且捕获异常try {startActivityForResult(intent, RESULT_SPEECH);txtText.setText("");} catch (ActivityNotFoundException a) {Toast t = Toast.makeText(getApplicationContext(),"Opps! Your device doesn't support Speech to Text",Toast.LENGTH_SHORT);t.show();}}});

3.使用onActivityResult接收返回的结果

  @Overrideprotected void onActivityResult(int requestCode, int resultCode, Intent data) {super.onActivityResult(requestCode, resultCode, data);switch (requestCode) {case RESULT_SPEECH: {if (resultCode == RESULT_OK && data != null) {ArrayList<String> text = data.getStringArrayListExtra(RecognizerIntent.EXTRA_RESULTS);//这里集合列表中第一个值为匹配度最高的值txtText.setText(text.get(0));}break;}}}

完整代码

1.MainActivity.java代码

import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.content.ActivityNotFoundException;
import android.content.Intent;
import android.speech.RecognizerIntent;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.EditText;
import android.widget.ImageButton;
import android.widget.TextView;
import android.widget.Toast;
import java.util.ArrayList;public class MainActivity extends AppCompatActivity {protected static final int RESULT_SPEECH = 1;private ImageButton btnSpeak;private EditText txtText;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);txtText =  findViewById(R.id.txtText);btnSpeak = (ImageButton) findViewById(R.id.btnSpeak);btnSpeak.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {//开启语音识别功能Intent intent = new Intent(RecognizerIntent.ACTION_RECOGNIZE_SPEECH);//设置模式intent.putExtra(RecognizerIntent.EXTRA_LANGUAGE_MODEL,"en-US");//提示语音开始文字intent.putExtra(RecognizerIntent.EXTRA_PROMPT,"Please start your voice");//开始进行语音识别,这里先检测手机(模拟器)是否支持语音识别并且捕获异常try {startActivityForResult(intent, RESULT_SPEECH);txtText.setText("");} catch (ActivityNotFoundException a) {Toast t = Toast.makeText(getApplicationContext(),"Opps! Your device doesn't support Speech to Text",Toast.LENGTH_SHORT);t.show();}}});}@Overridepublic boolean onCreateOptionsMenu(Menu menu) {// Inflate the menu; this adds items to the action bar if it is present.getMenuInflater().inflate(R.menu.menu_main, menu);return true;}@Overridepublic boolean onOptionsItemSelected(MenuItem item) {// Handle action bar item clicks here. The action bar will// automatically handle clicks on the Home/Up button, so long// as you specify a parent activity in AndroidManifest.xml.int id = item.getItemId();//noinspection SimplifiableIfStatementif (id == R.id.action_settings) {return true;}return super.onOptionsItemSelected(item);}@Overrideprotected void onActivityResult(int requestCode, int resultCode, Intent data) {super.onActivityResult(requestCode, resultCode, data);switch (requestCode) {case RESULT_SPEECH: {if (resultCode == RESULT_OK && data != null) {ArrayList<String> text = data.getStringArrayListExtra(RecognizerIntent.EXTRA_RESULTS);//这里集合列表中第一个值为匹配度最高的值txtText.setText(text.get(0));}break;}}}
}

2.activity_main.xml代码

<?xml version="1.0" encoding="utf-8"?>
<LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:layout_width="fill_parent"android:layout_height="wrap_content"android:layout_toLeftOf="@+id/txtText"android:gravity="center"android:orientation="vertical"><EditTextandroid:id="@+id/txtText"android:layout_width="fill_parent"android:layout_height="wrap_content"android:layout_weight="1"android:layout_gravity="left"android:layout_marginLeft="10dp"android:layout_marginRight="10dp"android:layout_marginTop="10dp"android:hint="@string/edit"/><ImageButtonandroid:id="@+id/btnSpeak"android:layout_width="fill_parent"android:layout_height="wrap_content"android:layout_margin="10dp"android:layout_marginRight="10dp"android:layout_marginTop="10dp"android:contentDescription="@string/speak"android:src="@android:drawable/ic_btn_speak_now"/></LinearLayout>

项目运行及问题解决

首先我们先把整个项目运行起来,运行结果如下图

接下来我们进行语音输入,发现语音输入用不了

为什么用不了呢?
通过网上查询得知原来使用语音识别功能需要语音识别程序(google voice)的支持,但是国内现在大部分厂商的手机里都没有这个程序。此外,这个语音识别方式需要联网到google的语音库中进行识别,因为google无法访问的问题也会导致识别失败。

知道了问题所在,解决起来也就是分分钟的事情了,首先先看一下实验所使用的模拟器,如下图

发现手机型号是国产的,在预设型号里面找了一下也都是国产手机型号。

现在的解决方法有两种,第一就是换一个可以支持语音识别程序的手机型号;第二就是直接下载语音识别程序附带到程序里面,显然第二种操作起来更加实际。
因为我所使用的模拟器可以联网,所以直接用模拟器自带的浏览器进行下载语音识别程序(google voice)

当然,如果你所使用的模拟器无法联网,也可以使用在Android emulator上安装 APK的方法进行下载安装 Google Voice Search APK。

安装完成后我们再次运行项目,就会发现当我们点击使用语音的时候就可以进行语音输入了。

进行语音输入的时候,模拟器要设置成可以接收语音,这样才能输入

参考文章:
1.Android-调用自带的谷歌语音识别技术
2.关于android上调用google的语音识别功能
3.在Android emulator上安装 APK

作者:卢泽凯
原文链接:https://blog.csdn.net/fjnuluzekai/article/details/106722420

Android开发之语音识别相关推荐

  1. Android开发之语音识别,Android开发知识体系

    switch (requestCode) { case RESULT_SPEECH: { if (resultCode == RESULT_OK && data != null) { ...

  2. android开发-百度语音识别Android SDK的简单使用

    目录 1.引言 2.开发环境 3.准备开发环境 3.1安装Android studio 3.2创建百度智能云平台应用 3.1下载百度语音识别SDK 4.实现语音识别的简单案例 4.1创建Android ...

  3. Android开发权威指南(第2版)新书发布

    <Android 开发权威指南(第二版)>是畅销书<Android开发权威指南>的升级版,内容更新超过80%,是一本全面介绍Android应用开发的专著,拥有45 章精彩内容供 ...

  4. Android开发笔记(序)写在前面的目录

    知识点分类 一方面写写自己走过的弯路掉进去的坑,避免以后再犯:另一方面希望通过分享自己的经验教训,与网友互相切磋,从而去芜存菁进一步提升自己的水平.因此博主就想,入门的东西咱就不写了,人不能老停留在入 ...

  5. Android开发笔记(序)

    本开发笔记,借鉴与其他开发者整理的文章范例与心得体会.在这里作为开发过程中的一个总结与笔记式记录. 如有侵犯作者权益,请及时联系告知删除.俗话说:集百家成一言,去粕成金. ************** ...

  6. Android开发必备(干货源码放送大)

    Android源码大放送(实战开发必备) 文件夹 PATH 列表 │  javaapk.com文件列表生成工具.bat │  使用说明.txt │  免费下载更多源码.url │  目录列表.txt ...

  7. Android开发笔记(一百零八)智能语音

    智能语音技术 如今越来越多的app用到了语音播报功能,例如地图导航.天气预报.文字阅读.口语训练等等.语音技术主要分两块,一块是语音转文字,即语音识别:另一块是文字转语音,即语音合成. 对中文来说,和 ...

  8. android系列:第一篇 android开发常用命令集合,代码目录简介

    下面整理了android开发常用命令集合如adb命令,adb over wifi,jgrep等代码搜索命令,编译环境变量配置,lunch平台选择,mm模块编译,godir代码路径跳转,log.v()等 ...

  9. Android开发笔记(序)写在前面的目录大全

    转自  湖前琴亭 的博客https://blog.csdn.net/aqi00/article/details/50012511 知识点分类 一方面写写自己走过的弯路掉进去的坑,避免以后再犯:另一方面 ...

最新文章

  1. PetaPoco - 轻量级高性能的ORM框架(支持.NET Core)
  2. 多线程共享全局变量以及锁机制
  3. 新鲜出炉!20款好看的英文字体下载
  4. md5-linux_shell
  5. 完成一个休闲网络游戏需要学习的知识
  6. php-cgi 68%,php cgi 进程占用太多怎么办
  7. 前端学习(3052):vue+element今日头条管理-自定义表格列列表
  8. 转:PHP中实现非阻塞模式
  9. 利用linux的mtrace命令定位内存泄露(Memory Leak)
  10. R count函数_【函数分享】PHP函数str_word_count()分享(202098)
  11. 实战二:手把手教你图像风格迁移
  12. 英雄连的制作公司THQ历史
  13. 排错的时候不要“想当然”
  14. 基于Go语言GoFrame+Layui搭建MVC项目教程
  15. AEJoy —— 表达式之闪烁光标的打字机效果(二)【JS】
  16. ROS,Ubuntu,noobs,raspbian和raspbeery pi3的关系
  17. PointNet: Deep Learning on Point Sets for 3D Classification and Segmentation
  18. Python-OpenCV图像处理(三):高斯噪声与高斯模糊
  19. ROS MoveIT1(Noetic)安装总结
  20. Anaconda3 下载安装教程(Windows)

热门文章

  1. Facebook禁止推广的产品,你知道吗?
  2. linux ssh快捷登录服务器
  3. 索尼android电视图片轮播,电视投屏居然还能这样玩?
  4. Cookie功能被禁用,如何启用?
  5. Python 计算两个连通子图距离_【CV学习笔记】图像的计算
  6. 网络直播多人PK计数器,计数工具下载
  7. python实现——数据包分析
  8. 网页变灰色前端是如何实现的?
  9. Python系列脚本
  10. 分布式理论(三)2PC协议