ScrollView viewPager ListView 结合使用的问题及解决办法
2015-06-16 10:30
435 查看
1. 解决ScrollView 和viewPager滑动冲突的问题
需要重写ScrollView ,使得viewpager获取到横向滑动事件
代码如下
public class PagerScrollView extends ScrollView {
private GestureDetector mGestureDetector;
public PagerScrollView(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
init();
}
public PagerScrollView(Context context) {
super(context);
init();
}
public PagerScrollView(Context context, AttributeSet attrs) {
super(context, attrs);
init();
}
private void init() {
mGestureDetector = new GestureDetector(getContext(),
new YScrollDetector());
setFadingEdgeLength(0);
}
@Override
public boolean onInterceptTouchEvent(MotionEvent ev) {
return super.onInterceptTouchEvent(ev)
&& mGestureDetector.onTouchEvent(ev);
}
private class YScrollDetector extends SimpleOnGestureListener {
@Override
public boolean onScroll(MotionEvent e1, MotionEvent e2,
float distanceX, float distanceY) {
if (Math.abs(distanceY) >= Math.abs(distanceX)) {
return true;
}
return false;
}
}
}
2. viewpager在scrollVIew不显示问题
需要设置scrollView 的属性 android:fillViewport="true"
viewPager先给一个固定高度,之后会动态改变
3. viewPager中加入ListView不能滚动问题
需要计算listView的高度,同时需要动态设置viewpager的高度
重写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
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
int expandSpec = MeasureSpec.makeMeasureSpec(Integer.MAX_VALUE >> 2,
MeasureSpec.AT_MOST);
super.onMeasure(widthMeasureSpec, expandSpec);
}
}
计算listview 的高度
/**
* 获取Listview的高度,然后设置ViewPager的高度
*
* @param listView
* @return
*/
public static int setListViewHeightBasedOnChildren1(ListView listView) {
// 获取ListView对应的Adapter
ListAdapter listAdapter = listView.getAdapter();
if (listAdapter == null) {
// pre-condition
return 0;
}
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);
return params.height;
}
5. scrollView滚动到顶端问题
uiHandler.post(new Runnable() {
@Override
public void run() {
// TODO Auto-generated method stub
scorllView.scrollTo(0, 0);
}
});
基本这5步可以解决问题
需要重写ScrollView ,使得viewpager获取到横向滑动事件
代码如下
public class PagerScrollView extends ScrollView {
private GestureDetector mGestureDetector;
public PagerScrollView(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
init();
}
public PagerScrollView(Context context) {
super(context);
init();
}
public PagerScrollView(Context context, AttributeSet attrs) {
super(context, attrs);
init();
}
private void init() {
mGestureDetector = new GestureDetector(getContext(),
new YScrollDetector());
setFadingEdgeLength(0);
}
@Override
public boolean onInterceptTouchEvent(MotionEvent ev) {
return super.onInterceptTouchEvent(ev)
&& mGestureDetector.onTouchEvent(ev);
}
private class YScrollDetector extends SimpleOnGestureListener {
@Override
public boolean onScroll(MotionEvent e1, MotionEvent e2,
float distanceX, float distanceY) {
if (Math.abs(distanceY) >= Math.abs(distanceX)) {
return true;
}
return false;
}
}
}
2. viewpager在scrollVIew不显示问题
需要设置scrollView 的属性 android:fillViewport="true"
viewPager先给一个固定高度,之后会动态改变
3. viewPager中加入ListView不能滚动问题
需要计算listView的高度,同时需要动态设置viewpager的高度
重写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
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
int expandSpec = MeasureSpec.makeMeasureSpec(Integer.MAX_VALUE >> 2,
MeasureSpec.AT_MOST);
super.onMeasure(widthMeasureSpec, expandSpec);
}
}
计算listview 的高度
/**
* 获取Listview的高度,然后设置ViewPager的高度
*
* @param listView
* @return
*/
public static int setListViewHeightBasedOnChildren1(ListView listView) {
// 获取ListView对应的Adapter
ListAdapter listAdapter = listView.getAdapter();
if (listAdapter == null) {
// pre-condition
return 0;
}
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);
return params.height;
}
5. scrollView滚动到顶端问题
uiHandler.post(new Runnable() {
@Override
public void run() {
// TODO Auto-generated method stub
scorllView.scrollTo(0, 0);
}
});
基本这5步可以解决问题
相关文章推荐
- ScrollView滚动条颜色的设置方法
- 刷新Activity中的scrollview示例(局部ui刷新)
- 使用ViewPager实现高仿launcher左右拖动效果
- Android之ScrollView嵌套ListView和GridView冲突的解决方法
- 实现轮转广告带底部指示的自定义ViewPager控件
- 自定义RadioButton和ViewPager实现TabHost带滑动的页卡效果
- 使用ViewPager实现android软件使用向导功能实现步骤
- Android ViewPager相册横向移动的实现方法
- android 实现ScrollView自动滚动的实例代码
- Android中实现监听ScrollView滑动事件
- Android ScrollView使用代码示例
- 开源中国 OsChina Android 客户端源码分析(3)可以拖拽的ScrollView
- android 中的 scrollView 控件的默认位置和子控件的焦点冲突
- viewpager的layout_width="wrap_content"无效问题
- 安卓布局应用学习代码附带效果图
- Fragment+viewpager+Fragment 嵌套 第二次进入该fragment不显示数据
- android自定义tabbar,并带badgeview消息提示
- ViewPager播放图片问题
- ViewPager : Banner滚动
- 在ScrollView中嵌套ListView时,ListView只能显示一行多一点