I have a Silverlight application that I need to embed some less-than-common fonts in. It's simple enough for me to just copy over the TTF/OTF and compile that with my app. However, in many cases, only like 5-10 of the characters are actually used. In other cases, some font files are incredibly large (Arial Unicode MS Regular is 22.1 MB, as an example). Fast download times of my app is really important, so optimizing the fonts used is paramount.
So, what I was thinking is that I've seen in applications like Expression Blend where a <Glyph/>
is used to create a read-only font and you can also just choose embed only certain characters. In other circumstances, I've seen people use fonts that only contained certain characters as a sub-set of the full font (and not use a <Glyph/>
in Silverlight, but rather just use the sub-set .TTF as <FontFamily/>
.) That's kind of what I'm after, except I'm not using Expressions.
I'm not looking for sneaky workarounds, like exporting to an XPS file and grabbing the .odtff file.
Is there a programmatic way (.NET/GDI+) to create a sub-set of a font with only certain characters and compile it out to a .TTF/.OTF? Also, this would need to work for .TTC files as well.
Changing the accepted answer to this one as it is pure .NET with no external references. Uses .NET 4.0:
In WPF for fonts there are static and dynamic linking. It all can be defined in Blend. With static linking of fonts only needed characters are compiled and embedded in your assembly. With dynamic linking all font set is embedded. So try to set static linking for selected fonts and try if it works.
UPD
Try to add the following code into you
.csproj
file. Here we including Tahoma fonts. AutoFill property set to true says that we will embed in assembly only used characters of our controls. The set of chars in<Charachters/>
tag fill point to include these chars into assembly. All other tags set to false, because we don't need them.FontForge (http://fontforge.sourceforge.net/) is an open source font editor that allows for automated format conversions. It looks like it is Python only but it might be worth checking out.
The native API CreateFontPackage may be what you're looking for. You can pass a TTF and a list of characters to keep. If you pass
TTFCFP_SUBSET
forusSubsetFormat
, you'll then get back a working TTF with only those characters.Here's a thread with what appears to be code of a working example (in C, unfortunately).
I know it's an old question but I found very difficult to use the
CreateFontPackage
API from C# (as mentioned by @josh3736's answer) so I thought to share my code.I'm using the API with the glyphIndices, you can use it directly with the characters by removing the
TTFCFP_FLAGS_GLYPHLIST
flag.This is my code:
I used with code only with TTF files, for TTC (font collections) you have to change a few things but it should work nonetheless.