echarts彩虹柱状图 每个bar显示不同颜色, 标题在不同位置 ,工具中有可以直接保存为图片下载,平均线的添加

可以参考:

https://echarts.baidu.com/echarts2/doc/example.html

https://echarts.baidu.com/echarts2/doc/doc.html#LineStyle

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8" />
        <title></title>
    </head>
    <body>
        哈哈哈
        <div id="chartmain" style="600px; height: 400px;"></div>
    </body>
    <script type="text/javascript" src="js/jquery-3.3.1.min.js"></script>
    <script type="text/javascript" src="js/echarts.js"></script>
    <script>
        
option = {
    title: {
        //标题相对x、y轴的位置
        x: 'center',
        y: 'bottom',
        text: 'ECharts例子个数统计',
        subtext: 'Rainbow bar example',
        link: 'http://echarts.baidu.com/doc/example.html'
    },
    // 鼠标滑过柱状图显示值
    tooltip: {
        trigger: 'item'
    },
    // 右上角工具按钮
    toolbox: {
        show: true,
        feature: {
            dataView: {show: true, readOnly: false},
            restore: {show: true},
            saveAsImage: {show: true}
        }
    },
    calculable: true,
    grid: {
        borderWidth: 0,
        y: 80,
        y2: 60
    },
    xAxis: [
        {
            type: 'category',
            //x轴不显示(在鼠标滑过时,会显示在值前面)
            show: false,
            data: ['Line', 'Bar', 'Scatter', 'K', 'Pie', 'Radar', 'Chord', 'Force', 'Map', 'Gauge', 'Funnel']
        }
    ],
    yAxis: [
        {
            type: 'value',
            show: false
        }
    ],
    series: [
        {
            name: 'ECharts例子个数统计',
            type: 'bar',
            //定义每个bar的颜色和其上是否显示值
            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'
                        ];
                        //对每个bar显示一种颜色
                        return colorList[params.dataIndex]
                    },
                    label: {
                        //每个bar的最高点值显示在bar顶部
                        show: true,
                        position: 'top',
                        //值和x轴分类的显示格式(这里是换行显示)
                        formatter: '{b}
{c}'
                    }
                }
            },
            data: [12,21,10,4,12,5,6,5,25,23,7],
            markPoint: {
                tooltip: {
                    trigger: 'item',
                    backgroundColor: 'rgba(0,0,0,0)',
                    formatter: function(params){
                        return '<img src="' 
                                + params.data.symbol.replace('image://', '')
                                + '"/>';
                    }
                },
                data: [
                    {xAxis:0, y: 350, name:'Line', symbolSize:20, symbol: 'image://../asset/ico/折线图.png'},
                    {xAxis:1, y: 350, name:'Bar', symbolSize:20, symbol: 'image://../asset/ico/柱状图.png'},
                    {xAxis:2, y: 350, name:'Scatter', symbolSize:20, symbol: 'image://../asset/ico/散点图.png'},
                    {xAxis:3, y: 350, name:'K', symbolSize:20, symbol: 'image://../asset/ico/K线图.png'},
                    {xAxis:4, y: 350, name:'Pie', symbolSize:20, symbol: 'image://../asset/ico/饼状图.png'},
                    {xAxis:5, y: 350, name:'Radar', symbolSize:20, symbol: 'image://../asset/ico/雷达图.png'},
                    {xAxis:6, y: 350, name:'Chord', symbolSize:20, symbol: 'image://../asset/ico/和弦图.png'},
                    {xAxis:7, y: 350, name:'Force', symbolSize:20, symbol: 'image://../asset/ico/力导向图.png'},
                    {xAxis:8, y: 350, name:'Map', symbolSize:20, symbol: 'image://../asset/ico/地图.png'},
                    {xAxis:9, y: 350, name:'Gauge', symbolSize:20, symbol: 'image://../asset/ico/仪表盘.png'},
                    {xAxis:10, y: 350, name:'Funnel', symbolSize:20, symbol: 'image://../asset/ico/漏斗图.png'},
                ]
            }
        }
    ]
};
                    
                    
        //初始化echarts实例
        var myChart = echarts.init(document.getElementById('chartmain'));
        //使用制定的配置项和数据显示图表
        myChart.setOption(option);
    </script>
</html>

效果:

 上面是普通柱状图每个bar显示不同颜色的方法。

 -------------------------------------------------------------------------------------------------------

下面是分组柱状图

