管理 Android 上的演示文稿幻灯片母版
概述
幻灯片母版 定义了一组幻灯片的共享设计设置。它可以包含公共形状、徽标、背景、文本样式、主题设置和页脚设置。在 PowerPoint 中,编辑幻灯片母版是保持演示文稿一致性的常用方式,而无需在每张幻灯片上重复相同的格式。
Aspose.Slides for Android via Java 支持相同的模型。一个演示文稿可以包含一个或多个母版幻灯片,每个母版幻灯片可以包含若干布局幻灯片。普通幻灯片通常不会直接引用母版幻灯片,而是使用布局幻灯片,而该布局幻灯片属于某个母版幻灯片。
层级结构为:
- 幻灯片母版 - 定义共享的设计和主题。
- 布局幻灯片 - 定义占位符的具体排列和布局级别的格式。
- 普通幻灯片 - 包含实际的演示内容,并使用一个布局幻灯片。

在 Aspose.Slides 中,幻灯片母版由 IMasterSlide 接口表示。演示文稿中的所有母版幻灯片可通过 Presentation.getMasters 集合访问,该集合实现了 IMasterSlideCollection。有关完整的 Android via Java API,请参阅 com.aspose.slides API 参考。
Inheritance
当同一属性在多个层级上定义时,层级更具体的会覆盖更通用的。例如,如果母版幻灯片和布局幻灯片都定义了背景,则基于该布局的幻灯片使用布局的背景。有关布局幻灯片的更多信息,请参阅 应用或更改幻灯片布局。访问幻灯片母版
在 PowerPoint 中,可以通过 视图 > 幻灯片母版 打开幻灯片母版视图。

在 Aspose.Slides 中,使用 getMasters() 集合来访问母版幻灯片:
Presentation presentation = new Presentation("presentation.pptx");
try {
IMasterSlide firstMasterSlide = presentation.getMasters().get_Item(0);
int masterSlideCount = presentation.getMasters().size();
int firstMasterLayoutSlideCount = firstMasterSlide.getLayoutSlides().size();
System.out.println("Master slides: " + masterSlideCount);
System.out.println("Layouts in the first master: " + firstMasterLayoutSlideCount);
} finally {
presentation.dispose();
}
您还可以通过普通幻灯片的布局获取其使用的母版幻灯片:
Presentation presentation = new Presentation("presentation.pptx");
try {
ISlide slide = presentation.getSlides().get_Item(0);
ILayoutSlide layoutSlide = slide.getLayoutSlide();
IMasterSlide masterSlide = layoutSlide.getMasterSlide();
String masterSlideName = masterSlide.getName();
System.out.println(masterSlideName);
} finally {
presentation.dispose();
}
幻灯片母版包含的内容
母版幻灯片是类似幻灯片的对象。它实现了 IBaseSlide,因此它公开了许多普通幻灯片和布局幻灯片使用的相同属性。
常用的母版幻灯片成员包括:
| 成员 | 用途 |
|---|---|
getBackground() |
设置母版级别的幻灯片背景。 |
getShapes() |
存储放置在母版上的形状,例如徽标、图片框和共享文本。 |
getLayoutSlides() |
存储属于该母版的布局幻灯片。 |
getThemeManager() |
提供对母版主题 API 的访问。 |
getHeaderFooterManager() |
控制母版及其子布局的页眉、页脚、日期和幻灯片编号。 |
getDependingSlides() |
返回通过其布局依赖于该母版的普通幻灯片。 |
向幻灯片母版添加图像
向母版幻灯片添加图像后,使用该母版布局的幻灯片都会显示该图像。这对于徽标、水印、装饰带以及其他重复的视觉元素非常有用。
下面的示例向第一个母版幻灯片添加徽标:
Presentation presentation = new Presentation("presentation.pptx");
try {
IMasterSlide masterSlide = presentation.getMasters().get_Item(0);
IImage logo = Images.fromFile("logo.png");
try {
IPPImage logoImage = presentation.getImages().addImage(logo);
masterSlide.getShapes().addPictureFrame(
ShapeType.Rectangle,
20,
20,
80,
80,
logoImage);
} finally {
logo.dispose();
}
presentation.save("presentation-with-logo.pptx", SaveFormat.Pptx);
} finally {
presentation.dispose();
}
有关图片框的更多信息,请参阅 图片框。
使用占位符
占位符通常在布局幻灯片上定义。母版幻灯片提供共享的样式和主题,布局幻灯片继承这些设置,同时每个布局决定哪些占位符可用以及它们的位置。
在 PowerPoint 中,占位符命令位于幻灯片母版视图中。

