ios - current - maps swift 4
¿hay una manera de obtener direcciones en mkmapview utilizando una API de Apple integrada? (4)
Sé que los mapas de Google son conocidos por ser los mejores mapas, pero no quiero tener que descargar un montón de bibliotecas adicionales y todo eso. Preferiría hacer algo rápido y simple para obtener una ruta rápida desde el punto A hasta B y terminar con eso. ¿Hay una manera de hacer esto con funciones / bibliotecas integradas? ¿Puede alguien apuntarme en la dirección correcta?
EDITAR
No estoy tratando de obtener indicaciones paso a paso ni nada en mi caso, solo quiero dibujar una línea de principio a fin. Tal vez dar opciones sobre qué rutas tomar. ¿Hay una manera de hacerlo o no?
Otra posibilidad es enviar la dirección a la aplicación Apple Maps. Acabo de ver esto hecho en un entorno profesional y ese fue el método elegido.
Versión rápida
let request = MKDirectionsRequest();
request.source = MKMapItem.mapItemForCurrentLocation();
let locationPlacemark = MKPlacemark(coordinate: CLLocationCoordinate2DMake(13.724362, 100.515342), addressDictionary: nil);
request.destination = MKMapItem(placemark: locationPlacemark);
request.transportType = MKDirectionsTransportType.Any;
request.requestsAlternateRoutes = true;
let directions = MKDirections(request: request);
directions.calculateDirectionsWithCompletionHandler ({
(response: MKDirectionsResponse?, error: NSError?) in
print(response?.description)
print(error?.description)
guard let response = response else {
//handle the error here
return;
}
self.myRoute = response.routes[0]
self.mkMapView.addOverlay(self.myRoute!.polyline)
});
y su delegado
func mapView(mapView: MKMapView, rendererForOverlay overlay: MKOverlay) -> MKOverlayRenderer {
let myLineRenderer = MKPolylineRenderer(polyline: (self.myRoute?.polyline)!)
myLineRenderer.strokeColor = UIColor.redColor()
myLineRenderer.lineWidth = 3
return myLineRenderer
}
si desea mostrar un diálogo de alerta cuando pulsó un Pin, haga esto:
- (void)mapView:(MKMapView *)mapView annotationView:(MKAnnotationView *)view calloutAccessoryControlTapped:(UIControl *)control {
[mapView deselectAnnotation:view.annotation animated:YES];
if ([view.annotation isKindOfClass:[PinOfProject class]])
{
CLLocationCoordinate2D coordinate = [view.annotation coordinate];
MKPlacemark *placemark = [[MKPlacemark alloc] initWithCoordinate:coordinate addressDictionary:nil];
MKMapItem *mapitem = [[MKMapItem alloc] initWithPlacemark:placemark];
self.mapItem = mapitem;
CGPoint pin = [mapView convertCoordinate:view.annotation.coordinate toPointToView:self.view];
CGRect rec = CGRectMake(pin.x-13, pin.y-14,view.frame.size.width,view.frame.size.height);
[self showAlertInformationForTrash:rec];
}
}
-(void)showAlertInformationForTrash:(CGRect)rec{
UIActionSheet *actionSheet = [[UIActionSheet alloc] initWithTitle:@"Show Route?" delegate:self cancelButtonTitle:nil destructiveButtonTitle:nil otherButtonTitles:@"Route", @"Cancel", nil];
actionSheet.tag = 1;
[actionSheet showFromRect:rec inView:self.view animated:YES];
}
- (void)actionSheet:(UIActionSheet *)actionSheet clickedButtonAtIndex:(NSInteger)buttonIndex {
if (buttonIndex == 0) {
[self showRouteToAnnotation];
}
}
-(void)showRouteToAnnotation{
MKMapItem *myMapItem = self.mapItem;
MKDirectionsRequest *request = [[MKDirectionsRequest alloc] init];
[request setSource:[MKMapItem mapItemForCurrentLocation]];
[request setDestination:myMapItem];
[request setTransportType:MKDirectionsTransportTypeAutomobile]; // This can be limited to automobile and walking directions.
[request setRequestsAlternateRoutes:NO]; // Gives you several route options.
MKDirections *directions = [[MKDirections alloc] initWithRequest:request];
[directions calculateDirectionsWithCompletionHandler:^(MKDirectionsResponse *response, NSError *error) {
if (!error) {
for (MKRoute *route in [response routes]) {
[self.mapView addOverlay:[route polyline] level:MKOverlayLevelAboveRoads]; // Draws the route above roads, but below labels.
for (int i = 0; i < route.steps.count; i++) {
MKRouteStep *step = [route.steps objectAtIndex:i];
NSString *newStep = step.instructions;
NSLog(@"%@", newStep);
}
}
}
}];
}
- (MKOverlayRenderer *)mapView:(MKMapView *)mapView rendererForOverlay:(id<MKOverlay>)overlay
{
if ([overlay isKindOfClass:[MKPolyline class]]) {
MKPolylineRenderer *renderer = [[MKPolylineRenderer alloc] initWithOverlay:overlay];
[renderer setStrokeColor:[UIColor blueColor]];
[renderer setLineWidth:5.0];
return renderer;
}
return nil;
}
- Oh, pero tenga en cuenta que hago una propiedad en mi .h @property (strong, nonatomic) MKMapItem * mapItem;
En iOS 7, puede obtener y mostrar direcciones usando MKDirectionsRequest
.
Aquí hay algunos ejemplos de código para mostrar indicaciones desde la ubicación actual a otro elemento del mapa:
MKDirectionsRequest *request = [[MKDirectionsRequest alloc] init];
[request setSource:[MKMapItem mapItemForCurrentLocation]];
[request setDestination:myMapItem];
[request setTransportType:MKDirectionsTransportTypeAny]; // This can be limited to automobile and walking directions.
[request setRequestsAlternateRoutes:YES]; // Gives you several route options.
MKDirections *directions = [[MKDirections alloc] initWithRequest:request];
[directions calculateDirectionsWithCompletionHandler:^(MKDirectionsResponse *response, NSError *error) {
if (!error) {
for (MKRoute *route in [response routes]) {
[myMapView addOverlay:[route polyline] level:MKOverlayLevelAboveRoads]; // Draws the route above roads, but below labels.
// You can also get turn-by-turn steps, distance, advisory notices, ETA, etc by accessing various route properties.
}
}
}];
Si es nuevo en iOS 7, deberá implementar el mapView:rendererForOverlay:
para que aparezca cualquier superposición. Algo como:
- (MKOverlayRenderer *)mapView:(MKMapView *)mapView rendererForOverlay:(id<MKOverlay>)overlay
{
if ([overlay isKindOfClass:[MKPolyline class]]) {
MKPolylineRenderer *renderer = [[MKPolylineRenderer alloc] initWithOverlay:overlay];
[renderer setStrokeColor:[UIColor blueColor]];
[renderer setLineWidth:5.0];
return renderer;
}
return nil;
}