大光明电影院,王玉普最新消息,重生校园追美记
android自定义view的构造函数
自定义view是android中一个常见的需求,每个自定义的view都需要实现三个基本的构造函数,而这三个构造函数又有两种常见的写法。
第一种
每个构造函数分别调用基类的构造函数,再调用一个公共的初始化方法做额外初始化。
public class myview extends listview { public myview(context context) { super(context); sharedconstructor(); } public myview(context context, attributeset attrs) { super(context, attrs); sharedconstructor(); } public myview(context context, attributeset attrs, int defstyleattr) { super(context, attrs, defstyleattr); sharedconstructor(); } private void sharedconstructor() { // do some initialize work. } }
第二种
级联式调用,每一个构造函数调用比它多一个参数的构造函数,最后一个构造函数调用基类的构造函数,最后在做一些额外的初始化工作。
public class myview extends listview { public myview(context context) { this(context, null); } public myview(context context, attributeset attrs) { this(context, attrs, 0); } public myview(context context, attributeset attrs, int defstyleattr) { super(context, attrs, defstyleattr); // other initialize work. } }
那么问题来了,我们该使用哪一种方式呢?
结论是:最好使用第一种,因为第二种方法在某些情况下会有问题,比如你自定义的view继承自listview或者textview的时候,listview或者textview内部的构造函数会有一个默认的defstyle, 第二种方法调用时defstyle会传入0,这将覆盖基类中默认的defstyle,进而导致一系列问题。以listview为例,看看它的构造函数。
public listview(context context) { this(context, null); } public listview(context context, attributeset attrs) { this(context, attrs, com.android.internal.r.attr.listviewstyle); } public listview(context context, attributeset attrs, int defstyleattr) { this(context, attrs, defstyleattr, 0); } public listview(context context, attributeset attrs, int defstyleattr, int defstyleres) { super(context, attrs, defstyleattr, defstyleres); // other works. }
可以看到listview的第二个构造函数代码中传入了一个com.android.internal.r.attr.listviewstyle,使用第二种方法(级联式)调用时,我们传入的是0,将会覆盖这个默认值。但是第一种方法中调用了super(context, attrs); 进而调用了基类的 this(context, attrs, com.android.internal.r.attr.listviewstyle);就不会产生问题。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复
Android apk 项目一键打包并上传到蒲公英的实现方法
Android 自定义LineLayout实现满屏任意拖动功能的示例代码
android 限制某个操作每天只能操作指定的次数(示例代码详解)
Android 集成 google 登录并获取性别等隐私信息的实现代码
网友评论