tangrams / cinnabar-style

Colorful cartography for that classic look
http://tangrams.github.io/cinnabar-style/
MIT License
10 stars 11 forks source link

Tangram Cinnabar Style

Cinnabar is a classic look and should be your go-to for general mapping applications. Give OpenStreetMap data a refined basemap skin using the Tangram graphics library and Mapzen's versatile Vector Tiles.

This style is a High Road influenced evolution of the Traditional style Stamen created for Mapzen's Open Android app in 2014. Please use and adapt the open source scene file in your own projects!

Looking for help? There is a mini tutorial after the preview image below walking thru Vector Tiles API key signup and building a Leaflet map using Tangram and this repo's scene file.

A family of styles with many flavours

Mapzen offers the Cinnabar style in three flavors:

  1. Default (this repo) - Some labels for streets, cities, water bodies, and some big parks with name only (no icons). No business labels. Good for data visualization overlays that need to provide some location context.
  2. More labels - Full set of labels, including high contrast icons highlighting OpenStreetMap business listing data.
  3. No labels - Just the lines and polygons, please.

Looking for a different style? We offer a range of styles including Refill (high contrast black & white cartography) and Zinc (soft gray cartography).

Live Cinnabar demo: http://tangrams.github.io/cinnabar-style

tangram cinnabar style

Developer resources

So how do you actually use this stuff? Tangram styles are called "scenes" and are written in YAML. The scene file (e.g.: cinnabar-style.yaml) requires a vector tile source. To use Mapzen's vector tile service you must first obtain a free developer API key and update your scene file with that key.

Sign up for a Mapzen Vector Tiles API key

Mapzen Vector Tiles are a free, shared tile service. As such, there are generous limitations on requests to prevent individual users from degrading the overall system performance.

  1. Go to https://mapzen.com/developers.
  2. Sign in with your GitHub account. If you have not done this before, you need to agree to the terms first.
  3. Create a new key for Vector Tiles, and optionally, give it a project name so you can remember the purpose of the key.
  4. Keep the web page open so you can copy the key into your source code later.

Building a Leaflet map using Tangram

Using Tangram and Mapzen's Vector tiles inside the popular Leaflet mapping framework is easy. We'll make it even easier soon to do this via a Leaflet provider, but in the meantime...

  1. Update your copy of the scene file on line 453 to reference the API key you created in Step 3 in the Sign up section above. url: //vector.mapzen.com/osm/all/{z}/{x}/{y}.topojson?api_key=vector-tiles-{your-api-key-here}
  2. Reference the index-demo.html file in any of the style repos for how to configure Leaflet with Tangram and the scene file (e.g.: Cinnabar).
  3. Looking for a more sophisticated implementation that includes basic search? The main index.html file has a more real world example.
  4. Need help testing your map locally? See the README in each repo.
  5. Wondering where to host your map? Make a public repo on Github (or fork ours!) and enjoy their GitHub Pages to github.io magic dance.

Tangram resources

  1. Procedural Cartography with Tangram Patricio's presentation notes from JS.Geo metope in August 2015.
  2. Walkthrough: Make a map with Tangram by Rhonda on Mapzen's documentation team.

To run locally

Want to modify the style to fit your needs? Clone or downloaded the repo locally. Then...

Start a web server in the repo's directory:

python -m SimpleHTTPServer 8000

If that doesn't work, try:

python -m http.server 8000

Then navigate to: http://localhost:8000, which loads the index.html file.

You should be all set, happy mapping! But please let us know at hello@mapzen.com or via Twitter @mapzen if you encounter any funk and we'll help you get up and running.

See also: