canvas学习笔记一

简介:

为了研究pixi库,就顺带从头到位学习下canvas吧

判断支持力度

复制代码
var webgl = (function() {
    try {
        var canvas = document.createElement('canvas');
        return !!window.WebGLRenderingContext && (canvas.getContext('webgl') || canvas.getContext('experimental-webgl'));
    } catch (e) {
        return false;
    }
})();
复制代码

getContext方法指定参数2d,表示该canvas对象用于生成2D图案(即平面图案)。如果参数是3d,就表示用于生成3D图像(即立体图案),这部分实际上单独叫做WebGL API

 

绘制路径

  • beginPath方法表示开始绘制路径
  • moveTo(x, y)方法设置线段的起点
  • lineTo(x, y)方法设置线段的终点
  • stroke方法用来给透明的线段着色
复制代码
    //////////
    //绘制路径 //
    //////////
    context.beginPath()
    context.moveTo(20, 20)
    context.lineTo(30, 30)
    context.moveTo(100, 150)
    context.lineTo(150, 200)
    context.lineWidth = 2
    context.strokeStyle = "red"
    context.stroke()
复制代码

 

绘制矩形

  • fillRect(x, y, width, height)方法用来绘制矩形,它的四个参数分别为矩形左上角顶点的x坐标、y坐标,以及矩形的宽和高。fillStyle属性用来设置矩形的填充色
  • strokeRect方法与fillRect类似,用来绘制空心矩形
  • clearRect方法用来清除某个矩形区域的内容
复制代码
    //////////
    //绘制路径 //
    //////////
    context.beginPath()
    context.moveTo(20, 20)
    context.lineTo(30, 30)
    context.moveTo(100, 150)
    context.lineTo(150, 200)
    context.lineWidth = 2
    context.strokeStyle = "red"
    context.stroke()
复制代码

 

绘制文本

  • fillText(string, x, y) 用来绘制文本,它的三个参数分别为文本内容、起点的x坐标、y坐标。使用之前,需用font设置字体、大小、样式(写法类似与CSS的font属性)。与此类似的还有strokeText方法,用来添加空心字
  • fillText方法不支持文本断行,即所有文本出现在一行内。所以,如果要生成多行文本,只有调用多次fillText方法。
复制代码
    //////////
    //绘制路径 //
    //////////
    context.beginPath()
    context.moveTo(20, 20)
    context.lineTo(30, 30)
    context.moveTo(100, 150)
    context.lineTo(150, 200)
    context.lineWidth = 2
    context.strokeStyle = "red"
    context.stroke()
复制代码

 

绘制圆形和扇形

arc方法用来绘制扇形

ctx.arc(x, y, radius, startAngle, endAngle, anticlockwise);

arc方法

  • x和y参数是圆心坐标
  • radius是半径
  • startAngle和endAngle则是扇形的起始角度和终止角度(以弧度表示)
  • anticlockwise表示做图时应该逆时针画(true)还是顺时针画(false)
复制代码
    //////////
    //绘制路径 //
    //////////
    context.beginPath()
    context.moveTo(20, 20)
    context.lineTo(30, 30)
    context.moveTo(100, 150)
    context.lineTo(150, 200)
    context.lineWidth = 2
    context.strokeStyle = "red"
    context.stroke()
复制代码

 

设置渐变色

createLinearGradient方法用来设置渐变色。

createLinearGradient方法的参数是(x1, y1, x2, y2),其中x1和y1是起点坐标,x2和y2是终点坐标。通过不同的坐标值,可以生成从上至下、从左到右的渐变等等。

复制代码
    /////////
    //渐变色 //
    /////////
    var myGradient = context.createLinearGradient(0, 0, 0, 60); 
    myGradient.addColorStop(0, "#BABABA");
    myGradient.addColorStop(1, "#636363");
    context.fillStyle = myGradient;
    context.fillRect(10,250,200,100);
复制代码

 

设置阴影

复制代码
/////////
    //渐变色 //
    /////////
    var myGradient = context.createLinearGradient(0, 0, 0, 60); 
    myGradient.addColorStop(0, "#BABABA");
    myGradient.addColorStop(1, "#636363");
    context.fillStyle = myGradient;
    context.fillRect(10,250,200,100);
复制代码

 


 


本文转自艾伦 Aaron博客园博客,原文链接:http://www.cnblogs.com/aaronjs/p/4268122.html,如需转载请自行联系原作者

相关文章
|
移动开发 前端开发 JavaScript
让自己也能使用Canvas
<canvas> 是 HTML5 新增的元素,可使用JavaScript脚本来绘制图形。例如:画图,合成照片,创建动画甚至实时视频处理与渲染。
让自己也能使用Canvas
|
4月前
|
移动开发 前端开发 JavaScript
canvas详解00-认识canvas
canvas详解00-认识canvas
35 1
canvas详解00-认识canvas
|
移动开发 前端开发 JavaScript
Canvas2D基础
1. canvas内容就是上面这些了,就好比设计师能用的颜色就那么多,但是将颜色,图形组合起来,创意真的是无限的,canvas也是如此。 2. webGL是一个 对OpenGL ES 2.0浏览器实现接口,用于3D绘画,生产阶段最好不要用,可用于实验阶段。
209 0
|
12月前
|
存储 XML 前端开发
神奇的 Canvas
canvas是为了解决页面只能显示静态图片而出现的一种可以使用JavaScript绘制的HTML标签,它可以接受两个参数width和height(原来有三个,还有一个moz-opaque控制透明度,已经废弃了)
80 0
|
前端开发
Canvas入门(二)
Canvas入门(二)
139 0
|
前端开发
Canvas入门(四)
Canvas入门(四)
105 0
|
前端开发
Canvas入门(一)
Canvas入门(一)
217 0
|
前端开发 JavaScript
Canvas入门(三)
Canvas入门(三)
110 0
|
移动开发 前端开发 小程序
Canvas 2D详解
Canvas 2D详解
Canvas 2D详解
|
移动开发 前端开发 JavaScript
canvas从入门到猪头
canvas从入门到猪头
canvas从入门到猪头

热门文章

最新文章