A Udacity FEND Project (Neighborhood Map)
In the city of Bonn (the former german capital) you find a lot of trees. This app helps you to identify what kind of trees surround you in your neighborhood.
You can view it live here.
If you want to download or clone the repository you can either
- place the contents of the
dist
directory in a web server of your choice and open http://my.web.srv/dist/index.html in your browser - or build the project by starting
npm install
,bower install
and launch an internal web server withgulp serve
. See here for how to install npm and bower.
- Select your favoured district.
- At first the markers in the map are clustered so you can see where a lot of trees are growing. Zoom into the map to view the locations of single trees.
- The marker for single trees differ in color. The color changes with the age of the tree from light green (young) to dark green (old).
- At the head of the marker the age of the tree is displayed.
- Now filter the trees. You can filter by type, age or street name. After changing any of the three, list entries and markers are immediately updated.
- Select a list entry to locate the corresponding tree in the map and open a window with further Wikipedia information.
- Click any marker to display Wikipedia information about the tree.
- The app is built with the help of yeoman's generator-webapp and uses npm, bower and gulp.
- Bootstrap is used for styling.
- The JavaScript framework is provided by Knockout.
- LokiJS helps to filter and sort the tree data.
- Marker clustering is done by Google's MarkerClusterer.
- The first challenge was the size of the tree data JSON file which is around 27 MB big. This would take too much time when loaded by an AJAX request. So I wrote a python script to split the data: one JSON file per district. The districts polygons can be found here. I used shapely.geometry to determine which tree belongs to which district. Python's rtree module speeds up the process.
- Rendering the markers for more than 64,000 trees was the next problem because it slows down the browser. I decided to force the user to choose a district so that max. 4,500 markers have to be rendered. But even this amount of markers takes much time during the map generation. Thanks to Google's MarkerClusterer the markers can be clustered. With the smaller numbers of clusters the map will render fast.
- Inserting DOM elements for around 4,500 list elements is another ambitious task for a browser. To circumvent this I implemented a lazy list component (inspired by adrienne). This displays 20 entries at first. Only when scrolling to the last element the next 20 elements are displayed.
Unfortunately the source file for the trees contains no english names - only the latin/scientific and a german name for the tree type are provided. To keep this app as international as possible the latin names are used and the english Wikipedia entries will be displayed.
All trees the city of Bonn owns are provided by the open data portal Offene Daten:Bonn. The informations for a tree are retrieved from Wikipedia.