{"remainingRequest":"D:\\jenkins\\workspace\\xcjy-fvue\\node_modules\\thread-loader\\dist\\cjs.js!D:\\jenkins\\workspace\\xcjy-fvue\\node_modules\\babel-loader\\lib\\index.js!D:\\jenkins\\workspace\\xcjy-fvue\\node_modules\\cache-loader\\dist\\cjs.js??ref--0-0!D:\\jenkins\\workspace\\xcjy-fvue\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!D:\\jenkins\\workspace\\xcjy-fvue\\src\\components\\MineMap\\index.vue?vue&type=script&lang=js","dependencies":[{"path":"D:\\jenkins\\workspace\\xcjy-fvue\\src\\components\\MineMap\\index.vue","mtime":1741378119818},{"path":"D:\\jenkins\\workspace\\xcjy-fvue\\babel.config.js","mtime":1741314102158},{"path":"D:\\jenkins\\workspace\\xcjy-fvue\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"D:\\jenkins\\workspace\\xcjy-fvue\\node_modules\\thread-loader\\dist\\cjs.js","mtime":499162500000},{"path":"D:\\jenkins\\workspace\\xcjy-fvue\\node_modules\\babel-loader\\lib\\index.js","mtime":456789000000},{"path":"D:\\jenkins\\workspace\\xcjy-fvue\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"D:\\jenkins\\workspace\\xcjy-fvue\\node_modules\\vue-loader\\lib\\index.js","mtime":499162500000}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:import _objectSpread from "D:/jenkins/workspace/xcjy-fvue/node_modules/@babel/runtime/helpers/esm/objectSpread2.js";
import "core-js/modules/es.symbol.js";
import "core-js/modules/es.symbol.description.js";
import "core-js/modules/es.array.map.js";
import "core-js/modules/es.array.push.js";
import "core-js/modules/es.iterator.constructor.js";
import "core-js/modules/es.iterator.for-each.js";
import "core-js/modules/es.iterator.map.js";
import "core-js/modules/es.object.freeze.js";
import "core-js/modules/es.object.to-string.js";
import "core-js/modules/web.dom-collections.for-each.js";
//
//
//
//

import patroIcon from '@/views/bigScreen/patrolRescue/image/patrol-icon.png';
import rescueIcon from '@/views/bigScreen/patrolRescue/image/rescue-icon.png';
import emergerEventIcon from '@/views/bigScreen/patrolRescue/image/emerger-event-icon.png';
import rescueEventIcon from '@/views/bigScreen/patrolRescue/image/rescue-event-icon.png';
import roadIcon from '@/views/bigScreen/patrolRescue/image/cardRroad.png';
import pickupIcon from '@/views/bigScreen/patrolRescue/image/pickup.png';
export default {
  name: 'MineMap',
  // Main
  props: {
    // 默认地图加载配置
    defaultOptions: {
      default: function _default() {
        return {};
      },
      type: Object,
      required: false
    },
    // 自定义类名
    customClass: {
      default: '',
      type: String,
      required: false
    },
    // 自定义点位集合
    markers: {
      default: function _default() {
        return [];
      },
      type: Array,
      required: false
    },
    // 自定义线集合
    lines: {
      default: function _default() {
        return [];
      },
      type: Array,
      required: false
    },
    // 自定义面集合
    polygons: {
      default: function _default() {
        return [];
      },
      type: Array,
      required: false
    }
  },
  data: function data() {
    return {
      mapOptions: {
        // style: 'https://service.minedata.cn/map/solu/style/11001' /* 底图样式 */,
        // style: 'miniMap/service/solu/style/id/16932' /* 底图样式 */,
        style: 'https://map.hope.cmet1965.com:58000/service/solu/style/id/16932' /* 底图样式 */,
        center: [107.85585, 28.465908] /*地图中心点*/,
        zoom: 6 /*地图默认缩放等级*/,
        pitch: 0 /*地图俯仰角度*/,
        maxZoom: 20 /*地图最大缩放等级*/,
        minZoom: 3 /*地图最小缩放等级*/
      },
      mineMap: Object.freeze(minemap),
      // mineMap插件
      map: null,
      // 地图实例对象
      mapLoaded: false,
      boundaryLineFace: [{
        // 地图省份边界  layerIdl边界线 layerIdf 边界面
        code: 'SC',
        layerIdl: '20187ac7367e14034b8c19a40a33fe30',
        layerIdf: '4394876460f6c3bd34d0615bf04cff47'
      }, {
        code: 'AH',
        layerIdl: 'ef01a0169aaec81e77e9f0048ceb9713',
        layerIdf: '3dde510c446230cbd4fdd15c5fb85416'
      }, {
        code: 'YN',
        layerIdl: '06fc0230dad437e85d24600e06516587',
        layerIdf: '031e5e61df73778bce2c2d82a4fc0a1c'
      }, {
        code: 'GZ',
        layerIdl: '6c66cdbaddbcf839a529b03bcee23266',
        layerIdf: 'd960ce4f0fe3eafeebf02a908e25910b'
      }, {
        code: 'CQ',
        layerIdl: 'dfc9779a51de79b2eb40790f613964e2',
        layerIdf: 'b37573d5d73f223aa5cf4293efeda3c0'
      }, {
        code: 'XJ',
        layerIdl: 'b6f8c73b2d314bd6e091012fd7698e94',
        layerIdf: '238a5e9de56faa7385873aaadf3ad67d'
      }, {
        code: 'HN',
        layerIdl: '4edbe95e3ec8786276bb39ce7c42453f',
        layerIdf: 'c1c5c040257326352d694528b7e33fac'
      }],
      // 重庆 1766017472697475072
      //云南   1766017976202698752
      //四川 1766019322897244160
      provinceMarker: [{
        zb: [107.569855, 30.367095],
        id: '1430049550537723904',
        //重庆
        zoom: 6.8
      }, {
        zb: [102.928995, 30.52487],
        id: '"1551973634565787637"',
        zoom: 5.8 //四川
      }, {
        zb: [101.593103, 25.353375],
        id: '1551973630102081536',
        //云南
        zoom: 6
      }, {
        zb: [106.641243, 27.10797],
        id: 'GZ',
        zoom: 6.5
      }, {
        zb: [117.229929, 32.325398],
        id: 'AH',
        zoom: 6.5
      }],
      intervalId: null,
      startRescueintervalId: null,
      rescueBlinkIntervals: [],
      idList: [],
      sourceIdList: [],
      rescueIdList: [],
      rescueSourceIdList: [],
      //图层资源id
      markersRescue: [],
      markerRescueEvent: [],
      markerEmergencies: [],
      markerOnlineCar: [],
      markerOnlyCar: [],
      onlineCarClick: false,
      count: 0,
      patrolClick: false,
      rescueClick: false,
      emergenciesClick: false,
      rescueEventClick: false,
      //-------------------------
      eventMarkers: [],
      // 事件驻点
      taskMarkers: [],
      // 任务驻点
      jyPlaceMarkers: [],
      // 巡查驻点
      xcPlaceMarkers: [] // 救援驻点
    };
  },
  created: function created() {
    // 配置 key、solution
    this.mineMap.key = '30be7831caf84685b94e78727e4ce25f';
    this.mineMap.solution = 16932;
    this.mineMap.domainUrl = 'https://map.hope.cmet1965.com:58000'; /* MineMap根域名地址 */
    /* MineMap矢量数据服务根域名地址 */
    this.mineMap.dataDomainUrl = 'https://map.hope.cmet1965.com:58000';
    /* MineMap矢量数据服务新规范根域名地址 */
    this.mineMap.serverDomainUrl = 'https://map.hope.cmet1965.com:58000';
    /* MineMap底图雪碧图地址 */
    this.mineMap.spriteUrl = ['https://map.hope.cmet1965.com:58000/minemapapi/zsxz/zsxz']; // "./mapresource/sprite/sprite",
    /* MineMap后台服务根地址 */
    this.mineMap.serviceUrl = 'https://map.hope.cmet1965.com:58000/service/';

    // 合并覆盖默认配置项
    this.mapOptions = _objectSpread(_objectSpread({}, this.mapOptions), this.defaultOptions);
  },
  mounted: function mounted() {
    this.initMineMap();
  },
  methods: {
    // 加载mineMap2D地图
    initMineMap: function initMineMap() {
      var _this = this;
      // 初始化地图实例
      this.map = new this.mineMap.Map(_objectSpread({
        container: this.$refs.map
      }, this.mapOptions)).on('load', function (_) {
        _this.setHinight(); // 确保在地图加载完成后调用 setHinight
        _this.mapLoaded = true; // 当地图加载完成时，设置标志为 true
      }).on('error', function (error) {
        return _this.$emit('onError', error);
      });
    },
    //设置高亮区域
    setHinight: function setHinight() {
      var _this2 = this;
      if (this.map) {
        this.boundaryLineFace.forEach(function (el) {
          _this2.map.setLayoutProperty(el.layerIdl, 'visibility', 'visible');
          _this2.map.setLayoutProperty(el.layerIdf, 'visibility', 'visible');
        });
        this.$emit('onLoad', this.map);
      }
    },
    //地图中心点切换-test
    changeMapCenter: function changeMapCenter(val) {
      var _this3 = this;
      this.provinceMarker.forEach(function (el) {
        if (val === el.id) {
          _this3.$nextTick(function () {
            _this3.map.flyTo({
              center: el.zb,
              zoom: el.zoom
            });
          });
        }
      });
    },
    // 重新加载地图
    resetMap: function resetMap(callback) {
      var _this4 = this;
      if (this.map && this.mapLoaded) {
        // 移除所有动态添加的标记、线和面
        this.markers.forEach(function (marker) {
          return marker.remove();
        });
        this.lines.forEach(function (line) {
          return _this4.map.removeLayer(line.id);
        });
        this.polygons.forEach(function (polygon) {
          return _this4.map.removeLayer(polygon.id);
        });

        // 清空存储的图层引用
        this.markers.length = 0;
        this.lines.length = 0;
        this.polygons.length = 0;

        // 重新应用底图样式
        var _this$mapOptions = this.mapOptions,
          center = _this$mapOptions.center,
          zoom = _this$mapOptions.zoom;
        this.map.setCenter(center);
        this.map.setZoom(zoom);
      }
      callback && callback(this.map);
    },
    //清除巡查驻点图层标记
    clearLayMarker: function clearLayMarker() {
      var _this5 = this;
      this.markers.forEach(function (marker) {
        return marker.remove();
      });
      this.markers.length = 0; // 清空标记数组
      //移除数据源
      this.sourceIdList.forEach(function (item) {
        _this5.map.removeSource(item);
      });
      this.sourceIdList.length = 0;
      // 移除路段图层
      this.idList.forEach(function (item) {
        if (_this5.map.getLayer(item)) {
          _this5.map.removeLayer(item);
        }
      });
      this.idList.length = 0;
      // this.stopBlink()
      // this.stopBlinking()
    },
    //清除救援驻点图层标记
    clearLayRescueMaker: function clearLayRescueMaker() {
      var _this6 = this;
      this.markersRescue.forEach(function (marker) {
        return marker.remove();
      });
      this.markersRescue.length = 0; // 清空标记数组
      //移除数据源
      this.rescueSourceIdList.forEach(function (item) {
        _this6.map.removeSource(item);
      });
      this.rescueSourceIdList.length = 0;
      // 移除路段图层
      this.rescueIdList.forEach(function (item) {
        if (_this6.map.getLayer(item)) {
          _this6.map.removeLayer(item);
        }
      });
      this.rescueIdList.length = 0;
      this.stopRescueStartBlinking();
    },
    //清除车辆检测标记
    clearCarMarker: function clearCarMarker() {
      this.markerOnlineCar.forEach(function (marker) {
        marker.remove();
      });
      this.markerOnlineCar.length = 0;
      this.markerOnlyCar.forEach(function (marker) {
        marker.remove();
      });
      this.markerOnlyCar.length = 0;
    },
    //改变地图中心点
    changeCenter: function changeCenter(val) {
      if (this.map) {
        // this.map // 同时传入缩放级别和中心点经纬度
        //   .setZoomAndCenter(8, val) //设置地图层级
        this.map.flyTo({
          center: val,
          zoom: 6.5
        });
      }
    },
    /**
     * @description:
     * @param {*} type 类型
     * @return {*}
     */
    removeMarker: function removeMarker(type) {
      this["".concat(type, "Markers")].forEach(function (marker) {
        return marker.remove();
      });
    },
    removeAllMarker: function removeAllMarker() {
      this.eventMarkers.forEach(function (marker) {
        return marker.remove();
      });
      this.taskMarkers.forEach(function (marker) {
        return marker.remove();
      });
      this.jyPlaceMarkers.forEach(function (marker) {
        return marker.remove();
      });
      this.xcPlaceMarkers.forEach(function (marker) {
        return marker.remove();
      });
    },
    /**
     * @description:
     * @param {Array} markers 点位集合
     * @param {String} type 类型
     * @return { void }
     */
    // 地图打点
    minemapMarker: function minemapMarker(markers, type) {
      var _this7 = this;
      markers.forEach(function (item) {
        if (item.lng && item.lat) {
          item.lnglat = [item.lng, item.lat];
          // 创建div作为标记点
          var el = document.createElement('div');
          el.className = 'map-point';

          // let p1 = document.createElement('div')
          // p1.className = 'text-box text-box-bg-' + item.state
          // p1.innerHTML = item.bridgeName

          var p2 = document.createElement('div');
          p2.className = 'icon-box icon-point-' + type + 'Point';

          // let p3 = document.createElement('div')
          // p3.className = 'icon-bridge icon-bridge-' + item.type

          // p2.appendChild(p3)
          // el.appendChild(p1)
          el.appendChild(p2);

          // 标记点位
          var marker = new minemap.Marker(el, {
            offset: [-33, -30]
          }).setLngLat(item.lnglat).addTo(_this7.map);
          _this7["".concat(type, "Markers")].push(marker);
          // 添加点击事件
          // el.addEventListener('click', () => {
          //   this.$refs.infoDialog.open(item)
          // })
        } else {
          console.log('该点位无定位数据', item);
        }
      });
    },
    abc: function abc() {
      console.log(123, '调用地图方法-----------------------');
    },
    // ---------------------------------------------------------------------
    //滚动组件车载布控球
    addCarVideoMarker: function addCarVideoMarker(val) {
      var _this8 = this;
      this.clearCarMarker();
      if (this.map) {
        var coordinateObjects = [];
        if (!val) {
          coordinateObjects = [{
            lng: 106.08,
            lat: 29.88
          }, {
            lng: 106.1,
            lat: 29.86
          }, {
            lng: 105.719017,
            lat: 30.25304
          }];
          this.count++;
          this.changeCenter([106.08, 29.88]);
        } else {
          coordinateObjects.push({
            lng: 106.08,
            lat: 29.88
          });
          this.changeCenter([106.08, 29.88]);
          this.count = 0;
          this.clearCarMarker();
        }
        if (this.count !== 0 && this.count % 2 == 0) {
          this.clearCarMarker();
          return;
        }
        // 遍历坐标对象数组，为每个坐标创建一个标注
        coordinateObjects.forEach(function (coordinateObj, index) {
          var box = document.createElement('div');
          box.style['position'] = 'relative';
          box.style.width = '75px';
          box.style.width = '128px';
          // 创建标注元素
          var el = document.createElement('div');
          var carMaker = document.createElement('div');
          var carNumber = document.createElement('div');
          var smallbox = document.createElement('div');
          el.id = 'marker';
          carMaker.style.width = '3px';
          carMaker.style.height = '46px';
          carMaker.style.background = 'linear-gradient( 180deg, #1AB3FF 44%, rgba(26,179,255,0) 100%)';
          carMaker.style.borderRadius = '0 0 2px 2px';
          carNumber.textContent = '渝AYX286';
          carNumber.style.width = '75px';
          carNumber.style.height = '22px';
          carNumber.style.background = '#1ab3ff';
          carNumber.style['border'] = '1px solid #fff';
          carNumber.style['font-size'] = '12px';
          carNumber.style.color = '#fff';
          carNumber.style['box-shadow'] = 'inset 0 0 4px 0';
          carNumber.style.textAlign = 'center';
          el.style['background-image'] = "url(".concat(pickupIcon, ")");
          el.style['background-size'] = 'cover';
          el.style.width = '60px';
          el.style.height = '60px';
          el.style['border-radius'] = '20%';
          smallbox.style.position = 'absolute';
          smallbox.style.top = '-32px';
          smallbox.style.left = '28px';
          smallbox.appendChild(carNumber);
          smallbox.appendChild(carMaker);
          box.appendChild(smallbox);
          box.appendChild(el);
          if (!val) {
            var _marker = new minemap.Marker(box, {
              offset: [0, 0]
            }).setLngLat(coordinateObj) // 使用对象的 lng 和 lat 属性
            .addTo(_this8.map);
            _this8.markerOnlineCar.push(_marker);
            box.addEventListener('click', function () {
              _this8.$emit('openVideoDialog', coordinateObj);
            });
          } else {
            //车载视频显示
            var _marker = new minemap.Marker(box, {
              offset: [0, 0]
            }).setLngLat(coordinateObj) // 使用对象的 lng 和 lat 属性
            .addTo(_this8.map);
            _this8.markerOnlyCar.push(_marker);
            _this8.$emit('openVideoDialog', coordinateObj);
          }
        });
      }
    },
    //路线图层
    addCustomerMarker: function addCustomerMarker(val) {
      var _this9 = this;
      if (this.map) {
        // this.clearLayMarker()
        var coordinateObjects = [{
          lng: 105.89,
          lat: 30.07,
          description: '璧山北收费站',
          id: 1,
          coordinates: [[105.96, 29.97], [105.89, 30.07]],
          Sections: '渝遂',
          Station: [390, 0],
          type: '收费站',
          managementCompany: '重庆珑钟救援服务有限公司',
          trailerNum: 3,
          //拖车
          crane: 2,
          //吊车
          leader: '河东',
          leaderPhone: '15825922716',
          pickup: 2 //皮卡
        }, {
          lng: 106.1,
          lat: 29.86,
          description: '铜梁北收费站',
          id: 2,
          coordinates: [[106.1, 29.86], [106.11, 29.85]],
          Sections: '渝遂',
          Station: [363, 0],
          type: '收费站',
          managementCompany: '重庆珑钟救援服务有限公司',
          trailerNum: 3,
          //拖车
          crane: 2,
          //吊车
          leader: '河东',
          leaderPhone: '15825922716',
          pickup: 3 //皮卡
        }, {
          lng: 105.719017,
          lat: 30.25304,
          description: '铜梁东收费站',
          id: 3,
          coordinates: [[105.719017, 30.25304], [105.721367, 30.246401]],
          Sections: '渝遂',
          Station: [372, 0],
          type: '收费站',
          managementCompany: '重庆珑钟救援服务有限公司',
          trailerNum: 3,
          //拖车
          crane: 2,
          //吊车
          leader: '河东',
          leaderPhone: '15825922716',
          pickup: 5 //皮卡
        }, {
          lng: 105.98,
          lat: 29.95,
          description: '田家收费站',
          id: 4,
          coordinates: [[105.98, 29.95], [106.01, 29.93]],
          Sections: '渝遂',
          Station: [330, 0],
          type: '收费站',
          managementCompany: '重庆珑钟救援服务有限公司',
          trailerNum: 3,
          //拖车
          crane: 2,
          //吊车
          leader: '河东',
          leaderPhone: '15825922716',
          pickup: 2 //皮卡
        }];
        this.changeCenter([106.08, 29.88]);
        //判断是否清除标记
        if (val == 'patrol') {
          this.patrolClick = !this.patrolClick;
          if (!this.patrolClick) {
            this.clearLayMarker();
            return;
          }
        }
        if (val == 'rescue') {
          this.rescueClick = !this.rescueClick;
          if (!this.rescueClick) {
            this.clearLayRescueMaker();
            return;
          }
        }
        if (val == 'Emergencies') {
          this.emergenciesClick = !this.emergenciesClick;
          if (!this.emergenciesClick) {
            this.markerEmergencies.forEach(function (marker) {
              return marker.remove();
            });
            this.markerEmergencies.length = 0;
            return;
          }
        }
        if (val == 'rescueEvent') {
          this.rescueEventClick = !this.rescueEventClick;
          if (!this.rescueEventClick) {
            this.markerRescueEvent.forEach(function (marker) {
              return marker.remove();
            });
            this.markerRescueEvent.length = 0;
            return;
          }
        }
        // 遍历坐标对象数组，为每个坐标创建一个标注
        coordinateObjects.forEach(function (coordinateObj, index) {
          //公共容器
          var p = document.createElement('div');
          // 创建标注元素
          var el = document.createElement('div');
          var textEl = document.createElement('div');
          el.id = 'marker';

          //巡查驻点
          if (val == 'patrol') {
            el.style['background-image'] = "url(".concat(patroIcon, ")");
            textEl.style.border = '2px solid #51fd8a';
            textEl.style.backgroundColor = '#1ea64b'; // 可以设置背景色
          }
          //救援驻点
          if (val == 'rescue') {
            el.style['background-image'] = "url(".concat(rescueIcon, ")");
            textEl.style.backgroundColor = '#43adad';
            textEl.style.border = '2px solid #04fbfb';
          }
          //突发事件
          if (val == 'Emergencies') {
            el.style['background-image'] = "url(".concat(emergerEventIcon, ")");
            textEl.style.backgroundColor = '#785000';
            textEl.style.border = '2px solid #ffc95a';
          }
          //救援事件
          if (val == 'rescueEvent') {
            el.style['background-image'] = "url(".concat(rescueEventIcon, ")");
            textEl.style.backgroundColor = '#7c0d2d';
            textEl.style.border = '2px solid #bd4467';
          }
          el.style['background-size'] = 'cover';
          el.style.width = '40px';
          el.style.height = '40px';
          el.style['border-radius'] = '20%';
          // 创建文字描述元素
          textEl.textContent = coordinateObj.description; // 设置描述文本
          textEl.style.padding = '2px 5px'; // 内边距
          textEl.style.borderRadius = '3px'; // 圆角
          textEl.style.fontSize = '12px'; // 字体大小
          textEl.style.color = 'white';
          textEl.style.whiteSpace = 'nowrap'; // 防止文本换行
          p.appendChild(textEl);
          p.appendChild(el);
          p.style.display = 'flex';
          p.style.flexDirection = 'column';
          p.style.justifyContent = 'center';
          p.style.alignItems = 'center';
          // 创建一个新的标注实例，并设置偏移量
          if (val == 'patrol') {
            var _marker = new minemap.Marker(p, {
              offset: [0, 0]
            }).setLngLat(coordinateObj) // 使用对象的 lng 和 lat 属性
            .addTo(_this9.map);
            _this9.markers.push(_marker);
            _this9.addSources(coordinateObj.coordinates, coordinateObj.id);
            _this9.addLayers(coordinateObj.id);
            _this9.idList.push("lineLayer-".concat(coordinateObj.id));
            _this9.sourceIdList.push("lineSource-".concat(coordinateObj.id));
            if (_this9.rescueIdList.length) {
              _this9.stopRescueStartBlinking();
            }
            p.addEventListener('click', function () {
              _this9.$emit('patrolStationList', coordinateObj);
            });
          }
          if (val == 'rescue') {
            var _marker = new minemap.Marker(p, {
              offset: [0, 0]
            }).setLngLat(coordinateObj) // 使用对象的 lng 和 lat 属性
            .addTo(_this9.map);
            _this9.markersRescue.push(_marker);
            _this9.addRescueSources(coordinateObj.coordinates, coordinateObj.id);
            _this9.addRescueLayers(coordinateObj.id);
            _this9.rescueIdList.push("lineRescueLayer-".concat(coordinateObj.id));
            _this9.rescueSourceIdList.push("lineRescueSource-".concat(coordinateObj.id));
            p.addEventListener('click', function () {
              _this9.$emit('stationList', coordinateObj);
            });
          }
          if (val == 'Emergencies') {
            var _marker = new minemap.Marker(p, {
              offset: [0, 0]
            }).setLngLat(coordinateObj) // 使用对象的 lng 和 lat 属性
            .addTo(_this9.map);
            _this9.markerEmergencies.push(_marker);
            // if (this.idList.length) {
            //   this.stopBlink()
            // }
            if (_this9.rescueIdList.length) {
              _this9.stopRescueStartBlinking();
            }
            p.addEventListener('click', function () {
              _this9.$emit('openEventDialog', coordinateObj);
            });
          }
          if (val == 'rescueEvent') {
            var _marker = new minemap.Marker(p, {
              offset: [0, 0]
            }).setLngLat(coordinateObj) // 使用对象的 lng 和 lat 属性
            .addTo(_this9.map);
            _this9.markerRescueEvent.push(_marker);
            // if (this.idList.length) {
            //   this.stopBlink()
            // }
            if (_this9.rescueIdList.length) {
              _this9.stopRescueStartBlinking();
            }
            p.addEventListener('click', function () {
              _this9.$emit('openEventDialog', coordinateObj);
            });
          } else {
            return;
          }
        });
        if (this.rescueIdList.length && val == 'rescue') {
          this.startRescueStartBlinking();
          setTimeout(function () {
            _this9.stopRescueStartBlinking();
          }, 8000);
        }
      }
    },
    // 为每个标注点设计源--巡查驻点
    addSources: function addSources(coordinates, id) {
      var jsonData = {
        type: 'FeatureCollection',
        features: [{
          type: 'Feature',
          geometry: {
            type: 'LineString',
            coordinates: coordinates
          },
          properties: {
            title: '路线一',
            kind: 1
          }
        }]
      };
      this.map.addSource("lineSource-".concat(id), {
        type: 'geojson',
        data: jsonData
      });
    },
    // 为每个标注点添加图层--巡查驻点
    addLayers: function addLayers(id) {
      this.map.addLayer({
        id: "lineLayer-".concat(id),
        type: 'line',
        source: "lineSource-".concat(id),
        layout: {
          'line-join': 'round',
          'line-cap': 'round',
          'border-visibility': 'visible' //是否开启线边框
        },
        paint: {
          'line-width': 8,
          'line-color': {
            type: 'categorical',
            property: 'kind',
            stops: [[1, '#FFD48A '], [2, '#FFD48A ']],
            default: '#ff0000'
          },
          'line-border-width': 2,
          //设置线边框宽度
          'line-border-opacity': 1,
          //设置线边框透明度
          'line-border-color': {
            stops: [[1, '#00FFFF'], [2, ' #FFFFFF']]
          } //设置线边框颜色
        },
        minzoom: 7,
        maxzoom: 17.5
      });
    },
    // 为每个标注点设计源--救援驻点
    addRescueSources: function addRescueSources(coordinates, id) {
      var jsonData = {
        type: 'FeatureCollection',
        features: [{
          type: 'Feature',
          geometry: {
            type: 'LineString',
            coordinates: coordinates
          },
          properties: {
            title: '路线一',
            kind: 1
          }
        }]
      };
      this.map.addSource("lineRescueSource-".concat(id), {
        type: 'geojson',
        data: jsonData
      });
    },
    // 为每个标注点添加图层--救援驻点
    addRescueLayers: function addRescueLayers(id) {
      this.map.addLayer({
        id: "lineRescueLayer-".concat(id),
        type: 'line',
        source: "lineRescueSource-".concat(id),
        layout: {
          'line-join': 'round',
          'line-cap': 'round',
          'border-visibility': 'visible' //是否开启线边框
        },
        paint: {
          'line-width': 8,
          'line-color': {
            type: 'categorical',
            property: 'kind',
            stops: [[1, '#FFD48A '], [2, '#FFD48A ']],
            default: '#ff0000'
          },
          'line-border-width': 2,
          //设置线边框宽度
          'line-border-opacity': 1,
          //设置线边框透明度
          'line-border-color': {
            stops: [[1, '#00FFFF'], [2, ' #FFFFFF']]
          } //设置线边框颜色
        },
        minzoom: 7,
        maxzoom: 17.5
      });
    },
    // //巡查驻点闪烁
    // startBlinking() {
    //   this.intervalId = setInterval(() => {
    //     this.idList.forEach((item) => {
    //       // this.map.setPaintProperty(item, 'line-opacity', 0)
    //       if (this.map.getLayer) {
    //         this.map.setPaintProperty(
    //           item,
    //           'line-opacity',
    //           this.map.getPaintProperty(item, 'line-opacity') == 0 ? 1 : 0
    //         )
    //       }
    //     })
    //   }, 1000)
    // },
    // //关闭巡查驻点闪烁
    // stopBlink() {
    //   if (this.intervalId) {
    //     clearInterval(this.intervalId)
    //     this.intervalId = null // 清除引用，避免内存泄漏
    //     this.idList.forEach((item) => {
    //       this.map.setPaintProperty(item, 'line-opacity', 1)
    //     })
    //   }
    // },
    //开启救援驻点闪烁
    startRescueStartBlinking: function startRescueStartBlinking() {
      var _this10 = this;
      this.startRescueintervalId = setInterval(function () {
        _this10.rescueIdList.forEach(function (item) {
          if (_this10.map.getLayer) {
            _this10.map.setPaintProperty(item, 'line-opacity', _this10.map.getPaintProperty(item, 'line-opacity') == 0 ? 1 : 0);
          }
        });
      }, 1000);
    },
    //关闭巡查救援闪烁
    stopRescueStartBlinking: function stopRescueStartBlinking() {
      var _this11 = this;
      if (this.startRescueintervalId) {
        clearInterval(this.startRescueintervalId);
        this.startRescueintervalId = null;
        this.rescueIdList.forEach(function (item) {
          _this11.map.setPaintProperty(item, 'line-opacity', 1);
        });
      }
    }
  },
  beforeDestroy: function beforeDestroy() {
    // 注销地图实例,移除地图
    if (this.map) {
      this.map.remove();
    }
  }
};"},null]}