Step 1. Add the JitPack repository to your build file
Add it in your root settings.gradle at the end of repositories:
dependencyResolutionManagement {
repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
repositories {
mavenCentral()
maven { url 'https://jitpack.io' }
}
}
Add it in your settings.gradle.kts at the end of repositories:
dependencyResolutionManagement {
repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
repositories {
mavenCentral()
maven { url = uri("https://jitpack.io") }
}
}
Add to pom.xml
<repositories>
<repository>
<id>jitpack.io</id>
<url>https://jitpack.io</url>
</repository>
</repositories>
Add it in your build.sbt at the end of resolvers:
resolvers += "jitpack" at "https://jitpack.io"
Add it in your project.clj at the end of repositories:
:repositories [["jitpack" "https://jitpack.io"]]
Step 2. Add the dependency
dependencies {
implementation 'com.github.EnterPrayz:icepick:3.0.0'
}
dependencies {
implementation("com.github.EnterPrayz:icepick:3.0.0")
}
<dependency>
<groupId>com.github.EnterPrayz</groupId>
<artifactId>icepick</artifactId>
<version>3.0.0</version>
</dependency>
libraryDependencies += "com.github.EnterPrayz" % "icepick" % "3.0.0"
:dependencies [[com.github.EnterPrayz/icepick "3.0.0"]]
Icepick is an Android library that simplifies the lifecycle of save and restore instance state. It uses annotation processing to generate code that does bundle manipulation and key generation, removing lots of boilerplate from your classes.
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:3.0.0'
provided 'frankiesardo:icepick-processor:3.0.0'
}
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>3.0.0</version>
</dependency>
<dependency>
<groupId>frankiesardo</groupId>
<artifactId>icepick-processor</artifactId>
<version>3.0.0</version>
<optional>true</optional>
</dependency>
</dependencies>
Copyright 2013 Frankie Sardo
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.