百度地图开发-绘制点线提示框 07

简介: 百度地图开发-绘制点线提示框 07

上一篇推文简单介绍了与地图的交互,如移动,缩放,点击,截图等功能,都是很常见的业务。接下来就让我们一起学习在地图上面打点,标注信息,绘制线和面等功能。



标记点、绘制线、面、增加提示信息


关于在百度地图上绘制点的功能,其实有很大的作用,比如我们在地图中查询饭店,满足要求的都可以用标记点的形式展示出来,用户可以一目了然的看到具体位置。同时如果可以在标记的点上添加对应饭店的弹窗信息,那么用户就更能清晰的看到。


点标记


点标记用来在地图上标记任何位置,例如用户位置、车辆位置、店铺位置等一切带有位置属性的事物。


添加点标记


 //取得当前的位置
    LatLng point=new LatLng(currentLocation.getLatitude(),currentLocation.getLongitude());
    //构建Marker图标
    BitmapDescriptor bitmap= BitmapDescriptorFactory.fromResource(R.drawable.flag);
    //在地图上添加Marker并显示
    mBaiduMap.addOverlay(new MarkerOptions().position(point).icon(bitmap));



点击添加标记后,就可以在当前位置处添加标记信息。


标记点


对于Marker,百度官方还是给的自定义权限挺高的,可以对其进行设置图标、动画类型、透明度、是否可拖拽、标题等都可进行调整,根据需求进行自定义操作。同时教程说还可对标记点增加点击和拖拽事件。


绘制线


根据对应的教程写法,可以实现绘制折线、虚线、分段颜色绘制线、分段纹理绘制线,通过整个功能可以绘制各种各样的规划路线或物体轨迹。


 //构建折线点坐标
    LatLng p1 = new LatLng(39.077218, 117.072102);
    LatLng p2 = new LatLng(39.007423, 117.110989);
    LatLng p3 = new LatLng(39.077218, 117.172345);
    List<LatLng> points = new ArrayList<LatLng>();
    points.add(p1);
    points.add(p2);
    points.add(p3);
    //设置折线的属性
    OverlayOptions mOverlayOptions = new PolylineOptions()
              .width(10)
              .color(0xAAFF0000)
              .points(points);
    //在地图上绘制折线
    Overlay mPolyline = mBaiduMap.addOverlay(mOverlayOptions);



对于线的属性有多种可供设置的,常用属性如下:color颜色、width宽度、Points坐标列表、colorsvalues分段颜色值列表、extralnfo额外信息等都是可以进行调整的。


也可以添加线的点击事件,当某些场合需要点击绘制的路线时可以使用。


对于绘制这块还可以绘制弧线,绘制多边形,绘制圆等可以参考百度地图教程自己按需进行实现即可。


接下来添加文字和信息窗,其实也就是弹窗信息。


文字覆盖物


其实就是在地图的某一个点,来用文字来进行表示


LatLng ll=new LatLng(39.077218,117.072102);
 OverlayOptions mTextOptions=new TextOptions().text("阿辉最牛逼")
    .bgColor(0xAAFFFF00) //背景色
    .fontSize(24) //字号
    .fontColor(0xFFFF00FF) //文字颜色
    .rotate(-30) //旋转角度
    .position(ll);
  Overlay mText=mBaiduMap.addOverlay(mTextOptions);



添加信息框


这块教程中说了两种方式可以实现信息框的显示,一种是使用View构造InfoWindow另一种是使用BitmpDescriptor构造InfoWindow。我们这里简单实现下第一种即可。


 //添加信息框
    Button button=new Button(getApplicationContext());
    button.setBackgroundResource(R.drawable.flag);
    button.setText("你好阿辉");
    LatLng p1 = new LatLng(39.007423, 117.110989);
    mBaiduMap.showInfoWindow(new InfoWindow(button,p1,-100));


弹出框


这里我只是临时找了一个图片来弹出框的底图的,先把功能实现了再说。大家在使用的过程中要做一些好看一点的图,这样子软件的整体美观就提高了。


基本上和地图的交互就介绍到这里,目前只是简单的说了说比较常用的,至于一些细节功能还是需要去看看百度的官方文档,虽然我对那文档不是很感冒。

目录
相关文章
|
XML JSON 安全
Gob实践全攻略,数据传输利器
Gob实践全攻略,数据传输利器
336 0
|
API Android开发 开发者
Android 12 适配指南——SplashScreen
Android 12(API 31)引入了 SplashScreen 相关API,用于开发Android应用的启动页。 SplashScreen相关API的引入影响在Andorid 12设备上运行的所有应用。若开发者未进行SplashScreen的适配工作,在应用冷启动和温启动时,可能会呈现两个启动页先后出现的情况(Android SplashScreen启动页 + Android应用自定义开发的启动页或引导页)。
2637 0
Android 12 适配指南——SplashScreen
|
JavaScript
vue3-在自定义hooks使用useRouter 报错问题
vue3-在自定义hooks使用useRouter 报错问题
2238 0
|
安全
阿里云服务器被xmrigMiner及pnscan及伪装httpd的病毒入侵排查记录
阿里云服务器被xmrigMiner及pnscan及伪装httpd的病毒入侵排查记录
1444 0
|
11月前
|
数据库连接 PHP Apache
PHP在Apache中如何运行?
PHP在Apache中如何运行?
361 5
|
11月前
|
数据采集 存储 监控
Java爬虫:数据采集的强大工具
在数据驱动的时代,Java爬虫技术凭借其强大的功能和灵活性,成为企业获取市场信息、用户行为及竞争情报的关键工具。本文详细介绍了Java爬虫的工作原理、应用场景、构建方法及其重要性,强调了在合法合规的前提下,如何有效利用Java爬虫技术为企业决策提供支持。
|
XML Java 数据库连接
springboot中整合mybatis及简单使用
这篇文章介绍了如何在Spring Boot项目中整合MyBatis,包括依赖引入、配置数据源、创建测试表、编写Mapper接口和XML文件、以及创建Service和Controller层的步骤。
springboot中整合mybatis及简单使用
|
12月前
微信接口报错 "errcode":40163,"errmsg":"code been used, 如何处理?
【10月更文挑战第11天】微信接口报错 "errcode":40163,"errmsg":"code been used, 如何处理?
5808 1
|
Web App开发 Go iOS开发
【IOS】教你如何在手机端轻松安装 ipa 文件 -(安装器已失效 21.10)
【IOS】教你如何在手机端轻松安装 ipa 文件 -(安装器已失效 21.10)
|
存储 人工智能 安全
大环境下AI发展迅速,如何保证AI的安全问题?
保障AI安全的关键措施包括:数据隐私保护(加密、访问控制、脱敏、共享协议)、模型安全(验证、鲁棒性、监测、更新)、用户信息保护(透明收集、匿名化、保密协议)、网络安全(实时监测、防护措施)和合规伦理(遵守法规、融入设计)。此外,安全培训和意识提升也是重要一环。多角度策略确保AI技术的安全、健康和可持续发展。
2376 0