gdal-enhanced
v0.9.13
Published
Bindings to GDAL (Geospatial Data Abstraction Library) with non-default drivers
Downloads
220
Readme
node-gdal
This is a fork of the great work done by the Natural Atlas team with some additional drivers and functionality added.
Read and write raster and vector geospatial datasets straight from Node.js with this native GDAL binding. GDAL 2.1.1 (GEOS 3.4.2, Proj.4 4.9.2, Expat 2.1.0) comes bundled, so node-gdal will work straight out of the box. To get started, browse the API Documentation or examples.
$ npm install gdal-enhanced --save
To link against shared libgdal, install using:
# requires libgdal-dev (debian: sudo apt-get install libgdal-dev)
$ npm install gdal-enhanced --build-from-source --shared_gdal
Sample Usage
Raster
var gdal = require("gdal-enhanced");
var dataset = gdal.open("sample.tif");
console.log("number of bands: " + dataset.bands.count());
console.log("width: " + dataset.rasterSize.x);
console.log("height: " + dataset.rasterSize.y);
console.log("geotransform: " + dataset.geoTransform);
console.log("srs: " + (dataset.srs ? dataset.srs.toWKT() : 'null'));
Vector
var gdal = require("gdal-enhanced");
var dataset = gdal.open("sample.shp");
var layer = dataset.layers.get(0);
console.log("number of features: " + layer.features.count());
console.log("fields: " + layer.fields.getNames());
console.log("extent: " + JSON.stringify(layer.extent));
console.log("srs: " + (layer.srs ? layer.srs.toWKT() : 'null'));
Notes
- This binding is currently not async, so it will block node's event loop. This will be changing in the future (#18). In the meantime, be very careful (or avoid) using it in server code. We recommended using tools like worker-farm to push expensive operations to a seperate process.
Bundled Drivers
AAIGrid
, ACE2
, ADRG
, AIG
, AVCBin
, AVCE00
, AeronavFAA
, AirSAR
, BLX
, BMP
, BNA
, BT
, CEOS
, COASP
, COSAR
, CPG
, CSV
, CTG
, CTable2
, DGN
, DIMAP
, DIPEx
, DOQ1
, DOQ2
, DTED
, DXF
, E00GRID
, ECRGTOC
, EDIGEO
, EHdr
, EIR
, ELAS
, ENVI
, ERS
, ESAT
, ESRI Shapefile
, MapInfo File
, FAST
, FIT
, FujiBAS
, GFF
, GML
, GPSBabel
, GPSTrackMaker
, GPX
, GRASSASCIIGrid
, GS7BG
, GSAG
, GSBG
, GSC
, GTX
, GTiff
, GenBin
, GeoJSON
, GeoRSS
, Geoconcept
, HF2
, HFA
, HTF
, IDA
, ILWIS
, INGR
, IRIS
, ISIS2
, ISIS3
, Idrisi
, JAXAPALSAR
, JDEM
, JPEG
, KMLSUPEROVERLAY
, KML
, KRO
, L1B
, LAN
, LCP
, LOSLAS
, Leveller
, MAP
, MEM
, MFF2
, MFF
, Memory
, MrSID
, MG4Lidar
, JP2MrSID
, NDF
, NGSGEOID
, NITF
, NTv2
, NWT_GRC
, NWT_GRD
, OGR_GMT
, OGR_PDS
, OGR_SDTS
, OGR_VRT
, OpenAir
, OpenFileGDB
, PAux
, PCIDSK
, PDS
, PGDUMP
, PNG
, PNM
, REC
, RMF
, ROI_PAC
, RPFTOC
, RS2
, RST
, R
, S57
, SAGA
, SAR_CEOS
, SDTS
, SEGUKOOA
, SEGY
, SGI
, SNODAS
, SRP
, SRTMHGT
, SUA
, SVG
, SXF
, TIL
, TSX
, Terragen
, UK .NTF
, USGSDEM
, VICAR
, VRT
, WAsP
, XPM
, XPlane
, XYZ
, ZMap
Contributors
This binding is a collaboration between Natural Atlas and Mapbox. Its contributors are Brandon Reavis, Brian Reavis, Dane Springmeyer, Zac McCormick, and others.
Before submitting pull requests, please update the tests and make sure they all pass.
$ make test # test against bundled gdal
$ make test-shared # test against shared gdal
License
Copyright © 2015 Natural Atlas, Inc. & Contributors
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at: http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.