1 /* 2 * Copyright (C) 2014 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 package android.telephony; 18 19 import android.content.Context; 20 import android.graphics.Bitmap; 21 import android.graphics.Canvas; 22 import android.graphics.Color; 23 import android.graphics.Paint; 24 import android.graphics.PorterDuff; 25 import android.graphics.PorterDuffColorFilter; 26 import android.graphics.Rect; 27 import android.graphics.Typeface; 28 import android.os.Build; 29 import android.os.Parcel; 30 import android.os.Parcelable; 31 import android.util.DisplayMetrics; 32 33 /** 34 * A Parcelable class for Subscription Information. 35 */ 36 public class SubscriptionInfo implements Parcelable { 37 38 /** 39 * Size of text to render on the icon. 40 */ 41 private static final int TEXT_SIZE = 16; 42 43 /** 44 * Subscription Identifier, this is a device unique number 45 * and not an index into an array 46 */ 47 private int mId; 48 49 /** 50 * The GID for a SIM that maybe associated with this subscription, empty if unknown 51 */ 52 private String mIccId; 53 54 /** 55 * The index of the slot that currently contains the subscription 56 * and not necessarily unique and maybe INVALID_SLOT_ID if unknown 57 */ 58 private int mSimSlotIndex; 59 60 /** 61 * The name displayed to the user that identifies this subscription 62 */ 63 private CharSequence mDisplayName; 64 65 /** 66 * String that identifies SPN/PLMN 67 * TODO : Add a new field that identifies only SPN for a sim 68 */ 69 private CharSequence mCarrierName; 70 71 /** 72 * The source of the name, NAME_SOURCE_UNDEFINED, NAME_SOURCE_DEFAULT_SOURCE, 73 * NAME_SOURCE_SIM_SOURCE or NAME_SOURCE_USER_INPUT. 74 */ 75 private int mNameSource; 76 77 /** 78 * The color to be used for tinting the icon when displaying to the user 79 */ 80 private int mIconTint; 81 82 /** 83 * A number presented to the user identify this subscription 84 */ 85 private String mNumber; 86 87 /** 88 * Data roaming state, DATA_RAOMING_ENABLE, DATA_RAOMING_DISABLE 89 */ 90 private int mDataRoaming; 91 92 /** 93 * SIM Icon bitmap 94 */ 95 private Bitmap mIconBitmap; 96 97 /** 98 * Mobile Country Code 99 */ 100 private int mMcc; 101 102 /** 103 * Mobile Network Code 104 */ 105 private int mMnc; 106 107 /** 108 * ISO Country code for the subscription's provider 109 */ 110 private String mCountryIso; 111 112 /** 113 * @hide 114 */ SubscriptionInfo(int id, String iccId, int simSlotIndex, CharSequence displayName, CharSequence carrierName, int nameSource, int iconTint, String number, int roaming, Bitmap icon, int mcc, int mnc, String countryIso)115 public SubscriptionInfo(int id, String iccId, int simSlotIndex, CharSequence displayName, 116 CharSequence carrierName, int nameSource, int iconTint, String number, int roaming, 117 Bitmap icon, int mcc, int mnc, String countryIso) { 118 this.mId = id; 119 this.mIccId = iccId; 120 this.mSimSlotIndex = simSlotIndex; 121 this.mDisplayName = displayName; 122 this.mCarrierName = carrierName; 123 this.mNameSource = nameSource; 124 this.mIconTint = iconTint; 125 this.mNumber = number; 126 this.mDataRoaming = roaming; 127 this.mIconBitmap = icon; 128 this.mMcc = mcc; 129 this.mMnc = mnc; 130 this.mCountryIso = countryIso; 131 } 132 133 /** 134 * @return the subscription ID. 135 */ getSubscriptionId()136 public int getSubscriptionId() { 137 return this.mId; 138 } 139 140 /** 141 * @return the ICC ID. 142 */ getIccId()143 public String getIccId() { 144 return this.mIccId; 145 } 146 147 /** 148 * @return the slot index of this Subscription's SIM card. 149 */ getSimSlotIndex()150 public int getSimSlotIndex() { 151 return this.mSimSlotIndex; 152 } 153 154 /** 155 * @return the name displayed to the user that identifies this subscription 156 */ getDisplayName()157 public CharSequence getDisplayName() { 158 return this.mDisplayName; 159 } 160 161 /** 162 * Sets the name displayed to the user that identifies this subscription 163 * @hide 164 */ setDisplayName(CharSequence name)165 public void setDisplayName(CharSequence name) { 166 this.mDisplayName = name; 167 } 168 169 /** 170 * @return the name displayed to the user that identifies Subscription provider name 171 */ getCarrierName()172 public CharSequence getCarrierName() { 173 return this.mCarrierName; 174 } 175 176 /** 177 * Sets the name displayed to the user that identifies Subscription provider name 178 * @hide 179 */ setCarrierName(CharSequence name)180 public void setCarrierName(CharSequence name) { 181 this.mCarrierName = name; 182 } 183 184 /** 185 * @return the source of the name, eg NAME_SOURCE_UNDEFINED, NAME_SOURCE_DEFAULT_SOURCE, 186 * NAME_SOURCE_SIM_SOURCE or NAME_SOURCE_USER_INPUT. 187 * @hide 188 */ getNameSource()189 public int getNameSource() { 190 return this.mNameSource; 191 } 192 193 /** 194 * Creates and returns an icon {@code Bitmap} to represent this {@code SubscriptionInfo} in a user 195 * interface. 196 * 197 * @param context A {@code Context} to get the {@code DisplayMetrics}s from. 198 * 199 * @return A bitmap icon for this {@code SubscriptionInfo}. 200 */ createIconBitmap(Context context)201 public Bitmap createIconBitmap(Context context) { 202 int width = mIconBitmap.getWidth(); 203 int height = mIconBitmap.getHeight(); 204 DisplayMetrics metrics = context.getResources().getDisplayMetrics(); 205 206 // Create a new bitmap of the same size because it will be modified. 207 Bitmap workingBitmap = Bitmap.createBitmap(metrics, width, height, mIconBitmap.getConfig()); 208 209 Canvas canvas = new Canvas(workingBitmap); 210 Paint paint = new Paint(); 211 212 // Tint the icon with the color. 213 paint.setColorFilter(new PorterDuffColorFilter(mIconTint, PorterDuff.Mode.SRC_ATOP)); 214 canvas.drawBitmap(mIconBitmap, 0, 0, paint); 215 paint.setColorFilter(null); 216 217 // Write the sim slot index. 218 paint.setAntiAlias(true); 219 paint.setTypeface(Typeface.create("sans-serif", Typeface.NORMAL)); 220 paint.setColor(Color.WHITE); 221 // Set text size scaled by density 222 paint.setTextSize(TEXT_SIZE * metrics.density); 223 // Convert sim slot index to localized string 224 final String index = String.format("%d", mSimSlotIndex + 1); 225 final Rect textBound = new Rect(); 226 paint.getTextBounds(index, 0, 1, textBound); 227 final float xOffset = (width / 2.f) - textBound.centerX(); 228 final float yOffset = (height / 2.f) - textBound.centerY(); 229 canvas.drawText(index, xOffset, yOffset, paint); 230 231 return workingBitmap; 232 } 233 234 /** 235 * A highlight color to use in displaying information about this {@code PhoneAccount}. 236 * 237 * @return A hexadecimal color value. 238 */ getIconTint()239 public int getIconTint() { 240 return mIconTint; 241 } 242 243 /** 244 * Sets the color displayed to the user that identifies this subscription 245 * @hide 246 */ setIconTint(int iconTint)247 public void setIconTint(int iconTint) { 248 this.mIconTint = iconTint; 249 } 250 251 /** 252 * @return the number of this subscription. 253 */ getNumber()254 public String getNumber() { 255 return mNumber; 256 } 257 258 /** 259 * @return the data roaming state for this subscription, either 260 * {@link SubscriptionManager#DATA_ROAMING_ENABLE} or {@link SubscriptionManager#DATA_ROAMING_DISABLE}. 261 */ getDataRoaming()262 public int getDataRoaming() { 263 return this.mDataRoaming; 264 } 265 266 /** 267 * @return the MCC. 268 */ getMcc()269 public int getMcc() { 270 return this.mMcc; 271 } 272 273 /** 274 * @return the MNC. 275 */ getMnc()276 public int getMnc() { 277 return this.mMnc; 278 } 279 280 /** 281 * @return the ISO country code 282 */ getCountryIso()283 public String getCountryIso() { 284 return this.mCountryIso; 285 } 286 287 public static final Parcelable.Creator<SubscriptionInfo> CREATOR = new Parcelable.Creator<SubscriptionInfo>() { 288 @Override 289 public SubscriptionInfo createFromParcel(Parcel source) { 290 int id = source.readInt(); 291 String iccId = source.readString(); 292 int simSlotIndex = source.readInt(); 293 CharSequence displayName = source.readCharSequence(); 294 CharSequence carrierName = source.readCharSequence(); 295 int nameSource = source.readInt(); 296 int iconTint = source.readInt(); 297 String number = source.readString(); 298 int dataRoaming = source.readInt(); 299 int mcc = source.readInt(); 300 int mnc = source.readInt(); 301 String countryIso = source.readString(); 302 Bitmap iconBitmap = Bitmap.CREATOR.createFromParcel(source); 303 304 return new SubscriptionInfo(id, iccId, simSlotIndex, displayName, carrierName, 305 nameSource, iconTint, number, dataRoaming, iconBitmap, mcc, mnc, countryIso); 306 } 307 308 @Override 309 public SubscriptionInfo[] newArray(int size) { 310 return new SubscriptionInfo[size]; 311 } 312 }; 313 314 @Override writeToParcel(Parcel dest, int flags)315 public void writeToParcel(Parcel dest, int flags) { 316 dest.writeInt(mId); 317 dest.writeString(mIccId); 318 dest.writeInt(mSimSlotIndex); 319 dest.writeCharSequence(mDisplayName); 320 dest.writeCharSequence(mCarrierName); 321 dest.writeInt(mNameSource); 322 dest.writeInt(mIconTint); 323 dest.writeString(mNumber); 324 dest.writeInt(mDataRoaming); 325 dest.writeInt(mMcc); 326 dest.writeInt(mMnc); 327 dest.writeString(mCountryIso); 328 mIconBitmap.writeToParcel(dest, flags); 329 } 330 331 @Override describeContents()332 public int describeContents() { 333 return 0; 334 } 335 336 /** 337 * @hide 338 */ givePrintableIccid(String iccId)339 public static String givePrintableIccid(String iccId) { 340 String iccIdToPrint = null; 341 if (iccId != null) { 342 if (iccId.length() > 9 && !Build.IS_DEBUGGABLE) { 343 iccIdToPrint = iccId.substring(0, 9) + Rlog.pii(false, iccId.substring(9)); 344 } else { 345 iccIdToPrint = iccId; 346 } 347 } 348 return iccIdToPrint; 349 } 350 351 @Override toString()352 public String toString() { 353 String iccIdToPrint = givePrintableIccid(mIccId); 354 return "{id=" + mId + ", iccId=" + iccIdToPrint + " simSlotIndex=" + mSimSlotIndex 355 + " displayName=" + mDisplayName + " carrierName=" + mCarrierName 356 + " nameSource=" + mNameSource + " iconTint=" + mIconTint 357 + " dataRoaming=" + mDataRoaming + " iconBitmap=" + mIconBitmap + " mcc " + mMcc 358 + " mnc " + mMnc + "}"; 359 } 360 } 361