博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Expo大作战(三十五)--expo sdk api之Location!
阅读量:6093 次
发布时间:2019-06-20

本文共 4013 字,大约阅读时间需要 13 分钟。

简要:本系列文章讲会对expo进行全面的介绍,本人从2017年6月份接触expo以来,对expo的研究断断续续,一路走来将近10个月,废话不多说,接下来你看到内容,讲全部来与官网

我猜去全部机翻+个人修改补充+demo测试的形式,对expo进行一次大补血!欢迎加入expo兴趣学习交流群:597732981

【之前我写过一些列关于expo和rn入门配置的东i西,大家可以点击这里查看:】

相关文章:

写在二十三章以后的话,之前的翻译,不管如何,好与不好,终究是告一段落,也把expo基础理论的东西又深入的理解了一遍,后续expo大作战系列将主要介绍expo sdk的api。


位置Location

该模块允许从设备读取地理位置信息。 您的应用可以轮询当前位置或订阅位置更新事件。

在尝试获取之前,您必须先获得访问用户位置的权限。 为此,您需要使用 API。 在下面的例子中你可以看到这一点。

Expo.Location.getCurrentPositionAsync(options)

获取设备的当前位置。

参数

option(object) -

选项图:

  • enableHighAccuracy(boolean) - 是否启用高精度模式。对于低精度的实施可以避免消耗大量功率的地理位置提供商(如GPS)。
  • maximumAge(数字) - (仅限Android)。如果指定,则允许以毫秒为单位返回先前缓存的最旧位置。如果未指定,则始终获取新位置。在iOS上,此选项将被忽略,并且总是返回新的位置。

返回

返回包含以下字段的对象:

coords(对象) - 位置的坐标,包含以下字段:

  • latitude (number)  - 以度为单位的纬度。
  • longitude (number) - 以度为单位的经度。
  • altitude (number)  - WGS 84参考椭球面以上的高度(米)。
  • accuracy (number) - 位置的不确定性半径,以米为单位。
  • altitudeAccuracy(number) - 海拔高度值的准确度,单位为米(仅限iOS)。
  • heading (number)) - 此设备的水平行进方向,以度为单位开始测量,以正北为单位并沿指南针顺时针方向继续。因此,北部是0度,东部是90度,南部是180度,依此类推。
  • speed (number) - 设备的瞬时速度,单位为米/秒。

timestamp (number) - 获取此位置信息的时间,以时间为单位,以毫秒为单位。

Expo.Location.watchPositionAsync(options, callback)

从设备订阅位置更新。请注意,更新只会在应用程序处于前台时发生。背景位置跟踪计划中,但尚未实施。

参数

options(object) -

选项图:

  • enableHighAccuracy(boolean) - 是否启用高精度模式。对于低精度的实施可以避免消耗大量功率的地理位置提供商(如GPS)。
  • timeInterval(number) - 每次更新之间以毫秒为单位等待的最短时间。
  • distanceInterval(number) - 仅当位置以米为单位改变至少该距离时才接收更新。

callback(function) -

每个位置更新都会调用此函数。它只传递一个参数:包含以下字段的对象:

coords(对象) - 位置的坐标,包含以下字段:

  • latitude (number)  - 以度为单位的纬度。
  • longitude (number) - 以度为单位的经度。
  • altitude (number)  - WGS 84参考椭球面以上的高度(米)。
  • accuracy (number) - 位置的不确定性半径,以米为单位。
  • altitudeAccuracy(number) - 海拔高度值的准确度,单位为米(仅限iOS)。
  • heading (number)) - 此设备的水平行进方向,以度为单位开始测量,以正北为单位并沿指南针顺时针方向继续。因此,北部是0度,东部是90度,南部是180度,依此类推。
  • speed (number) - 设备的瞬时速度,单位为米/秒。

timespan(number) - 获取此位置信息的时间,以时间为单位,以毫秒为单位。

返回

返回具有一个字段的订阅对象:

  • remove(function) - 不带任何参数调用此函数来删除此订阅。该回调将不再被称为位置更新。

Expo.Location.getProviderStatusAsync()

检查位置提供者的状态。

返回

返回包含以下字段的对象:

  • locationServicesEnabled(boolean) - 是否启用位置服务。
  • gpsAvailable(boolean)(仅限android) - 如果GPS提供者可用,如果是,则位置数据将来自GPS。
  • networkAvailable(boolean)(仅限android) - 如果网络提供者可用,如果是,则位置数据将来自蜂窝网络。
  • passiveAvailable(boolean)(仅限android) - 如果被动提供者可用,如果是,则位置数据将被动地确定。

Expo.Location.getHeadingAsync()

从设备获取当前的朝向信息

参数

没有

