平时ExpandableListView我用到的机会不是很多,最近刚好用到了,给ExpandableListView配置groupItem和childItem的时候,发现自动配的高度太小了,所以直接配置了一下
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="50dp"
android:background="@color/blue5"
android:orientation="vertical">
<TextView
android:id="@+id/tvGroup"
android:textSize="18sp"
android:textColor="@color/white"
android:layout_gravity="center"
android:gravity="center"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
</LinearLayout>
可以看到,我给它的高度设置成了50dp,按理来说应该是很大了,但实际查看发现并没有变化。
由于我没有去看计算高度的源码,这里就不说原理了,直接上解决方法
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/blue5"
android:orientation="vertical">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="50dp"
android:orientation="vertical">
<TextView
android:id="@+id/tvGroup"
android:textSize="18sp"
android:textColor="@color/white"
android:layout_gravity="center"
android:gravity="center"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
</LinearLayout>
</LinearLayout>
区别就在于,将最外层LinearLayout的高度改回自适应,然后在中间再加一层LinearLayout,这时候,给中间层的LinearLayout设置的具体高度,就是实际显示的高度了,当然,如果你只有一个控件,可以直接给这个控件设置具体高度,也可以达到想要的效果。childItem也是同理。
补充一个小知识:
移除自带的间隔线
android:divider="@null"
移除自带的展开收缩箭头
android:groupIndicator="@null"
需要用到自定义展开收缩图标的时候,可以在自己的groupView布局文件那里去设置,状态的改变则在adapter的getGroupView根据isExpanded去改变。
具体原理暂时没去看,有时间又记起来的话,会去补回来。