欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

C# 填充Excel图表、图例背景色

程序员文章站 2022-03-20 09:38:14
填充背景色,一般可以选择多种不同样式来填充背景,包括填充为纯色背景、渐变背景、图片背景或者纹理背景等。下面的内容将分别介绍通过C#来设置Excel中图表背景色、以及图表中的图例背景色的方法。 使用工具:Spire.XLS for .NET dll引用:下载安装后,注意在程序中添加引用Spire.Xl ......

填充背景色,一般可以选择多种不同样式来填充背景,包括填充为纯色背景、渐变背景、图片背景或者纹理背景等。下面的内容将分别介绍通过c#来设置excel中图表背景色、以及图表中的图例背景色的方法。

使用工具spire.xls for .net

dll引用:下载安装后,注意在程序中添加引用spire.xls.dll(dll文件在安装路径下的bin文件夹中获取)

C# 填充Excel图表、图例背景色

【示例1】填充图表背景色

测试文档如下:

C# 填充Excel图表、图例背景色

step1:加载文档

//实例化workbook类的对象
workbook workbook = new workbook();
//加载测试文档
workbook.loadfromfile("sample.xlsx");

step2:获取图表

//获取第一个工作表中的第一个图表
worksheet ws = workbook.worksheets[1];
chart chart = ws.charts[0];

step3:填充图表背景色(纯色)

 //设置图表的背景填充色(纯色)
 chart.chartarea.fill.forecolor = color.lightskyblue;
 ////设置图表绘图区域的背景填充色(纯色)
 ///chart.plotarea.foregroundcolor =system.drawing.color.lightyellow;

step4:加载图片填充图表背景

// 加载图片,填充整个图表区域
chart.chartarea.fill.custompicture(image.fromfile("tp.png"), "none");
//设置绘图区域的图片填充的透明度
chart.plotarea.fill.transparency = 0.8;
////加载图片,仅填充图表中的绘图区域
//chart.plotarea.fill.custompicture(image.fromfile("tp.png"), "none");

step5:保存文档

workbook.savetofile("result.xlsx", excelversion.version2010);

纯色背景色设置效果:

1.填充整个图表

C# 填充Excel图表、图例背景色

2.填充图表中的绘图区域

C# 填充Excel图表、图例背景色

图片填充效果:

1.填充整个图表

C# 填充Excel图表、图例背景色

2.填充图表中的绘图区域

C# 填充Excel图表、图例背景色

 

全部代码:

using spire.xls;
using spire.xls.core.spreadsheet.charts;
using system.drawing;

namespace fillchartwithimg_xls
{
    class program
    {
        static void main(string[] args)
        {
            //实例化workbook类的对象
            workbook workbook = new workbook();
            //加载测试文档
            workbook.loadfromfile("sample.xlsx");

            //获取第一个工作表中的第一个图表
            worksheet ws = workbook.worksheets[1];
            chart chart = ws.charts[0];

            //设置图表的背景填充色(纯色)
            chart.chartarea.fill.forecolor = color.lightskyblue;
            //设置图表绘图区域的背景填充色(纯色)
            //chart.plotarea.foregroundcolor = system.drawing.color.lightyellow;


            //// 加载图片,填充整个图表区域
            //chart.chartarea.fill.custompicture(image.fromfile("tp.png"), "none");
            ////设置绘图区域的图片填充的透明度
            //chart.plotarea.fill.transparency = 0.8;

            ////加载图片,仅填充图表中的绘图区域
            //chart.plotarea.fill.custompicture(image.fromfile("tp.png"), "none");            

            //保存文档
            workbook.savetofile("result3.xlsx", excelversion.version2010);
            system.diagnostics.process.start("result3.xlsx");           
        }
    }
}

 

【示例2】填充图表中的图例背景色

测试图表:

C# 填充Excel图表、图例背景色

step1:加载文档

//实例化workbook类的对象,并加载测试文档
workbook workbook = new workbook();
workbook.loadfromfile("test.xlsx");

step2:获取图表

//获取工作表中的第一个图表
worksheet ws = workbook.worksheets[0];
spire.xls.chart chart = ws.charts[0];

step3:单色填充图例背景

//填充图例背景色
xlschartframeformat x = chart.legend.frameformat as xlschartframeformat;
//单色填充
x.fill.filltype = shapefilltype.solidcolor;
x.foregroundcolor = color.gainsboro;

step4:渐变色填充图例背景

//渐变色填充
x.fill.filltype = shapefilltype.gradient;
x.foregroundcolor = color.aliceblue;
x.backgroundcolor = color.bisque;

step5:纹理填充图例背景

//纹理填充
x.fill.filltype = shapefilltype.texture;
x.fill.texture = gradienttexturetype.bouquet;

step6:加载图片填充图例背景

//图片填充
x.fill.custompicture("img.png");

step7:保存文档

workbook.savetofile("output.xlsx", excelversion.version2010);

图例背景色填充效果:

1.单色填充效果

C# 填充Excel图表、图例背景色

2.渐变填充效果

C# 填充Excel图表、图例背景色

3.纹理填充效果

 C# 填充Excel图表、图例背景色

4.图片填充效果

 C# 填充Excel图表、图例背景色

全部代码:

using spire.xls;
using spire.xls.charts;
using spire.xls.core.spreadsheet.charts;
using system.drawing;

namespace setfontoflegendinchart_xls
{
    class program
    {
        static void main(string[] args)
        {
            //实例化workbook类的对象,并加载测试文档
            workbook workbook = new workbook();
            workbook.loadfromfile("test.xlsx");

            //获取工作表中的第一个图表
            worksheet ws = workbook.worksheets[0];
            spire.xls.chart chart = ws.charts[0];

            //填充图例背景色
            xlschartframeformat x = chart.legend.frameformat as xlschartframeformat;
            //单色填充
            x.fill.filltype = shapefilltype.solidcolor;
            x.foregroundcolor = color.gainsboro;

            ////渐变色填充
            //x.fill.filltype = shapefilltype.gradient;
            //x.foregroundcolor = color.aliceblue;
            //x.backgroundcolor = color.bisque;

            ////纹理填充
            //x.fill.filltype = shapefilltype.texture;
            //x.fill.texture = gradienttexturetype.bouquet;

            ////图片填充
            //x.fill.custompicture("img.png");

             //保存文档
            workbook.savetofile("output.xlsx", excelversion.version2010);
            system.diagnostics.process.start("output.xlsx");
        }
    }
}

 

更多excel背景色填充的方法,可参考以下文章:

1. c# 设置excel单元格背景色

2. c# 设置excel表格图片背景

(本文完)

转载请注明出处!