Updated TTS settings to support language, country and variant settings.

Disable/enable entries based on whether language files are installed on the phone.
Added entry to install the language files on the phone.
This commit is contained in:
Jean-Michel Trivi
2009-06-22 16:03:40 -07:00
parent db33eb01cd
commit 1e6a45a2d0
4 changed files with 182 additions and 47 deletions

View File

@@ -122,12 +122,12 @@
</string-array> </string-array>
<!-- Do not translate. --> <!-- Do not translate. -->
<string-array name="tts_lang_values"> <string-array name="tts_lang_values">
<item>en-rUS</item> <item>eng-USA</item>
<item>en-rGB</item> <item>eng-GBR</item>
<item>fr-rFR</item> <item>fra-FRA</item>
<item>de-rDE</item> <item>deu-DEU</item>
<item>it-rIT</item> <item>ita-ITA</item>
<item>es-rES</item> <item>spa-ESP</item>
</string-array> </string-array>
<!-- Wi-Fi settings --> <!-- Wi-Fi settings -->

View File

@@ -1737,10 +1737,16 @@ found in the list of installed applications.</string>
<string name="tts_default_lang_title">Language</string> <string name="tts_default_lang_title">Language</string>
<!-- On main TTS Settings screen, summary for default language for synthesized voice --> <!-- On main TTS Settings screen, summary for default language for synthesized voice -->
<string name="tts_default_lang_summary">Sets the language-specific voice for the spoken text</string> <string name="tts_default_lang_summary">Sets the language-specific voice for the spoken text</string>
<!-- On main TTS Settings screen, triggers an example of speech synthesis --> <!-- On main TTS Settings screen, triggers playback of an example of speech synthesis -->
<string name="tts_play_example_title">Listen to an example</string> <string name="tts_play_example_title">Listen to an example</string>
<!-- On main TTS Settings screen, summary for triggering an example of speech synthesis --> <!-- On main TTS Settings screen, summary for triggering playback of an example of speech synthesis -->
<string name="tts_play_example_summary">Play a short demonstration of speech synthesis</string> <string name="tts_play_example_summary">Play a short demonstration of speech synthesis</string>
<!-- On main TTS Settings screen, click to install required speech synthesis data -->
<string name="tts_install_data_title">Install voice data</string>
<!-- On main TTS Settings screen, summary for click to install required speech synthesis data -->
<string name="tts_install_data_summary">Install the voice data required for speech synthesis</string>
<!-- On main TTS Settings screen, summary for when required speech synthesis data alrady installed on SD card -->
<string name="tts_data_installed_summary">Voices required for speech synthesis already properly installed</string>
<!-- Text spoken by the TTS engine for demonstration purposes --> <!-- Text spoken by the TTS engine for demonstration purposes -->
<string name="tts_demo">This is an example of speech synthesis.</string> <string name="tts_demo">This is an example of speech synthesis.</string>
<!-- Text spoken by the TTS engine when TTS settings (other than language) have been changed --> <!-- Text spoken by the TTS engine when TTS settings (other than language) have been changed -->

View File

@@ -22,6 +22,12 @@
android:persistent="false" android:persistent="false"
android:title="@string/tts_play_example_title" android:title="@string/tts_play_example_title"
android:summary="@string/tts_play_example_summary" /> android:summary="@string/tts_play_example_summary" />
<Preference
android:key="tts_install_data"
android:persistent="false"
android:title="@string/tts_install_data_title"
android:summary="@string/tts_install_data_summary" />
<CheckBoxPreference <CheckBoxPreference
android:key="toggle_use_default_tts_settings" android:key="toggle_use_default_tts_settings"

View File

