利用百度地图API显示多个地标信息弹出提示框的解决方法

3 篇文章 0 订阅

通过使用百度地图API显示多个地标信息,每个地标信息弹出的提示框内容都是最后一个地标信息的数据,为此,查找很多资料终于解决了此疑难杂症,现将方法整理如下:

@{
    Layout = null;
}

<!DOCTYPE html>

<html>
<head>
    <meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
    <title>MapIndex</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=您的密钥"></script>
    </script>
    <script src="~/Scripts/jquery-1.10.2.min.js"></script>
</head>
<body>
    <div id="container"></div>
    <script type="text/javascript">
        function message(obj, unitname, unittype, licenseid, address) {
            var opts = {
                width: 250,
                height: 100,
                title: unitname
            }
            var infoWindow = new BMap.InfoWindow("企业类型:" + unittype + "<br>" + "地址:" + address , opts);  // 创建信息窗口对象
            obj.openInfoWindow(infoWindow, map.getCenter());
        }

        function addMarker(point, marker, unitname, unittype, licenseid, address) {  // 创建图标对象
            map.addOverlay(marker);
            marker.addEventListener("click", function () {
                message(this, unitname, unittype, licenseid, address);
            });
        }

        function InitMap() {
            $.ajax({
                type: 'GET',
                url: 'GetCoordinates',
                data: '',
                success: function (data) {
				    //百度地图API方法,所有标注点弹出的提示框中的内容都是最后一个地标信息的内容
                    //for (var i = 0; i < data.length; i++) {
                    //    var p = new BMap.Point(data[i].Longitude, data[i].Latitude);  // 创建点坐标
                    //    var m = new BMap.Marker(p);  // 创建标注
                    //    map.addOverlay(m);              // 将标注添加到地图中

                    //    var opts = {
                    //        width: 250,     // 信息窗口宽度
                    //        height: 100,     // 信息窗口高度
                    //        title: "企业名称:" + data[i].UnitName, // 信息窗口标题
                    //    }
                    //    var infoWindow = new BMap.InfoWindow("企业类型:" + data[i].UnitType + "<br>" + "地址:" + data[i].Address, opts);  // 创建信息窗口对象
                    //    m.addEventListener("click", function () {
                    //        map.openInfoWindow(infoWindow, p); //开启信息窗口
                    //    });
                    //}

                    for (var i = 0; i < data.length; i++) {
                        var point = new BMap.Point(data[i].Longitude, data[i].Latitude);  // 创建点坐标
                        var marker = new BMap.Marker(point);  // 创建标注
                        addMarker(point, marker, data[i].UnitName, data[i].UnitType, data[i].Address);
                    }
                },
                error: function () {

                },
                dataType: "json"
            });
        }

        var map = new BMap.Map("container");          // 创建地图实例
        map.enableScrollWheelZoom(true);     //开启鼠标滚轮缩放
        map.addControl(new BMap.NavigationControl());
        map.addControl(new BMap.ScaleControl());
        map.addControl(new BMap.OverviewMapControl());
        var point = new BMap.Point(112.613712,35.088129);  // 创建点坐标
        var marker = new BMap.Marker(point);  // 创建标注
        map.addOverlay(marker);              // 将标注添加到地图中
        map.centerAndZoom(point, 15);                 // 初始化地图,设置中心点坐标和地图级别
        InitMap();
    </script>
</body>
</html>


  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值