HarmonyOS 如何给图片增加文字水印

请问一下如何在PixelMap对象上增加文字水印?

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

可以参考此demo:

import { image } from '@kit.ImageKit'

@Entry
@Component
struct Index {
  @State pixelMap: PixelMap | null = null
  aboutToAppear(): void {
    getContext(this).resourceManager.getMediaContent($r("app.media.startIcon")).then((data) => {
      let arrayBuffer = data.buffer.slice(data.byteOffset, data.byteLength + data.byteOffset)
      let imageSource: image.ImageSource = image.createImageSource(arrayBuffer);
      imageSource.getImageInfo((err, value) => {
        if (err) {
          return;
        }
        let opts: image.DecodingOptions =
          { editable: true, desiredSize: { height: value.size.height, width: value.size.width } };
        imageSource.createPixelMap(opts, (err,
          pixelMap) => {
          // 这个回调的pixelMap就是当前图片的pixelMap
          let offScreenCanvas = new OffscreenCanvas(value.size.width, value.size.height)
          let OffScreenContext = offScreenCanvas.getContext("2d")
          OffScreenContext.drawImage(pixelMap, 0, 0, offScreenCanvas.width, offScreenCanvas.height)
          OffScreenContext.fillStyle = '#30000000'
          OffScreenContext.font = "50px"
          OffScreenContext.fillText("水印水印水印水印水印", 20, 30)
          // 获取新的PixelMap
          this.pixelMap = OffScreenContext.getPixelMap(0, 0, offScreenCanvas.width, offScreenCanvas.height)
        })
      })
    })
  }
  build() {
    Flex({ direction: FlexDirection.Column, alignItems: ItemAlign.Center, justifyContent: FlexAlign.Center }) {
      Image(this.pixelMap).width(100).height(100)
    }.width('100%').height('100%')
  }
}
分享
微博
QQ
微信
回复
20h前
相关问题
HarmonyOS 如何 app 添加水印
386浏览 • 1回复 待解决
HarmonyOS 如何Text增加描边
63浏览 • 1回复 待解决
图片处理(加动态水印
359浏览 • 1回复 待解决
HarmonyOS是否支持图片添加水印
345浏览 • 1回复 待解决
如何文字添加下划线?
675浏览 • 1回复 待解决
HarmonyOS 拍照后的图片水印
35浏览 • 1回复 待解决
HarmonyOS 水印相机、水印视频
25浏览 • 1回复 待解决
如何按钮添加图片
5622浏览 • 4回复 待解决
HarmonyOS 绘制水印如何实现?
247浏览 • 1回复 待解决
HarmonyOS 如何使用全局水印
12浏览 • 1回复 待解决
HarmonyOS 图片+文字排列问题
109浏览 • 1回复 待解决