- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用带有一些标记的传单 map 。我还有一个侧边栏,可以在其中看到标记的名称,如果单击标记的名称, map 将缩放到标记的 lnglat。它已经可以工作,但我的问题是,当我刷新页面并在侧边栏中选择一个标记时,它将缩放到该标记,但标记的图标不在那里,但是当我再次单击侧边栏中的标记时,然后标记图标正在显示。
我有这个点击功能:
$("#mapContainer").on("click",".zoomMarker",function(){
var no = $(this).attr("mapNo");
var deviceID = $(this).attr("deviceID");
console.log("deviceID: ",deviceID);
var events = findMapNo(no).eventData[deviceID].events;
console.log("events: ",events)
if( events.length>0 ){
var lat = events[events.length-1][4];
var lng = events[events.length-1][3];
var latLng = new L.latLng(lat, lng);
findMapNo(no).map.setZoom(20);
findMapNo(no).map.panTo(latLng);
}else{
toaster("Marker No Location","warning");
}
});
我有这个标记功能。我尝试将 addTo(mapContnr.map) 放入标记变量及其工作原理,但我无法使用 addTo(mapContnr.map) 因为我正在使用标记集群。
var markersLayer, markersCluster, tooltips = [];
function createMarker(data, no, action){
var mapContnr = findMapNo(no);
var markers = [];
var markers2 = []; //will append on arrayMap and the keys is deviceID
var bounds = L.latLngBounds(); // Instantiate LatLngBounds
clearElements(no);
markersCluster = L.markerClusterGroup({
spiderfyOnMaxZoom: true,
showCoverageOnHover: true,
zoomToBoundsOnClick: true,
removeOutsideVisibleBounds: true,
chunkedLoading: true
});
for(var x in data){
if(!data[x].events||data[x].events.length<1){ continue; }
var latest = data[x].events.length-1;
var lat = parseFloat(data[x].events[latest][4]);
var lon = parseFloat(data[x].events[latest][3]);
var accuracy = parseFloat(data[x].events[latest][5]);
var deviceID = data[x].deviceID;
if(lat!=0||lon!=0){
var latLng = L.latLng(lat, lon);
var iconSettings = getAssetSetup(x);
console.log(iconSettings);
var height = iconSettings.iconSizePx.h;
if(!iconSettings){ continue; };
//::customicon
var customIcon = L.icon({
iconUrl: iconSettings.iconURL,
iconSize: [iconSettings.iconSizePx.w, iconSettings.iconSizePx.h],
popupAnchor: [0, 0] // point from which the popup should open relative to the iconAnchor
});
//::marker label/tooltip
var tooltp = L.tooltip({
permanent: true,
className: 'Vlabel',
direction: 'right',
offset: [-6, height/2+11],
}).setContent("<span>"+findVehicleDetails(deviceID).label+"</span>");
tooltips.push(tooltp);
//::popup/infowindow
var temp_content = createPopupContent(x, latest, no);
temp_content += "<div class='menu_logo' style='margin-top:10px; min-height: 15px;'>";
temp_content += "<img src='"+base_url+"assets/img/zoom-logo.png' style='width:18px; height:18px;' class='marker_menu_logo' onclick='zoomMarker("+data[x].events[latest][4]+","+data[x].events[latest][3]+","+no+")'><div class='verticalLine'></div>";
temp_content += "<img src='"+base_url+"assets/img/route-logo.png' style='width:25px; height:10.55px; margin-top: 4px;' class='marker_menu_logo' onclick='getTrail("+deviceID+","+no+")'><div class='verticalLine'></div>";
temp_content += "<img src='"+base_url+"assets/img/direction-logo.png' style='width:18px; height:18px; margin-top: -2px;' class='marker_menu_logo' onclick='leaf_direction("+data[x].events[latest][4]+","+data[x].events[latest][3]+","+no+")'><div class='verticalLine'></div>";
temp_content += "<img src='"+base_url+"assets/img/streetview-logo.png' style='width:18px; height:18px;' class='marker_menu_logo' onclick='streetView("+data[x].events[latest][4]+","+data[x].events[latest][3]+","+data[x].events[latest][8]+","+no+")'>";
temp_content += "</div>";
var popup = L.popup({
minWidth: 200,
closeOnClick: true,
minHeight: 200,
offset: [0, -height/4]
}).setContent(temp_content);
var marker = new L.marker(latLng, { icon: customIcon}).bindTooltip(tooltp).bindPopup(popup).openPopup();
bounds.extend(marker.getLatLng());
markers.push(marker);
markersCluster.addLayer(marker);
}//::END LonLat not 0
} //::END FOR LOOP
//var group = L.featureGroup(markers);
//mapContnr.map.fitBounds(group.getBounds());
markersLayer = L.layerGroup(markers);
//markersLayer.addTo(mapContnr.map); //dont add since there's already a marker cluster layer
markersCluster.on('clusterclick', function (a) {
if (mapContnr.map.getZoom() >= mapContnr.map.options.maxZoom) {
a.layer.spiderfy();
} else{
a.layer.getBounds()
}
});
//mapContnr.map.fitBounds(markersCluster.getBounds());
mapContnr.map.addLayer(markersCluster);
mapContnr.markers = markers;
mapContnr.markerLayers = markersLayer;
mapContnr.markersClusters = markersCluster;
if(mapContnr.markers.length > 1){
mapContnr.map.fitBounds(bounds);
mapContnr.bounds = bounds;
}
if(mapContnr.markers.length == 1){
//mapContnr.map.setZoom(15);
//getLatLng();
var latlng = mapContnr.markers[0].getLatLng();
zoomMarker(latlng.lat,latlng.lng,no);
}
}//END :: createMarker
最佳答案
试试这个 fitbounds()方法
您可以在此处查看工作 JS fiddle .
代码片段
document.getElementById('map').style.height = window.innerHeight + 'px';
const map = L.map("map").setView([48.86, 2.35], 12);
L.tileLayer('http://{s}.tile.osm.org/{z}/{x}/{y}.png', {
attribution: '© <a href="http://osm.org/copyright">OpenStreetMap</a> contributors'
}).addTo(map);
const myFeatureGroup = L.featureGroup().addTo(map).on("click", markerClick);
for (let i = 0; i < 20; i++) {
L.marker(getRandomLatLng()).addTo(myFeatureGroup).bindPopup(`<b>Marker number ${i}</b>`);
}
function markerClick(event) {
map.fitBounds([event.latlng])
}
function getRandomLatLng() {
return [48.86 + 0.1 * Math.random() - 0.05, 2.35 + 0.1 * Math.random() - 0.05];
}
关于javascript - 传单:通过点击功能缩放到标记,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58872404/
我有一个带有 LeafletJS 的项目。 例如,我在 map 中有 2 个点 (A, B)。我将其显示为 2 个标记 我必须画一条从 A 到 B 的折线。 我移动了标记 A,我想将标记 A 的折线的
是否可以向自定义图标标记添加文本?我想避免在图像编辑器中编辑图标只是为了添加文本。 我已经像这样创建了我的自定义图标标记: var airfieldIcon = L.icon({ ic
我想要一个 Leaflet 图层控件,选中/取消选中时必须显示/隐藏主图层内的所有子图层。我还想独立检查/取消选中子层。我浏览了 Leaflet 文档和论坛,但找不到任何引用资料。我应该为此编写一个自
如何处理 Leaflet map 库中的重叠线? 我从服务器 sid 下载 geoJSON 并将其绘制到 map 上。如果有两个相同的条目,Leaflet 会绘制它们两次。这可以通过在服务器端查找完全
我在项目中使用 leafletjs。在 map 上我有几个多边形和标记。当其中一个被点击时,所有这些都有一个点击事件来显示一些信息。如果用户单击 map 的“空白”部分(而不是任何多边形或标记),我想
我正在尝试对下一个边界的外观做出预测。这是一个plunkr: https://plnkr.co/edit/sk6NRh51WZA2vpWP 这就是我让它工作的方式,但它不是很有效: const ori
我是 Leaflet 的新手,目前我正在努力学习教程。到目前为止,我设法创建了一个交互式 clorophet map ,就像示例中的 http://leafletjs.com/examples/cho
我很难弄清楚为什么我无法在 map 上绘制正确的国家/地区。我已经完成了所有代码,但我仍然不明白为什么不能正常工作。 如果您看到任何问题,请告诉我。我很欣赏。 这是数据集 Country
是否可以在使用 Stamen Toner-lite tiles 的 Leaflet map 上设置中间(2.5、3.5、4.5 等)缩放级别? ?这是我到目前为止计算缩放级别的代码: leafletm
早上、下午或晚上。 我有以下位置数据(从'Count of sampling points within a grid cell'调整) # Demo data set.seed(123) # lat
大家好,我正在开发一个具有 map 功能的网站。我的目标是,如果您单击标记,则使其拖动。 这是我的代码 else if (select1.value === "Arson"){ var note =
我正在开发一个应用程序,用户可以在其中上传KML文件,并使用Leaflet,toGeoJSON和Angular-Leaflet-Directive在屏幕上呈现路径。 我使用toGeoJSON.kml(
我需要在多边形要素中实现多色填充。填充将根据要素属性进行有条件的格式化。 假设我需要一个具有 3 色图案的多边形,如下所示: let fillPalette = ['orange', 'green',
我从 javascript 开始,并试图解决这个问题。 我希望当用户单击 map 时出现一个表单。当他们填写表单时,我想在该位置创建一个标记,并将该标记的弹出内容设置为表单中的值。添加表单完成后,我还
我已经在地理服务器中发布了一个功能,我可以通过传单及其 basemap 成功访问该功能。现在我需要在弹出窗口中获取feature onclick的属性信息。 我按原样使用了示例( https://gi
我正在使用带有一些标记的传单 map 。我还有一个侧边栏,可以在其中看到标记的名称,如果单击标记的名称, map 将缩放到标记的 lnglat。它已经可以工作,但我的问题是,当我刷新页面并在侧边栏中选
我正在使用 Leaflet 和 Mapbox,我想设置 map 的 View : 所有标记均可见 中心设置为特定点 使用 setView 和 fitbounds 单独完成每个点很容易,但我不知道如何同
是否有所有潜在 map 源的列表?在示例页面上,可以浏览四种类型的 map 。外面还有什么? http://tombatossals.github.io/angular-leaflet-directi
我正在使用 Leaflet 制作交互式 map 。我在 map 上有标记(基于其经度和纬度坐标),并且我希望某些标记具有与其他标记不同的颜色。例如,某些坐标我给它的分数是“10”,我希望它是粉红色的,
我可能忽略了如何在 map 上更改 LeftletJS 的光标。 http://leafletjs.com/reference.htm 我尝试设置map_div.style.cursor = 'cro
我是一名优秀的程序员,十分优秀!