Newer
Older
urbanLifeline_YanAn / src / views / oneMap / components / ZTGL.vue
@zhangqy zhangqy on 22 Oct 7 KB 风险评估图层优化
<template>
  <div id="ZTGL">
    <div
      :class="[
        'LeftBox',
        'animate__animated',
        showPanel ? 'animate__fadeOutLeft' : 'animate__fadeInLeft',
      ]"
    >
      <LeftBox />
    </div>
    <div
      :class="[
        'RightBox',
        'animate__animated',
        showPanel ? 'animate__fadeOutRight' : 'animate__fadeInRight',
      ]"
    >
      <RightBox />
    </div>
    <!-- <div class="PerspectiveControl" :class="[showPanel ? 'TuChengImgTrue' : 'TuChengImgFalse']"> -->

    <!-- <div
        class="zzsj flex flex-justcontent-spacebetween"
        v-for="(item, index) in angleviewList"
        :class="activedname == item.name ? 'activedright' : ''"
        @click="categoryclick(item, index)"
      >
        <div class="ImgB">
          <img :src="item.Limg" alt="" v-if="activedname == item.name" />
          <img :src="item.img" alt="" v-else />
        </div>
        <div class="angleview">{{ item.name }}</div>
      </div> -->
    <!-- </div> -->
  </div>
</template>

<script setup name="ZTGL">
import { ref, reactive, toRefs, onMounted, onBeforeUnmount } from "vue";
const AllData = reactive({});
import LeftBox from "@/views/oneMap/OverallOverview/LeftBox.vue";
import RightBox from "@/views/oneMap/OverallOverview/RightBox.vue";
import testProjection from "@/assets/testProjection.json";
import testProjectionLabel from "@/assets/testProjectionLabel.json";
import mapBoxVectorLayer from "@/utils/GISdocument/mapboxVectorLayer.js";
import xtb_img from "@/assets/newImgs/xtb_img.png";

import zhsja from "@/assets/images/zhps/zhsja.png"; //综合
import zhsjl from "@/assets/images/zhps/zhsjl.png"; //综合
import qll from "@/assets/images/zhps/qll.png"; //桥梁
import qln from "@/assets/images/zhps/qln.png"; //桥梁
import sdl from "@/assets/images/zhps/sdl.png"; //隧道
import sda from "@/assets/images/zhps/sda.png"; //隧道

import bus from "@/bus";
const showPanel = ref(true); //面板展开收起
// 面板内容展开收起控制
const props = defineProps({
  showPanel: {
    type: Boolean,
  },
});
// const angleviewList = ref([
//   {
//     name: '综合视角',
//     img: zhsja,
//     Limg: zhsjl,
//     lonlat: [109.478, 36.606],
//     zoom: 14,
//     bearing: 0,
//     pitch: 55,
//   },
//   {
//     name: '桥梁视角',
//     img: qln,
//     Limg: qll,
//     lonlat: [109.4716, 36.6064],
//     zoom: 18,
//     bearing: 300,
//     pitch: 45,
//   },
//   {
//     name: '隧道视角',
//     img: sda,
//     Limg: sdl,
//     lonlat: [109.4636, 36.6134],
//     zoom: 18,
//     bearing: 30,
//     pitch: 45,
//   },
// ]);
// const activedname = ref('综合视角');
// // 点击事件
// function categoryclick(val) {
//   console.log(val.name, '1');
//   activedname.value = val.name;
//   if (activedname.value == '综合视角') {
//     console.log('综合视角');
//     newfiberMapbox.map.easeTo({
//       center: val.lonlat,
//       zoom: val.zoom,
//       bearing: val.bearing,
//       pitch: val.pitch,
//     });
//   } else if (activedname.value == '桥梁视角') {
//     console.log('桥梁视角');
//     newfiberMapbox.map.easeTo({
//       center: val.lonlat,
//       zoom: val.zoom,
//       bearing: val.bearing,
//       pitch: val.pitch,
//     });
//   } else {
//     console.log('隧道视角');
//     newfiberMapbox.map.easeTo({
//       center: val.lonlat,
//       zoom: val.zoom,
//       bearing: val.bearing,
//       pitch: val.pitch,
//     });
//   }
// }
watch(
  () => props.showPanel,
  () => {
    showPanel.value = props.showPanel;
  },
  { immediate: true }
);
onMounted(() => {
  // activedname.value = '综合视角';
  let initeGLTimer = setInterval(() => {
    if (!newfiberMapbox) return;
    if (!newfiberMapbox.map.getLayer("buildingLayer")) return;
    newfiberMapbox.map.easeTo({
      center: [109.478, 36.606],
      zoom: 14,
    });
    const layer = new mapboxL7.LineLayer({
      name: "testProjection",
    })
      .source(testProjection)
      .size(30)
      .shape("wall")
      .style({
        opacity: 0.8,
        sourceColor: "#16f7ff",
        targetColor: "rbga(255,255,255, 0)",
      });
    newfiberMapbox.addLayer(layer);
    mapBoxVectorLayer.addGeojsonSymbol("testProjection", testProjectionLabel, xtb_img);
    // setTimeout(() => {
    //   newfiberMapbox.map.moveLayer("buildingLayer", "testProjection");
    // }, 1000);
    // setTimeout(() => {
    //   newfiberMapbox.map.easeTo({
    //     center: [109.488, 36.596],
    //     zoom: 15,
    //   });
    // }, 2000);
    clearInterval(initeGLTimer);
  }, 100);
});
onBeforeUnmount(() => {
  bus.emit("SetLayerShow", ["蓝色地图"]);
  mapBoxVectorLayer.removeByIds(["clickPoint"]);
  bus.emit("closeCesiumPopup");
  if (newfiberMapbox.getLayerByName("testProjection")) {
    newfiberMapbox.removeLayer(newfiberMapbox.getLayerByName("testProjection"));
    mapBoxVectorLayer.removeByIds(["testProjection"]);
  }
});
</script>

