Android仿字节颜色自定义进度条

本文实例为大家分享了Android仿字节颜色自定义进度条的具体代码,供大家参考,具体内容如下

效果展示

代码实现

第一步:编写自定义属性

res/values/attrs.xml

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <declare-styleable name="MyLoadingView">
        <attr name="loading_color_one" format="color"/>
        <attr name="loading_color_two" format="color"/>
        <attr name="loading_color_three" format="color"/>
        <attr name="loading_color_four" format="color"/>
        <attr name="loading_color_five" format="color"/>
    </declare-styleable>
</resources>

第二步:编写自定义java类

package com.wust.jingdutiao;

import android.animation.ValueAnimator;
import android.content.Context;
import android.content.res.TypedArray;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.RectF;
import android.graphics.drawable.ColorDrawable;
import android.graphics.drawable.Drawable;
import android.util.AttributeSet;
import android.util.TypedValue;
import android.view.View;
import android.view.animation.Animation;

import androidx.annotation.Nullable;

/**
 * ClassName: MyLodingView <br/>
 * Description: <br/>
 * date: 2021/7/21 15:59<br/>
 *
 * @author yiqi<br />
 * @QQ 1820762465
 * @微信 yiqiideallife
 * @技术交流QQ群 928023749
 */
public class MyLoadingView extends View {

    private int rect_color_one;
    private int rect_color_two;
    private int rect_color_three;
    private int rect_color_four;
    private int rect_color_five;
    private Paint rect_one_paint;
    private Paint rect_two_paint;
    private Paint rect_three_paint;
    private Paint rect_four_paint;
    private Paint rect_five_paint;
    private int mWidth;
    private int mHeight;
    private float[] mHeightRate = {1/16.0f,1/10.0f,1/8.0f};
    private int HORIZONTAL_OFFSET = 5;
    private int bg_default_color;
    private ValueAnimator va;

    public MyLoadingView(Context context) {
        super(context);
    }

    public MyLoadingView(Context context, @Nullable AttributeSet attrs) {
        super(context, attrs);
        initAttrs(context, attrs);
        initPaint();
        initAnima();
    }

