Add SwitchPreference
Change-Id: I073e9bfba8c4e1a625c27f976f71ea56a81ba20f
This commit is contained in:
committed by
Gilles Debunne
parent
de13001f76
commit
be0a453505
@@ -16,20 +16,11 @@
|
||||
|
||||
package android.preference;
|
||||
|
||||
import android.app.Service;
|
||||
import android.content.Context;
|
||||
import android.content.SharedPreferences;
|
||||
import android.content.res.TypedArray;
|
||||
import android.os.Parcel;
|
||||
import android.os.Parcelable;
|
||||
import android.util.AttributeSet;
|
||||
import android.view.View;
|
||||
import android.view.ViewGroup;
|
||||
import android.view.accessibility.AccessibilityEvent;
|
||||
import android.view.accessibility.AccessibilityManager;
|
||||
import android.widget.CheckBox;
|
||||
import android.widget.Checkable;
|
||||
import android.widget.TextView;
|
||||
|
||||
/**
|
||||
* A {@link Preference} that provides checkbox widget
|
||||
@@ -41,31 +32,18 @@ import android.widget.TextView;
|
||||
* @attr ref android.R.styleable#CheckBoxPreference_summaryOn
|
||||
* @attr ref android.R.styleable#CheckBoxPreference_disableDependentsState
|
||||
*/
|
||||
public class CheckBoxPreference extends Preference {
|
||||
public class CheckBoxPreference extends TwoStatePreference {
|
||||
|
||||
private CharSequence mSummaryOn;
|
||||
private CharSequence mSummaryOff;
|
||||
|
||||
private boolean mChecked;
|
||||
private boolean mSendAccessibilityEventViewClickedType;
|
||||
|
||||
private AccessibilityManager mAccessibilityManager;
|
||||
|
||||
private boolean mDisableDependentsState;
|
||||
|
||||
public CheckBoxPreference(Context context, AttributeSet attrs, int defStyle) {
|
||||
super(context, attrs, defStyle);
|
||||
|
||||
TypedArray a = context.obtainStyledAttributes(attrs,
|
||||
com.android.internal.R.styleable.CheckBoxPreference, defStyle, 0);
|
||||
mSummaryOn = a.getString(com.android.internal.R.styleable.CheckBoxPreference_summaryOn);
|
||||
mSummaryOff = a.getString(com.android.internal.R.styleable.CheckBoxPreference_summaryOff);
|
||||
mDisableDependentsState = a.getBoolean(
|
||||
com.android.internal.R.styleable.CheckBoxPreference_disableDependentsState, false);
|
||||
setSummaryOn(a.getString(com.android.internal.R.styleable.CheckBoxPreference_summaryOn));
|
||||
setSummaryOff(a.getString(com.android.internal.R.styleable.CheckBoxPreference_summaryOff));
|
||||
setDisableDependentsState(a.getBoolean(
|
||||
com.android.internal.R.styleable.CheckBoxPreference_disableDependentsState, false));
|
||||
a.recycle();
|
||||
|
||||
mAccessibilityManager =
|
||||
(AccessibilityManager) getContext().getSystemService(Service.ACCESSIBILITY_SERVICE);
|
||||
}
|
||||
|
||||
public CheckBoxPreference(Context context, AttributeSet attrs) {
|
||||
@@ -84,246 +62,9 @@ public class CheckBoxPreference extends Preference {
|
||||
if (checkboxView != null && checkboxView instanceof Checkable) {
|
||||
((Checkable) checkboxView).setChecked(mChecked);
|
||||
|
||||
// send an event to announce the value change of the CheckBox and is done here
|
||||
// because clicking a preference does not immediately change the checked state
|
||||
// for example when enabling the WiFi
|
||||
if (mSendAccessibilityEventViewClickedType &&
|
||||
mAccessibilityManager.isEnabled() &&
|
||||
checkboxView.isEnabled()) {
|
||||
mSendAccessibilityEventViewClickedType = false;
|
||||
|
||||
// we send an event on behalf of the check box because in onBind the latter
|
||||
// is detached from its parent and such views do not send accessibility events
|
||||
AccessibilityEvent event = AccessibilityEvent.obtain(
|
||||
AccessibilityEvent.TYPE_VIEW_CLICKED);
|
||||
event.setClassName(checkboxView.getClass().getName());
|
||||
event.setPackageName(getContext().getPackageName());
|
||||
event.setEnabled(checkboxView.isEnabled());
|
||||
event.setContentDescription(checkboxView.getContentDescription());
|
||||
event.setChecked(((Checkable) checkboxView).isChecked());
|
||||
mAccessibilityManager.sendAccessibilityEvent(event);
|
||||
}
|
||||
sendAccessibilityEventForView(checkboxView);
|
||||
}
|
||||
|
||||
// Sync the summary view
|
||||
TextView summaryView = (TextView) view.findViewById(com.android.internal.R.id.summary);
|
||||
if (summaryView != null) {
|
||||
boolean useDefaultSummary = true;
|
||||
if (mChecked && mSummaryOn != null) {
|
||||
summaryView.setText(mSummaryOn);
|
||||
useDefaultSummary = false;
|
||||
} else if (!mChecked && mSummaryOff != null) {
|
||||
summaryView.setText(mSummaryOff);
|
||||
useDefaultSummary = false;
|
||||
}
|
||||
|
||||
if (useDefaultSummary) {
|
||||
final CharSequence summary = getSummary();
|
||||
if (summary != null) {
|
||||
summaryView.setText(summary);
|
||||
useDefaultSummary = false;
|
||||
}
|
||||
}
|
||||
|
||||
int newVisibility = View.GONE;
|
||||
if (!useDefaultSummary) {
|
||||
// Someone has written to it
|
||||
newVisibility = View.VISIBLE;
|
||||
}
|
||||
if (newVisibility != summaryView.getVisibility()) {
|
||||
summaryView.setVisibility(newVisibility);
|
||||
}
|
||||
}
|
||||
syncSummaryView(view);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void onClick() {
|
||||
super.onClick();
|
||||
|
||||
boolean newValue = !isChecked();
|
||||
|
||||
// in onBindView() an AccessibilityEventViewClickedType is sent to announce the change
|
||||
// not sending
|
||||
mSendAccessibilityEventViewClickedType = true;
|
||||
|
||||
if (!callChangeListener(newValue)) {
|
||||
return;
|
||||
}
|
||||
|
||||
setChecked(newValue);
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets the checked state and saves it to the {@link SharedPreferences}.
|
||||
*
|
||||
* @param checked The checked state.
|
||||
*/
|
||||
public void setChecked(boolean checked) {
|
||||
if (mChecked != checked) {
|
||||
mChecked = checked;
|
||||
persistBoolean(checked);
|
||||
notifyDependencyChange(shouldDisableDependents());
|
||||
notifyChanged();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the checked state.
|
||||
*
|
||||
* @return The checked state.
|
||||
*/
|
||||
public boolean isChecked() {
|
||||
return mChecked;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean shouldDisableDependents() {
|
||||
boolean shouldDisable = mDisableDependentsState ? mChecked : !mChecked;
|
||||
return shouldDisable || super.shouldDisableDependents();
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets the summary to be shown when checked.
|
||||
*
|
||||
* @param summary The summary to be shown when checked.
|
||||
*/
|
||||
public void setSummaryOn(CharSequence summary) {
|
||||
mSummaryOn = summary;
|
||||
if (isChecked()) {
|
||||
notifyChanged();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @see #setSummaryOn(CharSequence)
|
||||
* @param summaryResId The summary as a resource.
|
||||
*/
|
||||
public void setSummaryOn(int summaryResId) {
|
||||
setSummaryOn(getContext().getString(summaryResId));
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the summary to be shown when checked.
|
||||
* @return The summary.
|
||||
*/
|
||||
public CharSequence getSummaryOn() {
|
||||
return mSummaryOn;
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets the summary to be shown when unchecked.
|
||||
*
|
||||
* @param summary The summary to be shown when unchecked.
|
||||
*/
|
||||
public void setSummaryOff(CharSequence summary) {
|
||||
mSummaryOff = summary;
|
||||
if (!isChecked()) {
|
||||
notifyChanged();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @see #setSummaryOff(CharSequence)
|
||||
* @param summaryResId The summary as a resource.
|
||||
*/
|
||||
public void setSummaryOff(int summaryResId) {
|
||||
setSummaryOff(getContext().getString(summaryResId));
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the summary to be shown when unchecked.
|
||||
* @return The summary.
|
||||
*/
|
||||
public CharSequence getSummaryOff() {
|
||||
return mSummaryOff;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns whether dependents are disabled when this preference is on ({@code true})
|
||||
* or when this preference is off ({@code false}).
|
||||
*
|
||||
* @return Whether dependents are disabled when this preference is on ({@code true})
|
||||
* or when this preference is off ({@code false}).
|
||||
*/
|
||||
public boolean getDisableDependentsState() {
|
||||
return mDisableDependentsState;
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets whether dependents are disabled when this preference is on ({@code true})
|
||||
* or when this preference is off ({@code false}).
|
||||
*
|
||||
* @param disableDependentsState The preference state that should disable dependents.
|
||||
*/
|
||||
public void setDisableDependentsState(boolean disableDependentsState) {
|
||||
mDisableDependentsState = disableDependentsState;
|
||||
}
|
||||
|
||||
@Override
|
||||
protected Object onGetDefaultValue(TypedArray a, int index) {
|
||||
return a.getBoolean(index, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void onSetInitialValue(boolean restoreValue, Object defaultValue) {
|
||||
setChecked(restoreValue ? getPersistedBoolean(mChecked)
|
||||
: (Boolean) defaultValue);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected Parcelable onSaveInstanceState() {
|
||||
final Parcelable superState = super.onSaveInstanceState();
|
||||
if (isPersistent()) {
|
||||
// No need to save instance state since it's persistent
|
||||
return superState;
|
||||
}
|
||||
|
||||
final SavedState myState = new SavedState(superState);
|
||||
myState.checked = isChecked();
|
||||
return myState;
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void onRestoreInstanceState(Parcelable state) {
|
||||
if (state == null || !state.getClass().equals(SavedState.class)) {
|
||||
// Didn't save state for us in onSaveInstanceState
|
||||
super.onRestoreInstanceState(state);
|
||||
return;
|
||||
}
|
||||
|
||||
SavedState myState = (SavedState) state;
|
||||
super.onRestoreInstanceState(myState.getSuperState());
|
||||
setChecked(myState.checked);
|
||||
}
|
||||
|
||||
private static class SavedState extends BaseSavedState {
|
||||
boolean checked;
|
||||
|
||||
public SavedState(Parcel source) {
|
||||
super(source);
|
||||
checked = source.readInt() == 1;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void writeToParcel(Parcel dest, int flags) {
|
||||
super.writeToParcel(dest, flags);
|
||||
dest.writeInt(checked ? 1 : 0);
|
||||
}
|
||||
|
||||
public SavedState(Parcelable superState) {
|
||||
super(superState);
|
||||
}
|
||||
|
||||
public static final Parcelable.Creator<SavedState> CREATOR =
|
||||
new Parcelable.Creator<SavedState>() {
|
||||
public SavedState createFromParcel(Parcel in) {
|
||||
return new SavedState(in);
|
||||
}
|
||||
|
||||
public SavedState[] newArray(int size) {
|
||||
return new SavedState[size];
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
180
core/java/android/preference/SwitchPreference.java
Normal file
180
core/java/android/preference/SwitchPreference.java
Normal file
@@ -0,0 +1,180 @@
|
||||
/*
|
||||
* Copyright (C) 2010 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
package android.preference;
|
||||
|
||||
import android.content.Context;
|
||||
import android.content.res.TypedArray;
|
||||
import android.util.AttributeSet;
|
||||
import android.view.View;
|
||||
import android.widget.Checkable;
|
||||
import android.widget.CompoundButton;
|
||||
import android.widget.Switch;
|
||||
|
||||
/**
|
||||
* A {@link Preference} that provides a two-state toggleable option.
|
||||
* <p>
|
||||
* This preference will store a boolean into the SharedPreferences.
|
||||
*
|
||||
* @attr ref android.R.styleable#SwitchPreference_summaryOff
|
||||
* @attr ref android.R.styleable#SwitchPreference_summaryOn
|
||||
* @attr ref android.R.styleable#SwitchPreference_switchTextOff
|
||||
* @attr ref android.R.styleable#SwitchPreference_switchTextOn
|
||||
* @attr ref android.R.styleable#SwitchPreference_disableDependentsState
|
||||
*/
|
||||
public class SwitchPreference extends TwoStatePreference {
|
||||
// Switch text for on and off states
|
||||
private CharSequence mSwitchOn;
|
||||
private CharSequence mSwitchOff;
|
||||
private final Listener mListener = new Listener();
|
||||
|
||||
private class Listener implements View.OnClickListener, CompoundButton.OnCheckedChangeListener {
|
||||
@Override
|
||||
public void onClick(View v) {
|
||||
SwitchPreference.this.onClick();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
|
||||
SwitchPreference.this.setChecked(isChecked);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Construct a new SwitchPreference with the given style options.
|
||||
*
|
||||
* @param context The Context that will style this preference
|
||||
* @param attrs Style attributes that differ from the default
|
||||
* @param defStyle Theme attribute defining the default style options
|
||||
*/
|
||||
public SwitchPreference(Context context, AttributeSet attrs, int defStyle) {
|
||||
super(context, attrs, defStyle);
|
||||
|
||||
TypedArray a = context.obtainStyledAttributes(attrs,
|
||||
com.android.internal.R.styleable.SwitchPreference, defStyle, 0);
|
||||
setSummaryOn(a.getString(com.android.internal.R.styleable.SwitchPreference_summaryOn));
|
||||
setSummaryOff(a.getString(com.android.internal.R.styleable.SwitchPreference_summaryOff));
|
||||
setSwitchTextOn(a.getString(
|
||||
com.android.internal.R.styleable.SwitchPreference_switchTextOn));
|
||||
setSwitchTextOff(a.getString(
|
||||
com.android.internal.R.styleable.SwitchPreference_switchTextOff));
|
||||
setDisableDependentsState(a.getBoolean(
|
||||
com.android.internal.R.styleable.SwitchPreference_disableDependentsState, false));
|
||||
a.recycle();
|
||||
}
|
||||
|
||||
/**
|
||||
* Construct a new SwitchPreference with the given style options.
|
||||
*
|
||||
* @param context The Context that will style this preference
|
||||
* @param attrs Style attributes that differ from the default
|
||||
*/
|
||||
public SwitchPreference(Context context, AttributeSet attrs) {
|
||||
this(context, attrs, com.android.internal.R.attr.switchPreferenceStyle);
|
||||
}
|
||||
|
||||
/**
|
||||
* Construct a new SwitchPreference with default style options.
|
||||
*
|
||||
* @param context The Context that will style this preference
|
||||
*/
|
||||
public SwitchPreference(Context context) {
|
||||
this(context, null);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void onBindView(View view) {
|
||||
super.onBindView(view);
|
||||
|
||||
View checkableView = view.findViewById(com.android.internal.R.id.switchWidget);
|
||||
if (checkableView != null && checkableView instanceof Checkable) {
|
||||
((Checkable) checkableView).setChecked(mChecked);
|
||||
|
||||
sendAccessibilityEventForView(checkableView);
|
||||
|
||||
if (checkableView instanceof Switch) {
|
||||
final Switch switchView = (Switch) checkableView;
|
||||
switchView.setTextOn(mSwitchOn);
|
||||
switchView.setTextOff(mSwitchOff);
|
||||
switchView.setOnCheckedChangeListener(mListener);
|
||||
}
|
||||
|
||||
if (checkableView.hasFocusable()) {
|
||||
// This is a focusable list item. Attach a click handler to toggle the button
|
||||
// for the rest of the item.
|
||||
view.setOnClickListener(mListener);
|
||||
}
|
||||
}
|
||||
|
||||
syncSummaryView(view);
|
||||
}
|
||||
|
||||
/**
|
||||
* Set the text displayed on the switch widget in the on state.
|
||||
* This should be a very short string; one word if possible.
|
||||
*
|
||||
* @param onText Text to display in the on state
|
||||
*/
|
||||
public void setSwitchTextOn(CharSequence onText) {
|
||||
mSwitchOn = onText;
|
||||
notifyChanged();
|
||||
}
|
||||
|
||||
/**
|
||||
* Set the text displayed on the switch widget in the off state.
|
||||
* This should be a very short string; one word if possible.
|
||||
*
|
||||
* @param offText Text to display in the off state
|
||||
*/
|
||||
public void setSwitchTextOff(CharSequence offText) {
|
||||
mSwitchOff = offText;
|
||||
notifyChanged();
|
||||
}
|
||||
|
||||
/**
|
||||
* Set the text displayed on the switch widget in the on state.
|
||||
* This should be a very short string; one word if possible.
|
||||
*
|
||||
* @param resId The text as a string resource ID
|
||||
*/
|
||||
public void setSwitchTextOn(int resId) {
|
||||
setSwitchTextOn(getContext().getString(resId));
|
||||
}
|
||||
|
||||
/**
|
||||
* Set the text displayed on the switch widget in the off state.
|
||||
* This should be a very short string; one word if possible.
|
||||
*
|
||||
* @param resId The text as a string resource ID
|
||||
*/
|
||||
public void setSwitchTextOff(int resId) {
|
||||
setSwitchTextOff(getContext().getString(resId));
|
||||
}
|
||||
|
||||
/**
|
||||
* @return The text that will be displayed on the switch widget in the on state
|
||||
*/
|
||||
public CharSequence getSwitchTextOn() {
|
||||
return mSwitchOn;
|
||||
}
|
||||
|
||||
/**
|
||||
* @return The text that will be displayed on the switch widget in the off state
|
||||
*/
|
||||
public CharSequence getSwitchTextOff() {
|
||||
return mSwitchOff;
|
||||
}
|
||||
}
|
||||
309
core/java/android/preference/TwoStatePreference.java
Normal file
309
core/java/android/preference/TwoStatePreference.java
Normal file
@@ -0,0 +1,309 @@
|
||||
/*
|
||||
* Copyright (C) 2010 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
package android.preference;
|
||||
|
||||
import android.app.Service;
|
||||
import android.content.Context;
|
||||
import android.content.SharedPreferences;
|
||||
import android.content.res.TypedArray;
|
||||
import android.os.Parcel;
|
||||
import android.os.Parcelable;
|
||||
import android.util.AttributeSet;
|
||||
import android.view.View;
|
||||
import android.view.accessibility.AccessibilityEvent;
|
||||
import android.view.accessibility.AccessibilityManager;
|
||||
import android.widget.TextView;
|
||||
|
||||
/**
|
||||
* Common base class for preferences that have two selectable states, persist a
|
||||
* boolean value in SharedPreferences, and may have dependent preferences that are
|
||||
* enabled/disabled based on the current state.
|
||||
*/
|
||||
public abstract class TwoStatePreference extends Preference {
|
||||
|
||||
private CharSequence mSummaryOn;
|
||||
private CharSequence mSummaryOff;
|
||||
boolean mChecked;
|
||||
private boolean mSendAccessibilityEventViewClickedType;
|
||||
private AccessibilityManager mAccessibilityManager;
|
||||
private boolean mDisableDependentsState;
|
||||
|
||||
public TwoStatePreference(Context context, AttributeSet attrs, int defStyle) {
|
||||
super(context, attrs, defStyle);
|
||||
|
||||
mAccessibilityManager =
|
||||
(AccessibilityManager) getContext().getSystemService(Service.ACCESSIBILITY_SERVICE);
|
||||
}
|
||||
|
||||
public TwoStatePreference(Context context, AttributeSet attrs) {
|
||||
super(context, attrs);
|
||||
|
||||
mAccessibilityManager =
|
||||
(AccessibilityManager) getContext().getSystemService(Service.ACCESSIBILITY_SERVICE);
|
||||
}
|
||||
|
||||
public TwoStatePreference(Context context) {
|
||||
super(context);
|
||||
|
||||
mAccessibilityManager =
|
||||
(AccessibilityManager) getContext().getSystemService(Service.ACCESSIBILITY_SERVICE);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void onClick() {
|
||||
super.onClick();
|
||||
|
||||
boolean newValue = !isChecked();
|
||||
|
||||
// in onBindView() an AccessibilityEventViewClickedType is sent to announce the change
|
||||
// not sending
|
||||
mSendAccessibilityEventViewClickedType = true;
|
||||
|
||||
if (!callChangeListener(newValue)) {
|
||||
return;
|
||||
}
|
||||
|
||||
setChecked(newValue);
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets the checked state and saves it to the {@link SharedPreferences}.
|
||||
*
|
||||
* @param checked The checked state.
|
||||
*/
|
||||
public void setChecked(boolean checked) {
|
||||
if (mChecked != checked) {
|
||||
mChecked = checked;
|
||||
persistBoolean(checked);
|
||||
notifyDependencyChange(shouldDisableDependents());
|
||||
notifyChanged();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the checked state.
|
||||
*
|
||||
* @return The checked state.
|
||||
*/
|
||||
public boolean isChecked() {
|
||||
return mChecked;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean shouldDisableDependents() {
|
||||
boolean shouldDisable = mDisableDependentsState ? mChecked : !mChecked;
|
||||
return shouldDisable || super.shouldDisableDependents();
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets the summary to be shown when checked.
|
||||
*
|
||||
* @param summary The summary to be shown when checked.
|
||||
*/
|
||||
public void setSummaryOn(CharSequence summary) {
|
||||
mSummaryOn = summary;
|
||||
if (isChecked()) {
|
||||
notifyChanged();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @see #setSummaryOn(CharSequence)
|
||||
* @param summaryResId The summary as a resource.
|
||||
*/
|
||||
public void setSummaryOn(int summaryResId) {
|
||||
setSummaryOn(getContext().getString(summaryResId));
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the summary to be shown when checked.
|
||||
* @return The summary.
|
||||
*/
|
||||
public CharSequence getSummaryOn() {
|
||||
return mSummaryOn;
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets the summary to be shown when unchecked.
|
||||
*
|
||||
* @param summary The summary to be shown when unchecked.
|
||||
*/
|
||||
public void setSummaryOff(CharSequence summary) {
|
||||
mSummaryOff = summary;
|
||||
if (!isChecked()) {
|
||||
notifyChanged();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @see #setSummaryOff(CharSequence)
|
||||
* @param summaryResId The summary as a resource.
|
||||
*/
|
||||
public void setSummaryOff(int summaryResId) {
|
||||
setSummaryOff(getContext().getString(summaryResId));
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the summary to be shown when unchecked.
|
||||
* @return The summary.
|
||||
*/
|
||||
public CharSequence getSummaryOff() {
|
||||
return mSummaryOff;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns whether dependents are disabled when this preference is on ({@code true})
|
||||
* or when this preference is off ({@code false}).
|
||||
*
|
||||
* @return Whether dependents are disabled when this preference is on ({@code true})
|
||||
* or when this preference is off ({@code false}).
|
||||
*/
|
||||
public boolean getDisableDependentsState() {
|
||||
return mDisableDependentsState;
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets whether dependents are disabled when this preference is on ({@code true})
|
||||
* or when this preference is off ({@code false}).
|
||||
*
|
||||
* @param disableDependentsState The preference state that should disable dependents.
|
||||
*/
|
||||
public void setDisableDependentsState(boolean disableDependentsState) {
|
||||
mDisableDependentsState = disableDependentsState;
|
||||
}
|
||||
|
||||
@Override
|
||||
protected Object onGetDefaultValue(TypedArray a, int index) {
|
||||
return a.getBoolean(index, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void onSetInitialValue(boolean restoreValue, Object defaultValue) {
|
||||
setChecked(restoreValue ? getPersistedBoolean(mChecked)
|
||||
: (Boolean) defaultValue);
|
||||
}
|
||||
|
||||
/**
|
||||
* Send an accessibility event for the given view if appropriate
|
||||
* @param view View that should send the event
|
||||
*/
|
||||
void sendAccessibilityEventForView(View view) {
|
||||
// send an event to announce the value change of the state. It is done here
|
||||
// because clicking a preference does not immediately change the checked state
|
||||
// for example when enabling the WiFi
|
||||
if (mSendAccessibilityEventViewClickedType &&
|
||||
mAccessibilityManager.isEnabled() &&
|
||||
view.isEnabled()) {
|
||||
mSendAccessibilityEventViewClickedType = false;
|
||||
|
||||
int eventType = AccessibilityEvent.TYPE_VIEW_CLICKED;
|
||||
view.sendAccessibilityEventUnchecked(AccessibilityEvent.obtain(eventType));
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Sync a summary view contained within view's subhierarchy with the correct summary text.
|
||||
* @param view View where a summary should be located
|
||||
*/
|
||||
void syncSummaryView(View view) {
|
||||
// Sync the summary view
|
||||
TextView summaryView = (TextView) view.findViewById(com.android.internal.R.id.summary);
|
||||
if (summaryView != null) {
|
||||
boolean useDefaultSummary = true;
|
||||
if (mChecked && mSummaryOn != null) {
|
||||
summaryView.setText(mSummaryOn);
|
||||
useDefaultSummary = false;
|
||||
} else if (!mChecked && mSummaryOff != null) {
|
||||
summaryView.setText(mSummaryOff);
|
||||
useDefaultSummary = false;
|
||||
}
|
||||
|
||||
if (useDefaultSummary) {
|
||||
final CharSequence summary = getSummary();
|
||||
if (summary != null) {
|
||||
summaryView.setText(summary);
|
||||
useDefaultSummary = false;
|
||||
}
|
||||
}
|
||||
|
||||
int newVisibility = View.GONE;
|
||||
if (!useDefaultSummary) {
|
||||
// Someone has written to it
|
||||
newVisibility = View.VISIBLE;
|
||||
}
|
||||
if (newVisibility != summaryView.getVisibility()) {
|
||||
summaryView.setVisibility(newVisibility);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
protected Parcelable onSaveInstanceState() {
|
||||
final Parcelable superState = super.onSaveInstanceState();
|
||||
if (isPersistent()) {
|
||||
// No need to save instance state since it's persistent
|
||||
return superState;
|
||||
}
|
||||
|
||||
final SavedState myState = new SavedState(superState);
|
||||
myState.checked = isChecked();
|
||||
return myState;
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void onRestoreInstanceState(Parcelable state) {
|
||||
if (state == null || !state.getClass().equals(SavedState.class)) {
|
||||
// Didn't save state for us in onSaveInstanceState
|
||||
super.onRestoreInstanceState(state);
|
||||
return;
|
||||
}
|
||||
|
||||
SavedState myState = (SavedState) state;
|
||||
super.onRestoreInstanceState(myState.getSuperState());
|
||||
setChecked(myState.checked);
|
||||
}
|
||||
|
||||
static class SavedState extends BaseSavedState {
|
||||
boolean checked;
|
||||
|
||||
public SavedState(Parcel source) {
|
||||
super(source);
|
||||
checked = source.readInt() == 1;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void writeToParcel(Parcel dest, int flags) {
|
||||
super.writeToParcel(dest, flags);
|
||||
dest.writeInt(checked ? 1 : 0);
|
||||
}
|
||||
|
||||
public SavedState(Parcelable superState) {
|
||||
super(superState);
|
||||
}
|
||||
|
||||
public static final Parcelable.Creator<SavedState> CREATOR =
|
||||
new Parcelable.Creator<SavedState>() {
|
||||
public SavedState createFromParcel(Parcel in) {
|
||||
return new SavedState(in);
|
||||
}
|
||||
|
||||
public SavedState[] newArray(int size) {
|
||||
return new SavedState[size];
|
||||
}
|
||||
};
|
||||
}
|
||||
}
|
||||
@@ -16,8 +16,6 @@
|
||||
|
||||
package android.widget;
|
||||
|
||||
import com.android.internal.R;
|
||||
|
||||
import android.content.Context;
|
||||
import android.content.res.ColorStateList;
|
||||
import android.content.res.Resources;
|
||||
@@ -37,6 +35,8 @@ import android.view.MotionEvent;
|
||||
import android.view.VelocityTracker;
|
||||
import android.view.ViewConfiguration;
|
||||
|
||||
import com.android.internal.R;
|
||||
|
||||
/**
|
||||
* A Switch is a two-state toggle switch widget that can select between two
|
||||
* options. The user may drag the "thumb" back and forth to choose the selected option,
|
||||
@@ -84,6 +84,7 @@ public class Switch extends CompoundButton {
|
||||
private Layout mOnLayout;
|
||||
private Layout mOffLayout;
|
||||
|
||||
@SuppressWarnings("hiding")
|
||||
private final Rect mTempRect = new Rect();
|
||||
|
||||
private static final int[] CHECKED_STATE_SET = {
|
||||
|
||||
Reference in New Issue
Block a user