自定义进度条---圆形以及线条

原创 2015年11月21日 16:41:27

自定义进度条—圆形以及线条

CD:
弄了一天半终于将Android机与电脑通过usb数据线传输数据的问题给解决了,过几天将遇到的问题写出来以免下次用到时又忘了.

比较简单直接上代码:

1,自定义myProcessView
public class myProcessView extends View {

    private Paint mPaint; //画笔
    private int color;   //设置的颜色
    private String text;  // 文字显示进度
    private int mProcess = 0;    //当前进度值
    private int Max = 0;    //进度的最大值
   private double n = 3.6;  //圆形进度条要乘的弧度
    int screenWidth;    //屏幕的宽
    public myTextView(Context context) {
        this(context, null);
    }

    public myTextView(Context context, AttributeSet attrs) {
        this(context, attrs, 0);
    }

    public myTextView(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
        //得到屏幕的宽
          screenWidth = getScreenWidth(context);
         //在构造方法中创建画笔
        mPaint = new Paint();

    }


    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);

        mPaint.setColor(Color.RED);
        mPaint.setStyle(Paint.Style.STROKE);

        RectF rect = new RectF(0, 0, 40, 40); //  坐标是相对于父布局的

        int lineProcess = (mProcess/max)*screenWidth;
        //绘制线性进度条
        canvas.drawLine(0,0,lineProcess ,0,mPaint);
        //绘制圆形进度条   
        canvas.drawArc(rect, 3, (mProcess *3.6), false, mPaint);


    }

    public void setText(String t) {
        this.text = t;
    }
     public void setMax(int max) {
        this.max= max;
    }
    public void setProcess(int pro) {
        this.mProcess = pro;
 if(mProcess > 100){
            return;
        }else{
        invalidate();

        }
        invalidate();

        }
    }
}

2,使用进度条
public class CustomActivity extends Activity {

    myProcessView myProcessView ;
    int mCount = 0;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_custom);

        myProcessView = (com.example.custom.view.myProcessView ) findViewById(R.id.my);

  myProcessView.setMax(设置进度的最大值);  
      //一般这行代码都是在得到下载进度是调用 
  myProcessView.setProcess(当前进度); 

    }
}

备注:
圆形进度条可以使用.线性进度条有一个问题是 如果是下载文件,我们没有办法得到文件最大的值(也就是进度比无法得出),要下班了.有时间在整理.

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

自己定义一个带进度的圆形进度条

很多的时候,系统自带的View满足不了我们功能的需求,那么我们就需要自己来自定义一个能满足我们需求的View,自定义View我们需要先继承View,添加类的构造方法,重写父类View的一些方法,例如o...
  • halaoda
  • halaoda
  • 2017年10月09日 19:22
  • 67

2种方式实现带进度的圆形进度条

progressbar默认为水平和圆形进度条,但圆形的进度条是没有进度的。下面提供2中方式实现带进度的圆形进度条。...

简单实现带节点的进度条

带节点进度条的实现方法不止一个,但是如果要实现图中这种效果的,初步看好像还不简单。进度条的形状不规则、背景是渐变颜色、节点上面还有个勾。这里提供一个很简单的思路,简单的都不好意思说了……...

自定义圆形进度条

  • 2016年10月27日 16:56
  • 35.33MB
  • 下载

自定义圆形进度条

  • 2017年02月14日 12:12
  • 23.56MB
  • 下载

Android 自定义圆形旋转进度条,仿微博头像加载效果

微博 App 的用户头像有一个圆形旋转进度条的加载效果,看上去效果非常不错,如图所示:据说 Instagram 也采用了这种效果。最近抽空研究了一下,最后实现的效果是这样:基本上能模拟出个大概,代码量...

Android 自定义圆形进度条View

  • 2015年12月31日 15:50
  • 695KB
  • 下载

自定义view之圆形进度条

本节介绍自定义view-圆形进度条 思路: 根据前面介绍的自定义view内容可拓展得之; 1:新建类继承自View 2:添加自定义view属性 3:重写onDraw(Canvas canvas) 4:...

自定义圆形进度条

  • 2017年04月01日 10:48
  • 136KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:自定义进度条---圆形以及线条
举报原因:
原因补充:

(最多只允许输入30个字)