HarmonyOS之应用开发的电话服务与蜂窝网络

举报
Serendipity·y 发表于 2022/02/17 01:03:26 2022/02/17
【摘要】 一、电话服务 电话服务系统提供了一系列的 API 用于获取无线蜂窝网络和 SIM 卡相关的一些信息。应用可以通过调用 RadioInfoManager 中的 API,来获取当前注册网络名称、网络服务状态...

一、电话服务

  • 电话服务系统提供了一系列的 API 用于获取无线蜂窝网络和 SIM 卡相关的一些信息。
  • 应用可以通过调用 RadioInfoManager 中的 API,来获取当前注册网络名称、网络服务状态以及信号强度等信息;以及调用 SimInfoManager 中的 API,来获取 SIM 卡的相关信息。
  • 注册获取 SIM 卡状态接口仅针对有 SIM 卡在位场景生效,若用户拔出 SIM 卡,则接收不到回调事件。应用可通过调用 hasSimCard 接口来确定当前卡槽是否有卡在位。

二、获取当前蜂窝网络信号信息

① 应用场景
  • 应用通常需要获取用户所在蜂窝网络下信号信息,以便获取当前驻网质量。
  • 开发者可以通过本业务,获取到用户指定SIM卡当前所在网络下的信号信息。
② API 说明
  • RadioInfoManager 类中提供了获取当前网络信号信息列表的方法。
  • RadioInfoManager 的主要接口:
功能分类 接口名 描述 所需权限
获取管理对象 getInstance​(Context context) 获取网络管理对象
信号强度信息 getSignalInfoList​​(int slotId) 获取当前注册蜂窝网络信号强度信息
③ 使用
  • 调用 RadioInfoManager 的 getInstance 接口,获取到 RadioInfoManager 实例。
  • 调用 getSignalInfoList(slotId) 方法,返回所有 SignalInformation 列表。
  • 遍历 SignalInformation 列表,并分别根据 signalNetworkType 转换为对应制式的 SignalInformation 子类对象。
  • 调用子类中的方法,获取信号强度信息。
	// 获取RadioInfoManager对象。
	RadioInfoManager radioInfoManager = RadioInfoManager.getInstance(context);
	
	// 获取信号信息。
	List<SignalInformation> signalList = radioInfoManager.getSignalInfoList(slotId);
	
	// 检查信号信息列表大小。
	if (signalList.size() == 0) {
	    return;
	}
	// 依次遍历list获取当前驻网networkType对应的信号信息。
	LteSignalInformation lteSignal = new LteSignalInformation();
	for (SignalInformation signal : signalList) {
	    int signalNetworkType = signal.getNetworkType();
	    if (signalNetworkType == TelephonyConstants.NETWORK_TYPE_LTE) {
	        lteSignal = (LteSignalInformation) signal;
	    }
	}
	// 调用子类中相应方法,获取对应制式的信号强度信息。
	int signalLevel = lteSignal.getSignalLevel();

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20

三、观察蜂窝网络状态变化

① 应用场景
  • 应用可以通过观察蜂窝网络状态变化,来接收最新蜂窝网络服务状态信息、信号信息等。
② API 说明
  • RadioStateObserver 类中提供了观察蜂窝网络状态变化的方法,为了能够实时观察蜂窝网络状态变化,应用必须包含以下权限:
观察状态名称 权限名称
网络状态信息(NETWORK_STATE) ohos.permission.GET_NETWORK_INFO
信号信息(SIGNAL_INFO) NA
  • 需要使用 RadioInfoManager 的如下接口将继承 RadioStateObserver 类的对象注册到系统服务:
接口名 观察事件的掩码 描述
addObserver OBSERVE_MASK_NETWORK_STATE 观察蜂窝网络驻网状态信息
OBSERVE_MASK_SIGNAL_INFO 观察蜂窝网络信号信息
removeObserver N/A 停止观察所有状态的变化
③ 使用
  • 添加观察事件:
    • 调用 RadioInfoManager 的 getInstance 接口,获取到 RadioInfoManager 实例。
    • 创建继承 RadioStateObserver 的类 MyRadioStateObserver,并覆写状态变化回调方法。
    • 创建 MyRadioStateObserver 的对象 observer。
    • 调用 RadioInfoManager 的 addObserver 方法,传入已创建的 MyRadioStateObserver 对象 observer 和需要观察的 mask。
	// 获取RadioInfoManager对象。
	RadioInfoManager radioInfoManager = RadioInfoManager.getInstance(context);
	// 创建继承RadioStateObserver的类MyRadioStateObserver
	class MyRadioStateObserver extends RadioStateObserver {
	    // 构造方法,在当前线程的runner中执行回调,slotId需要传入要观察的卡槽ID(0或1)。
	    MyRadioStateObserver(int slotId) {
	        super(slotId);
	    }
	
	    // 构造方法,在执行runner中执行回调。
	    MyRadioStateObserver(int slotId, EventRunner runner) {
	        super(slotId, runner);
	    }
	
	    // 网络注册状态变化的回调方法。
	    @Override
	    public void onNetworkStateUpdated(NetworkState state) {
	        ...
	    }
	
	    // 信号信息变化的回调方法。
	    @Override
	    public void onSignalInfoUpdated(List<SignalInformation> signalInfos) {
	        ...
	    }
	}
	
	// 执行回调的runner。
	EventRunner runner = EventRunner.create();
	
	// 创建MyRadioStateObserver的对象。
	MyRadioStateObserver observer = new MyRadioStateObserver(slotId, runner);
	
	// 添加回调,以NETWORK_STATE和SIGNAL_INFO为例。
	radioInfoManager.addObserver(observer, RadioStateObserver.OBSERVE_MASK_NETWORK_STATE | RadioStateObserver.OBSERVE_MASK_SIGNAL_INFO);

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 停止观察
    • 调用 RadioInfoManager 的 getInstance 接口,获取到 RadioInfoManager 实例。
    • 调用 RadioInfoManager 的 removeObserver 方法,传入添加观察事件时创建的 MyRadioStateObserver 对象 observer。
	// 获取RadioInfoManager对象。
	RadioInfoManager radioInfoManager = RadioInfoManager.getInstance(context);
	// 停止观察
	radioInfoManager.removeObserver(observer);

  
 
  • 1
  • 2
  • 3
  • 4

文章来源: blog.csdn.net,作者:Serendipity·y,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/Forever_wj/article/details/118392614

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。