日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

geojson 格式说明(格式详解)

發(fā)布時(shí)間:2024/3/24 编程问答 52 豆豆
生活随笔 收集整理的這篇文章主要介紹了 geojson 格式说明(格式详解) 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

1. 簡(jiǎn)介

GeoJSON是一種對(duì)地理數(shù)據(jù)結(jié)構(gòu)進(jìn)行編碼的格式。GeoJSON對(duì)象可以表示幾何信息、要素或者要素集合。GeoJSON支持下面幾何類型:Point, LineString, Polygon, MultiPoint, MultiLineString, MultiPolygon和GeometryCollection。GeoJSON里的要素包含一個(gè)幾何對(duì)象和屬性對(duì)象,要素集合表示多個(gè)要素的集合。一個(gè)完整的GeoJSON數(shù)據(jù)結(jié)構(gòu)總是一個(gè)JSON對(duì)象。在GeoJSON里,對(duì)象由鍵值對(duì)的集合組成。對(duì)每個(gè)成員來(lái)說(shuō),名字總是字符串。成員的值要么是字符串、數(shù)字、對(duì)象、數(shù)組,要么是"true","false"和"null",其中數(shù)組和對(duì)象都是由以上類型的值組成。

geojson數(shù)據(jù)獲取地址:http://datav.aliyun.com/tools/atlas/#&lat=31.769817845138945&lng=104.29901249999999&zoom=4

2. GeoJSON對(duì)象

