Android教程之Android自带的语音识别例子初探

简介:

语音识别技术是在Android SDK1.5中才加入的(RecognizerIntent),这里我们简单的分析一下自带的api例子,其实它就是通过一个Intent的Action动作来完成的。主要有以下两种模式:

ACTION_RECOGNIZE_SPEECH:一般语音识别,在这种模式下我们可以捕捉到语音的处理后的文字列。

ACTION_WEB_SEARCH:网络搜索

该例子同样是使用ACTION_RECOGNIZE_SPEECH模式,我们需要实现onActivityResult方法,当语音识别结束之后的回调函数。

好了,废话不多说,看下面的代码,我加入了注释,重要的本来就不多几行。

 
  1. package com.example.android.apis.app;     
  2.     
  3. import android.app.Activity;     
  4. import android.content.Intent;     
  5. import android.content.pm.PackageManager;     
  6. import android.content.pm.ResolveInfo;     
  7. import android.os.Bundle;     
  8. import android.speech.RecognizerIntent;     
  9. import android.view.View;     
  10. import android.view.View.OnClickListener;     
  11. import android.widget.ArrayAdapter;     
  12. import android.widget.Button;     
  13. import android.widget.ListView;     
  14. import java.util.ArrayList;     
  15. import java.util.List;     
  16.     
  17. public class VoiceRecognition extends Activity implements OnClickListener {     
  18.          
  19.     private static final int VOICE_RECOGNITION_REQUEST_CODE = 1234;     
  20.          
  21.     private ListView mList;     
  22.     
  23.     /**     
  24.      * Called with the activity is first created.     
  25.      */     
  26.     @Override     
  27.     public void onCreate(Bundle savedInstanceState)      
  28.     {     
  29.         super.onCreate(savedInstanceState);     
  30.     
  31.         setContentView(R.layout.voice_recognition);     
  32.     
  33.         Button speakButton = (Button) findViewById(R.id.btn_speak);     
  34.              
  35.         mList = (ListView) findViewById(R.id.list);     
  36.     
  37.         // Check to see if a recognition activity is present     
  38.         PackageManager pm = getPackageManager();     
  39.         List<ResolveInfo> activities = pm.queryIntentActivities(new Intent(RecognizerIntent.ACTION_RECOGNIZE_SPEECH), 0);     
  40.         if (activities.size() != 0)     
  41.         {     
  42.             speakButton.setOnClickListener(this);     
  43.         }     
  44.         else     
  45.         {     
  46.             speakButton.setEnabled(false);     
  47.             speakButton.setText("Recognizer not present");     
  48.         }     
  49.     }     
  50.     
  51.     
  52.     public void onClick(View v)     
  53.     {     
  54.         if (v.getId() == R.id.btn_speak)     
  55.         {     
  56.             startVoiceRecognitionActivity();     
  57.         }     
  58.     }     
  59.     
  60.     private void startVoiceRecognitionActivity()     
  61.     {     
  62.         //通过Intent传递语音识别的模式     
  63.         Intent intent = new Intent(RecognizerIntent.ACTION_RECOGNIZE_SPEECH);     
  64.         //语言模式和自由形式的语音识别     
  65.         intent.putExtra(RecognizerIntent.EXTRA_LANGUAGE_MODEL, RecognizerIntent.LANGUAGE_MODEL_FREE_FORM);     
  66.         //提示语音开始     
  67.         intent.putExtra(RecognizerIntent.EXTRA_PROMPT, "Speech recognition demo");     
  68.         //开始执行我们的Intent、语音识别     
  69.         startActivityForResult(intent, VOICE_RECOGNITION_REQUEST_CODE);     
  70.     }     
  71.     
  72.     
  73.     //当语音结束时的回调函数onActivityResult     
  74.     @Override     
  75.     protected void onActivityResult(int requestCode, int resultCode, Intent data)     
  76.     {     
  77.         if (requestCode == VOICE_RECOGNITION_REQUEST_CODE && resultCode == RESULT_OK)     
  78.         {     
  79.             // 取得语音的字符     
  80.             ArrayList<String> matches = data.getStringArrayListExtra(RecognizerIntent.EXTRA_RESULTS);     
  81.             mList.setAdapter(new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, matches));     
  82.         }     
  83.     
  84.         super.onActivityResult(requestCode, resultCode, data);     
  85.     }     
  86. }  

当然这里需要设备的支持,所以模拟器是没有效果的!

实际上在没有设备时会跑出ActivityNotFoundException异常。

这个例子很简单,到此为止,谢谢!



本文转自 yarin 51CTO博客,原文链接:http://blog.51cto.com/yarin/380015,如需转载请自行联系原作者

相关实践学习
达摩院智能语音交互 - 声纹识别技术
声纹识别是基于每个发音人的发音器官构造不同,识别当前发音人的身份。按照任务具体分为两种: 声纹辨认:从说话人集合中判别出测试语音所属的说话人,为多选一的问题 声纹确认:判断测试语音是否由目标说话人所说,是二选一的问题(是或者不是) 按照应用具体分为两种: 文本相关:要求使用者重复指定的话语,通常包含与训练信息相同的文本(精度较高,适合当前应用模式) 文本无关:对使用者发音内容和语言没有要求,受信道环境影响比较大,精度不高 本课程主要介绍声纹识别的原型技术、系统架构及应用案例等。 讲师介绍: 郑斯奇,达摩院算法专家,毕业于美国哈佛大学,研究方向包括声纹识别、性别、年龄、语种识别等。致力于推动端侧声纹与个性化技术的研究和大规模应用。
相关文章
|
3月前
|
网络协议 Android开发 数据安全/隐私保护
Android手机上使用Socks5全局代理-教程+软件
Android手机上使用Socks5全局代理-教程+软件
2687 2
|
3月前
|
缓存 网络协议 安全
49. 【Android教程】HTTP 使用详解
49. 【Android教程】HTTP 使用详解
54 1
|
3月前
|
XML 存储 JSON
51. 【Android教程】JSON 数据解析
51. 【Android教程】JSON 数据解析
81 2
|
3月前
|
存储 API 文件存储
47. 【Android教程】SharedPreferences 存储
47. 【Android教程】SharedPreferences 存储
48 2
|
22天前
|
人工智能 语音技术 Windows
语音识别教程:Whisper
本文是一份详细的Whisper语音识别模型使用教程,包括了FFmpeg的安装、Whisper模型的安装与使用,以及如何实现实时录制音频并转录的步骤和代码示例,旨在帮助用户基于Whisper和GPT创建AI字幕。
|
2月前
|
达摩院 语音技术 异构计算
语音识别-免费开源的语音转文本软件Whisper的本地搭建详细教程,python版本是3.805,ffmpeg是专门处理音视频的,ffmpeg的下载链接,现在要求安装python和ffmpeg
语音识别-免费开源的语音转文本软件Whisper的本地搭建详细教程,python版本是3.805,ffmpeg是专门处理音视频的,ffmpeg的下载链接,现在要求安装python和ffmpeg
|
3月前
|
存储 安全 大数据
46. 【Android教程】文件存储
46. 【Android教程】文件存储
34 3
|
3月前
|
存储 编解码 Android开发
58. 【Android教程】音频录制:MediaRecord
58. 【Android教程】音频录制:MediaRecord
37 2
|
3月前
|
Web App开发 移动开发 前端开发
52. 【Android教程】网页视图:WebView
52. 【Android教程】网页视图:WebView
42 1
|
3月前
|
XML 存储 JavaScript
50. 【Android教程】xml 数据解析
50. 【Android教程】xml 数据解析
46 1