處理SpeechRecognizer的識別結果需要以下幾個步驟:
SpeechRecognizer speechRecognizer = SpeechRecognizer.createSpeechRecognizer(this);
Intent intent = new Intent(RecognizerIntent.ACTION_RECOGNIZE_SPEECH);
intent.putExtra(RecognizerIntent.EXTRA_LANGUAGE_MODEL, RecognizerIntent.LANGUAGE_MODEL_FREE_FORM);
intent.putExtra(RecognizerIntent.EXTRA_CALLING_PACKAGE, getPackageName());
intent.putExtra(RecognizerIntent.EXTRA_MAX_RESULTS, 1);
speechRecognizer.setRecognitionListener(new RecognitionListener() {
@Override
public void onReadyForSpeech(Bundle params) {
// 當語音識別準備就緒時,可以在這里顯示提示信息
}
@Override
public void onBeginningOfSpeech() {
// 當開始說話時,可以在這里顯示提示信息
}
@Override
public void onRmsChanged(float rmsdB) {
// 實時音量變化,可以在這里更新音量條
}
@Override
public void onBufferReceived(byte[] buffer) {
// 接收到語音數據時,可以在這里處理
}
@Override
public void onEndOfSpeech() {
// 當說話結束時,可以在這里顯示提示信息
}
@Override
public void onError(int error) {
// 出現錯誤時,可以在這里處理錯誤
}
@Override
public void onResults(Bundle results) {
// 獲取識別結果
ArrayList<String> matches = results.getStringArrayList(SpeechRecognizer.RESULTS_RECOGNITION);
String result = matches.get(0);
// 在這里處理識別結果,例如顯示在TextView中
}
@Override
public void onPartialResults(Bundle partialResults) {
// 獲取部分識別結果,可以在這里實時顯示識別內容
}
@Override
public void onEvent(int eventType, Bundle params) {
// 其他事件處理
}
});
speechRecognizer.startListening(intent);
speechRecognizer.stopListening();
speechRecognizer.destroy();
通過以上步驟,你可以處理SpeechRecognizer的識別結果。注意在實際應用中,需要根據需求調整代碼,例如處理錯誤、顯示提示信息等。