Android のプレゼンテーションでチャート データ マーカーを管理する
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として保存したりすると、マーカーはサイズ、塗り、アウトラインなどの外観と設定を保持します。