-
Notifications
You must be signed in to change notification settings - Fork 43
/
Copy pathpixelate.min.js
1 lines (1 loc) · 1.38 KB
/
pixelate.min.js
1
!function(e,t){var a=function(){var a={value:.05,reveal:!0,revealonclick:!1},n=arguments[0]||{},i=this,e=i.parentNode;"object"!=typeof n&&(n={value:parseInt(arguments[0])}),n=function(){var e={};for(var t in a)i.hasAttribute("data-"+t)?e[t]=i.getAttribute("data-"+t):e[t]=t in n?n[t]:a[t];return e}();var t=i.width,r=i.height,d=!1,o=document.createElement("canvas");o.width=t,o.height=r;var l=o.getContext("2d");l.mozImageSmoothingEnabled=!1,l.webkitImageSmoothingEnabled=!1,l.imageSmoothingEnabled=!1;var u=t*n.value,c=r*n.value;l.drawImage(i,0,0,u,c),l.drawImage(o,0,0,u,c,0,0,o.width,o.height),i.style.display="none",e.insertBefore(o,i),!1!==n.revealonclick&&"false"!==n.revealonclick&&o.addEventListener("click",function(){(d=!d)?l.drawImage(i,0,0,t,r):(l.drawImage(i,0,0,u,c),l.drawImage(o,0,0,u,c,0,0,o.width,o.height))}),!1!==n.reveal&&"false"!==n.reveal&&(o.addEventListener("mouseenter",function(){d||l.drawImage(i,0,0,t,r)}),o.addEventListener("mouseleave",function(){d||(l.drawImage(i,0,0,u,c),l.drawImage(o,0,0,u,c,0,0,o.width,o.height))}))};"function"==typeof t&&t.fn.extend({pixelate:function(){var e=arguments;return this.each(function(){a.apply(this,e)})}}),document.addEventListener("DOMContentLoaded",function(){for(var e=document.querySelectorAll("img[data-pixelate]"),t=0;t<e.length;t++)e[t].addEventListener("load",function(){a.apply(this)})})}(window,"undefined"==typeof jQuery?null:jQuery);