フォールバックフォントを使用したプレゼンテーションのレンダリング
Contents
[
Hide
]
以下の例では、これらの手順が含まれています:
- フォールバックフォントルールのコレクションを作成します。
- フォールバックフォントルールを削除し、別のルールにフォールバックフォントを追加します。
- ルールのコレクションをgetFontsManager。getFontFallBackRulesCollectionメソッドに設定します。
- Presentation.saveメソッドを使用して、同じフォーマットでプレゼンテーションを保存するか、別のフォーマットで保存できます。フォールバックフォントルールのコレクションをFontsManagerに設定すると、これらのルールはプレゼンテーションに対するすべての操作(保存、レンダリング、変換など)で適用されます。
// ルールコレクションの新しいインスタンスを作成
IFontFallBackRulesCollection rulesList = new FontFallBackRulesCollection();
// いくつかのルールを作成
rulesList.add(new FontFallBackRule(0x400, 0x4FF, "Times New Roman"));
for (IFontFallBackRule fallBackRule : rulesList)
{
// 読み込まれたルールからフォールバックフォント「Tahoma」を削除しようとしています
fallBackRule.remove("Tahoma");
// 指定された範囲のルールを更新します
if ((fallBackRule.getRangeEndIndex() >= 0x4000) && (fallBackRule.getRangeStartIndex() < 0x5000))
fallBackRule.addFallBackFonts("Verdana");
}
// リストから既存のルールを削除することもできます
if (rulesList.size() > 0)
rulesList.remove(rulesList.get_Item(0));
Presentation pres = new Presentation("input.pptx");
try {
// 使用するために準備されたルールリストを割り当て
pres.getFontsManager().setFontFallBackRulesCollection(rulesList);
// 初期化されたルールコレクションを使用してサムネイルをレンダリングしJPEGに保存
IImage slideImage = pres.getSlides().get_Item(0).getImage(1f, 1f);
// JPEG形式でディスクに画像を保存
try {
slideImage.save("Slide_0.jpg", ImageFormat.Jpeg);
} finally {
if (slideImage != null) slideImage.dispose();
}
} finally {
if (pres != null) pres.dispose();
}