解决多个listview或者gridview与scrollview滚动条冲突的问题

本文介绍了如何处理多个listview或gridview在scrollview中滚动条的冲突问题,通过获取adapter中每一项item的高度并动态设置listview或gridview的高度,以实现正确的滚动行为。示例代码提供了适用于4列gridview的算法,可根据实际需求进行调整。

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

RT

根据adapter获取到每一项item的高度,再动态设置listview或者gridview的高度。

public class Utility {
		public void setListViewHeightBasedOnChildren(ListView listView) {
			ListAdapter listAdapter = listView.getAdapter();
			if (listAdapter == null) {
				return;
			}
			int totalHeight = 0;
			int count = listAdapter.getCount();
			for (int i = 0; i < count; i++) { // listAdapter.getCount()返回数据项的数目
				View listItem = listAdapter.getView(i, null, listView);
				listItem.measure(0, 0); // 计算子项View 的宽高
				totalHeight += listItem.getMeasuredHeight(); // 统计所有子项的总高度
			}
			ViewGroup.LayoutParams params = listView.getLayoutParams();
			params.height = totalHeight
					+ (listView.getDividerHeight() * (count - 1));
			// listView.getDividerHeight()获取子项间分隔符占用的高度
			// params.height最后得到整个ListView完整显示需要的高度
			listView.setLayoutParams(params);
		}

		public void setGridViewHeightBasedOnChildren(GridView gridView) {
			ListAdapter listAdapter = gridView.getAdapter();
			if (listAdapter == null) {
				return;
			}
			int totalHeight = 0;
			int count = listAdapter.getCount();
			View listItem = listAdapter.getView(0, null, gridView);
			listItem.measure(0, 0); // 计算子项View 的宽高
			totalHeight = listItem.getMeasuredHeight() + 10; // 统计所有子项的总高度
			int yu = count % 4;
			ViewGroup.LayoutParams params = gridView.getLayoutParams();
			if (yu > 0) {
				params.height = (count - yu) / 4 * (totalHeight + 10)
						+ totalHeight;
			} else {
				params.height = count / 4 * totalHeight + (count / 4 - 1) * 10;
			}
			gridView.setLayoutParams(params);
		}
	}

我这儿gridview是显示4列,所以获取高度的时候算法是这样,可以根据需要更改。

 


用法在listview.setadapter之后,调用此方法中的其中某一个.

new Utility().setListViewHeightBasedOnChildren(AppList);


 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值