ECharts 饼图指定颜色显示

一、通过setOption的color属性分配颜色范围

先介绍这里提到的color属性

color:调色盘颜色列表。如果系列没有设置颜色,则会依次循环从该列表中取颜色作为系列颜色。 默认为:

['#5470c6', '#91cc75', '#fac858', '#ee6666', '#73c0de', '#3ba272', '#fc8452', '#9a60b4', '#ea7ccc']

下图所示即为上述默认颜色数组的显示

 

二、更改颜色属性

1、支持的颜色格式

1)使用 RGB 表示纯颜色,比如 'rgb(128, 128, 128)',如果想要加上 alpha 通道表示不透明度,可以使用 RGBA,比如 'rgba(128, 128, 128, 0.5)',也可以使用十六进制格式,比如 '#ccc'

2)渐变色或者纹理填充

// 线性渐变,前四个参数分别是 x0, y0, x2, y2, 范围从 0 - 1,相当于在图形包围盒中的百分比,如果 globalCoord 为 `true`,则该四个值是绝对的像素位置
{
  type: 'linear',
  x: 0,
  y: 0,
  x2: 0,
  y2: 1,
  colorStops: [{
      offset: 0, color: 'red' // 0% 处的颜色
  }, {
      offset: 1, color: 'blue' // 100% 处的颜色
  }],
  global: false // 缺省为 false
}
// 径向渐变,前三个参数分别是圆心 x, y 和半径,取值同线性渐变
{
  type: 'radial',
  x: 0.5,
  y: 0.5,
  r: 0.5,
  colorStops: [{
      offset: 0, color: 'red' // 0% 处的颜色
  }, {
      offset: 1, color: 'blue' // 100% 处的颜色
  }],
  global: false // 缺省为 false
}
// 纹理填充
{
  image: imageDom, // 支持为 HTMLImageElement, HTMLCanvasElement,不支持路径字符串
  repeat: 'repeat' // 是否平铺,可以是 'repeat-x', 'repeat-y', 'no-repeat'
}

2、完整代码如下:关键代码有注释

代码更改取自官方饼图示例:https://echarts.apache.org/examples/zh/editor.html?c=pie-simple

option = {
  title: {
    text: 'Referer of a Website',
    subtext: 'Fake Data',
    left: 'center'
  },
  tooltip: {
    trigger: 'item'
  },
  legend: {
    orient: 'vertical',
    left: 'left'
  },
  color: ['red', 'green','yellow','blue','purple'], // 自定义颜色范围
  series: [
    {
      name: 'Access From',
      type: 'pie',
      radius: '50%',
      data: [
        { value: 1048, name: 'Search Engine' },
        { value: 735, name: 'Direct' },
        { value: 580, name: 'Email' },
        { value: 484, name: 'Union Ads' },
        { value: 300, name: 'Video Ads' }
      ],
      emphasis: {
        itemStyle: {
          shadowBlur: 10,
          shadowOffsetX: 0,
          shadowColor: 'rgba(0, 0, 0, 0.5)'
        }
      }
    }
  ]
};

3、呈现效果

以上就是ECharts 饼图指定颜色显示的介绍,做此记录,如有帮助,欢迎点赞关注收藏!

### ECharts 默认配色方案 ECharts默认配色方案是由其主题决定的,默认情况下会采用 `default` 主题的颜色序列。该颜色序列为一组预定义的颜色数组,当绘制时,这些颜色会被依次分配给各个扇区[^1]。 以下是 ECharts 默认的主题颜色列表: ```javascript [ '#c23531','#2f4554','#61a0a8','#d48265','#91c7ae','#749f83', '#ca8622','#bda29a','#6e7074','#546570','#c4ccd3' ] ``` 如果数据项的数量超过了这个颜色数组的长度,则会重新从头开始循环使用这些颜色[^2]。 在实际应用中,如果不希望使用默认配色方案,可以通过自定义 `series.data` 中的 `itemStyle.color` 属性来覆盖默认颜色[^3]。然而,在未做任何额外配置的情况下,上述颜色将是 ECharts 自动为分配的颜色。 ### 示例代码展示默认配色方案的应用 以下是一个简单的例子,展示了如何利用 ECharts 的默认配色方案创建一个: ```javascript var chartDom = document.getElementById('main'); var myChart = echarts.init(chartDom); var option; option = { series: [ { name: 'Access From', type: 'pie', radius: ['50%', '70%'], data: [ { value: 10, name: 'Source A' }, { value: 15, name: 'Source B' }, { value: 20, name: 'Source C' }, { value: 25, name: 'Source D' } ] } ] }; myChart.setOption(option); ``` 在这个示例中,如果没有显式地为每个数据项指定颜色ECharts 将自动按照默认颜色顺序渲染中的每一个部分。 #### 注意事项 尽管可以依赖于默认配色方案,但在某些场景下为了增强可视化效果或满足特定设计需求,建议通过自定义颜色实现更灵活的表现形式。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

GoodTimeGGB

鼓励一下!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值