IsSubsettingNeeded
内容
[
隐藏
]FontSavingArgs.IsSubsettingNeeded property
允许指定在导出为字体资源之前是否对当前字体进行子集化。
public bool IsSubsettingNeeded { get; set; }
评论
字体可以导出为完整的原始字体文件或子集化以仅包含文档中使用的字符 。子集化可以减少生成的字体资源大小。
默认情况下,Aspose.Words 通过将原始字体文件大小 与中指定的大小进行比较来决定是否执行子集化。FontResourcesSubsettingSizeThreshold
。 您可以通过设置IsSubsettingNeeded
财产。
例子
演示如何定义保存为 HTML 时导出字体的自定义逻辑。
public void SaveExportedFonts()
{
Document doc = new Document(MyDir + "Rendering.docx");
// 配置 SaveOptions 对象以将字体导出到单独的文件。
// 设置将以自定义方式处理字体保存的回调。
HtmlSaveOptions options = new HtmlSaveOptions
{
ExportFontResources = true,
FontSavingCallback = new HandleFontSaving()
};
// 回调将导出 .ttf 文件并将它们与输出文档一起保存。
doc.Save(ArtifactsDir + "HtmlSaveOptions.SaveExportedFonts.html", options);
foreach (string fontFilename in Array.FindAll(Directory.GetFiles(ArtifactsDir), s => s.EndsWith(".ttf")))
{
Console.WriteLine(fontFilename);
}
}
/// <summary>
/// 打印有关导出字体的信息并将其保存在与其输出 .html 相同的本地系统文件夹中。
/// </summary>
public class HandleFontSaving : IFontSavingCallback
{
void IFontSavingCallback.FontSaving(FontSavingArgs args)
{
Console.Write($"Font:\t{args.FontFamilyName}");
if (args.Bold) Console.Write(", bold");
if (args.Italic) Console.Write(", italic");
Console.WriteLine($"\nSource:\t{args.OriginalFileName}, {args.OriginalFileSize} bytes\n");
// 我们也可以从这里访问源文档。
Assert.True(args.Document.OriginalFileName.EndsWith("Rendering.docx"));
Assert.True(args.IsExportNeeded);
Assert.True(args.IsSubsettingNeeded);
// 有两种方法保存导出的字体。
// 1 - 将其保存到本地文件系统位置:
args.FontFileName = args.OriginalFileName.Split(Path.DirectorySeparatorChar).Last();
// 2 - 将其保存到流中:
args.FontStream =
new FileStream(ArtifactsDir + args.OriginalFileName.Split(Path.DirectorySeparatorChar).Last(), FileMode.Create);
Assert.False(args.KeepFontStreamOpen);
}
}
也可以看看
- class FontSavingArgs
- 命名空间 Aspose.Words.Saving
- 部件 Aspose.Words