AndroidManifest.xml:
MainActivity.java:
activity_main.xml:
circular_progress_bar.xml: under res/drawable
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.blogspot.codingatharva.manualprograms"> <application android:allowBackup="true" android:icon="@mipmap/ic_launcher" android:label="@string/app_name" android:roundIcon="@mipmap/ic_launcher_round" android:supportsRtl="true" android:theme="@style/AppTheme"> <activity android:name=".MainActivity"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> </application> </manifest>
MainActivity.java:
package com.blogspot.codingatharva.manualprograms;
import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.ProgressBar;
public class MainActivity extends AppCompatActivity {
Button b;
ProgressBar pb;
private int progressStatus = 0;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
b = findViewById(R.id.btn);
pb = findViewById(R.id.progressBar);
b.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
startProgress(v);
}
});
}
public void startProgress(View view) {
pb.setProgress(0);
new Thread(new Task()).start();
}
class Task implements Runnable {
@Override
public void run() {
for (int i = 0; i <= 10; i++) {
final int value = i;
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
pb.setProgress(value);
}
}
}
}
activity_main.xml:
<?xml version= "1.0" encoding= "utf-8" ?> <RelativeLayout xmlns:android = "http://schemas.android.com/apk/res/android" xmlns:tools = "http://schemas.android.com/tools" android:layout_width= "match_parent" android:layout_height= "match_parent" android:layout_margin= "16dp" tools:context= ".MainActivity" > <ProgressBar android:id= "@+id/progressBar" style= "?android:attr/progressBarStyleHorizontal" android:layout_width= "200dp" android:layout_height= "200dp" android:layout_centerInParent= "true" android:background= "@drawable/circular_shape" android:indeterminate= "false" android:max= "100" android:progress= "0" android:progressDrawable= "@drawable/circular_progress_bar" /> <Button android:id="@+id/btn" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center" android:layout_below="@+id/progressBar" android:text="Start"/> </RelativeLayout>
circular_progress_bar.xml: under res/drawable
<?xml version="1.0" encoding="utf-8"?>
<rotate xmlns:android = "http://schemas.android.com/apk/res/android"
android:fromDegrees= "270"
android:toDegrees= "270" >
<shape
android:innerRadiusRatio= "2.5"
android:shape= "ring"
android:thickness= "1dp"
android:useLevel= "true" > <!-- this line fixes the issue for lollipop api 21 -->
<gradient
android:angle= "0"
android:endColor= "#007DD6"
android:startColor= "#007DD6"
android:type= "sweep"
android:useLevel= "false" />
</shape>
</rotate>
circular_shape.xml: under res/drawable
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android = "http://schemas.android.com/apk/res/android"
android:innerRadiusRatio= "2.5"
android:shape= "ring"
android:thickness= "1dp"
android:useLevel= "false" >
<solid android:color= "#CCC" />
</shape>
