在 Android 上的演示文稿中管理 SmartArt 形状节点
添加 SmartArt 节点
Aspose.Slides for Android via Java 提供了最简易的 API 来以最简单的方式管理 SmartArt 形状。以下示例代码将帮助在 SmartArt 形状中添加节点和子节点。
- 创建 Presentation 类的实例并加载包含 SmartArt 形状的演示文稿。
- 通过索引获取第一张幻灯片的引用。
- 遍历第一张幻灯片中的每个形状。
- 检查形状是否为 SmartArt 类型,如果是 SmartArt,则将选定的形状强制转换为 SmartArt。
- 在 SmartArt 形状的 NodeCollection 中添加新节点并在 TextFrame 中设置文本。
- 现在,在新添加的 SmartArt 节点中添加一个 Child Node 并在 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 类型的 SmartArt 形状。
- 访问已添加 SmartArt 形状中的第一个节点。
- 现在,为选定的 Node 在位置 2 添加一个 Child Node 并设置其文本。
- 保存演示文稿。
// 创建演示文稿实例
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 形状内的所有 Nodes。
- 访问并显示 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 形状内的所有 Nodes。
- 对于每个选定的 SmartArt Node,遍历其内部的所有 Child Nodes。
- 访问并显示子节点的位置、层级和文本等信息。
// 实例化 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 子节点
本示例演示如何在特定位置访问 SmartArt 形状中各节点的子节点。
- 创建 Presentation 类的实例。
- 通过索引获取第一张幻灯片的引用。
- 添加一种 StackedList 类型的 SmartArt 形状。
- 访问已添加的 SmartArt 形状。
- 访问该 SmartArt 形状索引为 0 的节点。
- 现在,使用 get_Item() 方法访问索引为 1 的 Child Node。
- 访问并显示子节点的位置、层级和文本等信息。
// 实例化演示文稿
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。
- 检查 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,则将选定的形状强制转换为 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 Android via 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 节点集合中识别 Assistant Nodes 并对其进行更改。
- 创建 Presentation 类的实例并加载包含 SmartArt 形状的演示文稿。
- 通过索引获取第二张幻灯片的引用。
- 遍历第一张幻灯片中的每个形状。
- 检查形状是否为 SmartArt 类型,如果是 SmartArt,则将选定的形状强制转换为 SmartArt。
- 遍历 SmartArt 形状中的所有节点,并检查它们是否为 Assistant Nodes。
- 将 Assistant Node 的状态更改为普通节点。
- 保存演示文稿。
// 创建演示文稿实例
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);
// 检查节点是否为 Assistant 节点
if (node.isAssistant())
{
// 将 Assistant 节点设为 false 并使其成为普通节点
node.isAssistant();
}
}
}
}
// 保存演示文稿
pres.save("ChangeAssitantNode.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
![]() |
|---|
| 图:幻灯片中 SmartArt 形状的助理节点已更改 |
设置节点的填充格式
Aspose.Slides for Android via Java 使得添加自定义 SmartArt 形状并设置其填充格式成为可能。本文解释了如何创建和访问 SmartArt 形状以及使用 Aspose.Slides for Android via Java 为其设置填充格式。
请按照以下步骤操作:
- 创建 Presentation 类的实例。
- 使用索引获取幻灯片的引用。
- 通过设置其 LayoutType 添加一个 SmartArt 形状。
- 为 SmartArt 形状的节点设置 FillFormat。
- 将修改后的演示文稿写入为 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 的图像用于预览或报告吗?

