1# 拨打电话 2 3## 场景介绍 4 5开发者可以通过两种不同的方式实现拨打电话的功能: 6- 对于系统应用,开发者可以使用dialCall接口,直接进行音频/视频呼叫,在应用界面显示对应的通话。 7- 对于三方应用,开发者可以使用makeCall接口,拉起系统电话应用,用户可以自行呼出通话。 8 9## 基本概念 10 11- 通话状态码 12 将当前的通话状态上报给app,可以根据当前的通话状态去做一些逻辑处理。例如在当前没有正在进行呼叫的时候,可以正常拨打新的一通电话。 13 14 | 名称 | 值 | 说明 | 15 | ------------------ | ---- | ------------------------------------------------------------ | 16 | CALL_STATE_UNKNOWN | -1 | 无效状态,当获取呼叫状态失败时返回。 | 17 | CALL_STATE_IDLE | 0 | 表示没有正在进行的呼叫。 | 18 | CALL_STATE_RINGING | 1 | 表示来电正在振铃或等待。 | 19 | CALL_STATE_OFFHOOK | 2 | 表示至少有一个呼叫处于拨号、通话中或呼叫保持状态,并且没有新的来电振铃或等待。 | 20 21## 约束与限制 22 231. 仅支持在标准系统上运行。 242. 设备需插入可用的SIM卡。 25 26 27## 接口说明 28 29> **说明:** 30> 为了保证应用的运行效率,大部分API调用都是异步的,对于异步调用的API均提供了callback和Promise两种方式,以下示例均采用callback函数,更多方式可以查阅[API参考](../reference/apis/js-apis-call.md)。 31 32| 接口名 | 描述 | 33| ----------------------------------------------------------------------------------- | ------------------------------------------------------------ | 34| hasVoiceCapability(): boolean; | 判断是否具有语音功能。 | 35| dialCall(phoneNumber: string, callback: AsyncCallback<void>): void | 拨号。该接口为系统接口。 | 36| makeCall(phoneNumber: string, callback: AsyncCallback<void>): void | 转到拨号屏幕,显示被叫号码。 | 37 38observer模块为开发者提供订阅和取消订阅通话业务状态的功能。具体API说明详见[接口文档](../reference/apis/js-apis-observer.md)。 39 40| 接口名 | 描述 | 41| ------------------------------------------------------------ | ------------------ | 42| on(type: 'callStateChange', options: { slotId: number }, callback: Callback<{ state: CallState, number: string }>): void; | 监听通话状态变化。 | 43 44## 开发步骤 45 46### 使用dialCall拨打电话(仅供系统应用使用) 47 481. 声明接口调用所需要的权限:ohos.permission.PLACE_CALL。 49此权限级别为system_basic,在申请权限前,请保证符合[权限使用的基本原则](../security/accesstoken-overview.md#权限使用的基本原则)。然后参考[配置文件权限声明指导文档](../security/accesstoken-guidelines.md#配置文件权限声明)声明对应权限。 502. 导入call和observer模块。 513. 调用hasVoiceCapability,确认当前设备是否支持拨号。 52 如果设备支持呼叫能力,则继续跳转到拨号界面,并显示拨号的号码。 534. 调用dialCall接口,拨打电话。 545. (可选)订阅通话业务状态变化。 55 ```ts 56 // import需要的模块 57 import call from '@ohos.telephony.call'; 58 import observer from '@ohos.telephony.observer'; 59 import { BusinessError } from '@ohos.base'; 60 61 // 调用查询能力接口 62 let isSupport = call.hasVoiceCapability(); 63 if (isSupport) { 64 // 如果设备支持呼叫能力,调用以下接口进行拨号 65 call.dialCall("13xxxx", (err: BusinessError) => { 66 console.log(`callback: dial call err->${JSON.stringify(err)}`); 67 }) 68 69 // 订阅通话业务状态变化(可选) 70 class SlotId {slotId: number = 0} 71 class CallStateCallback { 72 state: call.CallState = call.CallState.CALL_STATE_UNKNOWN; 73 number: string = ""; 74 } 75 let slotId: SlotId = {slotId: 0} 76 observer.on("callStateChange", slotId, (data: CallStateCallback) => { 77 console.log("call state change, data is:" + JSON.stringify(data)); 78 }); 79 } 80 ``` 81 82### 使用makeCall拨打电话 83 841. 导入call和observer模块。 852. 调用hasVoiceCapability,确认当前设备是否支持拨号。 86 如果设备支持呼叫能力,则继续跳转到拨号界面,并显示拨号的号码。 873. 调用makeCall接口,拉起系统电话应用,拨打电话。 884. (可选)订阅通话业务状态变化。 89 90 ```ts 91 // import需要的模块 92 import call from '@ohos.telephony.call'; 93 import observer from '@ohos.telephony.observer'; 94 import { BusinessError } from '@ohos.base'; 95 96 // 调用查询能力接口 97 let isSupport = call.hasVoiceCapability(); 98 if (isSupport) { 99 // 如果设备支持呼叫能力,则继续跳转到拨号界面,并显示拨号的号码 100 call.makeCall("13xxxx", (err: BusinessError) => { 101 if (!err) { 102 console.log("make call success."); 103 } else { 104 console.log("make call fail, err is:" + JSON.stringify(err)); 105 } 106 }); 107 // 订阅通话业务状态变化(可选) 108 class SlotId {slotId: number = 0} 109 class CallStateCallback { 110 state: call.CallState = call.CallState.CALL_STATE_UNKNOWN; 111 number: string = ""; 112 } 113 let slotId: SlotId = {slotId: 0} 114 observer.on("callStateChange", slotId, (data: CallStateCallback) => { 115 console.log("call state change, data is:" + JSON.stringify(data)); 116 }); 117 } 118 ``` 119 120## 相关实例 121 122针对拨打电话,有以下相关实例可供参考: 123 124- [拨打电话(ArkTS)(API9)](https://gitee.com/openharmony/applications_app_samples/tree/OpenHarmony-4.0-Release/code/BasicFeature/Telephony/Call) 125