在演示文稿中使用 JavaScript 管理项目符号和编号列表
在 Microsoft PowerPoint 中,您可以像在 Word 和其他文本编辑器中一样创建项目符号和编号列表。Aspose.Slides for Node.js via Java 也允许您在演示文稿的幻灯片中使用项目符号和编号。
为什么使用项目符号列表?
项目符号列表帮助您快速高效地组织和呈现信息。
项目符号列表示例
在大多数情况下,项目符号列表具有以下三项主要功能:
- 将读者或观众的注意力吸引到重要信息上
- 使读者或观众能够轻松扫描关键要点
- 高效传达和交付重要细节。
为什么使用编号列表?
编号列表同样有助于组织和呈现信息。当条目的顺序(例如 步骤 1、步骤 2 等)重要或需要引用条目(例如 参见步骤 3)时,理想情况下应使用编号(而非项目符号)。
编号列表示例
以下是 创建项目符号 过程(步骤 1 到步骤 15)的摘要:
- 创建演示文稿类的实例。
- 执行多个任务(步骤 3 到步骤 14)。
- 保存演示文稿。
创建项目符号
本主题也属于管理文本段落系列主题的一部分。本文将演示如何管理段落项目符号。项目符号在需要按步骤描述的情况下更为有用。此外,使用项目符号后文本看起来组织良好。项目符号段落始终更易阅读和理解。我们将看到开发人员如何使用 Aspose.Slides for Node.js via Java 的这一小而强大的功能。请按照以下步骤使用 Aspose.Slides for Node.js via Java 管理段落项目符号:
- 创建 Presentation 类的实例。
- 使用 Slide 对象访问幻灯片集合中的所需幻灯片。
- 在选定幻灯片中添加 AutoShape。
- 访问已添加形状的 TextFrame。
- 删除 TextFrame 中的默认段落。
- 使用 Paragraph 类创建第一个段落实例。
- 设置段落的项目符号类型。
- 将项目符号类型设置为 Symbol 并设置项目符号字符。
- 设置段落文本。
- 设置段落缩进以放置项目符号。
- 设置项目符号颜色。
- 设置项目符号高度。
- 将创建的段落添加到 TextFrame 段落集合。
- 添加第二个段落并重复 7 到 13 步骤。
- 保存演示文稿。
以下 Java 示例代码实现上述步骤,演示如何在幻灯片中创建项目符号列表:
// 实例化一个表示 PPTX 文件的 Presentation 类
var pres = new aspose.slides.Presentation();
try {
// 访问第一张幻灯片
var slide = pres.getSlides().get_Item(0);
// 添加并访问自动形状
var aShp = slide.getShapes().addAutoShape(aspose.slides.ShapeType.Rectangle, 200, 200, 400, 200);
// 访问已创建自动形状的文本框
var txtFrm = aShp.getTextFrame();
// 删除默认的现有段落
txtFrm.getParagraphs().removeAt(0);
// 创建段落
var para = new aspose.slides.Paragraph();
// 设置段落项目符号样式和符号
para.getParagraphFormat().getBullet().setType(aspose.slides.BulletType.Symbol);
para.getParagraphFormat().getBullet().setChar(8226);
// 设置段落文本
para.setText("Welcome to Aspose.Slides");
// 设置项目符号缩进
para.getParagraphFormat().setIndent(25);
// 设置项目符号颜色
para.getParagraphFormat().getBullet().getColor().setColorType(aspose.slides.ColorType.RGB);
para.getParagraphFormat().getBullet().getColor().setColor(java.getStaticFieldValue("java.awt.Color", "BLACK"));
// 将 IsBulletHardColor 设置为 true 以使用自定义项目符号颜色
para.getParagraphFormat().getBullet().isBulletHardColor();
// 设置项目符号高度
para.getParagraphFormat().getBullet().setHeight(100);
// 将段落添加到文本框
txtFrm.getParagraphs().add(para);
// 将演示文稿保存为 PPTX 文件
pres.save("Bullet.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
pres.dispose();
}
创建图片项目符号
Aspose.Slides for Node.js via Java 允许您更改项目符号列表中的项目符号。您可以将项目符号替换为自定义符号或图像。如果希望为列表添加视觉趣味或进一步吸引列表条目,请使用自己的图像作为项目符号。
理想情况下,如果您打算用图片替换常规项目符号符号,建议选择具有透明背景的简洁图形图像。这类图像最适合作为自定义项目符号符号。
无论如何,所选图像都会被压缩至非常小的尺寸,因此我们强烈建议您选择在列表中替代项目符号符号时仍保持良好外观的图像。
创建图片项目符号的步骤如下:
- 创建 Presentation 类的实例。
- 使用 Slide 对象访问幻灯片集合中的所需幻灯片。
- 在选定幻灯片中添加 autoshape。
- 访问已添加形状的 TextFrame。
- 删除 TextFrame 中的默认段落。
- 使用 Paragraph 类创建第一个段落实例。
- 从磁盘加载图像到 PPImage。
- 将项目符号类型设置为 Picture 并设置图像。
- 设置段落文本。
- 设置段落缩进以放置项目符号。
- 设置项目符号颜色。
- 设置项目符号高度。
- 将创建的段落添加到 TextFrame 段落集合。
- 添加第二个段落并重复前述步骤。
- 保存演示文稿。
以下 JavaScript 代码演示如何在幻灯片中创建图片项目符号:
var pres = new aspose.slides.Presentation();
try {
// 访问第一张幻灯片
var slide = pres.getSlides().get_Item(0);
// 实例化用于项目符号的图像
var picture;
var image = aspose.slides.Images.fromFile("asp1.jpg");
try {
picture = pres.getImages().addImage(image);
} finally {
if (image != null) {
image.dispose();
}
}
// 添加并访问自动形状
var aShp = slide.getShapes().addAutoShape(aspose.slides.ShapeType.Rectangle, 200, 200, 400, 200);
// 访问已创建自动形状的文本框
var txtFrm = aShp.getTextFrame();
// 删除默认的现有段落
txtFrm.getParagraphs().removeAt(0);
// 创建新段落
var para = new aspose.slides.Paragraph();
para.setText("Welcome to Aspose.Slides");
// 设置段落项目符号样式和图像
para.getParagraphFormat().getBullet().setType(aspose.slides.BulletType.Picture);
para.getParagraphFormat().getBullet().getPicture().setImage(picture);
// 设置项目符号高度
para.getParagraphFormat().getBullet().setHeight(100);
// 将段落添加到文本框
txtFrm.getParagraphs().add(para);
// 将演示文稿写入为 PPTX 文件
pres.save("Bullet.pptx", aspose.slides.SaveFormat.Pptx);
} catch (e) {console.log(e);
} finally {
if (pres != null) {
pres.dispose();
}
}
创建多层项目符号
要创建包含不同层级项目的列表(在主项目符号列表下的子列表),请按以下步骤操作:
- 创建 Presentation 类的实例。
- 使用 Slide 对象访问幻灯片集合中的所需幻灯片。
- 在选定幻灯片中添加 autoshape。
- 访问已添加形状的 TextFrame。
- 删除 TextFrame 中的默认段落。
- 使用 Paragraph 类创建深度为 0 的第一个段落实例。
- 使用 Paragraph 类创建深度为 1 的第二个段落实例。
- 使用 Paragraph 类创建深度为 2 的第三个段落实例。
- 使用 Paragraph 类创建深度为 3 的第四个段落实例。
- 将创建的段落添加到 TextFrame 段落集合。
- 保存演示文稿。
以下代码实现上述步骤,展示如何在 JavaScript 中创建多层项目符号列表:
// 实例化一个表示 PPTX 文件的 Presentation 类
var pres = new aspose.slides.Presentation();
try {
// 访问第一张幻灯片
var slide = pres.getSlides().get_Item(0);
// 添加并访问自动形状
var aShp = slide.getShapes().addAutoShape(aspose.slides.ShapeType.Rectangle, 200, 200, 400, 200);
// 访问已创建自动形状的文本框
var txtFrm = aShp.addTextFrame("");
// 删除默认的现有段落
txtFrm.getParagraphs().clear();
// 创建第一个段落
var para1 = new aspose.slides.Paragraph();
// 设置段落项目符号样式和符号
para1.setText("Content");
para1.getParagraphFormat().getBullet().setType(aspose.slides.BulletType.Symbol);
para1.getParagraphFormat().getBullet().setChar(8226);
para1.getParagraphFormat().getDefaultPortionFormat().getFillFormat().setFillType(java.newByte(aspose.slides.FillType.Solid));
para1.getParagraphFormat().getDefaultPortionFormat().getFillFormat().getSolidFillColor().setColor(java.getStaticFieldValue("java.awt.Color", "BLACK"));
// 设置项目符号层级
para1.getParagraphFormat().setDepth(0);
// 创建第二个段落
var para2 = new aspose.slides.Paragraph();
// 设置段落项目符号样式和符号
para2.setText("Second level");
para2.getParagraphFormat().getBullet().setType(aspose.slides.BulletType.Symbol);
para2.getParagraphFormat().getBullet().setChar('-');
para2.getParagraphFormat().getDefaultPortionFormat().getFillFormat().setFillType(java.newByte(aspose.slides.FillType.Solid));
para2.getParagraphFormat().getDefaultPortionFormat().getFillFormat().getSolidFillColor().setColor(java.getStaticFieldValue("java.awt.Color", "BLACK"));
// 设置项目符号层级
para2.getParagraphFormat().setDepth(1);
// 创建第三个段落
var para3 = new aspose.slides.Paragraph();
// 设置段落项目符号样式和符号
para3.setText("Third level");
para3.getParagraphFormat().getBullet().setType(aspose.slides.BulletType.Symbol);
para3.getParagraphFormat().getBullet().setChar(8226);
para3.getParagraphFormat().getDefaultPortionFormat().getFillFormat().setFillType(java.newByte(aspose.slides.FillType.Solid));
para3.getParagraphFormat().getDefaultPortionFormat().getFillFormat().getSolidFillColor().setColor(java.getStaticFieldValue("java.awt.Color", "BLACK"));
// 设置项目符号层级
para3.getParagraphFormat().setDepth(2);
// 创建第四个段落
var para4 = new aspose.slides.Paragraph();
// 设置段落项目符号样式和符号
para4.setText("Fourth Level");
para4.getParagraphFormat().getBullet().setType(aspose.slides.BulletType.Symbol);
para4.getParagraphFormat().getBullet().setChar('-');
para4.getParagraphFormat().getDefaultPortionFormat().getFillFormat().setFillType(java.newByte(aspose.slides.FillType.Solid));
para4.getParagraphFormat().getDefaultPortionFormat().getFillFormat().getSolidFillColor().setColor(java.getStaticFieldValue("java.awt.Color", "BLACK"));
// 设置项目符号层级
para4.getParagraphFormat().setDepth(3);
// 将段落添加到文本框
txtFrm.getParagraphs().add(para1);
txtFrm.getParagraphs().add(para2);
txtFrm.getParagraphs().add(para3);
txtFrm.getParagraphs().add(para4);
// 将演示文稿保存为 PPTX 文件
pres.save("MultilevelBullet.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
if (pres != null) {
pres.dispose();
}
}
创建自定义编号列表
Aspose.Slides for Node.js via Java 提供了简单的 API 来管理具有自定义数字格式的段落。要在段落中添加自定义编号列表,请按照下面的步骤操作:
- 创建 Presentation 类的实例。
- 使用 Slide 对象访问幻灯片集合中的所需幻灯片。
- 在选定幻灯片中添加 autoshape。
- 访问已添加形状的 TextFrame。
- 删除 TextFrame 中的默认段落。
- 使用 Paragraph 类创建第一个段落实例,并将 NumberedBulletStartWith 设置为 2。
- 使用 Paragraph 类创建第二个段落实例,并将 NumberedBulletStartWith 设置为 3。
- 使用 Paragraph 类创建第三个段落实例,并将 NumberedBulletStartWith 设置为 7。
- 将创建的段落添加到 TextFrame 段落集合。
- 保存演示文稿。
以下 JavaScript 代码展示如何在幻灯片中创建编号列表:
// 实例化一个表示 PPTX 文件的 Presentation 类
var pres = new aspose.slides.Presentation();
try {
// 访问第一张幻灯片
var slide = pres.getSlides().get_Item(0);
// 添加并访问自动形状
var aShp = slide.getShapes().addAutoShape(aspose.slides.ShapeType.Rectangle, 200, 200, 400, 200);
// 访问已创建自动形状的文本框
var txtFrm = aShp.addTextFrame("");
// 删除默认的现有段落
txtFrm.getParagraphs().clear();
// 第一个列表
var paragraph1 = new aspose.slides.Paragraph();
paragraph1.setText("bullet 2");
paragraph1.getParagraphFormat().setDepth(4);
paragraph1.getParagraphFormat().getBullet().setNumberedBulletStartWith(2);
paragraph1.getParagraphFormat().getBullet().setType(aspose.slides.BulletType.Numbered);
txtFrm.getParagraphs().add(paragraph1);
var paragraph2 = new aspose.slides.Paragraph();
paragraph2.setText("bullet 3");
paragraph2.getParagraphFormat().setDepth(4);
paragraph2.getParagraphFormat().getBullet().setNumberedBulletStartWith(3);
paragraph2.getParagraphFormat().getBullet().setType(aspose.slides.BulletType.Numbered);
txtFrm.getParagraphs().add(paragraph2);
// 第二个列表
var paragraph5 = new aspose.slides.Paragraph();
paragraph5.setText("bullet 5");
paragraph5.getParagraphFormat().setDepth(4);
paragraph5.getParagraphFormat().getBullet().setNumberedBulletStartWith(5);
paragraph5.getParagraphFormat().getBullet().setType(aspose.slides.BulletType.Numbered);
txtFrm.getParagraphs().add(paragraph5);
pres.save(resourcesOutputPath + "SetCustomBulletsNumber-slides.pptx.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
if (pres != null) {
pres.dispose();
}
}
常见问题
使用 Aspose.Slides 创建的项目符号和编号列表能否导出为 PDF 或图像等其他格式?
是的,Aspose.Slides 在将演示文稿导出为 PDF、图像等格式时,完全保留项目符号和编号列表的格式和结构,确保结果一致。
是否可以从现有演示文稿中导入项目符号或编号列表?
可以,Aspose.Slides 允许您导入并编辑现有演示文稿中的项目符号或编号列表,同时保留其原始格式和外观。
Aspose.Slides 是否支持在多语言演示文稿中使用项目符号和编号列表?
是的,Aspose.Slides 完全支持多语言演示文稿,您可以在任何语言中创建项目符号和编号列表,包括使用特殊或非拉丁字符。