用Canvas怎么给前端页面添加水印,方法是什么
Admin 2022-06-27 群英技术资讯 1360 次浏览
关于“用Canvas怎么给前端页面添加水印,方法是什么”的知识有一些人不是很理解,对此小编给大家总结了相关内容,具有一定的参考借鉴价值,而且易于学习与理解,希望能对大家有所帮助,有这个方面学习需要的朋友就继续往下看吧。前言
前端实现的水印基本都是不安全的,可被破解的~.~
水印
水印(watermark)是一种容易识别、被夹于纸内,能够透过光线穿过从而显现出各种不同阴影的技术。
实现
先创建一个 wrap 块,并给其设置一些样式:
<div class="wrap1 wrap_common"></div>
<style>
* {
margin: 0;
padding: 0;
}
.wrap_common {
position: relative;
margin: 0 auto;
width: 800px;
height: 44vh;
border: 1px solid rgba(0, 0, 0, 1);
background: rgba(255, 255, 255, 1);
overflow: hidden;
}
.wrap_common:first-child{
margin-bottom: 5vh;
}
</style>
1. DIV绝对定位
通过图层叠加的方式将水印追加到 wrap 上,我们先看一下最终效果

动态获取到 wrap 的长宽并计算其能放几个水印块,并相应的设置每一个水印块的偏移值 left,top即可:
const wrap = document.querySelector('.wrap1');
const { clientWidth, clientHeight } = wrap;
const waterHeight = 100;
const waterWidth = 180;
// 能放下几行几列
const [columns, rows] = [Math.ceil(clientWidth / waterWidth), Math.ceil(clientHeight / waterHeight)]
for (let i = 0; i < columns; i++) {
for (let j = 0; j <= rows; j++) {
// 生成水印块
const watcerMarkElement = createWaterMarkElement();
// 动态设置偏移值
addAttributes(watcerMarkElement, {
width: `${waterWidth}px` ,
height: `${waterHeight}px` ,
left: `${waterWidth + (i - 1) * waterWidth + 10}px` ,
top: `${waterHeight + (j - 1) * waterHeight + 10}px` ,
});
wrap.appendChild(watcerMarkElement)
}
}
2. canvas+背景图
我们知道,可以给 div 设置样式 background,我们可以很轻松的实现背景图片,那么水印也可以通过这种方式来实现,其中背景图片通过 canvas 画出来,并且通过 toDataURL() 将图片转为 dataURL(base64),最后追加到 background-image 样式中。
const wrap = document. querySelector('. wrap2');
wrap.style.backgroundImage = `url(${drawWaterMark()})` ;
drawWaterMark 方法实现如下 :
const drawWaterMark = (text = '小豪看世界') => {
const sin = Math.sin(Math.PI / 4.5);
const cos = Math.cos(Math.PI / 4.5);
const canvas = document.createElement('canvas')
canvas.width = 200;
canvas.height = 100;
const ctx = canvas.getContext('2d');
ctx.transform(cos, -sin, sin, cos, 0, 0);
ctx.font = '16px';
ctx.fillStyle = 'rgba(0,0,0,.4)';
ctx.fillText(text, 80, 140);
ctx.fillText(text, -30, 100);
return canvas.toDataURL('image/png')
};

我们可以看到 wrap 插入了一个 base64的图片,强迫症的童鞋可以处理一下,将它转为 style 标签插入到body中;
改为 style 标签插入:
const style = document. createElement('style');
style.type = 'text/css';
style.innerHTML = `
.wrap2 {
background-image: url(${drawWaterMark()});
}
`;
document.body.appendChild(style);
emmm,看起来美观一点了~.~

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要介绍了前端水印的简单实现代码示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
这篇文章主要介绍了基于HTML代码实现图片碎片化加载功能,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
这篇文章主要给大家分享CSS计数器的内容,可能一些朋友不是很了解CSS计数器是什么以及CSS计数器怎样使用,在下文小编会给大家详细的介绍CSS计数器及其用法,下面跟随小编一起来学习一下吧。
css设置上边距的方法一:使用margin-top属性margin-top属性可以设置元素的上外边距围绕在元素边框的空白区域是外边距。设置外边距会在元素外创建额外的“空白”。
本章给大家带来HTML5中如何使用rel属性的预加载功能?有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008