機能と特長
機能と特長
Aspose.Slides FOSS for Java は、PowerPoint .pptx ファイルをプログラムで操作するための幅広い機能を提供します。このページでは、代表的なコード例とともに、サポートされているすべての機能領域を一覧しています。
プレゼンテーション I/O
既存の.pptxファイルを開くか新規に作成し、PPTX形式で保存し直してください。
import org.aspose.slides.foss.Presentation;
import org.aspose.slides.foss.export.SaveFormat;
// Open an existing presentation
try (Presentation prs = new Presentation("input.pptx")) {
System.out.println("Slide count: " + prs.getSlides().size());
prs.save("output.pptx", SaveFormat.PPTX);
}
// Create a new presentation (starts with one blank slide)
try (Presentation prs = new Presentation()) {
prs.save("new.pptx", SaveFormat.PPTX);
}注: PPTX は唯一サポートされている保存形式です。PDF、HTML、SVG、または画像へのエクスポートは利用できません。
ソースファイル内の不明な XML パーツは保存時に verbatim で保持されるため、.pptx を開いて再保存しても、ライブラリがまだ理解できないコンテンツが削除されることはありません。
スライド管理
スライドを追加、削除、複製、並べ替える。
import org.aspose.slides.foss.Presentation;
import org.aspose.slides.foss.export.SaveFormat;
try (Presentation prs = new Presentation()) {
// Access the first slide
var slide = prs.getSlides().get(0);
// Add an additional blank slide at the end
prs.getSlides().addEmptySlide(prs.getLayoutSlides().get(0));
System.out.println("Total slides: " + prs.getSlides().size());
prs.save("multi-slide.pptx", SaveFormat.PPTX);
}シェイプ
スライドに AutoShapes、PictureFrames、Tables、Connectors を追加します。
AutoShapes
import org.aspose.slides.foss.Presentation;
import org.aspose.slides.foss.ShapeType;
import org.aspose.slides.foss.export.SaveFormat;
try (Presentation prs = new Presentation()) {
var slide = prs.getSlides().get(0);
// Add a rectangle at (x=50, y=50) with width=300, height=100
var shape = slide.getShapes().addAutoShape(ShapeType.RECTANGLE, 50, 50, 300, 100);
shape.addTextFrame("Aspose.Slides FOSS");
prs.save("shapes.pptx", SaveFormat.PPTX);
}テーブル
import org.aspose.slides.foss.Presentation;
import org.aspose.slides.foss.export.SaveFormat;
try (Presentation prs = new Presentation()) {
var slide = prs.getSlides().get(0);
// Column widths and row heights in points
double[] colWidths = {120.0, 120.0, 120.0};
double[] rowHeights = {40.0, 40.0, 40.0};
var table = slide.getShapes().addTable(50, 50, colWidths, rowHeights);
table.getRows().get(0).get(0).getTextFrame().setText("Product");
table.getRows().get(0).get(1).getTextFrame().setText("Quantity");
table.getRows().get(0).get(2).getTextFrame().setText("Price");
prs.save("table.pptx", SaveFormat.PPTX);
}コネクタ
import org.aspose.slides.foss.Presentation;
import org.aspose.slides.foss.ShapeType;
import org.aspose.slides.foss.export.SaveFormat;
try (Presentation prs = new Presentation()) {
var slide = prs.getSlides().get(0);
var box1 = slide.getShapes().addAutoShape(ShapeType.RECTANGLE, 50, 100, 150, 60);
var box2 = slide.getShapes().addAutoShape(ShapeType.RECTANGLE, 350, 100, 150, 60);
var conn = slide.getShapes().addConnector(ShapeType.BENT_CONNECTOR3, 0, 0, 10, 10);
conn.setStartShapeConnectedTo(box1);
conn.setStartShapeConnectionSiteIndex(3); // right side
conn.setEndShapeConnectedTo(box2);
conn.setEndShapeConnectionSiteIndex(1); // left side
prs.save("connector.pptx", SaveFormat.PPTX);
}テキストの書式設定
PortionFormat を使用して段落および文字レベルでテキストをフォーマットします。
import org.aspose.slides.foss.Presentation;
import org.aspose.slides.foss.ShapeType;
import org.aspose.slides.foss.NullableBool;
import org.aspose.slides.foss.FillType;
import org.aspose.slides.foss.drawing.Color;
import org.aspose.slides.foss.export.SaveFormat;
try (Presentation prs = new Presentation()) {
var slide = prs.getSlides().get(0);
var shape = slide.getShapes().addAutoShape(ShapeType.RECTANGLE, 50, 50, 500, 150);
var tf = shape.addTextFrame("Bold blue heading");
var fmt = tf.getParagraphs().get(0).getPortions().get(0).getPortionFormat();
fmt.setFontHeight(28);
fmt.setFontBold(NullableBool.TRUE);
fmt.getFillFormat().setFillType(FillType.SOLID);
fmt.getFillFormat().getSolidFillColor().setColor(Color.fromArgb(255, 0, 70, 127));
prs.save("text.pptx", SaveFormat.PPTX);
}NullableBool.TRUE はプロパティを明示的に設定します; NullableBool.NOT_DEFINED はスライドマスターから継承します。
塗りつぶしタイプ
形状に単色、グラデーション、パターン、または画像の塗りつぶしを適用します。
import org.aspose.slides.foss.Presentation;
import org.aspose.slides.foss.ShapeType;
import org.aspose.slides.foss.FillType;
import org.aspose.slides.foss.drawing.Color;
import org.aspose.slides.foss.export.SaveFormat;
try (Presentation prs = new Presentation()) {
var slide = prs.getSlides().get(0);
var shape = slide.getShapes().addAutoShape(ShapeType.RECTANGLE, 50, 50, 300, 150);
// Solid fill
shape.getFillFormat().setFillType(FillType.SOLID);
shape.getFillFormat().getSolidFillColor().setColor(Color.fromArgb(255, 30, 120, 200));
prs.save("fill.pptx", SaveFormat.PPTX);
}ビジュアルエフェクト
シェイプに外側の影、グロー、ソフトエッジ、ぼかし、反射、内部の影を適用します。
効果プロパティはshape.getEffectFormat()からアクセスできます。enableOuterShadowEffect()、enableGlowEffect()、enableSoftEdgeEffect()、setBlurEffect(radius, grow)、enableReflectionEffect()、またはenableInnerShadowEffect()を呼び出して、それぞれを個別に構成します。
3D フォーマット
shape.getThreeDFormat() を使用して 3D ベベル、カメラ、ライトリグ、マテリアル、押し出し深さを適用します。これにより、3D 効果をサポートする PPTX ビューアでのシェイプ描画の視覚的深さと照明モデルが制御されます。
スピーカーノート
getNotesSlideManager() を使用して任意のスライドにノートを添付します。
import org.aspose.slides.foss.Presentation;
import org.aspose.slides.foss.export.SaveFormat;
try (Presentation prs = new Presentation()) {
var notes = prs.getSlides().get(0).getNotesSlideManager().addNotesSlide();
notes.getNotesTextFrame().setText("Key talking point: emphasize the ROI benefit.");
prs.save("notes.pptx", SaveFormat.PPTX);
}コメント
著者情報とスライド位置を含むスレッドコメントを追加する。
import org.aspose.slides.foss.Presentation;
import org.aspose.slides.foss.drawing.PointF;
import org.aspose.slides.foss.export.SaveFormat;
import java.time.LocalDateTime;
try (Presentation prs = new Presentation()) {
var author = prs.getCommentAuthors().addAuthor("Jane Smith", "JS");
var slide = prs.getSlides().get(0);
author.getComments().addComment(
"Please verify this data before the presentation.",
slide,
new PointF(2.0f, 2.0f),
LocalDateTime.now()
);
prs.save("comments.pptx", SaveFormat.PPTX);
}埋め込み画像
ファイルから画像をプレゼンテーションに埋め込み、スライドにPictureFrameとして追加します。
import org.aspose.slides.foss.Presentation;
import org.aspose.slides.foss.ShapeType;
import org.aspose.slides.foss.export.SaveFormat;
import java.nio.file.Files;
import java.nio.file.Path;
try (Presentation prs = new Presentation()) {
byte[] imageData = Files.readAllBytes(Path.of("logo.png"));
var image = prs.getImages().addImage(imageData);
var slide = prs.getSlides().get(0);
slide.getShapes().addPictureFrame(ShapeType.RECTANGLE, 50, 50, 200, 150, image);
prs.save("with-image.pptx", SaveFormat.PPTX);
}ドキュメント プロパティ
コア、アプリ、カスタムのドキュメント プロパティを読み書きします。
import org.aspose.slides.foss.Presentation;
import org.aspose.slides.foss.export.SaveFormat;
try (Presentation prs = new Presentation()) {
var props = prs.getDocumentProperties();
// Core properties
props.setTitle("Q1 Results");
props.setAuthor("Finance Team");
props.setSubject("Quarterly Review");
props.setKeywords("Q1, finance, results");
// Custom property
props.setCustomPropertyValue("ReviewedBy", "Legal Team");
prs.save("deck.pptx", SaveFormat.PPTX);
}既知の制限
以下の領域は UnsupportedOperationException を発生させ、このエディションでは利用できません:
| 領域 | ステータス |
|---|---|
| チャート | 未実装 |
| SmartArt | 未実装 |
| アニメーションとトランジション | 未実装 |
| PDF / HTML / SVG / 画像エクスポート | 未実装 (PPTX のみ) |
| VBA マクロ | 未実装 |
| デジタル署名 | 未実装 |
| ハイパーリンクとアクション設定 | 未実装 |
| OLE オブジェクト | 未実装 |
| 数式テキスト | 未実装 |
参照
- はじめに: インストールと最初のプログラム
- API リファレンス: クラスとメソッドのリファレンス
- ハウツーガイド: タスク指向の記事