跟踪文档转换进度

可能的使用场景

有时转换大型 Excel 文件可能需要一些时间。在此期间,您可能希望显示文档转换进度而不仅仅是加载屏幕,以增强应用程序的可用性。 Aspose.Cells 通过提供支持跟踪文档转换过程**IPageSavingCallback**界面。这**IPageSavingCallback**接口提供**PageStartSaving**和**PageEndSaving**您可以在自定义类中实现的方法。您还可以控制呈现哪些页面,如*测试页面保存回调*自定义类。

跟踪文档转换进度

以下代码示例加载源文件并使用测试页面保存回调实现的自定义类**IPageSavingCallback**界面。

示例代码

// For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-Java
// The path to the source directory.
String sourceDir = Utils.Get_SourceDirectory();
// The path to the output directory.
String outputDir = Utils.Get_OutputDirectory();
Workbook wb = new Workbook(sourceDir + "PagesBook1.xlsx");
PdfSaveOptions pdfSaveOptions = new PdfSaveOptions();
pdfSaveOptions.setPageSavingCallback(new TestPageSavingCallback());
wb.save(outputDir + "DocumentConversionProgress.pdf", pdfSaveOptions);

以下是代码测试页面保存回调自定义类。

// For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-Java
class TestPageSavingCallback implements IPageSavingCallback {
public void pageStartSaving(PageStartSavingArgs args)
{
System.out.println("Start saving page index " + args.getPageIndex() + " of pages " + args.getPageCount());
//don't output pages before page index 2.
if (args.getPageIndex() < 2)
{
args.setToOutput(false);
}
}
public void pageEndSaving(PageEndSavingArgs args)
{
System.out.println("End saving page index " + args.getPageIndex() + " of pages " + args.getPageCount());
//don't output pages after page index 8.
if (args.getPageIndex() >= 8)
{
args.setHasMorePages(false);
}
}
}

控制台输出

开始保存第 11 页的第 0 页索引
结束保存第 11 页的第 0 页索引
开始保存第 11 页的第 1 页索引
结束保存页面索引 1,共 11 页
开始保存第 11 页的第 2 页索引
结束保存第 11 页的第 2 页索引
开始保存第 11 页的第 3 页索引
结束保存第 11 页的第 3 页索引
开始保存第 11 页的第 4 页索引
结束保存页面索引 4,共 11 页
开始保存第 11 页的第 5 页索引
结束保存页面索引 5 of pages 11
开始保存第 11 页的第 6 页索引
结束保存页面索引 6 of pages 11
开始保存第 11 页的第 7 页索引
结束保存页面索引 7 of pages 11
开始保存第 11 页的第 8 页索引
结束保存页面索引 8,共 11 页