在呈现Excel文件为PDF时,有时会进行字体替换。Aspose.Cells提供了一个功能,让开发人员知道特定字体已经被替换,从而发出警告。这是一个有用的功能,可以帮助您确定为什么Aspose.Cells呈现的PDF与实际Excel文件不同,并且您可以采取相应的措施。例如,您可以安装缺少的字体,以便呈现结果看起来一致。

以下截图显示了下面代码中使用的源Excel文件。 单元格A6和A7中有一些文本,其字体在Microsoft Excel中无法正确呈现。

todo:image_alt_text

Aspose.Cells将使用合适的字体替换单元格A6和A7中的字体,如下所示。

todo:image_alt_text

下载源文件和输出PDF

您可以从以下链接下载源Excel文件和输出PDF

以下代码实现IWarningCallback并设置实现接口的PdfSaveOptions.setWarningCallback()方法。现在,无论在任何单元格中是否替换字体,Aspose.Cells都会在WarningCallback.warning()方法内触发警告。

 public class WarningCallback implements IWarningCallback {

    @Override

    public void warning(WarningInfo info) {

        if(info.getWarningType() == WarningType.FONT_SUBSTITUTION)

        {

            System.out.println("WARNING INFO: " + info.getDescription());

        }

    }

}

//........

//........

static void Run() throws Exception

{

    Workbook workbook = new Workbook("source.xlsx");

    PdfSaveOptions options = new PdfSaveOptions();

    options.setWarningCallback(new WarningCallback());

    workbook.save("output.pdf", options);

}

警告输出

在转换源文件后,以下警告将输出到调试控制台:

WARNING INFO: Font substitution: Font [ Athene Logos; Regular ] has been substituted in Cell [ A6 ] in Sheet [ Sheet1 ].

WARNING INFO: Font substitution: Font [ B Traffic; Regular ] has been substituted in Cell [ A7 ] in Sheet [ Sheet1 ].