原文移至: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);
}
}