Anatomy of a Web Map
3 exceptions to yesterday's simplified story!
Exception #1: Can’t interact with many features on a raster. BUT
UTFGrid (Mapbox invention) makes it possible.
data:image/s3,"s3://crabby-images/819a0/819a08c7f4471596ad1bc91a952064005cf32b74" alt=""
UTFGrid is an invisble tile layer made up of arbitrary letters which are indexes into the clickable data
Exception #2: Tiles are always rasters except when they're not!
vector tiles! What are they?
vector tiles: they are an alternative to a database that makes raster tiles.
Raster: ask for data to fit into tile - burned
Vector: already have vector data sliced up in the way that I will make raster tiles
So someone has to go through and chop up that data, like
MapBox or yourself
Advantages:
Styling - can be styled when requested, allowing for many map styles on global data
Size - really small, enabling global high resolution maps, fast map loads, and efficient caching
Dynamicity - client side filtering/querying and zoom dependent styling
Scalability - WebGL works on the graphic card
Disdvantages:
WebGL - not every browser has full support yet
Complexity - still a bit complex to use
Ecuador sample data:
1015 districts (admin level 2)
33 attributes (per district)
500,000 vertices
Loading from local GeoJson: 1.62 s
Loading protocol buffer from TileLive: 161 ms
Exception #3:
D3 exists outside the world of tiles
you can’t easily make road map in D3 BUT can do things that are clumsy in slippy maps like...
data:image/s3,"s3://crabby-images/4e043/4e043da45db1156cf122da004b0142c79f3d2371" alt=""
choropleth maps
data:image/s3,"s3://crabby-images/b5562/b55624a3810b65496d3113c567c731168ca7aecc" alt=""
cartograms
data:image/s3,"s3://crabby-images/4a976/4a97686616a5f526df651c9b5fd1927ea716469b" alt=""
different map projections (in the browser!)
data:image/s3,"s3://crabby-images/7a910/7a9102f548dab3fba9e939cc446c8e8e41cff276" alt=""
D3
data:image/s3,"s3://crabby-images/2b9d3/2b9d3b5a82f0dd31d8c7ae3dca8f0fdf9cabeee5" alt=""
IS
data:image/s3,"s3://crabby-images/168db/168dbd7ec3b7edffb247a5162b213e15bc93a8d5" alt=""
IN
data:image/s3,"s3://crabby-images/caaa6/caaa6de8d056256b73c8be04dac067ff657fa18e" alt=""
SANE
Very powerful, but steepish learning curve
Postgis is a spatial database extender for PostgreSQL object-relational database.
Geoserver is an open source server for sharing geospatial data
Geonode is an Open Source Geospatial Content Management System