html5 Canvas画图教程(10)—把面拆成线条模拟出圆角矩形


Posted in HTML / CSS onJanuary 09, 2013

上一篇文章我讲了画矩形和圆形的方法,他们都有原生的canvas绘图函数可完成。而本文讲的圆角矩形则只有通过其他方法模拟出来。
一个正常的圆角矩形,我们先假设他四个角的圆角弧度一致——因为这样比较好画。我们动用把面拆成线条的能力,很容易就能发现圆角矩形其实是由4条钩子般的曲线组成。

html5 Canvas画图教程(10)—把面拆成线条模拟出圆角矩形


提到钩子,如果你看过我介绍arcTo的文章,那么可能你一下就明白了这种图形就可以用arcTo画出来。
我讲arcTo的时候提过,arcTo有个特性就是,他的第2条切线延长也并不会对他画出的线条造成影响(在上文的最后部分),这也为我们画圆角矩形提供了方便,不用担心变形。
下面放出我在国外网站上发现的canvas画圆角矩形的方法,应该是效率最高的了。
复制代码
代码如下:

//圆角矩形
CanvasRenderingContext2D.prototype.roundRect = function (x, y, w, h, r) {
if (w < 2 * r) r = w / 2;
if (h < 2 * r) r = h / 2;
this.beginPath();
this.moveTo(x+r, y);
this.arcTo(x+w, y, x+w, y+h, r);
this.arcTo(x+w, y+h, x, y+h, r);
this.arcTo(x, y+h, x, y, r);
this.arcTo(x, y, x+w, y, r);
// this.arcTo(x+r, y);
this.closePath();
return this;
}

此函数的参数,依次是x坐标,y坐标,宽度,高度,圆角半径。特别要注意最后这个参数——圆角半径。
此方法用了4次arcTo画出了一个圆角矩形,他的每个角的弧度都是一样的。此圆角矩形的坐标点也是和矩形一样的左上角,但他的起笔点可不是这里,而是:

html5 Canvas画图教程(10)—把面拆成线条模拟出圆角矩形


你可以去掉其中的某条线,看看此方法的原理。
当然,提醒一下,不论画什么图形,都要记得闭合路径——closePath,避免留下隐患。

这个方法最后有个return this,是为了让你能使用链式语法,如:
ctx.roundRect(200,300,200,120,20).stroke();你不需要的话也可以去掉他。
如果你并不想扩充ContextRenderingContext2D原型,你也可以把这个方法另外做一个函数。
当时发现这个函数的时候,我连arcTo是什么都不知道,所以也没有记住是在哪个网站上发现的,反正不是我原创的,在此感谢作者。

在前文中我一直强调这个方法画出的圆角矩形每个角都是一致的,是因为css3中的border-radius可以很轻松的画出每个角甚至每个角的邻边圆弧不一致的圆角矩形,待我找找canvas中画不规则圆角矩形的办法吧,不过个人觉得挺难的。

HTML / CSS 相关文章推荐
使用CSS3实现字体颜色渐变的实现
Mar 09 HTML / CSS
CSS3 media queries + jQuery实现响应式导航
Sep 30 HTML / CSS
css3的transition效果和transfor效果示例介绍
Oct 30 HTML / CSS
举例详解CSS3中的Transition
Jul 15 HTML / CSS
CSS3制作炫酷的自定义发光文字
Mar 28 HTML / CSS
纯css3制作煽动翅膀的蝴蝶的示例
Apr 23 HTML / CSS
css3动画鼠标放上图片逐渐变大鼠标离开图片逐渐缩小效果
Jan 27 HTML / CSS
关于 HTML5 的七个传说小结
Apr 12 HTML / CSS
HTML 5 input placeholder 属性如何完美兼任ie
May 12 HTML / CSS
有关HTML5中背景音乐的自动播放功能
Oct 16 HTML / CSS
Html5页面二次分享的实现
Jul 30 HTML / CSS
AmazeUI 网格的实现示例
Aug 13 HTML / CSS
html5 Canvas画图教程(9)—canvas中画出矩形和圆形
Jan 09 #HTML / CSS
html5 Canvas画图教程(8)—canvas里画曲线之bezierCurveTo方法
Jan 09 #HTML / CSS
html5 Canvas画图教程(7)—canvas里画曲线之quadraticCurveTo方法
Jan 09 #HTML / CSS
html5 Canvas画图教程(6)—canvas里画曲线之arcTo方法
Jan 09 #HTML / CSS
html5 Canvas画图教程(5)—canvas里画曲线之arc方法
Jan 09 #HTML / CSS
html5 Canvas画图教程(4)—未闭合的路径及渐变色的填充方法
Jan 09 #HTML / CSS
html5 Canvas画图教程(3)—canvas出现1像素线条模糊不清的原因
Jan 09 #HTML / CSS
You might like
php中实现记住密码自动登录的代码
2011/03/02 PHP
php number_format() 函数通过千位分组来格式化数字的实现代码
2013/08/06 PHP
php switch语句多个值匹配同一代码块的实现
2014/03/03 PHP
YII中assets的使用示例
2014/07/31 PHP
JavaScript Archive Network 集合
2007/05/12 Javascript
ie浏览器使用js导出网页到excel并打印
2014/03/11 Javascript
jQuery实现切换字体大小的方法
2015/03/10 Javascript
jQuery的Scrollify插件实现滑动到页面下一节点
2015/07/05 Javascript
微信小程序 定义全局数据、函数复用、模版等详细介绍
2016/10/27 Javascript
JavaScript字符串对象
2017/01/14 Javascript
JS及JQuery对Html内容编码,Html转义
2017/02/17 Javascript
JS验证input输入框(字母,数字,符号,中文)
2017/03/23 Javascript
React Native使用fetch实现图片上传的示例代码
2018/03/07 Javascript
vue实现提示保存后退出的方法
2018/03/15 Javascript
vue使用自定义指令实现拖拽
2021/01/29 Javascript
vue-cli在 history模式下的配置详解
2019/11/26 Javascript
原生javascript中this几种常见用法总结
2020/02/24 Javascript
python处理二进制数据的方法
2015/06/03 Python
Python中的集合类型知识讲解
2015/08/19 Python
Python的Django REST框架中的序列化及请求和返回
2016/04/11 Python
Python利用matplotlib生成图片背景及图例透明的效果
2017/04/27 Python
python3 模拟登录v2ex实例讲解
2017/07/13 Python
scrapy爬虫实例分享
2017/12/28 Python
解决python写入mysql中datetime类型遇到的问题
2018/06/21 Python
python之cv2与图像的载入、显示和保存实例
2018/12/05 Python
分享一个pycharm专业版安装的永久使用方法
2019/09/24 Python
你还在@微信官方?聊聊Python生成你想要的微信头像
2019/09/25 Python
Pytorch之Variable的用法
2019/12/31 Python
Python Django中间件使用原理及流程分析
2020/06/13 Python
入学生会自荐书范文
2014/02/05 职场文书
六查六看剖析材料
2014/10/06 职场文书
聊聊JS ES6中的解构
2021/04/29 Javascript
sql通过日期判断年龄函数的示例代码
2021/07/16 SQL Server
SQL基础查询和LINQ集成化查询
2022/01/18 MySQL
mongoDB数据库索引快速入门指南
2022/03/23 MongoDB
Axios代理配置及封装响应拦截处理方式
2022/04/07 Vue.js