自定义控件从入门到精通(二)——组合控件

组合控件的目的是封装公共模块或者业务模块。比如说app的标题栏,包括一些返回键等按钮,自定义的控件,包含各个按钮,并封装一些接口,让用户实现这些接口。这样不需要每个界面都将这些重写一遍,大大提高了开发效率。

实现的步骤主要是:

1.在attrs.xml声明新的属性。

2.在代码构造函数中取出新声明的属性,并且根据这些属性,结合LayoutParams将各个控件添加入父view。

组合控件式继承线程的常用布局的,比如RelativeLayout,LinerLayout等。继承这些布局而不是直接继承Viewgroup的好处是不用自己重写onMeasure和onLayout方法,前提是你的布局不是奇异布局(比如说流式布局)。所以跟我刚开头说的一样,适合于封装一些业务控件。

我实现的自定义组合控件很简单,就是上面图片,下面文字,我的目的是用在九宫格里。当做完这个demo的时候,特别想跟大家分享一个学习自定义控件的思路,在学习自定义控件的过程中,看完涉及到的知识点,然后根据自定义控件的种类每个类型都看一两个demo后,赶紧动手写一些简单的,因为即使很简单,也会涉及到view绘制的各个流程和一些常用的方法,这时你就会有一些成就感,而且对于掌握这个高逼格技术心里也有底了,下一步就可以找些那些高手做的复杂的自定义控件去研究了。

好了,上具体步骤:

1.在attrs.xml声明新属性。

2.在构造函数中

publicItemView(Context context, AttributeSet attrs) {

super(context, attrs);

itemtextTextView=newTextView(getContext());

imgImageView=newImageView(getContext());

//获得属性

TypedArray ta = context.obtainStyledAttributes(attrs, R.styleable.ItemView);

itemtext= ta.getString(R.styleable.ItemView_itemtext);

img= ta.getDrawable(R.styleable.ItemView_imgsrc);

//设置子控件的属性

itemtextTextView.setText(itemtext);

itemtextTextView.setTextColor(Color.BLACK);

itemtextTextView.setGravity(Gravity.CENTER);

imgImageView.setImageDrawable(img);

//添加view
mimgParams=newLayoutParams(LayoutParams.MATCH_PARENT,200);

addView(imgImageView,mimgParams);

mTextParams=newLayoutParams(ViewGroup.LayoutParams.MATCH_PARENT,ViewGroup.LayoutParams.WRAP_CONTENT);

addView(itemtextTextView,mTextParams);

}

很多属性都可以写到attrs.xml中声明,在代码中获取后进行设置。也可以直接在代码中写死,根据需求选择。

3.使用


android:layout_width="100dp"

android:layout_height="wrap_content"

android:layout_alignParentStart="true"

android:layout_below="@+id/animViewbig"

android:orientation="vertical"

app:imgsrc="@mipmap/zly"

app:itemtext="照片">

你可能感兴趣的:(自定义控件从入门到精通(二)——组合控件)