zoukankan      html  css  js  c++  java
  • 百度地图:实现地图找房

    baidu API 引入:

        <script type="text/javascript" src="//api.map.baidu.com/api?v=2.0&ak=***"></script>
        <script type="text/javascript" src="//api.map.baidu.com/library/GeoUtils/1.2/src/GeoUtils.js"></script>
        <script type="text/javascript" src="//api.map.baidu.com/library/InfoBox/1.2/src/InfoBox_min.js"></script>

    html:

    <div id="mapContainer"></div>

    简单实现逻辑:

    (function (win, $) {
        class SearchMap {
            constructor(options, sourceData, listener) {
                this.map = undefined; //地图实例
                this.point = undefined; //地图中心点
                this.polygon = undefined;
                this.options = options || {}; //参数选项
                this.sourceData = sourceData; //原始数据
                this.listener = listener; //地图缩放或平移的事件监听器
                this.initMap();
            }
    
            initMap() {
                let _this = this;
                this.map = new BMap.Map('mapContainer', { minZoom: 9, maxZoom: 18 });
                this.point = new BMap.Point(this.options.lng, this.options.lat);
                this.map.centerAndZoom(this.point, 9);
                this.map.enableScrollWheelZoom(true);
                this.addMarks();
                this.map.addEventListener("zoomend", function () {
                    var zoomLevel = _this.map.getZoom(); //获取地图缩放级别
                    if (zoomLevel <= 10) {
                        _this.addMarks();
                    } else {
                        _this.getAllLabel();
                    }
                });
            }
            // 根据行政区划绘制聚合点位
            addMarks() {
                // 添加marks时先清除之前的覆盖物
                let _this = this;
                let _map = this.map;
                let _polygon = this.polygon;
                _map.clearOverlays();
                // 模拟郑州市聚点数据
                let clusterList = [
                    { "name": "郑州市", "code": "410100000", "longitude": "113.451854", "latitude": "34.556306", "count": "445" },
                    { "name": "开封市", "code": "410200000", "longitude": "114.356733", "latitude": "34.506238", "count": "377" },
                    { "name": "洛阳市", "code": "410300000", "longitude": "112.134468", "latitude": "34.263041", "count": "370" },
                    { "name": "平顶山市", "code": "410400000", "longitude": "112.992161", "latitude": "33.773999", "count": "300" },
                    { "name": "安阳市", "code": "410500000", "longitude": "114.098163", "latitude": "36.106852", "count": "290" },
                    { "name": "鹤壁市", "code": "410600000", "longitude": "114.208643", "latitude": "35.653125", "count": "245" },
                    { "name": "新乡市", "code": "410700000", "longitude": "113.933677", "latitude": "35.31059", "count": "236" },
                    { "name": "焦作市", "code": "410800000", "longitude": "113.050848", "latitude": "35.124706", "count": "210" },
                    { "name": "濮阳市", "code": "410900000", "longitude": "115.169299", "latitude": "35.769421", "count": "225" },
                    { "name": "许昌市", "code": "411000000", "longitude": "113.956834", "latitude": "34.043383", "count": "155" }
                ];
                //为了提高百度地图性能,本篇例子点位全用label来加载点位
                $.each(clusterList, function (index, data) {
                    // 添加经纬的中心点
                    let point = new BMap.Point(data.longitude, data.latitude);
                    //自定义label样式
                    let template = `
                    <div class="circle-bubble" data-longitude="${data.longitude}" data-latitude="${data.latitude}">
                        <p class="name">${data.name}</p>
                        <p class="count"><span>${data.count}</span>个楼盘</p>
                    </div>`;
                    let clusterLabel = new BMap.Label(template,
                        {
                            position: point, //label 在此处添加点位位置信息
                            offset: new BMap.Size(-46, -46)
                        });
                    clusterLabel.setStyle({
                         "92px",  //
                        height: "92px", //高度
                        border: "0",  //
                        background: "rgba(17,164,60,.9)",    //背景颜色
                        borderRadius: "50%",
                        cursor: "pointer"
                    });
                    clusterLabel.setTitle(data.name);
                    _map.addOverlay(clusterLabel);//添加点位
                    // 当鼠标悬停在label上时显示行政区划边界
                    clusterLabel.addEventListener("mouseover", function () {
                        clusterLabel.setStyle({ background: "rgba(255,102,0,.9)" }); //修改覆盖物背景颜色
                        var regionName = clusterLabel.getTitle();
                        _this.getBoundary(regionName);
                    });
                    // 当鼠标离开时在删除边界折线数据
                    clusterLabel.addEventListener("mouseout", function () {
                        clusterLabel.setStyle({ background: "rgba(17,164,60,.9)" }); //修改覆盖物背景颜色
                        if (win.polygon) {
                            var polyPathArray = new Array();
                            win.polygon.setPath(polyPathArray);
                            _map.removeOverlay(polygon);//清除折线数据
                        }
                    });
    
                    clusterLabel.addEventListener("click", function () {
                        _map.zoomIn();
                        _this.getAllLabel();//获取所有点位数据
                    });
    
                })
    
            }
            // 根据行政区划绘制边界
            getBoundary(regionName) {
                let _map = this.map;
                let boundary = new BMap.Boundary();
                boundary.get(regionName, function (rs) {
                    //行政区域的点有多少个
                    if (rs.boundaries.length === 0) {
                        alert('未能获取当前输入行政区域');
                        return;
                    }
                    for (const itemBoundary of rs.boundaries) {
                        if (!win.polygon) {
                            win.polygon = new BMap.Polygon(itemBoundary, {
                                strokeWeight: 2,
                                strokeColor: "rgb(17,164,60)",
                                fillColor: "rgba(17,164,60, .1)"
                            }); //建立多边形覆盖物
                            _map.addOverlay(polygon);  //添加覆盖物
                        } else {
                            win.polygon.setPath(itemBoundary);
                            _map.addOverlay(polygon);  //添加覆盖物
                        }
                        polygon.enableMassClear();
                    }
                });
            }
    
            //绘制详细楼盘点位信息
            getAllLabel() {
                let _map = this.map;
                _map.clearOverlays();
                //模拟点位数据
                var labelList = [
                    { "name": "楼盘一", "code": "01", "longitude": "113.515919", "latitude": "34.799769", "price": "10000" },
                    { "name": "楼盘二", "code": "02", "longitude": "113.509444", "latitude": "34.4475", "price": "999" },
                    { "name": "楼盘三", "code": "03", "longitude": "113.68175", "latitude": "34.737633", "price": "888" },
                    { "name": "楼盘四", "code": "04", "longitude": "113.280769", "latitude": "34.814961", "price": "777" }
                ];
                $.each(labelList, function (index, data) {
                    let point = new BMap.Point(data.longitude, data.latitude);
                    let houseTemplate = `
                    <div class="house-bubble" data-longitude="${data.longitude}" data-latitude="${data.latitude}">
                        <p>
                            <span class="price">${data.price}</span>
                            <span class="unit">元/㎡</span>
                            <em>|</em>
                            <span class="name">${data.name}</span>
                        </p>
                        <div class="triangle-down"></div>
                    </div>`;
                    let houseLabel = new BMap.Label(houseTemplate,
                        {
                            position: point, //label 在此处添加点位位置信息
                            offset: new BMap.Size(-12, -15)
                        });
                    houseLabel.setStyle({
                        height: "30px", //高度
                        border: "0",  //
                        backgroundColor: "rgba(17,164,60,.9)",
                        borderRadius: "4px",
                        cursor: "pointer"
                    });
                    houseLabel.setTitle(data.name);
                    labelList.push(houseLabel);
                    _map.addOverlay(houseLabel);
    
                    let lastHouseLabel = null;
                    //鼠标点击时打开新标签并关闭上一个标签内容
                    houseLabel.addEventListener("mouseover", function () {
                        houseLabel.setStyle({ background: "rgba(255,102,0,.9)" });
                    });
                    houseLabel.addEventListener("mouseout", function () {
                        houseLabel.setStyle({ background: "rgba(17,164,60,.9)" }); //修改覆盖物背景颜色
                    });
                    //鼠标点击时标签一直存在
                    // houseLabel.addEventListener("click", function () {
                    //     houseLabel.setStyle({ background: "rgba(255,102,0,.9)" });
                    // });
                });
                //addViewLabel(labelData);//加载可视范围点
            }
        }
        win.SearchMap = SearchMap;
    })(window, jQuery)

    信息弹出层:

    //信息窗口模板
               var tpl="<div class='infoBox' data-longitude='"+data.longitude+"' data-latitude='"+data.latitude+"' data-id='"+data.code+"'>" +
                    "<div class='infoArea'><p class='name'>"+data.name+"</p><p class='num'>均价<span class='red'> "+data.num+" </span>万元/m3</p></div>" +
                   "<i class='arrow'><i class='arrow-i'></i></i></div>";
                var infoBox = new BMapLib.InfoBox(map, tpl, {
                    boxStyle: {
                         "160px",
                        minHeight: "50px",
                        marginBottom: "30px",
                        backgroundColor: "white"
                    },
                    closeIconMargin: "15px 10px 4px 4px",
                    closeIconUrl: "img/icon-close.png",
                    enableAutoPan: false,
                    align: INFOBOX_AT_TOP
                });
                //鼠标点击时打开新标签并关闭上一个标签内容
                myLabel.addEventListener("mouseover", function () {
                    if (window.lastInfoBox) {
                        //判断上一个窗体是否存在,若存在则执行close
                        window.lastInfoBox.close();
                    }
                    window.lastInfoBox = infoBox;
                    infoBox.open(point);
                });
               //鼠标点击时标签一直存在
                myLabel.addEventListener("click", function () {
                    window.lastInfoBox=null;
                    infoBox.open(point);
                });

    //根据地图视野动态加载数据,当数据多时此方法用来提高地图加载性能 //由于此篇模拟点位数据较少,视野加载不明显,当数据多时可直观感觉

    function addViewLabel(labels) {
            map.clearOverlays();
            for(var i = 0; i < labels.length; i ++){
                var result = BMapLib.GeoUtils.isPointInRect(labels[i].point, map.getBounds());
                if(result == true) {
                    map.addOverlay(labels[i])
                } else{
                    map.removeOverlay(labels[i]);
                }
            }
        }
  • 相关阅读:
    快速傅里叶变换(FFT)
    【BZOJ】1005: [HNOI2008]明明的烦恼(prufer编码+特殊的技巧)
    【BZOJ】1030: [JSOI2007]文本生成器(递推+ac自动机)
    cf490 C. Hacking Cypher(无语)
    高精度模板2(带符号压位加减乘除开方封包)
    【BZOJ】1004: [HNOI2008]Cards(置换群+polya+burnside)
    【BZOJ】1500: [NOI2005]维修数列(splay+变态题)
    【BZOJ】1064: [Noi2008]假面舞会(判环+gcd+特殊的技巧)
    【BZOJ】1052: [HAOI2007]覆盖问题(贪心)
    【BZOJ】1028: [JSOI2007]麻将(贪心+暴力)
  • 原文地址:https://www.cnblogs.com/Nyan-Workflow-FC/p/13346489.html
Copyright © 2011-2022 走看看