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 ( |
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 |
void | setDisableDependentsState(boolean disableDependentsState) Sets whether dependents are disabled when this preference is on ( |
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 |
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
public TwoStatePreference (Context context)
| Parameters | |
|---|---|
context | Context |
TwoStatePreference
public TwoStatePreference (Context context, AttributeSet attrs)
| Parameters | |
|---|---|
context | Context |
attrs | AttributeSet |
TwoStatePreference
public TwoStatePreference (Context context, AttributeSet attrs, int defStyleAttr)
| Parameters | |
|---|---|
context | Context |
attrs | AttributeSet |
defStyleAttr | int |
TwoStatePreference
public TwoStatePreference (Context context, AttributeSet attrs, int defStyleAttr, int defStyleRes)
| Parameters | |
|---|---|
context | Context |
attrs | AttributeSet |
defStyleAttr | int |
defStyleRes | int |
Public methods
getDisableDependentsState
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
public CharSequence getSummaryOff ()
Returns the summary to be shown when unchecked.
| Returns | |
|---|---|
CharSequence | The summary. |
getSummaryOn
public CharSequence getSummaryOn ()
Returns the summary to be shown when checked.
| Returns | |
|---|---|
CharSequence | The summary. |
isChecked
public boolean isChecked ()
Returns the checked state.
| Returns | |
|---|---|
boolean | The checked state. |
setChecked
public void setChecked (boolean checked)
Sets the checked state and saves it to the SharedPreferences.
| Parameters | |
|---|---|
checked | boolean: The checked state. |
setDisableDependentsState
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
public void setSummaryOff (CharSequence summary)
Sets the summary to be shown when unchecked.
| Parameters | |
|---|---|
summary | CharSequence: The summary to be shown when unchecked. |
setSummaryOff
public void setSummaryOff (int summaryResId)
| Parameters | |
|---|---|
summaryResId | int: The summary as a resource. |
See also:
setSummaryOn
public void setSummaryOn (int summaryResId)
| Parameters | |
|---|---|
summaryResId | int: The summary as a resource. |
See also:
setSummaryOn
public void setSummaryOn (CharSequence summary)
Sets the summary to be shown when checked.
| Parameters | |
|---|---|
summary | CharSequence: The summary to be shown when checked. |
shouldDisableDependents
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
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
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
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
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
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. |