默认情况下,GoogleMap不会为地图拖动开始和拖动停止提供事件。 I have already reported that problem here
我想要使用简单handler
事件的自定义 onTouch
并将其与setOnCameraChangeListener
结合使用。
然而,我未能找到如何访问onTouch
GoogleMap
事件的{{1}}事件。它不提供回调。
我想知道如何在 Google Map API v2 中处理地图的onTouch事件?
答案 0 :(得分:41)
以下是确定拖动开始和拖动结束事件的可能解决方法:
您必须延长SupportMapFragment
或MapFragment
。在onCreateView()
中,您必须将自己的MapView
打包在自定义的FrameLayout
中(例如,下面是类TouchableWrapper
),您可以在其中拦截触摸事件并识别地图被窃听与否。如果您的onCameraChange
被调用,只需检查地图视图是否被按下(例如,下面是变量mMapIsTouched
)。
示例代码:
更新1:
getView()
dispatchTouchEvent()
代替onInterceptTouchEvent()
自定义FrameLayout:
private class TouchableWrapper extends FrameLayout {
@Override
public boolean dispatchTouchEvent(MotionEvent ev) {
switch (ev.getAction()) {
case MotionEvent.ACTION_DOWN:
mMapIsTouched = true;
break;
case MotionEvent.ACTION_UP:
mMapIsTouched = false;
break;
}
return super.dispatchTouchEvent(ev);
}
}
在自定义的MapFragment中:
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup parent, Bundle savedInstanceState) {
mOriginalContentView = super.onCreateView(inflater, parent, savedInstanceState);
mTouchView = new TouchableWrapper(getActivity());
mTouchView.addView(mOriginalContentView);
return mTouchView;
}
@Override
public View getView() {
return mOriginalContentView;
}
在相机中更改回调方法:
private final OnCameraChangeListener mOnCameraChangeListener = new OnCameraChangeListener() {
@Override
public void onCameraChange(CameraPosition cameraPosition) {
if (!mMapIsTouched) {
refreshClustering(false);
}
}
};
答案 1 :(得分:2)
有一种更简单的方法可以做到这一点,在这样的onCameraMoveStarted
监听器上处理你的案例
代码段
下方@Override
public void onCameraMoveStarted(int reason) {
if (reason == OnCameraMoveStartedListener.REASON_GESTURE) {
Toast.makeText(this, "The user gestured on the map.",
Toast.LENGTH_SHORT).show();
} else if (reason == OnCameraMoveStartedListener
.REASON_API_ANIMATION) {
Toast.makeText(this, "The user tapped something on the map.",
Toast.LENGTH_SHORT).show();
} else if (reason == OnCameraMoveStartedListener
.REASON_DEVELOPER_ANIMATION) {
Toast.makeText(this, "The app moved the camera.",
Toast.LENGTH_SHORT).show();
}
}