android 使用Drawable实现加载动画效果的按钮

本文介绍了如何使用Android的Drawable实现一个显示下载进度的按钮。通过结合ClipDrawable和LayerDrawable,创建了一个可按百分比填充的进度条效果。详细代码和实现方法在文中提供。
摘要由CSDN通过智能技术生成

前言

最近项目有个需求, 需要一个展示下载状态的按钮, 类似这样:
在这里插入图片描述

这个效果有多种方法都可以实现, 最初的思路是在自定义view里封装一个ProgressBar/Button, 然后根据状态设置两个控件Visibility, 后来想了想还是放弃了ProgressBar, 直接使用了ClipDrawable 作为 BackgroundDrawable 实现的, 感觉更方便一些.

Github 上存有完整代码: https://github.com/YouCii/LearnApp/blob/master/app/src/main/java/com/youcii/mvplearn/widget/DownLoadButton.kt
转载请标明出处, 原文地址:
https://blog.csdn.net/j550341130/article/details/83993676


核心类

1. ClipDrawable
这是一个按比例裁剪的Drawable, 可以使用它实现按百分比进度填充红色的部分. Clip的布局 bg_download_button_clip 具体写法如下:

<clip
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:clipOrientation="horizontal"
    android:drawable="@drawable/bg_download_button_downloading"
    android:gravity="left"/>

其中 android:gravity 是用来设置裁剪起始位置, 有多种属性可以设置, 具体可以搜一下.
内部的 bg_download_button_downloading 就是一个完整填充的红色背景

<shape xmlns:android="http://schemas.android.com/apk/res/android">
    <corners android:radius="100px"/>
    <solid android:color="#D8413A"/>
</shape>

在代码中获取方法与普通Drawable一样

private var solidDrawable: Drawable? = resources.getDrawable(R.drawable.bg_download_button_clip)

然后通过设置solidDrawablelevel来实现进度, level最大是10000, 所以设置进度时需要这样做

solidDrawable?.level = currentPercent * 100

注意, ClipDrawable只是一个按某规则进行裁剪的Drawable, 最外部是没有边框的, 想要一个固定存在的边框的话仅用ClipDrawable就不够了, 需要叠加一个普通的边框Drawable, 这就需要用到LayerDrawable了.

2. LayerDrawable</

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值