É um projeto que converte texto em voz usando a classe TextToSpeech fornecida pelo Google.
É o construtor TextToSpeech(Context context, TextToSpeech.OnInitListener listener) . Há um construtor que pode definir o mecanismo TTS, mas eu decidi omiti -lo.
InitListener será descrito abaixo.
private TextToSpeech textToSpeech;
@Override
protected void onCreate(Bundle savedInstanceState) {
textToSpeech = new TextToSpeech(this, initListener);
}
//음성 재생 상태에 대한 callback을 받을 수 있는 추상 클래스
private UtteranceProgressListener progressListener = new UtteranceProgressListener() {
@Override
public void onStart(String utteranceId) { // 음성이 재생되었을 때
}
@Override
public void onDone(String utteranceId) { // 제공된 텍스트를 모두 음성으로 재생한 경우
}
@Override
public void onError(String utteranceId) { // ERROR!
}
};
textToSpeech.setOnUtteranceProgressListener(progressListener);
setLanguage() abaixo pode definir o idioma da fala. Você pode selecionar a voz necessária de acordo com a situação, como Locale.English, Locale.Canada.
//음성 관련 초기화 상태에 대한 callback을 받을 수 있는 인터페이스
private TextToSpeech.OnInitListener initListener = new TextToSpeech.OnInitListener() {
@Override
public void onInit(int status) {
if(status != TextToSpeech.ERROR)
textToSpeech.setLanguage(Locale.KOREAN); // 한글로 설정
}
};
Antes de explicar, o 'UtterranceID' indica um valor de identificação para a voz atualmente tocada. Parece ser útil ao controlar a voz múltipla.
O método speak(String text, int queueMode, HashMap<String, String> params) foi obsoleto no nível 21. Portanto, de acordo com o nível da API, use o novo speak(CharSequence text, int queueMode, Bundle params, String utteranceId) , o seguinte a seguir.
String text = editText.getText.toString();
if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
String myUtteranceID = "myUtteranceID";
textToSpeech.speak(text, TextToSpeech.QUEUE_FLUSH, null, myUtteranceID);
}
else {
HashMap<String, String> hashMap = new HashMap<>();
hashMap.put(TextToSpeech.Engine.KEY_PARAM_UTTERANCE_ID, "myUtteranceID");
textToSpeech.speak(text, TextToSpeech.QUEUE_FLUSH, hashMap);
}
Simplesmente use um método como textToSpeech.stop() para parar a voz atualmente sendo tocada.
O instante inicial do TextToSPeech através do mecanismo de fala deve ser completamente encerrado através do textToSpeech.shutDown() . Ou seviceConnection ... eu tenho uma exceção.
ex. No caso de atividade, como mostrado abaixo, você pode chamar shutDown() para corresponder ao ciclo de vida.
@Override
protected void onDestroy() {
if(textToSpeech != null)
textToSpeech.shutDown();
super.onDestroy();
}
O projeto criou uma classe TTS e facilitou o uso. Depois disso, o projeto será adicionado ao projeto.
