This plugin handles two-way conversion between GeoJSON and the ArcGIS Geometry format used by Esri.
The ArcGIS parser can be used client-side in a browser and server-side via Node.js.
// parse an ArcGIS Geometry to GeoJSON
var geojsonPoint = Terraformer.ArcGIS.parse({
x: -122.6764,
y: 45.5165,
spatialReference: {
wkid: 4326,
},
});
// convert a GeoJSON object into an ArcGIS geometry
var arcgisPoint = Terraformer.ArcGIS.convert({
type: "Point",
coordinates: [45.5165, -122.6764],
});
In the browser, the core Terraformer library is required.
<script src="terraformer.min.js"></script>
<script src="terraformer-arcgis-parser.min.js"></script>
<script>
// Terraformer and Terraformer.ArcGIS will be defined.
</script>
You can also use Bower to install the components if you like, or download them and host them yourself.
$ bower install terraformer-arcgis-parser
Just install the package from npm with $ npm install terraformer-arcgis-parser
Then include it in your application.
Terraformer.ArcGIS = require("terraformer-arcgis-parser");
// Start parsing and converting!
Terraformer.ArcGIS.parse(json, options)
- Converts from ArcGIS JSON to GeoJSON or a Terraformer.Primitive.
Option | Type | Default | Description |
---|---|---|---|
idAttribute |
String |
"OBJECTID" |
By default, when converting GeoJSON Features the id key of your output feature will be set on the OBJECTID field. This option allows you to assign your ID using a different fieldname. |
Terraformer will also handle converting FeatureCollection
and GeometryCollection
objects to arrays of ArcGIS geometries or features. However it will not do this in reverse. This is because there is no official structure for arrays of features and geometries in ArcGIS and output features will be missing an id
property. See this issue for more details.
// parse an ArcGIS Geometry to GeoJSON
var point = Terraformer.ArcGIS.parse({
x: -122.6764,
y: 45.5165,
spatialReference: {
wkid: 4326,
},
});
Terraformer.ArcGIS.convert(geoJSON, options)
will convert GeoJSON or a Terraformer Primitive to ArcGIS JSON.
Option | Type | Default | Description |
---|---|---|---|
sr |
Number |
4326 |
This is used to set the value of spatialReference.wkid in the output. Setting sr does not convert the geojson coordinates, it only identifies the projection using the appropriate code. |
idAttribute |
String |
"OBJECTID" "FID" |
When converting ArcGIS Feature the attributes will contain the ID of the feature. This is usually called OBJECTID or FID . If your feature does not use the OBJECTID or FID keys as its ID, you should define what the key representing your Features ID is. |
If the geometry is in the Web Mercator spatial reference it will be reprojected to WGS84.
// take a Terraformer.Primitive or GeoJSON and convert it to an ArcGIS JSON object
var point = ArcGIS.convert({
type: "Point",
coordinates: [45.5165, -122.6764],
});