跳到主要内容
版本:v8

@capacitor/geolocation

Geolocation API 提供简单的方法,用于通过 GPS 获取和跟踪设备的当前位置,并在可用时提供海拔、方向和速度信息。

安装

npm install @capacitor/geolocation
npx cap sync

iOS

Apple 要求在 Info.plist 中为位置信息指定隐私描述:

  • NSLocationAlwaysAndWhenInUseUsageDescription (隐私 - 始终和在应用使用时访问位置)
  • NSLocationWhenInUseUsageDescription (隐私 - 在应用使用时访问位置)

[!NOTE] 这个 Capacitor 插件本身不直接支持后台地理位置。但是,它依赖于 ion-ios-geolocation,该库可以在后台报告位置。因此,Apple 要求你在 Info.plist 中包含 NSLocationAlwaysAndWhenInUseUsageDescription 条目。由于此权限提示不会向用户显示,你可以安全地使用与 NSLocationWhenInUseUsageDescription 相同的描述字符串。

iOS 指南中阅读有关 配置 Info.plist 的更多信息,了解如何在 Xcode 中设置 iOS 权限。

Android

此插件要求将以下权限添加到你的 AndroidManifest.xml

<!-- Geolocation Plugin -->
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-feature android:name="android.hardware.location.gps" />

前两个权限请求位置数据(精确和粗略),最后一行是可选的,但如果你的应用 需要 GPS 才能运行,则有必要添加。你可以省略它,但请注意,这可能意味着你的应用会安装在缺少 GPS 硬件的设备上。

Android 指南中阅读有关 设置权限 的更多信息,了解如何设置 Android 权限。

API

有关错误代码列表,请参见 错误

getCurrentPosition(...)

getCurrentPosition(options?: PositionOptions | undefined) => Promise<Position>

获取设备的当前 GPS 位置。

参数类型
options
PositionOptions

返回值:

Promise<Position>

自: 1.0.0


watchPosition(...)

watchPosition(options: PositionOptions, callback: WatchPositionCallback) => Promise<CallbackID>

设置位置变化的监听器。请注意,监听位置变化可能会消耗大量电量。请明智地仅在需要时监听。

参数类型
options
PositionOptions
callback
WatchPositionCallback

返回值: Promise<string>

自: 1.0.0


clearWatch(...)

clearWatch(options: ClearWatchOptions) => Promise<void>

清除指定的监听器。

参数类型
options
ClearWatchOptions

自: 1.0.0


checkPermissions()

checkPermissions() => Promise<PermissionStatus>

检查位置权限。如果系统位置服务被禁用,会抛出错误。

返回值:

Promise<PermissionStatus>

自: 1.0.0


requestPermissions(...)

requestPermissions(permissions?: GeolocationPluginPermissions | undefined) => Promise<PermissionStatus>

请求位置权限。如果系统位置服务被禁用,会抛出错误。

在 Web 上不可用。

参数类型
permissions
GeolocationPluginPermissions

返回值:

Promise<PermissionStatus>

自: 1.0.0


接口

Position