@@ -20,6 +20,8 @@ import static android.provider.Settings.Secure.TTS_USE_DEFAULTS;
import static android.provider.Settings.Secure.TTS_DEFAULT_RATE; import static android.provider.Settings.Secure.TTS_DEFAULT_RATE;
import static android.provider.Settings.Secure.TTS_DEFAULT_PITCH; import static android.provider.Settings.Secure.TTS_DEFAULT_PITCH;
import static android.provider.Settings.Secure.TTS_DEFAULT_LANG; import static android.provider.Settings.Secure.TTS_DEFAULT_LANG;
import static android.provider.Settings.Secure.TTS_DEFAULT_COUNTRY;
import static android.provider.Settings.Secure.TTS_DEFAULT_VARIANT;
import android.content.ContentResolver; import android.content.ContentResolver;
import android.content.Intent; import android.content.Intent;
@@ -32,10 +34,12 @@ import android.preference.Preference;
import android.preference.PreferenceActivity; import android.preference.PreferenceActivity;
import android.preference.CheckBoxPreference; import android.preference.CheckBoxPreference;
import android.provider.Settings; import android.provider.Settings;
import android.provider.Settings.SettingNotFoundException;
import android.speech.tts.TextToSpeech; import android.speech.tts.TextToSpeech;
import android.util.Log; import android.util.Log;
import java.util.List; import java.util.List;
import java.util.StringTokenizer;
public class TextToSpeechSettings extends PreferenceActivity implements public class TextToSpeechSettings extends PreferenceActivity implements
Preference.OnPreferenceChangeListener, Preference.OnPreferenceClickListener, Preference.OnPreferenceChangeListener, Preference.OnPreferenceClickListener,
@@ -44,19 +48,28 @@ public class TextToSpeechSettings extends PreferenceActivity implements
private static final String TAG = "TextToSpeechSettings"; private static final String TAG = "TextToSpeechSettings";
private static final String KEY_TTS_PLAY_EXAMPLE = "tts_play_example"; private static final String KEY_TTS_PLAY_EXAMPLE = "tts_play_example";
private static final String KEY_TTS_INSTALL_DATA = "tts_install_data";
private static final String KEY_TTS_USE_DEFAULT = "toggle_use_default_tts_settings"; private static final String KEY_TTS_USE_DEFAULT = "toggle_use_default_tts_settings";
private static final String KEY_TTS_DEFAULT_RATE = "tts_default_rate"; private static final String KEY_TTS_DEFAULT_RATE = "tts_default_rate";
private static final String KEY_TTS_DEFAULT_PITCH = "tts_default_pitch"; private static final String KEY_TTS_DEFAULT_PITCH = "tts_default_pitch";
private static final String KEY_TTS_DEFAULT_LANG = "tts_default_lang"; private static final String KEY_TTS_DEFAULT_LANG = "tts_default_lang";
private static final String KEY_TTS_DEFAULT_COUNTRY = "tts_default_country";
private static final String KEY_TTS_DEFAULT_VARIANT = "tts_default_variant";
private static final String LOCALE_DELIMITER = "-";
// TODO move this to android.speech.tts.TextToSpeech.Engine // TODO move this to android.speech.tts.TextToSpeech.Engine
private static final String FALLBACK_TTS_DEFAULT_SYNTH = "com.svox.pico"; private static final String FALLBACK_TTS_DEFAULT_SYNTH = "com.svox.pico";
private Preference mPlayExample = null; private Preference mPlayExample = null;
private Preference mInstallData = null;
private CheckBoxPreference mUseDefaultPref = null; private CheckBoxPreference mUseDefaultPref = null;
private ListPreference mDefaultRatePref = null; private ListPreference mDefaultRatePref = null;
private ListPreference mDefaultPitchPref = null; private ListPreference mDefaultPitchPref = null;
private ListPreference mDefaultLangPref = null; private ListPreference mDefaultLocPref = null;
private String mDefaultLanguage = null;
private String mDefaultCountry = null;
private String mDefaultLocVariant = null;
private String mDefaultEng = ""; private String mDefaultEng = "";
private boolean mEnableDemo = false; private boolean mEnableDemo = false;
@@ -75,20 +88,21 @@ public class TextToSpeechSettings extends PreferenceActivity implements
addPreferencesFromResource(R.xml.tts_settings); addPreferencesFromResource(R.xml.tts_settings);
initDemo(); initClickers();
initDefaultSettings(); initDefaultSettings();
checkVoiceData();
} }
@Override @Override
protected void onResume() { protected void onStart() {
super.onResume(); super.onStart();
// whenever we return to this screen, we don't know the state of the // whenever we return to this screen, we don't know the state of the
// system, so we have to recheck that we can play the demo, or it must be disabled. // system, so we have to recheck that we can play the demo, or it must be disabled.
// TODO make the TTS service listen to "changes in the system", i.e. sd card un/mount
mEnableDemo = false; mEnableDemo = false;
initDemo(); initClickers();
updateWidgetState();
checkVoiceData();
} }
@@ -101,54 +115,118 @@ public class TextToSpeechSettings extends PreferenceActivity implements
} }
private void initDemo() { private void initClickers() {
mPlayExample = findPreference(KEY_TTS_PLAY_EXAMPLE); mPlayExample = findPreference(KEY_TTS_PLAY_EXAMPLE);
mPlayExample.setEnabled(mEnableDemo);
mPlayExample.setOnPreferenceClickListener(this); mPlayExample.setOnPreferenceClickListener(this);
mInstallData = findPreference(KEY_TTS_INSTALL_DATA);
mInstallData.setOnPreferenceClickListener(this);
} }
private void initDefaultSettings() { private void initDefaultSettings() {
ContentResolver resolver = getContentResolver(); ContentResolver resolver = getContentResolver();
int intVal = 0;
// Find the default TTS values in the settings, initialize and store the
// settings if they are not found.
// "Use Defaults" // "Use Defaults"
mUseDefaultPref = mUseDefaultPref = (CheckBoxPreference) findPreference(KEY_TTS_USE_DEFAULT);
(CheckBoxPreference) findPreference(KEY_TTS_USE_DEFAULT); try {
mUseDefaultPref.setChecked(Settings.Secure.getInt(resolver, intVal = Settings.Secure.getInt(resolver, TTS_USE_DEFAULTS);
TTS_USE_DEFAULTS, } catch (SettingNotFoundException e) {
TextToSpeech.Engine.FALLBACK_TTS_USE_DEFAULTS) == 1 ? true : false); // "use default" setting not found, initialize it
intVal = TextToSpeech.Engine.FALLBACK_TTS_USE_DEFAULTS;
Settings.Secure.putInt(resolver, TTS_USE_DEFAULTS, intVal);
}
mUseDefaultPref.setChecked(intVal == 1);
mUseDefaultPref.setOnPreferenceChangeListener(this); mUseDefaultPref.setOnPreferenceChangeListener(this);
// Default engine // Default engine
mDefaultEng = FALLBACK_TTS_DEFAULT_SYNTH; mDefaultEng = FALLBACK_TTS_DEFAULT_SYNTH;
// Default rate // Default rate
mDefaultRatePref = mDefaultRatePref = (ListPreference) findPreference(KEY_TTS_DEFAULT_RATE);
(ListPreference) findPreference(KEY_TTS_DEFAULT_RATE); try {
mDefaultRatePref.setValue(String.valueOf(Settings.Secure.getInt( intVal = Settings.Secure.getInt(resolver, TTS_DEFAULT_RATE);
resolver, TTS_DEFAULT_RATE, TextToSpeech.Engine.FALLBACK_TTS_DEFAULT_RATE))); } catch (SettingNotFoundException e) {
// default rate setting not found, initialize it
intVal = TextToSpeech.Engine.FALLBACK_TTS_DEFAULT_RATE;
Settings.Secure.putInt(resolver, TTS_DEFAULT_RATE, intVal);
}
mDefaultRatePref.setValue(String.valueOf(intVal));
mDefaultRatePref.setOnPreferenceChangeListener(this); mDefaultRatePref.setOnPreferenceChangeListener(this);
// Default pitch // Default pitch
mDefaultPitchPref = mDefaultPitchPref = (ListPreference) findPreference(KEY_TTS_DEFAULT_PITCH);
(ListPreference) findPreference(KEY_TTS_DEFAULT_PITCH); try {
mDefaultPitchPref.setValue(String.valueOf(Settings.Secure.getInt( intVal = Settings.Secure.getInt(resolver, TTS_DEFAULT_PITCH);
resolver, TTS_DEFAULT_PITCH, TextToSpeech.Engine.FALLBACK_TTS_DEFAULT_PITCH))); } catch (SettingNotFoundException e) {
// default pitch setting not found, initialize it
intVal = TextToSpeech.Engine.FALLBACK_TTS_DEFAULT_PITCH;
Settings.Secure.putInt(resolver, TTS_DEFAULT_PITCH, intVal);
}
mDefaultPitchPref.setValue(String.valueOf(intVal));
mDefaultPitchPref.setOnPreferenceChangeListener(this); mDefaultPitchPref.setOnPreferenceChangeListener(this);
// Default language
mDefaultLangPref = // Default language / country / variant : these three values map to a single ListPref
(ListPreference) findPreference(KEY_TTS_DEFAULT_LANG); // representing the matching Locale
String defaultLang = String.valueOf(Settings.Secure.getString(resolver, String language = null;
TTS_DEFAULT_LANG)); String country = null;
if (defaultLang.compareTo("null") == 0) { String variant = null;
mDefaultLangPref.setValue(TextToSpeech.Engine.FALLBACK_TTS_DEFAULT_LANG); mDefaultLocPref = (ListPreference) findPreference(KEY_TTS_DEFAULT_LANG);
Log.i(TAG, "TTS initDefaultSettings() default lang null "); language = Settings.Secure.getString(resolver, KEY_TTS_DEFAULT_LANG);
if (language != null) {
mDefaultLanguage = language;
} else { } else {
mDefaultLangPref.setValue(defaultLang); // default language setting not found, initialize it, as well as the country and variant
Log.i(TAG, "TTS initDefaultSettings() default lang is "+defaultLang); language = TextToSpeech.Engine.FALLBACK_TTS_DEFAULT_LANG;
country = TextToSpeech.Engine.FALLBACK_TTS_DEFAULT_COUNTRY;
variant = TextToSpeech.Engine.FALLBACK_TTS_DEFAULT_VARIANT;
Settings.Secure.putString(resolver, KEY_TTS_DEFAULT_LANG, language);
Settings.Secure.putString(resolver, KEY_TTS_DEFAULT_COUNTRY, country);
Settings.Secure.putString(resolver, KEY_TTS_DEFAULT_VARIANT, variant);
} }
mDefaultLangPref.setOnPreferenceChangeListener(this); if (country == null) {
// country wasn't initialized yet because a default language was found
country = Settings.Secure.getString(resolver, KEY_TTS_DEFAULT_COUNTRY);
if (country.compareTo("null") != 0) {
mDefaultCountry = country;
} else {
// default country setting not found, initialize it, as well as the variant;
country = TextToSpeech.Engine.FALLBACK_TTS_DEFAULT_COUNTRY;
variant = TextToSpeech.Engine.FALLBACK_TTS_DEFAULT_VARIANT;
Settings.Secure.putString(resolver, KEY_TTS_DEFAULT_COUNTRY, country);
Settings.Secure.putString(resolver, KEY_TTS_DEFAULT_VARIANT, variant);
}
}
if (variant == null) {
// variant wasn't initialized yet because a default country was found
variant = Settings.Secure.getString(resolver, KEY_TTS_DEFAULT_VARIANT);
if (variant.compareTo("null") != 0) {
mDefaultLocVariant = variant;
} else {
// default variant setting not found, initialize it
variant = TextToSpeech.Engine.FALLBACK_TTS_DEFAULT_VARIANT;
Settings.Secure.putString(resolver, KEY_TTS_DEFAULT_VARIANT, variant);
}
}
// we now have the default lang/country/variant trio, build a string value from it
String localeString = new String(language);
if (country.compareTo("") != 0) {
localeString += LOCALE_DELIMITER + country;
} else {
localeString += LOCALE_DELIMITER + " ";
}
if (variant.compareTo("") != 0) {
localeString += LOCALE_DELIMITER + variant;
}
Log.v(TAG, "In initDefaultSettings: localeString=" + localeString);
// TODO handle the case where localeString isn't in the existing entries
mDefaultLocPref.setValue(localeString);
mDefaultLocPref.setOnPreferenceChangeListener(this);
} }
@@ -179,7 +257,7 @@ public class TextToSpeechSettings extends PreferenceActivity implements
Log.v(TAG, "TTS engine for settings screen failed to initialize successfully."); Log.v(TAG, "TTS engine for settings screen failed to initialize successfully.");
mEnableDemo = false; mEnableDemo = false;
} }
mPlayExample.setEnabled(mEnableDemo); updateWidgetState();
} }
@@ -214,6 +292,9 @@ public class TextToSpeechSettings extends PreferenceActivity implements
try { try {
Settings.Secure.putInt(getContentResolver(), Settings.Secure.putInt(getContentResolver(),
TTS_DEFAULT_RATE, value); TTS_DEFAULT_RATE, value);
if (mTts != null) {
mTts.setSpeechRate(value);
}
Log.i(TAG, "TTS default rate is "+value); Log.i(TAG, "TTS default rate is "+value);
} catch (NumberFormatException e) { } catch (NumberFormatException e) {
Log.e(TAG, "could not persist default TTS rate setting", e); Log.e(TAG, "could not persist default TTS rate setting", e);
@@ -229,26 +310,68 @@ public class TextToSpeechSettings extends PreferenceActivity implements
Log.e(TAG, "could not persist default TTS pitch setting", e); Log.e(TAG, "could not persist default TTS pitch setting", e);
} }
} else if (KEY_TTS_DEFAULT_LANG.equals(preference.getKey())) { } else if (KEY_TTS_DEFAULT_LANG.equals(preference.getKey())) {
// Default language // Default locale
String value = (String) objValue; ContentResolver resolver = getContentResolver();
Settings.Secure.putString(getContentResolver(), parseLocaleInfo((String) objValue);
TTS_DEFAULT_LANG, value); Settings.Secure.putString(resolver, TTS_DEFAULT_LANG, mDefaultLanguage);
Log.i(TAG, "TTS default lang is "+value); Settings.Secure.putString(resolver, TTS_DEFAULT_COUNTRY, mDefaultCountry);
Settings.Secure.putString(resolver, TTS_DEFAULT_VARIANT, mDefaultLocVariant);
Log.v(TAG, "TTS default lang/country/variant set to "
+ mDefaultLanguage + "/" + mDefaultCountry + "/" + mDefaultLocVariant);
} }
return true; return true;
} }
/**
* Called when mPlayExample or mInstallData is clicked
*/
public boolean onPreferenceClick(Preference preference) { public boolean onPreferenceClick(Preference preference) {
if (preference == mPlayExample) { if (preference == mPlayExample) {
// Play example
if (mTts != null) { if (mTts != null) {
mTts.speak(getResources().getString(R.string.tts_demo), mTts.speak(getResources().getString(R.string.tts_demo),
TextToSpeech.TTS_QUEUE_FLUSH, null); TextToSpeech.TTS_QUEUE_FLUSH, null);
} }
return true; return true;
} }
if (preference == mInstallData) {
// Install data
// TODO launch request for installer
return true;
}
return false; return false;
} }
private void updateWidgetState() {
mPlayExample.setEnabled(mEnableDemo);
mUseDefaultPref.setEnabled(mEnableDemo);
mDefaultRatePref.setEnabled(mEnableDemo);
mDefaultPitchPref.setEnabled(mEnableDemo);
mDefaultLocPref.setEnabled(mEnableDemo);
mInstallData.setEnabled(!mEnableDemo);
}
private void parseLocaleInfo(String locale) {
StringTokenizer tokenizer = new StringTokenizer(locale, LOCALE_DELIMITER);
mDefaultLanguage = "";
mDefaultCountry = "";
mDefaultLocVariant = "";
if (tokenizer.hasMoreTokens()) {
mDefaultLanguage = tokenizer.nextToken().trim();
}
if (tokenizer.hasMoreTokens()) {
mDefaultCountry = tokenizer.nextToken().trim();
}
if (tokenizer.hasMoreTokens()) {
mDefaultLocVariant = tokenizer.nextToken().trim();
}
}
} }