Kanji Book
data:image/s3,"s3://crabby-images/02082/02082ee0e1bc4f634a6559312923206d2212ccb7" alt="Main page of Kanji Book"
I’ve been learning Japanese ever since my first trip to Japan in early 2018. As anyone who has studies Japanese knows, it’s a little more complicated than just a new alphabet with new sounds that make up a new vocabulary to learn. One of the biggest complications in learning Japanese is learning kanji. There are over ten thousand kanji in use, but there’s a set of 2136 that are in more regular use. I figured a good way to get exposed to a lot of kanji would be making a game. I couldn’t crack a mechanic that was both deep and wide enough to cover learning kanji (though I still think it’s out there!), so I settled on a more traditional flashcard-style app. As you learn kanji, the English text in the UI slowly changes to kanji.
data:image/s3,"s3://crabby-images/1fc4a/1fc4aa2d5c34da77629ebd7897c7608947506699" alt="Completed Kanji Book"
Building Kanji Book presented a few new challenges for me. First, finding good data sets. Luckily there are a few really good ones online. After doing a lot of processing to remix and swizzle the data, I had enough JSON and SVG to render kanji stroke-by-stroke, display all its readings, and its definition. With the stroke-by-stroke rendering, I added a drawing mode that let you practice and check your progress after each stroke.
data:image/s3,"s3://crabby-images/a76e0/a76e006d7c31bf5449ef1eeae2e27917a659e59f" alt="Drawing a kanji"
Rendering SVG was new to me. I used a nice bezier spline package for Unity and wrote a SVG parser and then a renderer powered by the spline package. I ended up making editor tools to blit the SVGs to PNGs so I had more options in drawing them. I had a fun moment where I found a bug visually because my SVG parser was missing an instruction. Luckily I had enough exposure at this point to recognize if a kanji ’looked wrong’ and this one did. I found the offending SVG instruction and fixed it and it ’looked correct’ in the diff.
data:image/s3,"s3://crabby-images/925d6/925d688f49784a81908ea5ce4a06fa432e96aba1" alt="SVG renderer"
The entry point to the Settings page is a はんこ (name stamp) with the name 鞠琴 .
data:image/s3,"s3://crabby-images/334df/334dffbd65fa1cac92f37afade9dbf7441329ffe" alt="Hanko with 鞠琴"
My stress test for the SVG renderer, a 20+ stroke kanji.
data:image/s3,"s3://crabby-images/7525a/7525a3c9e9c3e251a65e8a465f185fded61fbccc" alt="A very complicated kanji"
With Kanji Book being mostly data-driven after I normalized all the data, I was able to pretty easily drop in hiragana and katakana datasets to make a simpler Kana Book. This app isn’t strictly necessary, learning both kana sets doesn’t take too long, but it was a fun exercise for me.
data:image/s3,"s3://crabby-images/77433/77433e5da921688f57baef7236814828662316bf" alt="Kana Book"