【发布时间】:2017-09-09 07:46:53
【问题描述】:
【问题讨论】:
-
欢迎来到 SO .. 在发布问题 stackoverflow.com/help/how-to-ask 之前阅读此内容。
标签: android
【问题讨论】:
标签: android
为progressbar创建自定义drawable,并使用属性android:progressDrawable设置自定义drawable。
试试这个:
<ProgressBar
android:id="@+id/ProgressBar"
style="?android:attr/progressBarStyleHorizontal"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:indeterminate="false"
android:maxHeight="14dip"
android:minHeight="14dip"
android:progress="75"
android:progressDrawable="@drawable/custom_progressbar" />
custom_progressbar.xml:
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<!-- background color -->
<item android:id="@android:id/background">
<shape>
<solid android:color="#D9D9D9" />
<corners android:radius="10dp"/>
</shape>
</item>
<!-- progress color -->
<item android:id="@android:id/progress">
<clip>
<shape>
<solid android:color="#F1C40F" />
<corners android:radius="10dp"/>
</shape>
</clip>
</item>
</layer-list>
输出:
【讨论】:
使用原生 ProgressBar 并将可绘制对象设置为其“android:progressDrwable”。 drawable 看起来像这样:
<!-- background -->
<item android:id="@android:id/background">
<shape>
<corners android:radius="4dp" />
<solid android:color="#000000" />
</shape>
</item>
<!-- progress -->
<item android:id="@android:id/progress">
<clip>
<shape>
<corners android:radius="4dp" />
<solid android:color="#000000" />
</shape>
</clip>
</item>
<!-- second progress -->
<item android:id="@android:idcondaryProgress">
<clip>
<shape>
<corners android:radius="4dp" />
<solid android:color="#000000" />
</shape>
</clip>
</item>
【讨论】: