One reason why I'm building Placemark is that it's still too hard to create maps. I think that's true, but I also enjoy precision, and I know that statement is all too vague.
Most of the vagueness is caused by that phrase "create maps." Off the top of my head, making a map might mean:
- Opening Google Earth or Google My Maps and dropping a few points with descriptions onto a map, and sharing that.
- Building a full-fledged web application that centers on an embedded map using Mapbox GL JS or the Google Maps API.
- Designing a new cartographic style for OpenStreetMap or using vector tiles or rendering with Mapnik.
- Processing raw raster data to produce mosaics, and then turning those mosaics into satellite maps.
- Working on a dataset by editing the data itself in OpenStreetMap, or creating a derived dataset by writing complex SQL queries to generate vector tiles.
Some of these tasks are completely orthogonal. You can spend all day creating an interactive web map experience without changing cartographic styles or creating geographic data.
You can edit OpenStreetMap all day long without touching a line of code or choosing a color.
There are major contributions to cartography that are things like highway stacking orders, which exist in a space between data, code, and style.
It's complicated because map creation is a system inside of a system. Some real-world inputs flow into it – national borders from the United Nations, images from a satellite, GPS coordinates – and outputs like websites and PDFs and images flow out of it. And in the middle is the complex map creation ecosystem.
Why is that ecosystem complex?
In part because of all of those different kinds of inputs and outputs: the world of maps is so varied and its data is so expansive that there are few one-size-fits-all technologies. Shapefiles were a popular format, but are painful to use with web applications, so you might want to use GeoJSON instead. If the data's too large for that, you've got OSM XML and databases like PostGIS. The world would be simpler if there was just one format, but it's not just the challenge of consensus causing the format diversity.
Data isn't visual
It's also complex because map data isn't visual: with the exception of the KML format, a geographical line or point doesn't have a color or width or any other set style properties. It's analogous to the difference between HTML and CSS - map styles define presentation semantics. But it's a stark difference to how things like graphics editors - which look, on the surface, quite similar, work.
A lot of map-makers are professionals
Before apps like SnapChat and TikTok swept through an entire generation, video editing was hard. If you were learning how to use Final Cut or Premier, chances were that you'd watch tutorials, take a class, or actually read the manual. Even iMovie is pretty complex. When these desktop applications reigned, a lot of the people making videos were working on capital-v Video projects, films or commercials or shorts, and they were willing to spend the time to sweat the details.
But now that everyone has a 4k video camera in their pocket and social capital to be won by publishing 30 second shorts, investment in easy, tailored video editing tools is rushing in. There's a market in the low to medium range of skill and commitment that there wasn't before.
A lot of the people editing maps today are still pros. They're working for your city planning department or National Geographic or some oil drilling concern. They are deeply about specific capabilities and outcomes and are willing - not happy, but willing - to put up with kludgy software to get there.
Placemark aims to reinvent part of the map-making process. It won't replace the whole ecosystem, or make mapmaking truly easy for everyone in that list. We're starting with data - creating, editing, collaborating on data. I think that part is still too hard, and the tools could be better. Data editing is an afterthought for companies whose main business is an API or something else. It's the centerpiece of Placemark, the place we'll expand out from.