Routen für einzelne Ziele

In dieser Anleitung erfahren Sie, wie Sie mit dem Navigation SDK for Android eine Route in Ihrer App darstellen. In dieser Anleitung wird davon ausgegangen, dass Sie das Navigation SDK bereits in Ihre App eingebunden haben, wie unter Projekt einrichten beschrieben.

Zusammenfassung

  1. Fügen Sie Ihrer App ein UI-Element hinzu, entweder als Navigationsfragment oder als Navigationsansicht. Mit diesem UI-Element wird Ihrer Aktivität die interaktive Karte und die Benutzeroberfläche für die Turn-by-Turn-Navigation hinzugefügt.
  2. Berechtigungen zur Standortermittlung anfordern Ihre App muss die Berechtigung zur Standortermittlung anfordern, um den Gerätestandort zu bestimmen.
  3. Initialisieren Sie das SDK mit der Klasse NavigationApi.
  4. Legen Sie ein Ziel fest und steuern Sie die detaillierte Routenführung mit der Klasse Navigator. Dazu sind drei Schritte erforderlich:

    • Legen Sie das Ziel mit setDestination() fest.
    • Navigation mit startGuidance() starten
    • Mit getSimulator() können Sie den Fortschritt des Fahrzeugs auf der Route simulieren, um Ihre App zu testen, zu debuggen und zu präsentieren.
  5. Erstellen Sie Ihre App und führen Sie sie aus.

Code

UI-Element in App einfügen

In diesem Abschnitt werden zwei Möglichkeiten beschrieben, wie Sie die interaktive Karte und die Benutzeroberfläche für die Anzeige der Turn-by-Turn-Navigation hinzufügen können. In den meisten Fällen empfehlen wir, SupportNavigationFragment, einen Wrapper für NavigationView, anstelle der direkten Interaktion mit NavigationView zu verwenden. Weitere Informationen finden Sie unter Best Practices für die Interaktion mit Navigationskarten .

SupportNavigationFragment ist die UI-Komponente, in der die visuelle Ausgabe der Navigation angezeigt wird, einschließlich einer interaktiven Karte und einer detaillierten Routenführung. Sie können das Fragment in Ihrer XML-Layoutdatei wie hier gezeigt deklarieren:

<?xml version="1.0" encoding="utf-8"?>
<fragment xmlns:android="http://schemas.android.com/apk/res/android"
    android:name="com.google.android.libraries.navigation.SupportNavigationFragment"
    android:id="@+id/navigation_fragment"
    android:layout_width="match_parent"
    android:layout_height="match_parent"/>

Alternativ können Sie das Fragment programmatisch erstellen, wie in der Android-Dokumentation beschrieben, indem Sie FragmentActivity.getSupportFragmentManager() verwenden.

Alternativ zu einem Fragment ist die UI-Komponente zum Anzeigen einer Karte für die Navigation auch als NavigationView verfügbar.

Berechtigung zur Standortermittlung anfordern

In diesem Abschnitt wird veranschaulicht, wie Sie eine detaillierte Berechtigung zur Standortermittlung anfordern. Weitere Informationen finden Sie im Leitfaden zu Android-Berechtigungen.

  1. Fügen Sie die Berechtigung als untergeordnetes Element des Elements <manifest> in Ihrem Android-Manifest hinzu:

    <manifest xmlns:android="http://schemas.android.com/apk/res/android"
        package="com.example.navsdksingledestination">
        <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
    </manifest>
    
  2. Fordern Sie in Ihrer App Laufzeitberechtigungen an und geben Sie dem Nutzer die Möglichkeit, die Berechtigung zur Standortermittlung zu erteilen oder abzulehnen. Mit dem folgenden Code wird überprüft, ob der Nutzer eine gültige Berechtigung zur Standortermittlung erteilt hat. Falls nicht, wird die Berechtigung angefordert:

        if (ContextCompat.checkSelfPermission(this.getApplicationContext(),
                android.Manifest.permission.ACCESS_FINE_LOCATION)
                    == PackageManager.PERMISSION_GRANTED) {
            mLocationPermissionGranted = true;
        } else {
            ActivityCompat.requestPermissions(this,
                    new String[] { android.Manifest.permission.ACCESS_FINE_LOCATION },
                    PERMISSIONS_REQUEST_ACCESS_FINE_LOCATION);
        }
    
        if (!mLocationPermissionGranted) {
            displayMessage("Error loading Navigation SDK: "
                    + "The user has not granted location permission.");
            return;
        }
    
  3. Überschreibe den Rückruf onRequestPermissionsResult(), um das Ergebnis der Berechtigungsanfrage zu verarbeiten:

        @Override
        public void onRequestPermissionsResult(int requestCode, @NonNull String permissions[],
                                               @NonNull int[] grantResults) {
            mLocationPermissionGranted = false;
            switch (requestCode) {
                case PERMISSIONS_REQUEST_ACCESS_FINE_LOCATION: {
                    // If request is canceled, the result arrays are empty.
                    if (grantResults.length > 0
                            && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
                        mLocationPermissionGranted = true;
                    }
                }
            }
        }
    

