Display the language name on the spacebar if the full display locale name is too longer than the space bar

Bug: 4329512
Change-Id: I477684747bf9e70a6909c25877fbe9e622571fd4
This commit is contained in:
satok 2011-04-25 20:55:58 +09:00
parent 9d4aadbe24
commit cae6b1060e
2 changed files with 19 additions and 12 deletions

View file

@ -194,8 +194,7 @@ public class LatinKeyboard extends Keyboard {
// Layout local language name and left and right arrow on spacebar. // Layout local language name and left and right arrow on spacebar.
private static String layoutSpacebar(Paint paint, Locale locale, Drawable lArrow, private static String layoutSpacebar(Paint paint, Locale locale, Drawable lArrow,
Drawable rArrow, int width, int height, float origTextSize, Drawable rArrow, int width, int height, float origTextSize) {
boolean allowVariableTextSize) {
final float arrowWidth = lArrow.getIntrinsicWidth(); final float arrowWidth = lArrow.getIntrinsicWidth();
final float arrowHeight = lArrow.getIntrinsicHeight(); final float arrowHeight = lArrow.getIntrinsicHeight();
final float maxTextWidth = width - (arrowWidth + arrowWidth); final float maxTextWidth = width - (arrowWidth + arrowWidth);
@ -206,17 +205,23 @@ public class LatinKeyboard extends Keyboard {
int textWidth = getTextWidth(paint, language, origTextSize, bounds); int textWidth = getTextWidth(paint, language, origTextSize, bounds);
// Assuming text width and text size are proportional to each other. // Assuming text width and text size are proportional to each other.
float textSize = origTextSize * Math.min(maxTextWidth / textWidth, 1.0f); float textSize = origTextSize * Math.min(maxTextWidth / textWidth, 1.0f);
// allow variable text size
textWidth = getTextWidth(paint, language, textSize, bounds);
// If text size goes too small or text does not fit, use middle or short name
final boolean useMiddleName = (textSize / origTextSize < MINIMUM_SCALE_OF_LANGUAGE_NAME)
|| (textWidth > maxTextWidth);
final boolean useShortName; final boolean useShortName;
if (allowVariableTextSize) { if (useMiddleName) {
textWidth = getTextWidth(paint, language, textSize, bounds); language = SubtypeSwitcher.getMiddleDisplayLanguage(locale);
// If text size goes too small or text does not fit, use short name textWidth = getTextWidth(paint, language, origTextSize, bounds);
useShortName = textSize / origTextSize < MINIMUM_SCALE_OF_LANGUAGE_NAME textSize = origTextSize * Math.min(maxTextWidth / textWidth, 1.0f);
|| textWidth > maxTextWidth; useShortName = (textSize / origTextSize < MINIMUM_SCALE_OF_LANGUAGE_NAME)
|| (textWidth > maxTextWidth);
} else { } else {
useShortName = textWidth > maxTextWidth; useShortName = false;
textSize = origTextSize;
} }
if (useShortName) { if (useShortName) {
language = SubtypeSwitcher.getShortDisplayLanguage(locale); language = SubtypeSwitcher.getShortDisplayLanguage(locale);
textWidth = getTextWidth(paint, language, origTextSize, bounds); textWidth = getTextWidth(paint, language, origTextSize, bounds);
@ -276,11 +281,9 @@ public class LatinKeyboard extends Keyboard {
defaultTextSize = 14; defaultTextSize = 14;
} }
final boolean allowVariableTextSize = true;
final String language = layoutSpacebar(paint, inputLocale, final String language = layoutSpacebar(paint, inputLocale,
mButtonArrowLeftIcon, mButtonArrowRightIcon, width, height, mButtonArrowLeftIcon, mButtonArrowRightIcon, width, height,
getTextSizeFromTheme(mContext.getTheme(), textStyle, defaultTextSize), getTextSizeFromTheme(mContext.getTheme(), textStyle, defaultTextSize));
allowVariableTextSize);
// Draw language text with shadow // Draw language text with shadow
// In case there is no space icon, we will place the language text at the center of // In case there is no space icon, we will place the language text at the center of

View file

@ -607,6 +607,10 @@ public class SubtypeSwitcher {
return toTitleCase(locale.getDisplayLanguage(locale)); return toTitleCase(locale.getDisplayLanguage(locale));
} }
public static String getMiddleDisplayLanguage(Locale locale) {
return toTitleCase(locale.getDisplayLanguage(new Locale(locale.getLanguage())));
}
public static String getShortDisplayLanguage(Locale locale) { public static String getShortDisplayLanguage(Locale locale) {
return toTitleCase(locale.getLanguage()); return toTitleCase(locale.getLanguage());
} }