    public MyLoadingView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
        initAttrs(context, attrs);
        initPaint();
        initAnima();
    }

    //设置 属性动画
    private void initAnima() {
        va = ValueAnimator.ofInt(0, 4);
        va.setDuration(3000);
        va.setRepeatCount(ValueAnimator.INFINITE);
        va.setRepeatMode(ValueAnimator.RESTART);
        va.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
            @Override
            public void onAnimationUpdate(ValueAnimator animation) {
                int value = (int) animation.getAnimatedValue();
                setRectColorByNum(value);
            }
        });
        postDelayed(new Runnable() {
            @Override
            public void run() {
                va.start();
            }
        },500);
    }

    private void initAttrs(Context context, AttributeSet attrs) {
        //获取用户传来的五种颜色
        TypedArray ty = context.obtainStyledAttributes(attrs, R.styleable.MyLoadingView);

        rect_color_one = ty.getColor(R.styleable.MyLoadingView_loading_color_one, Color.parseColor("#325AB4"));
        rect_color_two = ty.getColor(R.styleable.MyLoadingView_loading_color_two, Color.parseColor("#3C8CFF"));
        rect_color_three = ty.getColor(R.styleable.MyLoadingView_loading_color_three, Color.parseColor("#888888"));
        rect_color_four = ty.getColor(R.styleable.MyLoadingView_loading_color_four, Color.parseColor("#00C8D2"));
        rect_color_five = ty.getColor(R.styleable.MyLoadingView_loading_color_five, Color.parseColor("#78E6DC"));

        //获取背景色
        try {
            ColorDrawable bg = (ColorDrawable) getBackground();
            bg_default_color = bg.getColor();
        }catch (Exception e){
            bg_default_color = Color.WHITE;
        }

        ty.recycle();
    }

    //初始化画笔
    private void initPaint() {
        rect_one_paint = getPaintByColor(rect_color_one);
        rect_two_paint = getPaintByColor(rect_color_two);
        rect_three_paint = getPaintByColor(rect_color_three);
        rect_four_paint = getPaintByColor(rect_color_four);
        rect_five_paint = getPaintByColor(rect_color_five);
    }

    private Paint getPaintByColor(int Color) {
        Paint paint = new Paint();
        paint.setAntiAlias(true);
        paint.setDither(true);
        paint.setColor(Color);
        return paint;
    }

    @Override
    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
        mWidth = MeasureSpec.getSize(widthMeasureSpec);
        mHeight = MeasureSpec.getSize(heightMeasureSpec);
        //让其为正方形,并且宽高不能小于40
        mWidth = mHeight = Math.max(Math.min(mWidth, mHeight),dp2px(100));
        setMeasuredDimension(mWidth, mHeight);
    }

    private int dp2px(int value) {
        return (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP,value,getResources().getDisplayMetrics());
    }

    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);
        //绘制矩形
        drawRect(canvas);

    }

    private void drawRect(Canvas canvas) {
        int centerX = mWidth/2;
        int centerY = mHeight/2;
        RectF rectOne = new RectF(centerX-HORIZONTAL_OFFSET,
                centerY-mWidth*mHeightRate[0],
                centerX+HORIZONTAL_OFFSET,
                centerY+mWidth*mHeightRate[0]);
        canvas.drawRoundRect(rectOne,5,5,rect_one_paint);

        RectF rectTwo = new RectF(centerX+HORIZONTAL_OFFSET*3,
                centerY-mWidth*mHeightRate[1],
                centerX+HORIZONTAL_OFFSET*5,
                centerY+mWidth*mHeightRate[1]);
        canvas.drawRoundRect(rectTwo,5,5,rect_two_paint);

        RectF rectThree = new RectF(centerX-HORIZONTAL_OFFSET*3,
                centerY-mWidth*mHeightRate[1],
                centerX-HORIZONTAL_OFFSET*5,
                centerY+mWidth*mHeightRate[1]);
        canvas.drawRoundRect(rectThree,5,5,rect_three_paint);

        RectF rectFour = new RectF(centerX+HORIZONTAL_OFFSET*7,
                centerY-mWidth*mHeightRate[2],
                centerX+HORIZONTAL_OFFSET*9,
                centerY+mWidth*mHeightRate[2]);
        canvas.drawRoundRect(rectFour,5,5,rect_four_paint);

        RectF rectFive = new RectF(centerX-HORIZONTAL_OFFSET*7,
                centerY-mWidth*mHeightRate[2],
                centerX-HORIZONTAL_OFFSET*9,
                centerY+mWidth*mHeightRate[2]);
        canvas.drawRoundRect(rectFive,5,5,rect_five_paint);
    }

    //根据属性动画的 变化的值 给画笔换不同的颜色
    private void setRectColorByNum(int num){
        if (num == 0){
            rect_one_paint.setColor(rect_color_one);
            rect_two_paint.setColor(bg_default_color);
            rect_three_paint.setColor(bg_default_color);
            rect_four_paint.setColor(bg_default_color);
            rect_five_paint.setColor(bg_default_color);
        }else if (num == 1){
            rect_one_paint.setColor(bg_default_color);
            rect_two_paint.setColor(rect_color_two);
            rect_three_paint.setColor(rect_color_three);
            rect_four_paint.setColor(bg_default_color);
            rect_five_paint.setColor(bg_default_color);
        }else if (num == 2){
            rect_one_paint.setColor(bg_default_color);
            rect_two_paint.setColor(bg_default_color);
            rect_three_paint.setColor(bg_default_color);
            rect_four_paint.setColor(rect_color_four);
            rect_five_paint.setColor(rect_color_five);
        }else if (num == 3){
            rect_one_paint.setColor(rect_color_one);
            rect_two_paint.setColor(rect_color_two);
            rect_three_paint.setColor(rect_color_three);
            rect_four_paint.setColor(rect_color_four);
            rect_five_paint.setColor(rect_color_five);
        }
        invalidate();
    }
}

第三步:使用

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".MainActivity"
    android:gravity="center">

    <com.wust.jingdutiao.MyLoadingView
        android:layout_width="100dp"
        android:layout_height="100dp"/>

</LinearLayout>