<style lang="scss" scoped>
#ZTGL {
  .LeftBox {
    width: 450px;
    height: calc(100% - 98px);
    position: absolute;
    left: 10px;
    top: 70px;
    // background: url('@/assets/images/LeftContent.png') no-repeat;
    background: linear-gradient(
      0deg,
      rgba(0, 43, 67, 0.8) 0%,
      rgba(0, 76, 118, 0.8) 100%
    );
    border-radius: 6px;
    border: 1px solid #47eef3;
    box-shadow: inset 0 0 5px 5px #47eef38a;
    z-index: 999;
  }
  .RightBox {
    width: 450px;
    height: calc(100% - 98px);
    position: absolute;
    right: 10px;
    top: 70px;
    // background: url('@/assets/images/rightContent.png') no-repeat;
    background: linear-gradient(
      0deg,
      rgba(0, 43, 67, 0.8) 0%,
      rgba(0, 76, 118, 0.8) 100%
    );
    border-radius: 6px;
    border: 1px solid #47eef3;
    box-shadow: inset 0 0 5px 5px #47eef38a;
    z-index: 999;
  }
  .PerspectiveControl {
    height: 120px;
    width: 105px;
    // background: red;
    position: absolute;
    bottom: 100px;
    left: 480px;
    .zzsj {
      width: 105px;
      height: 36px;
      background: linear-gradient(
        0deg,
        rgba(126, 158, 166, 0.2) 0%,
        rgba(126, 158, 166, 0.8) 100%
      );
      border-radius: 2px;
      text-align: center;
      align-items: center;
      margin-top: 5px;
      cursor: pointer;

      .ImgB {
        width: 20px;
        height: 20px;
        // background: url('@/assets/images/zhps/zhsja.png') no-repeat;
        background-size: 100% 100%;
        display: flex;
        align-items: center;
        margin-left: 8px;
      }

      .angleview {
        font-family: Source Han Sans CN;
        font-weight: bold;
        font-size: 15px;
        color: #c7d7db;
        margin-right: 10px;
      }
    }
    .activedright {
      background: linear-gradient(0deg, rgba(16, 173, 211, 0.4) 0%, #10add3 100%);
      border-radius: 2px;
      font-family: Source Han Sans CN;
      font-weight: bold;
      font-size: 14px;
      color: #16f7ff;
    }
  }
  .TuChengImgTrue {
    transform: translateX(-460px);
    transition: all 1s ease;
  }
  .TuChengImgFalse {
    transform: translateX(0px);
    transition: all 1s ease;
  }
}
</style>