Jak mohu otevřít Google Maps na cestu pomocí souřadnic na iPhone

hlasů
18

Já používám UIMapView pro zobrazení místa na iPhone. Chci udělat pokyny z aktuálního umístění do oblasti zájmu, nemyslím si, že jeho možné pomocí MapKit (ale pokud je to, prosím informujte) Tak jsem se otevře buď v aplikaci Mapy Google nebo Safari ji zobrazit.

Mohu-li to provést zadáním souřadnic z aktuálního umístění (), aby se koordinuje (umístění zájmu) Mám tyto délky a zeměpisné šířky. Nebo musím používat adresy ulice?

Mám-li to nutné používat adresy ulice, mohu si je od zeměpisné šířky a délky.

Položena 10/10/2009 v 14:58
zdroj uživatelem
V jiných jazycích...                            


7 odpovědí

hlasů
75

Jo, to není možné pomocí MapKit. Dalo by se pokusit vytvořit požadavek na mapy Google URL, který obsahuje jak vaši aktuální polohu a cíl, který se otevře v aplikaci Mapy Google s směrech.

Zde je příklad url:

http://maps.google.com/?saddr=34.052222,-118.243611&daddr=37.322778,-122.031944

Zde je návod, jak byste mohli realizovat to v kódu:

CLLocationCoordinate2D start = { 34.052222, -118.243611 };
CLLocationCoordinate2D destination = { 37.322778, -122.031944 };    

NSString *googleMapsURLString = [NSString stringWithFormat:@"http://maps.google.com/?saddr=%1.6f,%1.6f&daddr=%1.6f,%1.6f",
                                 start.latitude, start.longitude, destination.latitude, destination.longitude];

[[UIApplication sharedApplication] openURL:[NSURL URLWithString:googleMapsURLString]];
Odpovězeno 12/10/2009 v 06:37
zdroj uživatelem

hlasů
4

Použít měchu kód pro obě mapy Google a Apple v Swift 3 -

if UIApplication.shared.canOpenURL(URL(string: "comgooglemaps://")!)
        {
            let urlString = "http://maps.google.com/?daddr=\(destinationLocation.latitude),\(destinationLocation.longitude)&directionsmode=driving"

            // use bellow line for specific source location

            //let urlString = "http://maps.google.com/?saddr=\(sourceLocation.latitude),\(sourceLocation.longitude)&daddr=\(destinationLocation.latitude),\(destinationLocation.longitude)&directionsmode=driving"

            UIApplication.shared.openURL(URL(string: urlString)!)
        }
        else
        {
            //let urlString = "http://maps.apple.com/maps?saddr=\(sourceLocation.latitude),\(sourceLocation.longitude)&daddr=\(destinationLocation.latitude),\(destinationLocation.longitude)&dirflg=d"
            let urlString = "http://maps.apple.com/maps?daddr=\(destinationLocation.latitude),\(destinationLocation.longitude)&dirflg=d"

            UIApplication.shared.openURL(URL(string: urlString)!)
        }
Odpovězeno 04/01/2017 v 19:42
zdroj uživatelem

hlasů
2

Je possible.Use MKMapView Get koordinovat umístění, kam jste poklepal na telefonu a pomocí dvou poloha požádat KML soubor z webové služby Google, analyzovat KML soubor (vzorek app KML diváka v web pro vývojáře) a zobrazení trasy .. ..
Děkuji

Odpovězeno 29/06/2011 v 07:23
zdroj uživatelem

hlasů
1

Google zkontroluje mapa Prvním z nich je instalován v zařízení, či nikoli

if ([[UIApplication sharedApplication] canOpenURL:
         [NSURL URLWithString:@"comgooglemaps://"]]) {
        [[UIApplication sharedApplication] openURL:[NSURL URLWithString:@"comgooglemaps://?saddr=23.0321,72.5252&daddr=22.9783,72.6002&zoom=14&views=traffic"]];
    } else {
        NSLog(@"Can't use comgooglemaps://");
    }

Přidejte dotazu schématu v .plist

<key>LSApplicationQueriesSchemes</key>
<array>
 <string>comgooglemaps</string>
