【百度地图API】建立全国银行位置查询系统(三)——如何在地图上添加银行标注

简介: 原文:【百度地图API】建立全国银行位置查询系统(三)——如何在地图上添加银行标注你将在第三章中学会以下知识: 如何在地图上添加带银行logo的标注?(你也可以换成商场logo,酒店logo等) 如何在标注上显示信息窗口,以及添加文字标签等其他覆盖物; 最后,介绍一个获取坐标的给力工具。
原文: 【百度地图API】建立全国银行位置查询系统(三)——如何在地图上添加银行标注

<摘要>你将在第三章中学会以下知识:

  1. 如何在地图上添加带银行logo的标注?(你也可以换成商场logo,酒店logo等)
  2. 如何在标注上显示信息窗口,以及添加文字标签等其他覆盖物;
  3. 最后,介绍一个获取坐标的给力工具。

-----------------------------------------------------------------------------------------------------------------

一、如何添加标注、标签和信息窗口?

img_5672b8879cafd28d5dbe282b9aa85cde.jpg

首先,我们需要创建一个点坐标,利用该点坐标来创建一个标注(Maker),最后将该标注显示在地图上。

比如我们了解到国家博物馆的坐标是116.407804,39.912123(如何获取这个坐标,请查看下文中的坐标拾取工具)。

所以创建这个点,再创建一个标注在这个点上。最关键的一步就是将它显示出来,显示覆盖物用addOverlay。

var pointMarker = new BMap.Point( 116.407804 , 39.912123 ); // 创建标注的坐标
var marker = new BMap.Marker(pointMarker); // 创建标注
map.addOverlay(marker); // 将标注添加到地图中

 

接下来,我们需要在这个标注的基础上,添加一个信息窗口。

为了在标注上添加一个信息窗口,我们需要对该标注建立一个监听事件,当鼠标点击标注后,方能显示信息窗口。

添加事件请使用addEventListener.

 

var infoWindow = new BMap.InfoWindow( " 点击标注后信息窗口就显示了 " ); // 创建信息窗口对象
marker.addEventListener( " click " , function (){ // 给标注添加点击事件
this .openInfoWindow(infoWindow);
});

 

同理,你可以自己添加文字标签label。

其中point是文字标签显示的位置,offset可以设置它的偏移量。{}里的东西默认是可以不写的。

 

var label = new BMap.Label( " 请点击红色标注 " ,{point : pointMarker, 
        offset: new BMap.Size( 3 , - 6 )}); // 定义一个文字标签
map.addOverlay(label);

点击这里,运行该代码。右键点击新打开的窗口,可以查看源代码哦。

 

二、如何添加银行的标注?

但是,大家会不会觉得默认的这个红色标注很丑呢?那么我们一起来换一个标注吧!下面开始讲解,如何自定义标注。

为了看清楚,我把标注放得比较大。你自己可以换张小图片试试。

img_eae66cfb2e08c7122a558ee96030b115.jpg

首先,我们要准备的是一张标注的图片。注意,一定需要一张背景透明的图片。然后定义三家银行的标注样式。有4个地方需要我们来设置。

第一就是银行图标的地址,我们可以把多张银行图标放在一张图上。比如这张图,点击这里下载。

第二是这个标注的大小BMap.Size,需要根据你银行图标的大小来定。

第三个是标注的偏移量offset。为什么要有偏移量呢?因为我们希望图标下面那个小尖尖刚好指在我们需要的坐标点上。

第四个就是相当于CSS sprites的设置了。由于我们的银行图标都放在了同一张图上,所以需要靠imageOffset这个设置来调整显示位置。

具体代码如下:

 

