أرقام تعريف الأماكن

اختيار النظام الأساسي: Android iOS JavaScript خدمة الويب

تحدِّد أرقام تعريف الأماكن مكانًا بشكلٍ فريد في قاعدة بيانات "أماكن Google" وعلى "خرائط Google". يتم قبول أرقام تعريف الأماكن في طلبات واجهات برمجة التطبيقات التالية في "خرائط Google":

  • استرداد عنوان لرقم تعريف مكان في خدمة الويب Geocoding API خدمة ترميز المواقع الجغرافية، واجهة برمجة التطبيقات JavaScript لخرائط Google
  • تحديد نقاط البداية والوجهة والنقاط الوسيطة في خدمة Routes API وDirections API على الويب وDirections Service وMaps JavaScript API
  • تحديد نقاط البداية والوجهات في واجهة برمجة التطبيقات Routes API و Distance Matrix API و Distance Matrix Service، وواجهة برمجة التطبيقات JavaScript لخرائط Google
  • استرداد تفاصيل الأماكن في خدمة الويب Places API وحزمة تطوير البرامج (SDK) للأماكن لنظام Android وحزمة تطوير البرامج (SDK) للأماكن لنظام iOS ومكتبة الأماكن
  • استخدام مَعلمات رقم تعريف المكان في واجهة برمجة التطبيقات Maps Embed API
  • استرداد طلبات البحث في عناوين URL في "خرائط Google"
  • عرض حدود السرعة في Roads API
  • العثور على مضلّعات الحدود وتصميمها في التصميم المستنِد إلى البيانات للحدود

العثور على رقم تعريف مكان معيّن

هل تبحث عن معرّف مكان معيّن؟ استخدِم أداة البحث عن معرّف المكان أدناه للبحث عن مكان والحصول على معرّفه:

بدلاً من ذلك، يمكنك الاطّلاع على أداة البحث عن معرّف المكان باستخدام رمزها في مستندات واجهة برمجة التطبيقات JavaScript للخرائط.

نظرة عامة

معرّف المكان هو معرّف نصي يحدِّد مكانًا بشكل فريد. قد يختلف طول المعرّف (ما مِن حدّ أقصى لطول أرقام تعريف الأماكن). أمثلة:

  • ChIJgUbEo8cfqokR5lP9_Wh_DaM
  • GhIJQWDl0CIeQUARxks3icF8U8A
  • EicxMyBNYXJrZXQgU3QsIFdpbG1pbmd0b24sIE5DIDI4NDAxLCBVU0EiGhIYChQKEgnRTo6ixx-qiRHo_bbmkCm7ZRAN
  • EicxMyBNYXJrZXQgU3QsIFdpbG1pbmd0b24sIE5DIDI4NDAxLCBVU0E
  • IhoSGAoUChIJ0U6OoscfqokR6P225pApu2UQDQ

تتوفّر أرقام تعريف الأماكن لمعظم المواقع الجغرافية، بما في ذلك الأنشطة التجارية والمعالم والمتنزهات والتقاطعات. من الممكن أن يحتوي المكان أو الموقع الجغرافي نفسه على أرقام تعريف أماكن مختلفة ومتعدّدة. قد تتغيّر أرقام تعريف الأماكن بمرور الوقت.

يمكنك استخدام معرّف المكان نفسه في Places API و عدد من واجهات برمجة تطبيقات "منصّة خرائط Google". على سبيل المثال، يمكنك استخدام معرّف المكان نفسه لتحديد مكان في Places API وMaps JavaScript API وGeocoding API وMaps Embed API وRoads API.

استرداد تفاصيل المكان باستخدام رقم تعريف المكان

من الطرق الشائعة لاستخدام أرقام تعريف الأماكن هي البحث عن مكان (باستخدام Places API أو مكتبة الأماكن في واجهة برمجة التطبيقات JavaScript للخرائط، على سبيل المثال)، ثم استخدام رقم تعريف المكان الذي تم إرجاعه لاسترداد تفاصيل المكان. يمكنك تخزين رقم تعريف المكان واستخدامه لاسترداد تفاصيل المكان نفسها لاحقًا. يمكنك الاطّلاع على مزيد من المعلومات عن حفظ أرقام تعريف الأماكن أدناه.

مثال على استخدام حزمة تطوير برامج الأماكن لأجهزة Android

في حزمة تطوير برامج "الأماكن" لنظام التشغيل Android، يمكنك استرداد معرّف مكان من خلال استدعاء Place.getId(). تعرِض خدمة الإكمال التلقائي للأماكن أيضًا رقم تعريف مكان لكل مكان يتطابق مع طلب البحث والفلترة المقدَّمَين. استخدِم معرّف المكان لاسترداد كائن Place مرة أخرى لاحقًا.

للحصول على مكان حسب المعرّف، اتصل بـ PlacesClient.fetchPlace()، مع تضمين FetchPlaceRequest.

تعرض واجهة برمجة التطبيقات FetchPlaceResponse في Task. يحتوي العنصر FetchPlaceResponse على عنصر Place يتطابق مع رقم تعريف المكان المقدَّم.

