التنقّل في مسار وجهة واحدة

اتّبِع هذا الدليل لرسم مسار داخل تطبيقك باستخدام حزمة تطوير البرامج Navigation SDK لنظام التشغيل Android. يفترض هذا الدليل أنّك قد دمجت حزمة تطوير البرامج (SDK) الخاصة بخدمة Navigation في تطبيقك، كما هو موضّح في إعداد مشروعك.

ملخّص

  1. أضِف عنصر واجهة مستخدم إلى تطبيقك، إما كجزء تنقّل أو كطريقة عرض تنقّل. يضيف عنصر واجهة المستخدم هذا الخريطة التفاعلية وواجهة مستخدم التنقّل خطوة بخطوة إلى نشاطك.
  2. طلب أذونات تحديد الموقع الجغرافي يجب أن يطلب تطبيقك إذن تحديد الموقع الجغرافي لتحديد الموقع الجغرافي للجهاز.
  3. اضبط حزمة SDK باستخدام الفئة NavigationApi.
  4. حدِّد وجهة وتحكَّم في التنقّل المفصّل باستخدام الفئة Navigator. يتضمّن ذلك ثلاث خطوات:

    • حدِّد الوجهة باستخدام setDestination().
    • ابدأ التنقّل باستخدام startGuidance().
    • استخدِم getSimulator() لمحاكاة تقدّم المركبة على طول المسار، وذلك لاختبار تطبيقك وتصحيح أخطائه وعرضه.
  5. إنشاء تطبيقك وتشغيله

الاطّلاع على الرمز

إضافة عنصر واجهة مستخدم إلى تطبيقك

يتناول هذا القسم طريقتَين يمكنك من خلالهما إضافة الخريطة التفاعلية وواجهة المستخدم لعرض اتّجاهات مفصّلة للتنقّل. في معظم الحالات، ننصحك باستخدام SupportNavigationFragment، وهي أداة تغليف NavigationView، بدلاً من التفاعل مباشرةً مع NavigationView. لمزيد من المعلومات، يُرجى الاطّلاع على أفضل الممارسات للتفاعل مع خريطة التنقّل .

SupportNavigationFragment هي أحد عناصر واجهة المستخدم التي تعرض الناتج المرئي للتنقّل، بما في ذلك خريطة تفاعلية واتجاهات مفصّلة. يمكنك تعريف الجزء في ملف تنسيق XML كما هو موضّح هنا:

<?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"/>

بدلاً من ذلك، يمكنك إنشاء الجزء بشكل آلي، كما هو موضّح في مستندات Android، باستخدام FragmentActivity.getSupportFragmentManager().

كبديل لـ "جزء"، يتوفّر أيضًا عنصر واجهة المستخدِم لعرض خريطة للتنقّل على شكل NavigationView.

طلب إذن تحديد الموقع الجغرافي

يوضّح هذا القسم كيفية طلب إذن الوصول إلى الموقع الجغرافي الدقيق. لمزيد من التفاصيل، يُرجى الاطّلاع على دليل أذونات Android.

  1. أضِف الإذن كعنصر فرعي من العنصر <manifest> في بيان Android:

    <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. طلب أذونات التشغيل في تطبيقك، ما يتيح للمستخدم فرصة منح إذن الوصول إلى الموقع الجغرافي أو رفضه يتحقّق الرمز التالي مما إذا كان المستخدم قد منح إذن تحديد الموقع الجغرافي بدقة. إذا لم يكن الأمر كذلك، سيطلب الإذن:

        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. تجاوز دالة الاستدعاء onRequestPermissionsResult() للتعامل مع نتيجة طلب الإذن:

        @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;
                    }
                }
            }
        }
    

إعداد حزمة تطوير البرامج للتنقّل

