Icepick is an Android library that eliminates the boilerplate of saving and restoring instance state. It uses annotation processing to generate code that does bundle manipulation and key generation, so that you don't have to write it yourself.
class ExampleActivity extends Activity {
@Icicle String username; // This will be automatically saved and restored
@Override public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
Icepick.restoreInstanceState(this, savedInstanceState);
}
@Override public void onSaveInstanceState(Bundle outState) {
super.onSaveInstanceState(outState);
Icepick.saveInstanceState(this, outState);
}
// You can put the calls to Icepick into a BaseActivity
// All Activities extending BaseActivity automatically have state saved/restored
}
Icepick can also generate the instance state code for your Custom Views:
class CustomView extends View {
@Icicle int selectedPosition; // This will be automatically saved and restored
@Override public Parcelable onSaveInstanceState() {
return Icepick.saveInstanceState(this, super.onSaveInstanceState());
}
@Override public void onRestoreInstanceState(Parcelable state) {
super.onRestoreInstanceState(Icepick.restoreInstanceState(this, state));
}
// You can put the calls to Bundles into a BaseCustomView and inherit from it
// All Views extending this CustomView automatically have state saved/restored
}
If Proguard is enabled make sure you add these rules to your configuration:
-dontwarn icepick.**
-keep class **$$Icicle { *; }
-keepnames class * { @icepick.Icicle *;}
Icepick needs two libraries: icepick
and icepick-processor
.
Gradle:
repositories {
maven {url "https://clojars.org/repo/"}
}
dependencies {
compile 'frankiesardo:icepick:{{latest-version}}'
provided 'frankiesardo:icepick-processor:{{latest-version}}'
}
Maven:
<repositories>
<repository>
<id>clojars</id>
<url>https://clojars.org/repo/</url>
<snapshots>
<enabled>true</enabled>
</snapshots>
<releases>
<enabled>true</enabled>
</releases>
</repository>
</repositories>
<dependencies>
<dependency>
<groupId>frankiesardo</groupId>
<artifactId>icepick</artifactId>
<version>{{latest-version}}</version>
</dependency>
<dependency>
<groupId>frankiesardo</groupId>
<artifactId>icepick-processor</artifactId>
<version>{{latest-version}}</version>
<optional>true</optional>
</dependency>
</dependencies>