自定义控件大概步骤如下:
A,自定义属性的声明及获取:在res/values/attrs.xml声明,在view的构造方法中,获取 TypedArray a = context.getTheme().obtainStyledAttributes(attrs, R.styleable.InputCodeView, 0, 0);
B,测量onMeasure:模式3种,1->Exactly:恰好,明确的值,2->at_most:一般为包裹时,想要多大就多大,最大不能超过父view。
3-> UNSPECIFIED:父容器不对子View的大小做限制,一般用作Android系统内部,ListView和ScrollView等滑动控件
注:自定义View在重写onMeasure()的过程中要处理View的宽或高为wrap_content的情况为:(第3点)
同理:同下图=>getSuggestedMinimumWidth()方法。
View本身的最小宽度=>mMinWidth,如果view无背景时 如有背景,那么该MinimumWidth为View本身最小宽度mMinWidth和View背景的最小宽度的最大值
![](https://img-blog.csdn.net/20161220205026031?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvcXFfMjk3MzExNzM=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
获取View的宽或者高的大小
![](https://img-blog.csdn.net/20161220205531112?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvcXFfMjk3MzExNzM=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
设置View的宽和高的测量值
![](https://img-blog.csdn.net/20161220205703661?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvcXFfMjk3MzExNzM=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
注:ViewGroup是一个抽象类,它没重写View的onMeasure( )但它有提供measureChildren( )测量所有的子View。
在measureChildren()方法中调用measureChild( )测量每个子View,在该方法内又会调用到child.measure( )方法
即ViewGroup中测量子View的流程: measureChildren( )---> measureChild( )---> child.measure( )
C,布局onLayout:决定子view的位置
D,绘制onDraw:绘制内容,invalidate 在主线程中,postInvalidate 在子线程中, draw.xxx方法
E,onTouchEvent:响应用户,action_down,action_move,action_up,action_pointer_down,action_pointer_up.
VelocityTracker 类,表示速率,速度跟踪可以获得触摸的坐标,根据按下的时间可以简单计算出速度大小
要跟踪的时候使用obtain()方法来来获得VelocityTracker类的一个实例对象
使用addMovement(MotionEvent)函数将当前的移动事件传递给VelocityTracker对象
使用computeCurrentVelocity(int units)函数来计算当前的速度
使用getXVelocity ()、getYVelocity ()函数来获得当前的速度
请求父view不要拦截,自已处理事件:parent.requestDisallowInterceptTouchEvent(true);
F,onInterceptTouchEvent:一般为viewGroup的,事件由父view 传递给 子view,如果返回true,则把子view事件拦截掉了。
注:一般无用户响应,只需重写onMeasure,onLayout方法。
重识下自定义view基本步骤
最新推荐文章于 2021-11-30 17:18:39 发布