1 自定义view方法的简介
1.1 onMeasure 方法
对于onMeasure方法不得不要说一下测量模式,这里的测量模式和父类是有一定关系的.我们不关注和父类的关系.后面的博客的写到,我们现在只需要记住有三种测量模式和他们的意思就行了.
分别是:
UNSPECIFIED :未指定模式;任意大小,想多大就多大.一般开发几乎用不到.一般在ListView,ScrollView和RecyclerView中会用到.所以我们不需要关心它
EXACTLY :精确模式.准确的值,比如你在布局这样写.
android:layout_width="100dp"
//或者
android:layout_width="match_parent"
他的测量模式就是**EXACTLY **
AT_MOST:最大模式,包裹内容,比如你在布局这样写
android:layout_width="wrap_content"
对于onMeasure你暂时只需要知道这些就o78k了
1.2 onDrawable 方法
主要用来绘制效果,onDrawable传入了一个参数Canvas,画布.可以用他绘制各种东西,比如canvas.drawCircle()画圆,drawText()画文本.
@Override
protected void onDraw(Canvas canvas) {
// 画圆
canvas.drawCircle();
// 画文本
canvas.drawText();
}
暂时你也只需要知道onDrawable是用来绘制效果的就行了.
onTouchEvent 方法
用来处理触摸事件与用户进行交互.
人的触摸事件不外乎就那么几种.所以Android的触摸事件肯定包括
手指按下:MotionEvent.ACTION_DOWN
手指移动:MotionEvent.ACTION_MOVE
手指抬起:MotionEvent.ACTION_UP
@Override
public boolean onTouchEvent(MotionEvent event) {
switch (event.getAction()) {
case MotionEvent.ACTION_DOWN:
Log.d(TAG,"ACTION_DOWN");
break;
case MotionEvent.ACTION_MOVE:
Log.d(TAG,"ACTION_MOVE");
break;
case MotionEvent.ACTION_UP:
Log.d(TAG,"ACTION_UP");
break;
default:
break;
}
return super.onTouchEvent(event);
}
先阶段,你只需要知道onTouchEvent是用来跟人交互和常用的触摸事件就好了.什么事件分发先不用管.
1.3 自定义属性
自定义的属性是用来配置的.比如Textview的text和textColor都是自定义属性.我们可以通过属性进行配置.而不是在代码中写死.
如果定义自定义属性?
1.3.1 在res的values下面新建一个attr.xml
当然不命名为attr.xml也是可以的.但是约定俗成,大家都这样命名.
<?xml version="1.0" encoding="utf-8"?>
<resources>
<!--declare-styleable这个name写自定义View的名字-->
<declare-styleable name="MyTextView">
<!--attr的name就是你属性的名字,format的属性对应的格式,有 color(颜色),string(文本),dimension(sp,dp)-->
<attr name="myTextColor" format="color"/>
</declare-styleable>
</resources>
1.3.2在布局中使用
<?xml version="1.0" encoding="utf-8"?>
<!--在根布局申明app的命名空间-->
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent">
<!--再用app就可以使用我们自己定义的属性了-->
<com.zsj.slidingmenu.MyTextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
app:myTextColor="@color/colorPrimary" />
</android.support.constraint.ConstraintLayout>
1.3.3在代码中获取布局设置的属性值
public class MyTextView extends View {
public MyTextView(Context context) {
this(context, null);
}
public MyTextView(Context context, @Nullable AttributeSet attrs) {
this(context, attrs, 0);
}
public MyTextView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
// 获取TypedArray
TypedArray typedArray = context.obtainStyledAttributes(attrs, R.styleable.MyTextView);
int myTextColor = typedArray.getColor(R.styleable.MyTextView_myTextColor, Color.RED);
//回收
typedArray.recycle();
}
}