Lavorare con le Immagini nelle Presentazioni — Aspose.Slides FOSS per .NET

Aspose.Slides FOSS for .NET lets you embed images in a presentation’s shared image collection and display them on slides using PictureFrame forme. Le immagini possono anche essere usate come riempimenti di sfondo delle forme tramite FillType.Picture.


Aggiungere un’immagine da file

Carica i byte dell’immagine dal disco e aggiungili alla collezione di immagini della presentazione con prs.Images.AddImage(). Quindi posiziona l’immagine su una diapositiva come una PictureFrame:

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

using var prs = new Presentation();
// Add the image to the shared collection
var imageData = File.ReadAllBytes("logo.png");
var img = prs.Images.AddImage(imageData);

// Place it on the slide as a PictureFrame
var slide = prs.Slides[0];
slide.Shapes.AddPictureFrame(ShapeType.Rectangle, 50, 50, 300, 200, img);

prs.Save("with-image.pptx", SaveFormat.Pptx);

I quattro argomenti posizionali per AddPictureFrame() sono: x, y, width, height in punti.


Aggiungere un’immagine da uno stream

Se disponi di dati immagine da uno stream (ad es., scaricati da un URL o letti da un database), passali direttamente a AddImage():

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

using var prs = new Presentation();
using var stream = File.OpenRead("photo.jpg");
var img = prs.Images.AddImage(stream);
prs.Slides[0].Shapes.AddPictureFrame(ShapeType.Rectangle, 100, 80, 400, 250, img);
prs.Save("from-stream.pptx", SaveFormat.Pptx);

Posizionamento e dimensionamento di un PictureFrame

Il PictureFrame restituito da AddPictureFrame() eredita tutti i Shape proprietà geometriche e può essere riposizionato dopo la creazione:

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

using var prs = new Presentation();
var imageData = File.ReadAllBytes("photo.jpg");
var img = prs.Images.AddImage(imageData);

var pf = prs.Slides[0].Shapes.AddPictureFrame(ShapeType.Rectangle, 0, 0, 100, 100, img);

// Reposition and resize after creation
pf.X = 50;
pf.Y = 100;
pf.Width = 350;
pf.Height = 250;

prs.Save("positioned.pptx", SaveFormat.Pptx);

Usare un’immagine come riempimento di una forma

Qualsiasi forma (non solo PictureFrame) può usare un’immagine come riempimento di sfondo. Imposta FillType = FillType.Picture e assegna l’immagine a PictureFillFormat.Picture.Image:

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

using var prs = new Presentation();
var imageData = File.ReadAllBytes("background.png");
var img = prs.Images.AddImage(imageData);

var slide = prs.Slides[0];
var shape = slide.Shapes.AddAutoShape(ShapeType.RoundCornerRectangle, 50, 50, 400, 250);
shape.FillFormat.FillType = FillType.Picture;
shape.FillFormat.PictureFillFormat.PictureFillMode = PictureFillMode.Stretch;
shape.FillFormat.PictureFillFormat.Picture.Image = img;

prs.Save("picture-fill.pptx", SaveFormat.Pptx);

PictureFillMode.Stretch scala l’immagine per riempire l’intera forma.


Aggiungere più immagini tra le diapositive

Immagini aggiunte a prs.Images sono condivise su tutte le diapositive. Lo stesso oggetto immagine può essere usato su più diapositive senza duplicare i dati:

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

using var prs = new Presentation();
var logoData = File.ReadAllBytes("logo.png");
var logo = prs.Images.AddImage(logoData);

// Add the same image to the first slide
prs.Slides[0].Shapes.AddPictureFrame(ShapeType.Rectangle, 600, 10, 100, 40, logo);

prs.Save("shared-image.pptx", SaveFormat.Pptx);

Vedi anche

 Italiano