C++ を使用してプレゼンテーションのチャート データシリーズを管理する

シリーズは、チャートにプロットされた数値の行または列です。

chart-series-powerpoint

データシリーズのオーバーラップを設定

IChartSeries::get_Overlap() メソッドを使用すると、2D チャートで棒や列がどの程度オーバーラップするかを指定できます(範囲: -100〜100)。
このプロパティは、親シリーズグループのすべてのシリーズに適用されます。これは該当するグループプロパティの投影です。
get_ParentSeriesGroup()::set_Overlap() メソッドを使用して、Overlap の希望値を設定します。

  1. Presentation クラスのインスタンスを作成します。
  2. スライドにクラスター化された列チャートを追加します。
  3. 最初のチャートシリーズにアクセスします。
  4. チャートシリーズの ParentSeriesGroup にアクセスし、シリーズの希望するオーバーラップ値を設定します。
  5. 変更されたプレゼンテーションを PPTX ファイルに書き出します。

この C++ コードは、チャートシリーズのオーバーラップを設定する方法を示しています。

auto presentation = System::MakeObject<Presentation>();
auto shapes = presentation->get_Slides()->idx_get(0)->get_Shapes();

// チャートを追加
auto chart = shapes->AddChart(ChartType::ClusteredColumn, 50.0f, 50.0f, 600.0f, 400.0f, true);
auto series = chart->get_ChartData()->get_Series();
if (series->idx_get(0)->get_Overlap() == 0)
{
    // シリーズのオーバーラップを設定
    series->idx_get(0)->get_ParentSeriesGroup()->set_Overlap(-30);
}

// プレゼンテーション ファイルをディスクに保存
presentation->Save(u"SetChartSeriesOverlap_out.pptx", SaveFormat::Pptx);

データシリーズの色を変更

Aspose.Slides for C++ では、シリーズの色を次の方法で変更できます。

  1. Presentation クラスのインスタンスを作成します。
  2. スライドにチャートを追加します。
  3. 色を変更したいシリーズにアクセスします。
  4. 希望する塗りつぶしタイプと塗りつぶし色を設定します。
  5. 変更されたプレゼンテーションを保存します。

この C++ コードは、シリーズの色を変更する方法を示しています。

auto pres = System::MakeObject<Presentation>(u"test.pptx");
auto shapes = pres->get_Slides()->idx_get(0)->get_Shapes();

auto chart = shapes->AddChart(ChartType::Pie, 50.0f, 50.0f, 600.0f, 400.0f);
auto point = chart->get_ChartData()->get_Series()->idx_get(0)->get_DataPoints()->idx_get(1);

point->set_Explosion(30);
point->get_Format()->get_Fill()->set_FillType(FillType::Solid);
point->get_Format()->get_Fill()->get_SolidFillColor()->set_Color(Color::get_Blue());

pres->Save(u"output.pptx", SaveFormat::Pptx);

データシリーズカテゴリの色を変更

Aspose.Slides for C++ では、シリーズカテゴリの色を次の方法で変更できます。

  1. Presentation クラスのインスタンスを作成します。
  2. スライドにチャートを追加します。
  3. 色を変更したいシリーズカテゴリにアクセスします。
  4. 希望する塗りつぶしタイプと塗りつぶし色を設定します。
  5. 変更されたプレゼンテーションを保存します。

このコードは、シリーズカテゴリの色を変更する方法を示しています。

auto pres = System::MakeObject<Presentation>();
auto shapes = pres->get_Slides()->idx_get(0)->get_Shapes();
auto chart = shapes->AddChart(ChartType::ClusteredColumn, 50.0f, 50.0f, 600.0f, 400.0f);
auto point = chart->get_ChartData()->get_Series()->idx_get(0)->get_DataPoints()->idx_get(0);

point->get_Format()->get_Fill()->set_FillType(FillType::Solid);
point->get_Format()->get_Fill()->get_SolidFillColor()->set_Color(Color::get_Blue());

pres->Save(u"output.pptx", SaveFormat::Pptx);

データシリーズ名を変更

デフォルトでは、チャートの凡例名は各列または行のデータ上部にあるセルの内容です。

