by Sanjay Bhangar & Yuvi Panda

The workshop will cover using the Leaflet mapping library to display a GeoJSON feed on a map. We will cover styling and filtering layers, handling events like mouse-over / click, and finally, editing layers and saving back to the server.

Aim of the workshop would be for people attending to go out with a clear idea of how to do read/write with mapping data on the web. We start with read (GeoJSON from server -> plain rendering + customization) and then move to write (adding markers/shapes, then serializing them as GeoJSON to get sent to the server for persistance)

On the back-end, we will cover the basics of setting up a GeoDjango project, defining one's models, and using the GeoDjango ORM to query spatial data, and then output data as GeoJSON. We will cover different geographic field types and basic geo concepts like projection, etc. but not go into too many back-end details. Also, while we will use GeoDjango as the back-end frame-work, attempts will be made to make the concepts as generalized as possible. Familiarity with basic MVC concepts and some experience of working with an ORM would be desirable, but not required.

We will spend the majority of time on building in-browser tools to display, style and edit GeoJSON data sent from the server. We will cover setting up Leaflet, various in-built controls, the general architecture / conventions used in the library, setting up various map layers, and working with the Leaflet draw plugin to draw and edit features on the map. We will cover adding interactivity to features, like click and mouse-over events, as well as having other controls on the web-page to change the style of objects. We will go through the basic work-flow of editing and drawing features, and serializing them to GeoJSON to send back to the server to save.

Requirements: Familiarity with Web Development (Javascript/jQuery, MVC) is necessary. Experience with Python/Django is useful, but not necessary

Date: Sunday, September 23, 2012
Time: 2:00 PM to 5:00 PM
Venue:  The Centre for Internet and Society, No. 194, Second 'C' Cross, Domlur,  2nd Stage, Bangalore.

About the speakers: Sanjay Bhangar is co-founder of CAMP ( http://camputer.org ), an artist / hacker-space in Mumbai and works part-time with Topomancy LLC on map-based projects. He has worked on http://pad.ma and a wide range of web-based initiatives.

Yuvi Panda is a 21 year old open source geek who chases shiny new things way too often. He wrote major parts of the Wikipedia Android/iOS app and POSM, a nice mobile editor for OSM. Amongst his hobbies is taunting people who still use OpenLayers. He's currently a student at KCG College of Technology.