// 创建招商银行的标注图标
var zsIcon = new BMap.Icon( " http://ui-love.com/baidumap/bank/marker.gif " , // 图片地址
new BMap.Size( 40 , 64 ), // 标注显示大小
{
offset:
new BMap.Size( 20 , 64 ), // 标注底部小尖尖的偏移量
imageOffset: new BMap.Size( 0 , 0 ) // 这里相当于CSS sprites
});
// 创建中国银行的标注图标
var zgIcon = new BMap.Icon( " http://ui-love.com/baidumap/bank/marker.gif " , // 图片地址
new BMap.Size( 40 , 64 ), // 标注显示大小
{
offset:
new BMap.Size( 20 , 64 ), // 标注底部小尖尖的偏移量
imageOffset: new BMap.Size( 0 , - 64 ) // 这里相当于CSS sprites
});
// 创建建设银行的标注图标
var jsIcon = new BMap.Icon( " http://ui-love.com/baidumap/bank/marker.gif " , // 图片地址
new BMap.Size( 40 , 64 ), // 标注显示大小
{
offset:
new BMap.Size( 20 , 64 ), // 标注底部小尖尖的偏移量
imageOffset: new BMap.Size( 0 , - 128 ) // 这里相当于CSS sprites
});

 

然后我们分别添加3个银行标注在地图上。点击这里运行代码。源代码如下:

 

<! DOCTYPE html >
< html >
< head >
< meta http-equiv ="Content-Type" content ="text/html; charset=utf-8" />
< title > 酸奶小妹——百度地图API学习 </ title >
< style type ="text/css" >
html
{ height : 100% }
body
{ height : 100% ; margin : 0px ; padding : 0px }
#milkMap
{ height : 400px ; width : 600px ; border : 1px solid blue ; }
</ style >
< script type ="text/javascript" src ="http://api.map.baidu.com/api?v=1.1&services=false" ></ script >
</ head >
< body >
< div id ="milkMap" ></ div >
</ body >
< script type ="text/javascript" >
var map = new BMap.Map( " milkMap " ); // 创建地图实例
var point = new BMap.Point( 116.404 , 39.915 ); // 创建点坐标
map.centerAndZoom(point, 16 ); // 初始化地图,设置中心点坐标和地图级别
map.addControl( new BMap.OverviewMapControl({isOpen: 1 , anchor: BMAP_ANCHOR_TOP_RIGHT})); // 为地图添加鹰眼
map.addControl( new BMap.NavigationControl()); // 为地图添加鱼骨

var myCopyright = new BMap.CopyrightControl({offset: new BMap.Size( 485 , 0 )}) // 设置版权信息偏移量
map.addControl(myCopyright); // 为地图添加版权控件
myCopyright.addCopyright({id : 1 , content : ' <a style="line-height:30px;height:30px;display:block;color:red;background:yellow" href="http://www.cnblogs.com/milkmap/"><img src="http://www.ui-love.com/static/img/uiico.ico" />酸奶小妹的博客园</a> ' });

// 创建招商银行的标注图标
var zsIcon = new BMap.Icon( " http://ui-love.com/baidumap/bank/marker.gif " , // 图片地址
new BMap.Size( 40 , 64 ), // 标注显示大小
{
offset:
new BMap.Size( 20 , 64 ), // 标注底部小尖尖的偏移量
imageOffset: new BMap.Size( 0 , 0 ) // 这里相当于CSS sprites
});
// 创建中国银行的标注图标
var zgIcon = new BMap.Icon( " http://ui-love.com/baidumap/bank/marker.gif " , // 图片地址
new BMap.Size( 40 , 64 ), // 标注显示大小
{
offset:
new BMap.Size( 20 , 64 ), // 标注底部小尖尖的偏移量
imageOffset: new BMap.Size( 0 , - 64 ) // 这里相当于CSS sprites
});
// 创建建设银行的标注图标
var jsIcon = new BMap.Icon( " http://ui-love.com/baidumap/bank/marker.gif " , // 图片地址
new BMap.Size( 40 , 64 ), // 标注显示大小
{
offset:
new BMap.Size( 20 , 64 ), // 标注底部小尖尖的偏移量
imageOffset: new BMap.Size( 0 , - 128 ) // 这里相当于CSS sprites
});

var pointMarker1 = new BMap.Point( 116.403704 , 39.912123 ); // 创建招商银行标注的坐标
var pointMarker2 = new BMap.Point( 116.407804 , 39.916123 ); // 创建中国银行标注的坐标
var pointMarker3 = new BMap.Point( 116.400804 , 39.915123 ); // 创建建设银行标注的坐标
var marker1 = new BMap.Marker(pointMarker1, {icon: zsIcon}); // 创建招商银行标注
var marker2 = new BMap.Marker(pointMarker2, {icon: zgIcon}); // 创建中国银行标注
var marker3 = new BMap.Marker(pointMarker3, {icon: jsIcon}); // 创建建设银行标注
map.addOverlay(marker1); // 将招商银行标注添加到地图中
map.addOverlay(marker2); // 将中国银行标注添加到地图中
map.addOverlay(marker3); // 将建设银行标注添加到地图中

