Flutter是谷歌的移动UI框架,可以快速在iOS和Android上构建高质量的原生用户界面,因其毫秒级热重载能够实现快速开发、具备超强原生性能以及富有表现力和灵活的UI,越来越受开发者喜爱,因此推出百度定位Flutter插件供广大开发者在开发Flutter Application的时候,可以集成本插件实现基本定位需求。

百度定位服务终于在2020年3月更新了这个服务。

第一步:打开/创建一个flutter application工程

根据开发者的实际使用情况,打开一个已有的flutter application工程,或新建一个flutter application工程。 这里以新建一个flutter application工程为例介绍。

第二步:分别申请Android端和iOS端AK

您可以在控制台应用管理中分别创建Android端和iOS端AK,具体步骤可参照Android SDK创建AK说明iOS SDK创建AK说明
温馨提示:申请iOS端AK时,需填写Bundle Identifier。打开一个iOS工程代码文件,点击Android Studio右上角Open iOS module in Xcode,用Xcode打开iOS工程,方便查看Bundle Identifier。




flutter获取云服务器资源 flutter 服务_flutter git 拉不起来


第三步:设置Android端及iOS端AK

1. 设置Android端AK
在Android目录清单文件的application节点中设置Android端AK,添加如下代码:


<meta-data
    android:name="com.baidu.lbsapi.API_KEY"
    android:value="开发者申请的AK" />


2. 设置iOS端AK
在dart文件中,通过对外接口setApiKey设置iOS端AK,可参考百度定位Flutter插件Demo。代码如下:


@override
void initState() {
  super.initState();

  _locationPlugin.requestPermission();
  //动态申请定位权限

  LocationFlutterPlugin.setApiKey("开发者申请的AK");
  //设置iOS端AK, Android端AK可以直接在清单文件中配置
}


第四步:集成百度地图定位Flutter插件

1. 在工程目录下新建plugins目录。
2. 将所下载的百度地图定位Flutter插件拷贝到plugins目录中。
3. 在工程中找到pubspec.yaml,在dependencies节点下添加如下代码:


flutter获取云服务器资源 flutter 服务_iOS_02


4. 点击右上角package get按钮,完成插件的集成。


flutter获取云服务器资源 flutter 服务_flutter git 拉不起来_03


5. 对于iOS端,需要继续手动部署百度iOS定位SDK。选择iOS设备,点击运行按钮,生成Pods工程。
6. 用Xcode打开iOS目录,对Pods工程手动部署百度iOS定位SDK,具体步骤可参照iOS定位SDK手动部署说明


flutter获取云服务器资源 flutter 服务_flutter 阿里 号码认证_04


第五步:导入dart类,使用对外接口

在需要获取定位信息的位置导入如下dart类文件:


import 'package:bdmap_location_flutter_plugin/bdmap_location_flutter_plugin.dart';
import 'package:bdmap_location_flutter_plugin/flutter_baidu_location.dart';
import 'package:bdmap_location_flutter_plugin/flutter_baidu_location_android_option.dart';
import 'package:bdmap_location_flutter_plugin/flutter_baidu_location_ios_option.dart';


对外接口的使用方法,可参照百度定位Flutter插件Demo中lib目录的main.dart类。