Как я могу использовать распознавание речи без раздражающего диалога на телефонах Android

Возможно ли это без изменения API-интерфейсов Android? Я нашел статью об этом. Есть один комментарий, который я должен внести в API 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"); } } } 

Обязательно удалите раздражающие журналы после отладки!

    Используйте интерфейс SpeechRecognizer . Ваше приложение должно иметь разрешение RECORD_AUDIO, и затем вы можете создать SpeechRecognizer, дать ему RecognitionListener, а затем вызвать его метод startListening . Вы получите обратные вызовы слушателю, когда речевой распознаватель готов начать прослушивание речи и как он принимает речь и преобразует ее в текст.

    GAST имеет удобный абстрактный class, который вы можете использовать для использования classа SpeechRecognizer с очень маленьким новым кодом. Существует также пример запуска SpeechRecognizer в качестве справочной службы, использующей это и это

    Спасибо, что опубликовали это! Мне было полезно определить прослушиватель 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); } }); } 

    Я пробовал хранить все свои знания от 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); 

    Выход : –

    введите описание изображения здесь

    Interesting Posts

    Вход в Windows 7 с одной учетной записью очень медленный. Зачем?

    Как использовать только одно окно / приложение для другого пользователя в сети?

    «Нестатический метод не может ссылаться на статический контекст»

    Явный эквивалент unsigned long long?

    Как исправить предупреждение о настройке языкового стандарта на Perl?

    Почему для 64-разрядной версии Windows 7 требуется больше памяти, чем 32-разрядная?

    Проверка того, является ли объект заданным типом в Swift

    Почему Windows 7 предполагает наличие нового сетевого соединения при подключении к существующей точке доступа?

    Почему функция CSS calc () не работает для меня?

    Переопределение кнопки «Главная» – как мне избавиться от выбора?

    Как я могу автоматически конвертировать все файлы исходного кода в папку (рекурсивно) в один PDF с подсветкой синтаксиса?

    Как обрабатывать новое окно в Selenium WebDriver с помощью Java?

    VBA, удалите дубликаты из массива

    MySQL эквивалент ранга ORACLES ()

    Как реализовать db-прослушиватель в Java

    Давайте будем гением компьютера.