Isso é possível sem modificar as APIs do Android? Eu encontrei um artigo sobre isso. Há um comentário que devo fazer modificações nas APIs do Android. Mas não disse como fazer a modificação. Alguém pode me dar algumas sugestões sobre como fazer isso? Obrigado!
Eu encontrei este artigo; Reconhecedor de Fala Suas necessidades são quase as mesmas que as minhas. É uma boa referência para mim!
Eu tenho totalmente esse problema resolvido.
Eu pesquisei um código de exemplo utilizável a partir deste site China
Aqui está o meu código fonte
package voice.recognition.test;
import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.speech.RecognitionListener;
import android.speech.RecognizerIntent;
import android.speech.SpeechRecognizer;
import android.widget.Button;
import android.widget.TextView;
import java.util.ArrayList;
import android.util.Log;
public class voiceRecognitionTest extends Activity implements OnClickListener
{
private TextView mText;
private SpeechRecognizer sr;
private static final String TAG = "MyStt3Activity";
@Override
public void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
Button speakButton = (Button) findViewById(R.id.btn_speak);
mText = (TextView) findViewById(R.id.textView1);
speakButton.setOnClickListener(this);
sr = SpeechRecognizer.createSpeechRecognizer(this);
sr.setRecognitionListener(new listener());
}
class listener implements RecognitionListener
{
public void onReadyForSpeech(Bundle params)
{
Log.d(TAG, "onReadyForSpeech");
}
public void onBeginningOfSpeech()
{
Log.d(TAG, "onBeginningOfSpeech");
}
public void onRmsChanged(float rmsdB)
{
Log.d(TAG, "onRmsChanged");
}
public void onBufferReceived(byte[] buffer)
{
Log.d(TAG, "onBufferReceived");
}
public void onEndOfSpeech()
{
Log.d(TAG, "onEndofSpeech");
}
public void onError(int error)
{
Log.d(TAG, "error " + error);
mText.setText("error " + error);
}
public void onResults(Bundle results)
{
String str = new String();
Log.d(TAG, "onResults " + results);
ArrayList data = results.getStringArrayList(SpeechRecognizer.RESULTS_RECOGNITION);
for (int i = 0; i < data.size(); i++)
{
Log.d(TAG, "result " + data.get(i));
str += data.get(i);
}
mText.setText("results: "+String.valueOf(data.size()));
}
public void onPartialResults(Bundle partialResults)
{
Log.d(TAG, "onPartialResults");
}
public void onEvent(int eventType, Bundle params)
{
Log.d(TAG, "onEvent " + eventType);
}
}
public void onClick(View v) {
if (v.getId() == R.id.btn_speak)
{
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,"voice.recognition.test");
intent.putExtra(RecognizerIntent.EXTRA_MAX_RESULTS,5);
sr.startListening(intent);
Log.i("111111","11111111");
}
}
}
Certifique-se de excluir os logs irritantes após a depuração!
android
speech-recognition
speech
Jim31837
fonte
fonte
<uses-permission android:name="android.permission.RECORD_AUDIO" />
no seu arquivo AndroidManifest.xml, caso contrário, o SpeechRecognizer não captará nenhum áudioRespostas:
Use a interface SpeechRecognizer . Seu aplicativo precisa ter a permissão RECORD_AUDIO e, em seguida, você pode criar um SpeechRecognizer, fornecer um RecognitionListener e, em seguida, chamar seu
startListening
método. Você receberá retornos de chamada para o ouvinte quando o reconhecedor de fala estiver pronto para começar a ouvir e assim que receber fala e a converter em texto.fonte
has leaked ServiceConnection android.speech.SpeechRecognizer$Connection@414f0e40 that was originally bound here
erroO GAST tem uma classe abstrata útil que você pode usar para usar a
SpeechRecognizer
classe com muito pouco código novo. Há também um exemplo deSpeechRecognizer
como executar o serviço como plano de fundo usando este e estefonte
Obrigado por postar isso! Achei útil definir o ouvinte onclick no oncreate:
fonte
Acabo fazendo o projeto Github para converter texto em fala e fala em texto sem uma caixa de diálogo irritante,
https://github.com/hiteshsahu/Android-TTS-STT/tree/master/app/src/main/java/com/hiteshsahu/stt_tts/translation_engine
fonte