Uvod

Aspose.Slides FOSS za .NET pruža sveobuhvatan skup klasa za upravljanje PowerPoint prezentacijama u potpunosti u C#. Biblioteka vam omogućuje stvaranje novih .pptx datoteka od nule, učitavanje postojećih, manipuliranje slajdovima i oblicima te spremanje rezultata natrag na disk – sve bez instalacije Microsoft Officea ili bilo koje vanjske ovisnosti.

Aspose.Slides.Foss NuGet paket cilja .NET 9.0 i radi identično na Windowsu, macOS‑u, Linuxu i Docker kontejnerima. Objavljen je pod MIT licencom, pa ga možete koristiti u komercijalnim i open‑source projektima bez ikakvih ograničenja.

Ovaj post prolazi kroz osnovne mogućnosti upravljanja prezentacijom: rad s diapozitivima, izgradnju hijerarhija oblika, organiziranje teksta, upravljanje tablicama i spremanje u PPTX.


Što je uključeno

Stvaranje i učitavanje prezentacija

Klasa Presentation je ulazna točka za svaku operaciju. Možete stvoriti praznu prezentaciju, učitati je iz putanje datoteke ili pročitati iz toka. Klasa implementira IDisposable, pa njezino umotavanje u using izjavu osigurava pravilno oslobađanje resursa.

// Create a brand-new, empty presentation
using var pres = new Presentation();

// Load an existing file
using var existing = new Presentation("report.pptx");

Objekt Presentation izlaže potpunu hijerarhiju slajdova putem svojstava kao što su Slides, Masters, LayoutSlides, Sections, CommentAuthors, Images i NotesSize.

Rad s Slides

SlideCollection vraćen od strane Presentation.Slides podržava dodavanje, kloniranje, umetanje, promjenu redoslijeda i uklanjanje slajdova. Možete klonirati slajd unutar iste prezentacije ili između prezentacija, uz očuvanje ili ponovno mapiranje izgleda.

using var pres = new Presentation();

// The default presentation contains one blank slide
var firstSlide = pres.Slides[0];

// Clone the first slide and append it
pres.Slides.AddClone(firstSlide);

// Insert a clone at a specific position
pres.Slides.InsertClone(1, firstSlide);

// Remove a slide by index
pres.Slides.RemoveAt(2);

// Total slide count
int count = pres.Slides.Count;

Svaki Slide izlaže SlideNumber, Hidden, LayoutSlide, NotesSlideManager i Name. Kolekciju možete iterirati pomoću foreach ili je pretvoriti u niz pomoću ToArray().

Oblici i AutoOblici

Svaki slajd sadrži ShapeCollection koji je dostupan putem Slide.Shapes. Zbirka pruža metode tvornice za najčešće vrste oblika.

using var pres = new Presentation();
var slide = pres.Slides[0];

// Add a rectangle AutoShape
var rect = slide.Shapes.AddAutoShape(
    ShapeType.Rectangle, 50, 50, 300, 150);

// Add a connector
var connector = slide.Shapes.AddConnector(
    ShapeType.BentConnector3, 100, 200, 200, 50);

// Reorder a shape to bring it forward
slide.Shapes.Reorder(0, rect);

// Remove all shapes
slide.Shapes.Clear();

Metode AddAutoShape i InsertAutoShape prihvaćaju ShapeType enum vrijednost i koordinate položaja i veličine. AddConnector, InsertConnector, AddPictureFrame i InsertPictureFrame slijede isti obrazac.

Tekst: Odlomci i dijelovi

Tekst u prezentaciji nalazi se unutar TextFrame, koji sadrži ParagraphCollection. Svaki Paragraph drži PortionCollection od Portion objekata koji predstavljaju pojedinačne tekstualne segmente s neovisnim formatiranjem.

using var pres = new Presentation();
var slide = pres.Slides[0];

var shape = slide.Shapes.AddAutoShape(
    ShapeType.Rectangle, 50, 50, 400, 200);

