在 .NET 中配置回退字体集合

应用回退规则

FontFallBackRule 类的实例可以组织到FontFallBackRulesCollection中,该集合实现IFontFallBackRulesCollection接口。可以向集合中添加或删除规则。

然后可以将此集合分配给FontsManager类的FontFallBackRulesCollection属性。FontsManager 控制整个演示文稿中的字体。进一步了解关于 FontsManager 和 FontsLoader

每个Presentation都有一个FontsManager属性,其中包含自己的 FontsManager 类实例。

以下示例演示如何创建回退字体规则集合并将其分配到特定演示文稿的 FontsManager:

using (Presentation presentation = new Presentation())
{
	IFontFallBackRulesCollection userRulesList = new FontFallBackRulesCollection();

	userRulesList.Add(new FontFallBackRule(0x0B80, 0x0BFF, "Vijaya"));
	userRulesList.Add(new FontFallBackRule(0x3040, 0x309F, "MS Mincho, MS Gothic"));

	presentation.FontsManager.FontFallBackRulesCollection = userRulesList;
}

在使用回退字体集合初始化 FontsManager 后,回退字体将在演示文稿渲染期间应用。

常见问题

我的回退规则会嵌入到 PPTX 文件中并在保存后在 PowerPoint 中可见吗?

不会。回退规则是运行时渲染设置;它们不会序列化到 PPTX 中,也不会出现在 PowerPoint 的用户界面中。

回退是否适用于 SmartArt、WordArt、图表和表格中的文本?

是的。这些对象中的所有文本都使用相同的字形替换机制。

Aspose 是否随库分发任何字体?

不会。您需要自行添加和使用字体,责任由您自行承担。

缺失字体的替换/替代与缺失字形的回退可以一起使用吗?

可以。它们是同一字体解析管道的独立阶段:首先引擎解析字体可用性(replacement/substitution),然后回退为可用字体中缺失的字形填补空缺。