详解html5 canvas常用api总结(二)--绘图API


Posted in HTML / CSS onDecember 14, 2016

canvas可以绘制出很多奇妙的样式和美丽的效果,通过几个简单的api就可以在画布上呈现出千变万化的效果,还可以制作网页游戏,接下来就总结一下和绘图有关的API。

绘画的时候canvas相当于画布,而context相当于画笔。

1.绘制线条

moveTo(x0,y0):把当前画笔(ictx)移动到(x0,y0)这个位置。

lineTo(x1,y1):从当前位置(x0,y0)处到(x1,y1)画一条直线。

beginPath():开启一条路径或者重置当前路径。

closePath():从当前点回到路径起始点,也就是上一个beginPath的位置,回避和路径。

stroke():绘制。必须加了这个函数才会画图,所以这个一定要放在最后。

var icanvas=document.getElementById("iCanvas");

var ictx=icanvas.getContext("2d");

ictx.beginPath();

ictx.moveTo(0,0);

ictx.lineTo(300,150);

ictx.lineTo(3,150);

ictx.closePath();

ictx.stroke();

效果:

详解html5 canvas常用api总结(二)--绘图API

这里要注意,如果closepath放在stroke函数后面,则不会绘制成一个闭合的线条,因为在闭合前,已经绘制了,所以左边那条直线不会画出来。

2.线条样式

lineCap:线条端点样式,butt,round,square。                        

详解html5 canvas常用api总结(二)--绘图API

lineJoin:两线条相交时的拐点样式,其中设置为miter时还可以通过miterLimet设置拐点交界处的最大长度。

 

详解html5 canvas常用api总结(二)--绘图API

miterLimet:如果斜接长度超过 miterLimit 的值,边角会以 lineJoin 的 "bevel" 类型来显示。

lineWidth:线条宽度

strokeStyle: 线条颜色、渐变(定义好的渐变对象)、模式。 context.strokeStyle="#333";

var iCanvas=document.getElementById("iCanvas");

var ictx=iCanvas.getContext("2d");

ictx.beginPath();

ictx.strokeStyle="#0000ff";

ictx.lineWidth=20;

ictx.lineCap="round";

ictx.moveTo(10,10);

ictx.lineTo(80,80);

ictx.stroke();

ictx.beginPath();//在这里必须beginPath,不然一直会以第一个为基础会话,在最后的stroke的时候,会再次画一条黑色的斜线,一共3条线。

ictx.strokeStyle="#000000";

ictx.lineCap="butt";

ictx.lineWidth=10;

ictx.moveTo(80,10);

ictx.lineTo(10,80);

ictx.stroke();

beginPath和closePath可以不成对出现,两者之间几乎没有关系,closePath是用来闭合终点和起始点画一条闭合路径的。

3.绘制曲线

arc(x,y,radius,startAngle,endAngle,anticlockwise):绘制曲线,radius是曲线半径,startAngle,endAngle开始角度和结束角度,用的是弧度(Math.PI/180)*角度值,anticlockwise绘制方向;

arcTo(x1,y1,x2,y2,radius):绘制两切线之前的曲线。

ictx.beginPath();

ictx.moveTo(20,20);           // 创建开始点

ictx.lineTo(100,20);          // 创建水平线

ictx.arcTo(150,20,150,70,50); // 创建弧

ictx.lineTo(150,120);         // 创建垂直线

ictx.stroke();

绘制曲线的起点和水平线结束点与设置的第一个点的连线相切,曲线的终点和第一个设置点与第二个设置点的连线相切。

详解html5 canvas常用api总结(二)--绘图API

quadraticCurveTo(x1,y1,x2,y2):二次贝塞尔曲线。(x1,y1)控制点的坐标,(x2,y2)结束点的坐标

bezierCurveTo(x1,y1,x2,y2,x,y):三次贝塞尔曲线。(x1,y1)控制点1的坐标,(x2,y2)控制点2的坐标 (x,y)结束点的坐标。

贝塞尔曲线在绘制一些非常流畅的曲线时非常有用。 

4.绘制矩形及填充

rect():创建矩形;

