Android 位置感知通知

标签 android notifications location battery

我正在寻找位置感知通知的最佳技术。

我的第一个尝试是使用 LocationManager 的 addProximityAlert,但它需要 ACCESS_FINE_LOCATION(COARSE_LOCATION 给我一个 SecurityException)并保持 GPS 始终开启和 Activity (至少在 Jelly Bean 上),这会很快耗尽电池电量。当屏幕处于休眠状态时,它似乎也不会每 4 分钟检查一次(addProximityAlert)。

我正在考虑与 PASSIVE_PROVIDER 合作来收集其他应用程序的位置信息,并且可能使用服务每隔一段时间请求 COARSE_LOCATION(例如屏幕关闭时每 4 分钟一次,屏幕关闭时更频繁已打开且设备已插入)。

要求是当用户靠近某些位置时,应用会触发通知。

有人已经实现或建议以有效且电池效率高的方式实现此功能吗?

最佳答案

我构建了这样一个应用程序(因此我在办公时间问答中提出了关于如何测量 LocationManager 功耗的问题),同时它运行得非常好。 我最初打算使用内置的接近警报,但遇到了与您相同的问题并且认为它不够灵活。

相反,我构建了一个服务,该服务使用 LocationProvider 使用 NETWORK_PROVIDER 每五分钟轮询一次位置,计算到所需位置的距离,如果在附近,则触发通知。 在拥有大量 Wifi 网络的城市,这给了我 50 米的(报告的)精度。

我还使用 PASSIVE_PROVIDER 从其他应用的位置请求中获益。

如果我在所需位置附近并且报告的精度过于粗略而无法确定我是否在指定的邻近范围内,我将使用单个 GPS 位置请求作为备用。如果 NETWORK_PROVIDER 超时,我也会使用单个 GPS 位置请求。为了不让 GPS 供应商在我使用地铁时耗尽电池电量,它还有一个指数退避超时。

当我连接到 Wifi 网络时,我假设我没有移动,并在此期间禁用位置提供程序。

我所做的最后更改是为 NETWORK_PROVIDER 使用 15 分钟(“不精确重复”)计时器,如果我可以确定我将无法在 15 分钟内到达任何已保存的位置(因此使用5 分钟间隔没有意义)。这有助于节省电力。

我正在考虑使用更长的时间间隔来节省更多的电量,但是在这里很难找到一种启发式方法来确定我是否能够在那段时间内到达我保存的位置之一,因为我可以并不总是假设相同的行驶速度(步行、乘火车或汽车旅行)。 但由于我无法测量由我的应用引起的 LocationManager 的功耗,我不知道如何评估日常场景中的功耗。

我不介意内置 API 是否会提供所有这些逻辑,但我认为它不会,所以我自己构建了它。

希望对你有帮助。

关于Android 位置感知通知,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12081964/

相关文章:

android - windowMinWidthMajor 和 android :windowMinWidthMajor 有什么区别

ios - 在自己的应用程序/ View 中接收本地通知(或如何在 SwiftUI 中注册 UNUserNotificationCenterDelegate)

Android 短信拦截无通知图标或 WAP-PUSH 消息

ios - 在 IOS 中从蜂窝网络获取纬度和经度

java - 我如何在Android中获取手机的经度,纬度?

java - 安卓图片加载

android - 如何使用 SoundPool 同步声音

android - 检查是否已调用 Activity 以获得结果

ruby-on-rails - 具有外部输入和实时通知的 Web 应用程序的想法

android - 如何停止测试位置提供程序