要使用 Aspose.Slides 添加新占位符,请操作属于母版的布局幻灯片:
Presentation presentation = new Presentation("presentation.pptx");
try {
IMasterSlide masterSlide = presentation.getMasters().get_Item(0);
ILayoutSlide blankLayoutSlide = masterSlide.getLayoutSlides().getByType(SlideLayoutType.Blank);
if (blankLayoutSlide == null) {
blankLayoutSlide = masterSlide.getLayoutSlides().add(SlideLayoutType.Blank, "Blank");
}
blankLayoutSlide.getPlaceholderManager().addTextPlaceholder(60, 120, 600, 80);
presentation.getSlides().addEmptySlide(blankLayoutSlide);
presentation.save("presentation-with-placeholder.pptx", SaveFormat.Pptx);
} finally {
presentation.dispose();
}
您也可以格式化已存在于母版幻灯片上的占位符形状。下面的示例查找标题占位符并应用线性渐变填充:
Presentation presentation = new Presentation("presentation.pptx");
try {
IMasterSlide masterSlide = presentation.getMasters().get_Item(0);
IAutoShape titlePlaceholder = null;
for (IShape shape : masterSlide.getShapes()) {
if (shape instanceof IAutoShape) {
IAutoShape autoShape = (IAutoShape) shape;
if (autoShape.getPlaceholder() != null &&
autoShape.getPlaceholder().getType() == PlaceholderType.Title) {
titlePlaceholder = autoShape;
break;
}
}
}
if (titlePlaceholder != null) {
int redGradientColor = Color.valueOf(255, 0, 0).toArgb();
int purpleGradientColor = Color.valueOf(128, 0, 128).toArgb();
titlePlaceholder.getFillFormat().setFillType(FillType.Gradient);
titlePlaceholder.getFillFormat().getGradientFormat().setGradientShape(GradientShape.Linear);
titlePlaceholder.getFillFormat().getGradientFormat().getGradientStops().add(0.0f, redGradientColor);
titlePlaceholder.getFillFormat().getGradientFormat().getGradientStops().add(1.0f, purpleGradientColor);
}
presentation.save("presentation-title-style.pptx", SaveFormat.Pptx);
} finally {
presentation.dispose();
}

有关占位符和文本格式化的更多选项,请参阅 在占位符中设置提示文本 和 文本格式化。
更改幻灯片母版背景
母版背景会被布局和未覆盖该背景的幻灯片继承。以下示例为第一个母版幻灯片设置纯色背景:
Presentation presentation = new Presentation("presentation.pptx");
try {
IMasterSlide masterSlide = presentation.getMasters().get_Item(0);
int masterBackgroundColor = Color.GREEN;
masterSlide.getBackground().setType(BackgroundType.OwnBackground);
masterSlide.getBackground().getFillFormat().setFillType(FillType.Solid);
masterSlide.getBackground().getFillFormat().getSolidFillColor().setColor(masterBackgroundColor);
presentation.save("presentation-master-background.pptx", SaveFormat.Pptx);
} finally {
presentation.dispose();
}
将幻灯片母版克隆到另一个演示文稿
使用 IMasterSlideCollection.addClone 将母版幻灯片复制到另一个演示文稿中。复制后的母版可以在目标演示文稿中被布局和幻灯片使用。
Presentation sourcePresentation = new Presentation("source.pptx");
Presentation destinationPresentation = new Presentation("destination.pptx");
try {
IMasterSlide sourceMasterSlide = sourcePresentation.getMasters().get_Item(0);
IMasterSlide clonedMasterSlide = destinationPresentation.getMasters().addClone(sourceMasterSlide);
destinationPresentation.save("destination-with-master.pptx", SaveFormat.Pptx);
} finally {
sourcePresentation.dispose();
destinationPresentation.dispose();
}
如果需要连同母版一起克隆普通幻灯片,请参阅 克隆幻灯片。
添加多个幻灯片母版
一个演示文稿可以包含多个母版幻灯片。这在不同章节需要不同品牌、页面结构或主题设置时非常有用。

