Cómo crear un gráfico combinado con C++
Escenarios de uso posibles
Los gráficos combo en Excel te permiten aprovechar esta opción porque puedes combinar fácilmente dos o más tipos de gráficos para hacer que tus datos sean comprensibles. Los gráficos combo son útiles cuando tus datos contienen múltiples tipos de valores, incluidos precio y volumen. Además, los gráficos combo son factibles cuando los números de tus datos varían ampliamente de serie a serie.
Gráfico combo
Después de ejecutar el código a continuación, verás el gráfico combo como se muestra a continuación.
Código de muestra
El siguiente código de muestra carga el archivo de Excel de muestra y genera el archivo de Excel de salida.
#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();
}