百度地图使用

AK获取

1.在百度地图开发者平台注册账号  https://lbsyun.baidu.com/

2.创建地图应用

3.获取AK

使用百度地图

1.引入js

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

2.创建一个地图需要的容器(可以定义地图的宽高)

<div id="container"></div>
<style type="text/css">
       /*容器地图的宽高  */
      #container {
        height: 600px;
        width: 800px;
      }
</style>

3.初始化地图

var map = new BmapGL.Map("container")
var  point = new BmapGL.Point(经度,纬度)
map.centerAndZoom(point,16)

添加功能

可以对创建的地图添加很多的功能:鼠标滚动收缩、添加点、画圈、添加文本标注

1.鼠标滚动缩放

map.enableScrollWheelZoom(true);

2.添加点

var marker = new BMapGL.Marker(point);  
map.addOverlay(marker); 

也可以让添加的点链接起来

var lineArr = [];
        // 记录上一个个
        var last = null;
        // 添加事件      
        map.addEventListener("click",e=>{  
            //  有上一个就移除上一个
            last?map.removeOverlay(last):'';       
            // 获取单击点的位置(经度,纬度)
            var p = new BMapGL.Point(e.latlng.lng, e.latlng.lat); 
            // 添加到数组组件
            lineArr.push(p);
            // 创建一个标记
            var m = new BMapGL.Marker(p); 
            // 重新定义上一个
            last = m;
            // 显示标记
            map.addOverlay(m);     

        })

再给鼠标添加事件让点击鼠标时让之前的点链接

map.addEventListener("dblclick",function(){
            tempMarker?map.removeOverlay(tempMarker):'';//如果有tempMarker就移除
			list.push(list[0]);//把第0个点复制一份添加到最后面
			// 绘制线
			var polyline = new BMapGL.Polygon(list, {strokeColor:"blue", strokeWeight:5, strokeOpacity:0.5,fillColor:"#f00",fillOpacity:0.5})
			list = [];//清空list
			map.addOverlay(polyline);
})

完成这些后就得到如下效果的地图

3.添加控件

var scaleCtrl = new BMapGL.ScaleControl();  // 添加比例尺控件
        map.addControl(scaleCtrl);

        var zoomCtrl = new BMapGL.ZoomControl();  // 添加缩放控件
        map.addControl(zoomCtrl);
        
        var cityCtrl = new BMapGL.CityListControl();  // 添加城市列表控件
        map.addControl(cityCtrl);

 4.画圈

var circle = new BMapGL.Circle(point,1000,{strokeColor:"blue", strokeWeight:2, strokeOpacity:0.5}); //创建圆
 map.addOverlay(circle);  

5.添加文本标注

var content = "<strong style='color:red'>中国</strong>";
        var label = new BMapGL.Label(content, {       // 创建文本标注
            position: point,                          // 设置标注的地理位置
            offset: new BMapGL.Size(10, 20)           // 设置标注的偏移量
        })  
        map.addOverlay(label);  

6.搜索

var map = new BMapGL.Map('container');
var point = new BMapGL.Point(113.6648,34.7835);
map.centerAndZoom(point,17);
//定义个本地地图搜索
var local = new BMapGL.LocalSearch(map,{
	renderOptions:{map:map}
})
 $(function(){
	 // 添加input事件
	 $(".keyword").on("input",function(e){
		 // 通过ajax请求服务器地址
		 $.ajax({
			 url:`https://api.map.baidu.com/place/v2/suggestion?query=${$(".keyword").val()}&region=郑州&city_limit=true&output=json&ak=3pu554R4LxktRbjImRnmwFqo7yIxI5yV`,
			 dataType:"jsonp" //类型jsonp
		 })
		 .then(res=>{
			 // 输出请求回来的内容
			 console.log(res);
			 var str = "";
			 //变量result累加str
			 for(var i=0;i<res.result.length;i++){
				 str+=`<div class="item">${res.result[i].name}</div>`
			 }
			 //设置thml
			 $(".tip").html(str);
		 })
	 })
			 
	 //单击tip 获取对应item的值,隐藏tip
	 $(".tip").on("click",".item",function(){
		 //使用代理方法,获取item内容
		 var str = $(this).text();
		 //输出
		 local.search(str); //搜索关键字
		 console.log(str,"this");
		 //清空tip
		 $(".tip").html("");
	 })
	 $.ajax({
		 url:"https://api.map.baidu.com/location/ip?ak=3pu554R4LxktRbjImRnmwFqo7yIxI5yV&ip=&coor=bd09ll",
		 dataType:"jsonp"
	 })
	 .then(res=>{
		 console.log(res);
		 $("body").append(`<p>${res.content.address}</p>`)
	 })
 })

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
因为最近项目需要,用了3个星期研究了一下百度地图的官方demo,并基于其源代码做了一定的修改,部分模仿了官方版的百度地图V5.3.1(version code: 431,目前最新版是6.0.1)的界面。现放出源代码供大家学习研究,修改版例子中的代码已经尽可能注释了,不过本人水平有限,代码质量可能有待提高,请大家勿用于商业用途,因为可能有很多未知BUG。觉得好的话请大家顶! 开发环境: eclipse:Android Developer Tools Build: v22.0.1-685705 JDK:java version "1.7.0_03" 测试环境: 三星GT-i9228 android2.3.6 主要改动: 1、LayersDemo里面把“普通图、卫星图及交通流量图”集成到了PreferencesActivity里面,修改立即生效。 2、MapControlDemo里面把“缩放级别、旋转、俯视”集成到了PreferencesActivity里面,修改立即生效。把截图功能加到了menu里面。 PS:这里顺便说一下新版百度地图怎么控制俯视角度,我查了好久,连官方的手势说明都没找到,被我无意之间发现了:两只手指同时向下滑为俯视,同时向上为恢复,当然也可以点击地图左上角的指南针 3、UISettingsDemo里面把“缩放、平移、双击放大、旋转” 开关手势功能和显示隐藏“缩放控件、指南针位置”UI控件集,成到了PreferencesActivity里面,修改立即生效。 4、LocationOverlayDemo里面增加了比例尺和自定义缩放控件。 5、OverlayDemo只做了位置修改,下面的两个才是重头戏。 6、RoutePlanDemo模仿了百度地图5.3.1的路径规划。 7、OfflineDemo模仿了百度地图5.3.1的离线地图,并集成到一个界面了。 如有问题请参照百度文档,或者联系我QQ472950043。 模仿的版本是百度地图5.3.1 ,大家有需要的话可以到豌豆荚下载历史版本里面下载baiduditu_431.apk

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值