php+js实现百度地图多点标注的方法

5年以前  |  阅读数:1126 次  |  编程语言:PHP 

本文实例讲述了php+js实现百度地图多点标注的方法。分享给大家供大家参考,具体如下:

1.php创建json数据


    $products = $this->product_db->select($where);
    $products_json = json_encode($products);

2.js传入json数据

类似于这样的结构


    var markerArr = [{
      title: "名称:广州火车站",
      point: "113.264531,23.157003",
      address: "广东省广州市广州火车站",
      tel: "12306"
    }, {
      title: "名称:广州塔(赤岗塔)",
      point: "113.330934,23.113401",
      address: "广东省广州市广州塔(赤岗塔) ",
      tel: "18500000000"
    }, {
      title: "名称:广州动物园",
      point: "113.312213,23.147267",
      address: "广东省广州市广州动物园",
      tel: "18500000000"
    }, {
      title: "名称:天河公园",
      point: "113.372867,23.134274",
      address: "广东省广州市天河公园",
      tel: "18500000000"
    }];

js擅长处理json数据


    <script>
    var products_json = {$products_json};
    // 百度地图
    var citymap = new citymap(products_json,'宿迁');
    </script>

3.处理地图


    document.write('<script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak;=1We8imivxZnaKMujZIrlDZ0v"></script>');
    function citymap(markerArr, cityName){
      this.markerArr = markerArr;
      this.cityName = cityName;
      this.initMap = function() {
        this.createMap();//创建地图
        this.setMapEvent();//设置地图事件
        this.addMapControl();//向地图添加控件
      };
      this.createMap = function() {
        var map = new BMap.Map("dituContent");//在百度地图容器中创建一个地图
        map.centerAndZoom(cityName,'13');
        window.map = map;//将map变量存储在全局
        // 绘制点
        for (var i = 0; i < markerArr.length; i++) {
          var p0 = markerArr[i].baidu_lng;
          var p1 = markerArr[i].baidu_lat;
          var maker = this.addMarker(new window.BMap.Point(p0, p1),markerArr[i],i );
          this.addInfoWindow(maker, markerArr[i], i);
        }
      };
      this.addMarker = function(point,pro,index) {
        var myIcon = new BMap.Icon("http://api.map.baidu.com/img/markers.png",
          new BMap.Size(23, 25), {
            offset: new BMap.Size(10, 25),
            imageOffset: new BMap.Size(0, 0 - index * 25)
          });
        var marker = new BMap.Marker(point, {
          icon: myIcon
        });
        map.addOverlay(marker);
        var label = new BMap.Label(pro.name,{offset:new BMap.Size(20,-10)});
        // 设置label样式
        label.setStyle({ 
          color : "#CC3333", 
          fontSize : "13px", 
          backgroundColor :"#CCFFFF",
          border :"0", 
          fontWeight :"bold" 
        });
        marker.setLabel(label);
        return marker;
      };
      this.addInfoWindow = function(marker,pro) {
        //pop弹窗标题 
        var title = '<div style="font-weight:bold;color:#CE5521;font-size:14px"><a href="?m=home&c;=product&id;='+ pro.id +'">' + pro.name + '</a></div>';
        //pop弹窗信息 
        var html = [];
        html.push('<table cellspacing="0" style="table-layout:fixed;width:100%;font:12px arial,simsun,sans-serif"><tbody>');
        html.push('<tr>');
        html.push('<td style="vertical-align:top;line-height:16px;width:38px;white-space:nowrap;word-break:keep-all">地址:</td>');
        html.push('<td style="vertical-align:top;line-height:16px">' + pro.address + ' </td>');
        html.push('</tr>');
        html.push('</tbody></table>');
        var infoWindow = new BMap.InfoWindow(html.join(""), {
          title: title,
          width: 200
        });
        var openInfoWinFun = function() {
          marker.openInfoWindow(infoWindow);
        };
        marker.addEventListener("click", openInfoWinFun);
        return openInfoWinFun;
      }
      this.setMapEvent = function() {
        map.enableDragging();//启用地图拖拽事件,默认启用(可不写)
        // map.enableScrollWheelZoom();//启用地图滚轮放大缩小
        map.enableDoubleClickZoom();//启用鼠标双击放大,默认启用(可不写)
        map.enableKeyboard();//启用键盘上下左右键移动地图
      };
      this.addMapControl = function() {
        //向地图中添加缩放控件
        var ctrl_nav = new BMap.NavigationControl({anchor:BMAP_ANCHOR_TOP_LEFT,type:BMAP_NAVIGATION_CONTROL_LARGE});
        map.addControl(ctrl_nav);
          //向地图中添加缩略图控件
        var ctrl_ove = new BMap.OverviewMapControl({anchor:BMAP_ANCHOR_BOTTOM_RIGHT,isOpen:1});
        map.addControl(ctrl_ove);
          //向地图中添加比例尺控件
        var ctrl_sca = new BMap.ScaleControl({anchor:BMAP_ANCHOR_BOTTOM_LEFT});
        map.addControl(ctrl_sca);
      };
      this.initMap();
    }

更多关于PHP相关内容感兴趣的读者可查看本站专题:《php curl用法总结》、《PHP数组(Array)操作技巧大全》、《php排序算法总结》、《PHP常用遍历算法与技巧总结》、《PHP数据结构与算法教程》、《php程序设计算法总结》、《PHP数学运算技巧总结》、《php正则表达式用法总结》、《PHP运算与运算符用法总结》、《php字符串(string)用法总结》及《php常见数据库操作技巧汇总

希望本文所述对大家PHP程序设计有所帮助。

 相关文章:
PHP分页显示制作详细讲解
SSH 登录失败:Host key verification failed
获取IMSI
将二进制数据转为16进制以便显示
获取IMEI
文件下载
贪吃蛇
双位运算符
PHP自定义函数获取搜索引擎来源关键字的方法
Java生成UUID
发送邮件
年的日历图
提取后缀名
在Zeus Web Server中安装PHP语言支持
让你成为最历害的git提交人
Yii2汉字转拼音类的实例代码
再谈PHP中单双引号的区别详解
指定应用ID以获取对应的应用名称
Python 2与Python 3版本和编码的对比
php封装的page分页类完整实例