HarmonyOS 如何使用全局水印

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

添加全局水印使用canvas进行绘制、或者使用overlay属性绘制可参考DEMO:

1.canvas进行绘制:

@Entry
@Component
struct globalWaterPage {
  private settings: RenderingContextSettings = new RenderingContextSettings(true)
  private context: CanvasRenderingContext2D = new CanvasRenderingContext2D(this.settings)
  build() {
    Stack({ alignContent: Alignment.Center }) {
      Column() {
        Text("全局水印").fontColor("#495057")
        Image($r("app.media.empty")).width(300)
      }
      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)
          }
        })
    }.layoutWeight(1)
  }
}

2.使用overlay属性绘制:

@Entry
@Component
struct globalWaterPageB {
  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.empty")).width(300)
    }
    .layoutWeight(1)
    .overlay(this.Watermark())
    .width("100%")
    .height('100%')
  }
}
分享
微博
QQ
微信
回复
16h前
相关问题
如何使用canvas添加水印
1346浏览 • 1回复 待解决
HarmonyOS 水印相机、水印视频
25浏览 • 1回复 待解决
HarmonyOS 绘制水印如何实现?
247浏览 • 1回复 待解决
HarmonyOS 如何使用全局的Builder
0浏览 • 1回复 待解决
canvas如何实现水印效果
975浏览 • 1回复 待解决
HarmonyOS 如何全局使用loading组件?
758浏览 • 1回复 待解决
HarmonyOS 如何简单使用全局变量?
496浏览 • 1回复 待解决
HarmonyOS 如何给 app 添加水印
386浏览 • 1回复 待解决
HarmonyOS 背景水印问题
374浏览 • 1回复 待解决
HarmonyOS 如何在app内全页面添加水印
38浏览 • 1回复 待解决
HarmonyOS是否支持图片添加水印
345浏览 • 1回复 待解决
HarmonyOS 使用全局自定义弹窗
70浏览 • 1回复 待解决
HarmonyOS windows级别添加水印
45浏览 • 1回复 待解决
基于原生的水印添加能力
822浏览 • 1回复 待解决
图片处理(加动态水印
359浏览 • 1回复 待解决