鸿蒙Next开发-添加水印以及点击穿透设置

在鸿蒙Next中,为App全局添加水印可以通过以下方式实现,其中通过窗口添加水印是一种常见且高效的方式。以下是具体方案和实现细节:

在鸿蒙Next中,为App全局添加水印可以通过以下方式实现,其中通过窗口添加水印是一种常见且高效的方式。以下是具体方案和实现细节:


一、全局水印的实现方式

1. 窗口叠加水印(首选、推荐)

原理:在应用的主窗口(Window)上叠加一个半透明的水印层,覆盖所有页面内容。
优势:实现简单、性能较好,无需侵入业务逻辑。
实现步骤

(1) 创建全局水印组件

通过Stack布局在主页面内容上叠加水印层,通过设置hitTestBehavior(HitTestMode.Transparent)控制水印层不拦截点击事件,可结合文章<鸿蒙next开发-struct如何封装共用模块>把水印功能放到公共父模块里边去

// WatermarkComponent.ets
@Component
export struct WatermarkComponent {
  @State watermarkText: string = "水印内容" 

  build() {
    Stack() {
      // 主应用内容(通过插槽传递)
      Column() {
        Slot() // 占位符,用于承载实际页面内容
      }

      // 水印层(覆盖整个窗口)
      Flex({ direction: FlexDirection.Row, wrap: FlexWrap.Wrap }) {
        ForEach(Array(20).fill(0), (_, index) => {
          Text(this.watermarkText)
            .fontSize(16)
            .fontColor("#999999")
            .opacity(0.3)
            .rotate({ angle: -30 })
            .margin(20)
        })
      }
      .width('100%')
      .height('100%')
  .backgroundColor(Color.Transparent).hitTestBehavior(HitTestMode.Transparent)// 关键:设置水印层不拦截点击事件,否则水印下按钮点击失效。
    }
  }
}
(2) 在入口页面应用水印
// MainPage.ets
@Entry
@Component
struct MainPage {
  build() {
    WatermarkComponent() {
      // 此处放置实际页面内容
      Column() {
        Text("这是应用的主页面")
          .fontSize(24)
        // 其他组件...
      }
    }
  }
}
(3) 动态更新水印内容

可通过@State@Link实现水印动态化(如用户ID、时间戳):

@State watermarkText: string = `用户:张三 ${new Date().toLocaleString()}`

// 更新水印
updateWatermark() {
  this.watermarkText = `用户:张三 ${new Date().toLocaleString()}`
}

2. 全局悬浮窗水印

适用场景:需要跨多个Ability或独立于页面层级的水印。
实现步骤

(1) 创建悬浮窗服务
// WatermarkService.ets
import window from '@ohos.window';

export class WatermarkService {
  private static instance: WatermarkService | null = null;
  private watermarkWindow: window.Window | null = null;

  static getInstance() {
    if (!this.instance) {
      this.instance = new WatermarkService();
    }
    return this.instance;
  }

  async showWatermark() {
    try {
      this.watermarkWindow = await window.createWindow("watermark"window.WindowType.TYPE_FLOAT);
      await this.watermarkWindow.moveTo(00);
      await this.watermarkWindow.resize(window.Size.FULL_SCREEN);
      await this.watermarkWindow.setTouchable(false); // 禁止交互
      await this.watermarkWindow.loadContent("pages/WatermarkPage");
      await this.watermarkWindow.show();
    } catch (err) {
      console.error('悬浮窗创建失败:', err);
    }
  }
}
(2) 初始化全局水印
// App.ets
import { WatermarkService } from './WatermarkService';

export default class App {
  onCreate() {
    WatermarkService.getInstance().showWatermark(); // 应用启动时显示水印
  }
}

3. 自定义Ability水印

适用场景:需要与业务逻辑深度绑定的动态水印。
实现步骤

// WatermarkAbility.ets
import Ability from '@ohos.application.Ability';

export default class WatermarkAbility extends Ability {
  onWindowStageCreate(windowStage) {
    windowStage.loadContent("pages/WatermarkPage"(err) => {
      if (err) console.error("水印页面加载失败:", err);
    });
  }
}

二、技术对比与选型建议

方案优点缺点适用场景
窗口叠加水印
实现简单、性能高、无额外权限
需修改页面层级结构
单Ability应用、快速集成
全局悬浮窗
跨Ability生效、独立层级
需要悬浮窗权限、性能开销略高
企业级应用、高安全需求
自定义Ability
灵活控制水印生命周期
实现复杂度高
需要动态控制水印的场景


三、安全增强技巧

  1. 防截图绕过

    // 禁止截屏(需在config.json配置权限)
    import window from '@ohos.window';
    window.getTopWindow().then(win => {
      win.setWindowPrivacyMode(true); // 开启隐私模式
    });
  2. 动态水印

    // 绑定设备信息
    import deviceInfo from '@ohos.deviceInfo';
    this.watermarkText = `设备ID: ${deviceInfo.deviceId}`;
  3. 混淆水印元素

    // 随机角度和位置
    .rotate({ angle: -30 + Math.random() * 10 })
    .position({ x: `${Math.random() * 100}%`, y: `${Math.random() * 100}%` })

四、总结

  1. 窗口叠加水印是最高效的实现方式,适合大多数场景。
  2. 若需跨Ability或更高安全级别,推荐全局悬浮窗方案
  3. 通过Stack布局和Flex组件的灵活组合,可实现高密度、动态更新的水印效果。


来源:公众号
作者:Android技术之家

原文地址:https://mp.weixin.qq.com/s/wSqqPxr9i6fqr_-k4DbeJw

来源: 互联网
本文观点不代表码客-全球程序员交流社区立场,不承担法律责任,文章及观点也不构成任何投资意见。

