走向自定义View的深坑——自定义属性

为了让我们的自定义看起来和官方的差不多,正经一点,对没错是正经一点。我们的自定义控件要做的全面一点。BB两句为什么要自定义控件? 为了装逼为了满足脑洞为了世界的发展自定义属性,单独自定义属性没啥用,因为自定义属性是提供给自定义View使用的,所以我们要先创建一个自定义View才能愉快的使用。 前排提示,文章略长,请耐心看完。流程创建自定义View编写要用到的属性使用style给
摘要由CSDN通过智能技术生成

为了让我们的自定义看起来和官方的差不多,正经一点,对没错是正经一点。我们的自定义控件要做的全面一点。

BB两句

  • 为什么要自定义控件?
    • 为了装逼
    • 为了满足脑洞
    • 为了世界的发展

自定义属性,单独自定义属性没啥用,因为自定义属性是提供给自定义View使用的,所以我们要先创建一个自定义View才能愉快的使用。

前排提示,文章略长,请耐心看完。

流程

  • 创建自定义View
  • 编写要用到的属性
  • 使用style给属性赋值
  • 代码中获取属性的值
  • 画出文字

创建自定义View

自定义View的第一步就是要把我们的类写成View,怎么写成View呢,只要我们继承View这个类就可以了,一般情况下我们都是继承View或者ViewGroup这两个类进行View扩展。为了方便通常也是直接集成相关方面的View进行修改,如这些TextView、EditText、LinearLayout等等。

首先创建一个类,继承View,此时应该是这样的

    public class TextView extends View {
   
    }

啊嘞,这好像啥变化都没有啊-_-! 此时会报错,提示需要重写构造方法,一般情况下我们需要重写三个构造方法,以满足各个地方使用的需求,下面介绍使用场景

      public TextView(Context context) {
        this(context,null);
    }

    public TextView(Context context, AttributeSet attrs) {
        this(context, attrs,0);
    }

    public TextView(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
    }
  • 第一个构造方法简单来说就是在代码中实例化的时候执行
  • 第二个构造方法是在XML布局文件中使用的时候执行,并且是没有使用Style来定义要使用的属性
  • 第三个构造方法是在XML布局文件中使用并且指定了style的时候执行。

注意看第一个方法和第二个方法内,我是用的this,就是调用当前类的第二个、第三个构造,依次类推,这是为了简化代码,直接在第三个方法中初始化一次就行了
好了,简单结构了解了,就开始走下一步。

编写要用到的属性

为什么要自定义属性?想想你使用的TextView

    <TextView
        android:text="@string/app_name"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"/>

这些都是属性,我们的自定义View想要有更好的体验,我们需要进行自定义一些属性方便在XML中直接配置。
自定义属性需要在res/value/attrs.xml中配置,没有的创建一个,使用declare-styleable标签进行定义,标签中的name属性写成自定义View的类名,下面看代码。

    <declare-styleable name="TextView">
        <attr name="textSize" format="dimension"/>
        <attr name="textColor" format="color"/>
        <attr name="text" format="string"/>
        <attr name="gravity" format="enum">
            <enum name="center" value="0"/>
            <enum name="top" value="1"/>
            <enum name="bottom" value="2"/>
            <enum name="left" value="3"/>
            <enum name="right" value="4"/>
            <enum name="center_horizontal" value="5"/>
            <enum name="center_vertical" value="6"/>
        </attr>
    </declare-styleable>

好了,现在定义完了,可以在XML使用了,在使用前,需要先给自定义View设置一个命名控件,以便在代码中可以找到自定义的属性。

    <!--命名控件的声明-->
    xmlns:app="http://schemas.android.com/apk/res-auto"
    <com.github.odriver.viewdemo.view.TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        app:gravity="center"
        app:textSize="16sp"
        app:text="@string/app_name"
        app:textColor="@color/colorPrimary"
        />

好了,属性的使用就是这些了。

使用Style给属性赋值

有时候我们在使用控件的时候为了方便,为了懒࿰

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值