Java を使用してプレゼンテーションでチャート データ マーカーを管理する
Contents
[
Hide
]
チャート マーカー オプションの設定
マーカーは特定のシリーズ内のチャート データポイントに設定できます。チャート マーカー オプションを設定するには、以下の手順に従ってください。
- Presentation クラスをインスタンス化します。
- デフォルトのチャートを作成します。
- 画像を設定します。
- 最初のチャート シリーズを取得します。
- 新しいデータポイントを追加します。
- プレゼンテーションをディスクに書き込みます。
以下の例では、データポイントレベルでチャート マーカー オプションを設定しています。
// 空のプレゼンテーションを作成
Presentation pres = new Presentation();
try {
// 最初のスライドにアクセス
ISlide slide = pres.getSlides().get_Item(0);
// デフォルトのチャートを作成
IChart chart = slide.getShapes().addChart(ChartType.LineWithMarkers, 0, 0, 400, 400);
// デフォルトのチャート データ ワークシート インデックスを取得
int defaultWorksheetIndex = 0;
// チャート データ ワークシートを取得
IChartDataWorkbook fact = chart.getChartData().getChartDataWorkbook();
// デモシリーズを削除
chart.getChartData().getSeries().clear();
// 新しいシリーズを追加
chart.getChartData().getSeries().add(fact.getCell(defaultWorksheetIndex, 1, 1, "Series 1"), chart.getType());
// 画像 1 をロード
IPPImage imgx1 = pres.getImages().addImage(new FileInputStream(new File("Desert.jpg")));
// 画像 2 をロード
IPPImage imgx2 = pres.getImages().addImage(new FileInputStream(new File("Tulips.jpg")));
// 最初のチャートシリーズを取得
IChartSeries series = chart.getChartData().getSeries().get_Item(0);
// そこに新しいポイント (1:3) を追加.
IChartDataPoint point = series.getDataPoints().addDataPointForLineSeries(fact.getCell(defaultWorksheetIndex, 1, 1, (double) 4.5));
point.getMarker().getFormat().getFill().setFillType(FillType.Picture);
point.getMarker().getFormat().getFill().getPictureFillFormat().getPicture().setImage(imgx1);
point = series.getDataPoints().addDataPointForLineSeries(fact.getCell(defaultWorksheetIndex, 2, 1, (double) 2.5));
point.getMarker().getFormat().getFill().setFillType(FillType.Picture);
point.getMarker().getFormat().getFill().getPictureFillFormat().getPicture().setImage(imgx2);
point = series.getDataPoints().addDataPointForLineSeries(fact.getCell(defaultWorksheetIndex, 3, 1, (double) 3.5));
point.getMarker().getFormat().getFill().setFillType(FillType.Picture);
point.getMarker().getFormat().getFill().getPictureFillFormat().getPicture().setImage(imgx1);
point = series.getDataPoints().addDataPointForLineSeries(fact.getCell(defaultWorksheetIndex, 4, 1, (double) 4.5));
point.getMarker().getFormat().getFill().setFillType(FillType.Picture);
point.getMarker().getFormat().getFill().getPictureFillFormat().getPicture().setImage(imgx2);
// チャートシリーズのマーカーを変更
series.getMarker().setSize(15);
// チャート付きのプレゼンテーションを保存
pres.save("ScatterChart.pptx", SaveFormat.Pptx);
} catch (IOException e) {
} finally {
if (pres != null) pres.dispose();
}
FAQ
デフォルトで利用できるマーカー形状は何ですか?
標準の形状(円、正方形、菱形、三角形など)が利用可能です。リストは MarkerStyleType クラスで定義されています。非標準の形状が必要な場合は、画像塗りつぶし付きのマーカーを使用してカスタム ビジュアルをエミュレートできます。
チャートを画像または SVG にエクスポートするときにマーカーは保持されますか?
はい。チャートを raster formats にレンダリングする場合や、shapes as SVG を保存する場合、マーカーはサイズ、塗りつぶし、輪郭などの外観と設定を保持します。