Как я могу использовать распознавание речи без раздражающего диалога на телефонах Android
Возможно ли это без изменения API-интерфейсов Android?
Я нашел статью об этом.
Там один комментарий, что я должен внести изменения в API Android.
Но он не сказал, как сделать модификацию.
Может ли кто-нибудь дать мне несколько советов о том, как это сделать?
Спасибо!
Я нашел эту статью;
SpeechRecognizer
Его потребности почти такие же, как у меня.
Это хорошая рекомендация для меня!
Я полностью решил эту проблему.
Я googled полезный образец кода с этого веб-сайта Китая
Здесь мой исходный код
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");
}
}
}
Обязательно удалите раздражающие журналы после отладки!
Ответы
Ответ 1
Используйте SpeechRecognizer интерфейс. Ваше приложение должно иметь разрешение RECORD_AUDIO, и затем вы можете создать SpeechRecognizer, дать ему RecognitionListener и затем вызвать его метод startListening
. Вы получите обратные вызовы слушателю, когда речевой распознаватель готов начать прослушивание речи, а так как он принимает речь и преобразует ее в текст.
Ответ 2
GAST имеет удобный абстрактный класс, который вы можете использовать для использования класса SpeechRecognizer
с очень маленьким новым кодом. Существует также пример запуска SpeechRecognizer
в качестве фоновой службы, используя this и this
Ответ 3
Спасибо, что опубликовали это! Мне было полезно определить прослушиватель onclick в 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);
}
});
}
Ответ 4
Я пробовал хранить все мои уроки от TTS и STT в этот Github Repo. Если вам нравятся один лайнер, вы можете использовать мой проект.
Он использовал шаблон Factory для преобразования речи в текст в строке без раздражающего диалога
SpeechToText (STT).
TranslatorFactory.getInstance().getTranslator(TranslatorFactory.TRANSLATOR_TYPE.SPEECH_TO_TEXT, HomeActivity.this)
.initialize("Hello There", HomeActivity.this);
Выход: -
![введите описание изображения здесь]()
TextToSpeech (TTS)
TranslatorFactory.getInstance().getTranslator(TranslatorFactory.TRANSLATOR_TYPE.TEXT_TO_SPEECH, HomeActivity.this)
.initialize((null != message && !message ? message : "Invalid Input"), HomeActivity.this);
Выход: -
![введите описание изображения здесь]()