以下示例克隆默认母版,为克隆的母版设置不同的背景,在该克隆母版下创建布局,并基于该布局添加新幻灯片:
Presentation presentation = new Presentation("presentation.pptx");
try {
IMasterSlide defaultMasterSlide = presentation.getMasters().get_Item(0);
IMasterSlide sectionMasterSlide = presentation.getMasters().addClone(defaultMasterSlide);
int sectionMasterBackgroundColor = Color.GRAY;
sectionMasterSlide.getBackground().setType(BackgroundType.OwnBackground);
sectionMasterSlide.getBackground().getFillFormat().setFillType(FillType.Solid);
sectionMasterSlide.getBackground().getFillFormat().getSolidFillColor().setColor(sectionMasterBackgroundColor);
ILayoutSlide sourceBlankLayout = defaultMasterSlide.getLayoutSlides().getByType(SlideLayoutType.Blank);
if (sourceBlankLayout == null) {
sourceBlankLayout = defaultMasterSlide.getLayoutSlides().get_Item(0);
}
ILayoutSlide sectionBlankLayout = sectionMasterSlide.getLayoutSlides().addClone(sourceBlankLayout);
presentation.getSlides().addEmptySlide(sectionBlankLayout);
presentation.save("presentation-with-multiple-masters.pptx", SaveFormat.Pptx);
} finally {
presentation.dispose();
}
比较幻灯片母版
可以使用从 IBaseSlide 继承的 equals 方法比较母版幻灯片。比较检查结构和静态内容,如形状、文本、格式、动画以及其他幻灯片设置。它不比较唯一标识符(例如幻灯片 ID)或动态占位符值(例如当前日期)。
Presentation firstPresentation = new Presentation("first.pptx");
Presentation secondPresentation = new Presentation("second.pptx");
try {
int firstPresentationMasterCount = firstPresentation.getMasters().size();
int secondPresentationMasterCount = secondPresentation.getMasters().size();
for (int firstMasterIndex = 0; firstMasterIndex < firstPresentationMasterCount; firstMasterIndex++) {
for (int secondMasterIndex = 0; secondMasterIndex < secondPresentationMasterCount; secondMasterIndex++) {
IMasterSlide firstMasterSlide = firstPresentation.getMasters().get_Item(firstMasterIndex);
IMasterSlide secondMasterSlide = secondPresentation.getMasters().get_Item(secondMasterIndex);
boolean areMasterSlidesEqual = firstMasterSlide.equals(secondMasterSlide);
if (areMasterSlidesEqual) {
System.out.printf(
"first.pptx master #%d equals second.pptx master #%d%n",
firstMasterIndex,
secondMasterIndex);
}
}
}
} finally {
firstPresentation.dispose();
secondPresentation.dispose();
}
更多信息请参阅 比较演示文稿幻灯片。
将幻灯片母版视图设为默认视图
在 ViewProperties 上使用 setLastView 方法可以控制 PowerPoint 首次打开时的视图。下面的示例在幻灯片母版视图中打开演示文稿:
Presentation presentation = new Presentation("presentation.pptx");
try {
presentation.getViewProperties().setLastView(ViewType.SlideMasterView);
presentation.save("presentation-master-view.pptx", SaveFormat.Pptx);
} finally {
presentation.dispose();
}
有关更多视图设置,请参阅 保存演示文稿。
删除未使用的母版幻灯片
演示文稿有时会包含已不再被任何普通幻灯片使用的母版幻灯片。删除未使用的母版可以减小文件大小并简化模板维护。
使用 removeUnused 从 getMasters() 集合中删除未使用的母版:
Presentation presentation = new Presentation("presentation.pptx");
try {
presentation.getMasters().removeUnused(true);
presentation.save("presentation-clean.pptx", SaveFormat.Pptx);
} finally {
presentation.dispose();
}
您也可以使用低代码的 Compress.removeUnusedMasterSlides 方法:
Presentation presentation = new Presentation("presentation.pptx");
try {
Compress.removeUnusedMasterSlides(presentation);
presentation.save("presentation-clean.pptx", SaveFormat.Pptx);
} finally {
presentation.dispose();
}
常见问题
幻灯片母版和布局幻灯片有什么区别?
幻灯片母版定义了共享的设计设置,如主题、背景、公共形状和文本样式。布局幻灯片属于母版,并定义占位符的具体排列。普通幻灯片使用布局幻灯片,因此会同时继承布局和母版的设置。
一个演示文稿可以包含多个幻灯片母版吗?
可以。演示文稿可以包含多个幻灯片母版。当不同章节需要不同的视觉体系或品牌时,请使用多个母版。
应该在母版幻灯片还是布局幻灯片上添加占位符?
大多数情况下,在布局幻灯片上添加占位符。将在母版上放置共享的视觉元素和共享格式,然后在布局上放置内容占位符,供普通幻灯片使用。
可以删除仍在使用中的母版幻灯片吗?
不可以。拥有依赖幻灯片的母版不能直接安全删除。请先将这些幻灯片移动到另一个母版的布局下,或使用仅删除未使用母版的清理方法。