HTML5 Canvas绘制圆点虚线实例


Posted in HTML / CSS onJanuary 01, 2015

HTML5 Canvas 提供了很多图形绘制的函数,但是很可惜,Canvas API只提供了画实线的函数(lineTo),却并未提供画虚线的方法。这样的设计有时会带来很大的不便,《JavaScript权威指南》的作者David Flanagan就认为这样的决定是有问题的,尤其是在标准的修改和实现都比较简单的情况下 (“…something that is so trivial to add to the specification and so trivial to implement… I really think you’re making a mistake here” — http://lists.whatwg.org/pipermail/whatwg-whatwg.org/2007-May/011224.html)。

在Stack Overflow上,Phrogz提供了一个自己的画虚线的实现(http://stackoverflow.com/questions/4576724/dotted-stroke-in-canvas),严格的说,这是一个点划线的实现(p.s. 我认为该页面上Rod MacDougall的简化版更好)。那么,如果需要画圆点虚线(如下图所示),应该怎么办呢?

HTML5 Canvas绘制圆点虚线实例

以下是我自己的实现,只支持画水平的和垂直的圆点虚线,可以参考Phrogz与Rod MacDougall的方法来添加斜线描画的功能。

复制代码
代码如下:

var canvasPrototype = window.CanvasRenderingContext2D && CanvasRenderingContext2D.prototype;
canvasPrototype.dottedLine = function(x1, y1, x2, y2, interval) {
if (!interval) {
interval = 5;
}
var isHorizontal=true;
if (x1==x2){
isHorizontal=false;
}
var len = isHorizontal ? x2-x1 : y2-y1;
this.moveTo(x1, y1);
var progress=0;
while (len > progress) {
progress += interval;
if (progress > len) {
progress = len;
}
if (isHorizontal) {
this.moveTo(x1+progress,y1);
this.arc(x1+progress,y1,1,0,2*Math.PI,true);
this.fill();
} else {
this.moveTo(x1,y1+progress);
this.arc(x1,y1+progress,1,0,2*Math.PI,true);
this.fill();
}
}
}
HTML / CSS 相关文章推荐
CSS3属性选择符介绍
Oct 17 HTML / CSS
CSS3用@font-face实现自定义英文字体
Sep 23 HTML / CSS
CSS3制作炫酷带方向感应的鼠标滑过图片3D动画
Mar 16 HTML / CSS
使用CSS3美化HTML表单的技巧演示
May 17 HTML / CSS
利用CSS3的线性渐变linear-gradient制作边框的示例
Jun 02 HTML / CSS
详解CSS3的图层阴影和文字阴影效果使用
Jun 09 HTML / CSS
HTML5的结构和语义(5):交互
Oct 17 HTML / CSS
使用HTML5的链接预取功能(link prefetching)给网站提速
Dec 13 HTML / CSS
HTML5+CSS3应用详解
Feb 24 HTML / CSS
浅谈HTML5 FileReader分布读取文件以及其方法简介
Nov 09 HTML / CSS
localStorage的过期时间设置的方法详解
Nov 26 HTML / CSS
Html5页面点击遮罩层背景关闭遮罩层
Nov 30 HTML / CSS
HTML页面中添加Canvas标签示例
Jan 01 #HTML / CSS
HTML5 Canvas之测试浏览器是否支持Canvas的方法
Jan 01 #HTML / CSS
HTML5 Canvas中绘制矩形实例
Jan 01 #HTML / CSS
HTML5 Canvas中使用用路径描画圆弧
Jan 01 #HTML / CSS
HTML5 Canvas中使用路径描画二阶、三阶贝塞尔曲线
Jan 01 #HTML / CSS
HTML5制作酷炫音频播放器插件图文教程
Dec 30 #HTML / CSS
html5实现完美兼容各大浏览器的播放器
Dec 26 #HTML / CSS
You might like
php中判断文件存在是用file_exists还是is_file的整理
2012/09/12 PHP
浅谈php扩展imagick
2014/06/02 PHP
php结合web uploader插件实现分片上传文件
2016/05/10 PHP
js判断客户端是iOS还是Android等移动终端的方法
2013/12/11 Javascript
javascript获取元素偏移量的方法有哪些
2014/06/24 Javascript
javascript里使用php代码实例
2014/12/13 Javascript
js实现简单的可切换选项卡效果
2015/04/10 Javascript
JQuery点击事件回到页面顶部效果的实现代码
2016/05/24 Javascript
浅谈MVC+EF easyui dataGrid 动态加载分页表格
2016/11/10 Javascript
Ionic 2 实现列表滑动删除按钮的方法
2017/01/22 Javascript
在 Angular 中实现搜索关键字高亮示例
2017/03/21 Javascript
node.js遍历目录的方法示例
2018/08/01 Javascript
使用Vue CLI创建typescript项目的方法
2019/08/09 Javascript
Vue中的transition封装组件的实现方法
2019/08/13 Javascript
[04:44]DOTA2 2017全国高校联赛视频回顾
2017/08/21 DOTA
python sys模块sys.path使用方法示例
2013/12/04 Python
在Python中使用异步Socket编程性能测试
2014/06/25 Python
Python利用前序和中序遍历结果重建二叉树的方法
2016/04/27 Python
python在非root权限下的安装方法
2018/01/23 Python
Python3中内置类型bytes和str用法及byte和string之间各种编码转换 问题
2018/09/27 Python
python3实现小球转动抽奖小游戏
2020/04/15 Python
详解Django 时间与时区设置问题
2019/07/23 Python
完美解决pycharm导入自己写的py文件爆红问题
2020/02/12 Python
PyTorch中torch.tensor与torch.Tensor的区别详解
2020/05/18 Python
什么是Python中的顺序表
2020/06/02 Python
自定义Django_rest_framework_jwt登陆错误返回的解决
2020/10/18 Python
Python3 用什么IDE开发工具比较好
2020/11/28 Python
Django权限控制的使用
2021/01/07 Python
BrandAlley英国:法国折扣奢侈品网上零售商
2017/07/03 全球购物
中学门卫岗位职责
2013/12/26 职场文书
党的群众路线教育实践活动动员会主持词
2014/03/20 职场文书
公司总经理岗位职责范本
2014/08/15 职场文书
市贸粮局召开党的群众路线教育实践活动总结大会新闻稿
2014/10/21 职场文书
青年联谊会致辞
2015/07/31 职场文书
2019通用版新员工入职培训方案!
2019/07/11 职场文书
Redis中一个String类型引发的惨案
2021/07/25 Redis