百度地图滑动冲突的问题解决

原文移至:http://blog.csdn.net/jsmeli/article/details/73248836 请移步查看!


相信很多人用了镶嵌型的百度地图都会有滑动冲突的问题,那么如何解决呢?

我开始的解决思路就是屏蔽当前页面的滑动事件,下面说一个比较简单的解决方法:

通过比较百度Map的包名是否一致来 屏蔽滑动事件。


就拿ViewPager滑动事件与百度Map的滑动事件举例,可以自己定义一个ViewPager,

在canScroll方法中比较包名来判断滑动事件的返回值,返回true则表示自己处理滑动,屏蔽

掉ViewPager的滑动事件,变成百度Map的滑动事件,这样就完美解决冲突。


public class MyViewPager extends ViewPager{
    public MyViewPager(Context context) {
        super(context);
    }


    public MyViewPager(Context context, AttributeSet attrs) {
        super(context, attrs);
    }
    @Override
    protected boolean canScroll(View v, boolean checkV, int dx, int x, int y) {
        if(v.getClass().getName().equals("com.baidu.mapapi.map.MapView")) {
            return true;
        }
        return super.canScroll(v, checkV, dx, x, y);
    }


}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章