Javaでプレゼンテーションスライドを画像に変換
概要
Aspose.Slides for Java は、PowerPoint および OpenDocument のプレゼンテーション スライドを BMP、PNG、JPG(JPEG)、GIF などのさまざまな画像形式に簡単に変換できるようにします。
スライドを画像に変換するには、次の手順に従います。
- 変換設定を定義し、エクスポートしたいスライドを次のいずれかで選択します:
- ITiffOptions インターフェイス、または
- IRenderingOptions インターフェイス。
- 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 は、ITiffOptions と IRenderingOptions の 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();
}
Note
スライドから画像への変換プロセスでは、ノートの位置を指定するBottomFull を setNotesPosition メソッドで適用できません。ノートのテキストが大きすぎて、指定された画像サイズに収まらない可能性があるためです。
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();
}
Note
TIFF のサポートは JDK 9 未満のバージョンでは保証されません。すべてのスライドを画像に変換
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 はスライドを画像として保存する際に、影、透明度、その他のグラフィック効果のレンダリングをサポートしています。