如何实现Android标记的拖放操作?

时间:2010-10-09 18:45:22

标签: android drag-and-drop android-mapview marker

您好? 我正在使用Android中的MapView应用程序。我有三个标记,我希望以后可以使用Google Map API getlocation-function。为了试一试,我想用拖放功能移动标记,然后检查位置。

任何人已经拖拽到Android标记上工作,或者知道如何开始计算它?

/ AK

6 个答案:

答案 0 :(得分:44)

实施Google Maps Android API v2,请参阅:https://developers.google.com/maps/documentation/android/并在GoogleMap对象setOnMarkerDragListener上设置。对于Ex:

map.setOnMarkerDragListener(new OnMarkerDragListener() {
        @Override
        public void onMarkerDragStart(Marker arg0) {
            // TODO Auto-generated method stub
            Log.d("System out", "onMarkerDragStart..."+arg0.getPosition().latitude+"..."+arg0.getPosition().longitude);
        }

        @SuppressWarnings("unchecked")
        @Override
        public void onMarkerDragEnd(Marker arg0) {
            // TODO Auto-generated method stub
            Log.d("System out", "onMarkerDragEnd..."+arg0.getPosition().latitude+"..."+arg0.getPosition().longitude);

            map.animateCamera(CameraUpdateFactory.newLatLng(arg0.getPosition()));
        }

        @Override
        public void onMarkerDrag(Marker arg0) {
            // TODO Auto-generated method stub
            Log.i("System out", "onMarkerDrag...");
        }
    });

//Don't forget to Set draggable(true) to marker, if this not set marker does not drag.

map.addMarker(new MarkerOptions()
    .position(crntLocationLatLng)
    .icon(BitmapDescriptorFactory.fromResource(R.drawable.icon_my_location))
    .draggable(true));

答案 1 :(得分:24)

来自Here is a sample project

one of my books显示Android中Google地图上标记的拖放动作。

简而言之,它使用onTouchEvent()来检测用户何时触摸并将手指靠近标记。然后,它会从叠加层中删除标记,但会使用RelativeLayout将相同的图像放在地图的顶部。然后,在“移动”触摸事件时,移动图像(比强制整个叠加重绘更快)。当手指抬起时,图像会被移除,但标记会被放回到新位置的叠加层中。

答案 2 :(得分:4)

对于MapsV2。使用谷歌地图活动。别写自己的。

        mMap.setOnMapClickListener(new GoogleMap.OnMapClickListener() {
            @Override
            public void onMapClick(LatLng latLng) {
                mVisitingMarker.setPosition(latLng);
                mMap.animateCamera(CameraUpdateFactory.newLatLng(latLng));
            }
        });

        mMap.setOnMarkerDragListener(new GoogleMap.OnMarkerDragListener() {
            @Override
            public void onMarkerDragStart(Marker arg0) {
            }

            @SuppressWarnings("unchecked")
            @Override
            public void onMarkerDragEnd(Marker arg0) {
               Log.d("System out", "onMarkerDragEnd...");
                mMap.animateCamera(CameraUpdateFactory.newLatLng(arg0.getPosition()));
            }

            @Override
            public void onMarkerDrag(Marker arg0) {
            }
        });

答案 3 :(得分:3)

以下是Kotlin Lover的答案!非常简单!正如您在下面看到的。

   googleMap.addMarker(
        MarkerOptions()
            .position(latLatLng).draggable(true)
    )

下面是用于获取最终拖动位置的线性代码

   mMap.setOnMarkerDragListener(object : GoogleMap.OnMarkerDragListener {
        override fun onMarkerDragStart(arg0: Marker) {

        }

        override fun onMarkerDragEnd(arg0: Marker) {
            mMap.animateCamera(CameraUpdateFactory.newLatLngZoom(arg0.position, 1.0f))
            val message = arg0.position.latitude.toString() + "" + arg0.position.longitude.toString()
            Log.d(TAG + "_END", message)
        }

        override fun onMarkerDrag(arg0: Marker?) {
            val message = arg0!!.position.latitude.toString() + "" + arg0.position.longitude.toString()
            Log.d(TAG + "_DRAG", message)
        }
    })

如果有任何疑问,可以在评论框中发表评论!快乐编码????

答案 4 :(得分:1)

我发现了CommonsWare拖放功能的一些优化。

我正在我的地图上用标记进行一些精确的测量,我希望我的标记完全在我触摸的位置并抬起我的手指,因此测量结果非常准确。

如果您触摸“靠近”标记,则从CommonsWare打印原始标记时,标记不会移动到该确切点,而是随着手指的移动而移动。 我需要在ACTION_DOWN,ACTION_MOVE和ACTION_UP上显示我手指下方的标记。

如果有人需要,这是代码。我要感谢CommonsWare做这个功能,这是一个非常好的主意。

这是我修改的代码的一部分。

我的MapView是mapa;

        @Override
    public boolean onTouchEvent(MotionEvent event, MapView mapView) {

        final int action=event.getAction();
        final int x=(int)event.getX();
        final int y=(int)event.getY();
        boolean result=false;

              if (action==MotionEvent.ACTION_DOWN) {
                for (OverlayItem item : mOverlays) {
                  Point p=new Point(0,0);

                  mapa.getProjection().toPixels(item.getPoint(), p);

                      //I maintain the hitTest's bounds so you can still
                      //press near the marker
                  if (hitTest(item, marker, x-p.x, y-p.y)) {
                    result=true;

                    inDrag=item;

                    mOverlays.remove(inDrag);
                    populate();

                        //Instead of using the DragImageOffSet and DragTouchOffSet
                        //I use the x and y coordenates from the Point
                    setDragImagePosition(x, y);

                    dragImage.setVisibility(View.VISIBLE);

                    break;
                  }
                }
              }
              else if (action==MotionEvent.ACTION_MOVE && inDrag!=null) {
                setDragImagePosition(x, y);

                result=true;
              }
              else if (action==MotionEvent.ACTION_UP && inDrag!=null) {
                dragImage.setVisibility(View.GONE);

                    //I get the geopoint without using any OffSet, directly with the 
                    //Point coordenates
                GeoPoint pt=mapa.getProjection().fromPixels(x,y);

                OverlayItem toDrop=new OverlayItem(pt, inDrag.getTitle(),
                                                   inDrag.getSnippet());
                orig = inDrag.getMarker(0);

                    //In my case I had down heading Arrows as markers, so I wanted my 
                    //bounds to be at the center bottom
                toDrop.setMarker(boundCenterBottom(orig));

                mOverlays.add(toDrop);
                populate();

                inDrag=null;
                result=true;
              }


           return(result || super.onTouchEvent(event, mapView));


    }

    private void setDragImagePosition(int x, int y) {
      RelativeLayout.LayoutParams lp=
        (RelativeLayout.LayoutParams)dragImage.getLayoutParams();

          //Instead of using OffSet I use the Point coordenates.
          //I want my arrow to appear pointing to the point I am moving, so 
          //I set the margins as the Point coordenates minus the Height and half the
          //width of my arrow.
      lp.setMargins(x-(dragImage.getWidth()/2),y-dragImage.getHeight(), 0, 0);
      dragImage.setLayoutParams(lp);
    }

通过这种方式,您可以将箭头显示在您按下的位置,而不是箭头移动到的位置。

答案 5 :(得分:0)

Here是Android中Mapview中Drag&Drop引脚的完整代码