am f06d8698
: Add setting for allowing Google to use location for better search results.
Merge commit 'f06d8698a4a2de1973a25df0c6563bdfcba4eb03' * commit 'f06d8698a4a2de1973a25df0c6563bdfcba4eb03': Add setting for allowing Google to use location for better search results.
This commit is contained in:
committed by
The Android Open Source Project
commit
bfbb159a2b
@@ -1130,7 +1130,7 @@
|
|||||||
<string name="network_settings_summary">Set options for roaming, networks, APNs</string>
|
<string name="network_settings_summary">Set options for roaming, networks, APNs</string>
|
||||||
|
|
||||||
<!-- Security & location settings screen, section header for settings relating to location -->
|
<!-- Security & location settings screen, section header for settings relating to location -->
|
||||||
<string name="location_title">My Location sources</string>
|
<string name="location_title">My Location</string>
|
||||||
<!-- Security & location settings screen, setting check box label if the user wants to use wireless network-based positioning (cell ID, wifi, etc.) -->
|
<!-- Security & location settings screen, setting check box label if the user wants to use wireless network-based positioning (cell ID, wifi, etc.) -->
|
||||||
<string name="location_network_based">Use wireless networks</string>
|
<string name="location_network_based">Use wireless networks</string>
|
||||||
<!-- Security & location settings screen, setting summary when Use wireless networks check box is clear -->
|
<!-- Security & location settings screen, setting summary when Use wireless networks check box is clear -->
|
||||||
@@ -1143,9 +1143,19 @@
|
|||||||
<string name="location_street_level">When locating, accurate to street level (deselect to conserve battery)</string>
|
<string name="location_street_level">When locating, accurate to street level (deselect to conserve battery)</string>
|
||||||
<!-- Security & location settings screen, setting summary when Enable GPS satellites check box is clear -->
|
<!-- Security & location settings screen, setting summary when Enable GPS satellites check box is clear -->
|
||||||
<string name="location_gps_disabled">Locate to street-level (requires more battery plus view of sky)</string>
|
<string name="location_gps_disabled">Locate to street-level (requires more battery plus view of sky)</string>
|
||||||
<!-- Title of warning dialog to user that location information will be logged -->
|
<!-- Setting title for allow sending location to google -->
|
||||||
|
<string name="use_location_title">Share with Google</string>
|
||||||
|
<!-- Title of dialog to user requesting use of location information to improve services -->
|
||||||
|
<string name="use_location_summary">Allow Google to use location for improved search results and other services</string>
|
||||||
|
<!-- Message of dialog to user requesting use of location information -->
|
||||||
|
<string name="use_location_warning_message">Allow Google to use location for improved search results and other services</string>
|
||||||
|
<!-- Agree -->
|
||||||
|
<string name="agree">Agree</string>
|
||||||
|
<!-- Disagree -->
|
||||||
|
<string name="disagree">Disagree</string>
|
||||||
|
|
||||||
<!-- About -->
|
|
||||||
|
<!-- About --> <skip />
|
||||||
<!-- Main settings screen, setting title for the user to go into the About phone screen -->
|
<!-- Main settings screen, setting title for the user to go into the About phone screen -->
|
||||||
<string name="about_settings">About phone</string>
|
<string name="about_settings">About phone</string>
|
||||||
<!-- Main settings screen, setting summary for the user to go into the About phone screen-->
|
<!-- Main settings screen, setting summary for the user to go into the About phone screen-->
|
||||||
|
@@ -17,6 +17,7 @@
|
|||||||
<PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android">
|
<PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android">
|
||||||
|
|
||||||
<PreferenceCategory
|
<PreferenceCategory
|
||||||
|
android:key="location_category"
|
||||||
android:title="@string/location_title">
|
android:title="@string/location_title">
|
||||||
|
|
||||||
<CheckBoxPreference
|
<CheckBoxPreference
|
||||||
@@ -31,6 +32,12 @@
|
|||||||
android:summaryOn="@string/location_street_level"
|
android:summaryOn="@string/location_street_level"
|
||||||
android:summaryOff="@string/location_gps_disabled"/>
|
android:summaryOff="@string/location_gps_disabled"/>
|
||||||
|
|
||||||
|
<CheckBoxPreference
|
||||||
|
android:key="use_location"
|
||||||
|
android:title="@string/use_location_title"
|
||||||
|
android:persistent="false"
|
||||||
|
android:summary="@string/use_location_summary"/>
|
||||||
|
|
||||||
</PreferenceCategory>
|
</PreferenceCategory>
|
||||||
|
|
||||||
</PreferenceScreen>
|
</PreferenceScreen>
|
||||||
|
@@ -18,10 +18,14 @@ package com.android.settings;
|
|||||||
|
|
||||||
|
|
||||||
import android.app.Activity;
|
import android.app.Activity;
|
||||||
|
import android.app.AlertDialog;
|
||||||
|
import android.app.Dialog;
|
||||||
import android.content.ContentQueryMap;
|
import android.content.ContentQueryMap;
|
||||||
|
import android.content.ContentResolver;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.content.DialogInterface;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.SharedPreferences;
|
import android.content.pm.PackageManager.NameNotFoundException;
|
||||||
import android.database.Cursor;
|
import android.database.Cursor;
|
||||||
import android.location.LocationManager;
|
import android.location.LocationManager;
|
||||||
import android.net.vpn.VpnManager;
|
import android.net.vpn.VpnManager;
|
||||||
@@ -30,20 +34,22 @@ import android.preference.CheckBoxPreference;
|
|||||||
import android.preference.Preference;
|
import android.preference.Preference;
|
||||||
import android.preference.PreferenceActivity;
|
import android.preference.PreferenceActivity;
|
||||||
import android.preference.PreferenceCategory;
|
import android.preference.PreferenceCategory;
|
||||||
|
import android.preference.PreferenceGroup;
|
||||||
import android.preference.PreferenceScreen;
|
import android.preference.PreferenceScreen;
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
import android.util.Config;
|
import android.text.method.LinkMovementMethod;
|
||||||
import android.util.Log;
|
import android.widget.TextView;
|
||||||
|
|
||||||
|
import com.android.internal.widget.LockPatternUtils;
|
||||||
|
|
||||||
import java.util.Observable;
|
import java.util.Observable;
|
||||||
import java.util.Observer;
|
import java.util.Observer;
|
||||||
|
|
||||||
import com.android.internal.widget.LockPatternUtils;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gesture lock pattern settings.
|
* Gesture lock pattern settings.
|
||||||
*/
|
*/
|
||||||
public class SecuritySettings extends PreferenceActivity {
|
public class SecuritySettings extends PreferenceActivity implements
|
||||||
|
DialogInterface.OnDismissListener, DialogInterface.OnClickListener {
|
||||||
|
|
||||||
// Lock Settings
|
// Lock Settings
|
||||||
|
|
||||||
@@ -61,10 +67,18 @@ public class SecuritySettings extends PreferenceActivity {
|
|||||||
private CheckBoxPreference mShowPassword;
|
private CheckBoxPreference mShowPassword;
|
||||||
|
|
||||||
// Location Settings
|
// Location Settings
|
||||||
|
private static final String LOCATION_CATEGORY = "location_category";
|
||||||
private static final String LOCATION_NETWORK = "location_network";
|
private static final String LOCATION_NETWORK = "location_network";
|
||||||
private static final String LOCATION_GPS = "location_gps";
|
private static final String LOCATION_GPS = "location_gps";
|
||||||
|
|
||||||
|
// Vendor specific
|
||||||
|
private static final String GSETTINGS_PROVIDER = "com.google.android.providers.settings";
|
||||||
|
private static final String USE_LOCATION = "use_location";
|
||||||
|
private static final String KEY_DONE_USE_LOCATION = "doneLocation";
|
||||||
|
private CheckBoxPreference mUseLocation;
|
||||||
|
private boolean mOkClicked;
|
||||||
|
private Dialog mUseLocationDialog;
|
||||||
|
|
||||||
private CheckBoxPreference mNetwork;
|
private CheckBoxPreference mNetwork;
|
||||||
private CheckBoxPreference mGps;
|
private CheckBoxPreference mGps;
|
||||||
|
|
||||||
@@ -89,6 +103,17 @@ public class SecuritySettings extends PreferenceActivity {
|
|||||||
|
|
||||||
mNetwork = (CheckBoxPreference) getPreferenceScreen().findPreference(LOCATION_NETWORK);
|
mNetwork = (CheckBoxPreference) getPreferenceScreen().findPreference(LOCATION_NETWORK);
|
||||||
mGps = (CheckBoxPreference) getPreferenceScreen().findPreference(LOCATION_GPS);
|
mGps = (CheckBoxPreference) getPreferenceScreen().findPreference(LOCATION_GPS);
|
||||||
|
mUseLocation = (CheckBoxPreference) getPreferenceScreen().findPreference(USE_LOCATION);
|
||||||
|
|
||||||
|
// Vendor specific
|
||||||
|
try {
|
||||||
|
if (mUseLocation != null
|
||||||
|
&& getPackageManager().getPackageInfo(GSETTINGS_PROVIDER, 0) == null) {
|
||||||
|
((PreferenceGroup)findPreference(LOCATION_CATEGORY))
|
||||||
|
.removePreference(mUseLocation);
|
||||||
|
}
|
||||||
|
} catch (NameNotFoundException nnfe) {
|
||||||
|
}
|
||||||
updateToggles();
|
updateToggles();
|
||||||
|
|
||||||
// listen for Location Manager settings changes
|
// listen for Location Manager settings changes
|
||||||
@@ -98,6 +123,11 @@ public class SecuritySettings extends PreferenceActivity {
|
|||||||
null);
|
null);
|
||||||
mContentQueryMap = new ContentQueryMap(settingsCursor, Settings.System.NAME, true, null);
|
mContentQueryMap = new ContentQueryMap(settingsCursor, Settings.System.NAME, true, null);
|
||||||
mContentQueryMap.addObserver(new SettingsObserver());
|
mContentQueryMap.addObserver(new SettingsObserver());
|
||||||
|
boolean doneUseLocation = savedInstanceState != null
|
||||||
|
&& savedInstanceState.getBoolean(KEY_DONE_USE_LOCATION, true);
|
||||||
|
if (getIntent().getBooleanExtra("SHOW_USE_LOCATION", false) && !doneUseLocation) {
|
||||||
|
showUseLocationDialog(true);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private PreferenceScreen createPreferenceHierarchy() {
|
private PreferenceScreen createPreferenceHierarchy() {
|
||||||
@@ -198,6 +228,23 @@ public class SecuritySettings extends PreferenceActivity {
|
|||||||
Settings.System.TEXT_SHOW_PASSWORD, 1) != 0);
|
Settings.System.TEXT_SHOW_PASSWORD, 1) != 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onPause() {
|
||||||
|
if (mUseLocationDialog != null && mUseLocationDialog.isShowing()) {
|
||||||
|
mUseLocationDialog.dismiss();
|
||||||
|
}
|
||||||
|
mUseLocationDialog = null;
|
||||||
|
super.onPause();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onSaveInstanceState(Bundle icicle) {
|
||||||
|
if (mUseLocationDialog != null && mUseLocationDialog.isShowing()) {
|
||||||
|
icicle.putBoolean(KEY_DONE_USE_LOCATION, false);
|
||||||
|
}
|
||||||
|
super.onSaveInstanceState(icicle);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onPreferenceTreeClick(PreferenceScreen preferenceScreen,
|
public boolean onPreferenceTreeClick(PreferenceScreen preferenceScreen,
|
||||||
Preference preference) {
|
Preference preference) {
|
||||||
@@ -218,25 +265,84 @@ public class SecuritySettings extends PreferenceActivity {
|
|||||||
} else if (preference == mGps) {
|
} else if (preference == mGps) {
|
||||||
Settings.Secure.setLocationProviderEnabled(getContentResolver(),
|
Settings.Secure.setLocationProviderEnabled(getContentResolver(),
|
||||||
LocationManager.GPS_PROVIDER, mGps.isChecked());
|
LocationManager.GPS_PROVIDER, mGps.isChecked());
|
||||||
|
} else if (preference == mUseLocation) {
|
||||||
|
//normally called on the toggle click
|
||||||
|
if (mUseLocation.isChecked()) {
|
||||||
|
showUseLocationDialog(false);
|
||||||
|
} else {
|
||||||
|
updateUseLocation();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void showPrivacyPolicy() {
|
||||||
|
Intent intent = new Intent("android.settings.TERMS");
|
||||||
|
startActivity(intent);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void showUseLocationDialog(boolean force) {
|
||||||
|
// Show a warning to the user that location data will be shared
|
||||||
|
mOkClicked = false;
|
||||||
|
if (force) {
|
||||||
|
mUseLocation.setChecked(true);
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
Resources res = getResources();
|
||||||
|
CharSequence msg = new SpannableString(
|
||||||
|
res.getText(R.string.use_location_warning_message));
|
||||||
|
SpannableString spannable = (SpannableString) msg;
|
||||||
|
Annotation[] spans = spannable.getSpans(0, spannable.length(), Annotation.class);
|
||||||
|
if (spans != null && spans.length > 0) {
|
||||||
|
SpannableStringBuilder builder = new SpannableStringBuilder(spannable);
|
||||||
|
int start = spannable.getSpanStart(spans[0]);
|
||||||
|
int end = spannable.getSpanEnd(spans[0]);
|
||||||
|
ClickableSpan link = new ClickableSpan() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View view) {
|
||||||
|
showPrivacyPolicy();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
builder.setSpan(link, start, end, spannable.getSpanFlags(link));
|
||||||
|
msg = builder;
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
CharSequence msg = getResources().getText(R.string.use_location_warning_message);
|
||||||
|
mUseLocationDialog = new AlertDialog.Builder(this).setMessage(msg)
|
||||||
|
.setTitle(R.string.use_location_title)
|
||||||
|
.setIcon(android.R.drawable.ic_dialog_alert)
|
||||||
|
.setPositiveButton(R.string.agree, this)
|
||||||
|
.setNegativeButton(R.string.disagree, this)
|
||||||
|
.show();
|
||||||
|
((TextView)mUseLocationDialog.findViewById(android.R.id.message))
|
||||||
|
.setMovementMethod(LinkMovementMethod.getInstance());
|
||||||
|
mUseLocationDialog.setOnDismissListener(this);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Creates toggles for each available location provider
|
* Creates toggles for each available location provider
|
||||||
*/
|
*/
|
||||||
private void updateToggles() {
|
private void updateToggles() {
|
||||||
|
ContentResolver res = getContentResolver();
|
||||||
mNetwork.setChecked(Settings.Secure.isLocationProviderEnabled(
|
mNetwork.setChecked(Settings.Secure.isLocationProviderEnabled(
|
||||||
getContentResolver(), LocationManager.NETWORK_PROVIDER));
|
res, LocationManager.NETWORK_PROVIDER));
|
||||||
mGps.setChecked(Settings.Secure.isLocationProviderEnabled(
|
mGps.setChecked(Settings.Secure.isLocationProviderEnabled(
|
||||||
getContentResolver(), LocationManager.GPS_PROVIDER));
|
res, LocationManager.GPS_PROVIDER));
|
||||||
|
mUseLocation.setChecked(Settings.Gservices.getInt(res,
|
||||||
|
Settings.Gservices.USE_LOCATION_FOR_SERVICES, 2) == 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean isToggled(Preference pref) {
|
private boolean isToggled(Preference pref) {
|
||||||
return ((CheckBoxPreference) pref).isChecked();
|
return ((CheckBoxPreference) pref).isChecked();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void updateUseLocation() {
|
||||||
|
boolean use = mUseLocation.isChecked();
|
||||||
|
Settings.Gservices.putString(getContentResolver(),
|
||||||
|
Settings.Gservices.USE_LOCATION_FOR_SERVICES, use ? "1" : "0");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* For the user to disable keyguard, we first make them verify their
|
* For the user to disable keyguard, we first make them verify their
|
||||||
@@ -272,15 +378,33 @@ public class SecuritySettings extends PreferenceActivity {
|
|||||||
* @see #confirmPatternThenDisableAndClear
|
* @see #confirmPatternThenDisableAndClear
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
protected void onActivityResult(int requestCode, int resultCode,
|
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
|
||||||
Intent data) {
|
|
||||||
super.onActivityResult(requestCode, resultCode, data);
|
super.onActivityResult(requestCode, resultCode, data);
|
||||||
|
|
||||||
final boolean resultOk = resultCode == Activity.RESULT_OK;
|
final boolean resultOk = resultCode == Activity.RESULT_OK;
|
||||||
|
|
||||||
if ((requestCode == CONFIRM_PATTERN_THEN_DISABLE_AND_CLEAR_REQUEST_CODE) && resultOk) {
|
if ((requestCode == CONFIRM_PATTERN_THEN_DISABLE_AND_CLEAR_REQUEST_CODE)
|
||||||
|
&& resultOk) {
|
||||||
mLockPatternUtils.setLockPatternEnabled(false);
|
mLockPatternUtils.setLockPatternEnabled(false);
|
||||||
mLockPatternUtils.saveLockPattern(null);
|
mLockPatternUtils.saveLockPattern(null);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void onClick(DialogInterface dialog, int which) {
|
||||||
|
if (which == DialogInterface.BUTTON_POSITIVE) {
|
||||||
|
//updateProviders();
|
||||||
|
mOkClicked = true;
|
||||||
|
} else {
|
||||||
|
// Reset the toggle
|
||||||
|
mUseLocation.setChecked(false);
|
||||||
|
}
|
||||||
|
updateUseLocation();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void onDismiss(DialogInterface dialog) {
|
||||||
|
// Assuming that onClick gets called first
|
||||||
|
if (!mOkClicked) {
|
||||||
|
mUseLocation.setChecked(false);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user