Introdução
Aspose.Slides FOSS for C++ is now available: a free, MIT-licensed library for creating, reading, and editing PowerPoint .pptx arquivos em C++ nativo, sem dependência do Microsoft Office ou de qualquer runtime proprietário.
A biblioteca foi projetada para desenvolvedores que precisam gerar ou manipular arquivos de apresentação programaticamente: automatizar decks de slides a partir de dados, extrair texto e metadados de arquivos PPTX enviados, construir pipelines de relatórios baseados em apresentações, ou incorporar a criação de apresentações em aplicações desktop e servidor. Porque aspose_slides_foss é construído com CMake, compila e implanta no Windows, macOS e Linux.
Recursos Principais
- Suporte completo de round‑trip PPTX: Abra qualquer
.pptxarquivo, modifique seu conteúdo e salve‑o novamente sem perder partes XML desconhecidas que a biblioteca ainda não entende. - Gerenciamento de slides: Adicione, remova e itere slides usando
prs.slides(); a apresentação começa com um slide em branco após a construção de umPresentation. - AutoShapes, Tabelas e Conectores: Insira formas via
slide.shapes().add_auto_shape(), dados tabulares viaslide.shapes().add_table(), e conectores visuais entre formas viaslide.shapes().add_connector(). - Formatação de texto rico: Formate texto ao nível de caractere com
PortionFormat: tamanho da fonte, negrito, itálico, sublinhado e cor ARGB viaFillType::SOLIDeColorFormat. - Tipos de preenchimento: Aplique
FillType::SOLID,Gradient,Pattern, ouPicturepreenchimentos a qualquer forma. - Efeitos visuais: Sombra externa, brilho, borda suave, desfoque, reflexão e sombra interna via
shape.effect_format(). - 3D formatting: Bisel, câmera, rig de luz, material e profundidade de extrusão via
shape.three_d_format(). - Notas do apresentador: Anexar texto de notas a cada slide via
notes_slide_manager().add_notes_slide(). - Comentários em thread: Adicionar comentários com metadados do autor e posição do slide.
- Imagens incorporadas: Incorporar a partir de caminho de arquivo, buffer de memória ou stream.
- Propriedades do documento: Ler e gravar propriedades core, app e custom.
Começando
Adicione a biblioteca via CMake. É necessário um compilador 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)
Crie sua primeira apresentação com uma forma e salve-a:
#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;
}
O Presentation destrutor libera todos os recursos internos automaticamente quando sai de escopo.
Exemplo de Formatação de Texto
#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);
Limitações Atuais
As áreas a seguir lançam exceções nesta versão:
- Gráficos, SmartArt e objetos OLE
- Animações e transições de slides
- Exportar para PDF, HTML, SVG ou formatos de imagem
- Hyperlinks, configurações de ação, macros VBA e assinaturas digitais
Partes XML desconhecidas encontradas durante o carregamento são preservadas literalmente ao salvar, de modo que arquivos PPTX produzidos por outras ferramentas façam round‑trip com segurança.