gpt4 book ai didi

javascript - 如何检测谷歌地图标记图像无法加载以提供默认图像?

转载 作者:行者123 更新时间:2023-11-30 11:51:55 26 4
gpt4 key购买 nike

遵循 Google Maps API 中的示例代码(为简洁起见被 chop )如何检查标记图像加载失败并改用其他/默认图像?

var image = {
url: 'https://broken.url.com/no-such-image.png',
size: new google.maps.Size(20, 32),
origin: new google.maps.Point(0, 0),
anchor: new google.maps.Point(0, 32)
};

var marker = new google.maps.Marker({
position: {lat: -33.890542, lng: 151.274856},
map: map,
icon: image,
title: 'Marker demo',
zIndex: 1
});

最佳答案

您可以尝试使用javascript 来加载图像。如果它可以加载(onload 事件被触发),添加带有图像的标记,否则(onerror 事件被触发)回退到其他东西(例如没有图像的默认标记) :

var image = new Image();
var image_url = "https://broken.url.com/no-such-image.png";
image.onload = function () {
console.info("Image loaded, adding marker with image !");
var marker = new google.maps.Marker({
position: {lat: -33.890542, lng: 151.274856},
map: map,
icon: {
url: image_url,
size: new google.maps.Size(20, 32),
origin: new google.maps.Point(0, 0),
anchor: new google.maps.Point(0, 32)
},
title: 'Marker demo',
zIndex: 1
});
}
image.onerror = function () {
console.error("Cannot load image, adding marker without image");
var marker = new google.maps.Marker({
position: {lat: -33.890542, lng: 151.274856},
map: map,
title: 'Marker demo',
zIndex: 1
});
}
image.src = image_url;

关于javascript - 如何检测谷歌地图标记图像无法加载以提供默认图像?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39206804/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com