// Access the shape's text frame
var tf = shape.TextFrame;

// Read or set the full text
tf.Text = "Hello, presentation world!";

// Work with individual paragraphs and portions
var para = new Paragraph();
var portion = new Portion("Formatted run");
para.Portions.Add(portion);
tf.Paragraphs.Add(para);

Svaki Portion ima PortionFormat svojstvo za kontroliranje fonta, veličine, podebljanja/kurziva, boje, podcrtavanja i drugih atributa na razini znakova. ParagraphFormat kontrolira poravnanje, stil oznaka, razmak i uvlačenje.

Tablice

Tablice se dodaju putem ShapeCollection.AddTable, koji prihvaća širine stupaca i visine redaka kao nizove. Vraćeni Table objekt pruža pristup Rows, Columns i pojedinačnim Cell objektima.

using var pres = new Presentation();
var slide = pres.Slides[0];

double[] colWidths = { 150, 150, 150 };
double[] rowHeights = { 40, 40, 40 };

var table = slide.Shapes.AddTable(
    50, 50, colWidths, rowHeights);

// Set text in a cell
table.Rows[0][0].TextFrame.Text = "Header 1";
table.Rows[0][1].TextFrame.Text = "Header 2";
table.Rows[0][2].TextFrame.Text = "Header 3";

// Merge cells
table.MergeCells(table.Rows[1][0], table.Rows[1][2], false);

// Style presets
table.StylePreset = TableStylePreset.MediumStyle2Accent1;

Spremanje prezentacija

Metoda Presentation.Save zapisuje dokument u datoteku ili tok. Enum SaveFormat određuje izlazni format. PPTX je primarni podržani izlazni format.

using var pres = new Presentation();
// ... build slides ...

// Save to a file
pres.Save("output.pptx", SaveFormat.Pptx);

// Save to a stream
using var ms = new MemoryStream();
pres.Save(ms, SaveFormat.Pptx);

// Save specific slides by index
pres.Save("subset.pptx", new[] { 1, 3 }, SaveFormat.Pptx);

Također možete proslijediti SaveOptions objekt za dodatnu kontrolu nad izlazom.


Brzi početak

Instalirajte paket putem .NET CLI:

dotnet add package aspose.slides.foss

Zatim stvorite i spremite minimalnu prezentaciju:

using Aspose.Slides.Foss;
using Aspose.Slides.Foss.Export;

// 1. Create a new presentation
using var pres = new Presentation();

// 2. Get the default slide
var slide = pres.Slides[0];

// 3. Add a title shape
var title = slide.Shapes.AddAutoShape(
    ShapeType.Rectangle, 50, 30, 600, 60);
title.TextFrame.Text = "Quarterly Report";

// 4. Add a content shape
var body = slide.Shapes.AddAutoShape(
    ShapeType.Rectangle, 50, 120, 600, 300);
var para = new Paragraph();
para.Portions.Add(new Portion("Revenue grew 12% year-over-year."));
body.TextFrame.Paragraphs.Add(para);

// 5. Save as PPTX
pres.Save("quarterly-report.pptx", SaveFormat.Pptx);

Podržani formati

FormatEkstenzijaČitanjePisanje
PPTX.pptxDaDa
PPSX.ppsxNeDa
PPTM.pptmNeDa
POTX.potxNeDa
ODP.odpNeDa
FODP.fodpNeDa

Napomena: Biblioteka čita i zapisuje PPTX izvorno. Ostali formati navedeni u SaveFormat enumeraciji deklarirani su na razini API‑ja; stvarna vjernost izvoza može varirati. Legacy .ppt binarni format nije podržan.


Open Source i licenciranje

Aspose.Slides FOSS za .NET objavljen je pod MIT licencom. Cijeli izvorni kod dostupan je na GitHub. Možete ga koristiti u komercijalnim i open‑source projektima, mijenjati kod i redistribuirati ga bez ograničenja. Nije potreban API ključ, licencna datoteka niti registracija.


Početak