HTML5 Canvas一些常用的操作
粗略的Canvas API
1、 context
- var context = canvas.getContext('2d');
2、Canvas state
- context.save();//将当前状态压入状态栈中,保存当前的状态
- context.restore();//将状态栈中的栈顶元素出栈,恢复上次的状态
3、Line styles
- context.lineWidth[= value] ;//线宽
- context.lineCap[= value]; //线的开始和结束部分的形状(butt:没有,round:圆,square:方)
- context.lineJoin[= value]; // 线相交部分的形状(bevel:尖角,round:圆角,miter:按照一个既定值来设置)
- context.miterLimit[= value]; //设置context.lineJoin为miter时的既定值。
- context.setLineDash()
- context.getLineDash()
- context.lineDashOffset
4、Text styles
- context.font [= value];//字体,和CSS写法一致
- context.textAlign [= value];// 水平对齐(start,end,left,right,middle)
- context.textBaseLine [=value];//设置竖直方向的基准线 (取值:top,hanging,middle,alphabetic,ideographic,bottom)
5、Building Path
- context.moveTo(x,y);
- context.closePath();
- context.lineTo(x,y);
- context.quadraticCurveTo(cpx,cpy,x,y);//2次贝塞尔曲线
- context.bezierCurveTo(cp1x,cp1y,cp2x,cp2y,x,y);//3次贝塞尔曲线
- context.arcTo(x1,y1,x2,y2,radius);//画一段圆弧
- context.arc(x,y,radius,startAngle,endAngle);//画一段圆弧
- context.rect(x,y,w,h);//画一个矩形
6、Transformations
- context.scale(x,y);//缩放
- context.rotate(angle);//旋转
- context.translate(x,y);//平移
- context.transform(a,b,c,d,e,f);
- context.setTransform(a,b,c,d,e,f);
7、Fill and stroke styles
- context.fillStyle [= value];//填充
- context.strokeStyle [= value];//描边
- 填充和描边的值可以为:CSS color,CancasGradient(canvas的渐变效果),CanvasPattern
- var gradient = context.createLinearGradient(x0,y0,x1,y1);//线性渐变
- var gradient = context.createRadialGradient(x0,y0,r0,x1,y1,r1);//放射性渐变
- gradient.addColorStop(offset,color);//设置每个阶段的过渡颜色(offset为0.0~1.0之间)
- var pattern =context.createPattern(image,repetition);//设置背景图以及重复效果,image的值可以为HTMLImageElement,HTMLCanvasElement,HTMLVideoElement。repetition的值为:repeat,repeat-x,repeat-y,no-repeat
8、Drawing rectangles to the canvas
- context.clearRect(x,y,w,h);//清楚某个矩形区域内的所有图形
- context.fillRect(x,y,w,h);//填充某个矩形区域
- context.strokeRect(x,y,w,h);//对某个矩形区域进行描边
9、Drawing text to the canvas
- context.fillText(text,x,y,[,maxWidth]);//填充文字,参数依次为:要填写的值,起始x坐标,起始y坐标,最大宽度(可选))
- context.strokeText(text,x,y,[,maxWidth]);//对字体进行描边
- var metrics = context.measureText(text);
- metrics.width;
10、Drawing paths to the canvas
- context.beginPath();
- context.fill();
- context.stroke();
- context.drawFocusIfNeed(element);
- context.clip();
- context.isPoingInPath(x,y);
11、Dawing images to the canvas
- context.drawImage(image,dx,dy);
- context.drawImage(image,dx,dy,dw,dh);
- context.drawImage(image,sx,sy,sw,sh,dx,dy,dw,dh);//其中s开头的属性表示为图像源的属性,d开头的属性表示在canvas上的属性。
- image 的值为 HTMLImageElement,HTMLCanvasElement,HTMLVideoElement
参考资料:http://www.w3.org/TR/2dcontext/
HTML5 Canvas一些常用的操作的更多相关文章
- [js高手之路] html5 canvas系列教程 - 图片操作(drawImage,clip,createPattern)
接着上文[js高手之路] html5 canvas系列教程 - 文本样式(strokeText,fillText,measureText,textAlign,textBaseline)继续,本文介绍的 ...
- [js高手之路] html5 canvas系列教程 - 像素操作(反色,黑白,亮度,复古,蒙版,透明)
接着上文[js高手之路] html5 canvas系列教程 - 状态详解(save与restore),相信大家都应该玩过美颜功能,而我们今天要讲的就是canvas强大的像素处理能力,通过像素处理,实现 ...
- HTML5 Canvas ( 图形的像素操作 ) getImageData, putImageData, ImgData.data
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- 开源HTML5 Canvas游戏Runtime发布
Cantk-Runtime是通用的HTML5 Canvas 2D游戏引擎运行库,让HTML5游戏的性能飞起来.Cantk-Runtime以PhoneGap插件的方式提供,从此结束PhoneGap低性能 ...
- [js高手之路] html5 canvas动画教程 - 实时获取鼠标的当前坐标
有了前面的canvas基础之后,现在开始就精彩了,后面写的canvas教程都是属于综合应用,前面已经写了常用的canvas基础知识,参考链接如下: [js高手之路] html5 canvas系列教程 ...
- [js高手之路] html5 canvas系列教程 - 状态详解(save与restore)
本文内容与路径([js高手之路] html5 canvas系列教程 - 开始路径beginPath与关闭路径closePath详解)是canvas中比较重要的概念.掌握理解他们是做出复杂canvas动 ...
- [js高手之路] html5 canvas系列教程 - 线形渐变,径向渐变与阴影设置
接着上文[js高手之路] html5 canvas系列教程 - 像素操作(反色,黑白,亮度,复古,蒙版,透明)继续. 一.线形渐变 线形渐变指的是一条直线上发生的渐变. 用法: var linear ...
- html5 canvas常用api总结(一)
1.监听浏览器加载事件. window.addEventListener("load",eventWindowLoaded,false); load事件在html页面加载结束时发生 ...
- html5 canvas画图之图形随拖动而复制(有操作指示)
学习html5 canvas,写了一个小练习来加深理解,可以实现图形随拖动而复制. <!DOCTYPE html> <html> <head> <meta c ...
随机推荐
- Swift语言之类型方法
Swift语言有很多特性,其中之一就是类型方法,相对于其他比较流行的编程语言(C#.Java),在Swift中类型方法最大的特征在于它的可继承性,我们举个例子说明: 俗话说,龙生龙凤生凤老鼠生儿会打洞 ...
- ARM——操作系统—最小操作系统-开发板测试
怀着激动的心情,打算弄到硬件上试试. 折腾了一整天.终于运行起来了. 需要设置IBRD和CR,以及寄存器. 希望大家也能顺利完成自己的开发板实验. 我畅想了一下,目前所有带串口的嵌入式ARM设备,都应 ...
- ADB简单基础命令
1.查看设备 adb devices 这个命令是查看当前连接的设备, 连接到计算机的android设备或者模拟器将会列出显示 2.安装软件 adb install adb install :这个命令将 ...
- loadrunner总体使用篇
为什么要进行性能测试呢? 有些问题是只有在大并发或者压力测试下才会暴露出来的,在平常的公司内部测试中,感觉一切都是正常的,但是把服务放到生产线上,例如某个时刻突然有很多的用户要向我们的服务发送请求, ...
- JavaScript confirm 自定义风格及功能实现
在网上找了一些弹窗插件,例如bootbox, 功能和动画效果都做的很好,但是很难自定义样式. 项目需要,Google相关方法后写了一个Demo, 没有JavaScript confirm切断线程的功能 ...
- centos7 卸载openJDK 安装jdk7
[root@cms02 root]# rpm -qa | grep jdk java--openjdk-headless-1.7.0.75-2.5.4.2.el7_0.x86_64 java--ope ...
- 【GO】GO语言学习笔记三
7.数组: 几乎是最常用的数据类型了... 数组就是指一系列同一类型数据 的集合.数组中包含的每个数据被称为数组元素(element),一个数组包含的元素个数被称为数 组的长度. 常规的数组声明方法: ...
- JDBC的简单使用
JDBC的英文全称是: java Data Base Connectivity JDBC的主要作用: (是java数据库连接技术的简称)JDBC是由一系列连接(Conneation).SQL语句( ...
- bzoj 1079 着色方案
题目: 有n个木块排成一行,从左到右依次编号为1~n.你有k种颜色的油漆,其 中第i 种颜色的油漆足够涂ci 个木块.所有油漆刚好足够涂满所有木块,即c1+c2+-+ck=n.相邻两个木块涂相同色显得 ...
- Selenium 面试题总结(乙醇Blog记录的面试题)
###selenium中如何判断元素是否存在? - isElementPresent ###selenium中hidden或者是display = none的元素是否可以定位到? - 不能 # ...