如何使用 Kotlin 在 Android 中建立圓形進度條?


本示例演示如何使用 Kotlin 在 Android 中建立圓形進度條。

步驟 1 − 在 Android Studio 中新建一個專案,轉到檔案 ⇒ 新建專案,然後填寫所有必需的詳細資訊以新建一個專案。

步驟 2 − 將以下程式碼新增到 res/layout/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:padding="8dp"
   tools:context=".MainActivity">
   <TextView
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_centerHorizontal="true"
      android:layout_marginTop="70dp"
      android:background="#008080"
      android:padding="5dp"
      android:text="TutorialsPoint"
      android:textColor="#fff"
      android:textSize="24sp"
      android:textStyle="bold" />
   <ProgressBar
      android:id="@+id/circularProgressbar"
      style="?android:attr/progressBarStyleHorizontal"
      android:layout_width="250dp"
      android:layout_height="250dp"
      android:layout_centerInParent="true"
      android:indeterminate="false"
      android:max="100"
      android:progress="50"
      android:secondaryProgress="100" />
   <TextView
      android:id="@+id/textView"
      android:layout_width="250dp"
      android:layout_height="250dp"
      android:layout_centerInParent="true"
      android:gravity="center"
      android:text="25%"
      android:textColor="@color/colorPrimaryDark"
      android:textSize="24sp" />
</RelativeLayout>

步驟 3 − 建立一個可繪製的資原始檔(circularprogressbar.xml),然後新增以下程式碼

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:tools="http://schemas.android.com/tools"
   xmlns:android="http://schemas.android.com/apk/res/android"
   tools:ignore="ExtraText">
   android:layout_width="wrap_content"
   android:layout_height="wrap_content">
   <item android:id="@android:id/secondaryProgress">
   <shape
      android:innerRadiusRatio="6"
      android:shape="ring"
      android:thicknessRatio="20.0"
      android:useLevel="true">
      <gradient
         android:centerColor="@android:color/holo_green_light"
         android:endColor="@android:color/holo_red_dark"
         android:startColor="@android:color/white"
         android:type="sweep" />
      </shape>
   </item>
   <item android:id="@android:id/progress">
      <rotate
         android:fromDegrees="270"
         android:pivotX="50%"
         android:pivotY="50%"
         android:toDegrees="270">
         <shape
            android:innerRadiusRatio="6"
            android:shape="ring"
            android:thicknessRatio="20.0"
            android:useLevel="true">
            <gradient
               android:centerColor="@android:color/holo_blue_dark"
               android:endColor="@android:color/holo_purple"
               android:startColor="@android:color/holo_orange_dark"
               android:type="sweep" />
            <rotate
               android:fromDegrees="0"
               android:pivotX="50%"
               android:pivotY="50%"
               android:toDegrees="360" />
         </shape>
      </rotate>
   </item>
   <item android:id="@android:id/secondaryProgress">
      <shape
         android:innerRadiusRatio="6"
         android:shape="ring"
         android:thicknessRatio="20.0"
         android:useLevel="true">
         <gradient
            android:centerColor="@android:color/holo_blue_dark"
            android:endColor="@android:color/holo_purple"
            android:startColor="@android:color/holo_orange_dark"
            android:type="sweep" />
      </shape>
   </item>
</layer-list>

步驟 4 − 將以下程式碼新增到 src/MainActivity.kt 中

import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import android.os.Handler
import android.widget.ProgressBar
import android.widget.TextView
class MainActivity : AppCompatActivity() {
   internal var status = 0
   private val handler = Handler()
   lateinit var textView: TextView
   override fun onCreate(savedInstanceState: Bundle?) {
      super.onCreate(savedInstanceState)
      setContentView(R.layout.activity_main)
      title = "KotlinApp"
      val resources = resources
      val drawable = resources.getDrawable(R.drawable.circularprogressbar)
      val progressBar: ProgressBar = findViewById(R.id.circularProgressbar)
      progressBar.progress = 0
      progressBar.secondaryProgress = 100
      progressBar.max = 100
      progressBar.progressDrawable = drawable
      textView = findViewById(R.id.textView)
      Thread {
         while (status < 100) {
            status += 1
            handler.post {
               progressBar.progress = status
               textView.text = String.format("%d%%", status)
            }
            try {
               Thread.sleep(16)
            }
            catch (e: InterruptedException) {
               e.printStackTrace()
            }
         }
      }.start()
   }
}

步驟 5 − 將以下程式碼新增到 androidManifest.xml 中

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
   package="com.example.q11">
   <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>

讓我們嘗試執行你的應用程式。我假設你已將實際的安卓移動裝置連線到你的電腦。要從 android studio 執行該應用,開啟你專案中的其中一個活動檔案,然後單擊工具欄中的執行圖示Play 。選擇你的移動裝置作為選項,然後檢視將顯示預設介面的移動裝置。


更新日期: 2020 年 11 月 30 日

2K+ 次瀏覽

開啟你的 職業生涯

完成課程並獲得認證

立即開始
廣告