使用 Java 管理演示文稿中的 SmartArt 形状节点
添加 SmartArt 节点
Aspose.Slides for Java 提供了最简洁的 API,以最容易的方式管理 SmartArt 形状。以下示例代码演示如何在 SmartArt 形状中添加节点和子节点。
- 创建 Presentation 类的实例并加载包含 SmartArt 形状的演示文稿。
- 使用索引获取第一张幻灯片的引用。
- 遍历第一张幻灯片中的所有形状。
- 检查形状是否为 SmartArt 类型,如果是,则将选定的形状强制转换为 SmartArt。
- 在 SmartArt 形状的 NodeCollection(ISmartArtNodeCollection#addNode–)中 添加新节点 并在 TextFrame 中设置文本。
- 现在,在新添加的 SmartArt 节点中 添加 一个 子节点(ISmartArtNode#getChildNodes–),并在 TextFrame 中设置文本。
- 保存演示文稿。
// 加载所需的演示文稿
Presentation pres = new Presentation("SimpleSmartArt.pptx");
try {
// 遍历第一张幻灯片中的所有形状
for (IShape shape : pres.getSlides().get_Item(0).getShapes())
{
// 检查形状是否为 SmartArt 类型
if (shape instanceof SmartArt)
{
// 将形状强制转换为 SmartArt
SmartArt smart = (SmartArt) shape;
// 添加一个新的 SmartArt 节点
SmartArtNode TemNode = (SmartArtNode) smart.getAllNodes().addNode();
// 添加文本
TemNode.getTextFrame().setText("Test");
// 在父节点中添加新的子节点。它将被添加到集合的末尾
SmartArtNode newNode = (SmartArtNode) TemNode.getChildNodes().addNode();
// 添加文本
newNode.getTextFrame().setText("New Node Added");
}
}
// 保存演示文稿
pres.save("AddSmartArtNode.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
在特定位置添加 SmartArt 节点
以下示例代码说明如何在特定位置向 SmartArt 形状的相应节点添加子节点。
- 创建 Presentation 类的实例。
- 使用索引获取第一张幻灯片的引用。
- 在访问的幻灯片中添加一个 StackedList(SmartArtLayoutType#StackedList)类型的 SmartArt 形状。
- 访问已添加 SmartArt 形状中的第一个节点。
- 现在,在选定的 节点(SmartArtNode)的第 2 个位置添加 子节点(ISmartArtNode#getChildNodes–),并设置其文本。
- 保存演示文稿。
// 创建演示文稿实例
Presentation pres = new Presentation();
try {
// 访问演示文稿幻灯片
ISlide slide = pres.getSlides().get_Item(0);
// 添加 Smart Art IShape
ISmartArt smart = slide.getShapes().addSmartArt(0, 0, 400, 400, SmartArtLayoutType.StackedList);
// 访问索引为 0 的 SmartArt 节点
ISmartArtNode node = smart.getAllNodes().get_Item(0);
// 在父节点的第 2 位置添加新的子节点
SmartArtNode chNode = (SmartArtNode) ((SmartArtNodeCollection) node.getChildNodes()).addNodeByPosition(2);
// 添加文本
chNode.getTextFrame().setText("Sample Text Added");
// 保存演示文稿
pres.save("AddSmartArtNodeByPosition.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
访问 SmartArt 节点
以下示例代码帮助访问 SmartArt 形状中的节点。请注意,SmartArt 的 LayoutType 为只读,且仅在添加 SmartArt 形状时设置,后续无法更改。
- 创建 Presentation 类的实例并加载包含 SmartArt 形状的演示文稿。
- 使用索引获取第一张幻灯片的引用。
- 遍历第一张幻灯片中的所有形状。
- 检查形状是否为 SmartArt 类型,如果是,则将选定的形状强制转换为 SmartArt。
- 遍历 SmartArt 形状中的所有 节点(SmartArt#getAllNodes–)。
- 访问并显示信息,如 SmartArt 节点的位置、层级和文本。
// 实例化 Presentation 类
Presentation pres = new Presentation("SmartArtShape.pptx");
try {
// 获取第一张幻灯片
ISlide slide = pres.getSlides().get_Item(0);
// 遍历第一张幻灯片中的所有形状
for (IShape shape : slide.getShapes())
{
// 检查形状是否为 SmartArt 类型
if (shape instanceof ISmartArt)
{
// 将形状强制转换为 SmartArt
ISmartArt smart = (ISmartArt) shape;
// 遍历 SmartArt 中的所有节点
for (int i = 0; i < smart.getAllNodes().size(); i++)
{
// 访问索引为 i 的 SmartArt 节点
SmartArtNode node = (SmartArtNode) smart.getAllNodes().get_Item(i);
// 打印 SmartArt 节点参数
System.out.print(node.getTextFrame().getText() + " " + node.getLevel() + " " + node.getPosition());
}
}
}
} finally {
if (pres != null) pres.dispose();
}
访问 SmartArt 子节点
以下示例代码帮助访问 SmartArt 形状中各节点的子节点。
- 创建 Presentation 类的实例并加载包含 SmartArt 形状的演示文稿。
- 使用索引获取第一张幻灯片的引用。
- 遍历第一张幻灯片中的所有形状。
- 检查形状是否为 SmartArt 类型,如果是,则将选定的形状强制转换为 SmartArt。
- 遍历 SmartArt 形状中的所有 节点(SmartArt#getAllNodes–)。
- 对于每个选定的 SmartArt 节点(SmartArtNode),遍历该节点内的所有 子节点(SmartArtNode#getChildNodes–)。
- 访问并显示信息,如 子节点(ISmartArtNode#getChildNodes–)的位置、层级和文本。
// 实例化 Presentation 类
Presentation pres = new Presentation("AccessChildNodes.pptx");
try {
// 获取第一张幻灯片
ISlide slide = pres.getSlides().get_Item(0);
// 遍历第一张幻灯片中的所有形状
for (IShape shape : slide.getShapes())
{
// 检查形状是否为 SmartArt 类型
if (shape instanceof ISmartArt)
{
// 将形状强制转换为 SmartArt
ISmartArt smart = (ISmartArt) shape;
// 遍历 SmartArt 中的所有节点
for (int i = 0; i < smart.getAllNodes().size(); i++)
{
// 访问索引为 i 的 SmartArt 节点
SmartArtNode node0 = (SmartArtNode) smart.getAllNodes().get_Item(i);
// 遍历索引为 i 的 SmartArt 节点中的子节点
for (int j = 0; j < node0.getChildNodes().size(); j++)
{
// 访问 SmartArt 节点中的子节点
SmartArtNode node = (SmartArtNode) node0.getChildNodes().get_Item(j);
// 打印 SmartArt 子节点参数
System.out.print("j = " + j + ", Text = " + node.getTextFrame().getText() + ", Level = " + node.getLevel() + ", Position = " + node.getPosition());
}
}
}
}
} finally {
if (pres != null) pres.dispose();
}
在特定位置访问 SmartArt 子节点
本示例演示如何在特定位置访问属于相应节点的子节点。
- 创建 Presentation 类的实例。
- 使用索引获取第一张幻灯片的引用。
- 添加一个 StackedList(SmartArtLayoutType#StackedList)类型的 SmartArt 形状。
- 访问已添加的 SmartArt 形状。
- 访问该 SmartArt 形状中索引为 0 的节点。
- 现在,使用 get_Item() 方法访问该节点在位置 1 的 子节点(ISmartArtNode#getChildNodes–)。
- 访问并显示信息,如 子节点(ISmartArtNode#getChildNodes–)的位置、层级和文本。
// 实例化演示文稿
Presentation pres = new Presentation();
try {
// 访问第一张幻灯片
ISlide slide = pres.getSlides().get_Item(0);
// 在第一张幻灯片中添加 SmartArt 形状
ISmartArt smart = slide.getShapes().addSmartArt(0, 0, 400, 400, SmartArtLayoutType.StackedList);
// 访问索引为 0 的 SmartArt 节点
ISmartArtNode node = smart.getAllNodes().get_Item(0);
// 在父节点中访问位置为 1 的子节点
int position = 1;
SmartArtNode chNode = (SmartArtNode) ((SmartArtNodeCollection) node.getChildNodes()).get_Item(position);
// 打印 SmartArt 子节点参数
System.out.print("Text = " + chNode.getTextFrame().getText() + ", Level = " + chNode.getLevel() + ", Position = " + chNode.getPosition());
} finally {
if (pres != null) pres.dispose();
}
删除 SmartArt 节点
本示例演示如何删除 SmartArt 形状中的节点。
- 创建 Presentation 类的实例并加载包含 SmartArt 形状的演示文稿。
- 使用索引获取第一张幻灯片的引用。
- 遍历第一张幻灯片中的所有形状。
- 检查形状是否为 SmartArt 类型,如果是,则将选定的形状强制转换为 SmartArt。
- 检查该 SmartArt 是否拥有大于 0 个节点。
- 选择要删除的 SmartArt 节点。
- 现在,使用 RemoveNode 方法移除选定的节点。
- 保存演示文稿。
// 加载所需的演示文稿
Presentation pres = new Presentation("AddSmartArtNode.pptx");
try {
// 遍历第一张幻灯片中的所有形状
for (IShape shape : pres.getSlides().get_Item(0).getShapes())
{
// 检查形状是否为 SmartArt 类型
if (shape instanceof ISmartArt)
{
// 将形状强制转换为 SmartArt
ISmartArt smart = (ISmartArt) shape;
if (smart.getAllNodes().size() > 0)
{
// 访问索引为 0 的 SmartArt 节点
ISmartArtNode node = smart.getAllNodes().get_Item(0);
// 删除选中的节点
smart.getAllNodes().removeNode(node);
}
}
}
// 保存演示文稿
pres.save("RemoveSmartArtNode.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
从特定位置删除 SmartArt 节点
本示例演示如何在特定位置删除 SmartArt 形状中的节点。
- 创建 Presentation 类的实例并加载包含 SmartArt 形状的演示文稿。
- 使用索引获取第一张幻灯片的引用。
- 遍历第一张幻灯片中的所有形状。
- 检查形状是否为 SmartArt 类型,如果是,则将选定的形状强制转换为 SmartArt。
- 选择索引为 0 的 SmartArt 形状节点。
- 现在,检查所选 SmartArt 节点是否拥有超过 2 个子节点。
- 现在,使用 RemoveNode 方法删除 位置 1 的节点。
- 保存演示文稿。
// 加载所需的演示文稿
Presentation pres = new Presentation("AddSmartArtNode.pptx");
try {
// 遍历第一张幻灯片中的所有形状
for (IShape shape : pres.getSlides().get_Item(0).getShapes())
{
// 检查形状是否为 SmartArt 类型
if (shape instanceof SmartArt)
{
// 将形状强制转换为 SmartArt
SmartArt smart = (SmartArt) shape;
if (smart.getAllNodes().size() > 0)
{
// 访问索引为 0 的 SmartArt 节点
ISmartArtNode node = smart.getAllNodes().get_Item(0);
if (node.getChildNodes().size() >= 2)
{
// 删除位置为 1 的子节点
(node.getChildNodes()).removeNode(1);
}
}
}
}
// 保存演示文稿
pres.save("RemoveSmartArtNodeByPosition.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
为 SmartArt 对象中的子节点设置自定义位置
现在,Aspose.Slides for Java 支持设置 SmartArtShape 的 X 和 Y 属性。下面的代码片段展示了如何设置自定义 SmartArtShape 位置、大小和旋转,请注意,添加新节点会导致所有节点的位置和大小重新计算。使用自定义位置设置,用户可以根据需求放置节点。
// 实例化 Presentation 类
Presentation pres = new Presentation("SimpleSmartArt.pptx");
try{
ISmartArt smart = pres.getSlides().get_Item(0).getShapes().addSmartArt(20, 20, 600, 500, SmartArtLayoutType.OrganizationChart);
// 将 SmartArt 形状移动到新位置
ISmartArtNode node = smart.getAllNodes().get_Item(1);
ISmartArtShape shape = node.getShapes().get_Item(1);
shape.setX(shape.getX() + shape.getWidth() * 2);
shape.setY(shape.getY() - shape.getHeight() * 2);
// 更改 SmartArt 形状的宽度
node = smart.getAllNodes().get_Item(2);
shape = node.getShapes().get_Item(1);
shape.setWidth(shape.getWidth() + shape.getWidth() * 2);
// 更改 SmartArt 形状的高度
node = smart.getAllNodes().get_Item(3);
shape = node.getShapes().get_Item(1);
shape.setHeight(shape.getHeight() + shape.getHeight() * 2);
// 更改 SmartArt 形状的旋转
node = smart.getAllNodes().get_Item(4);
shape = node.getShapes().get_Item(1);
shape.setRotation(90);
pres.save("SmartArt.pptx", SaveFormat.Pptx);
}finally {
pres.dispose();
}
检查助理节点
我们将在本文的不同章节中使用以下源 SmartArt 形状进行研究。
![]() |
|---|
| 图:幻灯片中的源 SmartArt 形状 |
在以下示例代码中,我们将研究如何识别 SmartArt 节点集合中的 助理节点 并对其进行更改。
- 创建 Presentation 类的实例并加载包含 SmartArt 形状的演示文稿。
- 使用索引获取第二张幻灯片的引用。
- 遍历第一张幻灯片中的所有形状。
- 检查形状是否为 SmartArt 类型,如果是,则将选定的形状强制转换为 SmartArt。
- 遍历 SmartArt 形状中的所有节点,并检查它们是否为 助理节点(SmartArtNode#isAssistant–)。
- 将助理节点的状态更改为普通节点。
- 保存演示文稿。
// 创建演示文稿实例
Presentation pres = new Presentation("AddNodes.pptx");
try {
// 遍历第一张幻灯片中的所有形状
for (IShape shape : pres.getSlides().get_Item(0).getShapes())
{
// 检查形状是否为 SmartArt 类型
if (shape instanceof ISmartArt)
{
// 将形状强制转换为 SmartArt
ISmartArt smart = (SmartArt) shape;
// 遍历 SmartArt 形状的所有节点
for (int i = 0; i < smart.getAllNodes().size(); i++)
{
ISmartArtNode node = smart.getAllNodes().get_Item(i);
// 检查节点是否为助理节点
if (node.isAssistant())
{
// 将助理节点设为 false 并使其成为普通节点
node.isAssistant();
}
}
}
}
// 保存演示文稿
pres.save("ChangeAssitantNode.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
![]() |
|---|
| 图:幻灯片中 SmartArt 形状的助理节点已更改 |
设置节点的填充格式
Aspose.Slides for Java 使得添加自定义 SmartArt 形状并设置其填充格式成为可能。本文解释了如何创建和访问 SmartArt 形状以及使用 Aspose.Slides for Java 为其设置填充格式。
请按以下步骤操作:
- 创建 Presentation 类的实例。
- 使用索引获取幻灯片的引用。
- 通过设置其 LayoutType(SmartArtLayoutType#ClosedChevronProcess)添加一个 SmartArt 形状。
- 为 SmartArt 形状节点设置 FillFormat(IShape#getFillFormat–)。
- 将修改后的演示文稿写入为 PPTX 文件。
// 实例化演示文稿
Presentation pres = new Presentation();
try {
// 访问幻灯片
ISlide slide = pres.getSlides().get_Item(0);
// 添加 SmartArt 形状及节点
ISmartArt chevron = slide.getShapes().addSmartArt(10, 10, 800, 60, SmartArtLayoutType.ClosedChevronProcess);
ISmartArtNode node = chevron.getAllNodes().addNode();
node.getTextFrame().setText("Some text");
// 设置节点填充颜色
for (IShape item : node.getShapes())
{
item.getFillFormat().setFillType(FillType.Solid);
item.getFillFormat().getSolidFillColor().setColor(Color.RED);
}
// 保存演示文稿
pres.save("TestSmart.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
生成 SmartArt 子节点的缩略图
开发人员可以按照以下步骤生成 SmartArt 子节点的缩略图:
- 创建 Presentation 类的实例。
- 添加 SmartArt。
- 使用索引获取节点的引用。
- 获取缩略图图像。
- 将缩略图图像保存为任意所需的图像格式。
// 实例化表示 PPTX 文件的 Presentation 类
Presentation pres = new Presentation();
try {
// 添加 SmartArt
ISmartArt smart = pres.getSlides().get_Item(0).getShapes().addSmartArt(10, 10, 400, 300, SmartArtLayoutType.BasicCycle);
// 使用索引获取节点的引用
ISmartArtNode node = smart.getNodes().get_Item(1);
// 获取缩略图
IImage slideImage = node.getShapes().get_Item(0).getImage();
// 保存缩略图
try {
slideImage.save("SmartArt_ChildNote_Thumbnail.png", ImageFormat.Png);
} finally {
if (slideImage != null) slideImage.dispose();
}
} finally {
if (pres != null) pres.dispose();
}
常见问题
是否支持 SmartArt 动画?
是的。SmartArt 被视为普通形状,您可以使用 标准动画(进入、退出、强调、运动路径)并调整时间。如果需要,还可以对 SmartArt 节点内的形状进行动画处理。
如果不知道内部 ID,如何可靠定位幻灯片上的特定 SmartArt?
通过设置并搜索 替代文本 来实现。为 SmartArt 设置唯一的 AltText,可在程序中不依赖内部标识符而找到它。
将演示文稿转换为 PDF 时,SmartArt 的外观会被保留吗?
会。Aspose.Slides 在 PDF 导出 时高保真渲染 SmartArt,保留布局、颜色和效果。
我能提取整个 SmartArt 的图像用于预览或报告吗?
可以。您可以将 SmartArt 形状渲染为 光栅格式 或 SVG,以获得可缩放的矢量输出,适用于缩略图、报告或网页使用。

