android 通讯相关,MTK平台

本文详细介绍了Android中与通讯相关的概念,如IMSI和IMEI的结构及其作用。针对MTK平台,讲解了如何获取MCC和MNC,以及如何管理设备的唤醒锁(WalkLock)和键盘锁(KeyguardLock),包括它们的使用场景和注意事项。同时提到了屏幕状态的检测与控制问题。

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();
  }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值