例(サンプル画像)では、

  • 列は Series 1, Series 2,Series 3 です;
  • 行は Category 1, Category 2, Category 3,Category 4 です。

Aspose.Slides for C++ では、チャート データと凡例内のシリーズ名を更新または変更できます。

この C++ コードは、チャート データ ChartDataWorkbook 内のシリーズ名を変更する方法を示しています。

auto pres = System::MakeObject<Presentation>();

auto shapes = pres->get_Slides()->idx_get(0)->get_Shapes();
auto chart = shapes->AddChart(ChartType::Column3D, 50.0f, 50.0f, 600.0f, 400.0f, true);

auto seriesCell = chart->get_ChartData()->get_ChartDataWorkbook()->GetCell(0, 0, 1);
seriesCell->set_Value(ObjectExt::Box<String>(u"New name"));

pres->Save(u"pres.pptx", SaveFormat::Pptx);

この C++ コードは、Series を介して凡例内のシリーズ名を変更する方法を示しています。

auto pres = System::MakeObject<Presentation>();
auto shapes = pres->get_Slides()->idx_get(0)->get_Shapes();

auto chart = shapes->AddChart(ChartType::Column3D, 50.0f, 50.0f, 600.0f, 400.0f, true);
auto series = chart->get_ChartData()->get_Series()->idx_get(0);

auto name = series->get_Name();
name->get_AsCells()->idx_get(0)->set_Value(ObjectExt::Box<String>(u"New name"));

データシリーズの塗りつぶし色を設定

Aspose.Slides for C++ では、プロット領域内のチャートシリーズに自動塗りつぶし色を次のように設定できます。

  1. Presentation クラスのインスタンスを作成します。
  2. インデックスでスライドの参照を取得します。
  3. 好みのタイプに基づくデフォルト データでチャートを追加します(次の例では ChartType::ClusteredColumn を使用しています)。
  4. チャートシリーズにアクセスし、塗りつぶし色を Automatic に設定します。
  5. プレゼンテーションを PPTX ファイルに保存します。

この C++ コードは、チャートシリーズの自動塗りつぶし色を設定する方法を示しています。

auto presentation = System::MakeObject<Presentation>();
auto shapes = presentation->get_Slides()->idx_get(0)->get_Shapes();

// クラスタ化列チャートを作成
auto chart = shapes->AddChart(ChartType::ClusteredColumn, 100.0f, 50.0f, 600.0f, 400.0f);

// シリーズの塗りつぶし形式を自動に設定
for (const auto& series : chart->get_ChartData()->get_Series())
{
    series->GetAutomaticSeriesColor();
}

// プレゼンテーションファイルをディスクに書き込む
presentation->Save(u"AutoFillSeries_out.pptx", SaveFormat::Pptx);

データシリーズの反転塗りつぶし色を設定

Aspose.Slides では、プロット領域内のチャートシリーズに反転塗りつぶし色を次のように設定できます。

  1. Presentation クラスのインスタンスを作成します。
  2. インデックスでスライドの参照を取得します。
  3. 好みのタイプに基づくデフォルト データでチャートを追加します(次の例では ChartType::ClusteredColumn を使用しています)。
  4. チャートシリーズにアクセスし、塗りつぶし色を反転に設定します。
  5. プレゼンテーションを PPTX ファイルに保存します。

この C++ コードは、操作を示しています。

Color inverColor = Color::get_Red();
    
auto pres = System::MakeObject<Presentation>();
auto shapes = pres->get_Slides()->idx_get(0)->get_Shapes();
auto chart = shapes->AddChart(ChartType::ClusteredColumn, 100.0f, 100.0f, 400.0f, 300.0f);

auto workBook = chart->get_ChartData()->get_ChartDataWorkbook();
auto chartData = chart->get_ChartData();

chartData->get_Series()->Clear();
chartData->get_Categories()->Clear();

