热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

【百度地图API】百度API卫星图使用方法和卫星图对比工具

百度地图API推出卫星图接口也有一个月啦~本文除了介绍如何使用百度地图API来操作卫星图外,还顺带制作了个卫星图对比工具。一、百度地图API卫星图调用百度卫星图有两种

百度地图API推出卫星图接口也有一个月啦~  

本文除了介绍如何使用百度地图API来操作卫星图外,还顺带制作了个卫星图对比工具。

 

一、百度地图API卫星图

调用百度卫星图有两种方式,一是地图类型控件,一是地图底图设置。下面分别介绍这两种方法:

 

1、利用控件

使用控件有一大优势,就是地图类型控件上,有百度全部的地图类型,比如二维、三维、卫星等。

而且,只需要一句话,就能简单加上这个控件。

map.addControl(new BMap.MapTypeControl()); //添加地图类型控件

 

看到下图中,右上角那个控件了麽?这个就是地图类型控件啦~

添加她只需一句话,很简单吧。

 

全部源代码:

DOCTYPE html>
<html>
<head>
<meta http-equiv&#61;"Content-Type" content&#61;"text/html; charset&#61;gb2312" />
<title>地图类型控件title>
<script type&#61;"text/Javascript" src&#61;"http://api.map.baidu.com/api?v&#61;1.2">script>
head>
<body>
<div style&#61;"width:520px;height:340px;border:1px solid gray" id&#61;"container">div>
body>
html>
<script type&#61;"text/Javascript">
var map &#61; new BMap.Map("container"); // 创建Map实例
var point &#61; new BMap.Point(116.4035,39.915);map.setCurrentCity("北京"); // 设置地图显示的城市 此项是必须设置的,因为要使用三维图
map.centerAndZoom(point,15); // 初始化地图,设置中心点坐标和地图级别。

map.addControl(
new BMap.MapTypeControl()); //添加地图类型控件
script>

 

 

 

更多关于地图类型控件的知识&#xff1a;&#xff08;初学者可不看&#xff0c;上面的代码已经足够用啦~&#xff09;


MapTypeControl是负责切换地图类型的控件&#xff0c;此类继承Control所有功能。


MapTypeControlOptions表示MapTypeControl构造函数的可选参数。它没有构造函数&#xff0c;但可通过对象字面量形式表示&#xff08;自 1.2 新增&#xff09;。

 

MapTypeControlType常量表示MapTypeControl的外观样式&#xff08;自 1.2 新增&#xff09;。

 

 

 


下面来看看第二种方法。如果你只需要卫星图&#xff0c;不需要别的地图类型&#xff0c;你就需要下面这种方法了。同样相当简单&#xff0c;也是一句话就搞定的事情~

2、修改地图底图默认设置

var map &#61; new BMap.Map("container",{mapType: BMAP_HYBRID_MAP}); //设置卫星图为底图



 

 

二、卫星图对比工具

先来看图。下图中&#xff0c;左边是百度的卫星图&#xff0c;右边是谷歌的卫星图。

大家可以看到&#xff0c;无论是颜色&#xff0c;还是街道数据&#xff0c;都有明显的不同。

当然&#xff0c;如果你学会这些代码&#xff0c;你还可以将其他家API的卫星图拿来对比呀~~

 

对比工具主要是有以下功能&#xff1a;

1、同时展示百度和谷歌的卫星图

// 百度卫星图底图
var bdMap &#61; new BMap.Map("mapBaidu",{mapType: BMAP_HYBRID_MAP});


//谷歌卫星图底图
var ggMap &#61; new google.maps.Map(document.getElementById("mapGoogle"),{mapTypeId: google.maps.MapTypeId.SATELLITE});



2、拖动谷歌地图&#xff0c;百度地图跟着动&#xff08;联动效果&#xff09;

给谷歌地图添加拖拽事件&#xff0c;同理&#xff0c;也可以给百度地图添加。

