mirror of
https://github.com/haiwen/seahub.git
synced 2025-04-27 11:01:14 +00:00
251 lines
12 KiB
JavaScript
251 lines
12 KiB
JavaScript
(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 = {});
|