This is a template that tries to recreate the behaviour of how AnkiDroid displays cards. Use it to design beautiful cards for mobile.
-
Clone or download the repo and edit the HTML/CSS files using your favourite editor.
-
Once you finish, copy the HTML, CSS and scripts to Anki.
-
Replace tag content with Anki
{{fields}}
. -
That’s it! 🎉
Unfortunately, you can only preview cards correctly in Chrome/Chromium based browsers, as AnkiDroid uses Chrome Web View to display cards.
You can use placeholder images in this template. Place all of them on the same folder as the main HTML file.
However, in practice, all of the files should come from your collection.media directory, using the {{field}}
notation.
I also ask of you, that if you use this template to design your cards, to include the header in the CSS file in your final Anki styles deck.
I wanted to design good-looking cards for AnkiDroid but the debugging and previewing process was a mess. I had to sync every time I wanted to see how the cards looked and that process took ages.
Since Anki and AnkiDroid both use Chrome WebView to display cards, I decided to create an file structure similar to that of those to easily preview cards and modify as you would with any other HTML page.
In short, instead of designing cards inside Anki lousy Cards screen, you can design cards as if it were just another webpage and then copy your code to Anki.
Convenient mobile card designing advice included!
You can also use the debugging tools on Android to change the card CSS directly. However, it is a much more complicated and error prone process than just using the files.
-
Download the alpha release APK from here
-
Install and enable HTML/Javascript debugging in Advanced Preferences.
-
Enable Developer Options and USB Debugging in Android setings
-
Connect your device to your computer and activate debugging.
-
Using Chrome on the same computer open chrome://inspect and you should see your device name. Click on it and Inspect the WebView and you’ll get a full Chrome remote debugging console.
Spot a mistake? Have a something nice you want to implement?
Open an issue and let me know.
Feel free to fork the code and make a Pull Request!