在这里取了近似值&#xff0c;没有使用坐标转换工具。如果使用的话&#xff0c;应该会更加准确的。&#xff08;搜索线性转换&#xff0c;或者直接看源代码&#xff09;

google.maps.event.addListener(ggMap, &#39;dragend&#39;, function() {
blng &#61; ggMap.center.lng() &#43; 0.0065;
blat &#61; ggMap.center.lat() &#43; 0.0060;
bdMap.panTo(new BMap.Point(blng,blat));
});



3、放大缩小谷歌地图&#xff0c;百度地图也跟着放大和缩小

原理同上。谷歌的地图级别比百度小&#xff0c;所以要找一个地图级别的对应关系。大概是

google.maps.event.addListener(ggMap, &#39;zoom_changed&#39;, function() {
bdMap.setZoom(ggMap.zoom&#43;1);
});

 

 

 

全部源代码&#xff1a;

DOCTYPE html>
<html>
<head>
<meta name&#61;"viewport" content&#61;"initial-scale&#61;1.0, user-scalable&#61;no" />
<meta http-equiv&#61;"content-type" content&#61;"text/html; charset&#61;UTF-8"/>
<title>Google Map VS Baidu Maptitle>
<link href&#61;"http://code.google.com/apis/maps/documentation/Javascript/examples/default.css" rel&#61;"stylesheet" type&#61;"text/css" />
<script type&#61;"text/Javascript" src&#61;"http://maps.googleapis.com/maps/api/js?sensor&#61;false">script>
<script type&#61;"text/Javascript" src&#61;"http://api.map.baidu.com/api?v&#61;1.2">script>
<script type&#61;"text/Javascript">
function initialize() {
var blng;
var blat;
var myOptions &#61; {
zoom:
14,
center:
new google.maps.LatLng(39.90564219683827,116.39948),
panControl:
false,
zoomControl:
false,
scaleControl:
false,
mapTypeId: google.maps.MapTypeId.SATELLITE
}
var ggMap &#61; new google.maps.Map(document.getElementById("mapGoogle"),myOptions);

google.maps.event.addListener(ggMap,
&#39;dragend&#39;, function() {
blng
&#61; ggMap.center.lng() &#43; 0.0065;
blat
&#61; ggMap.center.lat() &#43; 0.0060;
bdMap.panTo(
new BMap.Point(blng,blat));
});
google.maps.event.addListener(ggMap,
&#39;zoom_changed&#39;, function() {
bdMap.setZoom(ggMap.zoom
&#43;1);
});
}
script>
head>
<body onload&#61;"initialize()" style&#61;"width:100%;height:100%;">
<div id&#61;"mapBaidu" style&#61;"width:50%;height:100%;float:left;">
<script type&#61;"text/Javascript">
var bdMap &#61; new BMap.Map("mapBaidu",{mapType: BMAP_HYBRID_MAP}); // 创建Map实例
       var point &#61; new BMap.Point(116.4035,39.915);map.setCurrentCity("北京"); // 设置地图显示的城市 此项是必须设置的,因为要使用三维图

bdMap.centerAndZoom(point,
15); // 初始化地图,设置中心点坐标和地图级别。
bdMap.addControl(new BMap.MapTypeControl()); //添加卫星图控件
bdMap.enableScrollWheelZoom();
script>
div>
<div id&#61;"mapGoogle" style&#61;"width:50%;height:100%;float:left;">div>
body>
<script type&#61;"text/Javascript">



script>
html>




转载于:https://www.cnblogs.com/milkmap/archive/2011/12/01/2270970.html


