最近在工作的时候,需要用到一个多行多列的radioGroup,在网上找资料的时候,又找不掉合适的,所以只好自己写一个,同时也个那些需要这个功能的人一些参考;
首先,我先分析了一下,我需要的仅仅是一个可以多行多列显示的控件,但是radioGroup却只有横向和纵向,并
不支持换行,最近刚刚好看了一些自定义控件的内容,因此,想想可以自己定义一个控件,当然,还是要继承自radioGroup,这样可以节省很多的功能;
剩下的,做的就是重写onMeasure和onLayout两个方法,来对子控件进行排列,实现多行效果,先上张图:
这是简单的效果图,控件的宽度是子控件自己决定的
该上关键代码啦
@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
super.onMeasure(widthMeasureSpec, heightMeasureSpec);
int height = 0;
if (getChildCount() > 0) {
startX = 0;
//父控件高度
rowNm = 0;
for (int i = 0; i < getChildCount(); i++) {
RadioButton rb = (RadioButton) getChildAt(i);
//测量子控件
measureChild(rb, widthMeasureSpec, heightMeasureSpec);
//子控件宽度+起始位置坐标,如果大于父控件高度,就换行
int w = rb.getMeasuredWidth() + 2 * childMarginHorizontal + startX + getPaddingLeft() + getPaddingRight();
if (w > getMeasuredWidth()) {
startX = 0;
rowNm++;
}
//否则起始位置后移
startX += rb.getMeasuredWidth() + 2 * childMarginHorizontal;
height = (rowNm + 1) * (rb.getMeasuredHeight() + 2 * childMarginVertical) + getPaddingB