# 锁屏管理 锁屏管理服务是OpenHarmony中系统服务,为锁屏应用提供注册亮屏、灭屏、开启屏幕、结束休眠、退出动画、请求解锁结果监听,并提供回调结果给锁屏应用。锁屏管理服务向三方应用提供请求解锁、查询锁屏状态、查询是否设置锁屏密码的能力。 > ![icon-note.gif](public_sys-resources/icon-note.gif) **说明:** > 本模块首批接口从API version 7开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。 ## 导入模块 ```js import screenlock from '@ohos.screenLock'; ``` ## screenlock.isScreenLocked isScreenLocked(callback: AsyncCallback<boolean>): void 判断屏幕是否锁屏,使用callback作为异步方法。 **系统能力**: SystemCapability.MiscServices.ScreenLock **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | callback | AsyncCallback<boolean> | 是 | 回调函数,返回true表示屏幕已锁屏,返回false表示屏幕未锁屏。 | **示例:** ```js screenlock.isScreenLocked((err, data)=>{ if (err) { console.error('isScreenLocked callback error -> ${JSON.stringify(err)}'); return; } console.info('isScreenLocked callback success data -> ${JSON.stringify(data)}'); }); ``` ## screenlock.isScreenLocked isScreenLocked(): Promise<boolean> 判断屏幕是否锁屏,使用Promise作为异步方法。 **系统能力**: SystemCapability.MiscServices.ScreenLock **返回值**: | 类型 | 说明 | | -------- | -------- | | Promise<boolean> | 以Promise形式返回结果。 | **示例**: ```js screenlock.isScreenLocked().then((data) => { console.log('isScreenLocked success: data -> ${JSON.stringify(data)}'); }).catch((err) => { console.error('isScreenLocked fail, promise: err -> ${JSON.stringify(err)}'); }); ``` ## screenlock.isSecureMode isSecureMode(callback: AsyncCallback<boolean>): void 判断设备是否处于安全模式下,使用callback作为异步方法。 **系统能力**: SystemCapability.MiscServices.ScreenLock **参数**: | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | callback | AsyncCallback<boolean> | 是 | 回调函数。返回true表示屏幕处于安全模式下,返回false表示屏幕当前不在安全模式下。 | **示例**: ```js screenlock.isSecureMode((err, data)=>{ if (err) { console.error('isSecureMode callback error -> ${JSON.stringify(err)}'); return; } console.info('isSecureMode callback success data -> ${JSON.stringify(err)}'); }); ``` ## screenlock.isSecureMode isSecureMode(): Promise<boolean> 判断设备是否处于安全模式下,使用Promise作为异步方法。 **系统能力**: SystemCapability.MiscServices.ScreenLock **返回值**: | 类型 | 说明 | | -------- | -------- | | Promise<boolean> | 以Promise形式返回结果。 | **示例**: ```js screenlock.isSecureMode().then((data) => { console.log('isSecureMode success: data->${JSON.stringify(data)}'); }).catch((err) => { console.error('isSecureMode fail, promise: err->${JSON.stringify(err)}'); }); ``` ## screenlock.unlockScreen unlockScreen(callback: AsyncCallback<void>): void 解锁屏幕,使用callback作为异步方法。 **系统能力**: SystemCapability.MiscServices.ScreenLock **参数**: | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | callback | AsyncCallback<void> | 是 | 回调函数,失败时返回错误信息。 | **示例**: ```js screenlock.unlockScreen((err) => { if (err) { console.error('unlockScreen callback error -> ${JSON.stringify(err)}'); return; } console.info('unlockScreen callback success'); }); ``` ## screenlock.unlockScreen unlockScreen(): Promise<void> 解锁屏幕,使用Promise作为异步方法。 **系统能力**: SystemCapability.MiscServices.ScreenLock **返回值**: | 类型 | 说明 | | -------- | -------- | | Promise<void> | 以Promise形式返回结果。 | **示例**: ```js screenlock.unlockScreen().then(() => { console.log('unlockScreen success'); }).catch((err) => { console.error('unlockScreen fail, promise: err->${JSON.stringify(err)}'); }); ``` ## screenlock.lockScreen9+ lockScreen(callback: AsyncCallback<boolean>): void 锁定屏幕,使用callback作为异步方法。 **系统能力**: SystemCapability.MiscServices.ScreenLock **系统接口**:此接口为系统接口,三方应用不支持调用。 **参数**: | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | callback | AsyncCallback<void> | 是 | 回调函数,失败时返回错误信息。 | **示例**: ```js screenlock.lockScreen((err) => { if (err) { console.error('lockScreen callback error -> ${JSON.stringify(err)}'); return; } console.info('lockScreen callback success'); }); ``` ## screenlock.lockScreen9+ lockScreen(): Promise<boolean> 锁定屏幕,使用Promise作为异步方法。 **系统能力**: SystemCapability.MiscServices.ScreenLock **系统接口**:此接口为系统接口,三方应用不支持调用。 **返回值**: | 类型 | 说明 | | -------- | -------- | | Promise<void> | 以Promise形式返回结果。 | **示例**: ```js screenlock.lockScreen().then(() => { console.log('lockScreen success'); }).catch((err) => { console.error('lockScreen fail, promise: err->${JSON.stringify(err)}'); }); ``` ## EventType 定义系统事件类型。 **系统能力**: SystemCapability.MiscServices.ScreenLock | 名称 | 说明 | | -------- | -------- | | beginWakeUp | 表示事件开始时开始唤醒。 | | endWakeUp | 表示事件结束时结束唤醒。 | | beginScreenOn | 表示事件开始时开始亮屏。 | | endScreenOn | 表示事件结束时结束亮屏。 | | beginScreenOff | 表示事件开始时开始灭屏。 | | endScreenOff | 表示事件结束时结束灭屏。 | | unlockScreen | 表示请求解锁屏幕。 | | lockScreen | 表示请求锁定屏幕。 | | beginExitAnimation | 表示动画开始退场。 | | beginSleep | 表示开始休眠。 | | endSleep | 表示结束休眠。 | | changeUser | 表示切换用户。 | | screenlockEnabled | 表示锁屏是否启用。 | | serviceRestart | 表示锁屏服务进行重启。 | ## SystemEvent 定义系统事件回调参数结构。 **系统能力**: SystemCapability.MiscServices.ScreenLock | 名称 | 说明 | | -------- | -------- | | eventType | 系统事件类型。 | | params | 系统事件的事件参数。 | ## screenlock.onSystemEvent9+ onSystemEvent(callback: Callback\): boolean 注册锁屏相关的系统事件。 **系统能力**: SystemCapability.MiscServices.ScreenLock **系统接口**:此接口为系统接口,三方应用不支持调用。 **参数**: | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | callback | Callback\ | 是 | 锁屏相关的系统事件回调函数 | **返回值:** | 类型 | 说明 | | ------- | -------------------------------------------- | | boolean | 返回true表示锁屏系统事件注册成功,否则返回false| **示例**: ```js let isSuccess = screenlock.onSystemEvent((err, event)=>{ console.log(`onSystemEvent:callback:${event.eventType}`) if (err) { console.log(`onSystemEvent callback error -> ${JSON.stringify(err)}`); } }); if (!isSuccess) { console.log(`onSystemEvent result is false`) } ``` ## screenlock.sendScreenLockEvent9+ sendScreenLockEvent(event: String, parameter: number, callback: AsyncCallback\): void 应用发送事件到锁屏服务,异步方法。 **系统能力**: SystemCapability.MiscServices.ScreenLock **系统接口**:此接口为系统接口,三方应用不支持调用。 **参数**: | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | event | String | 是 | 事件类型,支持如下取值:
- "unlockScreenResult",表示解锁结果。
- "screenDrawDone",表示屏幕绘制完成。 | | parameter | number | 是 | 解锁状态。
- parameter为0,表示解锁成功。
- parameter为1,表示解锁失败。
- parameter为2,表示解锁取消。 | | callback | AsyncCallback\ | 是 | 表示执行结果。 | **示例**: ```js screenlock.sendScreenLockEvent('unlockScreenResult', 0, (err, result) => { console.log('sending result:' + result); }); ``` ## screenlock.sendScreenLockEvent9+ sendScreenLockEvent(event: String, parameter: number): Promise\ 应用发送事件到锁屏服务,异步方法。 **系统能力**: SystemCapability.MiscServices.ScreenLock **系统接口**:此接口为系统接口,三方应用不支持调用。 **参数**: | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | event | String | 是 | 事件类型,支持如下取值:
- "unlockScreenResult",表示解锁结果。
- "screenDrawDone",表示屏幕绘制完成。 | | parameter | number | 是 | 解锁状态。
- parameter为0,表示解锁成功。
- parameter为1,表示解锁失败。
- parameter为2,表示解锁取消。 | **返回值**: | 类型 | 说明 | | -------- | -------- | | Promise\ | 以Promise形式返回执行结果。 | **示例**: ```js screenlock.sendScreenLockEvent('unlockScreenResult', 0).then((result) => { console.log('sending result:' + result); }); ```