ViewGroup会管理子view,负责子view的显示大小。
当ViewGroup大小为wrap_content时,ViewGroup就需要对子View进行遍历,以便获得所有子View的大小,从而决定自己的大小。
遍历测量完子View的大小后,就遍历子View,指定其显示的位置。
ViewGroup的绘制:是通过遍历其子View,然后使用dispatchDraw()方法绘制。
补充介绍:
在View中比较有用的回调方法:
- onFinishInflate():从XML中加载组件后回调。
- onSizeChanged():组件大小改变时回调。
- onMeasure():回调该方法进行测量。(上篇博客有介绍。)
- onLayout():回调该方法确定显示的位置。
- onTouchEvent()监听到触摸事件回调。
实现自定义控件的三种方式:
- 对现有控件进行扩展。
- 通过组合方法实现新控件。
- 重写View来实现全新控件。
对现有控件来扩展。
上一个自定义TextViewDemo。
package com.example.costomer_tan.view;
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.util.AttributeSet;
import android.util.Log;
import android.widget.TextView;
public class MyTextView extends TextView {
Paint paint1;
Paint paint2;
String TAG = "MainActivity";
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);
init();
}
private void init() {
paint1 = new Paint();
paint1.setColor(getResources().getColor(
android.R.color.holo_blue_bright));
paint1.setStyle(Paint.Style.FILL);
paint2 = new Paint();
paint2.setColor(Color.YELLOW);
paint2.setStyle(Paint.Style.FILL);
}
@Override
protected void onDraw(Canvas canvas) {
// 在回调方法前,实现自己的逻辑,对于TextView来说就是在绘制文本内容前。
canvas.drawRect(0, 0, getMeasuredWidth(), getMeasuredHeight(), paint1);
Log.e(TAG, "getMeasurewidth--》" + getWidth());
canvas.drawRect(10, 10, getMeasuredWidth() - 10,
getMeasuredHeight() - 10, paint2);
canvas.save();
//绘制文字时平移10像素。
canvas.translate(10, 0);
super.onDraw(canvas);
canvas.restore();
}
}
XML
<com.example.costomer_tan.view.MyTextView
android:layout_width="200dp"
android:layout_height="50dp"
android:gravity="center"
android:text="Android"
android:textSize="30sp" />