属性类型说明起始版本
timestampnumber坐标的创建时间戳1.0.0
coords{ latitude: number; longitude: number; accuracy: number; altitudeAccuracy: number | null; altitude: number | null; speed: number | null; heading: number | null; }GPS 坐标以及数据的精度1.0.0
属性类型描述默认值开始版本
enableHighAccuracyboolean高精度模式(例如 GPS,如果可用)。在 Android 12+ 设备上,如果用户未授予 ACCESS_FINE_LOCATION 权限(可通过 location 别名检查),此设置将被忽略。false1.0.0
timeoutnumber等待位置更新的最长时间(毫秒)。100001.0.0
maximumAgenumber可接受的缓存位置的最大存在时间(毫秒)。01.0.0
minimumUpdateIntervalnumberwatchPosition 的最小更新间隔。注意不要与 interval 混淆。如果位置更新的速度比此间隔更快,则只有在自上次位置更新以来已超过最小更新间隔时,才会触发更新。此参数仅适用于 Android 平台,在 iOS 或 Web 平台上无效。50006.1.0
intervalnumberwatchPosition 中接收位置更新的期望间隔(毫秒)。对于非常小的 interval 值(几秒或更少),平台可能无法保证及时的位置更新——实际更新时间可能比指定的更长。平台也可能能够提供比 interval 更快的更新。你可以使用 minimumUpdateInterval 来控制此行为。为了向后兼容 7.1.x 版本,如果未传递值,此参数的默认值将与 timeout 相同。此参数仅适用于 Android 平台,在 iOS 或 Web 平台上无效。
timeout
8.0.0
enableLocationFallbackboolean当 Google Play 服务的定位设置检查失败时,是否回退到 Android 框架的 LocationManager。失败可能由多种原因导致——例如设备没有 Play 服务或设备没有网络连接(飞行模式)。如果设置为 false,失败将传播给调用者。注意,LocationManager 可能不如 Google Play 服务的实现有效。如果设备处于飞行模式,则只使用 GPS 提供程序,这可能需要更长的时间来返回位置,具体取决于 GPS 信号。这意味着,要在此类情况下接收位置,您可能需要提供更长的超时时间。此参数仅适用于 Android 平台,在 iOS 或 Web 平台上无效。true8.0.0

ClearWatchOptions

属性类型
id
CallbackID
属性类型描述起始版本
location
PermissionState
位置别名的权限状态。在 Android 上,它会请求/检查 ACCESS_COARSE_LOCATION 和 ACCESS_FINE_LOCATION 权限。在 iOS 和 Web 上,它会请求/检查位置权限。1.0.0
coarseLocation
PermissionState
粗略位置别名的权限状态。在 Android 上,它会请求/检查 ACCESS_COARSE_LOCATION 权限。在 Android 12+ 上,用户可以选择"大致位置(ACCESS_COARSE_LOCATION)"或"精确位置(ACCESS_FINE_LOCATION)",因此如果应用不需要高精度,可以使用此别名。在 iOS 和 Web 上,其值与 location 别名相同。1.2.0

GeolocationPluginPermissions

属性类型
permissionsGeolocationPermissionType[]

类型别名

WatchPositionCallback

(position: Position | null, err?: any): void

CallbackID

string

PermissionState

'prompt' | 'prompt-with-rationale' | 'granted' | 'denied'

GeolocationPermissionType

'location' | 'coarseLocation'

错误信息

该插件在原生 Android 和 iOS 平台上会返回带有特定代码的错误信息。Web 平台不遵循此错误标准。

下表列出了所有插件错误:

错误代码平台错误信息
OS-PLUG-GLOC-0002Android, iOS尝试获取位置时发生错误。
OS-PLUG-GLOC-0003Android, iOS位置权限请求被拒绝。
OS-PLUG-GLOC-0004iOS'getCurrentPosition' 输入参数无效。
OS-PLUG-GLOC-0005iOS'watchPosition' 输入参数无效。
OS-PLUG-GLOC-0006iOS'clearWatch' 输入参数无效。
OS-PLUG-GLOC-0007Android, iOS位置服务未启用。
OS-PLUG-GLOC-0008iOS应用程序使用位置服务的权限受到限制。
OS-PLUG-GLOC-0009Android启用位置的请求被拒绝。
OS-PLUG-GLOC-0010Android, iOS无法在指定时间内获取位置。请尝试使用更长的超时时间。
OS-PLUG-GLOC-0011Android超时时间必须为正值。
OS-PLUG-GLOC-0012Android未找到 WatchId。
OS-PLUG-GLOC-0013Android必须提供 WatchId。
OS-PLUG-GLOC-0014AndroidGoogle Play 服务错误,用户可解决。
OS-PLUG-GLOC-0015AndroidGoogle Play 服务错误。
OS-PLUG-GLOC-0016Android位置设置错误。
OS-PLUG-GLOC-0017Android由于设备的网络和位置功能均已关闭,无法获取位置。