Newer
Older
DH_Apicture / src / views / pictureOnMap / page / components / DialogTabs / component / ylfxJCFX.vue
@zhangqy zhangqy 9 days ago 12 KB 开发风险分析高亮
<template>
  <div id="ylfxJCFX">
    <div id="HeaderEcharts"></div>
    <el-divider>管网历史分析</el-divider>
    <div id="BodyFenXi">
      <div class="flex flex-justcontent-spacebetween">
        <div class="eachInfo">
          <div class="name">所属雨水分区:</div>
          <div class="text">{{ listData.rainArea }}</div>
        </div>
        <div class="eachInfo">
          <div class="name">运维片区:</div>
          <div class="text">{{ listData.watchAreaName }}</div>
        </div>
      </div>
      <div class="tableBox">
        <div class="name">历史经验:</div>
        <div class="text popUpTable">
          <el-table :data="listData.rainHistoryList" class="w100" stripe>
            <el-table-column prop="time" label="降雨日期" width="140px">
            </el-table-column>
            <el-table-column prop="rain" label="日降雨量(mm)" />
            <el-table-column prop="jyjb" label="降雨级别">
              <template #default="scope">
                <div>
                  {{ RainfallLevelFun(scope.row.rain) }}
                </div>
              </template>
            </el-table-column>
            <el-table-column prop="maxData" label="最大雨强(mm)" />
            <el-table-column prop="zdss" label="最大水深(cm)" />
            <el-table-column prop="cmd" label="充满度" />
            <el-table-column prop="warn" label="风险" />
            <el-table-column prop="duration" label="风险时长(分钟)" width="140px" />
          </el-table>
        </div>
      </div>
      <div class="eachInfo">
        <div class="name">周边环境分析:</div>
        <div class="text">{{ listData.zbhjfx }}</div>
      </div>
    </div>
  </div>
</template>

<script setup name="ylfxJCFX">
import { ref, reactive, toRefs, onMounted, nextTick } from "vue";
import * as echarts from "echarts";
import { drainageDispatchRainAnalysisByGwjcd, getEchart } from "@/api/MonitorAssetsOnMap";
import { monitorAnalysisRiskTimeBetween } from "@/api/MonitoringAnalysis";
import moment from "moment";

const props = defineProps({
  // 数据id
  dataID: {
    type: String,
  },
  dataCode: {
    type: String,
  },
  arrstcode: {
    type: Array,
  },
  arrid: {
    type: Array,
  },
  Getproperties: {
    type: Object,
  },
});

