Newer
Older
KaiFengPC / src / views / floodSys / floodOneMap / tabRightFX.vue
@jimengfei jimengfei on 6 Jun 12 KB updata
<template>
  <!-- 风险研判 态势研判-->
  <div class="tabRightFX" v-if="tabShowWL == 4">
    <div class="allContent">
      <div class="selectTitle" style="margin-top: 15px">
        <div class="name">未来24h气象降雨预报</div>
      </div>
      <div class="staticPicture" v-loading="loadingWeather">
        <div id="chartOne"></div>
      </div>

      <div class="selectTitle">
        <div class="name">河道水位</div>
        <el-select v-model="riverIndex" style="margin: 0px 10px 0px 10px; width: 220px" size="small" @change="changeRiver">
          <el-option :label="item.stName" :value="item.stCode" v-for="item in riverLists" :key="item.stCode"></el-option>
        </el-select>
      </div>
      <div class="staticPicture" v-loading="loadingRiver">
        <div id="chartTwo"></div>
      </div>

      <div class="selectTitle">
        <div class="name">积水风险研判</div>
      </div>
      <el-table
        ref="tableArea"
        :data="tableData"
        v-loading="tableLoading"
        style="width: 100%; margin: 5px 0 10px 0"
        height="200"
        highlight-current-row
        @row-click="clickLogData"
        :empty-text="'暂无风险'"
      >
        <el-table-column prop="riskLevel" label="积水风险级别">
          <template #default="scope">
            {{
              scope.row.riskLevel == 'high'
                ? '高风险'
                : scope.row.riskLevel == 'middle'
                ? '中风险'
                : scope.row.riskLevel == 'low'
                ? '低风险'
                : '--'
            }}
          </template>
        </el-table-column>
        <el-table-column prop="avgZ" label="平均水深(m)" />
        <el-table-column prop="waterloggingArea" label="积水面积(k㎡)" />
      </el-table>
    </div>
    <!-- 积水区域预报水位弹窗 -->
    <el-dialog v-model="dialogShow" title="积水区域预报水位" width="800px" append-to-body>
      <LineChart
        v-if="dialogShow"
        :echartData="echartData"
        :refresh="refresh"
        style="width: 760px; height: 400px; margin-bottom: 30px"
      ></LineChart>
    </el-dialog>
  </div>
</template>
<script setup name="tabRightFX">
import chartOption from '@/components/Echarts/pieChart_1.js';
import * as echarts from 'echarts';
import { nextTick } from 'vue';
import bus from '@/bus';
import { ElLoading } from 'element-plus';
import { rainTrend, waterloggingRisk, riverRisk, geometryDurationData } from '@/api/floodSys/oneMap';
import LineChart from '@/components/Echarts/lineOneChart.vue'; //折线图
import xiaoganCityBoundary from '@/assets/geojson/xiaoganCityBoundary.json';

const tabShowWL = ref(null);
const loadingWeather = ref(true);
const tableData = ref([]);
const tableLoading = ref(true);
const tableArea = ref(null);
const riverIndex = ref(null);
const riverLists = ref([]);
const loadingRiver = ref(true);
const dialogShow = ref(false);
const refresh = ref(1);
const timer = ref(null);
const echartData = ref({
  xAxisData: [],
  yAxisName: '内涝点水位(m)',
  seriesData: [
    {
      type: 'line',
      smooth: true,
      data: [],
      // 填充区域的样式
      areaStyle: {
        // 填充色渐变
        color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
          { offset: 1, color: 'rgba(156, 205, 247, 0.3)' },
          { offset: 0, color: 'rgba(156, 205, 247, 1)' },
        ]),
      },
    },
  ],
});

// 降雨预报柱状图
let chart = null;
const initEcharts = async () => {
  if (!!chart) chart.dispose();
  chart = echarts.init(document.getElementById('chartOne'));
  loadingWeather.value = true;
  let res = await rainTrend();
  if (res && res.code == 200) {
    let datas = res.data;
    console.log(datas, 9999999);
    let times = [];
    if (Boolean(datas.dateRange.length)) {
      datas.dateRange.forEach(i => {
        times.push(i.substr(0, 16));
      });
    }
    chartOption.floodOneMapFXrain.legend.data = ['近24h实测雨量', '未来24h预报雨量'];
    chartOption.floodOneMapFXrain.xAxis[0].data = times;
    chartOption.floodOneMapFXrain.yAxis[0].name = 'mm';
    chartOption.floodOneMapFXrain.series[0].name = '近24h实测雨量';
    chartOption.floodOneMapFXrain.series[1].name = '未来24h预报雨量';
    chartOption.floodOneMapFXrain.series[0].data = datas.history;
    chartOption.floodOneMapFXrain.series[1].data = datas.forecast;
    if (datas.dateRange.length == 0) {
      chartOption.floodOneMapFXrain.graphic.invisible = false; //暂无数据
    } else {
      chartOption.floodOneMapFXrain.graphic.invisible = true; //暂无数据
    }
    // 设置鼠标滚轮放大缩小展示数据区间
    chartOption.floodOneMapFXrain.dataZoom = [{ type: 'inside', startValue: 5 }];
  }
  chart.clear();
  chart.setOption(chartOption.floodOneMapFXrain);
  loadingWeather.value = false;
};

