水平progressbar 带底部指示器和文字

根据项目要求需要实现以下效果:


列出源码:

public class TextProgressBar extends LinearLayout {

    String text;
    Paint mPaint;
    private Rect textRect;
    private Bitmap bitmap;
    private ProgressBar progressBar;
    int progress;
    int proWidth, proHeight;

    public TextProgressBar(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
        initText(context);
    }

    public TextProgressBar(Context context) {
        super(context);
        initText(context);
    }

    public TextProgressBar(Context context, AttributeSet attrs) {
        super(context, attrs);
        initText(context);
    }

    @Override
    protected synchronized void onDraw(Canvas canvas) {
        super.onDraw(canvas);
        progress = progressBar.getProgress();
        if (progress == 0 || progress == progressBar.getMax())
            return;
        this.mPaint.getTextBounds(this.text, 0, this.text.length(), textRect);

        proWidth = progressBar.getWidth();
        proHeight = progressBar.getHeight();

        //画指示器
        int bitmapx = (int) (progressBar.getLeft() + proWidth * ((progress * 1f) / progressBar.getMax())) - bitmap.getWidth() / 2;
        int bitmapy = proHeight + bitmap.getHeight() / 2;
        if (bitmapx < 0)
            bitmapx = progressBar.getLeft();
        if(bitmapx > progressBar.getRight()-bitmap.getWidth())
            bitmapx = progressBar.getRight()-bitmap.getWidth();
        canvas.drawBitmap(bitmap, bitmapx, bitmapy, mPaint);

        //写字
        int tvx = (int) (progressBar.getLeft() + proWidth * ((progress * 1f) / progressBar.getMax())) - textRect.centerX();
        int tvy = proHeight + bitmap.getHeight() * 2 + 4;
        if (tvx < 0)
            tvx = progressBar.getLeft();
        if(tvx >= progressBar.getRight()-textRect.width())
            tvx = progressBar.getRight()-textRect.width();
        canvas.drawText(this.text, tvx, tvy + bitmap.getHeight(), this.mPaint);

    }

    //初始化,画笔
    private void initText(Context context) {
        View inflate = View.inflate(context, R.layout.textprogressbar, this);
        progressBar = (ProgressBar) inflate.findViewById(R.id.progressbar1);
        progressBar.setProgress(50);
        setWillNotDraw(false);
        this.mPaint = new Paint();
        this.mPaint.setColor(getResources().getColor(R.color.red));
        this.mPaint.setTextSize(20);
        textRect = new Rect();
        text = "0";
        bitmap = BitmapFactory.decodeResource(context.getResources(), R.mipmap.progress_top);
    }

    public void setProgress(int progress) {
        progressBar.setProgress(progress);
    }


    public void setText(String str) {
        text = str;
    }
}


评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值