When this new mode (LOCATION_MODE_THROTTLE_REQUESTS_WHEN_SCREEN_OFF) is enabled, LocationManagerService will avoid sending almost all LocationRequests to providers. The only requests that will continue to be sent will be providers are the requests that ignore location settings. Bug: 121256487 Bug: 122849003 Bug: 119261320 Test: atest android.os.cts.batterysaving.BatterySaverLocationTest Change-Id: Iee95a6fb5ca11d4db7a0f0661bf3cb1051a5d710
125 lines
4.1 KiB
Java
125 lines
4.1 KiB
Java
/*
|
|
* Copyright (C) 2012 The Android Open Source Project
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
package com.android.internal.location;
|
|
|
|
import android.annotation.UnsupportedAppUsage;
|
|
import android.location.LocationRequest;
|
|
import android.os.Parcel;
|
|
import android.os.Parcelable;
|
|
import android.util.TimeUtils;
|
|
|
|
import java.util.ArrayList;
|
|
import java.util.List;
|
|
|
|
/** @hide */
|
|
public final class ProviderRequest implements Parcelable {
|
|
/** Location reporting is requested (true) */
|
|
@UnsupportedAppUsage
|
|
public boolean reportLocation = false;
|
|
|
|
/** The smallest requested interval */
|
|
@UnsupportedAppUsage
|
|
public long interval = Long.MAX_VALUE;
|
|
|
|
/**
|
|
* When this flag is true, providers should ignore all location settings, user consents, power
|
|
* restrictions or any other restricting factors and always satisfy this request to the best of
|
|
* their ability. This flag should only be used in event of an emergency.
|
|
*/
|
|
public boolean locationSettingsIgnored = false;
|
|
|
|
/**
|
|
* Whether provider shall make stronger than normal tradeoffs to substantially restrict power
|
|
* use.
|
|
*/
|
|
public boolean lowPowerMode = false;
|
|
|
|
/**
|
|
* A more detailed set of requests.
|
|
* <p>Location Providers can optionally use this to
|
|
* fine tune location updates, for example when there
|
|
* is a high power slow interval request and a
|
|
* low power fast interval request.
|
|
*/
|
|
@UnsupportedAppUsage
|
|
public final List<LocationRequest> locationRequests = new ArrayList<>();
|
|
|
|
@UnsupportedAppUsage
|
|
public ProviderRequest() {
|
|
}
|
|
|
|
public static final Parcelable.Creator<ProviderRequest> CREATOR =
|
|
new Parcelable.Creator<ProviderRequest>() {
|
|
@Override
|
|
public ProviderRequest createFromParcel(Parcel in) {
|
|
ProviderRequest request = new ProviderRequest();
|
|
request.reportLocation = in.readInt() == 1;
|
|
request.interval = in.readLong();
|
|
request.lowPowerMode = in.readBoolean();
|
|
request.locationSettingsIgnored = in.readBoolean();
|
|
int count = in.readInt();
|
|
for (int i = 0; i < count; i++) {
|
|
request.locationRequests.add(LocationRequest.CREATOR.createFromParcel(in));
|
|
}
|
|
return request;
|
|
}
|
|
|
|
@Override
|
|
public ProviderRequest[] newArray(int size) {
|
|
return new ProviderRequest[size];
|
|
}
|
|
};
|
|
|
|
@Override
|
|
public int describeContents() {
|
|
return 0;
|
|
}
|
|
|
|
@Override
|
|
public void writeToParcel(Parcel parcel, int flags) {
|
|
parcel.writeInt(reportLocation ? 1 : 0);
|
|
parcel.writeLong(interval);
|
|
parcel.writeBoolean(lowPowerMode);
|
|
parcel.writeBoolean(locationSettingsIgnored);
|
|
parcel.writeInt(locationRequests.size());
|
|
for (LocationRequest request : locationRequests) {
|
|
request.writeToParcel(parcel, flags);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public String toString() {
|
|
StringBuilder s = new StringBuilder();
|
|
s.append("ProviderRequest[");
|
|
if (reportLocation) {
|
|
s.append("ON");
|
|
s.append(" interval=");
|
|
TimeUtils.formatDuration(interval, s);
|
|
if (lowPowerMode) {
|
|
s.append(" lowPowerMode");
|
|
}
|
|
if (locationSettingsIgnored) {
|
|
s.append(" locationSettingsIgnored");
|
|
}
|
|
} else {
|
|
s.append("OFF");
|
|
}
|
|
s.append(']');
|
|
return s.toString();
|
|
}
|
|
}
|