HTML5 canvas基本绘图之图形变换


Posted in HTML / CSS onJune 27, 2016

<canvas></canvas>是HTML5中新增的标签,用于绘制图形,实际上,这个标签和其他的标签一样,其特殊之处在于该标签可以获取一个CanvasRenderingContext2D对象,我们可以通过JavaScript脚本来控制该对象进行绘图。

<canvas></canvas>只是一个绘制图形的容器,除了id、class、style等属性外,还有height和width属性。在<canvas>>元素上绘图主要有三步:

1.获取<canvas>元素对应的DOM对象,这是一个Canvas对象;
2.调用Canvas对象的getContext()方法,得到一个CanvasRenderingContext2D对象;
3.调用CanvasRenderingContext2D对象进行绘图。

图形变换

平移:context.translate(x,y),接收参数分别为原点在x轴方向平移x,在y轴方向平移y。

缩放:context.scale(x,y),接收参数分别为x坐标轴按x比例缩放,y坐标轴按y比例缩放。

旋转:context.rotate(angle),接收参数是坐标轴旋转的角度。

需要说明的是,对图形进行变化后,接下来的一次绘图是紧接着上一次的状态的,所以如果需要回到初始状态,要用到context.save();和context.restore();来保存和恢复当前状态:

JavaScript Code复制内容到剪贴板
  1. var canvas = document.getElementById("canvas");   
  2. var context = canvas.getContext("2d");   
  3.   
  4. //translate()   
  5. context.save();   
  6. context.fillStyle = "#1424DE";   
  7. context.translate(10,10);   
  8. context.fillRect(0,0,200,200);   
  9. context.restore();   
  10.   
  11. //scale()   
  12. context.save();   
  13. context.fillStyle = "#F5270B";   
  14. context.scale(0.5,0.5);   
  15. context.fillRect(500,50,200,200);   
  16. context.restore();   
  17. //rotate()   
  18.   
  19. context.save();   
  20. context.fillStyle = "#18EB0F";   
  21. context.rotate(Math.PI / 4);   
  22. context.fillRect(300,10,200,200);   
  23. context.restore();   

效果如下:

HTML5 canvas基本绘图之图形变换

另外一个跟图形变换相关的是:矩阵变换 :context.transform(a, b, c, d, e, f, g)。参数的含义如下:

a 水平缩放 ( 默认为1 )
b 水平倾斜 ( 默认为 0 )
c 垂直倾斜 ( 默认为 0 )
d 垂直缩放 ( 默认为1 )
e 水平位移 ( 默认为 0 )
f 垂直位移 ( 默认为 0 )

读者可以自行验证其各个参数的效果,这里就不一一介绍了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
CSS3对图片照片进行边缘模糊处理的实现
Aug 08 HTML / CSS
CSS3之边框多颜色Border-color属性使用示例
Oct 11 HTML / CSS
css3选择器基本介绍
Dec 15 HTML / CSS
使用CSS3滤镜的filter:blur属性制作毛玻璃模糊效果的方法
Jul 08 HTML / CSS
传统HTML页面实现模块化加载的方法
Oct 15 HTML / CSS
HTML5之多线程(Web Worker)
Jan 02 HTML / CSS
HTML5 声明兼容IE的写法
May 16 HTML / CSS
html5中为audio标签增加停止按钮动作实现方法
Jan 04 HTML / CSS
HTML5新增form控件和表单属性实例代码详解
May 15 HTML / CSS
使用Html5中的cavas画一面国旗
Sep 25 HTML / CSS
CSS 鼠标选中文字后改变背景色的实现代码
May 21 HTML / CSS
CSS list-style-type属性使用方法
May 21 HTML / CSS
HTML5 canvas基本绘图之填充样式实现
Jun 27 #HTML / CSS
HTML5 canvas基本绘图之绘制线条
Jun 27 #HTML / CSS
HTML5 canvas基本绘图之绘制五角星
Jun 27 #HTML / CSS
浅析HTML5中header标签的用法
Jun 24 #HTML / CSS
HTML5中使用postMessage实现两个网页间传递数据
Jun 22 #HTML / CSS
基于HTML5 的人脸识别活体认证的实现方法
Jun 22 #HTML / CSS
调用HTML5的Canvas API绘制图形的快速入门指南
Jun 17 #HTML / CSS
You might like
基于mysql的论坛(2)
2006/10/09 PHP
PHP在特殊字符前加斜杠的实现代码
2011/07/17 PHP
PHP对表单提交特殊字符的过滤和处理方法汇总
2014/02/18 PHP
PHP获取redis里不存在的6位随机数应用示例【设置24小时过时】
2017/06/07 PHP
Smarty缓存机制实例详解【三种缓存方式】
2019/07/20 PHP
thinkphp 框架数据库切换实现方法分析
2020/05/18 PHP
浅析PHP echo 和 print 语句
2020/06/30 PHP
总结一些js自定义的函数
2006/08/05 Javascript
jquery数据验证插件(自制,简单,练手)实例代码
2013/10/24 Javascript
用html5 js实现点击一个按钮达到浏览器全屏效果
2014/05/28 Javascript
jquery搜索框效果实现方法
2015/01/16 Javascript
JavaScript去除数组里重复值的方法
2015/07/13 Javascript
JS生成某个范围的随机数【四种情况详解】
2016/04/20 Javascript
通过javascript进行UTF-8编码的实现方法
2016/06/27 Javascript
Vue.js学习笔记之修饰符详解
2017/07/25 Javascript
vue下拉列表功能实例代码
2018/04/08 Javascript
浅谈Angular单元测试总结
2019/03/22 Javascript
Vue源码探究之虚拟节点的实现
2019/04/17 Javascript
vue Tab切换以及缓存页面处理的几种方式
2019/11/05 Javascript
Python3实现生成随机密码的方法
2014/08/23 Python
python获取各操作系统硬件信息的方法
2015/06/03 Python
python实现kNN算法
2017/12/20 Python
对python中的os.getpid()和os.fork()函数详解
2019/08/08 Python
基于Tensorflow高阶读写教程
2020/02/10 Python
python 元组的使用方法
2020/06/09 Python
Pycharm连接gitlab实现过程图解
2020/09/01 Python
ProBikeKit澳大利亚:自行车套件,跑步和铁人三项装备
2016/11/30 全球购物
豪华复古化妆:Besame Cosmetics
2019/09/06 全球购物
斯洛伐克最大的婴儿食品和用品网上商店:Feedo.sk
2020/12/21 全球购物
vue路由实现登录拦截
2021/03/24 Vue.js
家长评语和期望
2014/02/10 职场文书
培训班主持词
2014/03/28 职场文书
IT工程师岗位职责
2014/07/04 职场文书
出售房屋协议书范本
2014/10/06 职场文书
《刺客之王:C罗全景传记》:时代从来不会亏待手艺人
2019/11/28 职场文书
python编写五子棋游戏
2021/05/25 Python