获取字体支持的字符 – 在C#中

我有第三方字体,支持日语字符,我需要用于应用程序。 每当该字体不支持某个字符时,就会绘制常见的矩形(“默认字符”)。 显然不是所有日文字符都受支持,因为如果我试图绘制翻译办公室给我们的翻译,那么就会有很多矩形。

每当使用不支持的字符时,我都需要得到通知,这样我就可以更改这个单个字符的字体(比如Word做的那样)或者对它实现一些其他的反应。

有任何想法吗? 如果我可以从TTF文件中提取unicode字符列表,那么我将能够检查此列表是否包含已使用的字符。 但我怎么能这样做?

基于这个答案 。

一定要参考PresentationCore.dll

尝试使用此代码:

using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Windows.Media; namespace fontChecker { class Program { static void Main(string[] args) { var families = Fonts.GetFontFamilies(@"C:\WINDOWS\Fonts\Arial.TTF"); foreach (FontFamily family in families) { var typefaces = family.GetTypefaces(); foreach (Typeface typeface in typefaces) { GlyphTypeface glyph; typeface.TryGetGlyphTypeface(out glyph); IDictionary characterMap = glyph.CharacterToGlyphMap; foreach (KeyValuePair kvp in characterMap) { Console.WriteLine(String.Format("{0}:{1}", kvp.Key, kvp.Value)); } } } } } } 

由于ImageShack用广告替换旧的,已删除的图像,因此删除了输出图像。

你不能只在字符映射中提取它并记下未定义的字符范围吗?

可能有一种编程方式来解析TTF文件以获取此信息,但如果它只是一种特定的字体,则可能更容易打开字符映射,将Group by设置为Unicode Subrange并按“Japanese Hiragana / Katakana”分组,只需注意定义的范围。