در حال بارگذاری

پرش به مطلب اصلی

سرویس محدوده در دسترس (Isochrone)

این سرویس محدوده‌ای را مشخص می‌کند که از یک نقطه مرکزی در زمان یا مسافت معین قابل دسترسی است.

اطلاع
  1. ۱

    اولین قدم ثبت‌نام و دریافت API KEY برای اپلیکیشنی است که قصد دارید در آن از Map Api نشان استفاده کنید. کافیست در لینک فوق فرم مربوطه را تکمیل کنید تا بلافاصله API KEY را دریافت نمایید.

  2. ۲

    Api Key دریافتی از پنل توسعه‌دهندگان نشان را به صورتی که در ادامه مشاهده می‌کنید از طریق کلید Api-Key در header درخواست سرویس بگنجانید.

  3. ۳

    درخواست خود را با توجه به پارامترهایی که مربوط به سرویس موردنظرتان است با متد GET فراخوانی کنید.

  4. ۴

    چنانچه درخواست شما با موفقیت پردازش و پاسخ داده شود، خروجی با فرمت JSON دریافت خواهید کرد و چنانچه به هر دلیل خطایی رخ دهد، کد خطا بصورت HTTP Status Code و نوع آن با فرمت JSON ارسال می‌گردد. کدهای خطای احتمالی نیز در ادامه به صورت کامل توضیح داده شده‌اند.

شیوه‌ی فراخوانی

برای استفاده از این سرویس، یک درخواست GET به اندپوینت زیر ارسال کنید:

https://api.neshan.org/v1/isochrone?location=35.73615577230048%2C51.375986032513595&denoise=&polygons=true&distance=5&time=5

هدرهای درخواست (Headers)

Api-Key: YOUR_SERVICE_API_KEY

پارامترهای ورودی

پارامترتوضیحاتنوع پارامتر
locationمختصات مرکز به صورت Lat,Lng.اجباری
distanceیک عدد بر حسب کیلومتر که حداکثر مسافت قابل دسترسی را مشخص می‌کند.یکی از این دو اجباری است
timeیک عدد بر حسب دقیقه که حداکثر زمان قابل دسترسی را مشخص می‌کند.یکی از این دو اجباری است
polygonیکی از دو مقدار true یا false را می‌پذیرد. اگر true باشد، خروجی از نوع Polygon خواهد بود. در غیر این صورت، خروجی LineString است. (پیش‌فرض false)اختیاری
denoiseعددی بین 0 تا 1 برای کنترل ساده‌سازی محدوده. هرچه این عدد به 1 نزدیک‌تر باشد، پولیگان ساده‌تر (با نقاط کمتر) خواهد بود. (پیش‌فرض 0)اختیاری

نمونه درخواست

curl --location 'https://api.neshan.org/v1/isochrone?location=35.72084257271665%2C51.432258666992766&distance=5&time=5&polygon=false&denoise=0' \
--header 'Api-Key: YOUR_API_KEY'

فرمت پاسخ

پاسخ سرویس در قالب یک آبجکت GeoJSON بازگردانده می‌شود که شامل فیچرهای محدوده زمانی و مسافتی است.

{
"type": "FeatureCollection",
"features": [
{
"type": "Feature",
"properties": {
"contour": 1,
"metric": "distance"
},
"geometry": {
"type": "Polygon",
"coordinates": [
[
[51.379986, 35.741408],
[51.378875, 35.742045]
]
]
}
},
{
"type": "Feature",
"properties": {
"contour": 1,
"metric": "time"
},
"geometry": {
"type": "Polygon",
"coordinates": [
[
[51.374986, 35.737212],
[51.373986, 35.735875]
]
]
}
}
]
}

اجزای پاسخ

پارامترتوضیحات
typeنوع آبجکت GeoJSON که در اینجا همیشه FeatureCollection است.
featuresآرایه‌ای از فیچرهای (نواحی) ایجاد شده. هر فیچر شامل properties و geometry است.

آبجکت feature

پارامترتوضیحات
typeنوع آبجکت که همیشه Feature است.
propertiesیک آبجکت شامل مشخصات فیچر تولید شده.
geometryیک آبجکت شامل اطلاعات هندسی و مختصات لازم برای رسم ناحیه.

آبجکت properties

پارامترتوضیحات
metricمشخص می‌کند که این محدوده بر اساس کدام پارامتر ورودی ایجاد شده است: distance یا time.

آبجکت geometry

پارامترتوضیحات
typeنوع ناحیه ایجاد شده که Polygon یا LineString است (بسته به پارامتر ورودی polygon).
coordinatesآرایه‌ای از مختصات (Longitude, Latitude) که نقاط تشکیل‌دهنده محدوده را مشخص می‌کنند.

تاثیر پارامتر denoise

  • denoise = 0 (پیش‌فرض): پولیگان با جزئیات کامل و بدون ساده‌سازی ایجاد می‌شود.

Isochrone/isoDistance Denoise 0

  • denoise = 1: پولیگان با بالاترین حد ساده‌سازی ایجاد می‌شود که منجر به تعداد نقاط کمتر و حجم پاسخ کمتر می‌شود.

Isochrone/isoDistance Denoise 1

کد خطاهای سرویس

HTTP CodeStatusDescription
404NOT_FOUNDکد پستی با این مشخصات یافت نشده است
400INVALID_ARGUMENTخطا در پارامتر های ورودی
470CoordinateParseErrorچنانچه مختصات جغرافیایی ارسالی معتبر نباشد رخ خواهد داد.
480KeyNotFoundدر صورتی که در فراخوانی وب‌سرویس از یک Api Key نامعتبر استفاده کنید یا Api Key خود را در header ارسال نکنید رخ خواهد داد.
481LimitExceededدر صورتی که تعداد فراخوانی وب‌سرویس‌ها از میزان مجازی که برای شما تعیین شده‌است عبور کند رخ خواهد داد.
482RateExceededچنانچه تعداد درخواست وب‌سرویس در دقیقه از حد مجاز عبور کند رخ خواهد داد.
483ApiKeyTypeErrorکلید دسترسی استفاده شده با سرویس فراخوانی شده همخوانی ندارد. بایستی از کلید دسترسی مرتبط با سرویس مورد نظر استفاده کنید.
484ApiWhiteListErrorبا توجه به اسکوپ تعریف‌شده برای این کلید، شما مجاز به استفاده نیستید.
485ApiServiceListErrorسرویس فراخوانی شده با سرویس‌های تعریف‌شده برای این کلید دسترسی همخوانی ندارد.
500GenericErrorوقوع خطای ناشناخته