- 浏览: 5775231 次
- 性别:
- 来自: 上海
文章分类
- 全部博客 (890)
- WindowsPhone (0)
- android (88)
- android快速迭代 (17)
- android基础 (34)
- android进阶 (172)
- android高级 (0)
- android拾遗 (85)
- android动画&效果 (68)
- Material Design (13)
- LUA (5)
- j2me (32)
- jQuery (39)
- spring (26)
- hibernate (20)
- struts (26)
- tomcat (9)
- javascript+css+html (62)
- jsp+servlet+javabean (14)
- java (37)
- velocity+FCKeditor (13)
- linux+批处理 (9)
- mysql (19)
- MyEclipse (9)
- ajax (7)
- wap (8)
- j2ee+apache (24)
- 其他 (13)
- phonegap (35)
最新评论
-
Memories_NC:
本地lua脚本终于执行成功了,虽然不是通过redis
java中调用lua脚本语言1 -
ZHOU452840622:
大神://处理返回的接收状态 这个好像没有监听到 遇 ...
android 发送短信的两种方式 -
PXY:
拦截部分地址,怎么写的for(int i=0;i<lis ...
判断是否登录的拦截器SessionFilter -
maotou1988:
Android控件之带清空按钮(功能)的AutoComplet ...
自定义AutoCompleteTextView -
yangmaolinpl:
希望有表例子更好。。。,不过也看明白了。
浅谈onInterceptTouchEvent、onTouchEvent与onTouch
一般来说ViewPager如果有很多页的话,会加载它的上一页,当前页和下一页,当从n页以后再想回到第一页,就会再加载一次,这样第一页很多操作后的数据就会被重置,原因是在PagerAdapter的destroyItem经常会移除View,类似下面这样的代码:
现在我不想移除它,需要让View保持原来的状态
那么就要采用一个Map用于保存View
HashMap<Integer, View> viewMap = new HashMap<Integer, View>();
然后在PagerAdapter的instantiateItem方法中如下用法:
这样就保证不会View不会被重置了。
伪代码如下:
上面有一个自定义控件WinView,是一个刮刮卡效果的类,上面有手势刮奖的效果,
现在问题是,由于ViewPager和WinView都具有手势操作的能力,所以这两个控件放在一起回发生冲突,为了防止这种冲突就需要重写一下ViewPager
重写canScroll方法,将WinView排除在外即可。
如果不重写ViewPager,那么需要在WinView的
public boolean onTouchEvent(MotionEvent event)中写入如下语句,该方法专门用于剥夺父级控件的控制权
这样可以不用重写ViewPager了,推荐这样写(虽然我没试过!P)
@Override public void destroyItem(View container, int position, Object object) { // ((ViewPager) container).removeView(viewMap.get(position));// }
现在我不想移除它,需要让View保持原来的状态
那么就要采用一个Map用于保存View
HashMap<Integer, View> viewMap = new HashMap<Integer, View>();
然后在PagerAdapter的instantiateItem方法中如下用法:
@Override public Object instantiateItem(View container, int position) { View view = null; if (viewMap.containsKey(position)) { view = viewMap.get(position); } else { view = getLayoutInflater().inflate(R.layout.item_for_gallery, null); viewMap.put(position, view); ((ViewPager) container).addView(view, 0); } }
这样就保证不会View不会被重置了。
伪代码如下:
package com.mobovip.bgr; import java.util.ArrayList; import java.util.HashMap; import android.content.Context; import android.os.Bundle; import android.os.Parcelable; import android.view.View; import android.view.ViewGroup; import com.mobovip.model.Prize; import com.mobovip.util.Utils; public class PrizeActivity extends BaseActivity { private Context context; private HashMap<Integer, View> viewMap = new HashMap<Integer, View>(); private com.mobovip.view.MyViewPager viewPager; private MyAdapter adapter; private ArrayList<Prize> prizes; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_prize); context = this; initViews(); } @Override public void onResume() { super.onResume(); initValues(); } @Override protected void onDestroy() { // TODO Auto-generated method stub super.onDestroy(); } @Override protected void initViews() { // TODO Auto-generated method stub viewPager = (com.mobovip.view.MyViewPager) findViewById(R.id.viewPager); // viewPager.setOnPageChangeListener(new MyOnPageChangeListener()); } @Override protected void initValues() { // TODO Auto-generated method stub } @Override protected void updateViews(Object obj) { // TODO Auto-generated method stub prizes = (ArrayList<Prize>) obj; if (prizes == null) { return; } if (adapter == null) { adapter = new MyAdapter(); viewPager.setAdapter(adapter); viewPager.setCurrentItem(0); } else { adapter.notifyDataSetChanged(); } } class MyAdapter extends PagerAdapter { @Override public void destroyItem(View container, int position, Object object) { // 无需removeView // ((ViewPager) container).removeView(viewMap.get(position));// // View view = (View)object; } @Override public void finishUpdate(View container) { } @Override public int getCount() { return prizes.size(); } /** * 跳转到每个页面都要执行的方法 */ @Override public void setPrimaryItem(View container, int position, Object object) { } @Override public Object instantiateItem(View container, int position) { View view = null; if (viewMap.containsKey(position)) { view = viewMap.get(position); } else { view = getLayoutInflater().inflate(R.layout.item_for_gallery, null); viewMap.put(position, view); final Prize prize = prizes.get(position); String format = "MM-dd-yyyy HH:mm:ss"; int days = Utils.days(prize.getCreateTime(), getCurTime(format), format); prize.setExpires(prize.getExpires() - days); ((ViewPager) container).addView(view, 0); com.mobovip.view.WinView winView = (com.mobovip.view.WinView) view.findViewById(R.id.winView); winView.setPrize(prize); //处理其他逻辑 ...... } return view; } @Override public boolean isViewFromObject(View container, Object object) { return container == (object); } @Override public void restoreState(Parcelable arg0, ClassLoader arg1) { } @Override public Parcelable saveState() { return null; } @Override public void startUpdate(View container) { } @Override public void finishUpdate(ViewGroup container) { // TODO Auto-generated method stub super.finishUpdate(container); } } }
上面有一个自定义控件WinView,是一个刮刮卡效果的类,上面有手势刮奖的效果,
现在问题是,由于ViewPager和WinView都具有手势操作的能力,所以这两个控件放在一起回发生冲突,为了防止这种冲突就需要重写一下ViewPager
import android.content.Context; import android.util.AttributeSet; import android.view.View; public class MyViewPager extends ViewPager { public MyViewPager(Context context) { super(context); // TODO Auto-generated constructor stub } public MyViewPager(Context context, AttributeSet attrs) { super(context, attrs); // TODO Auto-generated constructor stub } @Override protected boolean canScroll(View v, boolean checkV, int dx, int x, int y) { if (v != this && v instanceof WinView) {// 解决冲突 return true; } return super.canScroll(v, checkV, dx, x, y); } }
重写canScroll方法,将WinView排除在外即可。
如果不重写ViewPager,那么需要在WinView的
public boolean onTouchEvent(MotionEvent event)中写入如下语句,该方法专门用于剥夺父级控件的控制权
// 阻止父控件获得触摸操作,拦截触摸事件,防止与ViewPager等控件发生手势冲突 getParent().requestDisallowInterceptTouchEvent(true);
这样可以不用重写ViewPager了,推荐这样写(虽然我没试过!P)
评论
2 楼
yangsiyu11
2016-06-24
最后一句话最关键了 找了一下午
1 楼
lxh2002
2015-08-08
感谢楼主分享,正好解决了我的问题。不过发现,
重写ViewPager的canScroll()完全正常,但在自定义View中requestDisallowInterceptTouchEvent()则无效,还没仔细研究是什么原因。
重写ViewPager的canScroll()完全正常,但在自定义View中requestDisallowInterceptTouchEvent()则无效,还没仔细研究是什么原因。
发表评论
-
某些android手机获取不到IMEI问题
2018-08-21 14:17 7489某些山寨机可能拿不到IMEI 如果非要IMEI可以模拟一个 ... -
APK安装成功后点击"打开"再按Home键应用会重启的问题
2018-08-21 14:13 2709安装系统SD卡里面的apk或者原有的程序更新版本的时候, ... -
使用volley链接Https地址时报SSLHandshakeException
2018-08-21 14:06 2027在真实设备上出现以下错误 ︰ Volley error: ... -
PhotoView+Viewpager双指缩放的时候出现pointerIndex out of range问题
2017-07-10 14:30 4183PhotoView+Viewpager开发图集效果的时候,在某 ... -
Android6.0权限封装
2017-04-01 12:04 1525简介 Android6.0中对权限分为了一般权限和危险权限。 ... -
实现点击 WebView 中的图片,调用原生控件展示图片
2017-04-01 11:14 2744现在有很多时候,我们的 App 都进行了混合开发,而最简单,最 ... -
Android 方法引用数超过 65535 优雅解决
2017-03-31 09:37 1472随着应用不断迭代更新,业务线的扩展,应用越来越大(比如:集成了 ... -
android引用资源@与属性?备忘单
2017-03-30 10:09 1232几天前我偶然发现了我A ... -
ViewPager 与SwipeRefreshLayout,RecyclerView,ScrollView滑动冲突解决方法
2017-03-30 09:55 6508ViewPager 作为一个横向滚动的控件, 在 ViewGr ... -
Android中一些你可能没注意的小效果实现
2017-02-15 21:09 0http://www.see-source.com/blog/ ... -
Android热修复:Andfix和Hotfix,两种方案的比较与实现
2017-02-15 21:00 0http://www.see-source.com/blog/ ... -
Android 从网页中跳转到本地App
2017-01-11 09:27 1822我们在使用微信、QQ、京东等app的时候,会发现有时候通过他们 ... -
Activity的启动模式和onNewIntent
2016-12-28 09:10 1291一、启动模式介绍 启 ... -
android5.0使用Notification报RemoteServiceException的解决办法
2016-08-31 16:13 11458有时android5.0下使用Notification会报如下 ... -
RecyclerView 中的 item 如何居中问题
2016-05-18 09:52 12388一个很简单的Item布局,我只要让它由上而下排列,文字居中 ... -
sqlite3:not found 解决方法
2015-12-08 16:03 2493最最最重要,先root你的手机吧 sqlite3 为一个可 ... -
隐藏底部虚拟键NavigationBar实现全屏
2015-10-08 17:20 9791import android.app.Activity; ... -
服务端执行慢或网络延迟时,Volley多次发送请求的问题
2015-07-27 15:40 6937原文: Android Volley double post ... -
如何获取 Android 设备的CPU核数、时钟频率以及内存大小
2015-06-30 17:04 4320原帖: http://www.jianshu.com/p/f7 ... -
android点滴5
2015-04-10 17:32 2001一些小效果的实现 http://www.see-source. ...
相关推荐
Viewpager setOffscreenPageLimit(0) 无效 至少会缓存一页 使用此viewpage 代替原生 的 之后设置setOffscreenPageLimit(0) 可不缓存
Android listview viewpager 滑动 跳动 冲突解决 ListView中嵌套ViewPage有或者滑动手势冲突解决 blog 地址 : http://blog.csdn.net/aaawqqq/article/details/43824631
本资源为使用ViewPager和Fragment实现页面切换和底部导航栏的效果源码,建议配合Android应用开发--底部导航栏效果的一种实现方式(ViewPager&Fragment)文章查看。
多个ViewPager嵌套的滑动冲突的处理,处理方法简单易懂,还标有注释,使用过程中没有bug,希望对大家有帮助吧
这个网址必须收藏,解决viewpager嵌套viewpager和其他view 冲突问题
解决SlidngMenu和ViewPager滑动冲突
viewpager 关于子页面控件监听的解决方法,含原代码,现成可用
自定义的ViewPager,可以实现页面之前的相互切换,可以...同时该ViewPager解决了传统ViewPager和ListView,ScrollView滑动冲突问题,当然ListView的滑动冲突实在ScrollView中解决的。实践表明,滑动切换效果较好。
ListView + ViewPager + Fragment + ListView 三层嵌套滑动控件的显示冲突解决方案,并且动态更新ViewPager的高度适应当前高度而不会出现大片空白
android 自定义RecyClerView与ViewPager事件冲突解决方法。自定义RecyClerView和自定义ViewPager,重写了onInterceptTouchEvent和dispatchTouchEvent方法,实现自定义RecyClerView列表上下滑动,同时也可以自定义...
HorizontalScrollView中嵌套viewpager的冲突的解决方法
NULL 博文链接:https://obacow.iteye.com/blog/2007511
解决滑动冲突的viewpager, 解决viewpager和其他空间 冲突的问题.把viewpaer的左右滑动禁用了.
完美解决ListView和ViewPager的滑动冲突
listview和viewpager及tabhost的touch事件冲突的解决,至少可以实现在重写父viewGroup的onintercpettouchevent的实现拦截和重写子viewGroup的onintercpettouchevent实现不允许拦截。
使用Fragment +ViewPager 框架 并且解决ViewPager与Gallery 的事件冲突
获取ViewPager 与 ScrollView 冲突事件的解决
//解决ViewPager和轮播图滑动冲突 @Override public boolean dispatchTouchEvent(MotionEvent ev) { switch (ev.getAction()) { case MotionEvent.ACTION_DOWN: // 让当前viewpager的父控件不去拦截touch事件 ...
自定义ViewGoup实现垂直和水平滑动,而且解决了垂直滑动和ViewPager水平滑动的冲突.
通过重写SwipeRefreshLayout的requestDisallowInterceptTouchEvent和onInterceptTouchEvent方法解决SwipeRefreshLayout与ViewPager滑动事件冲突问题