echarts实现折线图的拖拽效果

使用echarts实现折线图的拖拽,供大家参考,具体内容如下

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <script src="./echarts.js"></script>
</head>
<body>
  <div id="main" style="width: 600px;height:400px;"></div>
  <script type="text/javascript">
  var symbolSize = 20;
  var data = [[15,0],[-50,10],[-56.5,20],[-46.5,30],[-22.1,40]];
  var myChart = echarts.init(document.getElementById('main'));
  myChart.setOption({
  # 表示不使用默认的『显示』『隐藏』触发规则。
    tooltip: {
      triggerOn: 'none',formatter: function (params) {
        return 'X: ' + params.data[0].toFixed(2) + '<br>Y: ' + params.data[1].toFixed(2);
      }
    },xAxis: {
      min: -100,max: 80,type: 'value',axisLine: {onZero: false}
    },yAxis: {
      min: -30,max: 60,series: [
      {
        id: 'a',type: 'line',smooth: true,symbolSize: symbolSize,data: data
      }
    ],});
  myChart.setOption({
  #拖拽功能:用 graphic 组件,在每个点上面,覆盖一个隐藏的可拖拽的圆点
    graphic: echarts.util.map(data,function (item,dataIndex) {
      return {
        type: 'circle',position: myChart.convertToPixel('grid',item),shape: {
          r: symbolSize / 2
        },invisible: true,draggable: true,ondrag: echarts.util.curry(onPointDragging,dataIndex),onmousemove: echarts.util.curry(showTooltip,onmouseout: echarts.util.curry(hideTooltip,z: 100
      };
    })
  });
  window.addEventListener('resize',function () {
    myChart.setOption({
      graphic: echarts.util.map(data,dataIndex) {
        return {
          position: myChart.convertToPixel('grid',item)
        };
      })
    });
  });
  function showTooltip(dataIndex) {
    myChart.dispatchAction({
      type: 'showTip',seriesIndex: 0,dataIndex: dataIndex
    });
  }
  function hideTooltip(dataIndex) {
    myChart.dispatchAction({
      type: 'hideTip'
    });
  }
  function onPointDragging(dataIndex,dx,dy) {
    data[dataIndex] = myChart.convertFromPixel('grid',this.position);
    myChart.setOption({
      series: [{
        id: 'a',data: data
      }]
    });
  }

</script>
</body>
</html>

echarts实现折线图的拖拽效果


echarts实现折线图的拖拽效果


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


kindeditor4.x代码高亮功能默认使用的是prettify插件,prettify是Google提供的一款源代码语法高亮着色器,它提供一种简单的形式来着色HTML页面上的程序代码,实现方式如下: 首先在编辑器里面插入javascript代码: 确定后会在编辑器插入这样的代码: <pre
这一篇我将介绍如何让kindeditor4.x整合SyntaxHighlighter代码高亮,因为SyntaxHighlighter的应用非常广泛,所以将kindeditor默认的prettify替换为SyntaxHighlighter代码高亮插件 上一篇“让kindeditor显示高亮代码”中已经
js如何实现弹出form提交表单?(图文+视频)
js怎么获取复选框选中的值
js如何实现倒计时跳转页面
如何用js控制图片放大缩小
JS怎么获取当前时间戳
JS如何判断对象是否为数组
JS怎么获取图片当前宽高
JS对象如何转为json格式字符串
JS怎么获取图片原始宽高
怎么在click事件中调用多个js函数
js如何往数组中添加新元素
js如何拆分字符串
JS怎么对数组内元素进行求和
JS如何判断屏幕大小
js怎么解析json数据
js如何实时获取浏览器窗口大小
原生JS实现别踩白块小游戏(五)
原生JS实现别踩白块小游戏(一)