Newer
Older
urbanLifeline_YanAn / src / views / oneMap / index.vue
@zhangqy zhangqy on 6 Oct 13 KB 1
<template>
  <div id="oneMapIndex">
    <!-- 顶部 -->
    <div
      id="oneMapHeader"
      :class="[
        'oneMapHeader',
        'animate__animated',
        showPanel ? 'animate__fadeOutUp' : 'animate__fadeInDown',
      ]"
    >
      <!-- 标题 -->
      <img id="titleFont" src="@/assets/images/Sponge_screen/oneMapTitleFont.png" />
      <!-- 标题左侧展示组件 -->
      <div class="Timer"></div>
      <div class="Wather"></div>
      <!-- 标题右侧功能组件 -->
      <router-link to="/index">
        <div class="goHome header_icon"></div>
      </router-link>
      <div class="goUser_com header_icon" @click="toRYBox"></div>
      <div class="goClose_com header_icon"></div>
    </div>
    <!-- 内容 -->
    <div id="oneMapBody">
      <!-- 地图组件 -->
      <OneMap @map-click="mapClick" v-if="AllData.MapShowBol"></OneMap>
      <!-- 桥梁BIM -->
      <WangJiaPingBIM
        v-if="!AllData.MapShowBol && AllData.AC_MenuIndex == 4"
      ></WangJiaPingBIM>
      <!-- 降雨效果 -->
      <CanvasRain v-if="showRainFlow"></CanvasRain>
      <!-- 地图标注点弹窗popup -->
      <PopupInfo></PopupInfo>
      <!-- 前端专题组件 -->
      <!-- <transition name="fade" mode="out-in"> </transition> -->
      <!-- 图例 -->
      <img
        id="TuChengImg"
        src="@/assets/images/Sponge_screen/TuCheng.png"
        alt=""
        @click="ShowTuCheng = !ShowTuCheng"
      />
      <LayerControl :ShowTuCheng="ShowTuCheng"></LayerControl>
      <!-- 1:总体概览 -->
      <ComZTGL
        v-if="AllData.AC_MenuIndex == 1"
        :isActive="AllData.AC_MenuIndex == 1 ? true : false"
        :showPanel="showPanel"
      ></ComZTGL>
      <!-- 2:智慧燃气 -->
      <ComZHRQ
        v-if="AllData.AC_MenuIndex == 2"
        :isActive="AllData.AC_MenuIndex == 2 ? true : false"
        :showPanel="showPanel"
      ></ComZHRQ>
      <!-- 3:智慧排水 -->
      <ComZHPS
        v-if="AllData.AC_MenuIndex == 3"
        :isActive="AllData.AC_MenuIndex == 3 ? true : false"
        :showPanel="showPanel"
      ></ComZHPS>
      <!-- 4:智慧桥梁 -->
      <ComZHQL
        v-if="AllData.AC_MenuIndex == 4"
        :isActive="AllData.AC_MenuIndex == 4 ? true : false"
        :showPanel="showPanel"
      >
      </ComZHQL>
      <!-- 5:智慧隧道 -->
      <ComZHSD
        v-if="AllData.AC_MenuIndex == 5"
        :isActive="AllData.AC_MenuIndex == 5 ? true : false"
        :showPanel="showPanel"
      ></ComZHSD>
      <!-- 6:智慧海绵 -->
      <ComZHHM
        v-if="AllData.AC_MenuIndex == 6"
        :isActive="AllData.AC_MenuIndex == 6 ? true : false"
        :showPanel="showPanel"
      ></ComZHHM>
      <!-- 7:防洪排涝 -->
      <ComFHPL
        v-if="AllData.AC_MenuIndex == 7"
        :isActive="AllData.AC_MenuIndex == 7 ? true : false"
        :showPanel="showPanel"
      ></ComFHPL>
    </div>
    <!-- 底部菜单 -->
    <div id="BottomMenuBox">
      <Transition name="slide-fade">
        <div v-show="AllData.BottmBackGroundShow" class="BottmBackGround"></div>
      </Transition>
      <!-- 菜单List -->
      <div
        class="MenuList"
        :class="[
          'MenuList' + index,
          'animate__animated',
          showPanel ? 'animate__bounceInUp' : 'animate__bounceInUp',
        ]"
        v-for="(item, index) in AllData.MenuListData"
        @click="MenuClick(item, index)"
        v-if="BottomshowPanel"
      >
        <img class="MenuImg" v-if="AllData.AC_MenuIndex == item.id" :src="item.AC_icon" />
        <img class="MenuImg" v-else :src="item.iocn" />
        <p class="MenuFont" :class="AllData.AC_MenuIndex == item.id ? 'AC_Font' : ''">
          {{ item.name }}
        </p>
      </div>
    </div>

    <!-- 语音组件 -->
    <Voice></Voice>
  </div>
  <!-- 融云弹窗 -->
  <ModelRongYun
    :RYdialogShow="AllData.RYDialog"
    @OneDialogHide="dialogHide"
  ></ModelRongYun>
  <!-- 前端组件公共弹窗 -->
  <el-dialog
    modal-class="publicDialogVisible"
    v-model="dialogConfig.visible"
    :title="dialogConfig.title"
    width="1400px"
    :append-to-body="true"
    :destroy-on-close="true"
    :draggable="true"
  >
    <DialogTabs
      :dataID="dialogConfig.getSiteId"
      :SiteNo="dialogConfig.SiteNo"
      :comIDs="dialogConfig.comIDs"
      :customComponents="dialogConfig.customData"
      :RefName="dialogConfig.RefName"
    ></DialogTabs>
  </el-dialog>
