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 响应式媒体查询的示例代码
Sep 25 HTML / CSS
css3中背景尺寸background-size详解
Sep 02 HTML / CSS
通过CSS3的object-fit来调整图片适配尺寸的技巧简介
Feb 27 HTML / CSS
CSS3实现线性渐变用法示例代码详解
Aug 07 HTML / CSS
详解css3中dispaly的Grid布局与Flex布局
Sep 11 HTML / CSS
HTML5边玩边学(2)基础绘图实现方法
Sep 21 HTML / CSS
html5 浏览器支持 如何让所有的浏览器都支持HTML5标签样式
Dec 07 HTML / CSS
HTML5本地存储之Database Storage应用介绍
Jan 06 HTML / CSS
详解Canvas实用库Fabric.js使用手册
Jan 07 HTML / CSS
详解canvas.toDataURL()报错的解决方案全都在这了
Mar 31 HTML / CSS
HTML5公共页面提取作为公用代码的方法
Jun 30 HTML / CSS
CSS中Single Div 绘图技巧的实现
Jun 18 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中使用临时表查询数据的一个例子
2013/02/03 PHP
thinkphp缓存技术详解
2014/12/09 PHP
PHP动态输出JavaScript代码实例
2015/02/12 PHP
js异或加解密效果代码
2008/06/25 Javascript
contains和compareDocumentPosition 方法来确定是否HTML节点间的关系
2011/09/13 Javascript
javascript之querySelector和querySelectorAll使用介绍
2011/12/20 Javascript
JS数学函数Exp使用说明
2012/08/09 Javascript
Jquery事件的连接使用示例
2013/06/18 Javascript
JavaScript实现给按钮加上双重动作的方法
2015/08/14 Javascript
JS实现选项卡实例详解
2015/11/17 Javascript
javascript中的3种继承实现方法
2016/01/27 Javascript
如何利用模板将HTML从JavaScript中抽离
2016/10/08 Javascript
使用BootStrap实现表格隔行变色及hover变色并在需要时出现滚动条
2017/01/04 Javascript
JS轮播图中缓动函数的封装
2020/11/25 Javascript
Angularjs自定义指令Directive详解
2017/05/27 Javascript
Vue使用vue-cli创建项目
2017/09/01 Javascript
浅谈在Vue-cli里基于axios封装复用请求
2017/11/06 Javascript
webpack css加载和图片加载的方法示例
2018/09/11 Javascript
vue 音乐App QQ音乐搜索列表最新接口跨域设置方法
2018/09/25 Javascript
javascript中floor使用方法总结
2019/02/02 Javascript
element-ui中Table表格省市区合并单元格的方法实现
2019/08/07 Javascript
vue实现简单的登录弹出框
2020/10/26 Javascript
python迭代器与生成器详解
2016/03/10 Python
python使用ddt过程中遇到的问题及解决方案【推荐】
2018/10/29 Python
Django开发的简易留言板案例详解
2018/12/04 Python
python实现五子棋游戏
2019/06/18 Python
PyQT5 QTableView显示绑定数据的实例详解
2019/06/25 Python
canvas实现圆绘制的示例代码
2019/09/11 HTML / CSS
关于环保的标语
2014/06/13 职场文书
2014镇副书记群众路线专题民主生活会思想汇报
2014/09/23 职场文书
村党支部群众路线教育实践活动对照检查材料
2014/09/26 职场文书
捐助感谢信
2015/01/22 职场文书
写给纪委的违纪检讨书
2015/05/05 职场文书
周恩来的四个昼夜观后感
2015/06/03 职场文书
2016年党校科级干部培训班学习心得体会
2016/01/06 职场文书
Vue如何实现组件间通信
2021/05/15 Vue.js