推荐阅读
  • 使用nodejs爬取b站番剧数据,计算最佳追番推荐
    本文介绍了如何使用nodejs爬取b站番剧数据,并通过计算得出最佳追番推荐。通过调用相关接口获取番剧数据和评分数据,以及使用相应的算法进行计算。该方法可以帮助用户找到适合自己的番剧进行观看。 ... [详细]
  • Python脚本编写创建输出数据库并添加模型和场数据的方法
    本文介绍了使用Python脚本编写创建输出数据库并添加模型数据和场数据的方法。首先导入相应模块,然后创建输出数据库并添加材料属性、截面、部件实例、分析步和帧、节点和单元等对象。接着向输出数据库中添加场数据和历程数据,本例中只添加了节点位移。最后保存数据库文件并关闭文件。文章还提供了部分代码和Abaqus操作步骤。另外,作者还建立了关于Abaqus的学习交流群,欢迎加入并提问。 ... [详细]
  • 本文介绍了使用kotlin实现动画效果的方法,包括上下移动、放大缩小、旋转等功能。通过代码示例演示了如何使用ObjectAnimator和AnimatorSet来实现动画效果,并提供了实现抖动效果的代码。同时还介绍了如何使用translationY和translationX来实现上下和左右移动的效果。最后还提供了一个anim_small.xml文件的代码示例,可以用来实现放大缩小的效果。 ... [详细]
  • Nginx使用(server参数配置)
    本文介绍了Nginx的使用,重点讲解了server参数配置,包括端口号、主机名、根目录等内容。同时,还介绍了Nginx的反向代理功能。 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • 本文介绍了在使用Python中的aiohttp模块模拟服务器时出现的连接失败问题,并提供了相应的解决方法。文章中详细说明了出错的代码以及相关的软件版本和环境信息,同时也提到了相关的警告信息和函数的替代方案。通过阅读本文,读者可以了解到如何解决Python连接服务器失败的问题,并对aiohttp模块有更深入的了解。 ... [详细]
  • 在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板
    本文介绍了在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板的方法和步骤,包括将ResourceDictionary添加到页面中以及在ResourceDictionary中实现模板的构建。通过本文的阅读,读者可以了解到在Xamarin XAML语言中构建控件模板的具体操作步骤和语法形式。 ... [详细]
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • 基于移动平台的会展导游系统APP设计与实现的技术介绍与需求分析
    本文介绍了基于移动平台的会展导游系统APP的设计与实现过程。首先,对会展经济和移动互联网的概念进行了简要介绍,并阐述了将会展引入移动互联网的意义。接着,对基础技术进行了介绍,包括百度云开发环境、安卓系统和近场通讯技术。然后,进行了用户需求分析和系统需求分析,并提出了系统界面运行流畅和第三方授权等需求。最后,对系统的概要设计进行了详细阐述,包括系统前端设计和交互与原型设计。本文对基于移动平台的会展导游系统APP的设计与实现提供了技术支持和需求分析。 ... [详细]
  • Sleuth+zipkin链路追踪SpringCloud微服务的解决方案
    在庞大的微服务群中,随着业务扩展,微服务个数增多,系统调用链路复杂化。Sleuth+zipkin是解决SpringCloud微服务定位和追踪的方案。通过TraceId将不同服务调用的日志串联起来,实现请求链路跟踪。通过Feign调用和Request传递TraceId,将整个调用链路的服务日志归组合并,提供定位和追踪的功能。 ... [详细]
  • 本文介绍了iOS开发中检测和解决内存泄漏的方法,包括静态分析、使用instruments检查内存泄漏以及代码测试等。同时还介绍了最能挣钱的行业,包括互联网行业、娱乐行业、教育行业、智能行业和老年服务行业,并提供了选行业的技巧。 ... [详细]
  • 如何使用PLEX播放组播、抓取信号源以及设置路由器
    本文介绍了如何使用PLEX播放组播、抓取信号源以及设置路由器。通过使用xTeve软件和M3U源,用户可以在PLEX上实现直播功能,并且可以自动匹配EPG信息和定时录制节目。同时,本文还提供了从华为itv盒子提取组播地址的方法以及如何在ASUS固件路由器上设置IPTV。在使用PLEX之前,建议先使用VLC测试是否可以正常播放UDPXY转发的iptv流。最后,本文还介绍了docker版xTeve的设置方法。 ... [详细]
author-avatar
阳光无限好1981
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有