zoukankan      html  css  js  c++  java
  • canvas API笔记

    HTML5添加的最受欢迎的功能就是<canvas>元素,这个元素负责在页面的指定区域通过js动态地在这个区域绘制图形。

    <canvas> 由几组API构成。

    准备:

    <canvas id="drawing" width="200" height="200">A drawing of something.</canvas>

    要用canvas元素,必须设置width,height属性。

    如果浏览器不支持canvas,就会显示标签中的内容

    初始化:

    var drawing=document.getElementById("drawing");
    
    //确定浏览器支持<canvas>元素    
    
    if(drawing.getContext){
    
      var ctx = drawing.getContext('2d');
    
           ...
    
    }

    2D上下文,坐标开始于<canvas>元素左上角,原点坐标是(0,0)。

    上下文中设置的各种属性,都会在当前上下文中一直有效,除非再对上下文进行更改,有两个方法可以跟踪上下文的状态变化:

    ctx.save();//所有设置都会进入一个栈结构
    ctx.restore();//回到之前保存的栈结构
    //连续调用save()可以把多个设置保存到栈结构
    //之后连续调用restore()则可以一级一级返回

    1、填充和描边,这两个属性的值可以是字符串、渐变对象、模式对象,默认值是‘#000000’

    ctx.fillStyle="rgba(0,0,255,0.5)";//填充
    
    ctx.strokeStyle="#0000FF";//描边

    2、绘制矩形(矩形是唯一一种可以直接在2D上下文中绘制的形状)

    ctx.fillRect(x,y,width,height);//填充矩形
    
    ctx.strokeRect(x,y,width,height);//绘制矩形边框
    
    ctx.clearRect(x,y,width,height);//清除画布上的矩形区域

    三个方法都接收四个参数:x坐标、y坐标、宽度、高度

    3、绘制路径

    首先必须调用beginPath(),表示要开始绘制新的路径

    ctx.beginPath();//开始绘制新的路径
    //以(x,y)为圆心,radius为半径绘制一条弧线,起始和结束角度(弧度)分别为startAngle,endAngle
    //centerclockwise表示起始和结束角度是否按逆时针方向计算,false表示按顺时针方向计算
    ctx.arc(x,y,radius,startAngle,endAngle,centerclockwise);
    ctx.artTo(x1,y1,x2,y2,radius);//从上一点开始绘制一条弧线
    ctx.moveTo(x,y);//将绘图游标移动到(x,y),不画线
    ctx.lineTo(x,y);//绘制一条直线
    ctx.rect(x,y,width,height);//从(x,y)绘制一个矩形
    ctx.bezierCurveTo(c1x,c1y,c2x,c2y,x,y);//从上点绘制一条曲线,到(x,y)为止,并且以(c1x,c1y),(c2x,c2y)为控制点
    ctx.quadraticCurveTo(cx,cy,x,y);//从上点绘制一条二次曲线,到(x,y)为止,并且以(cx,cy)为控制点
    ctx.stroke();//描边路径
    ctx.closePath();//绘制一条连接到路径起点的线条
    ctx.fill();//填充路径
    ctx.clip();//在路径上创建一个剪切区域

    4、绘制文本

    ctx.font="bold 14px Arial";//表示文本样式、大小、字体
    ctx.textAlign="center";//对齐方式
    ctx.textBaseline="middle";//文本基线
    //接收4个参数:要绘制的文本,x,y坐标,最大像素宽度(可选)
    ctx.fillText("测试",x,y);//使用fillStyle属性绘制文本
    ctx.strokeText("测试",x,y);//使用strokeStyle为文本描边

    5、变换(位移缩放旋转

    创建绘图上下文时,会以默认值初始化变换矩阵

    ctx.rotate(angle);//旋转,围绕原点旋转图像angle弧度
    ctx.scale(scaleX,scaleY);//缩放,x方向乘以scaleX,y方向乘以scaleY
    ctx.translate(x,y);//位移,将坐标原点移动到(x,y)
    //dx,dy控制位移,m1_1,m2_2控制缩放,前四个参数控制旋转
    ctx.setTransform(1,0,0,1,0,0);//重置变换矩阵
    ctx.transform(m1_1,m1_2,m2_1,m2_2,dx,dy);//修改变换矩阵
    //直接修改变换矩阵方式:乘以如下矩阵:
    //m1_1 m1_2 dx
    //m2_1 m2_2 dy
    // 0   0    1

    位移和缩放

    对于坐标轴上的任意一点 A(x,y)移动到B(x1,y1),则B点的坐标值可以用如下的等式表示:

    x1 = x + dx

    y1 = y + dy

    同理,对于坐标轴上的任意一点 A(x,y)缩放到B(x1,y1),则B点的坐标值可以用如下的等式表示:

    x= x * m1_1

    y1 = y * m2_2

    其中m1_1、m2_2对应transform中的第一和第四个参数,位移的时候dx和dy代表具体的数值,而缩放的时候m1_1、m2_2则代表了对应x或者h轴上的缩放倍数,所以默认的倍数当然是1(也就是原来的大小),默认的位移当然是0,所以我们现在知道transform(m1_1,m1_2,m2_1,m2_2,dx,dy)的参数中m1_1,m2_2为1,dx,dy为0。

    接下来看比较复杂的旋转,如图:

    以点(0,0)为中心,将点A(100,-100)旋转45°后求点B的坐标轴是多少?(Canvas中y轴向下才是正数)。

    x = x * cos(弧度)  -  y * sin(弧度);

    y = y * cos(弧度)  +  x * sin(弧度); 

    弧度 = Math.PI * 180 / 角度

    -------------------------------------------------------------

    最终的公式

    x= m1_1*x +m2_1*y + dx

    y1 = m1_2*x + m2_2*y + dy

    调用:

    ctx.transform(cos(弧度),sin(弧度),-sin(弧度),cos(弧度),0,0);

    6、绘制图像

    var image=document.images[0];
    ctx.drawImage(image,x,y);//image:图片,x,y:绘制该图像的起点坐标
    ctx.drawImage(image,x,y,width,height);//width目标宽度,height:目标高度
    //把图像的某个区域绘制到上下文中
    //x,y:源图像坐标,width,height:源图像宽高度
    //x1,y1:目标图像坐标,width1,height1:目标图像宽高度
    ctx.drawImage(image,x,y,width,height,x1,y1,width1,height1);
    ctx.toDataURL();//获取操作结果

    7、阴影

    ctx.shadowBlur =0;//模糊的像素数,默认0,不模糊
    ctx.shadowOffsetX =0;//形状或路径x轴方向上的偏移量。默认0
    ctx.shadowOffsetY =0;//形状或路径y轴方向上的偏移量。默认0
    ctx.shadowColor ="#000000";//阴影颜色,默认黑色

    8、使用图像数据

    2D上下文可以通过getImageData()取得原始图像数据

    var imageData=ctx.getImageData(x,y,width,height);//获取原始图像数据
    //imageData对象有三个属性:width,height,data。
    //data是数组,保存着图像中每一个像素的数据
    //每个像素用4个元素保存:分别表示红绿蓝和透明度
    ctx.putImageData(imageData,x,y);//回写图像数据
  • 相关阅读:
    初心
    [CSP-S2019]:赛后总结
    最帅的快读
    检讨书模板
    $Linux$系统$GEDIT$编译运行$C++$和各种乱搞
    [CSP-S模拟测试]:C(倍增+数学)
    [CSP-S模拟测试]:B(期望DP)
    [CSP-S模拟测试]:A(单调栈维护凸包+二分答案)
    [NOIP2018]:旅行(数据加强版)(基环树+搜索+乱搞)
    [JZOJ6347]:ZYB玩字符串(DP+记忆化搜索)
  • 原文地址:https://www.cnblogs.com/anyun/p/9790120.html
Copyright © 2011-2022 走看看