在 .NET 中配置演示文稿的字体替代
获取字体替代
为了让您了解在演示文稿渲染过程中被替代的演示字体,Aspose.Slides 提供了来自IFontsManager接口的GetSubstitution方法。
The C# code shows you how to get all the font substitutions that are performed when a presentation is rendered:
using (Presentation pres = new Presentation(@"Presentation.pptx"))
{
foreach (var fontSubstitution in pres.FontsManager.GetSubstitutions())
{
Console.WriteLine("{0} -> {1}", fontSubstitution.OriginalFontName, fontSubstitution.SubstitutedFontName);
}
}
设置字体替代规则
Aspose.Slides 允许您以以下方式为字体设置规则,以确定在特定条件下(例如无法访问字体时)应采取的操作:
- 加载相关演示文稿。
- 加载将被替换的字体。
- 加载新字体。
- 为替换添加规则。
- 将规则添加到演示文稿的字体替换规则集合中。
- 生成幻灯片图像以观察效果。
This C# code demonstrates the font substitution process:
// 加载演示文稿
Presentation presentation = new Presentation("Fonts.pptx");
// 加载将被替换的源字体
IFontData sourceFont = new FontData("SomeRareFont");
// 加载新字体
IFontData destFont = new FontData("Arial");
// 添加字体替换规则
IFontSubstRule fontSubstRule = new FontSubstRule(sourceFont, destFont, FontSubstCondition.WhenInaccessible);
// 将规则添加到字体替换规则集合
IFontSubstRuleCollection fontSubstRuleCollection = new FontSubstRuleCollection();
fontSubstRuleCollection.Add(fontSubstRule);
// 将字体规则集合添加到规则列表
presentation.FontsManager.FontSubstRuleList = fontSubstRuleCollection;
using (IImage image = presentation.Slides[0].GetImage(1f, 1f))
{
// 以 JPEG 格式将图像保存到磁盘
image.Save("Thumbnail_out.jpg", ImageFormat.Jpeg);
}
NOTE
您可能想查看字体替换。FAQ
字体替换和字体替代有什么区别?
替换 是在整个演示文稿中强制用另一种字体覆盖原有字体。字体替代是一种在特定条件下触发的规则,例如原始字体不可用时,会使用指定的后备字体。
替代规则到底何时生效?
这些规则参与在加载、渲染和转换期间评估的标准字体选择序列;如果选定的字体不可用,则会应用替换或替代。
如果既未配置替换也未配置替代,而系统缺少该字体,默认行为是什么?
库会尝试选择最接近的可用系统字体,类似于 PowerPoint 的行为。
我可以在运行时附加自定义外部字体以避免替代吗?
可以。您可以在运行时添加外部字体,库会将其纳入选择和渲染过程,包括后续的转换。
Aspose 是否随库分发任何字体?
不。Aspose 不分发付费或免费字体;您需要自行添加并使用字体,需自行承担相应责任。
在 Windows、Linux 和 macOS 上的替代行为是否存在差异?
是的。字体发现从操作系统的字体目录开始。默认可用字体集合和搜索路径因平台而异,进而影响可用性和是否需要替代。
应如何准备环境以最小化批量转换期间的意外替代?
在机器或容器之间同步字体集合,添加外部字体以满足输出文档的需求,并在可能的情况下在演示文稿中嵌入字体,这样在渲染时所选字体即可用。