TranslateProject/sources/tech/20200808 An attempt to make a font look more handwritten.md
DarkSun dd651f8eb6 选题[tech]: 20200808 An attempt to make a font look more handwritten
sources/tech/20200808 An attempt to make a font look more handwritten.md
2020-08-09 05:02:56 +08:00

6.8 KiB
Raw Blame History

An attempt to make a font look more handwritten

Im actually not super happy with the results of this experiment, but I wanted to share it anyway because it was very easy and fun to play with fonts. And somebody asked me how to do it and I told her Id write a blog post about it :)

background: the original handwritten font

Some background: I have a font of my handwriting that Ive been use in my zines for a couple of years. I made it using a delightful app called iFontMaker. They pitch themselves on their website as “You can create your handmade typeface in less than 5 minutes just with your fingers”. In my experience the 5 minutes” part is pretty accurate I might have spent more like 15 minutes. Im skeptical of the “just your fingers” claim I used an Apple Pencil, which has much better accuracy. But it is extremely easy to make a TTF font of your handwriting with the app and if you happen to already have an Apple Pencil and iPad I think its a fun way to spend $7.99.

Heres what my font looks like. The “CONNECT” text on the left is my actual handwriting, and the paragraph on the right is the font. There are actually 2 fonts theres a regular font and a handwritten “monospace” font. (which actually isnt monospace in practice, I havent figured out how to make a actual monospace font in iFontMaker)

the goal: have more character variation in the font

In the screenshot above, its pretty obvious that its a font and not actual handwriting. Its easiest to see this when you have two of the same letter next to each other, like in “HTTP.

So I thought it might be fun to use some OpenType features to somehow introduce a little more variation into this font, like maybe the two Ts could be different. I didnt know how to do this though!

idea from Tristan Hume: use OpenType!

Then I was at !!Con 2020 in May (all the talk recordings are here!) and saw this talk by Tristan Hume about using OpenType to place commas in big numbers by using a special font. His talk and blog post are both great so here are a bunch of links the live demo is maybe the fastest way to see his results.

the main idea: OpenType lets you replace characters based on context

I started out being extremely confused about what OpenType even is. I still dont know much, but I learned that you can write extremely simple OpenType rules to change how a font looks, and you dont even have to really understand anything about fonts.

Heres an example rule:

sub a' b by other_a;

What sub a' b by other_a; means is: If an a glyph is before a b, then replace the a with the glyph other_a.

So this means I can make ab appear different from ac in the font. Its not random the way handwriting is, but it does introduce a little bit of variation.

OpenType reference documentation: awesome

The best documentation I found for OpenType was this OpenType™ Feature File Specification reference. There are a lot of examples of cool things you can do in there, like replace “ffi” with a ligature.

how to apply these rules: fonttools

Adding new OpenType rules to a font is extremely easy. Theres a Python library called fonttools, and these 5 lines of code will apply a list of OpenType rules (in rules.fea) to the font file input.ttf.

from fontTools.ttLib import TTFont
from fontTools.feaLib.builder import addOpenTypeFeatures

ft_font = TTFont('input.ttf')
addOpenTypeFeatures(ft_font, 'rules.fea', tables=['GSUB'])
ft_font.save('output.ttf')

fontTools also provides a couple of command line tools called ttx and fonttools. ttx converts a TTF font into an XML file, which was useful to me because I wanted to rename some glyphs in my font but did not understand anything about fonts. So I just converted my font into an XML file, used sed to rename the glyphs, and then used ttx again to convert the XML file back into a ttf.

fonttools merge let me merge my 3 handwriting fonts into 1 so that I had all the glyphs I needed in 1 file.

the code

I put my extremely hacky code for doing this in a repository called font-mixer. Its like 33 lines of code and I think its pretty straightforward. (its all in run.sh and combine.py)

the results

Heres a small sample the old font and the new font. I dont think the new font “feels” that much more like handwriting theres a little more variation, but it still doesnt compare to actual handwritten text (at the bottom).

It feels a little uncanny valley to me, like its obviously still a font but its pretending to be something else.

And heres a sample of the same text actually written by hand:

Its possible that the results would be better if I was more careful about how I made the 2 other handwriting fonts I mixed the original font with.

its cool that its so easy to add opentype rules!

Mostly what was delightful to me here is that its so easy to add OpenType rules to change how fonts work, like you can pretty easily make a font where the word “the” is always replaced with “teh” (typos all the time!).

I still dont know how to make a more realistic handwriting font though :). Im still using the old one (without the extra variations) and Im pretty happy with it.


via: https://jvns.ca/blog/2020/08/08/handwritten-font/

作者:Julia Evans 选题:lujun9972 译者:译者ID 校对:校对者ID

本文由 LCTT 原创编译,Linux中国 荣誉推出