使用系统ProgressBar实现三色进度条

使用系统ProgressBar实现如图三色进度条:

XML 复制代码
//布局中

<ProgressBar
            android:layout_width="0dp"
            android:layout_height="8dp"
            android:layout_marginLeft="16dp"
            app:layout_constraintBottom_toBottomOf="@id/photo"
            app:layout_constraintLeft_toRightOf="@id/photo"
            app:layout_constraintRight_toRightOf="parent"
            android:max="100"
            android:min="0"
            android:progress="10"
            android:progressTint="@color/color_FF71D4F8"
            style="@style/CustomProgressBarStyle"
            android:secondaryProgressTint="@color/color_FF3F66F2"
            android:secondaryProgress="50"/>


//style 样式
 <style name="CustomProgressBarStyle" parent="Widget.AppCompat.ProgressBar.Horizontal">
        <item name="android:progressDrawable">@drawable/bg_process</item>
 </style>

drawable:bg_process.xml

XML 复制代码
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">

    <item android:id="@android:id/background">
        <shape>
            <corners android:radius="4dp" />
            <solid android:color="@color/color_FFC9CBDF" />
        </shape>
    </item>

    <item android:id="@android:id/secondaryProgress">
        <clip>
            <shape>
                <corners android:radius="5dip" />

            </shape>
        </clip>
    </item>

    <item android:id="@android:id/progress">
        <clip>
            <shape>
                <corners android:radius="5dip" />

            </shape>
        </clip>
    </item>

</layer-list>

这个背景图是抄的 Widget.AppCompat.ProgressBar.Horizontal中的背景图的写法:

相关推荐
明道源码19 分钟前
Android Studio 代码编辑区域的使用
android·ide·android studio
小墙程序员2 小时前
从隐私协议了解Android App到底获取了哪些信息
android
小墙程序员2 小时前
Android 5 到 16 期间 service 的发展
android
Android小码家2 小时前
Android8.0+Camera2编译&烧录&源码研习
android·framework
消失的旧时光-19433 小时前
Kotlin 高阶函数在回调设计中的最佳实践
android·开发语言·kotlin
AI智能架构工坊5 小时前
提升AI虚拟健康系统开发效率:架构师推荐10款低代码开发平台
android·人工智能·低代码·ai
百锦再5 小时前
低代码开发的约束性及ABP框架的实践解析
android·开发语言·python·低代码·django·virtualenv·rxjava
那我掉的头发算什么6 小时前
【数据库】navicat的下载以及数据库约束
android·数据库·数据仓库·sql·mysql·数据库开发·数据库架构
明道源码6 小时前
Android Studio 应用运行到真机设备
android·ide·android studio
生莫甲鲁浪戴6 小时前
Android Studio新手开发第二十五天
android·ide·android studio