• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >html5 > 用HTML5 Canvas API中的clearRect()方法实现橡皮擦功能

用HTML5 Canvas API中的clearRect()方法实现橡皮擦功能

作者:Airing 字体:[增加 减小] 来源:互联网 时间:2017-08-06

本文主要包含HTML5,Canvas,API,clearRect等相关知识,Airing 希望在学习及工作中可以帮助到您

在现实世界中,我们使用画笔在画板上进行绘画;在html5 canvas中,我们同样可以使用canvas的画笔——CanvasRenderingContext2D对象在canvas上进行绘画。众所周知,我们的画笔一般都会与橡皮擦配套使用,以便于纠正绘画过程中的错误并重新绘画。在html5 canvas中,CanvasRenderingContext2D对象也同样给我们提供了一个可以永远重复使用的橡皮擦——clearRect()方法。

  1. clearRect(x, y, width, height)  

CanvasRenderingContext2D对象的clearRect()方法用于清除canvas内以指定坐标点(x,y)为左上角、宽度为width、高度为height的矩形区域中的所有图形像素。

下面,我们来看一个实际的例子。我们先绘制一个半径为50px的实心圆,然后使用橡皮擦clearRect()对其中的局部区域进行擦除。绘制圆形的原始html5代码如下:

  1. <!DOCTYPE html>   
  2. <html>   
  3. <head>   
  4. <meta charset="UTF-8">   
  5. <title>使用HTML5 clearRect()擦除指定的矩形区域的入门示例</title>   
  6. </head>   
  7. <body>   
  8.   
  9. <!-- 添加canvas标签,并加上红色边框以便于在页面上查看 -->   
  10. <canvas id="myCanvas" width="400px" height="300px" style="border: 1px solid red;">   
  11. 您的浏览器不支持canvas标签。   
  12. </canvas>   
  13.   
  14. <script type="text/javascript">   
  15. //获取Canvas对象(画布)   
  16. var canvas = document.getElementById("myCanvas");   
  17. //简单地检测当前浏览器是否支持Canvas对象,以免在一些不支持html5的浏览器中提示语法错误   
  18. if(canvas.getContext){     
  19.     //获取对应的CanvasRenderingContext2D对象(画笔)   
  20.     var ctx = canvas.getContext("2d");   
  21.        
  22.     //绘制一个以坐标点(100,10)为圆心、半径为50px的圆形   
  23.     ctx.arc(100, 100, 50, 0, Math.PI * 2, false);   
  24.        
  25.     //绘制并填充圆形内部   
  26.     ctx.fill();      
  27. }   
  28. </script>   
  29. </body>   
  30. </html>  

对应的显示效果如下:
2016315111842196.png (421×312)

现在,我们使用clearRect()方法对实心圆中以圆心(100,100)为中心,周边各10px的矩形区域部分进行擦除。

  1. <script type="text/javascript">   
  2. //获取Canvas对象(画布)   
  3. var canvas = document.getElementById("myCanvas");   
  4. //简单地检测当前浏览器是否支持Canvas对象,以免在一些不支持html5的浏览器中提示语法错误   
  5. if(canvas.getContext){     
  6.     //获取对应的CanvasRenderingContext2D对象(画笔)   
  7.     var ctx = canvas.getContext("2d");   
  8.        
  9.     //绘制一个以坐标点(100,10)为圆心、半径为50px的圆形   
  10.     ctx.arc(100, 100, 50, 0, Math.PI * 2, false);   
  11.        
  12.     //绘制并填充圆形内部   
  13.     ctx.fill();   
  14.        
  15.     //擦除矩形区域内的图形   
  16.     ctx.clearRect(90, 90, 20, 20);   
  17. }   
  18. </script>  

对应的显示效果如下(是不是有点像一个铜钱?)。
2016315111914378.png (417×320)


页面上我们可以擦除一片页面上的区域,让其显示出背景图片。
下面的例子中我们擦除了矩形中的空白让其显示页面背景:

您可能想查找下面的文章:

  • HTML5知识点总结
  • HTML5的本地存储
  • HTML5本地存储之IndexedDB
  • Html5实现文件异步上传功能
  • Html5新标签datalist实现输入框与后台数据库数据的动态匹配
  • 详解HTML5 window.postMessage与跨域
  • HTML5拖放API实现拖放排序的实例代码
  • 解决html5中video标签无法播放mp4问题的办法
  • HTML5新特性 多线程(Worker SharedWorker)
  • Html5新增标签有哪些

相关文章

  • 2018-12-03利用CSS3进行弹性布局时内容对齐的方法详解
  • 2018-12-03详解如何用HTML5 Canvas API控制图片的缩放变换_html5教程技巧
  • 2017-08-06HTML5图片预览实例分享
  • 2018-12-03html5 的a标签 Href 拨电话的写法_html5教程技巧
  • 2018-12-03绝对零基础,选择做 HTML5 还是 iOS 应用?
  • 2018-12-03利用HTML5的一个特性- DeviceOrientation来实现手机上摇一摇功能
  • 2018-12-03HTML5 js实现拖拉上传文件功能
  • 2018-12-03 小强的HTML5移动开发之路(10)——在线画板
  • 2018-12-03用HTML5 Canvas API中的clearRect()方法实现橡皮擦功能_html5教程技巧
  • 2018-12-03分享一个vue全局配置的实例代码

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • html5的Canvas元素有什么作用?<Canvas>的简单使用
    • html5的画布canvas——画出简单的矩形、三角形实例代码
    • HTML5中文件上传的代码
    • 怎样使用phonegap查找联系人
    • H5响应式建站有什么好处
    • HTML5 canvas实现瀑布流文字效果代码
    • html5仿AMD9官网酷炫的下载引导页动画特效的示例代码
    • html5 css3网站菜单实现代码
    • 《css权威指南》与《html5与css3权威指南》那个更权威更先进?
    • html5画布旋转效果示例_html5教程技巧

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有