Configuración Parte de Android Jetpack
La configuración permite que los usuarios cambien la funcionalidad y el comportamiento de una app. La configuración puede afectar el comportamiento en segundo plano, como la frecuencia con la que la app sincroniza datos con la nube, o pueden tener un alcance más amplio, como cambiar el contenido y la presentación de la interfaz de usuario.
Para integrar la configuración que puede configurar el usuario en tu app, usa la biblioteca de Preference de AndroidX. Esta biblioteca administra la interfaz de usuario e interactúa con el almacenamiento de modo que solo se definan las configuraciones individuales que el usuario pueda ajustar. La biblioteca incluye un tema de Material Design que proporciona una experiencia del usuario coherente en todos los dispositivos y todas las versiones de SO.
Comenzar
Un Preference
es el componente básico de la biblioteca de Preference. Una pantalla de configuración contiene una jerarquía de Preference
. Puedes definir esta jerarquía como un recurso XML o compilar una jerarquía mediante código.
En las siguientes secciones, se describe cómo compilar una pantalla de configuración simple con la biblioteca de Preference de AndroidX.
Antes de comenzar, agrega la dependencia de la biblioteca de Preference a tu archivo build.gradle
:
Groovy
dependencies { implementation "androidx.preference:preference-ktx:1.2.0" }
Kotlin
dependencies { implementation("androidx.preference:preference-ktx:1.2.0") }
Después de una sincronización de Gradle, puedes pasar a la parte XML de la tarea.
Cómo crear una jerarquía
En tu proyecto, navega a la carpeta res/xml
, crea un archivo preferences.xml
y agrégale el siguiente código:
<PreferenceScreen xmlns:app="http://schemas.android.com/apk/res-auto"> <SwitchPreferenceCompat app:key="notifications" app:title="Enable message notifications"/> <Preference app:key="feedback" app:title="Send feedback" app:summary="Report technical issues or suggest new features"/> </PreferenceScreen>
Esta jerarquía contiene dos objetos Preference
: un SwitchPreferenceCompat
que permite a los usuarios activar o desactivar una configuración, y un Preference
básico sin widget.
Cuando se compila una jerarquía, cada elemento Preference
debe tener una clave única.
Cómo aumentar la jerarquía
Para aumentar una jerarquía a partir de un atributo XML, crea un PreferenceFragmentCompat
, anula onCreatePreferences()
y agrega el recurso XML que deseas aumentar, tal como se indica en el siguiente ejemplo:
Kotlin
class MySettingsFragment : PreferenceFragmentCompat() { override fun onCreatePreferences(savedInstanceState: Bundle?, rootKey: String?) { setPreferencesFromResource(R.xml.preferences, rootKey) } }
Java
public class MySettingsFragment extends PreferenceFragmentCompat { @Override public void onCreatePreferences(Bundle savedInstanceState, String rootKey) { setPreferencesFromResource(R.xml.preferences, rootKey); } }
Luego, puedes agregar este Fragment
a tu Activity
como lo haces con cualquier otro Fragment
:
Kotlin
class MySettingsActivity : AppCompatActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) supportFragmentManager .beginTransaction() .replace(R.id.settings_container, MySettingsFragment()) .commit() } }
Java
public class MySettingsActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); getSupportFragmentManager() .beginTransaction() .replace(R.id.settings_container, new MySettingsFragment()) .commit(); } }
El resultado se muestra en la siguiente imagen:
Supervisa las preferencias
Para obtener un evento cuando cambia una preferencia, registra un objeto de escucha para ello:
Kotlin
findPreference<SwitchPreferenceCompat>("notifications") ?.setOnPreferenceChangeListener { _, newValue -> Log.d("Preferences", "Notifications enabled: $newValue") true // Return true if the event is handled. } findPreference<Preference>("feedback") ?.setOnPreferenceClickListener { Log.d("Preferences", "Feedback was clicked") true // Return true if the click is handled. }
Java
SwitchPreferenceCompat notificationsPref = findPreference("notifications"); if (notificationsPref != null) { notificationsPref.setOnPreferenceChangeListener((preference, newValue) -> { Log.d("Preferences", String.format("Notifications enabled: %s", newValue)); return true; // Return true if the event is handled. }); } Preference feedbackPref = findPreference("feedback"); if (feedbackPref != null) { feedbackPref.setOnPreferenceClickListener((preference) -> { Log.d("Preferences", "Feedback was clicked"); return true; // Return true if the event is handled. }); }
Leer el valor de preferencia actual
PreferenceFragmentCompat
oculta gran parte del mecanismo involucrado en el guardado y la lectura de las preferencias. Sin embargo, todo se almacena con SharedPreferences
, y puedes leer estos valores como lo haces normalmente con SharedPreferences
:
Kotlin
val preferences = PreferenceManager.getDefaultSharedPreferences(this).all preferences.forEach { Log.d("Preferences", "${it.key} -> ${it.value}") }
Java
var preferences = PreferenceManager.getDefaultSharedPreferences(context).getAll(); preferences.forEach((key, value) ->{ Log.d("Preferences", String.format("%s -> %s", key, value)); });
El fragmento anterior obtiene una instancia del SharedPreferences
predeterminado para la app, accede a todos los valores almacenados, los itera y los imprime en Logcat.