1
0
mirror of https://github.com/haiwen/seahub.git synced 2025-04-27 19:05:16 +00:00
seahub/media/js/watermark.js

251 lines
12 KiB
JavaScript
Raw Permalink Normal View History

(function(watermark){
window.watermarkdivs = [];
// 加载水印
var loadMark = function(settings) {
var defaultSettings={
watermark_id: 'wm_div_id', //水印总体的id
watermark_txt:"测试水印", //水印的内容
watermark_x:20, //水印起始位置x轴坐标
watermark_y:20, //水印起始位置Y轴坐标
watermark_rows:0, //水印行数
watermark_cols:0, //水印列数
watermark_x_space:100, //水印x轴间隔
watermark_y_space:50, //水印y轴间隔
watermark_font:'微软雅黑', //水印字体
watermark_color:'black', //水印字体颜色
watermark_fontsize:'18px', //水印字体大小
watermark_alpha:0.15, //水印透明度要求设置在大于等于0.003
watermark_width:150, //水印宽度
watermark_height:100, //水印长度
watermark_angle:15 //水印倾斜度数
};
//采用配置项替换默认值作用类似jquery.extend
if(arguments.length === 1&&typeof arguments[0] ==="object" )
{
var src = arguments[0]||{};
for(key in src)
{
if(src[key]&&defaultSettings[key]&&src[key]===defaultSettings[key])
continue;
else if(src[key])
defaultSettings[key]=src[key];
}
}
//如果元素存在就移除
var watermark_element = document.getElementById(defaultSettings.watermark_id);
if(watermark_element){
var _parentElement = watermark_element.parentNode;
if(_parentElement){
_parentElement.removeChild(watermark_element);
}
}
//获取页面最大宽度
var page_width = Math.max(document.body.scrollWidth,document.body.clientWidth)-30;
//获取页面最大长度
var page_height = Math.max(document.body.scrollHeight,document.body.clientHeight)-30;
// 是否支持ShadowRoot
var IsShadowRoot = typeof document.createShadowRoot === 'function';
//var IsIE78=/msie [6|7|8]/i.test(window.navigator.userAgent);
//var cosv=0;
//var sinv=0;
//var M12=0;
//if(IsIE78){
// var fv=360-defaultSettings.watermark_angle%360;
// cosv=Math.cos(fv);
// sinv=Math.sin(fv);
// M12=-sinv;
//}
//创建水印外壳div
var otdiv = document.getElementById(defaultSettings.watermark_id);
if(!otdiv){
otdiv = document.createElement('div');
//创建shadow dom
otdiv.id = defaultSettings.watermark_id;
otdiv.style.pointerEvents = "none";
//判断浏览器是否支持createShadowRoot方法
if(typeof otdiv.createShadowRoot === 'function'){
shadowRoot = otdiv.createShadowRoot();
}else{
shadowRoot = otdiv;
}
//将shadow dom随机插入到body内的任意位置
var nodeList = document.body.children;
var index = Math.floor(Math.random()*(nodeList.length-1));
if(nodeList[index]){
document.body.insertBefore(otdiv,nodeList[index]);
}else{
document.body.appendChild(otdiv);
}
}else if(otdiv,shadowRoot){
shadowRoot = otdiv.shadowRoot;
}
//如果将水印列数设置为0或水印列数设置过大超过页面最大宽度则重新计算水印列数和水印x轴间隔
if (defaultSettings.watermark_cols == 0 || (parseInt(defaultSettings.watermark_x + defaultSettings.watermark_width *defaultSettings.watermark_cols + defaultSettings.watermark_x_space * (defaultSettings.watermark_cols - 1)) > page_width)) {
defaultSettings.watermark_cols = parseInt((page_width - defaultSettings.watermark_x + defaultSettings.watermark_x_space) / (defaultSettings.watermark_width + defaultSettings.watermark_x_space));
defaultSettings.watermark_x_space = parseInt((page_width - defaultSettings.watermark_x - defaultSettings.watermark_width * defaultSettings.watermark_cols) / (defaultSettings.watermark_cols - 1));
}
//如果将水印行数设置为0或水印行数设置过大超过页面最大长度则重新计算水印行数和水印y轴间隔
if (defaultSettings.watermark_rows == 0 || (parseInt(defaultSettings.watermark_y + defaultSettings.watermark_height * defaultSettings.watermark_rows + defaultSettings.watermark_y_space * (defaultSettings.watermark_rows - 1)) > page_height)) {
defaultSettings.watermark_rows = parseInt((defaultSettings.watermark_y_space + page_height - defaultSettings.watermark_y) / (defaultSettings.watermark_height + defaultSettings.watermark_y_space));
defaultSettings.watermark_y_space = parseInt(((page_height - defaultSettings.watermark_y) - defaultSettings.watermark_height * defaultSettings.watermark_rows) / (defaultSettings.watermark_rows - 1));
}
var x;
var y;
for (var i = 0; i < defaultSettings.watermark_rows; i++) {
y = defaultSettings.watermark_y + (defaultSettings.watermark_y_space + defaultSettings.watermark_height) * i;
for (var j = 0; j < defaultSettings.watermark_cols; j++) {
x = defaultSettings.watermark_x + (defaultSettings.watermark_width + defaultSettings.watermark_x_space) * j;
var mask_div = document.createElement('div');
mask_div.innerHTML = defaultSettings.watermark_txt;
// 设置水印相关属性start
mask_div.id = defaultSettings.watermark_id + i + j;
//设置水印div倾斜显示
mask_div.style.webkitTransform = "rotate(-" + defaultSettings.watermark_angle + "deg)";
mask_div.style.MozTransform = "rotate(-" + defaultSettings.watermark_angle + "deg)";
mask_div.style.msTransform = "rotate(-" + defaultSettings.watermark_angle + "deg)";
mask_div.style.OTransform = "rotate(-" + defaultSettings.watermark_angle + "deg)";
mask_div.style.transform = "rotate(-" + defaultSettings.watermark_angle + "deg)";
mask_div.style.visibility = "";
mask_div.style.position = "absolute";
//选不中
mask_div.style.left = x + 'px';
mask_div.style.top = y + 'px';
mask_div.style.overflow = "hidden";
mask_div.style.zIndex = "9999";
mask_div.style.opacity = defaultSettings.watermark_alpha;
mask_div.style.filter="progid:DXImageTransform.Microsoft.Alpha(Opacity="+(defaultSettings.watermark_alpha*100)+")";
//if(IsIE78) //ie7 8
// mask_div.style.filter="progid:DXImageTransform.Microsoft.Matrix(M11="+cosv+",M12="+M12+",M21="+sinv+",M22="+cosv+",SizingMethod='auto expand')progid:DXImageTransform.Microsoft.Alpha(Opacity="+(defaultSettings.watermark_alpha*100)+")";
mask_div.style.fontSize = defaultSettings.watermark_fontsize;
mask_div.style.fontFamily = defaultSettings.watermark_font;
mask_div.style.color = defaultSettings.watermark_color;
mask_div.style.textAlign = "center";
mask_div.style.width = defaultSettings.watermark_width + 'px';
mask_div.style.height = defaultSettings.watermark_height + 'px';
mask_div.style.display = "block";
if(!IsShadowRoot)
{
mask_div.onclick= function(){
var vcliEle = getElementsByClientXY(document, event.clientX, event.clientY, 0, 0);
if (vcliEle != null) {
switch (vcliEle.nodeName) {
case "A":
vcliEle.click();
break;
case "SELECT":
//找不到方法打开下拉框
vcliEle.focus();
break;
case "TEXTAREA":
vcliEle.focus();
break;
case "INPUT":
var vtype = vcliEle.getAttribute("type").toLowerCase();
switch (vtype) {
case "radio":
case "checkbox":
case "button":
case "submit":
case "reset":
case "file":
vcliEle.click();
break;
default:
vcliEle.focus();
break;
}
break;
}
}
};
}
//设置水印相关属性end
//附加到文档碎片中
shadowRoot.appendChild(mask_div);
};
};
};
var getXYTagByTagName = function (tagname, doc, clientX, clientY, fleft, ftop) {
//本级的控件
var inputs = doc.getElementsByTagName(tagname);
for (var i = 0, j = inputs.length; i < j; i++) {
var vrect = inputs[i].getBoundingClientRect();
var xmin = vrect.left + fleft;
var ymin = vrect.top + ftop;
var vwidth = vrect.width || inputs[i].offsetWidth;
var vheight = vrect.height || inputs[i].clientHeight;
var xmax = xmin + vwidth;
var ymax = ymin + vheight;
if (xmin <= clientX && xmax >= clientX && ymin <= clientY && ymax >= clientY) {
return inputs[i];
}
}
return null;
}
var getElementsByClientXY = function (doc, clientX, clientY, fleft, ftop) {
//本级的控件
var vtag = getXYTagByTagName("input",doc, clientX, clientY, fleft, ftop);
if(vtag!=null)
return vtag;
vtag = getXYTagByTagName("textarea",doc, clientX, clientY, fleft, ftop);
if(vtag!=null)
return vtag;
vtag = getXYTagByTagName("select",doc, clientX, clientY, fleft, ftop);
if(vtag!=null)
return vtag;
vtag = getXYTagByTagName("a",doc, clientX, clientY, fleft, ftop);
if(vtag!=null)
return vtag;
//检查是否有iframe
var viframe = doc.getElementsByTagName("iframe");
for (var k = 0, m = viframe.length; k < m; k++) {
var vfrect = viframe[k].getBoundingClientRect();
vfleft = fleft + vfrect.left;
vftop = ftop + vfrect.top;
var vframedoc = viframe[k].contentDocument || viframe[k].contentWindow.document;
var ifrele = getElementsByClientXY(vframedoc, clientX, clientY, vfleft, vftop);
if (ifrele != null)
return ifrele;
}
return null;
}
//初始化水印添加load和resize事件
watermark.init = function (settings) {
try {
window.addEventListener('load', function () {
loadMark(settings);
});
window.addEventListener('resize', function () {
loadMark(settings);
});
window.addEventListener('DOMContentLoaded', function () {
loadMark(settings);
})
}
catch (ex)
{
loadMark(settings);
}
};
//手动加载水印
watermark.load = function (settings) {
loadMark(settings);
};
})(window.watermark = {});