自定义控件

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" />

 

属性值设置为小数时一定要特别注意获取的方式,注意是舍去还是四舍五入,否则很容易导致获取的值与设计的有偏差

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值