ngx-echarts做出炫酷定制化图表

前言

在使用echarts的时候,大家一定遇到过,UI小伙伴设计出的更具有自己项目特色的图表,比如渐变的图表、以及具有特殊样式的滚动条、炫酷的图表背景图等等,今天就结合实际需求来看一下具体的操作~

使用的库版本如下
"@angular/cli": "~11.1.4"

"ngx-echarts": "^6.0.1"
这个版本与angular的版本是息息相关的,具体请参照官网

"echarts": "^5.3.2"
echarts5以后的版本新增了许多炫酷的样式以及操作,比如图表圆角等,详细option配置请参照官网

项目中引入ngx-echarts

大家应该都清楚ngx-echarts是针对Angular对echarts的封装,让其在Angular中的使用更加的方便,适配度更高,当然,在引入这个库的时候也是很简单的,具体如下:

npm install echarts -S
npm install ngx-echarts -S

// 在你需要使用的模块中导入ngx-echarts
import { NgxEchartsModule } from 'ngx-echarts';
@NgModule({
  imports: [
    NgxEchartsModule.forRoot({
      echarts: () => import('echarts')}),
  ],
  providers: []
})

// 在组件中使用
// 只要给[options]属性赋不同的对象值,就可以显示不同的图表啦
// onChartInit这个方法,是用来获取这个图表的实例,方便后续对图标赋值,清空,监听缩放等等操作
 <div echarts [options]="options" class="line" (chartInit)="onChartInit($event)"></div>

如何做渐变的图表

想实现的如下所示的图表:

屏幕快照 2022-05-02 12.24.47.png

其实柱状图的渐变,很简单,只需要更改itemStyle的属性就可以,具体代码如下:

// 因为更改渐变颜色会使用到graphic,所以需要在文档中提前引入
import { graphic } from 'echarts';
// 在options的对象中,我们找到series对象,并更改itemStyle的属性即可
       series: [
            {
                name: '数量',
                type: 'bar',
                showBackground: false,
                itemStyle: {
                    color: '#52A8FF',
                    normal: {
                    // 这里就是实现渐变的重点代码了,当然你也可以通过更多的参数实现不同段的渐变
                        color: new graphic.LinearGradient( 
                          0, 0, 1, 0,
                          [
                              {offset: 0, color: '#BFE7FF'}, //  开始颜色
                              {offset: 1, color: '#009FFF'}  //  结束颜色
                          ]
                      )
                    },
                },
                barMaxWidth: 25,
                label: { show: true, position: 'insideRight', offset: [-5, 2], color: '#fff' },
                data: [30, 18, 10, 35, 21, 11, 9, 30, 18, 10],
            },
        ],

如何自定义图表的滚动条

如上述所示的滚动条是echarts5默认的滚动条,假如我们希望将它的滚动条更改成我们想要的样子该怎么做呢~ 我们先来看一下之前默认滚动的样式组成:

屏幕快照 2022-05-02 12.32.54.png

那当我们做一些定制化的滚动条时,也应该从这几个组成方面着手~现在我们希望将滚动条改成如下所示的样子:

屏幕快照 2022-05-02 12.50.33.png
// echarts中的滚动条样式,只要是通过options中的dataZoom这个对象进行调整的
dataZoom: [
          {
            type: 'slider',
            show: true,
            yAxisIndex: [0], //  因为这里设置的是纵向滚动条所以要设置这个属性
            right: 20, // 调整纵向滚动条的位置
            start: 10, // 中间滑块范围的起始值
            end: 30, // 中间滑块范围的结束值
            width: 8, // 设置滚动条的宽度
            backgroundColor: '#fff', //设置滚动条容器的背景色以及边框
            borderColor: '#fff',
            dataBackground:{ // 将滚动条容器的之前的背景色通过opacity进行隐藏掉
              lineStyle: {
                opacity: 0,
              },
              areaStyle: {
                opacity: 0
              }
            },
            fillerColor: '#ccc', // 设置中间滑块的填充颜色
            moveHandleSize: 0, // 将中间移动滑块上可以拖拽的icon移除掉
            // 设置滑块两侧缩放手柄的icon,也可以使用image
            handleIcon: '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.5M36.9,35.8h-1.3z M27.8,35.8 h-1.3H27L27.8,35.8L27.8,35.8z',// 画一个圆形
         }
        ],

如何使用炫酷背景图

假如我想实现如下所示的圆环图,中间的数据的背景图该如何实现呢~

屏幕快照 2022-05-02 13.03.51.png

其实我们可以借助graphic是原生图形元素组件。可以支持的多种图形元素来实现

// 只需要在options中的对象中添加这个graphic对象即可
      graphic: {
        elements: [
          {
            type: 'image',
            z: 3,
            style: {
              image: '/assets/test-bg.png', // 从本地获取背景图片
              width: 100, //  设置图片的大小
              height: 100,
            },
            left: 'center', //  这个背景图片的所在画布中的位置
            top: 'center',
          },
        ],
      },

可能也有小伙伴会好奇这个圆环的圆角是怎么画出来的呢~ 其实这个圆角就用到的echarts中的新特性borderRadius具体代码如下所示:

// 主要是通过设置options中series的属性值来更改圆环的演示和显示
      series: [
        {
          type: 'pie',
          hoverAnimation: true,
          hoverOffset: 15,
          startAngle: 180, // 起始角度
          clockwise: false, // 是否顺时针
          radius: ['70%', '60%'], // 设置圆环的大小,粗细
          center: ['50%', '50%'], // 圆环位置画布的位置
          avoidLabelOverlap: false,
          label: {
            show: false,
          },
          labelLine: {
            show: false,
          },
          data: [
            {
              value: 55,
              name: '小组A',
            },
            {
              value: 29,
              name: '小组B',
            },
          ],
          itemStyle: {
            borderRadius: 10, // 设置圆环中的圆角大小
          },
        },
      ],

总结

echart中的api是非常丰富了,在遇到定制化图表时,我们可以先去官网上看看,有没有提供具体的api进行操作和设置~😊

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,658评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,482评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,213评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,395评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,487评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,523评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,525评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,300评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,753评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,048评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,223评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,905评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,541评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,168评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,417评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,094评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,088评论 2 352

推荐阅读更多精彩内容