在Echarts图中给坐标轴加一个标识线markLine

Echart3数据可视化视图

给坐标轴加一个标识线markLine

当X轴不是数值时,而是一个类型数据,如年份,公司名,企业名,这时Echarts图就不是从X轴起始位置开始的,所以我们就要给X轴加一个虚拟的值'0',在markLine中也是在赋值起始位置X轴值时,放置虚拟数据,并且设置一个boundaryGap: 0,可以让坐标轴与刻度之间空白变为0,这时标示线就从X轴起始位置开始了,详细属性可以去Echarts官网查看。

这里还要说一句在设置markLine下面data值时{x:”,//代表的是容器内x的值,y:”,容器内y的值},如果要设置在坐标轴内的标示线,就要设置xAxis和yAxis.

代码如下

option ={
  xAxis: {
     splitLine: {
      show: false,
     },
     axisLabel: {
      color: '#fff',
      rotate: '35',
      fontSize: 10,
     },
     data: ['0', '2013年', '2014年', '2015年', '2016年', '2017年'],
     boundaryGap: 0,
    },
    yAxis: {
     name: '(单位/km)',
     splitLine: {
      show: false,
     },
     axisLabel: {
      color: '#fff',
     },
     axisPointer: {
      lineStyle: {
       color: '#fff',
      },
      value: '140',
     },
    },
    grid: {
     top: '10%',
     bottom: '27%',
    },
    series: [{
     data: DataAll,
     type: 'scatter',
     symbolSize: function (parmas) {
      return Math.ceil(parmas[2] / 1000);
     },
     label: {
      emphasis: {
       show: true,
       formatter: function (param) {
        return param.data[3] + param.data[4];
       },
       position: 'top',
      },
     },
     markLine: {
      data: [
       [
        { name: '标线1起点', xAxis: 0, yAxis: 300, symbol: 'circle'},
        { name: '标线1终点', xAxis: '2017年', yAxis: 300, symbol: 'circle' },
       ],
      ],
      label: {
       normal: {
        show: true,
        position: 'middle',
        formatter: '节能与新能源汽车技术路线图2020年目标',
       },
      },
      lineStyle: {
       normal: {
        type: 'solid',
        color: '#fff',
       },
      },
     },
     itemStyle: {
      normal: {
       color: '#0fefee',
      },
     },
    }],
}

效果图

补充知识:日常记要 之 Echarts结合百度地图,动态添加不同颜色的markline(markpoint同理)

其实找了网上的资料,大部分是同个颜色的markline,或者没有所谓的定时,很是苦恼,于是自己查找API,解决了实际开发中的问题,今天有空特地拿出来简单整理下,有什么不懂,或者我没说清楚的,欢迎留言,废话不多说,直接开始吧。

根据echarts官方API,动态添加markline需要使用addMarkLine()方法,它接收两个参数:一个seriesIdx系列索引(这里应该是指对应每一条markline的索引值)和一个markData(这里请参考官方API)。

在遇到的实际需求中,要求动态添加传播的路线,并且能够添加根据不同的颜色区分开来。这里遇到的问题主要有一下几个:

既然是动态添加markline,那么就存在一对多,或者多对一的情况。这个比较好处理,就是在数据中,添加一个表示层级关系的属性,一方面可以表现所谓的层级传播关系,另一方面,在每次传播过程中,同一层不管是一条markline还是多条,都是一样的处理方法;

颜色的区分,因为实际遇到的情况是层级并不会很多,所以没有做一个专门的Color对象去给每一层随机添加颜色,而是实现定义好一个长度能够满足需求的数组存储颜色值,这样的一个好处是避免随机下颜色接近看不出层级的关系;但是还有一个问题,是涉及到百度地图的,这个留在后面说;

索引值的问题,既然需要动态添加markline,那么seriesIdx是否动态变化呢,还是每一层一个seriesIdx呢,想知道吗?请耐心往下看吧。

其实上面提到的问题,在单纯用echarts下应该是比较好解决的(虽然我并没有做过测试),但是结合百度地图的话,有个坑这里必须提一下,就是百度地图是可以推动、缩放,以及它和echarts其实是两个东西啊(当然我这里说的是,你动态添加到ecahrts里面的数据,对百度地图来说,根本就不知道啊)。

那么怎么解决呢,上代码吧。

首先关于上面的第1个问题,由于数据是查询出来的,并且业务需求是没有实现规定好哪一条markline是哪一层,所以值考虑首位是不相同的,也就是开始和结束不在同一个位置,当然中间线的传播是可以的,这个根据具体的业务去处理就可以了。(这里插句话,阿里的 fastjson还是挺好用的,但是在它的JSONArray有点尴尬,有数据冲突(还是相同这个有点忘记了)然后遍历时,会生成一个$ref这样的循环引用的东西出来,简直了,不过JSONObject则不会出现同样的问题)。

 require.config({ // ecahrts引用,这里不做解释了,请自行参考ecahrts的API例子
        paths: {
echarts: './lib/echarts'
        },
        packages: [
{
  name: 'BMap',
  location: './lib/echarts/Bmap',
  main: 'main'
}
        ]
      });
      require(
        [
'echarts',
'BMap',
'echarts/chart/map'
// 使用柱map模块,按需加载
        ],
        function (echarts, BMapExtension) {
// 初始化地图
var BMapExt = new BMapExtension(that.element.find('div')[0], BMap, echarts, {
  enableMapClick: false
});
var map = BMapExt.getMap();

// 因为这个有实际用途了,所以这里的代码块就不贴出来了,可按照自己的需求实现,具体查看百度地图的API
// 这里主要处理的是,设置了百度地图的边界,初始化时显示的区域,以及地图的放大系数
......

// 在加载时,以下操作请加上,这里就回答了上面提到的第2个问题,因为echarts在动态加载markline时,其实数据时没有加载进百度地图的(当然我不知道这样说明对不对哈),但百度地图在每次缩放、拖拽时,都会重新渲染页面,导致出现的加载情况不是我们想要的,比如刚才添加的markline不见了,或者所有的markline颜色变得跟当前最后一条添加的markline一样,这些都是应该在这里先处理好,避免它发生。在全部的markline加载完之后,再初始化一下百度地图的数据,那么这个时候恢复百度地图原有的功能,不管怎么渲染,都不会再出现前面的情况。
map.disableScrollWheelZoom(); // 禁用滚轮缩放
map.disableDoubleClickZoom(); // 禁用双击放大
map.disableDragging(); // 禁止拖拽
map.disableAutoResize(); // 禁止自适应容器变化

// 初始化echarts
var fm = '{b}';
var count = 0;
var option = {
  color: [],
  tooltip: {
    trigger: 'item',
    formatter: fm
  },
  series: []
};
// 这里是添加鼠标hover在markline上时,显示的指定格式的内容
if (!$.isEmptyObject(that.options.tooltip)) {
  if (that.options.tooltip.formatter && that.options.tooltip.formatter.indexOf('function') > -1) {
    option.tooltip.formatter = eval('(' + that.options.tooltip.formatter + ')');
  }
}
          // 添加第一层的markline
that.buildMM(null, option, color, geoCoordVar, data, count);
// 百度地图获取echarts容器
var container = BMapExt.getEchartsContainer();
// 初始化
myChart = BMapExt.initECharts(container);
// 第一次设置option
BMapExt.setOption(option, true);

// setInterval的方式动态添加markline,count用来记录当前的层,用以判断是否所有层都已添加
var clear = null;
var count = 0;
clear = setInterval(function () {
 count++;
  if (count > level.length) {
     clear = window.clearInterval(clear);
     // 第二次设置option,这一步很重要,如果不设置,就会产生前面提到的情况(这真是一个坑,浪费了好多时间)
     BMapExt.setOption(option, true);
     map.enableScrollWheelZoom(); // 允许滚轮缩放
     map.enableDoubleClickZoom(); // 允许双击放大
     map.enableDragging();
   }
   // 添加下一层的markline
   that.buildMM(myChart, option, color, geoCoordVar, data, count);

         // 其它操作
         ......
           }, that.options.speed); // speed是指定的添加速度
        });

        buildMM: function (myChart, option, color, geoCoordVar, data, count) {
      for (var i = 0; i < data.length; i++) {
        // 在查询结果数据中,level标表示层级关系,这里与count匹配下一层的数据
        if (data[i]['level'] == count) {
          // 生成markline数据
var ml = {
  smooth: true,
  effect: {
    show: false
  },
  data: this.getMM(data[i])['markline'],
  itemStyle: {
    normal: {
      color: color[count],
      borderWidth: 1,
      lineStyle: {
        type: 'solid',
        shadowBlur: 20,
        color: color[count]
      }
    }
  }
};
// 由于每一条markline是一个series,并且结合百度地图,所以这里的参数中,需要注意type=map,mepType=none
var item = {
  name: data[i]['name'],
  type: 'map',
  mapType: 'none',
  data: [],
  markLine: ml,
  geoCoord: geoCoordVar,
  itemStyle: {
    normal: {
      color: color[count],
      borderWidth: 1,
      lineStyle: {
        type: 'solid',
        shadowBlur: 20,
        color: color[count]
      }
    }
  }
};
// 将当前markline的item添加到series中
option.series.push(item);
// 调用addMarkLine,这里请注意看,seriesIdx我设置的都是0,如果不设置0,是会报错的,所以也就是这么简单地解决了第三个问题,因为每一个addMarkLine的markline对echarts来时都是新增的(当然这也只是我个人理解)
   myChart.addMarkLine(
     0,
     ml
   );
        }
      }

    }

以上的代码我没有全部贴出来,但是已经够用了,主要的内容都在里面了。在每个地方基本都有做注释,如有什么说的不对的,欢迎批评指正。好了,就到这了~希望大家多多支持我们。

(0)

相关推荐

  • 解决echarts echarts数据动态更新和dataZoom被重置问题

    1.全局绑定滚轮事件,获得dataZoom最新的位置: myChart.on('dataZoom',function(event){ if(event.batch){ start=event.batch[0].start; end=event.batch[0].end; }else{ start=event.start; end=event.end; }; }); 2.把最新的start和end赋值给要更新的option window.setInterval(function () { num=

  • 解决Vue + Echarts 使用markLine标线(precision精度问题)

    在VUE实例中使用Echarts 安装echarts依赖: npm install echarts -s 编写代码: 引入echarts对象: 鉴于准备工作中已经通过npm安装了echarts依赖,所以可以直接在vue文件中使用代码import echarts from "echarts"引入echarts对象: <script> import echarts from 'echarts/lib/echarts' </script> 注意:只引入了echarts

  • 在Echarts图中给坐标轴加一个标识线markLine

    Echart3数据可视化视图 给坐标轴加一个标识线markLine 当X轴不是数值时,而是一个类型数据,如年份,公司名,企业名,这时Echarts图就不是从X轴起始位置开始的,所以我们就要给X轴加一个虚拟的值'0',在markLine中也是在赋值起始位置X轴值时,放置虚拟数据,并且设置一个boundaryGap: 0,可以让坐标轴与刻度之间空白变为0,这时标示线就从X轴起始位置开始了,详细属性可以去Echarts官网查看. 这里还要说一句在设置markLine下面data值时{x:",//代表的

  • python画图时给图中的点加标签和plt.text的使用

    背景: 今天在用matplotlib模块画各城市2019-nCoV疫情确诊人数和节前流入人口数的图的时候遇到了要给图中的点加上标签示意,原本图长这个样子 现在要给各散点标注是哪个哪个城市,即下面这种图: matplotlib模块加标签主要有matplotlib.pyplot.text()和matplotlib.pyplot.annotate()两个关键函数,后者适用范围更广,今天主要谈一下前者matplotlib.pyplot.text(),简写成plt.text() . 准备知识: 在此重点讲

  • python matplotlib如何给图中的点加标签

    这篇文章主要介绍了python matplotlib给图中的点加标签,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 在写论文用到matplotlib画散点图,想着如果能把每个点对应的ID打在点的旁边就好了,经过一番搜索,最后找到了方法. 首先是打点,先把所有的点画好,举例如下: p1 = ax.scatter(X[:,0], X[:,1], marker = '*', color = 'r', label='1', s=10) 再依次给每个点打

  • Python利用matplotlib做图中图及次坐标轴的实例

    图中图 准备数据 import matplotlib.pyplot as plt fig = plt.figure() x = [1, 2, 3, 4, 5, 6, 7] y = [1, 3, 4, 2, 5, 8, 6] - 大图 首先确定大图左下角的位置以及宽高: 注意,4个值都是占整个figure坐标系的百分比.在这里,假设figure的大小是10x10,那么大图就被包含在由(1, 1)开始,宽8,高8的坐标系内. # below are all percentage left, bott

  • Vue项目中使用better-scroll实现一个轮播图自动播放功能

    前言 better-scroll是一个非常非常强大的第三方库 在移动端利用这个库 不仅可以实现一个非常类似原生ScrollView的效果 也可以实现一个轮播图的效果 这里就先记录一下自己实现这个效果的一些过程吧 思路 1.首先要确定自己的HTML结构 基本结构就是一个wrapper包含一个content 2.其次需要明白的一个页面可以滚动的原理在于 当内容的高度超出了容器的高度才可以实现滚动 如果没有超出 那么就没有滚动的必要 因此第一点需要实现的就是 获取到所有内容的高度 由于实现的是一个轮播

  • VUE+elementui组件在table-cell单元格中绘制微型echarts图

    需求效果图示例 实际完成效果图 ** 代码实现 注:table表格为二次封装的子组件 -在table表格中 根据 scope.$index动态设置元素的id ,便于指定单元格的echarts初始化: -在单元格中触发一个方法,传入当前的scope.row数据或者指定其他数据,并且传入 scope.$index 以及一个字符串便于识别当前是哪条数据的charts -在方法中绘制echarts** <el-table-column align="center"> <tem

  • jQuery插件echarts设置折线图中折线线条颜色和折线点颜色的方法

    本文实例讲述了jQuery插件echarts设置折线图中折线线条颜色和折线点颜色的方法.分享给大家供大家参考,具体如下: 1.问题背景 设计一条折线图,但是图形中不用插件自带的颜色,需要自定义线条和折点的颜色 2.实现源码 (1)图形自分配颜色 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>echarts-设置折线图中折线线条颜色和折线点颜色</t

  • C#中#define后面只加一个参数的解释

    #define只加一个参数 的解释 <stdio.h> 里有: #ifndef __STDIO_H #define __STDIO_H 这个__STDIO_H代表什么?而define的用法不是后面加两个字符串吗,它这里却只加一个字符串,是什么意思? 还有很多头文件里都有如下语句 #if __STDC__ #define _Cdecl #else #define _Cdecl cdecl #endif __stdc__,cdecl代表什么? 比方说你#include进来一个stdio.h,再#i

  • python 实现在一张图中绘制一个小的子图方法

    有时候为了直观展现图的信息,可以在大图中添加小子图的方式进行数据分析,如下图所示: 具体的代码如下:该图连接了数据库,当然重要的不是数据展示,而是添加子图的方法. import matplotlib.pyplot as plt import MySQLdb as mdb import numpy as np from mpl_toolkits.axes_grid1.inset_locator import inset_axes from mpl_toolkits.axes_grid1.inset

  • vue中Element-ui 输入银行账号每四位加一个空格的实现代码

    一.问题描述: 我们在输入银行账号会设置每四位添加一个空格,输入金额,每三位添加一个空格.那么,在vue,element-ui 组件中,如何实现呢? 二.效果图: 三.实现代码: <el-table-column prop="account" label="银行账号"> <template slot-scope="scope"> <el-input type="text" maxlength=&q

随机推荐