voz reconocimiento programar por para internet google español dictado descargar controlar control como comando celular activar android speech-recognition speech

programar - ¿Cómo puedo usar el reconocimiento de voz sin el molesto diálogo en teléfonos Android?



reconocimiento de voz google (4)

¡Gracias por publicar esto! Me pareció útil definir el oyente onclick en oncreate:

@Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mText = (TextView) findViewById(R.id.textView1); MyRecognitionListener listener = new MyRecognitionListener(); sr = SpeechRecognizer.createSpeechRecognizer(this); sr.setRecognitionListener(listener); findViewById(R.id.button1).setOnClickListener( new View.OnClickListener() { @Override public void onClick(View v) { Intent intent = new Intent(RecognizerIntent.ACTION_RECOGNIZE_SPEECH); intent.putExtra(RecognizerIntent.EXTRA_LANGUAGE_MODEL, "en-US"); intent.putExtra(RecognizerIntent.EXTRA_MAX_RESULTS,1); intent.putExtra(RecognizerIntent.EXTRA_CALLING_PACKAGE,"voice.recognition.test"); sr.startListening(intent); } }); }

¿Es esto posible sin modificar las API de Android? Encontré un artículo sobre esto. Hay un comentario que debería hacer modificaciones a las API de Android. Pero no dijo cómo hacer la modificación. ¿Alguien puede darme algunas sugerencias sobre cómo hacer eso? ¡Gracias!

Encontré este artículo; SpeechRecognizer Sus necesidades son casi las mismas que las mías. ¡Es una buena referencia para mí!

Tengo totalmente resuelto este problema.
Busqué en Google un código de muestra utilizable de este sitio web de China Aquí está mi código fuente

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"); } } }

¡Asegúrese de eliminar los molestos registros después de la depuración!


He intentado almacenar todo mi aprendizaje de TTS y STT en este Github Repo . Si te gusta uno, entonces puedes usar mi proyecto.

Utilizó el patrón Factory para convertir Speech to Text en línea sin un diálogo molesto

SpeechToText (STT) .

TranslatorFactory.getInstance().getTranslator(TranslatorFactory.TRANSLATOR_TYPE.SPEECH_TO_TEXT, HomeActivity.this) .initialize("Hello There", HomeActivity.this);

Salida : -

TextToSpeech (TTS)

TranslatorFactory.getInstance().getTranslator(TranslatorFactory.TRANSLATOR_TYPE.TEXT_TO_SPEECH, HomeActivity.this) .initialize((null != message && !message ? message : "Invalid Input"), HomeActivity.this);

Salida : -


Use la interfaz SpeechRecognizer . Su aplicación necesita tener el permiso RECORD_AUDIO, y luego puede crear un SpeechRecognizer, darle un RecognitionListener y luego llamar a su método startListening . Recibirá devoluciones de llamada al oyente cuando el reconocedor de voz esté listo para comenzar a escuchar el habla y cuando reciba el habla y lo convierta en texto.


GAST tiene una útil clase abstracta que puede usar para usar la clase SpeechRecognizer con muy poco código nuevo. También hay un ejemplo de ejecutar SpeechRecognizer como un servicio en segundo plano usando this y this