Merge "Settings: Remove master swtich from battery saver." into lmp-preview-dev
This commit is contained in:
committed by
Android (Google) Code Review
commit
26ac83df59
@@ -3725,6 +3725,9 @@
|
|||||||
<!-- [CHAR_LIMIT=40] Battery saver: Label for feature, title + menu item -->
|
<!-- [CHAR_LIMIT=40] Battery saver: Label for feature, title + menu item -->
|
||||||
<string name="battery_saver">Battery saver</string>
|
<string name="battery_saver">Battery saver</string>
|
||||||
|
|
||||||
|
<!-- [CHAR_LIMIT=40] Battery saver: Title for always on option -->
|
||||||
|
<string name="battery_saver_always_on_title">Always on</string>
|
||||||
|
|
||||||
<!-- [CHAR_LIMIT=40] Battery saver: Title for automatic entry option -->
|
<!-- [CHAR_LIMIT=40] Battery saver: Title for automatic entry option -->
|
||||||
<string name="battery_saver_turn_on_automatically_title">Turn on automatically</string>
|
<string name="battery_saver_turn_on_automatically_title">Turn on automatically</string>
|
||||||
|
|
||||||
@@ -3735,7 +3738,7 @@
|
|||||||
<string name="battery_saver_turn_on_automatically_pct">at %1$d%% battery</string>
|
<string name="battery_saver_turn_on_automatically_pct">at %1$d%% battery</string>
|
||||||
|
|
||||||
<!-- [CHAR_LIMIT=NONE] Battery saver: Feature description -->
|
<!-- [CHAR_LIMIT=NONE] Battery saver: Feature description -->
|
||||||
<string name="battery_saver_description">To help improve battery life, Battery saver will reduce your device’s performance.\n\nBattery saver will turn off when your device is plugged in.</string>
|
<string name="battery_saver_description">To help improve battery life, Battery saver will reduce your device’s performance.\n\nBattery saver will be disabled when your device is plugged in.</string>
|
||||||
|
|
||||||
<!-- Process Stats strings -->
|
<!-- Process Stats strings -->
|
||||||
<skip />
|
<skip />
|
||||||
|
@@ -18,6 +18,14 @@
|
|||||||
android:title="@string/battery_saver"
|
android:title="@string/battery_saver"
|
||||||
android:key="battery_saver">
|
android:key="battery_saver">
|
||||||
|
|
||||||
|
<!-- Always on -->
|
||||||
|
<SwitchPreference
|
||||||
|
android:key="always_on"
|
||||||
|
android:title="@string/battery_saver_always_on_title"
|
||||||
|
android:switchTextOff=""
|
||||||
|
android:switchTextOn=""
|
||||||
|
android:persistent="false" />
|
||||||
|
|
||||||
<!-- Turn on automatically -->
|
<!-- Turn on automatically -->
|
||||||
<com.android.settings.notification.DropDownPreference
|
<com.android.settings.notification.DropDownPreference
|
||||||
android:key="turn_on_automatically"
|
android:key="turn_on_automatically"
|
||||||
|
@@ -24,29 +24,24 @@ import android.net.Uri;
|
|||||||
import android.os.AsyncTask;
|
import android.os.AsyncTask;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
import android.os.Message;
|
|
||||||
import android.provider.Settings.Global;
|
import android.provider.Settings.Global;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
import android.widget.Switch;
|
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.SettingsActivity;
|
|
||||||
import com.android.settings.SettingsPreferenceFragment;
|
import com.android.settings.SettingsPreferenceFragment;
|
||||||
import com.android.settings.notification.SettingPref;
|
import com.android.settings.notification.SettingPref;
|
||||||
import com.android.settings.widget.SwitchBar;
|
|
||||||
|
|
||||||
public class BatterySaverSettings extends SettingsPreferenceFragment
|
public class BatterySaverSettings extends SettingsPreferenceFragment {
|
||||||
implements SwitchBar.OnSwitchChangeListener {
|
|
||||||
private static final String TAG = "BatterySaverSettings";
|
private static final String TAG = "BatterySaverSettings";
|
||||||
|
private static final String KEY_ALWAYS_ON = "always_on";
|
||||||
private static final String KEY_TURN_ON_AUTOMATICALLY = "turn_on_automatically";
|
private static final String KEY_TURN_ON_AUTOMATICALLY = "turn_on_automatically";
|
||||||
private static final long WAIT_FOR_SWITCH_ANIM = 500;
|
private static final long WAIT_FOR_SWITCH_ANIM = 500;
|
||||||
|
|
||||||
private final H mHandler = new H();
|
private final Handler mHandler = new Handler();
|
||||||
private final SettingsObserver mSettingsObserver = new SettingsObserver(mHandler);
|
private final SettingsObserver mSettingsObserver = new SettingsObserver(mHandler);
|
||||||
|
|
||||||
private Context mContext;
|
private Context mContext;
|
||||||
private SwitchBar mSwitchBar;
|
private SettingPref mAlwaysOnPref;
|
||||||
private boolean mSwitchBarListenerAdded;
|
|
||||||
private SettingPref mTriggerPref;
|
private SettingPref mTriggerPref;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -56,8 +51,21 @@ public class BatterySaverSettings extends SettingsPreferenceFragment
|
|||||||
addPreferencesFromResource(R.xml.battery_saver_settings);
|
addPreferencesFromResource(R.xml.battery_saver_settings);
|
||||||
|
|
||||||
mContext = getActivity();
|
mContext = getActivity();
|
||||||
mSwitchBar = ((SettingsActivity) mContext).getSwitchBar();
|
mAlwaysOnPref = new SettingPref(SettingPref.TYPE_GLOBAL, KEY_ALWAYS_ON,
|
||||||
updateSwitchBar();
|
Global.LOW_POWER_MODE, 0) {
|
||||||
|
@Override
|
||||||
|
protected boolean setSetting(Context context, int value) {
|
||||||
|
mHandler.removeCallbacks(mStartMode);
|
||||||
|
if (value == 0) {
|
||||||
|
return super.setSetting(context, value);
|
||||||
|
} else {
|
||||||
|
// about lose animations, make sure we don't turn the mode on until the switch
|
||||||
|
// stops moving
|
||||||
|
mHandler.postDelayed(mStartMode, WAIT_FOR_SWITCH_ANIM);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
mTriggerPref = new SettingPref(SettingPref.TYPE_GLOBAL, KEY_TURN_ON_AUTOMATICALLY,
|
mTriggerPref = new SettingPref(SettingPref.TYPE_GLOBAL, KEY_TURN_ON_AUTOMATICALLY,
|
||||||
Global.LOW_POWER_MODE_TRIGGER_LEVEL,
|
Global.LOW_POWER_MODE_TRIGGER_LEVEL,
|
||||||
mContext.getResources().getInteger(
|
mContext.getResources().getInteger(
|
||||||
@@ -71,76 +79,34 @@ public class BatterySaverSettings extends SettingsPreferenceFragment
|
|||||||
return res.getString(R.string.battery_saver_turn_on_automatically_never);
|
return res.getString(R.string.battery_saver_turn_on_automatically_never);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
mAlwaysOnPref.init(this);
|
||||||
mTriggerPref.init(this);
|
mTriggerPref.init(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updateSwitchBar() {
|
|
||||||
final boolean mode = Global.getInt(getContentResolver(), Global.LOW_POWER_MODE, 0) != 0;
|
|
||||||
if (mSwitchBarListenerAdded) {
|
|
||||||
mSwitchBar.removeOnSwitchChangeListener(this);
|
|
||||||
}
|
|
||||||
mSwitchBar.getSwitch().setChecked(mode);
|
|
||||||
if (mSwitchBarListenerAdded) {
|
|
||||||
mSwitchBar.addOnSwitchChangeListener(this);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void updateTriggerLevel() {
|
|
||||||
mTriggerPref.update(mContext);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onResume() {
|
public void onResume() {
|
||||||
super.onResume();
|
super.onResume();
|
||||||
updateSwitchBar();
|
|
||||||
mSettingsObserver.setListening(true);
|
mSettingsObserver.setListening(true);
|
||||||
mSwitchBar.show();
|
|
||||||
mSwitchBar.addOnSwitchChangeListener(this);
|
|
||||||
mSwitchBarListenerAdded = true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onPause() {
|
public void onPause() {
|
||||||
super.onPause();
|
super.onPause();
|
||||||
mSettingsObserver.setListening(false);
|
mSettingsObserver.setListening(false);
|
||||||
if (mSwitchBarListenerAdded) {
|
|
||||||
mSwitchBar.removeOnSwitchChangeListener(this);
|
|
||||||
mSwitchBarListenerAdded = false;
|
|
||||||
}
|
|
||||||
mSwitchBar.hide();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
private final Runnable mStartMode = new Runnable() {
|
||||||
public void onSwitchChanged(Switch switchView, boolean isChecked) {
|
|
||||||
mHandler.postSetMode(isChecked);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void handleSetMode(final boolean mode) {
|
|
||||||
AsyncTask.execute(new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
Log.d(TAG, "LOW_POWER_MODE from settings: " + mode);
|
|
||||||
Global.putInt(getContentResolver(), Global.LOW_POWER_MODE, mode ? 1 : 0);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
private final class H extends Handler {
|
|
||||||
private static final int SET_MODE = 1;
|
|
||||||
|
|
||||||
public void postSetMode(boolean mode) {
|
|
||||||
removeMessages(SET_MODE);
|
|
||||||
final Message m = obtainMessage(SET_MODE, mode ? 1 : 0, 0);
|
|
||||||
sendMessageDelayed(m, mode ? WAIT_FOR_SWITCH_ANIM : 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void handleMessage(Message msg) {
|
public void run() {
|
||||||
if (msg.what == SET_MODE) {
|
AsyncTask.execute(new Runnable() {
|
||||||
handleSetMode(msg.arg1 != 0);
|
@Override
|
||||||
}
|
public void run() {
|
||||||
|
Log.d(TAG, "Starting LOW_POWER_MODE from settings");
|
||||||
|
Global.putInt(mContext.getContentResolver(), Global.LOW_POWER_MODE, 1);
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
|
||||||
private final class SettingsObserver extends ContentObserver {
|
private final class SettingsObserver extends ContentObserver {
|
||||||
private final Uri LOW_POWER_MODE_URI = Global.getUriFor(Global.LOW_POWER_MODE);
|
private final Uri LOW_POWER_MODE_URI = Global.getUriFor(Global.LOW_POWER_MODE);
|
||||||
@@ -154,10 +120,10 @@ public class BatterySaverSettings extends SettingsPreferenceFragment
|
|||||||
@Override
|
@Override
|
||||||
public void onChange(boolean selfChange, Uri uri) {
|
public void onChange(boolean selfChange, Uri uri) {
|
||||||
if (LOW_POWER_MODE_URI.equals(uri)) {
|
if (LOW_POWER_MODE_URI.equals(uri)) {
|
||||||
updateSwitchBar();
|
mAlwaysOnPref.update(mContext);
|
||||||
}
|
}
|
||||||
if (LOW_POWER_MODE_TRIGGER_LEVEL_URI.equals(uri)) {
|
if (LOW_POWER_MODE_TRIGGER_LEVEL_URI.equals(uri)) {
|
||||||
updateTriggerLevel();
|
mTriggerPref.update(mContext);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user