echarts 图例修改legend中icon的形状及大小

5,708 阅读5分钟

图例项的legend icon。

ECharts 提供的标记类型有 'circle', 'rect', 'roundRect', 'triangle', 'diamond', 'pin', 'arrow', 'none'

也可以通过 'image://url' 设置为图片,其中 URL 为图片的链接,或者 dataURI。

URL 为图片链接例如:

'image://http://xxx.xxx.xxx/a/b.png'

URL 为 dataURI 例如:

'image://'

可以通过 'path://' 将图标设置为任意的矢量路径。这种方式相比于使用图片的方式,不用担心因为缩放而产生锯齿或模糊,而且可以设置为任意颜色。路径图形会自适应调整为合适的大小。路径的格式参见 SVG PathData。可以从 Adobe Illustrator 等工具编辑导出。

例如:

'path://M30.9,53.2C16.8,53.2,5.3,41.7,5.3,27.6S16.8,2,30.9,2C45,2,56.4,13.5,56.4,27.6S45,53.2,30.9,53.2z M30.9,3.5C17.6,3.5,6.8,14.4,6.8,27.6c0,13.3,10.8,24.1,24.101,24.1C44.2,51.7,55,40.9,55,27.6C54.9,14.4,44.1,3.5,30.9,3.5z M36.9,35.8c0,0.601-0.4,1-0.9,1h-1.3c-0.5,0-0.9-0.399-0.9-1V19.5c0-0.6,0.4-1,0.9-1H36c0.5,0,0.9,0.4,0.9,1V35.8z M27.8,35.8 c0,0.601-0.4,1-0.9,1h-1.3c-0.5,0-0.9-0.399-0.9-1V19.5c0-0.6,0.4-1,0.9-1H27c0.5,0,0.9,0.4,0.9,1L27.8,35.8L27.8,35.8z'

修改icon大小

legend: {
    icon: 'circle',
    bottom: 10,
    itemHeight: 7, //修改icon图形大小
    textStyle: {
      fontSize: 13,
      color: '#000'
    },
    data: ['底层数据', '机构代码+企业名称', '联系电话', '联系人姓名', '详细地址', '实名认证']
},

一、默认 图例项的 icon

circle, rect, roundRect, triangle, diamond, pin, arrow, none

legend: {
    top: '5%',
    left: 'center',
    itemWidth: 20,
    itemHeight: 20,
    data: [
        {icon: 'circle', name: '搜索引擎'},
        {icon: 'rect', name: '直接访问'},
        {icon: 'roundRect', name: '邮件营销'},
        {icon: 'triangle', name: '联盟广告'},
        {icon: 'diamond', name: '视频广告'},
        {icon: 'pin', name: 'SEO'},
        {icon: 'arrow', name: '定点投放'}
    ]
}

分别对应以下几种图标 img-blog.csdnimg.cn/20201221150…

image.png none 就是没有的意思,上面就没放出来了

二、使用图片链接或者base64 图片

图片转base64 在线工具 地址tool.chinaz.com/tools/imgto…

图片使用前缀为 image://

示例如下:


legend: {
   top: '5%',
   left: 'center',
   itemWidth: 30,
   itemHeight: 30,
   data: [
       {icon: 'image://https://profile.csdnimg.cn/F/0/1/3_rudy_zhou', name: '搜索引擎'},
       {icon: 'image://', name: '定点投放'}
   ]
},

效果如下

image.png 这种方式,能自定义任意UI设计的图标,但是不支持动态置灰,无法跟随默认图表数据颜色

三、使用 矢量 路径

推荐使用方式

按照博主理解,echarts 默认的几个图例 icon 都是使用 了 矢量路径 的方式 那么矢量路径到底是什么,我们下面来看看。

我们最常见到的 svg 图片 里面的形状就是使用 矢量路径绘制

echarts 使用 矢量路径 写法前缀为:path://

legend: {
    top: '5%',
    left: 'center',
    itemWidth: 20,
    itemHeight: 20,
    icon: 'path://M78.625,93.094L66.494,72.081l12.132-21.013h24.264l12.132,21.013l-12.132,21.013H78.625z M95.547,80.377l4.79-8.296  l-4.79-8.296h-9.579l-4.79,8.296l4.79,8.296H95.547z'
},

效果如下

image.png

1.可以看到 图例 icon 变成了空心六边形,并且icon 颜色与图表中的 块儿 颜色对应上的

即使图表块儿设置了渐变色,图例 图标也能完成呈现渐变色彩

2.并且 echarts 5 中的 给有辨色障碍 人士预备的 无障碍花纹也能看到(当前图标存在空心,所以不明显)

3.再者 点击图例 取消显示 置灰效果也能应用置 图标上,这是 使用 图片链接或者base64 达不到的效果

简单来讲就是,使用 矢量路径, 显示效果与默认的几个图标一样,只是图标形状变成了自定义。

矢量路径也支持 复合路径,比如:

    legend: {
        top: '5%',
        left: 'center',
        itemWidth: 20,
        itemHeight: 20,
        data: [
            {icon: 'path://M78.625,93.094L66.494,72.081l12.132-21.013h24.264l12.132,21.013l-12.132,21.013H78.625z M95.547,80.377l4.79-8.296  l-4.79-8.296h-9.579l-4.79,8.296l4.79,8.296H95.547z', name: '搜索引擎'},
            {icon: 'path://M153.651,224.468c-21.867,0-39.658-17.791-39.658-39.658c0-21.87,17.791-39.661,39.658-39.661  c21.869,0,39.66,17.791,39.66,39.661C193.312,206.677,175.521,224.468,153.651,224.468z M153.651,159.149  c-14.148,0-25.658,11.512-25.658,25.661c0,14.148,11.51,25.658,25.658,25.658s25.66-11.51,25.66-25.658  C179.312,170.661,167.8,159.149,153.651,159.149z M165.791,172.67h-24.277v24.277h24.277V172.67z', name: '直接访问'}
        ]
    },

第二个图标中 圆环 与 矩形块 拼接的 复合路径

由于我较常用的导出矢量路径方式,是使用Adobe Ilustrator 正常情况下找 UI 小姐姐帮忙即可

不会使用 adobe ilustrator 的,可以去 www.iconfont.cn/ 阿里图标库,找到你要的图标

image.png

这里预览的就是 svg ,也可以直接复制这里的 path 标签的 d 属性就是。

想要学习简单的 编辑并导出 矢量路径可以接着看下面 同样有些坑,即使是上方简单的复合路径图形,初入行的UI 可能也不知道

1-3、以上例子的DEMO 点击查看图例更改 图标 自定义 demo

在 demo 内点击编辑源码,查看

四、创建 矢量路径并导出

后边的原文在这个博主这里 blog.csdn.net/rudy_zhou/a…