在Android中,要實現(xiàn)ProgressBar的分段顯示,可以通過設置android:indeterminate
屬性為false
,并添加自定義的進度條樣式。以下是實現(xiàn)分段顯示的步驟:
res/drawable
目錄下創(chuàng)建一個新的XML文件,例如progress_drawable.xml
,并添加以下內容:<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<item android:id="@android:id/secondaryProgress">
<clip>
<shape>
<corners android:radius="4dp" />
<gradient
android:startColor="#80FF80"
android:centerColor="#80FF80"
android:centerY="0.75"
android:endColor="#80FF80"
android:angle="270" />
</shape>
</clip>
</item>
<item android:id="@android:id/progress">
<clip>
<shape>
<corners android:radius="4dp" />
<gradient
android:startColor="#FF0000"
android:centerColor="#FF0000"
android:centerY="0.75"
android:endColor="#FF0000"
android:angle="270" />
</shape>
</clip>
</item>
</layer-list>
這個文件定義了一個帶有兩個進度條的漸變背景,一個是主要進度條(紅色),另一個是次要進度條(綠色)。
android:indeterminate
屬性設置為false
,同時將android:progressDrawable
屬性設置為我們剛剛創(chuàng)建的progress_drawable.xml
文件:<ProgressBar
android:id="@+id/progressBar"
style="?android:attr/progressBarStyleHorizontal"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:indeterminate="false"
android:max="100"
android:progress="50"
android:progressDrawable="@drawable/progress_drawable" />
// 獲取ProgressBar實例
ProgressBar progressBar = findViewById(R.id.progressBar);
// 設置主要進度條的值
int primaryProgress = 75;
progressBar.setProgress(primaryProgress);
// 設置次要進度條的值
int secondaryProgress = 25;
progressBar.setSecondaryProgress(secondaryProgress);
這樣,你就可以實現(xiàn)一個具有分段顯示效果的ProgressBar。