Android 自定义view《二》 自定义控件基本步骤(从入门到巅峰)

1.写一个类继承view或者其他控件

public class CustomView extends View {
}

2.在xml中定义自定义的view

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:id="@+id/main_root_ll"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical" >

<com.sigestudio.customviewdemo.views.CustomView
        android:layout_width="match_parent"
        android:layout_height="match_parent" />

</LinearLayout>

3.写构造方法:

public class CustomView extends View {
    public CustomView(Context context) {
        super(context);
    }

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

为什么要重写构造函数?

大致意思是无法解析我们的CustomView类找不到方法,为什么呢?我们在xml文件引用我们的CustomView类时为其指定了两个android自带的两个属性:layout_width和layout_height,当我们需要使用类似的属性(比如更多的什么id啊、padding啊、margin啊之类)时必须在自定义View的构造方法中添加一个AttributeSet类型的签名来解析这些属性:

4.重写ondraw()方法

Android也给我们提供了这两样东西:Paint和Canvas,一个是画笔而另一个呢当然是画布啦~~,我们可以看到在onDraw方法中,画布Canvas作为签名被传递进来,也就是说这个画布是Android为我们准备好的

--------------------- 

 
@Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
Paint paint = new Paint();
paint.setAntiAlias(true);
}

设置了抗锯齿(一种让图像边缘显得更圆滑光泽动感的碉堡算法):setAntiAlias(true)

5.CustomView的代码让其实现Runnable接口

实现Runnable接口还是在子线程,所以更新ui用:postInvalidate()

public class CustomView extends View implements Runnable {
    private Paint mPaint;// 画笔
    private Context mContext;// 上下文环境引用

    private int radiu;// 圆环半径

    public CustomView(Context context) {
        this(context, null);
    }

    public CustomView(Context context, AttributeSet attrs) {
        super(context, attrs);
        mContext = context;

        // 初始化画笔
        initPaint();
    }

    /**
     * 初始化画笔
     */
    private void initPaint() {
        // 实例化画笔并打开抗锯齿
        mPaint = new Paint(Paint.ANTI_ALIAS_FLAG);
 
      /*
       * 设置画笔样式为描边,圆环嘛……当然不能填充不然就么意思了
       * 
       * 画笔样式分三种:
       * 1.Paint.Style.STROKE:描边
       * 2.Paint.Style.FILL_AND_STROKE:描边并填充
       * 3.Paint.Style.FILL:填充
       */
        mPaint.setStyle(Paint.Style.STROKE);

        // 设置画笔颜色为浅灰色
        mPaint.setColor(Color.LTGRAY);
 
      /*
       * 设置描边的粗细,单位:像素px
       * 注意:当setStrokeWidth(0)的时候描边宽度并不为0而是只占一个像素
       */
        mPaint.setStrokeWidth(10);
    }

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

        // 绘制圆环
        canvas.drawCircle(MeasureUtil.getScreenSize((Activity) mContext)[0] / 2, MeasureUtil.getScreenSize((Activity) mContext)[1] / 2, radiu, mPaint);
    }

    @Override
    public void run() {
      /*
       * 确保线程不断执行不断刷新界面
       */
        while (true) {
            try {
            /*
             * 如果半径小于200则自加否则大于200后重置半径值以实现往复
             */
                if (radiu <= 200) {
                    radiu += 10;

                    // 刷新View
                    invalidate();
                } else {
                    radiu = 0;
                }

                // 每执行一次暂停40毫秒
                Thread.sleep(40);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
}

 

总结:.动画的原理:

大家如果了解动画的原理就会知道,一个动画是由无数张连贯的图片构成的,这些图片之间快速地切换再加上我们眼睛的视觉暂留给我们造成了在“动”的假象。

再提供一个setter方法对外设置半径值,并在设置了该值后调用invalidate()方法重绘View:

 

 

 

 

 

 

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值