返回

对象:

  • magHeading(数字) - 以度为单位的磁北测量
  • trueHeading(number) - 衡量真正的北方度(需要位置权限,如果没有给出则返回-1)
  • 准确度(数字) - 指南针的校准程度。
    •   3:高精度,2:中等精度,1:低精度,0:无
    •   IOS参考:3:<20度不确定度,2:<35度,1:<50度,0:> 50度

Expo.Location.watchHeadingAsync(callback)

指定从设备指南针更新

参数

callback(function) -

每个指南针更新都会调用该函数。它只传递一个参数:包含以下字段的对象:

  • magHeading(数字) - 以度为单位的磁北测量
  • trueHeading(number) - 衡量真正的北方度(需要位置权限,如果没有给出则返回-1)
  • accuracy (number)  - 指南针的校准程度。
    •   3:高精度,2:中等精度,1:低精度,0:无
    •   iOS参考:3:<20度不确定度,2:<35度,1:<50度,0:> 50度

返回

返回具有一个字段的订阅对象:

remove(function) - 不带任何参数调用此函数来删除此订阅。该回调将不再被称为位置更新。

 

Expo.Location.geocodeAsync(address)

将地址字符串编码到经纬度位置。

注意:地理编码消耗资源,必须合理使用。一次创建太多请求可能会导致错误,因此必须对其进行正确管理。

在Android上,您必须在使用地理编码之前向用户请求位置权限(Expo.Permissions.LOCATION)。

参数

adress(string) - 表示地址的字符串,例如。 “贝克街伦敦”(address (string) — A string representing address, eg. “Baker Street London”)

返回

返回经过地理编码的位置对象的数组(大多数情况下其大小为1),并包含以下字段:

latitude (number) - 以度为单位的纬度。

longitude (number) - 以度为单位的经度。
altitude (number)  - WGS 84参考椭球面以上的高度(米)。
accuracy (number) - 位置的不确定性半径,以米为单位。

Expo.Location.reverseGeocodeAsync(location)

将地址解析为邮政地址。

注意:地理编码消耗资源,必须合理使用。一次创建太多请求可能会导致错误,因此必须对其进行正确管理。

在Android上,您必须在使用地理编码之前向用户请求位置权限(Expo.Permissions.LOCATION)。
参数

location(object)- 表示位置的对象:

  • latitude (number)  - 反转地理代码的位置的纬度,以度为单位。
  • longitude (number) - 反转地理代码的位置的经度,以度为单位。

返回

返回包含以下字段的地址对象的数组(大多数情况下其大小为1):

  • city (string) 城市(字符串) - 地址的城市名称。
  • street (string) 街道(字符串) - 地址的街道名称。
  • region (string)  区域(字符串) - 地址的区域/区域名称。
  • postalCode (string) 邮政编码(字符串) - 地址的邮政编码。
  • country (string) 国家(字符串) - 地址的国家/地区名称。
  • name (string) 名称(字符串) - 地址的名称,例如“塔桥”。

Expo.Location.setApiKey(apiKey)

设置Google API密钥以使用地理编码API。此方法对于没有Google Play服务的Android设备非常有用,因此无需Geocoder服务。使用Google的API设置密钥之后就可以了。

参数

apiKey(string) - 从Google开发者网站收集的API密钥。


下一张继续介绍,这一篇主要介绍了:expo sdk api之Location欢迎大家关注我的微信公众号,这篇文章是否被大家认可,我的衡量标准就是公众号粉丝增长人数。欢迎大家转载,但必须保留本人博客链接!

 

 

你可能感兴趣的文章
Chisel_LLDB调试命令
查看>>
DNS Doctoring
查看>>
(转载一篇)Windows7与ArcGIS Desktop9.3冲突问题解决(由QQ安装问题引出)(经本人验证已解决)...
查看>>
dedecms生成文档数据库崩溃 mysql daemon failed to start
查看>>
Linux的50个基本命令
查看>>
Objective-C中创建单例方法的步骤
查看>>
[转]无法安装MVC3,一直卡在vs10-kb2483190
查看>>
Codeforces 520B:Two Buttons(思维,好题)
查看>>
web框架-(二)Django基础
查看>>
Jenkins持续集成环境部署
查看>>
emoji等表情符号存mysql的方法
查看>>
Excel到R中的日期转换
查看>>
检查磁盘利用率并且定期发送告警邮件
查看>>
MWeb 1.4 新功能介绍二:静态博客功能增强
查看>>
linux文本模式和文本替换功能
查看>>
Windows SFTP 的安装
查看>>
摄像机与绕任意轴旋转
查看>>
rsync 服务器配置过程
查看>>
查看linux发行版本方法
查看>>
写CV中
查看>>