ListView。但刚开始的时候,会发现放入的小ListView会显示不完全,它的高度始终有问题。上网查了下,发现别人也有遇到这样的问题,而大多
数人都不推荐这样的设计,因为默认情况下Android是禁止在ScrollView中放入另外的ScrollView的,它的高度是无法计算的。
又搜索了一下,发现有StackOverflow上的牛人已经解决了这个问题,经过试验发现是可以解决问题的,它的思路就是在设置完ListView的
Adapter后,根据ListView的子项目重新计算ListView的高度,然后把高度再作为LayoutParams设置给ListView,这
样它的高度就正确了,以下是源码:
Java代码
public class Utility {
public static void setListViewHeightBasedOnChildren(ListView listView) {
ListAdapter listAdapter = listView.getAdapter()
if (listAdapter == null) {
// pre-condition
return
}
int totalHeight = 0
for (int i = 0i <listAdapter.getCount()i++) {
View listItem = listAdapter.getView(i, null, listView)
listItem.measure(0, 0)
totalHeight += listItem.getMeasuredHeight()
}
ViewGroup.LayoutParams params = listView.getLayoutParams()
params.height = totalHeight + (listView.getDividerHeight() * (listAdapter.getCount() - 1))
listView.setLayoutParams(params)
}
}
只要在设置ListView的Adapter后调用此静态方法即可让ListView正确的显示在其父ListView的ListItem中。但是要注意
的是,子ListView的每个Item必须是LinearLayout,不能是其他的,因为其他的Layout(如RelativeLayout)没有
重写onMeasure(),所以会在onMeasure()时抛出异常。
在ScrollView中嵌套ListView(或者ScrollView)的另外一个问题就是,子ScrollView中无法滑动的(如果它没有显示完
全的话),因为滑动事件会被父ScrollView吃掉,如果想要让子ScrollView也可以滑动,只能强行截取滑动事件,有牛人在论坛中发过代码说
可以。虽然我没有亲自试过,但估计是可行的。
虽然在ScrollView中显示ScrollView在技术上的难题可以攻破,但是这样的设计却是非常差的用户体验因为用户会不容易看到和 *** 作子
ScrollView中的内容。比如好的设计是,父ListView的每个Item只显示概括性的描述,然后点击其Item会进入另外一个页面来详细描述
和展示以及对这个Item的 *** 作。
在item的布局中可以再添加ListView
但是由于两个滚动有冲突,所以让item里的listview计算定高,让外层的可以滚动就可以实现真正的嵌套了。
计算定高
public class Utility {public static void setListViewHeightBasedOnChildren(ListView listView) {
ListAdapter listAdapter = listView.getAdapter()
if (listAdapter == null) {
return
}
int totalHeight = 0
for (int i = 0 i < listAdapter.getCount() i++) {
View listItem = listAdapter.getView(i, null, listView)
listItem.measure(0, 0)
totalHeight += listItem.getMeasuredHeight()
}
ViewGroup.LayoutParams params = listView.getLayoutParams()
params.height = totalHeight + (listView.getDividerHeight() * (listAdapter.getCount() - 1))
listView.setLayoutParams(params)
}
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)