PowerPoint プレゼンテーションで Java を使用して SmartArt を管理する

SmartArt オブジェクトからテキストを取得する

現在、TextFrame メソッドが ISmartArtShape インターフェイスと SmartArtShape クラスにそれぞれ追加されました。このプロパティを使用すると、ノードのテキストだけでなく SmartArt からすべてのテキストを取得できます。以下のサンプルコードは SmartArt ノードからテキストを取得するのに役立ちます。

Presentation pres = new Presentation("Presentation.pptx");
try {
    ISlide slide = pres.getSlides().get_Item(0);
    ISmartArt smartArt = (ISmartArt)slide.getShapes().get_Item(0);

    ISmartArtNodeCollection smartArtNodes = smartArt.getAllNodes();
    for (ISmartArtNode smartArtNode : smartArtNodes)
    {
        for (ISmartArtShape nodeShape : smartArtNode.getShapes())
        {
            if (nodeShape.getTextFrame() != null)
                System.out.println(nodeShape.getTextFrame().getText());
        }
    }
} finally {
    if (pres != null) pres.dispose();
}

SmartArt オブジェクトのレイアウトタイプを変更する

SmartArt のレイアウトタイプを変更するには、以下の手順に従ってください:

  • Presentation クラスのインスタンスを作成します。
  • インデックスを使用してスライドの参照を取得します。
  • BasicBlockList の SmartArt を追加します。
  • LayoutType を BasicProcess に変更します。
  • プレゼンテーションを書き出して PPTX ファイルにします。

以下の例では、二つの図形の間にコネクタを追加しています。

Presentation pres = new Presentation();
try {
    // SmartArt BasicProcess を追加
    ISmartArt smart = pres.getSlides().get_Item(0).getShapes().addSmartArt(10, 10, 400, 300, SmartArtLayoutType.BasicBlockList);

    // LayoutType を BasicProcess に変更
    smart.setLayout(SmartArtLayoutType.BasicProcess);

    // プレゼンテーションを保存
    pres.save("ChangeSmartArtLayout_out.pptx", SaveFormat.Pptx);
} finally {
    if (pres != null) pres.dispose();
}

SmartArt オブジェクトの Hidden プロパティを確認する

注意: メソッド ISmartArtNode.isHidden() は、データモデルでこのノードが非表示ノードの場合に true を返します。任意の SmartArt のノードの hidden プロパティを確認するには、以下の手順に従ってください:

  • Presentation クラスのインスタンスを作成します。
  • RadialCycle の SmartArt を追加します。
  • SmartArt にノードを追加します。
  • isHidden プロパティを確認します。
  • プレゼンテーションを書き出して PPTX ファイルにします。

以下の例では、二つの図形の間にコネクタを追加しています。

Presentation pres = new Presentation();
try {
    // SmartArt BasicProcess を追加 
    ISmartArt smart = pres.getSlides().get_Item(0).getShapes().addSmartArt(10, 10, 400, 300, SmartArtLayoutType.RadialCycle);

    // SmartArt にノードを追加 
    ISmartArtNode node = smart.getAllNodes().addNode();

    // isHidden プロパティを確認
    boolean hidden = node.isHidden(); // true を返す

    if (hidden)
    {
        // いくつかのアクションまたは通知を実行
    }
    // プレゼンテーションを保存
    pres.save("CheckSmartArtHiddenProperty_out.pptx", SaveFormat.Pptx);
} finally {
    if (pres != null) pres.dispose();
}

組織図のタイプを取得または設定する

メソッド ISmartArtNode.getOrganizationChartLayout()setOrganizationChartLayout(int) は、現在のノードに関連付けられた組織図のタイプを取得または設定できるようにします。組織図のタイプを取得または設定するには、以下の手順に従ってください:

  • Presentation クラスのインスタンスを作成します。
  • スライド上に SmartArt を追加します。
  • 組織図のタイプを取得または set the organization chart type
  • プレゼンテーションを書き出して PPTX ファイルにします。

