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 3D位移translate效果实例介绍
May 03 HTML / CSS
IE兼容css3圆角的实现代码
Jul 21 HTML / CSS
纯CSS实现聊天框小尖角、气泡效果
Apr 04 HTML / CSS
结合 CSS3 transition transform 实现简单的跑马灯效果的示例
Feb 07 HTML / CSS
HTML5 placeholder属性详解
Jun 22 HTML / CSS
HTML5中通过li-canvas轻松实现单图、多图、圆角图绘制,单行文字、多行文字等
Nov 30 HTML / CSS
HTML5的革新 结构之美
Jun 20 HTML / CSS
网易微博Web App用HTML5开发的过程介绍
Jun 13 HTML / CSS
html5使用canvas画空心圆与实心圆
Dec 15 HTML / CSS
详解如何用HTML5 Canvas API控制图片的缩放变换
Mar 22 HTML / CSS
HTML5 层的叠加的实现
Jul 07 HTML / CSS
css弧边选项卡的项目实践
May 07 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使用mkdir创建多级目录入门例子
2014/05/10 PHP
php json转换成数组形式代码分享
2014/11/10 PHP
php实现模拟post请求用法实例
2015/07/11 PHP
yii2实现分页,带搜索的分页功能示例
2017/01/07 PHP
使用PHP访问RabbitMQ消息队列的方法示例
2018/06/06 PHP
Yii框架日志记录Logging操作示例
2018/07/12 PHP
关于laravel模板中生成URL的几种模式总结
2019/10/18 PHP
大家未必知道的Js技巧收藏
2008/04/07 Javascript
javascript setAttribute, getAttribute 在不同浏览器上的不同表现
2010/08/05 Javascript
js调用后台servlet方法实例
2013/06/09 Javascript
JavaScript异步编程Promise模式的6个特性
2014/04/03 Javascript
javascript解析xml实现省市县三级联动的方法
2015/07/25 Javascript
jQuery实现鼠标滑向当前图片高亮显示并且其它图片变灰的方法
2015/07/27 Javascript
JavaScript+html5 canvas实现本地截图教程
2020/04/16 Javascript
Jquery插件仿百度搜索关键字自动匹配功能
2016/05/11 Javascript
Node.js中的require.resolve方法使用简介
2017/04/23 Javascript
AngularJS自定义指令实现面包屑功能完整实例
2017/05/17 Javascript
js实现带进度条提示的多视频上传功能
2020/12/13 Javascript
Node.JS 循环递归复制文件夹目录及其子文件夹下的所有文件
2017/09/18 Javascript
JS变量提升及函数提升实例解析
2020/09/03 Javascript
python使用pil生成缩略图的方法
2015/03/26 Python
Python cookbook(数据结构与算法)实现对不原生支持比较操作的对象排序算法示例
2018/03/15 Python
Python安装whl文件过程图解
2020/02/18 Python
django实现将修改好的新模型写入数据库
2020/03/31 Python
PyQT5速成教程之Qt Designer介绍与入门
2020/11/02 Python
如何在vscode中安装python库的方法步骤
2021/01/06 Python
澳大利亚网上玩具商店:Mr Toys Toyworld
2018/03/25 全球购物
Bravofly德国:预订廉价航班和酒店
2019/09/22 全球购物
Viking Direct爱尔兰:办公用品和家具
2019/11/21 全球购物
美国在线医疗分销商:MedEx Supply
2020/02/04 全球购物
澳大利亚网上书店:QBD
2021/01/09 全球购物
机电工程学生自荐信范文
2013/12/07 职场文书
《珍珠泉》教学反思
2014/02/20 职场文书
后勤个人工作总结
2015/02/28 职场文书
2016党员入党决心书
2015/09/22 职场文书
基于go interface{}==nil 的几种坑及原理分析
2021/04/24 Golang