今天在做一个图形报表,有个需求是要把展现的统计图保存为图片, 图形报表用的Echarts-2.2.7,

以前有用过 Echarts,记得echarts插件是可以帮助我们把统计图保存为图片的。

只是不记得是怎么配置了,查看API文档很久也没有找到,最后在 文档/配置项手册 里面找到了配置方法 和配置 参数。

下图是 Echarts官网 实例中的配置:

下面来说说配置保存图片的步骤:

1.保存图片是Echarts的一个工具,先找到工具箱

  

toolbox

工具栏。内置有导出图片数据视图动态类型切换数据区域缩放重置五个工具。

2. 然后再找到 各工具的配置项

  

toolbox.feature Object
 

各工具配置项。

除了各个内置的工具按钮外,还可以自定义工具按钮。

3. 再找到保存图片的配置

toolbox.feature.saveAsImage Object

保存为图片。

4. 再看到了保存图片的配置项有的属性 和可填 参数

toolbox.feature.saveAsImage.type string
[ default: 'png' ]

保存的图片格式。支持 'png''jpeg'

toolbox.feature.saveAsImage.name string
 

保存的文件名称,默认使用 title.text 作为名称。

toolbox.feature.saveAsImage.backgroundColor Color
[ default: 'auto' ]

保存的图片背景色,默认使用 backgroundColor,如果backgroundColor不存在的话会取白色。

toolbox.feature.saveAsImage.excludeComponents Array
[ default: ['toolbox'] ]

保存为图片时忽略的组件列表,默认忽略工具栏。

toolbox.feature.saveAsImage.show boolean
[ default: true ]

是否显示该工具。

toolbox.feature.saveAsImage.title boolean
[ default: '保存为图片' ]
toolbox.feature.saveAsImage.icon *
 

Icon 的 path 字符串,ECharts 3 中支持使用自定义的 svg path 作为 icon,格式参见 SVG PathData。可以从 Adobe Illustrator 等工具编辑导出。

 
toolbox.feature.saveAsImage.iconStyle Object
 

保存为图片 icon 样式设置。

toolbox.feature.saveAsImage.pixelRatio number
[ default: 1 ]

保存图片的分辨率比例,默认跟容器相同大小,如果需要保存更高分辨率的,可以设置为大于 1 的值,例如 2。

5. 然后根据 自己的需求去配置就好了

6.查看文档库 截图

7. 项目的 JS 代码

require(
                          [
                           'echarts',
                           'echarts/chart/bar'   // 按需加载所需图表
                           ],
                           function (ec) {
                            // 基于准备好的dom,初始化echarts图表
                            var myChart1 = ec.init(document.getElementById('pro-price-main'));
                            option1 = {
                                 title : {
                                    text: '文档数量(单位:个)',
                                    textStyle: {
                                        fontWeight: 'normal',
                                        fontSize: '15',
                                        color: '#999'
                                    },
                                    x: 54
                                },
                                tooltip : {
                                    show: true,
                                    trigger: 'item',
                                },
                                legend: {
                                    x: 'center',
                                    y: 0,
                                    orient : 'horizontal',
                                    itemGap: 20,
                                    itemWidth: 30,
                                    itemHeight : 20,
                                    textStyle: {
                                        color: '#999'
                                    },
                                    data:['文库总数','文库增长数']
                                },
                                toolbox: {
                                    show: true,
                                    feature: {
                                        magicType: {
                                            type: ['stack', 'tiled']
                                        },
                                        dataView: {show:true},
                                        saveAsImage: {
                                            show:true,
                                            excludeComponents :['toolbox'],
                                            pixelRatio: 2
                                            
                                        }
                                    }
                                },
                                calculable : true,
                               
                                xAxis : [
                                    {
                                        type : 'category',
                                        show: true,
                                        splitLine: false,
                                        axisLine: {
                                            lineStyle: {
                                                width: 1,
                                                color: '#f2f2f2'
                                            }
                                        },
                                        axisLabel: {
                                            textStyle: {
                                                align: 'center',
                                                color: '#999'
                                            }
                                        },
                                        axisTick: {
                                            show: false
                                        },
                                        data : result.results["docMonthData"]  
                                    }
                                ],
                                yAxis : [
                                    {
                                        type : 'value',
                                        show: true,
                                        splitLine: {
                                            lineStyle: {
                                                color: ['#f2f2f2'],
                                                width: 1,
                                            }
                                        },
                                        axisLine: {
                                            lineStyle: {
                                                width: 1,
                                                color: '#f2f2f2'
                                            }
                                        },
                                        axisLabel: {
                                            textStyle: {
                                                color: '#999'
                                            }
                                        }
                                    }
                                ],
                                series : [
                                    {
                                        name:'文库总数',
                                        type:'bar',
                                        stack: '总量',
                                        data: result.results["docTotalData"],
                                        itemStyle: {
                                            normal: {
                                                color: '#7266ba'
                                            }
                                        }
                                    },
                                    {
                                        name:'文库增长数',
                                        type:'bar',
                                        stack: '总量',
                                        itemStyle: {                // 系列级个性化
                                            normal: {
                                                color: '#f9d21a'
                                            }
                                        },
                                        data: result.results["growthNumData"]
                                    }
                                ]
                            };
                            // 为echarts对象加载数据
                            myChart1.setOption(option1);
                          }
                      );