以下の例では、二つの図形の間にコネクタを追加しています。

Presentation pres = new Presentation();
try {
    // SmartArt BasicProcess を追加
    ISmartArt smart = pres.getSlides().get_Item(0).getShapes().addSmartArt(10, 10, 400, 300, SmartArtLayoutType.OrganizationChart);

    // 組織図のタイプを取得または設定
    smart.getNodes().get_Item(0).setOrganizationChartLayout(OrganizationChartLayoutType.LeftHanging);

    // プレゼンテーションを保存
    pres.save("OrganizeChartLayoutType_out.pptx", SaveFormat.Pptx);
} finally {
    if (pres != null) pres.dispose();
}

ピクチャー組織図を作成する

Aspose.Slides for Java は、ピクチャー組織図を簡単に作成できるシンプルな API を提供します。スライド上にチャートを作成するには、以下の手順を実行します:

  1. Presentation クラスのインスタンスを作成します。
  2. インデックスでスライドの参照を取得します。
  3. デフォルトデータと desired type (ChartType.PictureOrganizationChart) を指定してチャートを追加します。
  4. 変更したプレゼンテーションを書き出して PPTX ファイルにします。

以下のコードはチャートを作成するために使用されます。

Presentation pres = new Presentation("test.pptx");
try {
    ISmartArt smartArt = pres.getSlides().get_Item(0).getShapes().addSmartArt(0, 0, 400, 400, SmartArtLayoutType.PictureOrganizationChart);
    pres.save("OrganizationChart.pptx", SaveFormat.Pptx);
} finally {
    if (pres != null) pres.dispose();
}

SmartArt の状態を取得または設定する

SmartArt のレイアウトタイプを変更するには、以下の手順に従ってください:

  1. Presentation クラスのインスタンスを作成します。
  2. スライド上に SmartArt を追加します。
  3. SmartArt ダイアグラムの状態を Get または Set します。
  4. プレゼンテーションを書き出して PPTX ファイルにします。

以下のコードはチャートを作成するために使用されます。

// PPTX ファイルを表す Presentation クラスのインスタンスを作成
Presentation pres = new Presentation();
try {
    // SmartArt BasicProcess を追加
    ISmartArt smart = pres.getSlides().get_Item(0).getShapes().addSmartArt(10, 10, 400, 300, SmartArtLayoutType.BasicProcess);
    
    // SmartArt ダイアグラムの状態を取得または設定
    smart.setReversed(true);
    boolean flag = smart.isReversed();
    
    // プレゼンテーションを保存
    pres.save("output.pptx", SaveFormat.Pptx);
} finally {
    if (pres != null) pres.dispose();
}

FAQ

SmartArt は RTL 言語向けのミラーリング/反転をサポートしていますか?

はい。選択した SmartArt タイプが反転に対応している場合、setReversed メソッドはダイアグラムの方向 (LTR/RTL) を切り替えます。

同じスライドまたは別のプレゼンテーションに SmartArt をコピーして書式を保持するにはどうすればよいですか?

シェイプコレクションから clone the SmartArt shapeShapeCollection.addClone) を使用するか、clone the entire slide を使用してこのシェイプを含むスライド全体を複製できます。どちらの方法でもサイズ、位置、スタイルが保持されます。

SmartArt をプレビューや Web エクスポート用にラスタ画像としてレンダリングするには?

Render the slide(またはプレゼンテーション全体)を PNG/JPEG に変換する API を使用して、SmartArt をスライドの一部として描画できます。

スライドに複数の SmartArt がある場合、特定の SmartArt をプログラムで選択するにはどうすればよいですか?

一般的な方法は、alternative text(Alt Text)や name を使用し、slide shapes 内でその属性でシェイプを検索し、タイプが SmartArt であることを確認することです。ドキュメントにはシェイプの検索や操作の典型的な手法が記載されています。