GeoJSON

GeoJSON
Filename extensions .json, .geojson
Internet media type application/vnd.geo+json
Type of format GIS file format
Extended from JSON
Standard RFC 7946
Open format? yes
Website geojson.org

GeoJSON[1] is an open standard format designed for representing simple geographical features, along with their non-spatial attributes, based on JavaScript Object Notation.[2][3]

The features include points (therefore addresses and locations), line strings (therefore streets, highways and boundaries), polygons (countries, provinces, tracts of land), and multi-part collections of these types. GeoJSON features need not represent entities of the physical world only; mobile routing and navigation apps, for example, might describe their service coverage using GeoJSON.[4]

The GeoJSON format differs from other GIS standards in that it was written and is maintained not by a formal standards organization, but by an Internet working group of developers.[5]

A notable offspring of GeoJSON is TopoJSON, an extension of GeoJSON that encodes geospatial topology and that typically provides smaller file sizes.

History

The GeoJSON format working group and discussion were begun in March 2007[6] and the format specification was finalized in June 2008.

In April 2015 the Internet Engineering Task Force has founded the Geographic JSON working group[7] which released GeoJSON as RFC 7946 in August 2016.

Example

{ "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"}
           }
         }
       ]
     }

Geometries

Geometry primitives
Type Examples
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]]
    ]
}
Multipart geometries
Type Examples
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]]
        ]
    ]
}

Supported software

GeoJSON is supported by numerous mapping and GIS software packages, including OpenLayers,[8] Leaflet, MapServer,[9] Geoforge software,[10] GeoServer,[11] GeoDjango,[12] PointPlot, [13] GDAL,[14] Safe Software FME,[15] and CartoDB.[16] It is also possible to use GeoJSON with PostGIS[17] and Mapnik,[18] both of which handle the format via the GDAL OGR conversion library. Bing Maps, Yahoo! and Google also support GeoJSON in their API services.

The Google Maps JavaScript API v3 directly supports the integration of GeoJSON data layers[19] as of March 19, 2014.[20] For the Julia language a GeoJSON.jl package is available.

GitHub also supports GeoJSON rendering[21] and Potrace GeoJSON export.

Geojson.io supports GeoJSON rendering and editing in the web browser.

TopoJSON

TopoJSON is an extension of GeoJSON that encodes topology. Rather than representing geometries discretely, geometries in TopoJSON files are stitched together from shared line segments called arcs.[22] Arcs are sequences of points, while line strings and polygons are defined as sequences of arcs. Each arc is defined only once, but can be referenced several times by different shapes, thus reducing redundancy and decreasing the file size.[23] In addition, TopoJSON facilitates applications that use topology, such as topology-preserving shape simplification, automatic map coloring, and cartograms.

A reference implementation of the TopoJSON specification is available as a command-line tool to encode TopoJSON from GeoJSON (or ESRI Shapefiles) and a client side JavaScript library to decode TopoJSON back to GeoJSON again. TopoJSON is also supported by the popular OGR tool as of version 1.11[24] and PostGIS as of version 2.1.0.[25]

TopoJSON Schema

Given a GIS shape near coordinates latitude 0° en longitude 0° a simple but valid and complete topojson file containing all metadata, Polygon, LineString, Point elements, arcs and properties is defined as follows:

Topojson shapes
{
  "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]]
  ]
}

References

  1. The GeoJSON Format Specification
  2. Leonard Richardson; Mike Amundsen; Sam Ruby (12 September 2013). RESTful Web APIs. "O'Reilly Media, Inc.". p. 228. ISBN 978-1-4493-5974-4. Geojson: A Trobled Type ... a standard based on JSON, designed for representing geographic features like points on a map. ... There's another problem with GeoJSON: Iit has no registered media type. A GeoJSON document is served as application/json, just like any other JSON document. How is a client supposed to distinguish between geoJSON and plain old JSON?
  3. Erik Westra (23 June 2015). Python Geospatial Analysis Essentials. Packt Publishing Ltd. p. 27. ISBN 978-1-78355-389-1. GeoJSON ... is an open standard used to represent geospatial data structures as JavaScript Object Notation (JSON) objects.
  4. iOS Location and Maps Programming Guide
  5. The GeoJSON Discussion List
  6. March 2007 Archives by thread
  7. https://datatracker.ietf.org/wg/geojson/history/
  8. http://openlayers.org/dev/examples/vector-formats.html
  9. http://mapserver.org/output/template_output.html
  10. http://leafletjs.com/reference.html#geojson
  11. http://svn.codehaus.org/geoserver/tags/2.0.0-alpha1/geoserver/release/README.txt
  12. http://geodjango.org
  13. http://www.ndm.io
  14. http://gdal.org/ogr/drv_geojson.html
  15. http://www.safe.com/reader_writerPDF/geojson.pdf
  16. http://developers.cartodb.com/documentation/cartodb-js.html
  17. http://pugs.postgresql.org/files/Introduction_to_PostGIS_v1.0.pdf
  18. http://svn.mapnik.org/tags/release-0.6.0/docs/api_docs/python/mapnik-module.html
  19. https://developers.google.com/maps/documentation/javascript/examples/layer-data-simple
  20. http://googledevelopers.blogspot.com/2014/03/maps-made-easier-geojson-in-javascript.html
  21. https://github.com/blog/1528-there-s-a-map-for-that
  22. https://github.com/topojson/topojson-specification
  23. https://github.com/mbostock/topojson/wiki
  24. GDAL/OGR 1.11.0 Release Notes
  25. PostGIS AsTopoJSON

Sources

This article is issued from Wikipedia - version of the 11/22/2016. The text is available under the Creative Commons Attribution/Share Alike but additional terms may apply for the media files.