scrollerview嵌套listview问题解决
2016-07-08 12:56
204 查看
scrollerview嵌套listview问题解决
测量listview的高度,解决listview显示不全留白问题自定义listview
使用liearLayout代替listview
解决listview显示不全问题
package com.fcuser.utils; import android.view.View; import android.view.ViewGroup; import android.widget.ListAdapter; import android.widget.ListView; public class Utility { public static void setListViewHeightBasedOnChildren(ListView listView) { //获取ListView对应的Adapter ListAdapter listAdapter = listView.getAdapter(); if (listAdapter == null) { // pre-condition return; } int totalHeight = 0; for (int i = 0, len = listAdapter.getCount(); i < len; 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() * (listAdapter.getCount() - 1)); //listView.getDividerHeight()获取子项间分隔符占用的高度 //params.height最后得到整个ListView完整显示需要的高度 listView.setLayoutParams(params); } } 放在list.setAdapter(adapter)后面。
2、使用LinearLayout取代ListView
既然ListView不能适应ScrollView、那就换一个可以适应ScrollView的控件、干嘛非要吊死在ListView这一棵树上呢?而LinearLayout是最好的选择、但如果我仍想继续使用已经定义好的Adater呢?我们可以直接循环已经写好的Adapter、把item添加到LinearLayout即可、代码如下
/** * 绑定布局 */ public void bindLinearLayout(MyBaseAdapter adapter) { int count = adapter.getCount(); mLinearLayout.removeAllViews(); for (int i = 0; i < count; i++) { View v = adapter.getView(i, null, null); /* v.setOnClickListener(this.mClickListener);*/ //绑定Adapter的数据到LinearLayout布局 mLinearLayout.addView(v); } Log.v("countTAG", ""+count); }
3、自定义可适应ScrollView的ListView
就是要用ListView怎么办?那就只好自定义一个类继承自ListView、通过重写其onMeasure方法、达到对ScrollView适配的效果、下面是继承了ListView的自定义类、可以直接使用的
import android.content.Context; import android.util.AttributeSet; import android.widget.ListView; public class ListViewForScrollView extends ListView { public ListViewForScrollView(Context context) { super(context); } public ListViewForScrollView(Context context, AttributeSet attrs) { super(context, attrs); } public ListViewForScrollView(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); } @Override /** * 重写该方法、达到使ListView适应ScrollView的效果 */ protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { int expandSpec = MeasureSpec.makeMeasureSpec(Integer.MAX_VALUE >> 2, MeasureSpec.AT_MOST); super.onMeasure(widthMeasureSpec, expandSpec); } } 这个方法只要重写onMeasure方法、需要改动的地方比起方法一少不少代码、在xml布局中和Activty中使用的ListView改成这个自定义ListView就行了、这个方法有一个的小毛病、就是默认显示的首项是ListView、需要手动把ScrollView滚动至最顶端、代码如下 sv = (ScrollView) findViewById(R.id.act_solution_4_sv); sv.smoothScrollTo(0, 0);
相关文章推荐
- 一片空白
- python学习(2)- Python 简介
- MySQL索引原理及慢查询优化
- 图片的变换
- HDU 3232Crossing Rivers(数学期望)
- mysql分表的3种方法(转)
- 图片腐蚀效果
- 死锁:系统中有资源n个,现有k个进程互斥使用,每个进程最多使用m个资源
- SSH KEY免密码验证
- JSONObject json
- webstorm中使用git
- python 接受远程数据并写入数据库的相关模块
- 关于服务器的深入补充
- centos安装php扩展imagick-高性能处理图片
- Android GPS坐标距离计算
- 在命令行调用Junit测试类
- 一个简易的视屏播放器
- CSS3 涟漪效果
- Robert 的军队
- 根据Request获取客户端IP 内网IP及外网IP