Android で PPT と PPTX を PDF に変換(高度な機能を含む)
概要
Android で PowerPoint プレゼンテーション(PPT、PPTX、ODP など)を PDF 形式に変換すると、さまざまなデバイス間での互換性や、プレゼンテーションのレイアウトと書式を保持できるという利点があります。このガイドでは、プレゼンテーションを PDF に変換する方法、画像品質を制御するオプション、非表示スライドの含め方、PDF のパスワード保護、フォント置換の検出、変換対象スライドの選択、出力ドキュメントへのコンプライアンス基準の適用方法を示します。
PowerPoint から PDF への変換
Aspose.Slides を使用すると、次の形式のプレゼンテーションを PDF に変換できます。
- PPT
- PPTX
- ODP
プレゼンテーションを PDF に変換するには、ファイル名を Presentation クラスの引数として渡し、save メソッドで PDF として保存します。Presentation クラスは、プレゼンテーションを PDF に変換するためによく使用される save メソッドを公開しています。
NOTE
Aspose.Slides for Android via Java は、API 情報とバージョン番号を出力ドキュメントに埋め込みます。たとえば、プレゼンテーションを PDF に変換すると、Application フィールドに「Aspose.Slides」が、PDF Producer フィールドに「Aspose.Slides v XX.XX」という形式の値が設定されます。注意:この情報を出力ドキュメントから変更または削除するよう指示することはできません。Aspose.Slides は次の変換をサポートします。
- プレゼンテーション全体を PDF に変換
- プレゼンテーションの特定スライドを PDF に変換
Aspose.Slides はプレゼンテーションを PDF にエクスポートし、元のプレゼンテーションに極めて近い結果を生成します。変換時に正確に描画される要素と属性は次のとおりです。
- 画像
- テキストボックスと図形
- テキスト書式
- 段落書式
- ハイパーリンク
- ヘッダーとフッター
- 箇条書き
- 表
PowerPoint を PDF に変換
標準の PowerPoint から PDF への変換プロセスはデフォルトオプションを使用します。この場合、Aspose.Slides は最大品質レベルで最適な設定を用いてプレゼンテーションを PDF に変換しようとします。
以下のコードは、プレゼンテーション(PPT、PPTX、ODP など)を PDF に変換する方法を示しています。
// PowerPointまたはOpenDocumentファイルを表すPresentationクラスのインスタンスを作成します。
Presentation presentation = new Presentation("PowerPoint.ppt");
try {
// プレゼンテーションをPDFとして保存します。
presentation.save("PPT-to-PDF.pdf", SaveFormat.Pdf);
} finally {
presentation.dispose();
}
オプション付きで PowerPoint を PDF に変換
Aspose.Slides は、PdfOptions クラスのプロパティとして提供されるカスタムオプションを使用して、生成される PDF をカスタマイズしたり、パスワードでロックしたり、変換プロセスの動作を指定したりできます。
カスタムオプションで PowerPoint を PDF に変換
カスタム変換オプションを使用すると、ラスター画像の品質設定、メタファイルの処理方法、テキストの圧縮レベル、画像の DPI などを指定できます。
以下のコード例は、いくつかのカスタムオプションを使用して PowerPoint プレゼンテーションを PDF に変換する方法を示しています。
// PdfOptions クラスのインスタンスを作成します。
PdfOptions pdfOptions = new PdfOptions();
// JPG 画像の品質を設定します。
pdfOptions.setJpegQuality((byte)90);
// 画像の DPI を設定します。
pdfOptions.setSufficientResolution(300);
/// メタファイルの動作を設定します。
pdfOptions.setSaveMetafilesAsPng(true);
// テキストコンテンツの圧縮レベルを設定します。
pdfOptions.setTextCompression(PdfTextCompression.Flate);
// PDF コンプライアンスモードを定義します。
pdfOptions.setCompliance(PdfCompliance.Pdf15);
// PowerPoint または OpenDocument ファイルを表す Presentation クラスのインスタンスを作成します。
Presentation presentation = new Presentation("PowerPoint.pptx");
try {
// プレゼンテーションを PDF ドキュメントとして保存します。
presentation.save("PowerPoint-to-PDF.pdf", SaveFormat.Pdf, pdfOptions);
} finally {
presentation.dispose();
}
非表示スライドを含めて PowerPoint を PDF に変換
プレゼンテーションに非表示スライドが含まれている場合、PdfOptions クラスの setShowHiddenSlides メソッドを使用して、非表示スライドを結果の PDF のページとして含めることができます。
このコードは、非表示スライドを含めて PowerPoint プレゼンテーションを PDF に変換する方法を示しています。
// PowerPoint または OpenDocument ファイルを表す Presentation クラスのインスタンスを作成します。
Presentation presentation = new Presentation("PowerPoint.pptx");
try {
// PdfOptions クラスのインスタンスを作成します。
PdfOptions pdfOptions = new PdfOptions();
// 非表示スライドを追加します。
pdfOptions.setShowHiddenSlides(true);
// プレゼンテーションを PDF として保存します。
presentation.save("PowerPoint-to-PDF.pdf", SaveFormat.Pdf, pdfOptions);
} finally {
presentation.dispose();
}
パスワード保護された PDF に PowerPoint を変換
このコードは、PdfOptions クラスの保護パラメータを使用して、PowerPoint プレゼンテーションをパスワード保護された PDF に変換する方法を示しています。
// PowerPoint または OpenDocument ファイルを表す Presentation クラスのインスタンスを作成します。
Presentation presentation = new Presentation("PowerPoint.pptx");
try {
// PdfOptions クラスのインスタンスを作成します。
PdfOptions pdfOptions = new PdfOptions();
// PDF のパスワードとアクセス許可を設定します。
pdfOptions.setPassword("password");
pdfOptions.setAccessPermissions(PdfAccessPermissions.PrintDocument | PdfAccessPermissions.HighQualityPrint);
// プレゼンテーションを PDF として保存します。
presentation.save("PPTX-to-PDF.pdf", SaveFormat.Pdf, pdfOptions);
} finally {
presentation.dispose();
}
フォント置換の検出
Aspose.Slides は、PdfOptions クラスの下にある setWarningCallback メソッドを提供しており、プレゼンテーションから PDF への変換プロセス中にフォント置換を検出できます。
以下のコードは、フォント置換を検出する方法を示しています。
public static void main(String[] args) {
// PowerPoint または OpenDocument ファイルを表す Presentation クラスのインスタンスを作成します。
Presentation presentation = new Presentation("sample.pptx");
// PDF オプションで警告コールバックを設定します。
PdfOptions pdfOptions = new PdfOptions();
pdfOptions.setWarningCallback(new FontSubstitutionHandler());
// プレゼンテーションを PDF として保存します。
presentation.save("output.pdf", SaveFormat.Pdf, pdfOptions);
}
// 警告コールバックの実装です。
private static class FontSubstitutionHandler implements IWarningCallback {
public int warning(IWarningInfo warning) {
if (warning.getWarningType() == WarningType.DataLoss &&
warning.getDescription().startsWith("Font will be substituted")) {
System.out.println("Font substitution warning: " + warning.getDescription());
}
return ReturnAction.Continue;
}
}
選択したスライドだけを PowerPoint から PDF に変換
このコードは、PowerPoint プレゼンテーションから特定のスライドだけを PDF に変換する方法を示しています。
// PowerPoint または OpenDocument ファイルを表す Presentation クラスのインスタンスを作成します。
Presentation presentation = new Presentation("PowerPoint.pptx");
try {
// スライド番号の配列を設定します。
int[] slides = { 1, 3 };
// プレゼンテーションを PDF として保存します。
presentation.save("PPTX-to-PDF.pdf", slides, SaveFormat.Pdf);
} finally {
presentation.dispose();
}
カスタムスライドサイズで PowerPoint を PDF に変換
このコードは、指定したスライドサイズで PowerPoint プレゼンテーションを PDF に変換する方法を示しています。
float slideWidth = 612;
float slideHeight = 792;
// PowerPoint または OpenDocument ファイルを表す Presentation クラスのインスタンスを作成します。
Presentation presentation = new Presentation("SelectedSlides.pptx");
// 調整されたスライドサイズで新しいプレゼンテーションを作成します。
Presentation resizedPresentation = new Presentation();
try {
// カスタムスライドサイズを設定します。
resizedPresentation.getSlideSize().setSize(slideWidth, slideHeight, SlideSizeScaleType.EnsureFit);
// 元のプレゼンテーションから最初のスライドをクローンします。
ISlide slide = presentation.getSlides().get_Item(0);
resizedPresentation.getSlides().insertClone(0, slide);
// リサイズしたプレゼンテーションをノート付きの PDF として保存します。
resizedPresentation.save("PDF_with_notes.pdf", SaveFormat.Pdf);
} finally {
resizedPresentation.dispose();
presentation.dispose();
}
ノート付きスライドビューで PowerPoint を PDF に変換
このコードは、ノートを含む PDF を生成するために PowerPoint プレゼンテーションを変換する方法を示しています。
// PowerPoint または OpenDocument ファイルを表す Presentation クラスのインスタンスを作成します。
Presentation presentation = new Presentation("SelectedSlides.pptx");
try {
// PDF オプションをノートレイアウトで設定します。
NotesCommentsLayoutingOptions notesOptions = new NotesCommentsLayoutingOptions();
notesOptions.setNotesPosition(NotesPositions.BottomFull);
PdfOptions pdfOptions = new PdfOptions();
pdfOptions.setSlidesLayoutOptions(notesOptions);
// プレゼンテーションをノート付きの PDF として保存します。
presentation.save("PDF_with_notes.pdf", SaveFormat.Pdf, pdfOptions);
} finally {
presentation.dispose();
}
PDF のアクセシビリティとコンプライアンス基準
Aspose.Slides は、Web Content Accessibility Guidelines (WCAG) に準拠した変換手順を使用できます。次のコンプライアンス標準のいずれかを使用して PowerPoint ドキュメントを PDF にエクスポートできます:PDF/A1a、PDF/A1b、PDF/UA。
以下のコードは、異なるコンプライアンス基準に基づいて複数の PDF を生成する PowerPoint から PDF への変換プロセスを示しています。
Presentation presentation = new Presentation("pres.pptx");
try {
PdfOptions pdfOptions = new PdfOptions();
pdfOptions.setCompliance(PdfCompliance.PdfA1a);
presentation.save("pres-a1a-compliance.pdf", SaveFormat.Pdf, pdfOptions);
pdfOptions.setCompliance(PdfCompliance.PdfA1b);
presentation.save("pres-a1b-compliance.pdf", SaveFormat.Pdf, pdfOptions);
pdfOptions.setCompliance(PdfCompliance.PdfUa);
presentation.save("pres-ua-compliance.pdf", SaveFormat.Pdf, pdfOptions);
} finally {
presentation.dispose();
}
Note
Aspose.Slides は PDF 変換操作もサポートしており、PDF を一般的なファイル形式に変換できます。たとえば、PDF から HTML、PDF から画像、PDF から JPG、PDF から PNG への変換が可能です。さらに、PDF から SVG、PDF から TIFF、PDF から XML への専門形式への変換もサポートされています。注記:PDF/UA にエクスポートする場合、Aspose.Slides は SmartArt、チャート、数式などの複雑なグラフィックを単一の図形として扱います。個々のパス要素は別個のコンテンツとして保持されず、アーティファクトとしてマークされる可能性があります。代替テキストは全体の図形に対してのみ提供されます。
FAQ
複数の PowerPoint ファイルを一括で PDF に変換できますか?
はい、Aspose.Slides は複数の PPT または PPTX ファイルをバッチ変換して PDF にすることをサポートしています。ファイルを列挙し、プログラムから変換処理を適用できます。
変換後の PDF をパスワードで保護できますか?
もちろんです。PdfOptions クラスを使用して、変換時にパスワードとアクセス許可を設定できます。
PDF に非表示スライドを含めるにはどうすればよいですか?
PdfOptions クラスの setShowHiddenSlides メソッドを使用して、結果の PDF に非表示スライドを含めることができます。
Aspose.Slides は PDF の画像品質を高く保てますか?
はい、PdfOptions クラスの setJpegQuality や setSufficientResolution などのメソッドを使用して、PDF 内の画像を高品質に保つことができます。
Aspose.Slides は PDF/A コンプライアンス標準をサポートしていますか?
はい、Aspose.Slides は PDF/A1a、PDF/A1b、PDF/UA などのさまざまな標準に準拠した PDF のエクスポートをサポートし、アクセシビリティとアーカイブ要件を満たすことができます。