粗略的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一些常用的操作的更多相关文章

  1. [js高手之路] html5 canvas系列教程 - 图片操作(drawImage,clip,createPattern)

    接着上文[js高手之路] html5 canvas系列教程 - 文本样式(strokeText,fillText,measureText,textAlign,textBaseline)继续,本文介绍的 ...

  2. [js高手之路] html5 canvas系列教程 - 像素操作(反色,黑白,亮度,复古,蒙版,透明)

    接着上文[js高手之路] html5 canvas系列教程 - 状态详解(save与restore),相信大家都应该玩过美颜功能,而我们今天要讲的就是canvas强大的像素处理能力,通过像素处理,实现 ...

  3. HTML5 Canvas ( 图形的像素操作 ) getImageData, putImageData, ImgData.data

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  4. 开源HTML5 Canvas游戏Runtime发布

    Cantk-Runtime是通用的HTML5 Canvas 2D游戏引擎运行库,让HTML5游戏的性能飞起来.Cantk-Runtime以PhoneGap插件的方式提供,从此结束PhoneGap低性能 ...

  5. [js高手之路] html5 canvas动画教程 - 实时获取鼠标的当前坐标

    有了前面的canvas基础之后,现在开始就精彩了,后面写的canvas教程都是属于综合应用,前面已经写了常用的canvas基础知识,参考链接如下: [js高手之路] html5 canvas系列教程 ...

  6. [js高手之路] html5 canvas系列教程 - 状态详解(save与restore)

    本文内容与路径([js高手之路] html5 canvas系列教程 - 开始路径beginPath与关闭路径closePath详解)是canvas中比较重要的概念.掌握理解他们是做出复杂canvas动 ...

  7. [js高手之路] html5 canvas系列教程 - 线形渐变,径向渐变与阴影设置

    接着上文[js高手之路] html5 canvas系列教程 - 像素操作(反色,黑白,亮度,复古,蒙版,透明)继续. 一.线形渐变 线形渐变指的是一条直线上发生的渐变. 用法: var linear ...

  8. html5 canvas常用api总结(一)

    1.监听浏览器加载事件. window.addEventListener("load",eventWindowLoaded,false); load事件在html页面加载结束时发生 ...

  9. html5 canvas画图之图形随拖动而复制(有操作指示)

    学习html5 canvas,写了一个小练习来加深理解,可以实现图形随拖动而复制. <!DOCTYPE html> <html> <head> <meta c ...

随机推荐

  1. 自定义cell侧滑删除

    - (BOOL)tableView:(UITableView *)tableView canEditRowAtIndexPath:(NSIndexPath *)indexPath { return Y ...

  2. JavaScript中数组操作常用方法

    JavaScript中数组操作常用方法 1.检测数组 1)检测对象是否为数组,使用instanceof 操作符 if(value instanceof Array) { //对数组执行某些操作 } 2 ...

  3. Oracle EBS APIs

    参考链接: http://blog.csdn.net/pan_tian/article/details/7754598 http://blog.itpub.net/26687597/viewspace ...

  4. 当display=none时,元素和子元素高度为0的解决办法

    在前端中为了某种需要,我们需要获取display=none的元素或者子元素的实际高度来进行某些处理,然而html对display=none的元素和子元素是不进行渲染的,如果我们没有规定这些元素的高度那 ...

  5. python实现汉诺塔

    经典递归算法汉诺塔分析: 当A柱子只有1个盘子,直接A --> C 当A柱子上有3个盘子,A上第一个盘子 --> B, A上最后一个盘子 --> C, B上所有盘子(1个) --&g ...

  6. 《写给大忙人看的java se 8》笔记

    现在才来了解java8,是不是后知后觉了点? 新的编程技术,个人不喜欢第一时间跟进. 待社区已有实践积淀再切入似乎更划算些? 一点点精明的考虑. 不多说,上代码. //读<写给大忙人看的java ...

  7. 用shell脚本监控进程是否存在 不存在则启动的实例

    用shell脚本监控进程是否存在 不存在则启动的实例,先上代码干货: #!/bin/shps -fe|grep processString |grep -v grepif [ $? -ne 0 ]th ...

  8. tomcat输出servlet-api.jar - jar not loaded 解决办法

    tomcat输出servlet-api.jar - jar not loaded 解决办法 启动tomcat后,控制台输出信息:WEB-INF/lib/servlet-api.jar not load ...

  9. [已解决] git 重命名文件夹

    git mv oldfolder newfolder 原文地址:http://www.cnblogs.com/gifisan/p/5980608.html

  10. ubuntu14.04设置静态ip

    1. 找到文件并作如下修改: sudo vim /etc/network/interfaces 修改如下部分: auto eth0 iface eth0 inet static address 192 ...