var infoWindow1 = new BMap.InfoWindow( " 你点击了招商银行的标注 " ,{offset: new BMap.Size( 0 , - 64 )});
marker1.addEventListener(
" click " , function (){ // 给招商银行标注添加点击事件
this .openInfoWindow(infoWindow1); // 打开招商银行的窗口
});
var infoWindow2 = new BMap.InfoWindow( " 你点击了中国银行的标注 " ,{offset: new BMap.Size( 0 , - 64 )});
marker2.addEventListener(
" click " , function (){ // 给中国银行标注添加点击事件
this .openInfoWindow(infoWindow2); // 打开中国银行的窗口
});
var infoWindow3 = new BMap.InfoWindow( " 你点击了建设银行的标注 " ,{offset: new BMap.Size( 0 , - 64 )});
marker3.addEventListener(
" click " , function (){ // 给建设银行标注添加点击事件
this .openInfoWindow(infoWindow3); // 打开建设银行的窗口
});
</ script >
</ html >

 

--------------------------------------------------------------------------------------------------------------------

小贴士:什么是覆盖物?

答:覆盖物包括了标注Marker、文字标签Label、信息窗口InfoWindow、圆形Circle、多边形Polygon,以及折线Polyline。

添加任何一个覆盖物都需要map.addOverlay();这个函数。

 

如何添加其他覆盖物呢?你可以到API的官方网站上查询类参考->覆盖物

--------------------------------------------------------------------------------------------------------------------

 

三、找坐标的使用工具——坐标拾取系统

1、进入该工具网址:http://openapi.baidu.com/map/pick/index.html

2、在搜索框中输入你想查询位置的中文名称,例如“安定门”

img_eb00f8833edf3f6a970695e09b58d4fa.jpg

3、找到合适的位置,点击鼠标右键开启添加标注功能。(小窍门:地图级别越高,位置越精确,建议把地图级别开到17或者18级哦~)

4、开启功能后,你就可以左键点击地图了。无论你点在哪里,网页的右边都会出现一组坐标信息,这就是当前小红点的坐标了。

img_7edd1be00667c9d35dfef29b04c032c6.jpg

5、如果你想改变小红点的位置,可以直接点击地图上另外的点,也可以拖动小红点。

注意:如果你要拖动地图,请先点击鼠标右键,关闭添加标注的功能。

 

-----------------------------------------------------------------------------------------------------------------------

学到这里,大家已经可以动手自己做一张自定义的银行分布图了。

主要步骤:

1、利用工具找到银行的地理位置,也就是坐标。

2、把银行名称、地址、坐标等内容存入数据库。

img_558d4a05e87dc2da30d0ddd13bcdcdd9.jpg

3、创建一个搜索条,查询用户输入的关键字。比如,用户输入“大望路 招商银行”。

4、查询数据库,找到数据2符合条件。于是在(106.40,30.91)这个点上,添加一个招商银行的标注。

注意:这里显示的标注是自定义标注,就是说,如果查询的是招商银行,就显示招商银行的标注;查询的是建设银行,就显示建设银行的标注。

5、最后,利用panto或者setCenter把地图的中心移到银行标注的坐标点。

 

// 以下二者选其一即可。建议选第二个,因为地图平移的动画。
setCenter(markerPoint); // 重新设置地图的中心点
panto(markerPoint); // 将地图中心点平移到坐标点

 

至于怎样建立数据库,我这里就不多说了,因为不太涉及到GIS或者API的东西。

有兴趣的同学可以去学习一下数据库,还有PHP或者.NET等后台程序。

------------------------------------------------------------------------------------------------------------------------

 

如果我们没有自己的数据库,也想建立一个银行网点的分布图,应该如何做呢?

在下一章,我们将学会,如何利用百度地图的数据库来建立全国银行网点的查询地图。

