Android 自定义进度图形

只要给两张大小相同的图片(一张地图--无,一张进度的)就可以做一个想要的进度




废话就不多说了,直接上代码


 @Override
    protected void onDraw(Canvas canvas) {
        /*
         * drawBitmap(Bitmap bitmap, Rect src, RectF dst, Paint paint);
         * Rect src: 是对图片进行裁截,若是空null则显示整个图片
         * RectF dst:是图片在Canvas画布中显示的区域,
         * 大于src则把src的裁截区放大,
         * 小于src则把src的裁截区缩小。
         * 当想要让图片以画卷方式展现的话,主要是设置src大小,这边是默认从左到右显示,所以每次只要修改src中right的大小就好
         */

         Bitmap bitmap;
         Bitmap bitmapEmpty;
        if ( getWidth() == 0 || getHeight() == 0) {
            return;
        } else {

            float scale=0.8f;
            bitmap = BitmapFactory.decodeResource(context.getResources(), R.drawable.home_tree_full);

            scale=1.0f*getWidth()/bitmap.getWidth();

            bitmap=BitmapUtils.bitMapScale(bitmap,scale);


            bitmapEmpty = BitmapFactory.decodeResource(context.getResources(), R.drawable.home_tree_empty);
            bitmapEmpty=BitmapUtils.bitMapScale(bitmapEmpty,scale);
        }

        Rect src = new Rect();
        src.left = 0;
        src.top = (int) (bitmap.getHeight() * progress);
        src.right = bitmap.getWidth();
        src.bottom = bitmap.getHeight();


        Paint mPaint = new Paint();
        mPaint.setAntiAlias(true);// 设置画笔的锯齿效果。 true是去除,

        canvas.drawBitmap(bitmapEmpty, null, new RectF(0, 0, src.right, src.bottom), mPaint);
        canvas.drawBitmap(bitmap, src, new RectF(0, src.top, src.right, src.bottom), mPaint);

        mPaint.setColor(context.getResources().getColor(R.color.color_pumice));// 设置字体颜色
        mPaint.setTextSize(textSize);
        canvas.drawText(maxMileage, src.right * 0.33f, textSize, mPaint);
        canvas.drawText(otherMileage, src.right * 0.75f, src.bottom / 2 + textSize * 1.5f, mPaint);
    }


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值