Use Shared Preferences to load Preference Settings
In this exercise, we remove the hardcoded preference setting in xml/pref_general.xml
file so SharedPreferences
API will load the users selected preference location. We are able to accomplish this goal by using the SharedPreferenceChangeListener
which will detect when a user has made a change to their preference location setting. Then, if there is a change, we call the Forcast Adapter to query the weather info and refresh the activity.
As I complete these activities, I am finding that I get confused when it comes to identifying the various class, interfaces and API’s. The framework tucks those things nicely away somewhere and you only have to implement and call their methods. For this post, I would like to try and organize my understanding of those api’s, classes and interfaces.
-
Preference Manager - from what I am reading, it is the interface that communicates between the
PreferenceActivity
andSharedPreferences
. It is the glue that connect theSharedPreferences
with the androidactivity
.Preference Manager
is a good resource for handling setting and retrieving default values. -
Shared Preferences - this is the interface that provides methods that will do
CRUD
operations on the file system. -
Preference Object - object used to create the ui preference for a preference activity. The preference key will be stored in
sharedPreference
.
If you haven’t noticed already, the word preference is used a lot and can be confusing when trying to identify the individual parts.