Create ProgressView with Animations in Android

Source link:

Here an example how to create ProgressView with Animations in Android. You can add this libary on your project. Thanks for @skydoves,

ProgressView License

License API API Android Weekly API

A polished and flexible ProgressView, fully customizable with animations.

Including in your project

Download Jitpack


Add below codes to your root build.gradle file (not your module build.gradle file).

allprojects {

  repositories {


And add a dependency code to your module s build.gradle file.

dependencies {

  implementation "com.github.skydoves:progressview:1.0.1" 


Add following XML namespace inside your XML layout file.



Here is a basic example of implementing ProgressView.

app:progressView_colorBackground="@color/white" // the color of the container.
app:progressView_colorProgress="@color/skyBlue" // the color of the progress bar.
app:progressView_progress="40" // progress value.
app:progressView_max="100" // max progress value.
app:progressView_autoAnimate="true" // starts filling animation automatically when finishing inflate.
app:progressView_radius="12dp" // the corner radius of the progressView and progress bar.
app:progressView_padding="1dp" // the padding of the progress bar.
app:progressView_labelColorInner="@color/white" // the text color when the label placed on the progress bar.
app:progressView_labelColorOuter="@color/black" // the text color when the label placed out of the progress bar.
app:progressView_labelSize="13sp" // the label text size.
app:progressView_labelSpace="10dp" // the space size of the between label and progress bar. 
app:progressView_labelText="achieve 65%" // the text of the label.
app:progressView_labelTypeface="bold" // the typeface of the label.  />


We can give a gradient effect to the progress bar using the below attributes.

app:progressView_colorGradientStart="@color/md_yellow_100" // starting color of the gradient. app:progressView_colorGradientEnd="@color/md_yellow_200" // ending color of the gradient.

Filling Animation

We can implement the filling animation using below attributes or method.

app:progressView_autoAnimate="true" // starts filling animation automatically when progress is changed.

or we can animate manually using below method.


Hilighting Effect

We can give a highlighting effect on the progress bar when clicked.

app:progressView_highlighting="true" // gives the highlighting effect or not. app:progressView_highlightAlpha="0.8" // the alpha of the highlight. app:progressView_highlightColor="@color/skyBlue" // the color of the highlight. app:progressView_highlightWidth="1.5dp" // the thickness of the highlight. app:progressView_padding="1.5dp" // the padding of the progress bar.

OnProgressChangeListener, OnProgressClickListener

We can listen to the progress value is changed or the progressbar is clicked.

progressView.setOnProgressChangeListener(new OnProgressChangeListener() {

public void onChange(float progress) {

  progressView.setLabelText(progress + "% archived");

  progressView.setOnProgressClickListener(new OnProgressClickListener() {

public void onClickProgress(boolean highlighting) {

  // do something


We can simplify it using kotlin.

progressView.setOnProgressChangeListener {
 progressView.labelText = "achieve ${
 progressView.setOnProgressClickListener {
 Toast.makeText(baseContext, "clicked", Toast.LENGTH_SHORT).show() 

Vertical Orientation

We can implement the ProgressView vertically using the below option.
We should set the width and height value like vertical shape.




TextFrom is an attribute class that has some attributes about TextView for customizing ProgressView s label.

TextForm textForm = TextForm.Builder(context)
  .setText("This is a TextForm")

This is how to create TextForm using kotlin dsl.

val form = textForm(context) {

text = "This is a TextForm"
textColor = ContextCompat.getColor(baseContext, R.color.white_87)
textSize = 14f
textTypeface = Typeface.BOLD 

Create using Builder

We can create the ProgressView using ProgressView.Builder.

ProgressView progressView = new ProgressView.Builder(context)
  .setSize(300, 35)
  .setLabelColorInner(ContextCompat.getColor(context, R.color.white))
  .setLabelText("archive 70%")

This is how to create an instance of the ProgressView using kotlin dsl.

val myProgressView = progressView(context) {

  setSize(300, 35)
  setLabelColorInner(ContextCompat.getColor(context, R.color.white))
  setLabelText("archive 70%")

ProgressView Attributes

Here are attributes of the ProgressView and ProgressView.Builder.


Attributes Type Default Description
orientation ProgressViewOrientation Horizontal ProgressView s orientation.
progress Float 0f value of the progress.
max Float 100f value of the maximum progress. the progress value can not over the max value.
radius Dimension 8dp corner radius of the ProgressView.
padding Dimension 0dp padding of the prograssbar.
duration Long 1000L duration of the animation.
colorProgress Int(Color) colorPrimary color of the progressbar.
colorBackground Int(Color) Color.WHITE color of the container.
colorGradientStart Int(Color) colorPrimary starting color of the gradient.
colorGradientEnd Int(Color) colorPrimary ending color of the gradient.
autoAnimate Boolean true starts filling animation automatically when finishing inflate.


Attributes Type Default Description
labelText String "" text of the progressbar label.
labelSize Dimension 12p text size of the progressbar label.
labelColorInner Int(Color) colorPrimary text color when the label placed on the progress bar.
labelColorOuter Int(Color) colorPrimary text color when the label placed out of the progress bar.
labelSpace Dimension 8dp space size of the between label and progress bar.
labelTypeface Typeface Typeface.NORMAL typeface of the label.


Attributes Type Default Description
highlighting Boolean false highlights the progressbar when clicked.
highlightColor Int(Color) colorPrimary color of the highlighting effect.
highlightAlpha Float 1f alpha of the highlighting effect.
highlightWidth Float 0dp thickness of the highlighting effect.

Find this library useful? ❤️

Support it by joining stargazers for this repository. ⭐️


Copyright 2019 skydoves (Jaewoong Eum)  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  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.


Noodle is a very simple object storage and persistence library for Android.

No schema, no relations, no consistency rules, no thread-contained objects. You can use it as a key-value storage or collections - which are similar to tables, but not really.

Simple custom view of a beating heart using scaling animation. Has option to set the duration of animation based on BPM (beats per minute).

Are you tired of creating a new DialogFragment for each Dialog that you want to display?

This is an Android library that provides a simple implementation of a DialogFragment. It allows to define the content of the Dialog (and its button listeners) without having to create a new DialogFragment subclass.

Android App starter based on Android + MVP + Dagger2 + RxJava2 + Robolectric + Espresso + Mockito + JaCoCo.

Floating-ArcMenu A prety menu for all application

Android floating arc menu which reacts on scrolling events. Becomes visible when an attached target is scrolled up and invisible when scrolled down.

Ever get stuck with iOS image resources? Rather than write your own script, use this one to rename and move iOS image resources so they work for Android. Now converting iOS resources to Android ones is easy!


2D Engines   3D Engines   9-Patch   Action Bars   Activities   ADB   Advertisements   Analytics   Animations   ANR   AOP   API   APK   APT   Architecture   Audio   Autocomplete   Background Processing   Backward Compatibility   Badges   Bar Codes   Benchmarking   Bitmaps   Bluetooth   Blur Effects   Bread Crumbs   BRMS   Browser Extensions   Build Systems   Bundles   Buttons   Caching   Camera   Canvas   Cards   Carousels   Changelog   Checkboxes   Cloud Storages   Color Analysis   Color Pickers   Colors   Comet/Push   Compass Sensors   Conferences   Content Providers   Continuous Integration   Crash Reports   Credit Cards   Credits   CSV   Curl/Flip   Data Binding   Data Generators   Data Structures   Database   Database Browsers   Date &   Debugging   Decompilers   Deep Links   Dependency Injections   Design   Design Patterns   Dex   Dialogs   Distributed Computing   Distribution Platforms   Download Managers   Drawables   Emoji   Emulators   EPUB   Equalizers &   Event Buses   Exception Handling   Face Recognition   Feedback &   File System   File/Directory   Fingerprint   Floating Action   Fonts   Forms   Fragments   FRP   FSM   Functional Programming   Gamepads   Games   Geocaching   Gestures   GIF   Glow Pad   Gradle Plugins   Graphics   Grid Views   Highlighting   HTML   HTTP Mocking   Icons   IDE   IDE Plugins   Image Croppers   Image Loaders   Image Pickers   Image Processing   Image Views   Instrumentation   Intents   Job Schedulers   JSON   Keyboard   Kotlin   Layouts   Library Demos   List View   List Views   Localization   Location   Lock Patterns   Logcat   Logging   Mails   Maps   Markdown   Mathematics   Maven Plugins   MBaaS   Media   Menus   Messaging   MIME   Mobile Web   Native Image   Navigation   NDK   Networking   NFC   NoSQL   Number Pickers   OAuth   Object Mocking   OCR Engines   OpenGL   ORM   Other Pickers   Parallax List   Parcelables   Particle Systems   Password Inputs   PDF   Permissions   Physics Engines   Platforms   Plugin Frameworks   Preferences   Progress Indicators   ProGuard   Properties   Protocol Buffer   Pull To   Purchases   Push/Pull   QR Codes   Quick Return   Radio Buttons   Range Bars   Ratings   Recycler Views   Resources   REST   Ripple Effects   RSS   Screenshots   Scripting   Scroll Views   SDK   Search Inputs   Security   Sensors   Services   Showcase Views   Signatures   Sliding Panels   Snackbars   SOAP   Social Networks   Spannable   Spinners   Splash Screens   SSH   Static Analysis   Status Bars   Styling   SVG   System   Tags   Task Managers   TDD &   Template Engines   Testing   Testing Tools   Text Formatting   Text Views   Text Watchers   Text-to   Toasts   Toolkits For   Tools   Tooltips   Trainings   TV   Twitter   Updaters   USB   User Stories   Utils   Validation   Video   View Adapters   View Pagers   Views   Watch Face   Wearable Data   Wearables   Weather   Web Tools   Web Views   WebRTC   WebSockets   Wheel Widgets   Wi-Fi   Widgets   Windows   Wizards   XML   XMPP   YAML   ZIP Codes