GeoJSON總是由一個(gè)單獨(dú)的對(duì)象組成。這個(gè)對(duì)象表示幾何、要素或者要素集合,對(duì)象可能有任意數(shù)目成員(鍵值對(duì))。

  • GeoJSON對(duì)象必須有一個(gè)名字為"type"的成員。這個(gè)成員的值是由GeoJSON對(duì)象的類型所確定的字符串。
  • {"type": "FeatureCollection","features": [// 其他內(nèi)容] }
  • type成員的值必須是下面之一:“Point”, “MultiPoint”, “LineString”, “MultiLineString”, “Polygon”, “MultiPolygon”, “GeometryCollection”, “Feature”, 或者 “FeatureCollection”。(類似上面的代碼)

  • GeoJSON對(duì)象可能有一個(gè)可選的"crs"成員,它的值必須是一個(gè)坐標(biāo)參考系統(tǒng)的對(duì)象(見(jiàn)3.坐標(biāo)參考系統(tǒng)對(duì)象)。

  • {"type": "FeatureCollection","crs": {"type": "name","properties": {"name": "urn:ogc:def:crs:OGC:1.3:CRS84"}},"features": [// 其他內(nèi)容] }

    GeoJSON對(duì)象可能有一個(gè)"bbox"成員,它的值必須是邊界框數(shù)組**(見(jiàn)4.邊界框)**。

    {"type": "FeatureCollection","bbox": [-180.0, -90.0, 180.0, 90.0],"features": [// 其他內(nèi)容] }

    2.1 Geometry對(duì)象

    幾何(Geometry)是一種GeoJSON對(duì)象,這時(shí)type成員的值是下面字符串之一:"Point", "MultiPoint", "LineString", "MultiLineString", "Polygon", "MultiPolygon", 或者"GeometryCollection"。 除了“GeometryCollection”外的其他任何類型的GeoJSON幾何對(duì)象必須由一個(gè)名字為"coordinates"的成員。coordinates成員的值總是數(shù)組。這個(gè)數(shù)組里的元素的結(jié)構(gòu)由幾何類型來(lái)確定。

    {"type": "FeatureCollection","features": [{"type": "GeoJSON","geometry": {"type": "MultiPolygon","coordinates": [[[[108.953361,34.292663],[108.953404,34.289539],[108.950857,34.289529]// 多個(gè)經(jīng)緯度點(diǎn)]]]}}] }

    2.1.1.Position(基礎(chǔ)點(diǎn))

    position是基本的幾何結(jié)構(gòu)。幾何對(duì)象的"coordinates"成員由一個(gè)position(這兒是幾何點(diǎn))、position數(shù)組(線或者幾何多點(diǎn)),position數(shù)組的數(shù)組(面、多線)或者position的多維數(shù)組(多面)組成。

    position由數(shù)字?jǐn)?shù)組表示(可以理解為經(jīng)緯度)。必須至少兩個(gè)元素,可以有更多元素。元素的順序必須遵從x,y,z順序(投影坐標(biāo)參考系統(tǒng)中坐標(biāo)的東向、北向、高程或者地理坐標(biāo)參考系統(tǒng)中的坐標(biāo)經(jīng)度、緯度、高程)。任何數(shù)目的其他元素是允許的本文不做項(xiàng)目討論了。

    2.1.2. type類型:Point(點(diǎn))

    對(duì)類型"Point"來(lái)說(shuō),“coordinates"成員必須是一個(gè)單獨(dú)的position。

    { "type": "Point", "coordinates": [100.0, 0.0] }

    2.1.3. type類型:MultiPoint(多點(diǎn))

    對(duì)類型"MultiPoint"來(lái)說(shuō),"coordinates"成員必須是position數(shù)組。

    {"type": "MultiPoint","coordinates": [ [100.0, 0.0], [101.0, 1.0] ] }

    2.1.4. type類型:LineString(線)

    對(duì)類型"LineString"來(lái)說(shuō),“coordinates"成員必須是兩個(gè)或者多個(gè)position的數(shù)組。

    線性環(huán)是具有4個(gè)或者更多position的封閉的線。第一個(gè)和最后一個(gè)位置是相同的(它們表示相同的點(diǎn))。雖然線性環(huán)沒(méi)有鮮明地作為GeoJSON幾何類型,不過(guò)在面幾何類型定義里有提到它。

    {"type": "LineString","coordinates": [ [100.0, 0.0], [101.0, 1.0] ] }

    2.1.5. type類型:MultiLineString(多線)

    對(duì)類型“MultiLineString"來(lái)說(shuō),"coordinates"成員必須是一個(gè)線坐標(biāo)數(shù)組的數(shù)組。

    {"type": "MultiLineString","coordinates": [[ [100.0, 0.0], [101.0, 1.0] ],[ [102.0, 2.0], [103.0, 3.0] ]] }

    2.1.6. type類型:Polygon(面)

    對(duì)類型"Polygon"來(lái)說(shuō),"coordinates"成員必須是一個(gè)線性環(huán)坐標(biāo)數(shù)組的數(shù)組。對(duì)擁有多個(gè)環(huán)的的面來(lái)說(shuō),第一個(gè)環(huán)必須是外部環(huán),其他的必須是內(nèi)部環(huán)或者孔,而且內(nèi)部環(huán)和外部環(huán)的走向是相反的。

    沒(méi)有孔的:

    {"type": "Polygon","coordinates": [[ [100.0, 0.0], [101.0, 0.0], [101.0, 1.0], [100.0, 1.0], [100.0, 0.0] ]] }

    有孔的(外環(huán)和內(nèi)環(huán)的方向始終相反)

    {"type": "Polygon","coordinates": [[ [100.0, 0.0], [101.0, 0.0], [101.0, 1.0], [100.0, 1.0], [100.0, 0.0] ],[ [100.2, 0.2], [100.8, 0.2], [100.8, 0.8], [100.2, 0.8], [100.2, 0.2] ]] }

    2.1.7. type類型:MultiPlygon(多面)

    對(duì)類型"MultiPlygon"來(lái)說(shuō),"coordinates"成員必須是面坐標(biāo)數(shù)組的數(shù)組。

    {"type": "MultiPolygon","coordinates": [[[[102.0, 2.0], [103.0, 2.0], [103.0, 3.0], [102.0, 3.0], [102.0, 2.0]]],[[[100.0, 0.0], [101.0, 0.0], [101.0, 1.0], [100.0, 1.0], [100.0, 0.0]],[[100.2, 0.2], [100.8, 0.2], [100.8, 0.8], [100.2, 0.8], [100.2, 0.2]]]] }

    2.1.8. type類型:Geometry Collection(幾何集合)

    類型為"GeometryCollection"的GeoJSON對(duì)象是一個(gè)集合對(duì)象,它表示幾何對(duì)象的集合。幾何集合必須有一個(gè)名字為"geometries"的成員。與"geometries"相對(duì)應(yīng)的值是一個(gè)數(shù)組。這個(gè)數(shù)組中的每個(gè)元素都是一個(gè)GeoJSON幾何對(duì)象。

    {"type": "GeometryCollection","geometries": [{ "type": "Point","coordinates": [100.0, 0.0]},{ "type": "LineString","coordinates": [ [101.0, 0.0], [102.0, 1.0] ]}] }

    2.2 Feature對(duì)象

    類型為"Feature"的GeoJSON對(duì)象是要素對(duì)象。

  • 要素對(duì)象必須有一個(gè)名字為"geometry"的成員,這個(gè)幾何成員的值是上面定義的geometry對(duì)象或者JSON的null值。
  • 要素對(duì)象必須有一個(gè)名字為“properties"的成員,這個(gè)屬性成員的值是一個(gè)對(duì)象(任何JSON對(duì)象或者JSON的null值)。
  • 如果要素是常用的標(biāo)識(shí)符,那么這個(gè)標(biāo)識(shí)符應(yīng)當(dāng)包含名字為“id”的對(duì)象成員。
  • {"type": "FeatureCollection","features": [{"type": "Feature","properties": {"adcode": 610102,"name": "新城區(qū)","center": [108.959903,34.26927],"centroid": [108.991696,34.271932],"childrenNum": 0,"level": "district","parent": {"adcode": 610100},"subFeatureIndex": 0,"acroutes": [100000,610000,610100]},"geometry": {"type": "MultiPolygon","coordinates": [[[[108.953361,34.292663],[108.953404,34.289539],[108.950857,34.289529]// 多個(gè)經(jīng)緯度點(diǎn)]]]}}] }

    2.2.1 “properties"成員

    “properties"成員的內(nèi)容是保存要素對(duì)象的其他屬性信息,例如該要素對(duì)象的name信息等。

    2.3. FeatureCollection對(duì)象

    類型為"FeatureCollection"的GeoJSON對(duì)象是特征集合對(duì)象。

    類型為"FeatureCollection"的對(duì)象必須有一個(gè)名字為"features"的成員。與“features"相對(duì)應(yīng)的值是一個(gè)數(shù)組。這個(gè)數(shù)組中的每個(gè)元素都是上面定義的feature對(duì)象。

    可以參考2.2的例子

    3.坐標(biāo)參考系統(tǒng)對(duì)象

    GeoJSON對(duì)象的坐標(biāo)參考系統(tǒng)(CRS)是由它的"crs"成員來(lái)確定的。如果對(duì)象沒(méi)有crs成員,那么它的父對(duì)象或者祖父對(duì)象的crs成員可能被獲取作為它的crs。如果這樣還沒(méi)有獲得crs成員,那么默認(rèn)的CRS將應(yīng)用到GeoJSON對(duì)象。

  • 默認(rèn)的CRS是地理坐標(biāo)參考系統(tǒng),使用的是WGS84數(shù)據(jù),長(zhǎng)度和高度的單位是十進(jìn)制標(biāo)示。
  • 名字為"crs"成員的值必須是JSON對(duì)象(指的是下面的CRS對(duì)象)或者JSON的null。如果CRS的值為null,那么就假設(shè)沒(méi)有CRS了。
  • crs成員應(yīng)當(dāng)位于(特征集合、特征、幾何的順序的)層級(jí)結(jié)構(gòu)里GeoJSON對(duì)象的最頂級(jí),而且在自對(duì)象或者孫子對(duì)象里不應(yīng)該重復(fù)或者覆蓋。
  • 非空的CRS對(duì)象有兩個(gè)強(qiáng)制擁有的對(duì)象:“type"和"properties”。
  • type成員的值必須是字符串,這個(gè)字符串說(shuō)明了CRS對(duì)象的類型。
  • 屬性成員的值必須是對(duì)象。
  • CRS不能更改坐標(biāo)順序**(見(jiàn)2.1.1.位置)**
  • {"type": "FeatureCollection","crs": {"type": "name","properties": {"name": "urn:ogc:def:crs:OGC:1.3:CRS84"}},"features": [// 其他內(nèi)容] }

    3.1. CRS

    CRS對(duì)象可以通過(guò)name來(lái)表明坐標(biāo)參考系統(tǒng)。在這種情況下,它的"type"成員的值必須是字符串"name"。它的"properties"成員的值必須是包含"name"成員的對(duì)象。這個(gè)"name"成員的值必須是標(biāo)識(shí)坐標(biāo)參考系統(tǒng)的字符串。比如“urn:ogc:def:crs:OGC:1.3:CRS84"的OGC CRS的URN應(yīng)當(dāng)優(yōu)先于舊的標(biāo)識(shí)符如"EPSG:4326"得到選用。

    3.2. 在線CRS

    CRS對(duì)象也可以連接到互聯(lián)網(wǎng)上的CRS參數(shù)。在這種情況下,它的"type"成員的值必須是字符串"link",它的"properties"成員的值必須是一個(gè)鏈接對(duì)象。

  • 連接對(duì)象由一個(gè)必需的成員:“href”,和一個(gè)可選的成員:“type”。
  • 必需的"href"成員的值必須是解引用的URI(統(tǒng)一資源標(biāo)識(shí))。
  • 可選的"type"成員的值必須是字符串,而且這個(gè)字符串暗示了所提供的URI里用來(lái)表示CRS參數(shù)的格式。建議值是:“proj4”,“ogcwkt”,esriwkt",不過(guò)可以使用其他值。
  • {"type": "FeatureCollection","crs": {"type": "link","properties": {"href": "http://example.com/crs/42","type": "proj4"}},"features": [// 其他內(nèi)容] }

    相對(duì)路徑的輔助文件也可作為CRS直接處理:

    {"type": "FeatureCollection","crs": {"type": "link","properties": {"href": "data.crs","type": "ogcwkt"}},"features": [// 其他內(nèi)容] }

    4.Bounding Boxes

    為了包含geometry、feature或者feature collection的坐標(biāo)范圍信息,GeoJSON對(duì)象可能有一個(gè)名字為"bbox的成員。bbox成員的值必須是2*n數(shù)組,這兒n是所包含幾何對(duì)象的維度數(shù),并且所有坐標(biāo)軸的最大值和最小值。bbox的坐標(biāo)軸的順序遵循幾何坐標(biāo)軸的順序。除此之外,bbox的坐標(biāo)參考系統(tǒng)假設(shè)匹配它所在GeoJSON對(duì)象的坐標(biāo)參考系統(tǒng)。

    feature對(duì)象上的bbox成員的例子:

    {"type": "Feature","bbox": [-180.0, -90.0, 180.0, 90.0],"geometry": {"type": "Polygon","coordinates": [[[-180.0, 10.0], [20.0, 90.0], [180.0, -5.0], [-30.0, -90.0]]]} }

    feature collection對(duì)象中bbox成員的例子:

    {"type": "FeatureCollection","bbox": [100.0, 0.0, 105.0, 1.0],"features": [// 其他內(nèi)容] }

    參考:
    https://zhuanlan.zhihu.com/p/510882183
    https://blog.csdn.net/qq_36213352/article/details/117534921

    總結(jié)

    以上是生活随笔為你收集整理的geojson 格式说明(格式详解)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

    如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。