.NET에서 PowerPoint 슬라이드에 이미지 추가하는 방법

.NET에서 PowerPoint 슬라이드에 이미지 추가하는 방법

Aspose.Slides FOSS의 이미지는 picture frames로 삽입되며, 이미지와 같은 다른 도형처럼 위치를 지정하고 크기를 조정하며 스타일을 적용할 수 있는 도형입니다. 이미지 데이터는 prs.Images 컬렉션에 한 번 저장되고 프레임에 의해 참조됩니다.


전제 조건

dotnet add package Aspose.Slides.Foss

파일에서 이미지 추가

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

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

// Load image into the presentation's image collection
byte[] imageData = File.ReadAllBytes("photo.jpg");
var img = prs.Images.AddImage(imageData);

// Add a picture frame at (x=50, y=50, width=400, height=300) in points
var frame = slide.Shapes.AddPictureFrame(
    ShapeType.Rectangle,
    50, 50, 400, 300,
    img
);

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

AddPictureFrame 서명:

AddPictureFrame(shapeType, x, y, width, height, image) -> PictureFrame

모든 치수는 포인트(1 포인트 = 1/72 인치) 단위입니다. 표준 10 x 7.5인치 슬라이드의 좌표 공간은 720 x 540 포인트입니다.


스트림에서 이미지 추가

이미지를 스트림으로 이미 가지고 있는 경우(예: URL에서 다운로드했거나 데이터베이스에서 읽은 경우):

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

using var prs = new Presentation();
using var stream = File.OpenRead("logo.png");
var img = prs.Images.AddImage(stream);

prs.Slides[0].Shapes.AddPictureFrame(
    ShapeType.Rectangle,
    200, 100, 300, 200,
    img
);
prs.Save("logo-slide.pptx", SaveFormat.Pptx);

채우기 모드 제어

PictureFrame에 있는 PictureFormat은 이미지가 프레임 경계에 채워지는 방식을 제어합니다:

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

using var prs = new Presentation();
byte[] texData = File.ReadAllBytes("texture.png");
var img = prs.Images.AddImage(texData);
var frame = prs.Slides[0].Shapes.AddPictureFrame(
    ShapeType.Rectangle, 50, 50, 600, 350, img
);

// STRETCH: scale image to fill the frame exactly (default)
frame.PictureFormat.PictureFillMode = PictureFillMode.Stretch;

// TILE: repeat the image in a grid pattern
// frame.PictureFormat.PictureFillMode = PictureFillMode.Tile;

prs.Save("filled.pptx", SaveFormat.Pptx);
PictureFillMode동작
Stretch이미지를 프레임에 맞게 확대하여 채우되, 종횡비는 무시합니다
Tile이미지를 타일 패턴으로 반복합니다

다른 슬라이드에 여러 이미지 추가

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

string[] imageFiles = { "slide1.jpg", "slide2.jpg", "slide3.jpg" };

using var prs = new Presentation();
var layout = prs.Slides[0].LayoutSlide;

// Ensure enough slides exist
while (prs.Slides.Count < imageFiles.Length)
    prs.Slides.AddEmptySlide(layout);

for (int i = 0; i < imageFiles.Length; i++)
{
    if (!File.Exists(imageFiles[i])) continue;
    var img = prs.Images.AddImage(File.ReadAllBytes(imageFiles[i]));
    prs.Slides[i].Shapes.AddPictureFrame(
        ShapeType.Rectangle, 0, 0, 720, 540, img
    );
}

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

기존 프레젠테이션에서 이미지 개수 세기

using Aspose.Slides.Foss;

using var prs = new Presentation("with-image.pptx");
Console.WriteLine($"Presentation contains {prs.Images.Count} image(s)");

prs.Images 컬렉션은 모든 슬라이드에서 공유됩니다: 그림 프레임이 여러 슬라이드에 나타나더라도 동일한 이미지 바이트가 한 번만 저장됩니다.


관련 항목

 한국어