组合控件的目的是封装公共模块或者业务模块。比如说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="照片">