【笔记】Android 漫游定制SPN定制有关字段

本文详细介绍了SPN模块在Android系统的配置,包括非漫游SPN显示条件、覆盖卡文件EF_OPL和EF_PNN的设置,以及如何通过CarrierConfigManager处理漫游状态,如国内和国际漫游的区分,以及如何通过代码定制漫游时的OPL和PNN显示。
摘要由CSDN通过智能技术生成

一、SPN模块简介

【笔记】SPN和PLMN 运营商网络名称显示

Android U 配置 WiFiCalling 场景下PLMN/SPN 显示的代码逻辑介绍

【笔记】Android Telephony 漫游SPN显示定制(Roaming Alpha Tag)

二、相关配置字段

  • non_roaming_operator_string_array 是否视为非漫游
  • spn_display_condition_override_int 
  • opl_override_opl_string_array 覆写卡文件EF_OPL("plmn1,lactac_start,lactac_end,index")
  • pnn_override_string_array 覆写卡文件EF_PNN("alpha_long1,alpha_short1")

CarrierConfigManager 定义

frameworks/base/telephony/java/android/telephony/CarrierConfigManager.java

CarrierConfig-non_roaming_operator_string_array
【定义】CarrierConfig-non_roaming_operator_string_array​​​​​
CarrierConfig-spn_display_condition_override_int
【定义】CarrierConfig-spn_display_condition_override_int
【定义】CarrierConfig - opl_override_opl_string_array
【定义】CarrierConfig - opl_override_opl_string_array
【定义】CarrierConfig - pnn_override_string_array
【定义】CarrierConfig - pnn_override_string_array

三、需求场景及功能代码

漫游场景

漫游情况一般分为国内漫游和国际漫游(),一般国内漫游认为在国内,国际漫游在国外。

不清楚漫游到国内外的情况时,可以通过底层上报获取状态,接口getDataRoamingType()

frameworks/base/telephony/java/android/telephony/ServiceState.java (androidxref.cn android-14.0.0_r18)

frameworks

【代码】接口getDataRoamingType
【API】getDataRoamingType

漫游状态字段

Roming Type 定义及映射关系
ROAMING_TYPE_numFunction
ROAMING_TYPE_NOT_ROAMING0本地网络home
ROAMING_TYPE_UNKNOWN1漫游但不能判断类型 domestic or international.
ROAMING_TYPE_DOMESTIC2国内漫游 domestic
ROAMING_TYPE_INTERNATIONAL3国际漫游  international
    //@Retention注解标记了该注解的保留策略,即 SOURCE。
    //编译器在编译过程中会忽略@Retention注解,即编译后的代码中不会出现Retention。
    //@Retention注解的作用是为了给静态分析工具提供元数据。
    //@IntDef一个定义在 Android SDK 中的注解,用于告诉静态分析工具这个枚举类型 RoamingType 的取值范围,它包括一个 prefix 和一个 value。其中,prefix 参数指定了枚举值的前缀,这是为了避免与其他枚举类型的取值冲突;value 参数指定了枚举类型的所有可能取值。

    /** @hide */
    @Retention(RetentionPolicy.SOURCE) 
    @IntDef(prefix = { "ROAMING_TYPE_" }, value = {
            ROAMING_TYPE_NOT_ROAMING,
            ROAMING_TYPE_UNKNOWN,
            ROAMING_TYPE_DOMESTIC,
            ROAMING_TYPE_INTERNATIONAL
    })
    //定义了一个注解类型 RoamingType,它实际上是一个注解类的声明。
    //作用:可以在其他代码中使用该注解来表示 RoamingType 类型的值。
    public @interface RoamingType {}

    /**
     * Not roaming, registered in home network.
     * @hide
     */
    @SystemApi
    public static final int ROAMING_TYPE_NOT_ROAMING = 0;
    /**
     * registered in a roaming network, but can not tell if it's domestic or international.
     * @hide
     */
    @SystemApi
    public static final int ROAMING_TYPE_UNKNOWN = 1;
    /**
     * registered in a domestic roaming network
     * @hide
     */
    @SystemApi
    public static final int ROAMING_TYPE_DOMESTIC = 2;
    /**
     * registered in an international roaming network
     * @hide
     */
    @SystemApi
    public static final int ROAMING_TYPE_INTERNATIONAL = 3;

四、开发方案

  1. 将non_roaming_operator_string_array配置成false,则指定漫游到的mccmnc会视为home网,不会显示plmn,以spn为准。
  2. carrier_name_string和carrier_name_override_bool 配套配置实现overlay
  3. 对于漫游时,定制OPL(opl_override_opl_string_array)

比如针对cid=1952的卡,原始配置:packages/apps/CarrierConfig/assets/carrier_config_carrierid_1952_US-Cellular.xml

定制配置如下:/packages/apps/CarrierConfig/res/xml/vendor.xml

    <carrier_config cid="1952" name="U.S. Cellular">
        <string name="carrier_name_string">UScellular</string>
        <boolean name="carrier_name_override_bool" value="true"/>
        <!--plmn1,lactac_start,lactac_end,index"-->
        <string-array name="opl_override_opl_string_array" num="24">
            <item value="311580,0,65535,0" />
            <item value="311581,0,65535,0" />
            <item value="311582,0,65535,0" />
            <item value="311583,0,65535,0" />
            <item value="311584,0,65535,0" />
            <item value="311585,0,65535,0" />
            <item value="311586,0,65535,0" />
            <item value="311587,0,65535,0" />
            <item value="311588,0,65535,0" />
            <item value="311589,0,65535,0" />
            <item value="311220,0,65535,0" />
            <item value="311221,0,65535,0" />
            <item value="311222,0,65535,0" />
            <item value="311223,0,65535,0" />
            <item value="311224,0,65535,0" />
            <item value="311225,0,65535,0" />
            <item value="311226,0,65535,0" />
            <item value="311227,0,65535,0" />
            <item value="311228,0,65535,0" />
            <item value="311229,0,65535,0" />
            <item value="310120,0,65535,0" />
            <item value="312420,0,65535,0" />
            <item value="311480,0,65535,0" />
            <item value="310410,0,65535,0" />
        </string-array>
        <string-array name="pnn_override_string_array" num="1">
            <item value="UScelluar" />
        </string-array>
    </carrier_config>

  • 11
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值