Можно ли вызвать animatesDrop в MKAnnotationView, а не в MKPinAnnotationView? - PullRequest
9 голосов
/ 26 января 2010

Знаете ли вы, что в MKPinAnnotationView есть метод "animatesDrop" для анимации аннотации булавки сверху вниз, чтобы указать на карте тень? ОК, возможно ли сделать это с пользовательским изображением ??

Ответы [ 3 ]

21 голосов
/ 26 января 2010

Вы всегда можете сделать свою собственную анимацию в методе MKMapViewDelegate.

- (void)mapView:(MKMapView *)mapView didAddAnnotationViews:(NSArray *)views

Вероятно, что-то в этом роде (вы не получите необычную анимацию теней, если вы хотите, вам нужно сделать это самостоятельно):

- (void) mapView:(MKMapView *)mapView didAddAnnotationViews:(NSArray *)views {
    CGRect visibleRect = [mapView annotationVisibleRect]; 
    for (MKAnnotationView *view in views) {
       CGRect endFrame = view.frame;

       CGRect startFrame = endFrame; startFrame.origin.y = visibleRect.origin.y - startFrame.size.height;
       view.frame = startFrame;

       [UIView beginAnimations:@"drop" context:NULL]; 
       [UIView setAnimationDuration:1];

       view.frame = endFrame;

       [UIView commitAnimations];
    }
}

Swift Version

func mapView(mapView: MKMapView, didAddAnnotationViews views: [MKAnnotationView]) {
    let visibleRect = mapView.annotationVisibleRect

    for view:MKAnnotationView in views{
        let endFrame:CGRect = view.frame
        var startFrame:CGRect = endFrame
        startFrame.origin.y = visibleRect.origin.y - startFrame.size.height
        view.frame = startFrame;

        UIView.beginAnimations("drop", context: nil)
        UIView.setAnimationDuration(1)

        view.frame = endFrame;

        UIView.commitAnimations()
    }
}
3 голосов
/ 08 августа 2015

Тот же ответ, что и @ gcamp только в Swift для заинтересованных

func mapView(mapView: MKMapView, didAddAnnotationViews views: [MKAnnotationView]) {
    let visibleRect = mapView.annotationVisibleRect

    for view:MKAnnotationView in views{
        let endFrame:CGRect = view.frame
        var startFrame:CGRect = endFrame
        startFrame.origin.y = visibleRect.origin.y - startFrame.size.height
        view.frame = startFrame;

        UIView.beginAnimations("drop", context: nil)
        UIView.setAnimationDuration(1)

        view.frame = endFrame;

        UIView.commitAnimations()
    }
}
1 голос
/ 01 января 2013

Спасибо @gcamp за ваш ответ, он работает нормально, но я немного его модифицирую, чтобы быть точным в том месте, где будет отображаться представление mapView, проверьте код ниже:

- (void)mapView:(MKMapView *)mapView didAddAnnotationViews:(NSArray *)views
{
CGRect visibleRect = [mapView annotationVisibleRect];
for (MKAnnotationView *view in views)
 {
    CGRect endFrame = view.frame;
    endFrame.origin.y -= 15.0f;
    endFrame.origin.x += 8.0f;
    CGRect startFrame = endFrame;
    startFrame.origin.y = visibleRect.origin.y - startFrame.size.height;
    view.frame = startFrame;

    [UIView beginAnimations:@"drop" context:NULL];
    [UIView setAnimationDuration:0.2];

    view.frame = endFrame;

    [UIView commitAnimations];
 }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...