使用 Java 管理 PowerPoint 演示文稿中的 SmartArt

概述

SmartArt 是由节点、节点形状和布局组成的 PowerPoint 图表。使用 Aspose.Slides for Java,您可以创建 SmartArt、读取其节点中的文本、更改布局、检查隐藏节点、配置组织结构图布局,以及创建图片组织结构图。

获取 SmartArt 对象的文本

SmartArt 节点可以包含一个或多个形状。要读取可见文本,请遍历 ISmartArt.getAllNodes,然后读取由 ISmartArtShape.getTextFrame 返回的 ITextFrame

Presentation presentation = new Presentation("sample.pptx");
try {
    ISlide slide = presentation.getSlides().get_Item(0);
    IShape shape = slide.getShapes().get_Item(0);

    if (shape instanceof ISmartArt) {
        ISmartArt smartArt = (ISmartArt) shape;

        for (ISmartArtNode node : smartArt.getAllNodes()) {
            for (ISmartArtShape nodeShape : node.getShapes()) {
                if (nodeShape.getTextFrame() != null) {
                    System.out.println(nodeShape.getTextFrame().getText());
                }
            }
        }
    }
} finally {
    presentation.dispose();
}

更改 SmartArt 对象的布局类型

SmartArt 布局决定节点的排列和连接方式。下面的示例使用 SmartArtLayoutType BasicBlockList 值创建 SmartArt 对象,将其更改为 BasicProcess 值,并保存演示文稿。

Presentation presentation = new Presentation();
try {
    ISmartArt smartArt = presentation.getSlides().get_Item(0).getShapes().addSmartArt(
        10, 10, 400, 300, SmartArtLayoutType.BasicBlockList);

    smartArt.setLayout(SmartArtLayoutType.BasicProcess);

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

检查 SmartArt 节点是否隐藏

ISmartArtNode.isHidden 指示节点在 SmartArt 数据模型中是否隐藏。即使所选布局未将它们显示为可见的图表元素,隐藏节点仍可能存在于结构中。

下面的示例向使用 SmartArtLayoutType RadialCycle 值的 SmartArt 对象添加一个节点,并检查该节点的隐藏状态。

Presentation presentation = new Presentation();
try {
    ISmartArt smartArt = presentation.getSlides().get_Item(0).getShapes().addSmartArt(
        10, 10, 400, 300, SmartArtLayoutType.RadialCycle);

    ISmartArtNode node = smartArt.getAllNodes().addNode();
    boolean isHidden = node.isHidden();

    if (isHidden) {
        System.out.println("The node is hidden in the SmartArt data model.");
    }

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

获取或设置组织结构图布局

对于使用组织结构图布局的 SmartArt 图表,ISmartArtNode.getOrganizationChartLayoutISmartArtNode.setOrganizationChartLayout 定义子节点在父节点下的排列方式。例如,您可以根据所选的 OrganizationChartLayoutType 将子节点挂在左侧、右侧或两侧。

下面的示例创建一个组织结构图,并将第一个节点的布局设置为 OrganizationChartLayoutType LeftHanging 值。

Presentation presentation = new Presentation();
try {
    ISmartArt smartArt = presentation.getSlides().get_Item(0).getShapes().addSmartArt(
        10, 10, 400, 300, SmartArtLayoutType.OrganizationChart);

    ISmartArtNode rootNode = smartArt.getNodes().get_Item(0);
    rootNode.setOrganizationChartLayout(OrganizationChartLayoutType.LeftHanging);

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

创建图片组织结构图

图片组织结构图是一种针对包含图像占位符的层次结构图表设计的 SmartArt 布局。在将 SmartArt 对象添加到幻灯片时,请使用 SmartArtLayoutType PictureOrganizationChart 值。

Presentation presentation = new Presentation();
try {
    ISmartArt smartArt = presentation.getSlides().get_Item(0).getShapes().addSmartArt(
        0, 0, 400, 400, SmartArtLayoutType.PictureOrganizationChart);

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

常见问题

SmartArt 是否支持 RTL 语言的镜像或反转?
是的。当所选 SmartArt 布局支持反转时,ISmartArt.setReversed 方法可将图表方向从从左到右切换为从右到左,或反之。

如何在保留格式的情况下将 SmartArt 复制到同一幻灯片或另一个演示文稿?
您可以使用 ShapeCollection.addClone 克隆 SmartArt 形状(参见克隆 SmartArt 形状),或克隆包含 SmartArt 的整个幻灯片(参见克隆整个幻灯片)。这两种方法都会保留大小、位置和格式。

如何将 SmartArt 渲染为光栅图像以进行预览或网页导出?
可以将幻灯片(参见渲染幻灯片)或整个演示文稿渲染为 PNG 或 JPEG。SmartArt 会作为幻灯片的一部分进行渲染。

如果幻灯片上有多个 SmartArt 对象,如何找到特定的对象?
在 SmartArt 形状上设置唯一的 Shape.getAlternativeTextShape.getName 值,在 BaseSlide.getShapes 中搜索该值,然后确认匹配的形状是 ISmartArt