From 5d95ca4e84f1e62c0c523142e9b6f96c65fa2040 Mon Sep 17 00:00:00 2001 From: shawn_he Date: Tue, 8 Mar 2022 11:26:47 +0800 Subject: [PATCH] update docs Signed-off-by: shawn_he --- ...us_architecture-of-telephony-subsystem.png | Bin 30154 -> 55900 bytes en/readme/telephony.md | 103 ++++++++++-------- 2 files changed, 56 insertions(+), 47 deletions(-) diff --git a/en/readme/figures/en-us_architecture-of-telephony-subsystem.png b/en/readme/figures/en-us_architecture-of-telephony-subsystem.png index a86a2dfe63a87487f3874fe7389a366fcef3c2cb..1ac14c2b557895e673c98cd84aac3d810d1d9b82 100755 GIT binary patch literal 55900 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

kr)Sdmk;erSMu{;sU~G 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 DJX0$y literal 30154 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⋘^^g?J{}d3zw~1ZMsSqZ{E%>WW%1Zzp-RMoflVx1FtkzdaF$*7~KQl}X zS!>z9RWnD2&EtA_uclFAM{>+Qa1to19pd9I@#0lqTvs*xD-_}K;^*3S8Gz&OrS7H? z8*XINZ#mJM&dI62rf&DUc|S76a^@bE&7Uy-O3#0Gy~~y4w0Rb3o10o{{aBxBJ}KUI z>>Fnbx=y#Zq*MwQx$I4VV{cHOXTEsFUQMuYO*ye1z@C0Pz3aI(H$MwPcOL=t&8P^5 zgsnjlOVi+l~%Bv$QKzrX&`84Ih)%?x<>l{H*0Jl&oxn#e&1f$`*4e}dn+cm27lK`=*J0xfZ4FYRd-<9 z&t&D}f;PW-279T*p@`{jlNNn~4s^C{YzH zi5sgz1z2{nSWq2qSez1V48q$>PeTN9N=}Zu=`FbR3$9zpAJp4 z34@1s-e2z7(&uLI?QY;lTfb;60BLMIcR;(SfSi&-B|5lAR4jAvCR6=~nnr*_`^my2 zHlZ@&G}cpMvZMi^01m!m!w|h``>YM_B(1465rwoj?eS6W0qEH|c&@?*u=!9^w=&ED zqDCdpB*TDUW5Kbaao-V>MliLo2l^0I&o#9ZhQq|1(8c!AGR2GTqu3KKB3kcJD_QDj zK;&fVPO31UcPDZctb!MEM}k?R4uz$Lu0u0yT2xPN^RQH(2I#h%gb#hv9*+ohK) z+a(mgJ)7~I!Jeca*zQOiZB8_xe7lbsVebq4-RkP_A+=s-kXFtNr7iB$U~rB!Jn|8k zjlf5ugb%SJZ1t9WM{3ROOV@eZfT-}HZwc6n_#;?I_2_RJDM-=+_zzZwYp7iCnZ;O2oi!ZTUF`IL-5FQ_L4O>bq!Mhv4!EYI1~cE2zyP3W zgQx=dufrzSif+Jm?0QZR!fO^^<%Jf8=-14q{p4Q4ncRl?{9alK;Eq*e-6Q zbDa_Rsn_A8*S{pQMe^>VPcSxO{wlqy2VQbh*b6NQy$N+)KYIqhR z3kdxH`wjGz`HoPVOu!BVo(CP4MSVWHz0?kdzeLWjUq6e-m4Ma-P$31v5qU5CBx+21 zsu7!JPOgO;LR7~5D9}4<*nTcv4jj|pvh64uJ^vVxD4N{>{^0f(6y#L57s$;5JVyq- zusx&i($_^yk8wiU#>&idoe6xQSiSRlJ6oA6JD{7B!$G-ys{A4An{H4UGjIk?v0B&B z8}{eIbu!vv+<~)VQS_lGVTs}0;VP*A)49#3?CleFCxq!a%*$)5=#{{6zlPmvT%DWC zFNvr{x)Bg`tt4i*wN4*57crpd(Czj1n^z~=9Z@N<{pXtC_9@3+-fQ=i-zfKSI(_7| z#SROK4!^jzdU3-fSA_#BfxbTW8WavvUR57c0i<}9^^M-wZJdR&cB$&dSk>EqopKke zKp9P)dJ=hNC6dq?Mxs-YTd8=g3G9DzL{&M?-b7W`^j+p$w|9H*s#<|G%k8kV^VD|= zhpH-L<~6<-V&v`HV=8o&K*Is`)!LnpbrujZPR~IuNaBl{N)mWJH>(=vnKCxAt` zcE0Kj0`=&ufwkaL)3EhR?ca(EWu^Oryq8~#eaQ45a26Yg{uA1tb7>EB9AYs7y6WC_ zzr#l%wC49N0(fwBTwZE(r2pI#K*F1T;K*fW6_q zM#3q5J5ca2ujCKZE?V&t4jS`ach6BrA1d7kb(-=kvro(a`;{1SzemDCzLSTiMQy(% zo}>EjCOdH4iobmjhe@;i&`B{>Aq1k0dDFEWq)?zf$IkcP77&&nLYGF>k6+RrLyZGR zcaG%BZoB61+3UcPYB_d>p`HvMl8c<)_$^nMtB#c{=5W3b5UC^uUtkX2Qsu6QF6wpw zB75V$Uc~X=!B>R8t>bp-x9LwYtfN&DStt$opF`@7u=�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 diff --git a/en/readme/telephony.md b/en/readme/telephony.md index fc9c61caf1..9cc9a0d8d8 100755 --- a/en/readme/telephony.md +++ b/en/readme/telephony.md @@ -1,18 +1,30 @@ # Telephony +- [Introduction](#section104mcpsimp) +- [Directory Structure](#section119mcpsimp) +- [Constraints](#section123mcpsimp) +- [Usage](#section128mcpsimp) + - [Obtaining the Current Cellular Network Signal Information](#section1458213210369) + - [Observing Changes to the Cellular Network Status](#section750135512369) + +- [Repositories Involved](#section152mcpsimp) + ## Introduction The Telephony subsystem provides APIs for obtaining information about the wireless cellular network and SIM card. Applications can call these APIs to obtain information such as the name of the currently registered network, network service status, signal strength, and SIM card information. The Telephony subsystem consists of the following modules: -- Telephony core service: initializes the RIL Manager, SIM card module, and network search module. +- Telephony core service: initializes the Radio Interface Layer (RIL) Manager, SIM card module, and radio module. - Call Manager module: manages three types of calls – circuit switched \(CS\), IP multimedia subsystem \(IMS\), and over the top \(OTT\) calls. It is responsible for applying for the audio and video resources required for a call and resolving conflicts in a multi-channel call. - Cellular call module: implements basic calls over carrier networks. +- Cellular data module: implements cellular data services over carrier networks. - SMS & MMS module: provides the capabilities of sending and receiving short message service \(SMS\) messages and encoding and decoding multimedia messaging service \(MMS\) messages. - State registry module: provides APIs to register and deregister an observer that listens for various callback events of the telephony subsystem. +- Data storage module: stores persistent data and provides **DataAbility** access APIs. +- RIL Adapter module: implements adaptation of the modem communication interfaces. -**Figure 1** Telephony subsystem architecture +**Figure 1** Telephony subsystem architecture ![](figures/en-us_architecture-of-telephony-subsystem.png) @@ -20,55 +32,61 @@ The Telephony subsystem consists of the following modules: ``` base/telephony/ -├── core_service # Core service +├── core_service # Telephony core service ├── call_manager # Call Manager module ├── cellular_call # Cellular call module +├── cellular_data # Cellular data module ├── sms_mms # SMS & MMS module -└── state_registry # State registry module +├── state_registry # State registry module +├── data_storage # Data storage module +└── ril_adapter # RIL Adapter module ``` ## Constraints -1. The open-source version currently supports only the CS call and SMS services. Cellular data and dual-SIM card are not supported. +1. The open-source version currently provides the cellular call (CS call only), SMS & MMS, and cellular data services and supports the dual-SIM framework. +2. The Hardware Device Interface (HDI) support is subject to the chip vendors' adaptation capability. For details, see [Telephony Service Development](https://gitee.com/openharmony/docs/blob/master/en/device-dev/subsystems/subsys-tel.md). ## Usage Guidelines -### Obtaining Current Cellular Network Signal Information +To learn more about the usage of each subsystem module, refer to the respective README. The following illustrates API usage by exemplifying how to obtain the current cellular network signal information and observe the cellular network status changes. + +### Obtaining the Current Cellular Network Signal Information -1. Import the **radio** namespace from **@ohos.telephony.radio.d.ts**. -2. Call the **getSignalInformation\(slotId: number\)** method in callback or Promise mode. This method works in asynchronous mode. -3. Obtain the result from the **SignalInformation** array in the callback. -4. Traverse the **SignalInformation** array to obtain the **signalLevel** \(signal strength\) for each **signalType** \(radio access technology\). +1. Import the **radio** namespace from **@ohos.telephony.radio.d.ts**. +2. Call the **getSignalInformation\(slotId: number\)** function via callback or promise. This function works in asynchronous mode. +3. Obtain the result from the **SignalInformation** array in the callback. +4. Traverse the **SignalInformation** array to obtain the **signalLevel** (signal strength) for each **signalType** (radio access technology). ``` // Import the radio package. import radio from "@ohos.telephony.radio"; // Set the value of slotId. - let slotId = 1; + let slotId = 0; // Call the API in callback mode. radio.getSignalInformation(slotId, (err, value) => { if (err) { - // If the API call failed, err is not empty. + // If the API call fails, err is not empty. console.error(`failed to getSignalInformation because ${err.message}`); return; } - // If the API call succeeded, err is empty. + // If the API call is successful, err is empty. for (let i = 0; i < value.length; i++) { console.log(`success to getSignalInformation: type is ${value[i].signalType}, level is ${value[i].signalLevel}`); } }); - // Call the API in Promise mode. + // Call the API in promise mode. let promise = radio.getSignalInformation(slotId); promise.then((value) => { - // The API call succeeded. + // The API call is successful. for (let i = 0; i < value.length; i++) { console.log(`success to getSignalInformation: type is ${value[i].signalType}, level is ${value[i].signalLevel}`); } }).catch((err) => { - // The API call failed. + // The API call fails. console.error(`failed to getSignalInformation because ${err.message}`); }); ``` @@ -76,62 +94,53 @@ base/telephony/ ### Observing Cellular Network Status Changes -**Adding an Observer** +Adding an Observer -1. Import the **observer** namespace from **@ohos.telephony.observer.d.ts**. -2. Call the **on\(type: 'networkStateChange'\)** method with **slotId** \(slot ID, optional\) and **callback** \(callback processing function\) passed in. -3. Register an **observer** instance for callback events of network status changes. +1. Import the **observer** namespace from **@ohos.telephony.observer.d.ts**. +2. Call the **on\(type:'networkStateChange'\)** function with **slotId** (slot ID, optional) and **callback** (callback processing function) passed in. +3. Register an **observer** instance for callback events of network status changes. ``` // Import the observer package. import observer from '@ohos.telephony.observer'; // Registers an observer. - observer.on('networkStateChange', {slotId: 1}, (err, value) => { - if (err) { - // If the API call failed, err is not empty. - console.error(`failed, because ${err.message}`); - return; - } - // If the API call succeeded, err is empty. - console.log(`success on. network state is ` + value); + observer.on('networkStateChange', {slotId: 0}, (value) => { + console.log(`network state is ` + value); }); ``` -**Removing the Observer** +Removing the Observer -1. Import the **observer** namespace from **@ohos.telephony.observer.d.ts**. -2. Call the **off\(type: 'networkStateChange'\)** method with the **callback** object passed to the **observer**. +1. Import the **observer** namespace from **@ohos.telephony.observer.d.ts**. +2. Call the **off\(type: 'networkStateChange'\)** function with the **callback** object passed to **observer**. ``` // Import the observer package. import observer from '@ohos.telephony.observer'; - // Deregister the observer. - observer.off('networkStateChange', (err, value) => { - if (err) { - // If the API call failed, err is not empty. - console.error(`failed, because ${err.message}`); - return; - } - // If the API call succeeded, err is empty. - console.log(`success off`); - }); + // Unregister the observer. + observer.off('networkStateChange'); ``` ## Repositories Involved -**Telephony subsystem** +**Telephony Subsystem** + +[telephony\_core\_service](https://gitee.com/openharmony/telephony_core_service/blob/master/README.md) + +[telephony\_call\_manager](https://gitee.com/openharmony/telephony_call_manager/blob/master/README.md) -[telephony_core_service](https://gitee.com/openharmony/telephony_core_service/blob/master/README.md) +[telephony\_cellular\_call](https://gitee.com/openharmony/telephony_cellular_call/blob/master/README.md) -[telephony_call_manager](https://gitee.com/openharmony/telephony_call_manager/blob/master/README.md) +[telephony\_cellular\_data](https://gitee.com/openharmony/telephony_cellular_data/blob/master/README.md) -[telephony_cellular_call](https://gitee.com/openharmony/telephony_cellular_call/blob/master/README.md) +[telephony\_sms\_mms](https://gitee.com/openharmony/telephony_sms_mms/blob/master/README.md) -[telephony_sms_mms](https://gitee.com/openharmony/telephony_sms_mms/blob/master/README.md) +[telephony\_state\_registry](https://gitee.com/openharmony/telephony_state_registry/blob/master/README.md) -[telephony_state_registry](https://gitee.com/openharmony/telephony_state_registry/blob/master/README.md) +[telephony\_data\_storage](https://gitee.com/openharmony/telephony_data_storage/blob/master/README.md) +[telephony\_ril\_adapter](https://gitee.com/openharmony/telephony_ril_adapter/blob/master/README.md) -- GitLab