介绍
Aspose.Slides FOSS for C++ is now available: a free, MIT-licensed library for creating, reading, and editing PowerPoint .pptx 使用原生 C++ 编写的文件,不依赖 Microsoft Office 或任何专有运行时。.
该库面向需要以编程方式生成或操作演示文稿文件的开发者:从数据自动化生成幻灯片、从上传的 PPTX 文件提取文本和元数据、构建基于演示的报告流水线,或将演示文稿创建嵌入到桌面和服务器应用中。因为 aspose_slides_foss 使用 CMake 构建,可在 Windows、macOS 和 Linux 上编译和部署。.
关键特性
- 完整的往返 PPTX 支持::打开任意
.pptx文件,修改其内容,并保存回去而不会丢失库尚未理解的未知 XML 部分。. - 幻灯片管理::使用
prs.slides();;在构建 … 后,演示文稿会以一个空白幻灯片开始Presentation. - 自动形状、表格和连接线::通过 … 插入形状
slide.shapes().add_auto_shape(),,通过 … 插入表格数据slide.shapes().add_table(),,并通过 … 在形状之间插入可视连接线slide.shapes().add_connector(). - 富文本格式化::使用 … 在字符级别格式化文本
PortionFormat::通过 … 设置字体大小、粗体、斜体、下划线和 ARGB 颜色FillType::SOLID和ColorFormat. - 填充类型: 应用
FillType::SOLID,Gradient,Pattern, 或Picture填充任意形状。. - 视觉效果: 外阴影、发光、柔边、模糊、反射,以及内阴影,通过
shape.effect_format(). - 3D formatting: 倾斜、相机、灯光装置、材质,以及挤出深度,通过
shape.three_d_format(). - 演讲者备注: 通过将备注文本附加到每张幻灯片
notes_slide_manager().add_notes_slide(). - 线程式评论: 添加带有作者元数据和幻灯片位置的评论。.
- 嵌入图像: 从文件路径、内存缓冲区或流中嵌入。.
- 文档属性: 读取和写入核心、应用和自定义属性。.
入门指南
通过 CMake 添加库。需要 C++17 编译器。.
include(FetchContent)
FetchContent_Declare(
aspose_slides_foss
GIT_REPOSITORY https://github.com/aspose-slides-foss/Aspose.Slides-FOSS-for-Cpp.git
GIT_TAG main
)
FetchContent_MakeAvailable(aspose_slides_foss)
target_link_libraries(your_target PRIVATE aspose_slides_foss)
创建您的第一个包含形状的演示文稿并保存它::
#include <Aspose/Slides/Foss/presentation.h>
int main() {
using namespace Aspose::Slides::Foss;
Presentation prs;
auto& slide = prs.slides()[0];
auto& shape = slide.shapes().add_auto_shape(
ShapeType::RECTANGLE, 50, 50, 400, 120
);
shape.text_frame()->set_text("Hello from Aspose.Slides FOSS!");
prs.save("hello.pptx", SaveFormat::PPTX);
return 0;
}
该 Presentation 析构函数在超出作用域时会自动释放所有内部资源。.
文本格式示例
#include <Aspose/Slides/Foss/presentation.h>
using namespace Aspose::Slides::Foss;
Presentation prs;
auto& shape = prs.slides()[0].shapes().add_auto_shape(
ShapeType::RECTANGLE, 50, 50, 500, 150
);
shape.text_frame()->set_text("Bold heading in corporate blue");
auto& fmt = shape.text_frame()->paragraphs()[0].portions()[0].portion_format();
fmt.set_font_height(28);
fmt.set_font_bold(NullableBool::TRUE);
fmt.fill_format().set_fill_type(FillType::SOLID);
fmt.fill_format().solid_fill_color().set_color(Color::from_argb(255, 0, 70, 127));
prs.save("formatted.pptx", SaveFormat::PPTX);
当前限制
以下领域在此版本中会抛出异常::
- 图表、SmartArt 和 OLE 对象
- 动画和幻灯片切换
- 导出为 PDF、HTML、SVG 或图像格式
- 超链接、操作设置、VBA 宏和数字签名
在加载过程中遇到的未知 XML 部分在保存时会原样保留,从而确保其他工具生成的 PPTX 文件能够安全往返。.