Java에서 PowerPoint 프레젠테이션 만들기

Java에서 PowerPoint 프레젠테이션 만들기

Aspose.Slides FOSS for Java는 Microsoft Office에 대한 의존 없이 완전히 Java만으로 PowerPoint 프레젠테이션을 만들 수 있게 해줍니다. 이 가이드는 새 프레젠테이션을 만들고, 슬라이드와 도형을 추가하고, 텍스트를 서식 지정하고, 결과를 저장하는 방법을 보여줍니다.

단계별 가이드

1단계: Maven 의존성 추가

pom.xml에 Aspose.Slides FOSS를 추가하십시오. Java 21 이상이 필요합니다.

<dependency>
  <groupId>org.aspose.slides.foss</groupId>
  <artifactId>aspose-slides-foss</artifactId>
  <version>1.0.0</version>
</dependency>

설치 확인:

import org.aspose.slides.foss.Presentation;

Presentation prs = new Presentation();
prs.dispose();
System.out.println("Aspose.Slides FOSS ready");

2단계: 필요한 클래스 가져오기

저장에 필요한 Presentation 클래스와 SaveFormat 열거형을 가져오세요.

import org.aspose.slides.foss.Presentation;
import org.aspose.slides.foss.export.SaveFormat;
import org.aspose.slides.foss.ShapeType;
import org.aspose.slides.foss.ISlide;
import org.aspose.slides.foss.IAutoShape;

모든 도형 유형 상수는 org.aspose.slides.foss.ShapeType에 있습니다. 서식 지정 열거형(FillType, NullableBool)도 org.aspose.slides.foss에 있습니다.


3단계: 프레젠테이션 만들기

new Presentation()을 사용하여 try-with-resources로 감싸십시오. 새 프레젠테이션은 빈 슬라이드 하나로 시작합니다.

import org.aspose.slides.foss.Presentation;
import org.aspose.slides.foss.export.SaveFormat;

try (Presentation prs = new Presentation()) {
    System.out.println("Slides in new presentation: " + prs.getSlides().size());
    prs.save("output.pptx", SaveFormat.PPTX);
}

중요: 항상 try-with-resources를 사용하거나 finally 블록에서 prs.dispose()를 호출하십시오. 그렇지 않으면 리소스가 올바르게 해제되지 않습니다.


4단계: 슬라이드에 액세스

첫 번째 슬라이드는 인덱스 0에 있습니다. 빈 프레젠테이션에는 정확히 한 개의 슬라이드가 있습니다.

try (Presentation prs = new Presentation()) {
    ISlide slide = prs.getSlides().get(0);  // zero-based index
    System.out.println("Slide at index 0: " + slide);
    prs.save("output.pptx", SaveFormat.PPTX);
}

5단계: 도형 추가

slide.getShapes().addAutoShape()을 사용하여 AutoShape을 추가합니다. 매개변수는 (shapeType, x, y, width, height)이며 모두 포인트 단위입니다 (1포인트 = 1/72인치; 표준 슬라이드는 720 x 540 pt).

import org.aspose.slides.foss.Presentation;
import org.aspose.slides.foss.ISlide;
import org.aspose.slides.foss.IAutoShape;
import org.aspose.slides.foss.ITextFrame;
import org.aspose.slides.foss.IPortionFormat;
import org.aspose.slides.foss.ITable;
import org.aspose.slides.foss.ILayoutSlide;
import org.aspose.slides.foss.ShapeType;
import org.aspose.slides.foss.FillType;
import org.aspose.slides.foss.NullableBool;
import org.aspose.slides.foss.export.SaveFormat;
import org.aspose.slides.foss.drawing.Color;

try (Presentation prs = new Presentation()) {
    ISlide slide = prs.getSlides().get(0);

    // Rectangle at (50, 50) with 400 wide and 120 tall
    IAutoShape shape = slide.getShapes().addAutoShape(
        ShapeType.RECTANGLE, 50, 50, 400, 120
    );

    // Attach a text frame
    shape.addTextFrame("Hello from Aspose.Slides FOSS!");

    prs.save("with-shape.pptx", SaveFormat.PPTX);
}

6단계: 프레젠테이션 저장

try 블록이 종료되기 전에 prs.save(path, SaveFormat.PPTX)를 호출하십시오. PPTX는 유일하게 지원되는 출력 형식입니다.

prs.save("result.pptx", SaveFormat.PPTX);

파일은 원자적으로 기록됩니다. 이 호출 전에 오류가 발생하면 출력 파일이 생성되지 않습니다.


완전한 작업 예제

