android 有进度条的下载按钮

本文介绍了如何在Android中创建一个带有进度条的下载按钮,包括按钮在下载过程中的不同状态(可点击、显示下载中、下载完成)的管理,通过自定义ProgressButton组件和设置相应样式来实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  • 需求

    1. 下载按钮颜色,文字显示下载,可点击
    2. 下载过程中有进度显示,文字显示下载中,不可点击
    3. 下载完成后按钮颜色,文字显示下载完成,不可点击
  • 思考

    下载,下载完成可以使用同一个Button显示,下载过程可以使用ProgressBar显示,然后把这个状态切换等一系列逻辑封装成一个自定义view.   
    

  • 实现
    1.首先,因为需要初始化两个view,我们自定义一个ProgressButton 继承RelativeLayout承载这两个view
    2.有view状态切换,这里我们采用简单使用的流式代码
progressButton.setText("下载完成").finish().invalidate();

ProgressButton具体代码

package com.wind.process.progrss.view;

import android.content.Context;
import android.util.AttributeSet;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.ProgressBar;
import android.widget.RelativeLayout;
import android.widget.TextView;

import com.wind.process.progrss.R;

/**
 * Created by jiagf
 */
public class ProgressButton extends RelativeLayout {

    private RelativeLayout viewRoot;
    private TextView progressTv;
    private ProgressBar progressBar;
    private Builder builder;

    public ProgressButton(Context context) {
        super(context);
        initViews();
    }

    public ProgressButton(Context context, AttributeSet attrs) {
        super(context, attrs);
        initViews();

    }

    public ProgressButton(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
        initViews();
    }

    public ProgressButton(Context context, AttributeSet attrs, int defStyleAttr, int defStyleRes) {
        super(context, attrs, defStyleAttr);
        initViews();
    }

    public class Builder {
        private String text;
        private int progress;
        private int progressDrawable;
        private int textSize;

        public Builder setText(String text) {
            this.text = text;
            return this;
        }

        public Builder setProgress(int progress) {
            this.progress = progress;
            return this;
        }

        public Builder setProgressDrawable(int progressDrawable) {
            this.progressDrawable = progressDrawable;
            return this;
        }

        public Builder setTextSize(int textSize) {
            this.textSize = textSize;
            return this;
        }

        public Builder finish(){
            return finish(R.drawable.download_finished);
        }

        public Builder finish(int progressDrawable){
            this.progressDrawable = progressDrawable;
            return this;
        }

        public void invalidate() {
            if (text != null) {
                progressTv.setText(text);
            }
            if (textSize != 0) {
                progressTv.setTextSize(textSize);
            }
            if (progressDrawable != 0) {
                progressBar.setProgressDrawable(getContext().getResources().getDrawable(progressDrawable));
            }
            if (progress != 0) {
                progressBar.setProgress(progress);
                if(progressBar.getVisibility() != View.VISIBLE){
                    progressBar.setVisibility(View.VISIBLE);
                }
            }
        }

    }




    private void initViews() {
        builder = new Builder();
        viewRoot = (RelativeLayout) LayoutInflater.from(getContext()).inflate(R.layout.view_progress_button, null);
        addView(viewRoot, LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT);
        progressBar = (ProgressBar) viewRoot.findViewById(R.id.view_progress_button_pb);
        progressTv = (TextView) viewRoot.findViewById(R.id.view_progress_button_tv);
        progressTv.setText("下载");
    }

    public Builder getBuilder() {
        return builder;
    }

    public Builder setText(String text) {
        builder.setText(text);
        return builder;
    }

    public Builder setProgress(int progress) {
        builder.setProgress(progress);
        return builder;
    }

    public Builder setProgressDrawable(int progressDrawable) {
        builder.setProgressDrawable(progressDrawable);
        return builder;
    }

    public Builder setTextSize(int textSize) {
        builder.setTextSize(textSize);
        return builder;
    }




}

ProgressBar样式

<?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="20dp" />

            <solid android:color="@color/green" />
            <stroke android:color="#f0ffffff" android:width="1dp"/>
            <padding android:left="1dp" android:top="1dp" android:right="1dp" android:bottom="1dp"/>
        </shape>
    </item>
    <!-- 进度条 -->
    <item android:id="@android:id/progress">
        <clip>
            <shape>
                <corners android:radius="20dp" />

                <solid android:color="@color/red" />
            </shape>
        </clip>
    </item>

</layer-list>

下载地址

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值