// 新しいシリーズとカテゴリを追加
chartData->get_Series()->Add(workBook->GetCell(0, 0, 1, ObjectExt::Box<String>(u"Series 1")), chart->get_Type());
chartData->get_Categories()->Add(workBook->GetCell(0, 1, 0, ObjectExt::Box<String>(u"Category 1")));
chartData->get_Categories()->Add(workBook->GetCell(0, 2, 0, ObjectExt::Box<String>(u"Category 2")));
chartData->get_Categories()->Add(workBook->GetCell(0, 3, 0, ObjectExt::Box<String>(u"Category 3")));

// 最初のチャートシリーズを取得し、そのシリーズデータを設定
auto series = chartData->get_Series()->idx_get(0);
series->get_DataPoints()->AddDataPointForBarSeries(workBook->GetCell(0, 1, 1, ObjectExt::Box<int32_t>(-20)));
series->get_DataPoints()->AddDataPointForBarSeries(workBook->GetCell(0, 2, 1, ObjectExt::Box<int32_t>(50)));
series->get_DataPoints()->AddDataPointForBarSeries(workBook->GetCell(0, 3, 1, ObjectExt::Box<int32_t>(-30)));
Color seriesColor = series->GetAutomaticSeriesColor();
series->set_InvertIfNegative(true);
series->get_Format()->get_Fill()->set_FillType(FillType::Solid);
series->get_Format()->get_Fill()->get_SolidFillColor()->set_Color(seriesColor);
series->get_InvertedSolidFillColor()->set_Color(inverColor);
pres->Save(u"SetInvertFillColorChart_out.pptx", SaveFormat::Pptx);

チャートシリーズの反転塗りつぶし色を設定

Aspose.Slides は、IChartDataPoint::set_InvertIfNegative() および ChartDataPoint.set_InvertIfNegative() メソッドを使用して反転を設定できます。これらのメソッドで反転を設定すると、データ ポイントが負の値になると色が反転します。

この C++ コードは、操作を示しています。

auto pres = System::MakeObject<Presentation>();
auto shapes = pres->get_Slides()->idx_get(0)->get_Shapes();
auto chart = shapes->AddChart(ChartType::ClusteredColumn, 50.0f, 50.0f, 600.0f, 400.0f, true);
auto series = chart->get_ChartData()->get_Series();
chart->get_ChartData()->get_Series()->Clear();

auto workBook = chart->get_ChartData()->get_ChartDataWorkbook();
series->Add(workBook->GetCell(0, u"B1"), chart->get_Type());
auto dataPoints = series->idx_get(0)->get_DataPoints();
dataPoints->AddDataPointForBarSeries(workBook->GetCell(0, u"B2", ObjectExt::Box<int32_t>(-5)));
dataPoints->AddDataPointForBarSeries(workBook->GetCell(0, u"B3", ObjectExt::Box<int32_t>(3)));
dataPoints->AddDataPointForBarSeries(workBook->GetCell(0, u"B4", ObjectExt::Box<int32_t>(-2)));
dataPoints->AddDataPointForBarSeries(workBook->GetCell(0, u"B5", ObjectExt::Box<int32_t>(1)));

series->idx_get(0)->set_InvertIfNegative(false);

series->idx_get(0)->get_DataPoints()->idx_get(2)->set_InvertIfNegative(true);

pres->Save(u"out.pptx", SaveFormat::Pptx);

特定のデータ ポイント値をクリア

Aspose.Slides for C++ では、特定のチャートシリーズの DataPoints データを次のようにクリアできます。

  1. Presentation クラスのインスタンスを作成します。
  2. インデックスを使用してスライドの参照を取得します。
  3. インデックスを使用してチャートの参照を取得します。
  4. すべてのチャート DataPoints を反復し、XValueYValue を null に設定します。
  5. 特定のチャートシリーズのすべての DataPoints をクリアします。
  6. 変更されたプレゼンテーションを PPTX ファイルに書き込みます。

この C++ コードは、操作を示しています。

auto pres = System::MakeObject<Presentation>(u"TestChart.pptx");
auto sl = pres->get_Slides()->idx_get(0);

auto chart = System::ExplicitCast<IChart>(sl->get_Shapes()->idx_get(0));
auto dataPoints = chart->get_ChartData()->get_Series()->idx_get(0)->get_DataPoints();

for (const auto& dataPoint : dataPoints)
{
    dataPoint->get_XValue()->get_AsCell()->set_Value(nullptr);
    dataPoint->get_YValue()->get_AsCell()->set_Value(nullptr);
}

