Newer
Older
DH_Apicture / src / views / pictureOnMap / page / components / DialogTabs / component / shuikujianceEcharts.vue
@ZZJ ZZJ 6 days ago 7 KB update
<template>
  <!-- 天气温度平滑折线图 -->
  <div :id="id" style="width: 100%; height: 100%"></div>
</template>
<script setup>
import { guid } from '@/utils/ruoyi';
import { nextTick } from 'vue';
const id = guid();
const myChart = shallowRef('');
import * as echarts from 'echarts';

const props = defineProps({
  //刷新标志
  refresh: {
    type: [String, Number],
    default: 1,
  },
  //x轴数据
  XAxis: {
    type: Array,
    default: () => [],
  },
  //y轴数据
  YAxis: {
    type: Array,
    default: () => [],
  },
  //名字
  DataName: {
    type: String,
  },
  //类型
  typeName: {
    type: String,
    default: '',
  },
  yAxisarr: {
    type: Array,
    default: () => [],
  },
});

watch(
  () => props.refresh,
  value => {
    // console.log("???????");
    //先销毁实例
    myChart.value && myChart.value.dispose();
    init();
  },
  {
    deep: true,
  }
);
function init() {
  let colorarr = ['#99FF55', '#b14de5', '#FFC155', '#409eff', '#ff7f50', '#ff69b4', '#87ceeb', '#4682b4', '#98fb98'];
  let rightnumber = props.yAxisarr.length * '2.5' + '%';
  let newarr = [];
  let marklinedata = [];
  let maxArr = [];
  let minArr = [];
  let finyasx = [
    {
      show: false,
      inverse: true, //控制x轴在上方
      name: props.typeName,
      type: 'value',
      axisLabel: {
        show: true,
        color: '#409eff',
      },
      axisLine: {
        lineStyle: {
          color: '#409eff',
        },
      },
      splitLine: {
        show: true,
        lineStyle: {
          color: 'rgba(61,91,98,0.8)',
        },
      },
      // min: 0,
    },
  ];

  let finxse = [
    // {
    //   name: props.typeName,
    //   type: 'bar',
    //   barWidth: 12,
    //   itemStyle: {
    //     borderRadius: [0, 0, 6, 6],
    //     color: function () {
    //       return new echarts.graphic.LinearGradient(
    //         0,
    //         1,
    //         0,
    //         0,
    //         [
    //           {
    //             offset: 0.1,
    //             color: '#409eff', // 0% 处的颜色
    //           },
    //           {
    //             offset: 0.9,
    //             color: '#013068', // 100% 处的颜色
    //           },
    //         ],
    //         false
    //       );
    //     },
    //   },
    //   // showBackground: true,
    //   backgroundStyle: {
    //     color: 'transparent',
    //     borderWidth: 1,
    //     borderColor: 'rgba(148, 250, 65, 0.2)',
    //   },
    //   data: props.YAxis,
    // },
  ];

  // console.log("获取的Y轴的数据", props.yAxisarr);

  // 处理多个y轴遍历展示
  if (props.yAxisarr) {
    props.yAxisarr.map((item, index) => {
      let arr = [];
      let markLineArr = [];
      item.cordonLineList.map(p => {
        markLineArr.push(Number(p.lineValue));
        arr.push({
          silent: false, //鼠标悬停事件  true没有,false有
          lineStyle: {
            //警戒线的样式  ,虚实  颜色
            type: 'dashed',
            color: p.lineColor,
          },
          name: p.lineName,
          yAxis: Number(p.lineValue),
          label: {
            formatter: `${p.lineValue}-${p.lineName}`,
            color: p.lineColor,
          },
        });
      });

      item['maxValue'] = Math.max.apply(null, [...item.datas, ...markLineArr]);
      item['minValue'] = Math.min.apply(null, [...item.datas, ...markLineArr]);

      marklinedata.push(arr);
    });

    // console.log("marklinedata", marklinedata);
    props.yAxisarr.map((item, index) => {
      let obj = {
        name: item.dataName + item.unit,
        type: 'value',
        axisLabel: {
          show: true,
          color: colorarr[index],
        },
        axisLine: {
          show: true,
          lineStyle: {
            color: colorarr[index],
          },
        },
        splitLine: {
          show: true,
          lineStyle: {
            color: 'rgba(61,91,98,0.8)',
          },
        },
        min: Math.floor(item.minValue * 0.95),
        max: Math.floor(item.maxValue * 1.05),
      };

      if (index == 0) {
        obj.position = 'left';
      } else if (index == 1) {
        obj.position = 'right';
      } else {
        obj.position = 'right';
        obj.offset = (index - 1.1) * 70;
        // obj.show = false;
      }

      finyasx.push(obj);

      finxse.push({
        smooth: true, //变为曲线 默认false折线
        name: item.dataName + item.unit,
        type: 'line',
        yAxisIndex: index + 1,
        data: item.datas,
        markLine: {
          symbol: 'none', //去掉警戒线最后面的箭头
          label: {
            position: 'middle', //将警示值放在哪个位置,三个值“start”,"middle","end"  开始  中点 结束
          },
          data: marklinedata[index],
        },
      });
    });
  }

  myChart.value = echarts.init(document.getElementById(id));
  let option = {
    color: colorarr,
    legend: {
      show: true,
      orient: 'horizontal', //horizontal横向 vertical 纵向
      type: 'scroll',
      x: 'center', //居右显示
      align: 'left', //图例控制在左边
      // icon: 'circle',
      // itemWidth: 15,
      itemHeight: 15,
      itemHeight: 15,
      textStyle: {
        color: 'auto',
        rich: {
          another: {
            fontSize: 28,
          },
        },
        fontSize: 14,
      },
    },
    tooltip: {
      trigger: 'axis',
      // formatter: "{b}:{c}件",
      // formatter: "{b}:{c}",
      feature: {
        mark: { show: true },
        dataView: { show: true, readOnly: false },
        magicType: { show: true, type: ['line', 'bar'] },
        restore: { show: true },
        saveAsImage: { show: true },
      },
      axisPointer: {
        type: 'cross',
        textStyle: {
          color: '#fff',
        },
      },
    },
    grid: {
      top: '18%',
      left: '5%',
      right: rightnumber,
      // right: '5%',
      bottom: '15%',
      containLabel: true,
    },
    xAxis: [
      {
        type: 'category',
        data: props.XAxis,
        axisPointer: {
          type: 'shadow',
        },
        axisLabel: {
          show: true,
          color: '#fff',
        },
        axisLine: {
          lineStyle: {
            // color: '#3398DB',
          },
        },
      },
    ],
    yAxis: finyasx,
    dataZoom: [
      {
        show: true,
        // show: false,
        height: 4,
        bottom: 18,
        start: 0,
        end: 100,
        handleSize: '100%',
        fillerColor: '#94FA41',
        borderColor: 'transparent',
        backgroundColor: 'rgba(148, 250, 65, 0.2)',
        handleStyle: {
          color: '#94FA41',
        },
        moveHandleSize: 0,
        textStyle: {
          color: '#fff',
        },
      },
      {
        type: 'inside',
        show: true,
        height: 15,
        start: 1,
        end: 35,
      },
    ],
    series: finxse,
  };

  option && myChart.value.setOption(option);
}

function resizeTheChart() {
  if (myChart.value) {
    myChart.value.resize();
  }
}
onMounted(() => {
  nextTick(() => {
    init();
    window.addEventListener('resize', resizeTheChart);
  });
});
</script>