// 河湖风险研判切换河湖
function changeRiver(val) {
  riverIndex.value = val;
  getRiverData();
}
// 河湖风险研判echarts
let chartRiver = null;
async function getRiverData() {
  if (!!chartRiver) chartRiver.dispose();
  chartRiver = echarts.init(document.getElementById('chartTwo'));
  // echarts赋值
  let arrs = riverLists.value.filter(item => item.stCode == riverIndex.value);
  console.log(arrs);
  chartOption.floodOneMapFXYP.xAxis[0].data = arrs[0].riverX;
  chartOption.floodOneMapFXYP.series[1].data = arrs[0].riverY;
  chartOption.floodOneMapFXYP.series[1].markLine.data[0].yAxis = arrs[0].sfZ;
  chartOption.floodOneMapFXYP.series[1].markLine.data[0].label.formatter = '设防水位 ' + arrs[0].sfZ + 'm';
  let arrs2 = [];
  arrs[0].riverX.map(item => {
    arrs2.push(arrs[0].z);
  });
  chartOption.floodOneMapFXYP.series[0].data = arrs2;
  if (arrs[0].riverX.length == 0) {
    chartOption.floodOneMapFXYP.graphic.invisible = false; //暂无数据
  } else {
    chartOption.floodOneMapFXYP.graphic.invisible = true; //暂无数据
  }
  chartRiver.clear();
  chartRiver.setOption(chartOption.floodOneMapFXYP);
}
// 获取河湖风险研判下拉框值
async function getRiverSelect() {
  loadingRiver.value = true;
  let res = await riverRisk();
  if (res && res.code == 200) {
    let datas = res.data;
    riverLists.value = datas;
    riverIndex.value = datas[0].stCode;
    changeRiver(riverIndex.value);
  }
  loadingRiver.value = false;
}

//积水预报表格
async function getWaterLogging() {
  tableLoading.value = true;
  let res = await waterloggingRisk();
  if (res && res.code == 200) {
    tableData.value = res.data;
    tableLoading.value = false;
    clickLogData(tableData.value[2]);
    tableArea.value.setCurrentRow(tableData.value[2], true); //表格默认第3个高亮选中
  }
}
// 积水预报表格点击,gis加载积水单元
function clickLogData(val) {
  let golygonColor;
  let features = [];
  val.riskLevel == 'low' ? (golygonColor = '#10e8a1') : val.riskLevel == 'middle' ? (golygonColor = '#1e97f0') : (golygonColor = '#ff2603');
  let loading = ElLoading.service({
    lock: true,
    text: '正在进行积水单位渲染...',
  });
  val.geometry.forEach((element, index) => {
    let turfPolygon = turf.polygon(element.coordinates, { name: element.name, geoVal: element.geoVal, color: golygonColor });
    features.push(turfPolygon);
  });
  let waterlogRiskJson = turf.featureCollection(features);
  if (!!!newfiberMapbox.map.getLayer('waterLogingLayer')) {
    addWaterlogRiskLayer(waterlogRiskJson);
  } else {
    newfiberMapbox.map.getSource('waterLogingSource').setData(waterlogRiskJson);
  }
  loading.close();
}
//地图添加内涝风险
const addWaterlogRiskLayer = geojson => {
  newfiberMapbox.map.addSource('waterLogingSource', { type: 'geojson', data: geojson });
  newfiberMapbox.map.addLayer({
    id: 'waterLogingLayer',
    type: 'fill',
    source: 'waterLogingSource',
    paint: {
      'fill-color': ['get', 'color'],
    },
  });
};

