1、获取javascript API 服务方法,首先申请密钥(ak),才可成功载入APIJS文件。

用法例如以下:

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

假设须要限制区域,那么须要引入以下的js

<!-- 区域限制js -->

<script type="text/javascript" src="http://api.map.baidu.com/library/AreaRestriction/1.2/src/AreaRestriction_min.js"></script>

2、设置样式,冲满全屏,弹出窗体的样式

body, html,#l-map{width: 100%;height: 100%;overflow: hidden;margin:0;}

3、调用百度地图

var map = new BMap.Map("l-map");          //创建地图实例

var point = new BMap.Point(111.818239, 41.386087);  //创建点坐标

map.centerAndZoom(point, 5);                 //初始化地图,设置中心点坐标和地图级别

map.enableScrollWheelZoom();

map.addControl(new BMap.NavigationControl());  //加入�默认缩放平移控件

4、加入�缩放平移控件

map.addControl(new BMap.NavigationControl());  //加入�默认缩放平移控件

map.addControl(new BMap.NavigationControl({anchor: BMAP_ANCHOR_TOP_RIGHT, type: BMAP_NAVIGATION_CONTROL_SMALL}));  //右上角,仅包括平移和缩放button

map.addControl(new BMap.NavigationControl({anchor: BMAP_ANCHOR_BOTTOM_LEFT, type: BMAP_NAVIGATION_CONTROL_PAN}));  //左下角,仅包括平移button

map.addControl(new BMap.NavigationControl({anchor: BMAP_ANCHOR_BOTTOM_RIGHT, type: BMAP_NAVIGATION_CONTROL_ZOOM}));  //右下角,仅包括缩放button

map.enableScrollWheelZoom();    //启用滚轮放大缩小,默认禁用

map.enableContinuousZoom();    //启用地图惯性拖拽,默认禁用

5、区域限制必须引入上面的区域限制js

区域限制样例是仅仅显示北京市

var b = new BMap.Bounds(new BMap.Point(116.027143, 39.772348),

new BMap.Point(116.832025, 40.126349));

try {

BMapLib.AreaRestriction.setBounds(map, b);

} catch (e) {

alert(e);

}

6、加入�覆盖物,计时器调用覆盖物

//加入�覆盖物

function getBoundary(){

var bdary = new BMap.Boundary();

bdary.get("内蒙古", function(rs){       //获取行政区域

var count = rs.boundaries.length; //行政区域的点有多少个

for(var i = 0; i < count; i++){

var ply = new BMap.Polygon(rs.boundaries[i], {strokeWeight: 2, strokeColor: "#0000ff" ,fillColor: ""}); //建立多边形覆盖物 fillColor字体显示出来

map.addOverlay(ply);  //加入�覆盖物

map.setViewport(ply.getPath());    //调整视野

}

});

}

//计时器调用加入�覆盖物

setTimeout(function(){

//清除地图覆盖物

map.clearOverlays();

map.centerAndZoom(111.818239, 41.386087, 6);                 // 设置地图坐标,级别

//加入�行政区域覆盖

getBoundary();

}, 1000);

7、加入�标注

//point经纬度,txtinfo提示信息,type图片类型

function addMarker(point, txtInfo, type) {

var infoWindow = "";

var marker = new BMap.Marker(point, { icon: mapIcon(type) });

marker.addEventListener("click", function() {

infoWindow = new BMap.InfoWindow(txtInfo);

this.openInfoWindow(infoWindow);

});

map.addOverlay(marker);       //加入�标注

marker.setAnimation(BMAP_ANIMATION_BOUNCE); //动画效果

}

//创建ICON

function mapIcon(type) {

var mappng;

switch (parseInt(type)) {

case 1:

mappng = "${pageContext.request.contextPath}/images/triangle.png";

break;

case 2:

mappng = "${pageContext.request.contextPath}/images/ban.png";

break;

}

var mapIcon = new BMap.Icon(mappng,

new BMap.Size(24, 24), {

offset: new BMap.Size(0, -5),

imageOffset: new BMap.Size(0, 0)

});

return mapIcon;

}

