Merge "Fix b/266795925: Different font size in IW language."
This commit is contained in:
committed by
Android (Google) Code Review
commit
2646bc2f07
@@ -30,6 +30,7 @@ import com.android.settings.R;
|
|||||||
import com.android.settings.core.BasePreferenceController;
|
import com.android.settings.core.BasePreferenceController;
|
||||||
import com.android.settingslib.utils.StringUtil;
|
import com.android.settingslib.utils.StringUtil;
|
||||||
|
|
||||||
|
import java.util.Locale;
|
||||||
import java.util.regex.Matcher;
|
import java.util.regex.Matcher;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
@@ -39,6 +40,7 @@ public class ScreenOnTimeController extends BasePreferenceController {
|
|||||||
private static final String ROOT_PREFERENCE_KEY = "screen_on_time_category";
|
private static final String ROOT_PREFERENCE_KEY = "screen_on_time_category";
|
||||||
private static final String SCREEN_ON_TIME_TEXT_PREFERENCE_KEY = "screen_on_time_text";
|
private static final String SCREEN_ON_TIME_TEXT_PREFERENCE_KEY = "screen_on_time_text";
|
||||||
private static final Pattern NUMBER_PATTERN = Pattern.compile("[\\d]*[\\.,]?[\\d]+");
|
private static final Pattern NUMBER_PATTERN = Pattern.compile("[\\d]*[\\.,]?[\\d]+");
|
||||||
|
private static final Locale IW_LOCALE = new Locale("iw");
|
||||||
|
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
Context mPrefContext;
|
Context mPrefContext;
|
||||||
@@ -89,16 +91,22 @@ public class ScreenOnTimeController extends BasePreferenceController {
|
|||||||
final CharSequence timeSequence =
|
final CharSequence timeSequence =
|
||||||
StringUtil.formatElapsedTime(mPrefContext, (double) screenOnTime,
|
StringUtil.formatElapsedTime(mPrefContext, (double) screenOnTime,
|
||||||
/*withSeconds=*/ false, /*collapseTimeUnit=*/ false);
|
/*withSeconds=*/ false, /*collapseTimeUnit=*/ false);
|
||||||
mScreenOnTimeTextPreference.setText(enlargeFontOfNumber(removeCommas(timeSequence)));
|
mScreenOnTimeTextPreference.setText(
|
||||||
|
enlargeFontOfNumberIfNeeded(mPrefContext, removeCommas(timeSequence)));
|
||||||
mScreenOnTimeTextPreference.setVisible(true);
|
mScreenOnTimeTextPreference.setVisible(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
static CharSequence enlargeFontOfNumber(CharSequence text) {
|
static CharSequence enlargeFontOfNumberIfNeeded(Context context, CharSequence text) {
|
||||||
if (TextUtils.isEmpty(text)) {
|
if (TextUtils.isEmpty(text)) {
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
final Locale locale = context.getResources().getConfiguration().getLocales().get(0);
|
||||||
|
if (locale != null && IW_LOCALE.getLanguage().equals(locale.getLanguage())) {
|
||||||
|
return text;
|
||||||
|
}
|
||||||
|
|
||||||
final SpannableString spannableText = new SpannableString(text);
|
final SpannableString spannableText = new SpannableString(text);
|
||||||
final Matcher matcher = NUMBER_PATTERN.matcher(text);
|
final Matcher matcher = NUMBER_PATTERN.matcher(text);
|
||||||
while (matcher.find()) {
|
while (matcher.find()) {
|
||||||
|
Reference in New Issue
Block a user