diff --git a/README.md b/README.md index dae26ada4bd3..160c380f58a5 100644 --- a/README.md +++ b/README.md @@ -13,22 +13,42 @@ Developing Usage --------------- This library exports the following GDAL functions: +- CSLCount +- GDALSetCacheMax - GDALAllRegister - GDALOpen -- GDALGetRasterCount +- GDALClose +- GDALGetDriverByName +- GDALCreate +- GDALCreateCopy - GDALGetRasterXSize - GDALGetRasterYSize +- GDALGetRasterCount +- GDALGetRasterDataType +- GDALGetRasterBand - GDALGetProjectionRef +- GDALSetProjection - GDALGetGeoTransform +- GDALSetGeoTransform - OSRNewSpatialReference +- OSRImportFromEPSG - OCTNewCoordinateTransformation - OCTTransform -(and untested) +- GDALCreateGenImgProjTransformer +- GDALGenImgProjTransform +- GDALDestroyGenImgProjTransformer +- GDALSuggestedWarpOutput - GDALTranslate - GDALTranslateOptionsNew - GDALTranslateOptionsFree +- GDALReprojectImage To see full-fledged examples using all of these functions from within a WebWorker, check out the -`examples` directory. +`examples` directory. From simplest to most complex, these examples are: + +1. `inspect_geotiff` +2. `map_extent` +3. `thumbnail` +4. `thumbnail_map` -In order to limit Javascript build size, GDAL is currently built with support for GeoTIFFs only. +In order to limit Javascript build size, GDAL is currently built with support for GeoTIFFs and PNGs only. diff --git a/examples/README.md b/examples/README.md new file mode 100644 index 000000000000..9e5acfc66290 --- /dev/null +++ b/examples/README.md @@ -0,0 +1,24 @@ +The examples in this folder show how to use the Emscripten generated GDAL library in increasingly +complex ways. Ordered from easiest to hardest, they are roughly: + +1. `inspect_geotiff` (Show info about a GeoTIFF, roughly mimicking `gdalinfo` +2. `map_extent` (Display the GeoTIFF's extent on a Leaflet map) +3. `thumbnail` (Generate false-color PNG thumbnail of first three bands of a GeoTIFF) +4. `thumbnail_map` (Generate false-color PNG thumbnail, warp to EPSG:3857, display on Leaflet map) + +The examples build on each other, but in order to keep them as instructive as possible, they +deliberately repeat common elements, rather than pulling them out into wrapper functions. The reason +for this is that interacting with Emscripten-generated functions often involves direct access to the +Emscripten heap and manipulating pointers, so simply documenting function signatures may not provide +a complete picture of how to use a given function. Rather, there is often a significant amount of +boilerplate necessary in order to interact with Emscripten functions. The goal of these examples is +for each one to provide a standalone picture of how this boilerplate works. Writing a wrapper +library would get in the way of demonstrating these core concepts. Much of the code in these +examples could form the _foundation_ of a more ergonomic and idiomatic wrapper library, but +generating that library is not the purpose of these examples. Rather, it is to document the usage +patterns necessary for interacting with the Emscripten-generated GDAL API at the lowest level. + +In order to run these examples, make sure that `gdal.js`, `gdal.js.mem`, and `gdal.data` are +available from the example directory (there are symlinks to these locations in the root of the +repository for convenience). Then simply serve the directory from a webserver such as +`python -m SimpleHTTPServer`.