zoukankan      html  css  js  c++  java
  • 【百度地图API】暑假放假回老家——城市切换功能

    任务描述:

      酸奶小妹放寒假啦,要从北京呼啦一下飞回重庆呢。现在百度地图API上不能直接切换城市,怎么办呢?

    如何实现:

      利用API先搜索到要去城市,然后再让搜索到的城市显示在地图中心点。

      (百度地图上的实现方式是,给后端一个请求,后端返回该城市的经纬度)

    图示:

    运行代码:请点击这里

    代码:

    <!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>
    <meta http-equiv="Content-Type" content="text/html; charset=gb2312"/>
    <meta name="keywords" content="百度地图,百度地图API,百度地图自定义工具,百度地图所见即所得工具"/>
    <meta name="description" content="百度地图API自定义地图,帮助用户在可视化操作下生成百度地图"/>
    <title>从北京到重庆</title>
    <script type="text/javascript" src="http://api.map.baidu.com/api?&v=1.2">
    </script>
    </head>
    <body>
    <p>我要去<input id="txtSearch" type="text" value="重庆"/><input type="button" value="GO" onclick="search()"/></p>
    <div style="520px;height:340px;border:1px solid gray;" id="container"></div>
    </body>
    <script type="text/javascript">
    function $(id){
    return document.getElementById(id); //定义$
    }
    var map =new BMap.Map("container"); //创建地图
    map.centerAndZoom(new BMap.Point(116.330599, 39.95536), 10); //初始化地图

    var city =new BMap.LocalSearch(map,{renderOptions:{map:map,autoViewport:true}}); //地图显示到查询结果处

    function search(){
    var s = $("txtSearch").value;
    city.search(s);
    //查找城市
    }
    </script>
    </html>

    2012-02-07  更新一下API1.2的代码:

    原理:localsearch关键词,比如“西单”。

    在回调函数里,获取第一个POI的经纬度,并且该点为中心点。

    <!DOCTYPE html>
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
    <title>西单</title>
    <script type="text/javascript" src="http://api.map.baidu.com/api?v=1.2"></script>
    </head>
    <body>
    <div style="520px;height:340px;border:1px solid gray" id="container"></div>
    </body>
    </html>
    <script type="text/javascript">
    var map = new BMap.Map("container");
    map.centerAndZoom(
    new BMap.Point(116.404, 39.915), 11);

    function myFun(){
    var pp = local.getResults().getPoi(0).point;
    map.centerAndZoom(pp,
    18);
    }
    var local = new BMap.LocalSearch(map, {
    onSearchComplete: myFun
    });
    local.search(
    "西单");
    </script>



  • 相关阅读:
    python day05
    python day04
    python day03
    python day02
    计算机基本了解
    流程控制
    MFC程序中创建文件夹(文件路径)
    svn移动目录并且保存历史日志
    C++单例模式的问题
    PtInRect 的详细范围
  • 原文地址:https://www.cnblogs.com/milkmap/p/1914106.html
Copyright © 2011-2022 走看看