TwoStatePreference


public abstract class TwoStatePreference
extends Preference

java.lang.Object
   ↳ android.preference.Preference
     ↳ android.preference.TwoStatePreference


This class was deprecated in API level 29.
Use the AndroidX Preference Library for consistent behavior across all devices. For more information on using the AndroidX Preference Library see Settings.

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.

Summary

Inherited XML attributes

Inherited constants

Public constructors

TwoStatePreference(Context context)
TwoStatePreference(Context context, AttributeSet attrs)
TwoStatePreference(Context context, AttributeSet attrs, int defStyleAttr)
TwoStatePreference(Context context, AttributeSet attrs, int defStyleAttr, int defStyleRes)

Public methods

boolean getDisableDependentsState()

Returns whether dependents are disabled when this preference is on (true) or when this preference is off (false).

CharSequence getSummaryOff()

Returns the summary to be shown when unchecked.

CharSequence getSummaryOn()

Returns the summary to be shown when checked.

boolean isChecked()

Returns the checked state.

void setChecked(boolean checked)

Sets the checked state and saves it to the SharedPreferences.

void setDisableDependentsState(boolean disableDependentsState)

Sets whether dependents are disabled when this preference is on (true) or when this preference is off (false).

void setSummaryOff(CharSequence summary)

Sets the summary to be shown when unchecked.

void setSummaryOff(int summaryResId)
void setSummaryOn(int summaryResId)
void setSummaryOn(CharSequence summary)

Sets the summary to be shown when checked.

boolean shouldDisableDependents()

Checks whether this preference's dependents should currently be disabled.

Protected methods

void onClick()

Processes a click on the preference.

Object onGetDefaultValue(TypedArray a, int index)

Called when a Preference is being inflated and the default value attribute needs to be read.

void onRestoreInstanceState(Parcelable state)

Hook allowing a Preference to re-apply a representation of its internal state that had previously been generated by onSaveInstanceState().

Parcelable onSaveInstanceState()

Hook allowing a Preference to generate a representation of its internal state that can later be used to create a new instance with that same state.

void onSetInitialValue(boolean restoreValue, Object defaultValue)

Implement this to set the initial value of the Preference.

Inherited methods

Public constructors

TwoStatePreference

Added in API level 14
public TwoStatePreference (Context context)

Parameters
context Context

TwoStatePreference

Added in API level 14
public TwoStatePreference (Context context, 
                AttributeSet attrs)

Parameters
context Context

attrs AttributeSet

TwoStatePreference

Added in API level 14
public TwoStatePreference (Context context, 
                AttributeSet attrs, 
                int defStyleAttr)

Parameters
context Context

attrs AttributeSet

defStyleAttr int

TwoStatePreference

Added in API level 21
public TwoStatePreference (Context context, 
                AttributeSet attrs, 
                int defStyleAttr, 
                int defStyleRes)

Parameters
context Context

attrs AttributeSet

defStyleAttr int

defStyleRes int

Public methods

getDisableDependentsState

Added in API level 14
public boolean getDisableDependentsState ()

Returns whether dependents are disabled when this preference is on (true) or when this preference is off (false).

Returns
boolean Whether dependents are disabled when this preference is on (true) or when this preference is off (false).

getSummaryOff

Added in API level 14
public CharSequence getSummaryOff ()

Returns the summary to be shown when unchecked.

Returns
CharSequence The summary.

getSummaryOn

Added in API level 14
public CharSequence getSummaryOn ()

Returns the summary to be shown when checked.

Returns
CharSequence The summary.

isChecked

Added in API level 14
public boolean isChecked ()

Returns the checked state.

Returns
boolean The checked state.

setChecked

Added in API level 14
public void setChecked (boolean checked)

Sets the checked state and saves it to the SharedPreferences.

Parameters
checked boolean: The checked state.

setDisableDependentsState

Added in API level 14
public void setDisableDependentsState (boolean disableDependentsState)

Sets whether dependents are disabled when this preference is on (true) or when this preference is off (false).

Parameters
disableDependentsState boolean: The preference state that should disable dependents.

setSummaryOff

Added in API level 14
public void setSummaryOff (CharSequence summary)

Sets the summary to be shown when unchecked.

Parameters
summary CharSequence: The summary to be shown when unchecked.

setSummaryOff

Added in API level 14
public void setSummaryOff (int summaryResId)

Parameters
summaryResId int: The summary as a resource.

setSummaryOn

Added in API level 14
public void setSummaryOn (int summaryResId)

Parameters
summaryResId int: The summary as a resource.

setSummaryOn

Added in API level 14
public void setSummaryOn (CharSequence summary)

Sets the summary to be shown when checked.

Parameters
summary CharSequence: The summary to be shown when checked.

shouldDisableDependents

Added in API level 14
public boolean shouldDisableDependents ()

Checks whether this preference's dependents should currently be disabled.

Returns
boolean True if the dependents should be disabled, otherwise false.

Protected methods

onClick

Added in API level 14
protected void onClick ()

Processes a click on the preference. This includes saving the value to the SharedPreferences. However, the overridden method should call callChangeListener(java.lang.Object) to make sure the client wants to update the preference's state with the new value.

onGetDefaultValue

Added in API level 14
protected Object onGetDefaultValue (TypedArray a, 
                int index)

Called when a Preference is being inflated and the default value attribute needs to be read. Since different Preference types have different value types, the subclass should get and return the default value which will be its value type.

For example, if the value type is String, the body of the method would proxy to TypedArray.getString(int).

Parameters
a TypedArray: The set of attributes.

index int: The index of the default value attribute.

Returns
Object The default value of this preference type.

onRestoreInstanceState

Added in API level 14
protected void onRestoreInstanceState (Parcelable state)

Hook allowing a Preference to re-apply a representation of its internal state that had previously been generated by onSaveInstanceState(). This function will never be called with a null state.

Parameters
state Parcelable: The saved state that had previously been returned by onSaveInstanceState().

onSaveInstanceState

Added in API level 14
protected Parcelable onSaveInstanceState ()

Hook allowing a Preference to generate a representation of its internal state that can later be used to create a new instance with that same state. This state should only contain information that is not persistent or can be reconstructed later.

Returns
Parcelable A Parcelable object containing the current dynamic state of this Preference, or null if there is nothing interesting to save. The default implementation returns null.

onSetInitialValue

Added in API level 14
protected void onSetInitialValue (boolean restoreValue, 
                Object defaultValue)

Implement this to set the initial value of the Preference.

If restorePersistedValue is true, you should restore the Preference value from the SharedPreferences. If restorePersistedValue is false, you should set the Preference value to defaultValue that is given (and possibly store to SharedPreferences if shouldPersist() is true).

In case of using PreferenceDataStore, the restorePersistedValue is always true. But the default value (if provided) is set.

This may not always be called. One example is if it should not persist but there is no default value given.

Parameters
restoreValue boolean: True to restore the persisted value; false to use the given defaultValue.

defaultValue Object: The default value for this Preference. Only use this if restorePersistedValue is false.