2010-01-30 04:09:49 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2010 Google Inc.
|
|
|
|
*
|
|
|
|
* 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.inputmethod.latin;
|
|
|
|
|
|
|
|
import android.content.SharedPreferences;
|
|
|
|
import android.content.SharedPreferences.Editor;
|
|
|
|
import android.preference.PreferenceManager;
|
2010-02-24 03:01:43 +00:00
|
|
|
import android.text.TextUtils;
|
2010-01-30 04:09:49 +00:00
|
|
|
|
2010-11-11 07:03:19 +00:00
|
|
|
import java.util.ArrayList;
|
|
|
|
import java.util.Locale;
|
|
|
|
|
2010-01-30 04:09:49 +00:00
|
|
|
/**
|
|
|
|
* Keeps track of list of selected input languages and the current
|
|
|
|
* input language that the user has selected.
|
|
|
|
*/
|
|
|
|
public class LanguageSwitcher {
|
|
|
|
|
2010-11-11 07:03:19 +00:00
|
|
|
private final ArrayList<Locale> mLocales = new ArrayList<Locale>();
|
|
|
|
private final LatinIME mIme;
|
2010-01-30 04:09:49 +00:00
|
|
|
private String[] mSelectedLanguageArray;
|
|
|
|
private String mSelectedLanguages;
|
|
|
|
private int mCurrentIndex = 0;
|
|
|
|
private String mDefaultInputLanguage;
|
|
|
|
private Locale mDefaultInputLocale;
|
2010-05-03 18:14:31 +00:00
|
|
|
private Locale mSystemLocale;
|
2010-01-30 04:09:49 +00:00
|
|
|
|
|
|
|
public LanguageSwitcher(LatinIME ime) {
|
|
|
|
mIme = ime;
|
|
|
|
}
|
|
|
|
|
|
|
|
public int getLocaleCount() {
|
2010-11-11 07:03:19 +00:00
|
|
|
return mLocales.size();
|
2010-01-30 04:09:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Loads the currently selected input languages from shared preferences.
|
|
|
|
* @param sp
|
|
|
|
* @return whether there was any change
|
|
|
|
*/
|
|
|
|
public boolean loadLocales(SharedPreferences sp) {
|
|
|
|
String selectedLanguages = sp.getString(LatinIME.PREF_SELECTED_LANGUAGES, null);
|
|
|
|
String currentLanguage = sp.getString(LatinIME.PREF_INPUT_LANGUAGE, null);
|
|
|
|
if (selectedLanguages == null || selectedLanguages.length() < 1) {
|
|
|
|
loadDefaults();
|
2010-11-11 07:03:19 +00:00
|
|
|
if (mLocales.size() == 0) {
|
2010-01-30 04:09:49 +00:00
|
|
|
return false;
|
|
|
|
}
|
2010-11-11 07:03:19 +00:00
|
|
|
mLocales.clear();
|
2010-01-30 04:09:49 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
if (selectedLanguages.equals(mSelectedLanguages)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
mSelectedLanguageArray = selectedLanguages.split(",");
|
|
|
|
mSelectedLanguages = selectedLanguages; // Cache it for comparison later
|
|
|
|
constructLocales();
|
|
|
|
mCurrentIndex = 0;
|
|
|
|
if (currentLanguage != null) {
|
|
|
|
// Find the index
|
|
|
|
mCurrentIndex = 0;
|
2010-11-11 07:03:19 +00:00
|
|
|
for (int i = 0; i < mLocales.size(); i++) {
|
2010-01-30 04:09:49 +00:00
|
|
|
if (mSelectedLanguageArray[i].equals(currentLanguage)) {
|
|
|
|
mCurrentIndex = i;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// If we didn't find the index, use the first one
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
private void loadDefaults() {
|
|
|
|
mDefaultInputLocale = mIme.getResources().getConfiguration().locale;
|
2010-02-24 03:01:43 +00:00
|
|
|
String country = mDefaultInputLocale.getCountry();
|
|
|
|
mDefaultInputLanguage = mDefaultInputLocale.getLanguage() +
|
|
|
|
(TextUtils.isEmpty(country) ? "" : "_" + country);
|
2010-01-30 04:09:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
private void constructLocales() {
|
2010-11-11 07:03:19 +00:00
|
|
|
mLocales.clear();
|
|
|
|
for (final String lang : mSelectedLanguageArray) {
|
|
|
|
final Locale locale = new Locale(lang.substring(0, 2),
|
2010-05-03 18:14:31 +00:00
|
|
|
lang.length() > 4 ? lang.substring(3, 5) : "");
|
2010-11-11 07:03:19 +00:00
|
|
|
mLocales.add(locale);
|
2010-01-30 04:09:49 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the currently selected input language code, or the display language code if
|
|
|
|
* no specific locale was selected for input.
|
|
|
|
*/
|
|
|
|
public String getInputLanguage() {
|
|
|
|
if (getLocaleCount() == 0) return mDefaultInputLanguage;
|
|
|
|
|
|
|
|
return mSelectedLanguageArray[mCurrentIndex];
|
|
|
|
}
|
2010-02-05 02:31:40 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the list of enabled language codes.
|
|
|
|
*/
|
|
|
|
public String[] getEnabledLanguages() {
|
|
|
|
return mSelectedLanguageArray;
|
|
|
|
}
|
2010-01-30 04:09:49 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the currently selected input locale, or the display locale if no specific
|
|
|
|
* locale was selected for input.
|
|
|
|
* @return
|
|
|
|
*/
|
|
|
|
public Locale getInputLocale() {
|
|
|
|
if (getLocaleCount() == 0) return mDefaultInputLocale;
|
|
|
|
|
2010-11-11 07:03:19 +00:00
|
|
|
return mLocales.get(mCurrentIndex);
|
|
|
|
}
|
|
|
|
|
|
|
|
private int nextLocaleIndex() {
|
|
|
|
final int size = mLocales.size();
|
|
|
|
return (mCurrentIndex + 1) % size;
|
|
|
|
}
|
|
|
|
|
|
|
|
private int prevLocaleIndex() {
|
|
|
|
final int size = mLocales.size();
|
|
|
|
return (mCurrentIndex - 1 + size) % size;
|
2010-01-30 04:09:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the next input locale in the list. Wraps around to the beginning of the
|
|
|
|
* list if we're at the end of the list.
|
|
|
|
* @return
|
|
|
|
*/
|
|
|
|
public Locale getNextInputLocale() {
|
|
|
|
if (getLocaleCount() == 0) return mDefaultInputLocale;
|
2010-11-11 07:03:19 +00:00
|
|
|
return mLocales.get(nextLocaleIndex());
|
2010-01-30 04:09:49 +00:00
|
|
|
}
|
|
|
|
|
2010-05-03 18:14:31 +00:00
|
|
|
/**
|
|
|
|
* Sets the system locale (display UI) used for comparing with the input language.
|
|
|
|
* @param locale the locale of the system
|
|
|
|
*/
|
|
|
|
public void setSystemLocale(Locale locale) {
|
|
|
|
mSystemLocale = locale;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the system locale.
|
|
|
|
* @return the system locale
|
|
|
|
*/
|
|
|
|
public Locale getSystemLocale() {
|
|
|
|
return mSystemLocale;
|
|
|
|
}
|
|
|
|
|
2010-01-30 04:09:49 +00:00
|
|
|
/**
|
|
|
|
* Returns the previous input locale in the list. Wraps around to the end of the
|
|
|
|
* list if we're at the beginning of the list.
|
|
|
|
* @return
|
|
|
|
*/
|
|
|
|
public Locale getPrevInputLocale() {
|
|
|
|
if (getLocaleCount() == 0) return mDefaultInputLocale;
|
2010-11-11 07:03:19 +00:00
|
|
|
return mLocales.get(prevLocaleIndex());
|
2010-01-30 04:09:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public void reset() {
|
|
|
|
mCurrentIndex = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void next() {
|
2010-11-11 07:03:19 +00:00
|
|
|
mCurrentIndex = nextLocaleIndex();
|
2010-01-30 04:09:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public void prev() {
|
2010-11-11 07:03:19 +00:00
|
|
|
mCurrentIndex = prevLocaleIndex();
|
2010-01-30 04:09:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public void persist() {
|
|
|
|
SharedPreferences sp = PreferenceManager.getDefaultSharedPreferences(mIme);
|
|
|
|
Editor editor = sp.edit();
|
|
|
|
editor.putString(LatinIME.PREF_INPUT_LANGUAGE, getInputLanguage());
|
2010-09-12 12:05:25 +00:00
|
|
|
SharedPreferencesCompat.apply(editor);
|
2010-01-30 04:09:49 +00:00
|
|
|
}
|
|
|
|
}
|