/*
* Copyright (C) 2011 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 android.speech.tts;
/**
* Defines additional methods the synthesis callback must implement that
* are private to the TTS service implementation.
*
* All of these class methods (with the exception of {@link #stop()}) can be only called on the
* synthesis thread, while inside
* {@link TextToSpeechService#onSynthesizeText} or {@link TextToSpeechService#onSynthesizeTextV2}.
* {@link #stop()} is the exception, it may be called from multiple threads.
*/
abstract class AbstractSynthesisCallback implements SynthesisCallback {
/** If true, request comes from V2 TTS interface */
protected final boolean mClientIsUsingV2;
/**
* Constructor.
* @param clientIsUsingV2 If true, this callback will be used inside
* {@link TextToSpeechService#onSynthesizeTextV2} method.
*/
AbstractSynthesisCallback(boolean clientIsUsingV2) {
mClientIsUsingV2 = clientIsUsingV2;
}
/**
* Aborts the speech request.
*
* Can be called from multiple threads.
*/
abstract void stop();
/**
* Get status code for a "stop".
*
* V2 Clients will receive special status, V1 clients will receive standard error.
*
* This method should only be called on the synthesis thread,
* while in {@link TextToSpeechService#onSynthesizeText}.
*/
int errorCodeOnStop() {
return mClientIsUsingV2 ? TextToSpeech.STOPPED : TextToSpeech.ERROR;
}
}