如何使用 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 執行該應用,開啟你專案中的其中一個活動檔案,然後單擊工具欄中的執行圖示 。選擇你的移動裝置作為選項,然後檢視將顯示預設介面的移動裝置。
廣告