百度地图自定义POI示例

百度地图自定义POI示例

这个示例展示了如何使用百度地图JavaScript API GL来添加自定义POI(兴趣点)标注。

在这里插入图片描述

功能说明

  • 使用 addLabelsToMapTile 方法添加自定义POI标注
  • 支持添加文字标注和图标标注
  • 提供添加和清除标注的功能
  • 支持自定义标注样式(字体大小、颜色、光晕等)

关键点说明

  1. 坐标系统:

    • 地图初始化使用经纬度坐标:new BMapGL.Point(116.41869196404, 39.901641043953)
    • 添加标注使用墨卡托坐标:new BMapGL.Point(12957961.232564565, 4822048.673415739)
  2. 标注配置:

    • displayRange: [13, 21] - 控制标注在什么缩放级别范围内显示
    • textMargin: 8 - 文字边距
    • direction: 3/4 - 标注方位(3表示右侧,4表示下方)
    • uid - 标注的唯一标识符
  3. 样式设置:

    style: {
        fontSize: 30,
        haloSize: 2,
        color: 'rgba(80,92,88,1)',
        strokeColor: '#fff'
    }
    

使用说明

  1. 引入百度地图API:

    <script src="https://api.map.baidu.com/api?type=webgl&v=1.0&ak=您的密钥"></script>
    
  2. 创建地图容器:

    <div id="container"></div>
    
  3. 初始化地图:

    var map = new BMapGL.Map('container');
    var point = new BMapGL.Point(116.41869196404, 39.901641043953);
    map.centerAndZoom(point, 14);
    map.enableScrollWheelZoom();
    
  4. 添加标注:

    • 点击"添加"按钮调用 addLabels() 函数
    • 点击"清除"按钮调用 removeLabels() 函数

参考文档

注意事项

  1. 使用前需要替换为您自己的百度地图API密钥(ak)
  2. 添加标注时需要使用墨卡托坐标系统
  3. 建议根据实际需求调整displayRange以控制标注的显示范围
  4. 可以通过修改style对象来自定义标注的样式
因为最近项目需要,用了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、付费专栏及课程。

余额充值