ベースマップでイベントを使用しているため、この特定のイベントの不要な呼び出しを避けるために、プッシュピン自体にイベントをバインドすることをお勧めします。
ただし、コードを更新したい場合は、マウスがベース マップ上にあるときに「手」が Bing Maps の既定の要素であるため、実際に機能する完全な例を次に示します。コードを参照してください。
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Bing Maps Cursor</title>
<script type="text/javascript" charset="UTF-8" src="http://ecn.dev.virtualearth.net/mapcontrol/mapcontrol.ashx?v=7.0"></script>
<script type="text/javascript">
var map = null;
function getMap() {
// Initialize the map
map = new Microsoft.Maps.Map(document.getElementById('map'), {
credentials: "YOURKEY",
center: new Microsoft.Maps.Location(47.5, 2.75),
zoom: 4,
mapTypeId: Microsoft.Maps.MapTypeId.road
});
var pin = new Microsoft.Maps.Pushpin(new Microsoft.Maps.Location(47.5, 2.75));
map.entities.push(pin);
Microsoft.Maps.Events.addHandler(map, 'mousemove', function(event) {
if(event.targetType === 'pushpin') {
map.getRootElement().style.cursor = 'pointer';
} else {
map.getRootElement().style.cursor = 'url("' + Microsoft.Maps.Globals.cursorPath + 'grab.cur"), move';
}
});
}
</script>
</head>
<body onload="getMap();">
<div id="map" style="position: relative; width: 800px; height: 600px;">
</div>
</body>
</html>
また、画鋲イベントに基づく推奨アプローチが必要な場合は、次のようにします。
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Bing Maps Cursor</title>
<script type="text/javascript" charset="UTF-8" src="http://ecn.dev.virtualearth.net/mapcontrol/mapcontrol.ashx?v=7.0"></script>
<script type="text/javascript">
var map = null;
var cursorStyle = null;
function getMap() {
// Initialize the map
map = new Microsoft.Maps.Map(document.getElementById('map'), {
credentials: "YOURKEY",
center: new Microsoft.Maps.Location(47.5, 2.75),
zoom: 4,
mapTypeId: Microsoft.Maps.MapTypeId.road
});
var pin = new Microsoft.Maps.Pushpin(new Microsoft.Maps.Location(47.5, 2.75));
map.entities.push(pin);
Microsoft.Maps.Events.addHandler(pin, 'mouseover', changeCursor);
Microsoft.Maps.Events.addHandler(pin, 'mouseout', revertCursor);
}
function changeCursor(e) {
map.getRootElement().style.cursor = 'pointer';
}
function revertCursor(e) {
map.getRootElement().style.cursor = 'url("' + Microsoft.Maps.Globals.cursorPath + 'grab.cur"), move';
}
</script>
</head>
<body onload="getMap();">
<div id="map" style="position: relative; width: 800px; height: 600px;">
</div>
</body>
</html>