Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tangrams/tron-style
Tron 2.0
https://github.com/tangrams/tron-style
Last synced: 3 months ago
JSON representation
Tron 2.0
- Host: GitHub
- URL: https://github.com/tangrams/tron-style
- Owner: tangrams
- License: mit
- Created: 2016-06-22T15:47:09.000Z (over 8 years ago)
- Default Branch: gh-pages
- Last Pushed: 2020-05-02T17:22:36.000Z (almost 5 years ago)
- Last Synced: 2024-08-07T23:41:42.248Z (7 months ago)
- Language: HTML
- Homepage: https://tangrams.github.io/tron-style
- Size: 10.7 MB
- Stars: 62
- Watchers: 8
- Forks: 14
- Open Issues: 24
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
## TRON 2.0
Welcome to TRON 2.0 by [Geraldine Sarmiento](https://twitter.com/sensescape) and [Patricio Gonzalez Vivo](https://twitter.com/patriciogv). Rebuilt from the ground up to take advantage of the latest features of [Tangram (JS and ES)](https://mapzen.com/products/tangram/) graphics engine and conventions.
TRON is an exploration of scale transformations in the visual language of TRON with the use of Tangram [blocks](http://tangrams.github.io/blocks/). On this new version, visual forms and elements transform per zoom, revealing new cartographic details and a new experience of scale.
Beside the design challenges we want to make the source more approachable by dividing the scene file in multiple smaller pieces. So instead of having a single monolitical `.yaml` scene file you will find smaller modules that focus on a particular aspect of the map scene.
## How it works?
The main elements are:
- [`tron-style.yaml`](tron-style.yaml): is the main `.yaml` file that mix and hold all together. There you will find the definition of the `sources`, `cameras` and `scene:background:color`, together with the imports that glow and conects the `layers`, `styles` and `components` resources.
- [`layers/` folder](layers/): [layers on Tangram](https://mapzen.com/documentation/tangram/Filters-Overview/) are the set of rules that filter the data (comming from the `sources`) into different **style rules**. Tell how each component on the map should be treat. If it's `text`, `points`, `lines` or `polygons`. What's the default `size` and `color`, etc. In this folder you will find different `.yaml` scene files that carefully make sense of the data and display it in a cartographical intuitive way. This meticulus work was made by [Geraldine Sarmiento](https://twitter.com/sensescape) and [Nathaniel V. KELSO](https://twitter.com/kelsosCorner). At the end of each one of this layer-files you will find also a `styles` secction where the **custom shaders** are defined and crafted by [me (Patricio Gonzalez Vivo).](https://twitter.com/patriciogv) Shaders are not a simple thing, but at [Mapzen](https://mapzen.com) we are trying to make them more aproachable. Tangram `styles` can be mix, so for this map style we try to use that property to reduce the complexity and size of the shader by reusing them as much as possible.
- [`styles/` folder](styles): contain all the `styles` that are shared across layers. Is defenetly a more **abstract** layer. This folder sorts the `styles` by their `base` geoemtry (`points`, `lines` or `polygons`). Also for those `styles` common to all the other geometries can be found in `common.yaml`. You will note that most [shader styles](https://mapzen.com/documentation/tangram/Shaders-Overview/) "extends" from [blocks](http://tangrams.github.io/blocks/). As part of the efford on making GLSL Shaders more aproachable in Tangram. I had start a tool box library of shaders snippets that can be mix together, call [Tangram Blocks](http://tangrams.github.io/blocks/).
- [`components/` folder](components): This folders holds some of the global resources use in the scene, like [`fonts`](components/fonts.yaml) and [`images/`](components/images). Also there you can find the [`globals.yaml`](components/globals.yaml). This particular file is very interesting because holds `globals` variables and JS functions that control the map. From it is possible to customize the map, like **turning on or off the animations** or **changing the language**.
## Bundling
Having the scene file distributed accross different smaller modules creates more network calls. To solve this you will find in this repository a `bundle.py` script that construct a ZIP file (`tron.zip`) that will hold all the files needed.
To use it you will:
- first to clone locally the repository:
```bash
git clone https://github.com/tangrams/tron-style.git
cd tron
```- Load the [Tangram Blocks](http://tangrams.github.io/blocks/) submodule:
```bash
git submodule update --init --recursive
```- Install some Python modules:
```bash
pip install pyyaml
```- Then finally run the script
```bash
python <(curl -s https://raw.githubusercontent.com/tangrams/bundler/master/bundler.py)
```## Edit
One of the nice things of running a local instance of a [Tangram](https://mapzen.com/products/tangram/) scene is the hability to modify it and learn from it! We defenetly encourage to do it. You can host the style by doing:
```bash
python -m SimpleHTTPServer 8000
```Althought we also have been working on a way to edit [Tangram](https://mapzen.com/products/tangram/) scene files and see it change inmediatly. The project is call [TangramPlay](https://mapzen.com/tangram/play/) and can be found [here](https://mapzen.com/tangram/play/).
A quick way to start playing with Tron2.0 is by importing the scene file and inmediatly start editing on top of the scene file. For that:
1. [Click here to open Tron in TangramPlay](https://mapzen.com/tangram/play/?scene=https%3A%2F%2Fgist.githubusercontent.com%2Fanonymous%2F14f1c7495dde62cf831427dc9be89ec9%2Fraw%2F0b25fc8a0e90115090c90928d0fefa4423106b9b%2Fscene.yaml#8/40.574/-74.051)
2. Once you finish you can download it or copy it back to your local file, but **remember** to take out the first line `import`.
## About the process
Here are some resource we share and sketch [Geraldine Sarmiento](https://twitter.com/sensescape) and [I](https://twitter.com/patriciogv) during the development of TRON2.0. We hope you enjoy it.
- [Inspiration Pintboard](https://www.pinterest.com/patriciogonzv/tron-20/)
[data:image/s3,"s3://crabby-images/4939e/4939e738cdc2cffd6d7d31e591688c0ddf38dc72" alt="" Generative Tron Palette](http://player.thebookofshaders.com/?log=160726003844)
[data:image/s3,"s3://crabby-images/d6ec8/d6ec804ef633bb8d6cefc2d78e788d04637277ff" alt="" Glow lines ](http://player.thebookofshaders.com/?log=160726010850)
[data:image/s3,"s3://crabby-images/f1a7e/f1a7e1470e7c1b663b0a31576d0057b1e7e58547" alt="" Highways](http://player.thebookofshaders.com/?log=161011181616)
[data:image/s3,"s3://crabby-images/80e95/80e954892f332fddf3f77652037158cf59b375c4" alt="" Grid animation](http://player.thebookofshaders.com/?log=160706191515)
[data:image/s3,"s3://crabby-images/ae210/ae2101470ac481163a0b382ebf37f0e789468d9e" alt="" Grid animation](http://player.thebookofshaders.com/?log=160705205611)
[data:image/s3,"s3://crabby-images/91218/91218a90eb02ed623a88e4a48e7bcd6e12393110" alt="" Stripes](http://player.thebookofshaders.com/?log=160229221706)
[data:image/s3,"s3://crabby-images/a7971/a7971d203d05746eaadbc09598b9c4a52aa177bf" alt="" Stripes animation](http://player.thebookofshaders.com/?log=160705204919)
[data:image/s3,"s3://crabby-images/a2960/a2960fd2a156ebf02451208203d25645537a5da4" alt="" Simplex Grid animation](http://player.thebookofshaders.com/?log=160313020334)
[data:image/s3,"s3://crabby-images/d8ec5/d8ec5bbf029bf34e11f468086e071d6c27f5fd8c" alt="" Dots pattern](http://player.thebookofshaders.com/?log=160621211003)
[data:image/s3,"s3://crabby-images/9865c/9865c860da669ed91a6133581ab37d0a302e380a" alt="" Mosaic-dots transition](http://player.thebookofshaders.com/?log=160622150357)
[data:image/s3,"s3://crabby-images/ad597/ad59736abfa76260b623fc5f3d188ae79e0d5715" alt="" Stripes](http://player.thebookofshaders.com/?log=160621210032)
[data:image/s3,"s3://crabby-images/eb500/eb500f24b4534654638eb6e1ee737aa701c41b32" alt="" Stripes-char transition](http://player.thebookofshaders.com/?log=160621170831)
[data:image/s3,"s3://crabby-images/f3755/f37553d639a72ebed9d43c7f9fa0cc3be65e82e7" alt="" Contours](http://player.thebookofshaders.com/?log=160626213924)
[data:image/s3,"s3://crabby-images/d98af/d98af622ca33267c53aa0c327e0720eefa4c70df" alt="" Hill Shading](http://player.thebookofshaders.com/?log=160705083231)
[data:image/s3,"s3://crabby-images/d1f9f/d1f9f8f296e14ef72d00583dae62ddb0a2ee84ff" alt="" Buildings window](http://player.thebookofshaders.com/?log=160707203604)
[data:image/s3,"s3://crabby-images/645fa/645fa75a45736039c32f24c745b36a92d5d9f0ba" alt="" Generative Icons](http://player.thebookofshaders.com/?log=160805190306)
[data:image/s3,"s3://crabby-images/84b29/84b2926711964ea585b305c943c1032580ddb33a" alt="" Animated Icons](http://player.thebookofshaders.com/?log=160805194757)
[data:image/s3,"s3://crabby-images/3c3aa/3c3aa180e6800e11385f30c93a4efae49ac9c242" alt="" Animating Icons w POIs SDF's](http://player.thebookofshaders.com/?log=160818140257)
[data:image/s3,"s3://crabby-images/dcbd3/dcbd3c8b3a2351daf7ba4a4b659b906457bc3188" alt="" Animating Icons w POIs SDF's](http://player.thebookofshaders.com/?log=160817211857)