在 C++ 中管理 PowerPoint 文本段落
Aspose.Slides 提供了在 C++ 中处理 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对象提供的格式属性,为每个部分应用您偏好的格式设置。 - 保存修改后的演示文稿。
下面的 C++ 代码演示了添加包含部分的段落的实现步骤:
// 文档目录的路径。
const String outPath = u"../out/MultipleParagraphs_out.pptx";
// Load the desired the presentation
SharedPtr<Presentation> pres = MakeObject<Presentation>();
// Access first slide
SharedPtr<ISlide> sld = pres->get_Slides()->idx_get(0);
// Add an AutoShape of Rectangle type
SharedPtr<IAutoShape> ashp = sld->get_Shapes()->AddAutoShape(ShapeType::Rectangle, 150, 75, 150, 50);
// Add TextFrame to the Rectangle
SharedPtr<ITextFrame> tf=ashp->AddTextFrame(u" ");
// Accessing the first Paragraph
SharedPtr<IParagraph> para0 = tf->get_Paragraphs()->idx_get(0);
SharedPtr<Portion> port01 = MakeObject<Portion>();
SharedPtr<Portion> port02 = MakeObject<Portion>();
para0->get_Portions()->Add(port01);
para0->get_Portions()->Add(port02);
// Adding second Paragraph
SharedPtr<Paragraph> para1 = MakeObject<Paragraph>();
tf->get_Paragraphs()->Add(para1);
SharedPtr<Portion> port10 = MakeObject<Portion>();
SharedPtr<Portion> port11 = MakeObject<Portion>();
SharedPtr<Portion> port12 = MakeObject<Portion>();
para1->get_Portions()->Add(port10);
para1->get_Portions()->Add(port11);
para1->get_Portions()->Add(port12);
// Adding third Paragraph
SharedPtr<Paragraph> para2 = MakeObject<Paragraph>();
tf->get_Paragraphs()->Add(para2);
SharedPtr<Portion> port20 = MakeObject<Portion>();
SharedPtr<Portion> port21 = MakeObject<Portion>();
SharedPtr<Portion> port22 = MakeObject<Portion>();
para2->get_Portions()->Add(port20);
para2->get_Portions()->Add(port21);
para2->get_Portions()->Add(port22);
for (int i = 0; i < 3; i++)
{
for (int j = 0; j < 3; j++)
{
tf->get_Paragraphs()->idx_get(i)->get_Portions()->idx_get(j)->set_Text(u"Portion_"+j);
SharedPtr<IPortionFormat>format = tf->get_Paragraphs()->idx_get(i)->get_Portions()->idx_get(j)->get_PortionFormat();
if (j == 0)
{
format->get_FillFormat()->set_FillType(FillType::Solid);
format->get_FillFormat()->get_SolidFillColor()->set_Color(Color::get_Red());
format->set_FontBold(NullableBool::True);
format->set_FontHeight(15);
}
else if (j == 1)
{
format->get_FillFormat()->set_FillType(FillType::Solid);
format->get_FillFormat()->get_SolidFillColor()->set_Color(Color::get_Blue());
format->set_FontBold(NullableBool::True);
format->set_FontHeight(18);
}
}
}
// Save PPTX to Disk
pres->Save(outPath, Aspose::Slides::Export::SaveFormat::Pptx);
管理段落项目符号
项目符号列表可帮助您快速高效地组织和展示信息。使用项目符号的段落更易于阅读和理解。
- 创建 Presentation 类的实例。
- 通过索引获取相应幻灯片的引用。
- 向选定的幻灯片添加一个 autoshape。
- 获取该 autoshape 的 TextFrame。
- 删除
TextFrame中的默认段落。 - 使用 Paragraph 类创建第一个段落实例。
- 将段落的项目符号
Type设置为Symbol并指定项目符号字符。 - 设置段落的
Text。 - 设置段落的项目符号
Indent。 - 为项目符号设置颜色。
- 设置项目符号的高度。
- 将新段落添加到
TextFrame的段落集合中。 - 添加第二个段落,并重复步骤 7 至 13 中的操作。
- 保存演示文稿。
// 文档目录的路径。
const String outPath = u"../out/ParagraphBullets_out.pptx";
const String templatePath = u"../templates/DefaultFonts.pptx";
const String ImagePath = u"../templates/Tulips.jpg";
// 加载所需的演示文稿
SharedPtr<Presentation> pres = MakeObject<Presentation>();
// 访问第一张幻灯片
SharedPtr<ISlide> sld = pres->get_Slides()->idx_get(0);
// 添加矩形类型的 AutoShape
SharedPtr<IAutoShape> ashp = sld->get_Shapes()->AddAutoShape(ShapeType::Rectangle, 150, 75, 150, 50);
// 向矩形添加 TextFrame
ashp->AddTextFrame(u"");
// 访问文本框
SharedPtr<ITextFrame> txtFrame = ashp->get_TextFrame();
txtFrame->get_Paragraphs()->Clear();
// 为文本框创建 Paragraph 对象
SharedPtr<Paragraph> paragraph = MakeObject<Paragraph>();
// 设置文本
paragraph->set_Text(u"Welcome to Aspose.Slides");
// 设置项目符号缩进
paragraph->get_ParagraphFormat()->set_Indent (25);
// 设置项目符号颜色
paragraph->get_ParagraphFormat()->get_Bullet()->get_Color()->set_ColorType ( ColorType::RGB);
paragraph->get_ParagraphFormat()->get_Bullet()->get_Color()->set_Color(Color::get_Black());
// 将 IsBulletHardColor 设置为 true 以使用自定义的项目符号颜色
paragraph->get_ParagraphFormat()->get_Bullet()->set_IsBulletHardColor(NullableBool::True);
// 设置项目符号高度
paragraph->get_ParagraphFormat()->get_Bullet()->set_Height(100);
// 将段落添加到文本框
txtFrame->get_Paragraphs()->Add(paragraph);
// 创建第二个段落
// 为文本框创建 Paragraph 对象
SharedPtr<Paragraph> paragraph2 = MakeObject<Paragraph>();
// 设置文本
paragraph2->set_Text(u"This is numbered bullet");
// 设置段落项目符号类型和样式
paragraph2->get_ParagraphFormat()->get_Bullet()->set_Type ( BulletType::Numbered);
paragraph2->get_ParagraphFormat()->get_Bullet()->set_NumberedBulletStyle ( NumberedBulletStyle::BulletCircleNumWDBlackPlain);
// 设置项目符号缩进
paragraph2->get_ParagraphFormat()->set_Indent(25);
// 设置项目符号颜色
paragraph2->get_ParagraphFormat()->get_Bullet()->get_Color()->set_ColorType(ColorType::RGB);
paragraph2->get_ParagraphFormat()->get_Bullet()->get_Color()->set_Color(Color::get_Black());
// 将 IsBulletHardColor 设置为 true 以使用自定义的项目符号颜色
paragraph2->get_ParagraphFormat()->get_Bullet()->set_IsBulletHardColor(NullableBool::True);
// 设置项目符号高度
paragraph2->get_ParagraphFormat()->get_Bullet()->set_Height(100);
// 将段落添加到文本框
txtFrame->get_Paragraphs()->Add(paragraph2);
// 保存 PPTX 到磁盘
pres->Save(outPath, Aspose::Slides::Export::SaveFormat::Pptx);
管理图片项目符号
项目符号列表可帮助您快速高效地组织和展示信息。图片段落易于阅读和理解。
- 创建 Presentation 类的实例。
- 通过索引获取相应幻灯片的引用。
- 向幻灯片添加一个 autoshape。
- 获取该 autoshape 的 TextFrame。
- 删除
TextFrame中的默认段落。 - 使用 Paragraph 类创建第一个段落实例。
- 在 IPPImage 中加载图像。
- 将项目符号类型设置为 Picture,并设置图像。
- 设置段落的
Text。 - 设置段落的项目符号
Indent。 - 为项目符号设置颜色。
- 设置项目符号的高度。
- 将新段落添加到
TextFrame的段落集合中。 - 添加第二个段落,并根据前面的步骤重复操作。
- 保存修改后的演示文稿。
// 实例化一个表示 PPTX 文件的 Presentation 类
System::SharedPtr<Presentation> presentation = System::MakeObject<Presentation>();
// 访问第一张幻灯片
System::SharedPtr<ISlide> slide = presentation->get_Slide(0);
// 实例化用于项目符号的图像
System::SharedPtr<IImage> image = Images::FromFile(u"bullets.png");
System::SharedPtr<IPPImage> ippxImage = presentation->get_Images()->AddImage(image);
// 添加并访问 Autoshape
System::SharedPtr<IAutoShape> autoShape = slide->get_Shapes()->AddAutoShape(ShapeType::Rectangle, 200.0f, 200.0f, 400.0f, 200.0f);
// 访问 autoshape textframe
System::SharedPtr<ITextFrame> textFrame = autoShape->get_TextFrame();
// 删除默认段落
System::SharedPtr<IParagraphCollection> paragraphs = textFrame->get_Paragraphs();
paragraphs->RemoveAt(0);
// 创建新段落
System::SharedPtr<Paragraph> paragraph = System::MakeObject<Paragraph>();
paragraph->set_Text(u"Welcome to Aspose.Slides");
// 设置段落项目符号样式和图像
paragraph->get_ParagraphFormat()->get_Bullet()->set_Type(BulletType::Picture);
paragraph->get_ParagraphFormat()->get_Bullet()->get_Picture()->set_Image(ippxImage);
// 设置项目符号高度
paragraph->get_ParagraphFormat()->get_Bullet()->set_Height(100.0f);
// 将段落添加到 text frame
paragraphs->Add(paragraph);
// 将演示文稿保存为 PPTX 文件
presentation->Save(u"ParagraphPictureBulletsPPTX_out.pptx", SaveFormat::Pptx);
// 将演示文稿保存为 PPT 文件
presentation->Save(u"ParagraphPictureBulletsPPT_out.ppt", SaveFormat::Ppt);
管理多级项目符号
项目符号列表可帮助您快速高效地组织和展示信息。多级项目符号易于阅读和理解。
- 创建 Presentation 类的实例。
- 通过索引获取相应幻灯片的引用。
- 在新幻灯片中添加一个 autoshape。
- 获取该 autoshape 的 TextFrame。
- 删除
TextFrame中的默认段落。 - 通过 Paragraph 类创建第一个段落实例,并将深度设为 0。
- 通过
Paragraph类创建第二个段落实例,并将深度设为 1。 - 通过
Paragraph类创建第三个段落实例,并将深度设为 2。 - 通过
Paragraph类创建第四个段落实例,并将深度设为 3。 - 将新段落添加到
TextFrame的段落集合中。 - 保存修改后的演示文稿。
// 实例化一个表示 PPTX 文件的 Presentation 类
System::SharedPtr<Presentation> pres = System::MakeObject<Presentation>();
// 访问第一张幻灯片
System::SharedPtr<ISlide> slide = pres->get_Slide(0);
// 添加并访问 Autoshape
System::SharedPtr<IAutoShape> aShp = slide->get_Shapes()->AddAutoShape(ShapeType::Rectangle, 200.0f, 200.0f, 400.0f, 200.0f);
// 访问已创建 Autoshape 的文本框
System::SharedPtr<ITextFrame> text = aShp->AddTextFrame(u"");
// 清除默认段落
text->get_Paragraphs()->Clear();
// 添加第一段
System::SharedPtr<IParagraph> para1 = System::MakeObject<Paragraph>();
para1->set_Text(u"Content");
System::SharedPtr<IParagraphFormat> para1Format = para1->get_ParagraphFormat();
System::SharedPtr<IBulletFormat> bullet1Format = para1Format->get_Bullet();
bullet1Format->set_Type(BulletType::Symbol);
bullet1Format->set_Char(System::Convert::ToChar(8226));
System::SharedPtr<IFillFormat> defaultFillFormat1 = para1Format->get_DefaultPortionFormat()->get_FillFormat();
defaultFillFormat1->set_FillType(FillType::Solid);
defaultFillFormat1->get_SolidFillColor()->set_Color(System::Drawing::Color::get_Black());
// 设置项目符号层级
para1Format->set_Depth(0);
// 添加第二段
System::SharedPtr<IParagraph> para2 = System::MakeObject<Paragraph>();
para2->set_Text(u"Second Level");
System::SharedPtr<IParagraphFormat> para2Format = para2->get_ParagraphFormat();
System::SharedPtr<IBulletFormat> bullet2Format = para2Format->get_Bullet();
bullet2Format->set_Type(BulletType::Symbol);
bullet2Format->set_Char(u'-');
System::SharedPtr<IFillFormat> defaultFillFormat2 = para2Format->get_DefaultPortionFormat()->get_FillFormat();
defaultFillFormat2->set_FillType(FillType::Solid);
defaultFillFormat2->get_SolidFillColor()->set_Color(System::Drawing::Color::get_Black());
// 设置项目符号层级
para2Format->set_Depth(1);
// 添加第三段
System::SharedPtr<IParagraph> para3 = System::MakeObject<Paragraph>();
para3->set_Text(u"Third Level");
System::SharedPtr<IParagraphFormat> para3Format = para3->get_ParagraphFormat();
System::SharedPtr<IBulletFormat> bullet3Format = para3Format->get_Bullet();
bullet3Format->set_Type(BulletType::Symbol);
bullet3Format->set_Char(System::Convert::ToChar(8226));
System::SharedPtr<IFillFormat> defaultFillFormat3 = para3Format->get_DefaultPortionFormat()->get_FillFormat();
defaultFillFormat3->set_FillType(FillType::Solid);
defaultFillFormat3->get_SolidFillColor()->set_Color(System::Drawing::Color::get_Black());
// 设置项目符号层级
para3Format->set_Depth(2);
// 添加第四段
System::SharedPtr<IParagraph> para4 = System::MakeObject<Paragraph>();
para4->set_Text(u"Fourth Level");
System::SharedPtr<IParagraphFormat> para4Format = para4->get_ParagraphFormat();
System::SharedPtr<IBulletFormat> bullet4Format = para4Format->get_Bullet();
bullet4Format->set_Type(BulletType::Symbol);
bullet4Format->set_Char(u'-');
System::SharedPtr<IFillFormat> defaultFillFormat4 = para4Format->get_DefaultPortionFormat()->get_FillFormat();
defaultFillFormat4->set_FillType(FillType::Solid);
defaultFillFormat4->get_SolidFillColor()->set_Color(System::Drawing::Color::get_Black());
// 设置项目符号层级
para4Format->set_Depth(3);
// 将段落添加到集合
System::SharedPtr<IParagraphCollection> paragraphs = text->get_Paragraphs();
paragraphs->Add(para1);
paragraphs->Add(para2);
paragraphs->Add(para3);
paragraphs->Add(para4);
// 将演示文稿保存为 PPTX 文件
pres->Save(u"MultilevelBullet.pptx", SaveFormat::Pptx);
管理自定义编号列表的段落
IBulletFormat 接口提供了 NumberedBulletStartWith 属性等,可用于管理具有自定义编号或格式的段落。
- 创建 Presentation 类的实例。
- 获取包含该段落的幻灯片。
- 向幻灯片添加一个 autoshape。
- 获取该 autoshape 的 TextFrame。
- 删除
TextFrame中的默认段落。 - 通过 Paragraph 类创建第一个段落实例,并将 NumberedBulletStartWith 设置为 2。
- 通过
Paragraph类创建第二个段落实例,并将NumberedBulletStartWith设置为 3。 - 通过
Paragraph类创建第三个段落实例,并将NumberedBulletStartWith设置为 7。 - 将新段落添加到
TextFrame的段落集合中。 - 保存修改后的演示文稿。
auto presentation = System::MakeObject<Presentation>();
auto shape = presentation->get_Slide(0)->get_Shapes()->AddAutoShape(ShapeType::Rectangle, 200.0f, 200.0f, 400.0f, 200.0f);
// 访问已创建 Autoshape 的文本框
System::SharedPtr<ITextFrame> textFrame = shape->get_TextFrame();
// 删除默认的现有段落
textFrame->get_Paragraphs()->RemoveAt(0);
// 第一组列表
auto paragraph1 = System::MakeObject<Paragraph>();
paragraph1->set_Text(u"bullet 2");
auto paragraph1Format = paragraph1->get_ParagraphFormat();
paragraph1Format->set_Depth(4);
auto bullet1Format = paragraph1Format->get_Bullet();
bullet1Format->set_NumberedBulletStartWith(2);
bullet1Format->set_Type(BulletType::Numbered);
textFrame->get_Paragraphs()->Add(paragraph1);
auto paragraph2 = System::MakeObject<Paragraph>();
paragraph2->set_Text(u"bullet 3");
auto paragraph2Format = paragraph2->get_ParagraphFormat();
paragraph2Format->set_Depth(4);
auto bullet2Format = paragraph2Format->get_Bullet();
bullet2Format->set_NumberedBulletStartWith(3);
bullet2Format->set_Type(BulletType::Numbered);
textFrame->get_Paragraphs()->Add(paragraph2);
auto paragraph5 = System::MakeObject<Paragraph>();
paragraph5->set_Text(u"bullet 7");
auto paragraph5Format = paragraph5->get_ParagraphFormat();
paragraph5Format->set_Depth(4);
auto bullet5Format = paragraph5Format->get_Bullet();
bullet5Format->set_NumberedBulletStartWith(7);
bullet5Format->set_Type(BulletType::Numbered);
textFrame->get_Paragraphs()->Add(paragraph5);
presentation->Save(u"SetCustomBulletsNumber-slides.pptx", SaveFormat::Pptx);
设置段落缩进
- 创建 Presentation 类的实例。
- 通过索引获取相应幻灯片的引用。
- 向幻灯片添加一个矩形 autoshape。
- 向矩形 autoshape 添加一个包含三段的 TextFrame。
- 隐藏矩形的线条。
- 通过它们的 BulletOffset 属性为每个 Paragraph 设置缩进。
- 将修改后的演示文稿写入为 PPT 文件。
下面的 C++ 代码演示了如何设置段落缩进:
// 文档目录的路径。
const String outPath = u"../out/AddingSuperscriptAndSubscriptTextInTextFrame_out.pptx";
//const String templatePath = u"../templates/DefaultFonts.pptx";
// 加载所需的演示文稿
SharedPtr<Presentation> pres = MakeObject<Presentation>();
// 访问第一张幻灯片
SharedPtr<ISlide> sld = pres->get_Slides()->idx_get(0);
// 添加矩形类型的 AutoShape
SharedPtr<IAutoShape> ashp = sld->get_Shapes()->AddAutoShape(ShapeType::Rectangle, 100, 100, 300, 300);
// 向矩形添加 TextFrame
SharedPtr<ITextFrame> tf = ashp->AddTextFrame(String::Empty);
tf->get_Paragraphs()->Clear();
// 添加第一个段落
SharedPtr<Paragraph> superPar = MakeObject<Paragraph>();
SharedPtr<Portion> portion1 = MakeObject<Portion>(u"SlideTitle");
superPar->get_Portions()->Add(portion1);
SharedPtr<Portion> superPortion = MakeObject<Portion>();
superPortion->get_PortionFormat()->set_Escapement(30);
superPortion->set_Text(u"TM");
superPar->get_Portions()->Add(superPortion);
// 添加第一个段落
SharedPtr<Paragraph> subPar = MakeObject<Paragraph>();
SharedPtr<Portion> portion2 = MakeObject<Portion>(u"a");
subPar->get_Portions()->Add(portion2);
SharedPtr<Portion> subPortion = MakeObject<Portion>();
subPortion->get_PortionFormat()->set_Escapement(-25);
subPortion->set_Text(u"i");
subPar->get_Portions()->Add(subPortion);
// 将段落添加到文本框
ashp->get_TextFrame()->get_Paragraphs()->Add(superPar);
ashp->get_TextFrame()->get_Paragraphs()->Add(subPar);
// 将 PPTX 保存到磁盘
pres->Save(outPath, Aspose::Slides::Export::SaveFormat::Pptx);
为段落设置悬挂缩进
下面的 C++ 代码演示了如何为段落设置悬挂缩进:
System::SharedPtr<Presentation> pres = System::MakeObject<Presentation>();
auto autoShape = pres->get_Slide(0)->get_Shapes()->AddAutoShape(ShapeType::Rectangle, 50.0f, 250.0f, 550.0f, 150.0f);
System::SharedPtr<Paragraph> para1 = System::MakeObject<Paragraph>();
para1->set_Text(u"Example");
System::SharedPtr<Paragraph> para2 = System::MakeObject<Paragraph>();
para2->set_Text(u"Set Hanging Indent for Paragraph");
System::SharedPtr<Paragraph> para3 = System::MakeObject<Paragraph>();
para3->set_Text(u"This C# code shows you how to set the hanging indent for a paragraph: ");
para2->get_ParagraphFormat()->set_MarginLeft(10.f);
para3->get_ParagraphFormat()->set_MarginLeft(20.f);
auto paragraphs = autoShape->get_TextFrame()->get_Paragraphs();
paragraphs->Add(para1);
paragraphs->Add(para2);
paragraphs->Add(para3);
pres->Save(u"pres.pptx", SaveFormat::Pptx);
管理段落末尾运行属性
- 创建 Presentation 类的实例。
- 通过位置获取包含该段落的幻灯片引用。
- 向幻灯片添加一个矩形 autoshape。
- 向矩形添加一个包含两段的 TextFrame。
- 设置段落的
FontHeight和字体类型。 - 为段落设置 End 属性。
- 将修改后的演示文稿写入为 PPTX 文件。
下面的 C++ 代码演示了如何在 PowerPoint 中为段落设置 End 属性:
// 文档目录的路径。
const String outPath = u"../out/EndParaGraphProperties_out.pptx";
//const String templatePath = u"../templates/DefaultFonts.pptx";
// 加载所需的演示文稿
SharedPtr<Presentation> pres = MakeObject<Presentation>();
// 访问第一张幻灯片
SharedPtr<ISlide> sld = pres->get_Slides()->idx_get(0);
// 添加矩形类型的 AutoShape
SharedPtr<IAutoShape> ashp = sld->get_Shapes()->AddAutoShape(ShapeType::Rectangle, 100, 100, 300, 300);
// 向矩形添加 TextFrame
SharedPtr<ITextFrame> tf = ashp->AddTextFrame(String::Empty);
// 添加第一段
//SharedPtr<IParagraph> para1 = tf->get_Paragraphs()->idx_get(0);
SharedPtr<Paragraph> para1 = MakeObject<Paragraph>();
SharedPtr<Portion> port01 = MakeObject<Portion>(u"Sample text");
para1->get_Portions()->Add(port01);
// 添加第二段
SharedPtr<Paragraph> para2 = MakeObject<Paragraph>();
SharedPtr<Portion> port02 = MakeObject<Portion>(u"Sample text 2");
para2->get_Portions()->Add(port02);
SharedPtr<PortionFormat> endParagraphPortionFormat = MakeObject< PortionFormat>();
endParagraphPortionFormat->set_FontHeight ( 48);
endParagraphPortionFormat->set_LatinFont ( MakeObject< FontData>(u"Times New Roman"));
para2->set_EndParagraphPortionFormat(endParagraphPortionFormat);
ashp->get_TextFrame()->get_Paragraphs()->Add(para1);
ashp->get_TextFrame()->get_Paragraphs()->Add(para2);
// 将 PPTX 保存到磁盘
pres->Save(outPath, Aspose::Slides::Export::SaveFormat::Pptx);
将 HTML 文本导入段落
Aspose.Slides 提供了增强的功能,将 HTML 文本导入段落。
- 创建 Presentation 类的实例。
- 通过索引获取相应幻灯片的引用。
- 向幻灯片添加一个 autoshape。
- 添加并访问
autoshape的 ITextFrame - 删除
ITextFrame中的默认段落。 - 使用 TextReader 读取源 HTML 文件。
- 使用 Paragraph 类创建第一个段落实例。
- 将读取的 TextReader 中的 HTML 文件内容添加到 TextFrame 的 ParagraphCollection 中。
- 保存修改后的演示文稿。
下面的 C++ 代码实现了将 HTML 文本导入段落的步骤:
For complete examples and data files, please go to https://github.com/aspose-slides/Aspose.Slides-for-C
// 文档目录的路径。
const String outPath = u"../out/ImportingHTMLText_out.pptx";
const String sampleHtml = u"../templates/file.html";
// 加载所需的演示文稿
SharedPtr<Presentation> pres = MakeObject<Presentation>();
// 访问第一张幻灯片
SharedPtr<ISlide> sld = pres->get_Slides()->idx_get(0);
// 添加矩形类型的 AutoShape
SharedPtr<IAutoShape> ashp = sld->get_Shapes()->AddAutoShape(ShapeType::Rectangle, 10, 10, 700, 500);
// 重置默认填充颜色
ashp->get_FillFormat()->set_FillType(FillType::NoFill);
// 向矩形添加 TextFrame
ashp->AddTextFrame(u" ");
// 访问文本框
SharedPtr<ITextFrame> txtFrame = ashp->get_TextFrame();
// 获取 Paragraphs 集合
SharedPtr<Aspose::Slides::IParagraphCollection>ParaCollection = txtFrame->get_Paragraphs();
// 清除已添加文本框中的所有段落
ParaCollection->Clear();
// 使用流读取器加载 HTML 文件
SharedPtr<System::IO::StreamReader> tr = MakeObject<System::IO::StreamReader>(sampleHtml);
// 将 HTML 流读取器中的文本添加到文本框
ParaCollection->AddFromHtml(tr->ReadToEnd());
// 为文本框创建 Paragraph 对象
SharedPtr<IParagraph> paragraph = txtFrame->get_Paragraphs()->idx_get(0);
// 为段落创建 Portion 对象
SharedPtr<IPortion> portion = paragraph->get_Portions()->idx_get(0);
portion->set_Text(u"Aspose TextBox");
// 获取 Portion 格式
SharedPtr<IPortionFormat> pf = portion->get_PortionFormat();
// 设置 Portion 的字体
pf->set_LatinFont(MakeObject<FontData>(u"Times New Roman"));
// 设置字体的粗体属性
pf->set_FontBold(NullableBool::True);
// 设置字体的斜体属性
pf->set_FontItalic(NullableBool::True);
// 设置字体的下划线属性
pf->set_FontUnderline(TextUnderlineType::Single);
// 设置字体的高度
pf->set_FontHeight(25);
// 设置字体的颜色
pf->get_FillFormat()->set_FillType(FillType::Solid);
pf->get_FillFormat()->get_SolidFillColor()->set_Color(Color::get_Blue());
// 将 PPTX 保存到磁盘
pres->Save(outPath, Aspose::Slides::Export::SaveFormat::Pptx);
将段落文本导出为 HTML
Aspose.Slides 提供了增强的功能,将段落中包含的文本导出为 HTML。
- 创建 Presentation 类的实例并加载所需的演示文稿。
- 通过索引获取相应幻灯片的引用。
- 获取包含将导出为 HTML 的文本的形状。
- 获取该形状的 TextFrame。
- 创建
StreamWriter实例并添加新的 HTML 文件。 - 向 StreamWriter 提供起始索引并导出您选择的段落。
下面的 C++ 代码演示了如何将 PowerPoint 段落文本导出为 HTML:
For complete examples and data files, please go to https://github.com/aspose-slides/Aspose.Slides-for-C
// 文档目录的路径。
const String outPath = u"../out/output.html";
const String tempplatePath = u"../templates/DefaultFonts.pptx";
// 加载所需的演示文稿
SharedPtr<Presentation> pres = MakeObject<Presentation>(tempplatePath);
// 访问演示文稿的默认第一张幻灯片
SharedPtr<ISlide> slide = pres->get_Slides()->idx_get(0);
// 目标索引
int index = 0;
// 访问添加的形状
SharedPtr<IShape> shape = slide->get_Shapes()->idx_get(0);
SharedPtr<AutoShape> ashape = DynamicCast<Aspose::Slides::AutoShape>(shape);
// 将第一个段落提取为 HTML
SharedPtr<System::IO::StreamWriter> sw = MakeObject<System::IO::StreamWriter>(outPath, false, Encoding::get_UTF8());
// System::IO::StreamWriter^ sr = gcnew System::IO::StreamWriter("TestFile.txt", false, Encoding::get_UTF8());
// 通过提供段落起始索引和要复制的段落总数,将段落数据写入 HTML
sw->Write(ashape->get_TextFrame()->get_Paragraphs()->ExportToHtml(0, ashape->get_TextFrame()->get_Paragraphs()->get_Count(), nullptr));
sw->Close();
将段落保存为图像
在本节中,我们将通过两个示例演示如何将由 IParagraph 接口表示的文本段落保存为图像。这两个示例均包括使用 IShape 接口的 GetImage 方法获取包含段落的形状图像,计算段落在形状内的边界,并将其导出为位图图像。这些方法可让您从 PowerPoint 演示文稿中提取特定文本并保存为独立图像,适用于各种后续场景。
假设我们有一个名为 sample.pptx 的演示文稿,包含一张幻灯片,第一 个形状是一个包含三段文字的文本框。