</array>
Odpovězeno 15/06/2017 v 11:06
zdroj uživatelem

hlasů
1

Je možné ukázat trasu MapKit: Stačí použít MKPolyline

Mám křivky řetězec z googleMapsApi. I analyzovat ji na serveru s php, a vrátit se konečné polilyne řetězec mé aplikaci.

NSMutableArray *points = [myApp decodePolyline:[route objectForKey:@"polyline"]];

if([points count] == 0)
{
    return;
}

// while we create the route points, we will also be calculating the bounding box of our route
// so we can easily zoom in on it. 
MKMapPoint northEastPoint; 
MKMapPoint southWestPoint; 

// create a c array of points. 
MKMapPoint* pointArr = malloc(sizeof(CLLocationCoordinate2D) * [points count]);

for(int idx = 0; idx < points.count; idx++)
{
    // break the string down even further to latitude and longitude fields. 
    NSString* currentPointString = [points objectAtIndex:idx];
    NSArray* latLonArr = [currentPointString componentsSeparatedByCharactersInSet:[NSCharacterSet characterSetWithCharactersInString:@","]];

    CLLocationDegrees latitude  = [[latLonArr objectAtIndex:0] doubleValue];
    CLLocationDegrees longitude = [[latLonArr objectAtIndex:1] doubleValue];

    // create our coordinate and add it to the correct spot in the array 
    CLLocationCoordinate2D coordinate = CLLocationCoordinate2DMake(latitude, longitude);

    MKMapPoint point = MKMapPointForCoordinate(coordinate);

    if (idx == 0) {
        northEastPoint = point;
        southWestPoint = point;
    }
    else 
    {
        if (point.x > northEastPoint.x) 
            northEastPoint.x = point.x;
        if(point.y > northEastPoint.y)
            northEastPoint.y = point.y;
        if (point.x < southWestPoint.x) 
            southWestPoint.x = point.x;
        if (point.y < southWestPoint.y) 
            southWestPoint.y = point.y;
    }
    pointArr[idx] = point;
    _currentLenght++;
}

// create the polyline based on the array of points. 
self.routeLine = [MKPolyline polylineWithPoints:pointArr count:points.count];

_routeRect = MKMapRectMake(southWestPoint.x, southWestPoint.y, 
                           northEastPoint.x - southWestPoint.x, 
                           northEastPoint.y - southWestPoint.y);

// clear the memory allocated earlier for the points
free(pointArr);

if (nil != self.routeLine) {
        [self.mapView addOverlay:self.routeLine];
}
[self.mapView setVisibleMapRect:_routeRect];

A ukazuje:

- (MKOverlayView *)mapView:(MKMapView *)mapView viewForOverlay:(id <MKOverlay>)overlay
{
MKOverlayView* overlayView = nil;

if(overlay == self.routeLine)
{
    self.routeLineView = [[[MKPolylineView alloc] initWithPolyline:self.routeLine] autorelease];
    self.routeLineView.fillColor = [UIColor blueColor];
    self.routeLineView.strokeColor = TICNavigatorColor;
    self.routeLineView.lineWidth = 7;
    self.routeLineView.lineJoin = kCGLineJoinRound;
    self.routeLineView.lineCap = kCGLineCapRound;

    overlayView = self.routeLineView;
}

return overlayView; 
}

Pokusit se.

Odpovězeno 28/09/2012 v 07:53
zdroj uživatelem

hlasů
1

Solidní řešení je vytvořit řadič pohled s hrotem, který obsahuje UIWebView, a pak předat adresu URL, která vykonává mapa / směrovky služby společnosti Google. Tímto způsobem si udržet uživatele v aplikaci. Tento přístup není dostatečný, pokud vyhrnula webové stránky, protože Apple sada nepodporuje zoom. Ale s OS4, přinejmenším může uživatel dvojklikem na tlačítko domů a přepnout zpět do aplikace.

Odpovězeno 07/05/2010 v 00:55
zdroj uživatelem

hlasů
-1

Můžete odeslat e-mailem špendlíku na sebe a při otevření odkazu v e-mailu, zobrazí souřadnice.

Odpovězeno 18/08/2011 v 06:54
zdroj uživatelem

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more