Newer
Older
DH_Apicture / src / components / Map / MapBox.vue
@wudi wudi on 16 Dec 37 KB 1
<template>
  <MapBox
          :initJson="props.initJson"
          :loadCallback="getModalData"
          @map-click="mapClickEvt"
          v-show="MapShow"
  >
  </MapBox>

  <PopupInfo>
    {{item?.aaa}}
  </PopupInfo>
  <!-- <div id="trajectory-popup" ref="trajectory">1111</div> -->
  <!-- <div style="width: 700px; height: 350px" ref="streetSpace1" id="streetSpace1">
    <streetSpace :location="datas.location"></streetSpace>
  </div> -->
</template>

<script setup name="Map">
  import bus from "@/bus";
  import request from "@/utils/request";
  import MapBox from "@/components/Map/Map";
  import { getBaseListPoint } from "@/api/MonitorAssetsOnMap";
  import { supervisionRealinformationList } from "@/api/internetVehicles";
  import useUserStore from "@/store/modules/user";
  import { reactive, onMounted, onBeforeUnmount, nextTick, defineProps, watch } from "vue";
  import streetSpace from "@/components/Map/streetSpace";
  import gq_line from "../../../public/static/libs/mapbox/json/gq_line.json";
  import ys_flow1 from "../../../public/static/libs/mapbox/json/ys_flow_2.json";
  import line from "../../../public/static/libs/mapbox/json/line.json";
  import point from "../../../public/static/libs/mapbox/json/point.json";

  import outlet_route from "../../../public/static/libs/mapbox/json/outlet_route.json";
  import outlet_site from "../../../public/static/libs/mapbox/json/outlet_site.json";

  import ws_routeGeoJSON from "../../../public/static/libs/mapbox/json/ws_flow.json";
  // import ws_pointGeoJSON from "../../../public/static/libs/mapbox/json/ws_point.json";

  import PopupInfo from "@/components/Map/popup.vue";
  import { MapboxOverlay } from "@deck.gl/mapbox";
  import { LineLayer, GeoJsonLayer } from "@deck.gl/layers";
  import { TripsLayer, Tile3DLayer } from "@deck.gl/geo-layers";
  import { Tiles3DLoader } from "@loaders.gl/3d-tiles";
  const appStore = useUserStore();
  const MapShow = ref(true);
  const props = defineProps({
    // 数据id
    initJson: {
      type: String,
      default: () => "/static/libs/mapbox/style/wh_dhgx.json",
    },
    loadCallback: {
      type: Function,
      default: () => function () {},
    },
  });
  const datas = reactive({
    location: [],
    isOpenPanorama: false,
  });
  const { proxy } = getCurrentInstance();
  const refreshTimer = ref(null);
  const default_params = {
    point: {
      key: "point",
      prevId: null,
      children:{
        outlet_info2:{
          key:"outlet_info2"
        }
      }
    },
    sx_wn_hm_monitoring: {
      key: "sx_wn_hm_monitoring",
      prevId: null,
    },
    town: {
      key: "乡镇",
      c_key: "村",
      prevId: null,
    },
    hupo: {
      key: "湖泊",
      prevId: null,
    },
    gangqu: {
      key: "港渠",
      prevId: null,
    },
    psfq: {
      key: "排水分区",
      text_key:"排水分区_text",
      prevIds: [],
      children: {
        WS: { key: "污水分区" },
        YS: { key: "雨水分区" },
      },
    },
    hb_wh_dhgx_merge: {
      key: "hb_wh_dhgx_merge",
      children: {
        psfq: { key: "排水分区" },
      },
      prevId: null,
    },
    海绵型水系: { color: "rgba(35,184,153,1)" },
    海绵建筑与社区: { color: "rgba(255,119,125,1)" },
    海绵型道路广场: { color: "rgba(255,152,4,1)" },
    管网及泵站: { color: "rgba(0,153,68,1)" },
    海绵型公园绿地: { color: "rgba(223,214,20,1)" },
    flow: { color: "rgba(255,255,255,1)" },
    rain: { color: "rgba(255,255,255,1)" },

    water_level: { color: "rgba(255,255,255,1)" },
    waterlogging: { color: "rgba(255,255,255,1)" },

    rain_bz: { color: "rgba(255,255,255,1)" },
    sxt: { color: "rgba(255,255,255,1)" },
    WSCLC: { color: "rgba(255,255,255,1)" },
    overflow_outfall: { color: "rgba(255,255,255,1)" },

    rainfall: { color: "rgba(223,214,20,1)" },
    pipeline: { color: "rgba(223,214,20,1)" },
    drain_outlet: { color: "rgba(223,214,20,1)" },
  };
  window.mapInitBusName = "mapInitBusName";
  const mapClickEvt = (lngLat, properties, layerId) => {
    datas.isOpenPanorama &&
    (() => {
      setPopupDom("proxy.$refs.streetSpace1", 2);
      newfiberMap.popup1.setLngLat(lngLat).addTo(newfiberMap.map);
      datas.location = lngLat;
    })();

    const _keys = ["rain_water_pump_station_info1", "sewage_pump_station_info1",'rainwater_pipeline_quality_area1','clickPoint','temporary','sewage_pipeline_quality1'];

    console.log("properties", properties, layerId);
    // 图层点击事件
    if (properties) {
      if(properties.type == _keys[4])properties.type = properties.pointType
      bus.emit("FenQuClick", {properties,layerId:layerId.split('_')[0]});
    }
    clearTrajectory();
    // clearTemporaryData();
    proxy.$emit("map-click1", lngLat, properties, layerId);
    const { town, hupo, gangqu, hb_wh_dhgx_merge,psfq,point } = default_params;
    const { setLayerVisible, setHighlight, setGeoJSON, removeMapDatas } = events_params;


    (() => {
      setHighlight_(properties);
      // ysFlow();
      newfiberMap.getLayers().filter((i) => i.newfiberId == "村域边界")[0].setData(turf.featureCollection([]));
      busEmit(removeMapDatas.key, _keys.filter(i => i != (properties || {}).type));

      if (town.prevId) {
        busEmit(setLayerVisible.key, { layername: town.key, isCheck: true });
        busEmit(setLayerVisible.key, { layername: town.prevId, isCheck: false });
        town.prevId = null;
      }

      // clearRouteMethod();
/*      if (psfq.prevIds.length &&  !([psfq.key,point.key].includes(layerId))) {
        districtMask();
        const isOne = psfq.prevIds.length == 1?1:2
        let properties = psfq.prevIds[psfq.prevIds.length -1];
        areaToMap(properties);
        psfq.prevIds =_.dropRight(psfq.prevIds);
        clearRouteMethod();
        ys_flow(properties,false);
        showOutletInfo(properties);
      }*/
    })();
    ((
            {
              [point.key]: () => {
                const {outlet_info2} = point.children;
                (({
                  [outlet_info2.key]:(properties)=>    { clearRouteMethod();outletRouteMethod(properties)}
                })[properties.type] || function(){})(properties);
              },
              [psfq.key]: () => {
                ['污水系统流向1','雨水系统流向','雨水系统流向1','污水系统流向1','污水系统流向'].forEach(k => busEmit(setLayerVisible.key, {layername:k, isCheck: false}));
                properties.type == 'YS' && ["outlet_info2",'排口流向','排口流向1','rainwater_pipeline_quality1',_keys[2]].forEach(k => busEmit(setLayerVisible.key, {layername:k, isCheck: true}));
                areaToMap(properties);
              },
              [psfq.text_key]: () => {
                ['污水系统流向1','雨水系统流向','雨水系统流向1','污水系统流向1','污水系统流向'].forEach(k => busEmit(setLayerVisible.key, {layername:k, isCheck: false}));
                properties.type == 'YS' && ["outlet_info2",'排口流向','排口流向1','rainwater_pipeline_quality1',_keys[2]].forEach(k => busEmit(setLayerVisible.key, {layername:k, isCheck: true}));
                areaToMap({...properties,geometry:Terraformer.WKT.convert(JSON.parse(properties.geometrys))});
              },
              [town.key]: () => {
                newfiberMap.getLayers().filter((i) => i.newfiberId == "村域边界")[0].setData(turf.featureCollection(newfiberMap.map.getSource("hb_wh_gxq_cun2")._data.features.filter((i) => i.properties.type == properties.name)));
                busEmit(setLayerVisible.key, { layername: town.key, isCheck: false });
                busEmit(setLayerVisible.key, { layername: properties.name, isCheck: true });
                town.prevId = properties.name;
              },
              [hupo.key]: () => {
                if (hupo.prevId) {
                  busEmit(setLayerVisible.key, {
                    layername: hupo.prevId,
                    isCheck: false,
                    values: [hupo.prevId, ["严东湖", "严西湖"].join(",")],
                  });
                  hupo.prevId = null;
                  bus.emit("removeMapDatas", ["outlet_info1"]);
                }
                const keys = ["outlet_info", "村域边界", "lake"];
                const specialKeys = ["严东湖", "严西湖"];
                newfiberMap
                        .getLayers()
                        .filter((i) => i.newfiberId == keys[1])[0]
                        .setData(
                                turf.featureCollection(
                                        gq_line.features.filter((i) => i.properties.w_id == properties.name)
                                )
                        );
                let features = newfiberMap.map
                        .getSource("point")
                        ._data.features.filter(
                                (i) =>
                                        i.properties.type == keys[0] &&
                                        i.properties.waterBodyType == keys[2] &&
                                        i.properties.waterBodyId == properties.pid
                        )
                        .map((i) => _.cloneDeep(i));
                features.forEach((i) => (i.properties.type = i.properties.type + "1"));
                busEmit(events_params.setGeoJSON.key, {
                  json: turf.featureCollection(features),
                  key: keys[0] + 1,
                });
                const values = [
                  specialKeys.includes(properties.name) ? specialKeys.join(",") : properties.name,
                ];
                busEmit(setLayerVisible.key, {
                  layername: properties.name,
                  isCheck: true,
                  values,
                });
                hupo.prevId = properties.name;
              },
              [gangqu.key]: () => {
                if (gangqu.prevId) {
                  gangqu.prevId = null;
                  bus.emit("removeMapDatas", ["outlet_info1"]);
                }
                const keys = ["outlet_info", "村域边界", "channel"];
                newfiberMap
                        .getLayers()
                        .filter((i) => i.newfiberId == keys[1])[0]
                        .setData(
                                turf.featureCollection(
                                        gq_line.features.filter((i) => i.properties.name == properties.name)
                                )
                        );
                let features = newfiberMap.map
                        .getSource("point")
                        ._data.features.filter(
                                (i) =>
                                        i.properties.type == keys[0] &&
                                        i.properties.waterBodyType == keys[2] &&
                                        i.properties.waterBodyId == properties.pid
                        )
                        .map((i) => _.cloneDeep(i));
                features.forEach((i) => (i.properties.type = i.properties.type + "1"));
                busEmit(events_params.setGeoJSON.key, {
                  json: turf.featureCollection(features),
                  key: keys[0] + 1,
                });
                gangqu.prevId = properties.name;
              },
              [hb_wh_dhgx_merge.key]: () => {
                if (properties.layer == hb_wh_dhgx_merge.children.psfq.key) {
                  const layerSplit = properties.c_layer.split("_");
                  let geometry = Terraformer.WKT.parse(properties.geometry);

                  busEmit(setHighlight.key, []);
                  const type = _.chunk(layerSplit[1], 2)[0].join("");
                  let pType = type == "雨水" ? "YS" : "WS";
                  pType == "YS" ? ys_flow(properties, true) : ws_flow(properties);
                  districtMask(properties);
                  if (layerSplit[2] != 3) return mapCenterByData(turf.bbox(geometry));
                  /*         let features = newfiberMap.map.getSource("hb_wh_dhgx_pipe_line_n_y_w")._data.features.filter((i) => i.properties[type + "系统"] == properties.name && i.properties["管段类型"] == pType);
                           let pFeatures = newfiberMap.map.getSource("point")._data.features.filter((i) => _keys.includes(i.properties.type) && (i.properties.pointTypeName || "").includes(type));
                           let p_features = turf.pointsWithinPolygon(turf.featureCollection(pFeatures), geometry);
                           p_features.features.forEach((i) => (i.properties.type = i.properties.type + 1));
                           busEmit(setGeoJSON.key, { json: p_features });
                           console.log("features", p_features, pFeatures);
                           busEmit(setHighlight.key, turf.flatten(turf.featureCollection(features)).features);*/
                }
              },
            }[layerId] ||
            function () {
              //newfiberMap.map.easeTo(newfiberMap.config_.params.init);
            }
    )());

    function areaToMap(properties) {
      let isYS = properties.type == 'YS';
      clearRouteMethod();
      districtMask(properties);
      ({
        "1":()=>{
          !layerId && newfiberMap.map.easeTo(newfiberMap.config_.params.init);
          !isYS && wsRouteToMapByName(properties);
        },
        "2":()=>{
          [
            () => wsRouteToMapByName(properties),
            () => showOutletInfo(properties)
          ][Number(isYS)]();
        },
        "3":()=>{
          [
            ()=> {
              wsRouteToMapByName(properties);

            },
            () => {
              ys_flow({...properties, c_layer: `排水分区_${properties.type}_${properties.level}`}, true);
              let p_feature = turf.flatten(turf.feature(Terraformer.WKT.parse(properties.geometry))).features[0];
              let features = newfiberMap.map.getSource("point")._data.features.filter(i => _keys[2].includes(i.properties.type)).filter(o => turf.booleanPointInPolygon(o, p_feature));
              features = features.map(i => Object.assign(_.cloneDeep(i), {properties: {...i.properties, type: i.properties.type + 1}}));
              busEmit(setGeoJSON.key, {json: turf.featureCollection(features), key: _keys[2]});
            }][Number(isYS)]();
        },
        "4":()=>{}
      })[properties.level]();

      let [closeLayer, openLayer] = layerId ? [properties.type + properties.p_name, properties.type + properties.name] : [properties.type + properties.name, properties.p_type];
      busEmit(setLayerVisible.key, {layername: psfq.children[properties.type].key, isCheck: false, values: Array.from(new Set(newfiberMap.map.getSource("hb_wh_dhgx_psfq_geometrys")._data.features.map(i => i.properties.p_type)))});
      busEmit(setLayerVisible.key, {layername: psfq.children[properties.type].key, isCheck: true, values: [openLayer]});
      if(layerId && psfq.prevIds.filter(i => i.id == properties.id).length == 0) psfq.prevIds.push(properties);
    }

    function wsRouteToMapByName(properties) {
      const _keys_ = ['污水系统流向1','污水系统流向',"1_泵站","1_污水处理厂"];
      _keys_.forEach(k => busEmit(setLayerVisible.key, {layername:k, isCheck: true}));
      busEmit(removeMapDatas.key, _keys_);
      let features = _.cloneDeep(ws_routeGeoJSON.features.filter(i => i.properties.bind.split(',').includes(properties.name)));
      let geojson = turf.featureCollection(features.map(i => Object.assign(i,{properties:{name:i.properties.name,type:i.properties._type || '污水系统流向1',color:'rgb(255,74,25)',width:[0,7,5,3][properties.level]}})));
      newfiberMap.getLayers().filter(i => i.newfiberId == _keys_[1])[0].setData(geojson);
      busEmit(setGeoJSON.key, {json: geojson, key: _keys_[0]});

      if(['2','3'].includes(properties.level)){
        let kk = _.replace(_keys[5], /\d+/g, '');
        let polygon = turf.flatten(Terraformer.WKT.parse(properties.geometry)).features[0];
        let features_point = _.cloneDeep(newfiberMap.map.getSource("point")._data.features.filter(i => i.properties.type.includes(kk)).filter(o => turf.booleanPointInPolygon(o, polygon)));
        let features_point1 = _.cloneDeep(newfiberMap.map.getSource("point")._data.features.filter(i => _keys[1].includes(i.properties.type)).filter(o => turf.booleanPointInPolygon(o, polygon)));
        let geojson1 = turf.featureCollection(
                [
                ...features_point.map(i => ({...i,properties: {...i.properties, type: _keys[5]}})),
                ...features_point1.map(i => ({...i,properties: {...i.properties, type: _keys[1]}}))
        ].flat().filter(Boolean));
        busEmit(setGeoJSON.key, {json: geojson1, key: _keys[5]});
      }
    }

    function showOutletInfo(properties) {
      const key = 'outlet_info';
      busEmit(setLayerVisible.key, {layername: key+properties.w_id,isCheck: Boolean(layerId)});
    }

    function outletRouteMethod(properties) {
      const _keys = ['排口流向', '排口流向1', 'rainwater_pipeline_quality1'];
      _keys.forEach(k => busEmit(setLayerVisible.key, {layername: k,isCheck: true}));
      let sites = turf.featureCollection(outlet_site.features.filter(i => (i.properties.outlet_id || '').split(',').includes(properties.id) && i.properties.connectType != 'area'));
      let routes = turf.featureCollection(outlet_route.features.filter(i => (i.properties.outlet_id || '').split(',').includes(properties.id)));
      newfiberMap.getLayers().filter(i => i.newfiberId == _keys[1])[0].setData(routes);
      busEmit(setGeoJSON.key, {json: routes, key: _keys[0]});
      busEmit(setGeoJSON.key, {json: sites, key: _keys[2]});
    }

    function districtMask(properties = {}) {
      let mb = turf.polygon([ [[-180, -90], [180, -90], [180, 90], [-180, 90], [-180, -90]]]);
      let feature = []
      if(properties.geometry) {
        let area = turf.feature(Terraformer.WKT.parse(properties.geometry));
        feature = [turf.difference(mb,area)];
        mapCenterByData(turf.bbox(area));
      }
      newfiberMap.getLayers().filter(i => i.newfiberId == '蒙版')[0].setData(turf.featureCollection(feature));
    }

    function ys_flow(properties, visible) {
      const keys = ["雨水系统流向", "雨水系统流向1"];
      if(!visible) return keys.forEach((key) => busEmit(setLayerVisible.key, { layername: key, isCheck: visible }));
      const layerSplit = properties.c_layer.split("_");
      const level = layerSplit[2];
      let features = ys_flow1.features.filter(i => (i.properties.level_ == level && (level == '1' || i.properties['area_'+level] == properties.name)));
      const p = properties.name.substr(0,2);
      let feature = level == '3'?  ys_flow1.features.filter(i => (i.properties.bind || '').includes(properties.name)): ys_flow1.features.filter(i => i.properties.level_ < level && i.properties.area_2.includes(p))
      ysFlow(turf.featureCollection(features.concat(feature)));
      keys.forEach((key) => busEmit(setLayerVisible.key, { layername: key, isCheck: visible }));
      setHighlight_(properties);
    }

    function ws_flow(properties) {
      const keys_ = ["雨水", "污水"];
      const keys = ["1_泵站", "1_污水处理厂", "分区流向", "分区流向1"];
      bus.emit("removeMapDatas", keys);
      newfiberMap
              .getLayers()
              .filter((i) => i.newfiberId == keys[3])[0]
              .getSource()
              .setData(turf.featureCollection([]));
      let key = (properties.c_layer || "").includes(keys_[0]) ? keys_[0] : keys_[1];
      if (properties.pointTypeName) key = keys_[1];
      const nameKey = "龙王咀" || properties.name.substring(0, 2);
      let features = line.features.filter((i) => i.properties.area.includes(key));
      // let features1 = point.features.filter(i => i.properties.type.includes(key) );
      let points = _.groupBy(point.features, (a) => a.properties.type);
      features.forEach((i) => {
        i.properties.type = keys[2];
        i.properties.color = key == keys_[0] ? "rgba(21,127,176,1)" : "rgba(255,0,0,1)";
      });
      /*    Object.keys(points).map((key) =>
            bus.emit("setGeoJSON", {
              json: turf.featureCollection(
                points[key].map((i) => ({
                  type: i.type,
                  geometry: i.geometry,
                  properties: { ...i.properties, type: "1_" + key },
                }))
              ),
              key: "1_" + key,
            })
          );*/
      // bus.emit("setGeoJSON", { json: turf.featureCollection(features), key: keys[2] });
      /*  newfiberMap
          .getLayers()
          .filter((i) => i.newfiberId == keys[3])[0]
          .getSource()
          .setData(turf.featureCollection(features));*/
      setHighlight_(properties);
    }
  };

  function clearRouteMethod() {
    const { removeMapDatas } = events_params;
    const _keys = ['污水系统流向1','污水系统流向',"1_泵站","1_污水处理厂",'排口流向', '排口流向1', 'rainwater_pipeline_quality1',"sewage_pump_station_info1"];
    busEmit(removeMapDatas.key, [_keys[2],_keys[0],_keys[4],_keys[6]]);
    newfiberMap.getLayers().filter(i => [_keys[1],_keys[5]].includes(i.newfiberId)).forEach(i => i.setData(turf.featureCollection([])));
  }

  function setHighlight_(properties = {}) {
    const temporary = "temporary";
    bus.emit("removeMapDatas", [temporary]);
    if (!properties.geometry || properties.geometry.includes('POINT')) return;
    let geojson = turf.polygonToLine(Terraformer.WKT.parse(properties.geometry));
    geojson = geojson.features ? geojson : turf.featureCollection([geojson]);
    geojson.features.forEach((i) => (i.properties = { color: "rgba(255,255,0,1)", type: temporary }));
    bus.emit("setGeoJSON", { json: geojson, key: temporary });
 /*   newfiberMap
            .getLayers()
            .filter((i) => i.newfiberId == "村域边界")[0]
            .setData(geojson);*/
  }

  const getModalData = () => {
    isClockInRange();
    Object.keys(events_params)
            .filter((key) => events_params[key].method)
            .forEach((key) => busOn(events_params[key].key, events_params[key].method));
    // 获取地图项目数据
    dataToMap({});
    createPopup();
    busEmit(events_params.closeAllLayer.key);
    proxy.$emit("loadCallback");
    ww();
    ysFlow();

    newfiberMap.contextMenu = new mapboxgl1.ContextMenu({items: [
        {
          text: '街景',
          callback: async (point1,feature,layerId) => {
            console.log('周边街景经纬度1', point1);
            let point = _.cloneDeep(point1);
            let clickPoint = turf.point(Object.values(point));
            let positionAddress = '';
            gcoord.transform(clickPoint, gcoord.WGS84, gcoord.BD09);
            let data = await request(`/bdApi//baiduservice/panorama?fov=180&height=256&width=512&location=${turf.getCoords(clickPoint).join(',')}`);
            data.data.base64 = data && data.data && 'data:image/jpeg;base64,' + data.data.base64;
            gcoord.transform(clickPoint, gcoord.BD09, gcoord.GCJ02);
            const regeodata = await geoRegeo({ lngLat: turf.getCoords(clickPoint) });
            positionAddress = regeodata.info === 'OK' && regeodata.regeocode.formatted_address;
            gcoord.transform(clickPoint, gcoord.GCJ02, gcoord.WGS84);
            busEmit(events_params.setGeoJSON.key, {json: turf.featureCollection([clickPoint]), key: 'clickPoint',});
            data.stName = positionAddress;
            bus.emit('popupcontent', {
              popupShow: true,
              point: turf.getCoords(clickPoint),
              popupInfo: data,
            });
            console.log('周边街景经纬度2', turf.getCoords(clickPoint));
          }
        }
      ]})
    newfiberMap.contextMenu.addTo(newfiberMap.map);
  };

  const ysFlow = (geojson) => {
    const key = "雨水系统流向";
    const widths = ['',10,5,1];
    if(!geojson) {
      ys_flow1.features = ys_flow1.features.map(i => ({ ...i, properties: { ...i.properties, color:"rgba(10,170,249,1)" ,width: widths[i.properties.level_], name: undefined } }));
      geojson = turf.featureCollection(ys_flow1.features.filter(i => i.properties.level_ == 1));
    }
    bus.emit("removeMapDatas", [key+"1"]);
    newfiberMap.getLayers().filter((i) => i.newfiberId == key)[0].setData(geojson);
    busEmit(events_params.setGeoJSON.key, { json: geojson, key: key + 1 });
  };

  const ww = () => {
    const keys = ["尾水路径"];
    let features = newfiberMap.map
            .getSource("hb_wh_dhgx_merge")
            ._data.features.filter(
                    (i) => i.properties.c_layer.includes(keys[0]) && i.properties.geometry_type == 2
            );
    busEmit(events_params.setGeoJSON.key, {
      json: turf.featureCollection(features),
      key: keys[0],
    });
  };

  let prevObj = null;
  const panelDataToMap = (obj) => {
    let isUp=Object.keys(obj).includes('isUp')?obj.isUp:true;  //是否触发地图点击事件  默认触发
    // debugger
    const { setLayerVisible, setHighlight } = events_params;
    // if (prevObj != null) busEmit(setLayerVisible.key, { layername: prevObj.type, isCheck: false });
    busEmit(setHighlight.key, []);
    // busEmit(setLayerVisible.key, { layername: obj.type, isCheck: true });
    // debugger;
    let features = ["point", "linestring", "polygon","hb_wh_dhgx_psfq_geometrys", "hb_wh_dhgx_merge"].map((key) => newfiberMap.map.getSource(key)._options.data.features.filter((i) => (i.properties.name || "").includes(obj.name) || (obj.id ? obj.id == i.properties.pid : true))).flat();
    let feature = features.filter((i) => i.properties.p_type)[0] || features.filter((i) => i.properties.name == obj.name)[0] || features[_.random(0, features.length - 1)];
    console.log('feature.properties.p_type&&isUp',feature.properties.p_type&&isUp);
    if(feature.properties.p_type && isUp) return mapClickEvt(undefined,feature.properties,"排水分区");
    if (!feature) return;
    busEmit(setHighlight.key, [feature]);
    mapCenterByData(turf.bbox(feature));
  };

  const mapCenterByData = (bbox) => {
    newfiberMap.map.fitBounds(
            [
              [bbox[0], bbox[1]],
              [bbox[2], bbox[3]],
            ],
            { padding: 50, offset: [100, 10], maxZoom: 18, pitch: 0, duration: 500 }
    );
  };
  const trajectoryToMap = (data) => {
    clearTrajectory();
    const fields = { lng: "l", lat: "a" };
    mapCenterByData([data[0]["l"], data[0]["a"], data[1]["l"], data[1]["a"]].map(Number));
    newfiberMap.map.trackLayer = new mapboxgl1.TrackLayer(
            newfiberMap.map,
            data,
            fields,
            (properties, index) => {
              const lng = properties[fields.lng];
              const lat = properties[fields.lat];
              if (!(index % 50)) {
                newfiberMap.map.flyTo({
                  center: [lng, lat],
                  bearing: newfiberMap.map.getBearing(),
                  pitch: newfiberMap.map.getPitch(),
                  zoom: newfiberMap.map.getZoom(),
                });
              }
              /*        setPopupDom('proxy.$refs.trajectory', 1);
                                    newfiberMap.popup.setLngLat([lng,lat]).addTo(newfiberMap.map);*/
            }
    );
  };

  const clearTrajectory = () => {
    if (newfiberMap.map.trackLayer) newfiberMap.map.trackLayer.destory();
    if (newfiberMap.popup) newfiberMap.popup.remove();
  };

  const dataToMap = async ({ params, callback }) => {
    const { setLayerVisible, beansToMap } = events_params;
    const data_default_params = {
      sites: {
        method: getBaseListPoint,
        fields: { geometry: "geometry", name: "name" },
        groupMethod: (data) => _.groupBy(data.map((i) => i.data).flat().filter((i) => i.geometry).map((item) => ({ ...item })), (v) => v.pointType + (v.connectType ? "_" + v.connectType : "")),
        others:{
          outlet_info:{
            method:(data)=> data.map(i => ({...i,type:i.pointType+i.waterBodyId}))
          }
        }
      },
      //车辆
      cheliang: {
        method: supervisionRealinformationList,
        fields: { lng: "longitude", lat: "latitude", name: "plateNumber" },
        groupMethod: (data) =>
                _.groupBy(
                        data.supervisionRealinformationList
                                .filter((i) => i.longitude && i.latitude)
                                .map((item) => ({ ...item, type: item.vehicleCategory + item.status })),
                        (v) => v.type
                ),
      },
    };
    const other_data_params = {

    }
    let keys = Object.keys(params || data_default_params);
    const results = await Promise.all(keys.map((k, idx) => data_default_params[k].method((params || {})[k] || data_default_params[k].mPrams)));
    results.forEach((result, idx) => {
      const data = result.data;
      const k = keys[idx];
      if (!data) return;
      if(k == keys[0]) appStore.SET_MapData(filterGeometryNotEmpty(data));
      bus.emit("changeData");
      const groups = data_default_params[k].groupMethod(data);
      const g_keys = Object.keys(groups);
      bus.emit("removeMapDatas", g_keys);
      if(k == keys[0]) {
        appStore.SET_MapData(filterGeometryNotEmpty(data));
        appStore.SET_MapData_COUNT(_.assign({},...g_keys.map(a => ({[a]:groups[a].length}))));
      }
      g_keys.forEach((key) =>{
        busEmit(beansToMap.key, {beans: groups[key].map((i) => ({...i, color: (default_params[key] || {}).color,})), fields: data_default_params[k].fields, type: key});
        const other = (data_default_params[k].others || {})[key];
        other && busEmit(beansToMap.key, {beans: other.method(groups[key]), fields: data_default_params[k].fields, type: key});
      });
    });

    callback && callback();
  };

  const createPopup = () => {
    newfiberMap.popup = new mapboxgl1.Popup({
      closeButton: false,
      closeOnClick: false,
    });
    newfiberMap.popup1 = new mapboxgl1.Popup({
      closeButton: false,
      closeOnClick: false,
    });
  };

  const setPopupDom = (dom, offset) => {
    f();
    nextTick(f);
    function f() {
      console.log("eval(dom)", eval(dom));
      newfiberMap.popup1.setDOMContent(eval(dom));
      newfiberMap.popup1.setOffset(offset);
    }
  };

  function filterGeometryNotEmpty(inputData) {
    return inputData.map((item) => {
      // 过滤掉每个对象中的 data 数组里 geometry 为空的元素
      const filteredData = item.data.filter((dataPoint) => dataPoint.geometry !== "");
      return {
        ...item,
        data: filteredData,
      };
    });
  }

  //路径规划
  const pathPlanning = async (origin = "116.481028,39.989643", destination = "116.465302,40.004717", callback) => {
    const origin_ = origin.split(",").map(Number);
    const destination_ = destination.split(",").map(Number);
    if (origin_.length != 2 || destination_.length != 2) return console.log("输入参数错误:", origin, destination);
    const results = await request(`/amap/v3/direction/driving?origin=${origin}&destination=${destination}&extensions=all&output=json&key=f627fbb24176be73142eb0b5088d8683`);
    if (!results.route.paths[0]) return console.log("暂无路径!");
    callback && callback(turf.featureCollection(results.route.paths[0].steps.map((i) => turf.feature(Terraformer.WKT.parse(`LINESTRING(${i.polyline.split(";").map((i) => i.split(",").join(" ")).join(",")})`), i))));
  };

  //地理/逆地理编码
  const geoRegeo = async ({name,lngLat,callback}) => {
    let flag,params = null;
    if (name) flag = "geo", params = `address=${name}`;
    if (lngLat) flag = "regeo", params = `location=${lngLat.join(',')}`;
    if(!(flag || params)) console.log('name,lngLat is null!');
    const results = await request(`/amap/v3/geocode/${flag}?${params}&extensions=all&output=json&key=f627fbb24176be73142eb0b5088d8683&city=420111`);
    console.log('geoRegeo results',results);
    callback && callback(results);
    return results;
  };

  //判断是否在打卡点内
  const isClockInRange = (
          currentLocation = "POINT(109.41360117253636 34.49038724464877)",
          ranges = [
            "POINT(109.43167853335872 34.51345940211415)",
            "POINT(109.46797592891363 34.51145239795833)",
            "POINT(109.44903576574815 34.50165755773118)",
          ],
          rVal = 500
  ) => {
    const feature = { ...Terraformer.WKT.parse(currentLocation) };
    return (
            ranges
                    .map((i) => turf.buffer({ ...Terraformer.WKT.parse(i) }, rVal / 1000))
                    .map((i) => turf.booleanContains(i, feature))
                    .filter(Boolean)[0] || false
    );
  };

  const clearTemporaryData = () => {
    const { setLayerVisible, removeMapDatas } = events_params;
    const keys_ = [
      "问题管线",
      "1_泵站",
      "1_污水处理厂",
      "1_调蓄池",
      "分区流向",
      "分区流向1",
      "rainwater_pipeline_water_level",
      "rainwater_pipeline_water_level_GWGSWYX",
      "outlet_info1",
      "temporary",
      "highlight_linestring",
      "highlight_polygon",
      "highlight_point",'clickPoint','sewage_pipeline_quality1','rainwater_pipeline_quality_area1',"sewage_pump_station_info1"
    ];
    clearRouteMethod();
    const hideKeys = ["污水系统流向","雨水系统流向", "雨水系统流向1","排水分区_close"];
    bus.emit(removeMapDatas.key, keys_);
    const keys = newfiberMap.config_.l7.filter((i) => i.temporary).map((i) => i.key);
    newfiberMap
            .getLayers()
            .filter((i) => keys.includes(i.newfiberId))
            .forEach((i) => i.setData({ type: "FeatureCollection", features: [] }));
    hideKeys.forEach((i) => busEmit(setLayerVisible.key, { layername: i, isCheck: false }));

    setHighlight_();
  };

  const remove3Dtiles = () => {
    newfiberMap.map._controls
    newfiberMap.map._controls
            .filter((i) => i._deck)
            .forEach((i) => i.setProps({ layers: [] }));
  };

  const load3DTiles = ({ id, url }) => {
    remove3Dtiles();
    let deckOverlay = null;
    deckOverlay = newfiberMap.map._controls.filter((i) => i._deck)[0];
    if (!deckOverlay) {
      deckOverlay = new MapboxOverlay({
        interleaved: true,
        layers: [],
      });
      newfiberMap.map.addControl(deckOverlay);
    }
    const layers = deckOverlay._props.layers;
    deckOverlay.setProps({
      layers: [
        ...layers,
        new Tile3DLayer({
          id: id,
          name: id,
          data: url,
          loader: Tiles3DLoader,
          refinementStrategy: 'best-available',
          opacity: 0.7, // 支持鼠标拾取
          extruded: true, // 设置3D功能
          loadOptions: {
            "3d-tiles": {
              loadGLTF: true,
              decodeQuantizedPositions: false,
              isTileset: "auto",
              assetGltfUpAxis: null,
            },
          },
          pickable: true, // 设置可选取
          onTilesetLoad: (tileset) => {
            const { cartographicCenter, zoom } = tileset;
            deckOverlay.setProps({
              initialViewState: {
                longitude: cartographicCenter[0],
                latitude: cartographicCenter[1],
                zoom,
              },
            });
          },
          pointSize: 2,
        }),
      ],
    });
  };

  const busEmit = (event, params) => bus.emit(event, params);

  const busOn = (event, func) => bus.on(event, func);

  const busOff = (event) => bus.off(event);
  //添加临时动态线
  const addDynamicLine = (c_layer, c_layer1) => {
    if (newfiberMap.getLayerByName("dynamicLine")) {
      newfiberMap.removeLayer(newfiberMap.getLayerByName("dynamicLine"));
    }
    let dynamicLineJson = turf.featureCollection(
            newfiberMap.map
                    .getSource("sx_wn_hm_merge")
                    ._data.features.filter(
                    (feature) =>
                            feature.properties.c_layer.includes(c_layer) &&
                            feature.properties.c_layer.includes(c_layer1)
            )
    );
    console.log(c_layer, dynamicLineJson);
    let layer = new mapboxL7.LineLayer({
      name: "dynamicLine",
    })
            .source(dynamicLineJson)
            .size(3)
            .shape("line")
            .color("color")
            .animate({
              interval: 1,
              duration: 2,
              trailLength: 0.8,
            });
    newfiberMap.addLayer(layer);
  };
  const events_params = {
    removeMapDatas: { key: "removeMapDatas" },
    setGeoJSON: { key: "setGeoJSON" },
    setLayerVisible: { key: "setLayerVisible" },
    beansToMap: { key: "beansToMap" },
    closeAllLayer: { key: "closeAllLayer" },
    setHighlight: { key: "setHighlight" },
    geoRegeo: { key: "geoRegeo", method: geoRegeo },
    dataToMap: { key: "dataToMap", method: dataToMap },
    pathPlanning: { key: "pathPlanning", method: pathPlanning },
    panelDataToMap: { key: "panelDataToMap", method: panelDataToMap },
    trajectoryToMap: { key: "trajectoryToMap", method: trajectoryToMap },
    clearTrajectory: { key: "clearTrajectory", method: clearTrajectory },
    clearTemporaryData: { key: "clearTemporaryData", method: clearTemporaryData },
    load3DTiles: { key: "load3DTiles", method: load3DTiles },
    remove3Dtiles: { key: "remove3Dtiles", method: remove3Dtiles },
    isOpenPanorama: {
      key: "isOpenPanorama",
      method: (flag) => (datas.isOpenPanorama = flag),
    },
  };

  onMounted(() => {
    bus.on("YQ_head", (val) => {
      if (val == false) {
        MapShow.value = false;
      } else {
        MapShow.value = true;
      }
    });
  });

  onBeforeUnmount(() => {
    bus.off("YQ_head");
    Object.keys(events_params)
            .filter((key) => events_params[key].method)
            .forEach((key) => busOff(events_params[key].key));
    clearInterval(refreshTimer.value); // 清除定时器
    refreshTimer.value = null;
  });
</script>

<style lang="scss">
  #Map {
    width: 100%;
    height: 100%;
  }
</style>