<!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Hello, World</title>
<style type="text/css">
html{height:100%}
body{height:100%;margin:0px;padding:0px}
#container{height:100%}
</style>
<script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=6241064f1bb6ffb432dff3aae77c1d09"></script>
</head>
<body>
<div id="container"></div>
<div id="log"></div>
<script type="text/javascript">
var map = new BMap.Map("container"); // 创建地图实例
var point = new BMap.Point(116.404, 39.915); // 创建点坐标
map.centerAndZoom(point, 6); // 初始化地图,设置中心点坐标和地图级别
map.enableScrollWheelZoom();
map.addControl(new BMap.NavigationControl());
map.addControl(new BMap.NavigationControl());
map.addControl(new BMap.ScaleControl());
map.addControl(new BMap.OverviewMapControl());
map.addControl(new BMap.MapTypeControl());
map.addEventListener("zoomend", function(){
var zoom = this.getZoom();
if(zoom > 13){
dislayobj('obj1','none');
dislayobj('obj2','block');
}else{
dislayobj('obj2','none');
dislayobj('obj1','block');
}
});
function dislayobj (class_name, status) {
var displayObj = document.getElementsByClassName(class_name);
for (var i = 0; i < displayObj.length; i++) {
displayObj[i].style.display = status;
};
}
// 复杂的自定义覆盖物
function ComplexCustomOverlay(point, text, num, class_name, is_display){
this._point = point;
this._text = text;
this._num = num;
this._class = class_name;
this._is_display = is_display;
}
ComplexCustomOverlay.prototype = new BMap.Overlay();
ComplexCustomOverlay.prototype.initialize = function(map){
this._map = map;
var div = this._div = document.createElement("div");
div.style.position = "absolute";
div.style.zIndex = BMap.Overlay.getZIndex(this._point.lat);
div.style.background = "rgba(13, 173, 81, 0.9)";
div.style.border = "1px solid green";
div.style.color = "white";
div.style.borderRadius = "50%";
div.style.height = "100px";
div.style.width = "100px";
div.style.textAlign = "center";
div.style.padding = "2px";
div.style.whiteSpace = "nowrap";
div.style.MozUserSelect = "none";
div.style.fontSize = "14px";
if(this._is_display){
div.style.display = 'block';
}else{
div.style.display = 'none';
}
div.setAttribute('class',this._class);
var p1 = this._span = document.createElement("p");
p1.style.paddingTop = "14px";
div.appendChild(p1);
p1.appendChild(document.createTextNode(this._text));
var p2 = this._span = document.createElement("p");
div.appendChild(p2);
p2.style.fontSize = '16px';
p2.appendChild(document.createTextNode(this._num));
var that = this;
var arrow = this._arrow = document.createElement("div");
arrow.style.position = "absolute";
arrow.style.width = "11px";
arrow.style.height = "10px";
arrow.style.top = "22px";
arrow.style.left = "10px";
arrow.style.overflow = "hidden";
div.appendChild(arrow);
div.onmouseover = function(){
div.style.background = "rgba(238, 93, 91, 0.9)";
this.style.borderColor = "#EE5D5B";
}
div.onmouseout = function(){
div.style.background = "rgba(13, 173, 81, 0.9)";
div.style.borderColor = "green";
}
map.getPanes().labelPane.appendChild(div);
return div;
}
ComplexCustomOverlay.prototype.draw = function(){
var map = this._map;
var pixel = map.pointToOverlayPixel(this._point);
this._div.style.left = pixel.x - parseInt(this._arrow.style.left) + "px";
this._div.style.top = pixel.y - 30 + "px";
}
var txt = "昌平实验基地", num = parseInt(Math.random() * 1000,10) + "套" ;
var txt1 = "天津空港", num1 = parseInt(Math.random() * 1000,10) + "套" ;
var txt2 = "北京机壳仪器中心", num2 = parseInt(Math.random() * 1000,10) + "套" ;
var txt3 = "磁器口科研基地", num3 = parseInt(Math.random() * 1000,10) + "套" ;
var myCompOverlay = new ComplexCustomOverlay(new BMap.Point(116.407845,39.914101), txt, num, 'obj1', 1);
var myCompOverlay1 = new ComplexCustomOverlay(new BMap.Point(116.445087,39.956536), txt1, num1, 'obj1', 1);
var myCompOverlay2 = new ComplexCustomOverlay(new BMap.Point(116.360719,39.947963), txt2, num2, 'obj2', 0);
var myCompOverlay3 = new ComplexCustomOverlay(new BMap.Point(116.425298,39.899595), txt3, num3, 'obj2', 0);
map.addOverlay(myCompOverlay);
map.addOverlay(myCompOverlay1);
map.addOverlay(myCompOverlay2);
map.addOverlay(myCompOverlay3);
</script>
</body>
</html>
自定义百度地图上显示的覆盖物
最新推荐文章于 2023-11-29 20:39:28 发布