位置命令
location.get是一个节点命令(通过node.invoke)。- 默认关闭。
- Android 应用设置使用一个选择器:关闭 / 使用期间。
- 单独的切换开关:精确位置。
为什么使用选择器(而不仅仅是开关)
Section titled “为什么使用选择器(而不仅仅是开关)”操作系统权限是多级别的。我们可以在应用中展示一个选择器,但操作系统仍然决定实际授予的权限。
- iOS/macOS 可能会在系统提示/设置中显示 使用期间 或 始终。
- Android 应用目前仅支持前台位置。
- 精确位置是一项单独的授权(iOS 14+ 中的“Precise”,Android 中的“fine”与“coarse”)。
UI 中的选择器驱动我们请求的模式;实际授权存在于操作系统设置中。
每个节点设备:
location.enabledMode:off | whileUsinglocation.preciseEnabled: bool
UI 行为:
- 选择
whileUsing会请求前台权限。 - 如果操作系统拒绝了请求的级别,则恢复到已授予的最高级别并显示状态。
权限映射(node.permissions)
Section titled “权限映射(node.permissions)”可选。macOS 节点通过权限映射报告 location;iOS/Android 可能会省略它。
命令:location.get
Section titled “命令:location.get”通过 node.invoke 调用。
参数(建议):
{ "timeoutMs": 10000, "maxAgeMs": 15000, "desiredAccuracy": "coarse|balanced|precise"}响应载荷:
{ "lat": 48.20849, "lon": 16.37208, "accuracyMeters": 12.5, "altitudeMeters": 182.0, "speedMps": 0.0, "headingDeg": 270.0, "timestamp": "2026-01-03T12:34:56.000Z", "isPrecise": true, "source": "gps|wifi|cell|unknown"}错误(稳定代码):
LOCATION_DISABLED: 选择器已关闭。LOCATION_PERMISSION_REQUIRED: 请求模式缺少权限。LOCATION_BACKGROUND_UNAVAILABLE: 应用处于后台,但仅允许“使用期间”。LOCATION_TIMEOUT: 未能及时获取定位。LOCATION_UNAVAILABLE: 系统失败 / 没有提供程序。
- Android 应用在后台时会拒绝
location.get。 - 在 OpenClaw 上请求位置时,请保持 Android 打开。
- 其他节点平台可能有所不同。
模型/工具集成
Section titled “模型/工具集成”- 工具表面:
nodes工具添加location_get操作(需要节点)。 - CLI:
openclaw nodes location get --node <id>。 - Agent 指南:仅在用户启用了位置并了解范围时调用。
UX 文案(建议)
Section titled “UX 文案(建议)”- 关闭:“位置共享已禁用。”
- 使用时:“仅当 OpenClaw 打开时。”
- 精确:“使用精确 GPS 位置。关闭以共享大致位置。”