Echarts-2.2.7中统计出来的统计图保存为图片的更多相关文章

  1. Android将view保存为图片并放在相册中

    在Android中,可以将view保存为图片并放在相册中,步骤为 view->bitmap->file,即先将view转化为bitmap,再将bitmap保存到相册中. 需要将红框标注的v ...

  2. java学习,从一个字符串中统计同一类型出现的次数

    1.从字符串“AS345asdzf*())sddsWE”中统计大写字母.小写字母.其他类型的出现的次数 String s="AS345asdzf*())sddsWE"; int l ...

  3. SQL Server 中统计信息直方图中对于没有覆盖到谓词预估以及预估策略的变化(SQL2012-->SQL2014-->SQL2016)

    本位出处:http://www.cnblogs.com/wy123/p/6770258.html 统计信息写过几篇了相关的文章了,感觉还是不过瘾,关于统计信息的问题,最近又踩坑了,该问题虽然不算很常见 ...

  4. MySQL 8.0 中统计信息直方图的尝试

    直方图是表上某个字段在按照一定百分比和规律采样后的数据分布的一种描述,最重要的作用之一就是根据查询条件,预估符合条件的数据量,为sql执行计划的生成提供重要的依据在MySQL 8.0之前的版本中,My ...

  5. 【未解决】对于使用Windows的IDEA进行编译的文件,但无法在Linux系统中统计代码行数的疑问

    在我学习使用Windows的IDEA的过程中,将代码文件转移到Linux虚拟机当中,但无法在Linux系统中统计代码行数. 注意:拷贝进虚拟机的文件均能编译运行. 具体过程如下: root@yogil ...

  6. SQLSERVER中统计所有表的记录数

    SQLSERVER中统计所有表的记录数 利用系统索引表sysindexes中索引ID indid<1的行中的rows列存有该表的行数这一特点.    方法是利用隐藏未公开的系统存储过程sp_MS ...

  7. Java使用极小的内存完成对超大数据的去重计数,用于实时计算中统计UV

    Java使用极小的内存完成对超大数据的去重计数,用于实时计算中统计UV – lxw的大数据田地 http://lxw1234.com/archives/2015/09/516.htm Java使用极小 ...

  8. (转)如何在Linux中统计一个进程的线程数

    如何在Linux中统计一个进程的线程数 原文:http://os.51cto.com/art/201509/491728.htm 我正在运行一个程序,它在运行时会派生出多个线程.我想知道程序在运行时会 ...

  9. c#Winform程序调用app.config文件配置数据库连接字符串 SQL Server文章目录 浅谈SQL Server中统计对于查询的影响 有关索引的DMV SQL Server中的执行引擎入门 【译】表变量和临时表的比较 对于表列数据类型选择的一点思考 SQL Server复制入门(一)----复制简介 操作系统中的进程与线程

    c#Winform程序调用app.config文件配置数据库连接字符串 你新建winform项目的时候,会有一个app.config的配置文件,写在里面的<connectionStrings n ...

随机推荐

  1. KMP算法:next和nextval值计算

    KMP算法的next和nextval值计算 先看看next数据值的求解方法 例:下标从1开始(若题中给定下标为0开始,把所有值-1即可) next数组的求解方法:根据前一个字符next,一直循环找到第 ...

  2. 开启Android Apk调试与备份选项的Xposed模块的编写

    本文博客地址:https://blog.csdn.net/QQ1084283172/article/details/80963610 在进行Android应用程序逆向分析的时候,经常需要进行Andro ...

  3. Python中的Pexpect模块的简单使用

    Pexpect 是一个用来启动子程序并对其进行自动控制的 Python 模块. Pexpect 可以用来和像 ssh.ftp.passwd.telnet 等命令行程序进行自动交互.以下所有代码都是在K ...

  4. Android系统自带的android.util.Base64的实现源码

    由于Android逆向还原的时候,经常需要用到android.util.Base64的代码,因此从Android 4.4.4的 系统里抠出来进行备份,懒得用其他的代码进行修改替换了. /* * Cop ...

  5. Win64 驱动内核编程-26.强制结束进程

    强制结束进程 依然已经走到驱动这一层了,那么通常结束掉一个进程不是什么难的事情.同时因为win64 位的各种保护,导致大家慢慢的已经不敢HOOK了,当然这指的是产品.作为学习和破解的话当然可以尝试各种 ...

  6. [CTF]凯撒密码

    [CTF]凯撒密码 ---------------------  作者:___Blue_H  来源:CSDN  原文:https://blog.csdn.net/qq_37653144/article ...

  7. 1 cmd

    打开cmd 在终端打开指定文件 按住alt+e打开我的电脑 ​ 补充: ​ 1.windows和+组合快捷键 放大镜,(同理windows -) 然后在地址栏输入cmd,回车即可 常用命令 #盘符切换 ...

  8. JavaScript 原始值与包装对象

    前言 随着 JavaScript 越来越流行,越来越多地开发者开始接触并使用 JavaScript. 同时我也发现,有不少开发者对于 JavaScript 最基本的原始值和包装对象都没有很清晰的理解. ...

  9. flex布局的使用

    一.Flex布局是什么? Flex是Flexible Box的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性. 任何一个容器都可以指定为Flex布局. .box{ disp ...

  10. base64stego 还不懂base64的隐写,详解15行代码带你领略

    网上写了好多关于xctf MISC新手篇的base64Stego隐写的教程,但大都不太清楚,基本上都是讲了一段隐写原理,直接上代码了.但是代码是这道题的关键,代码讲了如何解码这个隐写的完整流程,这次我 ...