赞 ()

相关推荐

  • 置顶 开发项目接单群,免费入群了

    无论你是Android、ios、java、php,或者你是产品经理、老板,都可以免费入群接单或者发布项目,全程不收取任何费用。

    2025年02月21日 15点27分
  • 鸿蒙Next开发-添加水印以及点击穿透设置

    在鸿蒙Next中,为App全局添加水印可以通过以下方式实现,其中通过窗口添加水印是一种常见且高效的方式。以下是具体方案和实现细节:

    2025年02月26日 23点15分
  • 鸿蒙Next开发-普通函数和箭头函数 this指向的区别以及对UI刷新的影响

    鸿蒙Next开发-普通函数和箭头函数 this指向的区别以及对UI刷新的影响

    2025年02月26日 23点14分
  • 深入探索ArkUI @Builder与@BuilderParam的进阶应用

    在ArkUI的组件化开发体系中,@Builder和@BuilderParam这对装饰器组合扮演着UI模块化的重要角色。二者的差异与配合体现了声明式UI的核心思想:

    2025年02月26日 23点12分
  • Deepseek推荐:Android 开发者需要掌握的系统知识大纲

    一、操作系统基础1. Linux 内核机制内容介绍 Android 基于 Linux 内核,核心机制包括进程管理、内存管理、文件系统、Binder 驱动等。

    2025年02月26日 23点09分
  • Android App 厂商角标适配

    本篇介绍一下笔者在维护IM应用时,设置App角标的相关经验。同时这里设置角标都是基于系统厂商的Launcher,没有适配三方的Launcher应用,因为我们统计下来发现近些年使用三方Launcher应用比较少了,大部分用户还是以系统Launcher为主。所在在我们的项目中,主要是适配各个厂商。

    2025年02月26日 23点07分
  • 鸿蒙Next-方法装饰器以及防抖方法注解实现

    以下是关于 鸿蒙Next(HarmonyOS NEXT)中 MethodDecorator 的详细介绍及使用指南,结合了多个技术来源的实践总结:

    2025年02月26日 22点58分
  • DevEco Studio常用快捷键以及如何跟AndroidStudio的保持同步

    DevEco Studio是华为推出的用于开发HarmonyOS应用的集成开发环境,它提供了丰富的快捷键以提高开发效率,以下为你详细介绍不同操作场景下的常用快捷键:

    2025年02月26日 22点56分
  • Android | 利用ItemDecoration绘制RecyclerView分割线

    RecyclerView.ItemDecoration 是 Android 提供的一种扩展机制,用于为 RecyclerView 的每个子项(Item)添加装饰(Decoration)。它通常用于绘制分割线、边距、背景等,目的是增强 RecyclerView 的显示效果。

    2025年02月26日 22点52分
  • Android 布局优化:利用 ViewStub 和 Merge 提升性能

    提升界面渲染性能是一个至关重要的任务,尤其是在应用启动时,渲染界面需要快速且流畅。为了优化 UI 渲染速度,Android 提供了许多工具,其中 ViewStub 和 Merge 标签是非常有效的布局优化手段。通过合理使用这两者,可以延迟加载不必要的视图、减少布局的嵌套层级,从而加速应用的启动和运行。

    2025年02月26日 22点47分
  • 玩转 ImageView.ScaleType:图片的缩放与裁剪技巧

    ImageView 是最常用的控件之一,它用于展示各种类型的图片。为了能够根据需求调整图片的显示效果,Android 提供了 ImageView.ScaleType 枚举,它可以灵活地控制图片如何适应 ImageView 的尺寸。本文将探讨 ImageView.ScaleType 的不同选项、使用场景及其实现技巧。

    2025年02月26日 22点45分
  • Android加快你的编译速度

    工欲善其事,必先利其器。如果每次运行项目都要花费5-10分钟,那人的心态都要崩了。

    2025年02月25日 15点40分
  • Flutter多渠道打包的解决方案(walle)

    我们的应用集成了TalkingData这个第三方工具来统计日活、事件等,需要在应用启动时初始化SDK,这个时候需要传入当前渠道,以便数据的统计。 由于最开始是用脚本一个个打包,一直想解决打包过慢的问题,但是网上大多教程是基于命令行参数或flavor,实质上并没有根本解决打包效率的问题。直到发现了文章的主角 walle。

    2025年02月25日 15点36分
  • Android-分享一个对RecyclerView二次封装的库(EasyRecyclerView)

    在日常的Android开发当中,我们肯定会有使用到RecyclerView的需求,这里分享一个对RecyclerView二次封装的开源库——EasyRecyclerView。它基本上满足基本的开发需求,希望能帮看文章的小伙伴提高开发效率。

    2025年02月25日 15点31分
  • Android原生系统真的那么好用吗?安卓原生系统吊打其他系统,因为有Google-Play,所以应用都是纯净的?

    实际方面,原生 Android 的最大优势是更新快速,对供应商特别是 Android 上游的补丁的合并速度非常快,几乎总能在第一时间更新。因为系统越原生,更新的代价就越小。反之,如果一个停止更新的原生 Android 其实是没有多大意义的,它失去了它最大的优势。

    2025年02月25日 15点30分
  • Application 作为 Dialog 的 Context?小心踩坑!

    大家好,相信大家在使用 Dialog 时,都有一个非常基本的认知:就是 Dialog 的 context 只能是 Activity,而不能是 Application,不然会导致弹窗崩溃:

    2025年02月25日 15点25分

发表回复

评论列表

点击查看更多

    联系我们

    在线咨询: QQ交谈

    微信:dxmcpjl

    邮件:1529097251#qq.com

    工作时间:周一至周五,9:30-18:30,节假日休息

    微信