自定义ListView,既可以与Scrollview嵌套使用正常显示,也可以独立使用正常滑动

ListView与Scrollview嵌套使用时,只能显示一个item的高度,需要重写onMeasure方法,这样就可以显示完整了,但是ListView的高度就是所有子item的高度的和并且无法滑动,正好使用scrollview的滑动功能,二指完美结合。

 @Override
    public void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
        int expandSpec = MeasureSpec.makeMeasureSpec(Integer.MAX_VALUE >> 2, MeasureSpec.AT_MOST);
        super.onMeasure(widthMeasureSpec, expandSpec);
    }

但是这个重写了onMeasure的ListView自己却武功尽废,无法滑动了,原因是ListView的高度是子item的高度和,当然就无法滑动了。要解决这个问题,就还得从onMeasure着手。我们希望的是ListView的高度是父控件给的最大高度,而不是无限大。而且ListView必须测量子item的高度,这样才可以确定自己的高度,才可以让scrollview确定自己的高度。解决方案:

public class MyListView extends ListView {

    public MyListView(Context context, AttributeSet attrs) {
        super(context, attrs);
    }

    public MyListView(Context context) {
        super(context);
    }

    public MyListView(Context context, AttributeSet attrs, int defStyle) {
        super(context, attrs, defStyle);
    }

    @Override
    public void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
        //获取父控件给的高度
        int heightSize = MeasureSpec.getSize(heightMeasureSpec);
        //ScrollView+ListView只显示一个条目的原因是两个控件都不确定高度
        //想将ListView高度固定为父控件给的高度,同时要求ListView测量子view的高度,必须MeasureSpec.AT_MOST模式
        //组装heightMeasureSpec
        int expandSpec = MeasureSpec.makeMeasureSpec(heightSize, MeasureSpec.AT_MOST);
        int heightMode = MeasureSpec.getMode(expandSpec);
        //传入参数
        super.onMeasure(widthMeasureSpec, expandSpec);
    }

}

 

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值