zoukankan      html  css  js  c++  java
  • ECharts中color : function的用法(转)

    ECharts图表实战经验1:如何设置图表同序列不同数据点的独立颜色值

     

    最近有不少朋友在追问这样一个问题:我单序列的柱状图,我想让每一个根柱子的颜色都不一样,应该如何做?

    针对这个问题,其实我只想说你压根没有认真看完或者查找ECharts官方的示例,官方能够找到的示例有:

    1、http://echarts.baidu.com/doc/example/bar14.html

    2、http://echarts.baidu.com/doc/example/bar15.html

    那么你看完过后是否能够明白其中的道理呢?数据点的属性首先是通过itemStyle节点进行控制的,我们要控制数据点的颜色,自然我们就需要设置color,另外根据ECharts的API介绍,color是支持Function函数的。

    我们首先来看看这样一个例子:

    示例一:根据数据点所在序号从一个颜色数组内拿拿取对应颜色值

    我们首先设置一个颜色数组,最好比序列内的数据点个数要大或者相等,结合itemStyle内color的函数根据当前数据点在当前序列内所处的顺序序号去颜色数组内自动匹配颜色。

    代码如下所示:

    复制代码
    option = {
        title : {
            text: '某地区蒸发量和降水量',
            subtext: '纯属虚构'
        },
        tooltip : {
            trigger: 'axis'
        },
        legend: {
            data:['蒸发量']
        },
        toolbox: {
            show : true,
            feature : {
                mark : {show: true},
                dataView : {show: true, readOnly: false},
                magicType : {show: true, type: ['line', 'bar']},
                restore : {show: true},
                saveAsImage : {show: true}
            }
        },
        calculable : true,
        xAxis : [
            {
                type : 'category',
                data : ['1月','2月','3月','4月','5月','6月','7月','8月','9月','10月','11月','12月']
            }
        ],
        yAxis : [
            {
                type : 'value'
            }
        ],
        series : [
            {
                name:'蒸发量',
                type:'bar',
                data:[2.0, 4.9, 7.0, 23.2, 25.6, 76.7, 135.6, 162.2, 32.6, 20.0, 6.4, 3.3],
               itemStyle: {
                    normal: {
                        color: function(params) {
                            // build a color map as your need.
                            var colorList = [
                              '#C1232B','#B5C334','#FCCE10','#E87C25','#27727B',
                               '#FE8463','#9BCA63','#FAD860','#F3A43B','#60C0DD',
                               '#D7504B','#C6E579','#F4E001','#F0805A','#26C0C0'
                            ];
                            return colorList[params.dataIndex]
                        }
                    }
                }
            }
        ]
    };                  
    复制代码

    效果是不是很炫?!

    示例二:通过配置数据点的颜色扩展属性来达到控制不同数据点的颜色

    我们最想实现的应该是我们自己能够设置每一个数据点的颜色值,而非通过设置颜色数组的形式,那么我们应该如何做呢?

    1、我们需要改写series的data格式,之前是一个一维数据类型的数组,先走我们需要将至变成一个对象类型的一维数组,如下所示;

    复制代码
    
    
    data:[{
                  value:2.0,
                  color:"red"
                }, 4.9, 7.0, {
                  value:23.2,
                  color:"green"
                }, 25.6, 76.7, 135.6, 162.2, 32.6, 20.0, 6.4, 3.3]
     
    复制代码

    某些数据点我设置了其color属性,也就是我要用所配置的颜色来渲染柱子。

    2、为了没有配置颜色属性的数据点的颜色显示有所归属(因为我们通过params找不到当前序列的颜色,所以我们最好自己给其series设置一个颜色属性。如下所示:

    复制代码
    {
                name:'蒸发量',
                type:'bar',
                color:"#ff7f50",
                data:[{
                  value:2.0,
                  color:"red"
                }, 4.9, 7.0, {
                  value:23.2,
                  color:"green"
                }, 25.6, 76.7, 135.6, 162.2, 32.6, 20.0, 6.4, 3.3],
                itemStyle: {
                    normal: {
                      color: function(params) {                    
                        if(params.series.data[params.dataIndex] != null && params.series.data[params.dataIndex].color != undefined)
                        {
                           return params.series.data[params.dataIndex].color;
                        }else
                        {
                          return params.series.color;
                        }
                      }
                    }
                }
            }
    复制代码

    最后我们就可以通过改写itemStyle内color的function函数规则来返回数据点对象所配置的颜色以及序列所配置的颜色。

    当数据点对象尚未配置颜色color属性时,我们就返回当前序列所配置的color即可。

    示例代码的option配置如下所示:

    复制代码
    option = {
        title : {
            text: '某地区蒸发量和降水量',
            subtext: '纯属虚构'
        },
        tooltip : {
            trigger: 'axis'
        },
        legend: {
            data:['蒸发量']
        },
        toolbox: {
            show : true,
            feature : {
                mark : {show: true},
                dataView : {show: true, readOnly: false},
                magicType : {show: true, type: ['line', 'bar']},
                restore : {show: true},
                saveAsImage : {show: true}
            }
        },
        calculable : true,
        xAxis : [
            {
                type : 'category',
                data : ['1月','2月','3月','4月','5月','6月','7月','8月','9月','10月','11月','12月']
            }
        ],
        yAxis : [
            {
                type : 'value'
            }
        ],
        series : [
            {
                name:'蒸发量',
                type:'bar',
                color:"#ff7f50",
                data:[{
                  value:2.0,
                  color:"red"
                }, 4.9, 7.0, {
                  value:23.2,
                  color:"green"
                }, 25.6, 76.7, 135.6, 162.2, 32.6, 20.0, 6.4, 3.3],
                itemStyle: {
                    normal: {
                      color: function(params) {                    
                        if(params.series.data[params.dataIndex] != null && params.series.data[params.dataIndex].color != undefined)
                        {
                           return params.series.data[params.dataIndex].color;
                        }else
                        {
                          return params.series.color;
                        }
                      }
                    }
                }
            }
        ]
    };
                        
    复制代码

    作者: 王春天
    出处: http://www.cnblogs.com/spring_wang/
    Email: spring_best@yeah.net
    QQ交流:903639067 
    QQ群:322581894 关于作者:SNF快速开发平台 创始人。专注于快速开发平台的开发、代码生成器。同时专注于微软平台项目架构、管理和企业解决方案,多年项目开发与管理经验,精通DotNet,DB(SqlServer、Oracle等)技术。熟悉Java、VB及PB开发语言。在面向对象、面向服务以及数据库领域有一定的造诣。现从事项目实施、开发、架构等工作。并从事用友软件产品U8、U9、PLM 客开工作。 如有问题或建议,请多多赐教! 本文版权归作者和CNBLOGS博客共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,如有问题,可以通过邮箱或QQ 联系我,非常感谢。
  • 相关阅读:
    [Unity热更新]LuaFramework08.修改加载方式
    [Unity热更新]LuaFramework07.lua逻辑
    [Unity热更新]LuaFramework06.更新资源
    [Unity热更新]LuaFramework05.MonoBehaviour(lua版本)
    [Unity热更新]LuaFramework04.UI界面
    [Unity热更新]05.AssetBundleBrowser
    大数据学习day10-----zookeeper--------1.小文件合并,2 输入和输出 3 多路径输出 4.zookeeper(选举机制,安装,zk的shell客户端、java客户端)
    大数据学习day09----hadoop--day06-------1.MR程序在yarn上运行的基本流程 2. 数据倾斜解决方案 3.高效topN(指定分区器,分组规则,自定义排序规则)
    大数据学习-----day08-----hadoop05-------0.补充(查询源代码的操作)1.MR程序数据处理全流程 2.yarn 3. merger案例(小文件合并)4.数据倾斜 5join案例
    大数据学习day7------hadoop04----1 流量案例 2 电影案例(统计每部电影的均分,统计每个人的均分,统计电影的评论次数,***统计每部电影评分最高的N条记录(Integer.max),统计评论次数最多的n部电影(全局排序)) 3 line线段重叠次数案例 4.索引案例
  • 原文地址:https://www.cnblogs.com/hao-1234-1234/p/9182733.html
Copyright © 2011-2022 走看看