android kotlin - Notification progress bar percentage

MainActivity.kt

package com.cfsuman.kotlintutorials

import android.app.*
import android.content.Context
import android.os.Build
import android.os.Bundle
import android.os.Handler
import android.os.Looper
import android.widget.Button
import androidx.core.app.NotificationCompat
import androidx.core.app.NotificationManagerCompat


class MainActivity : Activity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        // get the context
        val context = this

        // get the widgets reference from XML layout
        val button = findViewById<Button>(R.id.button)


        // Create and register notification channel api 26+
        val channelId = "My_Channel_ID"
        val notificationId = 1
        createNotificationChannel(channelId)


        // button click listener
        button.setOnClickListener{
            val builder = NotificationCompat.Builder(context,channelId)
                .setContentTitle("Download Task")
                .setContentText("Downloading your file...")
                .setSmallIcon(R.drawable.ic_action_help)

            val max = 25
            var progress = 0
            var percentage = 0
            val handler = Handler(Looper.getMainLooper())

            with(NotificationManagerCompat.from(context)){
                builder.setProgress(max,progress,true)
                notify(notificationId,builder.build())

                Thread(Runnable{
                    while (progress < max){
                        progress +=1

                        try {
                            Thread.sleep(1000)
                        }catch (e:InterruptedException){
                            e.printStackTrace()
                        }

                        handler.post(Runnable {
                            if (progress == max){
                                builder.setContentText("Download complete.")
                                builder.setProgress(0,0,false)
                            }else{
                                // Calculate the percentage comple
                                percentage = (progress*100)/max
                                builder.setContentText(
                                    "$percentage% complete $progress of $max")
                                builder.setProgress(max,progress,true)
                            }

                            notify(notificationId,builder.build())
                        })
                    }
                }).start()
            }
        }
    }



    // create notification channel
    private fun createNotificationChannel(channelId:String) {
        // Create the NotificationChannel,
        // but only on API 26+ (Android 8.0) because
        // the NotificationChannel class is new and
        // not in the support library
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O){
            val name = "My Channel"
            val channelDescription = "Channel Description"
            val importance = NotificationManager.IMPORTANCE_DEFAULT

            val channel = NotificationChannel(channelId,name,importance)
            channel.apply {
                description = channelDescription
            }

            // Finally register the channel with system
            val notificationManager = getSystemService(
                Context.NOTIFICATION_SERVICE) as NotificationManager
            notificationManager.createNotificationChannel(channel)
        }
    }
}
activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#DCDCDC"
    android:id="@+id/rootLayout"
    android:padding="24dp">

    <Button
        android:id="@+id/button"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Show Notification"
        android:textAllCaps="false"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

</androidx.constraintlayout.widget.ConstraintLayout>
AndroidManifest.xml [Permission]

<uses-permission android:name="android.permission.POST_NOTIFICATIONS" />
More android examples