Javaでプレゼンテーションスライドを画像に変換

概要

Aspose.Slides for Java は、PowerPoint および OpenDocument のプレゼンテーション スライドを BMP、PNG、JPG(JPEG)、GIF などのさまざまな画像形式に簡単に変換できるようにします。

スライドを画像に変換するには、次の手順に従います。

  1. 変換設定を定義し、エクスポートしたいスライドを次のいずれかで選択します:
  2. getImage メソッドを呼び出してスライド画像を生成します。

Aspose.Slides for Java では、IImage はピクセル データで定義された画像を操作できるインターフェイスです。このインターフェイスを使用して、さまざまな形式(BMP、JPG、PNG など)で画像を保存できます。

スライドをビットマップに変換し、PNG で画像を保存

スライドをビットマップ オブジェクトに変換してアプリケーションで直接使用できます。または、スライドをビットマップに変換し、JPEG などの好みの形式で画像を保存することもできます。

このコードは、プレゼンテーションの最初のスライドをビットマップ オブジェクトに変換し、PNG 形式で画像を保存する方法を示しています:

Presentation presentation = new Presentation("Presentation.pptx");
try {
    // プレゼンテーションの最初のスライドをビットマップに変換します。
    IImage image = presentation.getSlides().get_Item(0).getImage();
	try {
        // 画像を PNG 形式で保存します。
        image.save("Slide_0.png", ImageFormat.Png);
    } finally {
        image.dispose();
    }
} finally {
    presentation.dispose();
}

カスタムサイズでスライドを画像に変換

特定のサイズの画像が必要になる場合があります。getImage のオーバーロードを使用すると、幅と高さの特定の寸法でスライドを画像に変換できます。

このサンプルコードは、その方法を示しています:

Dimension imageSize = new Dimension(1820, 1040);

Presentation presentation = new Presentation("Presentation.pptx");
try {
    // プレゼンテーションの最初のスライドを、指定されたサイズでビットマップに変換します。
    IImage image = presentation.getSlides().get_Item(0).getImage(imageSize);

    try {
        // 画像を JPEG 形式で保存します。
        image.save("Slide_0.jpg", ImageFormat.Jpeg);
    } finally {
        image.dispose();
    }
} finally {
    presentation.dispose();
}

ノートとコメント付きスライドを画像に変換

スライドによってはノートやコメントが含まれている場合があります。

Aspose.Slides は、ITiffOptionsIRenderingOptions の 2 つのインターフェイスを提供し、プレゼンテーション スライドを画像にレンダリングする際に制御できます。両インターフェイスには setSlidesLayoutOptions メソッドが含まれており、スライドを画像に変換する際にノートやコメントのレンダリングを設定できます。

NotesCommentsLayoutingOptions クラスを使用すると、生成される画像内のノートとコメントの位置を希望どおりに指定できます。

このコードは、ノートとコメントを含むスライドを変換する方法を示しています:

float scaleX = 2;
float scaleY = scaleX;

// プレゼンテーション ファイルを読み込みます。
Presentation presentation = new Presentation("Presentation_with_notes_and_comments.pptx");
try {
    NotesCommentsLayoutingOptions notesCommentsOptions = new NotesCommentsLayoutingOptions();
    notesCommentsOptions.setNotesPosition(NotesPositions.BottomTruncated);  // ノートの位置を設定します。
    notesCommentsOptions.setCommentsPosition(CommentsPositions.Right);      // コメントの位置を設定します。
    notesCommentsOptions.setCommentsAreaWidth(500);                         // コメント領域の幅を設定します。
    notesCommentsOptions.setCommentsAreaColor(Color.LIGHT_GRAY);            // コメント領域の色を設定します。

    // レンダリング オプションを作成します。
    RenderingOptions options = new RenderingOptions();
    options.setSlidesLayoutOptions(notesCommentsOptions);

    // プレゼンテーションの最初のスライドを画像に変換します。
    IImage image = presentation.getSlides().get_Item(0).getImage(options, scaleX, scaleY);

    try {
        // 画像を GIF 形式で保存します。
        image.save("Image_with_notes_and_comments_0.gif", ImageFormat.Gif);
    } finally {
        image.dispose();
    }
} finally {
    presentation.dispose();
}

TIFF オプションを使用してスライドを画像に変換

ITiffOptions インターフェイスは、サイズ、解像度、カラーパレットなどのパラメータを指定でき、生成される TIFF 画像をより細かく制御できます。

このコードは、TIFF オプションを使用して 300 DPI の解像度で 2160 × 2800 のサイズの白黒画像を出力する変換プロセスを示しています:

// プレゼンテーション ファイルを読み込みます。
Presentation presentation = new Presentation("sample.pptx");
try {
    // プレゼンテーションから最初のスライドを取得します。
    ISlide slide = presentation.getSlides().get_Item(0);

    // 出力 TIFF 画像の設定を構成します。
    TiffOptions tiffOptions = new TiffOptions();
    tiffOptions.setImageSize(new Dimension(2160, 2880));             // 画像サイズを設定します。
    tiffOptions.setPixelFormat(ImagePixelFormat.Format1bppIndexed);  // ピクセルフォーマットを設定します(白黒)。
    tiffOptions.setDpiX(300);                                        // 横方向の解像度を設定します。
    tiffOptions.setDpiY(300);                                        // 縦方向の解像度を設定します。

    // 指定されたオプションでスライドを画像に変換します。
    IImage image = slide.getImage(tiffOptions);

    try {
        // 画像を TIFF 形式で保存します。
        image.save("output.tiff", ImageFormat.Tiff);
    } finally {
        image.dispose();
    }
} finally {
    presentation.dispose();
}

すべてのスライドを画像に変換

Aspose.Slides を使用すると、プレゼンテーション内のすべてのスライドを画像に変換でき、実質的にプレゼンテーション全体を画像の連続に変換できます。

このサンプルコードは、Java でプレゼンテーションのすべてのスライドを画像に変換する方法を示しています:

float scaleX = 2;
float scaleY = scaleX;

Presentation presentation = new Presentation("Presentation.pptx");
try {
    // プレゼンテーションをスライドごとに画像にレンダリングします。
    for (int i = 0 ; i < presentation.getSlides().size(); i++)
    {
        // 非表示スライドを制御します(非表示スライドはレンダリングしません)。
        if (presentation.getSlides().get_Item(i).getHidden())
            continue;

        // スライドを画像に変換します。
        IImage image = presentation.getSlides().get_Item(i).getImage(scaleX, scaleY);

        try {
            // 画像を JPEG 形式で保存します。
            image.save("Slide_" + i + ".jpg", ImageFormat.Jpeg);
        } finally {
            image.dispose();
        }
    }
} finally {
    presentation.dispose();
} 

FAQ

Aspose.Slides はアニメーション付きスライドのレンダリングをサポートしていますか?
いいえ、getImage メソッドはスライドの静的画像のみを保存し、アニメーションは含まれません。

非表示のスライドを画像としてエクスポートできますか?
はい、非表示のスライドも通常のスライドと同様に処理できます。処理ループに含めていることを確認してください。

画像を影やエフェクトとともに保存できますか?
はい、Aspose.Slides はスライドを画像として保存する際に、影、透明度、その他のグラフィック効果のレンダリングをサポートしています。