.NET でプレゼンテーションの SmartArt グラフィックを管理

スマートアート シェイプの作成

Aspose.Slides for .NET は、スライドにカスタムの SmartArt シェイプをゼロから追加できるようになりました。Aspose.Slides for .NET は、SmartArt シェイプを最も簡単に作成できるシンプルな API を提供しています。スライドに SmartArt シェイプを作成するには、以下の手順に従ってください。

  • Presentation クラスのインスタンスを作成します。
  • インデックスを使用してスライドの参照を取得します。
  • LayoutType を設定して SmartArt シェイプを追加します。
  • 変更したプレゼンテーションを書き出して PPTX ファイルとして保存します。
// プレゼンテーションのインスタンス化
using (Presentation pres = new Presentation())
{

    // プレゼンテーションのスライドにアクセス
    ISlide slide = pres.Slides[0];

    // Smart Art シェイプを追加
    ISmartArt smart = slide.Shapes.AddSmartArt(0, 0, 400, 400, SmartArtLayoutType.BasicBlockList);

    // プレゼンテーションを保存
    pres.Save("SimpleSmartArt_out.pptx", Aspose.Slides.Export.SaveFormat.Pptx);
}

スライド上の SmartArt シェイプへのアクセス

以下のコードは、プレゼンテーション スライドに追加された SmartArt シェイプにアクセスするために使用されます。サンプルコードでは、スライド内のすべてのシェイプを走査し、SmartArt シェイプかどうかを確認します。シェイプが SmartArt タイプの場合は、SmartArt インスタンスに型変換します。

// 目的のプレゼンテーションをロードする
using (Presentation pres = new Presentation("AccessSmartArtShape.pptx"))
{

    // 最初のスライド内のすべてのシェイプを走査する
    foreach (IShape shape in pres.Slides[0].Shapes)
    {
        // シェイプが SmartArt タイプかどうかを確認する
        if (shape is ISmartArt)
        {
            // シェイプを SmartArtEx に型変換する
            ISmartArt smart = (ISmartArt)shape;
            System.Console.WriteLine("Shape Name:" + smart.Name);

        }
    }
}

特定の Layout Type を持つ SmartArt シェイプへのアクセス

以下のサンプルコードは、特定の LayoutType を持つ SmartArt シェイプにアクセスするのに役立ちます。SmartArt の LayoutType は読み取り専用で、SmartArt シェイプが追加されたときにのみ設定されるため、変更できないことに注意してください。

  • Presentation クラスのインスタンスを作成し、SmartArt シェイプが含まれるプレゼンテーションをロードします。
  • インデックスを使用して最初のスライドの参照を取得します。
  • 最初のスライド内のすべてのシェイプを走査します。
  • シェイプが SmartArt タイプかどうかを確認し、SmartArt の場合は選択したシェイプを SmartArt に型変換します。
  • 特定の LayoutType を持つ SmartArt シェイプを確認し、その後に必要な処理を実行します。
using (Presentation presentation = new Presentation("AccessSmartArtShape.pptx"))
{
    // 最初のスライド内のすべてのシェイプを走査する
    foreach (IShape shape in presentation.Slides[0].Shapes)
    {
        // シェイプが SmartArt タイプかどうかを確認する
        if (shape is ISmartArt)
        {
            // シェイプを SmartArtEx に型変換する
            ISmartArt smart = (ISmartArt) shape;

            // SmartArt のレイアウトを確認する
            if (smart.Layout == SmartArtLayoutType.BasicBlockList)
            {
                Console.WriteLine("Do some thing here....");
            }
        }
    }
}

SmartArt シェイプのスタイルを変更する

以下のサンプルコードは、特定の LayoutType を持つ SmartArt シェイプにアクセスするのに役立ちます。

  • Presentation クラスのインスタンスを作成し、SmartArt シェイプが含まれるプレゼンテーションをロードします。
  • インデックスを使用して最初のスライドの参照を取得します。
  • 最初のスライド内のすべてのシェイプを走査します。
  • シェイプが SmartArt タイプかどうかを確認し、SmartArt の場合は選択したシェイプを SmartArt に型変換します。
  • 特定の Style を持つ SmartArt シェイプを見つけます。
  • SmartArt シェイプに新しい Style を設定します。
  • プレゼンテーションを保存します。
