在 Java 中克隆演示文稿幻灯片
克隆演示文稿中的幻灯片
克隆是对某物进行完全复制或仿制的过程。Aspose.Slides for Java 还可以对任意幻灯片进行复制或克隆,然后将该克隆幻灯片插入当前或任何其他打开的演示文稿中。幻灯片克隆的过程会创建一个新幻灯片,开发人员可以对其进行修改而不改变原始幻灯片。克隆幻灯片有几种可能的方式:
- 在演示文稿中末尾克隆。
- 在演示文稿中其他位置克隆。
- 在另一演示文稿末尾克隆。
- 在另一演示文稿其他位置克隆。
- 在另一演示文稿的特定位置克隆。
在 Aspose.Slides for Java 中,由 Presentation 对象公开的(ISlide 对象集合)提供了 addClone 和 insertClone 方法,以执行上述类型的幻灯片克隆。
在演示文稿末尾克隆幻灯片
如果要克隆幻灯片并在同一演示文稿文件的现有幻灯片末尾使用它,请按照以下步骤使用 addClone 方法:
- 创建 Presentation 类的实例。
- 通过引用由 Presentation 对象公开的 Slides 集合,实例化 ISlideCollection 类。
- 调用由 ISlideCollection 对象公开的 addClone 方法,并将要克隆的幻灯片作为参数传递给该方法。
- 写入修改后的演示文稿文件。
在下面的示例中,我们将演示文稿中第一位置(索引为 0)的幻灯片克隆到演示文稿的末尾。
// 实例化表示演示文稿文件的 Presentation 类
Presentation pres = new Presentation("CloneWithinSamePresentationToEnd.pptx");
try {
// 将所需幻灯片克隆到同一演示文稿中幻灯片集合的末尾
ISlideCollection slds = pres.getSlides();
slds.addClone(pres.getSlides().get_Item(0));
// 将修改后的演示文稿写入磁盘
pres.save("Aspose_CloneWithinSamePresentationToEnd_out.pptx", SaveFormat.Pptx);
} finally {
pres.dispose();
}
在演示文稿中其他位置克隆幻灯片
如果要克隆幻灯片并在同一演示文稿文件的不同位置使用它,请使用 insertClone 方法:
- 创建 Presentation 类的实例。
- 通过引用由 Presentation 对象公开的 Slides 集合,实例化相应的类。
- 调用由 ISlideCollection 对象公开的 insertClone 方法,并将要克隆的幻灯片以及新位置的索引作为参数传递给该方法。
- 将修改后的演示文稿写入为 PPTX 文件。
在下面的示例中,我们将演示文稿中索引为 0(位置 1)的幻灯片克隆到索引 1(位置 2)。
// 实例化表示演示文稿文件的 Presentation 类
Presentation pres = new Presentation("CloneWithInSamePresentation.pptx");
try {
// 将所需幻灯片克隆到同一演示文稿中幻灯片集合的末尾
ISlideCollection slds = pres.getSlides();
// 将所需幻灯片克隆到同一演示文稿的指定索引位置
slds.insertClone(2, pres.getSlides().get_Item(1));
// 将修改后的演示文稿写入磁盘
pres.save("Aspose_CloneWithInSamePresentation_out.pptx", SaveFormat.Pptx);
} finally {
pres.dispose();
}
在另一演示文稿末尾克隆幻灯片
如果需要从一个演示文稿克隆幻灯片并将其放入另一个演示文稿文件的现有幻灯片末尾:
- 创建包含要克隆幻灯片来源的 Presentation 类实例。
- 创建包含目标演示文稿的 Presentation 类实例。
- 通过引用目标演示文稿的 Presentation 对象公开的 Slides 集合,实例化 ISlideCollection 类。
- 调用由 ISlideCollection 对象公开的 addClone 方法,并将来源演示文稿中的幻灯片作为参数传递给该方法。
- 写入修改后的目标演示文稿文件。
在下面的示例中,我们将来源演示文稿的第一索引幻灯片克隆到目标演示文稿的末尾。
// 实例化 Presentation 类以加载源演示文稿文件
Presentation srcPres = new Presentation("CloneAtEndOfAnother.pptx");
try {
// 实例化用于目标 PPTX 的 Presentation 类(要克隆幻灯片的地方)
Presentation destPres = new Presentation();
try {
// 将所需幻灯片从源演示文稿克隆到目标演示文稿幻灯片集合的末尾
ISlideCollection slds = destPres.getSlides();
slds.addClone(srcPres.getSlides().get_Item(0));
// 将目标演示文稿写入磁盘
destPres.save("Aspose2_out.pptx", SaveFormat.Pptx);
} finally {
destPres.dispose();
}
} finally {
srcPres.dispose();
}
在另一演示文稿中其他位置克隆幻灯片
如果需要从一个演示文稿克隆幻灯片并在另一个演示文稿文件的特定位置使用它:
- 创建包含来源演示文稿的 Presentation 类实例。
- 创建包含目标演示文稿的 Presentation 类实例。
- 通过引用目标演示文稿的 Presentation 对象公开的 Slides 集合,实例化 ISlideCollection 类。
- 调用由 ISlideCollection 对象公开的 insertClone 方法,并将来源演示文稿的幻灯片以及所需位置作为参数传递给该方法。
- 写入修改后的目标演示文稿文件。
在下面的示例中,我们将来源演示文稿索引为 0 的幻灯片克隆到目标演示文稿索引为 1(位置 2)。
// 实例化 Presentation 类以加载源演示文稿文件
Presentation srcPres = new Presentation("CloneAtEndOfAnother.pptx");
try {
// 实例化用于目标 PPTX 的 Presentation 类(要克隆幻灯片的地方)
Presentation destPres = new Presentation();
try {
// 将所需幻灯片从源演示文稿克隆到目标演示文稿幻灯片集合的末尾
ISlideCollection slds = destPres.getSlides();
slds.insertClone(2, srcPres.getSlides().get_Item(0));
// 将目标演示文稿写入磁盘
destPres.save("Aspose2_out.pptx", SaveFormat.Pptx);
} finally {
destPres.dispose();
}
} finally {
srcPres.dispose();
}
在另一演示文稿的特定位置克隆带母版的幻灯片
如果需要克隆带有母版的幻灯片并在另一个演示文稿中使用,首先必须先将所需的母版从来源演示文稿克隆到目标演示文稿,然后使用该母版克隆幻灯片。方法 addClone(ISlide, IMasterSlide, boolean) 需要目标演示文稿的母版,而不是来源演示文稿的母版。请按以下步骤克隆带母版的幻灯片:
- 创建包含来源演示文稿的 Presentation 类实例。
- 创建包含目标演示文稿的 Presentation 类实例。
- 访问要克隆的幻灯片及其母版。
- 通过引用目标演示文稿的 Presentation 对象公开的 Masters 集合,实例化 IMasterSlideCollection 类。
- 调用由 IMasterSlideCollection 对象公开的 addClone 方法,并将来源 PPTX 中的母版作为参数传递给该方法。
- 通过设置对目标演示文稿的 Presentation 对象公开的 Slides 集合的引用,实例化 ISlideCollection 类。
- 调用由 ISlideCollection 对象公开的 addClone 方法,并将来源演示文稿的幻灯片和已克隆的母版一起作为参数传递给该方法。
- 写入修改后的目标演示文稿文件。
在下面的示例中,我们使用来源幻灯片的母版,将来源演示文稿中索引为 0 的带母版幻灯片克隆到目标演示文稿的末尾。
// 实例化 Presentation 类以加载源演示文稿文件
Presentation srcPres = new Presentation("CloneToAnotherPresentationWithMaster.pptx");
try {
// 实例化用于目标演示文稿的 Presentation 类(要克隆幻灯片的地方)
Presentation destPres = new Presentation();
try {
// 从源演示文稿的幻灯片集合中实例化 ISlide,连同
// 母版幻灯片
ISlide SourceSlide = srcPres.getSlides().get_Item(0);
IMasterSlide SourceMaster = SourceSlide.getLayoutSlide().getMasterSlide();
// 将所需的母版幻灯片从源演示文稿克隆到母版集合中,位于
// 目标演示文稿
IMasterSlideCollection masters = destPres.getMasters();
IMasterSlide DestMaster = SourceSlide.getLayoutSlide().getMasterSlide();
// 将所需的母版幻灯片从源演示文稿克隆到母版集合中,位于
// 目标演示文稿
IMasterSlide iSlide = masters.addClone(SourceMaster);
// 将所需的幻灯片从源演示文稿连同所需的母版克隆到
// 目标演示文稿的幻灯片集合的末尾
ISlideCollection slds = destPres.getSlides();
slds.addClone(SourceSlide, iSlide, true);
// 将目标演示文稿保存到磁盘
destPres.save("CloneToAnotherPresentationWithMaster_out.pptx", SaveFormat.Pptx);
} finally {
destPres.dispose();
}
} finally {
srcPres.dispose();
}
在指定章节的末尾克隆幻灯片
如果要克隆幻灯片并在同一演示文稿文件的不同章节使用它,请使用由 ISlideCollection 接口公开的 addClone 方法。Aspose.Slides for Java 允许从第一章节克隆幻灯片,然后将该克隆幻灯片插入同一演示文稿的第二章节。
下面的代码片段演示了如何克隆幻灯片并将克隆的幻灯片插入指定章节。
IPresentation presentation = new Presentation();
try {
presentation.getSlides().get_Item(0).getShapes().addAutoShape(ShapeType.Rectangle, 200, 50, 300, 100);
presentation.getSections().addSection("Section 1", presentation.getSlides().get_Item(0));
ISection section2 = presentation.getSections().appendEmptySection("Section 2");
presentation.getSlides().addClone(presentation.getSlides().get_Item(0), section2);
// 将演示文稿保存到磁盘
presentation.save(dataDir + "CloneSlideIntoSpecifiedSection.pptx", SaveFormat.Pptx);
} finally {
if (presentation != null) presentation.dispose();
}
常见问题
演讲者备注和审阅者评论会被克隆吗?
会。备注页和审阅评论会包含在克隆中。如果不需要它们,请在插入后 移除它们。
图表及其数据源如何处理?
图表对象、格式以及嵌入的数据都会被复制。如果图表链接到外部源(例如 OLE 嵌入的工作簿),该链接会保留为 OLE 对象。在文件之间移动后,请验证数据可用性并检查刷新行为。
我可以控制克隆的插入位置和章节吗?
可以。您可以在特定幻灯片索引处插入克隆,并将其放入选定的 章节。如果目标章节不存在,请先创建,然后将幻灯片移动到该章节。