从 Android 10(API 级别 29)开始,Google 对后台服务获取 GPS 的行为进行了更严格的限制。这些限制在 Android 11(API 级别 30)中仍然有效,并且进一步加强了对隐私和用户数据的保护。
以下是关于 Android 11 中后台服务获取 GPS 的限制以及如何适配的详细说明:
1. 后台位置访问限制
从 Android 10 开始,应用在后台运行时访问位置信息需要额外的权限声明。具体来说:
- 如果你的应用需要在后台访问位置信息,必须声明
ACCESS_BACKGROUND_LOCATION
和FOREGROUND_SERVICE_LOCATION
权限。 - 用户需要明确授予“始终允许”位置权限,否则应用只能在前台访问位置信息。
权限声明
在 AndroidManifest.xml
文件中,你需要声明以下权限:
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_BACKGROUND_LOCATION" />
<uses-permission android:name="android.permission.FOREGROUND_SERVICE_LOCATION" />
用户授权
即使你在清单文件中声明了 ACCESS_BACKGROUND_LOCATION
和 FOREGROUND_SERVICE_LOCATION
,用户仍然需要手动授予“始终允许”权限。如果用户仅授予“仅在使用时允许”,则应用无法在后台访问位置信息。
2. 后台服务限制
Android 11 对后台服务的行为也施加了更多限制:
- 前台服务要求:如果你的应用需要在后台持续获取位置信息,建议使用前台服务(Foreground Service)。前台服务需要显示一个通知,告知用户服务正在运行。
- 后台启动限制:从 Android 10 开始,系统限制了后台应用启动活动(Activity)。虽然这不直接影响 GPS 获取,但可能影响用户体验。
2.1 前台服务示例
以下是一个使用前台服务获取位置信息的示例代码:
public class LocationService extends Service {
private FusedLocationProviderClient fusedLocationClient;
private LocationCallback locationCallback;
@Override
public void