【html5 canvas】使用Canvas做出橡皮擦效果 分类: HTML5 canvas javascript 橡皮擦效果 2014-12-30 16:15 324人阅读 评论(0) 收藏
2014-12-30 16:15
711 查看
html部分
lottery.js
另一个zepto.js是库函数文件,可网上自行查找
出来的效果如图
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html" charset="utf-8" /> <meta name="viewport" content="initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no" /> <title>My Canvas 0.1</title> <style type="text/css"> html,body,div,img{ margin:0; padding:0; } a,a:hover{ text-decoration:none; } .background{ width:100%; position:fixed; top:0; left:0; } </style> </head> <body> <img src="images/background.png" class="background resizeContainer"/> <div id="J_cover" class="resizeContainer"></div> <script type="text/javascript" src="js/zepto.js"></script> <script type="text/javascript" src="js/lottery.js"></script> <script type="text/javascript"> var canvas = { init : function(){ var self = this; var node = document.getElementById('J_cover'), canvas_url = 'images/cover.png', type = 'image'; var lottery = new Lottery(node, canvas_url, type, window_w, window_h, self.callback); lottery.init(); }, callback : function(){ $('#J_cover').hide(); } } var window_h, window_w; $(document).ready(function(){ window_w = $(window).width(); window_h = $(window).height(); $('.resizeContainer').width(window_w).height(window_h); canvas.init(); }); </script> </body> </html>
lottery.js
function Lottery(node, cover, coverType, width, height, drawPercentCallback) { //node:canvas的id,cover:上面一层的图片地址,coverType:'image'or'color',width:canvas宽, height:canvas高, drawPercentCallback:回调函数 //canvas this.conNode = node; this.background = null; this.backCtx = null; this.mask = null; this.maskCtx = null; this.lottery = null; this.lotteryType = 'image'; this.cover = cover || "#000"; this.coverType = coverType; this.pixlesData = null; this.width = width; this.height = height; this.lastPosition = null; this.drawPercentCallback = drawPercentCallback; this.vail = false; } Lottery.prototype = { createElement: function(tagName, attributes) { var ele = document.createElement(tagName); for (var key in attributes) { ele.setAttribute(key, attributes[key]); } return ele; }, getTransparentPercent: function(ctx, width, height) { var imgData = ctx.getImageData(0, 0, width, height), pixles = imgData.data, transPixs = []; for (var i = 0, j = pixles.length; i < j; i += 4) { var a = pixles[i + 3]; if (a < 128) { transPixs.push(i); } } return (transPixs.length / (pixles.length / 4) * 100).toFixed(2); }, resizeCanvas: function(canvas, width, height) { canvas.width = width; canvas.height = height; canvas.getContext('2d').clearRect(0, 0, width, height); }, resizeCanvas_w: function(canvas, width, height) { canvas.width = width; canvas.height = height; canvas.getContext('2d').clearRect(0, 0, width, height); if (this.vail) this.drawLottery(); else this.drawMask(); }, drawPoint: function(x, y, fresh) { this.maskCtx.beginPath(); this.maskCtx.arc(x, y, 20, 0, Math.PI * 2); this.maskCtx.fill(); this.maskCtx.beginPath(); this.maskCtx.lineWidth = 60; this.maskCtx.lineCap = this.maskCtx.lineJoin = 'round'; if (this.lastPosition) { this.maskCtx.moveTo(this.lastPosition[0], this.lastPosition[1]); } this.maskCtx.lineTo(x, y); this.maskCtx.stroke(); this.lastPosition = [x, y]; this.mask.style.zIndex = (this.mask.style.zIndex == 20) ? 21 : 20; }, bindEvent: function() { var _this = this; var device = (/android|webos|iphone|ipad|ipod|blackberry|iemobile|opera mini/i.test(navigator.userAgent.toLowerCase())); var clickEvtName = device ? 'touchstart' : 'mousedown'; var moveEvtName = device ? 'touchmove' : 'mousemove'; if (!device) { var isMouseDown = false; _this.conNode.addEventListener('mouseup', function(e) { e.preventDefault(); isMouseDown = false; var per = _this.getTransparentPercent(_this.maskCtx, _this.width, _this.height); if (per >= 80) {//在大于等于80%的时候调用回调函数 if (typeof(_this.drawPercentCallback) == 'function') _this.drawPercentCallback(); } }, false); } else { _this.conNode.addEventListener("touchmove", function(e) { if (isMouseDown) { e.preventDefault(); } if (e.cancelable) { e.preventDefault(); } else { window.event.returnValue = false; } }, false); _this.conNode.addEventListener('touchend', function(e) { isMouseDown = false; var per = _this.getTransparentPercent(_this.maskCtx, _this.width, _this.height); if (per >= 80) {//在大于等于80%的时候调用回调函数 if (typeof(_this.drawPercentCallback) == 'function') _this.drawPercentCallback(); } }, false); } this.mask.addEventListener(clickEvtName, function(e) { e.preventDefault(); isMouseDown = true; var x = (device ? e.touches[0].pageX : e.pageX || e.x); var y = (device ? e.touches[0].pageY : e.pageY || e.y); _this.drawPoint(x, y, isMouseDown); }, false); this.mask.addEventListener(moveEvtName, function(e) { e.preventDefault(); if (!isMouseDown) return false; e.preventDefault(); var x = (device ? e.touches[0].pageX : e.pageX || e.x); var y = (device ? e.touches[0].pageY : e.pageY || e.y); _this.drawPoint(x, y, isMouseDown); }, false); }, drawLottery: function() { if (this.lotteryType == 'image') { var image = new Image(), _this = this; image.onload = function() { this.width = _this.width; this.height = _this.height; _this.resizeCanvas(_this.background, _this.width, _this.height); _this.backCtx.drawImage(this, 0, 0, _this.width, _this.height); _this.drawMask(); } image.src = this.lottery; } else if (this.lotteryType == 'text') { this.width = this.width; this.height = this.height; this.resizeCanvas(this.background, this.width, this.height); this.backCtx.save(); this.backCtx.fillStyle = '#FFF'; this.backCtx.fillRect(0, 0, this.width, this.height); this.backCtx.restore(); this.backCtx.save(); var fontSize = 30; this.backCtx.font = 'Bold ' + fontSize + 'px Arial'; this.backCtx.textAlign = 'center'; this.backCtx.fillStyle = '#F60'; this.backCtx.fillText(this.lottery, this.width / 2, this.height / 2 + fontSize / 2); this.backCtx.restore(); this.drawMask(); } }, drawMask: function() { if (this.coverType == 'color') { this.maskCtx.fillStyle = this.cover; this.maskCtx.fillRect(0, 0, this.width, this.height); this.maskCtx.globalCompositeOperation = 'destination-out'; } else if (this.coverType == 'image') { var image = new Image(), _this = this; image.onload = function() { _this.resizeCanvas(_this.mask, _this.width, _this.height); var android = (/android/i.test(navigator.userAgent.toLowerCase())); _this.maskCtx.globalAlpha = 1;//上面一层的透明度,1为不透明 _this.maskCtx.drawImage(this, 0, 0, this.width, this.height, 0, 0, _this.width, _this.height); //---以下一段为在上面一层上写字 // var fontSize = 50; // var txt = '123123'; // var gradient = _this.maskCtx.createLinearGradient(0, 0, _this.width, 0); // gradient.addColorStop("0", "#fff"); // gradient.addColorStop("1.0", "#000"); // _this.maskCtx.font = 'Bold ' + fontSize + 'px Arial'; // _this.maskCtx.textAlign = 'left'; // _this.maskCtx.fillStyle = gradient; // _this.maskCtx.fillText(txt, _this.width / 2 - _this.maskCtx.measureText(txt).width / 2, 100); // _this.maskCtx.globalAlpha = 1; _this.maskCtx.globalCompositeOperation = 'destination-out'; } image.src = this.cover; } }, init: function(lottery, lotteryType) { if (lottery) { this.lottery = lottery; this.lottery.width = this.width; this.lottery.height = this.height; this.lotteryType = lotteryType || 'image'; this.vail = true; } if (this.vail) { this.background = this.background || this.createElement('canvas', { style: 'position:fixed;top:0;left:0;background-color:transparent;' }); } this.mask = this.mask || this.createElement('canvas', { style: 'position:fixed;top:0;left:0;background-color:transparent;' }); this.mask.style.zIndex = 20; if (!this.conNode.innerHTML.replace(/[\w\W]| /g, '')) { if (this.vail) this.conNode.appendChild(this.background); this.conNode.appendChild(this.mask); this.bindEvent(); } if (this.vail) this.backCtx = this.backCtx || this.background.getContext('2d'); this.maskCtx = this.maskCtx || this.mask.getContext('2d'); if (this.vail) this.drawLottery(); else this.drawMask(); var _this = this; window.addEventListener('resize', function() { _this.width = document.documentElement.clientWidth; _this.height = document.documentElement.clientHeight; _this.resizeCanvas_w(_this.mask, _this.width, _this.height); }, false); } }
另一个zepto.js是库函数文件,可网上自行查找
出来的效果如图
相关文章推荐
- 【图片压缩】使用canvas,html5进行图片压缩 分类: canvas 图片压缩 压缩 HTML5 fileReader 2015-03-20 17:14 118人阅读 评论(0) 收藏
- 【html5 audio】音乐播放,灵动的音符效果 分类: HTML5 audio 播放音乐 效果 2014-12-31 15:45 422人阅读 评论(0) 收藏
- 【html5 canvas】使用Canvas做出橡皮擦效果
- 【canvas马赛克效果】根据加载的图片动态生成对应的马赛克图片 分类: javascript 马赛克效果 马赛克 2015-03-20 17:35 79人阅读 评论(0) 收藏
- ubuntu中安装man手册查看函数原型 分类: linux使用 2010-02-28 22:50 2453人阅读 评论(0) 收藏 举报 ubuntu语言linuxlibrarysocketsys
- 将HtmlTable内容导出到Excel,使用NPOI组件 分类: ASP.NET 源代码 2012-12-17 13:37 2289人阅读 评论(3) 收藏
- Unable to find the ncurses libraries的解决办法 分类: DSP 2013-07-22 16:29 324人阅读 评论(0) 收藏
- AxWindowsMediaPlayer使用 分类: .NET 2012-03-31 12:50 1644人阅读 评论(0) 收藏
- 使用sudo 分类: ubuntu 测试 虚拟机 2013-07-30 09:56 232人阅读 评论(0) 收藏
- 使用StringIO 分类: python 小练习 2013-06-14 16:00 233人阅读 评论(0) 收藏
- 使用python下载文件 分类: python python下载 2013-06-22 16:58 277人阅读 评论(0) 收藏
- 使用sys无法通过sqlplus或者sqldeveloper连接数据库 分类: H2_ORACLE 2013-02-04 14:02 600人阅读 评论(0) 收藏
- 将HtmlTable内容导出到Excel,使用NPOI组件 分类: ASP.NET 源代码 2012-12-17 13:37 2288人阅读 评论(3) 收藏
- 如何在WDM中使用xp系统的DMA用来处理数据 分类: windows驱动程序WDM 浅谈PCI 2013-07-26 14:57 497人阅读 评论(0) 收藏
- python yield生成器 分类: python基础学习 2013-08-04 15:40 324人阅读 评论(0) 收藏
- python数据持久存储:pickle模块的基本使用 分类: python python基础学习 python 小练习 2013-06-17 14:41 209人阅读 评论(0) 收藏
- 数据库崩溃后对redo log的使用 分类: H2_ORACLE 2013-02-04 14:05 309人阅读 评论(0) 收藏
- 使用C语言读取properties文件V1.0 分类: H_HISTORY 2013-02-26 12:37 946人阅读 评论(0) 收藏
- 单片机c语言XBYTE的使用 分类: c51 单片机学习 2013-03-23 15:32 1546人阅读 评论(2) 收藏
- 使用reduce函数 分类: python 2013-04-18 20:34 316人阅读 评论(0) 收藏