يوضّح مثال الرمز البرمجي التالي الاتصال برقم fetchPlace() للحصول على تفاصيل عن المكان المحدّد.

Kotlin

// Define a Place ID.
val placeId = "INSERT_PLACE_ID_HERE"

// Specify the fields to return.
val placeFields = listOf(Place.Field.ID, Place.Field.NAME)

// Construct a request object, passing the place ID and fields array.
val request = FetchPlaceRequest.newInstance(placeId, placeFields)

placesClient.fetchPlace(request)
    .addOnSuccessListener { response: FetchPlaceResponse ->
        val place = response.place
        Log.i(PlaceDetailsActivity.TAG, "Place found: ${place.name}")
    }.addOnFailureListener { exception: Exception ->
        if (exception is ApiException) {
            Log.e(TAG, "Place not found: ${exception.message}")
            val statusCode = exception.statusCode
            TODO("Handle error with given status code")
        }
    }

      

Java

// Define a Place ID.
final String placeId = "INSERT_PLACE_ID_HERE";

// Specify the fields to return.
final List<Place.Field> placeFields = Arrays.asList(Place.Field.ID, Place.Field.NAME);

// Construct a request object, passing the place ID and fields array.
final FetchPlaceRequest request = FetchPlaceRequest.newInstance(placeId, placeFields);

placesClient.fetchPlace(request).addOnSuccessListener((response) -> {
    Place place = response.getPlace();
    Log.i(TAG, "Place found: " + place.getName());
}).addOnFailureListener((exception) -> {
    if (exception instanceof ApiException) {
        final ApiException apiException = (ApiException) exception;
        Log.e(TAG, "Place not found: " + exception.getMessage());
        final int statusCode = apiException.getStatusCode();
        // TODO: Handle error with given status code.
    }
});

      

حفظ أرقام تعريف الأماكن لاستخدامها لاحقًا

تكون أرقام تعريف الأماكن مُعفاة من قيود التخزين المؤقت المذكورة في الفقرة 3.2.3(ب) من بنود خدمة Google Maps Platform. ويمكنك بالتالي تخزين قيم معرّفات الأماكن لاستخدامها في وقت لاحق.

إعادة تحميل معرّفات الأماكن المخزّنة

تنصح Google بإعادة تحميل معرّفات الأماكن إذا مرّ أكثر من 12 شهرًا على إنشائها. يمكنك إعادة تحميل أرقام تعريف الأماكن بدون أي رسوم، وذلك من خلال تقديم طلب للحصول على تفاصيل الأماكن، مع تحديد الحقل Place.Field.ID فقط في المَعلمة fields.

يؤدي هذا الطلب إلى تنشيط Places Details - ID Refresh (تفاصيل الأماكن - إعادة تحميل المعرّف) رمز التخزين التعريفي.

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

رموز الخطأ عند استخدام أرقام تعريف الأماكن

يشير رمز الحالة INVALID_REQUEST إلى أنّ رقم تعريف المكان المحدّد غير صالح. قد يتم عرض القيمة INVALID_REQUEST عندما يتم اقتطاع معرّف المكان أو تعديله بأي شكل آخر، ولم يعُد صحيحًا.

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

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

  • عناوين الشوارع التي لا تظهر في "خرائط Google" كعناوين دقيقة، ولكن يتم استنتاجها من مجموعة من العناوين
  • أجزاء من مسار طويل، حيث يحدّد الطلب أيضًا مدينة أو منطقة
  • التقاطعات
  • الأماكن التي تحتوي على مكوّن عنوان من النوع subpremise

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

EpID4LC14LC_4LCo4LCv4LGN4LCo4LCX4LCw4LGNIC0g4LC44LGI4LCm4LGN4LCs4LC-4LCm4LGNIOCwsOCxi-CwoeCxjeCwoeCxgSAmIOCwteCwv-CwqOCwr-CxjSDgsKjgsJfgsLDgsY0g4LCu4LGG4LCv4LC_4LCo4LGNIOCwsOCxi-CwoeCxjeCwoeCxgSwg4LC14LC_4LCo4LCv4LGNIOCwqOCwl-CwsOCxjSDgsJXgsL7gsLLgsKjgsYAsIOCwsuCwleCxjeCwt-CxjeCwruCwv-CwqOCwl-CwsOCxjSDgsJXgsL7gsLLgsKjgsYAsIOCwuOCwsOCxguCwsOCxjSDgsKjgsJfgsLDgsY0g4LC14LGG4LC44LGN4LCf4LGNLCDgsLjgsK_gsYDgsKbgsL7gsKzgsL7gsKbgsY0sIOCwueCxiOCwpuCwsOCwvuCwrOCwvuCwpuCxjSwg4LCk4LGG4LCy4LCC4LCX4LC-4LCjIDUwMDA1OSwg4LCt4LC-4LCw4LCk4LCm4LGH4LC24LCCImYiZAoUChIJ31l5uGWYyzsR9zY2qk9lDiASFAoSCd9ZebhlmMs7Efc2NqpPZQ4gGhQKEglDz61OZpjLOxHgDJCFY-o1qBoUChIJi37TW2-YyzsRr_uv50r7tdEiCg1MwFcKFS_dyy4