不同图例类型显示不同 自定义颜色 的设置方法 ,还包含 辅助线:平均线 的设置方法:

 

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8" />
        <title></title>
    </head>
    <body>
        哈哈哈3
        <div id="chartmain" style="600px; height: 400px;"></div>
    </body>
    <script type="text/javascript" src="js/jquery-3.3.1.min.js"></script>
    <script type="text/javascript" src="js/echarts.js"></script>
    <script>
        //调用画图表方法
        drawGroupChart("chartmain");
        
        //定义画分组柱状图方法
        function  drawGroupChart(domId){
            
            var title = "嘿嘿1";
            var xA =  ['周一', '周二', '周三', '周四'];
            var legendData = ['百度', '谷歌', '必应'];
            
            //[620, 732, 701, 734] 是x轴上每一组bar上的第一个柱子的数据的值的集合
            //[120, 132, 101, 134] 是x轴上每一组bar上的第二个柱子的数据的值的集合
            //所以,每一个小集合中数据的顺序都要和xA中的数据顺序对应,整个大集合中数据的顺序要和legendData对应
            var dataList = [[620, 732, 701, 734],[120, 132, 101, 134],[60, 72, 71, 74, 190]];
            
            //定义一个颜色集合
            var colorList = [
              '#C1232B','#B5C334','#FCCE10','#E87C25','#27727B',
               '#FE8463','#9BCA63','#FAD860','#F3A43B','#60C0DD',
               '#D7504B','#C6E579','#F4E001','#F0805A','#26C0C0'
            ];
            
            //定义ss容器
            var ss = [];
            
            //生成数据
            $.each(legendData,function(i,v){
                //定义一个对象
                var o = {
                        name:v,
                        type: 'bar',
                        data: dataList[i],
                        
                        //定义每一类bar的颜色和其上是否显示值(如果不定义itemStyle属性,会按照echarts中的默认颜色配置)
                        itemStyle: {
                            normal: {
                                color: function(params) {
                                    // return colorList[params.dataIndex] //对每个bar(对分组bar图就是每一组)(即按照x轴中的每个元素)显示一种颜色
                                    return colorList[i] //对每一类bar(按照legendData中的每个元素)显示一种颜色
                                },
                                label: {
                                    //每个bar的最高点值显示在bar顶部
                                    show: true,
                                    position: 'top',
                                    //值和x轴分类的显示格式(这里是换行显示)
                                    formatter: '{b}
{c}'
                                }
                            }
                        },
                        
                        //增加辅助线 这里是 平均线
                        markLine: {
                            //平均线两端的起始点和样式,这里none为没有样式(比如箭头)
                            symbol: 'none',
                            data: [{          
                                type: 'average',
                                name: '平均值'
                            }],
                            //具体每一条平均线及其名称的显示样式
                            itemStyle: {
                                normal: {
                                    //线的样式
                                    lineStyle:{
                                        //线的颜色,这里和 legendData 一致
                                        color: colorList[i]
                                    },
                                    //辅助线的名字和值得显示方式
                                    label: {
                                        show: true,
                                        // position: 'left',
                                        //data中name和type值的显示格式(这里
是换行显示)
                                        // formatter: '{b}
{c}'   //{b}代表name,这里是"平均值" ;{c}代表具体的数值如"568"
                                        formatter: '{b}' //只显示 "平均值"三个字
                                    }
                                }
                            },
                        },
                };
                
                //将生成的数据添加到容器中
                ss.push(o);
            });
            
            //拼装 option 
            var option = {
                title:{text:title},
                tooltip: {
                    trigger: 'axis',
                    axisPointer: { // 坐标轴指示器,坐标轴触发有效
                        type: 'shadow' // 默认为直线,可选为:'line' | 'shadow'
                    }
                },
                legend: {
                    data: legendData
                },
                xAxis: [{
                    type: 'category',
                    data: xA
                }],
                yAxis: [{
                    type: 'value'
                }],
                series:  ss
                    /* [
                    {
                        name: '百度',
                        type: 'bar',
                        data: [620, 732, 701, 734],
                    },
                    {
                        name: '谷歌',
                        type: 'bar',
                        data: [120, 132, 101, 134],
                    },
                    {
                        name: '必应',
                        type: 'bar',
                        data: [60, 72, 71, 74, 190]
                    }
                ] */
            };
            //初始化echarts实例
            //var myChart = echarts.init(document.getElementById('chartmain'));
            var myChart = echarts.init(document.getElementById(domId));
            //使用制定的配置项和数据显示图表
            myChart.setOption(option);
        }
        
    </script>
</html>

结果样式:

原文地址:https://www.cnblogs.com/libin6505/p/10341754.html