百度地圖API 根據地址查詢經緯度

html頁面。引用上API:javascript

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title>根據地址查詢經緯度</title>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <script type="text/javascript" src="http://api.map.baidu.com/api?v=1.3"></script>
</head>
<body>
</body>

直接引用了1.3的版本,要引用1.3版本以上的話要加上key:html

<script type="text/javascript" src="http://api.map.baidu.com/api?v=1.5&ak=您的密鑰"></script>

成功引用了百度地圖API。接下來就是要調用他的一些方法了:java

首先在body中添加一個div,用來加載地圖用,簡單寫下樣式。api

<div id="container" 
    style="position: absolute;
        margin-top:30px; 
        width: 730px; 
        height: 590px; 
        top: 50; 
        border: 1px solid gray;
        overflow:hidden;">
</div>

而後是寫javascript代碼,來調用api中的方法。首先建立一個地圖,而後設置地圖顯示的中心地圖,及顯示的放大倍數:動畫

<script type="text/javascript">
    var map = new BMap.Map("container");
    map.centerAndZoom("上海", 15);</script>

而後,啓動地圖的方法縮小功能,以及地圖的拖拽功能:ui

map.enableScrollWheelZoom();    //啓用滾輪放大縮小,默認禁用
map.enableContinuousZoom();    //啓用地圖慣性拖拽,默認禁用

爲了使用地圖更加方便,咱們還能夠添加上縮放的平移控件,以及地圖的縮略圖控件,並設置他要顯示的位置:this

map.addControl(new BMap.NavigationControl());  //添加默認縮放平移控件
map.addControl(new BMap.OverviewMapControl()); //添加默認縮略地圖控件
map.addControl(new BMap.OverviewMapControl({ isOpen: true, anchor: BMAP_ANCHOR_BOTTOM_RIGHT }));   //右下角,打開
「BMAP_ANCHOR_BOTTOM_RIGHT」爲控件顯示的位置,表示控件位於地圖的右下角,能夠按照本身的喜歡添加參數值。

主要有一下四種:
BMAP_ANCHOR_TOP_LEFT 表示控件定位於地圖的左上角。
BMAP_ANCHOR_TOP_RIGHT 表示控件定位於地圖的右上角。
BMAP_ANCHOR_BOTTOM_LEFT 表示控件定位於地圖的左下角。
BMAP_ANCHOR_BOTTOM_RIGHT 表示控件定位於地圖的右下角。

  

