定位命令(节点)
太长不看
location.get是一个节点命令(通过node.invoke)。- 默认关闭。
- Android 应用设置使用选择器:关闭 / 使用期间。
- 独立开关:精确定位。
为什么是选择器(而不仅仅是一个开关)
操作系统权限是多级的。我们可以在应用内展示一个选择器,但操作系统仍然决定实际授予的权限。- iOS/macOS 可能会在系统提示/设置中显示 使用期间 或 始终。
- Android 应用目前仅支持前台定位。
- 精确定位是一个单独的授予项(iOS 14+ 的“Precise”,Android 的“fine”与“coarse”之分)。
设置模型
每个节点设备:location.enabledMode:off | whileUsinglocation.preciseEnabled: bool
- 选择
whileUsing会请求前台权限。 - 如果操作系统拒绝请求的级别,则回退到已授予的最高级别并显示状态。
权限映射 (node.permissions)
可选。macOS 节点通过权限映射报告location;iOS/Android 可能会省略它。
命令:location.get
通过 node.invoke 调用。
参数(建议):
LOCATION_DISABLED: 选择器已关闭。LOCATION_PERMISSION_REQUIRED: 请求的模式缺少权限。LOCATION_BACKGROUND_UNAVAILABLE: 应用处于后台,但仅允许“使用时”权限。LOCATION_TIMEOUT: 未能及时获取定位。LOCATION_UNAVAILABLE: 系统故障 / 无可用提供程序。
后台行为
- Android 应用在后台时会拒绝
location.get。 - 在 Android 上请求定位时,请保持 OpenClaw 打开。
- 其他节点平台可能会有所不同。
模型/工具集成
- 工具表面:
nodes工具添加location_get操作(需要节点)。 - CLI:
openclaw nodes location get --node <id>。 - Agent 指南:仅当用户启用了定位并了解其范围时才调用。
UX 文案(建议)
- 关闭:“位置共享已禁用。”
- 使用期间:“仅在 OpenClaw 打开时。”
- 精确:“使用精确的 GPS 位置。关闭以分享大致位置。”
本页面源自 openclaw/openclaw,由 BeaversLab 翻译,遵循 MIT 协议 发布。