Navigation SDK initialisieren

Die Klasse NavigationApi> bietet Initialisierungslogik, mit der Ihre App für die Verwendung der Google-Navigation autorisiert wird. In diesem Abschnitt wird beschrieben, wie Sie den Navigator initialisieren und welche anderen Konfigurationen Sie für Ihre App aktivieren können:

  1. Initialisieren Sie das Navigation SDK und überschreiben Sie den onNavigatorReady()-Callback, um die Navigation zu starten, wenn der Navigator bereit ist.

  2. Optional. Konfigurieren Sie die App so, dass Benachrichtigungen und Hintergrunddienste beendet werden, wenn der Nutzer die App auf seinem Gerät schließt. Diese Entscheidung hängt von Ihrem Geschäftsmodell ab. Möglicherweise möchten Sie das Standardverhalten des Navigators verwenden, bei dem weiterhin Abbiegehinweise und Standortaktualisierungen angezeigt werden, auch wenn die App geschlossen wird. Wenn Sie stattdessen die Navigation und Standortaktualisierungen beenden möchten, wenn der Endnutzer die App geschlossen hat, verwenden Sie diese Konfiguration.

  3. Optional. Straßensperrungen in unterstützten Ländern aktivieren Legen Sie die letzte Ziffer des Kennzeichens fest. Dieser Aufruf muss nur einmal erfolgen. Bei nachfolgenden Anfragen für Wegbeschreibungen wird er weiterhin verwendet. Dieser Anruf funktioniert nur in unterstützten Regionen. Unterstützte Länder für das Navigation SDK

        NavigationApi.getNavigator(this, new NavigationApi.NavigatorListener() {
                    /**
                     * Sets up the navigation UI when the navigator is ready for use.
                     */
                    @Override
                    public void onNavigatorReady(Navigator navigator) {
                        displayMessage("Navigator ready.");
                        mNavigator = navigator;
                        mNavFragment = (NavigationFragment) getFragmentManager()
                                .findFragmentById(R.id.navigation_fragment);
    
                        // Optional. Disable the guidance notifications and shut down the app
                        // and background service when the user closes the app.
                        // mNavigator.setTaskRemovedBehavior(Navigator.TaskRemovedBehavior.QUIT_SERVICE)
    
                        // Optional. Set the last digit of the car's license plate to get
                        // route restrictions for supported countries.
                        // mNavigator.setLicensePlateRestrictionInfo(getLastDigit(), "BZ");
    
                        // Set the camera to follow the device location with 'TILTED' driving view.
                        mNavFragment.getCamera().followMyLocation(Camera.Perspective.TILTED);
    
                        // Set the travel mode (DRIVING, WALKING, CYCLING, TWO_WHEELER, or TAXI).
                        mRoutingOptions = new RoutingOptions();
                        mRoutingOptions.travelMode(RoutingOptions.TravelMode.DRIVING);
    
                        // Navigate to a place, specified by Place ID.
                        navigateToPlace(SYDNEY_OPERA_HOUSE, mRoutingOptions);
                    }
    
                    /**
                     * Handles errors from the Navigation SDK.
                     * @param errorCode The error code returned by the navigator.
                     */
                    @Override
                    public void onError(@NavigationApi.ErrorCode int errorCode) {
                        switch (errorCode) {
                            case NavigationApi.ErrorCode.NOT_AUTHORIZED:
                                displayMessage("Error loading Navigation SDK: Your API key is "
                                        + "invalid or not authorized to use the Navigation SDK.");
                                break;
                            case NavigationApi.ErrorCode.TERMS_NOT_ACCEPTED:
                                displayMessage("Error loading Navigation SDK: User did not accept "
                                        + "the Navigation Terms of Use.");
                                break;
                            case NavigationApi.ErrorCode.NETWORK_ERROR:
                                displayMessage("Error loading Navigation SDK: Network error.");
                                break;
                            case NavigationApi.ErrorCode.LOCATION_PERMISSION_MISSING:
                                displayMessage("Error loading Navigation SDK: Location permission "
                                        + "is missing.");
                                break;
                            default:
                                displayMessage("Error loading Navigation SDK: " + errorCode);
                        }
                    }
                });
    

