私はこの質問を組み立てるのに苦労していますが、とにかくここで、基本的に TextToSpeech アプリと SpeechToText アプリケーションの 2 つのアプリケーションを作成しました。それらは正常に機能しています。今、それらをマージしようとしています。基本的に、ユーザーが「話す」という言葉を言った場合にのみ、テキストフィールドに入力されたテキストをテキストから音声への部分で言いたいと思います。それは、音声からテキストへの部分を使用して行われます。今私が抱えている問題は、ユーザーが何かを言ったときにアンドロイドが出力のリストを表示することですが、私は "Speak" である出力を 1 つだけ表示します。リストの代わりに出力を 1 つだけ取得するにはどうすればよいですか。
最初は、ボタンのクリックでアプリがアクティブになります。
私が試しているコードは次のとおりです。
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
Intent i = new Intent(RecognizerIntent.ACTION_RECOGNIZE_SPEECH);
i.putExtra(RecognizerIntent.EXTRA_LANGUAGE_MODEL,
RecognizerIntent.LANGUAGE_MODEL_FREE_FORM);
i.putExtra(RecognizerIntent.EXTRA_PROMPT, "system Activated");
startActivityForResult(i, check);
}
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
// TODO Auto-generated method stub
if (requestCode == check && resultCode == RESULT_OK) {
String command = data
.getStringExtra(RecognizerIntent.EXTRA_RESULTS).toString();
if (command.equals(command_verify)) {
speak();
} else
finish();
}
super.onActivityResult(requestCode, resultCode, data);
}
public void speak() {
String text_to_speak = message_field.getText().toString();
talk.speak(text_to_speak, TextToSpeech.QUEUE_FLUSH, null);
}