当我们ScrollView下嵌套ListView、GridView时会出现显示不全的问题,这样我们大部分是会重写ListView、gridView
一:重写ListView、gridView
重写ListView:
public class MyListView extends ListView {
public MyListView(Context context) {
// TODO Auto-generated method stub
super(context);
}
public MyListView(Context context, AttributeSet attrs) {
// TODO Auto-generated method stub
super(context, attrs);
}
public MyListView(Context context, AttributeSet attrs, int defStyle) {
// TODO Auto-generated method stub
super(context, attrs, defStyle);
}
@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
// TODO Auto-generated method stub
int expandSpec = MeasureSpec.makeMeasureSpec(Integer.MAX_VALUE >> 2,
MeasureSpec.AT_MOST);
super.onMeasure(widthMeasureSpec, expandSpec);
}
}
重写GridView:
/**
*自定义gridview,解决ScrollView中嵌套gridview显示不正常的问题(1行)
*/
public class MyGridView extends GridView{
public MyGridView(Context context, AttributeSet attrs) {
super(context, attrs);
}
public MyGridView(Context context) {
super(context);
}
public MyGridView(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);
}
}
但是有时候我们会发现,重写后加载多条数据时依然在列表最后显示不完全,这是因为我们设置的dividerheight的值没有被计算进去,所以计算的空间值要比实际的小,所以会显示不全,我们可以设置dividerheight=0,然后在item中的底部添加分隔线,这样显示的高度跟实际高度就会保持一致。
通过上面的方法可能会解决大部分人的问题,但是有时候我们会遇到条目中可能有隐藏的部分,可能点击条目中的button后才会显示,这部分布局显示后,listview的高度已经不会动态改变,所以依然显示不全,另一种方法就是,我们可以给listview添加头布局,脚布局,把不属于listview的那部分放到里面,只是要注意设置条目点击监听的时候要考虑头,脚布局,这样的效果也不错,赶紧去试试吧!