How to add a push pin to a MKMapView(IOS) when touching? How to add a push pin to a MKMapView(IOS) when touching? ios ios

How to add a push pin to a MKMapView(IOS) when touching?


You can use a UILongPressGestureRecognizer for this. Wherever you create or initialize the mapview, first attach the recognizer to it:

UILongPressGestureRecognizer *lpgr = [[UILongPressGestureRecognizer alloc]     initWithTarget:self action:@selector(handleLongPress:)];lpgr.minimumPressDuration = 2.0; //user needs to press for 2 seconds[self.mapView addGestureRecognizer:lpgr];[lpgr release];

Then in the gesture handler:

- (void)handleLongPress:(UIGestureRecognizer *)gestureRecognizer{    if (gestureRecognizer.state != UIGestureRecognizerStateBegan)        return;    CGPoint touchPoint = [gestureRecognizer locationInView:self.mapView];       CLLocationCoordinate2D touchMapCoordinate =         [self.mapView convertPoint:touchPoint toCoordinateFromView:self.mapView];    YourMKAnnotationClass *annot = [[YourMKAnnotationClass alloc] init];    annot.coordinate = touchMapCoordinate;    [self.mapView addAnnotation:annot];    [annot release];}

YourMKAnnotationClass is a class you define that conforms to the MKAnnotation protocol. If your app will only be running on iOS 4.0 or later, you can use the pre-defined MKPointAnnotation class instead.

For examples on creating your own MKAnnotation class, see the sample app MapCallouts.


Thanks to Anna for providing such a great answer! Here is a Swift version if anybody is interested (the answer has been updated to Swift 4.1 syntax).

Creating UILongPressGestureRecognizer:

let longPressRecogniser = UILongPressGestureRecognizer(target: self, action: #selector(MapViewController.handleLongPress(_:)))longPressRecogniser.minimumPressDuration = 1.0mapView.addGestureRecognizer(longPressRecogniser)

Handling the gesture:

@objc func handleLongPress(_ gestureRecognizer : UIGestureRecognizer){    if gestureRecognizer.state != .began { return }    let touchPoint = gestureRecognizer.location(in: mapView)    let touchMapCoordinate = mapView.convert(touchPoint, toCoordinateFrom: mapView)    let album = Album(coordinate: touchMapCoordinate, context: sharedContext)    mapView.addAnnotation(album)}