好了,地圖的一些基本設置已經添加上了,若是要其餘的功能,還能夠去經過查看百度地圖API的Demo來獲取調用的方法(http://developer.baidu.com/map/jsdemo.htm)。spa

接下來就是要是實現咱們的主要功能了。
首先,先在頁面上添加兩個文本框,和一個查詢按鈕。第一個文本框是用來輸入要查詢的地址,第二個文本框是用來顯示查詢所得的經緯度。html代碼就所有寫完了。
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title>根據地址查詢經緯度</title>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <script type="text/javascript" src="http://api.map.baidu.com/api?v=1.3"></script>
</head>
<body style="background:#CBE1FF">
    <div style="width:730px;margin:auto;">   
        要查詢的地址:<input id="text_" type="text" value="寧波天一廣場" style="margin-right:100px;"/>
        查詢結果(經緯度):<input id="result_" type="text" />
        <input type="button" value="查詢" onclick="searchByStationName();"/>
        <div id="container" 
            style="position: absolute;
                margin-top:30px; 
                width: 730px; 
                height: 590px; 
                top: 50; 
                border: 1px solid gray;
                overflow:hidden;">
        </div>
    </div>
</body>

 接下來就是要構建一個查詢:code

var localSearch = new BMap.LocalSearch(map);
localSearch.enableAutoViewport(); //容許自動調節窗體大小

而後咱們就能夠開始作最關鍵的一步了,就是獲取地址的具體經緯度:orm

function searchByStationName() {
  var keyword = document.getElementById("text_").value;
  localSearch.setSearchCompleteCallback(function (searchResult) {
    var poi = searchResult.getPoi(0);
    document.getElementById("result_").value = poi.point.lng + "," + poi.point.lat; //獲取經度和緯度,將結果顯示在文本框中
    map.centerAndZoom(poi.point, 13);
  });
  localSearch.search(keyword);

 

 

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title>根據地址查詢經緯度</title>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <script type="text/javascript" src="http://api.map.baidu.com/api?v=1.3"></script>
</head>
<body style="background:#CBE1FF">
    <div style="width:730px;margin:auto;">   
        要查詢的地址:<input id="text_" type="text" value="寧波天一廣場" style="margin-right:100px;"/>
        查詢結果(經緯度):<input id="result_" type="text" />
        <input type="button" value="查詢" onclick="searchByStationName();"/>
        <div id="container" 
            style="position: absolute;
                margin-top:30px; 
                width: 730px; 
                height: 590px; 
                top: 50; 
                border: 1px solid gray;
                overflow:hidden;">
        </div>
    </div>
</body>
<script type="text/javascript">
    var map = new BMap.Map("container");
    map.centerAndZoom("寧波", 12);
    map.enableScrollWheelZoom();    //啓用滾輪放大縮小,默認禁用
    map.enableContinuousZoom();    //啓用地圖慣性拖拽,默認禁用

    map.addControl(new BMap.NavigationControl());  //添加默認縮放平移控件
    map.addControl(new BMap.OverviewMapControl()); //添加默認縮略地圖控件
    map.addControl(new BMap.OverviewMapControl({ isOpen: true, anchor: BMAP_ANCHOR_BOTTOM_RIGHT }));   //右下角,打開

    var localSearch = new BMap.LocalSearch(map);
    localSearch.enableAutoViewport(); //容許自動調節窗體大小
function searchByStationName() {
    map.clearOverlays();//清空原來的標註
    var keyword = document.getElementById("text_").value;
    localSearch.setSearchCompleteCallback(function (searchResult) {
        var poi = searchResult.getPoi(0);
        document.getElementById("result_").value = poi.point.lng + "," + poi.point.lat;
        map.centerAndZoom(poi.point, 13);
        var marker = new BMap.Marker(new BMap.Point(poi.point.lng, poi.point.lat));  // 建立標註,爲要查詢的地方對應的經緯度
        map.addOverlay(marker);
        var content = document.getElementById("text_").value + "<br/><br/>經度:" + poi.point.lng + "<br/>緯度:" + poi.point.lat;
        var infoWindow = new BMap.InfoWindow("<p style='font-size:14px;'>" + content + "</p>");
        marker.addEventListener("click", function () { this.openInfoWindow(infoWindow); });
        // marker.setAnimation(BMAP_ANIMATION_BOUNCE); //跳動的動畫
    });
    localSearch.search(keyword);
} 
</script>
</html>

最後代碼能夠改爲:

<%@ Register src="Controls/LansiMap.ascx" tagname="LansiMap" tagprefix="uc1" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title>根據地址查詢經緯度</title>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <script type="text/javascript" src="http://api.map.baidu.com/api?v=1.3"></script>
</head>
<body style="background:#CBE1FF">
    <form id="form1" runat="server">
    <div style="width:730px;margin:auto;">   
        要查詢的地址:<input id="text_" type="text" value="上海" runat="server" style="margin-right:100px;"/>
        查詢結果(經緯度):<input id="result_" type="text" />
        <input type="button" value="查詢" onclick="searchByStationName();"/>
        <hr />
        <div id="container" 
            style="position: absolute;
                margin-top:30px; 
                width: 730px; 
                height: 590px; 
                top: 50; 
                border: 1px solid gray;
                overflow:hidden;">
                <uc1:LansiMap ID="LansiMap1" runat="server" />
        </div>
    </div>
    </form>
</body>
<script type="text/javascript">
    var map = new BMap.Map("container");

    map.centerAndZoom(new BMap.Point(121.4, 31.2), 11);
    map.addControl(new BMap.NavigationControl());

    var localSearch = new BMap.LocalSearch(map);

function searchByStationName() {

    var keyword = document.getElementById("text_").value;
    localSearch.setSearchCompleteCallback(function (searchResult) {
        var poi = searchResult.getPoi(0);
        document.getElementById("result_").value = poi.point.lng + "," + poi.point.lat;

    });
    localSearch.search(keyword);
} 
</script>
</html>
相關文章
相關標籤/搜索