Skip to content

Latest commit

 

History

History
41 lines (26 loc) · 2.7 KB

README.md

File metadata and controls

41 lines (26 loc) · 2.7 KB

elm-map

Spare yourself from dropping in a large blob of JS whenever you want to add a map viewer to your site!

This package has no JS dependencies meaning you don't need to mess with ports or web components to make it work.1

Here's an example of it in action.

Viewing examples

To view the example maps run the following commands in your terminal

cd examples
elm reactor

and then open localhost:8000 in your browser and select the module you want to view

Caveats

This map viewer doesn't have many of the features and styling options other map viewers like Mapbox offer. While some features don't exist simply because I haven't had time to add them, I suspect everyone will have their own specific use cases that will be difficult for this package to completely satisfy without making it difficult to use and a lot slower.

For that reason, I recommend cloning this package and changing it to suit your needs2! If you add cool features consider making a PR. Some of it might still be general purpose enough to for other people to use.

Also, people I've shown the map viewer to (around half) report that it's laggy on their device. No one has said it's unusably laggy but it's still not ideal. Performance improvements are ongoing but I recommend trying out the example viewer and deciding for yourself if the performance is good enough for your use case.

Generating a custom font

If you want to use a font other than dinProMedium then do the following steps:

  1. Download and run http://www.angelcode.com/products/bmfont/ (windows only, sorry)
  2. Options -> Load Configuration and select the bm-font-config.bmfc file found in this repo
  3. Options -> Font settings and pick the font you want to use from the dropdown
  4. Options -> Save bitmap font as...
  5. Update your Elm code to this MapViewer.initMapData { fntPath = <path to fnt file> , imagePath = <path to png file> }

Special thanks

Thanks to realia.se for letting me implement this during work hours!

Footnotes

  1. This package does depend on Mapbox servers to provide vector tiles. You'll need to create an account with them and generate an API key.

  2. Contact me on Elm slack (martin.stewart) or email me at [email protected] if you like to hire me to implement a specific feature.