android自定义渐变色等待条

android自定义渐变色等待条

最近在实习,不想用网上的下拉之后出现一个圆形的loading的样式,所以就想自定义一个渐变色等待条来用。
效果图如下:
变色条效果如图

原理

原理就是自定义view,重写onDraw方法,并开启一个线程来周期调用invalidate()让控件周期地重新绘制,实现渐变色的移动。

代码

废话不多说,直接上onDraw方法代码。

@Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);       
        mRect = new RectF(0, 0, mWidth, mHeight);
        mPaint = new Paint();
        mPaint.setAntiAlias(true);
        float[] positions = new float[3];
        positions[0] = 0f;
        //改变第二颜色的位置,类似于photoshop的渐变色位置设置
        positions[1] = pos;
        positions[2] = 1.0f;
        //线性渐变色
        LinearGradient shader = new LinearGradient(0, 0, mWidth, mHeight,
                SECTION_COLORS, positions, Shader.TileMode.MIRROR);
        //设置到画笔
        mPaint.setShader(shader);
        //绘制到画布
        canvas.drawRect(mRect, mPaint);
        if(!isAction){
            //启动周期绘制线程
            action();
        }
    }

再来看周期线程,其实就是每10毫秒将第二颜色的位置增加0.01,然后重绘控件

public void action() {
        pos = 0.00f;
        operator = true;
        isAction = true;
        new Thread(new Runnable() {

            @Override
            public void run() {
                try {
                    while (isAction) {
                        Thread.sleep(10);
                        if (operator) { 
                            //往右边移动0.01f
                            pos += 0.01f; 
                        } else { 
                            //往左边移动0.01f
                            pos -= 0.01f; 
                        }
                        if (pos >= 1f) {
                            //如果超过了1f,就调头
                            operator = false;
                        } else if (pos <= 0f) {
                            //如果低于了0f,就调头
                            operator = true;
                        }
                        //通知handler
                        handler.sendEmptyMessage(1);
                    }

                } catch (InterruptedException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }
            }

        }).start();

    }

handler接受到通知后只需要执行invalidate()就可以重绘控件了

private Handler handler = new Handler() {
        @Override
        public void handleMessage(Message msg) {
            if (msg.what == 1) {
                // 通知控件重绘
                invalidate();
            }
        }
    };

完整代码

下载地址

使用方法

<com.cyt.view.RainbowView
        android:layout_width="match_parent"
        android:layout_height="3dp" />
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值