Android 安卓 ViewPager中使用Gallery!

本文详细阐述了解决Android应用中ViewPager与Gallery滑动冲突的方法,包括焦点问题的解决策略和冲突区域的正确判断。通过实例代码展示如何在ScrollView内正确设置Gallery与ViewPager的交互,避免误触事件导致的滑动行为。最终,通过实例代码解决了冲突问题,确保了应用的正常交互体验。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51

分类: Android(收集整理)   767人阅读  评论(5)  收藏  举报

本次开发项目过程中,要在ViewPager中使用Gallery。遇到一个问题Gallery无法滑动,猜想应该是焦点问题,在网上搜到如下方法:

http://www.eoeandroid.com/thread-176552-1-1.html

[java]  view plain copy
  1. mPager.setOnTouchListener(new View.OnTouchListener()  
  2. {  
  3.         @Override  
  4.         public boolean onTouch(View v, MotionEvent event)   
  5.         {  
  6.                 Rect rect = new Rect();  
  7.                 g.getLocalVisibleRect(rect);  
  8.                                                                    
  9.                 if(rect.contains((int)event.getX(), (int)event.getY()))  
  10.                 {  
  11.                         return g.dispatchTouchEvent(event);  
  12.                 }  
  13.                                    
  14.                 return false;  
  15.         }  
  16. });  

解决思路:在ViewPager的onTouch事件中,判断一下点击位置,如果是在Gallery里面,就交给Gallery去处理。

新问题:Gallery是能滑动了,但是Gallery的范围获取的不对,在Gallery外面点击也能滑动。我的Gallery是在一个ScrollView(能上下滚动,还包含其它内容)里面,然后把ScrollView放到ViewPager里面。不知道其它情况可会遇到这个问题。

解决方法:还是按照上面的解决思路,不过不用getLocalVisibleRect去获取区域。通过getLocationOnScreen获取Gallery左上角的起始点,再通过Gallery的高度和宽度计算出来范围。特别说明:event.getY()得到的是相对坐标,要使用event.getRawY() 才是相对于屏幕的点。

[java]  view plain copy
  1. mPager.setOnTouchListener(new View.OnTouchListener()  
  2. {  
  3.         @Override  
  4.         public boolean onTouch(View v, MotionEvent event)  
  5.         {  
  6.                 int[] location = new int[2];  
  7.                 gallery.getLocationOnScreen(location);  
  8.                 if (location[0] != 0)  
  9.                 {  
  10.                         return false;  
  11.                 }  
  12.   
  13.                 if (event.getRawY() > location[1] && event.getRawY() - location[1] < gallery.getHeight())  
  14.                 {  
  15.                         return gallery.dispatchTouchEvent(event);  
  16.                 }  
  17.   
  18.                 return false;  
  19.         }  
  20. });  
后来我们项目组发现其实主要是跟横向的scrollview之间的冲突,在网上找到了解决方法,下面贴出 真正意义上解决问题的代码

public class UserGallery extends Gallery implements OnGestureListener {
        ViewPager mPager;
         
        public ViewPager getmPager() {
                return mPager;
        }
 
        public void setmPager(ViewPager mPager) {
                this .mPager = mPager;
        }
 
        /**
          * @param context
          * @param attrs
          */
        public UserGallery(Context context) {
                super (context);
                // TODO Auto-generated constructor stub
        }
 
        /**
          * @param context
          * @param attrs
          */
        public UserGallery(Context context, AttributeSet attrs) {
                super (context, attrs);
                // TODO Auto-generated constructor stub
        }
         
        @Override
        public boolean dispatchTouchEvent(MotionEvent ev) {
                // TODO Auto-generated method stub
                mPager.requestDisallowInterceptTouchEvent( true );
                return super .dispatchTouchEvent(ev);
        }
 
        @Override
        public boolean onInterceptTouchEvent(MotionEvent ev) {
                // TODO Auto-generated method stub
                mPager.requestDisallowInterceptTouchEvent( true );
                return super .onInterceptTouchEvent(ev);
        }
 
        @Override
        public boolean onTouchEvent(MotionEvent event) {
                // TODO Auto-generated method stub
                mPager.requestDisallowInterceptTouchEvent( true );
                return super .onTouchEvent(event);
        }
 
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值