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


    一、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
    1. //@Retention注解标记了该注解的保留策略,即 SOURCE。
    2. //编译器在编译过程中会忽略@Retention注解,即编译后的代码中不会出现Retention。
    3. //@Retention注解的作用是为了给静态分析工具提供元数据。
    4. //@IntDef一个定义在 Android SDK 中的注解,用于告诉静态分析工具这个枚举类型 RoamingType 的取值范围,它包括一个 prefix 和一个 value。其中,prefix 参数指定了枚举值的前缀,这是为了避免与其他枚举类型的取值冲突;value 参数指定了枚举类型的所有可能取值。
    5. /** @hide */
    6. @Retention(RetentionPolicy.SOURCE)
    7. @IntDef(prefix = { "ROAMING_TYPE_" }, value = {
    8. ROAMING_TYPE_NOT_ROAMING,
    9. ROAMING_TYPE_UNKNOWN,
    10. ROAMING_TYPE_DOMESTIC,
    11. ROAMING_TYPE_INTERNATIONAL
    12. })
    13. //定义了一个注解类型 RoamingType,它实际上是一个注解类的声明。
    14. //作用:可以在其他代码中使用该注解来表示 RoamingType 类型的值。
    15. public @interface RoamingType {}
    16. /**
    17. * Not roaming, registered in home network.
    18. * @hide
    19. */
    20. @SystemApi
    21. public static final int ROAMING_TYPE_NOT_ROAMING = 0;
    22. /**
    23. * registered in a roaming network, but can not tell if it's domestic or international.
    24. * @hide
    25. */
    26. @SystemApi
    27. public static final int ROAMING_TYPE_UNKNOWN = 1;
    28. /**
    29. * registered in a domestic roaming network
    30. * @hide
    31. */
    32. @SystemApi
    33. public static final int ROAMING_TYPE_DOMESTIC = 2;
    34. /**
    35. * registered in an international roaming network
    36. * @hide
    37. */
    38. @SystemApi
    39. 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

    1. <carrier_config cid="1952" name="U.S. Cellular">
    2. <string name="carrier_name_string">UScellularstring>
    3. <boolean name="carrier_name_override_bool" value="true"/>
    4. <string-array name="opl_override_opl_string_array" num="24">
    5. <item value="311580,0,65535,0" />
    6. <item value="311581,0,65535,0" />
    7. <item value="311582,0,65535,0" />
    8. <item value="311583,0,65535,0" />
    9. <item value="311584,0,65535,0" />
    10. <item value="311585,0,65535,0" />
    11. <item value="311586,0,65535,0" />
    12. <item value="311587,0,65535,0" />
    13. <item value="311588,0,65535,0" />
    14. <item value="311589,0,65535,0" />
    15. <item value="311220,0,65535,0" />
    16. <item value="311221,0,65535,0" />
    17. <item value="311222,0,65535,0" />
    18. <item value="311223,0,65535,0" />
    19. <item value="311224,0,65535,0" />
    20. <item value="311225,0,65535,0" />
    21. <item value="311226,0,65535,0" />
    22. <item value="311227,0,65535,0" />
    23. <item value="311228,0,65535,0" />
    24. <item value="311229,0,65535,0" />
    25. <item value="310120,0,65535,0" />
    26. <item value="312420,0,65535,0" />
    27. <item value="311480,0,65535,0" />
    28. <item value="310410,0,65535,0" />
    29. string-array>
    30. <string-array name="pnn_override_string_array" num="1">
    31. <item value="UScelluar" />
    32. string-array>
    33. carrier_config>

  • 相关阅读:
    解决Mac配置maven环境后,关闭终端后环境失效的问题(适用于所有终端关闭后环境失效的问题)
    java 企业工程管理系统软件源码 自主研发 工程行业适用
    【Educoder作业】操作系统之进程管理(一)
    【无标题】
    【AGC035E】Develop(图论,DP)
    哈希——开散列
    history对象
    不用996,不用007,赚的还比我多?我直接好家伙
    ESP32集成开发环境Espressif-IDE安装 – Windows
    Vue 3 中的 ref 和 reactive 有什么区别?
  • 原文地址:https://blog.csdn.net/qq_38666896/article/details/136479808