8、移除标注

map.removeOverlay(marker);          //移除标注点

function removeMarker() {

  var mkrs = map.getOverlays();  //获取地图上的标注,从0開始循环

  for (var i=0; i < mkrs.length;i++) {

   //object Polygon 是行政区域描边覆盖物,不移除

   if(mkrs[i] != "[object Polygon]"){

    map.removeOverlay(mkrs[i]);  //移除标注点

   }

  }

 }

9、加入�文字

 function addTxt(point,txtInfo){

  var opts = {

    position : point,    // 指定文本标注所在的地理位置

    offset   : new BMap.Size(-20, 5)    //设置文本偏移量

  

  }

  var label=new BMap.Label(txtInfo,opts);

  label.setStyle({

    color : "#000000",

    fontSize : "12px",

    height : "20px",

    lineHeight : "20px",

    fontFamily:"微软雅黑",

    border:"#000000"

   });

  map.addOverlay(label);

 }

10、输入地址获取经纬度

public static final String KEY_1 = "您的密钥(ak)";   

      

    /**

     * 返回输入地址的经纬度坐标

     * key lng(经度),lat(纬度)

     */ 

    public static Map<String,String> getGeocoderLatitude(String address){ 

        BufferedReader in = null; 

        try { 

            //将地址转换成utf-8的16进制 

            address = URLEncoder.encode(address, "UTF-8"); 

//       假设有代理,要设置代理,没代理可凝视 

//      System.setProperty("http.proxyHost","192.168.1.188"); 

//      System.setProperty("http.proxyPort","3128"); 

            URL tirc = new URL("http://api.map.baidu.com/geocoder?address="+ address +"&output=json&key="+
KEY_1); 

             

            in = new BufferedReader(new InputStreamReader(tirc.openStream(),"UTF-8")); 

            String res; 

            StringBuilder sb = new StringBuilder(""); 

            while((res = in.readLine())!=null){ 

                sb.append(res.trim()); 

            } 

            String str = sb.toString(); 

            Map<String,String> map = null; 

            if(StringUtils.isNotEmpty(str)){ 

                int lngStart = str.indexOf("lng\":"); 

                int lngEnd = str.indexOf(",\"lat"); 

                int latEnd = str.indexOf("},\"precise"); 

                if(lngStart > 0 && lngEnd > 0 && latEnd > 0){ 

                    String lng = str.substring(lngStart+5, lngEnd); 

                    String lat = str.substring(lngEnd+7, latEnd); 

                    map = new HashMap<String,String>(); 

                    map.put("lng", lng); 

                    map.put("lat", lat); 

                    return map; 

                } 

            } 

        }catch (Exception e) { 

            e.printStackTrace(); 

        }finally{ 

            try { 

                in.close(); 

            } catch (IOException e) { 

                e.printStackTrace(); 

            } 

        } 

        return null; 

    } 

    public static void main(String args[]){ 

        Map<String, String> json = MapAction.getGeocoderLatitude("北京市"); 

        System.out.println("lng : "+json.get("lng")); 

        System.out.println("lat : "+json.get("lat")); 

    }

