1.自定义控件常用的三个构造方法,参数分别1和2和3
public MView(Context context) {
super(context);
}
public MView(Context context, @Nullable AttributeSet attrs) {
super(context, attrs);
}
public MView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
}
2.三个方法的区别主要
a:代码中直接实例化自定义控件,会调用第一个构造函数
b:xml布局使用自定义控件,会调用第二个构造函数
c:xml布局使用自定义控件,并且控件含有自定义属性,仍然调用的是第二个构造函数.
3.总结:
系统默认只会调用自定义控件的前两个构造函数,第三个构造函数的调用,通常是我们自己在构造函数中主动调用的(例如,在第二个构造函数中调用第三个构造函数) 。通常,自定义控件时需要初始化一些数据,比如画布,画笔等,如果按照默认的构造方法,最好每个构造方法内都要进行初始化操作 ,因此,对构造方法进行修改。
1、自定义代码:
public class IconView extends View {
//代码中直接实例化自定义控件,会调用此构造函数,如 new IconView(this)
public IconView(Context context) {
this(context, null);
}
//在xml中布局使用时会调用此构造函数,attrs含有xml中添加的属性值
public IconView(Context context, @Nullable AttributeSet attrs) {
this(context, attrs, 0);
}
//系统默认会调用前两种构造函数,我们统一将上两种调用到第三个,然后在第三个中初始化
public IconView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
init(attrs);
}
private void init(AttributeSet attrs) {
TypedArray typedArray = getContext().obtainStyledAttributes(attrs, R.styleable.IconView);
float getDimension = typedArray.getDimension(R.styleable.IconView_icon_radius, 0f);
int getDimensionPixelOffset = typedArray.getDimensionPixelOffset(R.styleable.IconView_icon_radius, 0);
int getDimensionPixelSize = typedArray.getDimensionPixelSize(R.styleable.IconView_icon_radius, 0);
LogUtils.e("getDimension = " + getDimension);
// getDimension = 6.879944 获取xml中设置的dp值并转化为像素值,float类型
LogUtils.e("getDimensionPixelOffset = " + getDimensionPixelOffset);
//getDimensionPixelOffset = 6 获取xml中设置的dp值并转化为像素值,int类型,如果有小数,舍去
LogUtils.e("getDimensionPixelSize = " + getDimensionPixelSize);
//getDimensionPixelSize = 7 获取xml中设置的dp值并转化为像素值,int类型,如果有小数,进行四舍五入
}
}
修改前两个方法,把super 给成this,不管控件怎样产生,都去调用三个参数的构造方法,在里面进行初始化操作。
2、自定义属性,便于在xml中给自定义控件赋值:
在values中新建attrs.xml
<resources>
<declare-styleable name="IconView">
<attr name="icon_radius" format="dimension" />
</declare-styleable>
</resources>
3、xml布局中使用:
<com.example.zz.example.customcontrol.IconView
android:id="@+id/start_icon_view"
app:icon_radius="3.44dp"
android:background="@color/colorAccent"
android:layout_width="100dp"
android:layout_height="100dp" />
属性值设置为小数时一定要特别注意获取的方式,注意是舍去还是四舍五入,否则很容易导致获取的值与设计的有偏差