android語音識別技術

fmms 13年前發布 | 46K 次閱讀 Android Android開發 移動開發

         今天從網上找了個例子實現了語音識別,個人感覺挺好玩的,就把代碼貼出來與大家分享下:

         Android中主要通過RecognizerIntent來實現語音識別,其實代碼比較簡單,但是如果找不到設置,就會拋出異常 ActivityNotFoundException,所以我們需要捕捉這個異常。而且語音識別在模擬器上是無法測試的,因為語音識別是訪問google 云端數據,所以如果手機的網絡沒有開啟,就無法實現識別聲音的!一定要開啟手機的網絡,如果手機不存在語音識別功能的話,也是無法啟用識別!

        下面是RecognizerIntentActivity中的代碼:

public class RecognizerIntentActivity extends Activity {

    private Button btnReconizer;
    private static final int VOICE_RECOGNITION_REQUEST_CODE = 1234;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        // TODO Auto-generated method stub
        super.onCreate(savedInstanceState);
        setContentView(R.layout.reconizer);

        btnReconizer=(Button) this.findViewById(R.id.btnRecognizer);
        btnReconizer.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {
                // TODO Auto-generated method stub
                try{
                //通過Intent傳遞語音識別的模式,開啟語音
                Intent intent=new Intent(RecognizerIntent.ACTION_RECOGNIZE_SPEECH);
                //語言模式和自由模式的語音識別
                intent.putExtra(RecognizerIntent.EXTRA_LANGUAGE_MODEL, RecognizerIntent.LANGUAGE_MODEL_FREE_FORM);
                //提示語音開始
                intent.putExtra(RecognizerIntent.EXTRA_PROMPT, "開始語音");
                //開始語音識別
                startActivityForResult(intent, VOICE_RECOGNITION_REQUEST_CODE);
                }catch (Exception e) {
                    // TODO: handle exception
                    e.printStackTrace();
                    Toast.makeText(getApplicationContext(), "找不到語音設備", 1).show();
                }
            }
        });

    }

    @Override
    protected void onActivityResult(int requestCode, int resultCode, Intent data) {
        // TODO Auto-generated method stub
        //回調獲取從谷歌得到的數據 
        if(requestCode==VOICE_RECOGNITION_REQUEST_CODE && resultCode==RESULT_OK){
            //取得語音的字符
            ArrayList<String> results=data.getStringArrayListExtra(RecognizerIntent.EXTRA_RESULTS);

            String resultString="";
            for(int i=0;i<results.size();i++){
                resultString+=results.get(i);
            }
            Toast.makeText(this, resultString, 1).show();
        }
        super.onActivityResult(requestCode, resultCode, data);
    }
}

          其主要原理就是將語音發送到google云端,然后云端處理,匹配相應的數據,發送到客戶端。

          最后不要忘記,在manifest中加入網絡訪問權限:
<uses-permission android:name="android.permission.INTERNET" />

        運行后效果:

點擊開始語音按鈕,然后開始說話(這里要保證手機的網路是打開的):
  
正在等待云端數據,由于我這是2G的卡,等了好長時間還是加載不下來,等回公司了用公司的wifi試試,如果得到云端數據,就會通過Toast方式打印出來的。

轉自:  http://blog.csdn.net/wangkuifeng0118/article/details/7251813

 本文由用戶 fmms 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!