Flutter接入百度地图总结

SDK 版本
Flutter 3.10.5
flutter_baidu_mapapi_map 3.6.0
flutter_bmflocation 3.6.0

截止目前为止百度地图相关的sdk版本都是3.6.0。

flutter百度地图接入官方文档

配置相关API_KEY和AndroidManifest都可以参考官网的介绍。同时强烈建议将最新版本的DEMO可以下载下来试运行下

接下来主要是官网没有提到的

  1. 安卓端需要创建自己的application,并继承BmfMapApplication,否则安卓端页面在使用百度地图会立即崩溃闪退,同时修改AndroidManifest.xml里的android:name

  1. android/app/src目录下配置build.gradle,需要配置packagingOptions,参考如下

具体可以参考官网最新的3.6.0的demo

到目前为止,基本上大多数人都可以运行了;接下来提几个可能会遇到的注意事项:

依赖库的冲突问题

  • firebase_analytics与百度地图SDK冲突导致iOS平台崩溃。

  • firebase_in_app_messaging库,如果注册了后台消息监听的方法( FirebaseMessaging.onBackgroundMessage和FirebaseMessaging.onMessageOpenedApp),会导致百度地图无法定位。

  • flutter_compass库,在百度地图监听手机朝向和定位时,如果同时使用该库监听朝向,会不停的抛异常,所以不要重复监听。

有很多其他文章也提到下面的坑:

  • 需要在build.gradle里添加相关的依赖,这个在3.6.0版本的sdk里是不需要的
  • 在activity里使用SDKInitialize初始化,在最新版本是不需要的
  • 在proguard-rules.pro文件里添加百度的混淆配置,暂时我还没发布,后面遇到我再更新

这些可能是老版本才遇到的,最新的可以忽略了。

还有个发现,在AndroidManifest.xml中配置安卓API_KEY的时候,如果在百度控制台的SHA1值不正确,在调试阶段百度会提醒你SDK鉴权失败,并把正确的SHA1随日志打印出来。

缺失的功能

  1. 自定义定位图标只支持本地内置的图片资源,不能使用网络图片资源
  2. 一旦使用了自定义的图标,无法显示指针朝向
  3. 不支持地图单击回调,只支持双击和长按回调
相关推荐
小牛itbull5 分钟前
初始化electron项目运行后报错 electron uninstall 解决方法
前端·javascript·electron
闲蛋小超人笑嘻嘻27 分钟前
前端面试十四之webpack和vite有什么区别
前端·webpack·node.js
rggrgerj1 小时前
Vue3 组件完全指南代码
前端·javascript·vue.js
golang学习记2 小时前
从0死磕全栈之Next.js App Router动态路由详解:从入门到实战
前端
huangql5203 小时前
基于前端+Node.js 的 Markdown 笔记 PDF 导出系统完整实战
前端·笔记·node.js
在逃的吗喽3 小时前
Vue3新变化
前端·javascript·vue.js
yqwang_cn3 小时前
打造优雅的用户体验:自定义jQuery工具提示插件开发全解析
前端·jquery·ux
小Tomkk3 小时前
AI 提效:利用 AI 从前端 快速转型为UI/UX设计师和产品
前端·人工智能·ui
Demoncode_y4 小时前
Vue3中基于路由的动态递归菜单组件实现
前端·javascript·vue.js·学习·递归·菜单组件
杨超越luckly4 小时前
HTML应用指南:利用POST请求获取全国中国工商农业银行网点位置信息
大数据·前端·html·数据可视化·银行网点