다음 프로그램은 첫 번째 슬라이드에 제목 도형이 있고 두 번째 슬라이드에 표가 포함된 두 슬라이드 프레젠테이션을 생성합니다.

import org.aspose.slides.foss.Presentation;
import org.aspose.slides.foss.ISlide;
import org.aspose.slides.foss.IAutoShape;
import org.aspose.slides.foss.ITextFrame;
import org.aspose.slides.foss.IPortionFormat;
import org.aspose.slides.foss.ITable;
import org.aspose.slides.foss.ILayoutSlide;
import org.aspose.slides.foss.ShapeType;
import org.aspose.slides.foss.FillType;
import org.aspose.slides.foss.NullableBool;
import org.aspose.slides.foss.export.SaveFormat;
import org.aspose.slides.foss.drawing.Color;

public class CreatePresentation {
    public static void main(String[] args) {
        try (Presentation prs = new Presentation()) {
            // --- Slide 1: title shape ---
            ISlide slide1 = prs.getSlides().get(0);
            IAutoShape title = slide1.getShapes().addAutoShape(
                ShapeType.RECTANGLE, 40, 40, 640, 80
            );
            ITextFrame tf = title.addTextFrame("Q1 Results: Executive Summary");
            IPortionFormat fmt = tf.getParagraphs().get(0)
                .getPortions().get(0).getPortionFormat();
            fmt.setFontHeight(32);
            fmt.setFontBold(NullableBool.TRUE);
            fmt.getFillFormat().setFillType(FillType.SOLID);
            fmt.getFillFormat().getSolidFillColor().setColor(
                Color.fromArgb(255, 0, 70, 127)
            );

            // --- Slide 2: table ---
            prs.getSlides().addEmptySlide(prs.getLayoutSlides().get(0));
            ISlide slide2 = prs.getSlides().get(1);
            ITable table = slide2.getShapes().addTable(
                40, 40,
                new double[]{200.0, 120.0, 120.0},
                new double[]{40.0, 40.0, 40.0}
            );
            String[] headers = {"Region", "Revenue", "Growth"};
            String[][] data = {
                {"North", "$1.2M", "+8%"},
                {"South", "$0.9M", "+4%"},
            };
            for (int col = 0; col < headers.length; col++) {
                table.getRows().get(0).get(col).getTextFrame().setText(headers[col]);
            }
            for (int row = 0; row < data.length; row++) {
                for (int col = 0; col < data[row].length; col++) {
                    table.getRows().get(row + 1).get(col)
                        .getTextFrame().setText(data[row][col]);
                }
            }

            prs.save("q1-results.pptx", SaveFormat.PPTX);
        }
        System.out.println("Saved q1-results.pptx");
    }
}

일반적인 문제 및 해결책

IllegalStateException: Presentation already disposed

try-with-resources 블록이 종료된 후에 Presentation 객체의 메서드를 호출하고 있습니다. 모든 작업을 try 블록 안에 유지하십시오.

저장 시 UnsupportedOperationException

PPTX 이외의 저장 형식을 시도하거나 지원되지 않는 기능(차트 또는 애니메이션 등)을 사용할 때 발생합니다.

도형이 슬라이드의 표시 영역 밖에 표시됨

슬라이드는 기본적으로 720 x 540 포인트입니다. x + width <= 720y + height <= 540을 유지하십시오.


자주 묻는 질문

기본 슬라이드 크기는 무엇인가요?

새로운 Presentation()은 표준 10 x 7.5인치(720 x 540 포인트) 크기의 슬라이드를 생성합니다. 이 버전에서는 슬라이드 크기 변경을 아직 지원하지 않습니다.

여러 슬라이드를 추가할 수 있나요?

예. prs.getSlides().addEmptySlide(prs.getLayoutSlides().get(0))를 호출하여 빈 슬라이드를 추가하고 인덱스로 접근하십시오:

prs.getSlides().addEmptySlide(prs.getLayoutSlides().get(0));
ISlide slide2 = prs.getSlides().get(1);

기존 파일을 열고 슬라이드를 추가할 수 있나요?

예:

try (Presentation prs = new Presentation("existing.pptx")) {
    prs.getSlides().addEmptySlide(prs.getLayoutSlides().get(0));
    prs.save("existing.pptx", SaveFormat.PPTX);
}

어떤 형식으로 저장할 수 있나요?

SaveFormat.PPTX만 지원됩니다. 이 버전에서는 PDF, HTML, SVG 또는 이미지로 내보내기를 사용할 수 없습니다.


참고 항목

 한국어