到此为止,效果便可以完美实现了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Android中自定义进度条详解

    Android原生控件只有横向进度条一种,而且没法变换样式,比如原生rom的样子 很丑是吧,当伟大的产品设计要求更换前背景,甚至纵向,甚至圆弧状的,咋办,比如: ok,我们开始吧: 一)变换前背景 先来看看progressbar的属性: 复制代码 代码如下: <ProgressBar             android:id="@+id/progressBar"             style="?android:attr/progressBarStyleHor

  • android自定义进度条渐变色View的实例代码

    最近在公司,项目不是很忙了,偶尔看见一个兄台在CSDN求助,帮忙要一个自定义的渐变色进度条,我当时看了一下进度条,感觉挺漂亮的,就尝试的去自定义view实现了一个,废话不说,先上图吧! 这个自定义的view,完全脱离了android自带的ProgressView,并且没使用一张图片,这样就能更好的降低程序代码上的耦合性! 下面我贴出代码  ,大概讲解一下实现思路吧! 复制代码 代码如下: package com.spring.progressview; import android.conten

  • Android文件下载进度条的实现代码

    main.xml: 复制代码 代码如下: <?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    android:orientation="vertical"    android:layout_width="fill_paren

  • android中实现OkHttp下载文件并带进度条

    OkHttp是比较火的网络框架,它支持同步与异步请求,支持缓存,可以拦截,更方便下载大文件与上传文件的操作.下面我们用OkHttp来下载文件并带进度条! 相关资料: 官网地址:http://square.github.io/okhttp/ github源码地址:https://github.com/square/okhttp 一.服务器端简单搭建 可以参考搭建本地Tomcat服务器及相关配置这篇文章. 新建项目OkHttpServer,在WebContent目录下新建downloadfile目录

  • Android中实现Webview顶部带进度条的方法

    写这篇文章,做份备忘,简单滴展示一个带进度条的Webview示例,进度条位于Webview上面. 示例图如下: 主Activity代码: 复制代码 代码如下: package com.droidyue.demo.webviewprogressbar; import android.app.Activity; import android.os.Bundle; import android.view.Menu; import android.view.View; import android.vi

  • android ListView和ProgressBar(进度条控件)的使用方法

    ListView控件的使用:ListView控件里面装的是一行一行的数据,一行中可能有多列,选中一行,则该行的几列都被选中,同时可以触发一个事件,这种控件在平时还是用得很多的.使用ListView时主要是要设置一个适配器,适配器主要是用来放置一些数据.使用起来稍微有些复杂,这里用的是android自带的SimpleAdapter,形式如下:android.widget.SimpleAdapter.SimpleAdapter(Context context, List<? extends Map<

  • Android 动态改变SeekBar进度条颜色与滑块颜色的实例代码

    遇到个动态改变SeekBar进度条颜色与滑块颜色的需求,有的是根据不同进度改变成不同颜色. 对于这个怎么做呢?大家都知道设置下progressDrawable与thumb即可,但是这样设置好就是确定的了,要动态更改需要在代码里实现. 用shape进度条与滑块 SeekBar设置 代码里动态设置setProgressDrawable与setThumb 画图形,大家都比较熟悉,background是背景图,secondaryProgress第二进度条,progress进度条: <layer-list

  • 实例详解Android自定义ProgressDialog进度条对话框的实现

    Android SDK已经提供有进度条组件ProgressDialog组件,但用的时候我们会发现可能风格与我们应用的整体风格不太搭配,而且ProgressDialog的可定制行也不太强,这时就需要我们自定义实现一个ProgressDialog. 通过看源码我们发现,ProgressDialog继承自Alertdialog,有一个ProgressBar和两个TextView组成的,通过对ProgressDialog的源码进行改进就可以实现一个自定义的ProgressDialog. 1.效果: 首先

  • Android编程之ProgressBar圆形进度条颜色设置方法

    本文实例讲述了Android ProgressBar圆形进度条颜色设置方法.分享给大家供大家参考,具体如下: 你是不是还在为设置进度条的颜色而烦恼呢--别着急,且看如下如何解决. ProgressBar分圆形进度条和水平进度条 我这里就分享下如何设置圆形进度条的颜色吧,希望对大家会有帮助. 源码如下: 布局文件代码: <ProgressBar android:id="@+id/progressbar" android:layout_width="wrap_content

  • Android 七种进度条的样式

    当一个应用在后台执行时,前台界面就不会有什么信息,这时用户根本不知道程序是否在执行.执行进度如何.应用程序是否遇到错误终止等,这时需要使用进度条来提示用户后台程序执行的进度.Android系统提供了两大类进度条样式,长形进度条(progress-BarStyleHorizontal) 和圆形进度条(progressBarStyleLarge).进度条用处很多,比如,应用程序装载资源和网络连接时,可以提示用户稍等,这一类进度条只是代表应用程序中某一部分的执行情况,而整个应用程序执行情况呢,则可以通

随机推荐