百度地图js小结的更多相关文章

  1. 百度地图--JS版

    百度地图JS版本 ----选择关键字地图展示对应地址---- CSS body, html { width: %; height: %; margin: ; font-family: "微软 ...

  2. 外部引入的js 判断js脚本加载是否完成,完成后执行 相应的动作(以引入百度地图js为例)

    可以使用JQuery的 $.getScript(url,function(){});方法 $.getScript("http://api.map.baidu.com/getscript?v= ...

  3. 百度地图js根据经纬度定位和拖动定位点

    <!DOCTYPE html><html><head> <meta http-equiv="Content-Type" content=& ...

  4. 百度地图js版定位控件

    一 概述 百度地图在最新版已加入浏览器定位控件,个人认为应该是既高德地图更新了一个浏览器也能定位功能后,百度不甘落后自己简简单单,草草写了个这个功能的定位控件 GeolocationControl 这 ...

  5. 百度地图JS API不能使用position:fixed

    用于放置百度地图的dom元素及其任何一级父元素设置position:fixed属性时,js会报如下错误: Uncaught TypeError: Cannot read property 'offse ...

  6. 百度地图js lite api 支持点聚合

    百度地图lite api 是专门为h5 绘制海量点设计的,但是偏偏忽略掉了点聚合的需求,所以需要自己动手,做一次二次改造. 我们知道点聚合需要引入开源库: MarkerClusterer:  http ...

  7. 百度地图 JS API开发Demo01

    百度地图DEMO     <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http: ...

  8. 关于百度地图js api的getCurrentPosition定位不准确的解决方法

    很久之前帮大叔解决了一个gps坐标转换为百度地图坐标的问题.今天大叔又给我讲百度地图定位不准.我查了一下api,用了官方给出的这样一组函数. //创建查询对象 var geolocation = ne ...

  9. 百度地图 js api 实现 line 居中显示

    项目中有个需求需要在百度地图的中心显示画的线,以前用过mapPanto这个方法,传入坐标就可以将地图平移到这个坐标,不过不知道如何获取线的中心点,看了别人的代码,有以下两个函数可以实现这个功能 get ...

随机推荐

  1. es6 class 中 constructor 方法 和 super

    首先,ES6 的 class 属于一种“语法糖”,所以只是写法更加优雅,更加像面对对象的编程,其思想和 ES5 是一致的. <1>constructor function Point(x, ...

  2. ORA-12537: TNS:connection closed错误处理过程

    https://blog.csdn.net/mchdba/article/details/50018571

  3. gym101431B

    以此纪念我都快忘了的后缀自动机(捂脸) 不过这题有两种做法: 用后缀自动机,先把原串再接遍中间加入特殊连接字符再把原串反接两遍,对这个新构造出的串做后缀自动机.(或者直接建立广义后缀自动机) 下面只要 ...

  4. linux中top命令

    经常用到top命令,也就简单看看进程多不多,卡不卡, 这次在网上找到一个归纳总结的,以供参考. 简介 top 命令是 Linux 下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于 ...

  5. Oracle中生成uuid的方法

    Oracle中生成uuid的方法 下载LOFTER客户端 在Oracle SQL 提供了一个生成uuid的函数sys_guid: http://download.oracle.com/docs/cd/ ...

  6. LR字符串处理

    Action() { strchr和strrchr: //strchr:查找指定字符在一个字符串中第一次出现的位置,然后返回指向该位置的指针. //char *strchr(const char *s ...

  7. Failed to lookup view 'error'

    这个问题在npm run dev进行本地开发时,没有问题.但是在npm run build后,生产服务器上部署时出现问题. 我对本地的路径排查,发现写的没有问题 所以我去了生产的文件夹看路径 我去了s ...

  8. 如何使用Bootstrap4显示和隐藏元素

    如何使用Bootstrap4显示和隐藏元素 为了更快地进行移动设备开发,请使用响应式显示类来按设备显示和隐藏元素.避免创建相同站点的完全不同版本,而是相应地为每个屏幕大小隐藏元素. 要隐藏元素,只需使 ...

  9. springMVC+freemarker实现自定义标签

    在开发过程中,有些需要引用到重复的页面,或者动态的数据 修改数据库是可以实现,但是太麻烦了. freemarker自定义标签在开发中用途很广,就说个入门实例吧 基于springmvc. 首先需要导入对 ...

  10. Django错误大汇总

    1.安装django报错解决方案 找到第一条报错信息: File "c:\users\chenwei\envs\testvir2\lib\site-packages\pip\basecomm ...