自定义ProgressBar


package com.demo;

import android.content.Context;
import android.graphics.Canvas;
import android.graphics.drawable.Drawable;
import android.util.AttributeSet;
import android.view.View;

public class ProgressBar extends View implements Runnable
{
    private int offset;
    private int count;
    private int mWidth;
    private Drawable mBar;
    private int len;

    public ProgressBar(Context context)
    {
        super(context);
        initProgressBar(context);
    }

    public ProgressBar(Context context, AttributeSet attrs)
    {
        super(context, attrs);
        initProgressBar(context);
    }

    private void initProgressBar(Context context)
    {
        mBar = context.getResources().getDrawable(R.drawable.progressbar);
        mWidth = mBar.getIntrinsicWidth();
        new Thread(this).start();
    }

    @Override
    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec)
    {
        setMeasuredDimension(200, 30);
        count = 2 * getMeasuredWidth() / mWidth;
        offset = len = count * mWidth - getMeasuredWidth();
    }

    @Override
    protected void onDraw(Canvas canvas)
    {
        for (int i = 0; i < count; i++)
        {
            mBar.setBounds(i * mWidth - offset, 0, (i + 1) * mWidth - offset,
                    30);
            mBar.draw(canvas);
        }
        offset = offset > 0 ? offset - 3 : len;
    }

    @Override
    public void run()
    {
        while (!Thread.currentThread().isInterrupted())
        {
            try
            {
                Thread.sleep(100);
            }
            catch (InterruptedException e)
            {
                e.printStackTrace();
            }
            postInvalidate();
        }
    }
}



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Android 中,可以通过继承 ProgressBar 类来实现自定义 ProgressBar。下面是一个简单的示例: 1. 创建一个自定义 ProgressBar 类 CustomProgressBar,继承自 ProgressBar。 ``` public class CustomProgressBar extends ProgressBar { public CustomProgressBar(Context context) { super(context); } public CustomProgressBar(Context context, AttributeSet attrs) { super(context, attrs); } public CustomProgressBar(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); } } ``` 2. 在 CustomProgressBar 类中重写 onDraw() 方法,实现自定义绘制。 ``` @Override protected synchronized void onDraw(Canvas canvas) { super.onDraw(canvas); // 绘制背景 Paint paint = new Paint(); paint.setColor(Color.GRAY); paint.setStyle(Paint.Style.FILL); RectF rect = new RectF(0, 0, getWidth(), getHeight()); canvas.drawRoundRect(rect, 10, 10, paint); // 绘制进度 paint.setColor(Color.BLUE); float progress = getProgress() * 1.0f / getMax(); float progressWidth = getWidth() * progress; RectF progressRect = new RectF(0, 0, progressWidth, getHeight()); canvas.drawRoundRect(progressRect, 10, 10, paint); } ``` 在这个例子中,我们绘制了一个灰色的背景和蓝色的进度条。可以根据自己的需求进行自定义绘制。 3. 在布局文件中使用 CustomProgressBar。 ``` <com.example.myapplication.CustomProgressBar android:id="@+id/custom_progress_bar" android:layout_width="match_parent" android:layout_height="30dp" android:max="100" android:progress="50" /> ``` 在这个例子中,我们使用了自定义的 CustomProgressBar,并设置了最大值和当前进度。 以上就是自定义 ProgressBar 的简单示例。可以根据自己的需求进行进一步的自定义
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值