fillRect(x,y,width,height):绘制被填充的矩形:(x,y)起始点,width,height矩形宽高

strokeRect():绘制矩形线框

clearRect():清除掉矩形。

ictx.fillStyle="#0000ff";//设定填充颜色

ictx.fillRect(20,20,150,100);

ictx.strokeRect(180,20,100,100);

5.画笔属性

fillStyle:设置填充的颜色,渐变或模式(patten);

strokeStyle:画笔的颜色,渐变或者模式

6.绘制阴影

shadowColor:阴影yanse

shadowBlur:模糊级别

shadowOffsetX:阴影的水平距离

shadowOffsetY:阴影的垂直距离

ictx.shadowBlur=20;

ictx.shadowColor="#456";

ictx.shadowOffsetX=-10;

ictx.shadowOffsetY=30;//先设置阴影再画矩形

ictx.fillStyle="#108997";

ictx.fillRect(20,20,100,80);

ictx.stroke();

详解html5 canvas常用api总结(二)--绘图API

 7.绘制渐变

 createLinearGradient(x1,y1,x2,y2):绘制线性渐变,(x1,y1)是渐变的起始点,(x2,y2)是渐变的终点,位置不同可以制作出垂直或者水平渐变。

 createRadialGradient(x1,y1,r1,x2,y2,r2):径向渐变:,(x1,y1)是渐变的起始点圆心,r1是半径,(x2,y2)是渐变的终点,r2是结束点半径;

两种渐变都需要使用

addColorStop(stop,color)来设置渐变过程,stop是0.0到1.0的值。

var grd=ictx.createLinearGradient(0,0,170,0);

grd.addColorStop(0,"#000");

grd.addColorStop(0.5,"#378923");

grd.addColorStop(1,"#ddd");

ictx.fillStyle=grd;//这里渐变是一个对象,用来向fillstyle传值

ictx.fillRect(20,20,150,100);

 

var grd=ictx.createRadialGradient(300,225,15,250,225,100);

grd.addColorStop(0,"#345");

grd.addColorStop(1,"#fff");

ictx.fillStyle=grd;

ictx.fillRect(200,150,150,100);

详解html5 canvas常用api总结(二)--绘图API

8.填充背景

 createPattern(image,"repeat|repeat-x|repeat-y|no-repeat"):image是一个图片对象,后面的参数是用来设定图片的重复方式。

 9.其他相关API

fill():填充当前路径。

isPointInPath():ictx.isPointInPath(x,y);判断这个点是否位于当前路径

清除画布方法:获取画布的宽高,icanvas.height,icanvas.width;然后使用clearRect();

修改画布的宽高:icanvas.width='200';icanvas.width='300'的方法。

globalAlpha:设置透明度,只能是0~1的数字,如果透明度不一样,在画第二幅之前重新设置即可。

toDataURL:icanvas.toDataURL(type,encoderOptions),这个函数返回一个image的base64的URI,参数都是可选的,type可以设置图片类型如image/jpeg,image/webp,默认是image/png;encoderOptions是一个0~1的数字,用来设置image/jpeg,image/webp的图片质量,其他格式的type设置这个参数无效。

 10.剪裁

clip():从画布中剪裁任意形状和尺寸的画布,之后所有的绘图都会被限制在剪裁的区域内。这个方法通常和绘制矩形,圆形等路径一起使用,在这些方法后面,剪切这个图像,后来画的就必须在这个剪切后的画布上了。

ictx.arc(100,100,50,(Math.PI/180)*0,(Math.PI/180)*360,true);

ictx.stroke();

ictx.clip();

ictx.fillStyle="green";

ictx.fillRect(0,0,150,100);

详解html5 canvas常用api总结(二)--绘图API

如果还想操作外部的画布,在剪切前使用save()函数保存,剪切后使用restore()函数恢复到之前保存的状态,但是中间做的操作不会消失哈。

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

