Intro To Web Maps
& Leaflet 101
data:image/s3,"s3://crabby-images/7cd56/7cd56fbaea1e6224ed1ffb3ab6c4f26894dd2cb5" alt=""
data:image/s3,"s3://crabby-images/4b6af/4b6af4cfbda0bb5da06b335f9256a020af8b1863" alt=""
Follow along at: slides.com/kkowalsky/webmap
We're going to cover:
- What's a web map?
- Basic HTML/CSS & Javascript
- Spatial data
- Intro to Leaflet
- Leaflet.js tutorial
- Resources
What the heck is a web map?!
First things first:
data:image/s3,"s3://crabby-images/66af7/66af709bd6be35dbe99d6cc63179d8af1f586aa5" alt=""
Web maps aren't just digitized maps:
-
Tiles
-
Interactive
-
Functional
Most of you probably think of:
data:image/s3,"s3://crabby-images/df6db/df6db2b5c5f7e69ffdf06204c691cdee2f2bd9c0" alt=""
data:image/s3,"s3://crabby-images/71e29/71e29656ce469de16369ad997d59e0b81410e495" alt=""
data:image/s3,"s3://crabby-images/1d2bc/1d2bcf31a96e3f2ce8a4b3b21102259edbe71aaf" alt=""
data:image/s3,"s3://crabby-images/91984/9198470dddd17dfe92c3b09959e093de9537a553" alt=""
Mapping online is EXPLODING!
data:image/s3,"s3://crabby-images/eae55/eae5560245400ea824c78c341bee8d72da2890b0" alt=""
data:image/s3,"s3://crabby-images/bf2fe/bf2fe436468204d4e7dd9af0d501652688f1a240" alt=""
data:image/s3,"s3://crabby-images/71e0d/71e0d8cdad79a03dd355286dba13454a81888381" alt=""
data:image/s3,"s3://crabby-images/09b31/09b31d6433cfc55a7d85af74657b47e19dd21c5f" alt=""
data:image/s3,"s3://crabby-images/68895/68895f45445111561835f231889812bab017115e" alt=""
data:image/s3,"s3://crabby-images/67878/678780496791414b3791fadd984c25e7e8414f78" alt=""
data:image/s3,"s3://crabby-images/20059/20059e65b460c320eb8c996d6860feed8c0bafbe" alt=""
What's in a web map?
data:image/s3,"s3://crabby-images/d89af/d89af9a7b613336633f4a5a1668999b3117e5617" alt=""
"These tiles are typically 256x256 pixels and are placed side-by-side in order to create the illusion of a very large seamless image."
data:image/s3,"s3://crabby-images/01e3b/01e3b4c607ca530c76a89ef53f1e41350c3da552" alt=""
1. Tiles: the baselayer
Why tiles?
- Efficient
- Load Progressively
- Simple to use
data:image/s3,"s3://crabby-images/ea092/ea0923fde8e985f3e60ac0f7c558ba0aed877a43" alt=""
There are 2 types of tiles:
Raster
Vector
- Each zoom has own tiles
- More zoom = more tiles
- Every tile is just an image
- Have layers
- Using vector data
2. Data: the data layer
3. Javascript: putting it all together
data:image/s3,"s3://crabby-images/e505c/e505c8953925736ae8028548a8f6aef0ae23623a" alt=""
data:image/s3,"s3://crabby-images/bd9f2/bd9f256c5e3b88b989825960aea097d2c419bb1c" alt=""
HTML/CSS Review
"HTML is the noun, CSS is the adjective & Javascript is the verb" -A very smart person
data:image/s3,"s3://crabby-images/f0393/f03939180f4c228421ed6e4f1bcf4220a5f7af2f" alt=""
HTML uses <tags>
<img> You can use them for images </img>
<h1> Inserting words </h1>
<p> Writing a lot of words </p>
<a> Links </a>
<div> ALL SORTS OF THINGS! </div>
All we need for today: <div>
<div> defines a section/element to a web page
data:image/s3,"s3://crabby-images/21668/216685a07deb94344897529f2930bab026d92107" alt=""
With Leaflet,
we just need a div called 'map'
Without CSS, nothing would look pretty!
data:image/s3,"s3://crabby-images/b3211/b32112e4d5e67eb36648e6e7fa51a9786dbd1cef" alt=""
Basic CSS syntax:
selector = tag/class/id
selector{
property:
value;}
property = what are you styling?
value = what do you want it to be?
Example:
We have a div called 'map' in HTML
data:image/s3,"s3://crabby-images/58bac/58bac2fa38fa10b40d0e2346b43ec3d4d9ff55d1" alt=""
Spatial Data
data:image/s3,"s3://crabby-images/4b6af/4b6af4cfbda0bb5da06b335f9256a020af8b1863" alt=""
What kind of data can we get?
Raster vs. Vector
data:image/s3,"s3://crabby-images/90a86/90a86f348ea19e9a9fee5e6ad07ff77ad8e1fc80" alt=""
data:image/s3,"s3://crabby-images/48563/4856326854e8333c95e9197e877604546f385578" alt=""
We're gonna focus on vector
3 requirements:
- location
- geometry
- attribute info
Familiar formats: The Shapefile
data:image/s3,"s3://crabby-images/23001/2300144dd4a3c61bff6e386ea64f3244cd3f49c9" alt=""
data:image/s3,"s3://crabby-images/74dc4/74dc477c4cde3515007b887fcb0ee2a327cb0c3b" alt=""
Web Spatial Data is a little different...
Web formats:
- geoJSON
- CSV
- KML
- GPX
data:image/s3,"s3://crabby-images/8025d/8025d753872f7b49f585b562a8834992e06e586a" alt=""
You can convert to geoJSON!
data:image/s3,"s3://crabby-images/0784c/0784c8c00f7cf923e8a3282b538e03bc7adaf7b5" alt=""
geojson.io
Special thanks to:
data:image/s3,"s3://crabby-images/24802/248023aebcb96be2ad4a3d0a7d2c4ada71e8b230" alt=""
Intro to Web Mapping
By kkowalsky
Intro to Web Mapping
May 19, 2015 Intro to web mapping & leaflet 101 presentation
- 1,671