在 Android 上管理演示文稿的标签和自定义数据
演示文稿文件中的数据存储
PPTX 文件——带有 .pptx 扩展名的项目——存储在 PresentationML 格式中,该格式是 Office Open XML 规范的一部分。Office Open XML 格式定义了演示文稿中数据的结构。
在演示文稿中,slide(幻灯片)是其中的一个元素,slide part(幻灯片部件)包含单个幻灯片的内容。幻灯片部件可以与许多部件建立显式关系——例如由 ISO/IEC 29500 定义的用户自定义标签(User Defined Tags)。
自定义数据(特定于演示文稿)或用户可以以标签(ITagCollection)和 CustomXmlParts(ICustomXmlPartCollection)的形式存在。
获取标签的值
在幻灯片中,标签对应于 IDocumentProperties.getKeywords() 和 IDocumentProperties.setKeywords() 方法。下面的示例代码演示了如何使用 Aspose.Slides for Android(Java)获取 Presentation 的标签值:
Presentation pres = new Presentation("pres.pptx");
try{
String keywords = pres.getDocumentProperties().getKeywords();
} finally {
if (pres != null) pres.dispose();
}
向演示文稿添加标签
Aspose.Slides 允许您向演示文稿添加标签。标签通常由两个项目组成:
- 自定义属性的名称 -
MyTag - 自定义属性的值 -
My Tag Value
如果您需要根据特定规则或属性对某些演示文稿进行分类,那么向这些演示文稿添加标签可能会有所帮助。例如,如果您想对来自北美国家的所有演示文稿进行归类或放在一起,可以创建一个北美标签,然后将相关国家(美国、墨西哥和加拿大)设为其值。
下面的示例代码演示了如何使用 Aspose.Slides for Android(Java)向 Presentation 添加标签:
Presentation pres = new Presentation("pres.pptx");
try {
ITagCollection tags = pres.getCustomData().getTags();
pres.getCustomData().getTags().set_Item("MyTag", "My Tag Value");
} finally {
if (pres != null) pres.dispose();
}
标签也可以为 Slide 设置:
Presentation pres = new Presentation();
try {
ISlide slide = pres.getSlides().get_Item(0);
slide.getCustomData().getTags().set_Item("tag", "value");
} finally {
if (pres != null) pres.dispose();
}
或者任意单独的 Shape:
Presentation pres = new Presentation();
try {
ISlide slide = pres.getSlides().get_Item(0);
IAutoShape shape = slide.getShapes().addAutoShape(ShapeType.Rectangle, 10, 10, 100, 50);
shape.getTextFrame().setText("My text");
shape.getCustomData().getTags().set_Item("tag", "value");
} finally {
if (pres != null) pres.dispose();
}
限制
通过 getCustomData().getTags() 添加到自定义数据标签集合中的标签仅存储在 PowerPoint 文件中。在演示文稿导出为 PDF 时,这些标签 不会 转移到 PDF 的标签结构中。因此,作为标签分配的自定义标识符无法从已加标签的 PDF 中检索。
解决方法:您可以将自定义标识符存储在对象的 Alt Text(例如,shape.setAlternativeText("MyId"))中。导出为 PDF 后,Alt Text 可能会出现在 PDF 的标签结构中。
常见问题
我可以一次性删除演示文稿、幻灯片或形状上的所有标签吗?
可以。tag collection 支持 clear 操作,一次删除所有键值对。
如何在不遍历整个集合的情况下,仅通过名称删除单个标签?
在 tag collection 上使用 remove(name) 操作即可通过键名删除标签。
如何检索标签名称的完整列表以进行分析或过滤?
在 tag collection 上使用 getNamesOfTags;它会返回所有标签名称的数组。