diff options
Diffstat (limited to 'src/com/android/settings/LocationSettings.java')
-rw-r--r-- | src/com/android/settings/LocationSettings.java | 110 |
1 files changed, 77 insertions, 33 deletions
diff --git a/src/com/android/settings/LocationSettings.java b/src/com/android/settings/LocationSettings.java index 5301db1..d5c4d9f 100644 --- a/src/com/android/settings/LocationSettings.java +++ b/src/com/android/settings/LocationSettings.java @@ -19,14 +19,18 @@ package com.android.settings; import android.content.ContentQueryMap; import android.content.ContentResolver; +import android.content.Context; import android.content.Intent; import android.database.Cursor; import android.location.LocationManager; import android.preference.CheckBoxPreference; import android.preference.Preference; -import android.preference.Preference.OnPreferenceChangeListener; import android.preference.PreferenceScreen; +import android.preference.SwitchPreference; import android.provider.Settings; +import android.util.AttributeSet; +import android.view.View; +import android.widget.TextView; import java.util.Observable; import java.util.Observer; @@ -35,18 +39,18 @@ import java.util.Observer; * Gesture lock pattern settings. */ public class LocationSettings extends SettingsPreferenceFragment - implements OnPreferenceChangeListener { + implements Preference.OnPreferenceChangeListener { // Location Settings + private static final String KEY_LOCATION_TOGGLE = "location_toggle"; private static final String KEY_LOCATION_NETWORK = "location_network"; private static final String KEY_LOCATION_GPS = "location_gps"; private static final String KEY_ASSISTED_GPS = "assisted_gps"; - private static final String KEY_USE_LOCATION = "location_use_for_services"; private CheckBoxPreference mNetwork; private CheckBoxPreference mGps; private CheckBoxPreference mAssistedGps; - private CheckBoxPreference mUseLocation; + private SwitchPreference mLocationAccess; // These provide support for receiving notification when Location Manager settings change. // This is necessary because the Network Location Provider can change settings @@ -82,24 +86,12 @@ public class LocationSettings extends SettingsPreferenceFragment addPreferencesFromResource(R.xml.location_settings); root = getPreferenceScreen(); + mLocationAccess = (SwitchPreference) root.findPreference(KEY_LOCATION_TOGGLE); mNetwork = (CheckBoxPreference) root.findPreference(KEY_LOCATION_NETWORK); mGps = (CheckBoxPreference) root.findPreference(KEY_LOCATION_GPS); mAssistedGps = (CheckBoxPreference) root.findPreference(KEY_ASSISTED_GPS); - if (GoogleLocationSettingHelper.isAvailable(getActivity())) { - // GSF present, Add setting for 'Use My Location' - CheckBoxPreference useLocation = new CheckBoxPreference(getActivity()); - useLocation.setKey(KEY_USE_LOCATION); - useLocation.setTitle(R.string.use_location_title); - useLocation.setSummary(R.string.use_location_summary); - useLocation.setChecked( - GoogleLocationSettingHelper.getUseLocationForServices(getActivity()) - == GoogleLocationSettingHelper.USE_LOCATION_FOR_SERVICES_ON); - useLocation.setPersistent(false); - useLocation.setOnPreferenceChangeListener(this); - getPreferenceScreen().addPreference(useLocation); - mUseLocation = useLocation; - } + mLocationAccess.setOnPreferenceChangeListener(this); return root; } @@ -125,19 +117,19 @@ public class LocationSettings extends SettingsPreferenceFragment @Override public boolean onPreferenceTreeClick(PreferenceScreen preferenceScreen, Preference preference) { - + final ContentResolver cr = getContentResolver(); if (preference == mNetwork) { - Settings.Secure.setLocationProviderEnabled(getContentResolver(), + Settings.Secure.setLocationProviderEnabled(cr, LocationManager.NETWORK_PROVIDER, mNetwork.isChecked()); } else if (preference == mGps) { boolean enabled = mGps.isChecked(); - Settings.Secure.setLocationProviderEnabled(getContentResolver(), + Settings.Secure.setLocationProviderEnabled(cr, LocationManager.GPS_PROVIDER, enabled); if (mAssistedGps != null) { mAssistedGps.setEnabled(enabled); } } else if (preference == mAssistedGps) { - Settings.Secure.putInt(getContentResolver(), Settings.Secure.ASSISTED_GPS_ENABLED, + Settings.Secure.putInt(cr, Settings.Secure.ASSISTED_GPS_ENABLED, mAssistedGps.isChecked() ? 1 : 0); } else { // If we didn't handle it, let preferences handle it. @@ -154,9 +146,11 @@ public class LocationSettings extends SettingsPreferenceFragment ContentResolver res = getContentResolver(); boolean gpsEnabled = Settings.Secure.isLocationProviderEnabled( res, LocationManager.GPS_PROVIDER); - mNetwork.setChecked(Settings.Secure.isLocationProviderEnabled( - res, LocationManager.NETWORK_PROVIDER)); + boolean networkEnabled = Settings.Secure.isLocationProviderEnabled( + res, LocationManager.NETWORK_PROVIDER); mGps.setChecked(gpsEnabled); + mNetwork.setChecked(networkEnabled); + mLocationAccess.setChecked(gpsEnabled || networkEnabled); if (mAssistedGps != null) { mAssistedGps.setChecked(Settings.Secure.getInt(res, Settings.Secure.ASSISTED_GPS_ENABLED, 2) == 1); @@ -173,16 +167,66 @@ public class LocationSettings extends SettingsPreferenceFragment createPreferenceHierarchy(); } - public boolean onPreferenceChange(Preference preference, Object value) { - if (preference == mUseLocation) { - boolean newValue = (value == null ? false : (Boolean) value); - GoogleLocationSettingHelper.setUseLocationForServices(getActivity(), newValue); - // We don't want to change the value immediately here, since the user may click - // disagree in the dialog that pops up. When the activity we just launched exits, this - // activity will be restated and the new value re-read, so the checkbox will get its - // new value then. - return false; + /** Enable or disable all providers when the master toggle is changed. */ + private void onToggleLocationAccess(boolean checked) { + final ContentResolver cr = getContentResolver(); + Settings.Secure.setLocationProviderEnabled(cr, + LocationManager.GPS_PROVIDER, checked); + Settings.Secure.setLocationProviderEnabled(cr, + LocationManager.NETWORK_PROVIDER, checked); + updateLocationToggles(); + } + + @Override + public boolean onPreferenceChange(Preference pref, Object newValue) { + if (pref.getKey().equals(KEY_LOCATION_TOGGLE)) { + onToggleLocationAccess((Boolean) newValue); } return true; } + +} + +class WrappingSwitchPreference extends SwitchPreference { + + public WrappingSwitchPreference(Context context, AttributeSet attrs, int defStyle) { + super(context, attrs, defStyle); + } + + public WrappingSwitchPreference(Context context, AttributeSet attrs) { + super(context, attrs); + } + + @Override + protected void onBindView(View view) { + super.onBindView(view); + + TextView title = (TextView) view.findViewById(android.R.id.title); + if (title != null) { + title.setSingleLine(false); + title.setMaxLines(3); + } + } +} + +class WrappingCheckBoxPreference extends CheckBoxPreference { + + public WrappingCheckBoxPreference(Context context, AttributeSet attrs, int defStyle) { + super(context, attrs, defStyle); + } + + public WrappingCheckBoxPreference(Context context, AttributeSet attrs) { + super(context, attrs); + } + + @Override + protected void onBindView(View view) { + super.onBindView(view); + + TextView title = (TextView) view.findViewById(android.R.id.title); + if (title != null) { + title.setSingleLine(false); + title.setMaxLines(3); + } + } } |