在 Java 中管理 PowerPoint 文本段落
Aspose.Slides 提供了在 Java 中处理 PowerPoint 文本、段落和片段所需的所有接口和类。
- Aspose.Slides 提供了 ITextFrame 接口,以便您添加表示段落的对象。
ITextFame对象可以包含一个或多个段落(每个段落通过回车创建)。 - Aspose.Slides 提供了 IParagraph 接口,以便您添加表示片段的对象。
IParagraph对象可以包含一个或多个片段(iPortions 对象的集合)。 - Aspose.Slides 提供了 IPortion 接口,以便您添加表示文本及其格式属性的对象。
IParagraph 对象能够通过其底层的 IPortion 对象处理具有不同格式属性的文本。
添加包含多个片段的多个段落
以下步骤演示如何添加一个包含 3 个段落且每个段落包含 3 个片段的文本框:
- 创建 Presentation 类的实例。
- 通过索引访问相应幻灯片的引用。
- 向幻灯片添加一个矩形 IAutoShape。
- 获取与该 IAutoShape 关联的 ITextFrame。
- 创建两个 IParagraph 对象并将它们添加到 ITextFrame 的
IParagraphs集合中。 - 为每个新
IParagraph创建三个 IPortion 对象(默认段落创建两个 Portion 对象),并将每个IPortion对象添加到相应IParagraph的 IPortion 集合中。 - 为每个片段设置一些文本。
- 使用
IPortion对象提供的格式属性,为每个片段应用您选择的格式设置。 - 保存修改后的演示文稿。
// 实例化一个表示 PPTX 文件的 Presentation 类
Presentation pres = new Presentation();
try {
// 访问第一张幻灯片
ISlide slide = pres.getSlides().get_Item(0);
// 添加一个矩形类型的 AutoShape
IAutoShape ashp = slide.getShapes().addAutoShape(ShapeType.Rectangle, 50, 150, 300, 150);
// 访问 AutoShape 的 TextFrame
ITextFrame tf = ashp.getTextFrame();
// 创建具有不同文本格式的段落和片段
IParagraph para0 = tf.getParagraphs().get_Item(0);
IPortion port01 = new Portion();
IPortion port02 = new Portion();
para0.getPortions().add(port01);
para0.getPortions().add(port02);
IParagraph para1 = new Paragraph();
tf.getParagraphs().add(para1);
IPortion port10 = new Portion();
IPortion port11 = new Portion();
IPortion port12 = new Portion();
para1.getPortions().add(port10);
para1.getPortions().add(port11);
para1.getPortions().add(port12);
IParagraph para2 = new Paragraph();
tf.getParagraphs().add(para2);
IPortion port20 = new Portion();
IPortion port21 = new Portion();
IPortion port22 = new Portion();
para2.getPortions().add(port20);
para2.getPortions().add(port21);
para2.getPortions().add(port22);
for (int i = 0; i < 3; i++)
{
for (int j = 0; j < 3; j++)
{
IPortion portion = tf.getParagraphs().get_Item(i).getPortions().get_Item(j);
portion.setText("Portion0" + j);
if (j == 0) {
portion.getPortionFormat().getFillFormat().setFillType(FillType.Solid);
portion.getPortionFormat().getFillFormat().getSolidFillColor().setColor(Color.RED);
portion.getPortionFormat().setFontBold(NullableBool.True);
portion.getPortionFormat().setFontHeight(15);
} else if (j == 1) {
portion.getPortionFormat().getFillFormat().setFillType(FillType.Solid);
portion.getPortionFormat().getFillFormat().getSolidFillColor().setColor(Color.BLUE);
portion.getPortionFormat().setFontItalic(NullableBool.True);
portion.getPortionFormat().setFontHeight(18);
}
}
}
// 将 PPTX 写入磁盘
pres.save("multiParaPort_out.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
管理段落项目符号
项目符号列表帮助您快速、高效地组织和呈现信息。使用项目符号的段落更易于阅读和理解。
- 创建 Presentation 类的实例。
- 通过索引访问相应幻灯片的引用。
- 添加一个 autoshape 到选定的幻灯片。
- 访问 autoshape 的 TextFrame。
- 删除
TextFrame中的默认段落。 - 使用 Paragraph 类创建第一个段落实例。
- 将段落的 bullet
Type设置为Symbol并设置 bullet 字符。 - 设置段落的
Text。 - 为 bullet 设置段落的
Indent。 - 为 bullet 设置颜色。
- 设置 bullet 的高度。
- 将新段落添加到
TextFrame的段落集合中。 - 添加第二个段落并重复步骤 7 到 13。
- 保存演示文稿。
// 实例化一个表示 PPTX 文件的 Presentation 类
Presentation pres = new Presentation();
try {
// 访问第一张幻灯片
ISlide slide = pres.getSlides().get_Item(0);
// 添加并访问 Autoshape
IAutoShape aShp = slide.getShapes().addAutoShape(ShapeType.Rectangle, 200, 200, 400, 200);
// 访问自动形状的文本框
ITextFrame txtFrm = aShp.getTextFrame();
// 删除默认段落
txtFrm.getParagraphs().removeAt(0);
// 创建段落
Paragraph para = new Paragraph();
// 设置段落的项目符号样式和符号
para.getParagraphFormat().getBullet().setType(BulletType.Symbol);
para.getParagraphFormat().getBullet().setChar((char)8226);
// 设置段落文本
para.setText("Welcome to Aspose.Slides");
// 设置项目符号缩进
para.getParagraphFormat().setIndent(25);
// 设置项目符号颜色
para.getParagraphFormat().getBullet().getColor().setColorType(ColorType.RGB);
para.getParagraphFormat().getBullet().getColor().setColor(Color.BLACK);
para.getParagraphFormat().getBullet().setBulletHardColor(NullableBool.True); // 将 IsBulletHardColor 设置为 true 以使用自定义项目符号颜色
// 设置项目符号高度
para.getParagraphFormat().getBullet().setHeight(100);
// 将段落添加到文本框
txtFrm.getParagraphs().add(para);
// 创建第二段落
Paragraph para2 = new Paragraph();
// 设置段落项目符号类型和样式
para2.getParagraphFormat().getBullet().setType(BulletType.Numbered);
para2.getParagraphFormat().getBullet().setNumberedBulletStyle(NumberedBulletStyle.BulletCircleNumWDBlackPlain);
// 添加段落文本
para2.setText("This is numbered bullet");
// 设置项目符号缩进
para2.getParagraphFormat().setIndent(25);
para2.getParagraphFormat().getBullet().getColor().setColorType(ColorType.RGB);
para2.getParagraphFormat().getBullet().getColor().setColor(Color.BLACK);
para2.getParagraphFormat().getBullet().setBulletHardColor(NullableBool.True); // 将 IsBulletHardColor 设置为 true 以使用自定义项目符号颜色
// 设置项目符号高度
para2.getParagraphFormat().getBullet().setHeight(100);
// 将段落添加到文本框
txtFrm.getParagraphs().add(para2);
// 保存修改后的演示文稿
pres.save("Bullet_out.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
管理图片项目符号
项目符号列表帮助您快速、高效地组织和呈现信息。图片段落易于阅读和理解。
- 创建 Presentation 类的实例。
- 通过索引访问相应幻灯片的引用。
- 向幻灯片添加一个 autoshape。
- 访问 autoshape 的 TextFrame。
- 删除
TextFrame中的默认段落。 - 使用 Paragraph 类创建第一个段落实例。
- 在 IPPImage 中加载图像。
- 将 bullet 类型设置为 Picture 并设置图像。
- 设置段落的
Text。 - 为 bullet 设置段落的
Indent。 - 为 bullet 设置颜色。
- 设置 bullet 的高度。
- 将新段落添加到
TextFrame的段落集合中。 - 添加第二个段落并根据前述步骤重复操作。
- 保存修改后的演示文稿。
// 实例化一个表示 PPTX 文件的 Presentation 类
Presentation presentation = new Presentation();
try {
// 访问第一张幻灯片
ISlide slide = presentation.getSlides().get_Item(0);
// 实例化用于项目符号的图像
IPPImage picture;
IImage image = Images.fromFile("bullets.png");
try {
picture = presentation.getImages().addImage(image);
} finally {
if (image != null) image.dispose();
}
// 添加并访问 Autoshape
IAutoShape autoShape = slide.getShapes().addAutoShape(ShapeType.Rectangle, 200, 200, 400, 200);
// 访问自动形状的文本框
ITextFrame textFrame = autoShape.getTextFrame();
// 删除默认段落
textFrame.getParagraphs().removeAt(0);
// 创建新段落
Paragraph paragraph = new Paragraph();
paragraph.setText("Welcome to Aspose.Slides");
// 设置段落项目符号样式和图像
paragraph.getParagraphFormat().getBullet().setType(BulletType.Picture);
paragraph.getParagraphFormat().getBullet().getPicture().setImage(picture);
// 设置项目符号高度
paragraph.getParagraphFormat().getBullet().setHeight(100);
// 将段落添加到文本框
textFrame.getParagraphs().add(paragraph);
// 将演示文稿写入为 PPTX 文件
presentation.save("ParagraphPictureBulletsPPTX_out.pptx", SaveFormat.Pptx);
// 将演示文稿写入为 PPT 文件
presentation.save("ParagraphPictureBulletsPPT_out.ppt", SaveFormat.Ppt);
} catch (IOException e) {
} finally {
if (presentation != null) presentation.dispose();
}
管理多级项目符号
项目符号列表帮助您快速、高效地组织和呈现信息。多级项目符号易于阅读和理解。
- 创建 Presentation 类的实例。
- 通过索引访问相应幻灯片的引用。
- 在新幻灯片中添加一个 autoshape。
- 访问 autoshape 的 TextFrame。
- 删除
TextFrame中的默认段落。 - 使用 Paragraph 类创建第一个段落实例,并将深度设置为 0。
- 使用
Paragraph类创建第二个段落实例,并将深度设置为 1。 - 使用
Paragraph类创建第三个段落实例,并将深度设置为 2。 - 使用
Paragraph类创建第四个段落实例,并将深度设置为 3。 - 将新段落添加到
TextFrame的段落集合中。 - 保存修改后的演示文稿。
// 实例化一个表示 PPTX 文件的 Presentation 类
Presentation pres = new Presentation();
try {
// 访问第一张幻灯片
ISlide slide = pres.getSlides().get_Item(0);
// 添加并访问 Autoshape
IAutoShape aShp = slide.getShapes().addAutoShape(ShapeType.Rectangle, 200, 200, 400, 200);
// 访问创建的自动形状的文本框
ITextFrame text = aShp.addTextFrame("");
// 清除默认段落
text.getParagraphs().clear();
// 添加第一段落
IParagraph para1 = new Paragraph();
para1.setText("Content");
para1.getParagraphFormat().getBullet().setType(BulletType.Symbol);
para1.getParagraphFormat().getBullet().setChar((char)8226);
para1.getParagraphFormat().getDefaultPortionFormat().getFillFormat().setFillType(FillType.Solid);
para1.getParagraphFormat().getDefaultPortionFormat().getFillFormat().getSolidFillColor().setColor(Color.BLACK);
// 设置项目符号级别
para1.getParagraphFormat().setDepth((short)0);
// 添加第二段落
IParagraph para2 = new Paragraph();
para2.setText("Second Level");
para2.getParagraphFormat().getBullet().setType(BulletType.Symbol);
para2.getParagraphFormat().getBullet().setChar('-');
para2.getParagraphFormat().getDefaultPortionFormat().getFillFormat().setFillType(FillType.Solid);
para2.getParagraphFormat().getDefaultPortionFormat().getFillFormat().getSolidFillColor().setColor(Color.BLACK);
// 设置项目符号级别
para2.getParagraphFormat().setDepth((short)1);
// 添加第三段落
IParagraph para3 = new Paragraph();
para3.setText("Third Level");
para3.getParagraphFormat().getBullet().setType(BulletType.Symbol);
para3.getParagraphFormat().getBullet().setChar((char)8226);
para3.getParagraphFormat().getDefaultPortionFormat().getFillFormat().setFillType(FillType.Solid);
para3.getParagraphFormat().getDefaultPortionFormat().getFillFormat().getSolidFillColor().setColor(Color.BLACK);
// 设置项目符号级别
para3.getParagraphFormat().setDepth((short)2);
// 添加第四段落
IParagraph para4 = new Paragraph();
para4.setText("Fourth Level");
para4.getParagraphFormat().getBullet().setType(BulletType.Symbol);
para4.getParagraphFormat().getBullet().setChar('-');
para4.getParagraphFormat().getDefaultPortionFormat().getFillFormat().setFillType(FillType.Solid);
para4.getParagraphFormat().getDefaultPortionFormat().getFillFormat().getSolidFillColor().setColor(Color.BLACK);
// 设置项目符号级别
para4.getParagraphFormat().setDepth((short)3);
// 将段落添加到集合
text.getParagraphs().add(para1);
text.getParagraphs().add(para2);
text.getParagraphs().add(para3);
text.getParagraphs().add(para4);
// 将演示文稿写入为 PPTX 文件
pres.save("MultilevelBullet.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
管理具有自定义编号列表的段落
IBulletFormat 接口提供了 NumberedBulletStartWith 属性等,可让您管理具有自定义编号或格式的段落。
- 创建 Presentation 类的实例。
- 访问包含该段落的幻灯片。
- 向幻灯片添加一个 autoshape。
- 访问 autoshape 的 TextFrame。
- 删除
TextFrame中的默认段落。 - 使用 Paragraph 类创建第一个段落实例,并将 NumberedBulletStartWith 设置为 2。
- 使用
Paragraph类创建第二个段落实例,并将NumberedBulletStartWith设置为 3。 - 使用
Paragraph类创建第三个段落实例,并将NumberedBulletStartWith设置为 7。 - 将新段落添加到
TextFrame的段落集合中。 - 保存修改后的演示文稿。
Presentation presentation = new Presentation();
try {
IAutoShape shape = presentation.getSlides().get_Item(0).getShapes().addAutoShape(ShapeType.Rectangle, 200, 200, 400, 200);
// 访问创建的自动形状的文本框
ITextFrame textFrame = shape.getTextFrame();
// 删除默认已存在的段落
textFrame.getParagraphs().removeAt(0);
// 第一个列表
Paragraph paragraph1 = new Paragraph();
paragraph1.setText("bullet 2");
paragraph1.getParagraphFormat().setDepth((short)4);
paragraph1.getParagraphFormat().getBullet().setNumberedBulletStartWith((short)2);
paragraph1.getParagraphFormat().getBullet().setType(BulletType.Numbered);
textFrame.getParagraphs().add(paragraph1);
Paragraph paragraph2 = new Paragraph();
paragraph2.setText("bullet 3");
paragraph2.getParagraphFormat().setDepth((short)4);
paragraph2.getParagraphFormat().getBullet().setNumberedBulletStartWith((short)3);
paragraph2.getParagraphFormat().getBullet().setType(BulletType.Numbered);
textFrame.getParagraphs().add(paragraph2);
Paragraph paragraph5 = new Paragraph();
paragraph5.setText("bullet 7");
paragraph5.getParagraphFormat().setDepth((short)4);
paragraph5.getParagraphFormat().getBullet().setNumberedBulletStartWith((short)7);
paragraph5.getParagraphFormat().getBullet().setType(BulletType.Numbered);
textFrame.getParagraphs().add(paragraph5);
presentation.save("SetCustomBulletsNumber-slides.pptx", SaveFormat.Pptx);
} finally {
if (presentation != null) presentation.dispose();
}
设置段落的首行缩进
使用 IParagraphFormat.setIndent 方法控制段落的首行缩进。该方法仅移动相对于段落左侧边距的首行,正值将首行向右移动,剩余行保持与段落正文对齐。
需要整体移动段落时使用 IParagraphFormat.setMarginLeft。仅移动首行时使用 IParagraphFormat.setIndent。
下面的示例创建多个段落并分别设置不同的缩进值,以演示首行缩进对段落布局的影响。
- 创建 Presentation 类的实例。
- 访问目标幻灯片。
- 向幻灯片添加一个矩形 AutoShape。
- 向形状添加一个空的 TextFrame 并删除默认段落。
- 创建多个段落并为它们设置不同的 Indent 值。
- 将段落添加到文本框。
- 保存修改后的演示文稿。
Presentation presentation = new Presentation();
try {
ISlide slide = presentation.getSlides().get_Item(0);
IAutoShape rectangleShape = slide.getShapes().addAutoShape(ShapeType.Rectangle, 50, 50, 420, 220);
rectangleShape.getFillFormat().setFillType(FillType.NoFill);
rectangleShape.getLineFormat().getFillFormat().setFillType(FillType.Solid);
rectangleShape.getLineFormat().getFillFormat().getSolidFillColor().setColor(Color.GRAY);
ITextFrame textFrame = rectangleShape.addTextFrame("");
textFrame.getTextFrameFormat().setAutofitType(TextAutofitType.Shape);
textFrame.getParagraphs().removeAt(0);
Paragraph firstParagraph = new Paragraph();
firstParagraph.getParagraphFormat().getDefaultPortionFormat().getFillFormat().setFillType(FillType.Solid);
firstParagraph.getParagraphFormat().getDefaultPortionFormat().getFillFormat().getSolidFillColor().setColor(Color.BLACK);
firstParagraph.setText("No first-line indent. Wrapped lines start at the same position as the first line.");
firstParagraph.getParagraphFormat().setMarginLeft(20f);
firstParagraph.getParagraphFormat().setIndent(0f);
Paragraph secondParagraph = new Paragraph();
secondParagraph.getParagraphFormat().getDefaultPortionFormat().getFillFormat().setFillType(FillType.Solid);
secondParagraph.getParagraphFormat().getDefaultPortionFormat().getFillFormat().getSolidFillColor().setColor(Color.BLACK);
secondParagraph.setText("First-line indent of 20 points. The first line moves to the right, while wrapped lines remain aligned to the paragraph body.");
secondParagraph.getParagraphFormat().setMarginLeft(20f);
secondParagraph.getParagraphFormat().setIndent(20f);
Paragraph thirdParagraph = new Paragraph();
thirdParagraph.getParagraphFormat().getDefaultPortionFormat().getFillFormat().setFillType(FillType.Solid);
thirdParagraph.getParagraphFormat().getDefaultPortionFormat().getFillFormat().getSolidFillColor().setColor(Color.BLACK);
thirdParagraph.setText("First-line indent of 40 points. This paragraph shows a larger first-line offset to make the effect easier to see.");
thirdParagraph.getParagraphFormat().setMarginLeft(20f);
thirdParagraph.getParagraphFormat().setIndent(40f);
textFrame.getParagraphs().add(firstParagraph);
textFrame.getParagraphs().add(secondParagraph);
textFrame.getParagraphs().add(thirdParagraph);
presentation.save("paragraph_indent.pptx", SaveFormat.Pptx);
}
finally {
presentation.dispose();
}
结果:

设置段落的悬挂缩进
悬挂缩进是一种段落布局方式,其中首行位于其余行的左侧。在 Aspose.Slides 中,可使用 IParagraphFormat.setIndent 方法实现。将 indent 设置为负值即可使首行相对于段落正文向左移动。
实际使用中,IParagraphFormat.setMarginLeft 定义段落正文的左侧位置,而 IParagraphFormat.setIndent 定义首行相对于该左侧的偏移。要创建悬挂缩进,请将 MarginLeft 设置为正值,将 Indent 设置为负值。
此类格式常用于参考文献、注释、词汇表条目等,需要换行行对齐到段落正文而非首行首字符的场景。
- 创建 Presentation 类的实例。
- 访问目标幻灯片。
- 向幻灯片添加一个矩形 AutoShape。
- 向形状添加一个空的 TextFrame 并删除默认段落。
- 为每个段落设置正的 MarginLeft 值。
- 设置负的 Indent 值以实现悬挂缩进效果。
- 将段落添加到文本框。
- 保存修改后的演示文稿。
Presentation presentation = new Presentation();
try {
ISlide slide = presentation.getSlides().get_Item(0);
IAutoShape rectangleShape = slide.getShapes().addAutoShape(ShapeType.Rectangle, 50, 50, 420, 220);
rectangleShape.getFillFormat().setFillType(FillType.NoFill);
rectangleShape.getLineFormat().getFillFormat().setFillType(FillType.Solid);
rectangleShape.getLineFormat().getFillFormat().getSolidFillColor().setColor(Color.GRAY);
ITextFrame textFrame = rectangleShape.addTextFrame("");
textFrame.getTextFrameFormat().setAutofitType(TextAutofitType.Shape);
textFrame.getParagraphs().removeAt(0);
Paragraph firstParagraph = new Paragraph();
firstParagraph.getParagraphFormat().getDefaultPortionFormat().getFillFormat().setFillType(FillType.Solid);
firstParagraph.getParagraphFormat().getDefaultPortionFormat().getFillFormat().getSolidFillColor().setColor(Color.BLACK);
firstParagraph.setText("A hanging indent is created by combining a positive left margin with a negative indent. The first line starts to the left, while wrapped lines align with the paragraph body.");
firstParagraph.getParagraphFormat().setMarginLeft(40f);
firstParagraph.getParagraphFormat().setIndent(-20f);
Paragraph secondParagraph = new Paragraph();
secondParagraph.getParagraphFormat().getDefaultPortionFormat().getFillFormat().setFillType(FillType.Solid);
secondParagraph.getParagraphFormat().getDefaultPortionFormat().getFillFormat().getSolidFillColor().setColor(Color.BLACK);
secondParagraph.setText("This second example uses a deeper hanging indent so the difference between the first line and the wrapped lines is easier to compare.");
secondParagraph.getParagraphFormat().setMarginLeft(60f);
secondParagraph.getParagraphFormat().setIndent(-30f);
textFrame.getParagraphs().add(firstParagraph);
textFrame.getParagraphs().add(secondParagraph);
presentation.save("hanging_indent.pptx", SaveFormat.Pptx);
}
finally {
presentation.dispose();
}
结果:

管理段落结束运行属性
- 创建 Presentation 类的实例。
- 通过位置获取包含该段落的幻灯片的引用。
- 向幻灯片添加一个矩形 autoshape。
- 向矩形添加一个包含两个段落的 TextFrame。
- 设置段落的
FontHeight和字体类型。 - 为段落设置 End 属性。
- 将修改后的演示文稿写入为 PPTX 文件。
Presentation pres = new Presentation();
try {
IAutoShape shape = pres.getSlides().get_Item(0).getShapes().addAutoShape(ShapeType.Rectangle, 10, 10, 200, 250);
Paragraph para1 = new Paragraph();
para1.getPortions().add(new Portion("Sample text"));
Paragraph para2 = new Paragraph();
para2.getPortions().add(new Portion("Sample text 2"));
PortionFormat portionFormat = new PortionFormat();
portionFormat.setFontHeight(48);
portionFormat.setLatinFont(new FontData("Times New Roman"));
para2.setEndParagraphPortionFormat(portionFormat);
shape.getTextFrame().getParagraphs().add(para1);
shape.getTextFrame().getParagraphs().add(para2);
pres.save(resourcesOutputPath+"pres.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
将 HTML 文本导入段落
Aspose.Slides 提供了增强的 HTML 文本导入段落的支持。
- 创建 Presentation 类的实例。
- 通过索引访问相应幻灯片的引用。
- 向幻灯片添加一个 autoshape。
- 添加并访问
autoshape的 ITextFrame。 - 删除
ITextFrame中的默认段落。 - 使用 TextReader 读取源 HTML 文件。
- 使用 Paragraph 类创建第一个段落实例。
- 将读取的 TextReader 中的 HTML 内容添加到 TextFrame 的 ParagraphCollection。
- 保存修改后的演示文稿。
// 创建空的演示文稿实例
Presentation pres = new Presentation();
try {
// 访问演示文稿的默认第一张幻灯片
ISlide slide = pres.getSlides().get_Item(0);
// 添加 AutoShape 以容纳 HTML 内容
IAutoShape ashape = slide.getShapes().addAutoShape(ShapeType.Rectangle, 10, 10,
(float)pres.getSlideSize().getSize().getWidth() - 20, (float)pres.getSlideSize().getSize().getHeight() - 10);
ashape.getFillFormat().setFillType(FillType.NoFill);
// 向形状添加文本框
ashape.addTextFrame("");
// 清除已添加文本框中的所有段落
ashape.getTextFrame().getParagraphs().clear();
// 使用流读取器加载 HTML 文件
TextReader tr = new StreamReader("file.html");
// 将 HTML 流读取器中的文本添加到文本框
ashape.getTextFrame().getParagraphs().addFromHtml(tr.readToEnd());
// 保存演示文稿
pres.save("output_out.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
将段落文本导出为 HTML
Aspose.Slides 提供了增强的将段落文本导出为 HTML 的支持。
- 创建 Presentation 类的实例并加载所需的演示文稿。
- 通过索引访问相应幻灯片的引用。
- 访问包含要导出为 HTML 的文本的形状。
- 访问该形状的 TextFrame。
- 创建
StreamWriter实例并添加新的 HTML 文件。 - 为 StreamWriter 提供起始索引并导出您选择的段落。
// 加载演示文稿文件
Presentation pres = new Presentation("ExportingHTMLText.pptx");
try {
// 访问演示文稿的默认第一张幻灯片
ISlide slide = pres.getSlides().get_Item(0);
// 目标索引
int index = 0;
// 访问已添加的形状
IAutoShape ashape = (IAutoShape) slide.getShapes().get_Item(index);
// 创建输出 HTML 文件
OutputStream os = new FileOutputStream("output.html");
Writer writer = new OutputStreamWriter(os, "UTF-8");
//Extracting first paragraph as HTML
// 将段落数据写入 HTML,通过提供段落起始索引和要复制的段落总数
writer.write(ashape.getTextFrame().getParagraphs().exportToHtml(0, ashape.getTextFrame().getParagraphs().getCount(), null));
writer.close();
} catch (IOException e) {
} finally {
if (pres != null) pres.dispose();
}
将段落保存为图像
在本节中,我们将展示两个示例,演示如何将由 IParagraph 接口表示的文本段落保存为图像。两个示例都包括使用 IShape 接口的 getImage 方法获取包含段落的形状图像,计算段落在形状内部的边界,并将其导出为位图图像。这些方法可以帮助您从 PowerPoint 演示文稿中提取特定文本段落并保存为独立图像,便于在各种场景中进一步使用。
假设我们有一个名为 sample.pptx 的演示文稿,里面只有一张幻灯片,第一形状是包含三个段落的文本框。

示例 1
在此示例中,我们获取第二个段落的图像。为此,先从演示文稿的第一张幻灯片中提取形状的图像,然后计算该形状文本框中第二个段落的边界。随后将该段落重新绘制到新的位图图像中,并以 PNG 格式保存。该方法在需要将特定段落单独保存为图像且保持文本的精确尺寸和格式时特别有用。
Presentation presentation = new Presentation("sample.pptx");
try {
IAutoShape firstShape = (IAutoShape) presentation.getSlides().get_Item(0).getShapes().get_Item(0);
// 将形状保存为内存中的位图。
IImage shapeImage = firstShape.getImage();
ByteArrayOutputStream shapeImageStream = new ByteArrayOutputStream();
shapeImage.save(shapeImageStream, ImageFormat.Png);
shapeImage.dispose();
// 从内存创建形状位图。
InputStream shapeImageInputStream = new ByteArrayInputStream(shapeImageStream.toByteArray());
BufferedImage shapeBitmap = ImageIO.read(shapeImageInputStream);
// 计算第二段落的边界。
IParagraph secondParagraph = firstShape.getTextFrame().getParagraphs().get_Item(1);
Rectangle2D paragraphRectangle = secondParagraph.getRect();
// 计算输出图像的坐标和尺寸(最小尺寸为 1x1 像素)。
int imageX = (int) Math.floor(paragraphRectangle.getX());
int imageY = (int) Math.floor(paragraphRectangle.getY());
int imageWidth = Math.max(1, (int) Math.ceil(paragraphRectangle.getWidth()));
int imageHeight = Math.max(1, (int) Math.ceil(paragraphRectangle.getHeight()));
// 裁剪形状位图,仅获取段落位图。
BufferedImage paragraphBitmap = shapeBitmap.getSubimage(imageX, imageY, imageWidth, imageHeight);
ImageIO.write(paragraphBitmap, "png", new File("paragraph.png"));
} catch (IOException e) {
} finally {
if (presentation != null) presentation.dispose();
}
结果:

示例 2
在此示例中,我们在前述方法的基础上为段落图像添加了缩放因子。形状从演示文稿中提取并以 2 的缩放因子保存为图像,从而在导出段落时获得更高分辨率。随后在考虑缩放的情况下计算段落边界。缩放在需要更高细节图像的场景(例如高质量印刷材料)中尤其有用。
float imageScaleX = 2f;
float imageScaleY = imageScaleX;
Presentation presentation = new Presentation("sample.pptx");
try {
IAutoShape firstShape = (IAutoShape) presentation.getSlides().get_Item(0).getShapes().get_Item(0);
// 将形状以缩放方式保存为内存中的位图。
IImage shapeImage = firstShape.getImage(ShapeThumbnailBounds.Shape, imageScaleX, imageScaleY);
ByteArrayOutputStream shapeImageStream = new ByteArrayOutputStream();
shapeImage.save(shapeImageStream, ImageFormat.Png);
shapeImage.dispose();
// 从内存创建形状位图。
InputStream shapeImageInputStream = new ByteArrayInputStream(shapeImageStream.toByteArray());
BufferedImage shapeBitmap = ImageIO.read(shapeImageInputStream);
// 计算第二段落的边界。
IParagraph secondParagraph = firstShape.getTextFrame().getParagraphs().get_Item(1);
Rectangle2D paragraphRectangle = secondParagraph.getRect();
paragraphRectangle.setRect(
paragraphRectangle.getX() * imageScaleX,
paragraphRectangle.getY() * imageScaleY,
paragraphRectangle.getWidth() * imageScaleX,
paragraphRectangle.getHeight() * imageScaleY
);
// 计算输出图像的坐标和尺寸(最小尺寸为 1x1 像素)。
int imageX = (int) Math.floor(paragraphRectangle.getX());
int imageY = (int) Math.floor(paragraphRectangle.getY());
int imageWidth = Math.max(1, (int) Math.ceil(paragraphRectangle.getWidth()));
int imageHeight = Math.max(1, (int) Math.ceil(paragraphRectangle.getHeight()));
// 裁剪形状位图,仅获取段落位图。
BufferedImage paragraphBitmap = shapeBitmap.getSubimage(imageX, imageY, imageWidth, imageHeight);
ImageIO.write(paragraphBitmap, "png", new File("paragraph.png"));
} catch (IOException e) {
} finally {
if (presentation != null) presentation.dispose();
}
常见问题
我能完全禁用文本框内的自动换行吗?
可以。使用文本框的换行设置 (setWrapText) 将换行关闭,行就不会在框边缘断开。
如何获取特定段落在幻灯片上的精确边界?
您可以检索段落(甚至单个片段)的边界矩形,以了解其在幻灯片上的精确位置和尺寸。
段落对齐(左/右/居中/两端对齐)在哪里控制?
Alignment 是 ParagraphFormat 的段落级设置;它适用于整个段落,而不受单个片段格式的影响。
我能仅为段落的一部分(例如某个单词)设置拼写检查语言吗?
可以。语言在片段级别设置 (PortionFormat.setLanguageId),因此同一段落中可以共存多种语言。