Ziel festlegen

Die Klasse Navigator bietet Steuerungsmöglichkeiten zum Konfigurieren, Starten und Beenden einer Navigation.

Legen Sie mit dem Navigator aus dem vorherigen Abschnitt ein Ziel Waypoint für diese Fahrt fest. Nachdem die Route berechnet wurde, wird mit SupportNavigationFragment eine Polylinie angezeigt, die die Route auf der Karte darstellt, sowie eine Markierung am Zielort.

```none
    private void navigateToPlace(String placeId, RoutingOptions travelMode) {
        Waypoint destination;
        try {
            destination = Waypoint.builder().setPlaceIdString(placeId).build();
        } catch (Waypoint.UnsupportedPlaceIdException e) {
            displayMessage("Error starting navigation: Place ID is not supported.");
            return;
        }

        // Create a future to await the result of the asynchronous navigator task.
        ListenableResultFuture<Navigator.RouteStatus> pendingRoute =
                mNavigator.setDestination(destination, travelMode);

        // Define the action to perform when the SDK has determined the route.
        pendingRoute.setOnResultListener(
                new ListenableResultFuture.OnResultListener<Navigator.RouteStatus>() {
                    @Override
                    public void onResult(Navigator.RouteStatus code) {
                        switch (code) {
                            case OK:
                                // Hide the toolbar to maximize the navigation UI.
                                if (getActionBar() != null) {
                                    getActionBar().hide();
                                }

                                // Enable voice audio guidance (through the device speaker).
                                mNavigator.setAudioGuidance(
                                        Navigator.AudioGuidance.VOICE_ALERTS_AND_GUIDANCE);

                                // Simulate vehicle progress along the route for demo/debug builds.
                                if (BuildConfig.DEBUG) {
                                    mNavigator.getSimulator().simulateLocationsAlongExistingRoute(
                                            new SimulationOptions().speedMultiplier(5));
                                }

                                // Start turn-by-turn guidance along the current route.
                                mNavigator.startGuidance();
                                break;
                            // Handle error conditions returned by the navigator.
                            case NO_ROUTE_FOUND:
                                displayMessage("Error starting navigation: No route found.");
                                break;
                            case NETWORK_ERROR:
                                displayMessage("Error starting navigation: Network error.");
                                break;
                            case ROUTE_CANCELED:
                                displayMessage("Error starting navigation: Route canceled.");
                                break;
                            default:
                                displayMessage("Error starting navigation: "
                                        + String.valueOf(code));
                        }
                    }
                });
    }
```

App erstellen und ausführen

  1. Verbinden Sie ein Android-Gerät mit Ihrem Computer. Folgen Sie der Anleitung in Android Studio zum Ausführen von Apps auf einem Hardwaregerät. Alternativ können Sie mit dem AVD Manager für virtuelle Android-Geräte ein virtuelles Gerät konfigurieren. Beim Auswählen eines Emulators sollten Sie ein Image angeben, das die Google-APIs enthält.
  2. Klicken Sie in Android Studio auf die Menüoption Run oder das Wiedergabesymbol. Wählen Sie ein Gerät aus, wenn Sie dazu aufgefordert werden.

Tipps für eine bessere User Experience

  • Der Nutzer muss die Google-Nutzungsbedingungen für die Navigation akzeptieren, bevor die Navigation verfügbar ist. Diese Zustimmung ist nur einmal erforderlich. Standardmäßig fordert das SDK bei der ersten Ausführung des Navigators die Zustimmung ein. Sie können das Dialogfeld mit den Nutzungsbedingungen für die Navigation auch früher im UX-Ablauf Ihrer App auslösen, z. B. während der Registrierung oder Anmeldung, indem Sie TermsAndConditionsCheckOption verwenden.
  • Um die Navigationsqualität und die Genauigkeit der voraussichtlichen Ankunftszeit deutlich zu verbessern, sollten Sie Orts-IDs verwenden, um einen Wegpunkt zu initialisieren, anstatt Breiten-/Längengradkoordinaten.
  • In diesem Beispiel wird der Ziel-Waypoint aus einer bestimmten Orts-ID für das Sydney Opera House abgeleitet. Mit der Orts-ID-Suche können Sie Orts-IDs für andere bestimmte Orte abrufen.