Asse X vs. Asse delle categorie con C++
Possibili Scenari di Utilizzo
Ci sono diversi tipi di assi X. Mentre l’asse Y è un asse di tipo Valore, l’asse X può essere un asse di tipo Categoria o un asse di tipo Valore. Utilizzando un asse di tipo Valore, i dati sono trattati come dati numerici continuamente variabili, e il marcatore è posizionato in un punto lungo l’asse che varia in base al suo valore numerico. Utilizzando un asse di tipo Categoria, i dati sono trattati come una sequenza di etichette di testo non numeriche, e il marcatore è posizionato in un punto lungo l’asse in base alla sua posizione nella sequenza. Il codice di esempio qui sotto illustra la differenza tra Assi di Valore e di Categoria. I nostri dati di esempio sono mostrati nella tabella di esempio di seguito. La prima colonna contiene i nostri dati asse X, che possono essere trattati come Categorie o come Valori. Nota che i numeri non sono equispaziati, né appaiono in ordine numerico.
Gestire l’asse X e il’asse delle categorie come Microsoft Excel
Mostreremo questi dati su due tipi di grafico, il primo grafico è XY (Scatter) con asse X come asse dei valori, il secondo grafico è a linee con asse X come asse Categoria.
Codice di Esempio
#include <iostream>
#include "Aspose.Cells.h"
using namespace Aspose::Cells;
int main() {
Aspose::Cells::Startup();
// Create an instance of Workbook
Workbook workbook;
// Access the first worksheet
Worksheet worksheet = workbook.GetWorksheets().Get(0);
// Put the sample values used in charts
worksheet.GetCells().Get(u"A2").PutValue(1);
worksheet.GetCells().Get(u"A3").PutValue(3);
worksheet.GetCells().Get(u"A4").PutValue(2.5);
worksheet.GetCells().Get(u"A5").PutValue(3.5);
worksheet.GetCells().Get(u"B1").PutValue(u"Cats");
worksheet.GetCells().Get(u"C1").PutValue(u"Dogs");
worksheet.GetCells().Get(u"D1").PutValue(u"Fishes");
worksheet.GetCells().Get(u"B2").PutValue(7);
worksheet.GetCells().Get(u"B3").PutValue(6);
worksheet.GetCells().Get(u"B4").PutValue(5);
worksheet.GetCells().Get(u"B5").PutValue(4);
worksheet.GetCells().Get(u"C2").PutValue(7);
worksheet.GetCells().Get(u"C3").PutValue(5);
worksheet.GetCells().Get(u"C4").PutValue(4);
worksheet.GetCells().Get(u"C5").PutValue(3);
worksheet.GetCells().Get(u"D2").PutValue(8);
worksheet.GetCells().Get(u"D3").PutValue(7);
worksheet.GetCells().Get(u"D4").PutValue(3);
worksheet.GetCells().Get(u"D5").PutValue(2);
// Create Line Chart: X as Category Axis
int pieIdx = worksheet.GetCharts().Add(ChartType::LineWithDataMarkers, 6, 15, 20, 21);
// Retrieve the Chart object
Chart chart = worksheet.GetCharts().Get(pieIdx);
// Add Series
chart.GetNSeries().Add(u"B2:D5", true);
// Set the category data
chart.GetNSeries().SetCategoryData(u"=Sheet1!$A$2:$A$5");
// Set the first series name
chart.GetNSeries().Get(0).SetName(u"Cats");
// Set the second series name
chart.GetNSeries().Get(1).SetName(u"Dogs");
// Set the third series name
chart.GetNSeries().Get(2).SetName(u"Fishes");
// Set the Legend at the bottom of the chart area
chart.GetLegend().SetPosition(LegendPositionType::Bottom);
// Fill the PlotArea area with nothing
chart.GetPlotArea().GetArea().GetFillFormat().SetFillType(FillType::None);
// Create XY (Scatter) Chart: X as Value Axis
pieIdx = worksheet.GetCharts().Add(ChartType::ScatterConnectedByLinesWithDataMarker, 6, 6, 20, 12);
// Retrieve the Chart object
chart = worksheet.GetCharts().Get(pieIdx);
// Add Series
chart.GetNSeries().Add(u"B2:D5", true);
// Set X values for series
chart.GetNSeries().Get(0).SetXValues(u"{1,3,2.5,3.5}");
chart.GetNSeries().Get(1).SetXValues(u"{1,3,2.5,3.5}");
chart.GetNSeries().Get(2).SetXValues(u"{1,3,2.5,3.5}");
// Set the first series name
chart.GetNSeries().Get(0).SetName(u"Cats");
// Set the second series name
chart.GetNSeries().Get(1).SetName(u"Dogs");
// Set the third series name
chart.GetNSeries().Get(2).SetName(u"Fishes");
// Set the Legend at the bottom of the chart area
chart.GetLegend().SetPosition(LegendPositionType::Bottom);
// Fill the PlotArea area with nothing
chart.GetPlotArea().GetArea().GetFillFormat().SetFillType(FillType::None);
// Save the Excel file
workbook.Save(u"XAxis.xlsx");
Aspose::Cells::Cleanup();
return 0;
}