</template>

<script setup name="oneMapIndex">
import bus from "@/bus";
import { fullscreenToggel } from "@/utils/util";
import { ref, reactive, toRefs, onMounted } from "vue";
// 菜单的图片资源
import ZTGL from "@/assets/images/Sponge_screen/menu/ZTGL.png";
import AC_ZTGL from "@/assets/images/Sponge_screen/menu/AC_ZTGL.png";
import ZHRQ from "@/assets/images/Sponge_screen/menu/ZHRQ.png";
import AC_ZHRQ from "@/assets/images/Sponge_screen/menu/AC_ZHRQ.png";
import ZHPS from "@/assets/images/Sponge_screen/menu/ZHPS.png";
import AC_ZHPS from "@/assets/images/Sponge_screen/menu/AC_ZHPS.png";
import ZHQL from "@/assets/images/Sponge_screen/menu/ZHQL.png";
import AC_ZHQL from "@/assets/images/Sponge_screen/menu/AC_ZHQL.png";
import ZHSD from "@/assets/images/Sponge_screen/menu/ZHSD.png";
import AC_ZHSD from "@/assets/images/Sponge_screen/menu/AC_ZHSD.png";
import FXPL from "@/assets/images/Sponge_screen/menu/FXPL.png";
import AC_FXPL from "@/assets/images/Sponge_screen/menu/AC_FXPL.png";
import ZHHM from "@/assets/images/Sponge_screen/menu/ZHHM.png";
import AC_ZHHM from "@/assets/images/Sponge_screen/menu/AC_ZHHM.png";
// 引用地图
import OneMap from "./map/newfiberMapBox.vue";
// 引用王家坪大桥BIm
import WangJiaPingBIM from "./BIM/WangJiaPIng.vue";
// 引用语音识别
import Voice from "./../voice/recordPage/index.vue";
// 引入融云通讯录
import ModelRongYun from "@/views/RongyunCommunication/ModelRongYun/index.vue"; //融云调用
// 子系统引入
import ComZTGL from "./components/ZTGL.vue"; //总体概览
import ComZHRQ from "./components/ZHRQ.vue"; //智慧燃气
import ComZHPS from "./components/ZHPS.vue"; //智慧排水
import ComZHQL from "./components/ZHQL.vue"; //智慧桥梁
import ComZHSD from "./components/ZHSD.vue"; //智慧隧道
import ComZHHM from "./components/ZHHM.vue"; //智慧海绵
import ComFHPL from "./components/FHPL.vue"; //防洪排涝
import PopupInfo from "@/views/oneMap/components/mapboxPopup.vue"; //地图标注点弹窗
// 降雨效果
import CanvasRain from "@/views/oneMap/cityGK/canvasRain.vue"; //降雨效果
// 图层控制面板
import LayerControl from "@/views/oneMap/LayerControl/LayerControl.vue"; //图层控制面板
// 前端共同弹窗
import DialogTabs from "@/views/DialogTabs/dialogTabs.vue";

