删除旧地图-打开图层3

时间:2018-07-25 13:50:34

标签: dictionary openlayers-3 destroy

我想更改地图上的图标功能 我的想法是删除旧地图并生成新地图

我的地图:

var map = new ol.Map({
  renderer: 'canvas',
  target: 'mapOl',      
  layers: [ignLayer, vectorLayer],
  overlays: [overlayPopup],
  view: new ol.View({
    center: center,
    zoom: 9,
    maxZoom: 13, //Limit zoom levels
    minZoom: 7 
  })
});

删除:

$("#mapOl").empty();

它会生成具有正确图标功能的新地图,但第一张地图仍然存在!

我该怎么办,删除第一张卡片或尝试更改图标? 谢谢!

1 个答案:

答案 0 :(得分:0)

好!我找到了解决方法

首先,我只创建一次地图的 实例,然后使用功能 .data()在jQuery中为其分配引用。

然后,当我要“重新加载”我的地图(带有图标功能)时,我检查地图参考为空,如果它为空,则声明我的地图及其附带的所有内容(vectorLayers,其他图层...),否则我会用他的参考删除地图的旧vectorLayer(iconFeatures)并影响新的vectorLayer。

这是所有代码:

function displayMap(communesNbResults)
{
  /**
   * Elements that make up the popup.
   */
  var container = document.getElementById('popup');
  var content = document.getElementById('popup-content');
  var closer = document.getElementById('popup-closer');

//Create icons features by searching his geocode (long, lat)
 let vectorSource = createIconsFeature(communesNbResults);

//create the style
var iconStyle = new ol.style.Style({
  image: new ol.style.Icon(/** @type {olx.style.IconOptions} */ ({
    anchor: [0.5, 46],
    anchorXUnits: 'fraction',
    anchorYUnits: 'pixels',
    opacity: 1,
    src: ""
  }))
});

//add the feature vector to the layer vector, and apply a style to whole layer
var vectorLayer = new ol.layer.Vector({
  source: vectorSource,
  style: iconStyle
});

//Check if map not already exist
if($('#mapOl').data('map') == null)
{
  var center = ol.proj.transform([-2.811813, 48.557159], 'EPSG:4326', 'EPSG:3857');

  //Create all layers
  //Carte IGN
  let ignLayer = new ol.layer.Tile({
      preload: Infinity,
      source : new ol.source.WMTS({
          url: "https://wxs.ign.fr/KEY/geoportail/wmts",
          layer: "GEOGRAPHICALGRIDSYSTEMS.MAPS",
          matrixSet: "PM",
          format: "image/jpeg",
          style: "normal",
          tileGrid : new ol.tilegrid.WMTS({
              origin: [-20037508,20037508],
              // topLeftCorner
              resolutions: resolutions, // résolutions
              matrixIds: ["0","1","2","3","4","5","6","7","8","9","10","11","12","13","14","15","16","17","18","19"] // ids des TileMatrix                      // ids des TileMatrix
          })
      }),
  });

  /**
   * Create an overlay to anchor the popup to the map.
   */
  var overlayPopup = new ol.Overlay(/** @type {olx.OverlayOptions} */ ({
    element: container,
    autoPan: true,
    autoPanAnimation: {
        duration: 250
    }
  }));

  var map = new ol.Map({
    renderer: 'canvas',
    target: 'mapOl',      
    layers: [ignLayer, vectorLayer],
    overlays: [overlayPopup],
    view: new ol.View({
      center: center,
      zoom: 9,
      maxZoom: 13, //Limit zoom levels
      minZoom: 7 
    })
  });
  //Set reference for jQuery
  $('#mapOl').data('map', map);
  $('#mapOl').data('vectorLayer', vectorLayer);

  //Create and layerSwitcher at map
  var layerSwitcher = new ol.control.LayerSwitcher({
    // paramétrage de l'affichage de la couche OSM
    layers : [{
        layer: ignLayer,
        config: {
            title: "Carte IGN",
            description: "Carte topographique IGN"
        }
    }],
  });
  //Set reference for layerSwitcher
  $('#mapOl').data('layerSwitcher', layerSwitcher);

  //Add layerSwitcher at map
  map.addControl(layerSwitcher);
  //Remove layer icons (markers) of layerSwitcher !
  layerSwitcher.removeLayer(vectorLayer);

  //Listener 
  /**
    * Add a click handler to the map to render the popup.
    */
  map.on('singleclick', function(evt) {
    var feature = map.forEachFeatureAtPixel(evt.pixel,
        function(feature) {
          return feature;
        });

      //Si clique sur un marker ! 
      if (feature) {
        var coordinate = evt.coordinate;

        //Get infos to display
        let infos = feature['infos'][0];
        let hrefId = "map_" + infos['commune'];

        content.innerHTML = 'Infos';

        //Add "event listener" to retrieve all actesIndividus for this commune
        $(content).on('click', $('a#'+hrefId), function() {
            //Find tag <a>
            let aId = $(this).find( "a" ).prop('id');
            //Split to get Commune
            let commune = aId.split('_')[1];

            //Close map modal
            $('#modalcarte').modal('hide');

            //Call method to retrieve all actesIndividus (method: gene)
            mapToGene(commune);
        });

        //Show popup
        $(container).show();
        overlayPopup.setPosition(coordinate);
      }
  });

  /**
   * Add a click handler to hide the popup.
   * @return {boolean} Don't follow the href.
   */
  closer.onclick =  function() {
    overlayPopup.setPosition(undefined);
    closer.blur();
    return false;
  };
}
else //Change only vectorLayer (markers)
{
  let map = $('#mapOl').data('map');
  let oldVectorLayer = $('#mapOl').data('vectorLayer');
  //Set reference for new vectorLayer (for future map)
  $('#mapOl').data('vectorLayer', vectorLayer);

  let layerSwitcher = $('#mapOl').data('layerSwitcher');

  //Remove old and add new vectorLayer
  map.removeLayer(oldVectorLayer);
  map.addLayer(vectorLayer);

  //Remove layer icons (markers) of layerSwitcher !
  layerSwitcher.removeLayer(vectorLayer);
}

}