diff options
author | Amith Yamasani <yamasani@google.com> | 2010-11-04 09:59:44 -0700 |
---|---|---|
committer | Amith Yamasani <yamasani@google.com> | 2010-11-04 12:52:53 -0700 |
commit | 5203bdffe6ce2b829d0fab8c7691fa92aca6e972 (patch) | |
tree | 21f56cf20cf29975039b9fbac52f732bb44ef8d2 /src | |
parent | 96938b29bbce9a70627e24d5e84069ecea200ceb (diff) | |
download | packages_apps_settings-5203bdffe6ce2b829d0fab8c7691fa92aca6e972.zip packages_apps_settings-5203bdffe6ce2b829d0fab8c7691fa92aca6e972.tar.gz packages_apps_settings-5203bdffe6ce2b829d0fab8c7691fa92aca6e972.tar.bz2 |
Create activity wrappers for settings launchable through intents or shortcuts.
Meta data specifies the fragment class and top-level header that it belongs to.
Bug: 3127704
Diffstat (limited to 'src')
-rw-r--r-- | src/com/android/settings/Settings.java | 84 | ||||
-rw-r--r-- | src/com/android/settings/applications/ManageApplications.java | 9 |
2 files changed, 87 insertions, 6 deletions
diff --git a/src/com/android/settings/Settings.java b/src/com/android/settings/Settings.java index 3a6e6d8..bec8241 100644 --- a/src/com/android/settings/Settings.java +++ b/src/com/android/settings/Settings.java @@ -17,9 +17,13 @@ package com.android.settings; import android.content.Intent; +import android.content.pm.ActivityInfo; +import android.content.pm.PackageManager; +import android.content.pm.PackageManager.NameNotFoundException; import android.os.Bundle; import android.preference.PreferenceActivity; +import java.util.HashMap; import java.util.List; /** @@ -27,8 +31,36 @@ import java.util.List; */ public class Settings extends PreferenceActivity { + private static final String META_DATA_KEY_HEADER_ID = + "com.android.settings.TOP_LEVEL_HEADER_ID"; + private static final String META_DATA_KEY_FRAGMENT_CLASS = + "com.android.settings.FRAGMENT_CLASS"; + + private String mFragmentClass; + private int mTopLevelHeaderId; + // TODO: Update Call Settings based on airplane mode state. + protected HashMap<Integer, Integer> mHeaderIndexMap = new HashMap<Integer, Integer>(); + + @Override + protected void onCreate(Bundle savedInstanceState) { + getMetaData(); + super.onCreate(savedInstanceState); + + // TODO: Do this only if 2-pane mode + highlightHeader(); + } + + private void highlightHeader() { + if (mTopLevelHeaderId != 0) { + Integer index = mHeaderIndexMap.get(mTopLevelHeaderId); + if (index != null) { + getListView().setItemChecked(index, true); + } + } + } + @Override public Intent getIntent() { String startingFragment = getStartingFragmentClass(super.getIntent()); @@ -52,7 +84,9 @@ public class Settings extends PreferenceActivity { * Checks if the component name in the intent is different from the Settings class and * returns the class name to load as a fragment. */ - private String getStartingFragmentClass(Intent intent) { + protected String getStartingFragmentClass(Intent intent) { + if (mFragmentClass != null) return mFragmentClass; + String intentClass = intent.getComponent().getClassName(); if (intentClass.equals(getClass().getName())) return null; @@ -96,7 +130,8 @@ public class Settings extends PreferenceActivity { int i = 0; while (i < target.size()) { Header header = target.get(i); - long id = header.id; + // Ids are integers, so downcasting + int id = (int) header.id; if (id == R.id.dock_settings) { if (!needsDockSettings()) target.remove(header); @@ -106,12 +141,55 @@ public class Settings extends PreferenceActivity { if (!Utils.isVoiceCapable(this)) target.remove(header); } - if (target.get(i) == header) + // Increment if the current one wasn't removed by the Utils code. + if (target.get(i) == header) { + mHeaderIndexMap.put(id, i); i++; + } } } private boolean needsDockSettings() { return getResources().getBoolean(R.bool.has_dock_settings); } + + private void getMetaData() { + try { + ActivityInfo ai = getPackageManager().getActivityInfo(getComponentName(), + PackageManager.GET_META_DATA); + if (ai == null || ai.metaData == null) return; + mTopLevelHeaderId = ai.metaData.getInt(META_DATA_KEY_HEADER_ID); + mFragmentClass = ai.metaData.getString(META_DATA_KEY_FRAGMENT_CLASS); + } catch (NameNotFoundException nnfe) { + } + } + + /* + * Settings subclasses for launching independently. + */ + + public static class BluetoothSettingsActivity extends Settings { } + public static class WirelessSettingsActivity extends Settings { } + public static class TetherSettingsActivity extends Settings { } + public static class VpnSettingsActivity extends Settings { } + public static class DateTimeSettingsActivity extends Settings { } + public static class StorageSettingsActivity extends Settings { } + public static class WifiSettingsActivity extends Settings { } + public static class InputMethodAndLanguageSettingsActivity extends Settings { } + public static class InputMethodAndSubtypeEnablerActivity extends Settings { } + public static class LocalePickerActivity extends Settings { } + public static class UserDictionarySettingsActivity extends Settings { } + public static class SoundSettingsActivity extends Settings { } + public static class DisplaySettingsActivity extends Settings { } + public static class DeviceInfoSettingsActivity extends Settings { } + public static class ApplicationSettingsActivity extends Settings { } + public static class ManageApplicationsActivity extends Settings { } + public static class StorageUseActivity extends Settings { } + public static class DevelopmentSettingsActivity extends Settings { } + public static class AccessibilitySettingsActivity extends Settings { } + public static class SecuritySettingsActivity extends Settings { } + public static class PrivacySettingsActivity extends Settings { } + public static class DockSettingsActivity extends Settings { } + public static class RunningServicesActivity extends Settings { } + public static class VoiceInputOutputSettingsActivity extends Settings { } } diff --git a/src/com/android/settings/applications/ManageApplications.java b/src/com/android/settings/applications/ManageApplications.java index 20cf2f9..94283ee 100644 --- a/src/com/android/settings/applications/ManageApplications.java +++ b/src/com/android/settings/applications/ManageApplications.java @@ -16,9 +16,12 @@ package com.android.settings.applications; -import com.android.internal.content.PackageHelper; import com.android.settings.R; + +import com.android.internal.content.PackageHelper; import com.android.settings.applications.ApplicationsState.AppEntry; +import com.android.settings.Settings.RunningServicesActivity; +import com.android.settings.Settings.StorageUseActivity; import android.app.Fragment; import android.content.Context; @@ -519,9 +522,9 @@ public class ManageApplications extends Fragment implements if (className == null) { className = intent.getComponent().getClassName(); } - if (className.equals("com.android.settings.RunningServices")) { + if (className.equals(RunningServicesActivity.class.getName())) { defaultTabTag = TAB_RUNNING; - } else if (className.equals("com.android.settings.applications.StorageUse") + } else if (className.equals(StorageUseActivity.class.getName()) || action.equals(Intent.ACTION_MANAGE_PACKAGE_STORAGE)) { mSortOrder = SORT_ORDER_SIZE; mFilterApps = FILTER_APPS_ALL; |