目录
打赏
0
0
0
0
216
分享
相关文章
Spring AI与DeepSeek实战四:系统API调用
在AI应用开发中,工具调用是增强大模型能力的核心技术,通过让模型与外部API或工具交互,可实现实时信息检索(如天气查询、新闻获取)、系统操作(如创建任务、发送邮件)等功能;本文结合Spring AI与大模型,演示如何通过Tool Calling实现系统API调用,同时处理多轮对话中的会话记忆。
257 57
利用Apipost轻松实现用户充值系统的API自动化测试
API在现代软件开发中扮演着连接不同系统与模块的关键角色,其测试的重要性日益凸显。传统API测试面临效率低、覆盖率不足及难以融入自动化工作流等问题。Apipost提供了一站式API自动化测试解决方案,支持零代码拖拽编排、全场景覆盖,并可无缝集成CI/CD流程。通过可视化界面,研发与测试人员可基于同一数据源协作,大幅提升效率。同时,Apipost支持动态数据提取、性能压测等功能,满足复杂测试需求。文档还以用户充值系统为例,详细介绍了从创建测试用例到生成报告的全流程,帮助用户快速上手并提升测试质量。
深入研究:淘宝天猫商品详情查询API详解
淘宝开放平台提供一系列API接口,帮助开发者获取淘宝商品的详细信息并集成到自有应用中。主要功能包括:获取单个商品详情(item_get)、评论信息(item_review)、快递费用(item_fee)、等。此外,还支持搜索商品(item_search)、按图搜索(item_search_img)、优惠券查询(item_search_coupon)、类目信息(item_cat_get)等功能。返回数据通常为JSON格式,包含商品标题、价格、库存、主图链接等基本信息,以及HTML格式的详细描述内容,方便开发者解析与展示。
API数据源:轻松接入各类业务系统数据
在数字化转型中,企业面临多样化的数据需求。Quick BI推出API数据源功能,支持广泛的数据接入,包括实时天气、电商交易及内部业务数据,极大丰富了可分析数据范围。该功能提供灵活的连接方式(抽取和直连模式)、多元授权机制(基础认证、前置请求)和自动化数据解析,降低了操作门槛,提升了配置效率。通过动态Token获取等最佳实践,确保数据安全与实时性,满足企业具体业务需求。了解更多,请访问Quick BI官方文档或瓴羊官网。
254 77
单页图床HTML源码+本地API接口图床系统源码
图床系统是一种用于存储和管理图片文件的在线服务。它允许用户上传图片文件,并生成相应的图片链接,从而方便用户在网页、社交媒体或其他平台上分享图片。
92 2
单页图床HTML源码+本地API接口图床系统源码
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
107 5
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
速卖通商品列表接口(以 AliExpress Affiliate 商品查询 API 为例)
以下是使用 Python 调用速卖通商品列表接口(以 AliExpress Affiliate 商品查询 API 为例)的代码示例。该示例包含准备基础参数、生成签名、发送请求和处理响应等关键步骤,并附有详细注释说明。代码展示了如何通过公共参数和业务参数构建请求,使用 HMAC-SHA256 加密生成签名,确保请求的安全性。最后,解析 JSON 响应并输出商品信息。此接口适用于商品监控、数据采集与分析及商品推荐等场景。注意需通过 OAuth2.0 获取 `access_token`,并根据官方文档调整参数和频率限制。
java语言后台管理若依框架-登录提示404-接口异常-系统接口404异常如何处理-登录验证码不显示prod-api/captchaImage 404 (Not Found) 如何处理-解决方案优雅草卓伊凡
java语言后台管理若依框架-登录提示404-接口异常-系统接口404异常如何处理-登录验证码不显示prod-api/captchaImage 404 (Not Found) 如何处理-解决方案优雅草卓伊凡
443 5
位置定位 api
引用:http://www.iteye.com/news/23408 如果你经常关注技术领域,你可能对一些大的地理位置(Geoloaction)服务已经很熟悉了,比如Google地图、Foursquare、Bing地图,甚至Twitter的地理位置服务,也知道他们的API运用。
1250 0
1688API最新指南:商品详情接口接入与应用
本指南介绍1688商品详情接口的接入与应用,该接口可获取商品标题、价格、规格、库存等详细信息,适用于电商平台开发、数据分析等场景。接口通过商品唯一标识查询,支持HTTP GET/POST请求,返回JSON格式数据,助力开发者高效利用1688海量商品资源。
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等