折线图 最大值显示白点,默认显示tooltip框框,自定义tooltip

效果图:

 

代码如下:(直接放整个vue文件了,省事)

<template>
  <div>
    <div style="width: 406px; height:220px" id="zz_r_two1"></div>
    <div class="xsTitle">
      <div class="fang"></div>
      <span>今日峰值时段:11:00 - 13:00</span>
    </div>
  </div>
</template>

<script>
export default {
  name: "zz_r_two1",
  mounted() {
    this.drawLine();
  },
  methods: {
    // 自适应字体大小变化
    WidthAdaptive(res) {
      var windth = window.innerWidth;
      let fontSize = windth / 1920;
      return fontSize * res;
    },
    drawLine() {
      // 基于准备好的dom,初始化echarts实例
      let myChart = this.$echarts.init(document.getElementById("zz_r_two1"));
      let xLabel = [
        "00:00",
        "01:00",
        "02:00",
        "03:00",
        "04:00",
        "05:00",
        "06:00",
        "07:00",
        "08:00",
        "09:00",
      ];
      let goOutSchool = [30, 12, 69, 36, 13, 58, 130, 10, 2, 33];
      let maxNum = this.getMax(goOutSchool);
      let allNum = this.getAll(goOutSchool);
      let maxIndex = this.getMaxIndex(goOutSchool);
      let getSD = xLabel[maxIndex];

      let percentage = this.getPercentage(allNum, maxNum);

      let option = {
        backgroundColor: "transparent",
        grid: {
          top: "24%",
          left: "10%",
          right: "5%",
          bottom: "15%",
          // containLabel: true
        },
        tooltip: {
          show: true,
          backgroundColor: "rgba(67, 67, 67, 0.7)",
          formatter: "{b0}<br />" + percentage,
        },
        xAxis: [
          {
            type: "category",
            boundaryGap: true,
            axisLine: {
              //坐标轴轴线相关设置。数学上的x轴
              show: true,
              lineStyle: {
                color: "rgba(255, 255, 255, 0.15)",
              },
            },
            axisLabel: {
              //坐标轴刻度标签的相关设置
              textStyle: {
                color: "rgba(255, 255, 255, 0.65)",
                fontSize: this.WidthAdaptive(14),
                padding: this.WidthAdaptive(2),
              },
              formatter: function(data) {
                return data;
              },
            },
            splitLine: {
              show: false,
              lineStyle: {
                color: "#192a44",
              },
            },
            axisTick: {
              show: false,
            },
            data: xLabel,
          },
        ],
        yAxis: [
          {
            splitLine: {
              lineStyle: {
                type: "solid",
                color: "rgba(112,112,112,0.5)",
              },
            },
            axisLine: {
              show: false,
              lineStyle: {
                color: "#8C9493",
              },
            },
            axisLabel: {
              show: true,
              textStyle: {
                color: "rgba(255, 255, 255, 0.65)",
                fontSize: this.WidthAdaptive(14),
                padding: this.WidthAdaptive(2),
              },
            },
            axisTick: {
              show: false,
            },
          },
        ],
        series: [
          {
            name: "峰值时段",
            type: "line",
            symbol: "circle", // 默认是空心圆(中间是白色的),改成实心圆
            showAllSymbol: true,
            symbolSize: 0,
            smooth: true,
            lineStyle: {
              normal: {
                width: this.WidthAdaptive(2),
                color: "rgba(25, 104, 255, 1)", // 线条颜色
              },
              borderColor: "rgba(0,0,0,.4)",
            },
            itemStyle: {
              color: "rgba(25, 104, 255, 1)",
              borderColor: "#646ace",
              borderWidth: this.WidthAdaptive(20),
            },
            tooltip: {
              show: true,
            },
            markPoint: {
              data: [
                {
                  type: "max",
                  name: getSD,
                  symbol: "circle",
                  symbolSize: this.WidthAdaptive(14),
                  itemStyle: {
                    color: "rgba(255,255,255,1)",
                    borderColor: "#fff",
                    borderWidth: this.WidthAdaptive(0),
                  },
                  label: { show: false, fontSize: 0 },
                },
              ],
            },
            areaStyle: {
              //区域填充样式
              normal: {
                //线性渐变,前4个参数分别是x0,y0,x2,y2(范围0~1);相当于图形包围盒中的百分比。如果最后一个参数是‘true’,则该四个值是绝对像素位置。
                color: new this.$echarts.graphic.LinearGradient(
                  0,
                  0,
                  0,
                  1,
                  [
                    {
                      offset: 0,
                      color: "rgba(25, 104, 255, .5)",
                    },
                    {
                      offset: 1,
                      color: "rgba(25, 104, 255, 0)",
                    },
                  ],
                  false
                ),
                shadowColor: "rgba(61, 230, 255, 0.5)", //阴影颜色
                shadowBlur: this.WidthAdaptive(20), //shadowBlur设图形阴影的模糊大小。配合shadowColor,shadowOffsetX/Y, 设置图形的阴影效果。
              },
            },
            data: goOutSchool,
          },
        ],
      };
      window.onresize = function() {
        myChart.resize();
      };
      myChart.setOption(option);

      myChart.dispatchAction({
        type: "showTip",
        seriesIndex: 0, // 显示第几个series
        dataIndex: maxIndex, // 显示第几个数据
      });
    },

    //获取最大值
    getMax(arr) {
      //假设最大值max 为arr[0]
      var max = arr[0];
      //遍历对比
      for (var i = 0; i < arr.length; i++) {
        //若max小于当前项 说明不是最大值 将当前项的值赋予max
        // 继续遍历对比找到最大的值
        if (max < arr[i]) {
          max = arr[i];
        }
      }
      return max;
    },
    // 获得总数
    getAll(arr) {
      let num = 0;
      for (let i = 0; i < arr.length; i++) {
        num += parseInt(arr[i]);
      }
      return num;
    },
    // 计算最大值所占百分比
    getPercentage(all, max) {
      return (max / all).toFixed(2) * 100 + "%";
    },
    // 获得最大值下标
    getMaxIndex(arr) {
      var max = arr[0];
      //声明了个变量 保存下标值
      var index = 0;
      for (var i = 0; i < arr.length; i++) {
        if (max < arr[i]) {
          max = arr[i];
          index = i;
        }
      }
      return index;
    },
  },
};
</script>

<style scoped>
.xsTitle {
  width: 100%;
  height: 20px;
  position: absolute;
  left: 0;
  top: 12px;
  z-index: 999;
  display: flex;
  align-items: center;
}
.xsTitle > .fang {
  width: 9px;
  height: 9px;
  margin-left: 17px;
  margin-right: 9px;
  background: url("../img/f1.png") no-repeat;
  background-size: 100% 100%;
}
.xsTitle > span {
  font-family: Source Han Sans CN;
  font-size: 14px;
  font-weight: normal;
  color: #63dbee;
}
</style>

 

posted @ 2023-05-18 18:25  大云之下  阅读(224)  评论(0编辑  收藏  举报
大云之下