ツリーマップとサンバーストチャートのデータポイント

PowerPointチャートの他のタイプの中で、ツリーマップおよびサンバーストチャート(サンバーストグラフ、サンバーストダイアグラム、放射状チャート、放射状グラフまたはマルチレベル円グラフとしても知られています)の2つの「階層型」タイプがあります。これらのチャートは、葉から枝の頂点までのツリーとして構成された階層データを表示します。葉はシリーズデータポイントによって定義され、次のネストされたグループレベルは対応するカテゴリによって定義されます。Aspose.Slides for Android via Javaでは、Javaでサンバーストチャートとツリーマップのデータポイントをフォーマットできます。

以下はサンバーストチャートで、Series1列のデータが葉ノードを定義し、他の列が階層データポイントを定義しています:

todo:image_alt_text

プレゼンテーションに新しいサンバーストチャートを追加することから始めましょう:

Presentation pres = new Presentation();
try {
    IChart chart = pres.getSlides().get_Item(0).getShapes().addChart(ChartType.Sunburst, 100, 100, 450, 400);

    // ...
} finally {
    if (pres != null) pres.dispose();
}

チャートのデータポイントをフォーマットする必要がある場合、次のものを使用します:

IChartDataPointLevelsManager、  IChartDataPointLevelクラス  および IChartDataPoint.getDataPointLevelsメソッド  は、ツリーマップとサンバーストチャートのデータポイントをフォーマットするためのアクセスを提供します。  IChartDataPointLevelsManager はマルチレベルのカテゴリにアクセスするために使用され、  IChartDataPointLevelオブジェクトのコンテナを表します。 基本的には、データポイント専用に追加されたプロパティを持つ  IChartCategoryLevelsManagerのラッパーです。  IChartDataPointLevelクラスには 2つのメソッドがあります:getFormatと  getDataLabelで、これらは 対応する設定にアクセスするためのものです。

データポイントの値を表示

「Leaf 4」データポイントの値を表示します:

IChartDataPointCollection dataPoints = chart.getChartData().getSeries().get_Item(0).getDataPoints();
dataPoints.get_Item(3).getDataPointLevels().get_Item(0).getLabel().getDataLabelFormat().setShowValue(true);

todo:image_alt_text

データポイントのラベルと色を設定

「Branch 1」データラベルをカテゴリ名の代わりにシリーズ名(「Series1」)を表示するように設定します。その後、テキストの色を黄色に設定します:

IDataLabel branch1Label = dataPoints.get_Item(0).getDataPointLevels().get_Item(0).getLabel();
branch1Label.getDataLabelFormat().setShowCategoryName(false);
branch1Label.getDataLabelFormat().setShowSeriesName(true);

branch1Label.getDataLabelFormat().getTextFormat().getPortionFormat().getFillFormat().setFillType(FillType.Solid);
branch1Label.getDataLabelFormat().getTextFormat().getPortionFormat().getFillFormat().getSolidFillColor().setColor(Color.YELLOW);

todo:image_alt_text

データポイントのブランチ色を設定

「Steam 4」ブランチの色を変更します:

Presentation pres = new Presentation();
try {
    IChart chart = pres.getSlides().get_Item(0).getShapes().addChart(ChartType.Sunburst, 100, 100, 450, 400);

    IChartDataPointCollection dataPoints = chart.getChartData().getSeries().get_Item(0).getDataPoints();

    IChartDataPointLevel stem4branch = dataPoints.get_Item(9).getDataPointLevels().get_Item(1);

    stem4branch.getFormat().getFill().setFillType(FillType.Solid);
    stem4branch.getFormat().getFill().getSolidFillColor().setColor(Color.RED);

    pres.save("pres.pptx", SaveFormat.Pptx);
} finally {
    if (pres != null) pres.dispose();
}

todo:image_alt_text