diff options
author | Android (Google) Code Review <android-gerrit@google.com> | 2009-06-17 10:08:23 -0700 |
---|---|---|
committer | Android (Google) Code Review <android-gerrit@google.com> | 2009-06-17 10:08:23 -0700 |
commit | f11d7458ea2f52b3c4afad495274167b862e7a4c (patch) | |
tree | 08c0c94a4f8256f82e23a78adc5ebb57a18be725 /src/com | |
parent | 19e134e494a561324394fcc030ee8e30bb41c614 (diff) | |
parent | ec598cb91c02c035d19ccd8a9f17e2bf8da9da5a (diff) | |
download | packages_apps_settings-f11d7458ea2f52b3c4afad495274167b862e7a4c.zip packages_apps_settings-f11d7458ea2f52b3c4afad495274167b862e7a4c.tar.gz packages_apps_settings-f11d7458ea2f52b3c4afad495274167b862e7a4c.tar.bz2 |
Merge change 4378 into donut
* changes:
Make the Quick Launch settings show localized application names.
Diffstat (limited to 'src/com')
-rw-r--r-- | src/com/android/settings/quicklaunch/QuickLaunchSettings.java | 26 |
1 files changed, 25 insertions, 1 deletions
diff --git a/src/com/android/settings/quicklaunch/QuickLaunchSettings.java b/src/com/android/settings/quicklaunch/QuickLaunchSettings.java index 4d44524..40316b5 100644 --- a/src/com/android/settings/quicklaunch/QuickLaunchSettings.java +++ b/src/com/android/settings/quicklaunch/QuickLaunchSettings.java @@ -20,6 +20,8 @@ import android.app.AlertDialog; import android.app.Dialog; import android.content.DialogInterface; import android.content.Intent; +import android.content.pm.PackageManager; +import android.content.pm.ResolveInfo; import android.database.ContentObserver; import android.database.Cursor; import android.os.Bundle; @@ -39,6 +41,8 @@ import android.widget.AdapterView; import com.android.settings.R; +import java.net.URISyntaxException; + /** * Settings activity for quick launch. * <p> @@ -300,7 +304,27 @@ public class QuickLaunchSettings extends PreferenceActivity implements if (shortcut == 0) continue; ShortcutPreference pref = getOrCreatePreference(shortcut); - pref.setTitle(Bookmarks.getTitle(this, c)); + CharSequence title = Bookmarks.getTitle(this, c); + + /* + * The title retrieved from Bookmarks.getTitle() will be in + * the original boot locale, not the current locale. + * Try to look up a localized title from the PackageManager. + */ + int intentColumn = c.getColumnIndex(Bookmarks.INTENT); + String intentUri = c.getString(intentColumn); + PackageManager packageManager = getPackageManager(); + try { + Intent intent = Intent.getIntent(intentUri); + ResolveInfo info = packageManager.resolveActivity(intent, 0); + if (info != null) { + title = info.loadLabel(packageManager); + } + } catch (URISyntaxException e) { + // Just use the non-localized title, then. + } + + pref.setTitle(title); pref.setSummary(getString(R.string.quick_launch_shortcut, String.valueOf(shortcut))); pref.setHasBookmark(true); |