/*
 * 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 android.telephony;

import android.annotation.Nullable;
import android.os.Parcel;
import android.text.TextUtils;

import java.util.Objects;

CellIdentity is to represent a unique CDMA cell
/** * CellIdentity is to represent a unique CDMA cell */
public final class CellIdentityCdma extends CellIdentity { private static final String TAG = CellIdentityCdma.class.getSimpleName(); private static final boolean DBG = false; // Network Id 0..65535 private final int mNetworkId; // CDMA System Id 0..32767 private final int mSystemId; // Base Station Id 0..65535 private final int mBasestationId;
Longitude is a decimal number as specified in 3GPP2 C.S0005-A v6.0. It is represented in units of 0.25 seconds and ranges from -2592000 to 2592000, both values inclusive (corresponding to a range of -180 to +180 degrees).
/** * Longitude is a decimal number as specified in 3GPP2 C.S0005-A v6.0. * It is represented in units of 0.25 seconds and ranges from -2592000 * to 2592000, both values inclusive (corresponding to a range of -180 * to +180 degrees). */
private final int mLongitude;
Latitude is a decimal number as specified in 3GPP2 C.S0005-A v6.0. It is represented in units of 0.25 seconds and ranges from -1296000 to 1296000, both values inclusive (corresponding to a range of -90 to +90 degrees).
/** * Latitude is a decimal number as specified in 3GPP2 C.S0005-A v6.0. * It is represented in units of 0.25 seconds and ranges from -1296000 * to 1296000, both values inclusive (corresponding to a range of -90 * to +90 degrees). */
private final int mLatitude;
@hide
/** * @hide */
public CellIdentityCdma() { super(TAG, TYPE_CDMA, null, null, null, null); mNetworkId = Integer.MAX_VALUE; mSystemId = Integer.MAX_VALUE; mBasestationId = Integer.MAX_VALUE; mLongitude = Integer.MAX_VALUE; mLatitude = Integer.MAX_VALUE; }
public constructor
Params:
  • nid – Network Id 0..65535
  • sid – CDMA System Id 0..32767
  • bid – Base Station Id 0..65535
  • lon – Longitude is a decimal number ranges from -2592000 to 2592000
  • lat – Latitude is a decimal number ranges from -1296000 to 1296000
@hide
/** * public constructor * @param nid Network Id 0..65535 * @param sid CDMA System Id 0..32767 * @param bid Base Station Id 0..65535 * @param lon Longitude is a decimal number ranges from -2592000 * to 2592000 * @param lat Latitude is a decimal number ranges from -1296000 * to 1296000 * * @hide */
public CellIdentityCdma(int nid, int sid, int bid, int lon, int lat) { this(nid, sid, bid, lon, lat, null, null); }
public constructor
Params:
  • nid – Network Id 0..65535
  • sid – CDMA System Id 0..32767
  • bid – Base Station Id 0..65535
  • lon – Longitude is a decimal number ranges from -2592000 to 2592000
  • lat – Latitude is a decimal number ranges from -1296000 to 1296000
  • alphal – long alpha Operator Name String or Enhanced Operator Name String
  • alphas – short alpha Operator Name String or Enhanced Operator Name String
@hide
/** * public constructor * @param nid Network Id 0..65535 * @param sid CDMA System Id 0..32767 * @param bid Base Station Id 0..65535 * @param lon Longitude is a decimal number ranges from -2592000 * to 2592000 * @param lat Latitude is a decimal number ranges from -1296000 * to 1296000 * @param alphal long alpha Operator Name String or Enhanced Operator Name String * @param alphas short alpha Operator Name String or Enhanced Operator Name String * * @hide */
public CellIdentityCdma(int nid, int sid, int bid, int lon, int lat, String alphal, String alphas) { super(TAG, TYPE_CDMA, null, null, alphal, alphas); mNetworkId = nid; mSystemId = sid; mBasestationId = bid; if (!isNullIsland(lat, lon)) { mLongitude = lon; mLatitude = lat; } else { mLongitude = mLatitude = Integer.MAX_VALUE; } } private CellIdentityCdma(CellIdentityCdma cid) { this(cid.mNetworkId, cid.mSystemId, cid.mBasestationId, cid.mLongitude, cid.mLatitude, cid.mAlphaLong, cid.mAlphaShort); } CellIdentityCdma copy() { return new CellIdentityCdma(this); }
Take the latitude and longitude in 1/4 seconds and see if the reported location is on Null Island.
Returns:whether the reported Lat/Long are for Null Island
@hide
/** * Take the latitude and longitude in 1/4 seconds and see if * the reported location is on Null Island. * * @return whether the reported Lat/Long are for Null Island * * @hide */
private boolean isNullIsland(int lat, int lon) { return Math.abs(lat) <= 1 && Math.abs(lon) <= 1; }
Returns:Network Id 0..65535, Integer.MAX_VALUE if unknown
/** * @return Network Id 0..65535, Integer.MAX_VALUE if unknown */
public int getNetworkId() { return mNetworkId; }
Returns:System Id 0..32767, Integer.MAX_VALUE if unknown
/** * @return System Id 0..32767, Integer.MAX_VALUE if unknown */
public int getSystemId() { return mSystemId; }
Returns:Base Station Id 0..65535, Integer.MAX_VALUE if unknown
/** * @return Base Station Id 0..65535, Integer.MAX_VALUE if unknown */
public int getBasestationId() { return mBasestationId; }
Returns:Base station longitude, which is a decimal number as specified in 3GPP2 C.S0005-A v6.0. It is represented in units of 0.25 seconds and ranges from -2592000 to 2592000, both values inclusive (corresponding to a range of -180 to +180 degrees). Integer.MAX_VALUE if unknown.
/** * @return Base station longitude, which is a decimal number as * specified in 3GPP2 C.S0005-A v6.0. It is represented in units * of 0.25 seconds and ranges from -2592000 to 2592000, both * values inclusive (corresponding to a range of -180 * to +180 degrees). Integer.MAX_VALUE if unknown. */
public int getLongitude() { return mLongitude; }
Returns:Base station latitude, which is a decimal number as specified in 3GPP2 C.S0005-A v6.0. It is represented in units of 0.25 seconds and ranges from -1296000 to 1296000, both values inclusive (corresponding to a range of -90 to +90 degrees). Integer.MAX_VALUE if unknown.
/** * @return Base station latitude, which is a decimal number as * specified in 3GPP2 C.S0005-A v6.0. It is represented in units * of 0.25 seconds and ranges from -1296000 to 1296000, both * values inclusive (corresponding to a range of -90 * to +90 degrees). Integer.MAX_VALUE if unknown. */
public int getLatitude() { return mLatitude; } @Override public int hashCode() { return Objects.hash(mNetworkId, mSystemId, mBasestationId, mLatitude, mLongitude, super.hashCode()); } @Override public boolean equals(Object other) { if (this == other) { return true; } if (!(other instanceof CellIdentityCdma)) { return false; } CellIdentityCdma o = (CellIdentityCdma) other; return mNetworkId == o.mNetworkId && mSystemId == o.mSystemId && mBasestationId == o.mBasestationId && mLatitude == o.mLatitude && mLongitude == o.mLongitude && super.equals(other); } @Override public String toString() { return new StringBuilder(TAG) .append(":{ mNetworkId=").append(mNetworkId) .append(" mSystemId=").append(mSystemId) .append(" mBasestationId=").append(mBasestationId) .append(" mLongitude=").append(mLongitude) .append(" mLatitude=").append(mLatitude) .append(" mAlphaLong=").append(mAlphaLong) .append(" mAlphaShort=").append(mAlphaShort) .append("}").toString(); }
Implement the Parcelable interface
/** Implement the Parcelable interface */
@Override public void writeToParcel(Parcel dest, int flags) { if (DBG) log("writeToParcel(Parcel, int): " + toString()); super.writeToParcel(dest, TYPE_CDMA); dest.writeInt(mNetworkId); dest.writeInt(mSystemId); dest.writeInt(mBasestationId); dest.writeInt(mLongitude); dest.writeInt(mLatitude); }
Construct from Parcel, type has already been processed
/** Construct from Parcel, type has already been processed */
private CellIdentityCdma(Parcel in) { super(TAG, TYPE_CDMA, in); mNetworkId = in.readInt(); mSystemId = in.readInt(); mBasestationId = in.readInt(); mLongitude = in.readInt(); mLatitude = in.readInt(); if (DBG) log(toString()); }
Implement the Parcelable interface
/** Implement the Parcelable interface */
@SuppressWarnings("hiding") public static final Creator<CellIdentityCdma> CREATOR = new Creator<CellIdentityCdma>() { @Override public CellIdentityCdma createFromParcel(Parcel in) { in.readInt(); // skip return createFromParcelBody(in); } @Override public CellIdentityCdma[] newArray(int size) { return new CellIdentityCdma[size]; } };
@hide
/** @hide */
protected static CellIdentityCdma createFromParcelBody(Parcel in) { return new CellIdentityCdma(in); } }