This is the meme maker I've always wanted. There are a lot of them out there, but this one works entirely from a single HTML file, which you can download and keep your own copy of, if you like. It has no dependency on a server for anything but that. Everything is stored in your browser's local storage database.
The project is live at https://zapmeme.com
There's a list of bugs and features in TODO.md.
During development, the code lives in
index.html and some JS files, plus
elm.js, for the compiled Elm code. Once it works, I'll append all the JS and images inside of
index.html for shipping.
The code runs in
elm reactor, though not everything will work there.
git clone email@example.com:billstclair/zapmeme.git cd zapmeme elm reactor
Then aim your browser at http://localhost:8000/src/Main.elm
In order to size the text to the background image, we need to know the size of the uploaded background image. This relies on the
HtmlImageElement.naturalHeight properties, as documented at https://developer.mozilla.org/en-US/docs/Web/API/HTMLImageElement. They are accessed in Elm via CustomElement.ImageProperties.
I plan to use the ideas in Matti Paksula's From SVG to Canvas and Back to enable converting the meme to a PNG file for download.
Samuli Kaipiainen's code based on Paksula's paper is live at http://sampumon.github.io/SVG.toDataURL/butterfly_test.html, and is stored locally in
site/base64.js for IE). The NPM package that generated the initial version of
svg-to-data-url.js is at https://www.npmjs.com/package/svgtodatauri.
You can run the local copy by starting
elm reactor as documented above, and aiming your browser at http://localhost:8000/site/butterfly-test.html.
I plan to support all the fonts at https://fonts.google.com. You'll just have to name one of them, and it will be added to the
<head> and CSS automatically. Out of the box, I'm supporting the safe fonts listed at http://web.mit.edu/jmorzins/www/fonts.html with CSS at http://web.mit.edu/jmorzins/www/@/css/fonts.css
Copyright 2019, Bill St. Clair
Distributed under the MIT License. See LICENSE.