首页 > 系统 > Android > 正文

android 通讯相关,MTK平台

2019-11-06 10:04:32
字体:
来源:转载
供稿:网友

IMSI共有15位,其结构如下:MCC+MNC+MSIN ,(MNC+MSIN=NMSI) MCC:Mobile Country Code,移动国家码,MCC的资源由国际电联(ITU)统一分配和管理,唯一识别移动用户所属的国家,共3位,中国为460;   MNC:Mobile Network Code,移动网络码,共2位,中国移动TD系统使用00,中国联通GSM系统使用01,中国移动GSM系统使用02,中国电信CDMA系统使用03,一个典型的IMSI号码为460030912121001 MSIN:Mobile Subscriber Identification Number共有10位,其结构如下:09+M0M1M2M3+ABCD 其中的M0M1M2M3和MDN号码中的H0H1H2H3可存在对应关系,ABCD四位为自由分配。可以看出IMSI在MSIN号码前加了MCC即NMSI,可以区别出每个用户的来自的国家,因此可以实现国际漫游。在同一个国家内,如果有多个移动网络运营商,可以通过MNC来进行区别。

IMEI是国际移动设备身份码的缩写,国际移动装备辨识码,是由15位数字组成的”电子串号”,它与每台手机一一对应,而且该码是全世界唯一的。

获取MCC:

