Chart Area in Excel document

26 Aug 20247 minutes to read

Chart area refers to the space that contains the entire chart or graph within a document. It includes all elements of the chart, such as data points, labels, axes, and the plot area. Using XlsIO, you can customize various aspects of the chart area in the chart.

Formatting

Border

The following code snippet illustrates how to format the border of the chart area.

//Format Chart Area
IChartFrameFormat chartArea = chart.ChartArea;

//Set the border
chartArea.Border.LinePattern = ExcelChartLinePattern.Solid;
chartArea.Border.LineColor = Color.Blue;
chartArea.Border.LineWeight = ExcelChartLineWeight.Hairline;
//Format Chart Area
IChartFrameFormat chartArea = chart.ChartArea;

//Set the border
chartArea.Border.LinePattern = ExcelChartLinePattern.Solid;
chartArea.Border.LineColor = Color.Blue;
chartArea.Border.LineWeight = ExcelChartLineWeight.Hairline;
'Format Chart Area
IChartFrameFormat chartArea = chart.ChartArea

'Set the border
chartArea.Border.LinePattern = ExcelChartLinePattern.Solid
chartArea.Border.LineColor = Color.Blue
chartArea.Border.LineWeight = ExcelChartLineWeight.Hairline

Color

The following code snippet illustrates how to format the color of the chart area.

//Set the color
chartArea.Fill.FillType = ExcelFillType.Gradient;
chartArea.Fill.GradientColorType = ExcelGradientColor.TwoColor;
chartArea.Fill.BackColor = Color.FromArgb(205, 217, 234);
chartArea.Fill.ForeColor = Color.White;
//Set the color
chartArea.Fill.FillType = ExcelFillType.Gradient;
chartArea.Fill.GradientColorType = ExcelGradientColor.TwoColor;
chartArea.Fill.BackColor = Color.FromArgb(205, 217, 234);
chartArea.Fill.ForeColor = Color.White;
'Set the color
chartArea.Fill.FillType = ExcelFillType.Gradient
chartArea.Fill.GradientColorType = ExcelGradientColor.TwoColor
chartArea.Fill.BackColor = Color.FromArgb(205, 217, 234)
chartArea.Fill.ForeColor = Color.White

The complete code snippet illustrating the above options is shown below.

using (ExcelEngine excelEngine = new ExcelEngine())
{
  IApplication application = excelEngine.Excel;
  application.DefaultVersion = ExcelVersion.Xlsx;
  FileStream inputStream = new FileStream("../../../Data/InputTemplate.xlsx", FileMode.Open, FileAccess.Read);
  IWorkbook workbook = application.Workbooks.Open(inputStream);  
  IWorksheet sheet = workbook.Worksheets[0];
  IChartShape chart = sheet.Charts[0];

  //Format Chart Area
  IChartFrameFormat chartArea = chart.ChartArea;

  //Set the border
  chartArea.Border.LinePattern = ExcelChartLinePattern.Solid;
  chartArea.Border.LineColor = Color.Blue;
  chartArea.Border.LineWeight = ExcelChartLineWeight.Hairline;

  //Set the color
  chartArea.Fill.FillType = ExcelFillType.Gradient;
  chartArea.Fill.GradientColorType = ExcelGradientColor.TwoColor;
  chartArea.Fill.BackColor = Color.FromArgb(205, 217, 234);
  chartArea.Fill.ForeColor = Color.White;

  //Saving the workbook as stream
  FileStream outputStream = new FileStream("Output.xlsx", FileMode.Create, FileAccess.ReadWrite);
  workbook.SaveAs(outputStream);

  //Dispose streams
  outputStream.Dispose();
  inputStream.Dispose();
}
using (ExcelEngine excelEngine = new ExcelEngine())
{
  IApplication application = excelEngine.Excel;
  application.DefaultVersion = ExcelVersion.Xlsx;
  IWorkbook workbook = application.Workbooks.Open("InputTemplate.xlsx");
  IWorksheet sheet = workbook.Worksheets[0];
  IChartShape chart = sheet.Charts[0];

  //Format Chart Area
  IChartFrameFormat chartArea = chart.ChartArea;

  //Set the border
  chartArea.Border.LinePattern = ExcelChartLinePattern.Solid;
  chartArea.Border.LineColor = Color.Blue;
  chartArea.Border.LineWeight = ExcelChartLineWeight.Hairline;

  //Set the color
  chartArea.Fill.FillType = ExcelFillType.Gradient;
  chartArea.Fill.GradientColorType = ExcelGradientColor.TwoColor;
  chartArea.Fill.BackColor = Color.FromArgb(205, 217, 234);
  chartArea.Fill.ForeColor = Color.White;

  //Saving the workbook
  workbook.SaveAs("Output.xlsx");
}
Using excelEngine As ExcelEngine = New ExcelEngine()
  Dim application As IApplication = excelEngine.Excel
  application.DefaultVersion = ExcelVersion.Xlsx
  Dim workbook As IWorkbook = application.Workbooks.Open("InputTemplate.xlsx")
  Dim sheet As IWorksheet = workbook.Worksheets(0)
  Dim chart As IChartShape = sheet.Charts(0)

  'Format Chart Area
  Dim chartArea As IChartFrameFormat = chart.ChartArea

  'Set the border
  chartArea.Border.LinePattern = ExcelChartLinePattern.Solid
  chartArea.Border.LineColor = Color.Blue
  chartArea.Border.LineWeight = ExcelChartLineWeight.Hairline

  'Set the color
  chartArea.Fill.FillType = ExcelFillType.Gradient
  chartArea.Fill.GradientColorType = ExcelGradientColor.TwoColor
  chartArea.Fill.BackColor = Color.FromArgb(205, 217, 234)
  chartArea.Fill.ForeColor = Color.White

  'Saving the workbook
  workbook.SaveAs("Output.xlsx")
End Using

A complete working example for the chart area in C# is present on this GitHub page.

Transparency

The following code snippet illustrates how to apply transparency in the chart area.

//Set the transparency
chartArea.Fill.Transparency = 0.5;
//Set the transparency
chartArea.Fill.Transparency = 0.5;
'Set the transparency
chartArea.Fill.Transparency = 0.5

NOTE

Transparency is only applicable when FillType is set as SolidColor. Color-shaded fill is represented as a floating-point value ranging from 0.0 (Clear) to 1.0 (Opaque).