using (Presentation presentation = new Presentation("AccessSmartArtShape.pptx"))
{
    // 最初のスライド内のすべてのシェイプを走査する
    foreach (IShape shape in presentation.Slides[0].Shapes)
    {
        // シェイプが SmartArt タイプかどうかを確認する
        if (shape is ISmartArt)
        {
            // シェイプを SmartArtEx に型変換する
            ISmartArt smart = (ISmartArt)shape;

            // SmartArt のスタイルを確認する
            if (smart.QuickStyle == SmartArtQuickStyleType.SimpleFill)
            {
                // SmartArt のスタイルを変更する
                smart.QuickStyle = SmartArtQuickStyleType.Cartoon;
            }
        }
    }

    // プレゼンテーションを保存する
    presentation.Save("ChangeSmartArtStyle_out.pptx", SaveFormat.Pptx);
}

SmartArt シェイプのカラースタイルを変更する

この例では、任意の SmartArt シェイプのカラースタイルを変更する方法を学びます。以下のサンプルコードは、特定のカラー スタイルを持つ SmartArt シェイプにアクセスし、そのスタイルを変更します。

  • Presentation クラスのインスタンスを作成し、SmartArt シェイプが含まれるプレゼンテーションをロードします。
  • インデックスを使用して最初のスライドの参照を取得します。
  • 最初のスライド内のすべてのシェイプを走査します。
  • シェイプが SmartArt タイプかどうかを確認し、SmartArt の場合は選択したシェイプを SmartArt に型変換します。
  • 特定の Color Style を持つ SmartArt シェイプを見つけます。
  • SmartArt シェイプに新しい Color Style を設定します。
  • プレゼンテーションを保存します。
using (Presentation presentation = new Presentation("AccessSmartArtShape.pptx"))
{
    // 最初のスライド内のすべてのシェイプを走査する
    foreach (IShape shape in presentation.Slides[0].Shapes)
    {
        // シェイプが SmartArt タイプかどうかを確認する
        if (shape is ISmartArt)
        {
            // シェイプを SmartArtEx に型変換する
            ISmartArt smart = (ISmartArt)shape;

            // SmartArt のカラータイプを確認する
            if (smart.ColorStyle == SmartArtColorType.ColoredFillAccent1)
            {
                // SmartArt のカラータイプを変更する
                smart.ColorStyle = SmartArtColorType.ColorfulAccentColors;
            }
        }
    }

    // プレゼンテーションを保存する
    presentation.Save("ChangeSmartArtColorStyle_out.pptx", SaveFormat.Pptx);
}

FAQ

SmartArt を単一オブジェクトとしてアニメーション化できますか? はい。SmartArt はシェイプなので、他のシェイプと同様にアニメーション API を使用して 標準アニメーション(開始、終了、強調、動きのパス)を適用できます。

スライド上で内部 ID が分からない場合、特定の SmartArt をどのように見つけますか? 代替テキスト (AltText) を設定して使用し、その値でシェイプを検索します。これが対象シェイプを見つける推奨方法です。

SmartArt を他のシェイプとグループ化できますか? はい。SmartArt を他のシェイプ(画像、表など)とグループ化し、グループを操作することができます。

特定の SmartArt の画像(プレビューやレポート用など)を取得するにはどうすればよいですか? シェイプのサムネイル/画像をエクスポートします。ライブラリは個々のシェイプをラスターファイル(PNG/JPG/TIFF)に レンダリングできます。

プレゼンテーション全体を PDF に変換した際、SmartArt の外観は保持されますか? はい。レンダリング エンジンは PDF エクスポート において高忠実度を目指しており、さまざまな品質と互換性のオプションを提供します。