ScrollView嵌套Listview导致Listview显示不全解决方案

本文介绍了一种解决ScrollView与嵌套Listview(Gridview)冲突的方法,通过重写Listview的onMeasure方法使Listview适应item数目高度,避免滚动冲突。并提供了解决ScrollView自动滑动到Listview位置的问题的简单解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在做大量图片展示的APP的时候(如电商项目)经常需要用ScrollView去嵌套Listview(Gridview),由于ScrollView和Listview中都有上下滑动属性,所以产生了冲突。解决的办法是让Listview完全展开,只需要重写一下Listview的onMeasure(int widthMeasureSpec, int heightMeasureSpec)方法即可。

public class MyListView extends ListView {

public MyListView(Context context) {
        super(context);
        // TODO Auto-generated constructor stub
    }

public MyListView(Context context, AttributeSet attrs) {
        super(context, attrs);
        // TODO Auto-generated constructor stub
    }

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

    @Override 
    public void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { 

        int expandSpec = MeasureSpec.makeMeasureSpec( 
                Integer.MAX_VALUE >> 2, MeasureSpec.AT_MOST); 
        super.onMeasure(widthMeasureSpec, expandSpec); 
    } 
}

在Listview构建过程中如果measure specification mode是MeasureSpec.AT_MOST的话,就表示Listview会完全适应其item的数目高度,Listview不会产生滑动的情况,这样ScrollView中的Listview就得以正常显示了。
然而可能我们又会发现一个问题,Listview虽然正常显示了,但是有时候在进入界面的时候,ScrollView会自动滑动到Listview的位置,假如Listview位置在页面的下半部分,整个页面一加载其下半部分就会显示在屏幕顶部,而其上半部分就会滑出屏幕顶部,这显然不是我们所希望的,其实解决这个问题很简单,在加载页面的时候只需要让页面滑回来即可

mScrollView.smoothScrollTo(0, 0);

一行代码搞定!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值