为了让我们的自定义看起来和官方的差不多,正经一点,对没错是正经一点。我们的自定义控件要做的全面一点。
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给属性赋值
有时候我们在使用控件的时候为了方便,为了懒