自定义竖直ProgressBar

今天做电池电量遇到个问题那就是利用少的资源来显示电池不同的状态。最初的想法是改写progressbar,使其变成竖直,这样便于控制。写一个View继承ProgressBar,但是怎样改成竖直的呢,在网上搜了下,有个奇人利用canvas.rotate(-90);canvas.translate(-this.getHeight(), 0);这个方式很创新。拿出来和大家分享下。

package com.trustgo.mobile.monitor;


import com.trustgo.security.R;


import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.Canvas;
import android.graphics.drawable.BitmapDrawable;
import android.util.AttributeSet;
import android.widget.ProgressBar;


public class BatteryView extends ProgressBar{
    
private int viewWidth;
private int viewHeight;

    public BatteryView(Context context) {
        super(context);
        initView(context);
    }
    
    public BatteryView(Context context, AttributeSet attrs) {
        super(context, attrs);
        initView(context);
    }


    public BatteryView(Context context, AttributeSet attrs, int defStyle) {
        super(context, attrs, defStyle);
        initView(context);
    }
    
    
    protected synchronized void onMeasure(int widthMeasureSpec, int heightMeasureSpec)
    {
        this.setMeasuredDimension(viewWidth, viewHeight);


    }
    
    private void initView(Context context){
    BitmapDrawable bitmapDrawable = (BitmapDrawable) context.getResources()
    .getDrawable(R.drawable.system_manager_battary_bg);
    Bitmap bitmap = bitmapDrawable.getBitmap();
    viewWidth = bitmap.getWidth();
    viewHeight = bitmap.getHeight();
    }
    
@Override
    protected void onSizeChanged(int w, int h, int oldw, int oldh) {
        super.onSizeChanged(h, w, oldw, oldh);
    }
    
    @Override
    protected synchronized void onDraw(Canvas canvas) {
        // 旋转
        canvas.rotate(-90);
        canvas.translate(-this.getHeight(), 0);
        super.onDraw(canvas);
    }
}

关于progressbar样式只需要定义一个style就可以了。


  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值