页面加水印

// 绘制canvas水印
function setWatermark (str, domid, params) {
  var { width, height, angle, opacity, fontSize } = params || {}
  var dom = ""
  if (domid) {
    dom = document.getElementById(domid)
  } else {
    dom = document.body
  }
  // 固定id便于去重和移除
  var id = "jyWatermarkCanvasContainer"
  if (document.getElementById(id) !== null) {
    dom.removeChild(document.getElementById(id))
  }

  var can = document.createElement("canvas")
  can.width = width || 350
  can.height = height || 260

  var cans = can.getContext("2d")
  cans.rotate((-(angle || 20) * Math.PI) / 180)
  cans.font = `${fontSize || "20px"} Vedana`
  cans.fillStyle = `rgba(200, 200, 200, ${opacity || 0.2})`
  cans.textAlign = "left"
  cans.textBaseline = "Middle"
  cans.fillText(str, can.width / 3, can.height / 2)

  var div = document.createElement("div")
  div.id = id
  div.style.pointerEvents = "none"
  div.style.top = "70px"
  div.style.left = "0px"
  div.style.position = "fixed"
  div.style.zIndex = "100000"
  div.style.width = document.documentElement.clientWidth - 100 + "px"
  div.style.height = document.documentElement.clientHeight - 100 + "px"
  div.style.background =
    "url(" + can.toDataURL("image/png") + ") left top repeat"
  dom.appendChild(div)
  return id
}
// 水印移除
function removeWatermark () {
  var id = "jyWatermarkCanvasContainer"
  if (document.getElementById(id) !== null) {
    document.getElementById(id).remove()
  }
}
// 添加水印
function addWatermark (str, domid, params) {
  setWatermark(str, domid, params)
  // var id = setWatermark(str, domid, params)
  // 定时添加水印防删除
  // setInterval(() => {
  //   if (document.getElementById(id) === null) {
  //     id = setWatermark(str, domid, params)
  //   }
  // }, 500)
  // 窗口移动重新绘制
  // window.onresize = () => {
  //   setWatermark(str, domid)
  // }
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值