要捕捉“准备就绪”声音事件,您可以使用Android的SpeechRecognizer类,并实现RecognitionListener接口来监听事件。
以下是一个示例代码,演示如何使用SpeechRecognizer类来捕捉“准备就绪”声音事件:
import android.Manifest;
import android.content.Intent;
import android.content.pm.PackageManager;
import android.os.Bundle;
import android.speech.RecognitionListener;
import android.speech.RecognizerIntent;
import android.speech.SpeechRecognizer;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.app.ActivityCompat;
import java.util.ArrayList;
public class MainActivity extends AppCompatActivity implements RecognitionListener {
private TextView textView;
private Button button;
private SpeechRecognizer speechRecognizer;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
textView = findViewById(R.id.textView);
button = findViewById(R.id.button);
// 检查录音权限
if (ActivityCompat.checkSelfPermission(this, Manifest.permission.RECORD_AUDIO) != PackageManager.PERMISSION_GRANTED) {
ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.RECORD_AUDIO}, 1);
}
// 创建SpeechRecognizer实例
speechRecognizer = SpeechRecognizer.createSpeechRecognizer(this);
speechRecognizer.setRecognitionListener(this);
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// 创建RecognizerIntent
Intent intent = new Intent(RecognizerIntent.ACTION_RECOGNIZE_SPEECH);
intent.putExtra(RecognizerIntent.EXTRA_LANGUAGE_MODEL, RecognizerIntent.LANGUAGE_MODEL_FREE_FORM);
// 开始识别
speechRecognizer.startListening(intent);
}
});
}
@Override
public void onReadyForSpeech(Bundle params) {
// 准备就绪,可以开始说话
textView.setText("准备就绪,请开始说话");
}
@Override
public void onBeginningOfSpeech() {
// 检测到用户已经开始说话
textView.setText("检测到用户开始说话");
}
@Override
public void onEndOfSpeech() {
// 检测到用户已经停止说话
textView.setText("检测到用户停止说话");
}
@Override
public void onError(int error) {
// 发生错误
textView.setText("发生错误:" + error);
}
@Override
public void onResults(Bundle results) {
// 获取识别结果
ArrayList matches = results.getStringArrayList(SpeechRecognizer.RESULTS_RECOGNITION);
if (matches != null && !matches.isEmpty()) {
String recognizedText = matches.get(0);
textView.setText("识别结果:" + recognizedText);
}
}
// 实现其他RecognitionListener的方法...
@Override
protected void onDestroy() {
super.onDestroy();
// 释放SpeechRecognizer资源
if (speechRecognizer != null) {
speechRecognizer.destroy();
}
}
}
上述代码中,我们首先检查并请求录音权限。然后,我们创建SpeechRecognizer实例并设置RecognitionListener为当前Activity。在点击按钮时,我们创建RecognizerIntent,并使用speechRecognizer.startListening(intent)来开始识别过程。
在RecognitionListener的回调方法中,我们可以根据需要处理不同的事件。在此示例中,我们分别在onReadyForSpeech、onBeginningOfSpeech、onEndOfSpeech、onError和onResults方法中更新textView的文本以反映不同的事件。
请注意,此代码仅涉及“准备就绪”事件的捕捉。您可以根据您的需求实现其他RecognitionListener方法来处理其他事件。