How to set category axis with C++
Possible Usage Scenarios
After you create a chart in a worksheet, you can set the category axis for it. In this article, we will show you how to set the category axis for an Excel chart using Aspose.Cells with sample code.
The steps in sample code
-
Create a new workbook.
-
Create a new chart in the first worksheet.
-
Add some values to cells in the first worksheet.
-
Now you can set the category axis. There are two ways: using cell data or using strings directly, both of which are shown in the sample code.
-
Set the value axis, save the workbook to view the result.
Sample Code
#include <iostream>
#include "Aspose.Cells.h"
using namespace Aspose::Cells;
using namespace Aspose::Cells::Charts;
int main() {
Aspose::Cells::Startup();
// Your local test path
U16String path = u"";
// Create a new workbook
Workbook workbook;
WorksheetCollection worksheets = workbook.GetWorksheets();
Worksheet worksheet = worksheets.Get(0);
worksheet.SetName(u"CHART");
// Add a chart to the worksheet
int chartIndex = worksheet.GetCharts().Add(ChartType::Column, 8, 0, 20, 10);
Chart chart = worksheet.GetCharts().Get(chartIndex);
// Add some values to cells
worksheet.GetCells().Get(u"A1").PutValue(u"Sales");
worksheet.GetCells().Get(u"A2").PutValue(100);
worksheet.GetCells().Get(u"A3").PutValue(150);
worksheet.GetCells().Get(u"A4").PutValue(130);
worksheet.GetCells().Get(u"A5").PutValue(160);
worksheet.GetCells().Get(u"A6").PutValue(150);
worksheet.GetCells().Get(u"B1").PutValue(u"Days");
worksheet.GetCells().Get(u"B2").PutValue(1);
worksheet.GetCells().Get(u"B3").PutValue(2);
worksheet.GetCells().Get(u"B4").PutValue(3);
worksheet.GetCells().Get(u"B5").PutValue(4);
worksheet.GetCells().Get(u"B6").PutValue(5);
// Some values in string
U16String Sales = u"100,150,130,160,150";
U16String Days = u"1,2,3,4,5";
// Set Category Axis Data with string
chart.GetNSeries().SetCategoryData(u"{" + Days + u"}");
// Or you can set Category Axis Data with data in cells, try it!
// chart.GetNSeries().SetCategoryData(u"B2:B6");
// Add Series to the chart
chart.GetNSeries().Add(u"Demand1", true);
// Set value axis with string
chart.GetNSeries().Get(0).SetValues(u"{" + Sales + u"}");
chart.GetNSeries().Add(u"Demand2", true);
// Set value axis with data in cells
chart.GetNSeries().Get(1).SetValues(u"A2:A6");
// Set some Category Axis properties
chart.GetCategoryAxis().GetTickLabels().SetRotationAngle(45);
chart.GetCategoryAxis().GetTickLabels().GetFont().SetSize(8);
chart.GetLegend().SetPosition(LegendPositionType::Bottom);
// Save the workbook to view the result file
workbook.Save(path + u"Output.xlsx");
Aspose::Cells::Cleanup();
return 0;
}