Search code examples
iosobjective-cmkmapviewmkannotationmkoverlay

Need to add a Fixed Overlay like on mapview in IOS


I need to create a map view interface, which is something similar to the OLA Cabs Application in iOS. What I exactly wanna do is to fix an overlay on mapView and allow the user to scroll the map view across it. So that the overlay can be fixed at any location the User wants it to, I searched a lot about overlays, in iOS and MapKit, but couldn't make it possible. If some one can give me tips for achieving this I would be really grateful. Here is a snapshot of the screen

enter image description here

Here the annotation remains fixed and you can move the map view across it, So that when you stop the mapview, the overlay will be pointing to the new location, where you stopped


Solution

  • Click here to download demo...

    enter image description here

    Create a fix MKAnnotation and image view object to animating the location change effect in Map view.

    @property (nonatomic, strong) CustomAnnotation      *fixAnnotation;
    @property (nonatomic, strong) UIImageView           *annotationImage;
    

    Add this code in viewDidLoad() method:

     // Fix annotation
        _fixAnnotation = [[CustomAnnotation alloc] initWithTitle:@"Fix annotation" subTitle:@"Location" detailURL:nil location:self.mapView.userLocation.coordinate];
        [self.mapView addAnnotation:self.fixAnnotation];
    
        // Annotation image.
        CGFloat width = 64;
        CGFloat height = 64;
        CGFloat margiX = self.mapView.center.x - (width / 2);
        CGFloat margiY = self.mapView.center.y - (height / 2) - 32;
        // 32 is half size for navigationbar and status bar height to set exact location for image.
    
        _annotationImage = [[UIImageView alloc] initWithFrame:CGRectMake(margiX, margiY, width, height)];
        [self.annotationImage setImage:[UIImage imageNamed:@"mapannotation.png"]];
    

    Now have to remove image when you drag a map view and add image which looks like an annotation. And after completion of that add annotation and remove image from Map View.

    - (void)mapView:(MKMapView *)mapView regionWillChangeAnimated:(BOOL)animated {
        NSLog(@"Region will changed...");
        [self.mapView removeAnnotation:self.fixAnnotation];
        [self.mapView addSubview:self.annotationImage];
    
    }
    
    
    - (void)mapView:(MKMapView *)mapView regionDidChangeAnimated:(BOOL)animated {
        NSLog(@"Region did changed...");
        [self.annotationImage removeFromSuperview];
        CLLocationCoordinate2D centre = [mapView centerCoordinate];
        self.fixAnnotation.coordinate = centre;
        [self.mapView addAnnotation:self.fixAnnotation];
    }