Hur man skapar kombinationsdiagram med C++
Möjliga användningsscenario
Kombinationsdiagram i Excel låter dig dra nytta av detta alternativ eftersom du enkelt kan kombinera två eller flera diagramtyper för att göra din data förståelig. Kombinationsdiagram är användbara när din data innehåller flera olika typer av värden, inklusive pris och volym. Dessutom är kombinationsdiagram genomförbara när dina datanummer skiljer sig markant från serie till serie.
Kombinationsdiagram
Efter att ha kört koden nedan kommer du att se kombinationsdiagrammet som visas nedan.
Exempelkod
Följande provkod laddar den provfilen i Excel och genererar den resulterande Excelfilen.
#include <iostream>
#include "Aspose.Cells.h"
using namespace Aspose::Cells;
int main()
{
Aspose::Cells::Startup();
// Create the workbook
Workbook workbook(u"combo.xlsx");
// Access the first worksheet
Worksheet worksheet = workbook.GetWorksheets().Get(0);
// Add a stock volume (VHLC) chart
int32_t pieIdx = worksheet.GetCharts().Add(ChartType::StockVolumeHighLowClose, 15, 0, 34, 12);
// Retrieve the Chart object
Chart chart = worksheet.GetCharts().Get(pieIdx);
// Set the legend to be shown
chart.SetShowLegend(true);
// Set the chart title
chart.GetTitle().SetText(u"Combo Chart");
// Set the Legend position to bottom of the chart area
chart.GetLegend().SetPosition(LegendPositionType::Bottom);
// Set data range
chart.SetChartDataRange(u"A1:E12", true);
// Set category data
chart.GetNSeries().GetCategoryData() = u"A2:A12";
// Set the Series[1], Series[2], and Series[3] to different Marker Styles
for (int32_t j = 0; j < chart.GetNSeries().GetCount(); j++)
{
switch (j)
{
case 1:
chart.GetNSeries().Get(j).GetMarker().SetMarkerStyle(ChartMarkerType::Circle);
chart.GetNSeries().Get(j).GetMarker().SetMarkerSize(15);
chart.GetNSeries().Get(j).GetMarker().GetArea().SetFormatting(FormattingType::Custom);
chart.GetNSeries().Get(j).GetMarker().GetArea().SetForegroundColor(Color::Pink());
chart.GetNSeries().Get(j).GetBorder().SetIsVisible(false);
break;
case 2:
chart.GetNSeries().Get(j).GetMarker().SetMarkerStyle(ChartMarkerType::Dash);
chart.GetNSeries().Get(j).GetMarker().SetMarkerSize(15);
chart.GetNSeries().Get(j).GetMarker().GetArea().SetFormatting(FormattingType::Custom);
chart.GetNSeries().Get(j).GetMarker().GetArea().SetForegroundColor(Color::Orange());
chart.GetNSeries().Get(j).GetBorder().SetIsVisible(false);
break;
case 3:
chart.GetNSeries().Get(j).GetMarker().SetMarkerStyle(ChartMarkerType::Square);
chart.GetNSeries().Get(j).GetMarker().SetMarkerSize(15);
chart.GetNSeries().Get(j).GetMarker().GetArea().SetFormatting(FormattingType::Custom);
chart.GetNSeries().Get(j).GetMarker().GetArea().SetForegroundColor(Color::LightBlue());
chart.GetNSeries().Get(j).GetBorder().SetIsVisible(false);
break;
}
}
// Set the chart type for Series[0]
chart.GetNSeries().Get(0).SetType(ChartType::Line);
// Set style for the border of the first series
chart.GetNSeries().Get(0).GetBorder().SetStyle(LineType::Solid);
// Set color for the first series
chart.GetNSeries().Get(0).GetBorder().SetColor(Color::DarkBlue());
// Fill the PlotArea area with nothing
chart.GetPlotArea().GetArea().SetFormatting(FormattingType::None);
// Save the Excel file
workbook.Save(u"out.xlsx");
Aspose::Cells::Cleanup();
}