在 Android 上克隆演示文稿幻灯片
克隆演示文稿中的幻灯片
克隆是制作某对象的完全复制或副本的过程。Aspose.Slides for Android via Java 也可以对任意幻灯片进行复制或克隆,然后将该克隆幻灯片插入到当前演示文稿或任何其他已打开的演示文稿中。幻灯片克隆的过程会创建一个新幻灯片,开发人员可以对其进行修改而不影响原始幻灯片。克隆幻灯片有多种方式:
- 在演示文稿结尾处克隆。
- 在演示文稿的其他位置克隆。
- 在另一个演示文稿的结尾处克隆。
- 在另一个演示文稿的其他位置克隆。
- 在另一个演示文稿的特定位置克隆。
在 Aspose.Slides for Android via 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 类实例。
- 通过引用目标演示文稿的 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 类实例。
- 通过引用目标演示文稿的 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 类实例。
- 获取要克隆的幻灯片及其母版。
- 通过引用目标演示文稿的 Masters 集合,实例化 IMasterSlideCollection 类。
- 调用由 IMasterSlideCollection 对象公开的 addClone 方法,并将来源 PPTX 中的母版作为参数传递。
- 通过引用目标演示文稿的 Slides 集合,实例化 ISlideCollection 类。
- 调用由 ISlideCollection 对象公开的 addClone 方法,并将来源演示文稿的幻灯片和步骤 5 中克隆得到的母版作为参数传递。
- 写入修改后的目标演示文稿文件。
在下面的示例中,我们将来源演示文稿中索引为 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 Android via 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();
}
常见问题
演讲者备注和审阅者评论会被克隆吗?
会。备注页和审阅评论会随克隆一起复制。如果不需要它们,请在插入后 remove them。
图表及其数据源如何处理?
图表对象、格式以及嵌入的数据都会被复制。如果图表链接到外部源(例如 OLE 嵌入的工作簿),链接会以 OLE object 形式保留。文件移动后,请确认数据可用并刷新行为。
我可以控制克隆的插入位置和章节吗?
可以。您可以在特定幻灯片索引处插入克隆,并将其放入选定的 section。如果目标章节不存在,请先创建章节,然后再将幻灯片移动进去。