Меню
Главная
Случайная статья
Настройки
|
GeoJSON — открытый формат, предназначенный для хранения географических структур данных, основан на JSON.
Формат может хранить примитивные типы для описания географических объектов, такие как: точки (адреса и местоположения), линии (улицы, шоссе, границы), полигоны (страны, штаты, участки земли). Также могут храниться так называемые мультитипы, которые представляют собой объединение нескольких примитивных типов.
Формат GeoJSON отличается от других стандартов ГИС тем, что он был написан и поддерживается не какой-либо организацией по стандартизации, а с помощью рабочей группы разработчиков.
Дальнейшим развитием GeoJSON является TopoJSON, расширение GeoJSON, которое кодирует геопространственную топологию, и, как правило, обеспечивает меньший размер файлов.
Содержание
История
Формат GeoJSON начал обсуждаться рабочей группой в марте 2007 года[1] и окончательная спецификация стандарта была готова к июню 2008 года.
Пример{ "type": "FeatureCollection",
"features": [
{ "type": "Feature",
"geometry": {"type": "Point", "coordinates": [102.0, 0.5]},
"properties": {"prop0": "value0"}
},
{ "type": "Feature",
"geometry": {
"type": "LineString",
"coordinates": [
[102.0, 0.0], [103.0, 1.0], [104.0, 0.0], [105.0, 1.0]
]
},
"properties": {
"prop0": "value0",
"prop1": 0.0
}
},
{ "type": "Feature",
"geometry": {
"type": "Polygon",
"coordinates": [
[ [100.0, 0.0], [101.0, 0.0], [101.0, 1.0],
[100.0, 1.0], [100.0, 0.0] ]
]
},
"properties": {
"prop0": "value0",
"prop1": {"this": "that"}
}
}
]
}
Объекты
Примитивные типы
Типы
|
Примеры
|
Point
|
|
{ "type": "Point",
"coordinates": [30, 10]
}
|
LineString
|
|
{ "type": "LineString",
"coordinates": [
[30, 10], [10, 30], [40, 40]
]
}
|
Polygon
|
|
{ "type": "Polygon",
"coordinates": [
[[30, 10], [40, 40], [20, 40], [10, 20], [30, 10]]
]
}
|
|
{ "type": "Polygon",
"coordinates": [
[[35, 10], [45, 45], [15, 40], [10, 20], [35, 10]],
[[20, 30], [35, 35], [30, 20], [20, 30]]
]
}
|
Мультитипы
Типы
|
Примеры
|
MultiPoint
|
|
{ "type": "MultiPoint",
"coordinates": [
[10, 40], [40, 30], [20, 20], [30, 10]
]
}
|
MultiLineString
|
|
{ "type": "MultiLineString",
"coordinates": [
[[10, 10], [20, 20], [10, 40]],
[[40, 40], [30, 30], [40, 20], [30, 10]]
]
}
|
MultiPolygon
|
|
{ "type": "MultiPolygon",
"coordinates": [
[
[[30, 20], [45, 40], [10, 40], [30, 20]]
],
[
[[15, 5], [40, 10], [10, 20], [5, 10], [15, 5]]
]
]
}
|
|
{ "type": "MultiPolygon",
"coordinates": [
[
[[40, 40], [20, 45], [45, 30], [40, 40]]
],
[
[[20, 35], [10, 30], [10, 10], [30, 5], [45, 20], [20, 35]],
[[30, 20], [20, 15], [20, 25], [30, 20]]
]
]
}
|
Использование
GeoJSON поддерживается множеством картографических программных пакетов и ГИС, включая OpenLayers[2], Leaflet[3], MapServer[4], Geoforge software, GeoServer,[5] GeoDjango[6], GDAL[7], Safe Software FME[8], и CartoDB[9]. Кроме этого, можно использовать GeoJSON с PostGIS[10] и Mapnik[11], оба работают с форматом с помощью библиотеки GDAL OGR. Онлайн-сервисы Bing Maps, Yahoo! и Google также поддерживают GeoJSON в своих API.
Интерфейс Javascript API v3 карт Google Maps напрямую поддерживают интеграцию слоёв данных GeoJSON[12] с 19 марта 2014 года.[13]
GitHub тоже поддерживает GeoJSON[14] и GeoJSON-экспорт Potrace.
TopoJSON
TopoJSON является развитием GeoJSON. Вместо того, чтобы представлять географические объекты по отдельности, в TopoJSON они сшиты в единые объекты, называемые дугами (arcs)[15]. Дуги — это последовательность точек, в то время как линии и полигоны — являются последовательностью дуг. Каждая дуга определяется только один раз, но может быть использована несколько раз в различных формах, тем самым уменьшается избыточность и размер файлов.
Спецификация формата TopoJSON размещена на сайте GitHub[16].
Схема TopoJSON
Пример описания объекта, размещающегося около координат нулевой параллели и нулевой широты. Простое, но содержит все необходимые типы геометрии: Полигоны(Polygon), Линии(LineString), Точки(Point), Дуги (arcs) и Описания:
{
"type":"Topology",
"transform":{
"scale": [1,1],
"translate": [0,0]
},
"objects":{
"two-squares":{
"type": "GeometryCollection",
"geometries":[
{"type": "Polygon", "arcs":[[0,1]],"properties": {"name": "Left_Polygon" }},
{"type": "Polygon", "arcs":[[2,-1]],"properties": {"name": "Right_Polygon" }}
]
},
"one-line": {
"type":"GeometryCollection",
"geometries":[
{"type": "LineString", "arcs": [3],"properties":{"name":"Under_LineString"}}
]
},
"two-places":{
"type":"GeometryCollection",
"geometries":[
{"type":"Point","coordinates":[0,0],"properties":{"name":"Origine_Point"}},
{"type":"Point","coordinates":[0,-1],"properties":{"name":"Under_Point"}}
]
}
},
"arcs": [
[[1,2],[0,-2]],
[[1,0],[-1,0],[0,2],[1,0]],
[[1,2],[1,0],[0,-2],[-1,0]],
[[0,-1],[2,0]]
]
}
Примечания
- March 2007 Archives by thread (неопр.). Дата обращения: 12 октября 2015. Архивировано 8 сентября 2018 года.
- (неопр.). Дата обращения: 16 марта 2010. Архивировано 16 марта 2010 года.
- Documentation — Leaflet — a JavaScript library for interactive maps (неопр.). Дата обращения: 12 октября 2015. Архивировано 15 августа 2018 года.
- Template-Driven Output — MapServer 7.0.0 documentation (неопр.). Дата обращения: 12 октября 2015. Архивировано 16 марта 2017 года.
- GeoServer 2.0.0-alpha1 (August 11, 2008) Архивировано 13 декабря 2009 года.
- GeoDjango Архивировано 7 сентября 2009 года.
- (неопр.). Дата обращения: 9 октября 2009. Архивировано 15 апреля 2009 года.
- (неопр.). Дата обращения: 24 июля 2008. Архивировано 24 июля 2008 года.
- CartoDB.js — CartoDB Docs (неопр.). Дата обращения: 12 октября 2015. Архивировано из оригинала 27 июня 2014 года.
- (неопр.). Дата обращения: 1 июня 2010. Архивировано 1 июня 2010 года.
- (неопр.). Дата обращения: 2 мая 2009. Архивировано 2 мая 2009 года.
- Data Layer: Simple | Google Maps Javascript API (неопр.). Google Developers. Дата обращения: 12 октября 2015. Архивировано 30 декабря 2016 года.
- Google Developers Blog: Maps made easier: GeoJSON in the JavaScript Maps API (неопр.). Дата обращения: 12 октября 2015. Архивировано 4 марта 2016 года.
- There’s a map for that (неопр.). GitHub. Дата обращения: 12 октября 2015. Архивировано 27 сентября 2016 года.
- mbostock/topojson-specification · GitHub (неопр.). Дата обращения: 12 октября 2015. Архивировано 11 июня 2018 года.
- topojson-specification/README.md at master · mbostock/topojson-specification · GitHub (неопр.). Дата обращения: 12 октября 2015. Архивировано 8 декабря 2021 года.
Литература
Ссылки
|
|