Skip to content

Latest commit

 

History

History
58 lines (37 loc) · 2.84 KB

README.md

File metadata and controls

58 lines (37 loc) · 2.84 KB

About this repo

This repo is a serverless (i.e. javascript + html only) viewer for Cloud Optimized GeoTiff (COG) files. COG files are a variant of GeoTIFF raster goespatial files which are optimzied for serving in web apps.

This app reads the COG TIFF files and applies a color ramp in the browser. For this to work the browser JavaScript needs to know the min and max values of the entire TIFF file, since the system only reads small windows of the COG at any time for performance reasons. If you use GDAL to create the COG file it will include STATISTICS_MINIMUM and STATISTICS_MAXIMUM metadata fields which is sufficient. If you use another software to create the COG you will need to provide the min and max values another way. This setup is not well documented so please see the source code to understand how the JavaScript reads the min and max values.

This repo has support for reading QGIS Color Ramp files. These allow the creator to specify a custom color ramp across specific data values, allowing you to build subtle color palettes that bring out features in datasets where values are not evenly distributed.

This repo has support for exloring a STAC asset catalog. Click on the FAIRiCUBE logo to open the STAC catalog explorer, then click on an asset to load it for visualization.

If this page is called with a query paramter like `?data=https://my.url/my_dataset.tiff" it will load and visualize that COG file. This can be useful for example for creating links in a STAC catalog directly to a visualization.

Building the app

This app is built using Astro.build to package all the pieces of the web app into a single .html page, and SolidJS to power some interactive elements.

The app uses custom DOM events to connect elements (e.g. to redraw the color bar when a new palette is invoked) and localStorage API to manage state (e.g. which COG URL is being viewed, which palette is active, etc.), and provides access to the basic set of D3 color ramps.

To compile and edit the app on your local machine, you must have NodeJS installed then clone this repo and from inside the repo folder, run:

npm install
npm run dev # this will start a dev version on your local machine.

npm run dev

Runs the app in the development mode.
Open http://localhost:5173 to view it in the browser.

npm run build

The command npm run build builds the app for production and compiles the web page(s) the dist folder.

Github Pages

This repo contains a .yml file in ./github/workflows which builds the webapp and deploys it to GitHub Pages.

Creating Cloud Optimized GeoTIFFs

The easiest way is

gdalwarp -of COG -t_srs EPSG:3857   inputdata.tiff result.tiff

This will create the COG file, including overview tiles, and warp it to EPSG:3857 which is the normal for web maps.

Learn about COG format here: https://cogeo.org/