在 Java 中应用或更改幻灯片布局

概述

幻灯片布局定义了占位框的排列方式以及幻灯片内容的格式。它控制哪些占位符可用以及它们出现的位置。幻灯片布局帮助您快速且一致地设计演示文稿——无论是创建简单还是更复杂的内容。PowerPoint 中最常见的幻灯片布局包括:

标题幻灯片布局 – 包含两个文本占位符:一个用于标题,另一个用于副标题。

标题和内容布局 – 顶部有较小的标题占位符,下面有较大的占位符用于主要内容(如文本、项目符号、图表、图像等)。

空白布局 – 不包含任何占位符,您可以完全自行从头设计幻灯片。

幻灯片布局是母版幻灯片的一部分,母版幻灯片是定义演示文稿布局样式的顶层幻灯片。您可以通过母版幻灯片访问并修改布局幻灯片——可以按类型、名称或唯一 ID 操作。或者,直接在演示文稿中编辑特定的布局幻灯片。

要在 Aspose.Slides for Java 中使用幻灯片布局,您可以使用:

向演示文稿添加幻灯片布局

要自定义幻灯片的外观和结构,您可能需要向演示文稿中添加新的布局幻灯片。Aspose.Slides for Java 允许您检查特定布局是否已存在,必要时添加新布局,并基于该布局插入幻灯片。

  1. 创建一个 Presentation 类的实例。
  2. 访问 IMasterLayoutSlideCollection
  3. 检查所需的布局幻灯片是否已经在集合中存在。若不存在,则添加所需的布局幻灯片。
  4. 基于新布局幻灯片添加一个空白幻灯片。
  5. 保存演示文稿。

以下 Java 代码演示了如何向 PowerPoint 演示文稿添加幻灯片布局:

// 实例化表示 PowerPoint 文件的 Presentation 类。
Presentation presentation = new Presentation("Sample.pptx");
try {
    // 遍历布局幻灯片类型以选择布局幻灯片。
    IMasterLayoutSlideCollection layoutSlides = presentation.getMasters().get_Item(0).getLayoutSlides();
    ILayoutSlide layoutSlide = null;
    if (layoutSlides.getByType(SlideLayoutType.TitleAndObject) != null)
        layoutSlide = layoutSlides.getByType(SlideLayoutType.TitleAndObject);
    else
        layoutSlide = layoutSlides.getByType(SlideLayoutType.Title);

    if (layoutSlide == null) {
        // 演示文稿不包含所有布局类型的情况。
        // 演示文稿文件仅包含空白和自定义布局类型。
        // 但是,自定义类型的布局幻灯片可能具有可识别的名称,
        // 例如 "Title", "Title and Content", 等,可用于布局幻灯片选择。
        // 您也可以依赖一组占位符形状类型。
        // 例如,标题幻灯片应仅具有 Title 占位符类型,依此类推。
        for (ILayoutSlide titleAndObjectLayoutSlide : layoutSlides) {
            if (titleAndObjectLayoutSlide.getName().equals("Title and Object")) {
                layoutSlide = titleAndObjectLayoutSlide;
                break;
            }
        }

        if (layoutSlide == null) {
            for (ILayoutSlide titleLayoutSlide : layoutSlides) {
                if (titleLayoutSlide.getName().equals("Title")) {
                    layoutSlide = titleLayoutSlide;
                    break;
                }
            }

            if (layoutSlide == null) {
                layoutSlide = layoutSlides.getByType(SlideLayoutType.Blank);
                if (layoutSlide == null) {
                    layoutSlide = layoutSlides.add(SlideLayoutType.TitleAndObject, "Title and Object");
                }
            }
        }
    }

    // 使用添加的布局幻灯片插入空白幻灯片。
    presentation.getSlides().insertEmptySlide(0, layoutSlide);

    // 将演示文稿保存到磁盘。
    presentation.save("output.pptx", SaveFormat.Pptx);
} finally {
    presentation.dispose();
}

删除未使用的布局幻灯片

Aspose.Slides 在 Compress 类中提供了 removeUnusedLayoutSlides 方法,帮助您删除不需要且未使用的布局幻灯片。

以下 Java 代码展示了如何从 PowerPoint 演示文稿中删除布局幻灯片:

Presentation presentation = new Presentation("Presentation.pptx");
try {
    Compress.removeUnusedLayoutSlides(presentation);

    presentation.save("Output.pptx", SaveFormat.Pptx);
} finally {
    presentation.dispose();
}

向幻灯片布局添加占位符

Aspose.Slides 提供了 ILayoutSlide.getPlaceholderManager 方法,允许您向布局幻灯片添加新的占位符。

该管理器包含以下占位符类型对应的方法:

PowerPoint 占位符 ILayoutPlaceholderManager 方法
Content addContentPlaceholder(float x, float y, float width, float height)
Content (Vertical) addVerticalContentPlaceholder(float x, float y, float width, float height)
Text addTextPlaceholder(float x, float y, float width, float height)
Text (Vertical) addVerticalTextPlaceholder(float x, float y, float width, float height)
Picture addPicturePlaceholder(float x, float y, float width, float height)
Chart addChartPlaceholder(float x, float y, float width, float height)
Table addTablePlaceholder(float x, float y, float width, float height)
SmartArt addSmartArtPlaceholder(float x, float y, float width, float height)
Media addMediaPlaceholder(float x, float y, float width, float height)
Online Image addOnlineImagePlaceholder(float x, float y, float width, float height)

