An Interactive Version of the ZIPScribble Map
For more than five years, the ZIPScribble Map and its related pages have been the most popular feature on my website. To freshen things up a bit, I am adding an interactive version that runs in your browser. I have also added a few more countries, for a new total of 38.
While I still like the simple aesthetics of the bare map with just the scribble on a white background the best, it's obviously an interesting question to see where a particularly interesting scribble feature is located on a map. It was also a hassle to find particular countries so far, especially if you wanted to find out which ones were even available on the site at all.
This new map was built using Polymaps, which is a very clever toolkit for building "slippy" maps, i.e., the kind of dynamic in-browser maps we're used to now from Google Maps and others. They're easy to navigate using the usual pan and zoom controls (buttons or mouse wheel/trackpad gestures), so they should feel no different than other maps you've used. They're different in that they make it easier to build data displays on top of them, though. They're also fairly platform-agnostic, so a number of different map tile providers can be plugged in easily.
New ZIPScribble Map Features
Because of that, the new ZIPScribble map has some nifty tricks up its sleeves. You can switch between countries on the page, but you can also link to a particular one by using a hash. That way, I can link to some of the new countries like Japan or Mexico, for example, and they're all going to the same page. What's more, I can link to a map location, so I can focus in on how the Mississippi divides ZIP code zones, for example, or look at the Russian Enclave Kaliningrad (located between Poland and Lithuania). The page also remembers the last country you've visited when you come back to it using a generic link, though a specific link will override that.
Since the background map can be a distraction, it is possible to turn it off. I have also included a way to turn on states again, which are interesting for some countries. For countries where there is no state or province information in the data, that checkbox is inactive. Coloring states is an issue I have not solved, and I have not found a good way of generating enough distinct colors so that neighboring states don't end up with the same ones in some cases. So right now, the colors are randomly generated, which results in surprisingly reasonable choices. If you don't like the colors, you can disable and re-enable the states to create a new set of colors.
Needless to say, this requires a modern browser. Any reasonably recent browser (including IE9) works. FireFox works, though it's quite a bit slower than the others I've tried. The big drawback of using Polymaps (and thus SVG) is that it's not very fast on iPad. I built a simple prototype of this using Canvas, which worked much better on iOS. Getting the map overlay and the interaction to work was a major issue, though. I'm not sure if Canvas layers are doable in Polymaps, but I might try those at some point in the future.
New Data
Some interesting issues I've faced again had to do with finding reasonable bounding boxes. I chose to ignore some parts of Spain and France, for example, so I could focus more clearly on the main part of the countries. I've also again ignored Alaska and Hawaii in finding the bounding box for the U.S. All of those zip codes are there on the map, though, you just have to zoom out and pan around a bit. Also, the state connector lines are always visible, so there are cues that there's more outside the screen.
One part of the data that I am leaving out on purpose is the eastern-most part of Russia, where it extends beyond 180° longitude. Including those points causes some issues with Polymaps where the map wraps around, and which creates some distracting lines. Once there is a solution to that, I will add those points back in. Somebody also added the North Pole to Canada as a point, which caused some interesting issues with calculating bounding boxes (since all the longitude lines converge there).
To create good bounding boxes, I used some of Gregor Aisch's ideas, though I only add 10% of padding in each direction. I think this works quite well for an interactive map.
I have also updated all the data, which has caused some of the maps to improve considerably (relative to their static versions). While I was playing with the data, I also added some countries you might have heard of, like India, Pakistan, Argentina, Brazil, Japan, Mexico, and a few others. The data quality is very uneven, and I've left out a few countries where I just didn't trust it to be sensible. I will keep updating the data though, and adding more countries when their data becomes available or improves.
Source Code Available
As a final note, the source code for all of this is available on github.
And here's the link again: The Interactive ZIPScribble Map
Posted by Robert Kosara on January 15, 2012.