blob: 3c92010b67fbe661b982203b57ec7af475933c47 [file] [log] [blame]
/*
* Copyright 2020 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.android.settings.tts;
import android.app.Application;
import android.speech.tts.TextToSpeech;
import android.util.Pair;
import androidx.lifecycle.AndroidViewModel;
/**
* A helper view model to protect the TTS object from being destroyed and
* recreated on orientation change.
*/
public class TextToSpeechViewModel extends AndroidViewModel {
private TextToSpeech mTts;
// Save the application so we can use it as the TTS context
private final Application mApplication;
public TextToSpeechViewModel(Application application) {
super(application);
mApplication = application;
}
/*
* Since the view model now controls the TTS object, we need to handle shutting it down
* ourselves.
*/
@Override
protected void onCleared() {
shutdownTts();
}
protected void shutdownTts() {
mTts.shutdown();
mTts = null;
}
/*
* An accessor method to get the TTS object. Returns a pair of the TTS object and a boolean
* indicating whether the TTS object was newly created or not.
*/
protected Pair<TextToSpeech, Boolean> getTtsAndWhetherNew(
TextToSpeech.OnInitListener listener) {
boolean ttsCreated = false;
if (mTts == null) {
mTts = new TextToSpeech(this.mApplication, listener);
ttsCreated = true;
}
return Pair.create(mTts, ttsCreated);
}
}