码迷,mamicode.com
首页 > 移动开发 > 详细

Android开发中ScollView嵌套ListView显示不全问题解决

时间:2015-03-03 18:45:25      阅读:124      评论:0      收藏:0      [点我收藏+]

标签:android应用   listview   gridview   

      大多数时候,我们用ListView来加载数据的页面不需要在ListView的外面再套上一个ScollView,因为ListView本身可以滚动显示数据。有时我们页面中除要用ListView显示列表数据之外还要显示其它数据,这时候就需要在整个页面最个层套上一个Scollview,否则显示就可能出现问题(比如在ListView上面已经有很多其它数据,显示在手机上直接导致ListView看不见了,这时就要在整个屏幕布局加ScollView实现滑动界面),用过ScollView嵌套ListView的朋友都知道,在不做任务处理的情况下,ListView的数据只能显示一行多一点点,其它的就看不到了,这个问题怎么解决呢?通常我们可以有下面两种方式:

1,计算高度:

private int totalHeight=0;

public static void setListViewHeight(ListView listView){

/*得到适配器*/

Aadpter adapter = listView.getAdapter();

/*遍历控件*/

for (int i = 0; i < adapter .getCount(); i++) {

View view = adapter .getView(i, null, listView);

/*测量一下子控件的高度*/

view.measure(View.MeasureSpec.UNSPECIFIED, View.MeasureSpec.UNSPECIFIED);

totalHeight+=view.getMeasuredHeight();

}

  /*控件之间的间隙*/

totalHeight+=listView.getDividerHeight()*(listView.getCount()-1);

/*2、赋值给ListView的LayoutParams对象*/

ViewGroup.LayoutParams params = listView.getLayoutParams();

params.height = totalHeight;

listView.setLayoutParams(params);

}

2,重写ListView的onMeasure:

public class WholeListView extends ListView {  
  
    public WholeListView (Context context) {  
        super(context);  
    }  
  
    public WholeListView (Context context, AttributeSet attrs) {  
        super(context, attrs);  
    }  
  
    public WholeListView (Context context, AttributeSet attrs, int defStyle) {  
        super(context, attrs, defStyle);  
    }  
  
    @Override  
    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {  
        int expandSpec = MeasureSpec.makeMeasureSpec(Integer.MAX_VALUE >> 2,  
                MeasureSpec.AT_MOST);  
        super.onMeasure(widthMeasureSpec, expandSpec);  
    }  
}  

当然上面两个方法对GridView及Expandlistview也是有效的。

Android开发中ScollView嵌套ListView显示不全问题解决

标签:android应用   listview   gridview   

原文地址:http://blog.csdn.net/true100/article/details/44039811

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!