É possível ligar para o AnimatesDrop em um mkannotationview em vez de mkpinannotationview?
-
22-09-2019 - |
Pergunta
Você sabia que o mkpinannotationview tem um método "Animatesdrop" para animar uma anotação de pinos de cima para apontar no mapa com uma sombra? Ok, é possível fazer isso com uma imagem personalizada ??
Solução
Você sempre pode fazer sua animação personalizada no método MKMapViewDelegate.
- (void)mapView:(MKMapView *)mapView didAddAnnotationViews:(NSArray *)views
Provavelmente algo assim (você não receberá a animação de sombra sofisticada, se quiser, precisa fazer isso sozinho):
- (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];
}
}
Versão rápida
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()
}
}
Outras dicas
Mesma resposta que @GCamp Somente em Swift para os interessados
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()
}
}
Obrigado @GCamp pela sua resposta, ele funciona bem, mas eu o modifico um pouco para ser preciso para onde a visualização será descartada no MapView, verifique o código abaixo:
- (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];
}
}
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow