summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorAndroid (Google) Code Review <android-gerrit@google.com>2009-06-17 10:08:23 -0700
committerAndroid (Google) Code Review <android-gerrit@google.com>2009-06-17 10:08:23 -0700
commitf11d7458ea2f52b3c4afad495274167b862e7a4c (patch)
tree08c0c94a4f8256f82e23a78adc5ebb57a18be725 /src
parent19e134e494a561324394fcc030ee8e30bb41c614 (diff)
parentec598cb91c02c035d19ccd8a9f17e2bf8da9da5a (diff)
downloadpackages_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')
-rw-r--r--src/com/android/settings/quicklaunch/QuickLaunchSettings.java26
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);