An Open Web Mapping Toolbox
Dave Cole & Tom MacWright
from MapBox
What kind of web maps can you make?
A base map
Or tiled overlays
Or tiled overlays
With client features
Process:
1. Sourcing data
Where do you find reliable open data?
2. Processing data
Adding geo data, projections, summarization
data:image/s3,"s3://crabby-images/504d7/504d717476fc4832b66363d5927c7548a4a28141" alt=""
3. Design
visualizing the data; telling a story
4. Map distribution
rendering → serving tiles → interfaces on web & mobile
Where to find open data:
OpenStreetMap
openstreetmap.org
US Census
census.gov/
geo/www/tiger
Local government open data
data:image/s3,"s3://crabby-images/bfa0f/bfa0f64c4b24d2afd9aef48e2bc492b903175955" alt=""
Natural Earth
naturalearthdata.com
Data you create
Like a spreadsheet or list of addresses
Processing data:
Tools
QGIS, ORG / GDAL, PostGIS (CartoDB), scripting (Python)
Formats
shp, geojson, kml, geotiff, csv
Adding geographic data
Geocoding
55 4th Street, San Francisco, CA 94103 →
{
lng: -122.404883,
lat: 37.785034
}
Geocoding
nominatim.
openstreetmap.org
geocoder.us
geonames.org
Joining geo data
Projections
data:image/s3,"s3://crabby-images/7fab9/7fab95b7157a9068a320d087b04e29a116db74ed" alt=""
Projections
Converting a 3d globe to a flat map
Spherical mercator
data:image/s3,"s3://crabby-images/7ef19/7ef199f76e86052158ed98755076c411da447501" alt=""
Albers equal area
data:image/s3,"s3://crabby-images/cb7ec/cb7ecdd47c8cb5fa5a924409794eff9313f67e87" alt=""
Summarization
Viewing data in aggregate
Pivot tables
Aggregate records of data on an attribute
Pivot tables
data:image/s3,"s3://crabby-images/1a229/1a2291432bea666ed53caa11f9d49614b31ce772" alt=""
Pivot tables
data:image/s3,"s3://crabby-images/8badb/8badb17d4a61513e6df2309b258ddaacd52d922a" alt=""
Points in areas
data:image/s3,"s3://crabby-images/45216/45216a21b2e296617555551c45fbfedaf5596baf" alt=""
Nearest neighbors
data:image/s3,"s3://crabby-images/46ddd/46ddd51b1b0c0136927605d0b16b5c95018ff84c" alt=""
Gridding
data:image/s3,"s3://crabby-images/9464f/9464f6d1a5d29e39b90fe790f47952d9e99def2f" alt=""
Designing the map
TileMill + Carto
data:image/s3,"s3://crabby-images/92784/927849201c37be7811ea5099686f3154ac5c2034" alt=""
Color variables
/* ---- PALETTE ---- */
@motorway: #90BFE0; /* #90BFE0 */
@trunk: #FFFABB;
@primary: @trunk;
@secondary: @trunk;
@road: #bbb;
@track: @road;
Conditionals, attachments, functions, zoom levels
/* ---- ROAD COLORS ---- */
.highway[TYPE='motorway'] {
.line[zoom>=0] {
line-color:
spin(darken(@motorway,36),-10);
line-cap:round;
line-join:round;
}
.fill[zoom>=10] {
line-color:@motorway;
line-cap:round;
line-join:round;
}
}
Tiled overlays
When design and scale matter
Show millions of points precisely without sacrificing speed
Interactivity
data:image/s3,"s3://crabby-images/a24d9/a24d980c7899ece966a922cf5846e084d425635f" alt=""
MBTiles
data:image/s3,"s3://crabby-images/75d91/75d913972efea54e32eece7ead5709857996cb45" alt=""
MBTiles
data:image/s3,"s3://crabby-images/c4a89/c4a89117abac9c5c1ab061dc2072380665391ee9" alt=""
The Client Side
putting web maps on web pages
generally Javascript libraries that deal in images
lots of options:
OpenLayers
established, monolithic, 'hefty'
920KB
= 9.5 jQueries
= every deprecated 90s protocol
So it's overkill for most humans, but 2.12 will be sweet
Leaflet
OpenLayers post-web renassiance & workout time
Modest Maps
nothing but tiles: wafer thin & light
'Theme'
open source libraries > their © equivalents
// The world-famous
// Google Maps API
new google.maps.Map($('map')[0], {
zoom: 8,
center: new google.maps.LatLng(
-34.397, 150.644),
mapTypeId: google.maps.MapTypeId.ROADMAP
});
// Leaflet with MapBox Streets
var mylayer = 'http://a.tiles.mapbox.com/v3/tmcw.map-rnesfyru';
var map = new L.Map('map', {
center: new L.LatLng(-34.397, 150.644),
zoom: 8,
layers: [new L.TileLayer(mylayer + '/{z}/{x}/{y}.png')]
});
data:image/s3,"s3://crabby-images/6f104/6f1040eee986633dd24be369667d1a70a93c4efd" alt=""
'red dot fever'
// Making a marker in Google Maps
var marker = new google.maps.Marker({
position: new google.maps.LatLng(-34.397, 150.644),
map: map
});
// Making a marker in Leaflet
map.addLayer(new L.Marker(new L.LatLng(-34.397, 150.644)));
Performance
Multiple kinds.
Client-side
data:image/s3,"s3://crabby-images/7880c/7880c05d9972b3ac82b8417e70c31830c84f1046" alt=""
Client-side
Minimize page weight via magic.
Client-side
page weight = #/elements + kb/data + ms/javascript
Client-side
magic = MapBox's UTFGrid, Canvas
Server-side
data:image/s3,"s3://crabby-images/6824d/6824df30fe0c4251ee9e26410304026a01558380" alt=""
Server-side
Maximize clients × (maps/sec)
Server-side
Cache, optimize, distribute
Server-side
TileMill renders maps - then 'just' distribute tiles
Server-side
Never WMS again; tiles are cacheable and distributable
The future
data:image/s3,"s3://crabby-images/3f3d3/3f3d3f50ab5dc11b7b03b4812aa5de556865f2aa" alt=""
The future
vectors - first on mobile
The future
vectors - first on mobile & driven by data improvements
The future
mix & match components
The future
mix & match components → you don't need Google