Newer
Older
DH_Apicture / src / views / pictureOnMap / page / DrainageSystem / index.vue
@zhangqy zhangqy 19 days ago 4 KB 优化逻辑
<template>
  <!-- 排水体系 -->
  <div class="DrainageSystem">
    <!-- 中间的污水/雨水切换 -->
    <div class="TypeChangeBox">
      <div
        class="TypeBtn"
        v-for="(item, index) in AllData.yw_type"
        :class="[AllData.TypeID == item.key ? 'TypeBtnCheck' : '']"
        @click="TypeClick(item)"
      >
        <span class="TypenName">{{ item.name }}</span>
      </div>
    </div>
    <YSIndex v-if="AllData.TypeID == 'rain'"></YSIndex>
    <WSIndex v-if="AllData.TypeID == 'sewage'"></WSIndex>
  </div>
</template>

<script setup name="DrainageSystem">
import { ref, reactive, toRefs, onMounted, onBeforeUnmount } from "vue";
import bus from "@/bus";
import YSIndex from "./YSIndex.vue";
import WSIndex from "./WSIndex.vue";
import useUserStore from "@/store/modules/user";
const appStore = useUserStore();
const AllData = reactive({
  yw_type: [
    {
      name: "污水体系",
      key: "sewage",
      values: [
        { key: "污水分区", visible: true },
        { key: "newfiber-XYZLayer", visible: true },
        { key: "高清地图", visible: true },
        { key: "污水系统流向1", visible: false },
        { key: "污水系统流向", visible: false },
        { key: "1_污水处理厂", visible: false },
      ],
    },
    {
      name: "雨水体系",
      key: "rain",
      values: [
        { key: "雨水分区", visible: true },
        { key: "newfiber-XYZLayer", visible: true },
        { key: "高清地图", visible: true },
        { key: "rain_water_pump_station_info", visible: true },
        { key: "outlet_info2", visible: false },
        { key: "排口流向", visible: false },
        { key: "排口流向1", visible: false },
        { key: "rainwater_pipeline_quality1", visible: false },
      ],
    },
  ],
});

const TypeClick = (item) => {
  AllData.TypeID = item.key;
  appStore.Set_TiXiType(AllData.TypeID);
  TypeClick_(item);
};
const TypeClick_ = (item) => {
  const { setLayerVisible, clearTemporaryData, wsRouteToMapByName } = events_params;
  closeAllLayer();
  bus.emit(clearTemporaryData.key);
  newfiberMap.map.easeTo(newfiberMap.config_.params.init);
  item.values &&
    item.values
      .filter((i) => i.visible)
      .forEach((i) => bus.emit(setLayerVisible.key, { layername: i.key, isCheck: true }));
  item.key == "sewage" && bus.emit(wsRouteToMapByName.key);
};
const events_params = {
  setHighlight: { key: "setHighlight" },
  setLayerVisible: { key: "setLayerVisible" },
  clearTemporaryData: { key: "clearTemporaryData" },
  wsRouteToMapByName: { key: "wsRouteToMapByName" },
};
const closeAllLayer = () => {
  const { setLayerVisible, setHighlight } = events_params;
  AllData.yw_type
    .map((i) => i.values)
    .filter(Boolean)
    .flat()
    .forEach((i) =>
      bus.emit(setLayerVisible.key, {
        layername: i.key,
        isCheck: false,
        values: i.values,
      })
    );
  bus.emit(setHighlight.key, []);
};

onMounted(() => {
  let initeGLTimer = setInterval(() => {
    if (!window.newfiberMap) return;
    TypeClick(AllData.yw_type[1]);

    clearInterval(initeGLTimer);
  }, 100);

  bus.on(mapInitBusName, () =>
    TypeClick(AllData.yw_type.filter((i) => i.key == AllData.TypeID)[0])
  );
});

onBeforeUnmount(() => {
  bus.off("FenQuClick");
  bus.off("openJXFXDialog");
  bus.off(mapInitBusName);
  closeAllLayer();
});
</script>

<style lang="scss" scoped>
.DrainageSystem {
  .TypeChangeBox {
    left: 50%;
    position: fixed;
    top: 120px;
    width: 300px;
    height: 39px;
    margin-left: -150px;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: center;
    z-index: 10;

    .TypeBtn {
      width: 138px;
      height: 39px;
      background: url("@/assets/images/pictureOnMap/JCFX/MoRen.png") no-repeat center;
      float: left;
      cursor: pointer;
      .TypenName {
        display: inline-block;
        width: 138px;
        height: 39px;
        font-family: Source Han Sans CN;
        font-weight: bold;
        font-size: 16px;
        color: #ffffff;
        line-height: 36px;
        text-shadow: 0px 2px 8px rgba(5, 28, 55, 0.42);
        // background: linear-gradient(
        //   180deg,
        //   rgba(49, 190, 255, 0.3) 0%,
        //   rgba(239, 252, 254, 1) 40%,
        //   rgba(239, 252, 254, 1) 100%
        // );
        // background-clip: text;
        // -webkit-text-fill-color: transparent;
        text-align: center;
      }
    }
    .TypeBtnCheck {
      background: url("@/assets/images/pictureOnMap/JCFX/XuanZhong.png") no-repeat center;
    }
  }
}
</style>