網頁基於百度地圖定位


一、前言

  在做網站時,客戶的需求是需要在網站上顯示該公司的地理位置。基於此需求我使用百度地圖實現的地圖如下。

二、實現地圖效果

  

 

三、使用html+css+js 的代碼如下

  

<!DOCTYPE HTML>
<html>

<head>
    <title>測試使用百度地圖定位</title>
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <link href="css/bootstrap.css" rel='stylesheet' type='text/css' />
    <script src="http://api.map.baidu.com/api?v=1.4" type="text/javascript"></script>
</head>

<body>

    <div class="about_top">
        <div class="container">
            <div class="about" style="padding-top:1em;">
                <h3>聯系我們</h3>
                <div class="map">
                    <div id="container" style="width:100%;;min-height:600px;"></div>
                </div>
                <div class="contact zxx-contact">
                    <div class="col-md-6 contact_left">
                        
                        <p>電話:0000-5555555 | 88888888</p>
                        <p>地址:貴州省貴陽市花溪區貴州大學北校區</p>
                    </div>
                    <div class="col-md-6 contact_left">
                            <p>傳真:0859-5555555</p>
                            <p>電子郵件:1123195494@qq.com</p>
                        </div>

                    <div class="clearfix"> </div>
                </div>
            </div>
            <div class="copy" style="margin-top:20px;">
                <p>Copyright &copy; 2019-2020 幸福摩天輪</p>
            </div>
        </div>
    </div>
    <script type="text/javascript">
        //創建和初始化地圖函數:
        function initMap() {
            createMap(); //創建地圖
            setMapEvent(); //設置地圖事件
            addMapControl(); //向地圖添加控件
            addMarker(); //向地圖中添加marker
        }

        //創建地圖函數:
        function createMap() {
            var map = new BMap.Map("container"); //在百度地圖容器中創建一個地圖
            var point = new BMap.Point(106.6706,26.451518); //定義一個中心點坐標
            map.centerAndZoom(point, 16); //設定地圖的中心點和坐標並將地圖顯示在地圖容器中
            window.map = map; //將map變量存儲在全局
        }

        //地圖事件設置函數:
        function setMapEvent() {
            map.enableDragging(); //啟用地圖拖拽事件,默認啟用(可不寫)
            map.enableScrollWheelZoom(); //啟用地圖滾輪放大縮小
            map.enableDoubleClickZoom(); //啟用鼠標雙擊放大,默認啟用(可不寫)
            map.enableKeyboard(); //啟用鍵盤上下左右鍵移動地圖
        }

        //地圖控件添加函數:
        function addMapControl() {
            //向地圖中添加縮放控件
            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);
        }

        //標注點數組
        var markerArr = [{
            title: "&nbsp;貴州比特軟件有限公司&nbsp;",
            content: "單位地址:貴州省貴陽市花溪區貴州大學北校區<br/>電話:0000-888888&nbsp;0000-000000&nbsp;<br/>傳真:0851-888888&nbsp;<br/>電子郵件:1123195494@qq.com",
            point: "106.6706|26.451518",
            isOpen: 0,
            icon: {
                w: 23,
                h: 25,
                l: 0,
                t: 21,
                x: 9,
                lb: 12
            }
        }];
        //創建marker
        function addMarker() {
            for (var i = 0; i < markerArr.length; i++) {
                var json = markerArr[i];
                var p0 = json.point.split("|")[0];
                var p1 = json.point.split("|")[1];
                var point = new BMap.Point(p0, p1);
                var iconImg = createIcon(json.icon);
                var marker = new BMap.Marker(point, {
                    icon: iconImg
                });
                var iw = createInfoWindow(i);
                var label = new BMap.Label(json.title, {
                    "offset": new BMap.Size(json.icon.lb - json.icon.x + 10, -20)
                });
                marker.setLabel(label);
                map.addOverlay(marker);
                label.setStyle({
                    borderColor: "#808080",
                    color: "#333",
                    cursor: "pointer"
                });

                (function () {
                    var index = i;
                    var _iw = createInfoWindow(i);
                    var _marker = marker;
                    _marker.addEventListener("click", function () {
                        this.openInfoWindow(_iw);
                    });
                    _iw.addEventListener("open", function () {
                        _marker.getLabel().hide();
                    })
                    _iw.addEventListener("close", function () {
                        _marker.getLabel().show();
                    })
                    label.addEventListener("click", function () {
                        _marker.openInfoWindow(_iw);
                    })
                    if (!!json.isOpen) {
                        label.hide();
                        _marker.openInfoWindow(_iw);
                    }
                })()
            }
        }
        //創建InfoWindow
        function createInfoWindow(i) {
            var json = markerArr[i];
            var iw = new BMap.InfoWindow("<b class='iw_poi_title' title='" + json.title + "'>" + json.title +
                "</b><div class='iw_poi_content'>" + json.content + "</div>");
            return iw;
        }
        //創建一個Icon
        function createIcon(json) {
            var icon = new BMap.Icon("http://map.baidu.com/image/us_cursor.gif", new BMap.Size(json.w, json.h), {
                imageOffset: new BMap.Size(-json.l, -json.t),
                infoWindowOffset: new BMap.Size(json.lb + 5, 1),
                offset: new BMap.Size(json.x, json.h)
            })
            return icon;
        }

        initMap(); //創建和初始化地圖
    </script>
</body>

</html>


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM