zoukankan      html  css  js  c++  java
  • android语音识别技术

     

             今天从网上找了个例子实现了语音识别,个人感觉挺好玩的,就把代码贴出来与大家分享下:

             Android中主要通过RecognizerIntent来实现语音识别,其实代码比较简单,但是如果找不到设置,就会抛出异常 ActivityNotFoundException,所以我们需要捕捉这个异常。而且语音识别在模拟器上是无法测试的,因为语音识别是访问google 云端数据,所以如果手机的网络没有开启,就无法实现识别声音的!一定要开启手机的网络,如果手机不存在语音识别功能的话,也是无法启用识别!

            下面是RecognizerIntentActivity中的代码:

            

    1. public class RecognizerIntentActivity extends Activity {  
    2.   
    3.     private Button btnReconizer;  
    4.     private static final int VOICE_RECOGNITION_REQUEST_CODE = 1234;  
    5.     @Override  
    6.     protected void onCreate(Bundle savedInstanceState) {  
    7.         // TODO Auto-generated method stub  
    8.         super.onCreate(savedInstanceState);  
    9.         setContentView(R.layout.reconizer);  
    10.           
    11.         btnReconizer=(Button) this.findViewById(R.id.btnRecognizer);  
    12.         btnReconizer.setOnClickListener(new OnClickListener() {  
    13.               
    14.             @Override  
    15.             public void onClick(View v) {  
    16.                 // TODO Auto-generated method stub  
    17.                 try{  
    18.                 //通过Intent传递语音识别的模式,开启语音  
    19.                 Intent intent=new Intent(RecognizerIntent.ACTION_RECOGNIZE_SPEECH);  
    20.                 //语言模式和自由模式的语音识别  
    21.                 intent.putExtra(RecognizerIntent.EXTRA_LANGUAGE_MODEL, RecognizerIntent.LANGUAGE_MODEL_FREE_FORM);  
    22.                 //提示语音开始  
    23.                 intent.putExtra(RecognizerIntent.EXTRA_PROMPT, "开始语音");  
    24.                 //开始语音识别  
    25.                 startActivityForResult(intent, VOICE_RECOGNITION_REQUEST_CODE);  
    26.                 }catch (Exception e) {  
    27.                     // TODO: handle exception  
    28.                     e.printStackTrace();  
    29.                     Toast.makeText(getApplicationContext(), "找不到语音设备", 1).show();  
    30.                 }  
    31.             }  
    32.         });  
    33.           
    34.     }  
    35.       
    36.     @Override  
    37.     protected void onActivityResult(int requestCode, int resultCode, Intent data) {  
    38.         // TODO Auto-generated method stub  
    39.         //回调获取从谷歌得到的数据   
    40.         if(requestCode==VOICE_RECOGNITION_REQUEST_CODE && resultCode==RESULT_OK){  
    41.             //取得语音的字符  
    42.             ArrayList<Stringresults=data.getStringArrayListExtra(RecognizerIntent.EXTRA_RESULTS);  
    43.               
    44.             String resultString="";  
    45.             for(int i=0;i<results.size();i++){  
    46.                 resultString+=results.get(i);  
    47.             }  
    48.             Toast.makeText(this, resultString, 1).show();  
    49.         }  
    50.         super.onActivityResult(requestCode, resultCode, data);  
    51.     }  
    52. }  


               其主要原理就是将语音发送到google云端,然后云端处理,匹配相应的数据,发送到客户端。

              最后不要忘记,在manifest中加入网络访问权限:

        

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

        

            运行后效果:

        

        点击开始语音按钮,然后开始说话(这里要保证手机的网路是打开的):

        

          正在等待云端数据,由于我这是2G的卡,等了好长时间还是加载不下来,等回公司了用公司的wifi试试,如果得到云端数据,就会通过Toast方式打印出来的。

  • 相关阅读:
    在Vue中使用Echart图表库。【全网最简单】
    asp.net core的授权过滤器中获取action上的Attribute
    用node.js给C#写一个数据表的实体类生成工具
    node.js操作MySQL数据库
    基于node.js的爬虫框架 node-crawler简单尝试
    Angular双向绑定简单理解
    使用.Net core3.0 开发斗图小程序后端+斗图小程序
    Django的命令操作,python
    python,函数式编程
    python 推导式的用法
  • 原文地址:https://www.cnblogs.com/xgjblog/p/3843200.html
Copyright © 2011-2022 走看看