vue echarts动态效果流水线流程图

7 篇文章 0 订阅
2 篇文章 0 订阅

效果图:

3月15日 vue echarts流程图流水线效果功能

容器:

 <div id="echart2"></div>
 <script>
 import * as echarts from 'echarts'

export default {
  data() {
    return {
      flowIndex: 1,
    }
  },
  created() {
    this.flow(1)
  },
  mounted() {
    this.$nextTick(() => {
      this.setOption()
    })
  },
  computed: {},
  methods: {
    flow(index) {
      this.flowIndex = index;
      this.$nextTick(() => {
        if (index == 1) {
          this.getEchart2();
        }
      })
    },
    getEchart2() {
      echarts.init(document.getElementById('echart2')).dispose();
      var chartDom = document.getElementById('echart2');
      this.myChart = echarts.init(chartDom);
      var charts = {
        nodes: [ // 节点
          {
            name: '开始', value: [50, 600],
            label: {
              borderWidth: 1, // 边框宽度
              borderRadius: [4, 4, 4, 4],
              backgroundColor: '#7856FF',
              color: '#fff',
              padding: [10, 8, 10, 8],
            }
          },
          {
            name: '出发', value: [150, 500],
            label: {
              borderColor: '#387DFF', // 边框颜色
              borderWidth: 1, // 边框宽度
              borderRadius: [4, 4, 4, 4],
              backgroundColor: '#fff',
              color: '#387DFF',
              padding: [8, 5, 7, 5],
            },
          },
          {
            name: '加油', value: [200, 800],
            label: {
              borderColor: '#387DFF', // 边框颜色
              borderWidth: 1, // 边框宽度
              borderRadius: [4, 4, 4, 4],
              backgroundColor: '#fff',
              color: '#387DFF',
              padding: [8, 5, 7, 5],
            },
          },
          {
            name: '站点1', value: [300, 800],
            label: {
              borderColor: '#387DFF', // 边框颜色
              borderWidth: 1, // 边框宽度
              borderRadius: [4, 4, 4, 4],
              backgroundColor: '#fff',
              color: '#387DFF',
              padding: [8, 5, 7, 5],
            },
          },
          {
            name: '站点2', value: [450, 800],
            label: {
              borderColor: '#387DFF', // 边框颜色
              borderWidth: 1, // 边框宽度
              borderRadius: [4, 4, 4, 4],
              backgroundColor: '#fff',
              color: '#387DFF',
              padding: [8, 5, 7, 5],
            },
          },
          {
            name: '站点3', value: [600, 800],
            label: {
              borderColor: '#387DFF', // 边框颜色
              borderWidth: 1, // 边框宽度
              borderRadius: [4, 4, 4, 4],
              backgroundColor: '#fff',
              color: '#387DFF',
              padding: [8, 5, 7, 5],
            },
          },
          {
            name: '站点4', value: [800, 800],
            label: {
              borderColor: '#387DFF', // 边框颜色
              borderWidth: 1, // 边框宽度
              borderRadius: [4, 4, 4, 4],
              backgroundColor: '#fff',
              color: '#387DFF',
              padding: [8, 5, 7, 5],
            },
          },
          {
            name: '加油2', value: [200, 200],
            label: {
              borderColor: '#387DFF', // 边框颜色
              borderWidth: 1, // 边框宽度
              borderRadius: [4, 4, 4, 4],
              backgroundColor: '#fff',
              color: '#387DFF',
              padding: [8, 5, 7, 5],
            },
          },
          {
            name: '预备站点1', value: [300, 200],
            label: {
              borderColor: '#387DFF', // 边框颜色
              borderWidth: 1, // 边框宽度
              borderRadius: [4, 4, 4, 4],
              backgroundColor: '#fff',
              color: '#387DFF',
              padding: [8, 5, 7, 5],
            },
          },
          {
            name: '预备站点2', value: [450, 200],
            label: {
              borderColor: '#387DFF', // 边框颜色
              borderWidth: 1, // 边框宽度
              borderRadius: [4, 4, 4, 4],
              backgroundColor: '#fff',
              color: '#387DFF',
              padding: [8, 5, 7, 5],
            },
          },
          {
            name: '出口', value: [800, 500],
            label: {
              borderColor: '#387DFF', // 边框颜色
              borderWidth: 1, // 边框宽度
              borderRadius: [4, 4, 4, 4],
              backgroundColor: '#fff',
              color: '#387DFF',
              padding: [8, 5, 7, 5],
            },
          },
          {
            name: '终点', value: [1000, 500],
            label: {
              backgroundColor: '#13C2C2',
              color: '#fff',
              borderRadius: [4, 4, 4, 4],
              padding: [10, 8, 10, 8],
            },
          },

        ],
        linesData: [ // 连线
          {name: '', coords: [[50, 600], [50, 500]], symbol: 'none'},
          {name: '', coords: [[50, 500], [980, 500]]},
          {name: '', coords: [[150, 500], [150, 200]], symbol: 'none'},
          {name: '', coords: [[150, 500], [150, 800]], symbol: 'none'},
          {name: '', coords: [[150, 800], [800, 800]], symbol: 'none'},
          {name: '', coords: [[805, 800], [805, 500]], symbol: 'none'},
          {name: '', coords: [[150, 200], [805, 200]], symbol: 'none'},
          {name: '', coords: [[805, 200], [805, 500]], symbol: 'none'},
        ]
      }
      var option = {
        xAxis: {
          min: 0,
          max: 1060,
          show: false,
          type: "value",
        },
        yAxis: {
          min: 0,
          max: 1060,
          show: false,
          type: "value",
        },
        grid: {
          left: '1%',
          right: '0',
          bottom: 0,
          top: 0
        },
        tooltip: {
          show: false,
          axisPointer: {
            type: "shadow",
          },
          borderColor: "white",
          backgroundColor: "white",
          borderWidth: 1,
          padding: 0,
          textStyle: {
            fontSize: 14,
            color: '#333',
          },
        },
        series: [
          {
            type: "graph",
            coordinateSystem: "cartesian2d",
            symbol: "rect",
            symbolSize: [0.01, 0.01],
            // edgeSymbol: ['', 'arrow'],
            // edgeSymbolSize: [0, 0],
            lineStyle: {
              normal: {
                width: 0,
                color: '#387DFF'
              }
            },
            itemStyle: {
              color: "rgb(194, 194, 194)",
            },
            symbolOffset: [10, 0],
            force: {
              edgeLength: 10,//连线的长度
              repulsion: 50 //子节点之间的间距
            },
            label: {
              show: true,
              color: '#387DFF', // 节点文字颜色
            },
            effect: {
              show: true, //是否 运动
              trailLength: 0,
              symbol: 'triangle',
              symbolSize: 15,
              period: 2
            },
            data: charts.nodes
          },

          {
            type: "lines",
            polyline: false,
            coordinateSystem: "cartesian2d",
            lineStyle: {
              // type: "dashed", // 线条类型
              opacity: 1,
              width: 2,
              color: '#fcd75f',
            },
            effect: {
              show: true,
              trailLength: 0,// 特效存在时间长度
              symbol: 'arrow', // 特效的形状
              image:'../../../public/jd/button.jpg',
              symbolSize: 15, // 特效大小
              // loop: true, // 特效循环
              // scale: 1.5, // 特效缩放
              period: 1, // 特效速度
              // random: true, // 特效随机
              color: '#f30b03', // 特效颜色
              // brushType: 'both', // 特效覆盖类型
            },
            // animation: true, // 开启动画
            // animationDuration: 3000, // 动画时长
            symbol: ['circle', 'arrow'],
            symbolSize: 10,
            label: {
              show: true,
              position: "middle",
              fontSize: 16,
              color: '#08979C',
              formatter: function (args) {
                let val = args.data.name;
                var strs = val.split("");
                var str = "";
                if (args.data.linkView) {
                  for (var i = 0, s; (s = strs[i++]);) {
                    str += s;
                    if (!(i % 15)) str += "\n";
                  }
                  return str;
                }
              },

            },

            // lineStyle: {

            //     color: '#65B7E3',

            //     width: 2

            // },

            data: charts.linesData,

          },

        ],

      };
      option && this.myChart.setOption(option);
      let chart = this.myChart
      window.addEventListener('resize', function () {
        chart.resize();
      });
    },
  },
}
 </script>
<style lang="scss" scoped>
#echart2 {
  width: 100%;
  height: 59rem;
  margin: 0 auto auto;
  margin-left: 2rem;
}
</style>
  • 9
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值