dataPoints->Clear();

pres->Save(u"ClearSpecificChartSeriesDataPointsData.pptx", SaveFormat::Pptx);

データシリーズのギャップ幅を設定

Aspose.Slides for C++ では、シリーズのギャップ幅を set_GapWidth() メソッドで次のように設定できます。

  1. Presentation クラスのインスタンスを作成します。
  2. 最初のスライドにアクセスします。
  3. デフォルト データでチャートを追加します。
  4. 任意のチャートシリーズにアクセスします。
  5. GapWidth プロパティを設定します。
  6. 変更されたプレゼンテーションを PPTX ファイルに書き出します。

このコードは、シリーズのギャップ幅を設定する方法を示しています。

// 空のプレゼンテーションを作成
auto presentation = System::MakeObject<Presentation>();

// プレゼンテーションの最初のスライドにアクセス
auto slide = presentation->get_Slides()->idx_get(0);

// デフォルト データのチャートを追加
auto chart = slide->get_Shapes()->AddChart(ChartType::StackedColumn, 0.0f, 0.0f, 500.0f, 500.0f);

// チャート データシートのインデックスを設定
int32_t worksheetIndex = 0;

// チャート データ ワークシートを取得
auto workbook = chart->get_ChartData()->get_ChartDataWorkbook();

// シリーズを追加
chart->get_ChartData()->get_Series()->Add(workbook->GetCell(worksheetIndex, 0, 1, ObjectExt::Box<String>(u"Series 1")), chart->get_Type());
chart->get_ChartData()->get_Series()->Add(workbook->GetCell(worksheetIndex, 0, 2, ObjectExt::Box<String>(u"Series 2")), chart->get_Type());

// カテゴリを追加
chart->get_ChartData()->get_Categories()->Add(workbook->GetCell(worksheetIndex, 1, 0, ObjectExt::Box<String>(u"Category 1")));
chart->get_ChartData()->get_Categories()->Add(workbook->GetCell(worksheetIndex, 2, 0, ObjectExt::Box<String>(u"Category 2")));
chart->get_ChartData()->get_Categories()->Add(workbook->GetCell(worksheetIndex, 3, 0, ObjectExt::Box<String>(u"Category 3")));

// 2 番目のチャートシリーズを取得
auto series = chart->get_ChartData()->get_Series()->idx_get(1);
auto dataPoints = series->get_DataPoints();

// シリーズデータを設定
dataPoints->AddDataPointForBarSeries(workbook->GetCell(worksheetIndex, 1, 1, ObjectExt::Box<int32_t>(20)));
dataPoints->AddDataPointForBarSeries(workbook->GetCell(worksheetIndex, 2, 1, ObjectExt::Box<int32_t>(50)));
dataPoints->AddDataPointForBarSeries(workbook->GetCell(worksheetIndex, 3, 1, ObjectExt::Box<int32_t>(30)));
dataPoints->AddDataPointForBarSeries(workbook->GetCell(worksheetIndex, 1, 2, ObjectExt::Box<int32_t>(30)));
dataPoints->AddDataPointForBarSeries(workbook->GetCell(worksheetIndex, 2, 2, ObjectExt::Box<int32_t>(10)));
dataPoints->AddDataPointForBarSeries(workbook->GetCell(worksheetIndex, 3, 2, ObjectExt::Box<int32_t>(60)));

// GapWidth の値を設定
series->get_ParentSeriesGroup()->set_GapWidth(50);

// プレゼンテーションをディスクに保存
presentation->Save(u"GapWidth_out.pptx", SaveFormat::Pptx);

FAQ

単一のチャートに含められるシリーズの数に制限はありますか?

Aspose.Slides には追加できるシリーズ数の固定上限はありません。実際の上限は、チャートの可読性とアプリケーションで利用できるメモリによって決まります。

クラスター内の列が互いに近すぎる、または遠すぎる場合はどうすればよいですか?

そのシリーズ(または親シリーズグループ)のギャップ幅設定を調整します。値を増やすと列間のスペースが広がり、減らすと近くなります。