This library for Android provides classes which allow to store and retrieve settings from the preferences. There is an individual class for each native type:
BooleanPreference
for aboolean
valueDoublePreference
for adouble
valueFloatPreference
for afloat
valueIntPreference
for anint
valueLongPreference
for along
valueShortPreference
for ashort
valueStringPreference
for aString
value
Each class comes with two constructors - one of them allows to ommit the default value.
All classes declare the same methods: get()
, isSet()
, set()
and delete()
.
Here are the method signatures as definied in the StringPreference
class.
public class StringPreference {
public String get() { ... }
public boolean isSet() { ... }
public void set(String value) { ... }
public void delete() { ... }
}
Wrappers for frequently used classes can be found and added in the wiki. Take a look!
Add the library as a dependency to your build.gradle
in case you use Gradle:
dependencies {
compile "info.metadude.android:typed-preferences:{$version}"
}
Or if you use Maven you should be looking for this:
<dependency>
<groupId>info.metadude.android</groupId>
<artifactId>typed-preferences</artifactId>
<version>{$version}</version>
</dependency>
For anything else, go to Maven Central - or just build the library yourself.
The library is available in two different versions. If you need to support API level 8 in your project you must include the latest 1.x.x version. This library version persists the settings synchronously using the commit
method of the SharedPreferences.Editor
. If the minimum SDK version you need to support is API level 9 you can choose the latest 2.x.x version which relies on the apply
method of the SharedPreferences.Editor
. Thereby settings are persisted asynchronously.
For further information please stick to documentation of the SharedPreferences.Editor
interface.
Check out the demo project TypedPreferencesDemo
which shows how to use the library.
Run ./gradlew clean test
to execute the tests.
If you use this library and you are happy with it please send a tweet to @tbsprs and feel free to announce your app. I will be happy to list it here.
In case you do not like the library please do not hesitate to open an issue and let me know what can be improved.
This library is mainly inspired by the classes which have been published by Jake Wharton in the u2020 project.
Copyright 2014-2021 Tobias Preuss
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.