Opposite sign of Glonass & BDS offsets. Noticed after screenshot search & further testing. Bug: 28623392 Change-Id: I6a7c98f455ee7df278eed985ba57ec1c12d888e0
251 lines
8.8 KiB
Java
251 lines
8.8 KiB
Java
/*
|
|
* Copyright (C) 2008 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 android.location;
|
|
|
|
import android.util.SparseArray;
|
|
|
|
import java.util.Iterator;
|
|
import java.util.NoSuchElementException;
|
|
|
|
|
|
/**
|
|
* This class represents the current state of the GPS engine.
|
|
*
|
|
* <p>This class is used in conjunction with the {@link Listener} interface.
|
|
*
|
|
* @deprecated use {@link GnssStatus} and {@link GnssStatus.Callback}.
|
|
*/
|
|
@Deprecated
|
|
public final class GpsStatus {
|
|
private static final int NUM_SATELLITES = 255;
|
|
private static final int GLONASS_SVID_OFFSET = 64;
|
|
private static final int BEIDOU_SVID_OFFSET = 200;
|
|
private static final int SBAS_SVID_OFFSET = -87;
|
|
|
|
/* These package private values are modified by the LocationManager class */
|
|
private int mTimeToFirstFix;
|
|
private final SparseArray<GpsSatellite> mSatellites = new SparseArray<>();
|
|
|
|
private final class SatelliteIterator implements Iterator<GpsSatellite> {
|
|
private final int mSatellitesCount;
|
|
|
|
private int mIndex = 0;
|
|
|
|
SatelliteIterator() {
|
|
mSatellitesCount = mSatellites.size();
|
|
}
|
|
|
|
@Override
|
|
public boolean hasNext() {
|
|
for (; mIndex < mSatellitesCount; ++mIndex) {
|
|
GpsSatellite satellite = mSatellites.valueAt(mIndex);
|
|
if (satellite.mValid) {
|
|
return true;
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
|
|
@Override
|
|
public GpsSatellite next() {
|
|
while (mIndex < mSatellitesCount) {
|
|
GpsSatellite satellite = mSatellites.valueAt(mIndex);
|
|
++mIndex;
|
|
if (satellite.mValid) {
|
|
return satellite;
|
|
}
|
|
}
|
|
throw new NoSuchElementException();
|
|
}
|
|
|
|
@Override
|
|
public void remove() {
|
|
throw new UnsupportedOperationException();
|
|
}
|
|
}
|
|
|
|
private Iterable<GpsSatellite> mSatelliteList = new Iterable<GpsSatellite>() {
|
|
@Override
|
|
public Iterator<GpsSatellite> iterator() {
|
|
return new SatelliteIterator();
|
|
}
|
|
};
|
|
|
|
/**
|
|
* Event sent when the GPS system has started.
|
|
*/
|
|
public static final int GPS_EVENT_STARTED = 1;
|
|
|
|
/**
|
|
* Event sent when the GPS system has stopped.
|
|
*/
|
|
public static final int GPS_EVENT_STOPPED = 2;
|
|
|
|
/**
|
|
* Event sent when the GPS system has received its first fix since starting.
|
|
* Call {@link #getTimeToFirstFix()} to find the time from start to first fix.
|
|
*/
|
|
public static final int GPS_EVENT_FIRST_FIX = 3;
|
|
|
|
/**
|
|
* Event sent periodically to report GPS satellite status.
|
|
* Call {@link #getSatellites()} to retrieve the status for each satellite.
|
|
*/
|
|
public static final int GPS_EVENT_SATELLITE_STATUS = 4;
|
|
|
|
/**
|
|
* Used for receiving notifications when GPS status has changed.
|
|
* @deprecated use {@link GnssStatus.Callback} instead.
|
|
*/
|
|
@Deprecated
|
|
public interface Listener {
|
|
/**
|
|
* Called to report changes in the GPS status.
|
|
* The event number is one of:
|
|
* <ul>
|
|
* <li> {@link GpsStatus#GPS_EVENT_STARTED}
|
|
* <li> {@link GpsStatus#GPS_EVENT_STOPPED}
|
|
* <li> {@link GpsStatus#GPS_EVENT_FIRST_FIX}
|
|
* <li> {@link GpsStatus#GPS_EVENT_SATELLITE_STATUS}
|
|
* </ul>
|
|
*
|
|
* When this method is called, the client should call
|
|
* {@link LocationManager#getGpsStatus} to get additional
|
|
* status information.
|
|
*
|
|
* @param event event number for this notification
|
|
*/
|
|
void onGpsStatusChanged(int event);
|
|
}
|
|
|
|
/**
|
|
* Used for receiving NMEA sentences from the GPS.
|
|
* NMEA 0183 is a standard for communicating with marine electronic devices
|
|
* and is a common method for receiving data from a GPS, typically over a serial port.
|
|
* See <a href="http://en.wikipedia.org/wiki/NMEA_0183">NMEA 0183</a> for more details.
|
|
* You can implement this interface and call {@link LocationManager#addNmeaListener}
|
|
* to receive NMEA data from the GPS engine.
|
|
* @deprecated use {@link OnNmeaMessageListener} instead.
|
|
*/
|
|
@Deprecated
|
|
public interface NmeaListener {
|
|
void onNmeaReceived(long timestamp, String nmea);
|
|
}
|
|
|
|
// For API-compat a public ctor() is not available
|
|
GpsStatus() {}
|
|
|
|
private void setStatus(int svCount, int[] svidWithFlags, float[] cn0s, float[] elevations,
|
|
float[] azimuths) {
|
|
clearSatellites();
|
|
for (int i = 0; i < svCount; i++) {
|
|
final int constellationType =
|
|
(svidWithFlags[i] >> GnssStatus.CONSTELLATION_TYPE_SHIFT_WIDTH)
|
|
& GnssStatus.CONSTELLATION_TYPE_MASK;
|
|
int prn = svidWithFlags[i] >> GnssStatus.SVID_SHIFT_WIDTH;
|
|
// Other satellites passed through these APIs before GnssSvStatus was availble.
|
|
// GPS, SBAS & QZSS can pass through at their nominally
|
|
// assigned prn number (as long as it fits in the valid 0-255 range below.)
|
|
// Glonass, and Beidou are passed through with the defacto standard offsets
|
|
// Other future constellation reporting (e.g. Galileo) needs to use
|
|
// GnssSvStatus on (N level) HAL & Java layers.
|
|
if (constellationType == GnssStatus.CONSTELLATION_GLONASS) {
|
|
prn += GLONASS_SVID_OFFSET;
|
|
} else if (constellationType == GnssStatus.CONSTELLATION_BEIDOU) {
|
|
prn += BEIDOU_SVID_OFFSET;
|
|
} else if (constellationType == GnssStatus.CONSTELLATION_SBAS) {
|
|
prn += SBAS_SVID_OFFSET;
|
|
} else if ((constellationType != GnssStatus.CONSTELLATION_GPS) &&
|
|
(constellationType != GnssStatus.CONSTELLATION_QZSS)) {
|
|
continue;
|
|
}
|
|
if (prn > 0 && prn <= NUM_SATELLITES) {
|
|
GpsSatellite satellite = mSatellites.get(prn);
|
|
if (satellite == null) {
|
|
satellite = new GpsSatellite(prn);
|
|
mSatellites.put(prn, satellite);
|
|
}
|
|
|
|
satellite.mValid = true;
|
|
satellite.mSnr = cn0s[i];
|
|
satellite.mElevation = elevations[i];
|
|
satellite.mAzimuth = azimuths[i];
|
|
satellite.mHasEphemeris =
|
|
(svidWithFlags[i] & GnssStatus.GNSS_SV_FLAGS_HAS_EPHEMERIS_DATA) != 0;
|
|
satellite.mHasAlmanac =
|
|
(svidWithFlags[i] & GnssStatus.GNSS_SV_FLAGS_HAS_ALMANAC_DATA) != 0;
|
|
satellite.mUsedInFix =
|
|
(svidWithFlags[i] & GnssStatus.GNSS_SV_FLAGS_USED_IN_FIX) != 0;
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Copies GPS satellites information from GnssStatus object.
|
|
* Since this method is only used within {@link LocationManager#getGpsStatus},
|
|
* it does not need to be synchronized.
|
|
* @hide
|
|
*/
|
|
void setStatus(GnssStatus status, int timeToFirstFix) {
|
|
mTimeToFirstFix = timeToFirstFix;
|
|
setStatus(status.mSvCount, status.mSvidWithFlags, status.mCn0DbHz, status.mElevations,
|
|
status.mAzimuths);
|
|
}
|
|
|
|
void setTimeToFirstFix(int ttff) {
|
|
mTimeToFirstFix = ttff;
|
|
}
|
|
|
|
/**
|
|
* Returns the time required to receive the first fix since the most recent
|
|
* restart of the GPS engine.
|
|
*
|
|
* @return time to first fix in milliseconds
|
|
*/
|
|
public int getTimeToFirstFix() {
|
|
return mTimeToFirstFix;
|
|
}
|
|
|
|
/**
|
|
* Returns an array of {@link GpsSatellite} objects, which represent the
|
|
* current state of the GPS engine.
|
|
*
|
|
* @return the list of satellites
|
|
*/
|
|
public Iterable<GpsSatellite> getSatellites() {
|
|
return mSatelliteList;
|
|
}
|
|
|
|
/**
|
|
* Returns the maximum number of satellites that can be in the satellite
|
|
* list that can be returned by {@link #getSatellites()}.
|
|
*
|
|
* @return the maximum number of satellites
|
|
*/
|
|
public int getMaxSatellites() {
|
|
return NUM_SATELLITES;
|
|
}
|
|
|
|
private void clearSatellites() {
|
|
int satellitesCount = mSatellites.size();
|
|
for (int i = 0; i < satellitesCount; i++) {
|
|
GpsSatellite satellite = mSatellites.valueAt(i);
|
|
satellite.mValid = false;
|
|
}
|
|
}
|
|
}
|