const showPanel = ref(false);
const ShowTuCheng = ref(false); //图层面板显隐
const AllData = reactive({
  MapShowBol: true, //是否展示中心地图
  MenuListData: [
    {
      name: "总体概览",
      iocn: ZTGL,
      AC_icon: AC_ZTGL,
      id: 1,
    },
    {
      name: "智慧燃气",
      iocn: ZHRQ,
      AC_icon: AC_ZHRQ,
      id: 2,
    },
    {
      name: "智慧排水",
      iocn: ZHPS,
      AC_icon: AC_ZHPS,
      id: 3,
    },
    {
      name: "智慧海绵",
      iocn: ZHHM,
      AC_icon: AC_ZHHM,
      id: 6,
    },
    {
      name: "智慧桥梁",
      iocn: ZHQL,
      AC_icon: AC_ZHQL,
      id: 4,
    },
    {
      name: "智慧隧道",
      iocn: ZHSD,
      AC_icon: AC_ZHSD,
      id: 5,
    },
    {
      name: "防汛排涝",
      iocn: FXPL,
      AC_icon: AC_FXPL,
      id: 7,
    },
  ],
  AC_MenuIndex: 1,
  BottmBackGroundShow: false,
  RYDialog: false,
});
// 降雨效果
const showRainFlow = ref(false);
const BottomshowPanel = ref(true);
// 公共弹窗
const dialogConfig = reactive({
  visible: false,
  getSiteId: "",
  SiteNo: "",
  data: {},
  comIDs: ["spjk"],
  customData: [],
  RefName: "",
  title: "详情",
});
onMounted(() => {
  fullscreenToggel();
  AllData.BottmBackGroundShow = true;
  console.log(AllData.BottmBackGroundShow, "AllData.BottmBackGroundShow");
  bus.emit("BottomHidden", AllData.BottmBackGroundShow);
  // 降雨特征点击
  bus.on("checkRainL", (params) => {
    if (params == 1) {
      showRainFlow.value = false;
    } else {
      showRainFlow.value = true;
    }
  });
  // 底部隐藏
  bus.on("checkBottom", (params) => {
    if (params == 1) {
      BottomshowPanel.value = false;
    } else {
      BottomshowPanel.value = true;
    }
  });
  // 共同弹窗触发事件
  bus.on("publicDialog", (params) => {
    // 打开弹窗
    dialogConfig.visible = true;
    dialogConfig.title = params.title ?? "详情";
    dialogConfig.comIDs = params.comIDs ?? dialogConfig.comIDs;
  });
});
onBeforeUnmount(() => {
  bus.off("BottomHidden");
  bus.off("publicDialog");
});
// 菜单点击
const MenuClick = (item, index) => {
  // 改变菜单选中索引
  AllData.AC_MenuIndex = item.id;
  // 当选择的是智慧桥梁时 将隐藏地图展示BIM
  if (AllData.AC_MenuIndex == 4) {
    AllData.MapShowBol = false;
  } else {
    AllData.MapShowBol = true;
  }
};
// 打开融云通讯录
const toRYBox = () => {
  AllData.RYDialog = true;
  bus.emit("showRy");
};
// 关闭融云通讯录弹窗
const dialogHide = (val) => {
  if (!val) {
    AllData.RYDialog = false;
  }
};
//地图点击事件
const mapClick = async (point, properties, feature) => {
  console.log("point", point);
  console.log("properties", properties);
  console.log("feature---", feature);
  if (properties) {
    if (feature == "rq_pipeline_info") {
      if (!!newfiberMapbox.getLayerByName("rqLine")) {
        newfiberMapbox.removeLayer(newfiberMapbox.getLayerByName("rqLine"));
      }
      properties.pumpName = "燃气管线";
      let rqLine = turf.featureCollection([
        turf.feature(Terraformer.WKT.parse(properties.geometry)),
      ]);
      let layer = new mapboxL7.LineLayer({
        name: "rqLine",
      })
        .source(rqLine)
        .size(4)
        .shape("line")
        .texture("arrow")
        .color("rgb(241, 159, 27)")
        .animate({
          interval: 2, // 间隔
          duration: 2, // 持续时间,延时
          trailLength: 3, // 流线长度
        })
        .style({
          opacity: 1,
          lineTexture: true, // 开启线的贴图功能
          iconStep: 50, // 设置贴图纹理的间距
          borderWidth: 0, // 默认文 0,最大有效值为 0.5
          borderColor: "#fff", // 默认为 #ccc
        });
      newfiberMapbox.addLayer(layer);
    }
    bus.emit("popupcontent", {
      popupShow: true,
      point: point,
      popupInfo: properties,
    });
  }
};
</script>

