canvas教程

JavaScript html5 canvas画布中删除一个块区域的方法

字号+ 作者:H5之家 来源:H5之家 2017-06-30 12:05 我要评论( )

本文实例讲述了html5 canvas画布中删除一个块区域的方法。分享给大家供大家参考,具体如下:运行效果截图如下:附:图中,黑色小方块即为删除掉的块区域具体代码

本文实例讲述了html5 canvas画布中删除一个块区域的方法。分享给大家供大家参考,具体如下:

运行效果截图如下:



附:图中,黑色小方块即为删除掉的块区域

具体代码如下:

index.html:

<!DOCTYPE html> <html> <head> <meta http-equiv="Content-type" content="text/html;charset=UTF-8" /> <title>canvas中删除一块区域</title> <style type="text/css"> #canvas { background:black; margin-top:100px; margin-left:200px; } </style> </head> <body> <canvas ></canvas> </body> <script type="text/javascript" src="canvas.js"></script> <script type="text/javascript"> cache = {}; var offsetX = 50, offsetY = 20; cache.context = dyl.createContext('canvas'); dyl.rect(dyl.createColor(), 150, 150, 200, 200, 0.5); for(var i=0; i<10; i++) { dyl.clearRect(150 + i*20, 150 + i*20, 20, 20); } </script> </html>

canvas.js:

(function() { var dyl = {cache: {}}; dyl.setContext = function(context) { dyl.cache._context = context; return context; }; dyl.getDom = function(id) { return document.getElementById(id); }; dyl._getContext = function() { return dyl.cache._context; }; dyl.save = function() { var context = dyl._getContext(); context ? context.save() : void(0); }; dyl.restore = function() { var context = dyl._getContext(); context ? context.restore() : void(0); }; dyl.createContext = function(canvasID) { var canvas = this.getDom(canvasID); if(!canvas) { return null; } return dyl.setContext(canvas.getContext("2d")); }; dyl.createColor = function() { var color = "rgb("; color += Math.round(Math.random()*255); color += ","; color += Math.round(Math.random()*255); color += ","; color += Math.round(Math.random()*255); color += ")"; return color; }; dyl.addImg = function(img, x, y) { var context = dyl._getContext(); if(!img || !context) { return; } if(typeof img === "string") { var oImg = new Image(); oImg.src = img; oImg.onload = function() { context.drawImage(oImg, x, y); } return; } context.drawImage(img, x, y); }; dyl.rect = function(color, x, y, width, height, alpha) { var context = dyl._getContext(); if(!context) { return; } context.save(); context.fillStyle = color; context.globalAlpha = alpha ? alpha : 1; context.fillRect(x, y, width, height); context.restore(); }; dyl.circle = function(color, x, y, r, alpha) { var context = dyl._getContext(); context.save(); context.fillStyle = color; context.beginPath(); context.globalAlpha = alpha ? alpha : 1; context.arc(x, y, r, 0, 2*Math.PI); context.fill(); context.stroke(); }; dyl.clearRect = function(x, y, width, height) { var context = dyl._getContext(); if(!context) { return; } context.clearRect(x, y, width, height); }; dyl.scale = function(x, y) { var context = dyl._getContext(); if(!context) { return; } x = x ? x : 1; y = y ? y : 1; context.scale(x, y); }; if(!window.dyl) { window.dyl = dyl; } })();

希望本文所述对大家JavaScript程序设计有所帮助。

您可能感兴趣的文章:JavaScript+html5 canvas绘制的小人效果
JavaScript+html5 canvas***色彩斑斓的正方形效果
JavaScript+html5 canvas绘制缤纷多彩的三角形效果完整实例
JavaScript+html5 canvas***的百花齐放效果完整实例
JavaScript+html5 canvas绘制渐变区域完整实例
JavaScript+html5 canvas绘制的圆弧荡秋千效果完整实例
javascript+HTML5的Canvas实现Lab单车动画效果
javascript+HTML5的canvas实现七夕情人节3D玫瑰花效果代码
js+html5实现canvas绘制圆形图案的方法
html5 canvas js(数字时钟)实例代码
JavaScript+html5 canvas***的圆中圆效果实例

 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • h5 canvas 图片上传操作

    h5 canvas 图片上传操作

    2017-06-30 13:00

  • windows phone (25) Canvas元素B

    windows phone (25) Canvas元素B

    2017-06-29 16:02

  • Particles.js基于Canvas画布创建粒子原子颗粒效果

    Particles.js基于Canvas画布创建粒子原子颗粒效果

    2017-06-29 15:00

  • JParticles是一款基于 Canvas 的轻量级 JavaScript 粒子运动特效

    JParticles是一款基于 Canvas 的轻量级 JavaScript 粒子运动特效

    2017-06-29 15:00

网友点评