const AllData = reactive({
  chart: null,
  yAxis: [],
  yAxis_Name: "降雨量(mm)",
  yAxis3: [],
  yAxis3_Name: "水深(m)",
  xAxis: [],
  MGSW: 0,
  GSW: 0,
  MG: 0,
  YL: 0,
  FenXianTimer: [],
});
const Timers = ref([
  moment().subtract(3, "day").format("YYYY-MM-DD HH:mm:ss"),
  moment().format("YYYY-MM-DD HH:mm:ss"),
]);
const init = () => {
  //先获取Dom上的实例
  let chartDom = echarts.getInstanceByDom(document.getElementById("HeaderEcharts"));
  //然后判断实例是否存在,如果不存在,就创建新实例
  if (chartDom == null) {
    chartDom = echarts.init(document.getElementById("HeaderEcharts"));
    var option = {
      tooltip: {
        trigger: "axis",
        backgroundColor: "#004284",
        borderColor: "#0B9BFF",
        borderRadius: 6, // 设置圆角大小
        // 自定义提示框文本样
        textStyle: {
          // 字体颜色
          color: "white",
          // 字体大小
          fontSize: 14,
        },
      },
      legend: {
        data: [AllData.yAxis_Name, AllData.yAxis3_Name],
        textStyle: {
          color: "#FFFFFF",
          fontSize: 12,
        },
      },
      grid: {
        left: 100,
        right: 100,
        bottom: 20,
        containLabel: true,
      },

      xAxis: {
        type: "category",
        boundaryGap: true,
        data: AllData.xAxis,
        axisLabel: {
          color: "rgba(255,255,255,1)",
          fontSize: 12,
          fontFamily: "AlibabaPuHuiTi",
        },
      },

      dataZoom: [
        {
          // show: true,
          show: false,
          height: 4,
          bottom: 10,
          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: 0,
          end: 100,
        },
      ],
      yAxis: [
        {
          name: AllData.yAxis_Name,
          type: "value",
          // minInterval: 1,
          axisLabel: {
            color: "#AAC1CF",
            show: true,
            formatter: function (value) {
              return value.toFixed(2); // 保留两位小数
            },
          },
          min: 0,
          nameTextStyle: {
            color: "#19D5FF",
          },
          splitLine: {
            lineStyle: {
              type: "dashed",
              color: "#2161a8",
            },
          },
          alignTicks: true,
          position: "left",
          inverse: true,
          nameLocation: "start",
        },
        {
          name: AllData.yAxis3_Name,
          type: "value",
          // minInterval: 1,
          max: function (value) {
            return value.max > AllData.YL ? value.max : AllData.YL;
          },
          min: 0,
          axisLabel: {
            color: "#AAC1CF",
            show: true,
            formatter: function (value) {
              return value.toFixed(2); // 保留两位小数
            },
          },
          nameTextStyle: {
            color: "#99FF55",
          },
          splitLine: {
            lineStyle: {
              type: "dashed",
              color: "#2161a8",
            },
          },
          alignTicks: true,
        },
      ],
      series: [
        {
          name: AllData.yAxis_Name,
          type: "bar",
          data: AllData.yAxis,
          barWidth: "30%", // 可以是具体像素值 '20px' 或百分比 '50%'
          // 修改数据点颜色
          itemStyle: {
            borderRadius: [0, 0, 50, 50],
            color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
              { offset: 0, color: "#08B1FF" },
              { offset: 1, color: "#19D6FF" },
            ]), // 数据点颜色
          },
          markArea: {
            label: {
              color: "#fb6061",
            },
            itemStyle: {
              color: "#fb606150",
            },
            data: AllData.FenXianTimer,
          },
        },
        {
          name: AllData.yAxis3_Name,
          type: "line",
          data: AllData.yAxis3,
          yAxisIndex: 1,
          symbolSize: 7,
          // 修改折线颜色
          lineStyle: {
            color: "#99FF55", // 折线颜色
            width: 2, // 折线宽度
          },
          // 修改数据点颜色
          itemStyle: {
            color: "#99FF55", // 数据点颜色
          },
          // yAxisIndex: 1,
          markLine: {
            data: [],
            symbol: ["none", "none"], // 这里设置标记线两端的标记为'none',即不显示箭头
          },
        },
      ],
    };
    if (AllData.MGSW > 0) {
      option.series[1].markLine.data.push({
        yAxis: AllData.MGSW, // 这是水平线的 Y 轴值
        lineStyle: {
          type: "dashed",
          color: "red", // 线的颜色
        },
        label: {
          show: true,
          // formatter: "满管水位" + props.data.yAxis6_YJ,
          formatter: "溢流风险:" + AllData.MGSW,
          color: "red",
          fontSize: 12,
          position: "middle",
        },
      });
    }
    if (AllData.GSW > 0) {
      option.series[1].markLine.data.push({
        yAxis: AllData.GSW, // 这是水平线的 Y 轴值
        lineStyle: {
          type: "dashed",
          color: "yellow", // 线的颜色
          cap: "round",
        },
        label: {
          show: true,
          formatter: "高水位:" + AllData.GSW,
          color: "yellow",
          fontSize: 12,
          position: "middle",
        },
      });
    }
    if (AllData.MG > 0) {
      option.series[1].markLine.data.push({
        yAxis: AllData.MG, // 这是水平线的 Y 轴值
        lineStyle: {
          type: "dashed",
          color: "rgba(255, 191, 0, 1)", // 线的颜色
          cap: "round",
        },
        label: {
          show: true,
          formatter: "满管:" + AllData.MG,
          color: "rgba(255, 191, 0, 1)",
          fontSize: 12,
          position: "middle",
        },
      });
    }
    if (AllData.YL > 0) {
      option.series[1].markLine.data.push({
        yAxis: AllData.YL, // 这是水平线的 Y 轴值
        lineStyle: {
          type: "dashed",
          color: "#610404", // 线的颜色
          cap: "round",
        },
        label: {
          show: true,
          formatter: "溢流:" + AllData.YL,
          color: "#610404",
          fontSize: 12,
          position: "middle",
        },
      });
    }
    option && chartDom.setOption(option, true);
    AllData.chart = chartDom;
  }
};
const resizeTheChart = () => {
  if (AllData.chart) {
    AllData.chart.resize();
  }
};
const getChartsData = () => {
  getEchart({
    stType: props.Getproperties.stType,
    stCode: props.Getproperties.stCode,
    dataCode: props.Getproperties.dataCode,
    start: Timers.value[0],
    end: Timers.value[1],
  }).then((res) => {
    if (res && res.code == 200) {
      AllData.xAxis = res.data.times;
      res.data.datas.forEach((element) => {
        switch (element.dataKey) {
          case "z":
            AllData.yAxis3 = element.datas;
            element.cordonLineList.forEach((element) => {
              if (element.code == "ylfx") {
                AllData.MGSW = Number(element.lineValue);
              }
              if (element.code == "gsw") {
                AllData.GSW = Number(element.lineValue);
              }
              if (element.code == "mg") {
                AllData.MG = Number(element.lineValue);
              }
              if (element.code == "yl") {
                AllData.YL = Number(element.lineValue);
              }
            });
            break;

          case "pn05":
            AllData.yAxis = element.datas;
            break;
        }
      });
      getFengXianTimer();
    }
  });
};

