关闭

关于LiseView ScrollView 问题

标签: android
348人阅读 评论(0) 收藏 举报
分类:

 

参考:http://www.cnblogs.com/zhwl/p/3333585.html

 

在开发的过程当中,由于手机屏幕的大小的限制,我们经常需要使用滑动的方式,来显示更多的内容。在最近的工作中,遇见一个需求,需要将ListView嵌套到ScrollView中显示。于是乎有了如下布局: 

 

  1. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"   
  2.     xmlns:tools="http://schemas.android.com/tools"   
  3.     android:layout_width="match_parent"   
  4.     android:layout_height="match_parent"   
  5.     android:background="#FFE1FF"   
  6.     android:orientation="vertical" >   
  7.     <ScrollView   
  8.         android:layout_width="match_parent"   
  9.         android:layout_height="match_parent" >   
  10.         <LinearLayout   
  11.             android:layout_width="match_parent"   
  12.             android:layout_height="match_parent" >   
  13.             <ListView   
  14.                 android:id="@+id/listView1"   
  15.                 android:layout_width="match_parent"   
  16.                 android:layout_height="match_parent"   
  17.                 android:fadingEdge="vertical"   
  18.                 android:fadingEdgeLength="5dp" />   
  19.         </LinearLayout>   
  20.     </ScrollView>   
  21. </LinearLayout> 

运行程序,无论你如何调整layout_width,layout_height属性,ListView列表只显示一列 

在查阅的各种文档和资料后,发现在ScrollView中嵌套ListView空间,无法正确的计算ListView的大小,故可以通过代码,根据当前的ListView的列表项计算列表的尺寸。实现代码如下: 

 

[java] view plaincopy
  1. public class MainActivity extends Activity {   
  2.     private ListView listView;   
  3.     @Override   
  4.     protected void onCreate(Bundle savedInstanceState) {   
  5.         super.onCreate(savedInstanceState);   
  6.         setContentView(R.layout.activity_main);   
  7.         listView = (ListView) findViewById(R.id.listView1);   
  8.         String[] adapterData = new String[] { "Afghanistan""Albania",… … "Bosnia"};   
  9.         listView.setAdapter(new ArrayAdapter<String>(this,android.R.layout.simple_list_item_1,adapterData));   
  10.         setListViewHeightBasedOnChildren(listView);   
  11.     }   
  12.     public void setListViewHeightBasedOnChildren(ListView listView) {   
  13.         // 获取ListView对应的Adapter   
  14.         ListAdapter listAdapter = listView.getAdapter();   
  15.         if (listAdapter == null) {   
  16.             return;   
  17.         }   
  18.    
  19.         int totalHeight = 0;   
  20.         for (int i = 0, len = listAdapter.getCount(); i < len; i++) {   
  21.             // listAdapter.getCount()返回数据项的数目   
  22.             View listItem = listAdapter.getView(i, null, listView);   
  23.             // 计算子项View 的宽高   
  24.             listItem.measure(00);    
  25.             // 统计所有子项的总高度   
  26.             totalHeight += listItem.getMeasuredHeight();    
  27.         }   
  28.    
  29.         ViewGroup.LayoutParams params = listView.getLayoutParams();   
  30.         params.height = totalHeight+ (listView.getDividerHeight() * (listAdapter.getCount() - 1));   
  31.         // listView.getDividerHeight()获取子项间分隔符占用的高度   
  32.         // params.height最后得到整个ListView完整显示需要的高度   
  33.         listView.setLayoutParams(params);   
  34.     }   
  35. }   
运行结果,OK问题搞定,打完收工 

 

 

附上 crollView内自定义控件左右滑动不受影响自定义控件:

public class MyScrollView extends ScrollView {

 public MyScrollView(Context context) {
  super(context);
  mGestureDetector = new GestureDetector(new YScrollDetector());
  setFadingEdgeLength(0);
 }

 public MyScrollView(Context context, AttributeSet attrs, int defStyle) {
  super(context, attrs, defStyle);
  mGestureDetector = new GestureDetector(new YScrollDetector());
  setFadingEdgeLength(0);
 }

 public MyScrollView(Context context, AttributeSet attrs) {
  super(context, attrs);
  mGestureDetector = new GestureDetector(new YScrollDetector());
  setFadingEdgeLength(0);
 }

 private GestureDetector mGestureDetector;
 View.OnTouchListener mGestureListener;

 @Override
 public boolean onInterceptTouchEvent(MotionEvent ev) {
  return super.onInterceptTouchEvent(ev)
    && mGestureDetector.onTouchEvent(ev);
 }

 class YScrollDetector extends SimpleOnGestureListener {
  @Override
  public boolean onScroll(MotionEvent e1, MotionEvent e2,
    float distanceX, float distanceY) {
   if (distanceY != 0 && distanceX != 0) {

   }
   if (Math.abs(distanceY) >= Math.abs(distanceX)) {
    return true;
   }
   return false;
  }
 }
}

 

 

 

 

 

 

 

 

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:18625次
    • 积分:309
    • 等级:
    • 排名:千里之外
    • 原创:7篇
    • 转载:28篇
    • 译文:0篇
    • 评论:1条
    文章分类
    最新评论