HarmonyOS 有没有对UI添加水印的方法

HarmonyOS
7h前
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
aquaa

参考demo:

@Entry
@Component
struct PageWatermark {
  private settings: RenderingContextSettings = new RenderingContextSettings(true)
  private context: CanvasRenderingContext2D = new CanvasRenderingContext2D(this.settings)

  @Builder Watermark() {
    Canvas(this.context)
      .width("100%") .height("100%")
      .hitTestBehavior(HitTestMode.Transparent)
      .onReady(() => {
        this.context.fillStyle = '#10000000'
        this.context.font = "16vp"
        this.context.textAlign = "center"
        this.context.textBaseline = "middle"
        // 在这里绘制文字水印,也可以是图片水印
        for (let i = 0; i < this.context.width / 120; i++) {
          this.context.translate(120, 0)
          let j = 0
          for (; j < this.context.height / 120; j++) {
            this.context.rotate(-Math.PI / 180 * 30)
            // 此处水印数据是写成定值的,具体请替换为自己的水印
            this.context.fillText("水印水印水印", -60, -60)
            this.context.rotate(Math.PI / 180 * 30)
            this.context.translate(0, 120) }
          this.context.translate(0, -120 * j)
        }
      })
  }

  build() {
    Column() {
      Text("没有数据哦").fontColor("#495057")
      Image($r("app.media.startIcon"))
        .width(300)
        .layoutWeight(1)
        .overlay(this.Watermark())
        .width("100%")
    }
    .height('100%')
    .width('100%')
  }
}
分享
微博
QQ
微信
回复
6h前
相关问题
HarmonyOS是否支持图片添加水印
310浏览 • 1回复 待解决
HarmonyOS 如何给 app 添加水印
363浏览 • 1回复 待解决
如何使用canvas添加水印
1328浏览 • 1回复 待解决
基于原生水印添加能力
782浏览 • 1回复 待解决
HarmonyOS 有没有办法动态添加组件?
469浏览 • 1回复 待解决
HarmonyOS 有没有方法直接退出APP
598浏览 • 1回复 待解决
有没有给canvas设置ColorFilter方法
681浏览 • 1回复 待解决
有没有一个ARK UI组件库工程模版?
853浏览 • 1回复 待解决