Syncfusion Flutter OfficeChart is a feature rich and high-performance non-UI Excel chart library written natively in Dart. It allows you to add robust Excel chart functionalities to Flutter applications.
The Excel package is a non-UI and reusable Flutter library to create different Excel charts programmatically with chart elements. The creation of Excel file are in XLSX (Excel 2007 and above) format.
Disclaimer: This is a commercial package. To use this package, you need to have either a Syncfusion Commercial License or Syncfusion Community license. For more details, please check the LICENSE file.
Note: Our packages are now compatible with Flutter for Web. However, this will be in Beta until Flutter for Web becomes stable.
- Chart features
- Get the demo application
- Useful links
- Installation
- Getting started
- Support and feedback
- About Syncfusion
The following are the chart features of Syncfusion Flutter OfficeChart.
- Create a chart in Excel document.
- Add pie chart to Excel worksheet.
- Add column chart to Excel worksheet.
- Add line chart to Excel worksheet.
- Add bar chart to Excel worksheet.
- Add stacked chart to Excel worksheet.
- Add Chart elements.
- Add area chart to Excel worksheet.
- Add stacked100 chart to Excel worksheet.
Explore the full capability of our Flutter widgets on your device by installing our sample browser application from the following app stores, and view sample’ codes in GitHub.
Take a look at the following to learn more about Syncfusion Flutter XlsIO:
Install the latest version from pub
Import the following package to your project to create a Excel chart document from scratch.
import 'package:syncfusion_flutter_xlsio/xlsio.dart';
import 'package:syncfusion_flutter_officechart/officechart.dart';
Add the following code to create a chart in Excel document.
// Create a new Excel document.
final Workbook workbook = Workbook();
// Accessing worksheet via index.
final Worksheet sheet = workbook.worksheets[0];
// Setting value in the cell.
sheet.getRangeByName('A1').setText('John');
sheet.getRangeByName('A2').setText('Amy');
sheet.getRangeByName('A3').setText('Jack');
sheet.getRangeByName('A4').setText('Tiya');
sheet.getRangeByName('B1').setNumber(10);
sheet.getRangeByName('B2').setNumber(12);
sheet.getRangeByName('B3').setNumber(20);
sheet.getRangeByName('B4').setNumber(21);
// Create an instances of chart collection.
final ChartCollection charts = ChartCollection(sheet);
// Add the chart.
final Chart chart = charts.add();
// Set Chart Type.
chart.chartType = ExcelChartType.column;
// Set data range in the worksheet.
chart.dataRange = sheet.getRangeByName('A1:B4');
// set charts to worksheet.
sheet.charts = charts;
// save and dispose the workbook.
List<int> bytes = workbook.saveAsStream();
File('Chart.xlsx').writeAsBytes(bytes);
workbook.dispose();
Use the following code to add pie chart to Excel worksheet.
// Create a new Excel document.
final Workbook workbook = Workbook();
// Accessing worksheet via index.
final Worksheet sheet = workbook.worksheets[0];
// Setting value in the cell.
sheet.getRangeByName('A11').setText('Venue');
sheet.getRangeByName('A12').setText('Seating & Decor');
sheet.getRangeByName('A13').setText('Technical Team');
sheet.getRangeByName('A14').setText('performers');
sheet.getRangeByName('A15').setText('performer\'s Transport');
sheet.getRangeByName('B11:B15').numberFormat = '\$#,##0_)';
sheet.getRangeByName('B11').setNumber(17500);
sheet.getRangeByName('B12').setNumber(1828);
sheet.getRangeByName('B13').setNumber(800);
sheet.getRangeByName('B14').setNumber(14000);
sheet.getRangeByName('B15').setNumber(2600);
// Create an instances of chart collection.
final ChartCollection charts = ChartCollection(sheet);
// Add the chart.
final Chart chart1 = charts.add();
// Set Chart Type.
chart1.chartType = ExcelChartType.pie;
// Set data range in the worksheet.
chart1.dataRange = sheet.getRangeByName('A11:B15');
chart1.isSeriesInRows = false;
// set charts to worksheet.
sheet.charts = charts;
// save and dispose the workbook.
List<int> bytes = workbook.saveAsStream();
File('PieChart.xlsx').writeAsBytes(bytes);
workbook.dispose();
Use the following code to add column chart to Excel worksheet.
// Create a new Excel document.
final Workbook workbook = Workbook();
// Accessing worksheet via index.
final Worksheet sheet = workbook.worksheets[0];
// Setting value in the cell.
sheet.getRangeByName('A11').setText('Venue');
sheet.getRangeByName('A12').setText('Seating & Decor');
sheet.getRangeByName('A13').setText('Technical Team');
sheet.getRangeByName('A14').setText('performers');
sheet.getRangeByName('A15').setText('performer\'s Transport');
sheet.getRangeByName('B11:B15').numberFormat = '\$#,##0_)';
sheet.getRangeByName('B11').setNumber(17500);
sheet.getRangeByName('B12').setNumber(1828);
sheet.getRangeByName('B13').setNumber(800);
sheet.getRangeByName('B14').setNumber(14000);
sheet.getRangeByName('B15').setNumber(2600);
// Create an instances of chart collection.
final ChartCollection charts = ChartCollection(sheet);
// Add the chart.
final Chart chart1 = charts.add();
// Set Chart Type.
chart1.chartType = ExcelChartType.column;
// Set data range in the worksheet.
chart1.dataRange = sheet.getRangeByName('A11:B15');
chart1.isSeriesInRows = false;
// set charts to worksheet.
sheet.charts = charts;
// save and dispose the workbook.
List<int> bytes = workbook.saveAsStream();
File('ExcelColumnChart.xlsx').writeAsBytes(bytes);
workbook.dispose();
Use the following code to add bar chart to Excel worksheet.
// Create a new Excel document.
final Workbook workbook = Workbook();
// Accessing worksheet via index.
final Worksheet sheet = workbook.worksheets[0];
// Setting value in the cell.
sheet.getRangeByName('A1').setText('Items');
sheet.getRangeByName('B1').setText('Amount(in \$)');
sheet.getRangeByName('C1').setText('Count');
sheet.getRangeByName('A2').setText('Beverages');
sheet.getRangeByName('A3').setText('Condiments');
sheet.getRangeByName('A4').setText('Confections');
sheet.getRangeByName('A5').setText('Dairy Products');
sheet.getRangeByName('A6').setText('Grains / Cereals');
sheet.getRangeByName('B2').setNumber(2776);
sheet.getRangeByName('B3').setNumber(1077);
sheet.getRangeByName('B4').setNumber(2287);
sheet.getRangeByName('B5').setNumber(1368);
sheet.getRangeByName('B6').setNumber(3325);
sheet.getRangeByName('C2').setNumber(925);
sheet.getRangeByName('C3').setNumber(378);
sheet.getRangeByName('C4').setNumber(880);
sheet.getRangeByName('C5').setNumber(581);
sheet.getRangeByName('C6').setNumber(189);
// Create an instances of chart collection.
final ChartCollection charts = ChartCollection(sheet);
// Add the chart.
final Chart chart1 = charts.add();
// Set Chart Type.
chart1.chartType = ExcelChartType.bar;
// Set data range in the worksheet.
chart1.dataRange = sheet.getRangeByName('A1:C6');
chart1.isSeriesInRows = false;
// set charts to worksheet.
sheet.charts = charts;
// save and dispose the workbook.
List<int> bytes = workbook.saveAsStream();
File('BarChart.xlsx').writeAsBytes(bytes);
workbook.dispose();
Use the following code to add line chart to Excel worksheet.
// Create a new Excel document.
final Workbook workbook = Workbook();
// Accessing worksheet via index.
final Worksheet sheet = workbook.worksheets[0];
// Setting value in the cell.
sheet.getRangeByName('A1').setText('City Name');
sheet.getRangeByName('A2').setText('Chennai');
sheet.getRangeByName('A3').setText('Mumbai');
sheet.getRangeByName('A4').setText('Delhi');
sheet.getRangeByName('A5').setText('Hyderabad');
sheet.getRangeByName('A6').setText('Kolkata');
sheet.getRangeByName('B1').setText('Temp in C');
sheet.getRangeByName('B2').setNumber(34);
sheet.getRangeByName('B3').setNumber(40);
sheet.getRangeByName('B4').setNumber(47);
sheet.getRangeByName('B5').setNumber(20);
sheet.getRangeByName('B6').setNumber(66);
// Create an instances of chart collection.
final ChartCollection charts = ChartCollection(sheet);
// Add the chart.
final Chart chart = charts.add();
//Set Chart Type.
chart.chartType = ExcelChartType.line;
//Set data range in the worksheet.
chart.dataRange = sheet.getRangeByName('A1:B6');
chart.isSeriesInRows = false;
// set charts to worksheet.
sheet.charts = charts;
//save and dispose workbook.
List<int> bytes = workbook.saveAsStream();
File('LineChart.xlsx').writeAsBytes(bytes);
workbook.dispose();
This section covers the various stacked chart.
Stacked Column chart
Use the following code to add stacked column chart to Excel worksheet.
// Create a new Excel document.
final Workbook workbook = Workbook();
// Accessing worksheet via index.
final Worksheet sheet = workbook.worksheets[0];
// Setting value in the cell.
sheet.getRangeByName('A1').setText('Items');
sheet.getRangeByName('B1').setText('Amount(in \$)');
sheet.getRangeByName('C1').setText('Count');
sheet.getRangeByName('A2').setText('Beverages');
sheet.getRangeByName('A3').setText('Condiments');
sheet.getRangeByName('A4').setText('Confections');
sheet.getRangeByName('A5').setText('Dairy Products');
sheet.getRangeByName('A6').setText('Grains / Cereals');
sheet.getRangeByName('B2').setNumber(2776);
sheet.getRangeByName('B3').setNumber(1077);
sheet.getRangeByName('B4').setNumber(2287);
sheet.getRangeByName('B5').setNumber(1368);
sheet.getRangeByName('B6').setNumber(3325);
sheet.getRangeByName('C2').setNumber(925);
sheet.getRangeByName('C3').setNumber(378);
sheet.getRangeByName('C4').setNumber(880);
sheet.getRangeByName('C5').setNumber(581);
sheet.getRangeByName('C6').setNumber(189);
// Create an instances of chart collection.
final ChartCollection charts = ChartCollection(sheet);
// Add the chart.
final Chart chart1 = charts.add();
//Set Chart Type.
chart1.chartType = ExcelChartType.columnStacked;
//Set data range in the worksheet.
chart1.dataRange = sheet.getRangeByName('A1:C6');
chart1.isSeriesInRows = false;
// set charts to worksheet.
sheet.charts = charts;
//save and dispose workbook.
List<int> bytes = workbook.saveAsStream();
File('ColunmStackedChart.xlsx').writeAsBytes(bytes);
workbook.dispose();
Stacked bar chart
Use the following code to add stacked bar chart to Excel worksheet.
// Create a new Excel document.
final Workbook workbook = Workbook();
// Accessing worksheet via index.
final Worksheet sheet = workbook.worksheets[0];
// Setting value in the cell.
sheet.getRangeByName('A1').setText('Name');
sheet.getRangeByName('B1').setText('Salary');
sheet.getRangeByName('C1').setText('Working hr');
sheet.getRangeByName('A2').setText('Ben');
sheet.getRangeByName('A3').setText('Mark');
sheet.getRangeByName('A4').setText('Sundar');
sheet.getRangeByName('A5').setText('Geo');
sheet.getRangeByName('A6').setText('Andrew');
sheet.getRangeByName('B2').setNumber(1000);
sheet.getRangeByName('B3').setNumber(2000);
sheet.getRangeByName('B4').setNumber(2392);
sheet.getRangeByName('B5').setNumber(3211);
sheet.getRangeByName('B6').setNumber(4211);
sheet.getRangeByName('C2').setNumber(287);
sheet.getRangeByName('C3').setNumber(355);
sheet.getRangeByName('C4').setNumber(134);
sheet.getRangeByName('C5').setNumber(581);
sheet.getRangeByName('C6').setNumber(426);
//Create an instances of chart collection.
final ChartCollection charts = ChartCollection(sheet);
// Add the chart.
final Chart chart1 = charts.add();
//Set Chart Type.
chart1.chartType = ExcelChartType.barStacked;
//Set data range in the worksheet.
chart1.dataRange = sheet.getRangeByName('A1:C6');
chart1.isSeriesInRows = false;
// set charts to worksheet.
sheet.charts = charts;
//save and dispose workbook.
List<int> bytes = workbook.saveAsStream();
File('BarStackedChart.xlsx').writeAsBytes(bytes);
workbook.dispose();
Stacked Line chart
Use the following code to add stacked line chart to Excel worksheet.
// Create a new Excel document.
final Workbook workbook = Workbook();
// Accessing worksheet via index.
final Worksheet sheet = workbook.worksheets[0];
// Setting value in the cell.
sheet.getRangeByName('A1').setText('City Name');
sheet.getRangeByName('A2').setText('Chennai');
sheet.getRangeByName('A3').setText('Mumbai');
sheet.getRangeByName('A4').setText('Delhi');
sheet.getRangeByName('A5').setText('Hyderabad');
sheet.getRangeByName('A6').setText('Kolkata');
sheet.getRangeByName('B1').setText('Temp in C');
sheet.getRangeByName('B2').setNumber(34);
sheet.getRangeByName('B3').setNumber(40);
sheet.getRangeByName('B4').setNumber(47);
sheet.getRangeByName('B5').setNumber(20);
sheet.getRangeByName('B6').setNumber(66);
sheet.getRangeByName('C1').setText('Temp in F');
sheet.getRangeByName('C2').setNumber(93);
sheet.getRangeByName('C3').setNumber(104);
sheet.getRangeByName('C4').setNumber(120);
sheet.getRangeByName('C5').setNumber(80);
sheet.getRangeByName('C6').setNumber(140);
//Create an instances of chart collection.
final ChartCollection charts = ChartCollection(sheet);
// Add the chart.
final Chart chart1 = charts.add();
//Set Chart Type.
chart1.chartType = ExcelChartType.lineStacked;
//Set data range in the worksheet.
chart1.dataRange = sheet.getRangeByName('A1:C6');
chart1.isSeriesInRows = false;
// set charts to worksheet.
sheet.charts = charts;
//save and dispose workbook.
List<int> bytes = workbook.saveAsStream();
File('LineStackedChart.xlsx').writeAsBytes(bytes);
workbook.dispose();
Stacked Area chart
Use the following code to add stacked area chart to Excel worksheet.
// Create a new Excel document.
final Workbook workbook = Workbook();
// Accessing worksheet via index.
final Worksheet sheet = workbook.worksheets[0];
// Setting value in the cell.
sheet.getRangeByName('A1').text = 'Fruits';
sheet.getRangeByName('A2').text = 'Apples';
sheet.getRangeByName('A3').text = 'Grapes';
sheet.getRangeByName('A4').text = 'Bananas';
sheet.getRangeByName('A5').text = 'Oranges';
sheet.getRangeByName('A6').text = 'Melons';
sheet.getRangeByName('B1').text = 'Joey';
sheet.getRangeByName('B2').number = 5;
sheet.getRangeByName('B3').number = 4;
sheet.getRangeByName('B4').number = 4;
sheet.getRangeByName('B5').number = 2;
sheet.getRangeByName('B6').number = 2;
sheet.getRangeByName('C1').text = 'Mathew';
sheet.getRangeByName('C2').number = 3;
sheet.getRangeByName('C3').number = 5;
sheet.getRangeByName('C4').number = 4;
sheet.getRangeByName('C5').number = 1;
sheet.getRangeByName('C6').number = 7;
sheet.getRangeByName('D1').text = 'Peter';
sheet.getRangeByName('D2').number = 2;
sheet.getRangeByName('D3').number = 2;
sheet.getRangeByName('D4').number = 3;
sheet.getRangeByName('D5').number = 5;
sheet.getRangeByName('D6').number = 6;
// Create an instances of chart collection.
final ChartCollection charts = ChartCollection(sheet);
// Add the chart.
final Chart chart = charts.add();
// Set Chart Type.
chart.chartType = ExcelChartType.areaStacked;
// Set data range in the worksheet.
chart.dataRange = sheet.getRangeByName('A1:D6');
chart.isSeriesInRows = false;
//Set Chart Title
chart.chartTitle = 'Stacked Area Chart';
//Set Legend
chart.hasLegend = true;
chart.legend.position = ExcelLegendPosition.bottom;
//Positioning the chart in the worksheet
chart.topRow = 8;
chart.leftColumn = 1;
chart.bottomRow = 23;
chart.rightColumn = 8;
// set charts to worksheet.
sheet.charts = charts;
// save and dispose the workbook.
final List<int> bytes = workbook.saveAsStream();
workbook.dispose();
File('AreaStackedChart.xlsx').writeAsBytes(bytes);
Use the following code to add chart elements to Excel worksheet.
// Create a new Excel document.
final Workbook workbook = Workbook();
// Accessing worksheet via index.
final Worksheet sheet = workbook.worksheets[0];
// Setting value in the cell.
sheet.getRangeByName('A1').setText('Months');
sheet.getRangeByName('B1').setText('Internal Sales Amount');
sheet.getRangeByName('C1').setText('Reseller Sales Amount');
sheet.getRangeByName('A2').setDateTime(DateTime(2014, 01, 14, 14, 14, 14));
sheet.getRangeByName('A3').setDateTime(DateTime(2014, 02, 14, 14, 14, 14));
sheet.getRangeByName('A4').setDateTime(DateTime(2014, 03, 14, 14, 14, 14));
sheet.getRangeByName('A5').setDateTime(DateTime(2014, 04, 14, 14, 14, 14));
sheet.getRangeByName('A6').setDateTime(DateTime(2014, 05, 14, 14, 14, 14));
sheet.getRangeByName('B2').setNumber(700);
sheet.getRangeByName('B3').setNumber(200);
sheet.getRangeByName('B4').setNumber(300);
sheet.getRangeByName('B5').setNumber(500);
sheet.getRangeByName('B6').setNumber(800);
sheet.getRangeByName('C2').setNumber(30);
sheet.getRangeByName('C3').setNumber(40);
sheet.getRangeByName('C4').setNumber(70);
sheet.getRangeByName('C5').setNumber(2);
sheet.getRangeByName('C6').setNumber(100);
//Create an instances of chart collection.
final ChartCollection charts = ChartCollection(sheet);
// Add the chart.
final Chart chart = charts.add();
//Set Chart Type.
chart.chartType = ExcelChartType.line;
//Set data range in the worksheet.
chart.dataRange = sheet.getRangeByName('A1:C6');
chart.isSeriesInRows = false;
//setting chart tile with font properties
chart.chartTitle = 'Yearly sales';
chart.chartTitleArea.bold = true;
chart.chartTitleArea.size = 12;
//setting legend position.
chart.legend.position = ExcelLegendPosition.bottom;
//setting the chart position.
chart.topRow = 0;
chart.bottomRow = 20;
chart.leftColumn = 1;
chart.rightColumn = 8;
//setting Axis number format.
chart.primaryCategoryAxis.numberFormat = 'mmmm';
chart.primaryValueAxis.numberFormat = '0.00';
//setting datalabels
final ChartSerie serie = chart.series[0];
serie.dataLabels.isValue = true;
serie.dataLabels.isCategoryName = true;
serie.dataLabels.isSeriesName = true;
serie.dataLabels.textArea.bold = true;
serie.dataLabels.textArea.size = 12;
serie.dataLabels.textArea.fontName = 'Arial';
// set charts to worksheet.
sheet.charts = charts;
//save and dispose workbook.
List<int> bytes = workbook.saveAsStream();
File('ChartElement.xlsx').writeAsBytes(bytes);
workbook.dispose();
Use the following code to add area chart to Excel worksheet.
// Create a new Excel document.
final Workbook workbook = Workbook();
// Accessing worksheet via index.
final Worksheet sheet = workbook.worksheets[0];
// Setting value in the cell.
sheet.getRangeByName('A1').text = 'Fruits';
sheet.getRangeByName('A2').text = 'Apples';
sheet.getRangeByName('A3').text = 'Grapes';
sheet.getRangeByName('A4').text = 'Bananas';
sheet.getRangeByName('A5').text = 'Oranges';
sheet.getRangeByName('A6').text = 'Melons';
sheet.getRangeByName('B1').text = 'Joey';
sheet.getRangeByName('B2').number = 5;
sheet.getRangeByName('B3').number = 4;
sheet.getRangeByName('B4').number = 4;
sheet.getRangeByName('B5').number = 2;
sheet.getRangeByName('B6').number = 2;
sheet.getRangeByName('C1').text = 'Mathew';
sheet.getRangeByName('C2').number = 3;
sheet.getRangeByName('C3').number = 5;
sheet.getRangeByName('C4').number = 4;
sheet.getRangeByName('C5').number = 1;
sheet.getRangeByName('C6').number = 7;
sheet.getRangeByName('D1').text = 'Peter';
sheet.getRangeByName('D2').number = 2;
sheet.getRangeByName('D3').number = 2;
sheet.getRangeByName('D4').number = 3;
sheet.getRangeByName('D5').number = 5;
sheet.getRangeByName('D6').number = 6;
// Create an instances of chart collection.
final ChartCollection charts = ChartCollection(sheet);
// Add the chart.
final Chart chart = charts.add();
// Set Chart Type.
chart.chartType = ExcelChartType.area;
// Set data range in the worksheet.
chart.dataRange = sheet.getRangeByName('A1:D6');
chart.isSeriesInRows = false;
//Set Chart Title
chart.chartTitle = 'Area Chart';
//Set Legend
chart.hasLegend = true;
chart.legend.position = ExcelLegendPosition.bottom;
//Positioning the chart in the worksheet
chart.topRow = 8;
chart.leftColumn = 1;
chart.bottomRow = 23;
chart.rightColumn = 8;
// set charts to worksheet.
sheet.charts = charts;
// save and dispose the workbook.
final List<int> bytes = workbook.saveAsStream();
workbook.dispose();
File('AreaChart.xlsx').writeAsBytes(bytes);
This section covers the various stacked 100 chart.
Stacked 100 Column chart
Use the following code to add stacked 100 column chart to Excel worksheet.
// Create a new Excel document.
final Workbook workbook = Workbook();
// Accessing worksheet via index.
final Worksheet sheet = workbook.worksheets[0];
// Setting value in the cell.
sheet.getRangeByName('A1').text = 'Fruits';
sheet.getRangeByName('A2').text = 'Apples';
sheet.getRangeByName('A3').text = 'Grapes';
sheet.getRangeByName('A4').text = 'Bananas';
sheet.getRangeByName('A5').text = 'Oranges';
sheet.getRangeByName('A6').text = 'Melons';
sheet.getRangeByName('B1').text = 'Joey';
sheet.getRangeByName('B2').number = 5;
sheet.getRangeByName('B3').number = 4;
sheet.getRangeByName('B4').number = 4;
sheet.getRangeByName('B5').number = 2;
sheet.getRangeByName('B6').number = 2;
sheet.getRangeByName('C1').text = 'Mathew';
sheet.getRangeByName('C2').number = 3;
sheet.getRangeByName('C3').number = 5;
sheet.getRangeByName('C4').number = 4;
sheet.getRangeByName('C5').number = 1;
sheet.getRangeByName('C6').number = 7;
sheet.getRangeByName('D1').text = 'Peter';
sheet.getRangeByName('D2').number = 2;
sheet.getRangeByName('D3').number = 2;
sheet.getRangeByName('D4').number = 3;
sheet.getRangeByName('D5').number = 5;
sheet.getRangeByName('D6').number = 6;
// Create an instances of chart collection.
final ChartCollection charts = ChartCollection(sheet);
// Add the chart.
final Chart chart = charts.add();
// Set Chart Type.
chart.chartType = ExcelChartType.columnStacked100;
// Set data range in the worksheet.
chart.dataRange = sheet.getRangeByName('A1:D6');
chart.isSeriesInRows = false;
//Set Chart Title
chart.chartTitle = 'Stacked 100 Column Chart';
//Set Legend
chart.hasLegend = true;
chart.legend.position = ExcelLegendPosition.bottom;
//Positioning the chart in the worksheet
chart.topRow = 8;
chart.leftColumn = 1;
chart.bottomRow = 23;
chart.rightColumn = 8;
// set charts to worksheet.
sheet.charts = charts;
// save and dispose the workbook.
final List<int> bytes = workbook.saveAsStream();
workbook.dispose();
File('ColumnStacked100Chart.xlsx').writeAsBytes(bytes);
Stacked 100 bar chart
Use the following code to add stacked 100 bar chart to Excel worksheet.
// Create a new Excel document.
final Workbook workbook = Workbook();
// Accessing worksheet via index.
final Worksheet sheet = workbook.worksheets[0];
// Setting value in the cell.
sheet.getRangeByName('A1').text = 'Fruits';
sheet.getRangeByName('A2').text = 'Apples';
sheet.getRangeByName('A3').text = 'Grapes';
sheet.getRangeByName('A4').text = 'Bananas';
sheet.getRangeByName('A5').text = 'Oranges';
sheet.getRangeByName('A6').text = 'Melons';
sheet.getRangeByName('B1').text = 'Joey';
sheet.getRangeByName('B2').number = 5;
sheet.getRangeByName('B3').number = 4;
sheet.getRangeByName('B4').number = 4;
sheet.getRangeByName('B5').number = 2;
sheet.getRangeByName('B6').number = 2;
sheet.getRangeByName('C1').text = 'Mathew';
sheet.getRangeByName('C2').number = 3;
sheet.getRangeByName('C3').number = 5;
sheet.getRangeByName('C4').number = 4;
sheet.getRangeByName('C5').number = 1;
sheet.getRangeByName('C6').number = 7;
sheet.getRangeByName('D1').text = 'Peter';
sheet.getRangeByName('D2').number = 2;
sheet.getRangeByName('D3').number = 2;
sheet.getRangeByName('D4').number = 3;
sheet.getRangeByName('D5').number = 5;
sheet.getRangeByName('D6').number = 6;
// Create an instances of chart collection.
final ChartCollection charts = ChartCollection(sheet);
// Add the chart.
final Chart chart = charts.add();
// Set Chart Type.
chart.chartType = ExcelChartType.barStacked100;
// Set data range in the worksheet.
chart.dataRange = sheet.getRangeByName('A1:D6');
chart.isSeriesInRows = false;
//Set Chart Title
chart.chartTitle = 'Stacked 100 bar Chart';
//Set Legend
chart.hasLegend = true;
chart.legend.position = ExcelLegendPosition.bottom;
//Positioning the chart in the worksheet
chart.topRow = 8;
chart.leftColumn = 1;
chart.bottomRow = 23;
chart.rightColumn = 8;
// set charts to worksheet.
sheet.charts = charts;
// save and dispose the workbook.
final List<int> bytes = workbook.saveAsStream();
workbook.dispose();
File('BarStacked100Chart.xlsx').writeAsBytes(bytes);
Stacked 100 Line chart
Use the following code to add stacked 100 line chart to Excel worksheet.
// Create a new Excel document.
final Workbook workbook = Workbook();
// Accessing worksheet via index.
final Worksheet sheet = workbook.worksheets[0];
// Setting value in the cell.
sheet.getRangeByName('A1').text = 'Fruits';
sheet.getRangeByName('A2').text = 'Apples';
sheet.getRangeByName('A3').text = 'Grapes';
sheet.getRangeByName('A4').text = 'Bananas';
sheet.getRangeByName('A5').text = 'Oranges';
sheet.getRangeByName('A6').text = 'Melons';
sheet.getRangeByName('B1').text = 'Joey';
sheet.getRangeByName('B2').number = 5;
sheet.getRangeByName('B3').number = 4;
sheet.getRangeByName('B4').number = 4;
sheet.getRangeByName('B5').number = 2;
sheet.getRangeByName('B6').number = 2;
sheet.getRangeByName('C1').text = 'Mathew';
sheet.getRangeByName('C2').number = 3;
sheet.getRangeByName('C3').number = 5;
sheet.getRangeByName('C4').number = 4;
sheet.getRangeByName('C5').number = 1;
sheet.getRangeByName('C6').number = 7;
sheet.getRangeByName('D1').text = 'Peter';
sheet.getRangeByName('D2').number = 2;
sheet.getRangeByName('D3').number = 2;
sheet.getRangeByName('D4').number = 3;
sheet.getRangeByName('D5').number = 5;
sheet.getRangeByName('D6').number = 6;
// Create an instances of chart collection.
final ChartCollection charts = ChartCollection(sheet);
// Add the chart.
final Chart chart = charts.add();
// Set Chart Type.
chart.chartType = ExcelChartType.lineStacked100;
// Set data range in the worksheet.
chart.dataRange = sheet.getRangeByName('A1:D6');
chart.isSeriesInRows = false;
//Set Chart Title
chart.chartTitle = 'Stacked 100 line Chart';
//Set Legend
chart.hasLegend = true;
chart.legend.position = ExcelLegendPosition.bottom;
//Positioning the chart in the worksheet
chart.topRow = 8;
chart.leftColumn = 1;
chart.bottomRow = 23;
chart.rightColumn = 8;
// set charts to worksheet.
sheet.charts = charts;
// save and dispose the workbook.
final List<int> bytes = workbook.saveAsStream();
workbook.dispose();
File('lineStacked100Chart.xlsx').writeAsBytes(bytes);
Stacked 100 Area chart
Use the following code to add stacked 100 area chart to Excel worksheet.
// Create a new Excel document.
final Workbook workbook = Workbook();
// Accessing worksheet via index.
final Worksheet sheet = workbook.worksheets[0];
// Setting value in the cell.
sheet.getRangeByName('A1').text = 'Fruits';
sheet.getRangeByName('A2').text = 'Apples';
sheet.getRangeByName('A3').text = 'Grapes';
sheet.getRangeByName('A4').text = 'Bananas';
sheet.getRangeByName('A5').text = 'Oranges';
sheet.getRangeByName('A6').text = 'Melons';
sheet.getRangeByName('B1').text = 'Joey';
sheet.getRangeByName('B2').number = 5;
sheet.getRangeByName('B3').number = 4;
sheet.getRangeByName('B4').number = 4;
sheet.getRangeByName('B5').number = 2;
sheet.getRangeByName('B6').number = 2;
sheet.getRangeByName('C1').text = 'Mathew';
sheet.getRangeByName('C2').number = 3;
sheet.getRangeByName('C3').number = 5;
sheet.getRangeByName('C4').number = 4;
sheet.getRangeByName('C5').number = 1;
sheet.getRangeByName('C6').number = 7;
sheet.getRangeByName('D1').text = 'Peter';
sheet.getRangeByName('D2').number = 2;
sheet.getRangeByName('D3').number = 2;
sheet.getRangeByName('D4').number = 3;
sheet.getRangeByName('D5').number = 5;
sheet.getRangeByName('D6').number = 6;
// Create an instances of chart collection.
final ChartCollection charts = ChartCollection(sheet);
// Add the chart.
final Chart chart = charts.add();
// Set Chart Type.
chart.chartType = ExcelChartType.areaStacked100;
// Set data range in the worksheet.
chart.dataRange = sheet.getRangeByName('A1:D6');
chart.isSeriesInRows = false;
//Set Chart Title
chart.chartTitle = 'Stacked 100 Area Chart';
//Set Legend
chart.hasLegend = true;
chart.legend.position = ExcelLegendPosition.bottom;
//Positioning the chart in the worksheet
chart.topRow = 8;
chart.leftColumn = 1;
chart.bottomRow = 23;
chart.rightColumn = 8;
// set charts to worksheet.
sheet.charts = charts;
// save and dispose the workbook.
final List<int> bytes = workbook.saveAsStream();
workbook.dispose();
File('AreaStacked100Chart.xlsx').writeAsBytes(bytes);
- For any other queries, contact our Syncfusion support team or post the queries through the Community forums. You can also submit a feature request or a bug through our Feedback portal.
- To renew the subscription, click renew or contact our sales team at [email protected] | Toll Free: 1-888-9 DOTNET.
Founded in 2001 and headquartered in Research Triangle Park, N.C., Syncfusion has more than 20,000 customers and more than 1 million users, including large financial institutions, Fortune 500 companies, and global IT consultancies.
Today we provide 1,000+ controls and frameworks for web (ASP.NET Core, ASP.NET MVC, ASP.NET WebForms, JavaScript, Angular, React, Vue, and Blazor), mobile (Xamarin, Flutter, UWP, and JavaScript), and desktop development (WinForms, WPF, and UWP). We provide ready-to-deploy enterprise software for dashboards, reports, data integration, and big data processing. Many customers have saved millions in licensing fees by deploying our software.