const listData = ref({});
function gitDataFun() {
  let params = {
    id: props.Getproperties.id,
  };
  drainageDispatchRainAnalysisByGwjcd(params).then(
    (res) => {
      console.log("监测分析渍水风险降雨历史", res);
      if (res && res.code == 200) {
        listData.value = res.data;
      }
    },
    (error) => {}
  );
}
function RainfallLevelFun(rain) {
  let sum = Number(rain);
  let text = "";
  switch (true) {
    // 江河水位
    case sum > 200:
      text = "特大暴雨";
      break;
    case sum > 100:
      text = "大暴雨";
      break;
    case sum > 50:
      text = "暴雨";
      break;
    case sum > 25:
      text = "大雨";
      break;
    case sum > 10:
      text = "中雨";
      break;
    case sum > 0:
      text = "小雨";
      break;
    default:
      text = "无雨";
  }
  return text;
}
const getFengXianTimer = () => {
  monitorAnalysisRiskTimeBetween({
    startTime: Timers.value[0],
    endTime: Timers.value[1],
    stCode: props.Getproperties.stCode,
    dataCode: props.Getproperties.dataCode,
    menuType: "ylfxJCFX",
  }).then((res) => {
    if (res && res.code == 200) {
      AllData.FenXianTimer = res.data;
      init();
    }
  });
};
onMounted(() => {
  nextTick(() => {
    if (props.Getproperties.daterange) {
      Timers.value = props.Getproperties.daterange;
    }
    getChartsData();
    gitDataFun();
    window.addEventListener("resize", resizeTheChart);
  });
});
</script>

<style lang="scss" scoped>
#ylfxJCFX {
  width: 100%;
  height: 100%;
  #HeaderEcharts {
    // width: 1198px;
    // height: 320px;
    width: 100%;
    height: 320px;
  }
  #BodyFenXi {
    width: 100%;
    height: 250px;

    .eachInfo {
      display: flex;
      align-items: center;
      font-weight: bold;
      font-size: 14px;
      margin-bottom: 10px;

      .name {
        color: #ccdfff;
        width: 100px;
        text-align: right;
        padding-right: 10px;
      }
      .text {
        flex: 1;
        min-width: 300px;
        min-height: 37px;
        color: #8fbffe;
        background: #0d2359;
        border-radius: 6px;
        border: 1px solid #0b9bff;
        padding: 7px 12px;
      }
    }
    .tableBox {
      display: flex;
      font-size: 14px;
      margin-bottom: 10px;
      color: #ccefff;
      .name {
        color: #ccdfff;
        min-width: 100px;
        text-align: right;
        padding-right: 10px;
      }
      .text {
        width: calc(100% - 100px);
      }
      :deep(.el-scrollbar__wrap) {
        max-height: 120px;
        overflow-y: auto;
      }
    }
  }
}
</style>