以下 Java 代码演示了如何向空白布局幻灯片添加新的占位符形状:

Presentation presentation = new Presentation();
try {
    // 获取空白布局幻灯片。
    ILayoutSlide layout = presentation.getLayoutSlides().getByType(SlideLayoutType.Blank);

    // 获取布局幻灯片的占位符管理器。
    ILayoutPlaceholderManager placeholderManager = layout.getPlaceholderManager();

    // 向空白布局幻灯片添加不同的占位符。
    placeholderManager.addContentPlaceholder(20, 20, 310, 270);
    placeholderManager.addVerticalTextPlaceholder(350, 20, 350, 270);
    placeholderManager.addChartPlaceholder(20, 310, 310, 180);
    placeholderManager.addTablePlaceholder(350, 310, 350, 180);

    // 使用空白布局添加新幻灯片。
    ISlide newSlide = presentation.getSlides().addEmptySlide(layout);

    presentation.save("Placeholders.pptx", SaveFormat.Pptx);
} finally {
    presentation.dispose();
}

效果如下:

布局幻灯片上的占位符

设置布局幻灯片的页脚可见性

在 PowerPoint 演示文稿中,日期、幻灯片编号和自定义文本等页脚元素可以根据幻灯片布局显示或隐藏。Aspose.Slides for Java 允许您控制这些页脚占位符的可见性,这在您希望某些布局显示页脚信息而其他布局保持简洁时非常有用。

  1. 创建一个 Presentation 类的实例。
  2. 按索引获取布局幻灯片引用。
  3. 将幻灯片页脚占位符设为可见。
  4. 将幻灯片编号占位符设为可见。
  5. 将日期时间占位符设为可见。
  6. 保存演示文稿。

以下 Java 代码展示了如何设置幻灯片页脚的可见性以及相关操作:

Presentation presentation = new Presentation("Presentation.ppt");
try {
    ILayoutSlideHeaderFooterManager headerFooterManager = presentation.getLayoutSlides().get_Item(0).getHeaderFooterManager();

    if (!headerFooterManager.isFooterVisible()) {
        headerFooterManager.setFooterVisibility(true);
    }

    if (!headerFooterManager.isSlideNumberVisible()) {
        headerFooterManager.setSlideNumberVisibility(true);
    }

    if (!headerFooterManager.isDateTimeVisible()) {
        headerFooterManager.setDateTimeVisibility(true);
    }

    headerFooterManager.setFooterText("Footer text");
    headerFooterManager.setDateTimeText("Date and time text");

    presentation.save("Presentation.ppt", SaveFormat.Ppt);
} finally {
    presentation.dispose();
}

设置子布局幻灯片的页脚可见性

在 PowerPoint 演示文稿中,日期、幻灯片编号和自定义文本等页脚元素可以在母版幻灯片层面进行控制,以确保所有布局幻灯片的一致性。Aspose.Slides for Java 使您能够在母版幻灯片上设置这些页脚占位符的可见性和内容,并将这些设置传播到所有子布局幻灯片,从而在整个演示文稿中保持统一的页脚信息。

  1. 创建一个 Presentation 类的实例。
  2. 按索引获取母版幻灯片引用。
  3. 将母版及所有子布局的页脚占位符设为可见。
  4. 将母版及所有子布局的幻灯片编号占位符设为可见。
  5. 将母版及所有子布局的日期时间占位符设为可见。
  6. 保存演示文稿。

以下 Java 代码演示了此操作:

Presentation presentation = new Presentation("Presentation.ppt");
try {
    IMasterSlideHeaderFooterManager headerFooterManager = presentation.getMasters().get_Item(0).getHeaderFooterManager();

    headerFooterManager.setFooterAndChildFootersVisibility(true);
    headerFooterManager.setSlideNumberAndChildSlideNumbersVisibility(true);
    headerFooterManager.setDateTimeAndChildDateTimesVisibility(true);

    headerFooterManager.setFooterAndChildFootersText("Footer text");
    headerFooterManager.setDateTimeAndChildDateTimesText("Date and time text");

    presentation.save("Output.pptx", SaveFormat.Pptx);
} finally {
    presentation.dispose();
}

常见问题

母版幻灯片和布局幻灯片有什么区别?

母版幻灯片定义整体主题和默认格式,而布局幻灯片为不同类型的内容定义具体的占位符排列。

我可以将布局幻灯片从一个演示文稿复制到另一个吗?

可以,您可以通过 getLayoutSlides 方法获取源演示文稿的布局幻灯片集合,克隆所需的布局幻灯片,然后使用 addClone 方法将其插入到另一个演示文稿中。

如果删除仍被幻灯片使用的布局幻灯片会怎样?

如果尝试删除仍被演示文稿中至少一个幻灯片引用的布局幻灯片,Aspose.Slides 将抛出 PptxEditException。为了避免此问题,请使用 removeUnusedLayoutSlides 方法安全地删除未被使用的布局幻灯片。