// 获取预报水位线
async function getFutureData(params) {
  dialogShow.value = true;
  let res = await geometryDurationData({ name: params.name, type: 'depth' });
  if (res && res.code == 200) {
    let datas = res.data;
    echartData.value.xAxisData = datas.timeList;
    echartData.value.seriesData[0].data = datas.valueList;
    refresh.value = Math.random();
  }
}
//添加孝感城区边界
const addCityBoundary = () => {
  !newfiberMapbox.map.getSource('xiaoganCityBoundary') &&
    newfiberMapbox.map.addSource('xiaoganCityBoundary', { type: 'geojson', data: xiaoganCityBoundary });
  !newfiberMapbox.map.getLayer('xiaoganCityBoundary') &&
    !newfiberMapbox.map.addLayer({
      id: 'xiaoganCityBoundary',
      type: 'line',
      source: 'xiaoganCityBoundary',
      paint: {
        'line-color': 'rgba(255,18,60,1)',
        'line-width': 3,
      },
    });
};
onMounted(() => {
  bus.on('changeTableContent', val => {
    if (val == 4) {
      tabShowWL.value = val;
      nextTick(() => {
        newfiberMapbox.map.easeTo({
          center: [114.312, 34.802],
          zoom: 12.9,
          pitch: 0,
        });
        addCityBoundary();
        initEcharts(); //未来气象预报
        getRiverSelect(); //河湖风险研判
        getWaterLogging(); //积水预报
      });
      newfiberMapbox.map.on('click', e => {
        const clickFeature = (
          newfiberMapbox.map.queryRenderedFeatures([
            [e.point.x - 10 / 2, e.point.y - 10 / 2],
            [e.point.x + 10 / 2, e.point.y + 10 / 2],
          ]) || []
        ).filter(feature => feature.source == 'waterLogingSource')[0];
        if (!!!clickFeature) {
          return;
        }
        newfiberMapbox.map.easeTo({
          center: [e.lngLat.lng, e.lngLat.lat],
          zoom: 17,
        });
        // 获取预报水位线
        getFutureData(clickFeature.properties);
      });
      bus.emit('initeLayer', []);
    } else {
      tabShowWL.value = null;
      timer.value = setInterval(() => {
        if (!!!newfiberMapbox) {
          return;
        } else {
          !!newfiberMapbox.map.getLayer('waterLogingLayer') && newfiberMapbox.map.removeLayer('waterLogingLayer');
          !!newfiberMapbox.map.getSource('waterLogingSource') && newfiberMapbox.map.removeSource('waterLogingSource');
          !!newfiberMapbox.map.getLayer('xiaoganCityBoundary') && newfiberMapbox.map.removeLayer('xiaoganCityBoundary');
          !!newfiberMapbox.map.getSource('xiaoganCityBoundary') && newfiberMapbox.map.removeSource('xiaoganCityBoundary');
          clearInterval(timer.value);
        }
      }, 100);
    }
  });
});
onBeforeUnmount(() => {
  bus.off('changeTableContent');
  if (timer.value) {
    clearInterval(timer.value);
  }
});
</script>
<style lang="scss">
.tabRightFX {
  width: 100%;
  height: 100%;
  position: absolute;
  background: #00314e;
  border: 1px solid #094065;
  z-index: 115;
  .allContent {
    height: 750px;
    overflow: auto;
    .selectTitle {
      .switchName {
        color: #00d1ff;
        text-align: center;
        font-family: PingFang SC;
        font-size: 14px;
        font-weight: 400;
      }
      .scendRain {
        width: 100px;
        margin-right: 10px;
      }
    }
    .staticPicture {
      #chartOne,
      #chartTwo {
        height: 200px;
      }
    }
    .navBtn {
      display: flex;
      justify-content: flex-end;
      width: 504px;
      p {
        width: 70px;
        height: 20px;
        text-align: center;
        color: #00a6d2;
        cursor: pointer;
        background: #004770;
        font-family: PingFang SC;
        font-size: 14px;
        font-weight: 400;
        line-height: 20px;
        border-radius: 10px;
      }
      .active {
        background: #0188b1;
        border-radius: 10px;
        color: #004c6c;
      }
    }

    .dutyInfo {
      display: flex;
      margin: 5px;
      .name {
        margin-top: 15px;
        margin-left: 20px;
        color: #00d1ff;
        text-align: center;
        font-family: PingFang SC;
        font-size: 14px;
        font-weight: 400;
      }
      .phone {
        margin-top: 15px;
        margin-left: 20px;
        text-align: center;
        color: #00d1ff;
        font-family: PingFang SC;
        font-size: 14px;
        font-weight: 400;
      }
      .isRead {
        margin-top: 15px;
        margin-left: 200px;
        width: 52px;
        height: 28px;
        color: #00d1ff;
        font-family: PingFang SC;
        font-size: 14px;
        font-weight: 400;
        text-align: center;
        line-height: 28px;
        fill: #003758;
        border: 1px solid #01547b;
      }
      .isReadTrue {
        fill: #003758;
        border: 1px solid #00d1ff;
      }
    }
  }
}
</style>