android.speech.RecognizerIntent這個包里。前提是你的手機(jī)支持此功能。
10年積累的成都網(wǎng)站設(shè)計、成都做網(wǎng)站經(jīng)驗,可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識你,你也不認(rèn)識我。但先網(wǎng)站設(shè)計制作后付款的網(wǎng)站建設(shè)流程,更有榕江免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
開啟操作:
Intent
intent
=
newIntent(RecognizerIntent.ACTION_RECOGNIZE_SPEECH);//開啟語音識別功能。
intent.putExtra(RecognizerIntent.EXTRA_LANGUAGE_MODEL,
RecognizerIntent.LANGUAGE_MODEL_FREE_FORM);
//設(shè)置語言類型。
intent.putExtra(RecognizerIntent.EXTRA_PROMPT,
"請說話,我識別");
startActivityForResult(intent,REQUEST_CODE);
在onActivityResult()里用:
data.getStringArrayListExtra(RecognizerIntent.EXTRA_RESULTS)取得google云端反饋的數(shù)據(jù)即可。
語音識別,借助于云端技術(shù)可以識別用戶的語音輸入,包括語音控制等技術(shù),下面我們將利用Google 提供的Api 實現(xiàn)這一功能。
功能點(diǎn)為:通過用戶語音將用戶輸入的語音識別出來,并打印在列表上。
功能界面如下:
步驟閱讀
2
用戶通過點(diǎn)擊speak按鈕顯示界面:
步驟閱讀
3
用戶說完話后,將提交到云端搜索
步驟閱讀
4
在云端搜索完成后,返回打印數(shù)據(jù):
步驟閱讀
5
* Copyright (C) 2008 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
*
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.example.android.apis.app;
import com.example.android.apis.R;
import android.app.Activity;
import android.content.Intent;
import android.content.pm.PackageManager;
import android.content.pm.ResolveInfo;
import android.os.Bundle;
import android.speech.RecognizerIntent;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.ArrayAdapter;
import android.widget.Button;
import android.widget.ListView;
import java.util.ArrayList;
import java.util.List;
/**
* Sample code that invokes the speech recognition intent API.
*/
public class VoiceRecognition extends Activity implements OnClickListener {
private static final int VOICE_RECOGNITION_REQUEST_CODE = 1234;
private ListView mList;
/**
* Called with the activity is first created.
*/
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// Inflate our UI from its XML layout description.
setContentView(R.layout.voice_recognition);
// Get display items for later interaction
Button speakButton = (Button) findViewById(R.id.btn_speak);
mList = (ListView) findViewById(R.id.list);
// Check to see if a recognition activity is present
PackageManager pm = getPackageManager();
List activities = pm.queryIntentActivities(
new Intent(RecognizerIntent.ACTION_RECOGNIZE_SPEECH), 0);
if (activities.size() != 0) {
speakButton.setOnClickListener(this);
} else {
speakButton.setEnabled(false);
speakButton.setText("Recognizer not present");
}
}
/**
* Handle the click on the start recognition button.
*/
public void onClick(View v) {
if (v.getId() == R.id.btn_speak) {
startVoiceRecognitionActivity();
}
}
/**
* Fire an intent to start the speech recognition activity.
*/
private void startVoiceRecognitionActivity() {
Intent intent = new Intent(RecognizerIntent.ACTION_RECOGNIZE_SPEECH);
intent.putExtra(RecognizerIntent.EXTRA_LANGUAGE_MODEL,
RecognizerIntent.LANGUAGE_MODEL_FREE_FORM);
intent.putExtra(RecognizerIntent.EXTRA_PROMPT, "Speech recognition demo");
startActivityForResult(intent, VOICE_RECOGNITION_REQUEST_CODE);
}
/**
* Handle the results from the recognition activity.
*/
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
if (requestCode == VOICE_RECOGNITION_REQUEST_CODE resultCode == RESULT_OK) {
// Fill the list view with the strings the recognizer thought it could have heard
ArrayList matches = data.getStringArrayListExtra(
RecognizerIntent.EXTRA_RESULTS);
mList.setAdapter(new ArrayAdapter(this, android.R.layout.simple_list_item_1,
matches));
}
super.onActivityResult(requestCode, resultCode, data);
}
程序讀取一個事先的錄音文件,然后將其數(shù)據(jù)導(dǎo)入語音識別程序中進(jìn)行識別,識別結(jié)果可通過控件顯示出來
如果你想自己寫引擎,我不太清楚,我只知道TTS引擎可以自己寫,Voice Recognize就不知道了,不過利用Android提供的API就很容易了,API demo有示例,很簡單。但如果用原生ROM可以直接開發(fā),要是用第三方ROM就可能開發(fā)不了,需要先安裝語音搜索,也就是語音識別的引擎,因為很多ROM制造團(tuán)隊刪除了語音識別引擎
使用百度Android將語音識別轉(zhuǎn)化成文字,這樣會方便整理一些信息,但是如何進(jìn)行識別轉(zhuǎn)換的操作呢?詳細(xì)方法如下:
第一、將語音轉(zhuǎn)化成文字,需要采用ocr文字識別技術(shù)的。
第二、來到語音識別版塊后就可以點(diǎn)擊添加文件按鈕將保存好的錄音文件添加進(jìn)來了。
第三、點(diǎn)擊右邊開始識別區(qū)域就可以進(jìn)行錄音識別轉(zhuǎn)換成文字的操作了。
對上面的方法有疑問的歡迎提問哦!希望這個方法可以幫助到您!
google的語音識別返回的是一個String list,你和你預(yù)設(shè)的單詞對比一下吧.