我想更改地图上的图标功能 我的想法是删除旧地图并生成新地图
我的地图:
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();
它会生成具有正确图标功能的新地图,但第一张地图仍然存在!
我该怎么办,删除第一张卡片或尝试更改图标? 谢谢!
答案 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);
}
}