フォールバックフォントを使用したプレゼンテーションのレンダリング

Contents
[ ]

以下の例では、これらの手順が含まれています:

  1. フォールバックフォントルールのコレクションを作成します
  2. フォールバックフォントルールを削除し、別のルールにフォールバックフォントを追加します
  3. ルールのコレクションをgetFontsManagergetFontFallBackRulesCollectionメソッドに設定します。
  4. 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();
}