HTML / CSS 相关文章推荐
css3动画事件—webkitAnimationEnd与计时器time事件
Jan 31 HTML / CSS
CSS3图片旋转特效(360/60/-360度)
Oct 10 HTML / CSS
css3发光搜索表单分享
Apr 11 HTML / CSS
使用CSS3的::selection改变选中文本颜色的方法
Sep 29 HTML / CSS
html5使用canvas绘制一张图片
Dec 15 HTML / CSS
HTML5中原生的右键菜单创建方法
Jun 28 HTML / CSS
浅谈HTML5 & CSS3的新交互特性
Jul 19 HTML / CSS
HTML5制作表格样式
Nov 15 HTML / CSS
HTML5+WebSocket实现多文件同时上传的实例
Dec 29 HTML / CSS
基于canvas使用贝塞尔曲线平滑拟合折线段的方法
Jan 10 HTML / CSS
HTML5拖拽功能实现的拼图游戏
Jul 31 HTML / CSS
利用Node实现HTML5离线存储的方法
Oct 16 HTML / CSS
HTML5 Canvas玩转酷炫大波浪进度图效果实例(附demo)
Dec 14 #HTML / CSS
详解使用HTML5 Canvas创建动态粒子网格动画
Dec 14 #HTML / CSS
H5新属性audio音频和video视频的控制详解(推荐)
Dec 09 #HTML / CSS
Html5 Geolocation获取地理位置信息实例
Dec 09 #HTML / CSS
详解移动端html5页面长按实现高亮全选文本内容的兼容解决方案
Dec 03 #HTML / CSS
HTML5标签大全
Nov 23 #HTML / CSS
HTML5拖放效果的实现代码
Nov 17 #HTML / CSS
You might like
PHP 中文乱码解决办法总结分析
2009/07/30 PHP
关于PHP中Object对象的笔记分享
2011/06/28 PHP
PHP json格式和js json格式 js跨域调用实现代码
2012/09/08 PHP
PHP数组与对象之间使用递归实现转换的方法
2015/06/24 PHP
django中的ajax组件教程详解
2018/10/18 PHP
PHP实现读取文件夹及批量重命名文件操作示例
2019/04/15 PHP
PHP7 list() 函数修改
2021/03/09 PHP
将string解析为json的几种方式小结
2010/11/11 Javascript
用jquery模仿的a的title属性(兼容ie6/7)
2013/01/21 Javascript
可在线编辑网页文字效果代码(单击)
2013/03/02 Javascript
如何防止回车(enter)键提交表单
2014/05/11 Javascript
Node.js中的流(Stream)介绍
2015/03/30 Javascript
angular.bind使用心得
2015/10/26 Javascript
javascript简单比较日期大小的方法
2016/01/05 Javascript
JS中call/apply、arguments、undefined/null方法详解
2016/02/15 Javascript
jQuery如何跳转到另一个网页 就这么简单
2016/12/28 Javascript
详解react-native WebView 返回处理(非回调方法可解决)
2018/02/27 Javascript
javascript function(函数类型)使用与注意事项小结
2019/06/10 Javascript
[01:07:19]DOTA2-DPC中国联赛 正赛 CDEC vs XG BO3 第一场 1月19日
2021/03/11 DOTA
在python中安装basemap的教程
2018/09/20 Python
Python大数据之网络爬虫的post请求、get请求区别实例分析
2019/11/16 Python
解析Python 偏函数用法全方位实现
2020/06/26 Python
详解H5本地储存Web Storage
2017/07/03 HTML / CSS
Square Off美国/加拿大:世界上最聪明的国际象棋棋盘
2018/12/06 全球购物
如何配置、使用和清除Smarty缓存
2015/12/23 面试题
幼儿教师考核制度
2014/01/25 职场文书
优秀医生事迹材料
2014/02/12 职场文书
物控部经理职务说明书
2014/02/25 职场文书
环保建议书600字
2014/05/14 职场文书
优秀的应届生自荐信
2014/05/23 职场文书
给老婆的检讨书1000字
2015/01/01 职场文书
十岁生日答谢词
2015/01/05 职场文书
运动会开幕式致辞
2015/07/29 职场文书
Redis遍历所有key的两个命令(KEYS 和 SCAN)
2021/04/12 Redis
MySQL中出现乱码问题的终极解决宝典
2021/05/26 MySQL
Navicat Premium自定义 sql 标签的创建方式
2022/09/23 数据库