<style lang="scss" scoped>
#oneMapIndex {
  width: 100%;
  height: 100%;
  background: black;
  position: relative;
  #oneMapHeader {
    width: 100%;
    height: 100px;
    background: url("@/assets/images/Sponge_screen/db_img.png") no-repeat center;
    background-size: cover;
    z-index: 100;
    position: absolute;
    top: 0;
    left: 0;
    #titleFont {
      width: 634px;
      height: 47px;
      position: absolute;
      left: 50%;
      margin-left: -317px;
      top: 20px;
    }

    .header_icon {
      width: 22px;
      height: 22px;
      position: absolute;
      top: 10px;
      cursor: pointer;
    }
    .goHome {
      background: url("@/assets/images/Sponge_screen/sy_btn.png") no-repeat center;
      right: 150px;
    }
    .goUser_com {
      background: url("@/assets/images/Sponge_screen/hs_btn.png") no-repeat center;
      right: 100px;
    }
    .goClose_com {
      background: url("@/assets/images/Sponge_screen/gb_btn.png") no-repeat center;
      right: 50px;
    }
  }
  #oneMapBody {
    width: 100%;
    height: 100vh;
    // background: rgba(255, 192, 203, 0.304);
    z-index: 99;
    position: relative;
    box-sizing: border-box;

    #TuChengImg {
      width: 36px;
      height: 36px;
      position: absolute;
      right: 470px;
      top: 100px;
      cursor: pointer;
    }
  }
  #BottomMenuBox {
    position: absolute;
    bottom: 0;
    width: 952px;
    height: 162px;
    left: 50%;
    margin-left: -476px;
    z-index: 999;

    .BottmBackGround {
      position: absolute;
      bottom: 0;
      width: 952px;
      height: 62px;
      background: url("@/assets/images/Sponge_screen/menu/DB_img.png") no-repeat center;
      background-size: cover;
    }
    // 图标菜单样式 从左到右按照顺序进行设定
    .MenuList {
      position: absolute;
      width: 100px;
      height: 110px;
      text-align: center;
      cursor: pointer;
      .MenuImg {
        width: 83px;
        height: 66px;
      }
      .MenuFont {
        margin: 0;
        padding: 0;
        display: inline-block;
        width: 100%;
        height: 44px;
        line-height: 44px;
        font-family: PangMenZhengDao;
        font-weight: 400;
        font-size: 20px;
        color: #ffffff;
        text-shadow: 0px 0px 20px #00303c;
      }
      .AC_Font {
        color: #ffd97f;
      }
    }
    .MenuList0 {
      left: 70px;
      top: 39px;
    }
    .MenuList1 {
      left: 190px;
      top: 26px;
    }
    .MenuList2 {
      left: 310px;
      top: 13px;
    }
    .MenuList3 {
      left: 430px;
      top: 0px;
    }
    .MenuList4 {
      left: 550px;
      top: 13px;
    }
    .MenuList5 {
      left: 670px;
      top: 26px;
    }
    .MenuList6 {
      left: 780px;
      top: 39px;
    }
  }
}

/*
  进入和离开动画可以使用不同
  持续时间和速度曲线。
*/
.slide-fade-enter-active {
  transition: all 0.3s ease-out;
}

.slide-fade-leave-active {
  transition: all 0.8s cubic-bezier(1, 0.5, 0.8, 1);
}

.slide-fade-enter-from,
.slide-fade-leave-to {
  transform: translateY(80px);
  opacity: 0;
}
</style>

<style lang="scss">
.publicDialogVisible {
  .el-dialog {
    background: rgba(14, 69, 89, 0.9);
    height: 800px;
    border: 1px solid #15d2fd;

    .el-dialog__title {
      font-family: PangMenZhengDao;
      font-weight: 400;
      font-size: 24px;
      color: #ebfeff;
    }
    .el-dialog__body {
      width: 100%;
      height: calc(100% - 60px);
    }
  }
}
</style>