react-native-amap-geolocation安装与使用

react-native-amap-geolocation这款插件接入了高德地图定位模块。支持 Android + iOS,提供尽可能完善的原生接口, 同时提供符合 Web 标准的 Geolocation API。

ios下的安装

依次在命令下执行以下2条命令

    yarn add react-native-amap-geolocation
    react-native link react-native-amap-geolocation

如果出现了link的相关报错的话,就需要手动link一下

  1. 用xcode打开该项目
  2. 点击项目的根目录右键 add File to "项目名"
  3. 选择并添加 node_modules/react-native-amap-geolocation/lib/ios/AMapGeolocation.xcodeproj (或从文件浏览器里将该文件拖拽到 Libraries)
  4. Build Phases ➜ Link Binary With Libraries 中选择并添加 libAMapGeolocation.a

下载和安装高德IOS SDK

  1. 下载基础SDK(含IDFA)
  2. 下载定位SDK
  3. 将下载的AMapFoundationKit.frameworkAMapLocationKit.framework 以及 项目自带的ExternalAccessory.framework 添加到 Build Phases ➜ Link Binary With Libraries。

配置权限

高德地图官方文档权限参考

ios8-10权限 NSLocationWhenInUseUsageDescription和NSLocationAlwaysUsageDescription

ios11以上权限 NSLocationAlwaysAndWhenInUseUsageDescriptionNSLocationWhenInUseUsageDescription

ios8-ios11+权限NSLocationWhenInUseUsageDescriptionNSLocationAlwaysUsageDescriptionNSLocationAlwaysAndWhenInUseUsageDescription

苹果官方权限参考

ios11以上权限 NSLocationWhenInUseUsageDescriptionNSLocationAlwaysAndWhenInUseUsageDescription

ios11以下权限 NSLocationAlwaysUsageDescription

权限这个地方得注意。参考了高德和苹果的文档你会发现,他们说发恰恰相反,如果你按照高德和苹果3个权限全给的话或者高德的ios11+的,那你会弹不出权限提示。所以大家请采用以下的权限配置
  1. 打开info.plistt
  2. 添加NSLocationWhenInUseUsageDescription(表示应用在前台的时候可以搜到更新的位置信息)和NSLocationAlwaysUsageDescription(申请Always权限,以便应用在前台和后台都可以获取到更新的位置数据)
  3. App Transport Security Setting展开后的Allow Arbitrary Loads 为YES
这个权限很神奇,只添加NSLocationWhenInUseUsageDescription也可以,前台后台都可以获取到位置,但是3个权限全部添加的话,会出现弹出不了权限提示框的问题。所以大家添加NSLocationWhenInUseUsageDescription或者添加NSLocationWhenInUseUsageDescription和NSLocationAlwaysUsageDescription就可以了。
如果要支持后台持续定位,还需要配置以下
  1. 打开xcode,点击项目
  2. 选择Capabilities,把Background Modes打开为ON,然后打勾Loaction updates

使用

创建一个position.js,把操作封装起来

import { init, Geolocation,setAllowsBackgroundLocationUpdates} from "react-native-amap-geolocation";
//初始化sdk
export async function geolocationInit() {
    //设置高德key
    await init({
        ios: "你的key",
    });
    
    
    //开启后台定位,必须要Background Modes打开为ON,勾选Loaction updates,不然会报错!
    //必须在开始定位之前或者在定位stop的时候设置
    setAllowsBackgroundLocationUpdates(true);
    
}

//只获得一次当前地理位置
export function getCurrentPosition(){
    Geolocation.getCurrentPosition(position=>console.log(position));
}

//注册一个监听,它会每隔一段时间返回当前地理位置
export function watchPosition(){
    if(!this.watchId){
        this.watchId=Geolocation.watchPosition(position=>console.log(position)));
    }
}

...按照自己的需要封装

创建一个index.js 来使用定位,需要注意一点,高德sdk默认返回逆地理编码信息为false,如果要返回的话在AMapGeolocation.xcodeproj添加_manager.locatingWithReGeocode=YES

import React, { Component } from 'react';
import { SafeAreaView, View } from 'react-native';
import {setInterval} from "react-native-amap-geolocation";
import {getCurrentPosition,watchPosition,getCurrentPosition} from "./position"


export default class Main extends Component {

   componentDidMount() {

        //初始化定位组件
        geolocationInit();

        //启动监听
        watchPosition();

        //获取一次定位,getCurrentPosition会暂停掉监听
        //getCurrentPosition()

        //设置每隔15S获取一次定位
        setInterval(15000);
    }

    render() {
        return (
            <SafeAreaView>
                <View>
                ...ui+操作
                </View>
            </SafeAreaView>
        );
    }
}

官方文档安装指南
官方API文档
官方例子(不了解如何使用,推荐参考)

这里要提醒一下,持续定位第一次获取的时候会返回多条定位信息,注意监听不要多次创建还有像设置间隔获取,或者指定多少距离才更新位置的话,一定要创建监听之后再设置,否则会每次更新位置时返回信息的返回多条信息。在模拟器上开启监听持续定位,不会按照预想的每隔一段时间返回一次地理位置,但是真机会隔一段时间返回一次,一切正常。

安卓只要react-native link成功就不用配置了,如果失败请参考作者github的指南配置。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,012评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,628评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,653评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,485评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,574评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,590评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,596评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,340评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,794评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,102评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,276评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,940评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,583评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,201评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,441评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,173评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,136评论 2 352

推荐阅读更多精彩内容