public static int getMCC(Context context) { TelephonyManager tel = (TelephonyManager) context.getSystemService(Context.TELEPHONY_SERVICE); String imsi = tel.getSubscriberId(); Log.d("getMcc------------imsi="+imsi); if (imsi != null && imsi.length() >= 3) { int mcc = Integer.parseInt(imsi.substring(0, 3)); //int mnc = Integer.parseInt(networkOperator.substring(3)); Log.i("send SMS:**************** mcc=" + mcc); return mcc; } else return INT_ALQ_MCC; }

获取MNC:

public static String getMNC(Context context, int slotId) { TelephonyManager tel = (TelephonyManager) context.getSystemService(Context.TELEPHONY_SERVICE); String networkOperator = tel.getNetworkOperator(); Log.e("slotId:" + slotId); SubscriptionInfo info = SubscriptionManager.from(context).getActiveSubscriptionInfoForSimSlotIndex(slotId); if (info == null) return "0"; int subId = info.getSubscriptionId(); String imsi = tel.getSubscriberId(subId); if (imsi != null && imsi.length() >= 5) { int mnc = Integer.parseInt(imsi.substring(0, 5)); //int mnc = Integer.parseInt(networkOperator.substring(3)); Log.e("Send SMS:**************** slotId:" + slotId + ", imsi:" + imsi); return mnc + ""; } //默认返回印度MCC else return 0 + ""; }

获取IMEI

PRivate static String getDeviceIMEI(Context context, int slotId) { TelephonyManager tm = (TelephonyManager) context.getSystemService(Context.TELEPHONY_SERVICE); return tm.getDeviceId(slotId); }

是否飞行模式:

public static boolean IsAirModeOn(Context context) { return (Settings.System.getInt(context.getContentResolver(), Settings.System.AIRPLANE_MODE_ON, 0) == 1 ? true : false); }

双卡 获取那个卡是可用的

private int getSimId() { final List<SubscriptionInfo> subInfoList = SubscriptionManager.from(this).getActiveSubscriptionInfoList(); mSim0State = SubscriptionManager.getSimStateForSlotIdx(0); mSim1State = SubscriptionManager.getSimStateForSlotIdx(1); //Log.i("subInfoList.size="+subInfoList.size()); if (subInfoList != null) for (SubscriptionInfo subInfo : subInfoList) { int state = -1; int simId = -1; if (subInfo.getSimSlotIndex() == 0 && mSim0State == TelephonyManager.SIM_STATE_READY) { state = mSim0State; simId = 0; } else { state = mSim1State; simId = 1; } Log.i("ws->subInfo=" + subInfo + ";  simSlotIndex=" + subInfo.getSimSlotIndex() + ";  simState=" + state); if (state == TelephonyManager.SIM_STATE_READY) { return simId; } } return -1; }

监听卡改变的状态的广播

"android.intent.action.SIM_STATE_CHANGED";

WalkLock 与KeyguardLock

1: WalkLock 唤醒锁

WalkLock真的能点亮屏幕吗?

答案是肯定的。 可是有时候为什么不点亮屏幕,这个就是参数设置的问题了。 复制代码 代码如下: PowerManager.newWakeLock(PowerManager.FULL_WAKE_LOCK | PowerManager.ACQUIRE_CAUSES_WAKEUP, “Gank”);

PowerManager.FULL_WAKE_LOCK 这个参数是手机点亮的程度,(什么Cpu,屏幕亮度,键盘灯) PowerManager.ACQUIRE_CAUSES_WAKEUP 关键是这个参数的理解。 WalkLock点亮屏幕并非真的去点亮了屏幕,你可以理解为,它通过Android组件(Activity)去点亮了屏幕。

假如一个通知想去点亮屏幕,问题来了,它能点亮吗? 肯定不行。

不过拥有这个PowerManager.ACQUIRE_CAUSES_WAKEU参数,你就可以点亮屏幕了。它使WalkLock不再依赖组件就可以点亮屏幕了。

WalkLock如何获得屏幕的状态?

PowerManager.isScreenOn()方法;这个方法返回true: 屏幕是唤醒的 返回false:屏幕是休眠的

WalkLock唤醒和休眠的方法?

WalkLock.aquire() 在屏幕休眠的状态下唤醒屏幕 WalkLock.release() 在屏幕点亮的状态下,使屏幕休眠。

WalkLock.release()这个方法有个需要注意的地方:

例如:WalkLockA对象先唤醒了屏幕再使屏幕休眠,ok没问题

屏幕本身就是唤醒状态,WalkLockA对象没有唤醒过屏幕,WalkLockA对象如果尝试使屏幕休眠。会产生一个异常 UnLock Sreen。

2:KeyguardLock 键盘锁

KeyguardLock获得当前屏幕是否解锁?

KeygroundManager.inKeyguardRestrictedInputMode() 返回true表示键盘锁住, 返回false表示键盘解锁中

KeyguardLock给屏幕解锁和上锁?

KeyguardLock.disableKeyguard()解锁键盘 KeyguardLock.reenableKeyguard()锁键盘

KeyguardLock没有上面唤醒锁的问题,就是无论你键盘是否由KeyguardLockA解锁,你调用KeyguardLockA对象的reenableKeyguard()方法都不会有异常。

这两把锁一些概念性的理解,假如你认为你获得了一个键盘锁对象,你就可以锁屏幕了。这个就大错特错了。

你锁不了其他程序打开的屏幕(如果可以的话,一个for循环一直锁你屏幕,你哭都没眼泪)

你可以控制自己的锁,别想着别人的锁。

最后总结下用法:

一般这两把锁都是配合使用的,你解锁屏幕的时候肯定不希望屏幕漆黑一片。关闭键盘锁的时候希望屏幕也同时休眠。

问题:

1:我尝试手动关闭屏幕,可是总继续亮那么一小会。 2:如果手机自动关闭屏幕的话,不会有这个问题。

public void unlockScreen() { // 获取PowerManager的实例 PowerManager pm = (PowerManager) mContext .getSystemService(Context.POWER_SERVICE); // 得到一个WakeLock唤醒锁 mWakelock = pm.newWakeLock(PowerManager.FULL_WAKE_LOCK | PowerManager.ACQUIRE_CAUSES_WAKEUP | PowerManager.ON_AFTER_RELEASE, "SimpleTimer"); if (!mWakelock.isHeld()) { // 唤醒屏幕 mWakelock.acquire(); } // 获得一个KeyguardManager的实例 km = (KeyguardManager) mContext .getSystemService(Context.KEYGUARD_SERVICE); // 得到一个键盘锁KeyguardLock mKeyguardLock = km.newKeyguardLock("SimpleTimer"); if (km.inKeyguardRestrictedInputMode()) { // 解锁键盘 mKeyguardLock.disableKeyguard(); }}

注意,这里使用的mWakelock.isHeld())来判断屏幕当前是否是休眠状态,从Android 2.1 API Level7开始增加了一个判断屏幕是否处于点亮状态可以使用public boolean isScreenOn ()这个方法。

锁屏幕的代码是

public void lockScreen() { // release screen if (!km.inKeyguardRestrictedInputMode()) { // 锁键盘 mKeyguardLock.reenableKeyguard(); } // 使屏幕休眠 if (mWakelock.isHeld()) { mWakelock.release(); }}
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表