Dynamics 添加水印

水印效果如下:

实现方式如下

1、添加 mcs_watermark.js 

/*
页面添加水印
<script src="/WebResources/mcs_common.js"></script>
<script src="/WebResources/mcs_watermark.js"></script>
<script type="text/javascript">
watermark();
//or
//var now = getNow();
//watermark({"watermark_txt":"A B C X Y Z ","watermark_time":now});
</script>
*/

function watermark(settings) {
  //默认设置
  var defaultSettings = {
    watermark_txt: "default",
    watermark_time: "default",
    watermark_x: 20, //水印起始位置x轴坐标
    watermark_y: 20, //水印起始位置Y轴坐标
    watermark_rows: 20, //水印行数
    watermark_cols: 20, //水印列数
    watermark_x_space: 100, //水印x轴间隔
    watermark_y_space: 50, //水印y轴间隔
    watermark_color: "#aaa", //水印字体颜色
    watermark_alpha: 0.4, //水印透明度
    watermark_fontsize: "15px", //水印字体大小
    watermark_font: "微软雅黑", //水印字体
    watermark_width: 410, //水印宽度
    watermark_height: 80, //水印长度
    watermark_angle: 15, //水印倾斜度数
  };
  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];
    }
  }
  if (defaultSettings.watermark_txt === "default") {
    defaultSettings.watermark_txt = getDefaultWatermark();
  }
  if (defaultSettings.watermark_time === "default") {
    defaultSettings.watermark_time = getNow();
  }
  var oTemp = document.createDocumentFragment();
  //获取页面最大宽度
  var page_width = Math.max(
    document.body.scrollWidth,
    document.body.clientWidth
  );
  var cutWidth = page_width * 0.015;
  var page_width = page_width - cutWidth;
  //获取页面最大高度
  //   var page_height =
  //     Math.max(document.body.scrollHeight, document.body.clientHeight) + 450;
  //   page_height = Math.max(page_height, window.innerHeight - 30);
  var page_height = document.body.clientHeight;
  // page_height = Math.max(page_height, window.innerHeight - 30);
  //如果将水印列数设置为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.id = "mask_div" + i + j;
      mask_div.className = "mask_div";
      mask_div.appendChild(
        document.createTextNode(defaultSettings.watermark_txt)
      );
      mask_div.appendChild(document.createElement("br"));
      mask_div.appendChild(
        document.createTextNode(defaultSettings.watermark_time)
      );
      //设置水印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.pointerEvents = "none";
      mask_div.style.opacity = defaultSettings.watermark_alpha;
      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";
      oTemp.appendChild(mask_div);
    }
  }
  var parent_div = document.createElement("div");
  parent_div.style.visibility = "";
  parent_div.style.position = "absolute";
  parent_div.style.left = "0px";
  parent_div.style.top = "0px";
  parent_div.style.overflow = "hidden";
  parent_div.style.zIndex = "9999";
  //让水印不遮挡页面的点击事件
  parent_div.style.pointerEvents = "none";
  //   parent_div.style.opacity = defaultSettings.watermark_alpha;
  parent_div.style.width = page_width + "px";
  parent_div.style.height = page_height + "px";
  parent_div.style.display = "block";
  parent_div.appendChild(oTemp);
  document.body.appendChild(parent_div);
}

function getDefaultWatermark() {
  var watermarkTxt = Xrm.Page.context.getUserName();
  var userId = Xrm.Page.context.getUserId();
  var queryStr =
    "systemusers(" +
    userId.replace("{", "").replace("}", "") +
    ")?$select=fullname,domainname,mobilephone";
  CRM.Common.querySync(
    queryStr,
    true,
    function (res) {
      if (res != undefined) {
        if (res.mobilephone == null) res.mobilephone = "";
        watermarkTxt =
          res.fullname + " " + res.domainname + " " + res.mobilephone;
        return watermarkTxt;
      }
    },
    function () {}
  );
  return watermarkTxt;
}

function getNow() {
  var d = new Date();
  var year = d.getFullYear();
  var month = change(d.getMonth() + 1);
  var day = change(d.getDate());
  var hour = change(d.getHours());
  var minute = change(d.getMinutes());
  var second = change(d.getSeconds());

  function change(t) {
    if (t < 10) {
      return "0" + t;
    } else {
      return t;
    }
  }
  var time =
    year +
    "年" +
    month +
    "月" +
    day +
    "日 " +
    hour +
    ":" +
    minute +
    ":" +
    second;
  return time;
}

 2、在Dynamics Web安装目录下找到main.aspx,打开文件在末尾添加如下内容并保存;

...
<script src="/WebResources/mcs_common.js"></script>
<script src="/WebResources/mcs_watermark.js"></script>
<script type="text/javascript">
    watermark();
</script>
</body>
</html>

3、 重启IIS,刷新页面就能看到文章头部展示的水印效果;

ps:水印实现的脚本代码有很多,各种方式基本都可以用,这里用的是这个方式

 给html页面添加水印 - 慕尘 - 博客园 (cnblogs.com) 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值