HarmonyOS鸿蒙Next中应用中某个页面设置防截屏

HarmonyOS鸿蒙Next中应用中某个页面设置防截屏

  1. 通过@ohos.window中设置防截屏的属性,是在继承UIAbility的类中使用,这样的话整个App所有的页面都无法截屏。
  2. 通过哪个API可以实现应用中某个单独的页面设置防截屏,而其他页面正常可以截屏。
  3. 类似于activity.getWindow().addFlags(WindowManager.LayoutParams.FLAG_SECURE),可以获取某个页面自己的window来设置防截屏等属性。
4 回复

实现步骤: 一些页面需要实现防截屏功能。首先需要在module.json5中申请隐私窗口权限。 然后在onPageShow()中获取当前窗口对象并设置隐私模式。 在退出页面的时候,在onPageHide()生命周期中取消隐私模式即可。

参考文档: https://developer.huawei.com/consumer/cn/doc/harmonyos-references-V5/js-apis-window#setwindowprivacymode9

demo 如下:

//module.json5文件中

{
  "name" : 'ohos.permission.PRIVACY_WINDOW'
}

//EAbility文件中

onWindowStageCreate(windowStage: window.WindowStage): void {
  let windowClass: window.Window = windowStage.getMainWindowSync();
  // 获取应用主窗口

  AppStorage.setOrCreate("windowClass",windowClass);
}

//Index文件中

import { window } from '@kit.ArkUI';
import { BusinessError } from '@ohos.base';

@Entry
@Component
struct Index43 {
  private windowStage = AppStorage.get("windowStage") as window.WindowStage
  private windowClass = AppStorage.get("windowClass") as window.Window

  @State message: string = 'Hello World';



  build() {
    Row() {
      Column() {
        Text('禁止截屏')
          .fontSize(50)
          .fontWeight(FontWeight.Bold)
          .onClick(() => {

            let isPrivacyMode: boolean = true;
            try {
              this.windowClass.setWindowPrivacyMode(isPrivacyMode, (err: BusinessError) => {
                const errCode: number = err.code;
                if (errCode) {
                  console.error('Failed to set the window to privacy mode. Cause:' + JSON.stringify(err));
                  return;
                }
                console.info('Succeeded in setting the window to privacy mode.');
              });
            } catch (exception) {
              console.error('Failed to set the window to privacy mode. Cause:' + JSON.stringify(exception));
            }
          })


        Text('允许截屏')
          .fontSize(50)
          .fontWeight(FontWeight.Bold)
          .onClick(() => {

            let isPrivacyMode: boolean = false;
            try {
              this.windowClass.setWindowPrivacyMode(isPrivacyMode, (err: BusinessError) => {
                const errCode: number = err.code;
                if (errCode) {
                  console.error('Failed to set the window to privacy mode. Cause:' + JSON.stringify(err));
                  return;
                }
                console.info('Succeeded in setting the window to privacy mode.');
              });
            } catch (exception) {
              console.error('Failed to set the window to privacy mode. Cause:' + JSON.stringify(exception));
            }
          })

      }
      .width('100%')
    }
    .height('100%')
  }
}

更多关于HarmonyOS鸿蒙Next中应用中某个页面设置防截屏的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html


mWindow.setWindowPrivacyMode(true) 开启防截屏

mWindow.setWindowPrivacyMode(false) 关闭防截屏

mWindow可以通过这个方法获取 ,也能再ability里存个全局的

mWindow = window.findWindow(this.getUIContext().getWindowName())

在HarmonyOS鸿蒙Next中,可以通过设置页面的隐私保护属性来防止页面内容被截屏。具体实现方式是使用AbilityWindow对象,通过调用WindowaddFlags方法,设置WindowManager.LayoutParams.FLAG_SECURE标志。该标志可以防止当前窗口的内容被截屏或录屏。

以下是一个示例代码片段,展示如何在鸿蒙应用中设置防截屏:

import window from '@ohos.window';

export default class MainAbility extends Ability {
  onWindowStageCreate(windowStage: window.WindowStage) {
    let windowClass = windowStage.getMainWindow();
    windowClass.then((window) => {
      window.addFlags(window.WindowManager.LayoutParams.FLAG_SECURE);
    });
  }
}

通过这种方式,当用户尝试截屏时,系统会阻止截屏操作,从而保护页面内容的隐私。

在HarmonyOS Next中,可以通过设置页面的Window属性来防止截屏。具体方法如下:

  1. 在页面的onPageShow生命周期中,调用WindowsetSecure方法,将secure属性设置为true
  2. 在页面的onPageHide生命周期中,将secure属性恢复为false,以便其他页面可以正常截屏。

示例代码:

@Override
protected void onPageShow() {
    super.onPageShow();
    getWindow().setSecure(true);
}

@Override
protected void onPageHide() {
    super.onPageHide();
    getWindow().setSecure(false);
}

这样可以有效防止用户在特定页面进行截屏操作。

回到顶部
AI 助手
你好,我是IT营的 AI 助手
您可以尝试点击下方的快捷入口开启体验!