示例 1
在此示例中,我们将第二段文本获取为图像。为此,我们从演示文稿的第一张幻灯片中提取形状图像,然后计算该形状文本框中第二段的边界。随后将该段落重新绘制到新的位图图像中,并以 PNG 格式保存。该方法在需要将特定段落保存为独立图像且保持文本的精确尺寸和格式时尤为有用。
auto presentation = MakeObject<Presentation>(u"sample.pptx");
auto firstShape = ExplicitCast<IAutoShape>(presentation->get_Slide(0)->get_Shape(0));
// Save the shape in memory as a bitmap.
auto shapeImage = firstShape->GetImage();
auto shapeImageStream = MakeObject<MemoryStream>();
shapeImage->Save(shapeImageStream, ImageFormat::Png);
shapeImage->Dispose();
// Create a shape bitmap from memory.
shapeImageStream->set_Position(0);
auto shapeBitmap = MakeObject<Bitmap>(Image::FromStream(shapeImageStream));
// Calculate the boundaries of the second paragraph.
auto secondParagraph = firstShape->get_TextFrame()->get_Paragraph(1);
auto paragraphRectangle = secondParagraph->GetRect();
// Calculate the size for the output image (minimum size - 1x1 pixel).
auto imageWidth = std::max(1, (int)Math::Ceiling(paragraphRectangle.get_Width()));
auto imageHeight = std::max(1, (int)Math::Ceiling(paragraphRectangle.get_Height()));
// Prepare a bitmap for the paragraph.
auto paragraphBitmap = MakeObject<Bitmap>(imageWidth, imageHeight);
// Redraw the paragraph from the shape bitmap to the paragraph bitmap.
auto imageGraphics = Graphics::FromImage(paragraphBitmap.get());
RectangleF drawingRectangle(0, 0, paragraphRectangle.get_Width(), paragraphRectangle.get_Height());
imageGraphics->DrawImage(shapeBitmap.get(), drawingRectangle, paragraphRectangle, GraphicsUnit::Pixel);
imageGraphics->Dispose();
paragraphBitmap->Save(u"paragraph.png", Imaging::ImageFormat::get_Png());
presentation->Dispose();
结果如下:

示例 2
在此示例中,我们在前一种方法的基础上为段落图像添加了缩放因子。形状从演示文稿中提取,并以缩放因子 2 保存为图像。这样在导出段落时可获得更高分辨率的输出。随后在考虑缩放的情况下计算段落的边界。缩放在需要更高细节的图像时尤为有用,例如用于高质量印刷材料。
auto imageScaleX = 2.0f;
auto imageScaleY = imageScaleX;
auto presentation = MakeObject<Presentation>(u"sample.pptx");
auto firstShape = ExplicitCast<IAutoShape>(presentation->get_Slide(0)->get_Shape(0));
// 将形状以缩放方式保存为内存位图。
auto shapeImage = firstShape->GetImage(ShapeThumbnailBounds::Shape, imageScaleX, imageScaleY);
auto shapeImageStream = MakeObject<MemoryStream>();
shapeImage->Save(shapeImageStream, ImageFormat::Png);
shapeImage->Dispose();
// Create a shape bitmap from memory.
shapeImageStream->set_Position(0);
auto shapeBitmap = MakeObject<Bitmap>(Image::FromStream(shapeImageStream));
// Calculate the boundaries of the second paragraph.
auto secondParagraph = firstShape->get_TextFrame()->get_Paragraph(1);
auto paragraphRectangle = secondParagraph->GetRect();
paragraphRectangle.set_X(paragraphRectangle.get_X() * imageScaleX);
paragraphRectangle.set_Y(paragraphRectangle.get_Y() * imageScaleY);
paragraphRectangle.set_Width(paragraphRectangle.get_Width() * imageScaleX);
paragraphRectangle.set_Height(paragraphRectangle.get_Height() * imageScaleY);
// Calculate the size for the output image (minimum size - 1x1 pixel).
auto imageWidth = std::max(1, (int)Math::Ceiling(paragraphRectangle.get_Width()));
auto imageHeight = std::max(1, (int)Math::Ceiling(paragraphRectangle.get_Height()));
// Prepare a bitmap for the paragraph.
auto paragraphBitmap = MakeObject<Bitmap>(imageWidth, imageHeight);
// Redraw the paragraph from the shape bitmap to the paragraph bitmap.
auto imageGraphics = Graphics::FromImage(paragraphBitmap.get());
RectangleF drawingRectangle(0, 0, paragraphRectangle.get_Width(), paragraphRectangle.get_Height());
imageGraphics->DrawImage(shapeBitmap.get(), drawingRectangle, paragraphRectangle, GraphicsUnit::Pixel);
imageGraphics->Dispose();
paragraphBitmap->Save(u"paragraph.png", Imaging::ImageFormat::get_Png());
presentation->Dispose();
常见问题
我可以完全禁用文本框内部的自动换行吗?
可以。使用文本框的换行方法 (set_WrapText) 将换行关闭,这样行就不会在框的边缘断开。
如何获取特定段落在幻灯片上的精确边界?
您可以获取段落(甚至单个部分)的边界矩形,以了解其在幻灯片上的精确位置和大小。
段落对齐方式(左/右/居中/两端对齐)在哪里控制?
Alignment 是位于 ParagraphFormat 的段落级设置;它适用于整个段落,而不受单独部分格式的影响。
我能为段落的某一部分(例如某个单词)设置拼写检查语言吗?
可以。语言在部分级别设置,使用 (PortionFormat::set_LanguageId),因此在同一个段落中可以共存多种语言。