يوفّر الصف NavigationApi منطق الإعداد الذي يمنح تطبيقك الإذن باستخدام ميزة التنقّل من Google. يتناول هذا القسم كيفية بدء تشغيل أداة التنقّل، بالإضافة إلى بعض الإعدادات الأخرى التي يمكنك تفعيلها لتطبيقك:

  1. عليك إعداد حزمة تطوير البرامج (SDK) الخاصة بخدمة Navigation وتجاوز معاودة الاتصال onNavigatorReady() لبدء التنقّل عندما يكون برنامج التنقّل جاهزًا.

  2. اختيارية: اضبط التطبيق لإيقاف إشعارات التوجيه والخدمات التي تعمل في الخلفية عندما يغلق المستخدم التطبيق على جهازه. ويعتمد هذا الخيار على نموذج نشاطك التجاري. قد تحتاج إلى استخدام السلوك التلقائي لأداة التنقّل، والذي يواصل عرض إرشادات الانعطاف وتحديثات الموقع الجغرافي حتى عند إغلاق التطبيق. إذا كنت تريد بدلاً من ذلك إيقاف التنقّل وتحديثات الموقع الجغرافي عندما أغلق المستخدم التطبيق، عليك استخدام هذا الإعداد.

  3. اختيارية: تفعيل القيود على الطرق في البلدان التي تتوفّر فيها هذه الميزة اضبط الرقم الأخير من لوحة الترخيص. يجب إجراء هذه المكالمة مرة واحدة فقط، إذ تستمر طلبات الاتجاهات اللاحقة في استخدامها. لا يمكن إجراء هذه المكالمة إلا في المناطق المتوافقة. اطّلِع على البلدان التي تتوفّر فيها حزمة تطوير البرامج (SDK) الخاصة بخدمة Navigation.

        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);
                        }
                    }
                });
    

تحديد وجهة

يوفّر الصف Navigator عناصر تحكّم في عملية ضبط رحلة التنقّل وبدئها وإيقافها.

باستخدام Navigator الذي تم الحصول عليه في القسم السابق، اضبط وجهة Waypoint لهذه الرحلة. بعد احتساب الاتجاهات، يعرض الرمز SupportNavigationFragment خطًا متعدد الأضلاع يمثّل المسار على الخريطة، وعلامة في الوجهة.

```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));
                        }
                    }
                });
    }
```

إنشاء تطبيقك وتشغيله

  1. وصِّل جهاز Android بجهاز الكمبيوتر. اتّبِع تعليمات Android Studio حول كيفية تشغيل التطبيقات على جهاز فعلي. بدلاً من ذلك، يمكنك إعداد جهاز افتراضي باستخدام مدير الأجهزة الافتراضية في Android. عند اختيار محاكي، احرص على اختيار صورة تتضمّن واجهات برمجة التطبيقات من Google.
  2. في "استوديو Android"، انقر على خيار القائمة تشغيل أو رمز زر التشغيل. اختَر جهازًا حسب التعليمات.

تلميحات لتحسين تجربة المستخدم

  • يجب أن يوافق المستخدم على بنود خدمة &quot;خرائط Google&quot; قبل أن تصبح ميزة التنقّل متاحة. يجب الموافقة على هذه الشروط مرة واحدة فقط. تطلب حزمة SDK الموافقة تلقائيًا عند استدعاء أداة التنقّل للمرة الأولى. إذا كنت تفضّل ذلك، يمكنك عرض مربّع حوار "بنود خدمة التنقّل" في مرحلة مبكرة من مسار تجربة المستخدم في تطبيقك، مثلاً أثناء الاشتراك أو تسجيل الدخول، وذلك باستخدام TermsAndConditionsCheckOption.
  • لتحسين جودة التنقّل ودقة الوقت المقدَّر للوصول بشكل كبير، استخدِم معرّفات الأماكن لتهيئة نقطة طريق بدلاً من إحداثيات خطوط الطول والعرض.
  • يستمد هذا النموذج نقطة الطريق الخاصة بالوجهة من رقم تعريف مكان معيّن خاص بدار أوبرا سيدني. يمكنك استخدام أداة البحث عن أرقام تعريف الأماكن للحصول على أرقام تعريف أماكن أخرى محدّدة.