harmony 鸿蒙@ohos.nfc.controller (标准NFC)
@ohos.nfc.controller (标准NFC)
本模块主要用于管理NFC状态,包括打开和关闭NFC,读取NFC的状态等。
说明:
本模块首批接口从API version 7开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。
导入模块
import { nfcController } from '@kit.ConnectivityKit';
NfcState
定义不同的NFC状态值。
系统能力: SystemCapability.Communication.NFC.Core
原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。
名称 | 值 | 说明 |
---|---|---|
STATE_OFF | 1 | NFC已关闭状态。 |
STATE_TURNING_ON | 2 | NFC正在打开状态。 |
STATE_ON | 3 | NFC已打开状态。 |
STATE_TURNING_OFF | 4 | NFC正在关闭状态。 |
nfcController.isNfcAvailable(deprecated)
isNfcAvailable(): boolean
查询设备是否有NFC能力。
说明: 从 API version 7 开始支持,从 API version 9 开始废弃,建议使用canIUse(“SystemCapability.Communication.NFC.Core”)替代。
系统能力: SystemCapability.Communication.NFC.Core
返回值:
类型 | 说明 |
---|---|
boolean | true: 设备具备NFC能力, false: 设备不具备NFC能力。 |
nfcController.openNfc(deprecated)
openNfc(): boolean
打开NFC开关。
说明: 从 API version 7 开始支持,从 API version 9 开始废弃,建议使用enableNfc替代。
需要权限: ohos.permission.MANAGE_SECURE_SETTINGS(该权限仅系统应用可申请)
系统能力: SystemCapability.Communication.NFC.Core
返回值:
类型 | 说明 |
---|---|
boolean | true: 打开NFC成功, false: 打开NFC失败。 |
nfcController.enableNfc9+
enableNfc(): void
打开NFC开关,该接口只能被系统应用调用。
需要权限: ohos.permission.MANAGE_SECURE_SETTINGS(该权限仅系统应用可申请)
系统能力: SystemCapability.Communication.NFC.Core
错误码:
以下错误码的详细介绍请参见NFC错误码。
错误码ID | 错误信息 |
---|---|
201 | Permission denied. |
801 | Capability not supported. |
3100101 | The NFC state is abnormal in the service. |
nfcController.closeNfc(deprecated)
closeNfc(): boolean
关闭NFC开关。
说明: 从 API version 7 开始支持,从 API version 9 开始废弃,建议使用disableNfc替代。
需要权限: ohos.permission.MANAGE_SECURE_SETTINGS(该权限仅系统应用可申请)
系统能力: SystemCapability.Communication.NFC.Core
返回值:
类型 | 说明 |
---|---|
boolean | true: 关闭NFC成功, false: 关闭NFC失败。 |
nfcController.disableNfc9+
disableNfc(): void
关闭NFC开关,该接口只能被系统应用调用。
需要权限: ohos.permission.MANAGE_SECURE_SETTINGS(该权限仅系统应用可申请)
系统能力: SystemCapability.Communication.NFC.Core
错误码:
以下错误码的详细介绍请参见NFC错误码。
错误码ID | 错误信息 |
---|---|
201 | Permission denied. |
801 | Capability not supported. |
3100101 | The NFC state is abnormal in the service. |
nfcController.isNfcOpen
isNfcOpen(): boolean
查询NFC是否打开。
系统能力: SystemCapability.Communication.NFC.Core
原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。
返回值:
类型 | 说明 |
---|---|
boolean | true: NFC是打开的, false: NFC是关闭的。 |
nfcController.getNfcState
getNfcState(): NfcState
查询NFC状态。
系统能力: SystemCapability.Communication.NFC.Core
原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。
返回值:
类型 | 说明 |
---|---|
NfcState | NFC状态值,详细请见NfcState枚举值。 |
nfcController.on(‘nfcStateChange’)
on(type: ‘nfcStateChange’, callback: Callback<NfcState>): void
注册NFC开关状态事件,通过Callback方式获取NFC状态的变化通知。
系统能力: SystemCapability.Communication.NFC.Core
原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。
参数
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
type | string | 是 | 固定填”nfcStateChange”字符串。 |
callback | Callback<NfcState> | 是 | NFC状态改变通知的回调函数。 |
nfcController.off(‘nfcStateChange’)
off(type: ‘nfcStateChange’, callback?: Callback<NfcState>): void
取消NFC开关状态事件的注册,取消后NFC状态变化时,就不会再收到Callback的通知。
系统能力: SystemCapability.Communication.NFC.Core
原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。
参数
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
type | string | 是 | 固定填”nfcStateChange”字符串。 |
callback | Callback<NfcState> | 否 | NFC状态改变回调函数,可以空缺不填。如果callback不填,将取消注册该事件关联的所有回调函数。 |
示例
import { nfcController } from '@kit.ConnectivityKit';
// 注册回调以接收nfc状态更改通知
nfcController.on("nfcStateChange", (nfcState : number)=> {
console.log("nfcController on callback nfcState: " + nfcState);
});
// 打开nfc需要权限: ohos.permission.MANAGE_SECURE_SETTINGS(此权限仅系统应用可申请)
if (!nfcController.isNfcOpen()) {
// 从api9开始,使用'enableNfc'打开nfc
try {
nfcController.enableNfc();
console.log("nfcController enableNfc success");
} catch (businessError) {
console.error("nfcController enableNfc businessError: " + businessError);
}
} else {
console.log("nfcController NFC has been opened");
}
// 关闭nfc需要权限: ohos.permission.MANAGE_SECURE_SETTINGS(此权限仅系统应用可申请)
if (nfcController.isNfcOpen()) {
// 从api9开始,使用'disableNfc'关闭nfc
try {
nfcController.disableNfc();
console.log("nfcController disableNfc success");
} catch (businessError) {
console.error("nfcController disableNfc businessError: " + businessError);
}
} else {
console.log("nfcController NFC has been closed");
}
// 取消注册回调
nfcController.off("nfcStateChange");
你可能感兴趣的鸿蒙文章
harmony 鸿蒙Connectivity Kit(短距通信服务)
harmony 鸿蒙SE(secureElement)错误码
harmony 鸿蒙@ohos.bluetooth.a2dp (蓝牙a2dp模块)(系统接口)
- 所属分类: 后端技术
- 本文标签:
热门推荐
-
2、 - 优质文章
-
3、 gate.io
-
8、 golang
-
9、 openharmony
-
10、 Vue中input框自动聚焦